Mark Veidemanis
a78229a288
Add irc.json to gitignore
4 years ago
Mark Veidemanis
918d410927
Fix variable scope in LIST error handling
5 years ago
Mark Veidemanis
bc4d5cba8e
Separate provisioning into user and auth info
5 years ago
Mark Veidemanis
376d1bd911
Add IRC network definitions
5 years ago
Mark Veidemanis
778690ae3a
Add more comments and remove obsolete code
5 years ago
Mark Veidemanis
da3ba4ea8c
Add requirements
5 years ago
Mark Veidemanis
9c4ea94ebd
Add requirements file
5 years ago
Mark Veidemanis
a20fcdb8fc
Remove some debugging code from ChanKeep
5 years ago
Mark Veidemanis
7ffb6125aa
Fix various bugs uncovered by the LIST system
...
* Work around Twisted's broken handling of spaces
* Work around Twisted's broken line decoding
* Don't run signedOn twice for relays
* Improved detection of whether the endpoint is connected to ZNC
* Delay a LIST until all configured relays are online
* Discard a LIST if there are no callbacks for it
* Get rid of some double-negative ternary blocks
5 years ago
Mark Veidemanis
b4fa747853
Fix LIST handling and message parsing
...
* Always use simple LIST syntax if it succeeded once after a failed
complex query
* Reject asking for a LIST twice
* Quickly discard any ISUPPORT messages that don't contain things we
need to use
* Detect the server name and drop any messages from the server
5 years ago
Mark Veidemanis
f34de8940f
Improve performance in userinfo
...
* Implement a nick -> user mapping, preventing a superfluous SSCAN on
the entire dataset for when networks are disconnected
* Use one thread for all channels when a network instance is
disconnected, instead of one thread per channel
* Made returns comprising of only a list into tuples
5 years ago
Mark Veidemanis
a64765121a
Allow multiple arguments for the logging functions
5 years ago
Mark Veidemanis
5777ef0cfe
Improve ZNC error message detection
5 years ago
Mark Veidemanis
b97ebe43ab
Only start one relay with the auto command
...
We only need one initial relay, as ChanKeep will automatically add as
many as it needs when receiving a LIST response.
5 years ago
Mark Veidemanis
6ad6d6dc50
Fix channel allocation when relays are provisioned
...
Fix a bug where the channel allocation algorithm failed due to
necessary relays not having been provisioned yet.
Passed the newly created relay numbers to the allocation function
and assumed their CHANMAX would be the same as all other relays for
the same network.
5 years ago
Mark Veidemanis
0321651c20
Implement fair channel allocation in ChanKeep
...
* Allocate channels to relays only if they have free space based on
their chanlimit value
* Minify channels by removing ones that are already covered before
passing them off to be joined
5 years ago
Mark Veidemanis
7a6e3338c0
Implement ChanKeep joining functions
...
* Low-key channel joining with incrementally increasing delay
* Spin up needed instances to be able to cover a certain channel space
* Fix provisioning functions to prevent race conditions with lots of
relays being created at once
* Tweakable switchover from covering all channels to only covering
channels with more users than the mean of the cumulative user count
5 years ago
Mark Veidemanis
c3d0cb04b6
Pass all arguments from debug into print
...
Allows for multi-argument debug() statements without ugly + or %s
operators.
5 years ago
Mark Veidemanis
324af04de0
Don't return the same thing twice
...
The add_relay and provisionRelay functions both returned the alias.
Only use the output from one function.
5 years ago
Mark Veidemanis
f9619a5bc4
Remove help entry for del
5 years ago
Mark Veidemanis
31c9e64790
Implement function to set up multiple relays
5 years ago
Mark Veidemanis
33cb173db6
Switch to using Redis for LIST storage
5 years ago
Mark Veidemanis
7e90080a2c
Set up Redis database which isn't cleared on quit
5 years ago
Mark Veidemanis
da14a86e70
Fix getting LIST output to work with more networks
...
* Parse ISUPPORT properly if more than one channel prefix is supported
* Retry getting LIST another way is the response is empty
5 years ago
Mark Veidemanis
a027a0b4f6
Fix getting user records by nickname
...
Use -1 to refer to unlimited records instead of an arbitrarily large
number.
5 years ago
Mark Veidemanis
c92e618076
Remove the del command
5 years ago
Mark Veidemanis
06d3dd4d7e
Implement storing analytics on a LIST response
5 years ago
Mark Veidemanis
15b394bd79
Implement requesting a LIST and parsing the output
5 years ago
Mark Veidemanis
aa54759337
Additional error checking on user record deletion
5 years ago
Mark Veidemanis
f0fff7c958
Implement sorting relay output by custom keys
5 years ago
Mark Veidemanis
5eda50af13
Use net and num instead of name in relay output
5 years ago
Mark Veidemanis
78e4d6bd66
Rename 'message' to 'msg' and 'target' to 'channel'
5 years ago
Mark Veidemanis
ddadeb617c
Change message to msg in relay output and in functions, include name in connection notifications instead of net
5 years ago
Mark Veidemanis
89894287b3
Add error handling to exec command and fix minor bug in cleaning up relays
5 years ago
Mark Veidemanis
872d08be3e
Implement exec command for running raw Python code
5 years ago
Mark Veidemanis
d35f96de87
Error checking on alias removal and clean up when removing relays
5 years ago
Mark Veidemanis
a3b81f8849
Implement more automated provisioning of aliases and relays, and remove networks cleanly
5 years ago
Mark Veidemanis
0f31d7f5e2
Implement admall command to run commands as the administrative relay user
5 years ago
Mark Veidemanis
b19dfcc113
Add alias.json to gitignore
5 years ago
Mark Veidemanis
32309ecec2
Change alias definitions to be global, so aliases can be reused across different networks
5 years ago
Mark Veidemanis
355a80b19b
Fix the all and allc commands so they work with the new data format
5 years ago
Mark Veidemanis
15ca45e5df
Implement Ctrl-C handling and fix a large number of small bugs
5 years ago
Mark Veidemanis
006f8db6f6
Update the class name in the single command loader and import the debug function which it uses
5 years ago
Mark Veidemanis
2d70d5af11
Add error checking in places, set up automatic relay provisioning and fix starting bots
5 years ago
Mark Veidemanis
ff74968ff8
Merge branch 'master' into datarestructure
5 years ago
Mark Veidemanis
c63f301b7f
Defer initialUsers, initialNames and delChannel to threads to improve performance
5 years ago
Mark Veidemanis
545282e201
Add deduplication precision toggle, fix printing odd characters and implement sending messages to all instances of a certain network, or all networks associated with a certain alias
5 years ago
Mark Veidemanis
22bd0d3ac6
Don't crash if the part message is null
5 years ago
Mark Veidemanis
f34ddab6fc
Improvements to query and self event detection, implement all command and debug flags
5 years ago
Mark Veidemanis
1ec0e1f7e6
Remove provisioning restrictions, move all user tracking code to monitoring module, fix proper network name not being passed to the relay
5 years ago