azure-sdk-for-node/runtime/ms-rest
Rikki Gibson 6f2832f487 Update ms-rest deps 2018-06-11 10:34:58 -07:00
..
lib Update ms-rest deps 2018-06-11 10:34:58 -07:00
test Update ms-rest deps 2018-06-11 10:34:58 -07:00
.gitignore
.npmignore
Changelog.md Bump ms-rest version to 2.3.3 to solve azure package reference problems 2018-04-05 15:10:31 -07:00
LICENSE
README.md
index.d.ts Update WebResource definition in index.d.ts 2017-12-12 14:12:22 -08:00
ms-rest.njsproj
package-lock.json Update ms-rest deps 2018-06-11 10:34:58 -07:00
package.json Update ms-rest deps 2018-06-11 10:34:58 -07:00

README.md

MS-Rest

Infrastructure for serialization/deserialization, error handling, tracing, and http client pipeline configuration. Required by nodeJS client libraries generated using AutoRest.

  • Node.js version: 4.x.x or higher

How to Install

npm install ms-rest

Usage

var msrest = require('ms-rest');

Serialization/Deserialization

Features

  • Type checking

    • (String, Number, Boolean, ByteArray, Base64Url, Date, DateTime, Enum, TimeSpan, DateTimeRfc1123, UnixTime, Object, Stream, Sequence, Dictionary, Composite, Uuid(as a string))
  • Validation of specified constraints

    • ExclusiveMaximum, ExclusiveMinimum, InclusiveMaximum, InclusiveMinimum, MaxItems, MaxLength, MinItems, MinLength, MultipleOf, Pattern, UniqueItems
  • Flattening/Unflattening properties

  • Default Values

  • Model Properties marked as constant are set during serialization, irrespective of they being provided or not

  • Required check (If a model or property is marked required and is not provided in the object then an error is thrown)

  • Readonly check (If a model or property is marked readonly then it is not sent on the wire during, serialization)

  • Serializing Constant values

  • serialize an array of dictionary of primitive values

var mapper = {
  type : {
    name: 'Sequence', 
    element: {
      type : {
        name: 'Dictionary',
        value: {
          type: {
            name: 'Boolean'
          }
        }
      }
    }
  }
};
var array = [{ 1: true }, { 2: false }, { 1: true, 2: false, 3: true }];
var serializedArray = msRest.serialize(mapper, array, 'arrayObj');
assert.deepEqual(array, serializedArray);
var serializedProduct = msrest.serialize(mapper, productObj, 'productObject');
var deserializedArray = msRest.deserialize(mapper, serializedArray, 'serializedArrayObj');

For more examples on serialization/deserialization with complex types please take a look over here.