Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 | 57x 57x 57x 1x 1x 1x 1x 1x 1x 1x 1x 1x | import { CompletedProtoWallet, ProveCertificateResult } from "@bsv/sdk";
import { sdk, WalletSigner } from '../../index.client'
export async function proveCertificate(
signer: WalletSigner,
auth: sdk.AuthId,
vargs: sdk.ValidProveCertificateArgs
)
: Promise<ProveCertificateResult>
{
const lcargs: sdk.ValidListCertificatesArgs = {
partial: {
type: vargs.type,
serialNumber: vargs.serialNumber,
certifier: vargs.certifier,
subject: vargs.subject,
revocationOutpoint: vargs.revocationOutpoint,
signature: vargs.signature,
},
certifiers: [],
types: [],
limit: 2,
offset: 0,
privileged: false
}
const lcr = await signer.storage.listCertificates(lcargs)
Iif (lcr.certificates.length != 1)
throw new sdk.WERR_INVALID_PARAMETER('args', `a unique certificate match`)
const storageCert = lcr.certificates[0]
const wallet = new CompletedProtoWallet(signer.keyDeriver!)
const co = await sdk.CertOps.fromCounterparty(wallet, {
certificate: { ...storageCert },
keyring: storageCert.keyring!,
counterparty: storageCert.verifier || storageCert.subject
})
const e = await co.exportForCounterparty(vargs.verifier, vargs.fieldsToReveal)
const pr: ProveCertificateResult = {
certificate: e.certificate,
verifier: e.counterparty,
keyringForVerifier: e.keyring
}
return pr
}
|