10 IAM best practises
Identity and Credential Management
- Create Individual Users
- Configure a credential policy
- Rotate the credentials Regularly
- Enable MFA for privileged users (software or hardware)
- Manage permissions by group
- Grant least privilege
- Use IAM roles to share access; (benefit, no password share and no need to long-term store credentials)
- For example, PROD env account trust Dev env account; and then config a role to have access to database; Dev account then assign certain user to assume the role to manage the database.;
- Use IAM roles for EC2 instance.(launch the EC2 with role)
- Use CloudTrail to get logs of API calls
- Reduce or remove the use of root credential
- fine grained access control by resource tags
Account management
Reference
Overview
The policy language,
- Specification: define access policies
- Enforcement: evaluating policies
Policy Specification
Speicification: PARC Model
- AWS Policy using PARC model,
- P, Principal
- can be aws user, group or role, service, or federated user
- https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_principal.html
 
- A, Action
- thousands of actions
- Understand difference between NotAction and Deny. (Important).
 
- R, Resource
- arn representing aws services
 
- C, Condition
- multiple conditions will by default using OR
 
Policy Variables
- Policy version is mandatory, if not include, all variables will be treated as string
Policy Enforcement
- Request raised, AWS will retrive all policies associated with user and resource
- Filter retrieved policy using action and conditions
- Evaluate all Deny policies firstly
- Evaluate all Allow policies, if find true statement then Allow, if not then Deny.
Demo1, limit user access to his own home folder
make use of “limited” IAM administrator
Demo1, A user which can create user but only attach certain list of policies
- Apply policy to access to IAM
- give user list user access ; give user full user access to self
 
- Apply policy to create user and attach policy ( use condition to limit the list of policies)
Demo2, Demo Grant Conditional Cross-Account Access
- Define a policy in PROD account represent what kind of access and attach the policy to a role
- Define another policy in PROD account to define which principal can consume the role
- Define a policy in DEV account to certain user to consume the role
- user can switch (like gmail switch user)
Improvements
EC2 fine grained policies
- resource represent ec2 resource based on resource arn till the instance id
- use tag in conditions
Demo3, limit user from starting/stopping/terminating instance unless he owns that instance
- EC2 will have owner tag
- Policy grants user access to EC2 console
- Policy limit user access based on owner tag
Demo4, Limit user from starting expensive instances
- Make use of “NotAction” and “NotResource” to make sure we don’t miss out necessary access to launch a instance
- Define allow to certain action and certain resource and using condition to limit certain types
Improvement: make use of IfExists
| 1 | { | 
Policy simulator
- Test your policy
Decode authorization message (need access)
- use cli to decode
- Json Lint
