location ~ ^/_matrix/client/(r0|unstable)/register$ { proxy_pass http://127.0.0.1:8008; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $host; body_filter_by_lua_block { local proc = io.popen('/usr/local/bin/matrix_user_registered ' .. ngx.var.remote_addr,'w') proc:write(ngx.arg[1]) proc:close() } }
#!/usr/bin/zsh # access token of @abuse:… AT='MDMA...' # admin room to send notifications to ROOM='!x1y2z3:example.com' # ip of the new user, with gdpr redaction to /24 IP=`echo $1|cut -d. -f1-3`.0 #read stdin SI=`/bin/cat` #try to retrieve new user id U=`echo $SI|jq -r .user_id` [ -z "$U" ] && exit 0 [ "null" = "$U" ] && exit 0 # send notification curl -X PUT "https://asra.gr/_matrix/client/r0/rooms/${ROOM}/send/m.room.message/"`uuid -m -F SIV`"?access_token=${AT}" -H "accept: application/json" -H "Content-Type: application/json" -d "{ \"body\": \"@room New user registered: ${U} from ${IP}\", \"msgtype\": \"m.text\"}" >> /tmp/reguser.txt 2>> /tmp/reguser.txt
location ~ ^/_matrix/client/(r0|unstable)/rooms/.*/report/ { proxy_pass http://127.0.0.1:8008; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $host; rewrite_by_lua ' if ngx.var.request_method == "POST" then os.execute("/usr/local/bin/matrix_event_reported") end '; }
#!/bin/sh AT='MDMA...' ROOM='!x1y2z3:example.com' # log abuse reports echo date $* >> /tmp/report.log # TODO: abuse reports should be forwarded to appropriate admins or # abuse contacts. since some servers don't implement MSC 1929 # an idea is to implement a semi automatic filled db of some kind #https://asra.gr/.well-known/matrix/support # abuse@matrix.org: https://matrix.to/#/!OGEhHVWSdvArJzumhm:matrix.org/$3CNYJIakytzbO6qI4eR8JmCVJUMUUm57YmjJJIOR-ic curl -X PUT "https://asra.gr/_matrix/client/r0/rooms/${ROOM}/send/m.room.message/"`uuid -m -F SIV`"?access_token=${AT}" -H "accept: application/json" -H "Content-Type: application/json" -d "{ \"body\": \"@room there was a event reported\", \"msgtype\": \"m.text\"}"