update readme, doc, and status / return codes
This commit is contained in:
		
					parent
					
						
							
								7f466261d1
							
						
					
				
			
			
				commit
				
					
						1b31e7bba9
					
				
			
		
					 2 changed files with 12 additions and 12 deletions
				
			
		| 
						 | 
				
			
			@ -10,6 +10,7 @@ environment variables:
 | 
			
		|||
- `MATRIX_URL`: the url of the matrix homeserver
 | 
			
		||||
- `MATRIX_ID`: the user id of the bot on this server
 | 
			
		||||
- `MATRIX_PW`: the password for this user
 | 
			
		||||
- `API_KEY`: a secret to share with the users of the service
 | 
			
		||||
 | 
			
		||||
## Dev
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -33,6 +34,6 @@ docker-compose up -d
 | 
			
		|||
## Test / Usage
 | 
			
		||||
 | 
			
		||||
```
 | 
			
		||||
curl -d '{"text":"new contrib from toto: http://radio.localhost/map/#44", "key": "secret"}' matrixwebhook.localhost/!FwpsPdeIYWcXDVpRmO:matrix.org
 | 
			
		||||
curl -d '{"text":"new contrib from toto: http://radio.localhost/map/#44", "key": "secret"}' 'matrixwebhook.localhost/!FwpsPdeIYWcXDVpRmO:matrix.org'
 | 
			
		||||
```
 | 
			
		||||
(or matrixwebhook.localhost:4785 without docker)
 | 
			
		||||
(or localhost:4785 without docker)
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -31,32 +31,31 @@ class MatrixWebhookServer(HTTPServer):
 | 
			
		|||
 | 
			
		||||
class MatrixWebhookHandler(BaseHTTPRequestHandler):
 | 
			
		||||
    """
 | 
			
		||||
    Class given to the server, st. it knows what to do with a request.
 | 
			
		||||
    This one handles the HTTP request, and forwards it to the matrix room.
 | 
			
		||||
    Class given to the server, st. it knows what to do with an HTTP request.
 | 
			
		||||
    This one handles a POST, checks its content, and forwards it to the matrix room.
 | 
			
		||||
    """
 | 
			
		||||
 | 
			
		||||
    def do_POST(self):
 | 
			
		||||
        """
 | 
			
		||||
        main method, get a json dict from wifi-with-me, send a message to a matrix room
 | 
			
		||||
        get a json dict from the request, send a message to a matrix room
 | 
			
		||||
        """
 | 
			
		||||
        length = int(self.headers.get('Content-Length'))
 | 
			
		||||
        data = json.loads(self.rfile.read(length).decode())
 | 
			
		||||
        status = 'I need a json dict with text & key'
 | 
			
		||||
        status, ret = 400, 'I need a json dict with text & key'
 | 
			
		||||
        if all(key in data for key in ['text', 'key']):
 | 
			
		||||
            status = 'wrong key'
 | 
			
		||||
            status, ret = 401, 'I need the good "key"'
 | 
			
		||||
            if data['key'] == API_KEY:
 | 
			
		||||
                status = 'I need the id of the room as a path, and to be in this room'
 | 
			
		||||
                status, ret = 404, 'I need the id of the room as a path, and to be in this room'
 | 
			
		||||
                if self.path[1:] not in self.server.rooms:
 | 
			
		||||
                    # try to see if this room has been joined recently
 | 
			
		||||
                    self.server.rooms = self.server.client.get_rooms()
 | 
			
		||||
                if self.path[1:] in self.server.rooms:
 | 
			
		||||
                    status = 'OK'
 | 
			
		||||
                    self.server.rooms[self.path[1:]].send_text(data['text'])
 | 
			
		||||
                    status, ret = 200, json.dumps(self.server.rooms[self.path[1:]].send_text(data['text']))
 | 
			
		||||
 | 
			
		||||
        self.send_response(200 if status == 'OK' else 401)
 | 
			
		||||
        self.send_response(status)
 | 
			
		||||
        self.send_header('Content-Type', 'application/json')
 | 
			
		||||
        self.end_headers()
 | 
			
		||||
        self.wfile.write(b'{"status": "%a"}' % status)
 | 
			
		||||
        self.wfile.write(b'{"status": %i, "ret": "%a"}' % (status, ret))
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
if __name__ == '__main__':
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue