<!-- 
RSS generated by JIRA (8.20.10#820010-sha1:ace47f9899e9ee25d7157d59aa17ab06aee30d3d) at Wed Feb 07 20:52:10 UTC 2024

It is possible to restrict the fields that are returned in this document by specifying the 'field' parameter in your request.
For example, to request only the issue key and summary append 'field=key&field=summary' to the URL of your request.
-->
<rss version="0.92" >
<channel>
    <title>OpenDaylight JIRA</title>
    <link>https://jira.opendaylight.org</link>
    <description>This file is an XML representation of an issue</description>
    <language>en-us</language>    <build-info>
        <version>8.20.10</version>
        <build-number>820010</build-number>
        <build-date>22-06-2022</build-date>
    </build-info>


<item>
            <title>[YANGTOOLS-67] Getting flow config data in json format causes exception</title>
                <link>https://jira.opendaylight.org/browse/YANGTOOLS-67</link>
                <project id="10188" key="YANGTOOLS">yangtools</project>
                    <description>&lt;p&gt;... and no data is displayed. The exception is as follows&lt;/p&gt;

&lt;p&gt;type Exception report&lt;/p&gt;

&lt;p&gt;message&lt;/p&gt;

&lt;p&gt;description The server encountered an internal error that prevented it from fulfilling this request.&lt;/p&gt;

&lt;p&gt;exception&lt;/p&gt;

&lt;p&gt;java.lang.NullPointerException&lt;br/&gt;
	com.google.common.base.Joiner.join(Joiner.java:230)&lt;br/&gt;
	org.opendaylight.yangtools.yang.data.impl.codec.TypeDefinitionAwareCodec$BitsCodecStringImpl.serialize(TypeDefinitionAwareCodec.java:368)&lt;br/&gt;
	org.opendaylight.yangtools.yang.data.impl.codec.TypeDefinitionAwareCodec$BitsCodecStringImpl.serialize(TypeDefinitionAwareCodec.java:358)&lt;br/&gt;
	org.opendaylight.controller.sal.restconf.impl.RestCodec$ObjectCodec.serialize(RestCodec.java:75)&lt;br/&gt;
	org.opendaylight.controller.sal.rest.impl.JsonMapper.writeValueOfNodeByType(JsonMapper.java:207)&lt;br/&gt;
	org.opendaylight.controller.sal.rest.impl.JsonMapper.writeLeaf(JsonMapper.java:179)&lt;br/&gt;
	org.opendaylight.controller.sal.rest.impl.JsonMapper.writeChildrenOfParent(JsonMapper.java:104)&lt;br/&gt;
	org.opendaylight.controller.sal.rest.impl.JsonMapper.writeList(JsonMapper.java:153)&lt;br/&gt;
	org.opendaylight.controller.sal.rest.impl.JsonMapper.writeChildrenOfParent(JsonMapper.java:92)&lt;br/&gt;
	org.opendaylight.controller.sal.rest.impl.JsonMapper.writeList(JsonMapper.java:158)&lt;br/&gt;
	org.opendaylight.controller.sal.rest.impl.JsonMapper.write(JsonMapper.java:58)&lt;br/&gt;
	org.opendaylight.controller.sal.rest.impl.StructuredDataToJsonProvider.writeTo(StructuredDataToJsonProvider.java:55)&lt;br/&gt;
	org.opendaylight.controller.sal.rest.impl.StructuredDataToJsonProvider.writeTo(StructuredDataToJsonProvider.java:27)&lt;br/&gt;
	com.sun.jersey.spi.container.ContainerResponse.write(ContainerResponse.java:306)&lt;br/&gt;
	com.sun.jersey.server.impl.application.WebApplicationImpl._handleRequest(WebApplicationImpl.java:1479)&lt;br/&gt;
	com.sun.jersey.server.impl.application.WebApplicationImpl.handleRequest(WebApplicationImpl.java:1391)&lt;br/&gt;
	com.sun.jersey.server.impl.application.WebApplicationImpl.handleRequest(WebApplicationImpl.java:1381)&lt;br/&gt;
	com.sun.jersey.spi.container.servlet.WebComponent.service(WebComponent.java:416)&lt;br/&gt;
	com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:538)&lt;br/&gt;
	com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:716)&lt;br/&gt;
	javax.servlet.http.HttpServlet.service(HttpServlet.java:848)&lt;br/&gt;
	org.apache.catalina.filters.CorsFilter.handleNonCORS(CorsFilter.java:440)&lt;br/&gt;
	org.apache.catalina.filters.CorsFilter.doFilter(CorsFilter.java:179)&lt;br/&gt;
