aboutsummaryrefslogtreecommitdiff
Commit message (Expand)AuthorAgeFilesLines
* Only send `auth_text` if it's not None (sasl)Gravatar jesopo2019-02-061-4/+5
* `auth_text` would not be present in a failure scenarioGravatar jesopo2019-02-061-0/+1
* Handle error on server-final-message (sasl.scram)Gravatar jesopo2019-02-061-6/+9
* Remove particularly improper quit quotes, add Hillel the Elder quote (quit.py)Gravatar jesopo2019-02-061-2/+1
* Don't .lower() nicknames in Database.py, it doesn't know about IRC casemappingGravatar jesopo2019-02-062-4/+5
* `arguments` was not defined if they weren't provided (sasl)Gravatar jesopo2019-02-061-3/+1
* Fix mypy linting issue with dict creation (scram.py)Gravatar jesopo2019-02-061-1/+2
* "+" as part of a SASL handshake is irc-specific so remove it from scram.pyGravatar jesopo2019-02-062-5/+7
* Type annotate scram.py and don't pass base64 data to scram.py functionsGravatar jesopo2019-02-062-13/+13
* Forgot to remove Flask from requirements.txtGravatar jesopo2019-02-061-1/+0
* Don't take a users coins when they make an invalid roulette bet (coins.py)Gravatar jesopo2019-02-051-2/+2
* Split hash and hmac logic out to their own functions (sasl.scram)Gravatar jesopo2019-02-051-7/+10
* Actually check that we don't have CAPs that we're waiting on a ACK/NAK for•••before ending CAP negotiation (line_handler.py) Gravatar jesopo2019-02-051-0/+2
* STARTTLS was removed long agoGravatar jesopo2019-02-051-2/+0
* Manually count ACK/NAK for REQed CAPs before ENDing CAP negotiationGravatar jesopo2019-02-052-10/+11
* Disconnect from server and throw an exception if SCRAM server verification fails•••(sasl) Gravatar jesopo2019-02-051-0/+5
* Move scripts module to it's own directoryGravatar jesopo2019-02-052-1/+2
* CAP capabilities would not be index `2` if the line is multiline•••(line_handler.py) Gravatar jesopo2019-02-051-2/+2
* Remove debug print in `sasl/__init__.py`Gravatar jesopo2019-02-051-1/+0
* Move sasl.py to a directory module and move SCRAM logic to a different file,•••move `github/module.py` to `github/__init__.py` Gravatar jesopo2019-02-053-55/+98
* Switch to using __init__.py as main file of directory modules, so they behave•••like a package (also put the modules manually in sys.modules Gravatar jesopo2019-02-051-3/+4
* Switch to a non-deprecated method of loading files by filename•••(`importlib.util.spec_from_file_location`) Gravatar jesopo2019-02-051-2/+4
* Remove SCRAM-related variables on IRCServer object when we see•••server-final-message (sasl.py) Gravatar jesopo2019-02-051-0/+4
* Remove SCRAM debug logging (sasl.py)Gravatar jesopo2019-02-051-10/+0
* Support SCRAM SASL mechanisms (sasl.py)Gravatar jesopo2019-02-051-15/+97
* Add ")" that should have been removed when we stopped using `enumerate` for•••github webhook hooks (github) Gravatar jesopo2019-02-041-1/+1
* Reply to statusmsg commands (e.g. '/msg +channel !ping') with the same statusmsgGravatar jesopo2019-02-042-10/+20
* Try to match against full repository name first, so that we can make specific•••rules for specific repositories (github) Gravatar jesopo2019-02-041-3/+3
* We don't need to enumerate hooks (github)Gravatar jesopo2019-02-041-2/+1
* Delete `automodes` user_channel setting when it's empty (auto_mode.py)Gravatar jesopo2019-02-041-2/+6
* `user` doesn't exist in _move(), it's `user1` (coins.py)Gravatar jesopo2019-02-021-1/+1
* `apikey` command should have a minimum argument restriction (rest_api.py)Gravatar jesopo2019-02-011-1/+1
* Actually add private_unban function def. oops. (channel_op.py)Gravatar jesopo2019-01-301-0/+1
* Add private message `unban` command (channel_op.py)Gravatar jesopo2019-01-301-0/+10
* Actually use `channel` arg in _kick_command (channel_op.py)Gravatar jesopo2019-01-301-1/+1
* Support `kick` and `ban` command in private message (channel_op.py)Gravatar jesopo2019-01-301-7/+31
* `server.get_channel` was moved to `server.channels.get` a long time ago (set.py)Gravatar jesopo2019-01-301-1/+1
* Logging takes format params as a separate arg (commands.py)Gravatar jesopo2019-01-301-2/+2
* Add `make_event(..)` to EventHookContextGravatar jesopo2019-01-301-0/+4
* Make sure to call the specific hook we've decided is valid (commands.py)Gravatar jesopo2019-01-302-5/+12
* check we have a `channel_arg` kwarg before parsing it as an int•••(channel_access.py) Gravatar jesopo2019-01-301-10/+11
* Break when we've found a suitable command hook (commands.py)Gravatar jesopo2019-01-301-0/+1
* Use correct arg indexes for private channelset (set.py)Gravatar jesopo2019-01-301-6/+7
* Actually remove call to `preprocess.command` to after min_args check•••(commands.py) Gravatar jesopo2019-01-301-5/+5
* Correctly check if we're in a channel command before checking if the current•••hook is valid (commands.py) Gravatar jesopo2019-01-301-6/+2
* Check min_args before we check if a user has permission (commands.py)Gravatar jesopo2019-01-301-17/+17
* We need to turn `channel_arg` in to an int (channel_access.py)Gravatar jesopo2019-01-301-1/+1
* We should be using `potential_hook` until we've decided on a valid hook•••(commands.py) Gravatar jesopo2019-01-301-4/+4
* Get all hooks when checking command hooks, not just the first (commands.py)Gravatar jesopo2019-01-301-5/+4
* Check all hooks for a command and pick the first applicable one, to allow for•••private_only and channel_only commands to share the same command string (commands.py) Gravatar jesopo2019-01-301-16/+25