secrettype

package
v0.0.0-...-e7c744b Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jun 21, 2023 License: Apache-2.0 Imports: 0 Imported by: 0

Documentation

Index

Constants

View Source
const (
	Amazon     = "amazon"
	Azure      = "azure"
	Google     = "google"
	Dummy      = "dummy"
	Kubernetes = "kubernetes"
	Vsphere    = "vsphere"
)

Cloud constants

View Source
const (
	AwsRegion          = "AWS_REGION"
	AwsAccessKeyId     = "AWS_ACCESS_KEY_ID"
	AwsSecretAccessKey = "AWS_SECRET_ACCESS_KEY"
)

Amazon keys

View Source
const (
	AzureClientID       = "AZURE_CLIENT_ID"
	AzureClientSecret   = "AZURE_CLIENT_SECRET"
	AzureTenantID       = "AZURE_TENANT_ID"
	AzureSubscriptionID = "AZURE_SUBSCRIPTION_ID"
)

Azure keys

View Source
const (
	Type          = "type"
	ProjectId     = "project_id"
	PrivateKeyId  = "private_key_id"
	PrivateKey    = "private_key"
	ClientEmail   = "client_email"
	ClientId      = "client_id"
	AuthUri       = "auth_uri"
	TokenUri      = "token_uri"
	AuthX509Url   = "auth_provider_x509_cert_url"
	ClientX509Url = "client_x509_cert_url"
)

Google keys

View Source
const (
	VsphereURL                 = "url"
	VsphereUser                = "user"
	VspherePassword            = "password"
	VsphereFingerprint         = "fingerprint"
	VsphereDatacenter          = "datacenter"
	VsphereDatastore           = "datastore"
	VsphereResourcePool        = "resourcePool"
	VsphereFolder              = "folder"
	VsphereDefaultNodeTemplate = "defaultNodeTemplate"
)

vSphere keys

View Source
const (
	User                 = "user"
	Identifier           = "identifier"
	PublicKeyData        = "public_key_data"
	PublicKeyFingerprint = "public_key_fingerprint"
	PrivateKeyData       = "private_key_data"
)

Ssh keys

View Source
const (
	TLSHosts    = "hosts"
	TLSValidity = "validity"
	CACert      = "caCert"
	CAKey       = "caKey"
	ServerKey   = "serverKey"
	ServerCert  = "serverCert"
	ClientKey   = "clientKey"
	ClientCert  = "clientCert"
	PeerKey     = "peerKey"
	PeerCert    = "peerCert"
)

TLS keys

View Source
const (
	KubernetesCACert        = "kubernetesCaCert"
	KubernetesCASigningCert = "kubernetesCaSigningCert"
	KubernetesCAKey         = "kubernetesCaKey"

	EtcdCACert = "etcdCaCert"
	EtcdCAKey  = "etcdCaKey"

	FrontProxyCACert = "frontProxyCaCert"
	FrontProxyCAKey  = "frontProxyCaKey"

	SAPub = "saPub"
	SAKey = "saKey"

	EncryptionSecret = "enc"

	// some useful helpers
	KubernetesCACommonName           = "kubernetes-ca"
	EtcdCACommonName                 = "etcd-ca"
	KubernetesFrontProxyCACommonName = "kubernetes-front-proxy-ca"
)

Distribution keys

View Source
const (
	Username = "username"
	Password = "password"
)

Password keys

View Source
const (
	CfApiKey   = "CF_API_KEY"
	CfApiEmail = "CF_API_EMAIL"
)

CloudFlare keys

View Source
const (
	// GenericSecret represents generic secret types, without schema
	GenericSecret = "generic"
	// AllSecrets represents generic secret types which selects all secrets
	AllSecrets = ""
	// SSHSecretType marks secrets as of type "ssh"
	SSHSecretType = "ssh"
	// TLSSecretType marks secrets as of type "tls"
	TLSSecretType = "tls"
	// DistributionSecretType marks secrets as of type "distribution"
	PKESecretType = "pkecert"
	// FnSecretType marks secrets as of type "fn"
	FnSecretType = "fn"
	// PasswordSecretType marks secrets as of type "password"
	PasswordSecretType = "password"
	// HtpasswdSecretType marks secrets as of type "htpasswd"
	HtpasswdSecretType = "htpasswd"
	// CloudFlareSecretType marks secrets as of type "cloudflare"
	CloudFlareSecretType = "cloudflare"
	// DigitalOceanSecretType marks secrets as of type "digitalocean"
	DigitalOceanSecretType = "digitalocean"
	// VaultSecretType as marks secrets as of type "vault"
	VaultSecretType = "vault"
	// SlackSecretType as marks secrets as of type "slack"
	SlackSecretType = "slack"
	// PagerDutySecretType as marks secrets as of type "pagerduty"
	PagerDutySecretType = "pagerduty"
)
View Source
const (
	DoToken = "DO_TOKEN"
)

