cartography 0.108.0rc1__py3-none-any.whl → 0.109.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 (81) 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 -17
  5. cartography/data/jobs/cleanup/gcp_compute_vpc_cleanup.json +0 -12
  6. cartography/intel/aws/cloudtrail.py +17 -4
  7. cartography/intel/aws/cloudtrail_management_events.py +614 -16
  8. cartography/intel/aws/cloudwatch.py +73 -4
  9. cartography/intel/aws/ec2/subnets.py +37 -63
  10. cartography/intel/aws/ecr.py +55 -80
  11. cartography/intel/aws/elasticache.py +102 -79
  12. cartography/intel/aws/eventbridge.py +91 -0
  13. cartography/intel/aws/glue.py +117 -0
  14. cartography/intel/aws/identitycenter.py +71 -23
  15. cartography/intel/aws/kms.py +160 -200
  16. cartography/intel/aws/lambda_function.py +206 -190
  17. cartography/intel/aws/rds.py +243 -458
  18. cartography/intel/aws/resourcegroupstaggingapi.py +77 -18
  19. cartography/intel/aws/resources.py +4 -0
  20. cartography/intel/aws/route53.py +334 -332
  21. cartography/intel/aws/secretsmanager.py +62 -44
  22. cartography/intel/entra/groups.py +29 -1
  23. cartography/intel/gcp/__init__.py +10 -0
  24. cartography/intel/gcp/compute.py +19 -42
  25. cartography/intel/trivy/__init__.py +73 -13
  26. cartography/intel/trivy/scanner.py +115 -92
  27. cartography/models/aws/cloudtrail/management_events.py +95 -6
  28. cartography/models/aws/cloudtrail/trail.py +21 -0
  29. cartography/models/aws/cloudwatch/metric_alarm.py +53 -0
  30. cartography/models/aws/ec2/subnets.py +65 -0
  31. cartography/models/aws/ecr/__init__.py +0 -0
  32. cartography/models/aws/ecr/image.py +41 -0
  33. cartography/models/aws/ecr/repository.py +72 -0
  34. cartography/models/aws/ecr/repository_image.py +95 -0
  35. cartography/models/aws/elasticache/__init__.py +0 -0
  36. cartography/models/aws/elasticache/cluster.py +65 -0
  37. cartography/models/aws/elasticache/topic.py +67 -0
  38. cartography/models/aws/eventbridge/__init__.py +0 -0
  39. cartography/models/aws/eventbridge/rule.py +77 -0
  40. cartography/models/aws/glue/__init__.py +0 -0
  41. cartography/models/aws/glue/connection.py +51 -0
  42. cartography/models/aws/identitycenter/awspermissionset.py +44 -0
  43. cartography/models/aws/kms/__init__.py +0 -0
  44. cartography/models/aws/kms/aliases.py +86 -0
  45. cartography/models/aws/kms/grants.py +65 -0
  46. cartography/models/aws/kms/keys.py +88 -0
  47. cartography/models/aws/lambda_function/__init__.py +0 -0
  48. cartography/models/aws/lambda_function/alias.py +74 -0
  49. cartography/models/aws/lambda_function/event_source_mapping.py +88 -0
  50. cartography/models/aws/lambda_function/lambda_function.py +89 -0
  51. cartography/models/aws/lambda_function/layer.py +72 -0
  52. cartography/models/aws/rds/__init__.py +0 -0
  53. cartography/models/aws/rds/cluster.py +89 -0
  54. cartography/models/aws/rds/instance.py +154 -0
  55. cartography/models/aws/rds/snapshot.py +108 -0
  56. cartography/models/aws/rds/subnet_group.py +101 -0
  57. cartography/models/aws/route53/__init__.py +0 -0
  58. cartography/models/aws/route53/dnsrecord.py +214 -0
  59. cartography/models/aws/route53/nameserver.py +63 -0
  60. cartography/models/aws/route53/subzone.py +40 -0
  61. cartography/models/aws/route53/zone.py +47 -0
  62. cartography/models/aws/secretsmanager/secret.py +106 -0
  63. cartography/models/entra/group.py +26 -0
  64. cartography/models/entra/user.py +6 -0
  65. cartography/models/gcp/compute/__init__.py +0 -0
  66. cartography/models/gcp/compute/vpc.py +50 -0
  67. cartography/util.py +8 -1
  68. {cartography-0.108.0rc1.dist-info → cartography-0.109.0.dist-info}/METADATA +2 -2
  69. {cartography-0.108.0rc1.dist-info → cartography-0.109.0.dist-info}/RECORD +73 -44
  70. cartography/data/jobs/cleanup/aws_dns_cleanup.json +0 -65
  71. cartography/data/jobs/cleanup/aws_import_identity_center_cleanup.json +0 -16
  72. cartography/data/jobs/cleanup/aws_import_lambda_cleanup.json +0 -50
  73. cartography/data/jobs/cleanup/aws_import_rds_clusters_cleanup.json +0 -23
  74. cartography/data/jobs/cleanup/aws_import_rds_instances_cleanup.json +0 -47
  75. cartography/data/jobs/cleanup/aws_import_rds_snapshots_cleanup.json +0 -23
  76. cartography/data/jobs/cleanup/aws_import_secrets_cleanup.json +0 -8
  77. cartography/data/jobs/cleanup/aws_kms_details.json +0 -10
  78. {cartography-0.108.0rc1.dist-info → cartography-0.109.0.dist-info}/WHEEL +0 -0
  79. {cartography-0.108.0rc1.dist-info → cartography-0.109.0.dist-info}/entry_points.txt +0 -0
  80. {cartography-0.108.0rc1.dist-info → cartography-0.109.0.dist-info}/licenses/LICENSE +0 -0
  81. {cartography-0.108.0rc1.dist-info → cartography-0.109.0.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,74 @@
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 AWSLambdaFunctionAliasNodeProperties(CartographyNodeProperties):
16
+ id: PropertyRef = PropertyRef("AliasArn")
17
+ arn: PropertyRef = PropertyRef("AliasArn", extra_index=True)
18
+ aliasname: PropertyRef = PropertyRef("Name")
19
+ functionversion: PropertyRef = PropertyRef("FunctionVersion")
20
+ description: PropertyRef = PropertyRef("Description")
21
+ revisionid: PropertyRef = PropertyRef("RevisionId")
22
+ functionarn: PropertyRef = PropertyRef("FunctionArn")
23
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
24
+
25
+
26
+ @dataclass(frozen=True)
27
+ class AWSLambdaFunctionAliasToAWSAccountRelProperties(CartographyRelProperties):
28
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
29
+
30
+
31
+ # Standard relationship: AWSLambda --[:KNOWN_AS]--> AWSLambdaFunctionAlias
32
+ @dataclass(frozen=True)
33
+ class AWSLambdaToAliasRelProperties(CartographyRelProperties):
34
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
35
+
36
+
37
+ @dataclass(frozen=True)
38
+ class AWSLambdaToAliasRel(CartographyRelSchema):
39
+ target_node_label: str = "AWSLambda"
40
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
41
+ {"id": PropertyRef("FunctionArn")},
42
+ )
43
+ direction: LinkDirection = LinkDirection.INWARD
44
+ rel_label: str = "KNOWN_AS"
45
+ properties: AWSLambdaToAliasRelProperties = AWSLambdaToAliasRelProperties()
46
+
47
+
48
+ @dataclass(frozen=True)
49
+ class AWSLambdaFunctionAliasToAWSAccountRel(CartographyRelSchema):
50
+ target_node_label: str = "AWSAccount"
51
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
52
+ {"id": PropertyRef("AWS_ID", set_in_kwargs=True)},
53
+ )
54
+ direction: LinkDirection = LinkDirection.INWARD
55
+ rel_label: str = "RESOURCE"
56
+ properties: AWSLambdaFunctionAliasToAWSAccountRelProperties = (
57
+ AWSLambdaFunctionAliasToAWSAccountRelProperties()
58
+ )
59
+
60
+
61
+ @dataclass(frozen=True)
62
+ class AWSLambdaFunctionAliasSchema(CartographyNodeSchema):
63
+ label: str = "AWSLambdaFunctionAlias"
64
+ properties: AWSLambdaFunctionAliasNodeProperties = (
65
+ AWSLambdaFunctionAliasNodeProperties()
66
+ )
67
+ sub_resource_relationship: AWSLambdaFunctionAliasToAWSAccountRel = (
68
+ AWSLambdaFunctionAliasToAWSAccountRel()
69
+ )
70
+ other_relationships: OtherRelationships = OtherRelationships(
71
+ [
72
+ AWSLambdaToAliasRel(),
73
+ ]
74
+ )
@@ -0,0 +1,88 @@
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 AWSLambdaEventSourceMappingNodeProperties(CartographyNodeProperties):
16
+ id: PropertyRef = PropertyRef("UUID")
17
+ batchsize: PropertyRef = PropertyRef("BatchSize")
18
+ startingposition: PropertyRef = PropertyRef("StartingPosition")
19
+ startingpositiontimestamp: PropertyRef = PropertyRef("StartingPositionTimestamp")
20
+ parallelizationfactor: PropertyRef = PropertyRef("ParallelizationFactor")
21
+ maximumbatchingwindowinseconds: PropertyRef = PropertyRef(
22
+ "MaximumBatchingWindowInSeconds"
23
+ )
24
+ eventsourcearn: PropertyRef = PropertyRef("EventSourceArn")
25
+ lastmodified: PropertyRef = PropertyRef("LastModified")
26
+ lastprocessingresult: PropertyRef = PropertyRef("LastProcessingResult")
27
+ state: PropertyRef = PropertyRef("State")
28
+ maximumrecordage: PropertyRef = PropertyRef("MaximumRecordAgeInSeconds")
29
+ bisectbatchonfunctionerror: PropertyRef = PropertyRef("BisectBatchOnFunctionError")
30
+ maximumretryattempts: PropertyRef = PropertyRef("MaximumRetryAttempts")
31
+ tumblingwindowinseconds: PropertyRef = PropertyRef("TumblingWindowInSeconds")
32
+ functionarn: PropertyRef = PropertyRef("FunctionArn")
33
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
34
+
35
+
36
+ # (:AWSLambda)-[:RESOURCE]->(:AWSLambdaEventSourceMapping)
37
+ # Note:The RESOURCE rel here is not the same as sub-resource relationship. Should rename eventually
38
+ @dataclass(frozen=True)
39
+ class AWSLambdaToEventSourceMappingRelProperties(CartographyRelProperties):
40
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
41
+
42
+
43
+ @dataclass(frozen=True)
44
+ class AWSLambdaToEventSourceMappingRel(CartographyRelSchema):
45
+ target_node_label: str = "AWSLambda"
46
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
47
+ {"id": PropertyRef("FunctionArn")},
48
+ )
49
+ direction: LinkDirection = LinkDirection.INWARD
50
+ rel_label: str = "RESOURCE"
51
+ properties: AWSLambdaToEventSourceMappingRelProperties = (
52
+ AWSLambdaToEventSourceMappingRelProperties()
53
+ )
54
+
55
+
56
+ # Sub-resource relationship: (:AWSAccount)-[:RESOURCE]->(:AWSLambdaEventSourceMapping)
57
+ @dataclass(frozen=True)
58
+ class AWSLambdaEventSourceMappingToAWSAccountRelProperties(CartographyRelProperties):
59
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
60
+
61
+
62
+ @dataclass(frozen=True)
63
+ class AWSLambdaEventSourceMappingToAWSAccountRel(CartographyRelSchema):
64
+ target_node_label: str = "AWSAccount"
65
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
66
+ {"id": PropertyRef("AWS_ID", set_in_kwargs=True)},
67
+ )
68
+ direction: LinkDirection = LinkDirection.INWARD
69
+ rel_label: str = "RESOURCE"
70
+ properties: AWSLambdaEventSourceMappingToAWSAccountRelProperties = (
71
+ AWSLambdaEventSourceMappingToAWSAccountRelProperties()
72
+ )
73
+
74
+
75
+ @dataclass(frozen=True)
76
+ class AWSLambdaEventSourceMappingSchema(CartographyNodeSchema):
77
+ label: str = "AWSLambdaEventSourceMapping"
78
+ properties: AWSLambdaEventSourceMappingNodeProperties = (
79
+ AWSLambdaEventSourceMappingNodeProperties()
80
+ )
81
+ sub_resource_relationship: AWSLambdaEventSourceMappingToAWSAccountRel = (
82
+ AWSLambdaEventSourceMappingToAWSAccountRel()
83
+ )
84
+ other_relationships: OtherRelationships = OtherRelationships(
85
+ [
86
+ AWSLambdaToEventSourceMappingRel(),
87
+ ]
88
+ )
@@ -0,0 +1,89 @@
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 AWSLambdaNodeProperties(CartographyNodeProperties):
16
+ id: PropertyRef = PropertyRef("FunctionArn")
17
+ arn: PropertyRef = PropertyRef("FunctionArn", extra_index=True)
18
+ name: PropertyRef = PropertyRef("FunctionName")
19
+ modifieddate: PropertyRef = PropertyRef("LastModified")
20
+ runtime: PropertyRef = PropertyRef("Runtime")
21
+ description: PropertyRef = PropertyRef("Description")
22
+ timeout: PropertyRef = PropertyRef("Timeout")
23
+ memory: PropertyRef = PropertyRef("MemorySize")
24
+ codesize: PropertyRef = PropertyRef("CodeSize")
25
+ handler: PropertyRef = PropertyRef("Handler")
26
+ version: PropertyRef = PropertyRef("Version")
27
+ tracingconfigmode: PropertyRef = PropertyRef("TracingConfigMode")
28
+ revisionid: PropertyRef = PropertyRef("RevisionId")
29
+ state: PropertyRef = PropertyRef("State")
30
+ statereason: PropertyRef = PropertyRef("StateReason")
31
+ statereasoncode: PropertyRef = PropertyRef("StateReasonCode")
32
+ lastupdatestatus: PropertyRef = PropertyRef("LastUpdateStatus")
33
+ lastupdatestatusreason: PropertyRef = PropertyRef("LastUpdateStatusReason")
34
+ lastupdatestatusreasoncode: PropertyRef = PropertyRef("LastUpdateStatusReasonCode")
35
+ packagetype: PropertyRef = PropertyRef("PackageType")
36
+ signingprofileversionarn: PropertyRef = PropertyRef("SigningProfileVersionArn")
37
+ signingjobarn: PropertyRef = PropertyRef("SigningJobArn")
38
+ codesha256: PropertyRef = PropertyRef("CodeSha256")
39
+ architectures: PropertyRef = PropertyRef("Architectures")
40
+ masterarn: PropertyRef = PropertyRef("MasterArn")
41
+ kmskeyarn: PropertyRef = PropertyRef("KMSKeyArn")
42
+ region: PropertyRef = PropertyRef("Region", set_in_kwargs=True)
43
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
44
+
45
+
46
+ @dataclass(frozen=True)
47
+ class AWSLambdaToAWSAccountRelProperties(CartographyRelProperties):
48
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
49
+
50
+
51
+ @dataclass(frozen=True)
52
+ class AWSLambdaToAWSAccountRel(CartographyRelSchema):
53
+ target_node_label: str = "AWSAccount"
54
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
55
+ {"id": PropertyRef("AWS_ID", set_in_kwargs=True)},
56
+ )
57
+ direction: LinkDirection = LinkDirection.INWARD
58
+ rel_label: str = "RESOURCE"
59
+ properties: AWSLambdaToAWSAccountRelProperties = (
60
+ AWSLambdaToAWSAccountRelProperties()
61
+ )
62
+
63
+
64
+ @dataclass(frozen=True)
65
+ class AWSLambdaToPrincipalRelProperties(CartographyRelProperties):
66
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
67
+
68
+
69
+ @dataclass(frozen=True)
70
+ class AWSLambdaToPrincipalRel(CartographyRelSchema):
71
+ target_node_label: str = "AWSPrincipal"
72
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
73
+ {"arn": PropertyRef("Role")},
74
+ )
75
+ direction: LinkDirection = LinkDirection.OUTWARD
76
+ rel_label: str = "STS_ASSUMEROLE_ALLOW"
77
+ properties: AWSLambdaToPrincipalRelProperties = AWSLambdaToPrincipalRelProperties()
78
+
79
+
80
+ @dataclass(frozen=True)
81
+ class AWSLambdaSchema(CartographyNodeSchema):
82
+ label: str = "AWSLambda"
83
+ properties: AWSLambdaNodeProperties = AWSLambdaNodeProperties()
84
+ sub_resource_relationship: AWSLambdaToAWSAccountRel = AWSLambdaToAWSAccountRel()
85
+ other_relationships: OtherRelationships = OtherRelationships(
86
+ [
87
+ AWSLambdaToPrincipalRel(),
88
+ ],
89
+ )
@@ -0,0 +1,72 @@
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 AWSLambdaLayerNodeProperties(CartographyNodeProperties):
16
+ id: PropertyRef = PropertyRef("Arn")
17
+ arn: PropertyRef = PropertyRef("Arn")
18
+ codesize: PropertyRef = PropertyRef("CodeSize")
19
+ signingprofileversionarn: PropertyRef = PropertyRef("SigningProfileVersionArn")
20
+ signingjobarn: PropertyRef = PropertyRef("SigningJobArn")
21
+ functionarn: PropertyRef = PropertyRef("FunctionArn")
22
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
23
+
24
+
25
+ # (:AWSLambda)-[:HAS]->(:AWSLambdaLayer)
26
+ @dataclass(frozen=True)
27
+ class AWSLambdaToLayerRelProperties(CartographyRelProperties):
28
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
29
+
30
+
31
+ @dataclass(frozen=True)
32
+ class AWSLambdaToLayerRel(CartographyRelSchema):
33
+ target_node_label: str = "AWSLambda"
34
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
35
+ {"id": PropertyRef("FunctionArn")},
36
+ )
37
+ direction: LinkDirection = LinkDirection.INWARD
38
+ rel_label: str = "HAS"
39
+ properties: AWSLambdaToLayerRelProperties = AWSLambdaToLayerRelProperties()
40
+
41
+
42
+ # (:AWSAccount)-[:RESOURCE]->(:AWSLambdaLayer)
43
+ @dataclass(frozen=True)
44
+ class AWSLambdaLayerToAWSAccountRelProperties(CartographyRelProperties):
45
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
46
+
47
+
48
+ @dataclass(frozen=True)
49
+ class AWSLambdaLayerToAWSAccountRel(CartographyRelSchema):
50
+ target_node_label: str = "AWSAccount"
51
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
52
+ {"id": PropertyRef("AWS_ID", set_in_kwargs=True)},
53
+ )
54
+ direction: LinkDirection = LinkDirection.INWARD
55
+ rel_label: str = "RESOURCE"
56
+ properties: AWSLambdaLayerToAWSAccountRelProperties = (
57
+ AWSLambdaLayerToAWSAccountRelProperties()
58
+ )
59
+
60
+
61
+ @dataclass(frozen=True)
62
+ class AWSLambdaLayerSchema(CartographyNodeSchema):
63
+ label: str = "AWSLambdaLayer"
64
+ properties: AWSLambdaLayerNodeProperties = AWSLambdaLayerNodeProperties()
65
+ sub_resource_relationship: AWSLambdaLayerToAWSAccountRel = (
66
+ AWSLambdaLayerToAWSAccountRel()
67
+ )
68
+ other_relationships: OtherRelationships = OtherRelationships(
69
+ [
70
+ AWSLambdaToLayerRel(),
71
+ ]
72
+ )
File without changes
@@ -0,0 +1,89 @@
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 RDSClusterNodeProperties(CartographyNodeProperties):
15
+ id: PropertyRef = PropertyRef("DBClusterArn")
16
+ arn: PropertyRef = PropertyRef("DBClusterArn", extra_index=True)
17
+ allocated_storage: PropertyRef = PropertyRef("AllocatedStorage")
18
+ availability_zones: PropertyRef = PropertyRef("AvailabilityZones")
19
+ backup_retention_period: PropertyRef = PropertyRef("BackupRetentionPeriod")
20
+ character_set_name: PropertyRef = PropertyRef("CharacterSetName")
21
+ database_name: PropertyRef = PropertyRef("DatabaseName")
22
+ db_cluster_identifier: PropertyRef = PropertyRef(
23
+ "DBClusterIdentifier", extra_index=True
24
+ )
25
+ db_parameter_group: PropertyRef = PropertyRef("DBClusterParameterGroup")
26
+ status: PropertyRef = PropertyRef("Status")
27
+ earliest_restorable_time: PropertyRef = PropertyRef("EarliestRestorableTime")
28
+ endpoint: PropertyRef = PropertyRef("Endpoint")
29
+ reader_endpoint: PropertyRef = PropertyRef("ReaderEndpoint")
30
+ multi_az: PropertyRef = PropertyRef("MultiAZ")
31
+ engine: PropertyRef = PropertyRef("Engine")
32
+ engine_version: PropertyRef = PropertyRef("EngineVersion")
33
+ engine_mode: PropertyRef = PropertyRef("EngineMode")
34
+ latest_restorable_time: PropertyRef = PropertyRef("LatestRestorableTime")
35
+ port: PropertyRef = PropertyRef("Port")
36
+ master_username: PropertyRef = PropertyRef("MasterUsername")
37
+ preferred_backup_window: PropertyRef = PropertyRef("PreferredBackupWindow")
38
+ preferred_maintenance_window: PropertyRef = PropertyRef(
39
+ "PreferredMaintenanceWindow"
40
+ )
41
+ hosted_zone_id: PropertyRef = PropertyRef("HostedZoneId")
42
+ storage_encrypted: PropertyRef = PropertyRef("StorageEncrypted")
43
+ kms_key_id: PropertyRef = PropertyRef("KmsKeyId")
44
+ db_cluster_resource_id: PropertyRef = PropertyRef("DbClusterResourceId")
45
+ clone_group_id: PropertyRef = PropertyRef("CloneGroupId")
46
+ cluster_create_time: PropertyRef = PropertyRef("ClusterCreateTime")
47
+ earliest_backtrack_time: PropertyRef = PropertyRef("EarliestBacktrackTime")
48
+ backtrack_window: PropertyRef = PropertyRef("BacktrackWindow")
49
+ backtrack_consumed_change_records: PropertyRef = PropertyRef(
50
+ "BacktrackConsumedChangeRecords"
51
+ )
52
+ capacity: PropertyRef = PropertyRef("Capacity")
53
+ scaling_configuration_info_min_capacity: PropertyRef = PropertyRef(
54
+ "ScalingConfigurationInfoMinCapacity"
55
+ )
56
+ scaling_configuration_info_max_capacity: PropertyRef = PropertyRef(
57
+ "ScalingConfigurationInfoMaxCapacity"
58
+ )
59
+ scaling_configuration_info_auto_pause: PropertyRef = PropertyRef(
60
+ "ScalingConfigurationInfoAutoPause"
61
+ )
62
+ deletion_protection: PropertyRef = PropertyRef("DeletionProtection")
63
+ region: PropertyRef = PropertyRef("Region", set_in_kwargs=True)
64
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
65
+
66
+
67
+ @dataclass(frozen=True)
68
+ class RDSClusterToAWSAccountRelProperties(CartographyRelProperties):
69
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
70
+
71
+
72
+ @dataclass(frozen=True)
73
+ class RDSClusterToAWSAccountRel(CartographyRelSchema):
74
+ target_node_label: str = "AWSAccount"
75
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
76
+ {"id": PropertyRef("AWS_ID", set_in_kwargs=True)}
77
+ )
78
+ direction: LinkDirection = LinkDirection.INWARD
79
+ rel_label: str = "RESOURCE"
80
+ properties: RDSClusterToAWSAccountRelProperties = (
81
+ RDSClusterToAWSAccountRelProperties()
82
+ )
83
+
84
+
85
+ @dataclass(frozen=True)
86
+ class RDSClusterSchema(CartographyNodeSchema):
87
+ label: str = "RDSCluster"
88
+ properties: RDSClusterNodeProperties = RDSClusterNodeProperties()
89
+ sub_resource_relationship: RDSClusterToAWSAccountRel = RDSClusterToAWSAccountRel()
@@ -0,0 +1,154 @@
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 RDSInstanceNodeProperties(CartographyNodeProperties):
16
+ id: PropertyRef = PropertyRef("DBInstanceArn")
17
+ arn: PropertyRef = PropertyRef("DBInstanceArn", extra_index=True)
18
+ db_instance_identifier: PropertyRef = PropertyRef(
19
+ "DBInstanceIdentifier", extra_index=True
20
+ )
21
+ db_instance_class: PropertyRef = PropertyRef("DBInstanceClass")
22
+ engine: PropertyRef = PropertyRef("Engine")
23
+ master_username: PropertyRef = PropertyRef("MasterUsername")
24
+ db_name: PropertyRef = PropertyRef("DBName")
25
+ instance_create_time: PropertyRef = PropertyRef("InstanceCreateTime")
26
+ availability_zone: PropertyRef = PropertyRef("AvailabilityZone")
27
+ multi_az: PropertyRef = PropertyRef("MultiAZ")
28
+ engine_version: PropertyRef = PropertyRef("EngineVersion")
29
+ publicly_accessible: PropertyRef = PropertyRef("PubliclyAccessible")
30
+ db_cluster_identifier: PropertyRef = PropertyRef("DBClusterIdentifier")
31
+ storage_encrypted: PropertyRef = PropertyRef("StorageEncrypted")
32
+ kms_key_id: PropertyRef = PropertyRef("KmsKeyId")
33
+ dbi_resource_id: PropertyRef = PropertyRef("DbiResourceId")
34
+ ca_certificate_identifier: PropertyRef = PropertyRef("CACertificateIdentifier")
35
+ enhanced_monitoring_resource_arn: PropertyRef = PropertyRef(
36
+ "EnhancedMonitoringResourceArn"
37
+ )
38
+ monitoring_role_arn: PropertyRef = PropertyRef("MonitoringRoleArn")
39
+ performance_insights_enabled: PropertyRef = PropertyRef(
40
+ "PerformanceInsightsEnabled"
41
+ )
42
+ performance_insights_kms_key_id: PropertyRef = PropertyRef(
43
+ "PerformanceInsightsKMSKeyId"
44
+ )
45
+ region: PropertyRef = PropertyRef("Region", set_in_kwargs=True)
46
+ deletion_protection: PropertyRef = PropertyRef("DeletionProtection")
47
+ preferred_backup_window: PropertyRef = PropertyRef("PreferredBackupWindow")
48
+ latest_restorable_time: PropertyRef = PropertyRef("LatestRestorableTime")
49
+ preferred_maintenance_window: PropertyRef = PropertyRef(
50
+ "PreferredMaintenanceWindow"
51
+ )
52
+ backup_retention_period: PropertyRef = PropertyRef("BackupRetentionPeriod")
53
+ endpoint_address: PropertyRef = PropertyRef("EndpointAddress")
54
+ endpoint_hostedzoneid: PropertyRef = PropertyRef("EndpointHostedZoneId")
55
+ endpoint_port: PropertyRef = PropertyRef("EndpointPort")
56
+ iam_database_authentication_enabled: PropertyRef = PropertyRef(
57
+ "IAMDatabaseAuthenticationEnabled"
58
+ )
59
+ auto_minor_version_upgrade: PropertyRef = PropertyRef("AutoMinorVersionUpgrade")
60
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
61
+
62
+
63
+ @dataclass(frozen=True)
64
+ class RDSInstanceToAWSAccountRelProperties(CartographyRelProperties):
65
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
66
+
67
+
68
+ @dataclass(frozen=True)
69
+ class RDSInstanceToAWSAccountRel(CartographyRelSchema):
70
+ target_node_label: str = "AWSAccount"
71
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
72
+ {
73
+ "id": PropertyRef("AWS_ID", set_in_kwargs=True),
74
+ }
75
+ )
76
+ direction: LinkDirection = LinkDirection.INWARD
77
+ rel_label: str = "RESOURCE"
78
+ properties: RDSInstanceToAWSAccountRelProperties = (
79
+ RDSInstanceToAWSAccountRelProperties()
80
+ )
81
+
82
+
83
+ @dataclass(frozen=True)
84
+ class RDSInstanceToEC2SecurityGroupRelProperties(CartographyRelProperties):
85
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
86
+
87
+
88
+ @dataclass(frozen=True)
89
+ class RDSInstanceToEC2SecurityGroupRel(CartographyRelSchema):
90
+ target_node_label: str = "EC2SecurityGroup"
91
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
92
+ {
93
+ "id": PropertyRef("security_group_ids", one_to_many=True),
94
+ }
95
+ )
96
+ direction: LinkDirection = LinkDirection.OUTWARD
97
+ rel_label: str = "MEMBER_OF_EC2_SECURITY_GROUP"
98
+ properties: RDSInstanceToEC2SecurityGroupRelProperties = (
99
+ RDSInstanceToEC2SecurityGroupRelProperties()
100
+ )
101
+
102
+
103
+ @dataclass(frozen=True)
104
+ class RDSInstanceToRDSInstanceRelProperties(CartographyRelProperties):
105
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
106
+
107
+
108
+ @dataclass(frozen=True)
109
+ class RDSInstanceToRDSInstanceRel(CartographyRelSchema):
110
+ target_node_label: str = "RDSInstance"
111
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
112
+ {
113
+ "db_instance_identifier": PropertyRef("read_replica_source_identifier"),
114
+ }
115
+ )
116
+ direction: LinkDirection = LinkDirection.OUTWARD
117
+ rel_label: str = "IS_READ_REPLICA_OF"
118
+ properties: RDSInstanceToRDSInstanceRelProperties = (
119
+ RDSInstanceToRDSInstanceRelProperties()
120
+ )
121
+
122
+
123
+ @dataclass(frozen=True)
124
+ class RDSInstanceToRDSClusterRelProperties(CartographyRelProperties):
125
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
126
+
127
+
128
+ @dataclass(frozen=True)
129
+ class RDSInstanceToRDSClusterRel(CartographyRelSchema):
130
+ target_node_label: str = "RDSCluster"
131
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
132
+ {
133
+ "db_cluster_identifier": PropertyRef("db_cluster_identifier"),
134
+ }
135
+ )
136
+ direction: LinkDirection = LinkDirection.OUTWARD
137
+ rel_label: str = "IS_CLUSTER_MEMBER_OF"
138
+ properties: RDSInstanceToRDSClusterRelProperties = (
139
+ RDSInstanceToRDSClusterRelProperties()
140
+ )
141
+
142
+
143
+ @dataclass(frozen=True)
144
+ class RDSInstanceSchema(CartographyNodeSchema):
145
+ label: str = "RDSInstance"
146
+ properties: RDSInstanceNodeProperties = RDSInstanceNodeProperties()
147
+ sub_resource_relationship: RDSInstanceToAWSAccountRel = RDSInstanceToAWSAccountRel()
148
+ other_relationships: OtherRelationships = OtherRelationships(
149
+ [
150
+ RDSInstanceToEC2SecurityGroupRel(),
151
+ RDSInstanceToRDSInstanceRel(),
152
+ RDSInstanceToRDSClusterRel(),
153
+ ]
154
+ )
@@ -0,0 +1,108 @@
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 RDSSnapshotNodeProperties(CartographyNodeProperties):
16
+ id: PropertyRef = PropertyRef("DBSnapshotArn")
17
+ arn: PropertyRef = PropertyRef("DBSnapshotArn", extra_index=True)
18
+ db_snapshot_identifier: PropertyRef = PropertyRef(
19
+ "DBSnapshotIdentifier", extra_index=True
20
+ )
21
+ db_instance_identifier: PropertyRef = PropertyRef("DBInstanceIdentifier")
22
+ snapshot_create_time: PropertyRef = PropertyRef("SnapshotCreateTime")
23
+ engine: PropertyRef = PropertyRef("Engine")
24
+ engine_version: PropertyRef = PropertyRef("EngineVersion")
25
+ allocated_storage: PropertyRef = PropertyRef("AllocatedStorage")
26
+ status: PropertyRef = PropertyRef("Status")
27
+ port: PropertyRef = PropertyRef("Port")
28
+ availability_zone: PropertyRef = PropertyRef("AvailabilityZone")
29
+ vpc_id: PropertyRef = PropertyRef("VpcId")
30
+ instance_create_time: PropertyRef = PropertyRef("InstanceCreateTime")
31
+ master_username: PropertyRef = PropertyRef("MasterUsername")
32
+ license_model: PropertyRef = PropertyRef("LicenseModel")
33
+ snapshot_type: PropertyRef = PropertyRef("SnapshotType")
34
+ iops: PropertyRef = PropertyRef("Iops")
35
+ option_group_name: PropertyRef = PropertyRef("OptionGroupName")
36
+ percent_progress: PropertyRef = PropertyRef("PercentProgress")
37
+ source_region: PropertyRef = PropertyRef("SourceRegion")
38
+ source_db_snapshot_identifier: PropertyRef = PropertyRef(
39
+ "SourceDBSnapshotIdentifier"
40
+ )
41
+ storage_type: PropertyRef = PropertyRef("StorageType")
42
+ tde_credential_arn: PropertyRef = PropertyRef("TdeCredentialArn")
43
+ encrypted: PropertyRef = PropertyRef("Encrypted")
44
+ kms_key_id: PropertyRef = PropertyRef("KmsKeyId")
45
+ timezone: PropertyRef = PropertyRef("Timezone")
46
+ iam_database_authentication_enabled: PropertyRef = PropertyRef(
47
+ "IAMDatabaseAuthenticationEnabled"
48
+ )
49
+ processor_features: PropertyRef = PropertyRef("ProcessorFeatures")
50
+ dbi_resource_id: PropertyRef = PropertyRef("DbiResourceId")
51
+ original_snapshot_create_time: PropertyRef = PropertyRef(
52
+ "OriginalSnapshotCreateTime"
53
+ )
54
+ snapshot_database_time: PropertyRef = PropertyRef("SnapshotDatabaseTime")
55
+ snapshot_target: PropertyRef = PropertyRef("SnapshotTarget")
56
+ storage_throughput: PropertyRef = PropertyRef("StorageThroughput")
57
+ region: PropertyRef = PropertyRef("Region", set_in_kwargs=True)
58
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
59
+
60
+
61
+ @dataclass(frozen=True)
62
+ class RDSSnapshotToAWSAccountRelProperties(CartographyRelProperties):
63
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
64
+
65
+
66
+ @dataclass(frozen=True)
67
+ class RDSSnapshotToAWSAccountRel(CartographyRelSchema):
68
+ target_node_label: str = "AWSAccount"
69
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
70
+ {"id": PropertyRef("AWS_ID", set_in_kwargs=True)}
71
+ )
72
+ direction: LinkDirection = LinkDirection.INWARD
73
+ rel_label: str = "RESOURCE"
74
+ properties: RDSSnapshotToAWSAccountRelProperties = (
75
+ RDSSnapshotToAWSAccountRelProperties()
76
+ )
77
+
78
+
79
+ @dataclass(frozen=True)
80
+ class RDSSnapshotToRDSInstanceRelProperties(CartographyRelProperties):
81
+ lastupdated: PropertyRef = PropertyRef("lastupdated", set_in_kwargs=True)
82
+
83
+
84
+ @dataclass(frozen=True)
85
+ class RDSSnapshotToRDSInstanceRel(CartographyRelSchema):
86
+ target_node_label: str = "RDSInstance"
87
+ target_node_matcher: TargetNodeMatcher = make_target_node_matcher(
88
+ {
89
+ "db_instance_identifier": PropertyRef("DBInstanceIdentifier"),
90
+ }
91
+ )
92
+ direction: LinkDirection = LinkDirection.OUTWARD
93
+ rel_label: str = "IS_SNAPSHOT_SOURCE"
94
+ properties: RDSSnapshotToRDSInstanceRelProperties = (
95
+ RDSSnapshotToRDSInstanceRelProperties()
96
+ )
97
+
98
+
99
+ @dataclass(frozen=True)
100
+ class RDSSnapshotSchema(CartographyNodeSchema):
101
+ label: str = "RDSSnapshot"
102
+ properties: RDSSnapshotNodeProperties = RDSSnapshotNodeProperties()
103
+ sub_resource_relationship: RDSSnapshotToAWSAccountRel = RDSSnapshotToAWSAccountRel()
104
+ other_relationships: OtherRelationships = OtherRelationships(
105
+ [
106
+ RDSSnapshotToRDSInstanceRel(),
107
+ ]
108
+ )