Skip to content

Commit

Permalink
Run ruff check --fix --unsafe-fixes
Browse files Browse the repository at this point in the history
  • Loading branch information
kdaily committed Dec 20, 2024
1 parent f98cc7f commit 728733e
Show file tree
Hide file tree
Showing 14 changed files with 71 additions and 92 deletions.
4 changes: 2 additions & 2 deletions awscli/customizations/cloudformation/artifact_exporter.py
Original file line number Diff line number Diff line change
Expand Up @@ -289,7 +289,7 @@ class ResourceWithS3UrlDict(Resource):
VERSION_PROPERTY = None

def __init__(self, uploader):
super(ResourceWithS3UrlDict, self).__init__(uploader)
super().__init__(uploader)

def do_export(self, resource_id, resource_dict, parent_dir):
"""
Expand Down Expand Up @@ -444,7 +444,7 @@ class CloudFormationStackResource(Resource):
PROPERTY_NAME = "TemplateURL"

def __init__(self, uploader):
super(CloudFormationStackResource, self).__init__(uploader)
super().__init__(uploader)

def do_export(self, resource_id, resource_dict, parent_dir):
"""
Expand Down
6 changes: 3 additions & 3 deletions awscli/customizations/cloudtrail/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ def get_trail_by_arn(cloudtrail_client, trail_arn):
for trail in trails:
if trail.get("TrailARN", None) == trail_arn:
return trail
raise ValueError("A trail could not be found for %s" % trail_arn)
raise ValueError(f"A trail could not be found for {trail_arn}")


def format_date(date):
Expand All @@ -45,7 +45,7 @@ def parse_date(date_string):
try:
return parser.parse(date_string)
except ValueError:
raise ValueError("Unable to parse date value: %s" % date_string)
raise ValueError(f"Unable to parse date value: {date_string}")


class PublicKeyProvider:
Expand Down Expand Up @@ -94,5 +94,5 @@ def get_public_key(self, signature_generate_time, public_key_fingerprint):
return key["Value"]

raise RuntimeError(
"No public keys found for key with fingerprint: %s" % public_key_fingerprint
f"No public keys found for key with fingerprint: {public_key_fingerprint}"
)
80 changes: 30 additions & 50 deletions awscli/customizations/cloudtrail/validation.py
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,7 @@ def parse_date(date_string):
return parser.parse(date_string)
except ValueError:
raise ParamValidationError(
'Unable to parse date value: %s' % date_string
f'Unable to parse date value: {date_string}'
)


Expand All @@ -77,7 +77,7 @@ def assert_cloudtrail_arn_is_valid(trail_arn):
pattern = re.compile(r'arn:.+:cloudtrail:.+:\d{12}:trail/.+')
if not pattern.match(trail_arn):
raise ParamValidationError(
'Invalid trail ARN provided: %s' % trail_arn
f'Invalid trail ARN provided: {trail_arn}'
)


Expand Down Expand Up @@ -202,17 +202,16 @@ class DigestError(ValueError):
class DigestSignatureError(DigestError):
"""Exception raised when a digest signature is invalid"""
def __init__(self, bucket, key):
message = ('Digest file\ts3://%s/%s\tINVALID: signature verification '
'failed') % (bucket, key)
super(DigestSignatureError, self).__init__(message)
message = (f'Digest file\ts3://{bucket}/{key}\tINVALID: signature verification '
'failed')
super().__init__(message)


class InvalidDigestFormat(DigestError):
"""Exception raised when a digest has an invalid format"""
def __init__(self, bucket, key):
message = 'Digest file\ts3://%s/%s\tINVALID: invalid format' % (bucket,
key)
super(InvalidDigestFormat, self).__init__(message)
message = f'Digest file\ts3://{bucket}/{key}\tINVALID: invalid format'
super().__init__(message)


class DigestProvider:
Expand Down Expand Up @@ -444,8 +443,7 @@ def traverse(self, start_date, end_date=None):
key, end_date = self._find_next_digest(
digests=digests, bucket=bucket, last_key=key,
last_start_date=last_start_date, cb=self._on_invalid,
message='Digest file\ts3://%s/%s\tINVALID: %s'
% (bucket, key, str(e)))
message=f'Digest file\ts3://{bucket}/{key}\tINVALID: {str(e)}')

def _load_digests(self, bucket, prefix, start_date, end_date):
return self.digest_provider.load_digest_keys_in_range(
Expand Down Expand Up @@ -502,16 +500,14 @@ def _load_and_validate_digest(self, public_keys, bucket, key):
if digest_data['digestS3Bucket'] != bucket \
or digest_data['digestS3Object'] != key:
raise DigestError(
('Digest file\ts3://%s/%s\tINVALID: has been moved from its '
'original location') % (bucket, key))
f'Digest file\ts3://{bucket}/{key}\tINVALID: has been moved from its '
'original location')
# Get the public keys in the given time range.
fingerprint = digest_data['digestPublicKeyFingerprint']
if fingerprint not in public_keys:
raise DigestError(
('Digest file\ts3://%s/%s\tINVALID: public key not found in '
'region %s for fingerprint %s') %
(bucket, key, self.digest_provider.trail_home_region,
fingerprint))
f'Digest file\ts3://{bucket}/{key}\tINVALID: public key not found in '
f'region {self.digest_provider.trail_home_region} for fingerprint {fingerprint}')
public_key_hex = public_keys[fingerprint]['Value']
self._digest_validator.validate(
bucket, key, public_key_hex, digest_data, digest)
Expand All @@ -523,9 +519,7 @@ def _load_public_keys(self, start_date, end_date):
start_date, end_date)
if not public_keys:
raise RuntimeError(
'No public keys found between %s and %s' %
(format_display_date(start_date),
format_display_date(end_date)))
f'No public keys found between {format_display_date(start_date)} and {format_display_date(end_date)}')
return public_keys


Expand Down Expand Up @@ -554,9 +548,8 @@ def validate(self, bucket, key, public_key, digest_data, inflated_digest):
public_key = RSA.new_public_key_from_der_data(decoded_key)
except RuntimeError:
raise DigestError(
('Digest file\ts3://%s/%s\tINVALID: Unable to load PKCS #1 key'
' with fingerprint %s')
% (bucket, key, digest_data['digestPublicKeyFingerprint']))
('Digest file\ts3://{}/{}\tINVALID: Unable to load PKCS #1 key'
' with fingerprint {}').format(bucket, key, digest_data['digestPublicKeyFingerprint']))

to_sign = self._create_string_to_sign(digest_data, inflated_digest)
signature_bytes = binascii.unhexlify(digest_data['_signature'])
Expand All @@ -577,7 +570,7 @@ def _create_string_to_sign(self, digest_data, inflated_digest):
if previous_signature is None:
# The value must be 'null' to match the Java implementation.
previous_signature = 'null'
string_to_sign = "%s\n%s/%s\n%s\n%s" % (
string_to_sign = "{}\n{}/{}\n{}\n{}".format(
digest_data['digestEndTime'],
digest_data['digestS3Bucket'],
digest_data['digestS3Object'],
Expand Down Expand Up @@ -668,7 +661,7 @@ class CloudTrailValidateLogs(BasicCommand):
]

def __init__(self, session):
super(CloudTrailValidateLogs, self).__init__(session)
super().__init__(session)
self.trail_arn = None
self.is_verbose = False
self.start_time = None
Expand Down Expand Up @@ -750,8 +743,7 @@ def _call(self):
self._track_found_times(digest)
self._valid_digests += 1
self._write_status(
'Digest file\ts3://%s/%s\tvalid'
% (digest['digestS3Bucket'], digest['digestS3Object']))
'Digest file\ts3://{}/{}\tvalid'.format(digest['digestS3Bucket'], digest['digestS3Object']))
if not digest['logFiles']:
continue
for log in digest['logFiles']:
Expand Down Expand Up @@ -790,8 +782,7 @@ def _download_log(self, log):
self._on_log_invalid(log)
else:
self._valid_logs += 1
self._write_status('Log file\ts3://%s/%s\tvalid'
% (log['s3Bucket'], log['s3Object']))
self._write_status('Log file\ts3://{}/{}\tvalid'.format(log['s3Bucket'], log['s3Object']))
except ClientError as e:
if e.response['Error']['Code'] != 'NoSuchKey':
raise
Expand All @@ -802,35 +793,29 @@ def _download_log(self, log):
def _write_status(self, message, is_error=False):
if is_error:
if self._is_last_status_double_space:
sys.stderr.write("%s\n\n" % message)
sys.stderr.write(f"{message}\n\n")
else:
sys.stderr.write("\n%s\n\n" % message)
sys.stderr.write(f"\n{message}\n\n")
self._is_last_status_double_space = True
elif self.is_verbose:
self._is_last_status_double_space = False
sys.stdout.write("%s\n" % message)
sys.stdout.write(f"{message}\n")

def _write_startup_text(self):
sys.stdout.write(
'Validating log files for trail %s between %s and %s\n\n'
% (self.trail_arn, format_display_date(self.start_time),
format_display_date(self.end_time)))
f'Validating log files for trail {self.trail_arn} between {format_display_date(self.start_time)} and {format_display_date(self.end_time)}\n\n')

