Documentation ¶
Index ¶
- func CheckpointValidator(strToValidate string) bool
- func CreateAndInitTree(ctx context.Context, adminClient trillian.TrillianAdminClient, ...) (*trillian.Tree, error)
- func CreateAndSignCheckpoint(ctx context.Context, hostname string, treeID int64, root *types.LogRootV1, ...) ([]byte, error)
- func FileOrURLReadCloser(ctx context.Context, url string, content []byte) (io.ReadCloser, error)
- func PrefixSHA(sha string) string
- func PublicKey(ctx context.Context, c *client.Rekor) (*ecdsa.PublicKey, error)
- func SignedCheckpointValidator(strToValidate string) bool
- func SignedNoteValidator(strToValidate string) bool
- func SignedTimestampNoteValidator(strToValidate string) bool
- func TimestampNoteValidator(strToValidate string) bool
- func ValidateSHA1Value(v string) error
- func ValidateSHA256Value(v string) error
- func ValidateSHA512Value(v string) error
- type Checkpoint
- type Response
- type SignedCheckpoint
- type SignedNote
- func (s SignedNote) MarshalText() ([]byte, error)
- func (s *SignedNote) Sign(identity string, signer signature.Signer, opts signature.SignOption) (*note.Signature, error)
- func (s SignedNote) String() string
- func (s *SignedNote) UnmarshalText(data []byte) error
- func (s SignedNote) Verify(verifier signature.Verifier) bool
- type SignedTimestampNote
- type TimestampNote
- type TrillianClient
- func (t *TrillianClient) AddLeaf(byteValue []byte) *Response
- func (t *TrillianClient) GetConsistencyProof(firstSize, lastSize int64) *Response
- func (t *TrillianClient) GetLatest(leafSizeInt int64) *Response
- func (t *TrillianClient) GetLeafAndProofByHash(hash []byte) *Response
- func (t *TrillianClient) GetLeafAndProofByIndex(index int64) *Response
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func CheckpointValidator ¶ added in v0.2.0
func CreateAndInitTree ¶ added in v1.1.1
func CreateAndInitTree(ctx context.Context, adminClient trillian.TrillianAdminClient, logClient trillian.TrillianLogClient) (*trillian.Tree, error)
func CreateAndSignCheckpoint ¶ added in v0.12.0
func CreateAndSignCheckpoint(ctx context.Context, hostname string, treeID int64, root *types.LogRootV1, signer signature.Signer) ([]byte, error)
CreateAndSignCheckpoint creates a signed checkpoint as a commitment to the current root hash
func FileOrURLReadCloser ¶
FileOrURLReadCloser Note: caller is responsible for closing ReadCloser returned from method!
func PrefixSHA ¶ added in v0.6.0
PrefixSHA sets the prefix of a sha hash to match how it is stored based on the length.
func SignedCheckpointValidator ¶ added in v0.2.0
func SignedNoteValidator ¶ added in v0.3.0
func SignedTimestampNoteValidator ¶ added in v0.4.0
func TimestampNoteValidator ¶ added in v0.4.0
func ValidateSHA1Value ¶ added in v0.4.0
func ValidateSHA256Value ¶ added in v0.4.0
validateSHA256Value ensures that the supplied string matches the following format: [sha256:]<64 hexadecimal characters> where [sha256:] is optional
func ValidateSHA512Value ¶ added in v1.1.0
validateSHA512Value ensures that the supplied string matches the following format: [sha512:]<128 hexadecimal characters> where [sha512:] is optional
Types ¶
type Checkpoint ¶ added in v0.2.0
type Checkpoint struct { // Origin is the unique identifier/version string Origin string // Size is the number of entries in the log at this checkpoint. Size uint64 // Hash is the hash which commits to the contents of the entire log. Hash []byte // OtherContent is any additional data to be included in the signed payload; each element is assumed to be one line OtherContent []string }
func (Checkpoint) MarshalCheckpoint ¶ added in v0.4.0
func (c Checkpoint) MarshalCheckpoint() ([]byte, error)
MarshalText returns the common format representation of this Checkpoint.
func (Checkpoint) String ¶ added in v0.2.0
func (c Checkpoint) String() string
String returns the String representation of the Checkpoint
func (*Checkpoint) UnmarshalCheckpoint ¶ added in v0.4.0
func (c *Checkpoint) UnmarshalCheckpoint(data []byte) error
UnmarshalText parses the common formatted checkpoint data and stores the result in the Checkpoint.
The supplied data is expected to begin with the following 3 lines of text, each followed by a newline: <ecosystem/version string> <decimal representation of log size> <base64 representation of root hash> <optional non-empty line of other content>... <optional non-empty line of other content>...
This will discard any content found after the checkpoint (including signatures)
type Response ¶ added in v1.1.1
type Response struct { // Status is the status code of the response Status codes.Code // Error contains an error on request or client failure Err error // GetAddResult contains the response from queueing a leaf in Trillian GetAddResult *trillian.QueueLeafResponse // GetLeafAndProofResult contains the response for fetching an inclusion proof and leaf GetLeafAndProofResult *trillian.GetEntryAndProofResponse // GetLatestResult contains the response for the latest checkpoint GetLatestResult *trillian.GetLatestSignedLogRootResponse // GetConsistencyProofResult contains the response for a consistency proof between two log sizes GetConsistencyProofResult *trillian.GetConsistencyProofResponse // contains filtered or unexported fields }
Response includes a status code, an optional error message, and one of the results based on the API call
type SignedCheckpoint ¶ added in v0.2.0
type SignedCheckpoint struct { Checkpoint SignedNote }
func CreateSignedCheckpoint ¶ added in v0.3.0
func CreateSignedCheckpoint(c Checkpoint) (*SignedCheckpoint, error)
func (*SignedCheckpoint) GetTimestamp ¶ added in v0.3.0
func (r *SignedCheckpoint) GetTimestamp() uint64
func (*SignedCheckpoint) SetTimestamp ¶ added in v0.3.0
func (r *SignedCheckpoint) SetTimestamp(timestamp uint64)
func (*SignedCheckpoint) UnmarshalText ¶ added in v0.2.0
func (r *SignedCheckpoint) UnmarshalText(data []byte) error
type SignedNote ¶ added in v0.3.0
type SignedNote struct { // Textual representation of a note to sign. Note string // Signatures are one or more signature lines covering the payload Signatures []note.Signature }
func (SignedNote) MarshalText ¶ added in v0.3.0
func (s SignedNote) MarshalText() ([]byte, error)
MarshalText returns the common format representation of this SignedNote.
func (*SignedNote) Sign ¶ added in v0.3.0
func (s *SignedNote) Sign(identity string, signer signature.Signer, opts signature.SignOption) (*note.Signature, error)
Sign adds a signature to a SignedCheckpoint object The signature is added to the signature array as well as being directly returned to the caller
func (SignedNote) String ¶ added in v0.3.0
func (s SignedNote) String() string
String returns the String representation of the SignedNote
func (*SignedNote) UnmarshalText ¶ added in v0.3.0
func (s *SignedNote) UnmarshalText(data []byte) error
UnmarshalText parses the common formatted signed note data and stores the result in the SignedNote. THIS DOES NOT VERIFY SIGNATURES INSIDE THE CONTENT!
The supplied data is expected to contain a single Note, followed by a single line with no comment, followed by one or more lines with the following format:
\u2014 name signature
- name is the string associated with the signer
- signature is a base64 encoded string; the first 4 bytes of the decoded value is a hint to the public key; it is a big-endian encoded uint32 representing the first 4 bytes of the SHA256 hash of the public key
type SignedTimestampNote ¶ added in v0.4.0
type SignedTimestampNote struct { TimestampNote SignedNote }
func CreateSignedTimestampNote ¶ added in v0.4.0
func CreateSignedTimestampNote(t TimestampNote) (*SignedTimestampNote, error)
func (*SignedTimestampNote) UnmarshalText ¶ added in v0.4.0
func (r *SignedTimestampNote) UnmarshalText(data []byte) error
type TimestampNote ¶ added in v0.3.0
type TimestampNote struct { // Origin is the unique identifier/version string Origin string // MessageImprint is the hash of the message to timestamp, of the form sha256:<sha> MessageImprint string // Nonce is a short random bytes to prove response freshness Nonce []byte // Time is the timestamp to imprint on the message Time time.Time // Radius is the time in microseconds used to indicate certainty Radius int64 // CertChainRef is a reference URL to the valid timestamping cert chain used to sign the response CertChainRef *url.URL // OtherContent is any additional data to be included in the signed payload; each element is assumed to be one line OtherContent []string }
func (TimestampNote) MarshalText ¶ added in v0.3.0
func (t TimestampNote) MarshalText() ([]byte, error)
MarshalText returns the common format representation of this TimestampNote.
func (TimestampNote) String ¶ added in v0.3.0
func (t TimestampNote) String() string
String returns the String representation of the TimestampNote
func (*TimestampNote) UnmarshalText ¶ added in v0.3.0
func (t *TimestampNote) UnmarshalText(data []byte) error
UnmarshalText parses the common formatted timestamp note data and stores the result in the TimestampNote.
The supplied data is expected to begin with the following 6 lines of text, each followed by a newline: <ecosystem/version string> <message hash of the format sha256:$SHA> <base64 representation of the nonce> <RFC 3339 representation of the time> <decimal representation of radius> <cert chain URI> <optional non-empty line of other content>... <optional non-empty line of other content>...
This will discard any content found after the checkpoint (including signatures)
type TrillianClient ¶ added in v1.1.1
type TrillianClient struct {
// contains filtered or unexported fields
}
TrillianClient provides a wrapper around the Trillian client
func NewTrillianClient ¶ added in v1.1.1
func NewTrillianClient(ctx context.Context, logClient trillian.TrillianLogClient, logID int64) TrillianClient
NewTrillianClient creates a TrillianClient with the given Trillian client and log/tree ID.
func (*TrillianClient) AddLeaf ¶ added in v1.1.1
func (t *TrillianClient) AddLeaf(byteValue []byte) *Response
func (*TrillianClient) GetConsistencyProof ¶ added in v1.1.1
func (t *TrillianClient) GetConsistencyProof(firstSize, lastSize int64) *Response
func (*TrillianClient) GetLatest ¶ added in v1.1.1
func (t *TrillianClient) GetLatest(leafSizeInt int64) *Response
func (*TrillianClient) GetLeafAndProofByHash ¶ added in v1.1.1
func (t *TrillianClient) GetLeafAndProofByHash(hash []byte) *Response
func (*TrillianClient) GetLeafAndProofByIndex ¶ added in v1.1.1
func (t *TrillianClient) GetLeafAndProofByIndex(index int64) *Response