@ebsifnmt/wallet-lib
v1.0.0-rc.9
Published
EBSI Wallet Library
Downloads
11
Readme
Wallet Library
EXPERIMENTAL
The Wallet Library is a TypeScript reference library implementing some generic EBSI-compliant wallet capabilities.
Table of Contents
Install
npm install @cef-ebsi/wallet-lib
Usage
import { EbsiWallet } from "@cef-ebsi/wallet-lib";
import { JsonRpcProvider } from "@ethersproject/providers";
import { BigNumber } from "@ethersproject/bignumber";
// Create a new random EBSI DID
const did = EbsiWallet.createDid();
console.log(did);
// prints "did:ebsi:zsSgDXeYPhZ3AuKhTFneDf1"
// Instantiating a new instance of EBSI Wallet
const privateKey =
"0a9a229c18f1777949243bbe875b754b77fb9cb3612c8b5c37876888f54f9731";
const wallet = new EbsiWallet(privateKey);
// Get wallet's public key (different formats)
const publicKey = wallet.getPublicKey();
/*
046a6457531aefa19d1840cca004f9ef1cf50d30c508d960a63fceedf336da829501b3c54c16b2d4f325c602e23f17da353ad0ccba6397f082be1e3eaab07cf3c1
*/
const publicKeyPem = wallet.getPublicKey({ format: "pem" });
/*
-----BEGIN PUBLIC KEY-----
MFYwEAYHKoZIzj0CAQYFK4EEAAoDQgAEamRXUxrvoZ0YQMygBPnvHPUNMMUI2WCm
P87t8zbagpUBs8VMFrLU8yXGAuI/F9o1OtDMumOX8IK+Hj6qsHzzwQ==
-----END PUBLIC KEY-----
*/
const publicKeyJwk = wallet.getPublicKey({ format: "jwk" });
/*
{
kty: "EC",
crv: "secp256k1",
x: "amRXUxrvoZ0YQMygBPnvHPUNMMUI2WCmP87t8zbagpU",
y: "AbPFTBay1PMlxgLiPxfaNTrQzLpjl_CCvh4-qrB888E",
}
*/
// Get wallet's Ethereum address
const publicKey = wallet.getEthereumAddress();
// returns 0xA2aa80C25AebE7d3b9984ef45179b4F39737fFBa
// Prepare an Ethereum transaction
const accessToken = ""; // This is an OAuth2 access token required by Ledger API, see @cef-ebsi/oauth2-auth library
const provider = new JsonRpcProvider({
url: "https://api.test.intebsi.xyz/ledger/v2/blockchains/besu",
headers: {
authorization: `Bearer ${accessToken}`,
},
});
const { chainId } = await ethersProvider.getNetwork();
// This is the raw transaction we want to prepare
const rawTransaction = {
from: "0x32DEF047DeFd076DB21A2D759aff2A591c972248",
gasPrice: BigNumber.from("0x4a817c800"),
to: "0x6fC21092DA55B392b045eD78F4732bff3C580e2c",
value: BigNumber.from("0x186cc6acd4b0000"),
nonce: 0,
data: "0xf2c298be000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000067269636d6f6f0000000000000000000000000000000000000000000000000000",
chainId,
};
const txRequest = await EbsiWallet.prepareEthereumTransaction(
rawTransaction,
provider
);
// txRequest now contains rawTransaction with an estimated gasLimit
Linting
You can lint the files (ESLint, OpenAPI, tsc) and run Prettier with one command:
yarn lint
Or you can run the different linters independently:
ESLint
yarn lint:eslint
or with yarn:
yarn eslint . --ext .js,.ts
Run eslint and precommit rules:
.git/hooks/pre-commit
Prettier
yarn lint:prettier
or with yarn:
yarn prettier . --check
tsc
yarn lint:tsc
or with yarn:
yarn tsc --noEmit --incremental false
Auditing the dependencies
Using audit-ci (this is the one we run during CI):
yarn run audit
Or using Yarn's built-in audit
command, to get more information:
yarn audit
Tests
Note: before running the e2e tests, make sure to create a local .env
file and fill it with the correct environment variables. You can check .env.example
to see what is expected.
Run all the tests:
yarn test
Run unit tests only:
yarn test:unit
# Or in CI mode (with coverage)
yarn test:ci
Run all the end-to-end tests:
yarn test:e2e
Run functional tests in a Node.js environment:
yarn test:e2e:node
Run functional tests in a browser environment:
yarn test:e2e:browser
Generate docs
The documentation is generated with TypeDoc, based on the TSDoc comments we leave in the code.
Run the following command to generate the docs:
yarn generate:docs
Serve the docs:
yarn serve:docs
License
Copyright (c) 2019 European Commission Licensed under the EUPL, Version 1.2 or - as soon they will be approved by the European Commission - subsequent versions of the EUPL (the "Licence"); You may not use this work except in compliance with the Licence. You may obtain a copy of the Licence at:
Unless required by applicable law or agreed to in writing, software distributed under the Licence is distributed on an "AS IS" basis, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the Licence for the specific language governing permissions and limitations under the Licence.