verifier

package
v0.1.5 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 8, 2020 License: Apache-2.0 Imports: 17 Imported by: 27

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type BBSG2SignatureProofVerifier added in v0.1.5

type BBSG2SignatureProofVerifier struct {
	// contains filtered or unexported fields
}

BBSG2SignatureProofVerifier is a signature verifier that verifies a BBS+ Signature Proof taking Bls12381G2Key2020 public key bytes as input. The reference implementation https://github.com/mattrglobal/bls12381-key-pair supports public key bytes only, JWK is not supported.

func NewBBSG2SignatureProofVerifier added in v0.1.5

func NewBBSG2SignatureProofVerifier(nonce []byte) *BBSG2SignatureProofVerifier

NewBBSG2SignatureProofVerifier creates a new BBSG2SignatureProofVerifier.

func (BBSG2SignatureProofVerifier) Algorithm added in v0.1.5

func (sv BBSG2SignatureProofVerifier) Algorithm() string

func (BBSG2SignatureProofVerifier) Curve added in v0.1.5

func (sv BBSG2SignatureProofVerifier) Curve() string

func (BBSG2SignatureProofVerifier) KeyType added in v0.1.5

func (sv BBSG2SignatureProofVerifier) KeyType() string

func (*BBSG2SignatureProofVerifier) Verify added in v0.1.5

func (v *BBSG2SignatureProofVerifier) Verify(pubKeyValue *PublicKey, doc, signature []byte) error

Verify verifies the signature.

type BBSG2SignatureVerifier added in v0.1.5

type BBSG2SignatureVerifier struct {
	// contains filtered or unexported fields
}

BBSG2SignatureVerifier is a signature verifier that verifies a BBS+ Signature taking Bls12381G2Key2020 public key bytes as input. The reference implementation https://github.com/mattrglobal/bls12381-key-pair supports public key bytes only, JWK is not supported.

func NewBBSG2SignatureVerifier added in v0.1.5

func NewBBSG2SignatureVerifier() *BBSG2SignatureVerifier

NewBBSG2SignatureVerifier creates a new BBSG2SignatureVerifier.

func (BBSG2SignatureVerifier) Algorithm added in v0.1.5

func (sv BBSG2SignatureVerifier) Algorithm() string

func (BBSG2SignatureVerifier) Curve added in v0.1.5

func (sv BBSG2SignatureVerifier) Curve() string

func (BBSG2SignatureVerifier) KeyType added in v0.1.5

func (sv BBSG2SignatureVerifier) KeyType() string

func (*BBSG2SignatureVerifier) Verify added in v0.1.5

func (v *BBSG2SignatureVerifier) Verify(pubKeyValue *PublicKey, doc, signature []byte) error

Verify verifies the signature.

type DocumentVerifier

type DocumentVerifier struct {
	// contains filtered or unexported fields
}

DocumentVerifier implements JSON LD document proof verification.

func New

func New(resolver keyResolver, suites ...SignatureSuite) (*DocumentVerifier, error)

New returns new instance of document verifier.

func (*DocumentVerifier) Verify

func (dv *DocumentVerifier) Verify(jsonLdDoc []byte, opts ...jsonld.ProcessorOpts) error

Verify will verify document proofs.

type ECDSASignatureVerifier added in v0.1.3

type ECDSASignatureVerifier struct {
	// contains filtered or unexported fields
}

ECDSASignatureVerifier verifies elliptic curve signatures.

func NewECDSAES256SignatureVerifier added in v0.1.3

func NewECDSAES256SignatureVerifier() *ECDSASignatureVerifier

NewECDSAES256SignatureVerifier creates a new signature verifier that verifies a ECDSA P-256 signature taking public key bytes and JSON Web Key as input.

func NewECDSAES384SignatureVerifier added in v0.1.3

func NewECDSAES384SignatureVerifier() *ECDSASignatureVerifier

NewECDSAES384SignatureVerifier creates a new signature verifier that verifies a ECDSA P-384 signature taking public key bytes and JSON Web Key as input.

func NewECDSAES521SignatureVerifier added in v0.1.3

func NewECDSAES521SignatureVerifier() *ECDSASignatureVerifier

NewECDSAES521SignatureVerifier creates a new signature verifier that verifies a ECDSA P-521 signature taking public key bytes and JSON Web Key as input.

func NewECDSASecp256k1SignatureVerifier added in v0.1.3

func NewECDSASecp256k1SignatureVerifier() *ECDSASignatureVerifier

NewECDSASecp256k1SignatureVerifier creates a new signature verifier that verifies a ECDSA secp256k1 signature taking public key bytes and JSON Web Key as input.

func (ECDSASignatureVerifier) Algorithm added in v0.1.3

func (sv ECDSASignatureVerifier) Algorithm() string

func (ECDSASignatureVerifier) Curve added in v0.1.3

func (sv ECDSASignatureVerifier) Curve() string

func (ECDSASignatureVerifier) KeyType added in v0.1.3

func (sv ECDSASignatureVerifier) KeyType() string

