1.1.0 • Published 2 years ago

@activitypods/synchronizer v1.1.0

Weekly downloads
-
License
Apache-2.0
Repository
-
Last release
2 years ago

Synchronizer Service

An ActivityPods service to notify of objects' updates.

When a watched object is updated or deleted, automatically send an activity to the actors who have the right to view this object.

Usage

The SynchronizerService is included in the CoreService. The easiest way to make use of it is to import the SynchronizerMixin along with the ControlledContainerMixin.

const { ControlledContainerMixin } = require('@semapps/ldp');
const { SynchronizerMixin } = require('@activitypods/synchronizer');

module.exports = {
  name: 'events',
  mixins: [SynchronizerMixin, ControlledContainerMixin], // In that order
  settings: {
    path: '/events',
    acceptedTypes: ['Event']
  }
}

Note: The SynchronizerMixin must be added before the ControlledContainerMixin, as it overrides its delete action.

Actions

watch

Watch a new type of object.

Parameters
PropertyTypeDefaultDescription
typeStringrequiredThe type of resource we want to watch

announceUpdate

Announce an object update to all actors who have the right to view this object.

Parameters
PropertyTypeDefaultDescription
objectUriStringrequiredThe URI of resource which has been updated
newDataObjectrequiredThe content of the resource (in JSON-LD)

announceDelete

Announce an object deletion to all actors who have the right to view this object.

Parameters
PropertyTypeDefaultDescription
objectUriStringrequiredThe URI of resource which has been deleted
oldDataObjectrequiredThe content of the resource before it was deleted (in JSON-LD)

Handled activities

Announce update

{
  "type": "Announce",
  "object": {
    "type": "Update",
    "object": {
      "type": "[WATCHED TYPES]"
    }
  }
}

Emitter's side effects

  • None

Recipients' side effects

  • The object cached in the recipients' PODs is refreshed

Announce delete

{
  "type": "Announce",
  "object": {
    "type": "Delete",
    "object": {
      "formerType": "[WATCHED TYPES]"
    }
  }
}

Emitter's side effects

  • None

Recipients' side effects

  • The object cached in the recipients' PODs is deleted
1.1.0

2 years ago

1.0.0

2 years ago

0.2.1

2 years ago

0.2.0

2 years ago