Skip to main content

cli bot

Project description

NAME

BOTL - bot library

SYNOPSIS

botl <cmd> [key=val] [key==val]
botl [-a] [-c] [-d] [-h] [-v] [-w]

options are:

-a     load all modules
-c     start console
-d     start daemon
-h     display help
-v     use verbose

DESCRIPTION

BOTL contains all the python3 code to program objects in a functional
way. It provides a base Object class that has only dunder methods, all
methods are factored out into functions with the objects as the first
argument. It is called Object Programming (OP), OOP without the
oriented.

BOTL  allows for easy json save//load to/from disk of objects. 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.

BOTL 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, code to introspect modules for
commands, deferred exception handling to not crash on an error, a
parser to parse commandline options and values, etc.

BOTL has a demo bot, it can connect to IRC, fetch and display RSS
feeds, take todo notes, keep a shopping list and log text. You can
also copy/paste the service file and run it under systemd for 24/7
presence in a IRC channel.

BOTL is Public Domain.

USAGE

without any argument the program does nothing

$ botl
$

see list of commands

$ botl cmd
cmd,err,mod,req,thr,ver

list of modules

$ botl mod
cmd,err,fnd,irc,log,mod,req,rss,tdo,thr

use -c to start a console

$ botl -c

use mod=<name1,name2> to load additional modules

$ botl -c mod=irc,rss
>

use -v for verbose

$ botl -cv mod=irc
BOTL started CV started Sat Dec 2 17:53:24 2023
>

CONFIGURATION

$ botl cfg
channel=#botl commands=True nick=botl port=6667 server=localhost

irc

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

sasl

$ botl pwd <nsvnick> <nspass>
$ botl cfg password=<frompwd>

rss

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

COMMANDS

cmd - commands
cfg - irc configuration
dlt - remove a user
dpl - sets display items
fnd - find objects
log - log some text
met - add a user
mre - displays cached output
pwd - sasl nickserv name/pass
rem - removes a rss feed
rss - add a feed
thr - show the running threads

SYSTEMD

save the following it in /etc/systems/system/botl.service and
replace "<user>" with the user running pipx

[Unit]
Description=bot library
Requires=network-online.target
After=network-online.target

[Service]
Type=simple
User=<user>
Group=<user>
WorkingDirectory=/home/<user>/.botl
ExecStart=/home/<user>/.local/pipx/venvs/botl/bin/botl -d
RemainAfterExit=yes

[Install]
WantedBy=default.target

then run this

$ mkdir ~/.botl
$ sudo systemctl enable botl --now

default channel/server is #botl on localhost

FILES

~/.botl
~/.local/bin/botl
~/.local/bin/botld
~/.local/pipx/venvs/botl/

AUTHOR

Bart Thate <bthate@dds.nl>

COPYRIGHT

BOTL 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

botl-105.tar.gz (29.0 kB view details)

Uploaded Source

File details

Details for the file botl-105.tar.gz.

File metadata

  • Download URL: botl-105.tar.gz
  • Upload date:
  • Size: 29.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.2

File hashes

Hashes for botl-105.tar.gz
Algorithm Hash digest
SHA256 c38f6fa8d3d5c316e937a42c88c243e0118b45ec21d22f0ae22b6f59c1572507
MD5 dca8cfd66e543d847c5bd56742ffff12
BLAKE2b-256 8c4613ad673e1ad65cbd420fac43aa3e7f94c94cfc9897d62b5d2f4f3f8a3fb4

See more details on using hashes here.

Supported by

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