cartography 0.112.0__py3-none-any.whl → 0.114.0__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of cartography might be problematic. Click here for more details.

Files changed (82) hide show
  1. cartography/_version.py +2 -2
  2. cartography/cli.py +8 -0
  3. cartography/config.py +4 -0
  4. cartography/data/indexes.cypher +0 -31
  5. cartography/intel/aws/apigatewayv2.py +116 -0
  6. cartography/intel/aws/iam.py +741 -492
  7. cartography/intel/aws/organizations.py +7 -8
  8. cartography/intel/aws/permission_relationships.py +4 -16
  9. cartography/intel/aws/resources.py +2 -0
  10. cartography/intel/azure/__init__.py +16 -0
  11. cartography/intel/azure/app_service.py +105 -0
  12. cartography/intel/azure/functions.py +124 -0
  13. cartography/intel/entra/__init__.py +31 -0
  14. cartography/intel/entra/app_role_assignments.py +277 -0
  15. cartography/intel/entra/applications.py +4 -238
  16. cartography/intel/entra/federation/__init__.py +0 -0
  17. cartography/intel/entra/federation/aws_identity_center.py +77 -0
  18. cartography/intel/entra/service_principals.py +217 -0
  19. cartography/intel/gcp/__init__.py +136 -436
  20. cartography/intel/gcp/clients.py +65 -0
  21. cartography/intel/gcp/compute.py +18 -44
  22. cartography/intel/gcp/crm/__init__.py +0 -0
  23. cartography/intel/gcp/crm/folders.py +108 -0
  24. cartography/intel/gcp/crm/orgs.py +65 -0
  25. cartography/intel/gcp/crm/projects.py +109 -0
  26. cartography/intel/gcp/dns.py +82 -169
  27. cartography/intel/gcp/gke.py +72 -113
  28. cartography/intel/gcp/iam.py +66 -54
  29. cartography/intel/gcp/storage.py +75 -159
  30. cartography/intel/github/__init__.py +41 -0
  31. cartography/intel/github/commits.py +423 -0
  32. cartography/intel/github/repos.py +73 -39
  33. cartography/models/aws/apigatewayv2/__init__.py +0 -0
  34. cartography/models/aws/apigatewayv2/apigatewayv2.py +53 -0
  35. cartography/models/aws/iam/access_key.py +103 -0
  36. cartography/models/aws/iam/account_role.py +24 -0
  37. cartography/models/aws/iam/federated_principal.py +60 -0
  38. cartography/models/aws/iam/group.py +60 -0
  39. cartography/models/aws/iam/group_membership.py +26 -0
  40. cartography/models/aws/iam/inline_policy.py +78 -0
  41. cartography/models/aws/iam/managed_policy.py +51 -0
  42. cartography/models/aws/iam/policy_statement.py +57 -0
  43. cartography/models/aws/iam/role.py +83 -0
  44. cartography/models/aws/iam/root_principal.py +52 -0
  45. cartography/models/aws/iam/service_principal.py +30 -0
  46. cartography/models/aws/iam/sts_assumerole_allow.py +38 -0
  47. cartography/models/aws/iam/user.py +54 -0
  48. cartography/models/azure/__init__.py +0 -0
  49. cartography/models/azure/app_service.py +59 -0
  50. cartography/models/azure/function_app.py +59 -0
  51. cartography/models/entra/entra_user_to_aws_sso.py +41 -0
  52. cartography/models/entra/service_principal.py +104 -0
  53. cartography/models/gcp/compute/subnet.py +74 -0
  54. cartography/models/gcp/crm/__init__.py +0 -0
  55. cartography/models/gcp/crm/folders.py +98 -0
  56. cartography/models/gcp/crm/organizations.py +21 -0
  57. cartography/models/gcp/crm/projects.py +100 -0
  58. cartography/models/gcp/dns.py +109 -0
  59. cartography/models/gcp/gke.py +69 -0
  60. cartography/models/gcp/iam.py +3 -0
  61. cartography/models/gcp/storage/__init__.py +0 -0
  62. cartography/models/gcp/storage/bucket.py +119 -0
  63. cartography/models/github/commits.py +63 -0
  64. {cartography-0.112.0.dist-info → cartography-0.114.0.dist-info}/METADATA +7 -5
  65. {cartography-0.112.0.dist-info → cartography-0.114.0.dist-info}/RECORD +69 -39
  66. cartography/data/jobs/cleanup/aws_import_account_access_key_cleanup.json +0 -17
  67. cartography/data/jobs/cleanup/aws_import_groups_cleanup.json +0 -13
  68. cartography/data/jobs/cleanup/aws_import_principals_cleanup.json +0 -30
  69. cartography/data/jobs/cleanup/aws_import_roles_cleanup.json +0 -13
  70. cartography/data/jobs/cleanup/aws_import_users_cleanup.json +0 -8
  71. cartography/data/jobs/cleanup/gcp_compute_vpc_subnet_cleanup.json +0 -35
  72. cartography/data/jobs/cleanup/gcp_crm_folder_cleanup.json +0 -23
  73. cartography/data/jobs/cleanup/gcp_crm_organization_cleanup.json +0 -17
  74. cartography/data/jobs/cleanup/gcp_crm_project_cleanup.json +0 -23
  75. cartography/data/jobs/cleanup/gcp_dns_cleanup.json +0 -29
  76. cartography/data/jobs/cleanup/gcp_gke_cluster_cleanup.json +0 -17
  77. cartography/data/jobs/cleanup/gcp_storage_bucket_cleanup.json +0 -29
  78. cartography/intel/gcp/crm.py +0 -355
  79. {cartography-0.112.0.dist-info → cartography-0.114.0.dist-info}/WHEEL +0 -0
  80. {cartography-0.112.0.dist-info → cartography-0.114.0.dist-info}/entry_points.txt +0 -0
  81. {cartography-0.112.0.dist-info → cartography-0.114.0.dist-info}/licenses/LICENSE +0 -0
  82. {cartography-0.112.0.dist-info → cartography-0.114.0.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,103 @@
1
+ from dataclasses import dataclass
2
+
3
+ from cartography.models.core.common import PropertyRef
4
+ from cartography.models.core.nodes import CartographyNodeProperties
5
+ from cartography.models.core.nodes import CartographyNodeSchema
6
+ from cartography.models.core.relationships import CartographyRelProperties
7
+ from cartography.models.core.relationships import CartographyRelSchema
8
+ from cartography.models.core.relationships import LinkDirection
9
+ from cartography.models.core.relationships import make_target_node_matcher
10
+ from cartography.models.core.relationships import OtherRelationships
11
+ from cartography.models.core.relationships import TargetNodeMatcher
12
+
13
+
14
+ @dataclass(frozen=True)
15
+ class AccountAccessKeyNodeProperties(CartographyNodeProperties):
16
+ # Required unique identifier
17
+ id: PropertyRef = PropertyRef("accesskeyid")
18
+ accesskeyid: PropertyRef = PropertyRef("accesskeyid", extra_index=True)
19
+
20
+ # Automatic fields (set by cartography)
21
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
22
+
23
+ # Business fields from AWS IAM access keys
24
+ createdate: PropertyRef = PropertyRef("createdate")
25
+ status: PropertyRef = PropertyRef("status")
26
+ lastuseddate: PropertyRef = PropertyRef("lastuseddate")
27
+ lastusedservice: PropertyRef = PropertyRef("lastusedservice")
28
+ lastusedregion: PropertyRef = PropertyRef("lastusedregion")
29
+
30
+
31
+ @dataclass(frozen=True)
32
+ class AWSUserToAccountAccessKeyRelProperties(CartographyRelProperties):
33
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
34
+
35
+
36
+ @dataclass(frozen=True)
37
+ class AWSUserToAccountAccessKeyRel(CartographyRelSchema):
38
+ target_node_label: str = "AccountAccessKey"
39
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
40
+ {
41
+ "accesskeyid": PropertyRef("accesskeyid"),
42
+ }
43
+ )
44
+ direction: LinkDirection = LinkDirection.OUTWARD
45
+ rel_label: str = "AWS_ACCESS_KEY"
46
+ properties: AWSUserToAccountAccessKeyRelProperties = (
47
+ AWSUserToAccountAccessKeyRelProperties()
48
+ )
49
+
50
+
51
+ @dataclass(frozen=True)
52
+ class AccountAccessKeyToAWSUserRelProperties(CartographyRelProperties):
53
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
54
+
55
+
56
+ @dataclass(frozen=True)
57
+ class AccountAccessKeyToAWSUserRel(CartographyRelSchema):
58
+ target_node_label: str = "AWSUser"
59
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
60
+ {
61
+ "arn": PropertyRef("user_arn"),
62
+ }
63
+ )
64
+ direction: LinkDirection = LinkDirection.INWARD
65
+ rel_label: str = "AWS_ACCESS_KEY"
66
+ properties: AccountAccessKeyToAWSUserRelProperties = (
67
+ AccountAccessKeyToAWSUserRelProperties()
68
+ )
69
+
70
+
71
+ @dataclass(frozen=True)
72
+ class AccountAccessKeyToAWSAccountRelProperties(CartographyRelProperties):
73
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
74
+
75
+
76
+ @dataclass(frozen=True)
77
+ class AccountAccessKeyToAWSAccountRel(CartographyRelSchema):
78
+ target_node_label: str = "AWSAccount"
79
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
80
+ {
81
+ "id": PropertyRef("AWS_ID", set_in_kwargs=True),
82
+ }
83
+ )
84
+ direction: LinkDirection = LinkDirection.INWARD
85
+ rel_label: str = "RESOURCE"
86
+ properties: AccountAccessKeyToAWSAccountRelProperties = (
87
+ AccountAccessKeyToAWSAccountRelProperties()
88
+ )
89
+
90
+
91
+ @dataclass(frozen=True)
92
+ class AccountAccessKeySchema(CartographyNodeSchema):
93
+ label: str = "AccountAccessKey"
94
+ properties: AccountAccessKeyNodeProperties = AccountAccessKeyNodeProperties()
95
+ sub_resource_relationship: AccountAccessKeyToAWSAccountRel = (
96
+ AccountAccessKeyToAWSAccountRel()
97
+ )
98
+ other_relationships: OtherRelationships = OtherRelationships(
99
+ [
100
+ AccountAccessKeyToAWSUserRel(),
101
+ AccountAccessKeyToAWSAccountRel(),
102
+ ]
103
+ )
@@ -0,0 +1,24 @@
1
+ from dataclasses import dataclass
2
+
3
+ from cartography.models.core.common import PropertyRef
4
+ from cartography.models.core.nodes import CartographyNodeProperties
5
+ from cartography.models.core.nodes import CartographyNodeSchema
6
+
7
+
8
+ @dataclass(frozen=True)
9
+ class AWSAccountAWSRoleNodeProperties(CartographyNodeProperties):
10
+ # Required unique identifier
11
+ id: PropertyRef = PropertyRef("id")
12
+
13
+ # Automatic fields (set by cartography)
14
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
15
+
16
+
17
+ @dataclass(frozen=True)
18
+ class AWSAccountAWSRoleSchema(CartographyNodeSchema):
19
+ """
20
+ An AWSAccount that was discovered from a trusted principal in an IAM role.
21
+ """
22
+
23
+ label: str = "AWSAccount"
24
+ properties: AWSAccountAWSRoleNodeProperties = AWSAccountAWSRoleNodeProperties()
@@ -0,0 +1,60 @@
1
+ from dataclasses import dataclass
2
+
3
+ from cartography.models.core.common import PropertyRef
4
+ from cartography.models.core.nodes import CartographyNodeProperties
5
+ from cartography.models.core.nodes import CartographyNodeSchema
6
+ from cartography.models.core.nodes import ExtraNodeLabels
7
+ from cartography.models.core.relationships import CartographyRelProperties
8
+ from cartography.models.core.relationships import CartographyRelSchema
9
+ from cartography.models.core.relationships import LinkDirection
10
+ from cartography.models.core.relationships import make_target_node_matcher
11
+ from cartography.models.core.relationships import TargetNodeMatcher
12
+
13
+
14
+ @dataclass(frozen=True)
15
+ class AWSFederatedPrincipalNodeProperties(CartographyNodeProperties):
16
+ # Required unique identifier
17
+ id: PropertyRef = PropertyRef("arn")
18
+ arn: PropertyRef = PropertyRef("arn", extra_index=True)
19
+
20
+ # Automatic fields (set by cartography)
21
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
22
+
23
+ # Business fields from AWS IAM federated principals
24
+ type: PropertyRef = PropertyRef("type")
25
+
26
+
27
+ @dataclass(frozen=True)
28
+ class AWSFederatedPrincipalToAWSAccountRelProperties(CartographyRelProperties):
29
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
30
+
31
+
32
+ @dataclass(frozen=True)
33
+ class AWSFederatedPrincipalToAWSAccountRel(CartographyRelSchema):
34
+ target_node_label: str = "AWSAccount"
35
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
36
+ {
37
+ "id": PropertyRef("AWS_ID", set_in_kwargs=True),
38
+ }
39
+ )
40
+ direction: LinkDirection = LinkDirection.INWARD
41
+ rel_label: str = "RESOURCE"
42
+ properties: AWSFederatedPrincipalToAWSAccountRelProperties = (
43
+ AWSFederatedPrincipalToAWSAccountRelProperties()
44
+ )
45
+
46
+
47
+ @dataclass(frozen=True)
48
+ class AWSFederatedPrincipalSchema(CartographyNodeSchema):
49
+ """
50
+ E.g. "arn:aws:iam::123456789012:saml-provider/my-saml-provider".
51
+ """
52
+
53
+ label: str = "AWSFederatedPrincipal"
54
+ properties: AWSFederatedPrincipalNodeProperties = (
55
+ AWSFederatedPrincipalNodeProperties()
56
+ )
57
+ sub_resource_relationship: AWSFederatedPrincipalToAWSAccountRel = (
58
+ AWSFederatedPrincipalToAWSAccountRel()
59
+ )
60
+ extra_node_labels: ExtraNodeLabels = ExtraNodeLabels(["AWSPrincipal"])
@@ -0,0 +1,60 @@
1
+ from dataclasses import dataclass
2
+
3
+ from cartography.models.aws.iam.group_membership import AWSGroupToAWSUserRel
4
+ from cartography.models.core.common import PropertyRef
5
+ from cartography.models.core.nodes import CartographyNodeProperties
6
+ from cartography.models.core.nodes import CartographyNodeSchema
7
+ from cartography.models.core.nodes import ExtraNodeLabels
8
+ from cartography.models.core.relationships import CartographyRelProperties
9
+ from cartography.models.core.relationships import CartographyRelSchema
10
+ from cartography.models.core.relationships import LinkDirection
11
+ from cartography.models.core.relationships import make_target_node_matcher
12
+ from cartography.models.core.relationships import OtherRelationships
13
+ from cartography.models.core.relationships import TargetNodeMatcher
14
+
15
+
16
+ @dataclass(frozen=True)
17
+ class AWSGroupNodeProperties(CartographyNodeProperties):
18
+ # Required unique identifier
19
+ id: PropertyRef = PropertyRef("arn")
20
+ arn: PropertyRef = PropertyRef("arn", extra_index=True)
21
+
22
+ # Automatic fields (set by cartography)
23
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
24
+
25
+ # Business fields from AWS IAM groups
26
+ groupid: PropertyRef = PropertyRef("groupid")
27
+ name: PropertyRef = PropertyRef("name")
28
+ path: PropertyRef = PropertyRef("path")
29
+ createdate: PropertyRef = PropertyRef("createdate")
30
+
31
+
32
+ @dataclass(frozen=True)
33
+ class AWSGroupToAWSAccountRelProperties(CartographyRelProperties):
34
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
35
+
36
+
37
+ @dataclass(frozen=True)
38
+ class AWSGroupToAWSAccountRel(CartographyRelSchema):
39
+ target_node_label: str = "AWSAccount"
40
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
41
+ {
42
+ "id": PropertyRef("AWS_ID", set_in_kwargs=True),
43
+ }
44
+ )
45
+ direction: LinkDirection = LinkDirection.INWARD
46
+ rel_label: str = "RESOURCE"
47
+ properties: AWSGroupToAWSAccountRelProperties = AWSGroupToAWSAccountRelProperties()
48
+
49
+
50
+ @dataclass(frozen=True)
51
+ class AWSGroupSchema(CartographyNodeSchema):
52
+ label: str = "AWSGroup"
53
+ properties: AWSGroupNodeProperties = AWSGroupNodeProperties()
54
+ sub_resource_relationship: AWSGroupToAWSAccountRel = AWSGroupToAWSAccountRel()
55
+ other_relationships: OtherRelationships = OtherRelationships(
56
+ [
57
+ AWSGroupToAWSUserRel(),
58
+ ]
59
+ )
60
+ extra_node_labels: ExtraNodeLabels = ExtraNodeLabels(["AWSPrincipal"])
@@ -0,0 +1,26 @@
1
+ from dataclasses import dataclass
2
+
3
+ from cartography.models.core.common import PropertyRef
4
+ from cartography.models.core.relationships import CartographyRelProperties
5
+ from cartography.models.core.relationships import CartographyRelSchema
6
+ from cartography.models.core.relationships import LinkDirection
7
+ from cartography.models.core.relationships import make_target_node_matcher
8
+ from cartography.models.core.relationships import TargetNodeMatcher
9
+
10
+
11
+ @dataclass(frozen=True)
12
+ class AWSGroupToAWSUserRelProperties(CartographyRelProperties):
13
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
14
+
15
+
16
+ @dataclass(frozen=True)
17
+ class AWSGroupToAWSUserRel(CartographyRelSchema):
18
+ target_node_label: str = "AWSUser"
19
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
20
+ {
21
+ "arn": PropertyRef("user_arn"),
22
+ }
23
+ )
24
+ direction: LinkDirection = LinkDirection.OUTWARD
25
+ rel_label: str = "MEMBER_AWS_GROUP"
26
+ properties: AWSGroupToAWSUserRelProperties = AWSGroupToAWSUserRelProperties()
@@ -0,0 +1,78 @@
1
+ from dataclasses import dataclass
2
+
3
+ from cartography.models.core.common import PropertyRef
4
+ from cartography.models.core.nodes import CartographyNodeProperties
5
+ from cartography.models.core.nodes import CartographyNodeSchema
6
+ from cartography.models.core.nodes import ExtraNodeLabels
7
+ from cartography.models.core.relationships import CartographyRelProperties
8
+ from cartography.models.core.relationships import CartographyRelSchema
9
+ from cartography.models.core.relationships import LinkDirection
10
+ from cartography.models.core.relationships import make_target_node_matcher
11
+ from cartography.models.core.relationships import OtherRelationships
12
+ from cartography.models.core.relationships import TargetNodeMatcher
13
+
14
+
15
+ @dataclass(frozen=True)
16
+ class AWSInlinePolicyNodeProperties(CartographyNodeProperties):
17
+ id: PropertyRef = PropertyRef("id")
18
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
19
+ name: PropertyRef = PropertyRef("name")
20
+ type: PropertyRef = PropertyRef("type")
21
+ arn: PropertyRef = PropertyRef("arn", extra_index=True)
22
+
23
+
24
+ @dataclass(frozen=True)
25
+ class AWSInlinePolicyToAWSPrincipalRelProperties(CartographyRelProperties):
26
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
27
+
28
+
29
+ @dataclass(frozen=True)
30
+ class AWSInlinePolicyToAWSPrincipalRel(CartographyRelSchema):
31
+ target_node_label: str = "AWSPrincipal"
32
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
33
+ {
34
+ "arn": PropertyRef("principal_arns", one_to_many=True),
35
+ }
36
+ )
37
+ direction: LinkDirection = LinkDirection.INWARD
38
+ rel_label: str = "POLICY"
39
+ properties: AWSInlinePolicyToAWSPrincipalRelProperties = (
40
+ AWSInlinePolicyToAWSPrincipalRelProperties()
41
+ )
42
+
43
+
44
+ @dataclass(frozen=True)
45
+ class AWSInlinePolicyToAWSAccountRelProperties(CartographyRelProperties):
46
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
47
+
48
+
49
+ @dataclass(frozen=True)
50
+ class AWSInlinePolicyToAWSAccountRel(CartographyRelSchema):
51
+ target_node_label: str = "AWSAccount"
52
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
53
+ {
54
+ "id": PropertyRef("AWS_ID", set_in_kwargs=True),
55
+ }
56
+ )
57
+ direction: LinkDirection = LinkDirection.INWARD
58
+ rel_label: str = "RESOURCE"
59
+ properties: AWSInlinePolicyToAWSAccountRelProperties = (
60
+ AWSInlinePolicyToAWSAccountRelProperties()
61
+ )
62
+
63
+
64
+ @dataclass(frozen=True)
65
+ class AWSInlinePolicySchema(CartographyNodeSchema):
66
+ """
67
+ Inline policies are defined on the given principal and are therefore scoped to that principal's account.
68
+ """
69
+
70
+ label: str = "AWSInlinePolicy"
71
+ properties: AWSInlinePolicyNodeProperties = AWSInlinePolicyNodeProperties()
72
+ sub_resource_relationship: AWSInlinePolicyToAWSAccountRel = (
73
+ AWSInlinePolicyToAWSAccountRel()
74
+ )
75
+ other_relationships: OtherRelationships = OtherRelationships(
76
+ [AWSInlinePolicyToAWSPrincipalRel()]
77
+ )
78
+ extra_node_labels: ExtraNodeLabels = ExtraNodeLabels(["AWSPolicy"])
@@ -0,0 +1,51 @@
1
+ from dataclasses import dataclass
2
+
3
+ from cartography.models.core.common import PropertyRef
4
+ from cartography.models.core.nodes import CartographyNodeProperties
5
+ from cartography.models.core.nodes import CartographyNodeSchema
6
+ from cartography.models.core.nodes import ExtraNodeLabels
7
+ from cartography.models.core.relationships import CartographyRelProperties
8
+ from cartography.models.core.relationships import CartographyRelSchema
9
+ from cartography.models.core.relationships import LinkDirection
10
+ from cartography.models.core.relationships import make_target_node_matcher
11
+ from cartography.models.core.relationships import OtherRelationships
12
+ from cartography.models.core.relationships import TargetNodeMatcher
13
+
14
+
15
+ @dataclass(frozen=True)
16
+ class AWSManagedPolicyNodeProperties(CartographyNodeProperties):
17
+ id: PropertyRef = PropertyRef("id")
18
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
19
+ name: PropertyRef = PropertyRef("name")
20
+ type: PropertyRef = PropertyRef("type")
21
+ arn: PropertyRef = PropertyRef("arn", extra_index=True)
22
+
23
+
24
+ @dataclass(frozen=True)
25
+ class AWSManagedPolicyToAWSPrincipalRelProperties(CartographyRelProperties):
26
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
27
+
28
+
29
+ @dataclass(frozen=True)
30
+ class AWSManagedPolicyToAWSPrincipalRel(CartographyRelSchema):
31
+ target_node_label: str = "AWSPrincipal"
32
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
33
+ {
34
+ "arn": PropertyRef("principal_arns", one_to_many=True),
35
+ }
36
+ )
37
+ direction: LinkDirection = LinkDirection.INWARD
38
+ rel_label: str = "POLICY"
39
+ properties: AWSManagedPolicyToAWSPrincipalRelProperties = (
40
+ AWSManagedPolicyToAWSPrincipalRelProperties()
41
+ )
42
+
43
+
44
+ @dataclass(frozen=True)
45
+ class AWSManagedPolicySchema(CartographyNodeSchema):
46
+ label: str = "AWSManagedPolicy"
47
+ properties: AWSManagedPolicyNodeProperties = AWSManagedPolicyNodeProperties()
48
+ other_relationships: OtherRelationships = OtherRelationships(
49
+ [AWSManagedPolicyToAWSPrincipalRel()]
50
+ )
51
+ extra_node_labels: ExtraNodeLabels = ExtraNodeLabels(["AWSPolicy"])
@@ -0,0 +1,57 @@
1
+ from dataclasses import dataclass
2
+
3
+ from cartography.models.core.common import PropertyRef
4
+ from cartography.models.core.nodes import CartographyNodeProperties
5
+ from cartography.models.core.nodes import CartographyNodeSchema
6
+ from cartography.models.core.relationships import CartographyRelProperties
7
+ from cartography.models.core.relationships import CartographyRelSchema
8
+ from cartography.models.core.relationships import LinkDirection
9
+ from cartography.models.core.relationships import make_target_node_matcher
10
+ from cartography.models.core.relationships import TargetNodeMatcher
11
+
12
+
13
+ @dataclass(frozen=True)
14
+ class AWSPolicyStatementNodeProperties(CartographyNodeProperties):
15
+ # Required unique identifier
16
+ id: PropertyRef = PropertyRef("id")
17
+
18
+ # Automatic fields (set by cartography)
19
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
20
+
21
+ # Business fields from AWS IAM policy statements
22
+ effect: PropertyRef = PropertyRef("Effect")
23
+ action: PropertyRef = PropertyRef("Action")
24
+ notaction: PropertyRef = PropertyRef("NotAction")
25
+ resource: PropertyRef = PropertyRef("Resource")
26
+ notresource: PropertyRef = PropertyRef("NotResource")
27
+ condition: PropertyRef = PropertyRef("Condition")
28
+ sid: PropertyRef = PropertyRef("Sid")
29
+
30
+
31
+ @dataclass(frozen=True)
32
+ class AWSPolicyStatementToAWSPolicyRelProperties(CartographyRelProperties):
33
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
34
+
35
+
36
+ @dataclass(frozen=True)
37
+ class AWSPolicyStatementToAWSPolicyRel(CartographyRelSchema):
38
+ target_node_label: str = "AWSPolicy"
39
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
40
+ {
41
+ "id": PropertyRef("POLICY_ID", set_in_kwargs=True),
42
+ }
43
+ )
44
+ direction: LinkDirection = LinkDirection.INWARD
45
+ rel_label: str = "STATEMENT"
46
+ properties: AWSPolicyStatementToAWSPolicyRelProperties = (
47
+ AWSPolicyStatementToAWSPolicyRelProperties()
48
+ )
49
+
50
+
51
+ @dataclass(frozen=True)
52
+ class AWSPolicyStatementSchema(CartographyNodeSchema):
53
+ label: str = "AWSPolicyStatement"
54
+ properties: AWSPolicyStatementNodeProperties = AWSPolicyStatementNodeProperties()
55
+ sub_resource_relationship: AWSPolicyStatementToAWSPolicyRel = (
56
+ AWSPolicyStatementToAWSPolicyRel()
57
+ )
@@ -0,0 +1,83 @@
1
+ from dataclasses import dataclass
2
+
3
+ from cartography.models.core.common import PropertyRef
4
+ from cartography.models.core.nodes import CartographyNodeProperties
5
+ from cartography.models.core.nodes import CartographyNodeSchema
6
+ from cartography.models.core.nodes import ExtraNodeLabels
7
+ from cartography.models.core.relationships import CartographyRelProperties
8
+ from cartography.models.core.relationships import CartographyRelSchema
9
+ from cartography.models.core.relationships import LinkDirection
10
+ from cartography.models.core.relationships import make_target_node_matcher
11
+ from cartography.models.core.relationships import OtherRelationships
12
+ from cartography.models.core.relationships import TargetNodeMatcher
13
+
14
+
15
+ @dataclass(frozen=True)
16
+ class AWSRoleNodeProperties(CartographyNodeProperties):
17
+ # Required unique identifier
18
+ id: PropertyRef = PropertyRef("arn")
19
+ arn: PropertyRef = PropertyRef("arn", extra_index=True)
20
+
21
+ # Automatic fields (set by cartography)
22
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
23
+
24
+ # Business fields from AWS IAM roles
25
+ roleid: PropertyRef = PropertyRef("roleid")
26
+ name: PropertyRef = PropertyRef("name")
27
+ path: PropertyRef = PropertyRef("path")
28
+ createdate: PropertyRef = PropertyRef("createdate")
29
+
30
+
31
+ @dataclass(frozen=True)
32
+ class AWSRoleToAWSAccountRelProperties(CartographyRelProperties):
33
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
34
+
35
+
36
+ @dataclass(frozen=True)
37
+ class AWSRoleToAWSAccountRel(CartographyRelSchema):
38
+ target_node_label: str = "AWSAccount"
39
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
40
+ {
41
+ "id": PropertyRef("AWS_ID", set_in_kwargs=True),
42
+ }
43
+ )
44
+ direction: LinkDirection = LinkDirection.INWARD
45
+ rel_label: str = "RESOURCE"
46
+ properties: AWSRoleToAWSAccountRelProperties = AWSRoleToAWSAccountRelProperties()
47
+
48
+
49
+ @dataclass(frozen=True)
50
+ class AWSRoleToAWSPrincipalTrustRelProperties(CartographyRelProperties):
51
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
52
+
53
+
54
+ @dataclass(frozen=True)
55
+ class AWSRoleToAWSPrincipalTrustRel(CartographyRelSchema):
56
+ """
57
+ Trust relationship with principals of type "AWS".
58
+ """
59
+
60
+ target_node_label: str = "AWSPrincipal"
61
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
62
+ {
63
+ "arn": PropertyRef("trusted_aws_principals", one_to_many=True),
64
+ },
65
+ )
66
+ direction: LinkDirection = LinkDirection.OUTWARD
67
+ rel_label: str = "TRUSTS_AWS_PRINCIPAL"
68
+ properties: AWSRoleToAWSPrincipalTrustRelProperties = (
69
+ AWSRoleToAWSPrincipalTrustRelProperties()
70
+ )
71
+
72
+
73
+ @dataclass(frozen=True)
74
+ class AWSRoleSchema(CartographyNodeSchema):
75
+ label: str = "AWSRole"
76
+ properties: AWSRoleNodeProperties = AWSRoleNodeProperties()
77
+ sub_resource_relationship: AWSRoleToAWSAccountRel = AWSRoleToAWSAccountRel()
78
+ other_relationships: OtherRelationships = OtherRelationships(
79
+ [
80
+ AWSRoleToAWSPrincipalTrustRel(),
81
+ ]
82
+ )
83
+ extra_node_labels: ExtraNodeLabels = ExtraNodeLabels(["AWSPrincipal"])
@@ -0,0 +1,52 @@
1
+ from dataclasses import dataclass
2
+
3
+ from cartography.models.core.common import PropertyRef
4
+ from cartography.models.core.nodes import CartographyNodeProperties
5
+ from cartography.models.core.nodes import CartographyNodeSchema
6
+ from cartography.models.core.nodes import ExtraNodeLabels
7
+ from cartography.models.core.relationships import CartographyRelProperties
8
+ from cartography.models.core.relationships import CartographyRelSchema
9
+ from cartography.models.core.relationships import LinkDirection
10
+ from cartography.models.core.relationships import make_target_node_matcher
11
+ from cartography.models.core.relationships import TargetNodeMatcher
12
+
13
+
14
+ @dataclass(frozen=True)
15
+ class AWSRootPrincipalNodeProperties(CartographyNodeProperties):
16
+ id: PropertyRef = PropertyRef("arn")
17
+ arn: PropertyRef = PropertyRef("arn", extra_index=True)
18
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
19
+
20
+
21
+ @dataclass(frozen=True)
22
+ class AWSRootPrincipalToAWSAccountRelProperties(CartographyRelProperties):
23
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
24
+
25
+
26
+ @dataclass(frozen=True)
27
+ class AWSRootPrincipalToAWSAccountRel(CartographyRelSchema):
28
+ target_node_label: str = "AWSAccount"
29
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
30
+ {
31
+ "id": PropertyRef("AWS_ID", set_in_kwargs=True),
32
+ }
33
+ )
34
+ direction: LinkDirection = LinkDirection.INWARD
35
+ rel_label: str = "RESOURCE"
36
+ properties: AWSRootPrincipalToAWSAccountRelProperties = (
37
+ AWSRootPrincipalToAWSAccountRelProperties()
38
+ )
39
+
40
+
41
+ @dataclass(frozen=True)
42
+ class AWSRootPrincipalSchema(CartographyNodeSchema):
43
+ """
44
+ Represents the AWS root principal for an AWS account
45
+ """
46
+
47
+ label: str = "AWSRootPrincipal"
48
+ properties: AWSRootPrincipalNodeProperties = AWSRootPrincipalNodeProperties()
49
+ sub_resource_relationship: AWSRootPrincipalToAWSAccountRel = (
50
+ AWSRootPrincipalToAWSAccountRel()
51
+ )
52
+ extra_node_labels: ExtraNodeLabels = ExtraNodeLabels(["AWSPrincipal"])
@@ -0,0 +1,30 @@
1
+ from dataclasses import dataclass
2
+
3
+ from cartography.models.core.common import PropertyRef
4
+ from cartography.models.core.nodes import CartographyNodeProperties
5
+ from cartography.models.core.nodes import CartographyNodeSchema
6
+ from cartography.models.core.nodes import ExtraNodeLabels
7
+
8
+
9
+ @dataclass(frozen=True)
10
+ class AWSServicePrincipalNodeProperties(CartographyNodeProperties):
11
+ # Required unique identifier
12
+ id: PropertyRef = PropertyRef("arn")
13
+ arn: PropertyRef = PropertyRef("arn", extra_index=True)
14
+
15
+ # Automatic fields (set by cartography)
16
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
17
+
18
+ # Business fields from AWS IAM service principals
19
+ type: PropertyRef = PropertyRef("type")
20
+
21
+
22
+ @dataclass(frozen=True)
23
+ class AWSServicePrincipalSchema(CartographyNodeSchema):
24
+ """
25
+ Represents a global AWS service principal e.g. "ec2.amazonaws.com"
26
+ """
27
+
28
+ label: str = "AWSServicePrincipal"
29
+ extra_node_labels: ExtraNodeLabels = ExtraNodeLabels(["AWSPrincipal"])
30
+ properties: AWSServicePrincipalNodeProperties = AWSServicePrincipalNodeProperties()
@@ -0,0 +1,38 @@
1
+ from dataclasses import dataclass
2
+
3
+ from cartography.models.core.common import PropertyRef
4
+ from cartography.models.core.relationships import CartographyRelProperties
5
+ from cartography.models.core.relationships import CartographyRelSchema
6
+ from cartography.models.core.relationships import LinkDirection
7
+ from cartography.models.core.relationships import make_source_node_matcher
8
+ from cartography.models.core.relationships import make_target_node_matcher
9
+ from cartography.models.core.relationships import SourceNodeMatcher
10
+ from cartography.models.core.relationships import TargetNodeMatcher
11
+
12
+
13
+ @dataclass(frozen=True)
14
+ class STSAssumeRoleAllowRelProperties(CartographyRelProperties):
15
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
16
+ _sub_resource_label: PropertyRef = PropertyRef(
17
+ "_sub_resource_label", set_in_kwargs=True
18
+ )
19
+ _sub_resource_id: PropertyRef = PropertyRef("_sub_resource_id", set_in_kwargs=True)
20
+
21
+
22
+ @dataclass(frozen=True)
23
+ class STSAssumeRoleAllowMatchLink(CartographyRelSchema):
24
+ rel_label: str = "STS_ASSUMEROLE_ALLOW"
25
+ direction: LinkDirection = LinkDirection.OUTWARD
26
+ properties: STSAssumeRoleAllowRelProperties = STSAssumeRoleAllowRelProperties()
27
+
28
+ # Target node (the role being assumed)
29
+ target_node_label: str = "AWSRole"
30
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
31
+ {"arn": PropertyRef("target_arn")},
32
+ )
33
+
34
+ # Source node (the principal that can assume the role)
35
+ source_node_label: str = "AWSPrincipal"
36
+ source_node_matcher: SourceNodeMatcher = make_source_node_matcher(
37
+ {"arn": PropertyRef("source_arn")},
38
+ )