0.0
No commit activity in last 3 years
No release in over 3 years
A client for RESTful transactions with a triannon annotation server
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

Runtime

 Project Readme

Build Status Coverage Status Dependency Status Gem Version

Under construction!

Any gem released prior to 1.x may have an unstable API. As the triannon server and this client are in rapid development (as of 2015), expect new gem releases that could break the API.

Triannon Client

A client for the triannon service, see also

Installation into ruby projects

gem 'triannon-client'

Then execute:

bundle

Using the client

Configuration

Edit a .env file to configure the triannon server address etc. (see .env_example); or use a configure block. The configuration for authentication depends on prior triannon server configuration, see

This example configuration may work with a triannon server running on localhost in the development environment (see below for details).

require 'triannon-client'
::TriannonClient.reset
::TriannonClient.configure do |config|
  config.debug = false
  config.host = 'http://localhost:3000'
  config.client_id = 'clientA'
  config.client_pass = 'secretA'
  config.container = '/annotations/bar'
  config.container_user = ''
  config.container_workgroups = 'org:wg-A, org:wg-B'
end

Get a client instance

A new instance is initialized using the configuration parameters (see above).

tc = TriannonClient::TriannonClient.new

Get a list of annotations

# return an RDF::Graph
graph = tc.get_annotations
anno_uris = tc.annotation_uris(graph)
anno_ids = anno_uris.map {|uri| tc.annotation_id(uri) }

Get a particular annotation

# the default response is an open annotation in an RDF::Graph
oa_anno = tc.get_annotation(id)

For specific response formats, specify an HTTP Accept header, e.g.

# explicitly request jsonld with an open annotation or a IIIF context
anno_oa   = tc.get_annotation(id, `application/ld+json; profile="http://www.w3.org/ns/oa-context-20130208.json"`)
anno_iiif = tc.get_annotation(id, `application/ld+json; profile="http://iiif.io/api/presentation/2/context.json"`)
# convenience methods to do the above
anno_oa   = tc.get_oa_annotation(id)
anno_iiif = tc.get_iiif_annotation(id)

Create an annotation

tc.post_annotation(open_annotation_jsonld)

Delete an annotation

uri = RDF::URI.new("http://your.triannon-server.com/annotations/45/4a/c0/93/454ac093-b37d-4580-bebd-449f8dabddc9")
id = tc.annotation_id(uri) #=> "45%2F4a%2Fc0%2F93%2F454ac093-b37d-4580-bebd-449f8dabddc9"
tc.delete_annotation(id)

Note: the annotation URI contains a pair-tree path (created by a Fedora 4 repository for triannon annotations). The annotation ID is the entire pair-tree path, after a URI escape. The URI escape makes it easier to work with the ID for tc.get_annotation(id) and tc.delete_annotation(id). For more information on object storage using pair-trees, see

Development

Clone and install:

git clone https://github.com/sul-dlss/triannon-client.git
cd triannon-client
./bin/setup.sh  # runs bundle install

Run tests:

rake

The server request/response cycle has been recorded in spec/fixtures/vcr_cassettes (see http://www.relishapp.com/vcr).

Tests with live server interactions

git clone https://github.com/sul-dlss/triannon.git
git clone https://gist.github.com/bcfc9698ce5f5af8f465.git triannon_reset
cp ./triannon_reset/triannon_server_reset.sh triannon/bin/
cd triannon
./bin/triannon_server_reset.sh
# GO GET A TASTY BEVERAGE ;-)
  • Run the triannon client specs against the localhost server.
git clone https://github.com/sul-dlss/triannon-client.git
cd triannon-client
./bin/setup.sh  # bundle update and package
rm -rf spec/fixtures/vcr_cassettes
rake