Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lwesterhof/semaphore
A simple (rule-based) bot library for Signal Private Messenger.
https://github.com/lwesterhof/semaphore
bot messaging python signal
Last synced: about 15 hours ago
JSON representation
A simple (rule-based) bot library for Signal Private Messenger.
- Host: GitHub
- URL: https://github.com/lwesterhof/semaphore
- Owner: lwesterhof
- License: agpl-3.0
- Created: 2020-05-22T13:11:56.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2024-05-23T20:11:59.000Z (8 months ago)
- Last Synced: 2025-01-13T07:08:31.581Z (8 days ago)
- Topics: bot, messaging, python, signal
- Language: Python
- Homepage: https://lwesterhof.github.io/semaphore/
- Size: 6.51 MB
- Stars: 138
- Watchers: 10
- Forks: 27
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE.txt
Awesome Lists containing this project
README
# Semaphore
[![PyPI](https://img.shields.io/pypi/v/semaphore-bot)](https://pypi.org/project/semaphore-bot/)
[![GitHub Workflow Status](https://img.shields.io/github/actions/workflow/status/lwesterhof/semaphore/python.yml)](https://github.com/lwesterhof/semaphore/actions)
[![GitHub tag (latest SemVer)](https://img.shields.io/github/v/tag/lwesterhof/semaphore)](https://github.com/lwesterhof/semaphore/tags)
[![License](https://img.shields.io/github/license/lwesterhof/semaphore)](https://github.com/lwesterhof/semaphore/blob/main/LICENSE.txt)A simple (rule-based) bot library for [Signal](https://signal.org/) Private Messenger in Python.
Please note that this library is unofficial, unapproved and not nearly as secure as the real Signal clients.## Table of contents
* [Requirements](#requirements)
* [Installation](#installation)
* [Quick start](#quick-start)
* [Code example](#code-example)
* [Example bots](#example-bots)
* [Changelog](#changelog)
* [License](#license)## Requirements
- ![PyPI - Python Version](https://img.shields.io/pypi/pyversions/semaphore-bot)
- [signald](https://gitlab.com/signald/signald) [0.23.0](https://gitlab.com/signald/signald/-/tags) or later, a daemon that facilitates communication over [Signal](https://signal.org/)## Installation
1. Install signald or build from source
```bash
$ git clone https://gitlab.com/signald/signald.git
$ cd signald
$ make installDist
$ make setup
```2. Install Semaphore
Latest release from PyPi:
```bash
$ pip install semaphore-bot
```From source with pip:
```bash
$ pip install git+https://github.com/lwesterhof/semaphore.git
```From source:
```bash
$ git clone https://github.com/lwesterhof/semaphore.git
$ cd semaphore
$ make build
$ make install
```## Quick start
1. Start signald
```bash
$ cd signald
$ build/install/signald/bin/signald
```2. Open a new terminal and connect to signald control socket
```bash
$ nc -U $XDG_RUNTIME_DIR/signald/signald.sock
```
(or `/var/run/signald/signald.sock` for older versions of signald, [see signald docs](https://signald.org/articles/protocol/#socket-file-location))3. Register phone number with Signal by sending following message on the control socket (replace `+xxxxxxxxxxx` with bot Signal number). Sometimes Signal requires completion of a [captcha](https://signald.org/articles/captcha/) to register.
```json
{"type": "register", "version": "v1", "account": "+xxxxxxxxxxx"}
```4. Verify phone number with SMS verification code by sending following message on the control socket (replace `+xxxxxxxxxxx` with bot Signal number and `zzzzzz` with verification code)
```json
{"type": "verify", "version": "v1", "account": "+xxxxxxxxxxx", "code": "zzzzzz"}
```5. Verify Signal is working by sending following message on the control socket (replace `+xxxxxxxxxxx` with bot Signal number and `+yyyyyyyyyyy` with your Signal number)
```json
{"type": "send", "version": "v1", "username": "+xxxxxxxxxxx", "recipientAddress": {"number": "+yyyyyyyyyyy"}, "messageBody": "Hello world"}
```6. Open a new terminal and set the `SIGNAL_PHONE_NUMBER` environment variable to your phone number:
```bash
$ export SIGNAL_PHONE_NUMBER=+xxxxxxxxxxx
```7. Start the example echo bot
```bash
$ python examples/echobot.py
```8. Send message to Signal bot running on `+xxxxxxxxxxx` and wait for an echo
9. Now you can start writing your own bot for [Signal](https://signal.org/) Private Messenger!
## Code example
```python
import anyio
from semaphore import Bot, ChatContext# Connect the bot to number.
bot = Bot("+xxxxxxxxxxx")@bot.handler('')
async def echo(ctx: ChatContext) -> None:
await ctx.message.reply(ctx.message.get_body())async def main():
async with bot:
# Set profile name.
await bot.set_profile("Semaphore example bot")# Run the bot until you press Ctrl-C.
await bot.start()anyio.run(main)
```## Example bots
The following example bots can be found in [examples](examples):
- [apodbot](examples/apodbot.py), replies with Astronomy Picture of the Day
- [bbcbot](examples/bbcbot.py), replies with latest BBC headlines
- [broadcastbot](examples/broadcastbot.py), send broadcast to all subscribers
- [btcbot](examples/btcbot.py), sends notification when BTC price drops below a set price
- [echobot](examples/echobot.py), repeats received messages
- [exceptionbot](examples/exceptionbot.py), with custom exception handler
- [expirationbot](examples/expirationbot.py), sets the message expiration timer for a chat to random value
- [groups](examples/groups.py), manage groups
- [lovebot](examples/lovebot.py), loves everything you say!
- [profilebot](examples/profilebot.py), retrieves profile for personal touch
- [quotebot](examples/quotebot.py), quotes and repeats received messages
- [spongebot](examples/spongebot.py), repeats received messages in sPOngEbOb sqUArepAnTs text
- [stickerbot](examples/stickerbot.py), links to the sticker pack for received stickers
- [timerbot](examples/timerbot.py), sends an alert after a predefined time
- [xkcdbot](examples/xkcdbot.py), replies with latest XKCD comic## Changelog
**v0.17.0**
* Add support for group actions (thanks @sks444)
* Add support for receiving mentions**v0.16.0**
* Compatibility with signald 0.23.0+
* Add method to retrieve profile of message sender**v0.15.0**
* Compatibility with signald 0.22.0+
* Add option to automatically accept group invites**v0.14.0**
* Compatibility with signald 0.18.0+
* Migrate to latest version of anyio (3.5.0)
* Add Dockerfile to run Signal bot in container
* Add support for link previews (thanks @Era-Dorta)**v0.13.0**
* Compatibility with signald 0.17.0+
* Add method to set expiration timer of chat (thanks @Era-Dorta)
* Example expiration timer bot**v0.12.0**
* Compatibility with signald 0.15.0+
* Add support for emoji and about to in profile (thanks @EsEnZeT)
* Add option to throw signals errors on send (thanks @eknoes)**v0.11.0**
* Compatibility with signald 0.14.0+ (signald protocol v1)
* Add support for waiting on signald send confirmation (thanks @eknoes)
* Add support for sending messages to groups (thanks @brazuzan)**v0.10.1**
* Add method to set profile name and profile picture
* Store e164 phone number and uuid for received messages**v0.10.0**
* Add support for sending messages without previous context (thanks @eknoes)
* Add support for exception handlers (thanks @eknoes)
* Add ability to set profile picture (thanks @eknoes)
* Support signald client protocol v1
* Compatibility with signald 0.12.0+**v0.9.1**
* Fix repeating job re-add to queue (thanks @grandchild)**v0.9.0**
* Support for typing indicators
* Support for GroupsV2 (thanks @thefinn93)
* Example sticker bot (thanks @iomintz)
* Compatibility with signald 0.11.0+**v0.8.0**
* Support for Python 3.9
* Support for executing multiple handlers in parallel (thanks @iomintz)
* Support incoming sticker messages (thanks @iomintz)**v0.7.1**
* Support for decorators to register handlers
* Support for sending delivery receipts
* Mark messages as read by default**v0.7.0**
* Compatibility with signald 0.10.0+
* Support for multiple replies/reactions by handler (thanks @iomintz)
* Marking messages as read is optional
* First release on PyPi**v0.6.0**
* Support for message reactions
* Example message reaction bot**v0.5.0**
* Improve the logging system
* Add logging to job queue
* Strict typing**v0.4.0**
* Support for recurring jobs
* Example BTC price notification bot**v0.3.0**
* Support for scheduled jobs
* Example timer bot**v0.2.0**
* Support for quoting messages
* Example quote bot**v0.1.0**
* First release on Github## License
This project is licensed under the AGPL-v3 license.
The full license can be found in [LICENSE.txt](LICENSE.txt).