Enhance Parser with a ParserContext.
[Sone.git] / src / main / java / net / pterodactylus / sone / text / FreenetLinkParser.java
index 24eac3b..fe602c6 100644 (file)
@@ -21,21 +21,22 @@ import java.io.BufferedReader;
 import java.io.IOException;
 import java.io.Reader;
 import java.io.StringReader;
+import java.net.MalformedURLException;
 import java.util.logging.Level;
 import java.util.logging.Logger;
 import java.util.regex.Matcher;
 import java.util.regex.Pattern;
 
-import net.pterodactylus.sone.data.Sone;
 import net.pterodactylus.util.logging.Logging;
 import net.pterodactylus.util.template.TemplateFactory;
+import freenet.keys.FreenetURI;
 
 /**
  * {@link Parser} implementation that can recognize Freenet URIs.
  *
  * @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
  */
-public class FreenetLinkParser implements Parser {
+public class FreenetLinkParser implements Parser<FreenetLinkParserContext> {
 
        /** The logger. */
        private static final Logger logger = Logging.getLogger(FreenetLinkParser.class);
@@ -73,9 +74,6 @@ public class FreenetLinkParser implements Parser {
        /** The template factory. */
        private final TemplateFactory templateFactory;
 
-       /** The Sone that posted the currently parsed text. */
-       private Sone postingSone;
-
        /**
         * Creates a new freenet link parser.
         *
@@ -87,22 +85,6 @@ public class FreenetLinkParser implements Parser {
        }
 
        //
-       // ACCESSORS
-       //
-
-       /**
-        * Sets the Sone that posted the text that will be parsed in the next call
-        * to {@link #parse(Reader)}. You need to synchronize calling this method
-        * and {@link #parse(Reader)}!
-        *
-        * @param sone
-        *            The Sone that posted the text
-        */
-       public void setPostingSone(Sone sone) {
-               postingSone = sone;
-       }
-
-       //
        // PART METHODS
        //
 
@@ -110,7 +92,7 @@ public class FreenetLinkParser implements Parser {
         * {@inheritDoc}
         */
        @Override
-       public Part parse(Reader source) throws IOException {
+       public Part parse(FreenetLinkParserContext context, Reader source) throws IOException {
                PartContainer parts = new PartContainer();
                BufferedReader bufferedReader = (source instanceof BufferedReader) ? (BufferedReader) source : new BufferedReader(source);
                String line;
@@ -176,7 +158,7 @@ public class FreenetLinkParser implements Parser {
                                                                        name = name.substring(name.lastIndexOf('/', name.lastIndexOf('/') - 1));
                                                                } else {
                                                                        /* shorten to 5 chars. */
-                                                                       name = name.substring(4, 9);
+                                                                       name = name.substring(4, Math.min(9, name.length()));
                                                                }
                                                        }
                                                }
@@ -185,9 +167,17 @@ public class FreenetLinkParser implements Parser {
                                                }
                                                boolean fromPostingSone = false;
                                                if ((linkType == LinkType.SSK) || (linkType == LinkType.USK)) {
-                                                       fromPostingSone = link.substring(4, 47).equals(postingSone.getId());
+                                                       try {
+                                                               new FreenetURI(link);
+                                                               fromPostingSone = link.substring(4, 47).equals(context.getPostingSone().getId());
+                                                               parts.add(fromPostingSone ? createTrustedFreenetLinkPart(link, name) : createFreenetLinkPart(link, name));
+                                                       } catch (MalformedURLException mue1) {
+                                                               /* it’s not a valid link. */
+                                                               parts.add(createPlainTextPart(link));
+                                                       }
+                                               } else {
+                                                       parts.add(fromPostingSone ? createTrustedFreenetLinkPart(link, name) : createFreenetLinkPart(link, name));
                                                }
-                                               parts.add(fromPostingSone ? createTrustedFreenetLinkPart(link, name) : createFreenetLinkPart(link, name));
                                        } else if ((linkType == LinkType.HTTP) || (linkType == LinkType.HTTPS)) {
                                                name = link.substring(linkType == LinkType.HTTP ? 7 : 8);
                                                int firstSlash = name.indexOf('/');