raml2ts
TypeScript icon, indicating that this package has built-in type declarations

0.0.9 • Public • Published

RAML2TS

At this moment goal of this module is to convert RAML files into JSON structures, which can be easily parsed and processed by type bindings module.

In a few words it performs following transformations:

  • expand all type expressions
  • collect used types from libraries and put them into main namespace with unique name
  • collect information about CRUD operations/member collections related to types and insert this information in a serialized types
  • merge facets and annotations into single namespace (types only).
  • discover map types
  • few more minor transforms.

One example of transform is:

#%RAML 1.0 Library 
uses:
  core: coreLib.raml
types:
  StudentClass:
    properties:
      name: string
      teacherFullName: string
      courseDescription: core.text
      numberOfHours:
       type: integer
       minimum: 1
       maximum: 192
 

transforms to:

{
  "StudentClass": {
    "id": "StudentClass",
    "type": "object",
    "properties": {
      "name": {
        "type": "string",
        "required": true
      },
      "teacherFullName": {
        "type": "string",
        "required": true
      },
      "courseDescription": {
        "type": "text",
        "required": true
      },
      "numberOfHours": {
        "type": "integer",
        "minimum": 1,
        "maximum": 192,
        "required": true
      }
    }
  }
}
 
 

in a more complex case:

#%RAML 1.0 Library 
uses:
  core: coreLib.raml
types:
  Party:
    properties:
      name:
        type: string
      leaders:
        (core.enumValues): "$.members"
      members:
        properties:
          //:
            type: string
            displayName: Class
            enum: ["Warrior", "Mage", "Priest", "Ranger"]

transforms to something like

{
  "Party": {
    "id": "Party",
    "type": "object",
    "properties": {
      "name": {
        "type": "string",
        "required": true
      },
      "leaders": {
        "type": "string",
        "enumValues": "$.members",
        "required": true
      },
      "members": {
        "type": "map",
        "componentType": {
          "type": "string",
          "displayName": "Class",
          "enum": [
            "Warrior",
            "Mage",
            "Priest",
            "Ranger"
          ]
        },
        "required": true
      }
    }
  }
}

Used format is not thought as final, it is just a very temporary solution to play with.

Actually this format is pretty similar to the one used in JS Parser now, (with except of addition of operations related connections, and more simple way to access type information, so it mmight be a good idea to check if it might be done in a more elegant way basing on latest changes in parser serialization)

Main function of the module is: parseToJSON(url: string, f: (v: ProcessingResult) => void): void which actually performs transformation

It is planned to add typescript client gen using this representation as internal information storage to this repository later.

Readme

Keywords

none

Package Sidebar

Install

npm i raml2ts

Weekly Downloads

3

Version

0.0.9

License

none

Last publish

Collaborators

  • petrochenko-pavel-a