cartography 0.102.0rc1__py3-none-any.whl → 0.103.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 (297) hide show
  1. cartography/__main__.py +1 -2
  2. cartography/_version.py +2 -2
  3. cartography/cli.py +376 -249
  4. cartography/client/core/tx.py +39 -18
  5. cartography/config.py +28 -0
  6. cartography/driftdetect/__main__.py +1 -2
  7. cartography/driftdetect/add_shortcut.py +10 -2
  8. cartography/driftdetect/cli.py +71 -75
  9. cartography/driftdetect/detect_deviations.py +7 -3
  10. cartography/driftdetect/get_states.py +20 -8
  11. cartography/driftdetect/model.py +5 -5
  12. cartography/driftdetect/serializers.py +8 -6
  13. cartography/driftdetect/storage.py +2 -2
  14. cartography/graph/cleanupbuilder.py +35 -15
  15. cartography/graph/job.py +46 -17
  16. cartography/graph/querybuilder.py +165 -80
  17. cartography/graph/statement.py +35 -26
  18. cartography/intel/analysis.py +4 -1
  19. cartography/intel/aws/__init__.py +114 -55
  20. cartography/intel/aws/apigateway.py +134 -63
  21. cartography/intel/aws/cloudtrail.py +127 -0
  22. cartography/intel/aws/cloudwatch.py +93 -0
  23. cartography/intel/aws/config.py +56 -20
  24. cartography/intel/aws/dynamodb.py +108 -40
  25. cartography/intel/aws/ec2/__init__.py +2 -2
  26. cartography/intel/aws/ec2/auto_scaling_groups.py +181 -78
  27. cartography/intel/aws/ec2/elastic_ip_addresses.py +41 -13
  28. cartography/intel/aws/ec2/images.py +49 -20
  29. cartography/intel/aws/ec2/instances.py +234 -136
  30. cartography/intel/aws/ec2/internet_gateways.py +40 -11
  31. cartography/intel/aws/ec2/key_pairs.py +44 -20
  32. cartography/intel/aws/ec2/launch_templates.py +101 -59
  33. cartography/intel/aws/ec2/load_balancer_v2s.py +104 -39
  34. cartography/intel/aws/ec2/load_balancers.py +82 -42
  35. cartography/intel/aws/ec2/network_acls.py +89 -65
  36. cartography/intel/aws/ec2/network_interfaces.py +146 -87
  37. cartography/intel/aws/ec2/reserved_instances.py +45 -16
  38. cartography/intel/aws/ec2/route_tables.py +327 -0
  39. cartography/intel/aws/ec2/security_groups.py +71 -21
  40. cartography/intel/aws/ec2/snapshots.py +61 -22
  41. cartography/intel/aws/ec2/subnets.py +54 -18
  42. cartography/intel/aws/ec2/tgw.py +100 -34
  43. cartography/intel/aws/ec2/util.py +1 -1
  44. cartography/intel/aws/ec2/volumes.py +69 -41
  45. cartography/intel/aws/ec2/vpc.py +37 -12
  46. cartography/intel/aws/ec2/vpc_peerings.py +83 -24
  47. cartography/intel/aws/ecr.py +88 -32
  48. cartography/intel/aws/ecs.py +83 -47
  49. cartography/intel/aws/efs.py +93 -0
  50. cartography/intel/aws/eks.py +55 -29
  51. cartography/intel/aws/elasticache.py +42 -18
  52. cartography/intel/aws/elasticsearch.py +57 -20
  53. cartography/intel/aws/emr.py +61 -23
  54. cartography/intel/aws/iam.py +401 -145
  55. cartography/intel/aws/iam_instance_profiles.py +22 -22
  56. cartography/intel/aws/identitycenter.py +71 -37
  57. cartography/intel/aws/inspector.py +159 -89
  58. cartography/intel/aws/kms.py +92 -38
  59. cartography/intel/aws/lambda_function.py +103 -34
  60. cartography/intel/aws/organizations.py +30 -10
  61. cartography/intel/aws/permission_relationships.py +133 -51
  62. cartography/intel/aws/rds.py +249 -85
  63. cartography/intel/aws/redshift.py +107 -46
  64. cartography/intel/aws/resourcegroupstaggingapi.py +120 -66
  65. cartography/intel/aws/resources.py +57 -44
  66. cartography/intel/aws/route53.py +108 -61
  67. cartography/intel/aws/s3.py +168 -83
  68. cartography/intel/aws/s3accountpublicaccessblock.py +157 -0
  69. cartography/intel/aws/secretsmanager.py +24 -12
  70. cartography/intel/aws/securityhub.py +20 -9
  71. cartography/intel/aws/sns.py +166 -0
  72. cartography/intel/aws/sqs.py +60 -28
  73. cartography/intel/aws/ssm.py +70 -30
  74. cartography/intel/aws/util/arns.py +7 -7
  75. cartography/intel/aws/util/common.py +31 -4
  76. cartography/intel/azure/__init__.py +78 -19
  77. cartography/intel/azure/compute.py +101 -27
  78. cartography/intel/azure/cosmosdb.py +496 -170
  79. cartography/intel/azure/sql.py +296 -105
  80. cartography/intel/azure/storage.py +322 -113
  81. cartography/intel/azure/subscription.py +39 -23
  82. cartography/intel/azure/tenant.py +13 -4
  83. cartography/intel/azure/util/credentials.py +95 -55
  84. cartography/intel/bigfix/__init__.py +2 -2
  85. cartography/intel/bigfix/computers.py +93 -65
  86. cartography/intel/cloudflare/__init__.py +74 -0
  87. cartography/intel/cloudflare/accounts.py +57 -0
  88. cartography/intel/cloudflare/dnsrecords.py +64 -0
  89. cartography/intel/cloudflare/members.py +75 -0
  90. cartography/intel/cloudflare/roles.py +65 -0
  91. cartography/intel/cloudflare/zones.py +64 -0
  92. cartography/intel/create_indexes.py +3 -2
  93. cartography/intel/crowdstrike/__init__.py +11 -9
  94. cartography/intel/crowdstrike/endpoints.py +5 -1
  95. cartography/intel/crowdstrike/spotlight.py +8 -3
  96. cartography/intel/cve/__init__.py +46 -13
  97. cartography/intel/cve/feed.py +48 -12
  98. cartography/intel/digitalocean/__init__.py +22 -13
  99. cartography/intel/digitalocean/compute.py +75 -108
  100. cartography/intel/digitalocean/management.py +44 -80
  101. cartography/intel/digitalocean/platform.py +48 -43
  102. cartography/intel/dns.py +36 -10
  103. cartography/intel/duo/__init__.py +21 -16
  104. cartography/intel/duo/api_host.py +14 -9
  105. cartography/intel/duo/endpoints.py +50 -45
  106. cartography/intel/duo/groups.py +18 -14
  107. cartography/intel/duo/phones.py +37 -34
  108. cartography/intel/duo/tokens.py +26 -23
  109. cartography/intel/duo/users.py +54 -50
  110. cartography/intel/duo/web_authn_credentials.py +30 -25
  111. cartography/intel/entra/__init__.py +25 -7
  112. cartography/intel/entra/ou.py +112 -0
  113. cartography/intel/entra/users.py +69 -63
  114. cartography/intel/gcp/__init__.py +185 -49
  115. cartography/intel/gcp/compute.py +418 -231
  116. cartography/intel/gcp/crm.py +96 -43
  117. cartography/intel/gcp/dns.py +60 -19
  118. cartography/intel/gcp/gke.py +72 -38
  119. cartography/intel/gcp/iam.py +61 -41
  120. cartography/intel/gcp/storage.py +84 -55
  121. cartography/intel/github/__init__.py +13 -11
  122. cartography/intel/github/repos.py +270 -137
  123. cartography/intel/github/teams.py +170 -88
  124. cartography/intel/github/users.py +70 -39
  125. cartography/intel/github/util.py +36 -34
  126. cartography/intel/gsuite/__init__.py +47 -26
  127. cartography/intel/gsuite/api.py +73 -30
  128. cartography/intel/jamf/__init__.py +19 -1
  129. cartography/intel/jamf/computers.py +30 -7
  130. cartography/intel/jamf/util.py +7 -2
  131. cartography/intel/kandji/__init__.py +6 -3
  132. cartography/intel/kandji/devices.py +14 -8
  133. cartography/intel/kubernetes/namespaces.py +7 -4
  134. cartography/intel/kubernetes/pods.py +7 -4
  135. cartography/intel/kubernetes/services.py +8 -4
  136. cartography/intel/lastpass/__init__.py +2 -2
  137. cartography/intel/lastpass/users.py +23 -12
  138. cartography/intel/oci/__init__.py +44 -11
  139. cartography/intel/oci/iam.py +134 -38
  140. cartography/intel/oci/organizations.py +13 -6
  141. cartography/intel/oci/utils.py +43 -20
  142. cartography/intel/okta/__init__.py +66 -15
  143. cartography/intel/okta/applications.py +42 -20
  144. cartography/intel/okta/awssaml.py +93 -33
  145. cartography/intel/okta/factors.py +16 -4
  146. cartography/intel/okta/groups.py +56 -29
  147. cartography/intel/okta/organization.py +5 -1
  148. cartography/intel/okta/origins.py +6 -2
  149. cartography/intel/okta/roles.py +15 -5
  150. cartography/intel/okta/users.py +20 -8
  151. cartography/intel/okta/utils.py +6 -4
  152. cartography/intel/openai/__init__.py +86 -0
  153. cartography/intel/openai/adminapikeys.py +90 -0
  154. cartography/intel/openai/apikeys.py +96 -0
  155. cartography/intel/openai/projects.py +94 -0
  156. cartography/intel/openai/serviceaccounts.py +82 -0
  157. cartography/intel/openai/users.py +78 -0
  158. cartography/intel/openai/util.py +29 -0
  159. cartography/intel/pagerduty/__init__.py +8 -7
  160. cartography/intel/pagerduty/escalation_policies.py +18 -6
  161. cartography/intel/pagerduty/schedules.py +12 -4
  162. cartography/intel/pagerduty/services.py +11 -4
  163. cartography/intel/pagerduty/teams.py +8 -3
  164. cartography/intel/pagerduty/users.py +3 -1
  165. cartography/intel/pagerduty/vendors.py +3 -1
  166. cartography/intel/semgrep/__init__.py +24 -6
  167. cartography/intel/semgrep/dependencies.py +50 -28
  168. cartography/intel/semgrep/deployment.py +3 -1
  169. cartography/intel/semgrep/findings.py +42 -18
  170. cartography/intel/snipeit/__init__.py +17 -3
  171. cartography/intel/snipeit/asset.py +12 -6
  172. cartography/intel/snipeit/user.py +8 -5
  173. cartography/intel/snipeit/util.py +9 -4
  174. cartography/intel/tailscale/__init__.py +77 -0
  175. cartography/intel/tailscale/acls.py +146 -0
  176. cartography/intel/tailscale/devices.py +127 -0
  177. cartography/intel/tailscale/postureintegrations.py +81 -0
  178. cartography/intel/tailscale/tailnets.py +76 -0
  179. cartography/intel/tailscale/users.py +80 -0
  180. cartography/intel/tailscale/utils.py +132 -0
  181. cartography/models/aws/apigateway.py +21 -17
  182. cartography/models/aws/apigatewaycertificate.py +28 -22
  183. cartography/models/aws/apigatewayresource.py +28 -20
  184. cartography/models/aws/apigatewaystage.py +33 -25
  185. cartography/models/aws/cloudtrail/__init__.py +0 -0
  186. cartography/models/aws/cloudtrail/trail.py +61 -0
  187. cartography/models/aws/cloudwatch/__init__.py +0 -0
  188. cartography/models/aws/cloudwatch/loggroup.py +52 -0
  189. cartography/models/aws/dynamodb/gsi.py +30 -22
  190. cartography/models/aws/dynamodb/tables.py +25 -17
  191. cartography/models/aws/ec2/auto_scaling_groups.py +102 -82
  192. cartography/models/aws/ec2/images.py +36 -34
  193. cartography/models/aws/ec2/instances.py +51 -45
  194. cartography/models/aws/ec2/keypair.py +21 -16
  195. cartography/models/aws/ec2/keypair_instance.py +28 -21
  196. cartography/models/aws/ec2/launch_configurations.py +30 -26
  197. cartography/models/aws/ec2/launch_template_versions.py +48 -38
  198. cartography/models/aws/ec2/launch_templates.py +21 -17
  199. cartography/models/aws/ec2/load_balancer_listeners.py +27 -23
  200. cartography/models/aws/ec2/load_balancers.py +47 -37
  201. cartography/models/aws/ec2/network_acl_rules.py +38 -30
  202. cartography/models/aws/ec2/network_acls.py +38 -29
  203. cartography/models/aws/ec2/networkinterface_instance.py +52 -39
  204. cartography/models/aws/ec2/networkinterfaces.py +53 -37
  205. cartography/models/aws/ec2/privateip_networkinterface.py +32 -22
  206. cartography/models/aws/ec2/reservations.py +18 -14
  207. cartography/models/aws/ec2/route_table_associations.py +97 -0
  208. cartography/models/aws/ec2/route_tables.py +128 -0
  209. cartography/models/aws/ec2/routes.py +85 -0
  210. cartography/models/aws/ec2/securitygroup_instance.py +29 -20
  211. cartography/models/aws/ec2/securitygroup_networkinterface.py +24 -15
  212. cartography/models/aws/ec2/subnet_instance.py +24 -19
  213. cartography/models/aws/ec2/subnet_networkinterface.py +40 -31
  214. cartography/models/aws/ec2/volumes.py +47 -40
  215. cartography/models/aws/efs/__init__.py +0 -0
  216. cartography/models/aws/efs/mount_target.py +52 -0
  217. cartography/models/aws/eks/clusters.py +23 -21
  218. cartography/models/aws/emr.py +32 -30
  219. cartography/models/aws/iam/instanceprofile.py +33 -24
  220. cartography/models/aws/identitycenter/awsidentitycenter.py +18 -14
  221. cartography/models/aws/identitycenter/awspermissionset.py +37 -29
  222. cartography/models/aws/identitycenter/awsssouser.py +23 -21
  223. cartography/models/aws/inspector/findings.py +77 -65
  224. cartography/models/aws/inspector/packages.py +35 -29
  225. cartography/models/aws/s3/__init__.py +0 -0
  226. cartography/models/aws/s3/account_public_access_block.py +51 -0
  227. cartography/models/aws/sns/__init__.py +0 -0
  228. cartography/models/aws/sns/topic.py +50 -0
  229. cartography/models/aws/ssm/instance_information.py +51 -39
  230. cartography/models/aws/ssm/instance_patch.py +32 -26
  231. cartography/models/bigfix/bigfix_computer.py +42 -38
  232. cartography/models/bigfix/bigfix_root.py +3 -3
  233. cartography/models/cloudflare/__init__.py +0 -0
  234. cartography/models/cloudflare/account.py +25 -0
  235. cartography/models/cloudflare/dnsrecord.py +55 -0
  236. cartography/models/cloudflare/member.py +82 -0
  237. cartography/models/cloudflare/role.py +44 -0
  238. cartography/models/cloudflare/zone.py +59 -0
  239. cartography/models/core/common.py +12 -10
  240. cartography/models/core/nodes.py +5 -2
  241. cartography/models/core/relationships.py +14 -6
  242. cartography/models/crowdstrike/hosts.py +37 -35
  243. cartography/models/cve/cve.py +34 -32
  244. cartography/models/cve/cve_feed.py +6 -6
  245. cartography/models/digitalocean/__init__.py +0 -0
  246. cartography/models/digitalocean/account.py +21 -0
  247. cartography/models/digitalocean/droplet.py +56 -0
  248. cartography/models/digitalocean/project.py +48 -0
  249. cartography/models/duo/api_host.py +3 -3
  250. cartography/models/duo/endpoint.py +43 -41
  251. cartography/models/duo/group.py +14 -14
  252. cartography/models/duo/phone.py +27 -27
  253. cartography/models/duo/token.py +16 -16
  254. cartography/models/duo/user.py +46 -44
  255. cartography/models/duo/web_authn_credential.py +27 -19
  256. cartography/models/entra/ou.py +48 -0
  257. cartography/models/entra/tenant.py +24 -18
  258. cartography/models/entra/user.py +64 -48
  259. cartography/models/gcp/iam.py +23 -23
  260. cartography/models/github/orgs.py +5 -4
  261. cartography/models/github/teams.py +37 -31
  262. cartography/models/github/users.py +34 -23
  263. cartography/models/kandji/device.py +22 -16
  264. cartography/models/kandji/tenant.py +6 -4
  265. cartography/models/lastpass/tenant.py +3 -3
  266. cartography/models/lastpass/user.py +32 -28
  267. cartography/models/openai/__init__.py +0 -0
  268. cartography/models/openai/adminapikey.py +90 -0
  269. cartography/models/openai/apikey.py +84 -0
  270. cartography/models/openai/organization.py +17 -0
  271. cartography/models/openai/project.py +70 -0
  272. cartography/models/openai/serviceaccount.py +50 -0
  273. cartography/models/openai/user.py +49 -0
  274. cartography/models/semgrep/dependencies.py +36 -24
  275. cartography/models/semgrep/deployment.py +5 -5
  276. cartography/models/semgrep/findings.py +58 -42
  277. cartography/models/semgrep/locations.py +27 -21
  278. cartography/models/snipeit/asset.py +30 -21
  279. cartography/models/snipeit/tenant.py +6 -4
  280. cartography/models/snipeit/user.py +19 -12
  281. cartography/models/tailscale/__init__.py +0 -0
  282. cartography/models/tailscale/device.py +95 -0
  283. cartography/models/tailscale/group.py +86 -0
  284. cartography/models/tailscale/postureintegration.py +58 -0
  285. cartography/models/tailscale/tag.py +102 -0
  286. cartography/models/tailscale/tailnet.py +29 -0
  287. cartography/models/tailscale/user.py +52 -0
  288. cartography/stats.py +3 -3
  289. cartography/sync.py +113 -31
  290. cartography/util.py +84 -62
  291. {cartography-0.102.0rc1.dist-info → cartography-0.103.0.dist-info}/METADATA +8 -15
  292. cartography-0.103.0.dist-info/RECORD +442 -0
  293. {cartography-0.102.0rc1.dist-info → cartography-0.103.0.dist-info}/WHEEL +1 -1
  294. cartography-0.102.0rc1.dist-info/RECORD +0 -377
  295. {cartography-0.102.0rc1.dist-info → cartography-0.103.0.dist-info}/entry_points.txt +0 -0
  296. {cartography-0.102.0rc1.dist-info → cartography-0.103.0.dist-info}/licenses/LICENSE +0 -0
  297. {cartography-0.102.0rc1.dist-info → cartography-0.103.0.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,82 @@
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 CloudflareMemberNodeProperties(CartographyNodeProperties):
16
+ status: PropertyRef = PropertyRef("status")
17
+ email: PropertyRef = PropertyRef("user.email")
18
+ firstname: PropertyRef = PropertyRef("user.first_name")
19
+ user_id: PropertyRef = PropertyRef("user.id")
20
+ lastname: PropertyRef = PropertyRef("user.last_name")
21
+ two_factor_authentication_enabled: PropertyRef = PropertyRef(
22
+ "user.two_factor_authentication_enabled"
23
+ )
24
+ id: PropertyRef = PropertyRef("id")
25
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
26
+
27
+
28
+ @dataclass(frozen=True)
29
+ class CloudflareMemberToAccountRelProperties(CartographyRelProperties):
30
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
31
+
32
+
33
+ @dataclass(frozen=True)
34
+ # (:CloudflareMember)<-[:RESOURCE]-(:CloudflareAccount)
35
+ class CloudflareMemberToAccountRel(CartographyRelSchema):
36
+ target_node_label: str = "CloudflareAccount"
37
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
38
+ {"id": PropertyRef("account_id", set_in_kwargs=True)},
39
+ )
40
+ direction: LinkDirection = LinkDirection.INWARD
41
+ rel_label: str = "RESOURCE"
42
+ properties: CloudflareMemberToAccountRelProperties = (
43
+ CloudflareMemberToAccountRelProperties()
44
+ )
45
+
46
+
47
+ @dataclass(frozen=True)
48
+ class CloudflareMemberToCloudflareRoleProperties(CartographyRelProperties):
49
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
50
+
51
+
52
+ @dataclass(frozen=True)
53
+ # (:CloudflareRole)<-[:HAS_ROLE]-(:CloudflareMember)
54
+ class CloudflareMemberToCloudflareRoleRel(CartographyRelSchema):
55
+ target_node_label: str = "CloudflareRole"
56
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
57
+ {
58
+ "id": PropertyRef(
59
+ "roles_ids",
60
+ one_to_many=True,
61
+ )
62
+ },
63
+ )
64
+ direction: LinkDirection = LinkDirection.OUTWARD
65
+ rel_label: str = "HAS_ROLE"
66
+ properties: CloudflareMemberToCloudflareRoleProperties = (
67
+ CloudflareMemberToCloudflareRoleProperties()
68
+ )
69
+
70
+
71
+ @dataclass(frozen=True)
72
+ class CloudflareMemberSchema(CartographyNodeSchema):
73
+ label: str = "CloudflareMember"
74
+ properties: CloudflareMemberNodeProperties = CloudflareMemberNodeProperties()
75
+ sub_resource_relationship: CloudflareMemberToAccountRel = (
76
+ CloudflareMemberToAccountRel()
77
+ )
78
+ other_relationships: OtherRelationships = OtherRelationships(
79
+ [
80
+ CloudflareMemberToCloudflareRoleRel(),
81
+ ],
82
+ )
@@ -0,0 +1,44 @@
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 CloudflareRoleNodeProperties(CartographyNodeProperties):
15
+ description: PropertyRef = PropertyRef("description")
16
+ name: PropertyRef = PropertyRef("name")
17
+ id: PropertyRef = PropertyRef("id")
18
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
19
+
20
+
21
+ @dataclass(frozen=True)
22
+ class CloudflareRoleToAccountRelProperties(CartographyRelProperties):
23
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
24
+
25
+
26
+ @dataclass(frozen=True)
27
+ # (:CloudflareRole)<-[:RESOURCE]-(:CloudflareAccount)
28
+ class CloudflareRoleToAccountRel(CartographyRelSchema):
29
+ target_node_label: str = "CloudflareAccount"
30
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
31
+ {"id": PropertyRef("account_id", set_in_kwargs=True)},
32
+ )
33
+ direction: LinkDirection = LinkDirection.INWARD
34
+ rel_label: str = "RESOURCE"
35
+ properties: CloudflareRoleToAccountRelProperties = (
36
+ CloudflareRoleToAccountRelProperties()
37
+ )
38
+
39
+
40
+ @dataclass(frozen=True)
41
+ class CloudflareRoleSchema(CartographyNodeSchema):
42
+ label: str = "CloudflareRole"
43
+ properties: CloudflareRoleNodeProperties = CloudflareRoleNodeProperties()
44
+ sub_resource_relationship: CloudflareRoleToAccountRel = CloudflareRoleToAccountRel()
@@ -0,0 +1,59 @@
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 CloudflareZoneNodeProperties(CartographyNodeProperties):
15
+ activated_on: PropertyRef = PropertyRef("activated_on")
16
+ created_on: PropertyRef = PropertyRef("created_on")
17
+ development_mode: PropertyRef = PropertyRef("development_mode")
18
+ cdn_only: PropertyRef = PropertyRef("meta.cdn_only")
19
+ custom_certificate_quota: PropertyRef = PropertyRef("meta.custom_certificate_quota")
20
+ dns_only: PropertyRef = PropertyRef("meta.dns_only")
21
+ foundation_dns: PropertyRef = PropertyRef("meta.foundation_dns")
22
+ page_rule_quota: PropertyRef = PropertyRef("meta.page_rule_quota")
23
+ phishing_detected: PropertyRef = PropertyRef("meta.phishing_detected")
24
+ modified_on: PropertyRef = PropertyRef("modified_on")
25
+ name: PropertyRef = PropertyRef("name")
26
+ original_dnshost: PropertyRef = PropertyRef("original_dnshost")
27
+ original_registrar: PropertyRef = PropertyRef("original_registrar")
28
+ status: PropertyRef = PropertyRef("status")
29
+ verification_key: PropertyRef = PropertyRef("verification_key")
30
+ id: PropertyRef = PropertyRef("id")
31
+ paused: PropertyRef = PropertyRef("paused")
32
+ type: PropertyRef = PropertyRef("type")
33
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
34
+
35
+
36
+ @dataclass(frozen=True)
37
+ class CloudflareZoneToAccountRelProperties(CartographyRelProperties):
38
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
39
+
40
+
41
+ @dataclass(frozen=True)
42
+ # (:CloudflareZone)<-[:RESOURCE]-(:CloudflareAccount)
43
+ class CloudflareZoneToAccountRel(CartographyRelSchema):
44
+ target_node_label: str = "CloudflareAccount"
45
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
46
+ {"id": PropertyRef("account_id", set_in_kwargs=True)},
47
+ )
48
+ direction: LinkDirection = LinkDirection.INWARD
49
+ rel_label: str = "RESOURCE"
50
+ properties: CloudflareZoneToAccountRelProperties = (
51
+ CloudflareZoneToAccountRelProperties()
52
+ )
53
+
54
+
55
+ @dataclass(frozen=True)
56
+ class CloudflareZoneSchema(CartographyNodeSchema):
57
+ label: str = "CloudflareZone"
58
+ properties: CloudflareZoneNodeProperties = CloudflareZoneNodeProperties()
59
+ sub_resource_relationship: CloudflareZoneToAccountRel = CloudflareZoneToAccountRel()
@@ -9,13 +9,13 @@ class PropertyRef:
9
9
  """
10
10
 
11
11
  def __init__(
12
- self,
13
- name: str,
14
- set_in_kwargs=False,
15
- extra_index=False,
16
- ignore_case=False,
17
- fuzzy_and_ignore_case=False,
18
- one_to_many=False,
12
+ self,
13
+ name: str,
14
+ set_in_kwargs=False,
15
+ extra_index=False,
16
+ ignore_case=False,
17
+ fuzzy_and_ignore_case=False,
18
+ one_to_many=False,
19
19
  ):
20
20
  """