DigitalOcean keys

View Source
const (
	HtpasswdFile = "htpasswd"
)

Htpasswd extra keys (+Password keys)

View Source
const (
	K8SConfig = "K8Sconfig"
)

Kubernetes keys

View Source
const (
	MasterToken = "master_token"
)

Fn keys

View Source
const (
	PagerDutyIntegrationKey = "integrationKey"
)

PagerDuty keys

View Source
const (
	SlackApiUrl = "apiUrl"
)

Slack keys

View Source
const (
	VaultToken = "token"
)

Vault keys

Variables

View Source
var DefaultRules = map[string]Meta{
	Amazon: {
		Fields: []FieldMeta{
			{Name: AwsRegion, Required: false, IsSafeToDisplay: true, Description: "Amazon Cloud region"},
			{Name: AwsAccessKeyId, Required: true, IsSafeToDisplay: true, Description: "Your Amazon Cloud access key id"},
			{Name: AwsSecretAccessKey, Required: true, Description: "Your Amazon Cloud secret access key id"},
		},
	},
	Azure: {
		Fields: []FieldMeta{
			{Name: AzureClientID, Required: true, IsSafeToDisplay: true, Description: "Your application client id"},
			{Name: AzureClientSecret, Required: true, Description: "Your client secret id"},
			{Name: AzureTenantID, Required: true, IsSafeToDisplay: true, Description: "Your tenant id"},
			{Name: AzureSubscriptionID, Required: true, IsSafeToDisplay: true, Description: "Your subscription id"},
		},
	},
	Google: {
		Fields: []FieldMeta{
			{Name: Type, Required: true, IsSafeToDisplay: true, Description: "service_account"},
			{Name: ProjectId, Required: true, IsSafeToDisplay: true, Description: "Google Could Project Id. Find more about, Google Cloud secret fields here: https://banzaicloud.com/docs/pipeline/secrets/providers/gke_auth_credentials/#method-2-command-line"},
			{Name: PrivateKeyId, Required: true, IsSafeToDisplay: true, Description: "Id of you private key"},
			{Name: PrivateKey, Required: true, Description: "Your private key "},
			{Name: ClientEmail, Required: true, IsSafeToDisplay: true, Description: "Google service account client email"},
			{Name: ClientId, Required: true, IsSafeToDisplay: true, Description: "Client Id"},
			{Name: AuthUri, Required: true, IsSafeToDisplay: true, Description: "OAuth2 authentatication IRU"},
			{Name: TokenUri, Required: true, IsSafeToDisplay: true, Description: "OAuth2 token URI"},
			{Name: AuthX509Url, Required: true, IsSafeToDisplay: true, Description: "OAuth2 provider ceritficate URL"},
			{Name: ClientX509Url, Required: true, IsSafeToDisplay: true, Description: "OAuth2 client ceritficate URL"},
		},
	},
	Kubernetes: {
		Fields: []FieldMeta{
			{Name: K8SConfig, Required: true},
		},
	},
	Vsphere: {
		Fields: []FieldMeta{
			{Name: VsphereURL, Required: true, IsSafeToDisplay: true, Description: "The URL endpoint of the vSphere instance to use (don't include auth info)"},
			{Name: VsphereUser, Required: true, IsSafeToDisplay: true, Description: "Username to use for vSphere authentication"},
			{Name: VspherePassword, Required: true, Description: "Password to use for vSphere authentication"},
			{Name: VsphereFingerprint, Required: true, IsSafeToDisplay: true, Description: "Fingerprint of the server certificate of vCenter"},
			{Name: VsphereDatacenter, Required: true, IsSafeToDisplay: true, Description: "Datacenter to use to store persistent volumes"},
			{Name: VsphereDatastore, Required: true, IsSafeToDisplay: true, Description: "Datastore that is in the given datacenter, and is available on all nodes"},
			{Name: VsphereResourcePool, Required: true, IsSafeToDisplay: true, Description: "Resource pool to create  VMs"},
			{Name: VsphereFolder, Required: true, IsSafeToDisplay: true, Description: "The name of the folder (aka blue folder) to create VMs"},
			{Name: VsphereDefaultNodeTemplate, Required: true, IsSafeToDisplay: true, Description: "The name of the default template name for VMs"},
		},
	},
	SSHSecretType: {
		Fields: []FieldMeta{
			{Name: User, Required: true, IsSafeToDisplay: true},
			{Name: Identifier, Required: true, IsSafeToDisplay: true},
			{Name: PublicKeyData, Required: true, IsSafeToDisplay: true},
			{Name: PublicKeyFingerprint, Required: true, IsSafeToDisplay: true},
			{Name: PrivateKeyData, Required: true},
		},
	},
	TLSSecretType: {
		Fields: []FieldMeta{
			{Name: TLSHosts, Required: true, IsSafeToDisplay: true},
			{Name: TLSValidity, Required: false, IsSafeToDisplay: true},
			{Name: CACert, Required: false},
			{Name: CAKey, Required: false},
			{Name: ServerKey, Required: false},
			{Name: ServerCert, Required: false},
			{Name: ClientKey, Required: false},
			{Name: ClientCert, Required: false},
			{Name: PeerKey, Required: false},
			{Name: PeerCert, Required: false},
		},
	},
	PKESecretType: {
		Fields: []FieldMeta{
			{Name: CACert, Required: false},
			{Name: CAKey, Required: false},

			{Name: KubernetesCACert, Required: false},
			{Name: KubernetesCAKey, Required: false},

			{Name: EtcdCACert, Required: false},
			{Name: EtcdCAKey, Required: false},

			{Name: FrontProxyCACert, Required: false},
			{Name: FrontProxyCAKey, Required: false},

			{Name: SAPub, Required: false},
			{Name: SAKey, Required: false},
		},
	},
	GenericSecret: {
		Fields: []FieldMeta{},
	},
	FnSecretType: {
		Fields: []FieldMeta{
			{Name: MasterToken, Required: true},
		},
	},
	PasswordSecretType: {
		Fields: []FieldMeta{
			{Name: Username, Required: true, IsSafeToDisplay: true, Description: "Your username"},
			{Name: Password, Required: false, Description: "Your password"},
		},
	},
	HtpasswdSecretType: {
		Fields: []FieldMeta{
			{Name: Username, Required: true, IsSafeToDisplay: true, Opaque: true, Description: "Your username"},
			{Name: Password, Required: false, Opaque: true, Description: "Your password"},
			{Name: HtpasswdFile, Required: false},
		},
	},
	CloudFlareSecretType: {
		Fields: []FieldMeta{
			{Name: CfApiKey, Required: true, Opaque: true, Description: "Your API key"},
			{Name: CfApiEmail, Required: true, IsSafeToDisplay: true, Opaque: true, Description: "Your API E-mail"},
		},
	},
	DigitalOceanSecretType: {
		Fields: []FieldMeta{
			{Name: DoToken, Required: true, Opaque: true, Description: "Your API Token"},
		},
	},
	VaultSecretType: {
		Fields: []FieldMeta{
			{Name: VaultToken, Required: true, Opaque: true, Description: "Token for Vault"},
		},
	},
	SlackSecretType: {
		Fields: []FieldMeta{
			{Name: SlackApiUrl, Required: true, IsSafeToDisplay: true, Opaque: true, Description: "Slack URL to send alerts to"},
		},
	},
	PagerDutySecretType: {
		Fields: []FieldMeta{
			{Name: PagerDutyIntegrationKey, Required: true, Opaque: true, Description: "The PagerDuty integration key"},
		},
	},
}

DefaultRules key matching for types nolint: gochecknoglobals

Functions

This section is empty.

Types

type FieldMeta

type FieldMeta struct {
	Name            string `json:"name"`
	Required        bool   `json:"required"`
	Opaque          bool   `json:"opaque,omitempty"`
	Description     string `json:"description,omitempty"`
	IsSafeToDisplay bool   `json:"isSafeToDisplay,omitempty"`
}

FieldMeta describes how a secret field should be validated

type Meta

type Meta struct {
	Fields []FieldMeta `json:"fields"`
}

Meta describes how a secret is built up and how it should be sourced

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL