Details
-
Bug
-
Resolution: Duplicate
-
Major
-
None
-
2.0-milestone-3
-
None
Description
Steps to reproduce:
- Add an image
- 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
- duplicates
-
FILEMAN-81 You can't download just one file
-
- Closed
-