Home Reference Source Repository

schema-mapper-tranformer

Transform an Item or Metadata by applying Changes to it.

build status Docs status

Installation

npm install --save schema-mapper-transformer

Usage

Transforming an item

Items can be transformed by applying changes to it. The following table shows how the item object is modified by each type of change

var transformer = require('schema-mapper-transformer');
var item = {
  user_id: 1,
  name: 'Koen'
};
var changes = [
  {
    change: 'column.rename',
    projectId: '1',
    schemaId: '1',
    columnId: '1',
    name: 'id',
    oldName: 'user_id'
  },
  {
    change: 'column.create',
    projectId: '1',
    schemaId: '1',
    columnId: '3',
    column: {
      name: 'email',
      type: 'string'
    }
  },
  {
    change: 'column.remove',
    projectId: '1',
    schemaId: '1',
    columnId: '2',
    oldColumn: {
      name: 'name',
      type: 'string'
    }
  }
];
var result = transformer.transformItem(item, changes);
console.log(result);
{
  id: 1,
  email: null
}

Transforming metadata

Metadata can be transformed by applying changes to it. The following table shows how the metadata object is modified by each type of change

var metadata = {
  projectName: 'demo',
  projectVersion: 1,
  schemaName: 'users'
};
var changes = [
  {
    change: 'project.rename',
    projectId: '1',
    name: 'demoproject',
    oldName: 'demo'
  },
  {
    change: 'project.tag',
    projectId: '1',
    version: 2,
    oldVersion: 1
  },
  {
    change: 'schema.rename',
    projectId: '1',
    schemaId: '1',
    oldName: 'user',
    name: 'users'
  }
];

var result = transformer.transformMetadata(metadata, changes);
console.log(result);
{
  projectName: 'demoproject',
  projectVersion: 2,
  schemaName: 'users'
}

API docs

API Docs

Licence

MIT