note The full stack trace of the root cause is available in the Apache Tomcat/7.0.32 logs.&lt;/p&gt;


&lt;p&gt;This is for a previously configured flow. the URL to get the flow is, for example:&lt;br/&gt;
&lt;a href=&quot;http://192.168.4.192:8080/restconf/config/opendaylight-inventory:nodes/node/openflow:1/table/0/&quot; class=&quot;external-link&quot; target=&quot;_blank&quot; rel=&quot;nofollow noopener&quot;&gt;http://192.168.4.192:8080/restconf/config/opendaylight-inventory:nodes/node/openflow:1/table/0/&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Accept header is &apos;application/json&apos;&lt;/p&gt;</description>
                <environment>&lt;p&gt;Operating System: Linux&lt;br/&gt;
Platform: Other&lt;/p&gt;</environment>
        <key id="22487">YANGTOOLS-67</key>
            <summary>Getting flow config data in json format causes exception</summary>
                <type id="10104" iconUrl="https://jira.opendaylight.org/secure/viewavatar?size=xsmall&amp;avatarId=10303&amp;avatarType=issuetype">Bug</type>
                                                <status id="5" iconUrl="https://jira.opendaylight.org/images/icons/statuses/resolved.png" description="A resolution has been taken, and it is awaiting verification by reporter. From here issues are either reopened, or are closed.">Resolved</status>
                    <statusCategory id="3" key="done" colorName="green"/>
                                    <resolution id="10000">Done</resolution>
                                        <assignee username="-1">Unassigned</assignee>
                                    <reporter username="jmedved@cisco.com">Jan Medved</reporter>
                        <labels>
                    </labels>
                <created>Sat, 21 Dec 2013 08:07:50 +0000</created>
                <updated>Sun, 10 Apr 2022 18:34:56 +0000</updated>
                            <resolved>Thu, 9 Jan 2014 17:11:03 +0000</resolved>
                                                                        <due></due>
                            <votes>0</votes>
                                    <watches>3</watches>
                                                                                                                <comments>
                            <comment id="42598" author="jgloncak" created="Wed, 8 Jan 2014 10:52:42 +0000"  >&lt;p&gt;Hi,&lt;/p&gt;

&lt;p&gt;can you please provide data which you used when mentioned exception was raised.&lt;br/&gt;
Thanks&lt;/p&gt;</comment>
                            <comment id="42599" author="jmedved@cisco.com" created="Wed, 8 Jan 2014 23:37:35 +0000"  >&lt;p&gt;Happens with every flow. For example, take the following flow that was programmed into the controller:&lt;/p&gt;

