63 Commits (5c6b6263960fbca42f62352d125dcea55509ba88)

Author SHA1 Message Date
Mark Veidemanis 5c6b626396 Check registration status before joining channels
Do not join channels if any relay for a network is unregistered.
4 years ago
Mark Veidemanis a3cdb35e05 Implement registration and confirmation of nicks 4 years ago
Mark Veidemanis d99c3c394f Restructure provisioning into fewer functions 4 years ago
Mark Veidemanis f4e5d248d5 Separate provisioning into user and auth info 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 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 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 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 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 78e4d6bd66 Rename 'message' to 'msg' and 'target' to 'channel' 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 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 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 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 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
Al Beano 63539a4edb Merge branch 'master' into datarestructure 5 years ago
Al Beano e5adcfef4c Rework data structures, storing all front-end network data in Network objects 5 years ago
Mark Veidemanis 2757256d4f Implement a single function for all callbacks from IRC hooks and send a seperate notification if an action takes place that concerns a bot 5 years ago
Al Beano 15bc195648 Add automatic alias generation function 5 years ago
Mark Veidemanis 56840e0060 Add the network number in ZNC relay notifications 5 years ago
Mark Veidemanis 68c6aa969d Remove keyword system, implement ZNC notifications to relay, remove exact from cast fields and fix security bug in relay 5 years ago
Mark Veidemanis 0637f762ea Add network name to fields shown in relay notifications 5 years ago
Mark Veidemanis 4ce093bfbe Implement a running count of the number of events per minute 5 years ago
Mark Veidemanis 9e1a6613a4 Implement sending of relay messages 6 years ago
Mark Veidemanis 488d81dac8 Fix a race condition in disabling networks post-creation, remove redundant bindhost code and fix a minor bug in the load command 6 years ago
Mark Veidemanis a4b7bd50b1 Implement additional error checking for provisioning instances and parsing messages, and prevent ZNC from auto-connecting an instance if ConnectOnCreate is off 6 years ago
Mark Veidemanis 8926cb76ec Renovate the module system and implement adding and resuming pool instances using the new relay/alias/network system 6 years ago
Mark Veidemanis 4efea3f535 Implement the backend for automatically provisioning relays 6 years ago
Mark Veidemanis 7cd6bc3616 Purge metadata entries on quit and escape glob characters 6 years ago
Mark Veidemanis 7d7ef69d98 Avoid doing pointless lookups against numbered networks 6 years ago
Mark Veidemanis 44aa0f1727 Implement users command to see the mutual users of one or more channels and squash some bugs 6 years ago
Mark Veidemanis a98ed4e4d0 Fix bug in the keyword module 6 years ago
Mark Veidemanis cfefa1d627 Implement a command to get the channels common to one or more users 6 years ago
Mark Veidemanis 249e99805a Implement optional x in y matching for attributes in the monitor system 6 years ago
Mark Veidemanis 2cb0b5d4a6 Add a count parameter to ensure all entries are searched 6 years ago