aws-sdk-secrets-manager 0.1.0__tar.gz
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.
- aws_sdk_secrets_manager-0.1.0/LICENSE +21 -0
- aws_sdk_secrets_manager-0.1.0/PKG-INFO +82 -0
- aws_sdk_secrets_manager-0.1.0/README.md +60 -0
- aws_sdk_secrets_manager-0.1.0/pyproject.toml +41 -0
- aws_sdk_secrets_manager-0.1.0/setup.cfg +4 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/__init__.py +17 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_async.py +25 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_auth/_identity.py +15 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_auth/_providers.py +159 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_auth/_signers.py +83 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_auth/_sigv4.py +364 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_auth/_zapros_handler.py +62 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/batch_get_secret_value.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/cancel_rotate_secret.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/create_secret.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/delete_resource_policy.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/delete_secret.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/describe_secret.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/get_random_password.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/get_resource_policy.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/get_secret_value.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/list_secret_version_ids.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/list_secrets.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/put_resource_policy.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/put_secret_value.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/remove_regions_from_replication.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/replicate_secret_to_regions.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/restore_secret.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/rotate_secret.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/stop_replication_to_replica.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/tag_resource.py +27 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/untag_resource.py +27 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/update_secret.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/update_secret_version_stage.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_operations/secretsmanager/validate_resource_policy.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_pagination.py +21 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_protocol/__init__.py +1 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_protocol/errors.py +58 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_protocol/xml.py +27 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_rule_engine/__init__.py +0 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_rule_engine/_aws_partition.py +160 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_rule_engine/_endpoint_rule_set.py +217 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_rule_engine/_endpoint_runtime.py +389 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_services/_pipeline.py +194 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_services/async_secrets_manager.py +1573 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/_services/secrets_manager.py +1548 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/errors/__init__.py +35 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/errors/_base.py +94 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/errors/decryption_failure.py +27 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/errors/encryption_failure.py +27 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/errors/internal_service_error.py +27 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/errors/invalid_next_token_exception.py +27 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/errors/invalid_parameter_exception.py +27 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/errors/invalid_request_exception.py +27 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/errors/limit_exceeded_exception.py +27 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/errors/malformed_policy_document_exception.py +27 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/errors/precondition_not_met_exception.py +27 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/errors/public_policy_exception.py +27 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/errors/resource_exists_exception.py +27 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/errors/resource_not_found_exception.py +27 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/py.typed +0 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/add_replica_region_list_type.py +10 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/api_error_list_type.py +10 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/api_error_type.py +18 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/automatically_rotate_after_days_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/batch_get_secret_value_request.py +29 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/batch_get_secret_value_response.py +24 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/boolean_type.py +7 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/cancel_rotate_secret_request.py +11 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/cancel_rotate_secret_response.py +20 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/client_request_token_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/create_secret_request.py +53 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/create_secret_response.py +25 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/created_date_type.py +6 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/delete_resource_policy_request.py +11 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/delete_resource_policy_response.py +15 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/delete_secret_request.py +19 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/delete_secret_response.py +20 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/deleted_date_type.py +6 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/deletion_date_type.py +6 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/describe_secret_request.py +11 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/describe_secret_response.py +104 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/description_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/duration_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/error_code.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/error_message.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/exclude_characters_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/exclude_lowercase_type.py +7 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/exclude_numbers_type.py +7 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/exclude_punctuation_type.py +7 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/exclude_uppercase_type.py +7 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/external_secret_rotation_metadata_item.py +19 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/external_secret_rotation_metadata_item_key_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/external_secret_rotation_metadata_item_value_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/external_secret_rotation_metadata_type.py +10 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/filter.py +19 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/filter_name_string_type.py +13 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/filter_value_string_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/filter_values_string_list.py +10 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/filters_list_type.py +8 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/get_random_password_request.py +45 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/get_random_password_response.py +14 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/get_resource_policy_request.py +11 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/get_resource_policy_response.py +20 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/get_secret_value_request.py +22 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/get_secret_value_response.py +40 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/include_space_type.py +7 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/kms_key_id_list_type.py +10 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/kms_key_id_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/last_accessed_date_type.py +6 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/last_changed_date_type.py +6 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/last_rotated_date_type.py +6 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/list_secret_version_ids_request.py +25 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/list_secret_version_ids_response.py +25 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/list_secrets_request.py +35 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/list_secrets_response.py +19 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/max_results_batch_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/max_results_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/medea_type_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/name_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/next_rotation_date_type.py +6 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/next_token_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/non_empty_resource_policy_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/owning_service_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/password_length_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/put_resource_policy_request.py +17 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/put_resource_policy_response.py +15 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/put_secret_value_request.py +37 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/put_secret_value_response.py +25 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/random_password_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/recovery_window_in_days_type.py +7 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/region_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/remove_regions_from_replication_request.py +14 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/remove_regions_from_replication_response.py +17 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/remove_replica_region_list_type.py +10 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/replica_region_type.py +17 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/replicate_secret_to_regions_request.py +19 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/replicate_secret_to_regions_response.py +17 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/replication_status_list_type.py +10 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/replication_status_type.py +30 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/require_each_included_type_type.py +7 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/restore_secret_request.py +11 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/restore_secret_response.py +15 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/role_arn_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/rotate_secret_request.py +40 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/rotate_secret_response.py +20 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/rotation_enabled_type.py +7 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/rotation_lambda_arn_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/rotation_rules_type.py +22 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/rotation_token_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/schedule_expression_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/secret_arn_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/secret_binary_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/secret_id_list_type.py +10 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/secret_id_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/secret_list_entry.py +99 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/secret_list_type.py +10 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/secret_name_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/secret_string_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/secret_value_entry.py +40 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/secret_values_type.py +10 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/secret_version_id_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/secret_version_stage_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/secret_version_stages_type.py +10 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/secret_versions_list_entry.py +34 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/secret_versions_list_type.py +10 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/secret_versions_to_stages_map_type.py +12 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/sort_by_type.py +10 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/sort_order_type.py +8 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/status_message_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/status_type.py +9 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/stop_replication_to_replica_request.py +11 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/stop_replication_to_replica_response.py +12 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/tag.py +15 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/tag_key_list_type.py +10 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/tag_key_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/tag_list_type.py +8 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/tag_resource_request.py +14 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/tag_value_type.py +5 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/timestamp_type.py +6 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/untag_resource_request.py +14 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/update_secret_request.py +40 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/update_secret_response.py +20 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/update_secret_version_stage_request.py +26 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/update_secret_version_stage_response.py +15 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/validate_resource_policy_request.py +15 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/validate_resource_policy_response.py +17 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/validation_errors_entry.py +17 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager/types/validation_errors_type.py +10 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager.egg-info/PKG-INFO +82 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager.egg-info/SOURCES.txt +194 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager.egg-info/dependency_links.txt +1 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager.egg-info/requires.txt +1 -0
- aws_sdk_secrets_manager-0.1.0/src/aws_sdk_secrets_manager.egg-info/top_level.txt +1 -0
- aws_sdk_secrets_manager-0.1.0/tests/test_endpoint_rules.py +596 -0
- aws_sdk_secrets_manager-0.1.0/tests/test_sigv4.py +433 -0
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2026 Karen Petrosyan
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
Metadata-Version: 2.4
|
|
2
|
+
Name: aws-sdk-secrets-manager
|
|
3
|
+
Version: 0.1.0
|
|
4
|
+
Summary: Python SDK for AWS Secrets Manager.
|
|
5
|
+
Classifier: Development Status :: 4 - Beta
|
|
6
|
+
Classifier: Intended Audience :: Developers
|
|
7
|
+
Classifier: License :: OSI Approved :: MIT License
|
|
8
|
+
Classifier: Operating System :: OS Independent
|
|
9
|
+
Classifier: Programming Language :: Python :: 3
|
|
10
|
+
Classifier: Programming Language :: Python :: 3.10
|
|
11
|
+
Classifier: Programming Language :: Python :: 3.11
|
|
12
|
+
Classifier: Programming Language :: Python :: 3.12
|
|
13
|
+
Classifier: Programming Language :: Python :: 3.13
|
|
14
|
+
Classifier: Programming Language :: Python :: 3.14
|
|
15
|
+
Classifier: Topic :: Software Development :: Code Generators
|
|
16
|
+
Classifier: Typing :: Typed
|
|
17
|
+
Requires-Python: >=3.10
|
|
18
|
+
Description-Content-Type: text/markdown
|
|
19
|
+
License-File: LICENSE
|
|
20
|
+
Requires-Dist: zapros>=0.12.0
|
|
21
|
+
Dynamic: license-file
|
|
22
|
+
|
|
23
|
+
# Getting Started
|
|
24
|
+
|
|
25
|
+
## Installation
|
|
26
|
+
|
|
27
|
+
```
|
|
28
|
+
pip install aws_sdk_secrets_manager
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
## Usage
|
|
32
|
+
|
|
33
|
+
```python
|
|
34
|
+
from aws_sdk_secrets_manager import AsyncSecretsManagerClient
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
async def main():
|
|
38
|
+
async with AsyncSecretsManagerClient() as s3:
|
|
39
|
+
# Example: call the batch_get_secret_value operation
|
|
40
|
+
response = await s3.batch_get_secret_value()
|
|
41
|
+
print(response["secret_values"])
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
## Error Handling
|
|
45
|
+
|
|
46
|
+
The SDK raises exceptions for errors returned by the API. Catch them to handle failures gracefully.
|
|
47
|
+
|
|
48
|
+
```python
|
|
49
|
+
from aws_sdk_secrets_manager import AsyncSecretsManagerClient
|
|
50
|
+
from aws_sdk_secrets_manager.error import DecryptionFailure
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
async def main():
|
|
54
|
+
async with AsyncSecretsManagerClient() as s3:
|
|
55
|
+
try:
|
|
56
|
+
await s3.batch_get_secret_value()
|
|
57
|
+
except DecryptionFailure as e:
|
|
58
|
+
print(f"Error: {e}")
|
|
59
|
+
print(e.data) # additional error data
|
|
60
|
+
```
|
|
61
|
+
|
|
62
|
+
## Retrying
|
|
63
|
+
|
|
64
|
+
The SDK retries failed operations automatically. Retry behaviour follows the Smithy specification: errors are retried based on their `is_retryable` and `is_throttling_error` attributes. Throttling errors use a longer base delay. Network-level failures (connection errors and timeouts) are also retried. Non-retryable errors, such as client errors without the `@retryable` trait, are raised immediately without further attempts.
|
|
65
|
+
|
|
66
|
+
The number of attempts defaults to 3 and can be changed at the client level via `retry_max_attempts`, or per call via `config_overrides`.
|
|
67
|
+
|
|
68
|
+
```python
|
|
69
|
+
from aws_sdk_secrets_manager import AsyncSecretsManagerClient
|
|
70
|
+
|
|
71
|
+
|
|
72
|
+
async def main():
|
|
73
|
+
async with AsyncSecretsManagerClient() as s3:
|
|
74
|
+
# Default: 3 attempts for every operation
|
|
75
|
+
response = await s3.batch_get_secret_value()
|
|
76
|
+
|
|
77
|
+
# Override per operation
|
|
78
|
+
response = await s3.batch_get_secret_value(config_overrides={"retry_max_attempts": 5})
|
|
79
|
+
|
|
80
|
+
# Disable retries for this call
|
|
81
|
+
response = await s3.batch_get_secret_value(config_overrides={"retry_max_attempts": 1})
|
|
82
|
+
```
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
# Getting Started
|
|
2
|
+
|
|
3
|
+
## Installation
|
|
4
|
+
|
|
5
|
+
```
|
|
6
|
+
pip install aws_sdk_secrets_manager
|
|
7
|
+
```
|
|
8
|
+
|
|
9
|
+
## Usage
|
|
10
|
+
|
|
11
|
+
```python
|
|
12
|
+
from aws_sdk_secrets_manager import AsyncSecretsManagerClient
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
async def main():
|
|
16
|
+
async with AsyncSecretsManagerClient() as s3:
|
|
17
|
+
# Example: call the batch_get_secret_value operation
|
|
18
|
+
response = await s3.batch_get_secret_value()
|
|
19
|
+
print(response["secret_values"])
|
|
20
|
+
```
|
|
21
|
+
|
|
22
|
+
## Error Handling
|
|
23
|
+
|
|
24
|
+
The SDK raises exceptions for errors returned by the API. Catch them to handle failures gracefully.
|
|
25
|
+
|
|
26
|
+
```python
|
|
27
|
+
from aws_sdk_secrets_manager import AsyncSecretsManagerClient
|
|
28
|
+
from aws_sdk_secrets_manager.error import DecryptionFailure
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
async def main():
|
|
32
|
+
async with AsyncSecretsManagerClient() as s3:
|
|
33
|
+
try:
|
|
34
|
+
await s3.batch_get_secret_value()
|
|
35
|
+
except DecryptionFailure as e:
|
|
36
|
+
print(f"Error: {e}")
|
|
37
|
+
print(e.data) # additional error data
|
|
38
|
+
```
|
|
39
|
+
|
|
40
|
+
## Retrying
|
|
41
|
+
|
|
42
|
+
The SDK retries failed operations automatically. Retry behaviour follows the Smithy specification: errors are retried based on their `is_retryable` and `is_throttling_error` attributes. Throttling errors use a longer base delay. Network-level failures (connection errors and timeouts) are also retried. Non-retryable errors, such as client errors without the `@retryable` trait, are raised immediately without further attempts.
|
|
43
|
+
|
|
44
|
+
The number of attempts defaults to 3 and can be changed at the client level via `retry_max_attempts`, or per call via `config_overrides`.
|
|
45
|
+
|
|
46
|
+
```python
|
|
47
|
+
from aws_sdk_secrets_manager import AsyncSecretsManagerClient
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
async def main():
|
|
51
|
+
async with AsyncSecretsManagerClient() as s3:
|
|
52
|
+
# Default: 3 attempts for every operation
|
|
53
|
+
response = await s3.batch_get_secret_value()
|
|
54
|
+
|
|
55
|
+
# Override per operation
|
|
56
|
+
response = await s3.batch_get_secret_value(config_overrides={"retry_max_attempts": 5})
|
|
57
|
+
|
|
58
|
+
# Disable retries for this call
|
|
59
|
+
response = await s3.batch_get_secret_value(config_overrides={"retry_max_attempts": 1})
|
|
60
|
+
```
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
[project]
|
|
2
|
+
name = "aws-sdk-secrets-manager"
|
|
3
|
+
version = "0.1.0"
|
|
4
|
+
description = "Python SDK for AWS Secrets Manager."
|
|
5
|
+
readme = "README.md"
|
|
6
|
+
requires-python = ">=3.10"
|
|
7
|
+
classifiers = [
|
|
8
|
+
"Development Status :: 4 - Beta",
|
|
9
|
+
"Intended Audience :: Developers",
|
|
10
|
+
"License :: OSI Approved :: MIT License",
|
|
11
|
+
"Operating System :: OS Independent",
|
|
12
|
+
"Programming Language :: Python :: 3",
|
|
13
|
+
"Programming Language :: Python :: 3.10",
|
|
14
|
+
"Programming Language :: Python :: 3.11",
|
|
15
|
+
"Programming Language :: Python :: 3.12",
|
|
16
|
+
"Programming Language :: Python :: 3.13",
|
|
17
|
+
"Programming Language :: Python :: 3.14",
|
|
18
|
+
"Topic :: Software Development :: Code Generators",
|
|
19
|
+
"Typing :: Typed",
|
|
20
|
+
]
|
|
21
|
+
dependencies = [
|
|
22
|
+
"zapros>=0.12.0",
|
|
23
|
+
]
|
|
24
|
+
|
|
25
|
+
[tool.pytest.ini_options]
|
|
26
|
+
pythonpath = ["src"]
|
|
27
|
+
testpaths = ["tests"]
|
|
28
|
+
|
|
29
|
+
[tool.pyright]
|
|
30
|
+
include = ["src", "tests"]
|
|
31
|
+
extraPaths = ["src"]
|
|
32
|
+
pythonVersion = "3.14"
|
|
33
|
+
|
|
34
|
+
[dependency-groups]
|
|
35
|
+
dev = [
|
|
36
|
+
"inline-snapshot>=0.33.0",
|
|
37
|
+
"pyright>=1.1.409",
|
|
38
|
+
"pytest>=9.0.3",
|
|
39
|
+
"ruff>=0.15.14",
|
|
40
|
+
"trio",
|
|
41
|
+
]
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
from __future__ import annotations
|
|
2
|
+
from ._auth._identity import Identity as Identity, Credentials as Credentials
|
|
3
|
+
from ._auth._providers import (
|
|
4
|
+
IdentityNotFound as IdentityNotFound,
|
|
5
|
+
IdentityProvider as IdentityProvider,
|
|
6
|
+
ChainedProvider as ChainedProvider,
|
|
7
|
+
CachedProvider as CachedProvider,
|
|
8
|
+
CredentialsProvider as CredentialsProvider,
|
|
9
|
+
StaticAwsCredentialsProvider as StaticAwsCredentialsProvider,
|
|
10
|
+
EnvCredentialsProvider as EnvCredentialsProvider,
|
|
11
|
+
ProfileCredentialsProvider as ProfileCredentialsProvider,
|
|
12
|
+
)
|
|
13
|
+
from ._auth._signers import Signer as Signer, SigV4Signer as SigV4Signer
|
|
14
|
+
from ._services.secrets_manager import SecretsManagerClient as SecretsManagerClient
|
|
15
|
+
from ._services.async_secrets_manager import (
|
|
16
|
+
AsyncSecretsManagerClient as AsyncSecretsManagerClient,
|
|
17
|
+
)
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
from __future__ import annotations
|
|
2
|
+
|
|
3
|
+
import asyncio
|
|
4
|
+
from typing import TYPE_CHECKING
|
|
5
|
+
|
|
6
|
+
if TYPE_CHECKING:
|
|
7
|
+
import trio
|
|
8
|
+
else:
|
|
9
|
+
try:
|
|
10
|
+
import trio
|
|
11
|
+
except ImportError:
|
|
12
|
+
trio = None
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
def in_trio_run() -> bool:
|
|
16
|
+
if trio is None:
|
|
17
|
+
return False
|
|
18
|
+
return trio.lowlevel.in_trio_run()
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
async def anysleep(delay: float) -> None:
|
|
22
|
+
if in_trio_run():
|
|
23
|
+
await trio.sleep(delay)
|
|
24
|
+
else:
|
|
25
|
+
await asyncio.sleep(delay)
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
from __future__ import annotations
|
|
2
|
+
|
|
3
|
+
from datetime import datetime
|
|
4
|
+
from typing import TypedDict
|
|
5
|
+
from typing_extensions import NotRequired
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
class Identity(TypedDict):
|
|
9
|
+
expiration: NotRequired[datetime | None]
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
class Credentials(Identity):
|
|
13
|
+
access_key: str
|
|
14
|
+
secret_key: str
|
|
15
|
+
session_token: NotRequired[str | None]
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
from __future__ import annotations
|
|
2
|
+
|
|
3
|
+
import configparser
|
|
4
|
+
import os
|
|
5
|
+
from abc import abstractmethod
|
|
6
|
+
from datetime import datetime, timezone
|
|
7
|
+
from pathlib import Path
|
|
8
|
+
from typing import Generic, TypeVar
|
|
9
|
+
|
|
10
|
+
from aws_sdk_secrets_manager._auth._identity import (
|
|
11
|
+
Credentials,
|
|
12
|
+
Identity,
|
|
13
|
+
)
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
class IdentityNotFound(Exception):
|
|
17
|
+
"""Raised when a provider cannot resolve an identity. Chain continues."""
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
IdentityT = TypeVar("IdentityT", bound="Identity")
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
class IdentityProvider(Generic[IdentityT]):
|
|
24
|
+
@abstractmethod
|
|
25
|
+
def resolve_identity(self) -> IdentityT:
|
|
26
|
+
raise NotImplementedError
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
class ChainedProvider(IdentityProvider[IdentityT]):
|
|
30
|
+
"""Try each provider in order; first non-`IdentityNotFound` wins."""
|
|
31
|
+
|
|
32
|
+
def __init__(self, *providers: IdentityProvider[IdentityT]) -> None:
|
|
33
|
+
if not providers:
|
|
34
|
+
raise ValueError("ChainedProvider requires at least one provider")
|
|
35
|
+
self._providers = providers
|
|
36
|
+
|
|
37
|
+
def resolve_identity(self) -> IdentityT:
|
|
38
|
+
errors: list[str] = []
|
|
39
|
+
for p in self._providers:
|
|
40
|
+
try:
|
|
41
|
+
return p.resolve_identity()
|
|
42
|
+
except IdentityNotFound as e:
|
|
43
|
+
errors.append(f"{type(p).__name__}: {e}")
|
|
44
|
+
raise IdentityNotFound("no provider succeeded: " + "; ".join(errors))
|
|
45
|
+
|
|
46
|
+
|
|
47
|
+
class CachedProvider(IdentityProvider[IdentityT]):
|
|
48
|
+
"""Cache an identity until its `expiration` (minus skew) elapses."""
|
|
49
|
+
|
|
50
|
+
_SKEW_SECONDS = 60
|
|
51
|
+
|
|
52
|
+
def __init__(self, inner: IdentityProvider[IdentityT]) -> None:
|
|
53
|
+
self._inner = inner
|
|
54
|
+
self._cached: IdentityT | None = None
|
|
55
|
+
|
|
56
|
+
def resolve_identity(self) -> IdentityT:
|
|
57
|
+
if self._cached is not None and not self._expired(self._cached):
|
|
58
|
+
return self._cached
|
|
59
|
+
self._cached = self._inner.resolve_identity()
|
|
60
|
+
return self._cached
|
|
61
|
+
|
|
62
|
+
@classmethod
|
|
63
|
+
def _expired(cls, ident: Identity) -> bool:
|
|
64
|
+
exp = ident.get("expiration")
|
|
65
|
+
if exp is None:
|
|
66
|
+
return False
|
|
67
|
+
return (exp - datetime.now(timezone.utc)).total_seconds() <= cls._SKEW_SECONDS
|
|
68
|
+
|
|
69
|
+
|
|
70
|
+
class CredentialsProvider(IdentityProvider[Credentials]):
|
|
71
|
+
"""Base class for providers that resolve AWS `Credentials`."""
|
|
72
|
+
|
|
73
|
+
@abstractmethod
|
|
74
|
+
def resolve_identity(self) -> Credentials:
|
|
75
|
+
raise NotImplementedError
|
|
76
|
+
|
|
77
|
+
|
|
78
|
+
class StaticAwsCredentialsProvider(CredentialsProvider):
|
|
79
|
+
def __init__(self, credentials: Credentials) -> None:
|
|
80
|
+
self._credentials = credentials
|
|
81
|
+
|
|
82
|
+
def resolve_identity(self) -> Credentials:
|
|
83
|
+
return self._credentials
|
|
84
|
+
|
|
85
|
+
|
|
86
|
+
class EnvCredentialsProvider(CredentialsProvider):
|
|
87
|
+
"""Read AWS_ACCESS_KEY_ID / AWS_SECRET_ACCESS_KEY / AWS_SESSION_TOKEN."""
|
|
88
|
+
|
|
89
|
+
def resolve_identity(self) -> Credentials:
|
|
90
|
+
ak = os.environ.get("AWS_ACCESS_KEY_ID")
|
|
91
|
+
sk = os.environ.get("AWS_SECRET_ACCESS_KEY")
|
|
92
|
+
if not ak or not sk:
|
|
93
|
+
raise IdentityNotFound("AWS_ACCESS_KEY_ID / AWS_SECRET_ACCESS_KEY unset")
|
|
94
|
+
out: Credentials = {"access_key": ak, "secret_key": sk}
|
|
95
|
+
token = os.environ.get("AWS_SESSION_TOKEN")
|
|
96
|
+
if token:
|
|
97
|
+
out["session_token"] = token
|
|
98
|
+
return out
|
|
99
|
+
|
|
100
|
+
|
|
101
|
+
class ProfileCredentialsProvider(CredentialsProvider):
|
|
102
|
+
"""Read ~/.aws/credentials and ~/.aws/config for the active profile."""
|
|
103
|
+
|
|
104
|
+
def __init__(
|
|
105
|
+
self,
|
|
106
|
+
profile: str | None = None,
|
|
107
|
+
credentials_file: Path | None = None,
|
|
108
|
+
config_file: Path | None = None,
|
|
109
|
+
) -> None:
|
|
110
|
+
self._profile = profile or os.environ.get("AWS_PROFILE", "default")
|
|
111
|
+
self._cred_file = credentials_file or Path(
|
|
112
|
+
os.environ.get("AWS_SHARED_CREDENTIALS_FILE")
|
|
113
|
+
or Path.home() / ".aws" / "credentials"
|
|
114
|
+
)
|
|
115
|
+
self._cfg_file = config_file or Path(
|
|
116
|
+
os.environ.get("AWS_CONFIG_FILE") or Path.home() / ".aws" / "config"
|
|
117
|
+
)
|
|
118
|
+
|
|
119
|
+
def resolve_identity(self) -> Credentials:
|
|
120
|
+
section = self._load_profile()
|
|
121
|
+
ak = section.get("aws_access_key_id")
|
|
122
|
+
sk = section.get("aws_secret_access_key")
|
|
123
|
+
if not ak or not sk:
|
|
124
|
+
raise IdentityNotFound(
|
|
125
|
+
f"profile {self._profile!r}: missing aws_access_key_id/aws_secret_access_key"
|
|
126
|
+
)
|
|
127
|
+
out: Credentials = {"access_key": ak, "secret_key": sk}
|
|
128
|
+
token = section.get("aws_session_token")
|
|
129
|
+
if token:
|
|
130
|
+
out["session_token"] = token
|
|
131
|
+
return out
|
|
132
|
+
|
|
133
|
+
def _load_profile(self) -> dict[str, str]:
|
|
134
|
+
merged: dict[str, str] = {}
|
|
135
|
+
if self._cfg_file.is_file():
|
|
136
|
+
cfg = configparser.ConfigParser()
|
|
137
|
+
cfg.read(self._cfg_file)
|
|
138
|
+
# config file profiles look like `[profile foo]`, except default
|
|
139
|
+
key = (
|
|
140
|
+
"default" if self._profile == "default" else f"profile {self._profile}"
|
|
141
|
+
)
|
|
142
|
+
if cfg.has_section(key):
|
|
143
|
+
merged.update(dict(cfg.items(key)))
|
|
144
|
+
if self._cred_file.is_file():
|
|
145
|
+
cfg = configparser.ConfigParser()
|
|
146
|
+
cfg.read(self._cred_file)
|
|
147
|
+
if cfg.has_section(self._profile):
|
|
148
|
+
merged.update(dict(cfg.items(self._profile)))
|
|
149
|
+
if not merged:
|
|
150
|
+
raise IdentityNotFound(
|
|
151
|
+
f"profile {self._profile!r} not found in {self._cred_file} or {self._cfg_file}"
|
|
152
|
+
)
|
|
153
|
+
return merged
|
|
154
|
+
|
|
155
|
+
|
|
156
|
+
def default_aws_credentials_chain() -> IdentityProvider[Credentials]:
|
|
157
|
+
return CachedProvider(
|
|
158
|
+
ChainedProvider(EnvCredentialsProvider(), ProfileCredentialsProvider())
|
|
159
|
+
)
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
from __future__ import annotations
|
|
2
|
+
|
|
3
|
+
from abc import ABC, abstractmethod
|
|
4
|
+
from typing import Generic, TypeVar
|
|
5
|
+
from typing import Any
|
|
6
|
+
from zapros import Request
|
|
7
|
+
from aws_sdk_secrets_manager._auth._sigv4 import SigV4AuthContext, sign_sigv4
|
|
8
|
+
from aws_sdk_secrets_manager._auth._identity import Credentials, Identity
|
|
9
|
+
from aws_sdk_secrets_manager._auth._providers import IdentityProvider
|
|
10
|
+
|
|
11
|
+
IdentityT = TypeVar("IdentityT", bound="Identity")
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
class Signer(ABC, Generic[IdentityT]):
|
|
15
|
+
"""Per-request request signer. Holds an IdentityProvider plus static config."""
|
|
16
|
+
|
|
17
|
+
def __init__(self, provider: IdentityProvider[IdentityT]) -> None:
|
|
18
|
+
self.provider = provider
|
|
19
|
+
|
|
20
|
+
@abstractmethod
|
|
21
|
+
async def asign(self, req: Request) -> Request: ...
|
|
22
|
+
@abstractmethod
|
|
23
|
+
def sign(self, req: Request) -> Request: ...
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
class SigV4Signer(Signer[Credentials]):
|
|
27
|
+
"""aws.auth#sigv4 — AWS Signature Version 4.
|
|
28
|
+
|
|
29
|
+
The full auth scheme (``name`` variant, ``signingName``, ``signingRegion``,
|
|
30
|
+
encoding/normalization flags) is provided by the caller — either from the
|
|
31
|
+
endpoint rule-set's ``authSchemes`` property or built by the generated
|
|
32
|
+
``get_signer`` from operation defaults.
|
|
33
|
+
"""
|
|
34
|
+
|
|
35
|
+
def __init__(
|
|
36
|
+
self, provider: IdentityProvider[Credentials], *, auth_scheme: dict[str, Any]
|
|
37
|
+
) -> None:
|
|
38
|
+
super().__init__(provider)
|
|
39
|
+
self._auth_scheme = auth_scheme
|
|
40
|
+
|
|
41
|
+
async def asign(self, req: Request) -> Request:
|
|
42
|
+
creds = self.provider.resolve_identity()
|
|
43
|
+
ctx: SigV4AuthContext = {
|
|
44
|
+
"type": "sig_v4",
|
|
45
|
+
"access_key_id": creds["access_key"],
|
|
46
|
+
"secret_access_key": creds["secret_key"],
|
|
47
|
+
"session_token": creds.get("session_token"),
|
|
48
|
+
"signing_region": self._auth_scheme["signingRegion"],
|
|
49
|
+
"signing_name": self._auth_scheme["signingName"],
|
|
50
|
+
}
|
|
51
|
+
if req.body is None:
|
|
52
|
+
body: bytes | None = b""
|
|
53
|
+
elif isinstance(req.body, bytes):
|
|
54
|
+
body = req.body
|
|
55
|
+
else:
|
|
56
|
+
body = None
|
|
57
|
+
# Strip Accept-Encoding so transports/intermediaries can't transcode
|
|
58
|
+
# the response and so the value never enters the canonical request.
|
|
59
|
+
if "accept-encoding" in req.headers:
|
|
60
|
+
del req.headers["Accept-Encoding"]
|
|
61
|
+
return sign_sigv4(req, ctx, body)
|
|
62
|
+
|
|
63
|
+
def sign(self, req: Request) -> Request:
|
|
64
|
+
creds = self.provider.resolve_identity()
|
|
65
|
+
ctx: SigV4AuthContext = {
|
|
66
|
+
"type": "sig_v4",
|
|
67
|
+
"access_key_id": creds["access_key"],
|
|
68
|
+
"secret_access_key": creds["secret_key"],
|
|
69
|
+
"session_token": creds.get("session_token"),
|
|
70
|
+
"signing_region": self._auth_scheme["signingRegion"],
|
|
71
|
+
"signing_name": self._auth_scheme["signingName"],
|
|
72
|
+
}
|
|
73
|
+
if req.body is None:
|
|
74
|
+
body: bytes | None = b""
|
|
75
|
+
elif isinstance(req.body, bytes):
|
|
76
|
+
body = req.body
|
|
77
|
+
else:
|
|
78
|
+
body = None
|
|
79
|
+
# Strip Accept-Encoding so transports/intermediaries can't transcode
|
|
80
|
+
# the response and so the value never enters the canonical request.
|
|
81
|
+
if "accept-encoding" in req.headers:
|
|
82
|
+
del req.headers["Accept-Encoding"]
|
|
83
|
+
return sign_sigv4(req, ctx, body)
|