Skip to content
This repository has been archived by the owner on Jan 13, 2020. It is now read-only.

Commit

Permalink
implement signature algorithm
Browse files Browse the repository at this point in the history
  • Loading branch information
jketterl committed Jun 10, 2020
1 parent 61d03b3 commit eebe33f
Show file tree
Hide file tree
Showing 3 changed files with 26 additions and 7 deletions.
12 changes: 8 additions & 4 deletions owrx/controllers/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,14 +7,18 @@ def __init__(self, handler, request, options):
self.request = request
self.options = options

def send_response(self, content, code=200, content_type="text/html", last_modified: datetime = None, max_age=None):
def send_response(self, content, code=200, content_type="text/html", last_modified: datetime = None, max_age=None, headers=None):
self.handler.send_response(code)
if headers is None:
headers = {}
if content_type is not None:
self.handler.send_header("Content-Type", content_type)
headers["Content-Type"] = content_type
if last_modified is not None:
self.handler.send_header("Last-Modified", last_modified.strftime("%a, %d %b %Y %H:%M:%S GMT"))
headers["Last-Modified"] = last_modified.strftime("%a, %d %b %Y %H:%M:%S GMT")
if max_age is not None:
self.handler.send_header("Cache-Control", "max-age: {0}".format(max_age))
headers["Cache-Control"] = "max-age: {0}".format(max_age)
for key, value in headers.items():
self.handler.send_header(key, value)
self.handler.end_headers()
if type(content) == str:
content = content.encode()
Expand Down
5 changes: 3 additions & 2 deletions owrx/controllers/status.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,9 +29,10 @@ def getReceiverStats(self, receiver):

def indexAction(self):
pm = Config.get()
headers = None
if "Authorization" in self.request.headers:
try:
ReceiverId.getResponseHeader(self.request.headers["Authorization"])
headers = ReceiverId.getResponseHeader(self.request.headers["Authorization"])
except KeyException:
logger.exception("error processing authorization header")
status = {
Expand All @@ -46,4 +47,4 @@ def indexAction(self):
"version": openwebrx_version,
"sdrs": [self.getReceiverStats(r) for r in SdrService.getSources().values()]
}
self.send_response(json.dumps(status), content_type="application/json")
self.send_response(json.dumps(status), content_type="application/json", headers=headers)
16 changes: 15 additions & 1 deletion owrx/receiverid.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
import re
import logging
import hashlib
from datetime import datetime
from owrx.config import Config

logger = logging.getLogger(__name__)
Expand Down Expand Up @@ -47,7 +49,11 @@ def getResponseHeader(requestHeader):
raise KeyException("invalid authorization header")
challenge = KeyChallenge(matches.group(1))
key = ReceiverId.findKey(challenge)
# TODO sign challenge and respond
time, signature = ReceiverId.signChallenge(challenge, key)
return {
"Signature": signature,
"Time": time,
}

@staticmethod
def findKey(challenge):
Expand All @@ -61,3 +67,11 @@ def parseKey(keyString):
if matching_keys:
return matching_keys[0]
return None

@staticmethod
def signChallenge(challenge, key):
now = datetime.utcnow().isoformat()
signString = "{challenge}:{time}".format(challenge=challenge.challenge, time=now)
m = hashlib.sha256()
m.update(signString.encode())
return now, m.hexdigest()

0 comments on commit eebe33f

Please sign in to comment.