cartography 0.109.0rc1__py3-none-any.whl → 0.110.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 (78) hide show
  1. cartography/_version.py +2 -2
  2. cartography/cli.py +14 -0
  3. cartography/config.py +4 -0
  4. cartography/data/indexes.cypher +0 -15
  5. cartography/data/jobs/analysis/aws_ec2_keypair_analysis.json +2 -2
  6. cartography/intel/aws/cloudtrail_management_events.py +21 -0
  7. cartography/intel/aws/cognito.py +201 -0
  8. cartography/intel/aws/ecs.py +7 -1
  9. cartography/intel/aws/eventbridge.py +91 -0
  10. cartography/intel/aws/glue.py +181 -0
  11. cartography/intel/aws/identitycenter.py +71 -23
  12. cartography/intel/aws/kms.py +173 -201
  13. cartography/intel/aws/lambda_function.py +206 -190
  14. cartography/intel/aws/rds.py +335 -445
  15. cartography/intel/aws/resources.py +6 -0
  16. cartography/intel/aws/route53.py +336 -332
  17. cartography/intel/aws/s3.py +104 -0
  18. cartography/intel/github/__init__.py +21 -25
  19. cartography/intel/github/repos.py +4 -36
  20. cartography/intel/kubernetes/__init__.py +4 -0
  21. cartography/intel/kubernetes/rbac.py +464 -0
  22. cartography/intel/kubernetes/util.py +17 -0
  23. cartography/intel/trivy/__init__.py +73 -13
  24. cartography/intel/trivy/scanner.py +115 -92
  25. cartography/models/aws/cognito/__init__.py +0 -0
  26. cartography/models/aws/cognito/identity_pool.py +70 -0
  27. cartography/models/aws/cognito/user_pool.py +47 -0
  28. cartography/models/aws/ec2/security_groups.py +1 -1
  29. cartography/models/aws/ecs/services.py +17 -0
  30. cartography/models/aws/ecs/tasks.py +1 -0
  31. cartography/models/aws/eventbridge/__init__.py +0 -0
  32. cartography/models/aws/eventbridge/rule.py +77 -0
  33. cartography/models/aws/glue/__init__.py +0 -0
  34. cartography/models/aws/glue/connection.py +51 -0
  35. cartography/models/aws/glue/job.py +69 -0
  36. cartography/models/aws/identitycenter/awspermissionset.py +44 -0
  37. cartography/models/aws/kms/__init__.py +0 -0
  38. cartography/models/aws/kms/aliases.py +86 -0
  39. cartography/models/aws/kms/grants.py +65 -0
  40. cartography/models/aws/kms/keys.py +88 -0
  41. cartography/models/aws/lambda_function/__init__.py +0 -0
  42. cartography/models/aws/lambda_function/alias.py +74 -0
  43. cartography/models/aws/lambda_function/event_source_mapping.py +88 -0
  44. cartography/models/aws/lambda_function/lambda_function.py +89 -0
  45. cartography/models/aws/lambda_function/layer.py +72 -0
  46. cartography/models/aws/rds/__init__.py +0 -0
  47. cartography/models/aws/rds/cluster.py +89 -0
  48. cartography/models/aws/rds/event_subscription.py +146 -0
  49. cartography/models/aws/rds/instance.py +154 -0
  50. cartography/models/aws/rds/snapshot.py +108 -0
  51. cartography/models/aws/rds/subnet_group.py +101 -0
  52. cartography/models/aws/route53/__init__.py +0 -0
  53. cartography/models/aws/route53/dnsrecord.py +235 -0
  54. cartography/models/aws/route53/nameserver.py +63 -0
  55. cartography/models/aws/route53/subzone.py +40 -0
  56. cartography/models/aws/route53/zone.py +47 -0
  57. cartography/models/github/dependencies.py +1 -2
  58. cartography/models/kubernetes/clusterrolebindings.py +98 -0
  59. cartography/models/kubernetes/clusterroles.py +52 -0
  60. cartography/models/kubernetes/rolebindings.py +119 -0
  61. cartography/models/kubernetes/roles.py +76 -0
  62. cartography/models/kubernetes/serviceaccounts.py +77 -0
  63. cartography/models/snipeit/asset.py +1 -0
  64. cartography/util.py +8 -1
  65. {cartography-0.109.0rc1.dist-info → cartography-0.110.0.dist-info}/METADATA +3 -3
  66. {cartography-0.109.0rc1.dist-info → cartography-0.110.0.dist-info}/RECORD +71 -41
  67. cartography/data/jobs/cleanup/aws_dns_cleanup.json +0 -65
  68. cartography/data/jobs/cleanup/aws_import_identity_center_cleanup.json +0 -16
  69. cartography/data/jobs/cleanup/aws_import_lambda_cleanup.json +0 -50
  70. cartography/data/jobs/cleanup/aws_import_rds_clusters_cleanup.json +0 -23
  71. cartography/data/jobs/cleanup/aws_import_rds_instances_cleanup.json +0 -47
  72. cartography/data/jobs/cleanup/aws_import_rds_snapshots_cleanup.json +0 -23
  73. cartography/data/jobs/cleanup/aws_kms_details.json +0 -10
  74. /cartography/data/jobs/{analysis → scoped_analysis}/aws_s3acl_analysis.json +0 -0
  75. {cartography-0.109.0rc1.dist-info → cartography-0.110.0.dist-info}/WHEEL +0 -0
  76. {cartography-0.109.0rc1.dist-info → cartography-0.110.0.dist-info}/entry_points.txt +0 -0
  77. {cartography-0.109.0rc1.dist-info → cartography-0.110.0.dist-info}/licenses/LICENSE +0 -0
  78. {cartography-0.109.0rc1.dist-info → cartography-0.110.0.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,235 @@
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 AWSDNSRecordNodeProperties(CartographyNodeProperties):
17
+ id: PropertyRef = PropertyRef("id")
18
+ name: PropertyRef = PropertyRef("name", extra_index=True)
19
+ type: PropertyRef = PropertyRef("type")
20
+ value: PropertyRef = PropertyRef("value")
21
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
22
+
23
+
24
+ @dataclass(frozen=True)
25
+ class AWSDNSRecordToZoneRelProperties(CartographyRelProperties):
26
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
27
+
28
+
29
+ @dataclass(frozen=True)
30
+ class AWSDNSRecordToZoneRel(CartographyRelSchema):
31
+ target_node_label: str = "AWSDNSZone"
32
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
33
+ {"zoneid": PropertyRef("zoneid")}
34
+ )
35
+ direction: LinkDirection = LinkDirection.OUTWARD
36
+ rel_label: str = "MEMBER_OF_DNS_ZONE"
37
+ properties: AWSDNSRecordToZoneRelProperties = AWSDNSRecordToZoneRelProperties()
38
+
39
+
40
+ @dataclass(frozen=True)
41
+ class AWSDNSRecordToAWSAccountRelProperties(CartographyRelProperties):
42
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
43
+
44
+
45
+ @dataclass(frozen=True)
46
+ class AWSDNSRecordToAWSAccountRel(CartographyRelSchema):
47
+ target_node_label: str = "AWSAccount"
48
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
49
+ {"id": PropertyRef("AWS_ID", set_in_kwargs=True)}
50
+ )
51
+ direction: LinkDirection = LinkDirection.INWARD
52
+ rel_label: str = "RESOURCE"
53
+ properties: AWSDNSRecordToAWSAccountRelProperties = (
54
+ AWSDNSRecordToAWSAccountRelProperties()
55
+ )
56
+
57
+
58
+ @dataclass(frozen=True)
59
+ class AWSDNSRecordToNameServerRelProperties(CartographyRelProperties):
60
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
61
+
62
+
63
+ @dataclass(frozen=True)
64
+ class AWSDNSRecordToNameServerRel(CartographyRelSchema):
65
+ target_node_label: str = "NameServer"
66
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
67
+ {
68
+ "id": PropertyRef("servers", one_to_many=True),
69
+ }
70
+ )
71
+ direction: LinkDirection = LinkDirection.OUTWARD
72
+ rel_label: str = "DNS_POINTS_TO"
73
+ properties: AWSDNSRecordToNameServerRelProperties = (
74
+ AWSDNSRecordToNameServerRelProperties()
75
+ )
76
+
77
+
78
+ @dataclass(frozen=True)
79
+ class AWSDNSRecordToEC2InstanceRelProperties(CartographyRelProperties):
80
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
81
+
82
+
83
+ @dataclass(frozen=True)
84
+ class AWSDNSRecordToEC2InstanceRel(CartographyRelSchema):
85
+ target_node_label: str = "EC2Instance"
86
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
87
+ {
88
+ "publicdnsname": PropertyRef("value"),
89
+ }
90
+ )
91
+ direction: LinkDirection = LinkDirection.OUTWARD
92
+ rel_label: str = "DNS_POINTS_TO"
93
+ properties: AWSDNSRecordToEC2InstanceRelProperties = (
94
+ AWSDNSRecordToEC2InstanceRelProperties()
95
+ )
96
+
97
+
98
+ @dataclass(frozen=True)
99
+ class AWSDNSRecordToLoadBalancerRelProperties(CartographyRelProperties):
100
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
101
+
102
+
103
+ @dataclass(frozen=True)
104
+ class AWSDNSRecordToLoadBalancerRel(CartographyRelSchema):
105
+ target_node_label: str = "LoadBalancer"
106
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
107
+ {
108
+ "dnsname": PropertyRef("value"),
109
+ }
110
+ )
111
+ direction: LinkDirection = LinkDirection.OUTWARD
112
+ rel_label: str = "DNS_POINTS_TO"
113
+ properties: AWSDNSRecordToLoadBalancerRelProperties = (
114
+ AWSDNSRecordToLoadBalancerRelProperties()
115
+ )
116
+
117
+
118
+ @dataclass(frozen=True)
119
+ class AWSDNSRecordToLoadBalancerV2RelProperties(CartographyRelProperties):
120
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
121
+
122
+
123
+ @dataclass(frozen=True)
124
+ class AWSDNSRecordToLoadBalancerV2Rel(CartographyRelSchema):
125
+ target_node_label: str = "LoadBalancerV2"
126
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
127
+ {
128
+ "dnsname": PropertyRef("value"),
129
+ }
130
+ )
131
+ direction: LinkDirection = LinkDirection.OUTWARD
132
+ rel_label: str = "DNS_POINTS_TO"
133
+ properties: AWSDNSRecordToLoadBalancerV2RelProperties = (
134
+ AWSDNSRecordToLoadBalancerV2RelProperties()
135
+ )
136
+
137
+
138
+ @dataclass(frozen=True)
139
+ class AWSDNSRecordToESDomainRelProperties(CartographyRelProperties):
140
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
141
+
142
+
143
+ @dataclass(frozen=True)
144
+ class AWSDNSRecordToESDomainRel(CartographyRelSchema):
145
+ target_node_label: str = "ESDomain"
146
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
147
+ {
148
+ "endpoint": PropertyRef("value"),
149
+ }
150
+ )
151
+ direction: LinkDirection = LinkDirection.OUTWARD
152
+ rel_label: str = "DNS_POINTS_TO"
153
+ properties: AWSDNSRecordToESDomainRelProperties = (
154
+ AWSDNSRecordToESDomainRelProperties()
155
+ )
156
+
157
+
158
+ @dataclass(frozen=True)
159
+ class AWSDNSRecordToDNSRecordRelProperties(CartographyRelProperties):
160
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
161
+
162
+
163
+ @dataclass(frozen=True)
164
+ class AWSDNSRecordToDNSRecordRel(CartographyRelSchema):
165
+ target_node_label: str = "AWSDNSRecord"
166
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
167
+ {
168
+ "name": PropertyRef("value"),
169
+ }
170
+ )
171
+ direction: LinkDirection = LinkDirection.OUTWARD
172
+ rel_label: str = "DNS_POINTS_TO"
173
+ properties: AWSDNSRecordToDNSRecordRelProperties = (
174
+ AWSDNSRecordToDNSRecordRelProperties()
175
+ )
176
+
177
+
178
+ @dataclass(frozen=True)
179
+ class AWSDNSRecordToIpRelProperties(CartographyRelProperties):
180
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
181
+
182
+
183
+ @dataclass(frozen=True)
184
+ class AWSDNSRecordToIpRel(CartographyRelSchema):
185
+ target_node_label: str = "Ip"
186
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
187
+ {
188
+ "id": PropertyRef("ip_addresses", one_to_many=True),
189
+ }
190
+ )
191
+ direction: LinkDirection = LinkDirection.OUTWARD
192
+ rel_label: str = "DNS_POINTS_TO"
193
+ properties: AWSDNSRecordToIpRelProperties = AWSDNSRecordToIpRelProperties()
194
+
195
+
196
+ @dataclass(frozen=True)
197
+ class AWSDNSRecordToElasticIPAddressRelProperties(CartographyRelProperties):
198
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
199
+
200
+
201
+ @dataclass(frozen=True)
202
+ class AWSDNSRecordToElasticIPAddressRel(CartographyRelSchema):
203
+ target_node_label: str = "ElasticIPAddress"
204
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
205
+ {
206
+ "public_ip": PropertyRef("value"),
207
+ }
208
+ )
209
+ direction: LinkDirection = LinkDirection.OUTWARD
210
+ rel_label: str = "DNS_POINTS_TO"
211
+ properties: AWSDNSRecordToElasticIPAddressRelProperties = (
212
+ AWSDNSRecordToElasticIPAddressRelProperties()
213
+ )
214
+
215
+
216
+ class AWSDNSRecordSchema(CartographyNodeSchema):
217
+ label: str = "AWSDNSRecord"
218
+ properties: AWSDNSRecordNodeProperties = AWSDNSRecordNodeProperties()
219
+ extra_node_labels: ExtraNodeLabels = ExtraNodeLabels(["DNSRecord"])
220
+ sub_resource_relationship: AWSDNSRecordToAWSAccountRel = (
221
+ AWSDNSRecordToAWSAccountRel()
222
+ )
223
+ other_relationships: OtherRelationships = OtherRelationships(
224
+ [
225
+ AWSDNSRecordToNameServerRel(),
226
+ AWSDNSRecordToEC2InstanceRel(),
227
+ AWSDNSRecordToLoadBalancerRel(),
228
+ AWSDNSRecordToLoadBalancerV2Rel(),
229
+ AWSDNSRecordToESDomainRel(),
230
+ AWSDNSRecordToDNSRecordRel(),
231
+ AWSDNSRecordToZoneRel(),
232
+ AWSDNSRecordToIpRel(),
233
+ AWSDNSRecordToElasticIPAddressRel(),
234
+ ]
235
+ )
@@ -0,0 +1,63 @@
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 NameServerNodeProperties(CartographyNodeProperties):
16
+ id: PropertyRef = PropertyRef("id")
17
+ name: PropertyRef = PropertyRef("id", extra_index=True)
18
+ zoneid: PropertyRef = PropertyRef("zoneid")
19
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
20
+
21
+
22
+ @dataclass(frozen=True)
23
+ class NameServerToZoneRelProperties(CartographyRelProperties):
24
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
25
+
26
+
27
+ @dataclass(frozen=True)
28
+ class NameServerToZoneRel(CartographyRelSchema):
29
+ target_node_label: str = "AWSDNSZone"
30
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
31
+ {"zoneid": PropertyRef("zoneid")}
32
+ )
33
+ direction: LinkDirection = LinkDirection.INWARD
34
+ rel_label: str = "NAMESERVER"
35
+ properties: NameServerToZoneRelProperties = NameServerToZoneRelProperties()
36
+
37
+
38
+ @dataclass(frozen=True)
39
+ class NameServerToAWSAccountRelProperties(CartographyRelProperties):
40
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
41
+
42
+
43
+ @dataclass(frozen=True)
44
+ class NameServerToAWSAccountRel(CartographyRelSchema):
45
+ target_node_label: str = "AWSAccount"
46
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
47
+ {"id": PropertyRef("AWS_ID", set_in_kwargs=True)}
48
+ )
49
+ direction: LinkDirection = LinkDirection.INWARD
50
+ rel_label: str = "RESOURCE"
51
+ properties: NameServerToAWSAccountRelProperties = (
52
+ NameServerToAWSAccountRelProperties()
53
+ )
54
+
55
+
56
+ @dataclass(frozen=True)
57
+ class NameServerSchema(CartographyNodeSchema):
58
+ label: str = "NameServer"
59
+ properties: NameServerNodeProperties = NameServerNodeProperties()
60
+ sub_resource_relationship: NameServerToAWSAccountRel = NameServerToAWSAccountRel()
61
+ other_relationships: OtherRelationships = OtherRelationships(
62
+ [NameServerToZoneRel()]
63
+ )
@@ -0,0 +1,40 @@
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 AWSDNSZoneSubzoneRelProperties(CartographyRelProperties):
15
+ # Mandatory fields for MatchLinks
16
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
17
+ _sub_resource_label: PropertyRef = PropertyRef(
18
+ "_sub_resource_label", set_in_kwargs=True
19
+ )
20
+ _sub_resource_id: PropertyRef = PropertyRef("_sub_resource_id", set_in_kwargs=True)
21
+
22
+
23
+ # MatchLink for creating SUBZONE relationships between DNS zones
24
+ @dataclass(frozen=True)
25
+ class AWSDNSZoneSubzoneMatchLink(CartographyRelSchema):
26
+ target_node_label: str = "AWSDNSZone"
27
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
28
+ {
29
+ "zoneid": PropertyRef("subzone_id"),
30
+ }
31
+ )
32
+ source_node_label: str = "AWSDNSZone"
33
+ source_node_matcher: SourceNodeMatcher = make_source_node_matcher(
34
+ {
35
+ "zoneid": PropertyRef("zone_id"),
36
+ }
37
+ )
38
+ properties: AWSDNSZoneSubzoneRelProperties = AWSDNSZoneSubzoneRelProperties()
39
+ direction: LinkDirection = LinkDirection.OUTWARD
40
+ rel_label: str = "SUBZONE"
@@ -0,0 +1,47 @@
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 AWSDNSZoneNodeProperties(CartographyNodeProperties):
16
+ id: PropertyRef = PropertyRef("zoneid")
17
+ zoneid: PropertyRef = PropertyRef("zoneid")
18
+ name: PropertyRef = PropertyRef("name", extra_index=True)
19
+ comment: PropertyRef = PropertyRef("comment")
20
+ privatezone: PropertyRef = PropertyRef("privatezone")
21
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
22
+
23
+
24
+ @dataclass(frozen=True)
25
+ class AWSDNSZoneToAWSAccountRelProperties(CartographyRelProperties):
26
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
27
+
28
+
29
+ @dataclass(frozen=True)
30
+ class AWSDNSZoneToAWSAccountRel(CartographyRelSchema):
31
+ target_node_label: str = "AWSAccount"
32
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
33
+ {"id": PropertyRef("AWS_ID", set_in_kwargs=True)}
34
+ )
35
+ direction: LinkDirection = LinkDirection.INWARD
36
+ rel_label: str = "RESOURCE"
37
+ properties: AWSDNSZoneToAWSAccountRelProperties = (
38
+ AWSDNSZoneToAWSAccountRelProperties()
39
+ )
40
+
41
+
42
+ @dataclass(frozen=True)
43
+ class AWSDNSZoneSchema(CartographyNodeSchema):
44
+ label: str = "AWSDNSZone"
45
+ properties: AWSDNSZoneNodeProperties = AWSDNSZoneNodeProperties()
46
+ extra_node_labels: ExtraNodeLabels = ExtraNodeLabels(["DNSZone"])
47
+ sub_resource_relationship: AWSDNSZoneToAWSAccountRel = AWSDNSZoneToAWSAccountRel()
@@ -16,10 +16,9 @@ class GitHubDependencyNodeProperties(CartographyNodeProperties):
16
16
  id: PropertyRef = PropertyRef("id")
