| 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; |
| 5 | import de.ids_mannheim.korap.user.User; |
| Michael Hanl | 1e18cb4 | 2015-08-06 20:57:35 +0200 | [diff] [blame] | 6 | |
| 7 | /** |
| 8 | * @author hanl |
| 9 | * @date 30/06/2015 |
| 10 | */ |
| Michael Hanl | f078532 | 2015-11-13 16:14:45 +0100 | [diff] [blame^] | 11 | public interface RewriteTask { |
| Michael Hanl | 1e18cb4 | 2015-08-06 20:57:35 +0200 | [diff] [blame] | 12 | |
| Michael Hanl | f078532 | 2015-11-13 16:14:45 +0100 | [diff] [blame^] | 13 | interface RewriteBefore extends RewriteTask { |
| 14 | /** |
| 15 | * @param node Json node in KoralNode wrapper |
| 16 | * @param config {@link KustvaktConfiguration} singleton instance to use default configuration parameters |
| 17 | * @param user injected by rewrite handler if available. Might cause {@link NullPointerException} if not checked properly |
| 18 | * @return |
| 19 | */ |
| 20 | JsonNode preProcess(KoralNode node, KustvaktConfiguration config, |
| 21 | User user); |
| Michael Hanl | 1e18cb4 | 2015-08-06 20:57:35 +0200 | [diff] [blame] | 22 | } |
| 23 | |
| Michael Hanl | f078532 | 2015-11-13 16:14:45 +0100 | [diff] [blame^] | 24 | interface RewriteAfter extends RewriteTask { |
| 25 | JsonNode postProcess(KoralNode node); |
| 26 | } |
| Michael Hanl | ac4962c | 2015-09-21 22:21:05 +0200 | [diff] [blame] | 27 | |
| 28 | /** |
| 29 | * query rewrites get injected the entire query from root containing all child nodes |
| 30 | * <p/> |
| Michael Hanl | f078532 | 2015-11-13 16:14:45 +0100 | [diff] [blame^] | 31 | * {@link RewriteQuery} does not allow the deletion of the root node or subnode through KoralNode. |
| Michael Hanl | ac4962c | 2015-09-21 22:21:05 +0200 | [diff] [blame] | 32 | * The {@link de.ids_mannheim.korap.resource.rewrite.RewriteHandler} will igonore respecitve invalid requests |
| Michael Hanl | ac4962c | 2015-09-21 22:21:05 +0200 | [diff] [blame] | 33 | */ |
| Michael Hanl | f078532 | 2015-11-13 16:14:45 +0100 | [diff] [blame^] | 34 | interface RewriteQuery extends RewriteBefore, RewriteAfter { |
| Michael Hanl | ac4962c | 2015-09-21 22:21:05 +0200 | [diff] [blame] | 35 | } |
| 36 | |
| Michael Hanl | ac4962c | 2015-09-21 22:21:05 +0200 | [diff] [blame] | 37 | /** |
| Michael Hanl | f078532 | 2015-11-13 16:14:45 +0100 | [diff] [blame^] | 38 | * Koral term nodes that are subject to rewrites |
| Michael Hanl | ac4962c | 2015-09-21 22:21:05 +0200 | [diff] [blame] | 39 | * Be aware that node rewrites are processed before query rewrites. Thus query rewrite may override previous node rewrites |
| Michael Hanl | 59bff81 | 2015-10-27 23:10:32 +0100 | [diff] [blame] | 40 | * <p/> |
| Michael Hanl | f078532 | 2015-11-13 16:14:45 +0100 | [diff] [blame^] | 41 | * {@link RewriteNode} rewrite supports the deletion of the respective node by simply setting the node invalid in KoralNode |
| Michael Hanl | ac4962c | 2015-09-21 22:21:05 +0200 | [diff] [blame] | 42 | */ |
| Michael Hanl | f078532 | 2015-11-13 16:14:45 +0100 | [diff] [blame^] | 43 | interface RewriteNode extends RewriteBefore { |
| 44 | } |
| 45 | |
| 46 | /** |
| 47 | * koral token nodes that are subject to rewrites |
| 48 | * Be aware that node rewrites are processed before query rewrites. Thus query rewrite may override previous node rewrites |
| 49 | * {@link RewriteKoralToken} rewrite DOES NOT support the deletion of the respective node |
| 50 | */ |
| 51 | interface RewriteKoralToken extends RewriteBefore { |
| Michael Hanl | ac4962c | 2015-09-21 22:21:05 +0200 | [diff] [blame] | 52 | } |
| Michael Hanl | 1e18cb4 | 2015-08-06 20:57:35 +0200 | [diff] [blame] | 53 | } |