Uploaded image for project: 'File Manager Application'
  1. File Manager Application
  2. FILEMAN-82

Velocity error when opening an image

    XMLWordPrintable

Details

    • Bug
    • Resolution: Duplicate
    • Major
    • None
    • 2.0-milestone-3
    • None

    Description

      Steps to reproduce:

      1. Add an image
      2. Try to open it

      You will get this error :

      org.xwiki.rendering.macro.MacroExecutionException: Failed to evaluate Velocity Macro for content [#macro (handleFileWebServiceRequest)
        #if ($request.action)
          #if ($services.csrf.isTokenValid($request.form_token))
            #if ($request.action == 'label')
              #labelFile
            #elseif ($request.action == 'move')
              #moveFile
            #elseif ($request.action == 'copy')
              #copyFile
            #elseif ($request.action == 'delete'
              #deleteFile
            #elseif ($request.action == 'download')
              #downloadFile
            #else
              $response.sendError(400, 'The specified action is not supported.')
            #end
          #elseif ($isAjaxRequest)
            $response.sendError(403, 'The CSRF token is missing.')
          #else
            $response.sendRedirect($services.csrf.getResubmissionURL())
          #end
        #else
          #set ($data = $NULL)
          #getFile($doc $data)
          #if ($data)
            #set ($discard = $response.setContentType('application/json'))
            $jsontool.serialize($data)
          #else
            $response.sendError(404)
          #end
        #end
      #end
      
      #macro (labelFile)
        ## TODO
      #end
      
      #macro (moveFile)
        #set ($jobId = $services.drive.move(["$!request.fromParent/$doc.name"], "$!request.toParent/$!request.name"))
        #handleJobStartFailure($jobId)
      #end
      
      #macro (copyFile)
        #set ($jobId = $services.drive.copy(["/$doc.name"], "$!request.parent/$!request.name"))
        #handleJobStartFailure($jobId)
      #end
      
      #macro (deleteFile)
        #set ($jobId = $services.drive.delete(["$!request.fromParent/$doc.name"]))
        #handleJobStartFailure($jobId)
      #end
      
      #macro (downloadFile)
        #set ($attachments = $doc.attachmentList)
        #if ($attachments.size() > 0)
          $response.sendRedirect($doc.getAttachmentURL($attachments.get(0).filename, 'download', 'force-download=1'))
        #else
          $response.sendError(404)
        #end
      #end
      
      #macro (linkToFileManager)
        #set ($driveReference = $services.model.resolveDocument('', 'default', $doc.documentReference.lastSpaceReference))
        #set ($driveDoc = $xwiki.getDocument($driveReference))
        #if (!$driveDoc.getObject('FileManagerCode.DriveClass'))
          ## TODO
          #set ($driveDoc = $NULL)
        #end
        #if ($driveDoc)
          #set ($driveNode = '/orphanFiles')
          #if ("$!doc.parent" != '')
            #set ($parentReference = $services.model.resolveDocument($doc.parent, 'explicit', $doc.documentReference))
            ## The parent must be on the same drive (space).
            #if ($doc.documentReference.parent.equals($parentReference.parent))
              #set ($driveNode = $parentReference.name)
            #end
          #end
          ## We append the anchor at the end of the URL instead of passing it as a parameter (or link attribute) because the
          ## URL factory encodes the anchor badly, messing the ? and = characters.
          [[View in File Manager>>path:$xwiki.getURL($driveReference)#?driveNode=$escapetool.url($driveNode)]]
        #end
      #end
      
      #macro (openFile)
        #set ($openAs = $collectionstool.orderedMap)
        ## The order is important: from specific to generic viewers/players.
        #set ($openAs.PDF = ['application/pdf'])
        #set ($openAs.Office = ['application/msword', 'application/vnd.ms-', 'application/vnd.oasis.opendocument.',
          'application/vnd.openxmlformats-officedocument.'])
        #set ($openAs.Text = ['text/', 'application/xml', 'application/javascript', 'application/ecmascript',
          'application/json', 'application/x-sh', '+xml'])
        #set ($openAs.Image = ['image/'])
        #set ($openAs.Audio = ['audio/'])
        #set ($openAs.Video = ['video/'])
        #if ($doc.attachmentList.size() > 0)
          #set ($attachment = $doc.attachmentList.get(0))
          #set ($mediaType = $attachment.mimeType.toLowerCase())
          #set ($fileType = $NULL)
          #foreach ($entry in $openAs.entrySet())
            #foreach ($pattern in $entry.value)
              #if ($mediaType == $pattern || $mediaType.startsWith($pattern) || $mediaType.endsWith($pattern))
                #set ($fileType = $entry.key)
                #break
              #end
            #end
            #if ($fileType)
              #break
            #end
          #end
          #if ($fileType)
            #evaluate("${escapetool.h}open${fileType}File(${escapetool.d}attachment)")
          #else
            {{info}}No viewer/player found for media type: $mediaType .{{/info}}
          #end
        #else
          {{error}}No attachment found.{{/error}}
        #end
      #end
      
      #macro (openPDFFile $attachment)
        {{pdfviewer file="$attachment.filename" /}}
      #end
      
      #macro (openOfficeFile $attachment)
        #if ("$!services.officemanager.serverState" == "Connected")
          #if ($services.officeviewer.isMimeTypeSupported($attachment.mimeType.toLowerCase()))
            #set ($attachmentReference = $services.model.createAttachmentReference($doc.documentReference, $attachment.filename))
            #set ($fileNameAsReference = $services.model.serialize($attachmentReference, 'compact', $doc.documentReference))
            {{office attachment="$fileNameAsReference" filterStyles="false" /}}
          #else
            {{info}}Unsupported office file type: $attachment.mimeType .{{/info}}
          #end
        #else
          {{info}}The wiki needs to be connected to an office server in order to view this file.{{/info}}
        #end
      #end
      
      #macro (openTextFile $attachment)
        #if ($attachment.filesize < 500000)
          #set ($language = $stringtool.substringAfterLast($attachment.filename, '.'))
          #if (!$language)
            #set ($language = 'none')
          #end
          {{code language="$language"}}
          $attachment.contentAsString
          {{/code}}
        #else
          {{info}}Text file too large to display.{{/info}}
        #end
      #end
      
      #macro (openImageFile $attachment)
        [[image:path:$doc.getAttachmentURL($attachment.filename)]]
      #end
      
      #macro (openAudioFile $attachment)
        #if ($xwiki.exists('Macros.JWPlayer'))
          {{jwplayer attachment="$doc.getAttachmentURL($attachment.filename)" /}}
        #else
          {{html clean="false"}}
          <audio src="$doc.getAttachmentURL($attachment.filename)" controls="controls">
            Your browser doesn't support HTML5 audio playback.
          </audio>
          {{/html}}
        #end
      #end
      
      #macro (openVideoFile $attachment)
        #if ($xwiki.exists('Macros.JWPlayer'))
          {{jwplayer attachment="$doc.getAttachmentURL($attachment.filename)" /}}
        #else
          {{html clean="false"}}
          <video src="$doc.getAttachmentURL($attachment.filename)" controls="controls">
            Your browser doesn't support HTML5 video playback.
          </video>
          {{/html}}
        #end
      #end]
      	at org.xwiki.rendering.internal.macro.velocity.VelocityMacro.evaluateString(VelocityMacro.java:131)
      	at org.xwiki.rendering.internal.macro.velocity.VelocityMacro.evaluateString(VelocityMacro.java:50)
      	at org.xwiki.rendering.macro.script.AbstractScriptMacro.evaluateBlock(AbstractScriptMacro.java:286)
      	at org.xwiki.rendering.macro.script.AbstractScriptMacro.execute(AbstractScriptMacro.java:182)
      	at org.xwiki.rendering.macro.script.AbstractScriptMacro.execute(AbstractScriptMacro.java:58)
      	at org.xwiki.rendering.internal.transformation.macro.MacroTransformation.transform(MacroTransformation.java:252)
      	at org.xwiki.rendering.internal.transformation.DefaultRenderingContext.transformInContext(DefaultRenderingContext.java:183)
      	at org.xwiki.rendering.internal.transformation.DefaultTransformationManager.performTransformations(DefaultTransformationManager.java:94)
      	at org.xwiki.display.internal.DocumentContentDisplayer.display(DocumentContentDisplayer.java:252)
      	at org.xwiki.display.internal.DocumentContentDisplayer.display(DocumentContentDisplayer.java:125)
      	at org.xwiki.display.internal.DocumentContentDisplayer.display(DocumentContentDisplayer.java:55)
      	at org.xwiki.display.internal.DefaultDocumentDisplayer.display(DefaultDocumentDisplayer.java:96)
      	at org.xwiki.display.internal.DefaultDocumentDisplayer.display(DefaultDocumentDisplayer.java:39)
      	at org.xwiki.sheet.internal.SheetDocumentDisplayer.display(SheetDocumentDisplayer.java:229)
      	at org.xwiki.sheet.internal.SheetDocumentDisplayer.applySheet(SheetDocumentDisplayer.java:209)
      	at org.xwiki.sheet.internal.SheetDocumentDisplayer.maybeDisplayWithSheet(SheetDocumentDisplayer.java:164)
      	at org.xwiki.sheet.internal.SheetDocumentDisplayer.display(SheetDocumentDisplayer.java:102)
      	at org.xwiki.sheet.internal.SheetDocumentDisplayer.display(SheetDocumentDisplayer.java:50)
      	at org.xwiki.display.internal.ConfiguredDocumentDisplayer.display(ConfiguredDocumentDisplayer.java:67)
      	at org.xwiki.display.internal.ConfiguredDocumentDisplayer.display(ConfiguredDocumentDisplayer.java:41)
      	at com.xpn.xwiki.doc.XWikiDocument.getRenderedContent(XWikiDocument.java:1104)
      	at com.xpn.xwiki.doc.XWikiDocument.getRenderedContent(XWikiDocument.java:1082)
      	at com.xpn.xwiki.doc.XWikiDocument.getRenderedContent(XWikiDocument.java:1114)
      	at com.xpn.xwiki.api.Document.getRenderedContent(Document.java:648)
      	at sun.reflect.GeneratedMethodAccessor357.invoke(Unknown Source)
      	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
      	at java.lang.reflect.Method.invoke(Method.java:606)
      	at org.apache.velocity.util.introspection.UberspectImpl$VelMethodImpl.doInvoke(UberspectImpl.java:395)
      	at org.apache.velocity.util.introspection.UberspectImpl$VelMethodImpl.invoke(UberspectImpl.java:384)
      	at org.apache.velocity.runtime.parser.node.ASTMethod.execute(ASTMethod.java:173)
      	at org.apache.velocity.runtime.parser.node.ASTReference.execute(ASTReference.java:280)
      	at org.apache.velocity.runtime.parser.node.ASTReference.value(ASTReference.java:567)
      	at org.apache.velocity.runtime.parser.node.ASTExpression.value(ASTExpression.java:71)
      	at org.apache.velocity.runtime.parser.node.ASTSetDirective.render(ASTSetDirective.java:142)
      	at org.apache.velocity.runtime.parser.node.ASTBlock.render(ASTBlock.java:72)
      	at org.apache.velocity.runtime.parser.node.SimpleNode.render(SimpleNode.java:342)
      	at org.apache.velocity.runtime.parser.node.ASTIfStatement.render(ASTIfStatement.java:106)
      	at org.apache.velocity.runtime.parser.node.ASTBlock.render(ASTBlock.java:72)
      	at org.xwiki.velocity.introspection.TryCatchDirective.render(TryCatchDirective.java:72)
      	at org.apache.velocity.runtime.parser.node.ASTDirective.render(ASTDirective.java:207)
      	at org.apache.velocity.runtime.parser.node.SimpleNode.render(SimpleNode.java:342)
      	at org.xwiki.velocity.internal.DefaultVelocityEngine.evaluateInternal(DefaultVelocityEngine.java:256)
      	at org.xwiki.velocity.internal.DefaultVelocityEngine.evaluate(DefaultVelocityEngine.java:222)
      	at org.xwiki.velocity.internal.DefaultVelocityEngine.evaluate(DefaultVelocityEngine.java:198)
      	at com.xpn.xwiki.internal.template.TemplateManager.evaluateContent(TemplateManager.java:674)
      	at com.xpn.xwiki.internal.template.TemplateManager.render(TemplateManager.java:574)
      	at com.xpn.xwiki.internal.template.TemplateManager.renderFromSkin(TemplateManager.java:555)
      	at com.xpn.xwiki.internal.template.TemplateManager.renderFromSkin(TemplateManager.java:526)
      	at com.xpn.xwiki.internal.template.TemplateManager.render(TemplateManager.java:512)
      	at com.xpn.xwiki.XWiki.evaluateTemplate(XWiki.java:1663)
      	at com.xpn.xwiki.XWiki.parseTemplate(XWiki.java:1643)
      	at com.xpn.xwiki.api.XWiki.parseTemplate(XWiki.java:801)
      	at sun.reflect.GeneratedMethodAccessor155.invoke(Unknown Source)
      	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
      	at java.lang.reflect.Method.invoke(Method.java:606)
      	at org.apache.velocity.util.introspection.UberspectImpl$VelMethodImpl.doInvoke(UberspectImpl.java:395)
      	at org.apache.velocity.util.introspection.UberspectImpl$VelMethodImpl.invoke(UberspectImpl.java:384)
      	at org.apache.velocity.runtime.parser.node.ASTMethod.execute(ASTMethod.java:173)
      	at org.apache.velocity.runtime.parser.node.ASTReference.execute(ASTReference.java:280)
      	at org.apache.velocity.runtime.parser.node.ASTReference.render(ASTReference.java:369)
      	at org.apache.velocity.runtime.parser.node.ASTBlock.render(ASTBlock.java:72)
      	at org.apache.velocity.runtime.directive.VelocimacroProxy.render(VelocimacroProxy.java:216)
      	at org.apache.velocity.runtime.directive.RuntimeMacro.render(RuntimeMacro.java:311)
      	at org.apache.velocity.runtime.directive.RuntimeMacro.render(RuntimeMacro.java:230)
      	at org.apache.velocity.runtime.parser.node.ASTDirective.render(ASTDirective.java:207)
      	at org.apache.velocity.runtime.parser.node.ASTBlock.render(ASTBlock.java:72)
      	at org.apache.velocity.runtime.parser.node.ASTIfStatement.render(ASTIfStatement.java:87)
      	at org.apache.velocity.runtime.parser.node.ASTBlock.render(ASTBlock.java:72)
      	at org.apache.velocity.runtime.parser.node.SimpleNode.render(SimpleNode.java:342)
      	at org.apache.velocity.runtime.parser.node.ASTIfStatement.render(ASTIfStatement.java:106)
      	at org.apache.velocity.runtime.parser.node.SimpleNode.render(SimpleNode.java:342)
      	at org.xwiki.velocity.internal.DefaultVelocityEngine.evaluateInternal(DefaultVelocityEngine.java:256)
      	at org.xwiki.velocity.internal.DefaultVelocityEngine.evaluate(DefaultVelocityEngine.java:222)
      	at org.xwiki.velocity.internal.DefaultVelocityEngine.evaluate(DefaultVelocityEngine.java:198)
      	at com.xpn.xwiki.internal.template.TemplateManager.evaluateContent(TemplateManager.java:674)
      	at com.xpn.xwiki.internal.template.TemplateManager.render(TemplateManager.java:574)
      	at com.xpn.xwiki.internal.template.TemplateManager.renderFromSkin(TemplateManager.java:555)
      	at com.xpn.xwiki.internal.template.TemplateManager.renderFromSkin(TemplateManager.java:526)
      	at com.xpn.xwiki.internal.template.TemplateManager.render(TemplateManager.java:512)
      	at com.xpn.xwiki.XWiki.evaluateTemplate(XWiki.java:1663)
      	at com.xpn.xwiki.web.Utils.parseTemplate(Utils.java:179)
      	at com.xpn.xwiki.web.XWikiAction.execute(XWikiAction.java:358)
      	at com.xpn.xwiki.web.XWikiAction.execute(XWikiAction.java:149)
      	at org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:425)
      	at org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:228)
      	at org.apache.struts.action.ActionServlet.process(ActionServlet.java:1913)
      	at org.apache.struts.action.ActionServlet.doGet(ActionServlet.java:449)
      	at javax.servlet.http.HttpServlet.service(HttpServlet.java:687)
      	at javax.servlet.http.HttpServlet.service(HttpServlet.java:790)
      	at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:769)
      	at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1667)
      	at com.xpn.xwiki.web.ActionFilter.doFilter(ActionFilter.java:115)
      	at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1650)
      	at org.xwiki.wysiwyg.server.filter.ConversionFilter.doFilter(ConversionFilter.java:127)
      	at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1650)
      	at org.xwiki.container.servlet.filters.internal.SetHTTPHeaderFilter.doFilter(SetHTTPHeaderFilter.java:63)
      	at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1650)
      	at com.xpn.xwiki.plugin.webdav.XWikiDavFilter.doFilter(XWikiDavFilter.java:66)
      	at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1650)
      	at org.xwiki.container.servlet.filters.internal.SavedRequestRestorerFilter.doFilter(SavedRequestRestorerFilter.java:208)
      	at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1650)
      	at org.xwiki.container.servlet.filters.internal.SetCharacterEncodingFilter.doFilter(SetCharacterEncodingFilter.java:111)
      	at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1650)
      	at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:583)
      	at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:143)
      	at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:577)
      	at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:223)
      	at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1125)
      	at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:515)
      	at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:185)
      	at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1059)
      	at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:141)
      	at org.eclipse.jetty.server.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:215)
      	at org.eclipse.jetty.server.handler.HandlerCollection.handle(HandlerCollection.java:110)
      	at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:97)
      	at org.eclipse.jetty.server.Server.handle(Server.java:497)
      	at org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:311)
      	at org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:248)
      	at org.eclipse.jetty.io.AbstractConnection$2.run(AbstractConnection.java:540)
      	at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:610)
      	at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:539)
      	at java.lang.Thread.run(Thread.java:745)
      Caused by: org.xwiki.velocity.XWikiVelocityException: Failed to evaluate content with id [xwiki:FileManagerCode.FileSheet]
      	at org.xwiki.velocity.internal.DefaultVelocityEngine.evaluate(DefaultVelocityEngine.java:224)
      	at org.xwiki.velocity.internal.DefaultVelocityEngine.evaluate(DefaultVelocityEngine.java:198)
      	at org.xwiki.rendering.internal.macro.velocity.VelocityMacro.evaluateString(VelocityMacro.java:124)
      	... 121 more
      Caused by: org.apache.velocity.runtime.parser.TemplateParseException: Encountered "#deleteFile" at 14:xwiki:FileManagerCode.FileSheet[line 11, column 1]
      Was expecting one of:
          <RPAREN> ...
          "-" ...
          "+" ...
          "*" ...
          "/" ...
          "%" ...
          <LOGICAL_AND> ...
          <LOGICAL_OR> ...
          <LOGICAL_LT> ...
          <LOGICAL_LE> ...
          <LOGICAL_GT> ...
          <LOGICAL_GE> ...
          <LOGICAL_EQUALS> ...
          <LOGICAL_NOT_EQUALS> ...
          
      	at org.apache.velocity.runtime.parser.Parser.parse(Parser.java:131)
      	at org.apache.velocity.runtime.RuntimeInstance.parse(RuntimeInstance.java:1226)
      	at org.xwiki.velocity.internal.DefaultVelocityEngine.evaluateInternal(DefaultVelocityEngine.java:239)
      	at org.xwiki.velocity.internal.DefaultVelocityEngine.evaluate(DefaultVelocityEngine.java:222)
      	... 123 more
      

      Attachments

        Issue Links

          Activity

            People

              mflorea Marius Dumitru Florea
              gabriela.smeria Gabriela Smeria
              Votes:
              0 Vote for this issue
              Watchers:
              2 Start watching this issue

              Dates

                Created:
                Updated:
                Resolved: