From a48a12eadb5fbc9320c43237fa30bdd642ed57fa Mon Sep 17 00:00:00 2001 From: Matthias Veit Date: Thu, 21 Dec 2023 08:27:53 +0100 Subject: [PATCH] [resotocore][feat] Add AWS CIS 2.0 (#1863) --- .../resotocore/db/arangodb_extensions.py | 32 +- .../report/benchmark/aws/aws_cis_1_5.json | 9 +- .../report/benchmark/aws/aws_cis_2_0.json | 514 ++++++++++++++++++ .../static/report/checks/aws/aws_ec2.json | 89 ++- .../static/report/checks/aws/aws_iam.json | 15 + 5 files changed, 601 insertions(+), 58 deletions(-) create mode 100644 resotocore/resotocore/static/report/benchmark/aws/aws_cis_2_0.json diff --git a/resotocore/resotocore/db/arangodb_extensions.py b/resotocore/resotocore/db/arangodb_extensions.py index bd3ad97cd4..a48d9176fb 100644 --- a/resotocore/resotocore/db/arangodb_extensions.py +++ b/resotocore/resotocore/db/arangodb_extensions.py @@ -12,23 +12,39 @@ class ArangoHTTPClient(HTTPClient): - def __init__(self, timeout: int, verify: Union[str, bool, None]): + def __init__( + self, + timeout: int, + verify: Union[str, bool, None], + retry_attempts: int = 3, + backoff_factor: float = 1.0, + pool_connections: int = 10, + pool_maxsize: int = 20, + ): log.info(f"Create ArangoHTTPClient with timeout={timeout} and verify={verify}") - self.timeout = timeout - self.verify = verify + self._timeout = timeout + self._verify = verify + self._retry_attempts = retry_attempts + self._backoff_factor = backoff_factor + self._pool_connections = pool_connections + self._pool_maxsize = pool_maxsize def create_session(self, host: str) -> Session: retry_strategy = Retry( - total=3, - backoff_factor=1, + total=self._retry_attempts, + backoff_factor=self._backoff_factor, status_forcelist=[429, 500, 502, 503, 504], allowed_methods=["HEAD", "GET", "OPTIONS"], ) - http_adapter = HTTPAdapter(max_retries=retry_strategy) + http_adapter = HTTPAdapter( + pool_connections=self._pool_connections, + pool_maxsize=self._pool_maxsize, + max_retries=retry_strategy, + ) session = Session() session.mount("https://", http_adapter) session.mount("http://", http_adapter) - session.verify = self.verify + session.verify = self._verify return session def send_request( @@ -41,5 +57,5 @@ def send_request( data: Union[str, MultipartEncoder, None] = None, auth: Optional[Tuple[str, str]] = None, ) -> Response: - response = session.request(method, url, params, data, headers, auth=auth, timeout=self.timeout) + response = session.request(method, url, params, data, headers, auth=auth, timeout=self._timeout) return Response(method, response.url, response.headers, response.status_code, response.reason, response.text) diff --git a/resotocore/resotocore/static/report/benchmark/aws/aws_cis_1_5.json b/resotocore/resotocore/static/report/benchmark/aws/aws_cis_1_5.json index e62e6a6091..6d36608c11 100644 --- a/resotocore/resotocore/static/report/benchmark/aws/aws_cis_1_5.json +++ b/resotocore/resotocore/static/report/benchmark/aws/aws_cis_1_5.json @@ -1,5 +1,5 @@ { - "title": "AWS CIS 1.5.0", + "title": "AWS CIS 1.5", "framework": "CIS", "clouds": ["aws"], "version": "1.5", @@ -507,6 +507,13 @@ "checks": [ "aws_ec2_routing_tables_with_least_privilege" ] + }, + { + "title": "5.6 Ensure that EC2 Metadata Service only allows IMDSv2", + "description": "When enabling the Metadata Service on AWS EC2 instances, users have the option of using either Instance Metadata Service Version 1 (IMDSv1; a request/response method) or Instance Metadata Service Version 2 (IMDSv2; a session-oriented method).", + "checks": [ + "aws_ec2_instance_imdsv2_enabled" + ] } ] } diff --git a/resotocore/resotocore/static/report/benchmark/aws/aws_cis_2_0.json b/resotocore/resotocore/static/report/benchmark/aws/aws_cis_2_0.json new file mode 100644 index 0000000000..670e15e687 --- /dev/null +++ b/resotocore/resotocore/static/report/benchmark/aws/aws_cis_2_0.json @@ -0,0 +1,514 @@ +{ + "title": "AWS CIS 2.0", + "framework": "CIS", + "clouds": ["aws"], + "version": "2.0", + "description": "The CIS Amazon Web Services Foundations Benchmark provides prescriptive guidance for configuring security options for a subset of Amazon Web Services with an emphasis on foundational, testable, and architecture agnostic settings.", + "children": [ + { + "title": "Section 1: Access Management", + "description": "This section contains recommendations for configuring identity and access management related options.", + "children": [ + { + "title": "1.1 Maintain current contact details", + "description": "Ensure contact email and telephone details for AWS accounts are current and map to more than one individual in your organization.", + "checks": [ + "aws_iam_account_maintain_current_contact_details" + ] + }, + { + "title": "1.2 Ensure security contact information is registered", + "description": "AWS provides customers with the option of specifying the contact information for account's security team. It is recommended that this information be provided.", + "checks": [ + "aws_iam_account_security_contact_information_is_registered" + ] + }, + { + "title": "1.3 Ensure security questions are registered in the AWS account", + "description": "The AWS support portal allows account owners to establish security questions that can be used to authenticate individuals calling AWS customer service for support. It is recommended that security questions be established.", + "checks": [ + "aws_iam_account_security_questions_are_registered_in_the_aws_account" + ] + }, + { + "title": "1.4 Ensure no 'root' user account access key exists", + "description": "The 'root' user account is the most privileged user in an AWS account. AWS Access Keys provide programmatic access to a given AWS account. It is recommended that all access keys associated with the 'root' user account be removed.", + "checks": [ + "aws_iam_no_root_access_key" + ] + }, + { + "title": "1.5 Ensure MFA is enabled for the 'root' user account", + "description": "The 'root' user account is the most privileged user in an AWS account. Multi-factor Authentication (MFA) adds an extra layer of protection on top of a username and password. With MFA enabled, when a user signs in to an AWS website, they will be prompted for their username and password as well as for an authentication code from their AWS MFA device.", + "checks": [ + "aws_iam_root_mfa_enabled" + ] + }, + { + "title": "1.6 Ensure hardware MFA is enabled for the 'root' user account", + "description": "The 'root' user account is the most privileged user in an AWS account. MFA adds an extra layer of protection on top of a user name and password. With MFA enabled, when a user signs in to an AWS website, they will be prompted for their user name and password as well as for an authentication code from their AWS MFA device. For Level 2, it is recommended that the root user account be protected with a hardware MFA.", + "checks": [ + "aws_iam_root_hardware_mfa_enabled" + ] + }, + { + "title": "1.7 Eliminate use of the 'root' user for administrative and daily tasks", + "description": "With the creation of an AWS account, a 'root user' is created that cannot be disabled or deleted. That user has unrestricted access to and control over all resources in the AWS account. It is highly recommended that the use of this account be avoided for everyday tasks.", + "checks": [ + "aws_iam_avoid_root_usage" + ] + }, + { + "title": "1.8 Ensure IAM password policy requires minimum length of 14 or greater", + "description": "Password policies are, in part, used to enforce password complexity requirements. IAM password policies can be used to ensure password are at least a given length. It is recommended that the password policy require a minimum password length 14.", + "checks": [ + "aws_iam_password_policy_minimum_length_14" + ] + }, + { + "title": "1.9 Ensure IAM password policy prevents password reuse", + "description": "IAM password policies can prevent the reuse of a given password by the same user. It is recommended that the password policy prevent the reuse of passwords.", + "checks": [ + "aws_iam_password_policy_reuse_24" + ] + }, + { + "title": "1.10 Ensure multi-factor authentication (MFA) is enabled for all IAM users that have a console password", + "description": "Multi-Factor Authentication (MFA) adds an extra layer of authentication assurance beyond traditional credentials. With MFA enabled, when a user signs in to the AWS Console, they will be prompted for their user name and password as well as for an authentication code from their physical or virtual MFA token. It is recommended that MFA be enabled for all accounts that have a console password.", + "checks": [ + "aws_iam_user_mfa_enabled_console_access" + ] + }, + { + "title": "1.11 Do not setup access keys during initial user setup for all IAM users that have a console password", + "description": "AWS console defaults to no check boxes selected when creating a new IAM user. When creating the IAM User credentials you have to determine what type of access they require.", + "checks": [ + "aws_iam_user_uses_access_keys_console_access" + ] + }, + { + "title": "1.12 Ensure credentials unused for 45 days or greater are disabled", + "description": "AWS IAM users can access AWS resources using different types of credentials, such as passwords or access keys. It is recommended that all credentials that have been unused in 45 or greater days be deactivated or removed.", + "checks": [ + "aws_iam_disable_old_credentials" + ] + }, + { + "title": "1.13 Ensure there is only one active access key available for any single IAM user", + "description": "Access keys are long-term credentials for an IAM user or the AWS account root user. You can use access keys to sign programmatic requests to the AWS CLI or AWS API (directly or using the AWS SDK).", + "checks": [ + "aws_iam_user_has_two_active_access_keys" + ] + }, + { + "title": "1.14 Ensure access keys are rotated every 90 days or less", + "description": "Access keys consist of an access key ID and secret access key, which are used to sign programmatic requests that you make to AWS. AWS users need their own access keys to make programmatic calls to AWS from the AWS Command Line Interface (AWS CLI), Tools for Windows PowerShell, the AWS SDKs, or direct HTTP calls using the APIs for individual AWS services. It is recommended that all access keys be regularly rotated.", + "checks": [ + "aws_iam_rotate_access_keys_after_90_days" + ] + }, + { + "title": "1.15 Ensure IAM Users Receive Permissions Only Through Groups", + "description": "IAM users are granted access to services, functions, and data through IAM policies. There are three ways to define policies for a user: 1) Edit the user policy directly, aka an inline, or user, policy; 2) attach a policy directly to a user; 3) add the user to an IAM group that has an attached policy. Only the third implementation is recommended.", + "checks": [ + "aws_iam_policy_attached_only_to_group_or_roles" + ] + }, + { + "title": "1.16 Ensure IAM policies that allow full \"*:*\" administrative privileges are not attached", + "description": "IAM policies are the means by which privileges are granted to users, groups, or roles. It is recommended and considered a standard security advice to grant least privilege -that is, granting only the permissions required to perform a task. Determine what users need to do and then craft policies for them that let the users perform only those tasks, instead of allowing full administrative privileges.", + "checks": [ + "aws_iam_policy_with_administrative_privileges_not_in_use" + ] + }, + { + "title": "1.17 Ensure a support role has been created to manage incidents with AWS Support", + "description": "AWS provides a support center that can be used for incident notification and response, as well as technical support and customer services. Create an IAM Role to allow authorized users to manage incidents with AWS Support.", + "checks": [ + "aws_iam_support_role_exists" + ] + }, + { + "title": "1.18 Ensure IAM instance roles are used for AWS resource access from instances", + "description": "AWS access from within AWS instances can be done by either encoding AWS keys into AWS API calls or by assigning the instance to a role which has an appropriate permissions policy for the required access. \"AWS Access\" means accessing the APIs of AWS in order to access AWS resources or manage AWS account resources.", + "checks": [ + "aws_ec2_instance_profile_attached" + ] + }, + { + "title": "1.19 Ensure that all the expired SSL/TLS certificates stored in AWS IAM are removed", + "description": "To enable HTTPS connections to your website or application in AWS, you need an SSL/TLS server certificate. You can use ACM or IAM to store and deploy server certificates. Use IAM as a certificate manager only when you must support HTTPS connections in a region that is not supported by ACM. IAM securely encrypts your private keys and stores the encrypted version in IAM SSL certificate storage. IAM supports deploying server certificates in all regions, but you must obtain your certificate from an external provider for use with AWS. You cannot upload an ACM certificate to IAM. Additionally, you cannot manage your certificates from the IAM Console.", + "checks": [ + "aws_iam_expired_server_certificates" + ] + }, + { + "title": "1.20 Ensure that IAM Access analyzer is enabled for all regions", + "description": "Enable IAM Access analyzer for IAM policies about all resources in each region. IAM Access Analyzer is a technology introduced at AWS reinvent 2019. After the Analyzer is enabled in IAM, scan results are displayed on the console showing the accessible resources. Scans show resources that other accounts and federated users can access, such as KMS keys and IAM roles. So the results allow you to determine if an unintended user is allowed, making it easier for administrators to monitor least privileges access. Access Analyzer analyzes only policies that are applied to resources in the same AWS Region.", + "checks": [ + "aws_iam_access_analyzer_enabled" + ] + }, + { + "title": "1.21 Ensure IAM users are managed centrally via identity federation or AWS Organizations for multi-account environments", + "description": "In multi-account environments, IAM user centralization facilitates greater user control. User access beyond the initial account is then provide via role assumption. Centralization of users can be accomplished through federation with an external identity provider or through the use of AWS Organizations.", + "checks": [ + "aws_iam_check_saml_providers_sts" + ] + }, + { + "title": "1.22 Ensure access to AWSCloudShellFullAccess is restricted", + "description": "AWS CloudShell is a convenient way of running CLI commands against AWS services. A managed IAM policy ('AWSCloudShellFullAccess') provides full access to CloudShell, which allows file upload and download capability between a user's local system and the CloudShell environment. Within the CloudShell environment a user has sudo permissions, and can access the internet. So it is feasible to install file transfer software (for example) and move data from CloudShell to external internet servers.", + "checks": [ + "aws_iam_check_cloudshell_access_restricted" + ] + } + ] + }, + { + "title": "Section 2: Storage", + "description": "This section contains recommendations for configuring AWS Storage.", + "children": [ + { + "title": "2.1 Simple Storage Service (S3)", + "description": "This section contains recommendations for configuring AWS Simple Storage Service (S3) Buckets.", + "children": [ + { + "title": "2.1.2 Ensure S3 Bucket Policy is set to deny HTTP requests", + "description": "At the Amazon S3 bucket level, you can configure permissions through a bucket policy making the objects accessible only through HTTPS.", + "checks": [ + "aws_s3_bucket_secure_transport_policy" + ] + }, + { + "title": "2.1.3 Ensure MFA Delete is enabled on S3 buckets", + "description": "Once MFA Delete is enabled on your sensitive and classified S3 bucket it requires the user to have two forms of authentication.", + "checks": [ + "aws_s3_bucket_no_mfa_delete" + ] + }, + { + "title": "2.1.4 Ensure all data in Amazon S3 has been discovered, classified and secured when required", + "description": "Amazon S3 buckets can contain sensitive data, that for security purposes should be discovered, monitored, classified and protected. Macie along with other 3rd party tools can automatically provide an inventory of Amazon S3 buckets.", + "checks": [ + "aws_s3_macie_is_enabled" + ] + }, + { + "title": "2.1.5 Ensure that S3 Buckets are configured with 'Block public access (bucket settings)'", + "description": "Amazon S3 provides Block public access (bucket settings) and Block public access (account settings) to help you manage public access to Amazon S3 resources. By default, S3 buckets and objects are created with public access disabled. However, an IAM principle with sufficient S3 permissions can enable public access at the bucket and/or object level. While enabled, Block public access (bucket settings) prevents an individual bucket, and its contained objects, from becoming publicly accessible. Similarly, Block public access (account settings) prevents all buckets, and contained objects, from becoming publicly accessible across the entire account.", + "checks": [ + "aws_s3_account_level_public_access_blocks" + ] + } + ] + }, + { + "title": "2.2 Elastic Compute Cloud (EC2)", + "description": "This section contains recommendations for configuring AWS Elastic Compute Cloud (EC2).", + "children": [ + { + "title": "2.2.1 Ensure EBS Volume Encryption is Enabled in all Regions", + "description": "Elastic Compute Cloud (EC2) supports encryption at rest when using the Elastic Block Store (EBS) service. While disabled by default, forcing encryption at EBS volume creation is supported.", + "checks": [ + "aws_ec2_volume_not_encrypted" + ] + } + ] + }, + { + "title": "2.3 Relational Database Service (RDS)", + "description": "This section contains recommendations for configuring AWS Relational Database Services (RDS).", + "children": [ + { + "title": "2.3.1 Ensure that encryption is enabled for RDS Instances", + "description": "Amazon RDS encrypted DB instances use the industry standard AES-256 encryption algorithm to encrypt your data on the server that hosts your Amazon RDS DB instances. After your data is encrypted, Amazon RDS handles authentication of access and decryption of your data transparently with a minimal impact on performance.", + "checks": [ + "aws_rds_storage_encrypted" + ] + }, + { + "title": "2.3.2 Ensure Auto Minor Version Upgrade feature is Enabled for RDS Instances", + "description": "Ensure that RDS database instances have the Auto Minor Version Upgrade flag enabled in order to receive automatically minor engine upgrades during the specified maintenance window. So, RDS instances can get the new features, bug fixes, and security patches for their database engines.", + "checks": [ + "aws_rds_auto_minor_version_upgrade" + ] + }, + { + "title": "2.3.3 Ensure that public access is not given to RDS Instance", + "description": "Ensure and verify that RDS database instances provisioned in your AWS account do restrict unauthorized access in order to minimize security risks. To restrict access to any publicly accessible RDS database instance, you must disable the database Publicly Accessible flag and update the VPC security group associated with the instance.", + "checks": [ + "aws_rds_no_public_access" + ] + } + ] + }, + { + "title": "2.4 Elastic File System (EFS)", + "description": "This section contains recommendations for configuring AWS Elastic File System (EFS).", + "children": [ + { + "title": "2.4.1 Ensure that encryption is enabled for EFS file systems", + "description": "EFS data should be encrypted at rest using AWS KMS (Key Management Service).", + "checks": [ + "aws_efs_storage_encrypted" + ] + } + ] + } + ] + }, + { + "title": "Section 3: Logging", + "description": "This section contains recommendations for configuring AWS logging features.", + "children": [ + { + "title": "3.1 Ensure CloudTrail is enabled in all regions", + "description": "AWS CloudTrail is a web service that records AWS API calls for your account and delivers log files to you. The recorded information includes the identity of the API caller, the time of the API call, the source IP address of the API caller, the request parameters, and the response elements returned by the AWS service. CloudTrail provides a history of AWS API calls for an account, including API calls made via the Management Console, SDKs, command line tools, and higher-level AWS services (such as CloudFormation).", + "checks": [ + "aws_cloudtrail_logging_in_all_regions_enabled" + ] + }, + { + "title": "3.2 Ensure CloudTrail log file validation is enabled", + "description": "CloudTrail log file validation creates a digitally signed digest file containing a hash of each log that CloudTrail writes to S3. These digest files can be used to determine whether a log file was changed, deleted, or unchanged after CloudTrail delivered the log. It is recommended that file validation be enabled on all CloudTrails.", + "checks": [ + "aws_cloudtrail_log_file_validation_enabled" + ] + }, + { + "title": "3.3 Ensure the S3 bucket used to store CloudTrail logs is not publicly accessible", + "description": "CloudTrail logs a record of every API call made in your AWS account. These logs file are stored in an S3 bucket. It is recommended that the bucket policy or access control list (ACL) applied to the S3 bucket that CloudTrail logs to prevent public access to the CloudTrail logs.", + "checks": [ + "aws_cloudtrail_logs_s3_bucket_is_not_publicly_accessible" + ] + }, + { + "title": "3.4 Ensure CloudTrail trails are integrated with CloudWatch Logs", + "description": "AWS CloudTrail is a web service that records AWS API calls made in a given AWS account. The recorded information includes the identity of the API caller, the time of the API call, the source IP address of the API caller, the request parameters, and the response elements returned by the AWS service. CloudTrail uses Amazon S3 for log file storage and delivery, so log files are stored durably. In addition to capturing CloudTrail logs within a specified S3 bucket for long term analysis, realtime analysis can be performed by configuring CloudTrail to send logs to CloudWatch Logs. For a trail that is enabled in all regions in an account, CloudTrail sends log files from all those regions to a CloudWatch Logs log group. It is recommended that CloudTrail logs be sent to CloudWatch Logs.", + "checks": [ + "aws_cloudtrail_no_logging_enabled", + "aws_cloudtrail_no_recent_log_event" + ] + }, + { + "title": "3.5 Ensure AWS Config is enabled in all regions", + "description": "AWS Config is a web service that performs configuration management of supported AWS resources within your account and delivers log files to you. The recorded information includes the configuration item (AWS resource), relationships between configuration items (AWS resources), any configuration changes between resources. It is recommended AWS Config be enabled in all regions.", + "checks": [ + "aws_config_enabled_in_all_regions" + ] + }, + { + "title": "3.6 Ensure S3 bucket access logging is enabled on the CloudTrail S3 bucket", + "description": "S3 Bucket Access Logging generates a log that contains access records for each request made to your S3 bucket. An access log record contains details about the request, such as the request type, the resources specified in the request worked, and the time and date the request was processed. It is recommended that bucket access logging be enabled on the CloudTrail S3 bucket.", + "checks": [ + "aws_cloudtrail_s3_bucket_logging_enabled" + ] + }, + { + "title": "3.7 Ensure CloudTrail logs are encrypted at rest using KMS CMKs", + "description": "AWS CloudTrail is a web service that records AWS API calls for an account and makes those logs available to users and resources in accordance with IAM policies. AWS Key Management Service (KMS) is a managed service that helps create and control the encryption keys used to encrypt account data, and uses Hardware Security Modules (HSMs) to protect the security of encryption keys. CloudTrail logs can be configured to leverage server side encryption (SSE) and KMS customer created master keys (CMK) to further protect CloudTrail logs. It is recommended that CloudTrail be configured to use SSE-KMS.", + "checks": [ + "aws_cloudtrail_uses_encryption_at_rest" + ] + }, + { + "title": "3.8 Ensure rotation for customer created symmetric CMKs is enabled", + "description": "AWS Key Management Service (KMS) allows customers to rotate the backing key which is key material stored within the KMS which is tied to the key ID of the Customer Created customer master key (CMK). It is the backing key that is used to perform cryptographic operations such as encryption and decryption. Automated key rotation currently retains all prior backing keys so that decryption of encrypted data can take place transparently. It is recommended that CMK key rotation be enabled for symmetric keys. Key rotation can not be enabled for any asymmetric CMK.", + "checks": [ + "aws_kms_key_rotation_enabled" + ] + }, + { + "title": "3.9 Ensure VPC flow logging is enabled in all VPCs", + "description": "VPC Flow Logs is a feature that enables you to capture information about the IP traffic going to and from network interfaces in your VPC. After you've created a flow log, you can view and retrieve its data in Amazon CloudWatch Logs. It is recommended that VPC Flow Logs be enabled for packet \"Rejects\" for VPCs.", + "checks": [ + "aws_ec2_vpc_flow_logs_enabled" + ] + }, + { + "title": "3.10 Ensure that Object-level logging for write events is enabled for S3 bucket", + "description": "S3 object-level API operations such as GetObject, DeleteObject, and PutObject are called data events. By default, CloudTrail trails don't log data events and so it is recommended to enable Object-level logging for S3 buckets.", + "checks": [ + "aws_cloudtrail_s3_data_events_write_enabled" + ] + }, + { + "title": "3.11 Ensure that Object-level logging for read events is enabled for S3 bucket", + "description": "S3 object-level API operations such as GetObject, DeleteObject, and PutObject are called data events. By default, CloudTrail trails don't log data events and so it is recommended to enable Object-level logging for S3 buckets.", + "checks": [ + "aws_cloudtrail_s3_data_events_read_enabled" + ] + } + ] + }, + { + "title": "Section 4: Monitoring", + "description": "This section contains recommendations for configuring AWS to assist with monitoring and responding to account activities.", + "children": [ + { + "title": "4.1 Ensure a log metric filter and alarm exist for unauthorized API calls", + "description": "Real-time monitoring of API calls can be achieved by directing CloudTrail Logs to CloudWatch Logs and establishing corresponding metric filters and alarms. It is recommended that a metric filter and alarm be established for unauthorized API calls.", + "checks": [ + "aws_cloudtrail_log_metric_filters_unauthorized_api_calls" + ] + }, + { + "title": "4.2 Ensure a log metric filter and alarm exist for Management Console sign-in without MFA", + "description": "Real-time monitoring of API calls can be achieved by directing CloudTrail Logs to CloudWatch Logs and establishing corresponding metric filters and alarms. It is recommended that a metric filter and alarm be established for console logins that are not protected by multi-factor authentication (MFA).", + "checks": [ + "aws_cloudtrail_log_metric_filters_console_login_no_mfa" + ] + }, + { + "title": "4.3 Ensure a log metric filter and alarm exist for usage of 'root' account", + "description": "Real-time monitoring of API calls can be achieved by directing CloudTrail Logs to CloudWatch Logs and establishing corresponding metric filters and alarms. It is recommended that a metric filter and alarm be established for root login attempts.", + "checks": [ + "aws_cloudtrail_log_metric_filters_root_account_usage" + ] + }, + { + "title": "4.4 Ensure a log metric filter and alarm exist for IAM policy changes", + "description": "Real-time monitoring of API calls can be achieved by directing CloudTrail Logs to CloudWatch Logs and establishing corresponding metric filters and alarms. It is recommended that a metric filter and alarm be established changes made to Identity and Access Management (IAM) policies.", + "checks": [ + "aws_cloudtrail_log_metric_filters_iam_policy_changes" + ] + }, + { + "title": "4.5 Ensure a log metric filter and alarm exist for CloudTrail configuration changes", + "description": "Real-time monitoring of API calls can be achieved by directing CloudTrail Logs to CloudWatch Logs and establishing corresponding metric filters and alarms. It is recommended that a metric filter and alarm be established for detecting changes to CloudTrail's configurations.", + "checks": [ + "aws_cloudtrail_log_metric_filters_cloud_trail_configuration_changes" + ] + }, + { + "title": "4.6 Ensure a log metric filter and alarm exist for AWS Management Console authentication failures", + "description": "Real-time monitoring of API calls can be achieved by directing CloudTrail Logs to CloudWatch Logs and establishing corresponding metric filters and alarms. It is recommended that a metric filter and alarm be established for failed console authentication attempts.", + "checks": [ + "aws_cloudtrail_log_metric_filters_authentication_failures" + ] + }, + { + "title": "4.7 Ensure a log metric filter and alarm exist for disabling or scheduled deletion of customer created CMKs", + "description": "Real-time monitoring of API calls can be achieved by directing CloudTrail Logs to CloudWatch Logs and establishing corresponding metric filters and alarms. It is recommended that a metric filter and alarm be established for customer created CMKs which have changed state to disabled or scheduled deletion.", + "checks": [ + "aws_cloudtrail_log_metric_filters_kms_key_deletion" + ] + }, + { + "title": "4.8 Ensure a log metric filter and alarm exist for S3 bucket policy changes", + "description": "Real-time monitoring of API calls can be achieved by directing CloudTrail Logs to CloudWatch Logs and establishing corresponding metric filters and alarms. It is recommended that a metric filter and alarm be established for changes to S3 bucket policies.", + "checks": [ + "aws_cloudtrail_log_metric_filters_s3_bucket_policy_changes" + ] + }, + { + "title": "4.9 Ensure a log metric filter and alarm exist for AWS Config configuration changes", + "description": "Real-time monitoring of API calls can be achieved by directing CloudTrail Logs to CloudWatch Logs and establishing corresponding metric filters and alarms. It is recommended that a metric filter and alarm be established for detecting changes to CloudTrail's configurations.", + "checks": [ + "aws_cloudtrail_log_metric_filters_config_configuration_changes" + ] + }, + { + "title": "4.10 Ensure a log metric filter and alarm exist for security group changes", + "description": "Real-time monitoring of API calls can be achieved by directing CloudTrail Logs to CloudWatch Logs and establishing corresponding metric filters and alarms. Security Groups are a stateful packet filter that controls ingress and egress traffic within a VPC. It is recommended that a metric filter and alarm be established for detecting changes to Security Groups.", + "checks": [ + "aws_cloudtrail_log_metric_filters_security_group_changes" + ] + }, + { + "title": "4.11 Ensure a log metric filter and alarm exist for changes to Network Access Control Lists (NACL)", + "description": "Real-time monitoring of API calls can be achieved by directing CloudTrail Logs to CloudWatch Logs and establishing corresponding metric filters and alarms. NACLs are used as a stateless packet filter to control ingress and egress traffic for subnets within a VPC. It is recommended that a metric filter and alarm be established for changes made to NACLs.", + "checks": [ + "aws_cloudtrail_log_metric_filters_network_acl_changes" + ] + }, + { + "title": "4.12 Ensure a log metric filter and alarm exist for changes to network gateways", + "description": "Real-time monitoring of API calls can be achieved by directing CloudTrail Logs to CloudWatch Logs and establishing corresponding metric filters and alarms. Network gateways are required to send/receive traffic to a destination outside of a VPC. It is recommended that a metric filter and alarm be established for changes to network gateways.", + "checks": [ + "aws_cloudtrail_log_metric_filters_network_gateway_changes" + ] + }, + { + "title": "4.13 Ensure a log metric filter and alarm exist for route table changes", + "description": "Real-time monitoring of API calls can be achieved by directing CloudTrail Logs to CloudWatch Logs and establishing corresponding metric filters and alarms. Routing tables are used to route network traffic between subnets and to network gateways. It is recommended that a metric filter and alarm be established for changes to route tables.", + "checks": [ + "aws_cloudtrail_log_metric_filters_route_table_changes" + ] + }, + { + "title": "4.14 Ensure a log metric filter and alarm exist for VPC changes", + "description": "Real-time monitoring of API calls can be achieved by directing CloudTrail Logs to CloudWatch Logs and establishing corresponding metric filters and alarms. It is possible to have more than 1 VPC within an account, in addition it is also possible to create a peer connection between 2 VPCs enabling network traffic to route between VPCs. It is recommended that a metric filter and alarm be established for changes made to VPCs.", + "checks": [ + "aws_cloudtrail_log_metric_filters_vpc_changes" + ] + }, + { + "title": "4.15 Ensure a log metric filter and alarm exists for AWS Organizations changes", + "description": "Real-time monitoring of API calls can be achieved by directing CloudTrail Logs to CloudWatch Logs and establishing corresponding metric filters and alarms. It is recommended that a metric filter and alarm be established for AWS Organizations changes made in the master AWS Account.", + "checks": [ + "aws_cloudtrail_log_metric_filters_aws_org_changes" + ] + }, + { + "title": "4.16 Ensure AWS Security Hub is enabled", + "description": "Security Hub collects security data from across AWS accounts, services, and supported third-party partner products and helps you analyze your security trends and identify the highest priority security issues. When you enable Security Hub, it begins to consume, aggregate, organize, and prioritize findings from AWS services that you have enabled, such as Amazon GuardDuty, Amazon Inspector, and Amazon Macie. You can also enable integrations with AWS partner security products.", + "checks": [ + "aws_cloudtrail_security_hub_enabled" + ] + } + ] + }, + { + "title": "Section 5: Networking", + "description": "This section contains recommendations for configuring security-related aspects of AWS Virtual Private Cloud (VPC).", + "children": [ + { + "title": "5.1 Ensure no Network ACLs allow ingress from 0.0.0.0/0 to remote server administration ports", + "description": "The Network Access Control List (NACL) function provide stateless filtering of ingress and egress network traffic to AWS resources. It is recommended that no NACL allows unrestricted ingress access to remote server administration ports, such as SSH to port 22 and RDP to port 3389.", + "checks": [ + "aws_ec2_allow_ingress_any_port_ipv4", + "aws_ec2_allow_ingress_any_port_ipv6", + "aws_ec2_allow_ingress_ssh_port_22_ipv4", + "aws_ec2_allow_ingress_ssh_port_22_ipv6", + "aws_ec2_allow_ingress_rdp_port_3389_ipv4", + "aws_ec2_allow_ingress_rdp_port_3389_ipv6" + ] + }, + { + "title": "5.2 Ensure no security groups allow ingress from 0.0.0.0/0 to remote server administration ports", + "description": "Security groups provide stateful filtering of ingress and egress network traffic to AWS resources. It is recommended that no security group allows unrestricted ingress access to remote server administration ports, such as SSH to port 22 and RDP to port 3389.", + "checks": [ + "aws_ec2_allow_ingress_from_internet_to_any_port_ipv4", + "aws_ec2_allow_ingress_from_internet_to_ssh_port_22_ipv4", + "aws_ec2_allow_ingress_from_internet_to_rdp_port_3389_ipv4" + ] + }, + { + "title": "5.3 Ensure no security groups allow ingress from ::/0 to remote server administration ports", + "description": "Security groups provide stateful filtering of ingress and egress network traffic to AWS resources. It is recommended that no security group allows unrestricted ingress access to remote server administration ports, such as SSH to port 22 and RDP to port 3389.", + "checks": [ + "aws_ec2_allow_ingress_from_internet_to_any_port_ipv6", + "aws_ec2_allow_ingress_from_internet_to_ssh_port_22_ipv6", + "aws_ec2_allow_ingress_from_internet_to_rdp_port_3389_ipv6" + ] + }, + { + "title": "5.4 Ensure the default security group of every VPC restricts all traffic", + "description": "A VPC comes with a default security group whose initial settings deny all inbound traffic, allow all outbound traffic, and allow all traffic between instances assigned to the security group. If you don't specify a security group when you launch an instance, the instance is automatically assigned to this default security group. Security groups provide stateful filtering of ingress/egress network traffic to AWS resources. It is recommended that the default security group restrict all traffic.", + "checks": [ + "aws_ec2_default_restrict_traffic" + ] + }, + { + "title": "5.5 Ensure routing tables for VPC peering are \"least access\"", + "description": "Once a VPC peering connection is established, routing tables must be updated to establish any connections between the peered VPCs. These routes can be as specific as desired - even peering a VPC to only a single host on the other side of the connection.", + "checks": [ + "aws_ec2_routing_tables_with_least_privilege" + ] + } + ] + } + ] +} diff --git a/resotocore/resotocore/static/report/checks/aws/aws_ec2.json b/resotocore/resotocore/static/report/checks/aws/aws_ec2.json index cf5acefc7a..ec666207b8 100644 --- a/resotocore/resotocore/static/report/checks/aws/aws_ec2.json +++ b/resotocore/resotocore/static/report/checks/aws/aws_ec2.json @@ -204,8 +204,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_any_port_ipv4", @@ -220,8 +219,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_any_port_ipv6", @@ -236,8 +234,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_port_mongodb_27017_27018", @@ -252,8 +249,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_ssh_port_22", @@ -268,8 +264,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_ssh_port_22_ipv4", @@ -284,8 +279,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_ssh_port_22_ipv6", @@ -300,8 +294,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_ftp_port_20_21", @@ -316,8 +309,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_rdp_port_3389", @@ -332,8 +324,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_rdp_port_3389_ipv4", @@ -348,8 +339,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_rdp_port_3389_ipv6", @@ -364,8 +354,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_cassandra_ports", @@ -380,8 +369,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_kibana_ports", @@ -396,8 +384,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_kafka_ports", @@ -412,8 +399,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_memcached_ports", @@ -428,8 +414,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_mysql_ports", @@ -444,8 +429,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_oracledb", @@ -460,8 +444,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_postgresql_ports", @@ -476,8 +459,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_redis_ports", @@ -492,8 +474,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_sql_server_ports", @@ -508,8 +489,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "allow_ingress_from_internet_to_telnet_ports", @@ -524,8 +504,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "wide_open_ipv4_security_group", @@ -540,8 +519,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "default_restrict_traffic", @@ -556,8 +534,7 @@ "remediation": { "text": "Apply Zero Trust approach. Implement a process to scan and remediate unrestricted or overly permissive network acls. Recommended best practices is to narrow the definition for the minimum ports required.", "url": "https://docs.aws.amazon.com/vpc/latest/userguide/vpc-network-acls.html" - }, - "internal_notes": "" + } }, { "name": "routing_tables_with_least_privilege", @@ -588,8 +565,7 @@ "remediation": { "text": "Encrypt all EBS volumes and Enable Encryption by default You can configure your AWS account to enforce the encryption of the new EBS volumes and snapshot copies that you create. For example; Amazon EBS encrypts the EBS volumes created when you launch an instance and the snapshots that you copy from an unencrypted snapshot.", "url": "https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/EBSEncryption.html" - }, - "internal_notes": "" + } }, { "name": "vpc_flow_logs_enabled", @@ -604,8 +580,23 @@ "remediation": { "text": "It is recommended that VPC Flow Logs be enabled for packet Rejects for VPCs.", "url": "http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/flow-logs.html" + } + }, + { + "name": "instance_imdsv2_enabled", + "title": "Ensure that EC2 Metadata Service only allows IMDSv2", + "result_kinds": ["aws_ec2_instance"], + "categories": [ "security", "compliance" ], + "risk": "Allowing Version 1 of the service may open EC2 instances to Server-Side Request Forgery (SSRF) attacks, so Amazon recommends utilizing Version 2 for better instance security.", + "severity": "medium", + "detect": { + "resoto": "is(aws_ec2_instance) and not instance_metadata_options.{(http_endpoint=enabled and http_tokens=required) or http_endpoint=disabled}" }, - "internal_notes": "" + "remediation": { + "text": "Login to AWS Management Console and open the Amazon EC2 console using https://console.aws.amazon.com/ec2/ Under the Instances menu, select Instances. For each Instance, select the instance, then choose Actions > Modify instance metadata options. If the Instance metadata service is enabled, set IMDSv2 to Required.", + "awscli": "aws ec2 modify-instance-metadata-options --instance-id --http-tokens required", + "url": "https://aws.amazon.com/blogs/security/defense-in-depth-open-firewalls-reverse-proxies-ssrf-vulnerabilities-ec2-instance-metadata-service/:https://docs.aws.amazon.com/cli/latest/reference/ec2/describe-instances.html" + } } ] } diff --git a/resotocore/resotocore/static/report/checks/aws/aws_iam.json b/resotocore/resotocore/static/report/checks/aws/aws_iam.json index 4676fb8432..8cb1d5b39e 100644 --- a/resotocore/resotocore/static/report/checks/aws/aws_iam.json +++ b/resotocore/resotocore/static/report/checks/aws/aws_iam.json @@ -318,6 +318,21 @@ "text": "Enable SAML provider and use temporary credentials. You can use temporary security credentials to make programmatic requests for AWS resources using the AWS CLI or AWS API (using the AWS SDKs ). The temporary credentials provide the same permissions that you have with use long-term security credentials such as IAM user credentials. In case of not having SAML provider capabilities prevent usage of long-lived credentials.", "url": "https://docs.aws.amazon.com/STS/latest/APIReference/API_AssumeRoleWithSAML.html" } + }, + { + "name": "check_cloudshell_access_restricted", + "title": "Ensure access to AWSCloudShellFullAccess is restricted", + "result_kind": ["aws_iam_role", "aws_iam_user"], + "categories": [ "security", "compliance" ], + "risk": "Access to this policy should be restricted as it presents a potential channel for data exfiltration by malicious cloud admins that are given full permissions to the service. AWS documentation describes how to create a more restrictive IAM policy which denies file transfer permissions.", + "severity": "medium", + "detect": { + "resoto": "is(aws_iam_policy) and name==AWSCloudShellFullAccess <-- is(aws_iam_user, aws_iam_role)" + }, + "remediation": { + "text": "Open the IAM console at https://console.aws.amazon.com/iam/ In the left pane, select Policies. Search for and select AWSCloudShellFullAccess. On the Entities attached tab, for each item, check the box and select Detach.", + "url": "https://docs.aws.amazon.com/cloudshell/latest/userguide/sec-auth-with-identities.html" + } } ] }