GitXplorerGitXplorer
s

open-knowledge

public
7 stars
1 forks
1 issues

Commits

List of commits on branch master.
Unverified
360b249f063c4bcae8d0c558f5c658fa51ed1924

Fix integration tests to pass

ss1na committed 6 years ago
Unverified
dff3943991a39b2aa34565202dd5b4c2aaade1d6

Fix graph-manager and open-knowledge tests, minor fixes

ss1na committed 6 years ago
Unverified
d605a9ddeb2e367f8a0b8ca1fae325b3f6465196

Rename GraphRegistry to SimpleRegistry

ss1na committed 6 years ago
Unverified
1fe92cf1cb287e26e66d0838510b13a239ef56ef

Accept version param in registry.getGraph

ss1na committed 6 years ago
Unverified
f03d103108899b19ee1424d944d231a6cf203566

Add basis for registry type containing tcr, initialize it in OK class

ss1na committed 6 years ago
Unverified
f36b9e9936c757bfe6dd2cc1b5072a137c748119

Add initialize method to graph, add deps, gitignore yarn.lock

ss1na committed 6 years ago

README

The README file for this repository.

Open Knowledge

CircleCI

Decentralized open linked data for your (decentralized) applications.

Note: This library is in early development phase, and therefore not suitable for production use. Note: Open-knowledge is undergoing changes in the architecture, and consequently the API. The Registry is being replaced by a TCR.

Overview

OpenKnowledge (OK) provides an easy way for developers to query openly available linked data, such as directors and actors of movies (from dbpedia), name of all cities in a country, or results of bioinformatics studies, in their (decentralized) applications.

On the other hand it enables data producers to publish their data directly to subscribers, without a central authority, and without the need for maintaining servers, benefiting from features such as versioning and attribution.

OK is built on top of IPFS and the Ethereum blockchain, and uses RDF (a W3C standard) as its knowledge representation model and SPARQL as its query language.

Usage

First, install the library via npm or yarn:

$ yarn add open-knowledge

OK depends on IPFS and web3 (for communicating with Ethereum), but in order not to make assumptions, and remain flexible, they have been defined as peer dependencies, and therefore should be installed separately.

$ yarn add ipfs-api
$ yarn add web3

Import the library in your code and instantiate an object according to the node example. If you're developing a dapp, chances are, you already have an IPFS and web3 object. Pass them to OpenKnowledge when instantiating. If not, have a look at the examples to see how to initialize IPFS and web3.

At this point, it's possible to retrieve a list of triples adhering to a pattern:

let res = await ok.getTriples(null, 'http://dbpedia.org/ontology/influenced', null, 'dbpedia')

Triple patterns suffice in many cases, but for complex queries, you can write a SPARQL query and execute it:

let res = await ok.execute(`
  PREFIX dbr: <http://dbpedia.org/resource/>
  PREFIX dbo: <http://dbpedia.org/ontology/>
  FROM <openknowledge:dbpedia>
  SELECT *
  {
    dbr:Lucky_Starr_and_the_Big_Sun_of_Mercury dbo:author ?o.
    ?s dbo:influenced ?o
  } LIMIT 15
`)

The two previous examples only return triples located in one knowledge graph. You can use the full power of linked data by executing queries over multiple knowledge graphs:

let q = `
  PREFIX dbr: <http://dbpedia.org/resource/>
  PREFIX dbo: <http://dbpedia.org/ontology/>
  SELECT *
  {
    dbr:Lucky_Starr_and_the_Big_Sun_of_Mercury dbo:author ?o.
    ?s dbo:influenced ?o.
    ?p dbo:wikiPageRedirects ?s
  } LIMIT 15
`

let res = await ok.executeFederated(q, ['default', 'dbpedia'])

In order to publish data, you need to have write permissions in a knowledge graph. You can create a knowledge graph of your own, in which case you become the owner of the graph. This operation requires gas.

let manager = await ok.newGraphManager('myGraph')

Then you can add triples to the knowledge graph, either by calling addTriples on the GraphManager directly or by passing the graph name along with the triples to the OpenKnowledge instance.

let tx = await ok.addTriples([['subject', 'property', 'object']], 'myGraph')

Please note that OK does not offer database functionalities and is not suitable for dynamic and fast-changing data. Morever, the data is published unencrypted and can be accessed by everyone.

Development Setup

You will need Node.js and either npm or yarn.

# Install dependencies, in project root
$ yarn

# Install rollup, for bundling the library
$ sudo yarn global add rollup

# Install truffle, for building contracts
$ sudo yarn global add truffle

# Install ganache-cli, for a custom ethereum network
# or use trufflesuite/ganache-cli:latest docker image
$ sudo yarn global add ganache-cli

# Start IPFS daemon, if installed
# or use ipfs/go-ipfs:latest docker image
$ ipfs daemon

# Start ganache, with network name dev
$ ganache-cli -i dev

# Deploy contracts on ganache
$ yarn contracts:deploy

# To build library, the result will be in dist/
$ yarn build

# To run node examples
$ cd example/node
$ yarn
# Publish some test data
$ node publish.js
# Query the published data
$ node index.js

Contribute

Contribution in any form is appreciated. If you find a bug, or want to discuss or provide feedbacks in any way, go ahead and create an issue. PRs are also more than welcome.

Acknowledgement

This project is being developed as part of the master's thesis of Sina Mahmoodi at Fraunhofer SCAI.