&lt;p&gt;&amp;lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot; standalone=&quot;no&quot;?&amp;gt;&lt;br/&gt;
&amp;lt;table &lt;br/&gt;
    xmlns=&quot;urn:opendaylight:flow:inventory&quot;&amp;gt;&lt;br/&gt;
    &amp;lt;flow&amp;gt;&lt;br/&gt;
        &amp;lt;strict&amp;gt;false&amp;lt;/strict&amp;gt;&lt;br/&gt;
        &amp;lt;instructions&amp;gt;&lt;br/&gt;
            &amp;lt;instruction&amp;gt;&lt;br/&gt;
                &amp;lt;order&amp;gt;0&amp;lt;/order&amp;gt;&lt;br/&gt;
                &amp;lt;apply-actions&amp;gt;&lt;br/&gt;
                    &amp;lt;action&amp;gt;&lt;br/&gt;
                        &amp;lt;order&amp;gt;0&amp;lt;/order&amp;gt;&lt;br/&gt;
                        &amp;lt;dec-nw-ttl/&amp;gt;&lt;br/&gt;
                    &amp;lt;/action&amp;gt;&lt;br/&gt;
                &amp;lt;/apply-actions&amp;gt;&lt;br/&gt;
            &amp;lt;/instruction&amp;gt;&lt;br/&gt;
        &amp;lt;/instructions&amp;gt;&lt;br/&gt;
        &amp;lt;table_id&amp;gt;0&amp;lt;/table_id&amp;gt;&lt;br/&gt;
        &amp;lt;id&amp;gt;2&amp;lt;/id&amp;gt;&lt;br/&gt;
        &amp;lt;cookie_mask&amp;gt;255&amp;lt;/cookie_mask&amp;gt;&lt;br/&gt;
        &amp;lt;out_port&amp;gt;0&amp;lt;/out_port&amp;gt;&lt;br/&gt;
        &amp;lt;installHw&amp;gt;false&amp;lt;/installHw&amp;gt;&lt;br/&gt;
        &amp;lt;out_group&amp;gt;2&amp;lt;/out_group&amp;gt;&lt;br/&gt;
        &amp;lt;match&amp;gt;&lt;br/&gt;
            &amp;lt;ipv4-destination&amp;gt;10.4.5.6/24&amp;lt;/ipv4-destination&amp;gt;&lt;br/&gt;
            &amp;lt;ethernet-match&amp;gt;&lt;br/&gt;
                &amp;lt;ethernet-type&amp;gt;&lt;br/&gt;
                    &amp;lt;type&amp;gt;2048&amp;lt;/type&amp;gt;&lt;br/&gt;
                &amp;lt;/ethernet-type&amp;gt;&lt;br/&gt;
            &amp;lt;/ethernet-match&amp;gt;&lt;br/&gt;
        &amp;lt;/match&amp;gt;&lt;br/&gt;
        &amp;lt;hard-timeout&amp;gt;0&amp;lt;/hard-timeout&amp;gt;&lt;br/&gt;
        &amp;lt;flags/&amp;gt;&lt;br/&gt;
        &amp;lt;cookie&amp;gt;14&amp;lt;/cookie&amp;gt;&lt;br/&gt;
        &amp;lt;idle-timeout&amp;gt;0&amp;lt;/idle-timeout&amp;gt;&lt;br/&gt;
        &amp;lt;flow-name&amp;gt;FooXf4&amp;lt;/flow-name&amp;gt;&lt;br/&gt;
        &amp;lt;priority&amp;gt;1&amp;lt;/priority&amp;gt;&lt;br/&gt;
        &amp;lt;barrier&amp;gt;false&amp;lt;/barrier&amp;gt;&lt;br/&gt;
    &amp;lt;/flow&amp;gt;&lt;br/&gt;
&amp;lt;/table&amp;gt;&lt;/p&gt;


&lt;p&gt;The URL for putting the flow was as follows:&lt;br/&gt;
&lt;a href=&quot;http://192.168.4.1:8080/restconf/config/opendaylight-inventory:nodes/node/openflow:1/table/0/flow/2&quot; class=&quot;external-link&quot; target=&quot;_blank&quot; rel=&quot;nofollow noopener&quot;&gt;http://192.168.4.1:8080/restconf/config/opendaylight-inventory:nodes/node/openflow:1/table/0/flow/2&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;accept header was application/xml, content header was application/xml&lt;/p&gt;


&lt;p&gt;The i retrieved the operational content of Table 0. URL was:&lt;/p&gt;

&lt;p&gt;&lt;a href=&quot;http://192.168.4.1:8080/restconf/config/opendaylight-inventory:nodes/node/openflow:1/table/0/&quot; class=&quot;external-link&quot; target=&quot;_blank&quot; rel=&quot;nofollow noopener&quot;&gt;http://192.168.4.1:8080/restconf/config/opendaylight-inventory:nodes/node/openflow:1/table/0/&lt;/a&gt;. With content type application/xml i get:&lt;/p&gt;

