npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@hashgraph/hedera-custodians-integration

v1.4.1

Published

A library to provide integration with custodial wallets

Downloads

236

Readme

Hedera Custodians Integration

License

1. Overview

The hedera-custodians-library library is a Typescript utility designed to simplify custodial wallet management. It provides developers with tools to abstract complex aspects of custodial wallets, allowing them to focus on their application's core logic.

Optimized for integration with the Hedera network, it supports services like Fireblocks and Dfns and is scalable for various wallet services. The library's code is organized in a clear directory structure, with source code and unit and integration tests in separate folders. It's developed in Typescript, optimized for Node.js, and managed through npm for easy dependency handling and testing. The library is user-friendly, emphasizing developer experience and code readability. It includes extensive unit tests, ensuring its reliability and stability for managing custodial wallets in Typescript applications.

Current services supported

  • Dfns
  • Fireblocks

2. Architecture

The hedera-custodians-library library implements a factory-strategy pattern, enabling object creation without specifying their exact class. The library's structure is divided into two primary directories:

  1. src/: This directory houses the core source code and is organized into subdirectories:
  • factories/: Contains logic to return the correct strategy based on received configuration.
  • models/: Hosts models for interacting with the library's exposed services, including the SignatureRequest.
  • services/: Includes CustodialWalletService, which exposes the library's services.
  • strategies/: Comprises configuration classes for the factory and individual strategy classes, each with specific strategy logic.
  • utils/: Stores reusable logic utilized across different strategies.
  1. tests/: Contains all unit tests for the utility functions and classes in the library. Each test file corresponds to a source file and includes tests for various functions and classes.

The strategy classes in the src/ directory, following a factory-strategy pattern, along with various helper functions and classes, facilitate the creation and management of custodial wallets, enhancing code readability and maintainability.

3. Technologies

  • TypeScript: TypeScript is a typed superset of JavaScript that adds static types. It's used in this project for writing the source code.
  • npm: npm is the package manager for Node.js and is used for managing dependencies and running scripts.
  • Jest: Jest is a JavaScript testing framework used to write and run tests.
  • dfns-sdk: This is the Dfns SDK. It's used for integrating with the Dfns platform.
  • fireblocks-sdk: This is the Fireblocks SDK. It's used for integrating with the Fireblocks platform.
  • dotenv: This is a zero-dependency module that loads environment variables from a .env file into process.env.

4. How to use it

4.1. Install

To install the hedera-custodians-library, you can easily get it from NPM. Run the following command in your terminal:

npm install @hashgraph/hedera-custodians-integration

This command will install the hedera-custodians-library along with all its necessary dependencies. Ensure you are in your project’s root directory or the appropriate subdirectory where you wish to add the library.

4.2. Import

To use a function or class from the hedera-custodians-library library in your code, you first need to import it. Here's an example of how to import a function:

// ESM import
import { function, Class, Type, Interface } from 'hedera-custodians-library';
// or CJS require
const { function, Class, Type, Interface } = require('hedera-custodians-library');

Replace function, Class, Type, Interface with the actual name of the component you want to use.

4.3. Run

In the custodial wallet management process, the CustodialWalletService class plays a central role. To create a service, instantiate the class with a relevant configuration, such as FireblocksConfig. This involves specifying essential parameters like API keys and account IDs. Following this, a signature request is created using the SignatureRequest class, defining the transaction bytes to be signed. The transaction signing is accomplished by calling the signTransaction method on the service instance. This streamlined approach provides a concise and effective way to manage custodial wallets in an application.

4.3.1. Create Service

To create a service, you need to instantiate the CustodialWalletService class with the appropriate configuration. This can be either a FireblocksConfig or DFNSConfig instance, depending on the service you want to use.

Here's an example of how to create a service:

import {
  CustodialWalletService,
  FireblocksConfig,
} from 'hedera-custodians-library';

const config = new FireblocksConfig(
  FIREBLOCKS_API_KEY,
  FIREBLOCKS_API_SECRET_KEY,
  FIREBLOCKS_BASE_URL,
  FIREBLOCKS_VAULT_ACCOUNT_ID,
  FIREBLOCKS_ASSET_ID
);

const service = new CustodialWalletService(config);

4.3.2. Create Signature Request

To create a signature request, you need to instantiate the SignatureRequest class with the transaction bytes you want to sign.

Here's an example of how to create a signature request:

import { SignatureRequest } from 'hedera-custodians-library';

const transactionBytes = new Uint8Array([1, 2, 3]); // replace with your transaction bytes
const request = new SignatureRequest(transactionBytes);

4.3.3. Sign Transaction

To sign a transaction, you need to call the signTransaction method on the service instance, passing in the signature request.

Here's an example of how to sign a transaction:

const signature = await service.signTransaction(request);

This will return a Uint8Array containing the signature of the transaction.

5. Examples

A set of examples with detailed usage of this library is available at examples.

6. Build

To compile TypeScript files into JavaScript. The command tsc -p tsconfig.json is typically run before deploying the application or testing the compiled JavaScript code.

