annotate src/de/mpiwg/itgroup/annotationManager/restlet/AddAndSearchAnnotations.java @ 1:f2f41d0dedf5

minimal changes
author dwinter
date Wed, 23 Nov 2011 15:26:33 +0100
parents 77530be3c747
children 6888ae3287b8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
dwinter
parents:
diff changeset
1 //TODO: handle XML-Post des Annoteaprotocolls http://www.w3.org/2001/Annotea/User/Protocol.html
dwinter
parents:
diff changeset
2
dwinter
parents:
diff changeset
3 package de.mpiwg.itgroup.annotationManager.restlet;
dwinter
parents:
diff changeset
4
dwinter
parents:
diff changeset
5 import java.io.IOException;
dwinter
parents:
diff changeset
6 import java.io.UnsupportedEncodingException;
dwinter
parents:
diff changeset
7 import java.net.URLDecoder;
dwinter
parents:
diff changeset
8 import java.net.URLEncoder;
dwinter
parents:
diff changeset
9 import java.util.ArrayList;
dwinter
parents:
diff changeset
10 import java.util.List;
dwinter
parents:
diff changeset
11 import java.util.regex.Matcher;
dwinter
parents:
diff changeset
12 import java.util.regex.Pattern;
dwinter
parents:
diff changeset
13
dwinter
parents:
diff changeset
14 import org.apache.log4j.Logger;
dwinter
parents:
diff changeset
15 import org.json.JSONArray;
dwinter
parents:
diff changeset
16 import org.json.JSONException;
dwinter
parents:
diff changeset
17 import org.json.JSONObject;
dwinter
parents:
diff changeset
18 import org.restlet.data.ClientInfo;
dwinter
parents:
diff changeset
19 import org.restlet.data.Form;
dwinter
parents:
diff changeset
20 import org.restlet.data.MediaType;
dwinter
parents:
diff changeset
21 import org.restlet.data.Status;
dwinter
parents:
diff changeset
22 import org.restlet.ext.json.JsonRepresentation;
dwinter
parents:
diff changeset
23 import org.restlet.representation.Representation;
dwinter
parents:
diff changeset
24 import org.restlet.representation.StringRepresentation;
dwinter
parents:
diff changeset
25 import org.restlet.resource.Get;
dwinter
parents:
diff changeset
26 import org.restlet.resource.Options;
dwinter
parents:
diff changeset
27 import org.restlet.resource.Post;
dwinter
parents:
diff changeset
28 import org.restlet.resource.ServerResource;
dwinter
parents:
diff changeset
29 import org.restlet.security.User;
dwinter
parents:
diff changeset
30
dwinter
parents:
diff changeset
31 import de.mpiwg.itgroup.annotationManager.Errors.TripleStoreSearchError;
dwinter
parents:
diff changeset
32 import de.mpiwg.itgroup.annotationManager.Errors.TripleStoreStoreError;
dwinter
parents:
diff changeset
33 import de.mpiwg.itgroup.annotationManager.RDFHandling.Convert;
dwinter
parents:
diff changeset
34 import de.mpiwg.itgroup.annotationManager.RDFHandling.Convert.Annotation;
dwinter
parents:
diff changeset
35 import de.mpiwg.itgroup.annotationManager.RDFHandling.RDFSearcher;
dwinter
parents:
diff changeset
36 import de.mpiwg.itgroup.nimanager.exceptions.TripleStoreHandlerException;
dwinter
parents:
diff changeset
37
dwinter
parents:
diff changeset
38 public class AddAndSearchAnnotations extends ServerResource {
dwinter
parents:
diff changeset
39
dwinter
parents:
diff changeset
40 private Logger logger = Logger.getRootLogger();
dwinter
parents:
diff changeset
41
dwinter
parents:
diff changeset
42 /**
dwinter
parents:
diff changeset
43 *
dwinter
parents:
diff changeset
44 * json hash: username: name des users xpointer: xpointer auf den Ausschnitt
dwinter
parents:
diff changeset
45 * (incl. der URL des Dokumentes) text: text der annotation annoturl: url
dwinter
parents:
diff changeset
46 * auf eine Annotation falls extern
dwinter
parents:
diff changeset
47 *
dwinter
parents:
diff changeset
48 * @return
dwinter
parents:
diff changeset
49 */
dwinter
parents:
diff changeset
50
dwinter
parents:
diff changeset
51
dwinter
parents:
diff changeset
52 @Options
dwinter
parents:
diff changeset
53 public void doOptions(Representation entity) {
dwinter
parents:
diff changeset
54 Form responseHeaders = (Form) getResponse().getAttributes().get(
dwinter
parents:
diff changeset
55 "org.restlet.http.headers");
dwinter
parents:
diff changeset
56 if (responseHeaders == null) {
dwinter
parents:
diff changeset
57 responseHeaders = new Form();
dwinter
parents:
diff changeset
58 getResponse().getAttributes().put("org.restlet.http.headers",
dwinter
parents:
diff changeset
59 responseHeaders);
dwinter
parents:
diff changeset
60 }
dwinter
parents:
diff changeset
61 responseHeaders.add("Access-Control-Allow-Origin", "*");
dwinter
parents:
diff changeset
62 responseHeaders.add("Access-Control-Allow-Methods", "POST,OPTIONS,GET");
dwinter
parents:
diff changeset
63 responseHeaders.add("Access-Control-Allow-Headers", "X-Requested-With, Content-Type, X-Annotator-Account-Id, X-Annotator-User-Id, X-Annotator-Auth-Token-Valid-Until, X-Annotator-Auth-Token");
dwinter
parents:
diff changeset
64 responseHeaders.add("Access-Control-Allow-Credentials", "false");
dwinter
parents:
diff changeset
65 responseHeaders.add("Access-Control-Max-Age", "60");
dwinter
parents:
diff changeset
66 }
dwinter
parents:
diff changeset
67
dwinter
parents:
diff changeset
68 @Get("json")
dwinter
parents:
diff changeset
69 public Representation doGetHTML(Representation entity){
dwinter
parents:
diff changeset
70
dwinter
parents:
diff changeset
71 doOptions(entity);
dwinter
parents:
diff changeset
72 Form form = getRequest().getResourceRef().getQueryAsForm();
dwinter
parents:
diff changeset
73 String uri = form.getFirstValue("uri");
dwinter
parents:
diff changeset
74 String user = form.getFirstValue("user");
dwinter
parents:
diff changeset
75
dwinter
parents:
diff changeset
76 String limit=form.getFirstValue("limit");
dwinter
parents:
diff changeset
77 String offset=form.getFirstValue("offset");
dwinter
parents:
diff changeset
78
dwinter
parents:
diff changeset
79
dwinter
parents:
diff changeset
80 //
dwinter
parents:
diff changeset
81 RDFSearcher searcher = new RDFSearcher("file:///annotations"); //TODO should ge into config file
dwinter
parents:
diff changeset
82
dwinter
parents:
diff changeset
83 JSONArray ja;
dwinter
parents:
diff changeset
84 try {
dwinter
parents:
diff changeset
85
dwinter
parents:
diff changeset
86 List<Convert.Annotation> annots=searcher.search(uri,user,limit,offset);
dwinter
parents:
diff changeset
87
dwinter
parents:
diff changeset
88 ja = new JSONArray();
dwinter
parents:
diff changeset
89 for (Convert.Annotation annot:annots){
dwinter
parents:
diff changeset
90 JSONObject jo = new JSONObject();
dwinter
parents:
diff changeset
91 jo.put("text", annot.text);
dwinter
parents:
diff changeset
92 jo.put("uri",annot.url);
dwinter
parents:
diff changeset
93
dwinter
parents:
diff changeset
94 JSONObject userObject= new JSONObject();
dwinter
parents:
diff changeset
95 userObject.put("id",annot.creator);
dwinter
parents:
diff changeset
96
dwinter
parents:
diff changeset
97 RestServer restServer = (RestServer) getApplication();
dwinter
parents:
diff changeset
98 String userName=restServer.getUserNameFromLdap(annot.creator);
dwinter
parents:
diff changeset
99 userObject.put("name",userName);
dwinter
parents:
diff changeset
100
dwinter
parents:
diff changeset
101 jo.put("user",userObject);
dwinter
parents:
diff changeset
102
dwinter
parents:
diff changeset
103 List<String> xpointer = new ArrayList<String>();
dwinter
parents:
diff changeset
104
dwinter
parents:
diff changeset
105 if (annot.xpointers==null || annot.xpointers.size()==0)
dwinter
parents:
diff changeset
106 xpointer.add(annot.xpointer);
dwinter
parents:
diff changeset
107 else {
dwinter
parents:
diff changeset
108 for(String xpointerString:annot.xpointers){
dwinter
parents:
diff changeset
109 xpointer.add(xpointerString);
dwinter
parents:
diff changeset
110 }
dwinter
parents:
diff changeset
111 }
dwinter
parents:
diff changeset
112 jo.put("ranges", transformToRanges(xpointer));
dwinter
parents:
diff changeset
113 ja.put(jo);
dwinter
parents:
diff changeset
114 }
dwinter
parents:
diff changeset
115 } catch (TripleStoreHandlerException e) {
dwinter
parents:
diff changeset
116 // TODO Auto-generated catch block
dwinter
parents:
diff changeset
117 e.printStackTrace();
dwinter
parents:
diff changeset
118 setStatus(Status.SERVER_ERROR_INTERNAL,"TripleStoreHandler Error");
dwinter
parents:
diff changeset
119 return null;
dwinter
parents:
diff changeset
120 } catch (TripleStoreSearchError e) {
dwinter
parents:
diff changeset
121 // TODO Auto-generated catch block
dwinter
parents:
diff changeset
122 e.printStackTrace();
dwinter
parents:
diff changeset
123 setStatus(Status.SERVER_ERROR_INTERNAL,"TripleStoreSearch Error");
dwinter
parents:
diff changeset
124 return null;
dwinter
parents:
diff changeset
125 } catch (JSONException e) {
dwinter
parents:
diff changeset
126 // TODO Auto-generated catch block
dwinter
parents:
diff changeset
127 e.printStackTrace();
dwinter
parents:
diff changeset
128 setStatus(Status.SERVER_ERROR_INTERNAL,"JSon Error");
dwinter
parents:
diff changeset
129 return null;
dwinter
parents:
diff changeset
130 }
dwinter
parents:
diff changeset
131
dwinter
parents:
diff changeset
132 JSONObject retObject = new JSONObject();
dwinter
parents:
diff changeset
133 try {
dwinter
parents:
diff changeset
134 retObject.put("rows",ja);
dwinter
parents:
diff changeset
135 retObject.put("total",ja.length());
dwinter
parents:
diff changeset
136 } catch (JSONException e) {
dwinter
parents:
diff changeset
137 // TODO Auto-generated catch block
dwinter
parents:
diff changeset
138 e.printStackTrace();
dwinter
parents:
diff changeset
139 setStatus(Status.SERVER_ERROR_INTERNAL,"JSon Error");
dwinter
parents:
diff changeset
140 return null;
dwinter
parents:
diff changeset
141 }
dwinter
parents:
diff changeset
142
dwinter
parents:
diff changeset
143 logger.debug("sending:");
dwinter
parents:
diff changeset
144 logger.debug(retObject);
dwinter
parents:
diff changeset
145 return new JsonRepresentation(retObject);
dwinter
parents:
diff changeset
146 }
dwinter
parents:
diff changeset
147
dwinter
parents:
diff changeset
148 private JSONArray transformToRanges(List<String> xpointers) {
dwinter
parents:
diff changeset
149
dwinter
parents:
diff changeset
150 JSONArray ja = new JSONArray();
dwinter
parents:
diff changeset
151
dwinter
parents:
diff changeset
152 Pattern rg = Pattern.compile("#xpointer\\(start-point\\(string-range\\(\"([^\"]*)\",([^,]*),1\\)\\)/range-to\\(end-point\\(string-range\\(\"([^\"]*)\",([^,]*),1\\)\\)\\)\\)");
dwinter
parents:
diff changeset
153 Pattern rg1 = Pattern.compile("#xpointer\\(start-point\\(string-range\\(\"([^\"]*)\",([^,]*),1\\)\\)\\)");
dwinter
parents:
diff changeset
154
dwinter
parents:
diff changeset
155
dwinter
parents:
diff changeset
156
dwinter
parents:
diff changeset
157 try {
dwinter
parents:
diff changeset
158 for(String xpointer:xpointers){
dwinter
parents:
diff changeset
159 String decoded =URLDecoder.decode(xpointer,"utf-8");
dwinter
parents:
diff changeset
160 Matcher m=rg.matcher(decoded);
1
f2f41d0dedf5 minimal changes
dwinter
parents: 0
diff changeset
161
f2f41d0dedf5 minimal changes
dwinter
parents: 0
diff changeset
162 if (m.find()){
0
dwinter
parents:
diff changeset
163 {
dwinter
parents:
diff changeset
164 JSONObject jo = new JSONObject();
dwinter
parents:
diff changeset
165 jo.put("start", m.group(1));
dwinter
parents:
diff changeset
166 jo.put("startOffset", m.group(2));
dwinter
parents:
diff changeset
167 jo.put("end", m.group(3));
dwinter
parents:
diff changeset
168 jo.put("endOffset", m.group(4));
dwinter
parents:
diff changeset
169 ja.put(jo);
1
f2f41d0dedf5 minimal changes
dwinter
parents: 0
diff changeset
170 }
0
dwinter
parents:
diff changeset
171 }
dwinter
parents:
diff changeset
172 m=rg1.matcher(xpointer);
1
f2f41d0dedf5 minimal changes
dwinter
parents: 0
diff changeset
173 if (m.find()){
0
dwinter
parents:
diff changeset
174 JSONObject jo = new JSONObject();
dwinter
parents:
diff changeset
175 jo.put("start", m.group(1));
dwinter
parents:
diff changeset
176 jo.put("startOffset", m.group(2));
dwinter
parents:
diff changeset
177
dwinter
parents:
diff changeset
178 ja.put(jo);
dwinter
parents:
diff changeset
179 }
dwinter
parents:
diff changeset
180
dwinter
parents:
diff changeset
181
dwinter
parents:
diff changeset
182 }
dwinter
parents:
diff changeset
183 } catch (JSONException e) {
dwinter
parents:
diff changeset
184 // TODO Auto-generated catch block
dwinter
parents:
diff changeset
185 e.printStackTrace();
dwinter
parents:
diff changeset
186 } catch (UnsupportedEncodingException e) {
dwinter
parents:
diff changeset
187 // TODO Auto-generated catch block
dwinter
parents:
diff changeset
188 e.printStackTrace();
dwinter
parents:
diff changeset
189 }
dwinter
parents:
diff changeset
190
dwinter
parents:
diff changeset
191
dwinter
parents:
diff changeset
192 return ja;
dwinter
parents:
diff changeset
193
dwinter
parents:
diff changeset
194
dwinter
parents:
diff changeset
195
dwinter
parents:
diff changeset
196
dwinter
parents:
diff changeset
197
dwinter
parents:
diff changeset
198 }
dwinter
parents:
diff changeset
199
dwinter
parents:
diff changeset
200 @Post("json")
dwinter
parents:
diff changeset
201 public Representation doPostJson(Representation entity) {
dwinter
parents:
diff changeset
202
dwinter
parents:
diff changeset
203 String retVal = doPost(entity);
dwinter
parents:
diff changeset
204 JSONObject jo;
dwinter
parents:
diff changeset
205 try {
dwinter
parents:
diff changeset
206 jo = new JSONObject("{\"annotUrl\":\"" + retVal + "\"}");
dwinter
parents:
diff changeset
207 } catch (JSONException e) {
dwinter
parents:
diff changeset
208 setStatus(Status.SERVER_ERROR_INTERNAL);
dwinter
parents:
diff changeset
209 return null;
dwinter
parents:
diff changeset
210 }
dwinter
parents:
diff changeset
211 JsonRepresentation retRep = new JsonRepresentation(jo);
dwinter
parents:
diff changeset
212 return retRep;
dwinter
parents:
diff changeset
213 }
dwinter
parents:
diff changeset
214
dwinter
parents:
diff changeset
215 @Post("html")
dwinter
parents:
diff changeset
216 public Representation doPostHtml(Representation entity) {
dwinter
parents:
diff changeset
217 String retVal = doPost(entity);
dwinter
parents:
diff changeset
218 if (retVal == null) {
dwinter
parents:
diff changeset
219 return null;
dwinter
parents:
diff changeset
220 }
dwinter
parents:
diff changeset
221 String text = String.format(
dwinter
parents:
diff changeset
222 "<html><body><a href=\"%s\">%s</a></body></html>", retVal
dwinter
parents:
diff changeset
223 .replace(">", "").replace("<", ""),
dwinter
parents:
diff changeset
224 retVal.replace(">", "&gt;").replace("<", "&lt;"));
dwinter
parents:
diff changeset
225 Representation retRep = new StringRepresentation(text,
dwinter
parents:
diff changeset
226 MediaType.TEXT_HTML);
dwinter
parents:
diff changeset
227 return retRep;
dwinter
parents:
diff changeset
228 }
dwinter
parents:
diff changeset
229
dwinter
parents:
diff changeset
230 public String doPost(Representation entity) {
dwinter
parents:
diff changeset
231 Convert.Annotation annot;
dwinter
parents:
diff changeset
232 // versuche basic authentifizierung und hole den Benutzer von dort.
dwinter
parents:
diff changeset
233
dwinter
parents:
diff changeset
234 // User authUser;= handleBasicAuthentification(entity);
dwinter
parents:
diff changeset
235
dwinter
parents:
diff changeset
236 if (entity.getMediaType().equals(MediaType.APPLICATION_JSON)) {
dwinter
parents:
diff changeset
237
dwinter
parents:
diff changeset
238 JsonRepresentation jrep;
dwinter
parents:
diff changeset
239 try {
dwinter
parents:
diff changeset
240 jrep = new JsonRepresentation(entity);
dwinter
parents:
diff changeset
241 } catch (IOException e1) {
dwinter
parents:
diff changeset
242 setStatus(Status.SERVER_ERROR_INTERNAL);
dwinter
parents:
diff changeset
243 return null;
dwinter
parents:
diff changeset
244 }
dwinter
parents:
diff changeset
245
dwinter
parents:
diff changeset
246 // try {
dwinter
parents:
diff changeset
247 // logger.debug(jrep.getText());
dwinter
parents:
diff changeset
248 // } catch (IOException e1) {
dwinter
parents:
diff changeset
249 // // TODO Auto-generated catch block
dwinter
parents:
diff changeset
250 // e1.printStackTrace();
dwinter
parents:
diff changeset
251 // }
dwinter
parents:
diff changeset
252 //
dwinter
parents:
diff changeset
253
dwinter
parents:
diff changeset
254 try {
dwinter
parents:
diff changeset
255 JSONObject jo = jrep.getJsonObject();
dwinter
parents:
diff changeset
256 String mode = jo.getString("mode"); // hole modus
dwinter
parents:
diff changeset
257 if (mode==null || mode.equals(""))
dwinter
parents:
diff changeset
258 mode="annotea"; // default mode (annotea) TODO make this configurable
dwinter
parents:
diff changeset
259
dwinter
parents:
diff changeset
260 if (mode.equals("annotator") ) { // annotator format
dwinter
parents:
diff changeset
261 annot = handleAnnotatorSchema(jo, entity);
dwinter
parents:
diff changeset
262 logger.debug("storing annotator object");
dwinter
parents:
diff changeset
263 logger.debug(jo);
dwinter
parents:
diff changeset
264 } else if (mode.equals("annotea")){
dwinter
parents:
diff changeset
265 annot = handleAnnotea(jo, entity);
dwinter
parents:
diff changeset
266 } else {
dwinter
parents:
diff changeset
267 setStatus(Status.CLIENT_ERROR_BAD_REQUEST,"mode "+mode+"not supported!");
dwinter
parents:
diff changeset
268 return null;
dwinter
parents:
diff changeset
269 }
dwinter
parents:
diff changeset
270
dwinter
parents:
diff changeset
271 } catch (JSONException e) {
dwinter
parents:
diff changeset
272 setStatus(Status.CLIENT_ERROR_BAD_REQUEST);
dwinter
parents:
diff changeset
273 return null;
dwinter
parents:
diff changeset
274 }
dwinter
parents:
diff changeset
275
dwinter
parents:
diff changeset
276 } else if (entity.getMediaType().equals(MediaType.APPLICATION_WWW_FORM)) {
dwinter
parents:
diff changeset
277 annot = handleForm(entity);
dwinter
parents:
diff changeset
278
dwinter
parents:
diff changeset
279 } else {
dwinter
parents:
diff changeset
280 setStatus(Status.CLIENT_ERROR_UNSUPPORTED_MEDIA_TYPE);
dwinter
parents:
diff changeset
281
dwinter
parents:
diff changeset
282 return null;
dwinter
parents:
diff changeset
283 }
dwinter
parents:
diff changeset
284
dwinter
parents:
diff changeset
285 if (annot==null){
dwinter
parents:
diff changeset
286 return null;
dwinter
parents:
diff changeset
287 }
dwinter
parents:
diff changeset
288 if (annot.xpointer == null || annot.creator == null) {
dwinter
parents:
diff changeset
289 setStatus(Status.CLIENT_ERROR_BAD_REQUEST);
dwinter
parents:
diff changeset
290
dwinter
parents:
diff changeset
291 return null;
dwinter
parents:
diff changeset
292 }
dwinter
parents:
diff changeset
293
dwinter
parents:
diff changeset
294
dwinter
parents:
diff changeset
295
dwinter
parents:
diff changeset
296 try {
dwinter
parents:
diff changeset
297 return new Convert("file:///annotations").storeAnnotation(annot);
dwinter
parents:
diff changeset
298 } catch (TripleStoreStoreError e) {
dwinter
parents:
diff changeset
299 e.printStackTrace();
dwinter
parents:
diff changeset
300 setStatus(Status.SERVER_ERROR_INTERNAL, "TripleStore Error");
dwinter
parents:
diff changeset
301 return null;
dwinter
parents:
diff changeset
302 }
dwinter
parents:
diff changeset
303 }
dwinter
parents:
diff changeset
304
dwinter
parents:
diff changeset
305 protected Convert.Annotation handleForm(Representation entity) {
dwinter
parents:
diff changeset
306 Convert.Annotation annot;
dwinter
parents:
diff changeset
307 Form form = new Form(entity);
dwinter
parents:
diff changeset
308 String username = form.getValues("username");
dwinter
parents:
diff changeset
309 String password = form.getValues("password");
dwinter
parents:
diff changeset
310 String xpointer = form.getValues("xpointer");
dwinter
parents:
diff changeset
311 String text = form.getValues("text");
dwinter
parents:
diff changeset
312 String url = form.getValues("url");
dwinter
parents:
diff changeset
313 String type = form.getValues("type");
dwinter
parents:
diff changeset
314 RestServer restServer = (RestServer) getApplication();
dwinter
parents:
diff changeset
315
dwinter
parents:
diff changeset
316 // falls user and password nicht null sind:
dwinter
parents:
diff changeset
317 User userFromForm = null;
dwinter
parents:
diff changeset
318 if (username != null && password != null) {
dwinter
parents:
diff changeset
319 if (restServer.authenticate(username, password, getRequest())) {
dwinter
parents:
diff changeset
320 userFromForm = new User(username);
dwinter
parents:
diff changeset
321 }
dwinter
parents:
diff changeset
322 }
dwinter
parents:
diff changeset
323 User authUser = null;
dwinter
parents:
diff changeset
324
dwinter
parents:
diff changeset
325 if (userFromForm == null) {
dwinter
parents:
diff changeset
326 authUser = handleBasicAuthentification(entity);
dwinter
parents:
diff changeset
327 }
dwinter
parents:
diff changeset
328
dwinter
parents:
diff changeset
329 // weder BasicAuth noch FormAuth
dwinter
parents:
diff changeset
330 if (authUser == null && userFromForm == null) {
dwinter
parents:
diff changeset
331 setStatus(Status.CLIENT_ERROR_FORBIDDEN);
dwinter
parents:
diff changeset
332 return null;
dwinter
parents:
diff changeset
333 }
dwinter
parents:
diff changeset
334
dwinter
parents:
diff changeset
335 if (userFromForm != null) {
dwinter
parents:
diff changeset
336 username = userFromForm.getIdentifier();
dwinter
parents:
diff changeset
337 } else {
dwinter
parents:
diff changeset
338 username = authUser.getIdentifier();
dwinter
parents:
diff changeset
339 }
dwinter
parents:
diff changeset
340
dwinter
parents:
diff changeset
341 annot = new Convert.Annotation(xpointer, username, null, text,
dwinter
parents:
diff changeset
342 type, url);
dwinter
parents:
diff changeset
343 return annot;
dwinter
parents:
diff changeset
344 }
dwinter
parents:
diff changeset
345
dwinter
parents:
diff changeset
346 @Post
dwinter
parents:
diff changeset
347 public Representation doPostHtml2(Representation entity) {
dwinter
parents:
diff changeset
348 return doPostHtml(entity);
dwinter
parents:
diff changeset
349 }
dwinter
parents:
diff changeset
350
dwinter
parents:
diff changeset
351 private User handleBasicAuthentification(Representation entity) {
dwinter
parents:
diff changeset
352 RestServer restServer = (RestServer) getApplication();
dwinter
parents:
diff changeset
353 if (!restServer.authenticate(getRequest(), getResponse())) {
dwinter
parents:
diff changeset
354 // Not authenticated
dwinter
parents:
diff changeset
355 return null;
dwinter
parents:
diff changeset
356 }
dwinter
parents:
diff changeset
357
dwinter
parents:
diff changeset
358 ClientInfo ci = getRequest().getClientInfo();
dwinter
parents:
diff changeset
359 logger.debug(ci);
dwinter
parents:
diff changeset
360 return getRequest().getClientInfo().getUser();
dwinter
parents:
diff changeset
361
dwinter
parents:
diff changeset
362 }
dwinter
parents:
diff changeset
363
dwinter
parents:
diff changeset
364 /**
dwinter
parents:
diff changeset
365 * using a minimal annotation format based on the annotea specification
dwinter
parents:
diff changeset
366 *
dwinter
parents:
diff changeset
367 * @param jo
dwinter
parents:
diff changeset
368 * must contain xpointer, text,url,type and can contain a
dwinter
parents:
diff changeset
369 * username, if not the username form the authentification will
dwinter
parents:
diff changeset
370 * be used.
dwinter
parents:
diff changeset
371 * @param authUser
dwinter
parents:
diff changeset
372 * user object
dwinter
parents:
diff changeset
373 * @return
dwinter
parents:
diff changeset
374 * @throws JSONException
dwinter
parents:
diff changeset
375 */
dwinter
parents:
diff changeset
376 public Annotation handleAnnotea(JSONObject jo, Representation entity)
dwinter
parents:
diff changeset
377 throws JSONException {
dwinter
parents:
diff changeset
378
dwinter
parents:
diff changeset
379 User authUser = handleBasicAuthentification(entity);
dwinter
parents:
diff changeset
380 String username = jo.getString("username"); // not required, if no
dwinter
parents:
diff changeset
381 // username given authuser
dwinter
parents:
diff changeset
382 // will be used.
dwinter
parents:
diff changeset
383 String xpointer = jo.getString("xpointer");
dwinter
parents:
diff changeset
384 String text = null;
dwinter
parents:
diff changeset
385 if (jo.has("text"))
dwinter
parents:
diff changeset
386 text = jo.getString("text");
dwinter
parents:
diff changeset
387
dwinter
parents:
diff changeset
388 String url = null;
dwinter
parents:
diff changeset
389 if (jo.has("url"))
dwinter
parents:
diff changeset
390 url = jo.getString("url");
dwinter
parents:
diff changeset
391
dwinter
parents:
diff changeset
392 String type = null;
dwinter
parents:
diff changeset
393 if (jo.has("type"))
dwinter
parents:
diff changeset
394 type = jo.getString("type");
dwinter
parents:
diff changeset
395
dwinter
parents:
diff changeset
396 if (username == null)
dwinter
parents:
diff changeset
397 username = authUser.getIdentifier();
dwinter
parents:
diff changeset
398
dwinter
parents:
diff changeset
399 return new Convert.Annotation(xpointer, username, null, text, type, url);
dwinter
parents:
diff changeset
400 }
dwinter
parents:
diff changeset
401
dwinter
parents:
diff changeset
402 /**
dwinter
parents:
diff changeset
403 * uses the specification from the annotator project.
dwinter
parents:
diff changeset
404 *
dwinter
parents:
diff changeset
405 * @see{https://github.com/okfn/annotator/wiki/Annotation-format The user
dwinter
parents:
diff changeset
406 * object must
dwinter
parents:
diff changeset
407 * contain an
dwinter
parents:
diff changeset
408 * id and
dwinter
parents:
diff changeset
409 * password or
dwinter
parents:
diff changeset
410 * basic
dwinter
parents:
diff changeset
411 * authentification
dwinter
parents:
diff changeset
412 * is used.
dwinter
parents:
diff changeset
413 *
dwinter
parents:
diff changeset
414 * @param jo
dwinter
parents:
diff changeset
415 * @param authUser
dwinter
parents:
diff changeset
416 * @return
dwinter
parents:
diff changeset
417 * @throws JSONException
dwinter
parents:
diff changeset
418 */
dwinter
parents:
diff changeset
419 public Convert.Annotation handleAnnotatorSchema(JSONObject jo,
dwinter
parents:
diff changeset
420 Representation entity) throws JSONException {
dwinter
parents:
diff changeset
421 Convert.Annotation annot;
dwinter
parents:
diff changeset
422 String url = jo.getString("uri");
dwinter
parents:
diff changeset
423 String text = jo.getString("text");
dwinter
parents:
diff changeset
424
dwinter
parents:
diff changeset
425 String username = null;
dwinter
parents:
diff changeset
426 if (jo.has("user")) { // not required, if no username given authuser
dwinter
parents:
diff changeset
427 // will be used otherwise username and password
dwinter
parents:
diff changeset
428 // has to be submitted
dwinter
parents:
diff changeset
429 JSONObject user = jo.getJSONObject("user");
dwinter
parents:
diff changeset
430 if (user.has("id")) {
dwinter
parents:
diff changeset
431 username = user.getString("id");
dwinter
parents:
diff changeset
432 if(!user.has("password")){
dwinter
parents:
diff changeset
433 User authUser = handleBasicAuthentification(entity);
dwinter
parents:
diff changeset
434 if (authUser==null){
dwinter
parents:
diff changeset
435 setStatus(Status.CLIENT_ERROR_FORBIDDEN);
dwinter
parents:
diff changeset
436 return null;
dwinter
parents:
diff changeset
437 }
dwinter
parents:
diff changeset
438 username = authUser.getIdentifier();
dwinter
parents:
diff changeset
439 } else {
dwinter
parents:
diff changeset
440 String password = user.getString("password");
dwinter
parents:
diff changeset
441 if (!((RestServer) getApplication()).authenticate(username,
dwinter
parents:
diff changeset
442 password, getRequest())) {
dwinter
parents:
diff changeset
443 setStatus(Status.CLIENT_ERROR_FORBIDDEN);
dwinter
parents:
diff changeset
444 return null;
dwinter
parents:
diff changeset
445 }
dwinter
parents:
diff changeset
446 }
dwinter
parents:
diff changeset
447 }
dwinter
parents:
diff changeset
448
dwinter
parents:
diff changeset
449 } else {
dwinter
parents:
diff changeset
450 User authUser = handleBasicAuthentification(entity);
dwinter
parents:
diff changeset
451 if (authUser == null) {
dwinter
parents:
diff changeset
452 setStatus(Status.CLIENT_ERROR_FORBIDDEN);
dwinter
parents:
diff changeset
453 return null;
dwinter
parents:
diff changeset
454 }
dwinter
parents:
diff changeset
455 username = authUser.getIdentifier();
dwinter
parents:
diff changeset
456 }
dwinter
parents:
diff changeset
457
dwinter
parents:
diff changeset
458 String xpointer;
dwinter
parents:
diff changeset
459 if (jo.has("ranges")) {
dwinter
parents:
diff changeset
460 JSONObject ranges = jo.getJSONArray("ranges").getJSONObject(0);
dwinter
parents:
diff changeset
461 String start = ranges.getString("start");
dwinter
parents:
diff changeset
462 String end = ranges.getString("end");
dwinter
parents:
diff changeset
463 String startOffset = ranges.getString("startOffset");
dwinter
parents:
diff changeset
464 String endOffset = ranges.getString("endOffset");
dwinter
parents:
diff changeset
465
dwinter
parents:
diff changeset
466 try {
dwinter
parents:
diff changeset
467 xpointer = url+"#"+
dwinter
parents:
diff changeset
468 URLEncoder.encode(String.format(
dwinter
parents:
diff changeset
469 "xpointer(start-point(string-range(\"%s\",%s,1))/range-to(end-point(string-range(\"%s\",%s,1))))",
dwinter
parents:
diff changeset
470 start, startOffset, end, endOffset),"utf-8");
dwinter
parents:
diff changeset
471 } catch (UnsupportedEncodingException e) {
dwinter
parents:
diff changeset
472 e.printStackTrace();
dwinter
parents:
diff changeset
473 setStatus(Status.SERVER_ERROR_INTERNAL);
dwinter
parents:
diff changeset
474 return null;
dwinter
parents:
diff changeset
475 }
dwinter
parents:
diff changeset
476 } else {
dwinter
parents:
diff changeset
477 xpointer = url;
dwinter
parents:
diff changeset
478 }
dwinter
parents:
diff changeset
479 return new Convert.Annotation(xpointer, username, null, text, null);
dwinter
parents:
diff changeset
480 }
dwinter
parents:
diff changeset
481
dwinter
parents:
diff changeset
482 }