networking_config
Sample rules
A few rules that use objects from this package:
disallow_default_vpc
from typing import List, Dict
from cloudrail.knowledge.context.aws.resources.networking_config.network_entity import NetworkEntity
from cloudrail.knowledge.context.aws.aws_environment_context import AwsEnvironmentContext
from cloudrail.knowledge.rules.aws.aws_base_rule import AwsBaseRule
from cloudrail.knowledge.rules.base_rule import Issue
from cloudrail.knowledge.rules.rule_parameters.base_paramerter import ParameterType
class DisallowResourcesInDefaultVpcRule(AwsBaseRule):
def execute(self, env_context: AwsEnvironmentContext, parameters: Dict[ParameterType, any]) -> List[Issue]:
issues: List[Issue] = []
network_entity_list: List[NetworkEntity] = env_context.get_all_network_entities()
for entity in network_entity_list:
if entity.network_resource.vpc is not None and entity.network_resource.vpc.is_default: # some resources can be out of vpc
issues.append(Issue(self._format_evidence(entity.get_friendly_name()), entity, entity))
return issues
def get_id(self) -> str:
return "disallow_default_vpc"
@staticmethod
def _format_evidence(entity: str) -> str:
return f"~Default VPC~. `{entity}` is defined within the default VPC."
def should_run_rule(self, environment_context: AwsEnvironmentContext) -> bool:
return bool(environment_context.get_all_network_entities())
NetworkEntity (AwsResource)
This class is the parent of all resources that have a network connection.
Attributes:
Name | Type | Description |
---|---|---|
name |
str |
Name of the network entity. |
network_resource |
NetworkResource |
Networking information of the entity. |
custom_invalidation(self)
inherited
A list of manual reasons why this resource should be invalidated
exclude_from_invalidation(self)
inherited
A list of attributes that should be excluded from the invalidation process