aws-sdk-acm 0.1.1__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.
Files changed (192) hide show
  1. aws_sdk_acm-0.1.1/LICENSE +21 -0
  2. aws_sdk_acm-0.1.1/PKG-INFO +98 -0
  3. aws_sdk_acm-0.1.1/README.md +75 -0
  4. aws_sdk_acm-0.1.1/pyproject.toml +47 -0
  5. aws_sdk_acm-0.1.1/setup.cfg +4 -0
  6. aws_sdk_acm-0.1.1/src/aws_sdk_acm/__init__.py +32 -0
  7. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_async.py +25 -0
  8. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_auth/_identity.py +16 -0
  9. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_auth/_providers.py +159 -0
  10. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_auth/_signers.py +84 -0
  11. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_auth/_sigv4.py +382 -0
  12. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_auth/_zapros_handler.py +62 -0
  13. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_operations/certificate_manager/add_tags_to_certificate.py +149 -0
  14. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_operations/certificate_manager/delete_certificate.py +143 -0
  15. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_operations/certificate_manager/describe_certificate.py +139 -0
  16. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_operations/certificate_manager/export_certificate.py +151 -0
  17. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_operations/certificate_manager/get_account_configuration.py +128 -0
  18. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_operations/certificate_manager/get_certificate.py +143 -0
  19. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_operations/certificate_manager/import_certificate.py +175 -0
  20. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_operations/certificate_manager/list_certificates.py +139 -0
  21. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_operations/certificate_manager/list_tags_for_certificate.py +141 -0
  22. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_operations/certificate_manager/put_account_configuration.py +133 -0
  23. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_operations/certificate_manager/remove_tags_from_certificate.py +145 -0
  24. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_operations/certificate_manager/renew_certificate.py +125 -0
  25. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_operations/certificate_manager/request_certificate.py +169 -0
  26. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_operations/certificate_manager/resend_validation_email.py +131 -0
  27. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_operations/certificate_manager/revoke_certificate.py +163 -0
  28. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_operations/certificate_manager/search_certificates.py +145 -0
  29. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_operations/certificate_manager/update_certificate_options.py +133 -0
  30. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_pagination.py +21 -0
  31. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_protocol/__init__.py +1 -0
  32. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_protocol/errors.py +59 -0
  33. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_protocol/xml.py +27 -0
  34. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_rule_engine/__init__.py +0 -0
  35. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_rule_engine/_aws_partition.py +160 -0
  36. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_rule_engine/_endpoint_rule_set.py +150 -0
  37. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_rule_engine/_endpoint_runtime.py +389 -0
  38. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_services/_pipeline.py +195 -0
  39. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_services/acm.py +1003 -0
  40. aws_sdk_acm-0.1.1/src/aws_sdk_acm/_services/async_acm.py +1020 -0
  41. aws_sdk_acm-0.1.1/src/aws_sdk_acm/errors/__init__.py +44 -0
  42. aws_sdk_acm-0.1.1/src/aws_sdk_acm/errors/_base.py +94 -0
  43. aws_sdk_acm-0.1.1/src/aws_sdk_acm/errors/access_denied_exception.py +48 -0
  44. aws_sdk_acm-0.1.1/src/aws_sdk_acm/errors/conflict_exception.py +48 -0
  45. aws_sdk_acm-0.1.1/src/aws_sdk_acm/errors/invalid_args_exception.py +48 -0
  46. aws_sdk_acm-0.1.1/src/aws_sdk_acm/errors/invalid_arn_exception.py +48 -0
  47. aws_sdk_acm-0.1.1/src/aws_sdk_acm/errors/invalid_domain_validation_options_exception.py +48 -0
  48. aws_sdk_acm-0.1.1/src/aws_sdk_acm/errors/invalid_parameter_exception.py +48 -0
  49. aws_sdk_acm-0.1.1/src/aws_sdk_acm/errors/invalid_state_exception.py +48 -0
  50. aws_sdk_acm-0.1.1/src/aws_sdk_acm/errors/invalid_tag_exception.py +48 -0
  51. aws_sdk_acm-0.1.1/src/aws_sdk_acm/errors/limit_exceeded_exception.py +48 -0
  52. aws_sdk_acm-0.1.1/src/aws_sdk_acm/errors/request_in_progress_exception.py +48 -0
  53. aws_sdk_acm-0.1.1/src/aws_sdk_acm/errors/resource_in_use_exception.py +48 -0
  54. aws_sdk_acm-0.1.1/src/aws_sdk_acm/errors/resource_not_found_exception.py +48 -0
  55. aws_sdk_acm-0.1.1/src/aws_sdk_acm/errors/tag_policy_exception.py +48 -0
  56. aws_sdk_acm-0.1.1/src/aws_sdk_acm/errors/throttling_exception.py +71 -0
  57. aws_sdk_acm-0.1.1/src/aws_sdk_acm/errors/too_many_tags_exception.py +48 -0
  58. aws_sdk_acm-0.1.1/src/aws_sdk_acm/errors/validation_exception.py +50 -0
  59. aws_sdk_acm-0.1.1/src/aws_sdk_acm/py.typed +0 -0
  60. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/_prelude/blob.py +12 -0
  61. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/_prelude/timestamp.py +12 -0
  62. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/acm_certificate_metadata.py +220 -0
  63. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/acm_certificate_metadata_filter.py +175 -0
  64. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/add_tags_to_certificate_request.py +43 -0
  65. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/arn.py +5 -0
  66. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/availability_error_message.py +5 -0
  67. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_body.py +5 -0
  68. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_body_blob.py +15 -0
  69. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_chain.py +5 -0
  70. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_chain_blob.py +15 -0
  71. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_detail.py +401 -0
  72. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_export.py +29 -0
  73. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_filter.py +78 -0
  74. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_filter_statement.py +111 -0
  75. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_filter_statement_list.py +35 -0
  76. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_managed_by.py +21 -0
  77. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_metadata.py +44 -0
  78. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_options.py +57 -0
  79. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_search_result.py +68 -0
  80. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_search_result_list.py +33 -0
  81. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_status.py +39 -0
  82. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_statuses.py +29 -0
  83. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_summary.py +308 -0
  84. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_summary_list.py +29 -0
  85. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_transparency_logging_preference.py +31 -0
  86. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/certificate_type.py +31 -0
  87. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/common_name_filter.py +49 -0
  88. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/comparison_operator.py +30 -0
  89. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/coral_availability_throttled_resource.py +5 -0
  90. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/coral_availability_throttling_reason.py +5 -0
  91. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/custom_attribute.py +34 -0
  92. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/custom_attribute_list.py +29 -0
  93. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/delete_certificate_request.py +29 -0
  94. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/describe_certificate_request.py +31 -0
  95. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/describe_certificate_response.py +40 -0
  96. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/distinguished_name.py +148 -0
  97. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/dns_name_filter.py +49 -0
  98. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/domain_component_list.py +17 -0
  99. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/domain_list.py +17 -0
  100. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/domain_name_string.py +5 -0
  101. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/domain_status.py +31 -0
  102. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/domain_validation.py +134 -0
  103. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/domain_validation_list.py +29 -0
  104. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/domain_validation_option.py +36 -0
  105. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/domain_validation_option_list.py +33 -0
  106. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/expiry_events_configuration.py +30 -0
  107. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/export_certificate_request.py +45 -0
  108. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/export_certificate_response.py +44 -0
  109. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/extended_key_usage.py +45 -0
  110. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/extended_key_usage_filter_list.py +33 -0
  111. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/extended_key_usage_list.py +29 -0
  112. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/extended_key_usage_name.py +49 -0
  113. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/extended_key_usage_names.py +33 -0
  114. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/failure_reason.py +59 -0
  115. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/filter_string.py +5 -0
  116. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/filters.py +118 -0
  117. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/general_name.py +112 -0
  118. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/general_name_list.py +27 -0
  119. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/get_account_configuration_response.py +42 -0
  120. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/get_certificate_request.py +29 -0
  121. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/get_certificate_response.py +37 -0
  122. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/http_redirect.py +34 -0
  123. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/idempotency_token.py +5 -0
  124. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/import_certificate_request.py +98 -0
  125. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/import_certificate_response.py +28 -0
  126. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/in_use_list.py +17 -0
  127. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/key_algorithm.py +39 -0
  128. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/key_algorithm_list.py +27 -0
  129. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/key_usage.py +36 -0
  130. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/key_usage_filter_list.py +27 -0
  131. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/key_usage_list.py +27 -0
  132. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/key_usage_name.py +47 -0
  133. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/key_usage_names.py +27 -0
  134. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/list_certificates_request.py +101 -0
  135. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/list_certificates_response.py +49 -0
  136. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/list_tags_for_certificate_request.py +31 -0
  137. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/list_tags_for_certificate_response.py +32 -0
  138. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/max_items.py +5 -0
  139. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/next_token.py +5 -0
  140. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/nullable_boolean.py +5 -0
  141. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/other_name.py +34 -0
  142. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/passphrase_blob.py +15 -0
  143. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/pca_arn.py +5 -0
  144. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/positive_integer.py +5 -0
  145. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/private_key.py +5 -0
  146. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/private_key_blob.py +15 -0
  147. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/put_account_configuration_request.py +54 -0
  148. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/record_type.py +21 -0
  149. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/remove_tags_from_certificate_request.py +43 -0
  150. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/renew_certificate_request.py +29 -0
  151. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/renewal_eligibility.py +29 -0
  152. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/renewal_status.py +33 -0
  153. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/renewal_summary.py +98 -0
  154. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/request_certificate_request.py +170 -0
  155. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/request_certificate_response.py +28 -0
  156. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/resend_validation_email_request.py +48 -0
  157. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/resource_record.py +50 -0
  158. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/revocation_reason.py +47 -0
  159. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/revoke_certificate_request.py +51 -0
  160. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/revoke_certificate_response.py +28 -0
  161. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/search_certificates_request.py +99 -0
  162. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/search_certificates_response.py +49 -0
  163. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/search_certificates_sort_by.py +62 -0
  164. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/search_certificates_sort_order.py +32 -0
  165. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/search_max_results.py +7 -0
  166. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/serial_number.py +5 -0
  167. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/service_error_message.py +5 -0
  168. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/sort_by.py +21 -0
  169. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/sort_order.py +29 -0
  170. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/string.py +5 -0
  171. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/subject_alternative_name_filter.py +44 -0
  172. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/subject_filter.py +42 -0
  173. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/t_stamp.py +15 -0
  174. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/tag.py +38 -0
  175. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/tag_key.py +5 -0
  176. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/tag_list.py +27 -0
  177. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/tag_value.py +5 -0
  178. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/throttling_reason.py +39 -0
  179. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/throttling_reason_list.py +29 -0
  180. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/timestamp_range.py +42 -0
  181. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/update_certificate_options_request.py +47 -0
  182. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/validation_email_list.py +17 -0
  183. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/validation_exception_message.py +5 -0
  184. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/validation_method.py +31 -0
  185. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/x509_attribute_filter.py +187 -0
  186. aws_sdk_acm-0.1.1/src/aws_sdk_acm/types/x509_attributes.py +158 -0
  187. aws_sdk_acm-0.1.1/src/aws_sdk_acm.egg-info/PKG-INFO +98 -0
  188. aws_sdk_acm-0.1.1/src/aws_sdk_acm.egg-info/SOURCES.txt +190 -0
  189. aws_sdk_acm-0.1.1/src/aws_sdk_acm.egg-info/dependency_links.txt +1 -0
  190. aws_sdk_acm-0.1.1/src/aws_sdk_acm.egg-info/requires.txt +2 -0
  191. aws_sdk_acm-0.1.1/src/aws_sdk_acm.egg-info/top_level.txt +1 -0
  192. aws_sdk_acm-0.1.1/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,98 @@
