Skip to main content

objects daemon

Project description

NAME

OBJD - object daemon

SYNOPSIS

objd <cmd> [key=val] [key==val]
objd

DESCRIPTION

OBJD 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 also
copy/paste the service file and run it under systemd for 24/7 presence
in a IRC channel.


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

OBJD contains 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. I call it Object Programming (OP), OOP without the oriented.

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

OBJD is Public Domain.

INSTALL

$ pipx install objd $ pipx ensurepath

USAGE

without any argument the program starts a daemon

$ objd
$


use objd <arguments> program to manage objd

CONFIGURATION

the cfg command is used for configuration of the IRC bot

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

irc

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

sasl

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

rss

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

COMMANDS

$ objd cmd
cfg,cmd,dne,dpl,err,flt,log,mod,mre,nme,pwd,rem,req,res,rss,tdo,thr,tmr


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/systemd/system/objd.service and
replace "<user>" with the user running pipx
[Unit]
Description=object daemon
Requires=network-online.target
After=network-online.target

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

[Install]
WantedBy=default.target
then run this::

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

default channel/server is #objd on localhost

FILES

~/.objd
~/.local/bin/objd
~/.local/pipx/venvs/objd/

AUTHOR

xobjectz <objx@proton.me>

COPYRIGHT

OBJD 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

objd-20.tar.gz (27.1 kB view details)

Uploaded Source

File details

Details for the file objd-20.tar.gz.

File metadata

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

File hashes

Hashes for objd-20.tar.gz
Algorithm Hash digest
SHA256 b5c59525b03fd67f51313f07b949096fb9aa7d0e5c40c3fdcfe0e37164467ca1
MD5 7d86a532b253e1d162d4c17dae47cc33
BLAKE2b-256 8409279f0691438e63b4593b4b411af6331e54a61d7b6c2060e4a30c482e52ee

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