Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/HirbodBehnam/file2url-go
A Telegram bot to convert files to URL for direct download links.
https://github.com/HirbodBehnam/file2url-go
directlink downloader telegram-bot
Last synced: about 1 month ago
JSON representation
A Telegram bot to convert files to URL for direct download links.
- Host: GitHub
- URL: https://github.com/HirbodBehnam/file2url-go
- Owner: HirbodBehnam
- License: mit
- Created: 2021-11-29T17:37:48.000Z (about 3 years ago)
- Default Branch: master
- Last Pushed: 2022-05-24T09:16:14.000Z (over 2 years ago)
- Last Synced: 2024-10-30T06:08:21.265Z (about 1 month ago)
- Topics: directlink, downloader, telegram-bot
- Language: Go
- Homepage:
- Size: 45.9 KB
- Stars: 25
- Watchers: 3
- Forks: 12
- Open Issues: 2
-
Metadata Files:
- Readme: README.MD
Awesome Lists containing this project
- awesome - HirbodBehnam/file2url-go - A Telegram bot to convert files to URL for direct download links. (Go)
README
# File 2 URL Bot
A simple bot to convert files sent to it to URLs to make direct download links.
## Features
* Fast download speeds
* Option to allow only specific users to create download links
* Range support
* Database support## Setup
At first download the program from [releases](https://github.com/HirbodBehnam/file2url-go/releases). Then before running
the application, set these values as environment variables:```bash
export APP_ID=1234
export APP_HASH=abcd
export BOT_TOKEN=zyxw
export ALLOWED_USERS=1,2
````ALLOWED_USERS` is the list of user IDs which are allowed to use the bot. Do not specify this variable in order to make
the bot public.### Running on your server
If you are planning to run this bot on your server you also have to specify these two environment variables:
```bash
export LISTEN=0.0.0.0:12345
export URL_PREFIX=my-ip-or-domain:12345
````LISTEN` is the listen address of the server. `URL_PREFIX` will be as the domain/ip of the links which are sent to
users.Then simply run the executable file.
### Running with Heroku
To run this app on Heroku, you only need to specify one environment variable other than bot id and app hash/id.
```bash
export DYNO_NAME=my-dyno-name
```### Databases
This bot will use a database to store the file information which is mapped from a UUID. By default, bot will use an in
memory cache to store these values. This each entry has a TTL of one day by default.You can change the in memory cache to [bbolt](https://github.com/etcd-io/bbolt) in order to make the data persistent on
disk. To enable bbolt, set the environment variable of `BOLT_DB_PATH` to a file which is the database.