-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathbackend.go
66 lines (57 loc) · 1.61 KB
/
backend.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
// Copyright (c) HashiCorp, Inc.
// SPDX-License-Identifier: MPL-2.0
package alicloud
import (
"context"
"strings"
"github.com/aliyun/alibaba-cloud-sdk-go/sdk"
"github.com/hashicorp/vault/sdk/framework"
"github.com/hashicorp/vault/sdk/logical"
)
// operationPrefixAliCloud is used as a prefix for OpenAPI operation id's.
const operationPrefixAliCloud = "ali-cloud"
func Factory(ctx context.Context, conf *logical.BackendConfig) (logical.Backend, error) {
sdkConfig := sdk.NewConfig()
sdkConfig.Scheme = "https"
b := newBackend(sdkConfig)
if err := b.Setup(ctx, conf); err != nil {
return nil, err
}
return b, nil
}
// newBackend allows us to pass in the sdkConfig for testing purposes.
func newBackend(sdkConfig *sdk.Config) logical.Backend {
var b backend
b.Backend = &framework.Backend{
Help: strings.TrimSpace(backendHelp),
PathsSpecial: &logical.Paths{
SealWrapStorage: []string{
"config",
},
},
Paths: []*framework.Path{
b.pathConfig(),
b.pathRole(),
b.pathListRoles(),
b.pathCreds(),
},
Secrets: []*framework.Secret{
b.pathSecrets(),
},
BackendType: logical.TypeLogical,
}
b.sdkConfig = sdkConfig
return b
}
type backend struct {
*framework.Backend
sdkConfig *sdk.Config
}
const backendHelp = `
The AliCloud backend dynamically generates AliCloud access keys for a set of
RAM policies. The AliCloud access keys have a configurable ttl set and
are automatically revoked at the end of the ttl.
After mounting this backend, credentials to generate RAM keys must
be configured and roles must be written using
the "role/" endpoints before any access keys can be generated.
`