Commit graph

2494 commits

Author SHA1 Message Date
jesopo
cf0a81d2e5 permit '!config #channel <setting>' and '!config own_nick <setting>' 2019-09-17 10:21:48 +01:00
jesopo
334d580c57 'seperate_hostmask()' -> 'parse_hostmask()' 2019-09-16 18:43:57 +01:00
jesopo
4ccfd821c8 update channel.topic_setter-related code 2019-09-16 18:41:47 +01:00
jesopo
03892d0ae3 topic_setter should be stored as a Hostmask 2019-09-16 18:38:46 +01:00
jesopo
7e67b07ada add !channels
closes #147
2019-09-16 16:05:36 +01:00
jesopo
6959bba5f3 move getting private_key/our_actor to __init__ (for main thread) 2019-09-16 15:49:03 +01:00
jesopo
6929ff0664 add strip_otr.py
closes #148
2019-09-16 15:29:09 +01:00
jesopo
fa33a927b1 url_for was moved to _module._url_for 2019-09-16 15:05:14 +01:00
jesopo
ea47c81ece expose url-for logic on Exports too 2019-09-16 14:55:29 +01:00
jesopo
ec4501c018 pass exports to ap_server.py 2019-09-16 14:23:06 +01:00
jesopo
f12551532f 'theading' -> 'threading' 2019-09-16 14:19:52 +01:00
jesopo
69032ea476 push inbox POSTs on to a background thread 2019-09-16 14:18:58 +01:00
jesopo
cc65892586 Revert "push inbox PUSHes on to background thread"
This reverts commit 18613311f9.
2019-09-16 13:58:13 +01:00
jesopo
18613311f9 push inbox PUSHes on to background thread 2019-09-16 13:54:07 +01:00
jesopo
f88b054f38 add !crate in rust.py 2019-09-16 12:11:03 +01:00
jesopo
d6960865d6 eval_rust.py -> rust.py 2019-09-16 12:02:35 +01:00
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