cartography 0.113.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.
- cartography/_version.py +2 -2
- cartography/cli.py +8 -0
- cartography/config.py +4 -0
- cartography/data/indexes.cypher +0 -27
- cartography/intel/aws/iam.py +741 -492
- cartography/intel/aws/organizations.py +7 -8
- cartography/intel/aws/permission_relationships.py +4 -16
- cartography/intel/azure/__init__.py +16 -0
- cartography/intel/azure/app_service.py +105 -0
- cartography/intel/azure/functions.py +124 -0
- cartography/intel/entra/__init__.py +31 -0
- cartography/intel/entra/app_role_assignments.py +277 -0
- cartography/intel/entra/applications.py +4 -238
- cartography/intel/entra/federation/__init__.py +0 -0
- cartography/intel/entra/federation/aws_identity_center.py +77 -0
- cartography/intel/entra/service_principals.py +217 -0
- cartography/intel/gcp/__init__.py +136 -440
- cartography/intel/gcp/clients.py +65 -0
- cartography/intel/gcp/compute.py +18 -44
- cartography/intel/gcp/crm/__init__.py +0 -0
- cartography/intel/gcp/crm/folders.py +108 -0
- cartography/intel/gcp/crm/orgs.py +65 -0
- cartography/intel/gcp/crm/projects.py +109 -0
- cartography/intel/gcp/gke.py +72 -113
- cartography/intel/github/__init__.py +41 -0
- cartography/intel/github/commits.py +423 -0
- cartography/intel/github/repos.py +73 -39
- cartography/models/aws/iam/access_key.py +103 -0
- cartography/models/aws/iam/account_role.py +24 -0
- cartography/models/aws/iam/federated_principal.py +60 -0
- cartography/models/aws/iam/group.py +60 -0
- cartography/models/aws/iam/group_membership.py +26 -0
- cartography/models/aws/iam/inline_policy.py +78 -0
- cartography/models/aws/iam/managed_policy.py +51 -0
- cartography/models/aws/iam/policy_statement.py +57 -0
- cartography/models/aws/iam/role.py +83 -0
- cartography/models/aws/iam/root_principal.py +52 -0
- cartography/models/aws/iam/service_principal.py +30 -0
- cartography/models/aws/iam/sts_assumerole_allow.py +38 -0
- cartography/models/aws/iam/user.py +54 -0
- cartography/models/azure/__init__.py +0 -0
- cartography/models/azure/app_service.py +59 -0
- cartography/models/azure/function_app.py +59 -0
- cartography/models/entra/entra_user_to_aws_sso.py +41 -0
- cartography/models/entra/service_principal.py +104 -0
- cartography/models/gcp/compute/subnet.py +74 -0
- cartography/models/gcp/crm/__init__.py +0 -0
- cartography/models/gcp/crm/folders.py +98 -0
- cartography/models/gcp/crm/organizations.py +21 -0
- cartography/models/gcp/crm/projects.py +100 -0
- cartography/models/gcp/gke.py +69 -0
- cartography/models/github/commits.py +63 -0
- {cartography-0.113.0.dist-info → cartography-0.114.0.dist-info}/METADATA +7 -5
- {cartography-0.113.0.dist-info → cartography-0.114.0.dist-info}/RECORD +58 -32
- cartography/data/jobs/cleanup/aws_import_account_access_key_cleanup.json +0 -17
- cartography/data/jobs/cleanup/aws_import_groups_cleanup.json +0 -13
- cartography/data/jobs/cleanup/aws_import_principals_cleanup.json +0 -30
- cartography/data/jobs/cleanup/aws_import_roles_cleanup.json +0 -13
- cartography/data/jobs/cleanup/aws_import_users_cleanup.json +0 -8
- cartography/data/jobs/cleanup/gcp_compute_vpc_subnet_cleanup.json +0 -35
- cartography/data/jobs/cleanup/gcp_crm_folder_cleanup.json +0 -23
- cartography/data/jobs/cleanup/gcp_crm_organization_cleanup.json +0 -17
- cartography/data/jobs/cleanup/gcp_crm_project_cleanup.json +0 -23
- cartography/data/jobs/cleanup/gcp_gke_cluster_cleanup.json +0 -17
- cartography/intel/gcp/crm.py +0 -355
- {cartography-0.113.0.dist-info → cartography-0.114.0.dist-info}/WHEEL +0 -0
- {cartography-0.113.0.dist-info → cartography-0.114.0.dist-info}/entry_points.txt +0 -0
- {cartography-0.113.0.dist-info → cartography-0.114.0.dist-info}/licenses/LICENSE +0 -0
- {cartography-0.113.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
|
+
)
|