Skip to main content

object shell

Project description

N A M E

OBJZ - object shell

S Y N O P S I S

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

D E S C R I P T I O N

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, easy programming of your own commands, 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.

I N S T A L L

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

U S A G E

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

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

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

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

P R O G R A M M I N G

objz has it’s 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.

F I L E S

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

A U T H O R

Bart Thate <bthate@dds.nl>

C O P Y R I G H T

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-110.tar.gz (22.2 kB view details)

Uploaded Source

Built Distribution

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

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

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for objz-110.tar.gz
Algorithm Hash digest
SHA256 ed0486d593c41ae1eaa7e2fe1c66b36a6908f647907050ca92d99e5fbc2b4c15
MD5 0a529061f5f6e3b442bcea76962e3cf5
BLAKE2b-256 1e6dea4e54183f57729da8117452859e33b2b1c609c8f5cc471014971cb3d451

See more details on using hashes here.

File details

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

File metadata

  • Download URL: objz-110-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-110-py3-none-any.whl
Algorithm Hash digest
SHA256 a417d3119ffc4f24d7ccfbe4a89934853fb6d8a94177dc0e1736368be3a9932d
MD5 0e1dba52a2b717bc91343ec90d7f948e
BLAKE2b-256 8fd953ad410f712ee73c0160ea41b53dae0459e5586e488eb37457f85408c51c

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