jesopo
a04a29aa2c
add per-channel default mumble server
...
closes #151
2019-09-17 10:45:11 +01:00
jesopo
89289065a9
suggest "!config <nickname> <setting> <value>" when settings are missing
2019-09-17 10:31:28 +01:00
jesopo
c8133e7847
treat config target "*" as current channel or current user in PM
2019-09-17 10:25:42 +01:00
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