configuration icon indicating copy to clipboard operation
configuration copied to clipboard

Unable to extract values from .yang file available inside "identity" for xml file generation.

Open thearpittripathi opened this issue 4 years ago • 1 comments

I am trying to generate xml output using pyang -f xsd --xsd-groups --xsd-no-any-augments filename.yang

Input Yang file: module toaster {

yang-version 1;

namespace "http://netconfcentral.org/ns/toaster";

prefix toast;

organization "Netconf Central";

contact "Andy Bierman [email protected]";

description "YANG version of the TOASTER-MIB.

Copyright (c) 2009 Andy Bierman and the persons identified as authors of the code. All rights reserved.

Redistribution and use in source and binary forms, with or without modification, is permitted pursuant to, and subject to the license terms contained in, the BSD 3-Clause License http://opensource.org/licenses/BSD-3-Clause";

revision "2009-11-20" { description "Toaster module in progress."; }

identity toast-type { description "Base for all bread types supported by the toaster. New bread types not listed here nay be added in the future."; }

identity white-bread { base toast:toast-type; description "White bread."; }

identity wheat-bread { base toast-type; description "Wheat bread."; }

identity wonder-bread { base toast-type; description "Wonder bread."; }

identity frozen-waffle { base toast-type; description "Frozen waffle."; }

identity frozen-bagel { base toast-type; description "Frozen bagel."; }

identity hash-brown { base toast-type; description "Hash browned potatos."; }

typedef DisplayString { type string { length "0 .. 255"; } description "YANG version of the SMIv2 DisplayString TEXTUAL-CONVENTION."; reference "RFC 2579, section 2.";

}

container toaster { presence "Indicates the toaster service is available"; description "Top-level container for all toaster database objects."; leaf toasterManufacturer { type DisplayString; config false; mandatory true; description "The name of the toaster's manufacturer. For instance, Microsoft Toaster."; }

leaf toasterModelNumber {
  type DisplayString;
  config false;
  mandatory true;
  description
    "The name of the toaster's model. For instance,
         Radiant Automatic.";
}

leaf toasterStatus {
  type enumeration {
    enum "up" {
      value 1;
      description
        "The toaster knob position is up.
                No toast is being made now.";
    }
    enum "down" {
      value 2;
      description
        "The toaster knob position is down.
                Toast is being made now.";
    }
  }
  config false;
  mandatory true;
  description
    "This variable indicates the current state of 
         the toaster.";
}

} // container toaster

rpc make-toast { description "Make some toast. The toastDone notification will be sent when the toast is finished. An 'in-use' error will be returned if toast is already being made. A 'resource-denied' error will be returned if the toaster service is disabled."; input { leaf toasterDoneness { type uint32 { range "1 .. 10"; } default '5'; description "This variable controls how well-done is the ensuing toast. It should be on a scale of 1 to 10. Toast made at 10 generally is considered unfit for human consumption; toast made at 1 is warmed lightly."; }

  leaf toasterToastType {
    type identityref {
      base toast:toast-type;
    }
    default 'wheat-bread';
    description
      "This variable informs the toaster of the type of 
             material that is being toasted. The toaster 
             uses this information, combined with 
             toasterDoneness, to compute for how 
             long the material must be toasted to achieve 
             the required doneness.";
  }
}

} // rpc make-toast

rpc cancel-toast { description "Stop making toast, if any is being made. A 'resource-denied' error will be returned if the toaster service is disabled."; } // rpc cancel-toast

notification toastDone { description "Indicates that the toast in progress has completed."; leaf toastStatus { type enumeration { enum "done" { value 0; description "The toast is done."; } enum "cancelled" { value 1; description "The toast was cancelled."; } enum "error" { value 2; description "The toaster service was disabled or the toaster is broken."; } } description "Indicates the final toast status"; } } // notification toastDone } // module toaster

thearpittripathi avatar Sep 13 '21 10:09 thearpittripathi

XML file is generating but does not have all values.

Output XML:


<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:yin="urn:ietf:params:xml:schema:yang:yin:1" xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0" xmlns:ncn="urn:ietf:params:xml:ns:netconf:notification:1.0" targetNamespace="http://netconfcentral.org/ns/toaster" xmlns="http://netconfcentral.org/ns/toaster" elementFormDefault="qualified" attributeFormDefault="unqualified" version="2009-11-20" xml:lang="en" xmlns:toast="http://netconfcentral.org/ns/toaster">

<xs:import namespace="urn:ietf:params:xml:ns:netconf:base:1.0" schemaLocation="http://www.iana.org/assignments/xml-registry/schema/netconf.xsd"/> <xs:import namespace="urn:ietf:params:xml:ns:netconf:notification:1.0" schemaLocation="http://www.iana.org/assignments/xml-registry/schema/notification.xsd"/> xs:annotation xs:documentation This schema was generated from the YANG module toaster by pyang version 1.2.

  The schema describes an instance document consisting
  of the entire configuration data store, operational
  data, rpc operations, and notifications.
  This schema can thus NOT be used as-is to
  validate NETCONF PDUs.
</xs:documentation>

</xs:annotation>

xs:annotation xs:documentation YANG version of the TOASTER-MIB.

  Copyright (c) 2009 Andy Bierman and the persons identified as
  authors of the code.  All rights reserved.

  Redistribution and use in source and binary forms, with or
  without modification, is permitted pursuant to, and subject
  to the license terms contained in, the BSD 3-Clause License
  http://opensource.org/licenses/BSD-3-Clause
</xs:documentation>

</xs:annotation>

<xs:simpleType name="DisplayString"> xs:annotation xs:documentation YANG version of the SMIv2 DisplayString TEXTUAL-CONVENTION. </xs:documentation> </xs:annotation>

<xs:restriction base="xs:string">
  <xs:minLength value="0"/>
  <xs:maxLength value="255"/>
</xs:restriction>

</xs:simpleType>

<xs:element name="toaster"> xs:annotation xs:documentation Top-level container for all toaster database objects. </xs:documentation> </xs:annotation> xs:complexType xs:sequence <xs:element name="toasterManufacturer" type="DisplayString"> xs:annotation xs:documentation The name of the toaster's manufacturer. For instance, Microsoft Toaster. </xs:documentation> </xs:annotation> </xs:element> <xs:element name="toasterModelNumber" type="DisplayString"> xs:annotation xs:documentation The name of the toaster's model. For instance, Radiant Automatic. </xs:documentation> </xs:annotation> </xs:element> <xs:element name="toasterStatus"> xs:annotation xs:documentation This variable indicates the current state of the toaster. </xs:documentation> </xs:annotation> xs:simpleType <xs:restriction base="xs:string"> <xs:enumeration value="up"/> <xs:enumeration value="down"/> </xs:restriction> </xs:simpleType> </xs:element> </xs:sequence> </xs:complexType> </xs:element> <xs:element name="make-toast" substitutionGroup="nc:rpcOperation"> xs:annotation xs:documentation Make some toast. The toastDone notification will be sent when the toast is finished. An 'in-use' error will be returned if toast is already being made. A 'resource-denied' error will be returned if the toaster service is disabled. </xs:documentation> </xs:annotation> xs:complexType xs:complexContent <xs:extension base="nc:rpcOperationType"> xs:sequence <xs:element name="toasterDoneness" minOccurs="0"> xs:annotation xs:documentation This variable controls how well-done is the ensuing toast. It should be on a scale of 1 to 10. Toast made at 10 generally is considered unfit for human consumption; toast made at 1 is warmed lightly. </xs:documentation> </xs:annotation> xs:simpleType <xs:restriction base="xs:unsignedInt"> <xs:minInclusive value="1"/> <xs:maxInclusive value="10"/> </xs:restriction> </xs:simpleType> </xs:element> <xs:element name="toasterToastType" minOccurs="0"> xs:annotation xs:documentation This variable informs the toaster of the type of material that is being toasted. The toaster uses this information, combined with toasterDoneness, to compute for how long the material must be toasted to achieve the required doneness. </xs:documentation> </xs:annotation> xs:simpleType <xs:restriction base="xs:QName"> </xs:restriction> </xs:simpleType> </xs:element> </xs:sequence> </xs:extension> </xs:complexContent> </xs:complexType> </xs:element> <xs:element name="cancel-toast" substitutionGroup="nc:rpcOperation"> xs:annotation xs:documentation Stop making toast, if any is being made. A 'resource-denied' error will be returned if the toaster service is disabled. </xs:documentation> </xs:annotation> xs:complexType xs:complexContent <xs:extension base="nc:rpcOperationType"> xs:sequence </xs:sequence> </xs:extension> </xs:complexContent> </xs:complexType> </xs:element> <xs:element name="toastDone" substitutionGroup="ncn:notificationContent"> xs:annotation xs:documentation Indicates that the toast in progress has completed. </xs:documentation> </xs:annotation> xs:complexType xs:complexContent <xs:extension base="ncn:NotificationContentType"> xs:sequence <xs:element name="toastStatus" minOccurs="0"> xs:annotation xs:documentation Indicates the final toast status </xs:documentation> </xs:annotation> xs:simpleType <xs:restriction base="xs:string"> <xs:enumeration value="done"/> <xs:enumeration value="cancelled"/> <xs:enumeration value="error"/> </xs:restriction> </xs:simpleType> </xs:element> </xs:sequence> </xs:extension> </xs:complexContent> </xs:complexType> </xs:element>

</xs:schema>

thearpittripathi avatar Sep 13 '21 10:09 thearpittripathi