Skip to main content

NIXBOT

Project description

NAME


nixbot - NIXBOT

SYNOPSIS


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

DESCRIPTION

NIXT 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, deferred exception handling to not crash on an error, etc.

NIXT 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.

NIXBOT 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.

NIXBOT is Public Domain.

INSTALL

installation is done with pipx


$ pipx install nixbot
$ pipx ensurepath

<new terminal>

$ nixbot srv > nixbot.service
$ sudo mv nixbot.service /etc/systemd/system/
$ sudo systemctl enable nixbot --now

joins #nixbot on localhost

USAGE

use nixbot to control the program, default it does nothing


$ nixbot
$

see list of commands


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

start console


$ nixbot -c

start console and run irc and rss clients


$ nixbot -c init=irc,rss

list available modules


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

start daemon


$ nixbot -d
$

start service


$ nixbot -s
<runs until ctrl-c>

COMMANDS

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
req - reconsider
rss - add a feed
syn - sync rss feeds
tdo - add todo item
thr - show running threads
upt - show uptime

CONFIGURATION

irc


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

sasl


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

rss


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

opml


$ nixbot exp
$ nixbot imp <filename>

PROGRAMMING

nixbot has it’s modules in the package, so edit a file in nixbot/modules/<name>.py and add the following for hello world

def hello(event):
    event.reply("hello world !!")

nixbot uses loading on demand of modules and has a tbl command to generate a table for this.


$ nixbot tbl > nixbot/modules/tbl.py

a md5sum can be added to verify the modules md5sums are matching.


$ nixbot md5

put this value in nixbot/modules/__init__.py and nixbot can execute the hello command now.


$ nixbot hello
hello world !!

Commands run in their own thread and the program borks on exit, output gets flushed on print so exceptions appear in the systemd logs. Modules can contain your own written python3 code, see the nixbot/modules directory for examples.

FILES


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

AUTHOR


Bart Thate <nixtniet@gmail.com>

COPYRIGHT


NIXBOT 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

nixbot-173.tar.gz (35.7 kB view details)

Uploaded Source

Built Distribution

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

nixbot-173-py3-none-any.whl (43.4 kB view details)

Uploaded Python 3

File details

Details for the file nixbot-173.tar.gz.

File metadata

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

File hashes

Hashes for nixbot-173.tar.gz
Algorithm Hash digest
SHA256 69307521d2f0919e1edc673d13f15c623b3550f85f91d3859193ee729db1e79a
MD5 c94b9fb52e5b28e582d9e50248ffed8e
BLAKE2b-256 1a23cd94d45e40bbab80dff6d366e68cac88e4d5e4d18a487a0caedd46cdf686

See more details on using hashes here.

File details

Details for the file nixbot-173-py3-none-any.whl.

File metadata

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

File hashes

Hashes for nixbot-173-py3-none-any.whl
Algorithm Hash digest
SHA256 ced3ffd08039591b3299e64be02e3fbf5d6a4ad583691ca3cea74430f9840ae5
MD5 bdb335a54ea58010d82e970d59071dbf
BLAKE2b-256 2c77e3a523bfa4938568bf7282384e3b989b3903d5325da0e627c192edd129ce

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