annotate src/de/mpiwg/itgroup/nimanager/persons/PersonByNameService.java @ 2:e3ecb88314a5

minor bugs ontologies added
author dwinter
date Fri, 02 Dec 2011 08:37:03 +0100
parents 1384a0d382fa
children f986e74583eb
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
1384a0d382fa first input
dwinter
parents:
diff changeset
1 package de.mpiwg.itgroup.nimanager.persons;
1384a0d382fa first input
dwinter
parents:
diff changeset
2
1384a0d382fa first input
dwinter
parents:
diff changeset
3 import java.io.UnsupportedEncodingException;
1384a0d382fa first input
dwinter
parents:
diff changeset
4 import java.net.URLDecoder;
1384a0d382fa first input
dwinter
parents:
diff changeset
5 import java.sql.SQLException;
1384a0d382fa first input
dwinter
parents:
diff changeset
6 import java.util.ArrayList;
1384a0d382fa first input
dwinter
parents:
diff changeset
7 import java.util.HashMap;
1384a0d382fa first input
dwinter
parents:
diff changeset
8 import java.util.List;
1384a0d382fa first input
dwinter
parents:
diff changeset
9 import java.util.Map;
1384a0d382fa first input
dwinter
parents:
diff changeset
10
1384a0d382fa first input
dwinter
parents:
diff changeset
11 import org.json.JSONArray;
1384a0d382fa first input
dwinter
parents:
diff changeset
12 import org.openrdf.model.Statement;
1384a0d382fa first input
dwinter
parents:
diff changeset
13 import org.openrdf.repository.RepositoryException;
1384a0d382fa first input
dwinter
parents:
diff changeset
14 import org.openrdf.repository.RepositoryResult;
1384a0d382fa first input
dwinter
parents:
diff changeset
15 import org.restlet.Context;
2
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
16 import org.restlet.data.ClientInfo;
0
1384a0d382fa first input
dwinter
parents:
diff changeset
17 import org.restlet.data.Form;
1384a0d382fa first input
dwinter
parents:
diff changeset
18 import org.restlet.data.MediaType;
1384a0d382fa first input
dwinter
parents:
diff changeset
19 import org.restlet.data.Status;
1384a0d382fa first input
dwinter
parents:
diff changeset
20 import org.restlet.engine.component.ChildContext;
1384a0d382fa first input
dwinter
parents:
diff changeset
21 import org.restlet.ext.json.JsonRepresentation;
1384a0d382fa first input
dwinter
parents:
diff changeset
22 import org.restlet.representation.Representation;
1384a0d382fa first input
dwinter
parents:
diff changeset
23 import org.restlet.representation.StringRepresentation;
1384a0d382fa first input
dwinter
parents:
diff changeset
24 import org.restlet.resource.Get;
1384a0d382fa first input
dwinter
parents:
diff changeset
25 import org.restlet.resource.Options;
1384a0d382fa first input
dwinter
parents:
diff changeset
26 import org.restlet.resource.ServerResource;
1384a0d382fa first input
dwinter
parents:
diff changeset
27
1384a0d382fa first input
dwinter
parents:
diff changeset
28 import virtuoso.jdbc4.VirtuosoResultSet;
1384a0d382fa first input
dwinter
parents:
diff changeset
29 import de.mpiwg.itgroup.nimanager.exceptions.TripleStoreHandlerException;
1384a0d382fa first input
dwinter
parents:
diff changeset
30 import de.mpiwg.itgroup.nimanager.owl.TripleStoreHandler;
1384a0d382fa first input
dwinter
parents:
diff changeset
31
1384a0d382fa first input
dwinter
parents:
diff changeset
32 public class PersonByNameService extends ServerResource {
1384a0d382fa first input
dwinter
parents:
diff changeset
33
1384a0d382fa first input
dwinter
parents:
diff changeset
34 private String VIRTUOSO_PW;
1384a0d382fa first input
dwinter
parents:
diff changeset
35 private String VIRTUOSO_USER;
1384a0d382fa first input
dwinter
parents:
diff changeset
36 private String virtuoso_server_url;
1384a0d382fa first input
dwinter
parents:
diff changeset
37 private String RELATION_FOR_NAME_SEARCH = "http://xmlns.com/foaf/0.1/name";
1384a0d382fa first input
dwinter
parents:
diff changeset
38 private String PERSONS_CONTEXT;
1384a0d382fa first input
dwinter
parents:
diff changeset
39 private TripleStoreHandler th;
1384a0d382fa first input
dwinter
parents:
diff changeset
40
1384a0d382fa first input
dwinter
parents:
diff changeset
41 public PersonByNameService() {
1384a0d382fa first input
dwinter
parents:
diff changeset
42 ChildContext context = (ChildContext)Context.getCurrent();
1384a0d382fa first input
dwinter
parents:
diff changeset
43 virtuoso_server_url = context.getParameters().getFirstValue("de.mpwig.itgroup.personSearch.virtuoso.url");
1384a0d382fa first input
dwinter
parents:
diff changeset
44 VIRTUOSO_PW = context.getParameters().getFirstValue("de.mpwig.itgroup.personSearch.virtuoso.pw");
1384a0d382fa first input
dwinter
parents:
diff changeset
45 VIRTUOSO_USER = context.getParameters().getFirstValue("de.mpwig.itgroup.personSearch.virtuoso.user");
1384a0d382fa first input
dwinter
parents:
diff changeset
46 PERSONS_CONTEXT = context.getParameters().getFirstValue("de.mpwig.itgroup.personSearch.virtuoso.personsGraphURI");
1384a0d382fa first input
dwinter
parents:
diff changeset
47 //th = TripleStoreHandler.getInstance("jdbc:virtuoso://virtuoso.mpiwg-berlin.mpg.de:1111", "dba", "dba");
1384a0d382fa first input
dwinter
parents:
diff changeset
48 try {
1384a0d382fa first input
dwinter
parents:
diff changeset
49 th = new TripleStoreHandler(virtuoso_server_url, VIRTUOSO_USER, VIRTUOSO_PW);
1384a0d382fa first input
dwinter
parents:
diff changeset
50 } catch (TripleStoreHandlerException e) {
1384a0d382fa first input
dwinter
parents:
diff changeset
51 // TODO Auto-generated catch block
1384a0d382fa first input
dwinter
parents:
diff changeset
52 e.printStackTrace();
1384a0d382fa first input
dwinter
parents:
diff changeset
53 }
1384a0d382fa first input
dwinter
parents:
diff changeset
54 }
1384a0d382fa first input
dwinter
parents:
diff changeset
55
1384a0d382fa first input
dwinter
parents:
diff changeset
56 @Options
1384a0d382fa first input
dwinter
parents:
diff changeset
57 public void doOptions(Representation entity) {
1384a0d382fa first input
dwinter
parents:
diff changeset
58 Form responseHeaders = (Form) getResponse().getAttributes().get(
1384a0d382fa first input
dwinter
parents:
diff changeset
59 "org.restlet.http.headers");
1384a0d382fa first input
dwinter
parents:
diff changeset
60 if (responseHeaders == null) {
1384a0d382fa first input
dwinter
parents:
diff changeset
61 responseHeaders = new Form();
1384a0d382fa first input
dwinter
parents:
diff changeset
62 getResponse().getAttributes().put("org.restlet.http.headers",
1384a0d382fa first input
dwinter
parents:
diff changeset
63 responseHeaders);
1384a0d382fa first input
dwinter
parents:
diff changeset
64 }
1384a0d382fa first input
dwinter
parents:
diff changeset
65 responseHeaders.add("Access-Control-Allow-Origin", "*");
1384a0d382fa first input
dwinter
parents:
diff changeset
66 responseHeaders.add("Access-Control-Allow-Methods", "POST,OPTIONS,GET");
1384a0d382fa first input
dwinter
parents:
diff changeset
67 responseHeaders.add("Access-Control-Allow-Headers", "Content-Type");
1384a0d382fa first input
dwinter
parents:
diff changeset
68 responseHeaders.add("Access-Control-Allow-Credentials", "false");
1384a0d382fa first input
dwinter
parents:
diff changeset
69 responseHeaders.add("Access-Control-Max-Age", "60");
1384a0d382fa first input
dwinter
parents:
diff changeset
70 }
1384a0d382fa first input
dwinter
parents:
diff changeset
71
1384a0d382fa first input
dwinter
parents:
diff changeset
72 public Representation getTest() {
1384a0d382fa first input
dwinter
parents:
diff changeset
73 return new StringRepresentation("TEST");
1384a0d382fa first input
dwinter
parents:
diff changeset
74 }
1384a0d382fa first input
dwinter
parents:
diff changeset
75
1384a0d382fa first input
dwinter
parents:
diff changeset
76 @Get("json")
1384a0d382fa first input
dwinter
parents:
diff changeset
77 public Representation getJson() {
1384a0d382fa first input
dwinter
parents:
diff changeset
78 Form responseHeaders = (Form) getResponse().getAttributes().get(
1384a0d382fa first input
dwinter
parents:
diff changeset
79 "org.restlet.http.headers");
1384a0d382fa first input
dwinter
parents:
diff changeset
80 if (responseHeaders == null) {
1384a0d382fa first input
dwinter
parents:
diff changeset
81 responseHeaders = new Form();
1384a0d382fa first input
dwinter
parents:
diff changeset
82 getResponse().getAttributes().put("org.restlet.http.headers",
1384a0d382fa first input
dwinter
parents:
diff changeset
83 responseHeaders);
1384a0d382fa first input
dwinter
parents:
diff changeset
84 }
1384a0d382fa first input
dwinter
parents:
diff changeset
85 responseHeaders.add("Access-Control-Allow-Origin", "*");
1384a0d382fa first input
dwinter
parents:
diff changeset
86
1384a0d382fa first input
dwinter
parents:
diff changeset
87 JSONArray resultsJsonArray = new JSONArray();
1384a0d382fa first input
dwinter
parents:
diff changeset
88 try {
1384a0d382fa first input
dwinter
parents:
diff changeset
89 String id = (String) getRequest().getAttributes().get("name");
1384a0d382fa first input
dwinter
parents:
diff changeset
90 id = URLDecoder.decode(id, "utf-8");
1384a0d382fa first input
dwinter
parents:
diff changeset
91 String queryPersonWPMD="sparql select DISTINCT * "+
2
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
92 "FROM <"+PERSONS_CONTEXT+"> "+
0
1384a0d382fa first input
dwinter
parents:
diff changeset
93 "FROM <file://newpersonsFromProjects>"+
1384a0d382fa first input
dwinter
parents:
diff changeset
94 " FROM <file://personendataWikipedia>"+
1384a0d382fa first input
dwinter
parents:
diff changeset
95 " where { " +
2
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
96 "{GRAPH <"+PERSONS_CONTEXT+">" +
0
1384a0d382fa first input
dwinter
parents:
diff changeset
97 "{"+
1384a0d382fa first input
dwinter
parents:
diff changeset
98 "?person <"+RELATION_FOR_NAME_SEARCH+"> \""+id+"\"@en."+
1384a0d382fa first input
dwinter
parents:
diff changeset
99 " ?ident <http://ontologies.mpiwg-berlin.mpg.de/authorities/namedIdentities/identifies_NamedEntity> ?person."+
1384a0d382fa first input
dwinter
parents:
diff changeset
100 " OPTIONAL {?wikipedia crm:P1_is_identified_by ?ident.}"+
1384a0d382fa first input
dwinter
parents:
diff changeset
101 " OPTIONAL {?wikipedia <http://dbpedia.org/ontology/birthDate> ?birthDate.}"+
1384a0d382fa first input
dwinter
parents:
diff changeset
102 " OPTIONAL {?wikipedia <http://dbpedia.org/ontology/deathDate> ?deathDate.}"
1384a0d382fa first input
dwinter
parents:
diff changeset
103 +"}" +
1384a0d382fa first input
dwinter
parents:
diff changeset
104 "} UNION {" +
1384a0d382fa first input
dwinter
parents:
diff changeset
105 "GRAPH <file://newpersonsFromProjects> {" +
1384a0d382fa first input
dwinter
parents:
diff changeset
106 "?person <"+RELATION_FOR_NAME_SEARCH+"> \""+id+"\""+
1384a0d382fa first input
dwinter
parents:
diff changeset
107 "}" +
1384a0d382fa first input
dwinter
parents:
diff changeset
108 "}" +
1384a0d382fa first input
dwinter
parents:
diff changeset
109 "}";
1384a0d382fa first input
dwinter
parents:
diff changeset
110 java.sql.Statement smt = th.sqlCon.createStatement();
1384a0d382fa first input
dwinter
parents:
diff changeset
111
1384a0d382fa first input
dwinter
parents:
diff changeset
112
1384a0d382fa first input
dwinter
parents:
diff changeset
113 smt.execute(queryPersonWPMD);
1384a0d382fa first input
dwinter
parents:
diff changeset
114 VirtuosoResultSet rs = (VirtuosoResultSet) smt.getResultSet();
1384a0d382fa first input
dwinter
parents:
diff changeset
115 Map<String,String> resultMap = new HashMap<String, String>();
1384a0d382fa first input
dwinter
parents:
diff changeset
116 while(rs.next()){
1384a0d382fa first input
dwinter
parents:
diff changeset
117 if (rs.getString("person")!=null){
1384a0d382fa first input
dwinter
parents:
diff changeset
118 resultMap.put("person",rs.getString("person"));
1384a0d382fa first input
dwinter
parents:
diff changeset
119 }else {
1384a0d382fa first input
dwinter
parents:
diff changeset
120 resultMap.put("person","");
1384a0d382fa first input
dwinter
parents:
diff changeset
121 }
1384a0d382fa first input
dwinter
parents:
diff changeset
122 if (rs.getString("wikipedia")!=null){
1384a0d382fa first input
dwinter
parents:
diff changeset
123 resultMap.put("wikipedia",rs.getString("wikipedia"));
1384a0d382fa first input
dwinter
parents:
diff changeset
124 } else {
1384a0d382fa first input
dwinter
parents:
diff changeset
125 resultMap.put("wikipedia","");
1384a0d382fa first input
dwinter
parents:
diff changeset
126 }
1384a0d382fa first input
dwinter
parents:
diff changeset
127 if (rs.getString("birthDate")!=null){
1384a0d382fa first input
dwinter
parents:
diff changeset
128 resultMap.put("birthDate",rs.getString("birthDate"));
1384a0d382fa first input
dwinter
parents:
diff changeset
129 } else {
1384a0d382fa first input
dwinter
parents:
diff changeset
130 resultMap.put("birthDate","");
1384a0d382fa first input
dwinter
parents:
diff changeset
131 }
1384a0d382fa first input
dwinter
parents:
diff changeset
132 if (rs.getString("deathDate")!=null){
1384a0d382fa first input
dwinter
parents:
diff changeset
133 resultMap.put("deathDate",rs.getString("deathDate"));
1384a0d382fa first input
dwinter
parents:
diff changeset
134 } else {
1384a0d382fa first input
dwinter
parents:
diff changeset
135 resultMap.put("deathDate","");
1384a0d382fa first input
dwinter
parents:
diff changeset
136 }
1384a0d382fa first input
dwinter
parents:
diff changeset
137 resultMap.put("name",id);
1384a0d382fa first input
dwinter
parents:
diff changeset
138 resultsJsonArray.put(resultMap);
1384a0d382fa first input
dwinter
parents:
diff changeset
139 }
1384a0d382fa first input
dwinter
parents:
diff changeset
140
1384a0d382fa first input
dwinter
parents:
diff changeset
141 return new JsonRepresentation(resultsJsonArray);
1384a0d382fa first input
dwinter
parents:
diff changeset
142
1384a0d382fa first input
dwinter
parents:
diff changeset
143 } catch (UnsupportedEncodingException e) {
1384a0d382fa first input
dwinter
parents:
diff changeset
144 e.printStackTrace();
1384a0d382fa first input
dwinter
parents:
diff changeset
145 setStatus(Status.SERVER_ERROR_INTERNAL, "REPOSITORY ERROR");
1384a0d382fa first input
dwinter
parents:
diff changeset
146 return new JsonRepresentation(new JSONArray());
1384a0d382fa first input
dwinter
parents:
diff changeset
147
1384a0d382fa first input
dwinter
parents:
diff changeset
148 } catch (SQLException e) {
1384a0d382fa first input
dwinter
parents:
diff changeset
149
1384a0d382fa first input
dwinter
parents:
diff changeset
150 e.printStackTrace();
1384a0d382fa first input
dwinter
parents:
diff changeset
151 setStatus(Status.SERVER_ERROR_INTERNAL, "REPOSITORY SQL ERROR");
1384a0d382fa first input
dwinter
parents:
diff changeset
152 return new JsonRepresentation(new JSONArray());
1384a0d382fa first input
dwinter
parents:
diff changeset
153
1384a0d382fa first input
dwinter
parents:
diff changeset
154 }
1384a0d382fa first input
dwinter
parents:
diff changeset
155
1384a0d382fa first input
dwinter
parents:
diff changeset
156
1384a0d382fa first input
dwinter
parents:
diff changeset
157 }
1384a0d382fa first input
dwinter
parents:
diff changeset
158
1384a0d382fa first input
dwinter
parents:
diff changeset
159 @Get("xml")
1384a0d382fa first input
dwinter
parents:
diff changeset
160 public Representation getXML() {
1384a0d382fa first input
dwinter
parents:
diff changeset
161 List<MediaType> supported=new ArrayList<MediaType>();
1384a0d382fa first input
dwinter
parents:
diff changeset
162 supported.add(MediaType.APPLICATION_JSON);
2
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
163
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
164 ClientInfo ci = getRequest().getClientInfo();
0
1384a0d382fa first input
dwinter
parents:
diff changeset
165
2
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
166 if(ci==null){ //don't know why this can happen, but sometimes does
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
167 setStatus(Status.SERVER_ERROR_INTERNAL);
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
168 return null;
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
169 }
0
1384a0d382fa first input
dwinter
parents:
diff changeset
170 MediaType types = getRequest().getClientInfo().getPreferredMediaType(supported);
1384a0d382fa first input
dwinter
parents:
diff changeset
171 if (types.equals(MediaType.APPLICATION_JSON))
1384a0d382fa first input
dwinter
parents:
diff changeset
172 return getJson();
1384a0d382fa first input
dwinter
parents:
diff changeset
173
1384a0d382fa first input
dwinter
parents:
diff changeset
174 try {
1384a0d382fa first input
dwinter
parents:
diff changeset
175 String id = (String) getRequest().getAttributes().get("name");
1384a0d382fa first input
dwinter
parents:
diff changeset
176 id = URLDecoder.decode(id, "utf-8");
1384a0d382fa first input
dwinter
parents:
diff changeset
177 RepositoryResult<Statement> statements = th.getStatements(null,
1384a0d382fa first input
dwinter
parents:
diff changeset
178 th.createUri(RELATION_FOR_NAME_SEARCH),
1384a0d382fa first input
dwinter
parents:
diff changeset
179 th.createLiteral(id, "en"), PERSONS_CONTEXT);
1384a0d382fa first input
dwinter
parents:
diff changeset
180 String ret = "<results>";
1384a0d382fa first input
dwinter
parents:
diff changeset
181 while (statements.hasNext()) {
1384a0d382fa first input
dwinter
parents:
diff changeset
182 Statement statement = statements.next();
1384a0d382fa first input
dwinter
parents:
diff changeset
183 ret += "<result subj=\"" + statement.getSubject().stringValue()
1384a0d382fa first input
dwinter
parents:
diff changeset
184 + "\"/>";
1384a0d382fa first input
dwinter
parents:
diff changeset
185 }
1384a0d382fa first input
dwinter
parents:
diff changeset
186 ret += "</results>";
1384a0d382fa first input
dwinter
parents:
diff changeset
187
1384a0d382fa first input
dwinter
parents:
diff changeset
188 return new StringRepresentation(ret, MediaType.TEXT_XML);
1384a0d382fa first input
dwinter
parents:
diff changeset
189
1384a0d382fa first input
dwinter
parents:
diff changeset
190 } catch (RepositoryException e) {
1384a0d382fa first input
dwinter
parents:
diff changeset
191
1384a0d382fa first input
dwinter
parents:
diff changeset
192 e.printStackTrace();
1384a0d382fa first input
dwinter
parents:
diff changeset
193 setStatus(Status.SERVER_ERROR_INTERNAL, "REPOSITORY ERROR");
1384a0d382fa first input
dwinter
parents:
diff changeset
194 return new StringRepresentation(
1384a0d382fa first input
dwinter
parents:
diff changeset
195 "<xml><error>Repository Error</error></xml>",
1384a0d382fa first input
dwinter
parents:
diff changeset
196 MediaType.TEXT_XML);
1384a0d382fa first input
dwinter
parents:
diff changeset
197 } catch (UnsupportedEncodingException e) {
1384a0d382fa first input
dwinter
parents:
diff changeset
198 e.printStackTrace();
1384a0d382fa first input
dwinter
parents:
diff changeset
199 setStatus(Status.SERVER_ERROR_INTERNAL, "REPOSITORY ERROR");
1384a0d382fa first input
dwinter
parents:
diff changeset
200 return new StringRepresentation(
1384a0d382fa first input
dwinter
parents:
diff changeset
201 "<xml><error>Unsupported encoding</error></xml>",
1384a0d382fa first input
dwinter
parents:
diff changeset
202 MediaType.TEXT_XML);
1384a0d382fa first input
dwinter
parents:
diff changeset
203 }
1384a0d382fa first input
dwinter
parents:
diff changeset
204 }
1384a0d382fa first input
dwinter
parents:
diff changeset
205
1384a0d382fa first input
dwinter
parents:
diff changeset
206 @Get("html")
1384a0d382fa first input
dwinter
parents:
diff changeset
207 public Representation getHTML() {
1384a0d382fa first input
dwinter
parents:
diff changeset
208
1384a0d382fa first input
dwinter
parents:
diff changeset
209 List<MediaType> supported=new ArrayList<MediaType>();
1384a0d382fa first input
dwinter
parents:
diff changeset
210 supported.add(MediaType.APPLICATION_JSON);
1384a0d382fa first input
dwinter
parents:
diff changeset
211
2
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
212 ClientInfo ci = getRequest().getClientInfo();
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
213
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
214 if(ci==null){ //don't know why this can happen, but sometimes does
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
215 setStatus(Status.SERVER_ERROR_INTERNAL);
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
216 return null;
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
217 }
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
218 MediaType types = ci.getPreferredMediaType(supported);
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
219 if (types!=null)
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
220 if (types.equals(MediaType.APPLICATION_JSON))
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
221 return getJson();
0
1384a0d382fa first input
dwinter
parents:
diff changeset
222
1384a0d382fa first input
dwinter
parents:
diff changeset
223 Form responseHeaders = (Form) getResponse().getAttributes().get(
1384a0d382fa first input
dwinter
parents:
diff changeset
224 "org.restlet.http.headers");
1384a0d382fa first input
dwinter
parents:
diff changeset
225 if (responseHeaders == null) {
1384a0d382fa first input
dwinter
parents:
diff changeset
226 responseHeaders = new Form();
1384a0d382fa first input
dwinter
parents:
diff changeset
227 getResponse().getAttributes().put("org.restlet.http.headers",
1384a0d382fa first input
dwinter
parents:
diff changeset
228 responseHeaders);
1384a0d382fa first input
dwinter
parents:
diff changeset
229 }
1384a0d382fa first input
dwinter
parents:
diff changeset
230 responseHeaders.add("Access-Control-Allow-Origin", "*");
1384a0d382fa first input
dwinter
parents:
diff changeset
231 try {
1384a0d382fa first input
dwinter
parents:
diff changeset
232 String id = (String) getRequest().getAttributes().get("name");
1384a0d382fa first input
dwinter
parents:
diff changeset
233 id = URLDecoder.decode(id, "utf-8");
1384a0d382fa first input
dwinter
parents:
diff changeset
234 // RepositoryResult<Statement> statements = th.getStatements(null,
1384a0d382fa first input
dwinter
parents:
diff changeset
235 // th.createUri(RELATION_FOR_NAME_SEARCH),
1384a0d382fa first input
dwinter
parents:
diff changeset
236 // th.createLiteral(id, "en"), PERSONS_CONTEXT);
1384a0d382fa first input
dwinter
parents:
diff changeset
237 String ret = "<html><body><div id=\"resultNames\">";
1384a0d382fa first input
dwinter
parents:
diff changeset
238 String queryPersonWPMD="sparql select * "+
2
e3ecb88314a5 minor bugs
dwinter
parents: 0
diff changeset
239 "FROM <"+PERSONS_CONTEXT+"> "+
0
1384a0d382fa first input
dwinter
parents:
diff changeset
240 " FROM <file://personendataWikipedia>"+
1384a0d382fa first input
dwinter
parents:
diff changeset
241 " where { "+
1384a0d382fa first input
dwinter
parents:
diff changeset
242 " ?person <"+RELATION_FOR_NAME_SEARCH+"> \""+id+"\"@en."+
1384a0d382fa first input
dwinter
parents:
diff changeset
243 " ?ident <http://ontologies.mpiwg-berlin.mpg.de/authorities/namedIdentities/identifies_NamedEntity> ?person."+
1384a0d382fa first input
dwinter
parents:
diff changeset
244 " ?wikipedia crm:P1_is_identified_by ?ident."+
1384a0d382fa first input
dwinter
parents:
diff changeset
245 " ?wikipedia <http://dbpedia.org/ontology/birthDate> ?birthDate."+
1384a0d382fa first input
dwinter
parents:
diff changeset
246 " ?wikipedia <http://dbpedia.org/ontology/deathDate> ?deathDate."
1384a0d382fa first input
dwinter
parents:
diff changeset
247 +"}";
1384a0d382fa first input
dwinter
parents:
diff changeset
248 java.sql.Statement smt = th.sqlCon.createStatement();
1384a0d382fa first input
dwinter
parents:
diff changeset
249
1384a0d382fa first input
dwinter
parents:
diff changeset
250
1384a0d382fa first input
dwinter
parents:
diff changeset
251 smt.execute(queryPersonWPMD);
1384a0d382fa first input
dwinter
parents:
diff changeset
252 VirtuosoResultSet rs = (VirtuosoResultSet) smt.getResultSet();
1384a0d382fa first input
dwinter
parents:
diff changeset
253
1384a0d382fa first input
dwinter
parents:
diff changeset
254 while(rs.next()){
1384a0d382fa first input
dwinter
parents:
diff changeset
255 String person= rs.getString("person");
1384a0d382fa first input
dwinter
parents:
diff changeset
256 String wikipedia= rs.getString("wikipedia");
1384a0d382fa first input
dwinter
parents:
diff changeset
257 String bd= rs.getString("birthDate");
1384a0d382fa first input
dwinter
parents:
diff changeset
258 String dd= rs.getString("deathDate");
1384a0d382fa first input
dwinter
parents:
diff changeset
259
1384a0d382fa first input
dwinter
parents:
diff changeset
260 ret+=String.format("<div><a href=\"%s\">%s (%s-%s)</a></div>",wikipedia,id,bd,dd);
1384a0d382fa first input
dwinter
parents:
diff changeset
261 }
1384a0d382fa first input
dwinter
parents:
diff changeset
262
1384a0d382fa first input
dwinter
parents:
diff changeset
263
1384a0d382fa first input
dwinter
parents:
diff changeset
264 // while (statements.hasNext()) {
1384a0d382fa first input
dwinter
parents:
diff changeset
265 // Statement statement = statements.next();
1384a0d382fa first input
dwinter
parents:
diff changeset
266 //
1384a0d382fa first input
dwinter
parents:
diff changeset
267 //
1384a0d382fa first input
dwinter
parents:
diff changeset
268 //
1384a0d382fa first input
dwinter
parents:
diff changeset
269 //
1384a0d382fa first input
dwinter
parents:
diff changeset
270 //
1384a0d382fa first input
dwinter
parents:
diff changeset
271 // //ret +=String.format("<div><a href=\"../id/%s\">%s</a></div>",URLEncoder.encode(statement.getSubject().stringValue()),statement.getSubject().stringValue() );
1384a0d382fa first input
dwinter
parents:
diff changeset
272 // ret +=String.format("<div><a href=\"%s\">%s</a></div>",statement.getSubject().stringValue(),statement.getSubject().stringValue() );
1384a0d382fa first input
dwinter
parents:
diff changeset
273 //
1384a0d382fa first input
dwinter
parents:
diff changeset
274 // }
1384a0d382fa first input
dwinter
parents:
diff changeset
275
1384a0d382fa first input
dwinter
parents:
diff changeset
276 ret += "</div></body></html>";
1384a0d382fa first input
dwinter
parents:
diff changeset
277
1384a0d382fa first input
dwinter
parents:
diff changeset
278 return new StringRepresentation(ret, MediaType.TEXT_HTML);
1384a0d382fa first input
dwinter
parents:
diff changeset
279
1384a0d382fa first input
dwinter
parents:
diff changeset
280 // } catch (RepositoryException e) {
1384a0d382fa first input
dwinter
parents:
diff changeset
281 //
1384a0d382fa first input
dwinter
parents:
diff changeset
282 // e.printStackTrace();
1384a0d382fa first input
dwinter
parents:
diff changeset
283 // setStatus(Status.SERVER_ERROR_INTERNAL, "REPOSITORY ERROR");
1384a0d382fa first input
dwinter
parents:
diff changeset
284 // return new StringRepresentation(
1384a0d382fa first input
dwinter
parents:
diff changeset
285 // "<xml><error>Repository Error</error></xml>",
1384a0d382fa first input
dwinter
parents:
diff changeset
286 // MediaType.TEXT_HTML);
1384a0d382fa first input
dwinter
parents:
diff changeset
287 } catch (UnsupportedEncodingException e) {
1384a0d382fa first input
dwinter
parents:
diff changeset
288 e.printStackTrace();
1384a0d382fa first input
dwinter
parents:
diff changeset
289 setStatus(Status.SERVER_ERROR_INTERNAL, "REPOSITORY ERROR");
1384a0d382fa first input
dwinter
parents:
diff changeset
290 return new StringRepresentation(
1384a0d382fa first input
dwinter
parents:
diff changeset
291 "<xml><error>Unsupported encoding</error></xml>",
1384a0d382fa first input
dwinter
parents:
diff changeset
292 MediaType.TEXT_HTML);
1384a0d382fa first input
dwinter
parents:
diff changeset
293 } catch (SQLException e) {
1384a0d382fa first input
dwinter
parents:
diff changeset
294
1384a0d382fa first input
dwinter
parents:
diff changeset
295 e.printStackTrace();
1384a0d382fa first input
dwinter
parents:
diff changeset
296 setStatus(Status.SERVER_ERROR_INTERNAL, "REPOSITORY SQL ERROR");
1384a0d382fa first input
dwinter
parents:
diff changeset
297 return new StringRepresentation(
1384a0d382fa first input
dwinter
parents:
diff changeset
298 "<xml><error>Unsupported encoding</error></xml>",
1384a0d382fa first input
dwinter
parents:
diff changeset
299 MediaType.TEXT_HTML);
1384a0d382fa first input
dwinter
parents:
diff changeset
300 }
1384a0d382fa first input
dwinter
parents:
diff changeset
301 }
1384a0d382fa first input
dwinter
parents:
diff changeset
302
1384a0d382fa first input
dwinter
parents:
diff changeset
303 }