Skip to content

A JavaScript library that empowers user defined Self-Sovereign Identity & Consent Management.

License

Notifications You must be signed in to change notification settings

energychain/tydids-core

Repository files navigation

tydids-core

tydids-core is a Node.js package that provides functionalities for Decentralized Identity (DID) based validation, authentication, and data privacy consent.

Project Homepage | JSFiddle

<script async src="//jsfiddle.net/stromdao/87fqscw0/13/embed/js,html,result/dark/"></script>

Installation

There are two ways to install tydids-core:

Using npm:

npm install tydids-core

This will install the package and its dependencies locally for use in your Node.js project.

Using HTML:

You can directly include the library in your HTML project using a CDN link:

<script src="https://unpkg.com/tydids-core@latest/dist/tydids.js"></script>
<script>
   const validation = new window.TyDIDs.Validation();
   // or 
   const dataidentity = new window.TyDIDs.DataIdentity();
   // or 
   const ssi = new window.TyDIDs.SSI(key);
</script>

This approach is useful for quick integration in web applications without the need for local installation.

Usage

For detailed usage examples and API reference, please refer to the files in the ./public folder. You can also try a live demo of the functionalities at:

Here's an example of how to use the Validation class:

const Validation = require("./Validation");
const ethers = require("ethers");

// Create a new Validation instance
const validation = new Validation();

// Attach a signer to the instance
const signer = new ethers.Wallet.createRandom();
validation.attachSigner(signer);

// Set validation data
await validation.setValidationObject({
  key_1: "Example Key",
  value_1: "Example Value",
});

// Sign the account data
await validation.signAccountData();

// Publish the validation
await validation.publish();

// Check if the validation is published
const publishedAt = await validation.isPublishedAt();
console.log("Published at:", publishedAt);

Shell Script

Install:

npm install -g tydids-core
tydids -h

Revoke with given SSI File:

tydids revoke <path_to_ssi_*.html>

Check if granted:

tydids isgranted <identity>

We welcome contributions to tydids-core. If you have improvements or new features, please create a pull request on the project's GitHub repository.

License

This project is licensed under the Apache-2.0 License. Please see the LICENSE file for more details.

Test Cases

The repository includes test cases that demonstrate how to use the Validation class. To run the test cases, navigate to the project directory and run npm test.

Maintainer / Impressum

STROMDAO GmbH
Gerhard Weiser Ring 29
69256 Mauer
Germany

+49 6226 968 009 0

dev@stromdao.com

Handelsregister: HRB 728691 (Amtsgericht Mannheim)

https://stromdao.de/