open-vault/logical/system_view.go

140 lines
4.6 KiB
Go
Raw Normal View History

package logical
2017-02-16 18:37:21 +00:00
import (
"context"
2017-03-16 00:14:48 +00:00
"errors"
2017-02-16 18:37:21 +00:00
"time"
"github.com/hashicorp/vault/helper/consts"
2018-09-18 03:03:00 +00:00
"github.com/hashicorp/vault/helper/license"
2017-04-04 00:52:29 +00:00
"github.com/hashicorp/vault/helper/pluginutil"
"github.com/hashicorp/vault/helper/wrapping"
2017-02-16 18:37:21 +00:00
)
// SystemView exposes system configuration information in a safe way
// for logical backends to consume
type SystemView interface {
2015-08-27 16:14:03 +00:00
// DefaultLeaseTTL returns the default lease TTL set in Vault configuration
DefaultLeaseTTL() time.Duration
2015-08-27 16:14:03 +00:00
// MaxLeaseTTL returns the max lease TTL set in Vault configuration; backend
// authors should take care not to issue credentials that last longer than
// this value, as Vault will revoke them
MaxLeaseTTL() time.Duration
2015-09-21 14:04:03 +00:00
// SudoPrivilege returns true if given path has sudo privileges
// for the given client token
SudoPrivilege(ctx context.Context, path string, token string) bool
// Returns true if the mount is tainted. A mount is tainted if it is in the
// process of being unmounted. This should only be used in special
// circumstances; a primary use-case is as a guard in revocation functions.
// If revocation of a backend's leases fails it can keep the unmounting
// process from being successful. If the reason for this failure is not
// relevant when the mount is tainted (for instance, saving a CRL to disk
// when the stored CRL will be removed during the unmounting process
// anyways), we can ignore the errors to allow unmounting to complete.
Tainted() bool
// Returns true if caching is disabled. If true, no caches should be used,
// despite known slowdowns.
CachingDisabled() bool
// When run from a system view attached to a request, indicates whether the
// request is affecting a local mount or not
LocalMount() bool
// ReplicationState indicates the state of cluster replication
2017-02-16 18:37:21 +00:00
ReplicationState() consts.ReplicationState
2017-03-16 00:14:48 +00:00
2018-09-18 03:03:00 +00:00
// HasFeature returns true if the feature is currently enabled
HasFeature(feature license.Features) bool
2017-03-16 00:14:48 +00:00
// ResponseWrapData wraps the given data in a cubbyhole and returns the
// token used to unwrap.
ResponseWrapData(ctx context.Context, data map[string]interface{}, ttl time.Duration, jwt bool) (*wrapping.ResponseWrapInfo, error)
2017-04-04 00:52:29 +00:00
2017-04-11 00:12:52 +00:00
// LookupPlugin looks into the plugin catalog for a plugin with the given
// name. Returns a PluginRunner or an error if a plugin can not be found.
2018-11-07 01:21:24 +00:00
LookupPlugin(context.Context, string, consts.PluginType) (*pluginutil.PluginRunner, error)
2017-04-11 00:12:52 +00:00
2017-05-04 17:41:59 +00:00
// MlockEnabled returns the configuration setting for enabling mlock on
2017-04-24 19:21:49 +00:00
// plugins.
MlockEnabled() bool
// EntityInfo returns a subset of information related to the identity entity
// for the given entity id
EntityInfo(entityID string) (*Entity, error)
2018-08-03 16:32:17 +00:00
// PluginEnv returns Vault environment information used by plugins
PluginEnv(context.Context) (*PluginEnvironment, error)
}
type StaticSystemView struct {
DefaultLeaseTTLVal time.Duration
MaxLeaseTTLVal time.Duration
SudoPrivilegeVal bool
TaintedVal bool
CachingDisabledVal bool
Primary bool
2017-04-24 19:21:49 +00:00
EnableMlock bool
LocalMountVal bool
2017-02-16 18:37:21 +00:00
ReplicationStateVal consts.ReplicationState
EntityVal *Entity
2018-09-18 03:03:00 +00:00
Features license.Features
2018-08-03 16:32:17 +00:00
VaultVersion string
PluginEnvironment *PluginEnvironment
}
func (d StaticSystemView) DefaultLeaseTTL() time.Duration {
return d.DefaultLeaseTTLVal
}
func (d StaticSystemView) MaxLeaseTTL() time.Duration {
return d.MaxLeaseTTLVal
}
func (d StaticSystemView) SudoPrivilege(_ context.Context, path string, token string) bool {
return d.SudoPrivilegeVal
}
func (d StaticSystemView) Tainted() bool {
return d.TaintedVal
}
func (d StaticSystemView) CachingDisabled() bool {
return d.CachingDisabledVal
}
func (d StaticSystemView) LocalMount() bool {
return d.LocalMountVal
}
2017-02-16 18:37:21 +00:00
func (d StaticSystemView) ReplicationState() consts.ReplicationState {
return d.ReplicationStateVal
}
2017-03-16 00:14:48 +00:00
func (d StaticSystemView) ResponseWrapData(_ context.Context, data map[string]interface{}, ttl time.Duration, jwt bool) (*wrapping.ResponseWrapInfo, error) {
return nil, errors.New("ResponseWrapData is not implemented in StaticSystemView")
2017-03-16 00:14:48 +00:00
}
2017-04-04 00:52:29 +00:00
2018-11-07 01:21:24 +00:00
func (d StaticSystemView) LookupPlugin(_ context.Context, _ string, _ consts.PluginType) (*pluginutil.PluginRunner, error) {
2017-04-11 18:50:34 +00:00
return nil, errors.New("LookupPlugin is not implemented in StaticSystemView")
2017-04-04 00:52:29 +00:00
}
2017-04-11 00:12:52 +00:00
2017-04-24 19:21:49 +00:00
func (d StaticSystemView) MlockEnabled() bool {
return d.EnableMlock
2017-04-11 00:12:52 +00:00
}
func (d StaticSystemView) EntityInfo(entityID string) (*Entity, error) {
return d.EntityVal, nil
}
2018-08-03 16:32:17 +00:00
2018-09-18 03:03:00 +00:00
func (d StaticSystemView) HasFeature(feature license.Features) bool {
return d.Features.HasFeature(feature)
}
2018-08-03 16:32:17 +00:00
func (d StaticSystemView) PluginEnv(_ context.Context) (*PluginEnvironment, error) {
return d.PluginEnvironment, nil
}