Skip to main content

object shell

Project description

NAME


OBJZ - object shell

SYNOPSIS


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

DESCRIPTION

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

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

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

OBJZ is Public Domain.

INSTALL

installation is done with pipx


$ pipx install objz
$ pipx ensurepath

<new terminal>

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

joins #objz on localhost

USAGE

use objz to control the program, default it does nothing


$ objz
$

see list of commands


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

start console


$ objz -c

start console and run irc and rss clients


$ objz -c init=irc,rss

list available modules


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

start daemon


$ objz -d
$

start service


$ objz -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


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

sasl


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

rss


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

opml


$ objz exp
$ objz imp <filename>

PROGRAMMING


objz has it’s user modules in the ~/.objz/mods directory so for a
hello world command you would edit a file in ~/.objz/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 !!

$ objz 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.

FILES


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

AUTHOR


Bart Thate <bthate@dds.nl>

COPYRIGHT


OBJZ 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

objz-111.tar.gz (22.4 kB view details)

Uploaded Source

Built Distribution

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

objz-111-py3-none-any.whl (27.6 kB view details)

Uploaded Python 3

File details

Details for the file objz-111.tar.gz.

File metadata

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

File hashes

Hashes for objz-111.tar.gz
Algorithm Hash digest
SHA256 92d2c8e56a4c23eb656e41ae945d28d07588919f8ff56cf2b438b65232e3af19
MD5 b636b3e23fc16f6168645483408e6c57
BLAKE2b-256 a7d05590dadd09ec52c3dd839a9fb1b37d0b5bedd9e196fb68229e1987544202

See more details on using hashes here.

File details

Details for the file objz-111-py3-none-any.whl.

File metadata

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

File hashes

Hashes for objz-111-py3-none-any.whl
Algorithm Hash digest
SHA256 26cf116e857651a628087cdeba0fd49aab4719987bc760f8e207edded5addd11
MD5 8d4ac9cd5315e42b9579622916fe2ca8
BLAKE2b-256 c8d0e54986e8313c63863db2c1b8721d15d7e899255df1649768646275b3e454

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