File: log.go

package info (click to toggle)
golang-github-transparency-dev-tessera 1.0.1-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 3,612 kB
  • sloc: sql: 33; sh: 17; makefile: 12
file content (45 lines) | stat: -rw-r--r-- 2,254 bytes parent folder | download
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
// Copyright 2024 The Tessera authors. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

package tessera

import (
	"errors"
	"fmt"
)

var (
	// ErrPushback is returned by underlying storage implementations when a new entry cannot be accepted
	// due to overload in the system. This could be because there are too many entries with indices assigned
	// but which have not yet been integrated into the tree, or it could be because the antispam mechanism
	// is not able to keep up with recently added entries. It should always be wrapped with a more
	// specific error to provide context to clients.
	//
	// Personalities encountering this error should apply back-pressure to the source of new entries
	// in an appropriate manner (e.g. for HTTP services, return a 503 with a Retry-After header).
	//
	// Personalities should check for this error (wrapped or not) using `errors.Is(e, ErrPushback)`.
	ErrPushback = errors.New("pushback")
	// ErrPushbackAntispam is a wrapped ErrPushback. It is returned by underlying storage implementations
	// when an entry cannot be accepted becasue the antispam follower has fallen too far behind the size
	// of the integrated tree.
	ErrPushbackAntispam = fmt.Errorf("antispam %w", ErrPushback)
	// ErrPushbackIntegration is a wrapped ErrPushback. It is returned by underlying storage implementations
	// when an entry cannot be accepted becasue there are too many "in-flight" add requests - i.e. entries
	// with sequence numbers assigned, but which are not yet integrated into the log.
	ErrPushbackIntegration = fmt.Errorf("integration %w", ErrPushback)
)

// Driver is the implementation-specific parts of Tessera. No methods are on here as this is not for public use.
type Driver any