Presets

With Presets you can specify default settings for new Cluster. Use Presets to reuse property settings across multiple providers.

Core Concept

As a Kubermatic Kubernetes Platform (KKP) administrator with superuser access, you can define Preset types in a Kubernetes Custom Resource Definition (CRD), allowing the assignment of new credential types to supported providers. This allows you to define a custom credential type that works in ways similar to existing credential types. For example, you could create a custom credential type that injects access keys, passwords or network settings into Cloud object.

Users can specify a credential list with unique names for the group of providers. This credential set can be used for every logged in user or can be filtered out by email domain.

The API allows using only credential names and never exposes the credential values. The proper credential name is used for credential injection.

If the Preset name is used together with standard credentials the preset is taken as a first.

Preset selection disables advanced settings. Advanced settings can be used only with standard credentials. There is no way to mix both kinds of settings.

Example

The following example shows an example for a Preset CRD:

apiVersion: kubermatic.k8s.io/v1
kind: Preset
metadata:
  name: example
spec:
  requiredEmailDomain: example.com
  anexia:
    token:
  aws:
    accessKeyId:
    secretAccessKey:
    vpcId:
    routeTableId:
    instanceProfileName:
    securityGroupID:
    roleARN:  
  alibaba:
    accessKeyId:
    accessKeySecret:  
  azure:
    tenantId:
    subscriptionId:
    clientId:
    clientSecret:
    resourceGroup:
    vnet:
    subnet:
    routeTable:
    securityGroup:  
  digitalocean:
    token:
  gcp:
    serviceAccount:
    network:
    subnetwork:  
  hetzner:
    token:
  openstack:
    username:
    password:
    tenant:  
    tenantID:
    domain: DEFAULT
    floatingIpPool: ext-net
    network:
    securityGroups:
    routerID:
    subnetID:  
  packet:
    apiKey:
    projectId:
    billingCycle:  
  vsphere:
    username:
    password:
    datastore:
    datastoreCluster:
    vmNetName:
  kubevirt:
    kubeconfig:

This file defines credentials for all listed providers. The accessible name for this preset is example. Only users with example.com domain can see this preset. Lack of the requiredEmailDomains field makes the preset available for everyone.