-
Notifications
You must be signed in to change notification settings - Fork 47
Expand file tree
/
Copy pathlog.go
More file actions
45 lines (41 loc) · 2.2 KB
/
log.go
File metadata and controls
45 lines (41 loc) · 2.2 KB
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