Skip to content

Commit

Permalink
Actually fix #1210 using multiple classes
Browse files Browse the repository at this point in the history
  • Loading branch information
Alex Chantavy committed Jul 14, 2023
1 parent c0d9ac4 commit facb63b
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 3 deletions.
4 changes: 2 additions & 2 deletions cartography/intel/aws/ec2/instances.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
from cartography.models.aws.ec2.reservations import EC2ReservationSchema
from cartography.models.aws.ec2.securitygroups import EC2SecurityGroupSchema
from cartography.models.aws.ec2.subnets import EC2SubnetSchema
from cartography.models.aws.ec2.volumes import EBSVolumeSchema
from cartography.models.aws.ec2.volumes import EBSVolumeInstanceSchema
from cartography.util import aws_handle_regions
from cartography.util import timeit

Expand Down Expand Up @@ -273,7 +273,7 @@ def load_ec2_instance_ebs_volumes(
) -> None:
load(
neo4j_session,
EBSVolumeSchema(),
EBSVolumeInstanceSchema(),
ebs_data,
Region=region,
AWS_ID=current_aws_account_id,
Expand Down
33 changes: 32 additions & 1 deletion cartography/models/aws/ec2/volumes.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@ class EBSVolumeNodeProperties(CartographyNodeProperties):
volumeid: PropertyRef = PropertyRef('VolumeId', extra_index=True)
region: PropertyRef = PropertyRef('Region', set_in_kwargs=True)
lastupdated: PropertyRef = PropertyRef('lastupdated', set_in_kwargs=True)
deleteontermination: PropertyRef = PropertyRef('DeleteOnTermination')
availabilityzone: PropertyRef = PropertyRef('AvailabilityZone')
createtime: PropertyRef = PropertyRef('CreateTime')
encrypted: PropertyRef = PropertyRef('Encrypted')
Expand Down Expand Up @@ -67,6 +66,9 @@ class EBSVolumeToEC2Instance(CartographyRelSchema):

@dataclass(frozen=True)
class EBSVolumeSchema(CartographyNodeSchema):
"""
EBS Volume properties as returned from the EBS Volume API response
"""
label: str = 'EBSVolume'
properties: EBSVolumeNodeProperties = EBSVolumeNodeProperties()
sub_resource_relationship: EBSVolumeToAWSAccount = EBSVolumeToAWSAccount()
Expand All @@ -75,3 +77,32 @@ class EBSVolumeSchema(CartographyNodeSchema):
EBSVolumeToEC2Instance(),
],
)


@dataclass(frozen=True)
class EBSVolumeInstanceProperties(CartographyNodeProperties):
"""
EBS Volume properties as known by an EC2 instance.
The EC2 instance API response includes a `deleteontermination` field and a snapshot id.
"""
arn: PropertyRef = PropertyRef('Arn', extra_index=True)
id: PropertyRef = PropertyRef('VolumeId')
volumeid: PropertyRef = PropertyRef('VolumeId', extra_index=True)
lastupdated: PropertyRef = PropertyRef('lastupdated', set_in_kwargs=True)
deleteontermination: PropertyRef = PropertyRef('DeleteOnTermination')
snapshotid: PropertyRef = PropertyRef('SnapshotId')


@dataclass(frozen=True)
class EBSVolumeInstanceSchema(CartographyNodeSchema):
"""
EBS Volume from EC2 Instance API response. This is separate from `EBSVolumeSchema` to prevent issue #1210.
"""
label: str = 'EBSVolume'
properties: EBSVolumeInstanceProperties = EBSVolumeInstanceProperties()
sub_resource_relationship: EBSVolumeToAWSAccount = EBSVolumeToAWSAccount()
other_relationships: OtherRelationships = OtherRelationships(
[
EBSVolumeToEC2Instance(),
],
)

0 comments on commit facb63b

Please sign in to comment.