func (*ECDSASignatureVerifier) Verify added in v0.1.3

func (sv *ECDSASignatureVerifier) Verify(pubKey *PublicKey, msg, signature []byte) error

Verify verifies the signature.

type Ed25519SignatureVerifier added in v0.1.3

type Ed25519SignatureVerifier struct {
	// contains filtered or unexported fields
}

Ed25519SignatureVerifier verifies a Ed25519 signature taking Ed25519 public key bytes as input.

func NewEd25519SignatureVerifier added in v0.1.3

func NewEd25519SignatureVerifier() *Ed25519SignatureVerifier

NewEd25519SignatureVerifier creates a new Ed25519SignatureVerifier.

func (Ed25519SignatureVerifier) Algorithm added in v0.1.3

func (sv Ed25519SignatureVerifier) Algorithm() string

func (Ed25519SignatureVerifier) Curve added in v0.1.3

func (sv Ed25519SignatureVerifier) Curve() string

func (Ed25519SignatureVerifier) KeyType added in v0.1.3

func (sv Ed25519SignatureVerifier) KeyType() string

func (Ed25519SignatureVerifier) Verify added in v0.1.3

func (sv Ed25519SignatureVerifier) Verify(pubKey *PublicKey, msg, signature []byte) error

Verify verifies the signature.

type PublicKey added in v0.1.3

type PublicKey struct {
	Type  string
	Value []byte
	JWK   *jose.JWK
}

PublicKey contains a result of public key resolution.

type PublicKeyVerifier added in v0.1.3

type PublicKeyVerifier struct {
	// contains filtered or unexported fields
}

PublicKeyVerifier makes signature verification using the public key based on one or several signature algorithms.

func NewCompositePublicKeyVerifier added in v0.1.3

func NewCompositePublicKeyVerifier(verifiers []SignatureVerifier, opts ...PublicKeyVerifierOpt) *PublicKeyVerifier

NewCompositePublicKeyVerifier creates a new PublicKeyVerifier based on one or more signature algorithms.

func NewPublicKeyVerifier added in v0.1.3

func NewPublicKeyVerifier(sigAlg SignatureVerifier, opts ...PublicKeyVerifierOpt) *PublicKeyVerifier

NewPublicKeyVerifier creates a new PublicKeyVerifier based on single signature algorithm.

func (*PublicKeyVerifier) Verify added in v0.1.3

func (pkv *PublicKeyVerifier) Verify(pubKey *PublicKey, msg, signature []byte) error

Verify verifies the signature.

type PublicKeyVerifierOpt added in v0.1.3

type PublicKeyVerifierOpt func(opts *PublicKeyVerifier)

PublicKeyVerifierOpt is the PublicKeyVerifier functional option.

func WithExactPublicKeyType added in v0.1.3

func WithExactPublicKeyType(jwkType string) PublicKeyVerifierOpt

WithExactPublicKeyType option is used to check the type of the PublicKey.

type RSAPS256SignatureVerifier added in v0.1.3

type RSAPS256SignatureVerifier struct {
	// contains filtered or unexported fields
}

RSAPS256SignatureVerifier verifies a Ed25519 signature taking RSA public key bytes as input.

func NewRSAPS256SignatureVerifier added in v0.1.3

func NewRSAPS256SignatureVerifier() *RSAPS256SignatureVerifier

NewRSAPS256SignatureVerifier creates a new RSAPS256SignatureVerifier.

func (RSAPS256SignatureVerifier) Algorithm added in v0.1.3

func (sv RSAPS256SignatureVerifier) Algorithm() string

func (RSAPS256SignatureVerifier) Curve added in v0.1.3

func (sv RSAPS256SignatureVerifier) Curve() string

func (RSAPS256SignatureVerifier) KeyType added in v0.1.3

func (sv RSAPS256SignatureVerifier) KeyType() string

func (RSAPS256SignatureVerifier) Verify added in v0.1.3

func (sv RSAPS256SignatureVerifier) Verify(key *PublicKey, msg, signature []byte) error

Verify verifies the signature.

type SignatureSuite added in v0.1.3

type SignatureSuite interface {

	// GetCanonicalDocument will return normalized/canonical version of the document
	GetCanonicalDocument(doc map[string]interface{}, opts ...jsonld.ProcessorOpts) ([]byte, error)

	// GetDigest returns document digest
	GetDigest(doc []byte) []byte

	// Verify will verify signature against public key
	Verify(pubKey *PublicKey, doc []byte, signature []byte) error

	// Accept registers this signature suite with the given signature type
	Accept(signatureType string) bool

	// CompactProof indicates weather to compact the proof doc before canonization
	CompactProof() bool
}

SignatureSuite encapsulates signature suite methods required for signature verification.

type SignatureVerifier added in v0.1.3

type SignatureVerifier interface {
	KeyType() string

	Curve() string

	Algorithm() string

	Verify(pubKey *PublicKey, msg, signature []byte) error
}

SignatureVerifier make signature verification of a certain algorithm (e.g. Ed25519 or ECDSA secp256k1).

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL