1
|
import urllib2
|
2
|
|
3
|
from flask import json
|
4
|
import pysolr
|
5
|
|
6
|
from DLIObject import DLIObject
|
7
|
|
8
|
|
9
|
class QueryResolver(object):
|
10
|
def __init__(self, solr_url):
|
11
|
self.solr_url = solr_url
|
12
|
self.solr_server = pysolr.Solr(self.solr_url)
|
13
|
self.facet_renaming = {'entitytype': "Typology", 'provenance': "Content Provider",
|
14
|
"Content Provider": 'provenance', "Typology": 'entitytype'}
|
15
|
|
16
|
def get_facet(self, facet, query=None):
|
17
|
data = []
|
18
|
|
19
|
f = 'entitytype'
|
20
|
if query is not None:
|
21
|
data.append({'facet': self.facet_renaming[f], 'query_name': f, 'values': [
|
22
|
{'key': facet[f][i], 'value': facet[f][i + 1]} for i in range(0, len(facet[f]), 2)]})
|
23
|
else:
|
24
|
data.append({'facet': self.facet_renaming[f], 'query_name': f,
|
25
|
'values': [{'key': facet[f][i], 'value': facet[f][i + 1]} for i in
|
26
|
range(0, len(facet[f]), 2)]})
|
27
|
f = 'provenance'
|
28
|
data.append({'facet': self.facet_renaming[f], 'query_name': f,
|
29
|
'values': [{'key': facet[f][i], 'value': facet[f][i + 1]} for i in range(0, len(facet[f]), 2)]})
|
30
|
|
31
|
return data
|
32
|
|
33
|
def get_item(self, persistent_identifier):
|
34
|
query = 'objidentifier:"%s"' % persistent_identifier
|
35
|
response = self.solr_server.search(q=query)
|
36
|
query_response = []
|
37
|
for hit in response:
|
38
|
result = hit['__result'][0]
|
39
|
query_response.append(DLIObject(result.encode('utf8')))
|
40
|
|
41
|
return {'objects': query_response}
|
42
|
|
43
|
def get_stats_detail(self):
|
44
|
data = urllib2.urlopen("http://node0-p-dli.d4science.org:8080/dli/mvc/ui/stats/getLastStats")
|
45
|
result = []
|
46
|
d = json.loads(data.read())
|
47
|
for k in d:
|
48
|
if 'Deduction' not in k['datasource']:
|
49
|
result.append(k)
|
50
|
return result
|
51
|
|
52
|
def get_stats(self):
|
53
|
|
54
|
data = urllib2.urlopen("http://node0-p-dli.d4science.org:8080/dli/mvc/ui/stats/getAllStats")
|
55
|
result = {}
|
56
|
d = json.loads(data.read())
|
57
|
for item in d:
|
58
|
result[item] = []
|
59
|
for k in d[item]:
|
60
|
if 'Deduction' not in k['datasource']:
|
61
|
result[item].append(k)
|
62
|
return result
|
63
|
|
64
|
def query(self, q, browse_fields, start=None, page_size=10, only_result=False, filter_query=None):
|
65
|
params = {}
|
66
|
if browse_fields is not None:
|
67
|
params['facet'] = 'true',
|
68
|
params['facet.field'] = browse_fields
|
69
|
params['facet.mincount'] = 1
|
70
|
|
71
|
if filter_query is not None:
|
72
|
params['fq'] = filter_query
|
73
|
if start is not None:
|
74
|
params['start'] = start
|
75
|
response = self.solr_server.search(q, rows=page_size, **params)
|
76
|
query_response = []
|
77
|
for hit in response:
|
78
|
result = hit['__result'][0]
|
79
|
query_response.append(DLIObject(result.encode('utf8')))
|
80
|
if not only_result:
|
81
|
facet = self.get_facet(response.facets['facet_fields'], q)
|
82
|
else:
|
83
|
facet = self.get_facet(response.facets['facet_fields'])
|
84
|
return {'objects': query_response, 'facet': facet, 'total': response.hits}
|