Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/teknologi-umum/gitgram
Github notifications for Telegram
https://github.com/teknologi-umum/gitgram
bot telegram telegram-bot webhook
Last synced: 3 months ago
JSON representation
Github notifications for Telegram
- Host: GitHub
- URL: https://github.com/teknologi-umum/gitgram
- Owner: teknologi-umum
- License: gpl-3.0
- Created: 2021-12-20T06:32:51.000Z (about 3 years ago)
- Default Branch: master
- Last Pushed: 2024-06-21T16:28:47.000Z (7 months ago)
- Last Synced: 2024-08-01T21:40:12.482Z (6 months ago)
- Topics: bot, telegram, telegram-bot, webhook
- Language: TypeScript
- Homepage:
- Size: 967 KB
- Stars: 1
- Watchers: 2
- Forks: 3
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-made-by-indonesian - Gitgram - `Github notifications for Telegram` *by [Teknologi Umum](https://github.com/teknologi-umum)* (G)
- made-in-indonesia - Gitgram - `Github notifications for Telegram` *by [Teknologi Umum](https://github.com/teknologi-umum)* (G)
README
![logo.png](./logo.png)
# Gitgram
GitHub notifications for Telegram
## Backstory
Gitgram was created because our team at that time was working on a big project, and we use Telegram to discuss the
project. We needed something to receive Github webhook notifications and send them to the Telegram group to ease our
communication without having to check directly on Github. Therefore, a bot was created.## Features
It sends every notification to the group within these events:
- deployment status
- issue
- issue comment
- ping
- pull request
- pull request reviews
- release
- vulnerability alerts## Usage
### From official Docker image
The easiest setup would be pulling from the official Docker image.
```sh
docker run \
-e WEBHOOK_SECRET="your-webhook-secret" \
-e BOT_TOKEN="your-bot-token" \
-e HOME_GROUP="your-home-group" \
-e IGNORE_PRIVATE_REPOSITORY=false \
-p 3000:3000 \
ghcr.io/teknologi-umum/gitgram:edge
```Another example of running Gitgram through Docker Compose is available on our
[infrastructure repository](https://github.com/teknologi-umum/infrastructure/blob/master/gitgram/docker-compose.yml).### From Docker
If you don't trust the official Docker image, you can always build the image yourself.
```sh
git clone https://github.com/teknologi-umum/gitgram.git
cd gitgram
docker build -t gitgram:latest .
docker run -d -p 3000:3000 --name gitgram gitgram:latest
```Don't forget to supply your own environment variables.
### From source
First you will need to clone this repo
```sh
git clone https://github.com/teknologi-umum/gitgram.git
```and then install all of its dependencies
```bash
pnpm install
```To make the bot work properly, you will need these environment variables.
- `NODE_ENV`
Used for NodeJS to determine whether the bot is running in production or development.
- `PORT`
Which port to run the HTTP server.
- `WEBHOOK_SECRET`
Your webhook secret. You should see it when you create your Github webhook.
- `BOT_TOKEN`
Your telegram bot token.
- `DEV_PROXY_URL`
Webhook proxy URL used for easier development process.
- `HOME_GROUP` (Optional)
Default group if the repository was not found on the mapping.
- `IGNORE_PRIVATE_REPOSITORY` (Optional)
Set to anything other than empty to make it ignore every notification from private repository.Example:
```ini
NODE_ENV=development
PORT=3000
WEBHOOK_SECRET=123456789
BOT_TOKEN=xyzx:isyelacuapwodncnmzdcmajwo
DEV_PROXY_URL=web.com/duffUGHIUGsdsd
```If you don't know how to make a Telegram bot and get its token, you can refer
to [Telegram Bot Documentation](https://core.telegram.org/bots)If you don't know how to make a webhook for Github, you can visit
[GitHub Webhook Documentation](https://docs.github.com/en/developers/webhooks-and-events/webhooks/about-webhooks)Build the bot with `pnpm run build`
Then run the bot with `pnpm run start`
## License
```
Gitgram is a bot send Github notifications to Telegram.
Copyright (C) 2021-present Teknologi Umum Gitgram contributorsThis program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.You should have received a copy of the GNU General Public License
along with this program. If not, see .
```See [full license](./LICENSE).