21
21
  :param name: The name of the property
@@ -74,13 +74,13 @@ class PropertyRef:
74
74
  if self.fuzzy_and_ignore_case and self.ignore_case:
75
75
  raise ValueError(
76
76
  f'Error setting PropertyRef "{self.name}": ignore_case cannot be used together with'
77
- 'fuzzy_and_ignore_case. Pick one or the other.',
77
+ "fuzzy_and_ignore_case. Pick one or the other.",
78
78
  )
79
79
 
80
80
  if self.one_to_many and (self.ignore_case or self.fuzzy_and_ignore_case):
81
81
  raise ValueError(
82
82
  f'Error setting PropertyRef "{self.name}": one_to_many cannot be used together with '
83
- '`ignore_case` or `fuzzy_and_ignore_case`.',
83
+ "`ignore_case` or `fuzzy_and_ignore_case`.",
84
84
  )
85
85
 
86
86
  def _parameterize_name(self) -> str:
@@ -103,4 +103,6 @@ class PropertyRef:
103
103
  querybuilder.build_ingestion_query(). This is used for things like applying the same update tag to all nodes of
104
104
  a given run.
105
105
  """
106
- return f"item.{self.name}" if not self.set_in_kwargs else self._parameterize_name()
106
+ return (
107
+ f"item.{self.name}" if not self.set_in_kwargs else self._parameterize_name()
108
+ )
@@ -16,6 +16,7 @@ class CartographyNodeProperties(abc.ABC):
16
16
  can enforce that all subclasses have an id and a lastupdated field. These fields are assigned to the node in the
17
17
  `SET` clause.
18
18
  """
