Metadata-Version: 2.4
Name: tgrad
Version: 0.1.1
Summary: Telegram daemon with CLI and Unix socket
Author-email: Tareq Mahmood <check@my.website>
License: MIT
Requires-Python: >=3.7
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: python-telegram-bot>=20.0
Dynamic: license-file

# tgrad 

![Release](https://github.com/tareqmahmood/tgrad/actions/workflows/release.yml/badge.svg) [![PyPI - Version](https://img.shields.io/pypi/v/tgrad)](https://pypi.org/project/tgrad/)


`tgrad` is a lightweight Python-based Telegram daemon. It lets other programs send messages to a Telegram bot using a local Unix domain socket. Includes a CLI and a Python API.

> [!NOTE]  
> This is mostly for personal use and with the intention to extend as personal needs evolve. Works for me. Hope it helps you too.


## ✨ Features

- 🧵 Runs as a background daemon
- 🧾 Message delivery to Telegram via local socket
- ⚙️ Easy CLI tools to configure, run, and send messages
- 🐍 Python API (`tgrad.send()`) for direct integration


## 📦 Installation

```bash
pip install tgrad
```

From latest in Github
```bash
git clone https://github.com/tareqmahmood/tgrad.git
cd tgrad
pip install .
```

## 🔐 Bot Setup

Before using `tgrad`, you need to create a Telegram bot and get the **bot token** and **chat ID**.

### Step 1: Create a Telegram Bot

1. Open Telegram and search for [`@BotFather`](https://t.me/BotFather).

2. Start the chat and send:

   ```
   /newbot
   ```

3. Follow the prompts:

   * Set a display name (e.g., `MyNotifierBot`)
   * Choose a unique username ending in `bot` (e.g., `my_notifier_bot`)

4. BotFather will respond with a message containing your bot token:

   ```
   Use this token to access the HTTP API:
   123456789:ABCdefGhIJKlmNoPQRstUvWXyZ12345678
   ```

   🔑 Save this as your **BOT\_TOKEN**.

---

### Step 2: Get Your Chat ID

1. Start a chat with your bot (click the link BotFather gives you).

2. Send a message like `hello` or `/start`.

3. Open this in your browser:

   ```
   https://api.telegram.org/bot<YOUR_BOT_TOKEN>/getUpdates
   ```

   Example:

   ```
   https://api.telegram.org/bot123456789:ABCdefGhIJKlmNoPQRstUvWXyZ12345678/getUpdates
   ```

4. Look for a JSON field like this in the response:

   ```json
   "chat": {
     "id": 987654321,
     "first_name": "Your Name",
     ...
   }
   ```

   📩 Use the `id` value as your **CHAT\_ID**.

> For groups: Add the bot to the group, send a message, and check `getUpdates` again. The `chat.id` will be a negative number like `-1001234567890`.


Once you have your `BOT_TOKEN` and `CHAT_ID`, configure `tgrad`:


```bash
tgrad-config -t <BOT_TOKEN> -c <CHAT_ID> [-s ~/.tgrad/tgrad.sock]
```

This saves your bot token, chat ID, and socket path to `~/.tgrad/config.json`.


## 🚀 Usage

### Start the Daemon Server

```bash
tgrad-server
```

It will listen for messages on the configured Unix socket.

### Send a Message via CLI

```bash
tgrad-client -t "Title" -m "Hello from CLI"
```

### Send a Message from Python

```python
import tgrad
tgrad.send("Alert", "Something happened!")
```

## 🧪 Testing

To test locally:

1. Run the server:

   ```bash
   tgrad-server
   ```

2. In another terminal:

   ```bash
   tgrad-client -t "Test" -m "This is a test message"
   ```

You should receive the message via your Telegram bot.


## 📄 License

MIT License.
