Team Access
Group Access
- Burnham Team, only having access to resources in their dedicated namespace along with a demonstration of how we can use Kubernative native construct to ensure that only people used in team-burnham namespace can access those resources. This is also known as soft multi-tenancy you are using Kubernetes constructs like namespaces, quotas, and network policies to prevent applications from being accessed. implementations in different namespaces communicate with each other.
kubectl describe role -n team-burnham
data:image/s3,"s3://crabby-images/bbf83/bbf837fe5a485233179861283959624915a93ee1" alt="Deployment Pipeline"
You can see that Team Burnham can only get and list a set of application-focused Kubernetes resources (pods, daemonsets, deployments, replicasets, statefulsets, and jobs). You’ll notice that they don’t have permission to create or delete resources in their respective namespaces.
- Retrieve the created role for Team burnham by running the following command:
aws cloudformation describe-stacks --stack-name dev-dev-blueprint | jq -r '.Stacks[0].Outputs[] | select(.OutputKey|match("burnhamteamrole"))| .OutputValue'
data:image/s3,"s3://crabby-images/6fd2d/6fd2dc87c3224bf238530734f06ccf50d3b004b7" alt="Deployment Pipeline"
- Create credentials for application
aws iam create-login-profile --user-name application --password Ekscdkworkshop123!
data:image/s3,"s3://crabby-images/d70aa/d70aa793079dca5981a99d57d60703882f7afcfc" alt="Deployment Pipeline"
Go to AWS
- Perform login with IAM user
- Enter your Account ID
- Select Next
data:image/s3,"s3://crabby-images/af782/af782f77be2e3e858c048ace0ba0fd11687c81eb" alt="Deployment Pipeline"
Next,
- Enter IAM user name as application
- Enter password just created
- Select Sign in
data:image/s3,"s3://crabby-images/0260c/0260c27d6b60e8c7fab59e63c71677f98e000615" alt="Deployment Pipeline"
- Complete the login
data:image/s3,"s3://crabby-images/8573f/8573fda42b5e473e9fc0f9dff89fd295f94df0aa" alt="Deployment Pipeline"
In the AWS interface
data:image/s3,"s3://crabby-images/d32db/d32db2a825b7073d34ce72c837eb96b8fb4fac82" alt="Deployment Pipeline"
In the Switch Role interface
- Account, enter your Account ID
- Then enter Role
- Select Switch Role
data:image/s3,"s3://crabby-images/94452/944521d58cfdd7af2c01b9ee3f963bb7807964b2" alt="Deployment Pipeline"
- Complete Switch Role
data:image/s3,"s3://crabby-images/9a8cf/9a8cf71874d93031e5a446f4c82e471a36ee943e" alt="Deployment Pipeline"
- Access to EKS
data:image/s3,"s3://crabby-images/e2ed0/e2ed0567d9e23d202508ebeea4dee9e1d5b2ae60" alt="Deployment Pipeline"
- Here you will see an error message stating that the Team Burnham user is NOT allowed to list deployments in all namespaces.
data:image/s3,"s3://crabby-images/3e7f2/3e7f265f7650d7945b4dd09d36b779c378c76834" alt="Deployment Pipeline"
data:image/s3,"s3://crabby-images/1e620/1e620aa2c0ebb71d542d52ce9563b06f5ff3a845" alt="Deployment Pipeline"
- When you select team-burnham in namespace, you will see the forbidden message disappear. This means that you are currently showing Team Burnham workloads (no workloads since any workloads have not been deployed).