19
+
19
20
  id: PropertyRef = field(init=False)
20
21
  lastupdated: PropertyRef = field(init=False)
21
22
 
@@ -24,12 +25,12 @@ class CartographyNodeProperties(abc.ABC):
24
25
  Data validation.
25
26
  1. Prevents direct instantiation. This workaround is needed since this is a dataclass and an abstract
26
27
  class without an abstract method defined. See https://stackoverflow.com/q/60590442.
27
- 2. Stops reserved words from being used as attribute names. See https://github.com/lyft/cartography/issues/1064.
28
+ 2. Stops reserved words from being used as attribute names. See https://github.com/cartography-cncf/cartography/issues/1064.
28
29
  """
29
30
  if self.__class__ == CartographyNodeProperties:
30
31
  raise TypeError("Cannot instantiate abstract class.")
31
32
 
32
- if hasattr(self, 'firstseen'):
33
+ if hasattr(self, "firstseen"):
33
34
  raise TypeError(
34
35
  "`firstseen` is a reserved word and is automatically set by the querybuilder on cartography nodes, so "
35
36
  f'it cannot be used on class "{type(self).__name__}(CartographyNodeProperties)". Please either choose '
@@ -43,6 +44,7 @@ class ExtraNodeLabels:
43
44
  Encapsulates a list of str representing additional labels for the CartographyNodeSchema that this is composed on.
44
45
  This wrapping is used to ensure dataclass immutability for the CartographyNodeSchema.
45
46
  """
