Browse Source

can now look up objects based upon their hash..

main
John-Mark Gurney 4 years ago
parent
commit
1514a41ca1
1 changed files with 36 additions and 2 deletions
  1. +36
    -2
      ui/server.py

+ 36
- 2
ui/server.py View File

@@ -14,7 +14,7 @@ from klein import Klein
from kleintest import * from kleintest import *
from twisted.trial import unittest from twisted.trial import unittest
from twisted.web.iweb import IRequest from twisted.web.iweb import IRequest
from cli import _asn1coder, Persona, MDBase
from cli import _asn1coder, Persona, MDBase, MetaData


import hashlib import hashlib
import mock import mock
@@ -27,6 +27,7 @@ defaultfile = 'mediaserver.store.pasn1'
class MEDAServer: class MEDAServer:
def __init__(self, fname): def __init__(self, fname):
self._fname = fname self._fname = fname
self._hashes = {}
try: try:
data = _asn1coder.loads(open(fname).read()) data = _asn1coder.loads(open(fname).read())
self._trustedkeys = {} self._trustedkeys = {}
@@ -58,6 +59,13 @@ class MEDAServer:
with open(self._fname, 'w') as fp: with open(self._fname, 'w') as fp:
fp.write(_asn1coder.dumps(obj)) fp.write(_asn1coder.dumps(obj))


@app.route('/lookup/<hash>')
def lookup(self, request, hash):
if hash in self._hashes:
return

request.setResponseCode(404)

@app.route('/obj/<id>') @app.route('/obj/<id>')
def obj_lookup(self, request, id): def obj_lookup(self, request, id):
try: try:
@@ -68,6 +76,15 @@ class MEDAServer:
except KeyError: # no object except KeyError: # no object
request.setResponseCode(404) request.setResponseCode(404)


def _storeobj(self, obj):
self._objstore.setdefault(obj.uuid, []).append(obj)
try:
hashes = obj.hashes
for i in hashes:
self._hashes.setdefault(i, []).append(obj.uuid)
except AttributeError:
pass

@app.route('/store') @app.route('/store')
def storeobj(self, request): def storeobj(self, request):
try: try:
@@ -81,7 +98,7 @@ class MEDAServer:
persona = self._trustedkeys[keyuuid] persona = self._trustedkeys[keyuuid]
persona.verify(obj) persona.verify(obj)


self._objstore.setdefault(obj.uuid, []).append(obj)
self._storeobj(obj)


request.setResponseCode(201) request.setResponseCode(201)


@@ -236,6 +253,23 @@ class _TestPostConfig(_BaseServerTest):
self.medaserver.addpubkey(persona.get_pubkey()) self.medaserver.addpubkey(persona.get_pubkey())


def test_hashlookup(self): def test_hashlookup(self):
# that the hash of a file
h = hashlib.sha256(open('fixtures/testfiles/test.txt').read()).hexdigest() h = hashlib.sha256(open('fixtures/testfiles/test.txt').read()).hexdigest()

# when looked up
r = self.requests.get('/lookup/%s' % h) r = self.requests.get('/lookup/%s' % h)

# returns a 404
self.assertEqual(r.status_code, 404) self.assertEqual(r.status_code, 404)

# but when the metadata object
mdobj = self.persona.MetaData(hashes=[ h ], mimetype=[ 'text/plain' ])

# is in the server
self.medaserver._storeobj(mdobj)

# when looked up
r = self.requests.get('/lookup/%s' % h)

# it is found
self.assertEqual(r.status_code, 200)

Loading…
Cancel
Save