signal-desktop/ts/updater/curve.ts

31 lines
826 B
TypeScript
Raw Normal View History

2023-01-03 11:55:46 -08:00
// Copyright 2019 Signal Messenger, LLC
2020-10-30 15:34:04 -05:00
// SPDX-License-Identifier: AGPL-3.0-only
import { PrivateKey, PublicKey } from '@signalapp/libsignal-client';
2025-06-30 11:43:41 -07:00
export function keyPair(): Record<string, Uint8Array> {
const privKey = PrivateKey.generate();
const pubKey = privKey.getPublicKey();
return {
publicKey: pubKey.serialize(),
privateKey: privKey.serialize(),
};
}
2025-06-30 11:43:41 -07:00
export function sign(privateKey: Uint8Array, message: Uint8Array): Uint8Array {
const privKeyObj = PrivateKey.deserialize(privateKey);
const signature = privKeyObj.sign(message);
return signature;
}
export function verify(
2025-06-30 11:43:41 -07:00
publicKey: Uint8Array,
message: Uint8Array,
signature: Uint8Array
2019-08-19 15:26:45 -07:00
): boolean {
const pubKeyObj = PublicKey.deserialize(publicKey);
const result = pubKeyObj.verify(message, signature);
return result;
}