forked from cirello-io/pglock
-
Notifications
You must be signed in to change notification settings - Fork 0
/
errors.go
102 lines (80 loc) · 2.89 KB
/
errors.go
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
/*
Copyright 2019 github.com/ucirello
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 pglock
import (
"errors"
"fmt"
)
// NotExistError is an error wrapper that gives the NotExist kind to an error.
type NotExistError struct {
error
}
// Unwrap returns the next error in the error chain.
func (err *NotExistError) Unwrap() error {
return err.error
}
func (err *NotExistError) Error() string {
return fmt.Sprintf("not exists: %s", err.error)
}
// UnavailableError is an error wrapper that gives the Unavailable kind to an
// error.
type UnavailableError struct {
error
}
// Unwrap returns the next error in the error chain.
func (err *UnavailableError) Unwrap() error {
return err.error
}
func (err *UnavailableError) Error() string {
return fmt.Sprintf("unavailable: %s", err.error)
}
// FailedPreconditionError is an error wrapper that gives the FailedPrecondition
// kind to an error.
type FailedPreconditionError struct {
error
}
// Unwrap returns the next error in the error chain.
func (err *FailedPreconditionError) Unwrap() error {
return err.error
}
func (err *FailedPreconditionError) Error() string {
return fmt.Sprintf("failed precondition: %s", err.error)
}
// OtherError is an error wrapper that gives the Other kind to an error.
type OtherError struct {
error
}
// Unwrap returns the next error in the error chain.
func (err *OtherError) Unwrap() error {
return err.error
}
func (err *OtherError) Error() string {
return fmt.Sprintf("%s", err.error)
}
// ErrNotPostgreSQLDriver is returned when an invalid database connection is
// passed to this locker client.
var ErrNotPostgreSQLDriver = errors.New("this is not a PostgreSQL connection")
// ErrNotAcquired indicates the given lock is already enforce to some other
// client.
var ErrNotAcquired = errors.New("cannot acquire lock")
// ErrLockAlreadyReleased indicates that a release call cannot be fulfilled
// because the client does not hold the lock
var ErrLockAlreadyReleased = errors.New("lock is already released")
// ErrLockNotFound is returned for get calls on missing lock entries.
var ErrLockNotFound = &NotExistError{errors.New("lock not found")}
// Validation errors
var (
ErrDurationTooSmall = errors.New("Heartbeat period must be no more than half the length of the Lease Duration, " +
"or locks might expire due to the heartbeat thread taking too long to update them (recommendation is to make it much greater, for example " +
"4+ times greater)")
)