2014-05-22 09:06:30 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# vi:si:et:sw=4:sts=4:ts=4
|
2014-09-02 22:32:44 +00:00
|
|
|
|
2014-05-22 09:06:30 +00:00
|
|
|
|
|
|
|
import json
|
2014-09-02 22:32:44 +00:00
|
|
|
from urllib.parse import urlencode
|
2014-05-22 09:06:30 +00:00
|
|
|
|
2014-08-12 08:16:57 +00:00
|
|
|
from ox.cache import read_url
|
|
|
|
|
2016-01-05 16:14:57 +00:00
|
|
|
import settings
|
|
|
|
|
2014-05-22 09:06:30 +00:00
|
|
|
import logging
|
2015-11-29 14:56:38 +00:00
|
|
|
logger = logging.getLogger(__name__)
|
2014-05-22 09:06:30 +00:00
|
|
|
|
|
|
|
def request(action, data):
|
|
|
|
data = urlencode({
|
|
|
|
'action': action,
|
|
|
|
'data': json.dumps(data)
|
|
|
|
})
|
|
|
|
url = 'http://meta.openmedialibrary.com/api/'
|
|
|
|
try:
|
2014-10-04 19:05:56 +00:00
|
|
|
return json.loads(read_url(url, data, timeout=60).decode('utf-8'))['data']
|
2014-05-22 09:06:30 +00:00
|
|
|
except:
|
2016-01-24 09:13:03 +00:00
|
|
|
logger.debug('metadata request failed', exc_info=True)
|
2014-05-22 09:06:30 +00:00
|
|
|
return {}
|
|
|
|
|
|
|
|
def find(query):
|
|
|
|
logger.debug('find %s', query)
|
2015-03-01 07:49:59 +00:00
|
|
|
return request('findMetadata', {'query': query}).get('items', [])
|
2014-05-22 09:06:30 +00:00
|
|
|
|
|
|
|
def lookup(key, value):
|
|
|
|
logger.debug('lookup %s %s', key, value)
|
2016-01-05 16:14:57 +00:00
|
|
|
data = request('getMetadata', {key: value})
|
|
|
|
for key in [k['id'] for k in settings.config['itemKeys'] if isinstance(k['type'], list)]:
|
|
|
|
if key in data and not isinstance(data[key], list):
|
|
|
|
data[key] = [data[key]]
|
|
|
|
return data
|