&lt;p&gt;&amp;lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot; standalone=&quot;no&quot;?&amp;gt;&lt;br/&gt;
&amp;lt;table &lt;br/&gt;
    xmlns=&quot;urn:opendaylight:flow:inventory&quot;&amp;gt;&lt;br/&gt;
    &amp;lt;flow&amp;gt;&lt;br/&gt;
        &amp;lt;strict&amp;gt;false&amp;lt;/strict&amp;gt;&lt;br/&gt;
        &amp;lt;instructions&amp;gt;&lt;br/&gt;
            &amp;lt;instruction&amp;gt;&lt;br/&gt;
                &amp;lt;order&amp;gt;0&amp;lt;/order&amp;gt;&lt;br/&gt;
                &amp;lt;apply-actions&amp;gt;&lt;br/&gt;
                    &amp;lt;action&amp;gt;&lt;br/&gt;
                        &amp;lt;order&amp;gt;0&amp;lt;/order&amp;gt;&lt;br/&gt;
                        &amp;lt;dec-nw-ttl/&amp;gt;&lt;br/&gt;
                    &amp;lt;/action&amp;gt;&lt;br/&gt;
                &amp;lt;/apply-actions&amp;gt;&lt;br/&gt;
            &amp;lt;/instruction&amp;gt;&lt;br/&gt;
        &amp;lt;/instructions&amp;gt;&lt;br/&gt;
        &amp;lt;table_id&amp;gt;0&amp;lt;/table_id&amp;gt;&lt;br/&gt;
        &amp;lt;id&amp;gt;2&amp;lt;/id&amp;gt;&lt;br/&gt;
        &amp;lt;cookie_mask&amp;gt;255&amp;lt;/cookie_mask&amp;gt;&lt;br/&gt;
        &amp;lt;out_port&amp;gt;0&amp;lt;/out_port&amp;gt;&lt;br/&gt;
        &amp;lt;installHw&amp;gt;false&amp;lt;/installHw&amp;gt;&lt;br/&gt;
        &amp;lt;out_group&amp;gt;2&amp;lt;/out_group&amp;gt;&lt;br/&gt;
        &amp;lt;match&amp;gt;&lt;br/&gt;
            &amp;lt;ipv4-destination&amp;gt;10.4.5.6/24&amp;lt;/ipv4-destination&amp;gt;&lt;br/&gt;
            &amp;lt;ethernet-match&amp;gt;&lt;br/&gt;
                &amp;lt;ethernet-type&amp;gt;&lt;br/&gt;
                    &amp;lt;type&amp;gt;2048&amp;lt;/type&amp;gt;&lt;br/&gt;
                &amp;lt;/ethernet-type&amp;gt;&lt;br/&gt;
            &amp;lt;/ethernet-match&amp;gt;&lt;br/&gt;
        &amp;lt;/match&amp;gt;&lt;br/&gt;
        &amp;lt;hard-timeout&amp;gt;0&amp;lt;/hard-timeout&amp;gt;&lt;br/&gt;
        &amp;lt;flags/&amp;gt;&lt;br/&gt;
        &amp;lt;cookie&amp;gt;14&amp;lt;/cookie&amp;gt;&lt;br/&gt;
        &amp;lt;idle-timeout&amp;gt;0&amp;lt;/idle-timeout&amp;gt;&lt;br/&gt;
        &amp;lt;flow-name&amp;gt;FooXf4&amp;lt;/flow-name&amp;gt;&lt;br/&gt;
        &amp;lt;priority&amp;gt;1&amp;lt;/priority&amp;gt;&lt;br/&gt;
        &amp;lt;barrier&amp;gt;false&amp;lt;/barrier&amp;gt;&lt;br/&gt;
    &amp;lt;/flow&amp;gt;&lt;br/&gt;
&amp;lt;/table&amp;gt;&lt;/p&gt;


&lt;p&gt;with content type application/json i get:&lt;/p&gt;

&lt;p&gt;HTTP Status 500 -&lt;/p&gt;

&lt;p&gt;type Exception report&lt;/p&gt;

&lt;p&gt;message&lt;/p&gt;

&lt;p&gt;description The server encountered an internal error that prevented it from fulfilling this request.&lt;/p&gt;

&lt;p&gt;exception&lt;/p&gt;

