Go to file
jesopo 66c2655df2 switch LICENCE from GPL-3.0 to MIT 2020-04-01 01:58:20 +01:00
ircstates '_create_channel'->'create_channel', '_create_user'->'create_user' 2020-04-01 00:52:53 +01:00
test change Emits to just be one object 2020-03-19 11:28:44 +00:00
.gitignore first commit 2020-03-12 14:00:26 +00:00
.travis.yml now that pypi irctokens supports typehints, remove --ignore-missing-imports 2020-03-12 15:34:36 +00:00
LICENSE switch LICENCE from GPL-3.0 to MIT 2020-04-01 01:58:20 +01:00
README.md remove anything related to sending; we're just a state machine. 2020-03-15 21:25:17 +00:00
VERSION v0.6.3 release 2020-04-01 00:54:31 +01:00
requirements.txt update irctokens to 0.9.2 2020-03-28 12:08:17 +00:00
setup.py fix package_data pointing at irctokens (copypaste!) 2020-03-19 16:08:07 +00:00

README.md

ircstates

Build Status

rationale

I wanted a bare-bones reference implementation of taking byte input, parsing it into tokens and then managing an IRC client session state from it.

with this library, you can have client session state managed for you and put additional arbitrary functionality on top of it.

usage

socket to state

import ircstates, irctokens, socket

NICK = "nickname"
CHAN = "#chan"
HOST = "127.0.0.1"
POST = 6667

server  = ircstates.Server("freenode")
sock    = socket.socket()
encoder = irctokens.StatefulEncoder()

sock.connect((HOST, POST))

def _send(raw):
    tokens = irctokens.tokenise(raw)
    encoder.push(tokens)

_send("USER test 0 * test")
_send(f"NICK {NICK}")

while True:
    while encoder.pending():
        sent_lines = encoder.pop(sock.send(encoder.pending()))
        for line in sent_lines:
            print(f"> {line.format()}")

    recv_lines = server.recv(sock.recv(1024))
    for line in recv_lines:
        print(f"< {line.format()}")

        # user defined behaviors...
        if line.command == "PING":
            _send(f"PONG :{line.params[0]}")

        if line.command == "001" and not CHAN in server.channels:
            _send(f"JOIN {CHAN}")

get a user's channels

>>> server.users
{'nickname': User(nickname='nickname')}
>>> user = server.users["nickname"]
>>> user
User(nickname='nickname')
>>> server.user_channels[user]
{Channel(name='#chan')}

get a channel's users

>>> server.channels
{'#chan': Channel(name='#chan')}
>>> channel = server.channels["#chan"]
>>> channel
Channel(name='#chan')
>>> server.channel_users[channel]
{User(nickname='nickname'): ChannelUser(user='nickname', channel='#chan', modes='ov')}

get a user's modes in channel

>>> user = server.users["nickname"]
>>> channel = server.channels["#chan"]
>>> channel_user = server.channel_users[channel][user]
>>> channel_user
ChannelUser(user='nickname', channel='#chan', modes='ov')
>>> channel_user.modes
{'o', 'v'}