Users
Core functionality of Loft is giving other people self-service access to Kubernetes clusters. Everyone who should get access to a Kubernetes cluster, must be an authenticated user in Loft.
Working with Users
Create User (manual)
Loft lets you connect a variety of SSO providers for authentication but you can also manually create users who can sign in via username and password:
Create a User
- Go to the Users view using the main menu on the left
- Click on the button
- Use the field Display Name to enter the Username for your user
- Click on the button at the very bottom
- Close the popup using the button
Impersonate User
Loft allows admins with appropriate RBAC permissions to impersonate users.
Impersonate User
- In the Users view, hover over the row with the User who you want to impersonate
- While hovering over the row, you will see buttons appear on the right in the Actions column
- Click on the button to Impersonate the user
- In the popup, click on the button to confirm that you want to start impersonation
- Whenver you want to switch back to your regular user, click the button on the right-hand side of the impersonation banner at the top of the page
To use Loft CLI as the impersonated user, you can run the following command while impersonation is active:
loft login localhost:9898 --insecure # or use your loft.domain.tld instead of localhost, and ideally with a valid SSL cert and without the --insecure flag
You can verify the login and print your user information via:
loft login
Configuration
Metadata
Display Name
data:image/s3,"s3://crabby-images/13b31/13b31d4c482543c83d541cb6c5942f20d51ee4c6" alt=""
JSONPath in User CRD:
spec.displayName (type: string)
Kubernetes Name
data:image/s3,"s3://crabby-images/f3cc5/f3cc5cb7d1fcab60650a407ee4a26bd1ea8b5d58" alt=""
JSONPath in User CRD:
metadata.name (type: string)
Labels
data:image/s3,"s3://crabby-images/e5a21/e5a21b670d974b266f354e3825e4bae2119261b5" alt=""
JSONPath in User CRD:
metadata.labels (type: map[string]string)
Annotations
data:image/s3,"s3://crabby-images/992ab/992abd7002f1d649bf5d9c63867f310479687e8c" alt=""
JSONPath in User CRD:
metadata.annotations (type: map[string]string)
User Information
Username
data:image/s3,"s3://crabby-images/b5568/b5568731d7c94ed298157366ba219f9a6b27aad4" alt=""
JSONPath in User CRD:
spec.username (type: string)
Email
data:image/s3,"s3://crabby-images/33fb3/33fb33b231d92b85c1e56c6113df2a9831782e11" alt=""
JSONPath in User CRD:
spec.email (type: string)
Password
data:image/s3,"s3://crabby-images/c9fd0/c9fd00481db2b352e7d307020aa2c10334f27519" alt=""
JSONPath in User CRD:
spec.passwordRef (type: SecretRef)
Team Memberships
data:image/s3,"s3://crabby-images/01aea/01aea9579480e230fc66ba61cabc8ba5d4e51d3a" alt=""
JSONPath in Team CRD:
$team.spec.users (type: string[])
Advanced Options
Kubernetes Groups
data:image/s3,"s3://crabby-images/e2d1f/e2d1fe9faa620d9468f00936f015e0c8708cc497" alt=""
JSONPath in User CRD:
spec.groups (type: string[])
Cluster Roles
data:image/s3,"s3://crabby-images/a888e/a888ef6743fe72f4f02d794e2d0667373dd57482" alt=""
JSONPath in User CRD:
spec.clusterRoles (type: ClusterRoleRef[])
Image Pull Secrets
data:image/s3,"s3://crabby-images/fa47e/fa47e4fcca8824debbd97bcbf9a1ad945da1e55b" alt=""
JSONPath in User CRD:
spec.imagePullSecrets (type: SecretRef[])
Access To User
data:image/s3,"s3://crabby-images/e61a1/e61a1cf094ec08d92481dc813e7fb0018053137c" alt=""
JSONPath in User CRD:
spec.access (type: Access[])