This module implements Signed Envelope.
Types
Envelope = object publicKey*: PublicKey domain*: string payloadType*: seq[byte] signature*: Signature
- Source Edit
EnvelopeError = enum EnvelopeInvalidProtobuf, EnvelopeFieldMissing, EnvelopeInvalidSignature, EnvelopeWrongType
- Source Edit
SignedPayload[T] = object envelope*: Envelope data*: T
- Source Edit
Procs
proc decode(T: typedesc[Envelope]; buf: sink seq[byte]; domain: string): Result[ Envelope, EnvelopeError] {....raises: [].}
- Source Edit
proc decode[T](_: typedesc[SignedPayload[T]]; buffer: sink seq[byte]): Result[ SignedPayload[T], EnvelopeError] {....raises: [].}
- Source Edit
proc encode(env: Envelope): Result[seq[byte], CryptoError] {....raises: [], tags: [], forbids: [].}
- Source Edit
proc encode[T](msg: SignedPayload[T]): Result[seq[byte], CryptoError] {. ...raises: [].}
- Source Edit
proc getField(pb: ProtoBuffer; field: int; value: var Envelope; domain: string): ProtoResult[ bool] {.inline, ...raises: [], tags: [RootEffect], forbids: [].}
- Source Edit
proc getField[T](pb: ProtoBuffer; field: int; value: var SignedPayload[T]): ProtoResult[ bool] {.inline, ...raises: [].}
- Source Edit
proc init(T: typedesc[Envelope]; privateKey: PrivateKey; payloadType: sink seq[byte]; payload: sink seq[byte]; domain: string): Result[ Envelope, CryptoError] {....raises: [].}
- Source Edit
proc init[T](_: typedesc[SignedPayload[T]]; privateKey: PrivateKey; data: T): Result[ SignedPayload[T], CryptoError] {....raises: [].}
- Source Edit
proc write(pb: var ProtoBuffer; field: int; env: Envelope): Result[void, CryptoError] {....raises: [], tags: [], forbids: [].}
- Source Edit
Exports
-
Signature, exclIfIt, shortLog, init, toBytes, DigestSheme, ephemeral, ECDHEScheme, init, filterIt, shortLog, init, sign, Rng, macOpenArray, PublicKey, Secret, $, mac, init, selectBest, init, ephemeral, withValue, write, init, stretchKeys, generateBytes, withValue, write, write, init, getField, init, init, generate, toBytes, write, random, getBytes, toOpt, init, newRng, withValue, getPublicKey, init, init, random, write, ivOpenArray, init, getField, iv, init, CryptoError, ==, key, SupportedSchemes, generate, RsaDefaultKeySize, init, keyOpenArray, SupportedSchemesInt, toBytes, capLen, shuffle, supported, ==, toRawBytes, libp2p_pki_schemes, random, pickOne, init, random, CryptoResult, shortLog, getBytes, verify, PKScheme, getBytes, init, toChunks, generate, PrivateKey, take, toOpt, newBearSslRng, orError, $, generate, goffset, getRawBytes, pick, getOrder, KeyPair, init, toOpt, init