3.0.0-rc.1 • Published 6 years ago

json-patch-queue v3.0.0-rc.1

Weekly downloads
1
License
MIT
Repository
github
Last release
6 years ago

JSON-Patch-Queue Build Status

Makes your JSON Patch application sequential

Implements a queue of JSON Patches, based on Versioned JSON Patch convention, that will resolve a problem of sequential application of JSON Patches.

Demo

Full Versioned JSON Patch + OT visualization

Specific visualization will come soon.

Install

Install the component using NPM

$ npm install json-patch-queue --save

Or

Install the component using Bower:

$ bower install json-patch-queue --save

Or download as ZIP.

Usage

Single Versioned

var targetObject = {};
// create queue
var myQueue = new JSONPatchQueueSynchronous(targetObject, "/path_to_version", jsonpatch);
// to compose versioned JSON Patch, to be send somewhere?
var versionedPatchToBeSent = myQueue.send(regularpatch);
// to apply/queue received versioned  JSON Patch
myQueue.receive(receivedVersionedPatch);

Multiple Versioned

var targetObject = {};

// create queue
var myQueue = new JSONPatchQueue(targetObject, ["/local_version", "/remote_version"], jsonpatch);
// to compose versioned JSON Patch, to be send somewhere?
var versionedPatchToBeSent = myQueue.send(regularpatch);
// to apply/queue received versioned  JSON Patch
myQueue.receive(receivedVersionedPatch);

Requirements

Agent requires a function to apply JSON Patch, we suggest fast JSON Patch (bower install fast-json-patch).

Methods

NameArgumentsDefaultDescription
sendJSONPatch sequenceChanges given JSON Patch to Versioned JSON Patch
receiveVersionedJSONPatch sequence Versioned JSON Patch to be queued and appliedReceives, and eventually applies given Versioned JSON Patch, to the object passed in the constructor

Multiple Versioned

NameArgumentsDefaultDescription
JSONPatchQueueObject obj---Target object where patches are applied
Array<JSONPointer> [localVersionPath, remoteVersionPath]Paths where to store the versions
Function applyfunction(object, patch) function to apply JSON Patch, must return the object in its final state
Boolean puristfalseset to true to enable pure/unoptimized Versioned JSON Patch convention

Single Versioned

NameArgumentsDefaultDescription
JSONPatchQueueSynchronousObject objTarget object where patches are applied
JSONPointer versionPathPath where to store the version
Function applyfunction(object, patch) function to apply JSON Patch, must return the object in its final
Boolean puristfalseset to true to enable pure/unoptimized Versioned JSON Patch convention

Properties

NameTypeDescription
objObjectTarget object where patches are applied
waitingArray<JSONPatch>Array of JSON Patches waiting in queue

Multiple Versioned

NameTypeDescription
localVersionNumberlocal version
remoteVersionNumberacknowledged remote version

Single Versioned

NameTypeDescription
versionNumberdocument version

Contributing

  1. Fork it!
  2. Create your feature branch: git checkout -b my-new-feature
  3. Commit your changes: git commit -m 'Add some feature'
  4. Push to the branch: git push origin my-new-feature
  5. Submit a pull request :D

History

For detailed changelog, check Releases.

License

MIT

See also