1
+ Metadata-Version: 2.4
2
+ Name: aws-sdk-acm
3
+ Version: 0.1.1
4
+ Summary: Python SDK for ACM.
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: jmespath>=1.0
21
+ Requires-Dist: zapros>=0.13.0
22
+ Dynamic: license-file
23
+
24
+ # Getting Started
25
+
26
+ ## Installation
27
+
28
+ ```
29
+ pip install aws-sdk-acm
30
+ ```
31
+
32
+ ## Usage
33
+
34
+ ```python
35
+ from aws_sdk_acm import AsyncACMClient
36
+
37
+
38
+ async def main():
39
+ async with AsyncACMClient() as s3:
40
+ # Example: call the add_tags_to_certificate operation
41
+ response = await s3.add_tags_to_certificate()
42
+ print(response)
43
+ ```
44
+
45
+ ## Pagination
46
+
47
+ Some operations in this SDK support pagination. If the operation supports pagination it will have an `iter_` prefixed method that returns an async iterator.
48
+
49
+ ```python
50
+ from aws_sdk_acm import AsyncACMClient
51
+
52
+
53
+ async def main():
54
+ async with AsyncACMClient() as s3:
55
+ # Example: paginate over list_certificates
56
+ async for item in s3.iter_list_certificates():
57
+ print(item)
58
+ ```
59
+
60
+ ## Error Handling
61
+
62
+ The SDK raises exceptions for errors returned by the API. Catch them to handle failures gracefully.
63
+
64
+ ```python
65
+ from aws_sdk_acm import AsyncACMClient
66
+ from aws_sdk_acm.error import InvalidArnException
67
+
68
+
69
+ async def main():
70
+ async with AsyncACMClient() as s3:
71
+ try:
72
+ await s3.add_tags_to_certificate()
73
+ except InvalidArnException as e:
74
+ print(f"Error: {e}")
75
+ print(e.data) # additional error data
76
+ ```
77
+
78
+ ## Retrying
79
+
80
+ 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.
81
+
82
+ 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`.
83
+
84
+ ```python
85
+ from aws_sdk_acm import AsyncACMClient
86
+
87
+
88
+ async def main():
89
+ async with AsyncACMClient() as s3:
90
+ # Default: 3 attempts for every operation
91
+ response = await s3.add_tags_to_certificate()
92
+
93
+ # Override per operation
94
+ response = await s3.add_tags_to_certificate(config_overrides={"retry_max_attempts": 5})
95
+
96
+ # Disable retries for this call
97
+ response = await s3.add_tags_to_certificate(config_overrides={"retry_max_attempts": 1})
98
+ ```
@@ -0,0 +1,75 @@
1
+ # Getting Started
2
+
3
+ ## Installation
4
+
5
+ ```
6
+ pip install aws-sdk-acm
7
+ ```
8
+
9
+ ## Usage
10
+
11
+ ```python
12
+ from aws_sdk_acm import AsyncACMClient
13
+
14
+
15
+ async def main():
16
+ async with AsyncACMClient() as s3:
17
+ # Example: call the add_tags_to_certificate operation
18
+ response = await s3.add_tags_to_certificate()
19
+ print(response)
20
+ ```
21
+
22
+ ## Pagination
23
+
24
+ Some operations in this SDK support pagination. If the operation supports pagination it will have an `iter_` prefixed method that returns an async iterator.
25
+
26
+ ```python
27
+ from aws_sdk_acm import AsyncACMClient
28
+
29
+
30
+ async def main():
31
+ async with AsyncACMClient() as s3:
32
+ # Example: paginate over list_certificates
33
+ async for item in s3.iter_list_certificates():
34
+ print(item)
35
+ ```
36
+
37
+ ## Error Handling
38
+
39
+ The SDK raises exceptions for errors returned by the API. Catch them to handle failures gracefully.
40
+
41
+ ```python
42
+ from aws_sdk_acm import AsyncACMClient
43
+ from aws_sdk_acm.error import InvalidArnException
44
+
45
+
46
+ async def main():
47
+ async with AsyncACMClient() as s3:
48
+ try:
49
+ await s3.add_tags_to_certificate()
50
+ except InvalidArnException as e:
51
+ print(f"Error: {e}")
52
+ print(e.data) # additional error data
53
+ ```
54
+
55
+ ## Retrying
56
+
57
+ 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.
58
+
59
+ 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`.
60
+
61
+ ```python
62
+ from aws_sdk_acm import AsyncACMClient
63
+
64
+
65
+ async def main():
66
+ async with AsyncACMClient() as s3:
67
+ # Default: 3 attempts for every operation
68
+ response = await s3.add_tags_to_certificate()
69
+
70
+ # Override per operation
71
+ response = await s3.add_tags_to_certificate(config_overrides={"retry_max_attempts": 5})
72
+
73
+ # Disable retries for this call
74
+ response = await s3.add_tags_to_certificate(config_overrides={"retry_max_attempts": 1})
75
+ ```
@@ -0,0 +1,47 @@
1
+ [project]
2
+ name = "aws-sdk-acm"
3
+ version = "0.1.1"
4
+ description = "Python SDK for ACM."
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
+ "jmespath>=1.0",
23
+ "zapros>=0.13.0",
24
+ ]
25
+
26
+ [tool.pytest.ini_options]
27
+ pythonpath = ["src"]
28
+ testpaths = ["tests"]
29
+
30
+ [tool.pyright]
31
+ include = ["src", "tests"]
32
+ extraPaths = ["src"]
33
+ pythonVersion = "3.14"
34
+ reportInvalidStringEscapeSequence = false
35
+
36
+ [tool.ruff.lint]
37
+ select = ["E", "F", "I"]
38
+ ignore = ["E501"]
39
+
40
+ [dependency-groups]
41
+ dev = [
42
+ "inline-snapshot>=0.33.0",
43
+ "pyright>=1.1.409",
44
+ "pytest>=9.0.3",
45
+ "ruff>=0.15.14",
46
+ "trio",
47
+ ]
@@ -0,0 +1,4 @@
1
+ [egg_info]
2
+ tag_build =
3
+ tag_date = 0
4
+
@@ -0,0 +1,32 @@
1
+ from __future__ import annotations
2
+
3
+ from ._auth._identity import Credentials as Credentials
4
+ from ._auth._identity import Identity as Identity
5
+ from ._auth._providers import (
6
+ CachedProvider as CachedProvider,
7
+ )
8
+ from ._auth._providers import (
9
+ ChainedProvider as ChainedProvider,
10
+ )
11
+ from ._auth._providers import (
12
+ CredentialsProvider as CredentialsProvider,
13
+ )
14
+ from ._auth._providers import (
15
+ EnvCredentialsProvider as EnvCredentialsProvider,
16
+ )
17
+ from ._auth._providers import (
18
+ IdentityNotFound as IdentityNotFound,
19
+ )
20
+ from ._auth._providers import (
21
+ IdentityProvider as IdentityProvider,
22
+ )
23
+ from ._auth._providers import (
24
+ ProfileCredentialsProvider as ProfileCredentialsProvider,
25
+ )
26
+ from ._auth._providers import (
27
+ StaticAwsCredentialsProvider as StaticAwsCredentialsProvider,
28
+ )
29
+ from ._auth._signers import Signer as Signer
30
+ from ._auth._signers import SigV4Signer as SigV4Signer
31
+ from ._services.acm import ACMClient as ACMClient
32
+ from ._services.async_acm import AsyncACMClient as AsyncACMClient
@@ -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,16 @@
1
+ from __future__ import annotations
2
+
3
+ from datetime import datetime
4
+ from typing import TypedDict
5
+
6
+ from typing_extensions import NotRequired
7
+
8
+
9
+ class Identity(TypedDict):
10
+ expiration: NotRequired[datetime | None]
11
+
12
+
13
+ class Credentials(Identity):
14
+ access_key: str
15
+ secret_key: str
16
+ 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_acm._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,84 @@
1
+ from __future__ import annotations
2
+
3
+ from abc import ABC, abstractmethod
4
+ from typing import Any, Generic, TypeVar
5
+
6
+ from zapros import Request
7
+
8
+ from aws_sdk_acm._auth._identity import Credentials, Identity
9
+ from aws_sdk_acm._auth._providers import IdentityProvider
10
+ from aws_sdk_acm._auth._sigv4 import SigV4AuthContext, sign_sigv4
11
+
12
+ IdentityT = TypeVar("IdentityT", bound="Identity")
13
+
14
+
15
+ class Signer(ABC, Generic[IdentityT]):
16
+ """Per-request request signer. Holds an IdentityProvider plus static config."""
17
+
18
+ def __init__(self, provider: IdentityProvider[IdentityT]) -> None:
19
+ self.provider = provider
20
+
21
+ @abstractmethod
22
+ async def asign(self, req: Request) -> Request: ...
23
+ @abstractmethod
24
+ def sign(self, req: Request) -> Request: ...
25
+
26
+
27
+ class SigV4Signer(Signer[Credentials]):
28
+ """aws.auth#sigv4 — AWS Signature Version 4.
29
+
30
+ The full auth scheme (``name`` variant, ``signingName``, ``signingRegion``,
31
+ encoding/normalization flags) is provided by the caller — either from the
32
+ endpoint rule-set's ``authSchemes`` property or built by the generated
33
+ ``get_signer`` from operation defaults.
34
+ """
35
+
36
+ def __init__(
37
+ self, provider: IdentityProvider[Credentials], *, auth_scheme: dict[str, Any]
38
+ ) -> None:
39
+ super().__init__(provider)
40
+ self._auth_scheme = auth_scheme
41
+
42
+ async def asign(self, req: Request) -> Request:
43
+ creds = self.provider.resolve_identity()
44
+ ctx: SigV4AuthContext = {
45
+ "type": "sig_v4",
46
+ "access_key_id": creds["access_key"],
47
+ "secret_access_key": creds["secret_key"],
48
+ "session_token": creds.get("session_token"),
49
+ "signing_region": self._auth_scheme["signingRegion"],
50
+ "signing_name": self._auth_scheme["signingName"],
51
+ }
52
+ if req.body is None:
53
+ body: bytes | None = b""
54
+ elif isinstance(req.body, bytes):
55
+ body = req.body
56
+ else:
57
+ body = None
58
+ # Strip Accept-Encoding so transports/intermediaries can't transcode
59
+ # the response and so the value never enters the canonical request.
60
+ if "accept-encoding" in req.headers:
61
+ del req.headers["Accept-Encoding"]
62
+ return sign_sigv4(req, ctx, body)
63
+
64
+ def sign(self, req: Request) -> Request:
65
+ creds = self.provider.resolve_identity()
66
+ ctx: SigV4AuthContext = {
67
+ "type": "sig_v4",
68
+ "access_key_id": creds["access_key"],
69
+ "secret_access_key": creds["secret_key"],
70
+ "session_token": creds.get("session_token"),
71
+ "signing_region": self._auth_scheme["signingRegion"],
72
+ "signing_name": self._auth_scheme["signingName"],
73
+ }
74
+ if req.body is None:
75
+ body: bytes | None = b""
76
+ elif isinstance(req.body, bytes):
77
+ body = req.body
78
+ else:
79
+ body = None
80
+ # Strip Accept-Encoding so transports/intermediaries can't transcode
81
+ # the response and so the value never enters the canonical request.
82
+ if "accept-encoding" in req.headers:
83
+ del req.headers["Accept-Encoding"]
84
+ return sign_sigv4(req, ctx, body)