annotate src/de/mpiwg/itgroup/nimanager/persons/PersonByNameService.java @ 0:1384a0d382fa

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