Here's a breakdown of the command:

  • tsc: This is the TypeScript compiler command. It's used to compile TypeScript (.ts) files into JavaScript (.js) files.

  • -p tsconfig.json: The -p option tells the TypeScript compiler to use the configuration from the tsconfig.json file. This file contains settings for the TypeScript compiler, such as the target JavaScript version, the root directory of the source files, compiler options, and more.

When you run npm run build in your terminal, npm will execute this script command, which will compile your TypeScript code into JavaScript using the settings from your tsconfig.json file.

7. Test

7.1. Files

Test files for the hedera-custodians-library library are in the __tests__/ directory, corresponding to the source files in the src/ directory. Key test files include:

  • StrategyFactory.test.ts: Tests the StrategyFactory for both Fireblocks and Dfns configurations. Verifies if the factory correctly instantiates FireblocksStrategy with Fireblocks config, and DFNSStrategy with Dfns config, ensuring each strategy is appropriately created.

  • Model.test.ts: Focuses on the SignatureRequest class, testing methods like getTransactionBytes and setTransactionBytes for handling transaction bytes.

  • Service.test.ts: An integration test suite for the CustodialWalletService class. It assesses the class's ability to manage configurations and sign transactions. The suite features distinct test cases, focusing on configuration settings and the signing process, with special attention to the integration with Fireblocks and Dfns services.

  • DFNSStrategy.test.ts: Tests the DFNSStrategy class, especially the sign method, using a mock Dfns API client for signature generation and verification.

  • FireblocksStrategy.test.ts: Similar to DFNSStrategy tests, but focused on the FireblocksStrategy class, using a mock Fireblocks SDK for the signing process.

The tests, written using Jest in a Node.js environment, comprehensively cover signature strategies, transaction handling, and other functionalities of the library.

7.2 Configuration

The configuration for the tests is defined in the jest.config.js file located in the root directory of the library.

The config.ts file is responsible for setting up the configurations for the FireblocksConfig and DFNSStrategy classes, which are used to manage the interactions with the Fireblocks and Dfns APIs, respectively.

To run the tests, you need to provide the following environment variables in a .env file:

Fireblocks

  • FIREBLOCKS_API_SECRET_KEY: Path to Fireblocks API secret key file or secret key value encoded in Base64
  • FIREBLOCKS_API_KEY: Your Fireblocks API key
  • FIREBLOCKS_BASE_URL: Base URL of Fireblocks API
  • FIREBLOCKS_ASSET_ID: Asset ID for Fireblocks
  • FIREBLOCKS_VAULT_ACCOUNT_ID: Vault account ID for Fireblocks
  • FIREBLOCKS_PUBLIC_KEY: Public key of the Vault for Fireblocks
  • FIREBLOCKS_HEDERA_ACCOUNT_ID: Hedera Account ID linked to the public key of the vault for Fireblocks

Dfns

  • DFNS_SERVICE_ACCOUNT_AUTHORIZATION_TOKEN: Authorization token for Dfns service account
  • DFNS_SERVICE_ACCOUNT_CREDENTIAL_ID: Credential ID for Dfns service account
  • DFNS_SERVICE_ACCOUNT_PRIVATE_KEY: Path to Dfns service account private key file or private key value encoded in Base64
  • DFNS_APP_ORIGIN: URL origin of Dfns app
  • DFNS_APP_ID: ID of Dfns app
  • DFNS_TEST_URL: Test URL for Dfns API
  • DFNS_WALLET_ID: Wallet ID for Dfns
  • DFNS_WALLET_PUBLIC_KEY: Public key of the Wallet for Dfns
  • DFNS_WALLET_HEDERA_ACCOUNT_ID: Hedera Account ID linked to the public key of the Wallet for Dfns. In Dfns the Hedera Account must be generated as an additional step
  • DFNS_WALLET_ID_ECDSA: Wallet ID for Dfns ECDSA key
  • DFNS_WALLET_PUBLIC_KEY_ECDSA: Public key of the Wallet for Dfns ECDSA key
  • DFNS_WALLET_HEDERA_ACCOUNT_ID_ECDSA: Hedera Account ID linked to the public key of the Wallet for Dfns ECDSA key. In Dfns the Hedera Account must be generated as an additional step

AWS KMS

  • AWS_ACCESS_KEY_ID: AWS access key ID for KMS
  • AWS_SECRET_ACCESS_KEY: AWS secret access key for KMS
  • AWS_REGION: AWS region for KMS
  • AWS_KMS_KEY_ID: AWS KMS key ID
  • AWS_KMS_PUBLIC_KEY: AWS KMS public key in PEM format. File path to a .pem file is recommended. You can also set it to the .pem file content base64 encoded
  • AWS_HEDERA_ACCOUNT_ID: AWS Hedera account ID

7.3. Run

To run the tests, navigate to the root directory of the hedera-custodians-library library and run the following command:

npm run test
# or
npm run test:coverage

8. Contributing

Contributions are welcome. Please see the contributing guide to see how you can get involved.

9. Code of Conduct

This project is governed by the Contributor Covenant Code of Conduct. By participating, you are expected to uphold this code of conduct. Please report unacceptable behavior to [email protected].

10. License

Apache License 2.0