47
+
46
48
  labels: List[str]
47
49
 
48
50
 
@@ -52,6 +54,7 @@ class CartographyNodeSchema(abc.ABC):
52
54
  Abstract base dataclass that represents a graph node in cartography. This is used to dynamically generate graph
53
55
  ingestion queries.
54
56
  """
57
+
55
58
  @property
56
59
  @abc.abstractmethod
57
60
  def label(self) -> str:
@@ -19,18 +19,19 @@ class LinkDirection(Enum):
19
19
 
20
20
  class EMRCluster(CartographyNodeSchema):
21
21
  label: str = "EMRCluster"
22
- sub_resource_relationship: CartographyRelSchema = EMRClusterToAWSAccount()
22
+ sub_resource_relationship: CartographyRelSchema = EMRClusterToAWSAccountRel()
23
23
  # ...
24
24
 
25
- class EMRClusterToAWSAccount(CartographyRelSchema):
25
+ class EMRClusterToAWSAccountRel(CartographyRelSchema):
26
26
  target_node_label: str = "AWSAccount"
27
27
  rel_label: str = "RESOURCE"
28
28
  direction: LinkDirection = LinkDirection.INWARD
29
29
  # ...
30
30
 
31
- If `EMRClusterToAWSAccount.direction` was LinkDirection.OUTWARD, then the directionality of the relationship would
31
+ If `EMRClusterToAWSAccountRel.direction` was LinkDirection.OUTWARD, then the directionality of the relationship would
32
32
  be `(:EMRCluster)-[:RESOURCE]->(:AWSAccount)` instead.
33
33
  """
