Commit graph

2472 commits

Author SHA1 Message Date
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