jesopo
|
709365ecf8
|
Utilise new line-tracking logic to reconnect when QUIT sends (admin.py)
|
2019-02-10 14:26:24 +00:00 |
|
jesopo
|
d5bb3c5405
|
Have to refer to timer.kwargs to get kwargs (in.py)
|
2019-02-10 13:27:49 +00:00 |
|
jesopo
|
25096c651a
|
Don't require client cert validation (rest_api.py)
|
2019-02-10 13:26:35 +00:00 |
|
jesopo
|
985f4d60a4
|
Only add a waiting clause for resume CAP if the server actually ACKs it
(resume.py)
|
2019-02-10 13:22:53 +00:00 |
|
jesopo
|
c7d21e2d9e
|
Typo, 'wrap_scket' -> 'ssl_wrap' (rest_api.py)
|
2019-02-10 13:20:22 +00:00 |
|
jesopo
|
93dd75ff31
|
Added !inlist, to list !in reminders (in.py)
|
2019-02-10 13:18:25 +00:00 |
|
jesopo
|
1d206fe78f
|
Use newly abstracted away ssl_wrap (rest_api.py)
|
2019-02-10 12:38:53 +00:00 |
|
jesopo
|
05ae25d3d7
|
ERROR log ERROR s from servers (line_handler.py)
|
2019-02-10 12:22:01 +00:00 |
|
jesopo
|
71eac9d3c0
|
Treat a QUIT from hostmask :* as referring to our connection (line_handler.py)
|
2019-02-10 00:29:22 +00:00 |
|
jesopo
|
ffdf49efc9
|
CAP END for RESUME TOKEN and RESUME ERR , don't for RESUME SUCCESS (resume.py)
|
2019-02-10 00:12:45 +00:00 |
|
jesopo
|
20d75e9716
|
Send request to RESUME a session AFTER we have a new token (resume.py)
|
2019-02-10 00:03:14 +00:00 |
|
jesopo
|
e2b019a9b8
|
log calls need a params arg (resume.py)
|
2019-02-10 00:02:24 +00:00 |
|
jesopo
|
84a3bf6135
|
Also capture channel setting-related modes (e.g. +f for flood settings)
|
2019-02-09 18:48:18 +00:00 |
|
jesopo
|
90618e883b
|
Move REGEX_CUTOFF to outs.py (commands)
|
2019-02-09 17:52:51 +00:00 |
|
jesopo
|
1ff2a00c48
|
Move StdOut/StdErr specific consts to outs.py (commands)
|
2019-02-09 17:50:40 +00:00 |
|
jesopo
|
6b042d9460
|
Split command StdOut/StdErr in to their own file (commands)
|
2019-02-09 17:49:01 +00:00 |
|
jesopo
|
b9e71ec833
|
title is already a parsed string from _get_title() (title.py)
|
2019-02-09 13:38:09 +00:00 |
|
jesopo
|
8bbfd1d1c3
|
Add empty params arg to log call (title.py)
|
2019-02-09 13:37:21 +00:00 |
|
jesopo
|
730a4e6b87
|
Don't use the event system to get results from other modules - use exports
|
2019-02-09 13:14:45 +00:00 |
|
jesopo
|
4bc43f686e
|
'username' -> 'nickname', update RESUME nickname when our nickname changes (resume.py)
|
2019-02-09 12:33:26 +00:00 |
|
jesopo
|
d3f5ff78a6
|
Another 'new-token' -> 'new-resume-token' (resume.py)
|
2019-02-09 12:27:37 +00:00 |
|
jesopo
|
a23e46ddbf
|
'def on_cap_new' -> 'def on_cap_ls' (resume.py)
|
2019-02-09 12:27:13 +00:00 |
|
jesopo
|
1e6e030d6f
|
Actually do 'resume' -> 'resume-token' (resume.py)
|
2019-02-09 12:26:47 +00:00 |
|
jesopo
|
feffb2325b
|
"resume" -> "resume-token", "new-token" -> "new-resume-token", typo that was
causing resume token to be deleted as soon as it was set (resume.py)
|
2019-02-09 12:23:37 +00:00 |
|
jesopo
|
3fae5c52cd
|
Forgot to import EventManager (title.py, youtube.py)
|
2019-02-09 10:57:32 +00:00 |
|
jesopo
|
31367b2b5d
|
Eat youtube URLs on LOW priority, switch auto-title to MONITOR priority
|
2019-02-09 10:56:06 +00:00 |
|
jesopo
|
9f6aa93082
|
Actually return title text, not html Tag object (title.py)
|
2019-02-09 10:38:44 +00:00 |
|
jesopo
|
2ac5a53131
|
Add a setting to get the title from URLs automatically (title.py)
|
2019-02-09 10:35:37 +00:00 |
|
jesopo
|
6018cc098d
|
We still need to 'CAP REQ :sasl' when we get 'CAP NEW :sasl' (sasl)
|
2019-02-09 02:58:25 +00:00 |
|
jesopo
|
697ce2ba30
|
Do a SASL reauthentication when we get CAP NEW for SASL (sasl)
|
2019-02-08 23:12:14 +00:00 |
|
jesopo
|
42e2596c9b
|
Return semi-helpful information to github webhooks (github)
|
2019-02-08 23:01:45 +00:00 |
|
jesopo
|
d772eaf36e
|
need to .items() a dict to tuple-iterate it (rest_api.py)
|
2019-02-08 22:53:33 +00:00 |
|
jesopo
|
678e6606ed
|
Abstract away sending response to REST API request (rest_api.py)
|
2019-02-08 22:04:39 +00:00 |
|
jesopo
|
4a68baa0a6
|
Return path from _path_data() (rest_api.py)
|
2019-02-08 21:56:58 +00:00 |
|
jesopo
|
e84f91977c
|
Typo, 'utils.parse' -> 'urllib.parse' (rest_api.py)
|
2019-02-08 21:55:42 +00:00 |
|
jesopo
|
12591d2357
|
Remove now not used params on _request() (rest_api.py)
|
2019-02-08 21:54:33 +00:00 |
|
jesopo
|
c7843a9338
|
Simplify/refactor REST API request parsing code (rest_api.py)
|
2019-02-08 21:52:24 +00:00 |
|
jesopo
|
dc0a021231
|
Show capabilities in API server stats (stats.py)
|
2019-02-08 17:56:13 +00:00 |
|
jesopo
|
9a0b8f3d00
|
server_capabilities is a dict, capabilities is a set (line_handler.py)
|
2019-02-08 17:48:41 +00:00 |
|
jesopo
|
91f78e834e
|
Still REQ CAPs caught from cap.ls command if line_handler.py doesn't request any
|
2019-02-08 17:32:43 +00:00 |
|
jesopo
|
518f32c4ec
|
Fix 2 misspellings of "capabilities" and fix having not changed a variable name
|
2019-02-08 17:32:00 +00:00 |
|
jesopo
|
15ab772442
|
Request CAPs we support when we see them advertised with CAP NEW
(line_handler.py)
|
2019-02-08 17:30:07 +00:00 |
|
jesopo
|
d3f23eafb8
|
make !sp and alias of !spotify (spotify.py)
|
2019-02-08 15:34:04 +00:00 |
|
jesopo
|
d61bb387f7
|
Show when a check_run is queued (github)
|
2019-02-07 23:05:29 +00:00 |
|
jesopo
|
a1496e5415
|
Check that a check_run actually started before it finished (github)
|
2019-02-07 22:59:50 +00:00 |
|
jesopo
|
03a1f62297
|
Script travis module in favour of github webhook check_run events
|
2019-02-07 22:34:54 +00:00 |
|
jesopo
|
fb125081ad
|
Turn seconds in to seconds/minutes/hours/etc (github)
|
2019-02-07 22:32:48 +00:00 |
|
jesopo
|
ede385aca8
|
Use check_run event instead of status for CI (github)
|
2019-02-07 22:30:50 +00:00 |
|
Evelyn
|
ce78bd850a
|
quit: add quote
|
2019-02-07 18:21:35 +00:00 |
|
jesopo
|
53a819512f
|
Make commit hash LIGHTBLUE in status event (github)
|
2019-02-07 15:56:30 +00:00 |
|
jesopo
|
58cd6338fd
|
Color/bold status state (github)
|
2019-02-07 15:49:36 +00:00 |
|
jesopo
|
c401c45a02
|
typo, "_short_id" -> "_short_hash" (github)
|
2019-02-07 15:46:07 +00:00 |
|
jesopo
|
f6079d92c8
|
Remove hanging "or" that i forgot to remove (line_handler.py)
|
2019-02-07 14:26:36 +00:00 |
|
jesopo
|
172acfd0d5
|
Tidy up logic to figure out of a NOTICE is a AUTH notice (line_handler.py)
|
2019-02-07 14:25:56 +00:00 |
|
jesopo
|
f5f5a55e21
|
Add command to list, add and remove travis webhooks (travis)
|
2019-02-07 14:05:12 +00:00 |
|
jesopo
|
0bdac094ea
|
Actually accept !ghwebhook list as a command (github)
|
2019-02-07 14:01:24 +00:00 |
|
jesopo
|
7d25ce44ad
|
Use HTML entity for less-than symbol (sasl README.md)
|
2019-02-07 13:53:46 +00:00 |
|
jesopo
|
35ad1c7c7b
|
Add SASL README.md
|
2019-02-07 13:51:08 +00:00 |
|
jesopo
|
a3ca29dabe
|
Show server name when we log a SASL failure (sasl)
|
2019-02-07 12:23:11 +00:00 |
|
jesopo
|
1485947fcc
|
First commit of travis webhook module
|
2019-02-07 11:49:42 +00:00 |
|
jesopo
|
90591ec5b4
|
Change isgd.py to use Exports to offer url shortening, not events
|
2019-02-07 10:07:11 +00:00 |
|
jesopo
|
d013703705
|
commit_comment events have commit_id in comment , not in the root data (github)
|
2019-02-07 07:42:05 +00:00 |
|
jesopo
|
7dd1eca7ae
|
Don't use string concat when we're already using %s formatting (sasl.scram)
|
2019-02-06 23:04:26 +00:00 |
|
jesopo
|
65766a093a
|
Add more comments, re-seperate out self._ variables and seperate some compound
function calls on to different lines for readability (sasl.scram)
|
2019-02-06 22:58:16 +00:00 |
|
jesopo
|
c77d8aaac8
|
Default error to "" , _client_first /_salted_password /_auth_message to b""
(sasl.scram)
|
2019-02-06 22:36:25 +00:00 |
|
jesopo
|
1bac2f67de
|
Add type hints to SCRAM ctor (sasl.scram)
|
2019-02-06 22:33:30 +00:00 |
|
jesopo
|
50a8de2792
|
Restrict scram algorithms to IANA Hash Function Textual Names (sasl.scram)
|
2019-02-06 22:28:50 +00:00 |
|
jesopo
|
4e3e782519
|
Remove pointless local auth_message variable (sasl.scram)
|
2019-02-06 22:00:23 +00:00 |
|
jesopo
|
efbbe4c3db
|
Move parsing username, password and algorithm to the only place that uses it and
add comments (sasl.scram)
|
2019-02-06 21:49:44 +00:00 |
|
jesopo
|
bffd43648d
|
uuid.uuid4() is not random enough for a nonce (sasl.scram)
|
2019-02-06 21:49:24 +00:00 |
|
jesopo
|
67252833c4
|
Remove pointless local salted_password variable (sasl.scram)
|
2019-02-06 21:19:25 +00:00 |
|
jesopo
|
cbdd8d6fc9
|
Remove pointless local assign of self._password (sasl.scram)
|
2019-02-06 21:16:55 +00:00 |
|
jesopo
|
90b540d5dc
|
Add type annotations to scram util functions (sasl)
|
2019-02-06 21:05:20 +00:00 |
|
jesopo
|
bf3986a1be
|
Log a WARN when we get a 904 (failed sasl)
|
2019-02-06 16:25:43 +00:00 |
|
jesopo
|
16ea48cb54
|
Assume we'll receive a 904 when SCRAM fails with an e= param (sasl)
|
2019-02-06 15:50:42 +00:00 |
|
jesopo
|
c006435fa1
|
Set SCRAM state to just Failure if there's a server-final-message error (sasl)
|
2019-02-06 15:41:31 +00:00 |
|
jesopo
|
09eb3d3314
|
Only panic about a scram failure if it's a server-final-message failure (sasl)
|
2019-02-06 15:38:59 +00:00 |
|
jesopo
|
0e63700761
|
Only send auth_text if it's not None (sasl)
|
2019-02-06 15:37:34 +00:00 |
|
jesopo
|
be95514174
|
auth_text would not be present in a failure scenario
|
2019-02-06 15:36:59 +00:00 |
|
jesopo
|
cfa590eef7
|
Handle error on server-final-message (sasl.scram)
|
2019-02-06 15:28:17 +00:00 |
|
jesopo
|
403466dee3
|
Remove particularly improper quit quotes, add Hillel the Elder quote (quit.py)
|
2019-02-06 14:22:27 +00:00 |
|
jesopo
|
3e54542b6a
|
arguments was not defined if they weren't provided (sasl)
|
2019-02-06 11:22:13 +00:00 |
|
jesopo
|
0004a8a59c
|
Fix mypy linting issue with dict creation (scram.py)
|
2019-02-06 11:09:45 +00:00 |
|
jesopo
|
a7554b835e
|
"+" as part of a SASL handshake is irc-specific so remove it from scram.py
|
2019-02-06 11:07:50 +00:00 |
|
jesopo
|
6b4bb7cdba
|
Type annotate scram.py and don't pass base64 data to scram.py functions
|
2019-02-06 08:50:19 +00:00 |
|
jesopo
|
13083e60a6
|
Don't take a users coins when they make an invalid roulette bet (coins.py)
|
2019-02-05 23:00:56 +00:00 |
|
jesopo
|
aa7aa17ec1
|
Split hash and hmac logic out to their own functions (sasl.scram)
|
2019-02-05 22:53:55 +00:00 |
|
jesopo
|
5d51a283bb
|
Actually check that we don't have CAPs that we're waiting on a ACK/NAK for
before ending CAP negotiation (line_handler.py)
|
2019-02-05 22:26:57 +00:00 |
|
jesopo
|
5991e02b0a
|
Manually count ACK/NAK for REQed CAPs before ENDing CAP negotiation
|
2019-02-05 19:20:02 +00:00 |
|
jesopo
|
ff2d5ef7e7
|
Disconnect from server and throw an exception if SCRAM server verification fails
(sasl)
|
2019-02-05 17:04:00 +00:00 |
|
jesopo
|
fd08e23bd4
|
Move scripts module to it's own directory
|
2019-02-05 16:56:21 +00:00 |
|
jesopo
|
8e59809db2
|
CAP capabilities would not be index 2 if the line is multiline
(line_handler.py)
|
2019-02-05 16:48:12 +00:00 |
|
jesopo
|
b742b1ecee
|
Remove debug print in sasl/__init__.py
|
2019-02-05 15:58:11 +00:00 |
|
jesopo
|
1fe20a2c98
|
Move sasl.py to a directory module and move SCRAM logic to a different file,
move `github/module.py` to `github/__init__.py`
|
2019-02-05 15:54:20 +00:00 |
|
jesopo
|
d4503fdf28
|
Remove SCRAM-related variables on IRCServer object when we see
server-final-message (sasl.py)
|
2019-02-05 12:53:19 +00:00 |
|
jesopo
|
d68c73affa
|
Remove SCRAM debug logging (sasl.py)
|
2019-02-05 12:34:50 +00:00 |
|
jesopo
|
51a4b8ef4e
|
Support SCRAM SASL mechanisms (sasl.py)
|
2019-02-05 12:17:25 +00:00 |
|
jesopo
|
0344ad6470
|
Add ")" that should have been removed when we stopped using enumerate for
github webhook hooks (github)
|
2019-02-04 21:35:31 +00:00 |
|
jesopo
|
ac16887c48
|
Reply to statusmsg commands (e.g. '/msg +channel !ping') with the same statusmsg
|
2019-02-04 21:32:44 +00:00 |
|
jesopo
|
e2d60a541c
|
Try to match against full repository name first, so that we can make specific
rules for specific repositories (github)
|
2019-02-04 10:17:27 +00:00 |
|
jesopo
|
66d2ef2c26
|
We don't need to enumerate hooks (github)
|
2019-02-04 10:17:15 +00:00 |
|
jesopo
|
36e838d585
|
Delete automodes user_channel setting when it's empty (auto_mode.py)
|
2019-02-04 08:45:48 +00:00 |
|
jesopo
|
d7d707d980
|
user doesn't exist in _move(), it's user1 (coins.py)
|
2019-02-02 20:41:08 +00:00 |
|
jesopo
|
1b94a72a65
|
apikey command should have a minimum argument restriction (rest_api.py)
|
2019-02-01 12:02:02 +00:00 |
|
jesopo
|
520d8b681f
|
Actually add private_unban function def. oops. (channel_op.py)
|
2019-01-30 21:07:03 +00:00 |
|
jesopo
|
d2dbb0a249
|
Add private message unban command (channel_op.py)
|
2019-01-30 21:06:02 +00:00 |
|
jesopo
|
98e1d4460e
|
Actually use channel arg in _kick_command (channel_op.py)
|
2019-01-30 21:03:21 +00:00 |
|
jesopo
|
8345ea36d4
|
Support kick and ban command in private message (channel_op.py)
|
2019-01-30 21:02:12 +00:00 |
|
jesopo
|
cd93118571
|
server.get_channel was moved to server.channels.get a long time ago (set.py)
|
2019-01-30 19:40:20 +00:00 |
|
jesopo
|
a2e23acc61
|
Logging takes format params as a separate arg (commands.py)
|
2019-01-30 19:39:03 +00:00 |
|
jesopo
|
72072bbd3d
|
Make sure to call the specific hook we've decided is valid (commands.py)
|
2019-01-30 19:35:43 +00:00 |
|
jesopo
|
8ac989fa96
|
check we have a channel_arg kwarg before parsing it as an int
(channel_access.py)
|
2019-01-30 19:20:11 +00:00 |
|
jesopo
|
0e66921d34
|
Break when we've found a suitable command hook (commands.py)
|
2019-01-30 19:15:11 +00:00 |
|
jesopo
|
b0d67e5170
|
Use correct arg indexes for private channelset (set.py)
|
2019-01-30 19:07:34 +00:00 |
|
jesopo
|
051e4347f9
|
Actually remove call to preprocess.command to after min_args check
(commands.py)
|
2019-01-30 11:41:25 +00:00 |
|
jesopo
|
f25bfd0ae2
|
Correctly check if we're in a channel command before checking if the current
hook is valid (commands.py)
|
2019-01-30 11:37:47 +00:00 |
|
jesopo
|
c822a1afd6
|
Check min_args before we check if a user has permission (commands.py)
|
2019-01-30 11:37:29 +00:00 |
|
jesopo
|
fc39f8f9fc
|
We need to turn channel_arg in to an int (channel_access.py)
|
2019-01-30 11:28:38 +00:00 |
|
jesopo
|
fc4a8d8e34
|
We should be using potential_hook until we've decided on a valid hook
(commands.py)
|
2019-01-30 11:26:54 +00:00 |
|
jesopo
|
64d12e3415
|
Get all hooks when checking command hooks, not just the first (commands.py)
|
2019-01-30 11:23:17 +00:00 |
|
jesopo
|
8a832b7230
|
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)
|
2019-01-30 11:20:14 +00:00 |
|
jesopo
|
b197a537f0
|
Add a private channelset command (set.py)
|
2019-01-30 11:16:42 +00:00 |
|
jesopo
|
2071a10180
|
Support a way to check user channel access in a private command
(channel_access.py)
|
2019-01-30 11:16:34 +00:00 |
|
jesopo
|
bb84fc0291
|
Add a permission to !channelunset and !channelget (set.py)
|
2019-01-30 08:10:41 +00:00 |
|
jesopo
|
9491a44295
|
Correctly compare current time and token expire time and actually cache the
token (spotify.py)
|
2019-01-29 22:46:00 +00:00 |
|
jesopo
|
d178938463
|
Typo, {,} instead of {:} made headers a set (spotify.py)
|
2019-01-29 22:40:44 +00:00 |
|
jesopo
|
a177c5050e
|
URL_SPOTIFY was renamed to URL_SEARCH (spotify.py)
|
2019-01-29 22:39:58 +00:00 |
|
jesopo
|
74e8ad0351
|
Forgot to import time (spotify.py)
|
2019-01-29 22:39:13 +00:00 |
|
jesopo
|
8acc01dd48
|
post_data is the kwarg for POST data, not data (spotify.py)
|
2019-01-29 22:38:31 +00:00 |
|
jesopo
|
bb047ec1b7
|
base64.b64encode(...) takes a byte array, not a string (spotify.py)
|
2019-01-29 22:37:44 +00:00 |
|
jesopo
|
af7a765547
|
Forgot to import base64 (spotify.py)
|
2019-01-29 22:36:54 +00:00 |
|
jesopo
|
2d085e7f91
|
Spotify now requires access tokens to use it's API (spotify.py)
|
2019-01-29 22:34:28 +00:00 |
|
jesopo
|
0c319be1e5
|
Correct usage help for kickban/tempkickban (channel_op.py)
|
2019-01-29 17:37:14 +00:00 |
|
jesopo
|
5e91f0d209
|
Remove haveibeenpwned.py , it's 99% useless
|
2019-01-29 16:01:43 +00:00 |
|
jesopo
|
a501fdea1f
|
Stop processing a command when we've decided the user doesn't have permission
(commands.py)
|
2019-01-29 15:38:04 +00:00 |
|
jesopo
|
249734ebef
|
We don't have an event object in _has_channel_access (channel_access.py)
|
2019-01-29 15:35:38 +00:00 |
|
jesopo
|
e0722dfc8a
|
Seperate out access checking logic so we can call across-modules with the event
system to check if users have specific channel access (channel_access.py)
|
2019-01-29 15:33:55 +00:00 |
|
jesopo
|
7937be5128
|
Don't double up command prefix in !usage output (commands.py)
|
2019-01-29 08:36:47 +00:00 |
|
jesopo
|
f97c1f02fd
|
Actually show the command prefix we now pass to _get_usage (commands.py)
|
2019-01-29 08:33:32 +00:00 |
|
jesopo
|
79ff20b66a
|
Show command prefix in usage strings (commands.py)
|
2019-01-29 08:32:22 +00:00 |
|
jesopo
|
5d47e7e895
|
Add a permission to !ghwebhook so an admin user can use it without +o (github)
|
2019-01-29 08:06:59 +00:00 |
|
jesopo
|
0564a173a3
|
Typo, 'acess' -> 'access' (channel_access.py)
|
2019-01-29 07:35:48 +00:00 |
|
jesopo
|
66b2ffee68
|
Support * as a channel permission, to give users all access
(channel_access.py)
|
2019-01-29 07:32:25 +00:00 |
|
jesopo
|
5e5a62044c
|
We don't need a seperate command for !channelset override (set.py)
|
2019-01-29 07:18:03 +00:00 |
|
jesopo
|
08404c4694
|
Use new utils.consts.PERMISSION_FORCE_SUCCESS in permissions.py
|
2019-01-29 07:14:53 +00:00 |
|
jesopo
|
f9446a3663
|
Show an error when an unknown subcommand is given to !access (channel_access.py)
|
2019-01-29 00:14:33 +00:00 |
|
jesopo
|
10b2ace653
|
Add require_access to commands on channel_op.py
|
2019-01-29 00:08:21 +00:00 |
|
jesopo
|
a3a535b195
|
Delete a user's 'access' channel setting when they have no permissions left
(channel_access.py)
|
2019-01-29 00:02:56 +00:00 |
|
jesopo
|
1b933e7c00
|
IRCUser.User objects don't have .id , they have .get_id() (channel_access.py)
|
2019-01-29 00:00:15 +00:00 |
|
jesopo
|
549332db38
|
Check a return is truthy before we decide it's an error (command.py)
|
2019-01-28 23:57:12 +00:00 |
|