2021-09-23 14:33:09 +10:00
|
|
|
import { Buffer } from "buffer";
|
|
|
|
|
|
|
|
import { keccak256 } from "js-sha3";
|
|
|
|
import { generatePrivateKey } from "js-waku";
|
|
|
|
import * as secp256k1 from "secp256k1";
|
|
|
|
|
2021-10-06 12:51:36 +11:00
|
|
|
import { hexToBuf } from "./utils";
|
|
|
|
|
2021-09-23 14:33:09 +10:00
|
|
|
export class Identity {
|
2021-09-23 15:47:21 +10:00
|
|
|
public constructor(public privateKey: Uint8Array) {}
|
2021-09-23 14:33:09 +10:00
|
|
|
|
|
|
|
public static generate(): Identity {
|
|
|
|
const privateKey = generatePrivateKey();
|
|
|
|
return new Identity(privateKey);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Hashes the payload with SHA3-256 and signs the result using the internal private key.
|
|
|
|
*/
|
|
|
|
public sign(payload: Uint8Array): Uint8Array {
|
|
|
|
const hash = keccak256(payload);
|
|
|
|
|
|
|
|
const { signature, recid } = secp256k1.ecdsaSign(
|
2021-10-06 12:51:36 +11:00
|
|
|
hexToBuf(hash),
|
2021-09-23 14:33:09 +10:00
|
|
|
this.privateKey
|
|
|
|
);
|
|
|
|
|
|
|
|
return Buffer.concat([signature, Buffer.from([recid])]);
|
|
|
|
}
|
2021-09-23 16:08:06 +10:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the compressed public key.
|
|
|
|
*/
|
|
|
|
public get publicKey(): Uint8Array {
|
|
|
|
return secp256k1.publicKeyCreate(this.privateKey, true);
|
|
|
|
}
|
2021-09-23 14:33:09 +10:00
|
|
|
}
|