-
Notifications
You must be signed in to change notification settings - Fork 7
Expand file tree
/
Copy pathopcommon.go
More file actions
90 lines (78 loc) · 2.5 KB
/
opcommon.go
File metadata and controls
90 lines (78 loc) · 2.5 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
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
//go:build !freebsd
package keyring
import (
"encoding/json"
"errors"
"fmt"
"os"
"strings"
onepassword "github.com/1password/onepassword-sdk-go"
)
const (
OPEnvVaultID = "OP_VAULT_ID"
OPItemFieldTitle = "keyring"
OPItemTag = "keyring"
OPItemTitlePrefix = "keyring"
OPItemTitlePrefixKeySep = ": "
)
var (
ErrEnvUnsetOrEmpty = errors.New("Environment variable unset or empty")
OPErrClient = errors.New(
"Unable to create a 1Password Connect / Service Accounts / Desktop Integration client",
)
OPErrItemMultiple = errors.New("Found multiple matching 1Password items")
OPErrItemTitleDuplicate = errors.New("Found duplicate 1Password item title")
OPErrKeyring = errors.New(
"Unable to create a 1Password Connect / Service Accounts / Desktop Integration keyring",
)
OPErrTokenFuncNil = fmt.Errorf("%w: Token function is nil", OPErrClient)
OPErrVaultID = fmt.Errorf("%w: %w: %#v", OPErrKeyring, ErrEnvUnsetOrEmpty, OPEnvVaultID)
)
type OPKeyringAPI interface {
Keyring
GetItemFromOPItemFieldValue(opItemFieldValue string) (*Item, error)
GetKeyFromOPItemTitle(opItemTitle string) string
GetOPItem(key string) (*onepassword.Item, error)
GetOPItemFieldValueFromItem(item *Item) (string, error)
GetOPItems() ([]onepassword.Item, error)
GetOPItemTitleFromKey(key string) string
GetOPToken(prompt string) (string, error)
}
type OPBaseKeyring struct {
VaultID string
ItemTitlePrefix string
ItemTag string
ItemFieldTitle string
TokenEnvs []string
TokenFunc PromptFunc
}
func (k *OPBaseKeyring) GetItemFromOPItemFieldValue(opItemFieldValue string) (*Item, error) {
var item Item
err := json.Unmarshal([]byte(opItemFieldValue), &item)
return &item, err
}
func (k *OPBaseKeyring) GetKeyFromOPItemTitle(opItemTitle string) string {
return strings.TrimPrefix(opItemTitle, k.ItemTitlePrefix+OPItemTitlePrefixKeySep)
}
func (k *OPBaseKeyring) GetOPItemFieldValueFromItem(item *Item) (string, error) {
opItemFieldValueBytes, err := json.Marshal(item)
if err != nil {
return "", err
}
return string(opItemFieldValueBytes), nil
}
func (k *OPBaseKeyring) GetOPItemTitleFromKey(key string) string {
return k.ItemTitlePrefix + OPItemTitlePrefixKeySep + key
}
func (k *OPBaseKeyring) GetOPToken(prompt string) (string, error) {
for _, tokenEnv := range k.TokenEnvs {
token := os.Getenv(tokenEnv)
if token != "" {
return token, nil
}
}
if k.TokenFunc != nil {
return k.TokenFunc(prompt)
}
return "", OPErrTokenFuncNil
}