/aws-iam-neo4j

Load AWS IAM entitlements into Neo4J

Primary LanguageShell

aws-iam-neo4j

Export IAM Settings of you accout

Run the following command to extract all your AWS IAM settings:

aws iam get-account-authorization-details > account_auth.json

Enable JSON import on neo4j

Enabled on the configuration of the database

apoc.import.file.enabled=true

Graph Schema

AWS IAM Schema

Relevant Cypher Queries

Show me a specific Policy and all related Relationships

MATCH (p:IAM_Policy)-[]->(n)
WHERE p.name = '<PolicyName>'
RETURN n,p 

Show me all Users

MATCH (u:IAM_User) RETURN u

Show me all Users and their Groups

MATCH (u:IAM_User)-[]->(g:IAM_Group) RETURN u,g

Show me all Groups with at least one User

MATCH (u:IAM_User)-[:MEMBER_OF]->(g:IAM_Group) 
WITH count(u) as n,u,g
WHERE n > 0
RETURN u,g

Show me all Roles

MATCH (r:IAM_Role) RETURN r

Show me all Roles with at least one Policy attached

MATCH (r:IAM_Role)-[]->(p:IAM_Policy) 
WITH count(p) as n, r, p
WHERE n > 0 
RETURN r,p

Show me the Policies, its Resources and Actions, and Users with Access

MATCH (r:IAM_Policy_Resource)<-[:HAS_RESOURCE]-(p:IAM_Policy)<-[:HAS_POLICY]-(u:IAM_User)
MATCH (a:IAM_Policy_Action)<-[:HAS_ACTION]-(p:IAM_Policy)
RETURN r,p,u,a