mirror of
https://github.com/signalapp/libsignal.git
synced 2026-04-25 17:25:18 +02:00
This allows the file to be checked by tsc, which would have caught some of the missing type aliases sooner (now added to Native.ts.in). Strictly speaking the behavior is slightly different: we have returned to exporting many items individually instead of collecting them on a single object. Co-authored-by: Alex Bakon <akonradi@signal.org>
75 lines
2.4 KiB
TypeScript
75 lines
2.4 KiB
TypeScript
//
|
|
// Copyright 2020-2022 Signal Messenger, LLC.
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
//
|
|
|
|
import { randomBytes } from 'node:crypto';
|
|
import * as Native from '../../Native.js';
|
|
import { RANDOM_LENGTH } from '../internal/Constants.js';
|
|
|
|
import ServerSecretParams from '../ServerSecretParams.js';
|
|
import GroupPublicParams from '../groups/GroupPublicParams.js';
|
|
|
|
import ExpiringProfileKeyCredentialResponse from './ExpiringProfileKeyCredentialResponse.js';
|
|
import ProfileKeyCommitment from './ProfileKeyCommitment.js';
|
|
import ProfileKeyCredentialPresentation from './ProfileKeyCredentialPresentation.js';
|
|
import ProfileKeyCredentialRequest from './ProfileKeyCredentialRequest.js';
|
|
import { Aci } from '../../Address.js';
|
|
|
|
export default class ServerZkProfileOperations {
|
|
serverSecretParams: ServerSecretParams;
|
|
|
|
constructor(serverSecretParams: ServerSecretParams) {
|
|
this.serverSecretParams = serverSecretParams;
|
|
}
|
|
|
|
issueExpiringProfileKeyCredential(
|
|
profileKeyCredentialRequest: ProfileKeyCredentialRequest,
|
|
userId: Aci,
|
|
profileKeyCommitment: ProfileKeyCommitment,
|
|
expirationInSeconds: number
|
|
): ExpiringProfileKeyCredentialResponse {
|
|
const random = randomBytes(RANDOM_LENGTH);
|
|
|
|
return this.issueExpiringProfileKeyCredentialWithRandom(
|
|
random,
|
|
profileKeyCredentialRequest,
|
|
userId,
|
|
profileKeyCommitment,
|
|
expirationInSeconds
|
|
);
|
|
}
|
|
|
|
issueExpiringProfileKeyCredentialWithRandom(
|
|
random: Uint8Array,
|
|
profileKeyCredentialRequest: ProfileKeyCredentialRequest,
|
|
userId: Aci,
|
|
profileKeyCommitment: ProfileKeyCommitment,
|
|
expirationInSeconds: number
|
|
): ExpiringProfileKeyCredentialResponse {
|
|
return new ExpiringProfileKeyCredentialResponse(
|
|
Native.ServerSecretParams_IssueExpiringProfileKeyCredentialDeterministic(
|
|
this.serverSecretParams,
|
|
random,
|
|
profileKeyCredentialRequest.getContents(),
|
|
userId.getServiceIdFixedWidthBinary(),
|
|
profileKeyCommitment.getContents(),
|
|
expirationInSeconds
|
|
)
|
|
);
|
|
}
|
|
|
|
verifyProfileKeyCredentialPresentation(
|
|
groupPublicParams: GroupPublicParams,
|
|
profileKeyCredentialPresentation: ProfileKeyCredentialPresentation,
|
|
now: Date = new Date()
|
|
): void {
|
|
Native.ServerSecretParams_VerifyProfileKeyCredentialPresentation(
|
|
this.serverSecretParams,
|
|
groupPublicParams.getContents(),
|
|
profileKeyCredentialPresentation.getContents(),
|
|
Math.floor(now.getTime() / 1000)
|
|
);
|
|
}
|
|
}
|