3 releases
new 0.1.2 | Mar 22, 2025 |
---|---|
0.1.1 | Aug 28, 2023 |
0.1.0 | Dec 3, 2021 |
#408 in Command line utilities
107 downloads per month
125KB
2.5K
SLoC
Telegram RaF [Refer a Friend](@RefafBot)
RaF is a bot for creating referral-based contests for your Telegram channels, groups and supergroups.
Create contests, let your users share their link to your channel/group, increase your audience, and give prizes to the winners!
Introduction
The software is written in rust. Raf depends on a fork of telexide, a rust library for making telegram bots. The fork makes the original library work and solves some issues.
The storage used is SQLite: RaF creates a raf.db
file in its run path where it saves all the relationships between:
- Who owns the channels
- The contests created
- The invitations each participant generated
- The users who joined the channel through an invitation
Setup
- Install RaF
For the development version:
cargo install --path .
For the production version:
cargo install telegram-raf
- Create the run path and the environment file
mkdir $HOME/.raf
echo 'BOT_NAME="<your bot name>"' > $HOME/.raf/raf.env
echo 'TOKEN="<your bot token>"' >> $HOME/.raf/raf.env
- Copy the systemd service file
sudo cp misc/systemd/raf@.service /lib/systemd/system/
- Start and enable the service
sudo systemctl start raf@$USER.service
sudo systemctl enable raf@$USER.service
The raf.db
(to backup or inspect) is in $HOME/.raf/
.
Broadcast Feature
The bot supports a broadcast feature that allows the bot owner to send messages to all users and channels. To use this feature:
-
Create a
broadcast.md
file in the bot's run directory ($HOME/.raf/
) with the message you want to broadcast. The message supports Markdown formatting. -
If the bot is currently running, stop it. It requires a separate instance. Now start the bot with the
--broadcast
flag:
raf --broadcast
- Once the bot is running, use the
/broadcast
command to send the message frombroadcast.md
to all users and channels. - You can restart the bot to make it work as usual.
The broadcast.md
file should be formatted using Markdown V2 syntax, as the bot will send the message with ParseMode::MarkdownV2
.
Contributing
Any feedback is welcome. Feel free to open issues and create pull requests!
License
Copyright 2021 Paolo Galeone <nessuno@nerdz.eu>
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
Dependencies
~37–51MB
~877K SLoC