&lt;p&gt;java.lang.NullPointerException&lt;br/&gt;
	com.google.common.base.Joiner.join(Joiner.java:230)&lt;br/&gt;
	org.opendaylight.yangtools.yang.data.impl.codec.TypeDefinitionAwareCodec$BitsCodecStringImpl.serialize(TypeDefinitionAwareCodec.java:368)&lt;br/&gt;
	org.opendaylight.yangtools.yang.data.impl.codec.TypeDefinitionAwareCodec$BitsCodecStringImpl.serialize(TypeDefinitionAwareCodec.java:358)&lt;br/&gt;
	org.opendaylight.controller.sal.restconf.impl.RestCodec$ObjectCodec.serialize(RestCodec.java:75)&lt;br/&gt;
	org.opendaylight.controller.sal.rest.impl.JsonMapper.writeValueOfNodeByType(JsonMapper.java:207)&lt;br/&gt;
	org.opendaylight.controller.sal.rest.impl.JsonMapper.writeLeaf(JsonMapper.java:179)&lt;br/&gt;
	org.opendaylight.controller.sal.rest.impl.JsonMapper.writeChildrenOfParent(JsonMapper.java:104)&lt;br/&gt;
	org.opendaylight.controller.sal.rest.impl.JsonMapper.writeList(JsonMapper.java:153)&lt;br/&gt;
	org.opendaylight.controller.sal.rest.impl.JsonMapper.writeChildrenOfParent(JsonMapper.java:92)&lt;br/&gt;
	org.opendaylight.controller.sal.rest.impl.JsonMapper.writeList(JsonMapper.java:158)&lt;br/&gt;
	org.opendaylight.controller.sal.rest.impl.JsonMapper.write(JsonMapper.java:58)&lt;br/&gt;
	org.opendaylight.controller.sal.rest.impl.StructuredDataToJsonProvider.writeTo(StructuredDataToJsonProvider.java:55)&lt;br/&gt;
	org.opendaylight.controller.sal.rest.impl.StructuredDataToJsonProvider.writeTo(StructuredDataToJsonProvider.java:27)&lt;br/&gt;
	com.sun.jersey.spi.container.ContainerResponse.write(ContainerResponse.java:306)&lt;br/&gt;
	com.sun.jersey.server.impl.application.WebApplicationImpl._handleRequest(WebApplicationImpl.java:1479)&lt;br/&gt;
	com.sun.jersey.server.impl.application.WebApplicationImpl.handleRequest(WebApplicationImpl.java:1391)&lt;br/&gt;
	com.sun.jersey.server.impl.application.WebApplicationImpl.handleRequest(WebApplicationImpl.java:1381)&lt;br/&gt;
	com.sun.jersey.spi.container.servlet.WebComponent.service(WebComponent.java:416)&lt;br/&gt;
	com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:538)&lt;br/&gt;
	com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:716)&lt;br/&gt;
	javax.servlet.http.HttpServlet.service(HttpServlet.java:848)&lt;br/&gt;
	org.apache.catalina.filters.CorsFilter.handleNonCORS(CorsFilter.java:440)&lt;br/&gt;
	org.apache.catalina.filters.CorsFilter.doFilter(CorsFilter.java:179)&lt;br/&gt;
note The full stack trace of the root cause is available in the Apache Tomcat/7.0.32 logs.&lt;/p&gt;



&lt;p&gt;Sending the logs to you in email, it&apos;s too long to attach...&lt;/p&gt;</comment>
                            <comment id="42600" author="jgloncak" created="Thu, 9 Jan 2014 13:21:59 +0000"  >&lt;p&gt;Try to replace &amp;lt;flags/&amp;gt; with &amp;lt;flags&amp;gt;&amp;lt;/flags&amp;gt;.&lt;/p&gt;</comment>
                            <comment id="42601" author="tony.tkacik@gmail.com" created="Thu, 9 Jan 2014 17:11:03 +0000"  >&lt;p&gt;Fixed in &lt;a href=&quot;https://git.opendaylight.org/gerrit/#/c/4065/&quot; class=&quot;external-link&quot; target=&quot;_blank&quot; rel=&quot;nofollow noopener&quot;&gt;https://git.opendaylight.org/gerrit/#/c/4065/&lt;/a&gt;.&lt;br/&gt;
Bug was caused in YANGtools implementation of bit codec.&lt;/p&gt;</comment>
                    </comments>
                    <attachments>
                    </attachments>
                <subtasks>
                    </subtasks>
                <customfields>
                                                                            <customfield id="customfield_11400" key="com.atlassian.jira.plugins.jira-development-integration-plugin:devsummary">
                        <customfieldname>Development</customfieldname>
                        <customfieldvalues>
                            
                        </customfieldvalues>
                    </customfield>
                                                                                                                        <customfield id="customfield_10208" key="com.atlassian.jira.plugin.system.customfieldtypes:textfield">
                        <customfieldname>External issue ID</customfieldname>
                        <customfieldvalues>
                            <customfieldvalue>258</customfieldvalue>

                        </customfieldvalues>
                    </customfield>
                                                                <customfield id="customfield_10201" key="com.atlassian.jira.plugin.system.customfieldtypes:url">
                        <customfieldname>External issue URL</customfieldname>
                        <customfieldvalues>
                            <customfieldvalue><![CDATA[https://bugs.opendaylight.org/show_bug.cgi?id=258]]></customfieldvalue>

                        </customfieldvalues>
                    </customfield>
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                <customfield id="customfield_10000" key="com.pyxis.greenhopper.jira:gh-lexo-rank">
                        <customfieldname>Rank</customfieldname>
                        <customfieldvalues>
                            <customfieldvalue>0|i024xr:</customfieldvalue>

                        </customfieldvalues>
                    </customfield>
                                                                                                                                                                                </customfields>
    </item>
</channel>
</rss>