def _write_summary_text(self):
if not self._is_last_status_double_space:
sys.stdout.write('\n')
sys.stdout.write('Results requested for %s to %s\n'
% (format_display_date(self.start_time),
format_display_date(self.end_time)))
sys.stdout.write(f'Results requested for {format_display_date(self.start_time)} to {format_display_date(self.end_time)}\n')
if not self._valid_digests and not self._invalid_digests:
sys.stdout.write('No digests found\n')
return
if not self._found_start_time or not self._found_end_time:
sys.stdout.write('No valid digests found in range\n')
else:
sys.stdout.write('Results found for %s to %s:\n'
% (format_display_date(self._found_start_time),
format_display_date(self._found_end_time)))
sys.stdout.write(f'Results found for {format_display_date(self._found_start_time)} to {format_display_date(self._found_end_time)}:\n')
self._write_ratio(self._valid_digests, self._invalid_digests, 'digest')
self._write_ratio(self._valid_logs, self._invalid_logs, 'log')
sys.stdout.write('\n')
Expand All @@ -845,13 +830,11 @@ def _write_ratio(self, valid, invalid, name):

def _on_missing_digest(self, bucket, last_key, **kwargs):
self._invalid_digests += 1
self._write_status('Digest file\ts3://%s/%s\tINVALID: not found'
% (bucket, last_key), True)
self._write_status(f'Digest file\ts3://{bucket}/{last_key}\tINVALID: not found', True)

def _on_digest_gap(self, **kwargs):
self._write_status(
'No log files were delivered by CloudTrail between %s and %s'
% (format_display_date(kwargs['next_end_date']),
'No log files were delivered by CloudTrail between {} and {}'.format(format_display_date(kwargs['next_end_date']),
format_display_date(kwargs['last_start_date'])), True)

def _on_invalid_digest(self, message, **kwargs):
Expand All @@ -861,17 +844,14 @@ def _on_invalid_digest(self, message, **kwargs):
def _on_invalid_log_format(self, log_data):
self._invalid_logs += 1
self._write_status(
('Log file\ts3://%s/%s\tINVALID: invalid format'
% (log_data['s3Bucket'], log_data['s3Object'])), True)
('Log file\ts3://{}/{}\tINVALID: invalid format'.format(log_data['s3Bucket'], log_data['s3Object'])), True)

def _on_log_invalid(self, log_data):
self._invalid_logs += 1
self._write_status(
"Log file\ts3://%s/%s\tINVALID: hash value doesn't match"
% (log_data['s3Bucket'], log_data['s3Object']), True)
"Log file\ts3://{}/{}\tINVALID: hash value doesn't match".format(log_data['s3Bucket'], log_data['s3Object']), True)

def _on_missing_log(self, log_data):
self._invalid_logs += 1
self._write_status(
'Log file\ts3://%s/%s\tINVALID: not found'
% (log_data['s3Bucket'], log_data['s3Object']), True)
'Log file\ts3://{}/{}\tINVALID: not found'.format(log_data['s3Bucket'], log_data['s3Object']), True)
14 changes: 7 additions & 7 deletions awscli/customizations/configservice/getstatus.py
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ class GetStatusCommand(BasicCommand):

def __init__(self, session):
self._config_client = None
super(GetStatusCommand, self).__init__(session)
super().__init__(session)

def _run_main(self, parsed_args, parsed_globals):
self._setup_client(parsed_globals)
Expand All @@ -57,12 +57,12 @@ def _check_configuration_recorders(self):
def _check_configure_recorder_status(self, configuration_recorder):
# Get the name of the recorder and print it out.
name = configuration_recorder['name']
sys.stdout.write('name: %s\n' % name)
sys.stdout.write(f'name: {name}\n')

# Get the recording status and print it out.
recording = configuration_recorder['recording']
recording_map = {False: 'OFF', True: 'ON'}
sys.stdout.write('recorder: %s\n' % recording_map[recording])
sys.stdout.write(f'recorder: {recording_map[recording]}\n')

# If the recorder is on, get the last status and print it out.
if recording:
Expand All @@ -78,7 +78,7 @@ def _check_delivery_channels(self):
def _check_delivery_channel_status(self, delivery_channel):
# Get the name of the delivery channel and print it out.
name = delivery_channel['name']
sys.stdout.write('name: %s\n' % name)
sys.stdout.write(f'name: {name}\n')

# Obtain the various delivery statuses.
stream_delivery = delivery_channel['configStreamDeliveryInfo']
Expand All @@ -95,7 +95,7 @@ def _check_delivery_channel_status(self, delivery_channel):