34
+
34
35
  INWARD = auto()
35
36
  OUTWARD = auto()
36
37
 
@@ -42,6 +43,7 @@ class CartographyRelProperties(abc.ABC):
42
43
  subclasses will have a lastupdated field defined on their resulting relationships. These fields are assigned to the
43
44
  relationship in the `SET` clause.
44
45
  """
46
+
45
47
  lastupdated: PropertyRef = field(init=False)
46
48
 
47
49
  def __post_init__(self):
@@ -49,12 +51,12 @@ class CartographyRelProperties(abc.ABC):
49
51
  Data validation.
50
52
  1. Prevents direct instantiation. This workaround is needed since this is a dataclass and an abstract
51
53
  class without an abstract method defined. See https://stackoverflow.com/q/60590442.
52
- 2. Stops reserved words from being used as attribute names. See https://github.com/lyft/cartography/issues/1064.
54
+ 2. Stops reserved words from being used as attribute names. See https://github.com/cartography-cncf/cartography/issues/1064.
53
55
  """
54
56
  if self.__class__ == CartographyRelProperties:
55
57
  raise TypeError("Cannot instantiate abstract class.")
56
58
 
57
- if hasattr(self, 'firstseen'):
59
+ if hasattr(self, "firstseen"):
58
60
  raise TypeError(
59
61
  "`firstseen` is a reserved word and is automatically set by the querybuilder on cartography rels, so "
60
62
  f'it cannot be used on class "{type(self).__name__}(CartographyRelProperties)". Please either choose '
@@ -72,6 +74,7 @@ class TargetNodeMatcher:
72
74
  This is used to ensure dataclass immutability when composed as part of a CartographyNodeSchema object.
73
75
  See `make_target_node_matcher()`.
74
76
  """
77
+
75
78
  pass
76
79
 
77
80
 
@@ -80,7 +83,10 @@ def make_target_node_matcher(key_ref_dict: Dict[str, PropertyRef]) -> TargetNode
80
83
  :param key_ref_dict: A Dict mapping keys present on the node to PropertyRef objects.
81
84
  :return: A TargetNodeMatcher used for CartographyRelSchema to match with other nodes.
82
85
  """
83
- fields = [(key, PropertyRef, field(default=prop_ref)) for key, prop_ref in key_ref_dict.items()]
86
+ fields = [
87
+ (key, PropertyRef, field(default=prop_ref))
88
+ for key, prop_ref in key_ref_dict.items()
89
+ ]
84
90
  return make_dataclass(TargetNodeMatcher.__name__, fields, frozen=True)()
85
91
 
86
92
 
@@ -92,6 +98,7 @@ class CartographyRelSchema(abc.ABC):
92
98
  The CartographyRelSchema contains properties that make it possible to connect the CartographyNodeSchema to other
93
99
  existing nodes in the graph.
94
100
  """
101
+
95
102
  @property
96
103
  @abc.abstractmethod
97
104
  def properties(self) -> CartographyRelProperties:
@@ -139,4 +146,5 @@ class OtherRelationships:
139
146
  Encapsulates a list of CartographyRelSchema. This is used to ensure dataclass immutability when composed as part of
140
147
  a CartographyNodeSchema object.
141
148
  """
149
+
142
150
  rels: List[CartographyRelSchema]
@@ -7,43 +7,45 @@ from cartography.models.core.nodes import CartographyNodeSchema
7
7
 
8
8
  @dataclass(frozen=True)
9
9
  class CrowdstrikeHostNodeProperties(CartographyNodeProperties):
10
- id: PropertyRef = PropertyRef('device_id')
11
- cid: PropertyRef = PropertyRef('cid')
12
- instance_id: PropertyRef = PropertyRef('instance_id', extra_index=True)
13
- serial_number: PropertyRef = PropertyRef('serial_number', extra_index=True)
14
- status: PropertyRef = PropertyRef('status')
15
- hostname: PropertyRef = PropertyRef('hostname')
16
- machine_domain: PropertyRef = PropertyRef('machine_domain')
17
- crowdstrike_first_seen: PropertyRef = PropertyRef('first_seen')
18
- crowdstrike_last_seen: PropertyRef = PropertyRef('last_seen')
19
- local_ip: PropertyRef = PropertyRef('local_ip')
20
- external_ip: PropertyRef = PropertyRef('external_ip')
21
- cpu_signature: PropertyRef = PropertyRef('cpu_signature')
22
- bios_manufacturer: PropertyRef = PropertyRef('bios_manufacturer')
23
- bios_version: PropertyRef = PropertyRef('bios_version')
24
- mac_address: PropertyRef = PropertyRef('mac_address')
25
- os_version: PropertyRef = PropertyRef('os_version')
26
- os_build: PropertyRef = PropertyRef('os_build')
27
- platform_id: PropertyRef = PropertyRef('platform_id')
28
- platform_name: PropertyRef = PropertyRef('platform_name')
29
- service_provider: PropertyRef = PropertyRef('service_provider')
30
- service_provider_account_id: PropertyRef = PropertyRef('service_provider_account_id')
31
- agent_version: PropertyRef = PropertyRef('agent_version')
32
- system_manufacturer: PropertyRef = PropertyRef('system_manufacturer')
33
- system_product_name: PropertyRef = PropertyRef('system_product_name')
34
- product_type: PropertyRef = PropertyRef('product_type')
35
- product_type_desc: PropertyRef = PropertyRef('product_type_desc')
36
- provision_status: PropertyRef = PropertyRef('provision_status')
37
- reduced_functionality_mode: PropertyRef = PropertyRef('reduced_functionality_mode')
38
- kernel_version: PropertyRef = PropertyRef('kernel_version')
39
- major_version: PropertyRef = PropertyRef('major_version')
40
- minor_version: PropertyRef = PropertyRef('minor_version')
41
- tags: PropertyRef = PropertyRef('tags')
42
- modified_timestamp: PropertyRef = PropertyRef('modified_timestamp')
43
- lastupdated: PropertyRef = PropertyRef('lastupdated', set_in_kwargs=True)
10
+ id: PropertyRef = PropertyRef("device_id")
11
+ cid: PropertyRef = PropertyRef("cid")
12
+ instance_id: PropertyRef = PropertyRef("instance_id", extra_index=True)
13
+ serial_number: PropertyRef = PropertyRef("serial_number", extra_index=True)
14
+ status: PropertyRef = PropertyRef("status")
15
+ hostname: PropertyRef = PropertyRef("hostname")
16
+ machine_domain: PropertyRef = PropertyRef("machine_domain")
17
+ crowdstrike_first_seen: PropertyRef = PropertyRef("first_seen")
18
+ crowdstrike_last_seen: PropertyRef = PropertyRef("last_seen")
19
+ local_ip: PropertyRef = PropertyRef("local_ip")
20
+ external_ip: PropertyRef = PropertyRef("external_ip")
21
+ cpu_signature: PropertyRef = PropertyRef("cpu_signature")
22
+ bios_manufacturer: PropertyRef = PropertyRef("bios_manufacturer")
23
+ bios_version: PropertyRef = PropertyRef("bios_version")
24
+ mac_address: PropertyRef = PropertyRef("mac_address")
25
+ os_version: PropertyRef = PropertyRef("os_version")
26
+ os_build: PropertyRef = PropertyRef("os_build")
27
+ platform_id: PropertyRef = PropertyRef("platform_id")
28
+ platform_name: PropertyRef = PropertyRef("platform_name")
29
+ service_provider: PropertyRef = PropertyRef("service_provider")
30
+ service_provider_account_id: PropertyRef = PropertyRef(
31
+ "service_provider_account_id"
32
+ )
33
+ agent_version: PropertyRef = PropertyRef("agent_version")
34
+ system_manufacturer: PropertyRef = PropertyRef("system_manufacturer")
35
+ system_product_name: PropertyRef = PropertyRef("system_product_name")
36
+ product_type: PropertyRef = PropertyRef("product_type")
37
+ product_type_desc: PropertyRef = PropertyRef("product_type_desc")
38
+ provision_status: PropertyRef = PropertyRef("provision_status")
39
+ reduced_functionality_mode: PropertyRef = PropertyRef("reduced_functionality_mode")
40
+ kernel_version: PropertyRef = PropertyRef("kernel_version")
41
+ major_version: PropertyRef = PropertyRef("major_version")
42
+ minor_version: PropertyRef = PropertyRef("minor_version")
43
+ tags: PropertyRef = PropertyRef("tags")
44
+ modified_timestamp: PropertyRef = PropertyRef("modified_timestamp")
45
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
44
46
 
45
47
 
46
48
  @dataclass(frozen=True)
47
49
  class CrowdstrikeHostSchema(CartographyNodeSchema):
48
- label: str = 'CrowdstrikeHost'
50
+ label: str = "CrowdstrikeHost"
49
51
  properties: CrowdstrikeHostNodeProperties = CrowdstrikeHostNodeProperties()
@@ -13,41 +13,41 @@ from cartography.models.core.relationships import TargetNodeMatcher
13
13
 
14
14
  @dataclass(frozen=True)
15
15
  class CVENodeProperties(CartographyNodeProperties):
16
- id: PropertyRef = PropertyRef('id')
17
- assigner: PropertyRef = PropertyRef('sourceIdentifier')
18
- description: PropertyRef = PropertyRef('descriptions_en')
19
- references: PropertyRef = PropertyRef('references_urls')
20
- problem_types: PropertyRef = PropertyRef('weaknesses')
21
- vector_string: PropertyRef = PropertyRef('vectorString')
22
- attack_vector: PropertyRef = PropertyRef('attackVector')
23
- attack_complexity: PropertyRef = PropertyRef('attackComplexity')
24
- privileges_required: PropertyRef = PropertyRef('privilegesRequired')
25
- user_interaction: PropertyRef = PropertyRef('userInteraction')
26
- scope: PropertyRef = PropertyRef('scope')
27
- confidentiality_impact: PropertyRef = PropertyRef('confidentialityImpact')
28
- integrity_impact: PropertyRef = PropertyRef('integrityImpact')
29
- availability_impact: PropertyRef = PropertyRef('availabilityImpact')
30
- base_score: PropertyRef = PropertyRef('baseScore')
31
- base_severity: PropertyRef = PropertyRef('baseSeverity')
32
- exploitability_score: PropertyRef = PropertyRef('exploitabilityScore')
33
- impact_score: PropertyRef = PropertyRef('impactScore')
34
- published_date: PropertyRef = PropertyRef('published')
35
- last_modified_date: PropertyRef = PropertyRef('lastModified')
36
- vuln_status: PropertyRef = PropertyRef('vulnStatus')
37
- lastupdated: PropertyRef = PropertyRef('lastupdated')
16
+ id: PropertyRef = PropertyRef("id")
17
+ assigner: PropertyRef = PropertyRef("sourceIdentifier")
18
+ description: PropertyRef = PropertyRef("descriptions_en")
19
+ references: PropertyRef = PropertyRef("references_urls")
20
+ problem_types: PropertyRef = PropertyRef("weaknesses")
21
+ vector_string: PropertyRef = PropertyRef("vectorString")
22
+ attack_vector: PropertyRef = PropertyRef("attackVector")
23
+ attack_complexity: PropertyRef = PropertyRef("attackComplexity")
24
+ privileges_required: PropertyRef = PropertyRef("privilegesRequired")
25
+ user_interaction: PropertyRef = PropertyRef("userInteraction")
26
+ scope: PropertyRef = PropertyRef("scope")
27
+ confidentiality_impact: PropertyRef = PropertyRef("confidentialityImpact")
28
+ integrity_impact: PropertyRef = PropertyRef("integrityImpact")
29
+ availability_impact: PropertyRef = PropertyRef("availabilityImpact")
30
+ base_score: PropertyRef = PropertyRef("baseScore")
31
+ base_severity: PropertyRef = PropertyRef("baseSeverity")
32
+ exploitability_score: PropertyRef = PropertyRef("exploitabilityScore")
33
+ impact_score: PropertyRef = PropertyRef("impactScore")
34
+ published_date: PropertyRef = PropertyRef("published")
35
+ last_modified_date: PropertyRef = PropertyRef("lastModified")
36
+ vuln_status: PropertyRef = PropertyRef("vulnStatus")
37
+ lastupdated: PropertyRef = PropertyRef("lastupdated")
38
38
 
39
39
 
40
40
  @dataclass(frozen=True)
41
41
  class CVEtoCVEFeedRelProperties(CartographyRelProperties):
42
- lastupdated: PropertyRef = PropertyRef('lastupdated', set_in_kwargs=True)
42
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
43
43
 
44
44
 
45
45
  @dataclass(frozen=True)
46
46
  # (:CVE)<-[:RESOURCE]-(:CVEFeed)
47
- class CVEtoCVEFeedRelSchema(CartographyRelSchema):
48
- target_node_label: str = 'CVEFeed'
47
+ class CVEtoCVEFeedRel(CartographyRelSchema):
48
+ target_node_label: str = "CVEFeed"
49
49
  target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
50
- {'id': PropertyRef('FEED_ID', set_in_kwargs=True)},
50
+ {"id": PropertyRef("FEED_ID", set_in_kwargs=True)},
51
51
  )
