2.0.0-rc.1 • Published 5 years ago

json-patch-ot-agent v2.0.0-rc.1

Weekly downloads
3
License
MIT
Repository
github
Last release
5 years ago

JSON-Patch-OT-Agent

Makes your JSON Patch application sequential

Build Status

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-ot-agent --save

Or

Install the component using Bower:

$ bower install json-patch-ot-agent --save

Or download as ZIP.

Usage

var targetObject = {};
// create queue
var myQueue = new new JSONPatchOTAgent(targetObject,
                jsonpatchTransform,
                ['/localVersion', '/remoteVersion'],
                jsonpatch
             );
// to compose versioned JSON Patch, to be send somewhere?
var versionedPatchToBeSent = myQueue.send(regularPatch);
// to apply/queue/transform received versioned JSON Patch
myQueue.receive(receivedVersionedPatch);

Requirements

Agent requires a specific transform function (as a first argument), if you do not have your own, we advise you JSON-Patch-OT (bower install json-patch-ot). You will also need 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 sequenceVersioned JSON Patch to be queued and applied
JSONPatchQueueObject objTarget object where patches are applied
__Function transformfunction(patch, againstPatch_es) function to transform given JSON Patch against others
__Array JSONPointer localVersionPath, remoteVersionPathPaths where to store the versions
__Function applyfunction(object, patch) function to apply JSON Patch, must return the final state of the object
__Boolean puristfalseset to true to enable pure/unoptimized Versioned JSON Patch convention

Properties

NameTypeDescription
objObject objTarget object where patches are applied
waitingArray JSONPatchArray of JSON Patches waiting in queue
localVersionNumberlocal version
remoteVersionNumberacknowledged remote version
ackLocalVersionNumberlocal version that is for sure acknowledged by remote

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