diff --git a/pom.xml b/pom.xml index 69c07ee7f91aee541dedc34b906fca2d6cbfa76f..9c1bb5ee6350cd3b060d333ec60e75fdb6adc457 100644 --- a/pom.xml +++ b/pom.xml @@ -1917,7 +1917,7 @@ <dependency> <groupId>org.openolat.jamwiki</groupId> <artifactId>jamwiki-core</artifactId> - <version>1.0.1</version> + <version>1.0.2</version> </dependency> <dependency> <groupId>org.openolat</groupId> diff --git a/src/main/java/org/olat/core/util/filter/impl/OpenOLATPolicy.java b/src/main/java/org/olat/core/util/filter/impl/OpenOLATPolicy.java index 35a7c9f80440f195f925ff2d0eb24067dd69b68c..7260236861f1fe3d845ff0a5a0180b729de363fd 100644 --- a/src/main/java/org/olat/core/util/filter/impl/OpenOLATPolicy.java +++ b/src/main/java/org/olat/core/util/filter/impl/OpenOLATPolicy.java @@ -45,11 +45,12 @@ public class OpenOLATPolicy { private static final String MEDIA_HOST = "http://my" + CodeHelper.getForeverUniqueID() + "localhost:8123/"; private static final Pattern PARAGRAPH = Pattern.compile("([\\p{L}\\p{N},'\\.\\s\\-_\\(\\)]|&[0-9]{2};)*"); - private static final Pattern COLORNAME = Pattern.compile("(aqua|black|blue|fuchsia|gray|grey|green|lime|maroon|navy|olive|purple|red|silver|teal|white|yellow)"); + private static final Pattern COLORNAME = Pattern.compile("(aqua|black|blue|fuchsia|gray|grey|green|lime|maroon|navy|olive|rebeccapurple|purple|red|silver|teal|white|yellow)"); private static final Pattern OFFSITEURL = Pattern.compile("(\\s)*((ht)tp(s?)://|mailto:)[\\p{L}\\p{N}]+[\\p{L}\\p{N}\\p{Zs}\\.\\#@\\$%\\+&;:\\-_~,\\?=/!\\(\\)]*(\\s)*"); private static final Pattern HTMLCLASS = Pattern.compile("[a-zA-Z0-9\\s,-_]+"); private static final Pattern ANYTHING = Pattern.compile(".*"); private static final Pattern ONSITEURL = Pattern.compile("([\\p{L}\\p{N}\\p{Zs}/\\.\\?=&\\-~_]|ccrep:)+"); + private static final Pattern ANCHOR = Pattern.compile("#[a-zA-Z0-9_]*"); private static final Pattern NUMBER = Pattern.compile("[0-9]+"); private static final Pattern HTMLTITLE = Pattern.compile("[a-zA-Z0-9\\s-_',:\\[\\]!\\./\\\\\\(\\)%&;\\+#]*"); private static final Pattern OLATINTERNALURL = Pattern.compile("javascript:parent\\.gotonode\\(\\d+\\)"); @@ -156,7 +157,7 @@ public class OpenOLATPolicy { .allowAttributes("rel") .matching(false,"nofollow").onElements("a") .allowAttributes("href") - .matching(new Patterns(ONSITEURL, OFFSITEURL, OLATINTERNALURL)) + .matching(new Patterns(ONSITEURL, OFFSITEURL, OLATINTERNALURL, ANCHOR)) .onElements("a") .allowAttributes("onclick") .matching(new OnClickValues()) @@ -363,22 +364,29 @@ public class OpenOLATPolicy { private final Pattern a; private final Pattern b; private final Pattern c; + private final Pattern d; public Patterns(Pattern a, Pattern b) { this(a, b, null); } public Patterns(Pattern a, Pattern b, Pattern c) { + this(a, b ,c , null); + } + + public Patterns(Pattern a, Pattern b, Pattern c, Pattern d) { this.a = a; this.b = b; this.c = c; + this.d = d; } @Override public boolean apply(String s) { return a.matcher(s).matches() || b.matcher(s).matches() - || c == null || c.matcher(s).matches(); + || c == null || c.matcher(s).matches() + || d == null || d.matcher(s).matches(); } // Needed for Java8 compat with later Guava that extends diff --git a/src/test/java/org/olat/core/util/filter/impl/XSSFilterParamTest.java b/src/test/java/org/olat/core/util/filter/impl/XSSFilterParamTest.java index da04872777d86315424f56f20e754bbd06f33f0e..a8c8d968de69deb6315fc6afe453e6d18b678230 100644 --- a/src/test/java/org/olat/core/util/filter/impl/XSSFilterParamTest.java +++ b/src/test/java/org/olat/core/util/filter/impl/XSSFilterParamTest.java @@ -188,7 +188,12 @@ public class XSSFilterParamTest { { "<a href=\"media/LTT ZUJ SCM 09.09.2019.pdf\">doc</a>", "<a href=\"media/LTT%20ZUJ%20SCM%2009.09.2019.pdf\">doc</a>" }, { "<a href=\"media/LTT%20ZUJ%20SCM%2009.09.2019.pdf\">doc</a>", "<a href=\"media/LTT%20ZUJ%20SCM%2009.09.2019.pdf\">doc</a>" }, { "<p><img class=\"b_float_left\" src=\"media/IMG 1484.jpg\" width=\"74\" height=\"74\" /></p>", "<p><img class=\"b_float_left\" src=\"media/IMG%201484.jpg\" width=\"74\" height=\"74\" /></p>" }, - { null, "" } // be tolerant + // link with anchor + { "<a href=\"#Summary\">Summary</a>", "<a href=\"#Summary\">Summary</a>" }, + { "<a href=\"#Title_1\">Title 1</a>", "<a href=\"#Title_1\">Title 1</a>" }, + { "<a href=\"#Title 1\">Title with space</a>", "<a>Title with space</a>" }, + { "<a href=\"#Title#1\">Title with #</a>", "<a>Title with #</a>" }, + { null, "" } // be tolerant }); }