You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@struts.apache.org by "Maurizio Cucchiara (Updated) (JIRA)" <ji...@apache.org> on 2011/10/26 02:18:32 UTC

[jira] [Updated] (WW-3694) JSONResult - buildSMDObject method is never called internally

     [ https://issues.apache.org/jira/browse/WW-3694?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Maurizio Cucchiara updated WW-3694:
-----------------------------------

    Attachment: WW-3694.patch

Calling directly {{buildSMD}} would risk to loop infinitely. 
Please check the attached patch and let me know what you think about.

                
> JSONResult - buildSMDObject method is never called internally
> -------------------------------------------------------------
>
>                 Key: WW-3694
>                 URL: https://issues.apache.org/jira/browse/WW-3694
>             Project: Struts 2
>          Issue Type: Bug
>          Components: Plugin - JSON
>    Affects Versions: 2.2.3.1
>         Environment: Tomcat on windows, JDK1.5
>            Reporter: Alex Yavorskiy
>         Attachments: WW-3694.patch
>
>
> Pre version 2.2.3.1 JSONResult object used to have a protected method that allowed us to have a subclass that could modify URL of the SMD command being sent in the response right before it was sent. That method was "writeSMD". In version 2.2.3.1 of Struts there is no more method named "writeSMD", but there appears to be equivalent protected method named "buildSMDObject". However, we observed that buildSMDObject is never called by the infrastructure, so there is no use overriding it.
> After inspecting source for JSONResult, it looks like line 180 in the readRootObject function is really intended to call buildSMDObject. However, instead of calling the protected method in question, it creates SMD object right there.
>  if (enableSMD) {
>             return new SMDGenerator(root, excludeProperties, ignoreInterfaces).generate(invocation);
>         }
> Fixing line 180 to call buildSMDObject should fix the issue. We had to significantly re-write our subclass for JSONResult to work around the deficiency. Hope this can be fixed in a future release.

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators: https://issues.apache.org/jira/secure/ContactAdministrators!default.jspa
For more information on JIRA, see: http://www.atlassian.com/software/jira