jesopo
cefbbe7c5f
return content warning from ap_utils.format_note and show it
...
closes #118
2019-09-16 11:10:49 +01:00
jesopo
050bf0a848
use json_body=True
for ActivityPub requests
2019-09-16 10:57:46 +01:00
jesopo
9d17710d6d
PKCS1v15 is a function
2019-09-16 10:53:10 +01:00
jesopo
55d5692856
refactor AP Note stringifying out to ap_utils.py
2019-09-16 10:51:59 +01:00
jesopo
b8adb6f52d
[:1] -> [:-1]
2019-09-15 22:52:20 +01:00
jesopo
52a7bf400f
'[1:]' -> '[:1]'
2019-09-15 22:50:55 +01:00
jesopo
4ed8906075
strip ":" from "nick: ++"
2019-09-15 22:49:43 +01:00
jesopo
30ead4dcb6
parse "nick: ++" as "nick++"
2019-09-15 22:47:50 +01:00
jesopo
21fa2120df
support "0" kickrejoin delay without creating a timer
2019-09-15 22:22:41 +01:00
jesopo
621fb0b396
event["channel"] -> event["target"]
2019-09-15 21:31:31 +01:00
jesopo
32a9a39e88
'hooked_repos_lowers' -> 'hooked_repos_lower'
2019-09-15 19:59:40 +01:00
jesopo
f8d24bc422
throw on_start() exceptions when tls key/certificate are not present
2019-09-15 17:11:45 +01:00
jesopo
5800fef4c9
use PKCS1v15 for HTTP signatures
2019-09-15 16:31:53 +01:00
jesopo
433e3cdcfb
data
-> post_data
2019-09-15 15:21:26 +01:00
jesopo
4f1f65919d
dict()ify inbox headers
2019-09-15 14:31:36 +01:00
jesopo
ca68b27ccd
actually pass signature and related headers to activity_request()
2019-09-15 14:27:34 +01:00
jesopo
06acbcfb98
readd accidentally lost ")"
2019-09-15 12:23:19 +01:00
jesopo
b22ab564be
actually use method
arg on activity_request()
2019-09-15 12:18:03 +01:00
jesopo
980a407ebb
change follow accept/followback logic to involve our own actor
2019-09-15 12:17:24 +01:00
jesopo
4b42549b55
don't pass actor to Inbox ctor but pass sending actor to .send
2019-09-15 12:15:58 +01:00
jesopo
4caef45299
add missing uuid import to ap_server.py
2019-09-15 11:58:24 +01:00
jesopo
7c6f5c51d3
pass Actor to Inbox
2019-09-15 11:57:42 +01:00
jesopo
676bb53f43
'ap_utils.request' -> 'ap_utils.activity_request'. dont pass privkey
2019-09-15 11:56:03 +01:00
jesopo
f5ab4f690a
pass whole PrivateKey object to ap_security, not just the key
2019-09-15 11:54:07 +01:00
jesopo
7a1eee7990
'security' -> 'ap_security'
2019-09-15 11:53:01 +01:00
jesopo
665a7a8d1a
key_id -> key.id, missing urllib import
2019-09-15 11:51:51 +01:00
jesopo
95d67199ff
Inbox.send should have a self
param
2019-09-15 11:49:53 +01:00
jesopo
863ce32cda
load user inbox before trying to access it
2019-09-15 11:48:58 +01:00
jesopo
c612bb8a15
Revert "Revert "open private key as a bytestring""
...
This reverts commit 97afbc1e40
.
2019-09-15 11:48:01 +01:00
jesopo
13072f53a7
load tls-key, not tls-certificate
2019-09-15 11:47:22 +01:00
jesopo
97afbc1e40
Revert "open private key as a bytestring"
...
This reverts commit 07e73a534e
.
2019-09-15 11:47:16 +01:00
jesopo
07e73a534e
open private key as a bytestring
2019-09-15 11:46:12 +01:00
jesopo
223c04b1a5
why would we be getting the *filename* from security.private_key()?
2019-09-15 11:44:27 +01:00
jesopo
9a7e2fabda
url_for does not exist in _private_key()
2019-09-15 11:43:04 +01:00
jesopo
3b5feaf2d7
missing json import
2019-09-15 11:41:27 +01:00
jesopo
4fb538f486
allow configuring REST API Host, have default public and local ports
2019-09-15 11:37:32 +01:00
jesopo
769d4e1a28
_ap_self_url no longer takes a username param
2019-09-15 11:24:59 +01:00
jesopo
13b25dc55d
'consts' -> 'ap_utils'
2019-09-15 11:24:00 +01:00
jesopo
89072de213
ap_server needs ap_utils import, pass bot instance to it too
2019-09-15 11:19:50 +01:00
jesopo
52a1b885ae
temp remove commands from ap_server.py
2019-09-15 11:07:39 +01:00
jesopo
71896f8081
move AP server event/exports to __init__.py
2019-09-15 11:06:00 +01:00
jesopo
74b9fd5cf3
activities.py -> ap_activities.py
2019-09-15 10:52:55 +01:00
jesopo
7c7ea653cf
send_mode() args should be an array
2019-09-15 10:49:56 +01:00
jesopo
54ee1b3594
re-merge fediverse an fediverse_server, so they can share utils
2019-09-15 10:43:46 +01:00
jesopo
ea34091a83
default REST API port to 5001, not 5000
2019-09-13 15:49:32 +01:00
jesopo
b835c109a0
move fediverse_server to a directory module, add rough outline of toot
...
federation
2019-09-13 11:51:39 +01:00
jesopo
fac0f569b8
remove TLS code from rest_api.py and force it to listen on localhost.
...
this is to force people to put something like nginx proxy_pass between the wider
internet and bitbot's rest api as the python stdlib http.server is not
production-secure.
2019-09-13 11:37:53 +01:00
jesopo
710caebbc4
_parse_flags() should always return 2 objects
2019-09-12 23:13:02 +01:00
jesopo
7094d94cd7
only apply modes for !flags when the user doesn't have them already
2019-09-12 22:40:23 +01:00
jesopo
1edb11ae1f
_check_flags() when flags are changed
2019-09-12 22:40:06 +01:00
jesopo
60ced118a0
get_user_status() -> get_user_modes(), filter in format_activity.py
2019-09-12 22:39:21 +01:00
jesopo
5b538eb5b6
add !b as an alias of !ban
2019-09-12 22:20:36 +01:00
jesopo
9194925739
set a bitbot-specific useragent for fediverse requests
2019-09-12 21:58:26 +01:00
jesopo
612849d0c5
'resetkarme' -> 'resetkarma'
2019-09-12 21:57:40 +01:00
jesopo
04489ce90a
return command (in case resolved alias) from _find_command_hook()
2019-09-12 21:53:52 +01:00
jesopo
2d7a192a6c
limit !flags mode changes to 3-per-line, add comment as to why
2019-09-12 15:13:42 +01:00
jesopo
8ac0fce53f
remove debug prints
2019-09-12 15:12:31 +01:00
jesopo
778cfe2010
remove extra ")"
2019-09-12 15:00:33 +01:00
jesopo
12fea0a38f
sort uppercase chars after lowercase chars for !flags
2019-09-12 15:00:00 +01:00
jesopo
5206bf3d47
remove auto_mode.py, it has been superseded by !flags
2019-09-12 14:55:43 +01:00
jesopo
ad85536389
check a user is authenticated before applying modes, catch login too
2019-09-12 14:55:26 +01:00
jesopo
6b5e0791be
first draft of !flags system
2019-09-12 14:29:28 +01:00
jesopo
9cda86065b
use utils.SensitiveSetting in nickserv.py
2019-09-12 12:17:52 +01:00
jesopo
ba0911f2e7
add utils.Setting.format() so subtypes can format differently
2019-09-12 12:17:09 +01:00
jesopo
e68c5575d1
'karma-verbose' -> 'karma-pattern'. don't even parse when false
2019-09-12 12:09:16 +01:00
jesopo
8081a014ce
remove now-unneeded "--require-config tls-certificate" from fediverse.py
2019-09-12 11:31:01 +01:00
jesopo
1b44b58aca
add !invite
2019-09-12 10:24:10 +01:00
jesopo
ad45848abb
Revert "switch to using IRCBot.http_client() in title.py"
...
This reverts commit 748008cf36
.
2019-09-11 18:08:37 +01:00
jesopo
748008cf36
switch to using IRCBot.http_client() in title.py
2019-09-11 17:54:55 +01:00
jesopo
4a97c9eb0d
refactor utils.http.requests to support a Request object
2019-09-11 17:44:07 +01:00
jesopo
4639951897
make context/conversation a "valid" URI
2019-09-11 13:46:21 +01:00
jesopo
72e99a2ce0
inbox should have https:// on it
2019-09-11 12:58:32 +01:00
jesopo
9988a49518
use correct link "type" for webfinger response
2019-09-11 12:49:10 +01:00
jesopo
cf9c82b131
force content-length on to REST API responses
2019-09-11 11:00:55 +01:00
jesopo
b6133579d1
return url
on actor
2019-09-11 10:54:36 +01:00
jesopo
0d0a7b95ef
force "acct:" on resource
key on webfinger response
2019-09-11 10:53:57 +01:00
jesopo
bbef6ee392
remove (i think) unneeded @context, add user summary and name
2019-09-11 10:42:59 +01:00
jesopo
7a860240ef
set content_type=ACTIVITY_TYPE on outbox
2019-09-10 18:48:26 +01:00
jesopo
ed07149257
remove unused duplicate ACTIVITY_TYPE
2019-09-10 18:48:15 +01:00
jesopo
be6f875e25
Revert "call self.finish() in rest_api.py in hopes it will force-close connections"
...
This reverts commit 5d6b2ff083
.
2019-09-10 18:33:14 +01:00
jesopo
5d6b2ff083
call self.finish() in rest_api.py in hopes it will force-close connections
2019-09-10 18:28:50 +01:00
jesopo
1dfb3c4461
'_prepare_actitivy' -> '_prepare_activity'
2019-09-10 18:21:20 +01:00
jesopo
02b038e15f
get_activities is a list, not a dict
2019-09-10 18:20:22 +01:00
jesopo
8726bd9717
implement first draft of fediverse outbox
2019-09-10 18:08:58 +01:00
jesopo
74d2c18954
return error codes from webfinger
2019-09-10 17:34:01 +01:00
jesopo
a99f359266
fix setting exported from fediverse_server.py
2019-09-10 17:33:49 +01:00
jesopo
c697c3bbb2
split out fediverse server to it's own module
2019-09-10 17:32:41 +01:00
jesopo
e96783dfac
support webfinger resource not having "acct:" on the front
2019-09-10 16:51:08 +01:00
jesopo
e048f61c73
.strip() client cert to remove needless newlines
2019-09-10 16:42:09 +01:00
jesopo
d75d33c42c
"%s", not "%d", cuz port
is a str
2019-09-10 16:41:16 +01:00
jesopo
a02bfdf157
get REST API port from settings if it's not in Host header
2019-09-10 16:39:44 +01:00
jesopo
d2de2cca7d
'index' -> 'inbox'
2019-09-10 16:30:54 +01:00
jesopo
7636843fc7
'get_params' -> 'get_params_str'
2019-09-10 16:29:35 +01:00
jesopo
b6f4e9c458
'location' -> 'self_id'
2019-09-10 16:24:11 +01:00
jesopo
eb5b0c25b6
'for_url' -> 'url_for', '_ap_self._id' -> '_ap_self_id'
2019-09-10 16:22:54 +01:00
jesopo
7dac75e566
implement ActivityPub user endpoint
2019-09-10 16:21:31 +01:00
jesopo
49527495b8
CaseInsensitiveDict does not implement .get() yet
2019-09-10 15:59:54 +01:00
jesopo
6b17c64b15
'resouce' -> 'resource'
2019-09-10 15:51:58 +01:00
jesopo
3993447eeb
'account' is no longer reformatted u@instance
2019-09-10 15:46:25 +01:00
jesopo
90d0452bfd
first draft of ActivityPub webfinger
2019-09-10 15:40:01 +01:00
jesopo
ef7da3409b
don't bother sorting json keys when the json is minified
2019-09-10 15:08:06 +01:00
jesopo
9ac46bab7d
duplicate 'rest-api' setting - copypaste issue for rest-api-minify
2019-09-10 15:00:47 +01:00
jesopo
2fc75c6af7
move more REST API code on to the main thread
2019-09-10 13:55:06 +01:00
jesopo
8653068650
'code' -> 'response.code'
2019-09-10 13:45:55 +01:00
jesopo
4a08c2d134
set response.code=200 as soon as we know there's a hook waiting for it
2019-09-10 13:45:14 +01:00
jesopo
fefb9d71fb
'event_response' -> 'obj' (copypaste error)
2019-09-10 13:39:59 +01:00
jesopo
3a0183eb03
refactor REST API to use a Response object
2019-09-10 13:38:25 +01:00
jesopo
7fbb5b2823
don't use full event names to check what command we're in
2019-09-10 12:59:52 +01:00
jesopo
bad108d7ce
support disabling word tracking per channel, not just per user
2019-09-10 10:34:44 +01:00
jesopo
a9d11fc7f8
use rpartition, not partition, to avoid splitting on leading @
2019-09-09 21:35:54 +01:00
jesopo
6d176a6aa1
add !unsilence
2019-09-09 18:06:37 +01:00
jesopo
0c5171a44f
add +time param to !silence
2019-09-09 18:06:27 +01:00
jesopo
695c7982a6
add a special flag to allow commands to bypass !silence
2019-09-09 18:05:10 +01:00
jesopo
c8ece388cc
use detect_encoding=False in github webhook url shortening
2019-09-09 16:08:51 +01:00
jesopo
8e824c9277
add !8 as alias of !8ball
2019-09-09 14:25:19 +01:00
jesopo
98931de283
remove redundant (and maybe wrong) GET params from webfinger call
...
closes #143
2019-09-09 10:30:06 +01:00
jesopo
b1033a0721
support location names for !timezone too
2019-09-08 18:22:04 +01:00
jesopo
95c007c1da
support showing time for locations, not just users
2019-09-08 18:17:32 +01:00
jesopo
896b98bbd1
remove LOW priority from youtube regex - it doesnt need it
2019-09-08 12:21:28 +01:00
jesopo
d0202ff809
don't disregard matched backslashes before ampersand
2019-09-08 11:43:13 +01:00
jesopo
9e0934a47e
support sed ampersand syntax
2019-09-08 11:18:08 +01:00
jesopo
a59afb883a
accept "," as well as ":" as a sed target marker
2019-09-07 22:38:21 +01:00
jesopo
b807ffbba8
force timezone info on to badge dates
2019-09-07 22:02:08 +01:00
jesopo
aa2e7249b2
use default webfinger url when host-meta lookups fail
2019-09-07 21:49:22 +01:00
jesopo
40d98b0034
only strip "@" once from the start of fedi usernames
2019-09-07 17:44:20 +01:00
jesopo
c914870094
only strip "nick: " prefix from karma when the nickname is known
2019-09-07 17:39:24 +01:00
jesopo
c631575e4f
don't group capture disregarded "nick: " prefix in karma
2019-09-07 17:34:55 +01:00
jesopo
4e617366d3
change to karma regex to best-effort strip "nick: "
2019-09-07 17:34:04 +01:00
jesopo
1340691413
support /embed/<id> youtube urls too
2019-09-07 16:28:18 +01:00
jesopo
dadefeb8f3
remove try-rejoin (on 477) logic. will move to a module later
2019-09-07 15:21:35 +01:00
jesopo
4c2c4a501c
return quote category even if =quote isnt present
2019-09-07 15:17:30 +01:00
jesopo
b654660d96
477 should check that we're *not* in a channel before trying rejoin
2019-09-07 14:25:43 +01:00
jesopo
ec5c5808a5
better wording of "!stats <alias>"
2019-09-07 14:16:27 +01:00
jesopo
34e5f976cc
support showing !stats per-network
2019-09-07 14:13:44 +01:00
jesopo
1cadbc79ac
disregard empty JOIN channel params (e.g. "JOIN #bad,")
2019-09-07 12:58:20 +01:00
jesopo
ea97dbb16d
Show the line that was actually send from !raw, after format and filter
2019-09-07 12:50:50 +01:00
jesopo
0a74a93672
'reconnections' dict is on IRCBot, not IRCServer
2019-09-07 12:22:54 +01:00
jesopo
6d1e7ad4b2
remove !qadd because !quote does the same things now
2019-09-05 18:09:16 +01:00
jesopo
7d96d346e1
show how many quotes found when searching with !quote
2019-09-05 18:09:02 +01:00
jesopo
0563305b20
support searching for quote content in !quote
2019-09-05 18:05:50 +01:00
jesopo
905abf46f0
automatically PART blacklisted channels if we join them (SAJOIN e.g.)
2019-09-05 15:16:18 +01:00
jesopo
d4bfde1a71
use tweet_mode="extended" for !tw user_timeline() calls too
2019-09-05 14:46:39 +01:00
jesopo
1e16cf601e
don't just remove the first key in a JOIN when there's a blacklisted channel
2019-09-05 14:32:30 +01:00
jesopo
6e4ec91003
add channel_blacklist.py
2019-09-05 14:14:21 +01:00
jesopo
0578d9ef5b
'bot' -> '_bot'
2019-09-05 14:13:40 +01:00
jesopo
638df8729e
switch to using pytz instead of an API for localised time
2019-09-05 12:25:17 +01:00
jesopo
1e79ed4249
remove debug prints from info.py
2019-09-05 11:58:35 +01:00
jesopo
1d95d2d12d
'recieved' -> 'received'
2019-09-04 15:59:37 +01:00
jesopo
62faf62b82
add !grab as an alias of !quotegrab
2019-09-04 15:54:43 +01:00
jesopo
9561cba168
add which.py - closes #134
2019-09-04 15:39:56 +01:00