| Michael Hanl | 1e18cb4 | 2015-08-06 20:57:35 +0200 | [diff] [blame] | 1 | package de.ids_mannheim.korap.resource.rewrite; |
| 2 | |
| 3 | import com.fasterxml.jackson.databind.JsonNode; |
| Michael Hanl | 59bff81 | 2015-10-27 23:10:32 +0100 | [diff] [blame] | 4 | import de.ids_mannheim.korap.config.KustvaktConfiguration; |
| Michael Hanl | ac4962c | 2015-09-21 22:21:05 +0200 | [diff] [blame] | 5 | import de.ids_mannheim.korap.exceptions.KustvaktException; |
| 6 | import de.ids_mannheim.korap.resources.Corpus; |
| 7 | import de.ids_mannheim.korap.resources.KustvaktResource; |
| 8 | import de.ids_mannheim.korap.security.ac.SecurityManager; |
| Michael Hanl | 59bff81 | 2015-10-27 23:10:32 +0100 | [diff] [blame] | 9 | import de.ids_mannheim.korap.user.User; |
| Michael Hanl | 1e18cb4 | 2015-08-06 20:57:35 +0200 | [diff] [blame] | 10 | |
| 11 | /** |
| 12 | * @author hanl |
| 13 | * @date 03/07/2015 |
| 14 | */ |
| Michael Hanl | ac4962c | 2015-09-21 22:21:05 +0200 | [diff] [blame] | 15 | // todo: test |
| Michael Hanl | f078532 | 2015-11-13 16:14:45 +0100 | [diff] [blame] | 16 | public class CollectionConstraint implements RewriteTask.RewriteNode { |
| Michael Hanl | ac4962c | 2015-09-21 22:21:05 +0200 | [diff] [blame] | 17 | |
| Michael Hanl | 1e18cb4 | 2015-08-06 20:57:35 +0200 | [diff] [blame] | 18 | @Override |
| Michael Hanl | f078532 | 2015-11-13 16:14:45 +0100 | [diff] [blame] | 19 | public JsonNode preProcess(KoralNode node, KustvaktConfiguration config, |
| Michael Hanl | 59bff81 | 2015-10-27 23:10:32 +0100 | [diff] [blame] | 20 | User user) { |
| Michael Hanl | f078532 | 2015-11-13 16:14:45 +0100 | [diff] [blame] | 21 | |
| 22 | if (node.get("@type").equals("koral:doc")) { |
| 23 | if (node.get("key").equals("corpusID") && !check(node, user)) { |
| 24 | node.removeNode(); |
| Michael Hanl | 1e18cb4 | 2015-08-06 20:57:35 +0200 | [diff] [blame] | 25 | // todo: add message that node was removed! |
| 26 | } |
| 27 | } |
| Michael Hanl | f078532 | 2015-11-13 16:14:45 +0100 | [diff] [blame] | 28 | return node.rawNode(); |
| Michael Hanl | 1e18cb4 | 2015-08-06 20:57:35 +0200 | [diff] [blame] | 29 | } |
| 30 | |
| Michael Hanl | f078532 | 2015-11-13 16:14:45 +0100 | [diff] [blame] | 31 | /** |
| 32 | * @param node |
| 33 | * @param user |
| 34 | * @return boolean if true access granted |
| 35 | */ |
| Michael Hanl | 59bff81 | 2015-10-27 23:10:32 +0100 | [diff] [blame] | 36 | private boolean check(KoralNode node, User user) { |
| Michael Hanl | f078532 | 2015-11-13 16:14:45 +0100 | [diff] [blame] | 37 | // todo: can be used to circumvent access control! |
| Michael Hanl | 59bff81 | 2015-10-27 23:10:32 +0100 | [diff] [blame] | 38 | if (user == null) |
| Michael Hanl | ac4962c | 2015-09-21 22:21:05 +0200 | [diff] [blame] | 39 | return true; |
| 40 | |
| Michael Hanl | f078532 | 2015-11-13 16:14:45 +0100 | [diff] [blame] | 41 | String id = node.get("value"); |
| Michael Hanl | ac4962c | 2015-09-21 22:21:05 +0200 | [diff] [blame] | 42 | KustvaktResource corpus; |
| 43 | try { |
| 44 | SecurityManager m = SecurityManager |
| Michael Hanl | 59bff81 | 2015-10-27 23:10:32 +0100 | [diff] [blame] | 45 | .findbyId(id, user, Corpus.class); |
| Michael Hanl | ac4962c | 2015-09-21 22:21:05 +0200 | [diff] [blame] | 46 | corpus = m.getResource(); |
| Michael Hanl | f078532 | 2015-11-13 16:14:45 +0100 | [diff] [blame] | 47 | }catch (RuntimeException | KustvaktException e) { |
| 48 | e.printStackTrace(); |
| Michael Hanl | ac4962c | 2015-09-21 22:21:05 +0200 | [diff] [blame] | 49 | return false; |
| 50 | } |
| Michael Hanl | f078532 | 2015-11-13 16:14:45 +0100 | [diff] [blame] | 51 | |
| Michael Hanl | ac4962c | 2015-09-21 22:21:05 +0200 | [diff] [blame] | 52 | return corpus != null; |
| Michael Hanl | 1e18cb4 | 2015-08-06 20:57:35 +0200 | [diff] [blame] | 53 | } |
| 54 | |
| 55 | } |