Compare commits
2 Commits
8039685e6b
...
2535c566a1
Author | SHA1 | Date | |
---|---|---|---|
2535c566a1 | |||
9cac021854 |
41
README.md
41
README.md
@ -1,2 +1,41 @@
|
||||
# TelegramPoster
|
||||
This bot is used for one and only task - post pictures from my personal archive.
|
||||
This bot is used for one and only task - post pictures from my personal archive.
|
||||
|
||||
## Installation
|
||||
To make this bot run at first you need to have a Python interpreter and git. Google is your friend finding it. You can also ignore git and simply download source code, should also work fine. After that you're ready to go.
|
||||
|
||||
1. Download the bot.
|
||||
1. `git clone https://git.end-play.xyz/profitroll/TelegramSender.git` (if you want to use git)
|
||||
2. `cd ./TelegramSender`
|
||||
|
||||
2. Install dependencies:
|
||||
`python -m pip install -r requirements.txt`
|
||||
Without installing those - bot cannot work at all
|
||||
|
||||
3. Install optional dependencies [Not required]:
|
||||
`python -m pip install -r requirements-optional.txt`
|
||||
These are not required but can make the bot run a bit faster
|
||||
|
||||
4. Configure your bot with a favorite text editor:
|
||||
`nano config.json`
|
||||
You can edit with vim, nano, on Windows it's Notepad or Notepad++. Whatever.
|
||||
If you don't know where to find bot_token and your id - here you can find some hints: [get bot token](https://www.siteguarding.com/en/how-to-get-telegram-bot-api-token), [get your id](https://www.alphr.com/telegram-find-user-id/), [get api_hash and api_id](https://core.telegram.org/api/obtaining_api_id).
|
||||
|
||||
5. Add bot to the channel
|
||||
To use your bot of course you need to have a channel or group otherwise makes no sense to have such a bot. [Here](https://stackoverflow.com/a/33497769) you can find a quick guide how to add your bot to a channel.
|
||||
|
||||
6. Fill your contents folder
|
||||
Of course bot cannot post something from nothing. Configure your `config.json` what media types bot should post (`"posting", "extensions"`), when to post them (`"posting", "time"`) and also where to find them (`"locations"`). You can also move them when sent by setting `"posting", "move_sent"` to `true`.
|
||||
|
||||
6. Good to go, run it!
|
||||
`python ./main.py`
|
||||
|
||||
## Command line arguments
|
||||
Of course bot also has them. You can perform some actions with them.
|
||||
* `--move-sent` - allows you to move all sent files from queue to sent directories
|
||||
* `--cleanup` - purge files in both `queue` and `sent` folders if they're sent. Requires `--confirm` argument
|
||||
* `--norun` - allows you to execute above arguments without tiggering the bot start itself
|
||||
|
||||
Examples:
|
||||
* `python3 ./main.py --move-sent --norun`
|
||||
* `python3 ./main.py --cleanup --confirm`
|
25
main.py
25
main.py
@ -23,18 +23,21 @@ if "--move-sent" in sys.argv:
|
||||
logWrite(f"Could not move sent file '{entry}' to '{configGet('sent', 'locations')}' due to {exp}")
|
||||
|
||||
if "--cleanup" in sys.argv:
|
||||
for entry in jsonLoad(configGet("index", "locations"))["sent"]:
|
||||
try:
|
||||
if "--confirm" in sys.argv:
|
||||
for entry in jsonLoad(configGet("index", "locations"))["sent"]:
|
||||
try:
|
||||
os.remove(configGet("queue", "locations")+os.sep+entry)
|
||||
except FileNotFoundError:
|
||||
pass
|
||||
try:
|
||||
os.remove(configGet("sent", "locations")+os.sep+entry)
|
||||
except FileNotFoundError:
|
||||
pass
|
||||
except Exception as exp:
|
||||
logWrite(f"Could not remove '{entry}' due to {exp}")
|
||||
try:
|
||||
os.remove(configGet("queue", "locations")+os.sep+entry)
|
||||
except FileNotFoundError:
|
||||
pass
|
||||
try:
|
||||
os.remove(configGet("sent", "locations")+os.sep+entry)
|
||||
except FileNotFoundError:
|
||||
pass
|
||||
except Exception as exp:
|
||||
logWrite(f"Could not remove '{entry}' due to {exp}")
|
||||
else:
|
||||
logWrite(f"Requested cleanup of sent files but not authorized. Please pass '--confirm' to perform that")
|
||||
|
||||
if "--norun" in sys.argv:
|
||||
logWrite("Argument --norun passed, not running the main script")
|
||||
|
Reference in New Issue
Block a user