Skip to main content

bot in reverse !

Project description

N A M E

TOB - bot in reverse !

S Y N O P S I S

tob <cmd> [key=val] [key==val] tob -cvaw [init=mod1,mod2] tob -d tob -s

D E S C R I P T I O N

TOB has all you need to program a unix cli program, such as disk perisistence for configuration files, event handler to handle the client/server connection, easy programming of your own commands, etc.

TOB contains python3 code to program objects in a functional way. it provides an “clean namespace” Object class that only has dunder methods, so the namespace is not cluttered with method names. This makes storing and reading to/from json possible.

TOB is a python3 IRC bot, it can connect to IRC, fetch and display RSS feeds, take todo notes, keep a shopping list and log text. You can run it under systemd for 24/7 presence in a IRC channel.

TOB is Public Domain.

I N S T A L L

installation is done with pipx

$ pipx install tob $ pipx ensurepath

<new terminal>

$ tob srv > tob.service $ sudo mv tob.service /etc/systemd/system/ $ sudo systemctl enable tob –now

joins #tob on localhost

U S A G E

use tob to control the program, default it does nothing

$ tob $

see list of commands

$ tob cmd cfg,cmd,dne,dpl,err,exp,imp,log,mod,mre,nme, pwd,rem,req,res,rss,srv,syn,tdo,thr,upt

start console

$ tob -c

start console and run irc and rss

$ tob -c init=irc,rss

list available modules

$ tob mod err,flt,fnd,irc,llm,log,mbx,mdl,mod,req,rss, rst,slg,tdo,thr,tmr,udp,upt``

start daemon

$ tob -d $

start service

$ tob -s

<runs until ctrl-c>

C O M M A N D S

here is a list of available commands

cfg - irc configuration cmd - commands dpl - sets display items err - show errors exp - export opml (stdout) imp - import opml log - log text mre - display cached output pwd - sasl nickserv name/pass rem - removes a rss feed res - restore deleted feeds rss - add a feed syn - sync rss feeds tdo - add todo item thr - show running threads upt - show uptime

C O N F I G U R A T I O N

irc

$ tob cfg server=<server> $ tob cfg channel=<channel> $ tob cfg nick=<nick>

sasl

$ tob pwd <nsnick> <nspass> $ tob cfg password=<frompwd>

rss

$ tob rss <url> $ tob dpl <url> <item1,item2> $ tob rem <url> $ tob nme <url> <name>

opml

$ tob exp $ tob imp <filename>

P R O G R A M M I N G

tob has it’s modules in the ~/.tob/mods directory so for a hello world command you would edit a file in ~/.tob/mods/hello.py and add the following

def hello(event):

event.reply(“hello world !!”)

typing the hello command would result into a nice hello world !!

$ tob hello hello world !!

commands run in their own thread and the program borks on exit to enable a short debug cycle, output gets flushed on print so exceptions appear in the systemd logs. modules can contain your own written python3 code.

F I L E S

~/.tob ~/.local/bin/tob ~/.local/pipx/venvs/tob/*

A U T H O R

Bart Thate <bthate@dds.nl>

C O P Y R I G H T

TOB is Public Domain

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tob-123.tar.gz (28.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tob-123-py3-none-any.whl (36.1 kB view details)

Uploaded Python 3

File details

Details for the file tob-123.tar.gz.

File metadata

  • Download URL: tob-123.tar.gz
  • Upload date:
  • Size: 28.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for tob-123.tar.gz
Algorithm Hash digest
SHA256 371a52e3a61a4144dac93e454e490428dd1bf4daf59892c9181a14f05b15c5d3
MD5 2f538931c4e091229d73937b7bd2e310
BLAKE2b-256 6b14a7a2c023caf5301682b1e20d66b6e8756a201c0a12f393c4ffd774ee4c33

See more details on using hashes here.

File details

Details for the file tob-123-py3-none-any.whl.

File metadata

  • Download URL: tob-123-py3-none-any.whl
  • Upload date:
  • Size: 36.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for tob-123-py3-none-any.whl
Algorithm Hash digest
SHA256 96eefdbd14fc5ece53a3788fc2a759a3e5e7a70f077c9e240d7003d086828273
MD5 a46dbba8ca63305d4366d94f1402cd8d
BLAKE2b-256 14fa97fef335d8df8c2da7d41e15118705a59d85d1a7b9e637eb7eab66af2be6

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page