def _check_last_status(self, status, status_name=''):
last_status = status['lastStatus']
sys.stdout.write('last %sstatus: %s\n' % (status_name, last_status))
sys.stdout.write(f'last {status_name}status: {last_status}\n')
if last_status == "FAILURE":
sys.stdout.write('error code: %s\n' % status['lastErrorCode'])
sys.stdout.write('message: %s\n' % status['lastErrorMessage'])
sys.stdout.write('error code: {}\n'.format(status['lastErrorCode']))
sys.stdout.write('message: {}\n'.format(status['lastErrorMessage']))
10 changes: 5 additions & 5 deletions awscli/customizations/configservice/subscribe.py
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ def __init__(self, session):
self._s3_client = None
self._sns_client = None
self._config_client = None
super(SubscribeCommand, self).__init__(session)
super().__init__(session)

def _run_main(self, parsed_args, parsed_globals):
# Setup the necessary all of the necessary clients.
Expand Down Expand Up @@ -139,9 +139,9 @@ def prepare_bucket(self, s3_path):
bucket_exists = self._check_bucket_exists(bucket)
if not bucket_exists:
self._create_bucket(bucket)
sys.stdout.write('Using new S3 bucket: %s\n' % bucket)
sys.stdout.write(f'Using new S3 bucket: {bucket}\n')
else:
sys.stdout.write('Using existing S3 bucket: %s\n' % bucket)
sys.stdout.write(f'Using existing S3 bucket: {bucket}\n')
return bucket, key

def _check_bucket_exists(self, bucket):
Expand All @@ -168,9 +168,9 @@ def prepare_topic(self, sns_topic):
if not self._check_is_arn(sns_topic):
response = self._sns_client.create_topic(Name=sns_topic)
sns_topic_arn = response['TopicArn']
sys.stdout.write('Using new SNS topic: %s\n' % sns_topic_arn)
sys.stdout.write(f'Using new SNS topic: {sns_topic_arn}\n')
else:
sys.stdout.write('Using existing SNS topic: %s\n' % sns_topic_arn)
sys.stdout.write(f'Using existing SNS topic: {sns_topic_arn}\n')
return sns_topic_arn

def _check_is_arn(self, sns_topic):
Expand Down
4 changes: 2 additions & 2 deletions awscli/customizations/configure/configure.py
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ class InteractivePrompter:
def get_value(self, current_value, config_name, prompt_text=''):
if config_name in ('aws_access_key_id', 'aws_secret_access_key'):
current_value = mask_value(current_value)
response = compat_input("%s [%s]: " % (prompt_text, current_value))
response = compat_input(f"{prompt_text} [{current_value}]: ")
if not response:
# If the user hits enter, we return a value of None
# instead of an empty string. That way we can determine
Expand Down Expand Up @@ -98,7 +98,7 @@ class ConfigureCommand(BasicCommand):
]

def __init__(self, session, prompter=None, config_writer=None):
super(ConfigureCommand, self).__init__(session)
super().__init__(session)
if prompter is None:
prompter = InteractivePrompter()
self._prompter = prompter
Expand Down
2 changes: 1 addition & 1 deletion awscli/customizations/configure/exportcreds.py
Original file line number Diff line number Diff line change
Expand Up @@ -194,7 +194,7 @@ class ConfigureExportCredentialsCommand(BasicCommand):
_MAX_RECURSION = 4

def __init__(self, session, out_stream=None, error_stream=None, env=None):
super(ConfigureExportCredentialsCommand, self).__init__(session)
super().__init__(session)
if out_stream is None:
out_stream = sys.stdout
if error_stream is None:
Expand Down
8 changes: 4 additions & 4 deletions awscli/customizations/configure/get.py
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ class ConfigureGetCommand(BasicCommand):
]

def __init__(self, session, stream=None, error_stream=None):
super(ConfigureGetCommand, self).__init__(session)
super().__init__(session)
if stream is None:
stream = sys.stdout
if error_stream is None:
Expand All @@ -53,7 +53,7 @@ def _run_main(self, args, parsed_globals):
else:
value = self._get_dotted_config_value(varname)

LOG.debug('Config value retrieved: %s' % value)
LOG.debug(f'Config value retrieved: {value}')

if isinstance(value, str):
self._stream.write(value)
Expand All @@ -63,8 +63,8 @@ def _run_main(self, args, parsed_globals):
# TODO: add support for this. We would need to print it off in
# the same format as the config file.
self._error_stream.write(
'varname (%s) must reference a value, not a section or '
'sub-section.' % varname
f'varname ({varname}) must reference a value, not a section or '
'sub-section.'
)
return 1
else:
Expand Down
Loading

0 comments on commit 728733e

Please sign in to comment.