Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ipfs-shipyard/ipfs-iiif-db
IIIF annotations JS client on top of IPFS
https://github.com/ipfs-shipyard/ipfs-iiif-db
Last synced: about 1 month ago
JSON representation
IIIF annotations JS client on top of IPFS
- Host: GitHub
- URL: https://github.com/ipfs-shipyard/ipfs-iiif-db
- Owner: ipfs-shipyard
- License: mit
- Created: 2017-04-21T16:37:46.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2017-07-15T09:52:50.000Z (over 7 years ago)
- Last Synced: 2024-10-02T17:47:16.238Z (2 months ago)
- Language: JavaScript
- Homepage:
- Size: 17.6 MB
- Stars: 12
- Watchers: 11
- Forks: 4
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-starred - ipfs-shipyard/ipfs-iiif-db - IIIF annotations JS client on top of IPFS (others)
README
# ipfs-iiif-db
> IIIF annotations JS client over IPFS
# CLI
You can run a node from the command line, and it will keep track of all the recors inside a partition.
```
$ ipfs-iiif-db-track [partition]
````partition` defaults to `"iiif"`.
The tracker will save all the changes into a local leveldb database.
# JavaScript API
## Install
```sh
$ npm install ipfs-iiif-db --save
```## Import
In thr browser environment, you can either use this library by including it and bundling your app together with it (using browserify or webpack, for instance), or you can
### in Node.js or in a browser with a bundler:
```js
const DB = require('ipfs-iiif-db')
```### Using a script tag in a browser
```html
```
Now you can access this library using the `IpfsIiifDb` on the global namespace. (In this case, replace `DB` on the examples below with `IpfsIiifDb`).
## Instantiate
```js
const db = DB([options])
```Arguments:
* options (object):
* `ipfs`: a [js-ipfs options object](https://github.com/ipfs/js-ipfs#advanced-options-when-creating-an-ipfs-node)
* `store` (string, defaults to `"memory"`): a local store, represented by a string. Can either be:
* `"indexeddb"`: for in-browser persistence
* `"leveldb"`: for Node.js persistence
* `partition` (string, defaults to `iiif`): the partition this data belongs to. It's used to broadcast new record ids (so trackers can follow (and pin) the global partition state)# Annotation list
Get an annotations object:
```js
const annotationList = db.annotationList([originalAnnotationList])
```Arguments:
* originalAnnotationList (object): the annotation list. Must contain an '@id' attribute.
If a string is given as first argument, it's assumed as the '@id' attriubute of the annotation list.
## annotationList API:
### annotationList.set (key, value)
Set a annotation list attribute `key` to a given value
```js
annotationList.set('@context', 'http://iiif.io/api/search/0/context.json')
```### annotationList.pushResource (resource)
Insert a resource at the end of the `resources` array.
```js
annotationList.pushResource({
"@id": "https://wellcomelibrary.org/iiif/b18035723/annos/searchResults/a2h0r885,2553,282,46",
"@type": "oa:Annotation",
"motivation": "sc:painting",
"resource": {
"@type": "cnt:ContentAsText",
"chars": "gediegenen"
},
"on": "https://wellcomelibrary.org/iiif/b18035723/canvas/c2#xywh=885,2553,282,46"
})
```### putResource (index, resource)
Insert a resource at the given position inside the `resources` array.
```js
annotationList.putResource(3, {
"@id": "https://wellcomelibrary.org/iiif/b18035723/annos/searchResults/a2h0r885,2553,282,46",
"@type": "oa:Annotation",
"motivation": "sc:painting",
"resource": {
"@type": "cnt:ContentAsText",
"chars": "gediegenen"
},
"on": "https://wellcomelibrary.org/iiif/b18035723/canvas/c2#xywh=885,2553,282,46"
})
```### deleteResourceAt (index)
Delete the resource at the given `index` position.
```js
annotationList.deleteResourceAt(3)
```### getResources ()
Return the `resources` array.
```js
annotationList.getResources()
```### pushHit (hit)
Insert a hit at the end of the `hits` array.
```js
annotationList.pushHit({
"@id": "https://wellcomelibrary.org/iiif/b18035723/annos/searchResults/a2h0r885,2553,282,46",
"@type": "oa:Annotation",
"motivation": "sc:painting",
"resource": {
"@type": "cnt:ContentAsText",
"chars": "gediegenen"
},
"on": "https://wellcomelibrary.org/iiif/b18035723/canvas/c2#xywh=885,2553,282,46"
})
```### putHit (index, hit)
Insert a hit at the given position inside the `hits` array.
```js
annotationList.putHit(3, {
"@id": "https://wellcomelibrary.org/iiif/b18035723/annos/searchResults/a2h0r885,2553,282,46",
"@type": "oa:Annotation",
"motivation": "sc:painting",
"resource": {
"@type": "cnt:ContentAsText",
"chars": "gediegenen"
},
"on": "https://wellcomelibrary.org/iiif/b18035723/canvas/c2#xywh=885,2553,282,46"
})
```### deleteHitAt (index)
Delete the hit at the given `index` position.
```js
annotationList.deleteHit(3)
```### getHits ()
Return the `hits` array.
```js
annotationList.getHits()
```### toJSON ()
Returns an object representation of the annotation list.
```js
console.log('current annotation list is: %j', annotationList.toJSON())
```## AnnotationList Events
### "started" (event)
Once the AnnotationList CRDT has finished the bootstrap process. You can take this opportunity to do an initial render of the list.
### "mutation" (event)
Emitted whenever anything in the annotation list changes.
```js
annotationList.on('mutation', (event) => {
console.log('new mutation', event)
console.log('annotation list now is:', annotationList.toJSON())
})
```Callback arguments:
* event (object):
* type (string): can either be:
* 'add' - for when a direct attribute is added
* 'update' - for when a direct attribute value is updated
* 'delete' - for when a direct attribute is deleted
* 'resource inserted' - for when an item is inserted in the `resources` array
* 'resource deleted' - for when an item is deleted from the `resources` array
* 'hit inserted' - for when an item is inserted in the `hits` array
* 'hit deleted' - for when an item is deleted from the `resources` array
* name (string): the attribute name
* value (object): the new value, if applicable
* oldValue (object): the previous value, if applicable
* index (integer): index of the insertion or deletion### "add" (event)
```js
annotationList.on('add', (event) => {
console.log('added attribute', event.name)
console.log('with value:', event.value)
})
```Callback arguments:
* event (object):
* name (string): the attribute name
* value (object): the value of the attribute### "update" (event)
```js
annotationList.on('update', (event) => {
console.log('updated attribute', event.name)
console.log('old value:', event.oldValue)
console.log('new value:', event.value)
})
```Callback arguments:
* event (object):
* name (string): the attribute name
* value (object): the new value of the attribute
* oldValue (object): the old value of the attribute### "delete" (event)
```js
annotationList.on('delete', (event) => {
console.log('deleted attribute', event.name)
console.log('old value:', event.oldValue)
})
```Callback arguments:
* event (object):
* name (string): the attribute name
* oldValue (object): the old value of the attribute### "resource inserted" (event)
```js
annotationList.on('resource inserted', (event) => {
console.log('inserted resource at pos', event.index)
console.log('with value:', event.value)
})
```Callback arguments:
* event (object):
* index (interger >= 0): the array index the insertion was done on
* value (object): the value that was inserted### "resource deleted" (event)
Callback arguments:
* event (object):
* index (interger >= 0): the array index that was removed### "hit inserted" (event)
Callback arguments:
* event (object):
* index (interger >= 0): the array index the insertion was done on
* value (object): the value that was inserted### "hit deleted" (event)
Callback arguments:
* event (object):
* index (interger >= 0): the array index that was removed# License
MIT
## Contribute
Feel free to join in. All welcome. Open an [issue](https://github.com/pgte/ipfs-iiif-db/issues)!
This repository falls under the IPFS [Code of Conduct](https://github.com/ipfs/community/blob/master/code-of-conduct.md).
[![](https://cdn.rawgit.com/jbenet/contribute-ipfs-gif/master/img/contribute.gif)](https://github.com/ipfs/community/blob/master/contributing.md)
## License
[MIT](LICENSE)