52
52
  direction: LinkDirection = LinkDirection.INWARD
53
53
  rel_label: str = "RESOURCE"
@@ -56,26 +56,28 @@ class CVEtoCVEFeedRelSchema(CartographyRelSchema):
56
56
 
57
57
  @dataclass(frozen=True)
58
58
  class CVEToSpotlightVulnerabilityRelProperties(CartographyRelProperties):
59
- lastupdated: PropertyRef = PropertyRef('lastupdated', set_in_kwargs=True)
59
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
60
60
 
61
61
 
62
62
  @dataclass(frozen=True)
63
63
  # (:CVE)<-[:HAS_CVE]-(:SpotlightVulnerability)
64
64
  class CVEToSpotlightVulnerabilityRel(CartographyRelSchema):
65
- target_node_label: str = 'SpotlightVulnerability'
65
+ target_node_label: str = "SpotlightVulnerability"
66
66
  target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
67
- {'id': PropertyRef('id')},
67
+ {"id": PropertyRef("id")},
68
68
  )
69
69
  direction: LinkDirection = LinkDirection.INWARD
70
70
  rel_label: str = "HAS_CVE"
71
- properties: CVEToSpotlightVulnerabilityRelProperties = CVEToSpotlightVulnerabilityRelProperties()
71
+ properties: CVEToSpotlightVulnerabilityRelProperties = (
72
+ CVEToSpotlightVulnerabilityRelProperties()
73
+ )
72
74
 