17
17
  name: PropertyRef = PropertyRef("name")
18
18
  original_name: PropertyRef = PropertyRef("original_name")
19
- version: PropertyRef = PropertyRef("version")
19
+ requirements: PropertyRef = PropertyRef("requirements")
20
20
  ecosystem: PropertyRef = PropertyRef("ecosystem")
21
21
  package_manager: PropertyRef = PropertyRef("package_manager")
22
- repo_name: PropertyRef = PropertyRef("repo_name")
23
22
  manifest_file: PropertyRef = PropertyRef("manifest_file")
24
23
  lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
25
24
 
@@ -0,0 +1,98 @@
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 KubernetesClusterRoleBindingNodeProperties(CartographyNodeProperties):
16
+ id: PropertyRef = PropertyRef("id")
17
+ name: PropertyRef = PropertyRef("name")
18
+ uid: PropertyRef = PropertyRef("uid")
19
+ creation_timestamp: PropertyRef = PropertyRef("creation_timestamp")
20
+ resource_version: PropertyRef = PropertyRef("resource_version")
21
+ role_name: PropertyRef = PropertyRef("role_name")
22
+ role_kind: PropertyRef = PropertyRef("role_kind")
23
+ service_account_ids: PropertyRef = PropertyRef("service_account_ids")
24
+ role_id: PropertyRef = PropertyRef("role_id")
25
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
26
+
27
+
28
+ @dataclass(frozen=True)
29
+ class KubernetesClusterRoleBindingToClusterRelProperties(CartographyRelProperties):
30
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
31
+
32
+
33
+ @dataclass(frozen=True)
34
+ class KubernetesClusterRoleBindingToClusterRel(CartographyRelSchema):
35
+ target_node_label: str = "KubernetesCluster"
36
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
37
+ {"id": PropertyRef("CLUSTER_ID", set_in_kwargs=True)}
38
+ )
39
+ direction: LinkDirection = LinkDirection.INWARD
40
+ rel_label: str = "RESOURCE"
41
+ properties: KubernetesClusterRoleBindingToClusterRelProperties = (
42
+ KubernetesClusterRoleBindingToClusterRelProperties()
43
+ )
44
+
45
+
46
+ @dataclass(frozen=True)
47
+ class KubernetesClusterRoleBindingToServiceAccountRelProperties(
48
+ CartographyRelProperties
49
+ ):
50
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
51
+
52
+
53
+ @dataclass(frozen=True)
54
+ class KubernetesClusterRoleBindingToServiceAccountRel(CartographyRelSchema):
55
+ target_node_label: str = "KubernetesServiceAccount"
56
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
57
+ {"id": PropertyRef("service_account_ids", one_to_many=True)}
58
+ )
59
+ direction: LinkDirection = LinkDirection.OUTWARD
60
+ rel_label: str = "SUBJECT"
61
+ properties: KubernetesClusterRoleBindingToServiceAccountRelProperties = (
62
+ KubernetesClusterRoleBindingToServiceAccountRelProperties()
63
+ )
64
+
65
+
66
+ @dataclass(frozen=True)
67
+ class KubernetesClusterRoleBindingToClusterRoleRelProperties(CartographyRelProperties):
68
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
69
+
70
+
71
+ @dataclass(frozen=True)
72
+ class KubernetesClusterRoleBindingToClusterRoleRel(CartographyRelSchema):
73
+ target_node_label: str = "KubernetesClusterRole"
74
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
75
+ {"id": PropertyRef("role_id")}
76
+ )
77
+ direction: LinkDirection = LinkDirection.OUTWARD
78
+ rel_label: str = "ROLE_REF"
79
+ properties: KubernetesClusterRoleBindingToClusterRoleRelProperties = (
80
+ KubernetesClusterRoleBindingToClusterRoleRelProperties()
81
+ )
82
+
83
+
84
+ @dataclass(frozen=True)
85
+ class KubernetesClusterRoleBindingSchema(CartographyNodeSchema):
86
+ label: str = "KubernetesClusterRoleBinding"
87
+ properties: KubernetesClusterRoleBindingNodeProperties = (
88
+ KubernetesClusterRoleBindingNodeProperties()
89
+ )
90
+ sub_resource_relationship: KubernetesClusterRoleBindingToClusterRel = (
91
+ KubernetesClusterRoleBindingToClusterRel()
92
+ )
93
+ other_relationships: OtherRelationships = OtherRelationships(
94
+ [
95
+ KubernetesClusterRoleBindingToServiceAccountRel(),
96
+ KubernetesClusterRoleBindingToClusterRoleRel(),
97
+ ]
98
+ )
@@ -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.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 KubernetesClusterRoleNodeProperties(CartographyNodeProperties):
15
+ id: PropertyRef = PropertyRef("id")
16
+ name: PropertyRef = PropertyRef("name")
17
+ uid: PropertyRef = PropertyRef("uid")
18
+ creation_timestamp: PropertyRef = PropertyRef("creation_timestamp")
19
+ resource_version: PropertyRef = PropertyRef("resource_version")
20
+ api_groups: PropertyRef = PropertyRef("api_groups")
21
+ resources: PropertyRef = PropertyRef("resources")
22
+ verbs: PropertyRef = PropertyRef("verbs")
23
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
24
+
25
+
26
+ @dataclass(frozen=True)
27
+ class KubernetesClusterRoleToClusterRelProperties(CartographyRelProperties):
28
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
29
+
30
+
31
+ @dataclass(frozen=True)
32
+ class KubernetesClusterRoleToClusterRel(CartographyRelSchema):
33
+ target_node_label: str = "KubernetesCluster"
34
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
35
+ {"id": PropertyRef("CLUSTER_ID", set_in_kwargs=True)}
36
+ )
37
+ direction: LinkDirection = LinkDirection.INWARD
38
+ rel_label: str = "RESOURCE"
39
+ properties: KubernetesClusterRoleToClusterRelProperties = (
40
+ KubernetesClusterRoleToClusterRelProperties()
41
+ )
42
+
43
+
44
+ @dataclass(frozen=True)
45
+ class KubernetesClusterRoleSchema(CartographyNodeSchema):
46
+ label: str = "KubernetesClusterRole"
47
+ properties: KubernetesClusterRoleNodeProperties = (
48
+ KubernetesClusterRoleNodeProperties()
49
+ )
50
+ sub_resource_relationship: KubernetesClusterRoleToClusterRel = (
51
+ KubernetesClusterRoleToClusterRel()
52
+ )
@@ -0,0 +1,119 @@
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 KubernetesRoleBindingNodeProperties(CartographyNodeProperties):
16
+ id: PropertyRef = PropertyRef("id")
17
+ name: PropertyRef = PropertyRef("name")
18
+ namespace: PropertyRef = PropertyRef("namespace")
19
+ uid: PropertyRef = PropertyRef("uid")
20
+ creation_timestamp: PropertyRef = PropertyRef("creation_timestamp")
21
+ resource_version: PropertyRef = PropertyRef("resource_version")
22
+ role_name: PropertyRef = PropertyRef("role_name")
23
+ role_kind: PropertyRef = PropertyRef("role_kind")
24
+ service_account_ids: PropertyRef = PropertyRef("service_account_ids")
25
+ role_id: PropertyRef = PropertyRef("role_id")
26
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
27
+
28
+
29
+ @dataclass(frozen=True)
30
+ class KubernetesRoleBindingToNamespaceRelProperties(CartographyRelProperties):
31
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
32
+
33
+
34
+ @dataclass(frozen=True)
35
+ class KubernetesRoleBindingToNamespaceRel(CartographyRelSchema):
36
+ target_node_label: str = "KubernetesNamespace"
37
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
38
+ {
39
+ "cluster_name": PropertyRef("CLUSTER_NAME", set_in_kwargs=True),
40
+ "name": PropertyRef("namespace"),
41
+ }
42
+ )
43
+ direction: LinkDirection = LinkDirection.INWARD
44
+ rel_label: str = "CONTAINS"
45
+ properties: KubernetesRoleBindingToNamespaceRelProperties = (
46
+ KubernetesRoleBindingToNamespaceRelProperties()
47
+ )
48
+
49
+
50
+ @dataclass(frozen=True)
51
+ class KubernetesRoleBindingToClusterRelProperties(CartographyRelProperties):
52
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
53
+
54
+
55
+ @dataclass(frozen=True)
56
+ class KubernetesRoleBindingToClusterRel(CartographyRelSchema):
57
+ target_node_label: str = "KubernetesCluster"
58
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
59
+ {"id": PropertyRef("CLUSTER_ID", set_in_kwargs=True)}
60
+ )
61
+ direction: LinkDirection = LinkDirection.INWARD
62
+ rel_label: str = "RESOURCE"
63
+ properties: KubernetesRoleBindingToClusterRelProperties = (
64
+ KubernetesRoleBindingToClusterRelProperties()
65
+ )
66
+
67
+
68
+ @dataclass(frozen=True)
69
+ class KubernetesRoleBindingToServiceAccountRelProperties(CartographyRelProperties):
70
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
71
+
72
+
73
+ @dataclass(frozen=True)
74
+ class KubernetesRoleBindingToServiceAccountRel(CartographyRelSchema):
75
+ target_node_label: str = "KubernetesServiceAccount"
76
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
77
+ {"id": PropertyRef("service_account_ids", one_to_many=True)}
78
+ )
79
+ direction: LinkDirection = LinkDirection.OUTWARD
80
+ rel_label: str = "SUBJECT"
81
+ properties: KubernetesRoleBindingToServiceAccountRelProperties = (
82
+ KubernetesRoleBindingToServiceAccountRelProperties()
83
+ )
84
+
85
+
86
+ @dataclass(frozen=True)
87
+ class KubernetesRoleBindingToRoleRelProperties(CartographyRelProperties):
88
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
89
+
90
+
91
+ @dataclass(frozen=True)
92
+ class KubernetesRoleBindingToRoleRel(CartographyRelSchema):
93
+ target_node_label: str = "KubernetesRole"
94
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
95
+ {"id": PropertyRef("role_id")}
96
+ )
97
+ direction: LinkDirection = LinkDirection.OUTWARD
98
+ rel_label: str = "ROLE_REF"
99
+ properties: KubernetesRoleBindingToRoleRelProperties = (
100
+ KubernetesRoleBindingToRoleRelProperties()
101
+ )
102
+
103
+
104
+ @dataclass(frozen=True)
105
+ class KubernetesRoleBindingSchema(CartographyNodeSchema):
106
+ label: str = "KubernetesRoleBinding"
107
+ properties: KubernetesRoleBindingNodeProperties = (
108
+ KubernetesRoleBindingNodeProperties()
109
+ )
110
+ sub_resource_relationship: KubernetesRoleBindingToClusterRel = (
111
+ KubernetesRoleBindingToClusterRel()
112
+ )
113
+ other_relationships: OtherRelationships = OtherRelationships(
114
+ [
115
+ KubernetesRoleBindingToNamespaceRel(),
116
+ KubernetesRoleBindingToServiceAccountRel(),
117
+ KubernetesRoleBindingToRoleRel(),
118
+ ]
119
+ )