Files
Desktop/ts/updater/curve.node.ts
2026-03-12 16:24:01 -07:00

36 lines
889 B
TypeScript

// Copyright 2019 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import { PrivateKey, PublicKey } from '@signalapp/libsignal-client';
type KeyPair = Readonly<{
publicKey: Uint8Array;
privateKey: Uint8Array;
}>;
export function keyPair(): KeyPair {
const privKey = PrivateKey.generate();
const pubKey = privKey.getPublicKey();
return {
publicKey: pubKey.serialize(),
privateKey: privKey.serialize(),
};
}
export function sign(privateKey: Uint8Array, message: Uint8Array): Uint8Array {
const privKeyObj = PrivateKey.deserialize(privateKey);
const signature = privKeyObj.sign(message);
return signature;
}
export function verify(
publicKey: Uint8Array,
message: Uint8Array,
signature: Uint8Array
): boolean {
const pubKeyObj = PublicKey.deserialize(publicKey);
const result = pubKeyObj.verify(message, signature);
return result;
}