ircstates/README.md

97 lines
2.0 KiB
Markdown
Raw Permalink Normal View History

2020-03-12 16:08:48 +00:00
# ircstates
[![Build Status](https://travis-ci.org/jesopo/ircstates.svg?branch=master)](https://travis-ci.org/jesopo/ircstates)
## 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
2020-10-03 17:29:33 +00:00
### simple
```python
import ircstates
server = ircstates.Server("freenode")
lines = server.recv(b":server 001 nick :hello world!\r\n")
lines += server.recv(b":nick JOIN #chan\r\n")
for line in lines:
server.parse_tokens(line)
2020-10-03 17:29:33 +00:00
chan = server.channels["#chan"]
```
2020-03-12 16:08:48 +00:00
### socket to state
2020-03-12 16:08:48 +00:00
```python
import ircstates, irctokens, socket
2020-03-12 16:08:48 +00:00
NICK = "nickname"
CHAN = "#chan"
HOST = "127.0.0.1"
2020-10-03 17:26:49 +00:00
PORT = 6667
2020-03-12 16:08:48 +00:00
server = ircstates.Server("freenode")
sock = socket.socket()
2020-03-12 16:08:48 +00:00
2020-10-03 17:26:49 +00:00
sock.connect((HOST, PORT))
def _send(raw: str):
sock.sendall(f"{raw}\r\n".encode("utf8"))
2020-03-12 16:08:48 +00:00
_send("USER test 0 * test")
_send(f"NICK {NICK}")
2020-03-12 16:08:48 +00:00
while True:
recv_data = sock.recv(1024)
recv_lines = server.recv(recv_data)
for line in recv_lines:
server.parse_tokens(line)
2020-03-12 16:08:48 +00:00
print(f"< {line.format()}")
# user defined behaviors...
if line.command == "PING":
_send(f"PONG :{line.params[0]}")
2020-03-12 16:08:48 +00:00
```
### get a user's channels
```python
>>> server.users
{'nickname': User(nickname='nickname')}
>>> user = server.users["nickname"]
>>> user
User(nickname='nickname')
>>> user.channels
{'#chan'}
2020-03-12 16:08:48 +00:00
```
### get a channel's users
```python
>>> server.channels
{'#chan': Channel(name='#chan')}
>>> channel = server.channels["#chan"]
>>> channel
Channel(name='#chan')
>>> channel.users
{'jess': ChannelUser(#chan jess)}
2020-03-12 16:08:48 +00:00
```
### get a user's modes in channel
```python
>>> channel = server.channels["#chan"]
>>> channel_user = channel.users["nickname"]
2020-03-12 16:08:48 +00:00
>>> channel_user
ChannelUser(#chan jess +ov)
2020-03-12 16:08:48 +00:00
>>> channel_user.modes
{'o', 'v'}
```
2020-04-01 22:39:07 +00:00
## contact
2021-05-24 17:27:10 +00:00
Come say hi at `#irctokens` on irc.libera.chat