Skip to content

Setting up

CI edited this page Apr 1, 2019 · 4 revisions

To start working with DataPeps, you need to add DataPeps SDK to your project.

Using a package manager

The simplest way to get started, is to add DataPeps SDK, using your favourite package manager.

npm

Go to your project directory and run:

npm install datapeps-sdk

yarn

Go to your project directory and run:

yarn add datapeps-sdk

Instantiation of DataPeps SDK

Just add the following line to your code to import the DataPeps SDK:

const DataPeps = require("datapeps-sdk");

Using the SDK with Node.js

When using DataPeps SDK with Node.js (on backend or if testing with Mocha), you need to add the package node-fetch to your project. It allows to use fetch(), which is currently supported by browsers, but not by Node.js.

You need to add a couple of lines to your code to use node-fetch with DataPeps and we show how to do it further.

Hello, DataPeps!

Let's have a glimpse at how exactly DataPeps simplifies cryptography for a developer.

Say there are two friends, Alice and Bob. Alice wants to send a message to Bob; however, Alice is quite rather concerned about data security (good for her!), and she wants to ensure, that only Bob can eventually read the picture. DataPeps to the rescue!

With DataPeps Alice encrypts the message like this:

async function aliceSend() {
  let aliceSession = await DataPeps.Session.login(aliceLogin, alicePassword);
  let resource = await new DataPeps.ResourceAPI(aliceSession).create("text", "", [bobLogin]);
  let messageToBob = "Hello, Bob!";
  let encryptedMessage = resource.encrypt(messageToBob);
  console.log('Alice sent a message: "' + messageToBob + '"');
  return [resource.id, encryptedMessage];
}

and Bob decrypts the message like this:

async function bobReceive(resourceId, encryptedMessage) {
  let bobSession = await DataPeps.Session.login(bobLogin, bobPassword);
  let resource = await new DataPeps.ResourceAPI(bobSession).get(resourceId);
  let decryptedMessage = resource.decrypt(encryptedMessage);
  console.log('Bob received a message: "' + decryptedMessage + '"');
}

Short and awesome! Now, let's discuss it a bit.

Suppose, Alice and Bob are already registered with DataPeps (we cover the case when they are not a bit further). First of all, Alice needs to establish a session with DataPeps server:

let aliceSession = await DataPeps.Session.login(aliceLogin, alicePassword);

Now, as Alice wants that only Bob reads a message, she needs to encrypt it for Bob (and just for him). For this Alice creates "a resource":

let resource = await new DataPeps.ResourceAPI(aliceSession).create("text", "", [bobLogin]);

Last, Alice encrypts the message:

let messageToBob = "Hello, Bob!";
let encryptedMessage = resource.encrypt(messageToBob);

Alice sends Bob the encrypted message and the resource's ID:

console.log('Alice sent a message: "' + messageToBob + '"');
return [resource.id, encryptedMessage];

When Bob wants to decrypt the message received from Alice, he establishes the session (as Alice did before) and fetches the resource, created by Alice from the DataPeps server, using the resource id:

let bobSession = await DataPeps.login(bobLogin, bobPassword);
let resource = await bobSession.Resource.get(resourceId);

Bob can now decrypt the message:

let decryptedMessage = resource.decrypt(encryptedMessage);
let messageToBob = new TextDecoder().decode(decryptedMessage);
console.log('Bob received a message: "' + messageToBob + '"');

Adding dependencies for Node.js

We will use Node.js to run the resulting code, so we will need to satisfy all the relevant dependencies:

const DataPeps = require("datapeps-sdk");

global.fetch = require("node-fetch");
global.Headers = global.fetch.Headers;

"Hello, DataPeps" code

Here is the complete example. Make sure that identities Alice and Bob are registered with DataPeps before you run the example.

Show code
const DataPeps = require("datapeps-sdk");

global.fetch = require("node-fetch");
global.Headers = global.fetch.Headers;

let aliceLogin = "aliceliddell",
  bobLogin = "bobmorane";

let alicePassword = "aliceP@ssw0rd",
  bobPassword = "bobP@ssw0rd";

async function aliceSend() {
  let aliceSession = await DataPeps.Session.login(aliceLogin, alicePassword);
  let resource = await new DataPeps.ResourceAPI(aliceSession).create(
    "text",
    "",
    [bobLogin]
  );
  let messageToBob = "Hello, Bob!";
  let encryptedMessage = resource.encrypt(messageToBob);
  console.log('Alice sent a message: "' + messageToBob + '"');
  return [resource.id, encryptedMessage];
}

async function bobReceive(resourceId, encryptedMessage) {
  let bobSession = await DataPeps.Session.login(bobLogin, bobPassword);
  let resource = await new DataPeps.ResourceAPI(bobSession).get(resourceId);
  let decryptedMessage = resource.decrypt(encryptedMessage);
  console.log('Bob received a message: "' + decryptedMessage + '"');
}

async function main() {
  var [resourceId, encryptedMessage] = await aliceSend();
  await bobReceive(resourceId, encryptedMessage);
}

main().catch(e => console.log("An error occurred: ", e));

Finally, create the following *package.json* in the project directory:
{
  "name": "hello-datapeps",
  "version": "0.0.1",
  "main": "hello-datapeps.js",
  "scripts": {
    "start": "node hello-datapeps.js"
  },
  "dependencies": {
    "datapeps-sdk": "^0.0.47",
    "node-fetch": "^2.3.0"
  }
}

Run the code:

npm install && node hello-datapeps.js

If you use yarn instead of npm, run:

yarn install && node run hello-datapeps.js