You are looking at the documentation of a prior release. To read the documentation of the latest release, please
visit here.
New to KubeVault? Please start here.
ElasticsearchRole
What is ElasticsearchRole
A ElasticsearchRole is a Kubernetes CustomResourceDefinition (CRD) which allows a user to create an Elasticsearch database secret engine role in a Kubernetes native way.
When a ElasticsearchRole is created, the KubeVault operator creates a Vault role according to the specification.
If the user deletes the ElasticsearchRole CRD, then the respective role will also be deleted from Vault.
ElasticsearchRole CRD Specification
Like any official Kubernetes resource, a ElasticsearchRole object has TypeMeta, ObjectMeta, Spec and Status sections.
A sample ElasticsearchRole object is shown below:
apiVersion: engine.kubevault.com/v1alpha1
kind: ElasticsearchRole
metadata:
name: es-role
namespace: demo
spec:
secretEngineRef:
name: es-secret-engine
creationStatements:
- "statement-0"
- "statement-1"
status:
observedGeneration: 1
phase: Success
Note: To resolve the naming conflict, name of the role in Vault will follow this format:
k8s.{clusterName}.{metadata.namespace}.{metadata.name}
Here, we are going to describe the various sections of the ElasticsearchRole crd.
ElasticsearchRole Spec
ElasticsearchRole spec contains information that necessary for creating a database role.
spec:
secretEngineRef:
name: <secret-engine-name>
path: <secret-engine-path>
defaultTTL: <default-ttl>
maxTTL: <max-ttl>
creationStatements:
- "statement-0"
- "statement-1"
revocationStatements:
- "statement-0"
ElasticsearchRole spec has the following fields:
spec.secretEngineRef
spec.secretEngineRef is a required field that specifies the name of a SecretEngine.
spec:
secretEngineRef:
name: vault-app
spec.creationStatements
spec.creationStatements is a required field that specifies a list of database statements executed to create and configure a user.
See in here for Vault documentation.
spec:
creationStatements:
- "{"elasticsearch_roles": ["superuser"]}"
spec.defaultTTL
spec.defaultTTL is an optional field that specifies the TTL for the leases associated with this role. Accepts time suffixed strings (“1h”) or an integer number of seconds.
Defaults to system/engine default TTL time.
spec:
defaultTTL: "1h"
spec.maxTTL
spec.maxTTL is an optional field that specifies the maximum TTL for the leases associated with this role. Accepts time suffixed strings (“1h”) or an integer number of seconds.
Defaults to system/engine default TTL time.
spec:
maxTTL: "1h"
ElasticsearchRole Status
status shows the status of the ElasticsearchRole. It is managed by the KubeVault operator. It contains the following fields:
observedGeneration: Specifies the most recent generation observed for this resource. It corresponds to the resource’s generation, which is updated on mutation by the API Server.phase: Indicates whether the role successfully applied to Vault or not.conditions: Represent observations of a ElasticsearchRole.










