vCluster Platform Configuration
The vCluster Platform config allows you to modify vCluster Platform's behaviour and enable or disable certain features, such as SSO login, custom branding, or auditing.
Changing vCluster Platform Config
vCluster Platform config can be applied directly via helm values or through the vCluster Platform UI in Admin
> Config
. Using helm values allows you to declaratively deploy vCluster Platform.
When using helm you can apply the vCluster Platform config via a vcluster.yaml
file. This also makes it possible to deploy vCluster Platform through GitOps solutions such as ArgoCD. An example vCluster Platform vcluster.yaml
could look like this:
config:
loftHost: my-vcluster-host.com
audit:
enabled: true
auth:
github:
clientId: $CLIENT_ID
clientSecret: $CLIENT_SECRET
redirectURI: https://my-vcluster-host.com/auth/github/callback
For a complete overview what helm values are possible, please take a look at the Loft github repository directly.
Changing the Loft Host variable
After setting up the platform and TLS certificates and configuring the ingress to use a custom domain, one should change the loftHost
variable shown above.
Initially, that value will be set to the URL of either the Loft Router domain or no domain in the case of air-gapped setups.
This value should be equal to the hostname specified in the ingress resource for accessing the platform.
This value of the loftHost
variable should only be the hostname that vCluster Platform Platform is reachable at and not contain protocols (such as HTTP) or subpaths.
After changing the loftHost
, all currently connected clusters must be redeployed by running the same connection commands in the corresponding Kubernetes context.
See the instructions on connecting Clusters for more guidance.
Clusters will also have to be reconnected if the additionalCA
or insecureSkipVerify
values are changed after the initial setup.
Sensitive Information in the vCluster Platform Config
Some fields within the vCluster Platform config allow placeholders for environment variables, such as the clientId
and clientSecret
fields. This makes it possible to not expose the sensitive information directly inside the vCluster Platform values and instead mount this information into vCluster Platform through an external secret.
To load the github clientId and clientSecret through a Kubernetes secret my-secret
, use the following configuration:
envValueFrom:
CLIENT_ID:
secretKeyRef:
name: my-secret
key: client_id
CLIENT_SECRET:
secretKeyRef:
name: my-secret
key: client_secret
config:
auth:
github:
clientId: $CLIENT_ID
clientSecret: $CLIENT_SECRET
redirectURI: https://my-vcluster-pro-host.com/auth/github/callback
Then use helm to apply this configuration:
helm upgrade loft vcluster-control-plane --install \
--repo https://charts.vcluster-pro.sh/ \
--version $VERSION
--namespace vcluster-pro \
--create-namespace \
--values values.yaml
Make sure to replace the $VERSION in the above statement with the vCluster Platform version you are using
Custom HTTP Headers
vCluster Platform allows you to add custom HTTP headers to all requests that are sent to the vCluster Platform API. This can be useful if you want to add custom headers to all requests, such as X-Frame-Options
or X-XSS-Protection
.
To add custom HTTP headers, use the following configuration:
config:
auth:
customHttpHeaders:
X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
Config reference
auth
required object pro
Authentication holds the information for authentication
auth
required object prooidc
required object pro
OIDC holds oidc authentication configuration
oidc
required object proissuerUrl
required string pro
IssuerURL is the URL the provider signs ID Tokens as. This will be the "iss"
field of all tokens produced by the provider and is used for configuration
discovery.
The URL is usually the provider's URL without a path, for example
"https://accounts.google.com" or "https://login.salesforce.com".
The provider must implement configuration discovery.
See: https://openid.net/specs/openid-connect-discovery-1_0.html#ProviderConfig
issuerUrl
required string proclientId
required string pro
ClientID the JWT must be issued for, the "sub" field. This plugin only trusts a single
client to ensure the plugin can be used with public providers.
The plugin supports the "authorized party" OpenID Connect claim, which allows
specialized providers to issue tokens to a client for a different client.
See: https://openid.net/specs/openid-connect-core-1_0.html#IDToken
clientId
required string proclientSecret
required string pro
ClientSecret to issue tokens from the OIDC provider
clientSecret
required string proredirectURI
required string pro
loft redirect uri. E.g. https://loft.my.domain/auth/oidc/callback
redirectURI
required string propostLogoutRedirectURI
required string pro
Loft URI to be redirected to after successful logout by OIDC Provider
postLogoutRedirectURI
required string procaFile
required string pro
Path to a PEM encoded root certificate of the provider. Optional
caFile
required string proinsecureCa
required boolean false pro
Specify whether to communicate without validating SSL certificates
insecureCa
required boolean false propreferredUsername
required string pro
Configurable key which contains the preferred username claims
preferredUsername
required string proloftUsernameClaim
required string pro
LoftUsernameClaim is the JWT field to use as the user's username.
loftUsernameClaim
required string prousernameClaim
required string pro
UsernameClaim is the JWT field to use as the user's id.
usernameClaim
required string proemailClaim
required string pro
EmailClaim is the JWT field to use as the user's email.
emailClaim
required string prousernamePrefix
required string pro
UsernamePrefix, if specified, causes claims mapping to username to be prefix with
the provided value. A value "oidc:" would result in usernames like "oidc:john".
usernamePrefix
required string progroupsClaim
required string pro
GroupsClaim, if specified, causes the OIDCAuthenticator to try to populate the user's
groups with an ID Token field. If the GroupsClaim field is present in an ID Token the value
must be a string or list of strings.
groupsClaim
required string progroups
required string[] pro
If required groups is non empty, access is denied if the user is not part of at least one
of the specified groups.
groups
required string[] proscopes
required string[] pro
Scopes that should be sent to the server. If empty, defaults to "email" and "profile".
scopes
required string[] progetUserInfo
required boolean false pro
GetUserInfo, if specified, tells the OIDCAuthenticator to try to populate the user's
information from the UserInfo.
getUserInfo
required boolean false progroupsPrefix
required string pro
GroupsPrefix, if specified, causes claims mapping to group names to be prefixed with the
value. A value "oidc:" would result in groups like "oidc:engineering" and "oidc:marketing".
groupsPrefix
required string protype
required string pro
Type of the OIDC to show in the UI. Only for displaying purposes
type
required string proclusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string progroupClusterAccountTemplates
required object[] pro
A mapping between groups and cluster account templates. If the user has a certain group, the cluster
account template will be added during creation
groupClusterAccountTemplates
required object[] progroup
required string pro
Group is the name of the group that should be matched
group
required string proclusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string progithub
required object pro
Github holds github authentication configuration
github
required object proclientId
required string pro
ClientID holds the github client id
clientId
required string proclientSecret
required string pro
ClientID holds the github client secret
clientSecret
required string proredirectURI
required string pro
RedirectURI holds the redirect URI. Should be https://loft.domain.tld/auth/github/callback
redirectURI
required string proorgs
required object[] pro
Loft queries the following organizations for group information.
Group claims are formatted as "(org):(team)".
For example if a user is part of the "engineering" team of the "coreos"
org, the group claim would include "coreos:engineering".
If orgs are specified in the config then user MUST be a member of at least one of the specified orgs to
authenticate with loft.
orgs
required object[] proname
required string pro
Organization name in github (not slug, full name). Only users in this github
organization can authenticate.
name
required string proteams
required string[] pro
Names of teams in a github organization. A user will be able to
authenticate if they are members of at least one of these teams. Users
in the organization can authenticate if this field is omitted from the
config file.
teams
required string[] prohostName
required string pro
Required ONLY for GitHub Enterprise.
This is the Hostname of the GitHub Enterprise account listed on the
management console. Ensure this domain is routable on your network.
hostName
required string prorootCA
required string pro
ONLY for GitHub Enterprise. Optional field.
Used to support self-signed or untrusted CA root certificates.
rootCA
required string proclusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string progroupClusterAccountTemplates
required object[] pro
A mapping between groups and cluster account templates. If the user has a certain group, the cluster
account template will be added during creation
groupClusterAccountTemplates
required object[] progroup
required string pro
Group is the name of the group that should be matched
group
required string proclusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string progitlab
required object pro
Gitlab holds gitlab authentication configuration
gitlab
required object proclientId
required string pro
Gitlab client id
clientId
required string proclientSecret
required string pro
Gitlab client secret
clientSecret
required string proredirectURI
required string pro
Redirect URI
redirectURI
required string probaseURL
required string pro
BaseURL is optional, default = https://gitlab.com
baseURL
required string progroups
required string[] pro
Optional groups whitelist, communicated through the "groups" scope.
If groups
is omitted, all of the user's GitLab groups are returned.
If groups
is provided, this acts as a whitelist - only the user's GitLab groups that are in the configured groups
below will go into the groups claim. Conversely, if the user is not in any of the configured groups
, the user will not be authenticated.
groups
required string[] progroups
is omitted, all of the user's GitLab groups are returned.
If groups
is provided, this acts as a whitelist - only the user's GitLab groups that are in the configured groups
below will go into the groups claim. Conversely, if the user is not in any of the configured groups
, the user will not be authenticated.clusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string progroupClusterAccountTemplates
required object[] pro
A mapping between groups and cluster account templates. If the user has a certain group, the cluster
account template will be added during creation
groupClusterAccountTemplates
required object[] progroup
required string pro
Group is the name of the group that should be matched
group
required string proclusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string progoogle
required object pro
Google holds google authentication configuration
google
required object proclientId
required string pro
Google client id
clientId
required string proclientSecret
required string pro
Google client secret
clientSecret
required string proredirectURI
required string pro
loft redirect uri. E.g. https://loft.my.domain/auth/google/callback
redirectURI
required string proscopes
required string[] pro
defaults to "profile" and "email"
scopes
required string[] prohostedDomains
required string[] pro
Optional list of whitelisted domains
If this field is nonempty, only users from a listed domain will be allowed to log in
hostedDomains
required string[] progroups
required string[] pro
Optional list of whitelisted groups
If this field is nonempty, only users from a listed group will be allowed to log in
groups
required string[] proserviceAccountFilePath
required string pro
Optional path to service account json
If nonempty, and groups claim is made, will use authentication from file to
check groups with the admin directory api
serviceAccountFilePath
required string proadminEmail
required string pro
Required if ServiceAccountFilePath
The email of a GSuite super user which the service account will impersonate
when listing groups
adminEmail
required string proclusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string progroupClusterAccountTemplates
required object[] pro
A mapping between groups and cluster account templates. If the user has a certain group, the cluster
account template will be added during creation
groupClusterAccountTemplates
required object[] progroup
required string pro
Group is the name of the group that should be matched
group
required string proclusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string promicrosoft
required object pro
Microsoft holds microsoft authentication configuration
microsoft
required object proclientId
required string pro
Microsoft client id
clientId
required string proclientSecret
required string pro
Microsoft client secret
clientSecret
required string proredirectURI
required string pro
loft redirect uri. Usually https://loft.my.domain/auth/microsoft/callback
redirectURI
required string protenant
required string pro
tenant configuration parameter controls what kinds of accounts may be authenticated in loft.
By default, all types of Microsoft accounts (consumers and organizations) can authenticate in loft via Microsoft.
To change this, set the tenant parameter to one of the following:
common - both personal and business/school accounts can authenticate in loft via Microsoft (default)
consumers - only personal accounts can authenticate in loft
organizations - only business/school accounts can authenticate in loft
tenant uuid or tenant name - only accounts belonging to specific tenant identified by either tenant uuid or tenant name can authenticate in loft
tenant
required string progroups
required string[] pro
It is possible to require a user to be a member of a particular group in order to be successfully authenticated in loft.
groups
required string[] proonlySecurityGroups
required boolean false pro
configuration option restricts the list to include only security groups. By default all groups (security, Office 365, mailing lists) are included.
onlySecurityGroups
required boolean false prouseGroupsAsWhitelist
required boolean false pro
Restrict the groups claims to include only the user’s groups that are in the configured groups
useGroupsAsWhitelist
required boolean false proclusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string progroupClusterAccountTemplates
required object[] pro
A mapping between groups and cluster account templates. If the user has a certain group, the cluster
account template will be added during creation
groupClusterAccountTemplates
required object[] progroup
required string pro
Group is the name of the group that should be matched
group
required string proclusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string prosaml
required object pro
SAML holds saml authentication configuration
saml
required object proredirectURI
required string pro
If the response assertion status value contains a Destination element, it
must match this value exactly.
Usually looks like https://your-loft-domain/auth/saml/callback
redirectURI
required string prossoURL
required string pro
SSO URL used for POST value.
ssoURL
required string procaData
required string pro
CAData is a base64 encoded string that holds the ca certificate for validating the signature of the SAML response.
Either CAData, CA or InsecureSkipSignatureValidation needs to be defined.
caData
required string prousernameAttr
required string pro
Name of attribute in the returned assertions to map to username
usernameAttr
required string proemailAttr
required string pro
Name of attribute in the returned assertions to map to email
emailAttr
required string progroupsAttr
required string pro
Name of attribute in the returned assertions to map to groups
groupsAttr
required string proca
required string pro
CA to use when validating the signature of the SAML response.
ca
required string proinsecureSkipSignatureValidation
required boolean false pro
Ignore the ca cert
insecureSkipSignatureValidation
required boolean false proentityIssuer
required string pro
When provided Loft will include this as the Issuer value during AuthnRequest.
It will also override the redirectURI as the required audience when evaluating
AudienceRestriction elements in the response.
entityIssuer
required string prossoIssuer
required string pro
Issuer value expected in the SAML response. Optional.
ssoIssuer
required string progroupsDelim
required string pro
If GroupsDelim is supplied the connector assumes groups are returned as a
single string instead of multiple attribute values. This delimiter will be
used split the groups string.
groupsDelim
required string proallowedGroups
required string[] pro
List of groups to filter access based on membership
allowedGroups
required string[] profilterGroups
required boolean false pro
If used with allowed groups, only forwards the allowed groups and not all
groups specified.
filterGroups
required boolean false pronameIDPolicyFormat
required string pro
Requested format of the NameID. The NameID value is is mapped to the ID Token
'sub' claim.
This can be an abbreviated form of the full URI with just the last component. For
example, if this value is set to "emailAddress" the format will resolve to:
urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress
If no value is specified, this value defaults to:
urn:oasis:names:tc:SAML:2.0:nameid-format:persistent
nameIDPolicyFormat
required string prorancher
required object pro
Rancher holds the rancher authentication options
rancher
required object propassword
required object pro
Password holds password authentication relevant information
password
required object prodisabled
required boolean true pro
If true login via password is disabled
disabled
required boolean true proconnectors
required object[] pro
Connectors are optional additional connectors for Loft.
connectors
required object[] proid
required string pro
ID is the id that should show up in the url
id
required string prodisplayName
required string pro
DisplayName is the name that should show up in the ui
displayName
required string prooidc
required object pro
OIDC holds oidc authentication configuration
oidc
required object proissuerUrl
required string pro
IssuerURL is the URL the provider signs ID Tokens as. This will be the "iss"
field of all tokens produced by the provider and is used for configuration
discovery.
The URL is usually the provider's URL without a path, for example
"https://accounts.google.com" or "https://login.salesforce.com".
The provider must implement configuration discovery.
See: https://openid.net/specs/openid-connect-discovery-1_0.html#ProviderConfig
issuerUrl
required string proclientId
required string pro
ClientID the JWT must be issued for, the "sub" field. This plugin only trusts a single
client to ensure the plugin can be used with public providers.
The plugin supports the "authorized party" OpenID Connect claim, which allows
specialized providers to issue tokens to a client for a different client.
See: https://openid.net/specs/openid-connect-core-1_0.html#IDToken
clientId
required string proclientSecret
required string pro
ClientSecret to issue tokens from the OIDC provider
clientSecret
required string proredirectURI
required string pro
loft redirect uri. E.g. https://loft.my.domain/auth/oidc/callback
redirectURI
required string propostLogoutRedirectURI
required string pro
Loft URI to be redirected to after successful logout by OIDC Provider
postLogoutRedirectURI
required string procaFile
required string pro
Path to a PEM encoded root certificate of the provider. Optional
caFile
required string proinsecureCa
required boolean false pro
Specify whether to communicate without validating SSL certificates
insecureCa
required boolean false propreferredUsername
required string pro
Configurable key which contains the preferred username claims
preferredUsername
required string proloftUsernameClaim
required string pro
LoftUsernameClaim is the JWT field to use as the user's username.
loftUsernameClaim
required string prousernameClaim
required string pro
UsernameClaim is the JWT field to use as the user's id.
usernameClaim
required string proemailClaim
required string pro
EmailClaim is the JWT field to use as the user's email.
emailClaim
required string prousernamePrefix
required string pro
UsernamePrefix, if specified, causes claims mapping to username to be prefix with
the provided value. A value "oidc:" would result in usernames like "oidc:john".
usernamePrefix
required string progroupsClaim
required string pro
GroupsClaim, if specified, causes the OIDCAuthenticator to try to populate the user's
groups with an ID Token field. If the GroupsClaim field is present in an ID Token the value
must be a string or list of strings.
groupsClaim
required string progroups
required string[] pro
If required groups is non empty, access is denied if the user is not part of at least one
of the specified groups.
groups
required string[] proscopes
required string[] pro
Scopes that should be sent to the server. If empty, defaults to "email" and "profile".
scopes
required string[] progetUserInfo
required boolean false pro
GetUserInfo, if specified, tells the OIDCAuthenticator to try to populate the user's
information from the UserInfo.
getUserInfo
required boolean false progroupsPrefix
required string pro
GroupsPrefix, if specified, causes claims mapping to group names to be prefixed with the
value. A value "oidc:" would result in groups like "oidc:engineering" and "oidc:marketing".
groupsPrefix
required string protype
required string pro
Type of the OIDC to show in the UI. Only for displaying purposes
type
required string proclusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string progroupClusterAccountTemplates
required object[] pro
A mapping between groups and cluster account templates. If the user has a certain group, the cluster
account template will be added during creation
groupClusterAccountTemplates
required object[] progroup
required string pro
Group is the name of the group that should be matched
group
required string proclusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string progithub
required object pro
Github holds github authentication configuration
github
required object proclientId
required string pro
ClientID holds the github client id
clientId
required string proclientSecret
required string pro
ClientID holds the github client secret
clientSecret
required string proredirectURI
required string pro
RedirectURI holds the redirect URI. Should be https://loft.domain.tld/auth/github/callback
redirectURI
required string proorgs
required object[] pro
Loft queries the following organizations for group information.
Group claims are formatted as "(org):(team)".
For example if a user is part of the "engineering" team of the "coreos"
org, the group claim would include "coreos:engineering".
If orgs are specified in the config then user MUST be a member of at least one of the specified orgs to
authenticate with loft.
orgs
required object[] proname
required string pro
Organization name in github (not slug, full name). Only users in this github
organization can authenticate.
name
required string proteams
required string[] pro
Names of teams in a github organization. A user will be able to
authenticate if they are members of at least one of these teams. Users
in the organization can authenticate if this field is omitted from the
config file.
teams
required string[] prohostName
required string pro
Required ONLY for GitHub Enterprise.
This is the Hostname of the GitHub Enterprise account listed on the
management console. Ensure this domain is routable on your network.
hostName
required string prorootCA
required string pro
ONLY for GitHub Enterprise. Optional field.
Used to support self-signed or untrusted CA root certificates.
rootCA
required string proclusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string progroupClusterAccountTemplates
required object[] pro
A mapping between groups and cluster account templates. If the user has a certain group, the cluster
account template will be added during creation
groupClusterAccountTemplates
required object[] progroup
required string pro
Group is the name of the group that should be matched
group
required string proclusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string progitlab
required object pro
Gitlab holds gitlab authentication configuration
gitlab
required object proclientId
required string pro
Gitlab client id
clientId
required string proclientSecret
required string pro
Gitlab client secret
clientSecret
required string proredirectURI
required string pro
Redirect URI
redirectURI
required string probaseURL
required string pro
BaseURL is optional, default = https://gitlab.com
baseURL
required string progroups
required string[] pro
Optional groups whitelist, communicated through the "groups" scope.
If groups
is omitted, all of the user's GitLab groups are returned.
If groups
is provided, this acts as a whitelist - only the user's GitLab groups that are in the configured groups
below will go into the groups claim. Conversely, if the user is not in any of the configured groups
, the user will not be authenticated.
groups
required string[] progroups
is omitted, all of the user's GitLab groups are returned.
If groups
is provided, this acts as a whitelist - only the user's GitLab groups that are in the configured groups
below will go into the groups claim. Conversely, if the user is not in any of the configured groups
, the user will not be authenticated.clusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string progroupClusterAccountTemplates
required object[] pro
A mapping between groups and cluster account templates. If the user has a certain group, the cluster
account template will be added during creation
groupClusterAccountTemplates
required object[] progroup
required string pro
Group is the name of the group that should be matched
group
required string proclusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string progoogle
required object pro
Google holds google authentication configuration
google
required object proclientId
required string pro
Google client id
clientId
required string proclientSecret
required string pro
Google client secret
clientSecret
required string proredirectURI
required string pro
loft redirect uri. E.g. https://loft.my.domain/auth/google/callback
redirectURI
required string proscopes
required string[] pro
defaults to "profile" and "email"
scopes
required string[] prohostedDomains
required string[] pro
Optional list of whitelisted domains
If this field is nonempty, only users from a listed domain will be allowed to log in
hostedDomains
required string[] progroups
required string[] pro
Optional list of whitelisted groups
If this field is nonempty, only users from a listed group will be allowed to log in
groups
required string[] proserviceAccountFilePath
required string pro
Optional path to service account json
If nonempty, and groups claim is made, will use authentication from file to
check groups with the admin directory api
serviceAccountFilePath
required string proadminEmail
required string pro
Required if ServiceAccountFilePath
The email of a GSuite super user which the service account will impersonate
when listing groups
adminEmail
required string proclusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string progroupClusterAccountTemplates
required object[] pro
A mapping between groups and cluster account templates. If the user has a certain group, the cluster
account template will be added during creation
groupClusterAccountTemplates
required object[] progroup
required string pro
Group is the name of the group that should be matched
group
required string proclusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string promicrosoft
required object pro
Microsoft holds microsoft authentication configuration
microsoft
required object proclientId
required string pro
Microsoft client id
clientId
required string proclientSecret
required string pro
Microsoft client secret
clientSecret
required string proredirectURI
required string pro
loft redirect uri. Usually https://loft.my.domain/auth/microsoft/callback
redirectURI
required string protenant
required string pro
tenant configuration parameter controls what kinds of accounts may be authenticated in loft.
By default, all types of Microsoft accounts (consumers and organizations) can authenticate in loft via Microsoft.
To change this, set the tenant parameter to one of the following:
common - both personal and business/school accounts can authenticate in loft via Microsoft (default)
consumers - only personal accounts can authenticate in loft
organizations - only business/school accounts can authenticate in loft
tenant uuid or tenant name - only accounts belonging to specific tenant identified by either tenant uuid or tenant name can authenticate in loft
tenant
required string progroups
required string[] pro
It is possible to require a user to be a member of a particular group in order to be successfully authenticated in loft.
groups
required string[] proonlySecurityGroups
required boolean false pro
configuration option restricts the list to include only security groups. By default all groups (security, Office 365, mailing lists) are included.
onlySecurityGroups
required boolean false prouseGroupsAsWhitelist
required boolean false pro
Restrict the groups claims to include only the user’s groups that are in the configured groups
useGroupsAsWhitelist
required boolean false proclusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string progroupClusterAccountTemplates
required object[] pro
A mapping between groups and cluster account templates. If the user has a certain group, the cluster
account template will be added during creation
groupClusterAccountTemplates
required object[] progroup
required string pro
Group is the name of the group that should be matched
group
required string proclusterAccountTemplates
required object[] pro
Cluster Account Templates that will be applied for users logging in through this authentication
clusterAccountTemplates
required object[] proname
required string pro
Name of the cluster account template to apply
name
required string prosync
required boolean false pro
Sync defines if Loft should sync changes to the cluster account template
to the cluster accounts and create new accounts if new clusters match the templates.
sync
required boolean false proaccountName
required string pro
AccountName is the name of the account that should
be created. Defaults to the user or team kubernetes name.
accountName
required string prosaml
required object pro
SAML holds saml authentication configuration
saml
required object proredirectURI
required string pro
If the response assertion status value contains a Destination element, it
must match this value exactly.
Usually looks like https://your-loft-domain/auth/saml/callback
redirectURI
required string prossoURL
required string pro
SSO URL used for POST value.
ssoURL
required string procaData
required string pro
CAData is a base64 encoded string that holds the ca certificate for validating the signature of the SAML response.
Either CAData, CA or InsecureSkipSignatureValidation needs to be defined.
caData
required string prousernameAttr
required string pro
Name of attribute in the returned assertions to map to username
usernameAttr
required string proemailAttr
required string pro
Name of attribute in the returned assertions to map to email
emailAttr
required string progroupsAttr
required string pro
Name of attribute in the returned assertions to map to groups
groupsAttr
required string proca
required string pro
CA to use when validating the signature of the SAML response.
ca
required string proinsecureSkipSignatureValidation
required boolean false pro
Ignore the ca cert
insecureSkipSignatureValidation
required boolean false proentityIssuer
required string pro
When provided Loft will include this as the Issuer value during AuthnRequest.
It will also override the redirectURI as the required audience when evaluating
AudienceRestriction elements in the response.
entityIssuer
required string prossoIssuer
required string pro
Issuer value expected in the SAML response. Optional.
ssoIssuer
required string progroupsDelim
required string pro
If GroupsDelim is supplied the connector assumes groups are returned as a
single string instead of multiple attribute values. This delimiter will be
used split the groups string.
groupsDelim
required string proallowedGroups
required string[] pro
List of groups to filter access based on membership
allowedGroups
required string[] profilterGroups
required boolean false pro
If used with allowed groups, only forwards the allowed groups and not all
groups specified.
filterGroups
required boolean false pronameIDPolicyFormat
required string pro
Requested format of the NameID. The NameID value is is mapped to the ID Token
'sub' claim.
This can be an abbreviated form of the full URI with just the last component. For
example, if this value is set to "emailAddress" the format will resolve to:
urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress
If no value is specified, this value defaults to:
urn:oasis:names:tc:SAML:2.0:nameid-format:persistent
nameIDPolicyFormat
required string prodisableTeamCreation
required boolean false pro
Prevents from team creation for the new groups associated with the user at the time of logging in through sso,
Default behaviour is false, this means that teams will be created for new groups.
disableTeamCreation
required boolean false proaccessKeyMaxTTLSeconds
required integer pro
AccessKeyMaxTTLSeconds is the global maximum lifespan of an accesskey in seconds.
Leaving it 0 or unspecified will disable it.
Specifying 2592000 will mean all keys have a Time-To-Live of 30 days.
accessKeyMaxTTLSeconds
required integer prologinAccessKeyTTLSeconds
required integer pro
LoginAccessKeyTTLSeconds is the time in seconds an access key is kept
until it is deleted.
Leaving it unspecified will default to 20 days.
Setting it to zero will disable the ttl.
Specifying 2592000 will mean all keys have a default Time-To-Live of 30 days.
loginAccessKeyTTLSeconds
required integer procustomHttpHeaders
required object pro
CustomHttpHeaders are additional headers that should be set for the authentication endpoints
customHttpHeaders
required object prooidc
required object pro
OIDC holds oidc provider relevant information
oidc
required object proenabled
required boolean true pro
If true indicates that loft will act as an OIDC server
enabled
required boolean true prowildcardRedirect
required boolean true pro
If true indicates that loft will allow wildcard '*' in client redirectURIs
wildcardRedirect
required boolean true proclients
required object[] pro
The clients that are allowed to request loft tokens
clients
required object[] proname
required string pro
The client name
name
required string proclientId
required string pro
The client id of the client
clientId
required string proclientSecret
required string pro
The client secret of the client
clientSecret
required string proredirectURIs
required string[] pro
A registered set of redirect URIs. When redirecting from dex to the client, the URI
requested to redirect to MUST match one of these values, unless the client is "public".
redirectURIs
required string[] proapps
required object pro
Apps holds configuration around apps
apps
required object pronoDefault
required boolean false pro
If this option is true, loft will not try to parse the default apps
noDefault
required boolean false prorepositories
required object[] pro
These are additional repositories that are parsed by loft
repositories
required object[] proname
required string pro
Name is the name of the repository
name
required string prourl
required string pro
URL is the repository url
url
required string prousername
required string pro
Username of the repository
username
required string propassword
required string pro
Password of the repository
password
required string proinsecure
required boolean false pro
Insecure specifies if the chart should be retrieved without TLS
verification
insecure
required boolean false propredefinedApps
required object[] pro
Predefined apps that can be selected in the Spaces ) Space menu
predefinedApps
required object[] prochart
required string pro
Chart holds the repo/chart name of the predefined app
chart
required string proinitialVersion
required string pro
InitialVersion holds the initial version of this app.
This version will be selected automatically.
initialVersion
required string proinitialValues
required string pro
InitialValues holds the initial values for this app.
The values will be prefilled automatically. There are certain
placeholders that can be used within the values that are replaced
by the loft UI automatically.
initialValues
required string proclusters
required string[] pro
Holds the cluster names where to display this app
clusters
required string[] protitle
required string pro
Title is the name that should be displayed for the predefined app.
If empty the chart name is used.
title
required string proiconUrl
required string pro
IconURL specifies an url to the icon that should be displayed for this app.
If none is specified the icon from the chart metadata is used.
iconUrl
required string proreadmeUrl
required string pro
ReadmeURL specifies an url to the readme page of this predefined app. If empty
an url will be constructed to artifact hub.
readmeUrl
required string proaudit
required object pro
Audit holds audit configuration
audit
required object proenabled
required boolean false pro
If audit is enabled and incoming api requests will be logged based on the supplied policy.
enabled
required boolean false prodisableAgentSyncBack
required boolean false pro
If true, the agent will not send back any audit logs to Loft itself.
disableAgentSyncBack
required boolean false prolevel
required integer pro
Level is an optional log level for audit logs. Cannot be used together with policy
level
required integer propolicy
required object pro
The audit policy to use and log requests. By default loft will not log anything
policy
required object prorules
required object[] pro
Rules specify the audit Level a request should be recorded at.
A request may match multiple rules, in which case the FIRST matching rule is used.
The default audit level is None, but can be overridden by a catch-all rule at the end of the list.
PolicyRules are strictly ordered.
rules
required object[] prolevel
required string pro
The Level that requests matching this rule are recorded at.
level
required string prousers
required string[] pro
The users (by authenticated user name) this rule applies to.
An empty list implies every user.
users
required string[] prouserGroups
required string[] pro
The user groups this rule applies to. A user is considered matching
if it is a member of any of the UserGroups.
An empty list implies every user group.
userGroups
required string[] proverbs
required string[] pro
The verbs that match this rule.
An empty list implies every verb.
verbs
required string[] proresources
required object[] pro
Resources that this rule matches. An empty list implies all kinds in all API groups.
resources
required object[] progroup
required string pro
Group is the name of the API group that contains the resources.
The empty string represents the core API group.
group
required string proresources
required string[] pro
Resources is a list of resources this rule applies to.
For example:
'pods' matches pods.
'pods/log' matches the log subresource of pods.
'' matches all resources and their subresources.
'pods/' matches all subresources of pods.
'*/scale' matches all scale subresources.
If wildcard is present, the validation rule will ensure resources do not
overlap with each other.
An empty list implies all resources and subresources in this API groups apply.
resources
required string[] proresourceNames
required string[] pro
ResourceNames is a list of resource instance names that the policy matches.
Using this field requires Resources to be specified.
An empty list implies that every instance of the resource is matched.
resourceNames
required string[] pronamespaces
required string[] pro
Namespaces that this rule matches.
The empty string "" matches non-namespaced resources.
An empty list implies every namespace.
namespaces
required string[] prononResourceURLs
required string[] pro
NonResourceURLs is a set of URL paths that should be audited.
s are allowed, but only as the full, final step in the path.
Examples:
"/metrics" - Log requests for apiserver metrics
"/healthz" - Log all health checks
nonResourceURLs
required string[] proomitStages
required string[] pro
OmitStages is a list of stages for which no events are created. Note that this can also
be specified policy wide in which case the union of both are omitted.
An empty list means no restrictions will apply.
omitStages
required string[] prorequestTargets
required string[] pro
RequestTargets is a list of request targets for which events are created.
An empty list implies every request.
requestTargets
required string[] proclusters
required string[] pro
Clusters that this rule matches. Only applies to cluster requests.
If this is set, no events for non cluster requests will be created.
An empty list means no restrictions will apply.
clusters
required string[] proomitStages
required string[] pro
OmitStages is a list of stages for which no events are created. Note that this can also
be specified per rule in which case the union of both are omitted.
omitStages
required string[] prodataStoreEndpoint
required string pro
DataStoreEndpoint is an endpoint to store events in.
dataStoreEndpoint
required string prodataStoreTTL
required integer pro
DataStoreMaxAge is the maximum number of hours to retain old log events in the datastore
dataStoreTTL
required integer propath
required string pro
The path where to save the audit log files. This is required if audit is enabled. Backup log files will
be retained in the same directory.
path
required string promaxAge
required integer pro
MaxAge is the maximum number of days to retain old log files based on the
timestamp encoded in their filename. Note that a day is defined as 24
hours and may not exactly correspond to calendar days due to daylight
savings, leap seconds, etc. The default is not to remove old log files
based on age.
maxAge
required integer promaxBackups
required integer pro
MaxBackups is the maximum number of old log files to retain. The default
is to retain all old log files (though MaxAge may still cause them to get
deleted.)
maxBackups
required integer promaxSize
required integer pro
MaxSize is the maximum size in megabytes of the log file before it gets
rotated. It defaults to 100 megabytes.
maxSize
required integer procompress
required boolean false pro
Compress determines if the rotated log files should be compressed
using gzip. The default is not to perform compression.
compress
required boolean false proloftHost
required string pro
LoftHost holds the domain where the loft instance is hosted. This should not include https or http. E.g. loft.my-domain.com
loftHost
required string prodevPodSubDomain
required string pro
DevPodSubDomain holds a subdomain in the following form *.workspace.my-domain.com
devPodSubDomain
required string prouiSettings
required object pro
UISettings holds the settings for modifying the Loft user interface
uiSettings
required object proloftVersion
required string pro
LoftVersion holds the current loft version
loftVersion
required string prologoURL
required string pro
LogoURL is url pointing to the logo to use in the Loft UI. This path must be accessible for clients accessing
the Loft UI!
logoURL
required string prologoBackgroundColor
required string pro
LogoBackgroundColor is the color value (ex: "#12345") to use as the background color for the logo
logoBackgroundColor
required string prolegalTemplate
required string pro
LegalTemplate is a text (html) string containing the legal template to prompt to users when authenticating to Loft
legalTemplate
required string proprimaryColor
required string pro
PrimaryColor is the color value (ex: "#12345") to use as the primary color
primaryColor
required string prosidebarColor
required string pro
SidebarColor is the color value (ex: "#12345") to use for the sidebar
sidebarColor
required string proaccentColor
required string pro
AccentColor is the color value (ex: "#12345") to use for the accent
accentColor
required string procustomCss
required string[] pro
CustomCSS holds URLs with custom css files that should be included when loading the UI
customCss
required string[] procustomJavaScript
required string[] pro
CustomJavaScript holds URLs with custom js files that should be included when loading the UI
customJavaScript
required string[] pronavBarButtons
required object[] pro
NavBarButtons holds extra nav bar buttons
navBarButtons
required object[] proposition
required string pro
Position holds the position of the button, can be one of:
TopStart, TopEnd, BottomStart, BottomEnd. Defaults to BottomEnd
position
required string protext
required string pro
Text holds text for the button
text
required string prolink
required string pro
Link holds the link of the navbar button
link
required string proicon
required string pro
Icon holds the url of the icon to display
icon
required string provault
required object pro
VaultIntegration holds the vault integration configuration
vault
required object proenabled
required boolean false pro
Enabled indicates if the Vault Integration is enabled for the project -- this knob only
enables the syncing of secrets to or from Vault, but does not setup Kubernetes authentication
methods or Kubernetes secrets engines for vclusters.
enabled
required boolean false proaddress
required string pro
Address defines the address of the Vault instance to use for this project.
Will default to the VAULT_ADDR
environment variable if not provided.
address
required string proVAULT_ADDR
environment variable if not provided.skipTLSVerify
required boolean false pro
SkipTLSVerify defines if TLS verification should be skipped when connecting to Vault.
skipTLSVerify
required boolean false pronamespace
required string pro
Namespace defines the namespace to use when storing secrets in Vault.
namespace
required string proauth
required object pro
Auth defines the authentication method to use for this project.
auth
required object protoken
required string pro
Token defines the token to use for authentication.
token
required string protokenSecretRef
required object pro
TokenSecretRef defines the Kubernetes secret to use for token authentication.
Will be used if token
is not provided.
Secret data should contain the token
key.
tokenSecretRef
required object protoken
is not provided.token
key.name
required string pro
Name of the referent.
More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names
TODO: Add other useful fields. apiVersion, kind, uid?
name
required string prokey
required string pro
The key of the secret to select from. Must be a valid secret key.
key
required string prooptional
required boolean false pro
Specify whether the Secret or its key must be defined
optional
required boolean false prosyncInterval
required string pro
SyncInterval defines the interval at which to sync secrets from Vault.
Defaults to 1m.
See https://pkg.go.dev/time#ParseDuration for supported formats.
syncInterval
required string pro1m.
See https://pkg.go.dev/time#ParseDuration for supported formats.