73
75
 
74
76
  @dataclass(frozen=True)
75
77
  class CVESchema(CartographyNodeSchema):
76
- label: str = 'CVE'
78
+ label: str = "CVE"
77
79
  properties: CVENodeProperties = CVENodeProperties()
78
- sub_resource_relationship: CVEtoCVEFeedRelSchema = CVEtoCVEFeedRelSchema()
80
+ sub_resource_relationship: CVEtoCVEFeedRel = CVEtoCVEFeedRel()
79
81
  other_relationships: OtherRelationships = OtherRelationships(
80
82
  [
81
83
  CVEToSpotlightVulnerabilityRel(),
@@ -7,14 +7,14 @@ from cartography.models.core.nodes import CartographyNodeSchema
7
7
 
8
8
  @dataclass(frozen=True)
9
9
  class CVEFeedNodeProperties(CartographyNodeProperties):
10
- id: PropertyRef = PropertyRef('FEED_ID')
11
- lastupdated: PropertyRef = PropertyRef('lastupdated', set_in_kwargs=True)
12
- format: PropertyRef = PropertyRef('format')
13
- version: PropertyRef = PropertyRef('version')
14
- timestamp: PropertyRef = PropertyRef('timestamp')
10
+ id: PropertyRef = PropertyRef("FEED_ID")
11
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
12
+ format: PropertyRef = PropertyRef("format")
13
+ version: PropertyRef = PropertyRef("version")
14
+ timestamp: PropertyRef = PropertyRef("timestamp")
15
15
 
16
16
 
17
17
  @dataclass(frozen=True)
18
18
  class CVEFeedSchema(CartographyNodeSchema):
19
- label: str = 'CVEFeed'
19
+ label: str = "CVEFeed"
20
20
  properties: CVEFeedNodeProperties = CVEFeedNodeProperties()
File without changes
@@ -0,0 +1,21 @@
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 DOAccountNodeProperties(CartographyNodeProperties):
10
+ id: PropertyRef = PropertyRef("id")
11
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
12
+ uuid: PropertyRef = PropertyRef("uuid")
13
+ droplet_limit: PropertyRef = PropertyRef("droplet_limit")
14
+ floating_ip_limit: PropertyRef = PropertyRef("floating_ip_limit")
15
+ status: PropertyRef = PropertyRef("status")
16
+
17
+
18
+ @dataclass(frozen=True)
19
+ class DOAccountSchema(CartographyNodeSchema):
20
+ label: str = "DOAccount"
21
+ properties: DOAccountNodeProperties = DOAccountNodeProperties()
@@ -0,0 +1,56 @@
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 DODropletNodeProperties(CartographyNodeProperties):
15
+ id: PropertyRef = PropertyRef("id")
16
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
17
+ name: PropertyRef = PropertyRef("name")
18
+ locked: PropertyRef = PropertyRef("locked")
19
+ status: PropertyRef = PropertyRef("status")
20
+ region: PropertyRef = PropertyRef("region")
21
+ created_at: PropertyRef = PropertyRef("created_at")
22
+ image: PropertyRef = PropertyRef("image")
23
+ size: PropertyRef = PropertyRef("size")
24
+ kernel: PropertyRef = PropertyRef("kernel")
25
+ tags: PropertyRef = PropertyRef("tags")
26
+ volumes: PropertyRef = PropertyRef("volumes")
27
+ vpc_uuid: PropertyRef = PropertyRef("vpc_uuid")
28
+ ip_address: PropertyRef = PropertyRef("ip_address")
29
+ private_ip_address: PropertyRef = PropertyRef("private_ip_address")
30
+ ip_v6_address: PropertyRef = PropertyRef("ip_v6_address")
31
+ account_id: PropertyRef = PropertyRef("ACCOUNT_ID", set_in_kwargs=True)
32
+ project_id: PropertyRef = PropertyRef("PROJECT_ID", set_in_kwargs=True)
33
+
34
+
35
+ @dataclass(frozen=True)
36
+ class DODropletToAccountRelProperties(CartographyRelProperties):
37
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
38
+
39
+
40
+ @dataclass(frozen=True)
41
+ # (:DOProject)<-[:RESOURCE]-(:DODroplet)
42
+ class DODropletToAccountRel(CartographyRelSchema):
43
+ target_node_label: str = "DOProject"
44
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
45
+ {"id": PropertyRef("PROJECT_ID", set_in_kwargs=True)},
46
+ )
47
+ direction: LinkDirection = LinkDirection.OUTWARD
48
+ rel_label: str = "RESOURCE"
49
+ properties: DODropletToAccountRelProperties = DODropletToAccountRelProperties()
50
+
51
+
52
+ @dataclass(frozen=True)
53
+ class DODropletSchema(CartographyNodeSchema):
54
+ label: str = "DODroplet"
55
+ properties: DODropletNodeProperties = DODropletNodeProperties()
56
+ sub_resource_relationship: DODropletToAccountRel = DODropletToAccountRel()