mirror of
https://github.com/jlu5/PyLink.git
synced 2025-01-11 20:52:42 +01:00
docs: update hooks-reference (#113)
This commit is contained in:
parent
b1aa4c2ec5
commit
f2efaf9437
@ -29,31 +29,53 @@ Some hooks, like MODE, are more complex and can include the entire state of a ch
|
|||||||
['001ZJZW01',
|
['001ZJZW01',
|
||||||
'MODE',
|
'MODE',
|
||||||
{'modes': [('+o', '38QAAAAAA')],
|
{'modes': [('+o', '38QAAAAAA')],
|
||||||
'oldchan': {'modes': set(),
|
'oldchan': IrcChannel({'modes': set(),
|
||||||
'prefixmodes': {'admins': set(),
|
'prefixmodes': {'admins': set(),
|
||||||
'halfops': set(),
|
'halfops': set(),
|
||||||
'ops': set(),
|
'ops': set(),
|
||||||
'owners': set(),
|
'owners': set(),
|
||||||
'voices': set()},
|
'voices': set()},
|
||||||
'topic': '',
|
'topic': '',
|
||||||
'topicset': False,
|
'topicset': False,
|
||||||
'ts': 1451169448,
|
'ts': 1451169448,
|
||||||
'users': {'38QAAAAAA', '001ZJZW01'}},
|
'users': {'38QAAAAAA', '001ZJZW01'}}),
|
||||||
'target': '#chat',
|
'target': '#chat',
|
||||||
'ts': 1451174702}]
|
'ts': 1451174702}]
|
||||||
```
|
```
|
||||||
|
|
||||||
## Core hooks
|
## Core hooks
|
||||||
|
|
||||||
The following hooks are required for PyLink's basic functioning.
|
The following hooks, sent with their correct data keys, are required for PyLink's basic functioning.
|
||||||
|
|
||||||
- **ENDBURST**: `{}` - Although the hook data is empty, this should be sent whenever a server finishes its burst. The sender should be the server that finishes bursting.
|
- **ENDBURST**: `{}`
|
||||||
<br>
|
- The hook data here is empty.
|
||||||
Plugins like Relay need this to know that the uplink has finished bursting all its users!
|
- This payload should be sent whenever a server finishes its burst, with the SID of the bursted server as the sender.
|
||||||
|
- Plugins like Relay need this to know that the uplink has finished bursting all its users!
|
||||||
|
|
||||||
- **PYLINK_DISCONNECT**: `{}` - This is sent to plugins by the IRC objects when their network has disconnected. The sender (numeric) is **None** in this case.
|
- **PYLINK_DISCONNECT**: `{}`
|
||||||
|
- This is sent to plugins by IRC object instances whenever their network has disconnected. The sender (numeric) here is always **None**.
|
||||||
|
|
||||||
|
- **PYLINK_SPAWNMAIN**: `{'olduser': olduserobj}`
|
||||||
|
- This is sent whenever `Irc.spawnMain()` is called to (re)spawn the main PyLink client, for example to rejoin it from a KILL. It basically tells plugins that the UID of the main PyLink client has changed, while giving them the old data too.
|
||||||
|
- Example payload:
|
||||||
|
|
||||||
|
- ```
|
||||||
|
{'olduser': IrcUser({'away': '',
|
||||||
|
'channels': {'#chat'},
|
||||||
|
'host': 'pylink-devel.overdrivenetworks.com',
|
||||||
|
'ident': 'pylink',
|
||||||
|
'identified': False,
|
||||||
|
'ip': '0.0.0.0',
|
||||||
|
'manipulatable': True,
|
||||||
|
'modes': {('o', None)},
|
||||||
|
'nick': 'PyLink-devel',
|
||||||
|
'realhost': 'pylink-devel.overdrivenetworks.com',
|
||||||
|
'realname': 'PyLink development server',
|
||||||
|
'ts': 1452393682,
|
||||||
|
'uid': '7PYAAAAAE'}),
|
||||||
|
'ts': 1452393899)}
|
||||||
|
```
|
||||||
|
|
||||||
- **PYLINK_SPAWNMAIN**: `{'olduser': olduserobj}` - This is sent whenever `Irc.spawnMain()` is called to (re)spawn the main PyLink client, for example to rejoin it from a KILL. It basically tells plugins that the UID of the main PyLink client has changed, while giving them the old data too.
|
|
||||||
|
|
||||||
## IRC command hooks
|
## IRC command hooks
|
||||||
|
|
||||||
|
@ -79,7 +79,7 @@ optional, and defaults to the one we've stored in the channel state if not given
|
|||||||
- `sjoinServer('100', '#test', [('', '100AAABBC'), ('qo', 100AAABBB'), ('h', '100AAADDD')])`
|
- `sjoinServer('100', '#test', [('', '100AAABBC'), ('qo', 100AAABBB'), ('h', '100AAADDD')])`
|
||||||
- `sjoinServer(self.irc.sid, '#test', [('o', self.irc.pseudoclient.uid)])`
|
- `sjoinServer(self.irc.sid, '#test', [('o', self.irc.pseudoclient.uid)])`
|
||||||
|
|
||||||
- **`spawnServer`**`(self, name, sid=None, uplink=None, desc=None)` - Spawns a server off another PyLink server. `desc` (server description) defaults to the one in the config. `uplink` defaults to the main PyLink server, and `sid` (the server ID) is automatically generated if not given.
|
- **`spawnServer`**`(self, name, sid=None, uplink=None, desc=None)` - Spawns a server off another PyLink server. `desc` (server description) defaults to the one in the config. `uplink` defaults to the main PyLink server, and `sid` (the server ID) is automatically generated if not given. Sanity checks for server name and SID validity ARE done by the protocol module here.
|
||||||
|
|
||||||
- **`squitServer`**`(self, source, target, text='No reason given')` - SQUITs a PyLink server.
|
- **`squitServer`**`(self, source, target, text='No reason given')` - SQUITs a PyLink server.
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user