byteplus-python-sdk-v2 3.0.43__py2.py3-none-any.whl → 3.0.45__py2.py3-none-any.whl
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.
- {byteplus_python_sdk_v2-3.0.43.dist-info → byteplus_python_sdk_v2-3.0.45.dist-info}/METADATA +27 -1
- {byteplus_python_sdk_v2-3.0.43.dist-info → byteplus_python_sdk_v2-3.0.45.dist-info}/RECORD +562 -94
- {byteplus_python_sdk_v2-3.0.43.dist-info → byteplus_python_sdk_v2-3.0.45.dist-info}/top_level.txt +2 -0
- byteplussdkcore/api_client.py +219 -1
- byteplussdkcore/auth/credential.py +4 -0
- byteplussdkcore/auth/providers/__init__.py +5 -1
- byteplussdkcore/auth/providers/cli_config_provider.py +628 -0
- byteplussdkcore/auth/providers/default_provider.py +103 -0
- byteplussdkcore/auth/providers/ecs_role_provider.py +186 -0
- byteplussdkcore/auth/providers/env_provider.py +38 -0
- byteplussdkcore/auth/providers/provider.py +36 -1
- byteplussdkcore/auth/providers/static_provider.py +3 -3
- byteplussdkcore/auth/providers/sts_oidc_provider.py +132 -42
- byteplussdkcore/auth/providers/sts_provider.py +10 -1
- byteplussdkcore/auth/providers/sts_saml_provider.py +77 -32
- byteplussdkcore/configuration.py +1 -1
- byteplussdkcore/endpoint/providers/default_provider.py +28 -0
- byteplussdkcore/endpoint/providers/standard_provider.py +2 -3
- byteplussdkcore/feature/__init__.py +6 -0
- byteplussdkcore/feature/rds/__init__.py +4 -0
- byteplussdkcore/feature/rds/connect_utils.py +88 -0
- byteplussdkcore/interceptor/interceptors/request.py +4 -0
- byteplussdkcore/interceptor/interceptors/resolve_endpoint_interceptor.py +8 -1
- byteplussdkcore/interceptor/interceptors/sign_request_interceptor.py +42 -14
- byteplussdkcore/signv4.py +86 -0
- byteplussdkexamples/byteplussdkarkruntime/async_completions.py +0 -2
- byteplussdkexamples/byteplussdkarkruntime/completions.py +1 -3
- byteplussdkexamples/byteplussdkarkruntime/context.py +1 -3
- byteplussdkkickart/__init__.py +251 -0
- byteplussdkkickart/api/__init__.py +6 -0
- byteplussdkkickart/api/kickart_api.py +11189 -0
- byteplussdkkickart/models/__init__.py +247 -0
- byteplussdkkickart/models/batch_delete_asset_request.py +123 -0
- byteplussdkkickart/models/batch_delete_asset_response.py +95 -0
- byteplussdkkickart/models/batch_delete_media_request.py +123 -0
- byteplussdkkickart/models/batch_delete_media_response.py +123 -0
- byteplussdkkickart/models/check_delete_media_request.py +123 -0
- byteplussdkkickart/models/check_delete_media_response.py +123 -0
- byteplussdkkickart/models/check_product_url_request.py +149 -0
- byteplussdkkickart/models/check_product_url_response.py +123 -0
- byteplussdkkickart/models/clear_ad_variations_output_videos_request.py +124 -0
- byteplussdkkickart/models/clear_ad_variations_output_videos_response.py +95 -0
- byteplussdkkickart/models/clear_ad_variations_project_request.py +150 -0
- byteplussdkkickart/models/clear_ad_variations_project_response.py +95 -0
- byteplussdkkickart/models/copy_genius_project_request.py +149 -0
- byteplussdkkickart/models/copy_genius_project_response.py +149 -0
- byteplussdkkickart/models/create_ad_variations_project_request.py +123 -0
- byteplussdkkickart/models/create_ad_variations_project_response.py +123 -0
- byteplussdkkickart/models/create_ai_template_task_request.py +227 -0
- byteplussdkkickart/models/create_ai_template_task_response.py +123 -0
- byteplussdkkickart/models/create_api_key_request.py +123 -0
- byteplussdkkickart/models/create_api_key_response.py +123 -0
- byteplussdkkickart/models/create_auth_url_request.py +149 -0
- byteplussdkkickart/models/create_auth_url_response.py +175 -0
- byteplussdkkickart/models/create_avatar_request.py +149 -0
- byteplussdkkickart/models/create_avatar_response.py +123 -0
- byteplussdkkickart/models/create_draft_request.py +149 -0
- byteplussdkkickart/models/create_draft_response.py +149 -0
- byteplussdkkickart/models/create_film_request.py +721 -0
- byteplussdkkickart/models/create_film_response.py +95 -0
- byteplussdkkickart/models/create_folder_request.py +279 -0
- byteplussdkkickart/models/create_folder_response.py +123 -0
- byteplussdkkickart/models/create_item_request.py +227 -0
- byteplussdkkickart/models/create_item_response.py +149 -0
- byteplussdkkickart/models/create_material_request.py +851 -0
- byteplussdkkickart/models/create_material_response.py +95 -0
- byteplussdkkickart/models/create_media_request.py +357 -0
- byteplussdkkickart/models/create_media_response.py +149 -0
- byteplussdkkickart/models/create_project_from_template_request.py +123 -0
- byteplussdkkickart/models/create_project_from_template_response.py +123 -0
- byteplussdkkickart/models/create_project_request.py +487 -0
- byteplussdkkickart/models/create_project_response.py +201 -0
- byteplussdkkickart/models/create_template_project_request.py +149 -0
- byteplussdkkickart/models/create_template_project_response.py +175 -0
- byteplussdkkickart/models/delete_all_task_item_request.py +124 -0
- byteplussdkkickart/models/delete_all_task_item_response.py +95 -0
- byteplussdkkickart/models/delete_api_key_request.py +123 -0
- byteplussdkkickart/models/delete_api_key_response.py +95 -0
- byteplussdkkickart/models/delete_task_item_request.py +123 -0
- byteplussdkkickart/models/delete_task_item_response.py +95 -0
- byteplussdkkickart/models/download_asset_request.py +149 -0
- byteplussdkkickart/models/download_asset_response.py +149 -0
- byteplussdkkickart/models/export_editor_video_request.py +279 -0
- byteplussdkkickart/models/export_editor_video_response.py +123 -0
- byteplussdkkickart/models/export_video_request.py +149 -0
- byteplussdkkickart/models/export_video_response.py +123 -0
- byteplussdkkickart/models/gen_ad_variations_analysis_request.py +124 -0
- byteplussdkkickart/models/gen_ad_variations_analysis_response.py +123 -0
- byteplussdkkickart/models/gen_ad_variations_video_request.py +124 -0
- byteplussdkkickart/models/gen_ad_variations_video_response.py +123 -0
- byteplussdkkickart/models/gen_bgm_by_product_request.py +175 -0
- byteplussdkkickart/models/gen_bgm_by_product_response.py +123 -0
- byteplussdkkickart/models/gen_bgm_by_video_request.py +175 -0
- byteplussdkkickart/models/gen_bgm_by_video_response.py +123 -0
- byteplussdkkickart/models/gen_main_video_request.py +175 -0
- byteplussdkkickart/models/gen_main_video_response.py +149 -0
- byteplussdkkickart/models/gen_pic_by_prompt_request.py +175 -0
- byteplussdkkickart/models/gen_pic_by_prompt_response.py +123 -0
- byteplussdkkickart/models/gen_pics_video_by_story_request.py +175 -0
- byteplussdkkickart/models/gen_pics_video_by_story_response.py +123 -0
- byteplussdkkickart/models/gen_product_intro_creative_request.py +149 -0
- byteplussdkkickart/models/gen_product_intro_creative_response.py +123 -0
- byteplussdkkickart/models/gen_product_intro_script_request.py +149 -0
- byteplussdkkickart/models/gen_product_intro_script_response.py +123 -0
- byteplussdkkickart/models/gen_product_intro_video_request.py +149 -0
- byteplussdkkickart/models/gen_product_intro_video_response.py +149 -0
- byteplussdkkickart/models/gen_product_storyboard_outline_request.py +149 -0
- byteplussdkkickart/models/gen_product_storyboard_outline_response.py +149 -0
- byteplussdkkickart/models/gen_product_storyboard_video_request.py +175 -0
- byteplussdkkickart/models/gen_product_storyboard_video_response.py +175 -0
- byteplussdkkickart/models/gen_story_by_prompt_request.py +123 -0
- byteplussdkkickart/models/gen_story_by_prompt_response.py +123 -0
- byteplussdkkickart/models/gen_template_script_request.py +175 -0
- byteplussdkkickart/models/gen_template_script_response.py +175 -0
- byteplussdkkickart/models/gen_template_video_request.py +201 -0
- byteplussdkkickart/models/gen_template_video_response.py +149 -0
- byteplussdkkickart/models/gen_video_by_prompt_request.py +175 -0
- byteplussdkkickart/models/gen_video_by_prompt_response.py +123 -0
- byteplussdkkickart/models/get_ai_template_task_status_request.py +123 -0
- byteplussdkkickart/models/get_ai_template_task_status_response.py +123 -0
- byteplussdkkickart/models/get_ai_template_template_info_request.py +123 -0
- byteplussdkkickart/models/get_ai_template_template_info_response.py +123 -0
- byteplussdkkickart/models/get_avatar_request.py +123 -0
- byteplussdkkickart/models/get_avatar_response.py +123 -0
- byteplussdkkickart/models/get_block_detail_request.py +149 -0
- byteplussdkkickart/models/get_block_detail_response.py +123 -0
- byteplussdkkickart/models/get_block_request.py +124 -0
- byteplussdkkickart/models/get_block_response.py +123 -0
- byteplussdkkickart/models/get_category_detail_request.py +201 -0
- byteplussdkkickart/models/get_category_detail_response.py +123 -0
- byteplussdkkickart/models/get_combo_balance_request.py +124 -0
- byteplussdkkickart/models/get_combo_balance_response.py +149 -0
- byteplussdkkickart/models/get_composition_request.py +123 -0
- byteplussdkkickart/models/get_composition_response.py +253 -0
- byteplussdkkickart/models/get_create_cost_request.py +123 -0
- byteplussdkkickart/models/get_create_cost_response.py +123 -0
- byteplussdkkickart/models/get_creator_info_request.py +123 -0
- byteplussdkkickart/models/get_creator_info_response.py +123 -0
- byteplussdkkickart/models/get_draft_request.py +123 -0
- byteplussdkkickart/models/get_draft_response.py +123 -0
- byteplussdkkickart/models/get_film_detail_request.py +175 -0
- byteplussdkkickart/models/get_film_detail_response.py +123 -0
- byteplussdkkickart/models/get_genius_project_request.py +124 -0
- byteplussdkkickart/models/get_genius_project_response.py +123 -0
- byteplussdkkickart/models/get_genius_template_request.py +123 -0
- byteplussdkkickart/models/get_genius_template_response.py +123 -0
- byteplussdkkickart/models/get_home_bootstrap2_request.py +149 -0
- byteplussdkkickart/models/get_home_bootstrap2_response.py +253 -0
- byteplussdkkickart/models/get_home_bootstrap_request.py +149 -0
- byteplussdkkickart/models/get_home_bootstrap_response.py +253 -0
- byteplussdkkickart/models/get_list_request.py +177 -0
- byteplussdkkickart/models/get_list_response.py +175 -0
- byteplussdkkickart/models/get_material_detail_request.py +227 -0
- byteplussdkkickart/models/get_material_detail_response.py +123 -0
- byteplussdkkickart/models/get_material_transcoding_list_request.py +331 -0
- byteplussdkkickart/models/get_material_transcoding_list_response.py +149 -0
- byteplussdkkickart/models/get_media_request.py +123 -0
- byteplussdkkickart/models/get_media_response.py +123 -0
- byteplussdkkickart/models/get_meta_list_request.py +201 -0
- byteplussdkkickart/models/get_meta_list_response.py +175 -0
- byteplussdkkickart/models/get_price_request.py +123 -0
- byteplussdkkickart/models/get_price_response.py +123 -0
- byteplussdkkickart/models/get_product_info_request.py +123 -0
- byteplussdkkickart/models/get_product_info_response.py +149 -0
- byteplussdkkickart/models/get_public_template_list_request.py +436 -0
- byteplussdkkickart/models/get_public_template_list_response.py +149 -0
- byteplussdkkickart/models/get_publish_draft_by_task_request.py +124 -0
- byteplussdkkickart/models/get_publish_draft_by_task_response.py +149 -0
- byteplussdkkickart/models/get_publish_draft_request.py +175 -0
- byteplussdkkickart/models/get_publish_draft_response.py +149 -0
- byteplussdkkickart/models/get_raw_api_key_request.py +123 -0
- byteplussdkkickart/models/get_raw_api_key_response.py +123 -0
- byteplussdkkickart/models/get_special_zone_config_request.py +124 -0
- byteplussdkkickart/models/get_special_zone_config_response.py +227 -0
- byteplussdkkickart/models/get_task_item_request.py +149 -0
- byteplussdkkickart/models/get_task_item_response.py +565 -0
- byteplussdkkickart/models/get_tasks_detail_request.py +123 -0
- byteplussdkkickart/models/get_tasks_detail_response.py +123 -0
- byteplussdkkickart/models/get_tenant_config_request.py +124 -0
- byteplussdkkickart/models/get_tenant_config_response.py +929 -0
- byteplussdkkickart/models/get_voice_recommendation_request.py +227 -0
- byteplussdkkickart/models/get_voice_recommendation_response.py +123 -0
- byteplussdkkickart/models/get_watermark_switch_status_request.py +124 -0
- byteplussdkkickart/models/get_watermark_switch_status_response.py +253 -0
- byteplussdkkickart/models/handle_o_auth_callback_request.py +177 -0
- byteplussdkkickart/models/handle_o_auth_callback_response.py +123 -0
- byteplussdkkickart/models/health_check_request.py +123 -0
- byteplussdkkickart/models/health_check_response.py +123 -0
- byteplussdkkickart/models/invoke_project_event_request.py +201 -0
- byteplussdkkickart/models/invoke_project_event_response.py +123 -0
- byteplussdkkickart/models/list_api_key_request.py +149 -0
- byteplussdkkickart/models/list_api_key_response.py +201 -0
- byteplussdkkickart/models/list_avatar_request.py +201 -0
- byteplussdkkickart/models/list_avatar_response.py +201 -0
- byteplussdkkickart/models/list_avatar_voice_request.py +279 -0
- byteplussdkkickart/models/list_avatar_voice_response.py +201 -0
- byteplussdkkickart/models/list_block_request.py +201 -0
- byteplussdkkickart/models/list_block_response.py +149 -0
- byteplussdkkickart/models/list_combo_request.py +149 -0
- byteplussdkkickart/models/list_combo_response.py +149 -0
- byteplussdkkickart/models/list_create_cost_request.py +149 -0
- byteplussdkkickart/models/list_create_cost_response.py +123 -0
- byteplussdkkickart/models/list_creative_point_logs_request.py +253 -0
- byteplussdkkickart/models/list_creative_point_logs_response.py +149 -0
- byteplussdkkickart/models/list_genius_project_request.py +149 -0
- byteplussdkkickart/models/list_genius_project_response.py +149 -0
- byteplussdkkickart/models/list_genius_template_request.py +175 -0
- byteplussdkkickart/models/list_genius_template_response.py +149 -0
- byteplussdkkickart/models/list_prompt_request.py +95 -0
- byteplussdkkickart/models/list_prompt_response.py +123 -0
- byteplussdkkickart/models/list_publish_accounts_request.py +149 -0
- byteplussdkkickart/models/list_publish_accounts_response.py +123 -0
- byteplussdkkickart/models/list_resources_request.py +95 -0
- byteplussdkkickart/models/list_resources_response.py +123 -0
- byteplussdkkickart/models/list_select_item_request.py +123 -0
- byteplussdkkickart/models/list_select_item_response.py +149 -0
- byteplussdkkickart/models/list_tasks_request.py +177 -0
- byteplussdkkickart/models/list_tasks_response.py +175 -0
- byteplussdkkickart/models/query_creative_point_logs_request.py +253 -0
- byteplussdkkickart/models/query_creative_point_logs_response.py +149 -0
- byteplussdkkickart/models/query_select_item_request.py +123 -0
- byteplussdkkickart/models/query_select_item_response.py +149 -0
- byteplussdkkickart/models/reorder_check_request.py +123 -0
- byteplussdkkickart/models/reorder_check_response.py +123 -0
- byteplussdkkickart/models/retry_risk_task_request.py +123 -0
- byteplussdkkickart/models/retry_risk_task_response.py +123 -0
- byteplussdkkickart/models/retry_task_request.py +149 -0
- byteplussdkkickart/models/retry_task_response.py +123 -0
- byteplussdkkickart/models/save_publish_draft_request.py +149 -0
- byteplussdkkickart/models/save_publish_draft_response.py +123 -0
- byteplussdkkickart/models/search_asset_request.py +487 -0
- byteplussdkkickart/models/search_asset_response.py +201 -0
- byteplussdkkickart/models/search_list_media_request.py +617 -0
- byteplussdkkickart/models/search_list_media_response.py +201 -0
- byteplussdkkickart/models/set_watermark_switch_status_request.py +253 -0
- byteplussdkkickart/models/set_watermark_switch_status_response.py +95 -0
- byteplussdkkickart/models/show_popup_request.py +124 -0
- byteplussdkkickart/models/show_popup_response.py +175 -0
- byteplussdkkickart/models/submit_publish_request.py +124 -0
- byteplussdkkickart/models/submit_publish_response.py +123 -0
- byteplussdkkickart/models/unbind_publish_account_request.py +124 -0
- byteplussdkkickart/models/unbind_publish_account_response.py +95 -0
- byteplussdkkickart/models/update_api_key_request.py +175 -0
- byteplussdkkickart/models/update_api_key_response.py +95 -0
- byteplussdkkickart/models/update_asset_request.py +149 -0
- byteplussdkkickart/models/update_asset_response.py +95 -0
- byteplussdkkickart/models/update_composition_product_info_request.py +151 -0
- byteplussdkkickart/models/update_composition_product_info_response.py +123 -0
- byteplussdkkickart/models/update_composition_request.py +149 -0
- byteplussdkkickart/models/update_composition_response.py +123 -0
- byteplussdkkickart/models/update_draft_request.py +227 -0
- byteplussdkkickart/models/update_draft_response.py +95 -0
- byteplussdkkickart/models/update_draft_title_request.py +151 -0
- byteplussdkkickart/models/update_draft_title_response.py +123 -0
- byteplussdkkickart/models/update_film_request.py +435 -0
- byteplussdkkickart/models/update_film_response.py +95 -0
- byteplussdkkickart/models/update_folder_media_path_request.py +175 -0
- byteplussdkkickart/models/update_folder_media_path_response.py +95 -0
- byteplussdkkickart/models/update_material_request.py +513 -0
- byteplussdkkickart/models/update_material_response.py +95 -0
- byteplussdkkickart/models/validate_avatar_image_request.py +123 -0
- byteplussdkkickart/models/validate_avatar_image_response.py +149 -0
- byteplussdkllmshield/models/llm_shield_sign.py +1 -1
- byteplussdkrdsmssql/__init__.py +1 -1
- byteplussdkrdsmssql/models/__init__.py +1 -1
- byteplussdkrdsmssql/models/describe_db_instance_specs_response.py +17 -17
- byteplussdkrdsmssql/models/{instance_spec_info_for_describe_db_instance_specs_output.py → instance_specs_info_for_describe_db_instance_specs_output.py} +45 -45
- byteplussdkvepfs/__init__.py +26 -0
- byteplussdkvepfs/api/vepfs_api.py +582 -0
- byteplussdkvepfs/models/__init__.py +26 -0
- byteplussdkvepfs/models/add_mount_service_clients_request.py +202 -0
- byteplussdkvepfs/models/add_mount_service_clients_response.py +123 -0
- byteplussdkvepfs/models/client_for_add_mount_service_clients_input.py +149 -0
- byteplussdkvepfs/models/client_for_describe_mount_service_tasks_output.py +149 -0
- byteplussdkvepfs/models/client_for_remove_mount_service_clients_input.py +149 -0
- byteplussdkvepfs/models/client_for_verify_mount_service_clients_input.py +149 -0
- byteplussdkvepfs/models/client_snapshot_for_describe_mount_service_task_results_output.py +305 -0
- byteplussdkvepfs/models/describe_lens_tasks_request.py +60 -1
- byteplussdkvepfs/models/describe_mount_service_clients_request.py +440 -0
- byteplussdkvepfs/models/describe_mount_service_clients_response.py +201 -0
- byteplussdkvepfs/models/describe_mount_service_task_results_request.py +415 -0
- byteplussdkvepfs/models/describe_mount_service_task_results_response.py +201 -0
- byteplussdkvepfs/models/describe_mount_service_tasks_request.py +267 -0
- byteplussdkvepfs/models/describe_mount_service_tasks_response.py +201 -0
- byteplussdkvepfs/models/instance_for_describe_mount_service_clients_output.py +253 -0
- byteplussdkvepfs/models/instance_for_describe_mount_service_task_results_output.py +253 -0
- byteplussdkvepfs/models/monitor_for_describe_mount_service_clients_output.py +123 -0
- byteplussdkvepfs/models/monitor_for_describe_mount_service_task_results_output.py +123 -0
- byteplussdkvepfs/models/mount_service_client_for_describe_mount_service_clients_output.py +305 -0
- byteplussdkvepfs/models/mount_service_task_result_for_describe_mount_service_task_results_output.py +201 -0
- byteplussdkvepfs/models/progress_for_describe_mount_service_tasks_output.py +201 -0
- byteplussdkvepfs/models/remove_mount_service_clients_request.py +150 -0
- byteplussdkvepfs/models/remove_mount_service_clients_response.py +123 -0
- byteplussdkvepfs/models/result_for_verify_mount_service_clients_output.py +175 -0
- byteplussdkvepfs/models/task_for_describe_mount_service_tasks_output.py +305 -0
- byteplussdkvepfs/models/verify_mount_service_clients_request.py +150 -0
- byteplussdkvepfs/models/verify_mount_service_clients_response.py +123 -0
- byteplussdkvke/__init__.py +69 -0
- byteplussdkvke/api/vke_api.py +1273 -206
- byteplussdkvke/models/__init__.py +69 -0
- byteplussdkvke/models/action_for_list_remedy_configs_output.py +149 -0
- byteplussdkvke/models/affinity_group_config_for_create_node_pool_input.py +149 -0
- byteplussdkvke/models/affinity_group_config_for_list_node_pools_output.py +149 -0
- byteplussdkvke/models/affinity_group_config_for_update_node_pool_config_input.py +149 -0
- byteplussdkvke/models/binding_remedy_config_request.py +262 -0
- byteplussdkvke/models/binding_remedy_config_response.py +123 -0
- byteplussdkvke/models/cluster_config_for_list_clusters_output.py +27 -1
- byteplussdkvke/models/cluster_config_for_update_cluster_config_input.py +53 -1
- byteplussdkvke/models/cluster_connector_config_request_for_update_cluster_config_input.py +215 -0
- byteplussdkvke/models/config_for_list_remedy_configs_output.py +253 -0
- byteplussdkvke/models/container_image_commitment_for_describe_container_image_commitments_output.py +227 -0
- byteplussdkvke/models/containerd_config_for_create_default_node_pool_input.py +149 -0
- byteplussdkvke/models/containerd_config_for_create_node_pool_input.py +149 -0
- byteplussdkvke/models/containerd_config_for_list_node_pools_output.py +149 -0
- byteplussdkvke/models/containerd_config_for_update_node_pool_config_input.py +149 -0
- byteplussdkvke/models/create_node_pool_request.py +27 -1
- byteplussdkvke/models/create_nodes_request.py +81 -3
- byteplussdkvke/models/create_snapshot_request.py +255 -0
- byteplussdkvke/models/create_snapshot_response.py +123 -0
- byteplussdkvke/models/data_volume_for_create_node_pool_input.py +87 -2
- byteplussdkvke/models/data_volume_for_list_node_pools_output.py +79 -1
- byteplussdkvke/models/data_volume_for_update_node_pool_config_input.py +87 -2
- byteplussdkvke/models/delete_nodes_request.py +2 -3
- byteplussdkvke/models/delete_snapshot_request.py +124 -0
- byteplussdkvke/models/delete_snapshot_response.py +123 -0
- byteplussdkvke/models/describe_container_image_commitments_request.py +227 -0
- byteplussdkvke/models/describe_container_image_commitments_response.py +149 -0
- byteplussdkvke/models/describe_snapshots_request.py +175 -0
- byteplussdkvke/models/describe_snapshots_response.py +149 -0
- byteplussdkvke/models/drain_for_list_remedy_configs_output.py +123 -0
- byteplussdkvke/models/eviction_hard_for_create_default_node_pool_input.py +62 -1
- byteplussdkvke/models/eviction_hard_for_create_node_pool_input.py +62 -1
- byteplussdkvke/models/eviction_hard_for_list_node_pools_output.py +55 -1
- byteplussdkvke/models/eviction_hard_for_update_node_pool_config_input.py +62 -1
- byteplussdkvke/models/exec_container_image_commitment_request.py +27 -1
- byteplussdkvke/models/exec_container_image_commitment_response.py +29 -1
- byteplussdkvke/models/filter_for_list_clusters_input.py +1 -1
- byteplussdkvke/models/filter_for_list_nodes_input.py +53 -1
- byteplussdkvke/models/filter_for_list_remedy_configs_input.py +234 -0
- byteplussdkvke/models/flannel_config_for_list_clusters_output.py +29 -3
- byteplussdkvke/models/flannel_config_for_update_cluster_config_input.py +123 -0
- byteplussdkvke/models/image_spec_for_describe_container_image_commitments_output.py +201 -0
- byteplussdkvke/models/instances_distribution_for_create_node_pool_input.py +201 -0
- byteplussdkvke/models/instances_distribution_for_list_node_pools_output.py +201 -0
- byteplussdkvke/models/instances_distribution_for_update_node_pool_config_input.py +201 -0
- byteplussdkvke/models/intersection_item_for_list_supported_images_output.py +149 -0
- byteplussdkvke/models/intervene_cordon_for_list_remedy_configs_output.py +149 -0
- byteplussdkvke/models/intervene_drain_for_list_remedy_configs_output.py +149 -0
- byteplussdkvke/models/irsa_config_for_list_clusters_output.py +253 -0
- byteplussdkvke/models/item_for_list_clusters_output.py +27 -1
- byteplussdkvke/models/item_for_list_instance_type_labels_output.py +175 -0
- byteplussdkvke/models/item_for_list_node_pools_output.py +27 -1
- byteplussdkvke/models/item_for_list_nodes_output.py +105 -1
- byteplussdkvke/models/item_for_list_remedy_configs_output.py +305 -0
- byteplussdkvke/models/item_for_list_supported_images_output.py +149 -0
- byteplussdkvke/models/kube_reserved_for_create_default_node_pool_input.py +7 -0
- byteplussdkvke/models/kube_reserved_for_create_node_pool_input.py +7 -0
- byteplussdkvke/models/kube_reserved_for_update_node_pool_config_input.py +7 -0
- byteplussdkvke/models/kubelet_config_for_create_default_node_pool_input.py +7 -24
- byteplussdkvke/models/kubelet_config_for_create_node_pool_input.py +7 -24
- byteplussdkvke/models/kubelet_config_for_update_node_pool_config_input.py +7 -24
- byteplussdkvke/models/kubernetes_config_for_create_default_node_pool_input.py +105 -1
- byteplussdkvke/models/kubernetes_config_for_create_node_pool_input.py +105 -1
- byteplussdkvke/models/kubernetes_config_for_list_node_pools_output.py +105 -1
- byteplussdkvke/models/kubernetes_config_for_update_node_pool_config_input.py +105 -1
- byteplussdkvke/models/label_for_list_instance_type_labels_output.py +149 -0
- byteplussdkvke/models/label_for_list_remedy_configs_output.py +149 -0
- byteplussdkvke/models/list_instance_type_labels_request.py +123 -0
- byteplussdkvke/models/list_instance_type_labels_response.py +123 -0
- byteplussdkvke/models/list_remedy_configs_request.py +175 -0
- byteplussdkvke/models/list_remedy_configs_response.py +201 -0
- byteplussdkvke/models/list_supported_add_instance_types_request.py +95 -0
- byteplussdkvke/models/list_supported_add_instance_types_response.py +123 -0
- byteplussdkvke/models/list_supported_gpu_driver_versions_request.py +176 -0
- byteplussdkvke/models/list_supported_gpu_driver_versions_response.py +123 -0
- byteplussdkvke/models/list_supported_images_request.py +175 -0
- byteplussdkvke/models/list_supported_images_response.py +149 -0
- byteplussdkvke/models/log_setup_for_create_cluster_input.py +1 -1
- byteplussdkvke/models/log_setup_for_update_cluster_config_input.py +1 -1
- byteplussdkvke/models/management_for_create_node_pool_input.py +149 -0
- byteplussdkvke/models/management_for_list_node_pools_output.py +149 -0
- byteplussdkvke/models/management_for_update_node_pool_config_input.py +149 -0
- byteplussdkvke/models/monitoring_config_for_list_clusters_output.py +27 -1
- byteplussdkvke/models/monitoring_config_for_update_cluster_config_input.py +27 -1
- byteplussdkvke/models/node_config_for_create_default_node_pool_input.py +27 -1
- byteplussdkvke/models/node_config_for_create_node_pool_input.py +216 -1
- byteplussdkvke/models/node_config_for_list_node_pools_output.py +209 -1
- byteplussdkvke/models/node_config_for_update_node_pool_config_input.py +216 -1
- byteplussdkvke/models/pods_config_for_update_cluster_config_input.py +27 -1
- byteplussdkvke/models/proxy_config_for_update_cluster_config_input.py +227 -0
- byteplussdkvke/models/public_access_config_for_create_node_pool_input.py +1 -1
- byteplussdkvke/models/public_access_config_for_update_node_pool_config_input.py +1 -1
- byteplussdkvke/models/public_access_network_config_for_create_cluster_input.py +1 -1
- byteplussdkvke/models/public_access_network_config_for_update_cluster_config_input.py +1 -1
- byteplussdkvke/models/registry_proxy_config_for_create_default_node_pool_input.py +149 -0
- byteplussdkvke/models/registry_proxy_config_for_create_node_pool_input.py +149 -0
- byteplussdkvke/models/registry_proxy_config_for_list_node_pools_output.py +149 -0
- byteplussdkvke/models/registry_proxy_config_for_update_node_pool_config_input.py +149 -0
- byteplussdkvke/models/remedy_config_for_create_node_pool_input.py +149 -0
- byteplussdkvke/models/remedy_config_for_list_node_pools_output.py +149 -0
- byteplussdkvke/models/remedy_config_for_update_node_pool_config_input.py +149 -0
- byteplussdkvke/models/remedy_strategy_for_list_remedy_configs_output.py +149 -0
- byteplussdkvke/models/rule_for_list_remedy_configs_output.py +175 -0
- byteplussdkvke/models/runtime_for_create_default_node_pool_input.py +156 -0
- byteplussdkvke/models/runtime_for_create_node_pool_input.py +156 -0
- byteplussdkvke/models/runtime_for_list_node_pools_output.py +149 -0
- byteplussdkvke/models/runtime_for_update_node_pool_config_input.py +156 -0
- byteplussdkvke/models/scheduled_instance_policy_for_create_scaling_policy_input.py +27 -1
- byteplussdkvke/models/scheduled_instance_policy_for_list_scaling_policies_output.py +27 -1
- byteplussdkvke/models/scheduled_instance_policy_for_update_scaling_policy_input.py +27 -1
- byteplussdkvke/models/snapshot_for_describe_snapshots_output.py +461 -0
- byteplussdkvke/models/status_for_list_clusters_input.py +1 -1
- byteplussdkvke/models/status_for_list_node_pools_input.py +1 -1
- byteplussdkvke/models/status_for_list_nodes_input.py +2 -2
- byteplussdkvke/models/supported_image_for_list_supported_images_output.py +149 -0
- byteplussdkvke/models/system_reserved_for_create_default_node_pool_input.py +7 -0
- byteplussdkvke/models/system_reserved_for_create_node_pool_input.py +7 -0
- byteplussdkvke/models/system_reserved_for_update_node_pool_config_input.py +7 -0
- byteplussdkvke/models/system_volume_for_create_node_pool_input.py +1 -1
- byteplussdkvke/models/system_volume_for_update_node_pool_config_input.py +1 -1
- byteplussdkvke/models/tag_for_create_snapshot_input.py +149 -0
- byteplussdkvke/models/unbinding_remedy_config_request.py +211 -0
- byteplussdkvke/models/unbinding_remedy_config_response.py +95 -0
- byteplussdkvke/models/update_cluster_config_request.py +27 -1
- byteplussdkvke/models/update_node_pool_config_request.py +27 -1
- byteplussdkvke/models/vpc_cni_config_for_list_clusters_output.py +29 -3
- byteplussdkvke/models/vpc_cni_config_for_update_cluster_config_input.py +29 -3
- byteplussdkvpc20250901/__init__.py +149 -0
- byteplussdkvpc20250901/api/__init__.py +6 -0
- byteplussdkvpc20250901/api/vpc20250901_api.py +4399 -0
- byteplussdkvpc20250901/models/__init__.py +145 -0
- byteplussdkvpc20250901/models/assign_private_ip_addresses_request.py +202 -0
- byteplussdkvpc20250901/models/assign_private_ip_addresses_response.py +201 -0
- byteplussdkvpc20250901/models/associate_route_table_request.py +176 -0
- byteplussdkvpc20250901/models/associate_route_table_response.py +149 -0
- byteplussdkvpc20250901/models/associate_vpc_cidr_block_request.py +150 -0
- byteplussdkvpc20250901/models/associate_vpc_cidr_block_response.py +201 -0
- byteplussdkvpc20250901/models/associated_elastic_ip_for_describe_network_interface_attributes_output.py +175 -0
- byteplussdkvpc20250901/models/associated_elastic_ip_for_describe_network_interfaces_output.py +175 -0
- byteplussdkvpc20250901/models/attach_network_interface_request.py +151 -0
- byteplussdkvpc20250901/models/attach_network_interface_response.py +149 -0
- byteplussdkvpc20250901/models/attachment_for_describe_network_interfaces_output.py +149 -0
- byteplussdkvpc20250901/models/authorize_security_group_egress_request.py +309 -0
- byteplussdkvpc20250901/models/authorize_security_group_egress_response.py +149 -0
- byteplussdkvpc20250901/models/authorize_security_group_ingress_request.py +309 -0
- byteplussdkvpc20250901/models/authorize_security_group_ingress_response.py +149 -0
- byteplussdkvpc20250901/models/create_network_interface_request.py +396 -0
- byteplussdkvpc20250901/models/create_network_interface_response.py +175 -0
- byteplussdkvpc20250901/models/create_route_entry_request.py +294 -0
- byteplussdkvpc20250901/models/create_route_entry_response.py +175 -0
- byteplussdkvpc20250901/models/create_route_table_request.py +266 -0
- byteplussdkvpc20250901/models/create_route_table_response.py +175 -0
- byteplussdkvpc20250901/models/create_security_group_request.py +254 -0
- byteplussdkvpc20250901/models/create_security_group_response.py +175 -0
- byteplussdkvpc20250901/models/create_subnet_request.py +294 -0
- byteplussdkvpc20250901/models/create_subnet_response.py +175 -0
- byteplussdkvpc20250901/models/create_vpc_request.py +292 -0
- byteplussdkvpc20250901/models/create_vpc_response.py +201 -0
- byteplussdkvpc20250901/models/delete_network_interface_request.py +124 -0
- byteplussdkvpc20250901/models/delete_network_interface_response.py +149 -0
- byteplussdkvpc20250901/models/delete_route_entry_request.py +124 -0
- byteplussdkvpc20250901/models/delete_route_entry_response.py +149 -0
- byteplussdkvpc20250901/models/delete_route_table_request.py +124 -0
- byteplussdkvpc20250901/models/delete_route_table_response.py +149 -0
- byteplussdkvpc20250901/models/delete_security_group_request.py +124 -0
- byteplussdkvpc20250901/models/delete_security_group_response.py +149 -0
- byteplussdkvpc20250901/models/delete_subnet_request.py +124 -0
- byteplussdkvpc20250901/models/delete_subnet_response.py +149 -0
- byteplussdkvpc20250901/models/delete_vpc_request.py +124 -0
- byteplussdkvpc20250901/models/delete_vpc_response.py +149 -0
- byteplussdkvpc20250901/models/describe_network_interface_attributes_request.py +124 -0
- byteplussdkvpc20250901/models/describe_network_interface_attributes_response.py +695 -0
- byteplussdkvpc20250901/models/describe_network_interfaces_request.py +548 -0
- byteplussdkvpc20250901/models/describe_network_interfaces_response.py +253 -0
- byteplussdkvpc20250901/models/describe_route_entry_list_request.py +393 -0
- byteplussdkvpc20250901/models/describe_route_entry_list_response.py +253 -0
- byteplussdkvpc20250901/models/describe_route_table_list_request.py +334 -0
- byteplussdkvpc20250901/models/describe_route_table_list_response.py +253 -0
- byteplussdkvpc20250901/models/describe_security_group_attributes_request.py +228 -0
- byteplussdkvpc20250901/models/describe_security_group_attributes_response.py +461 -0
- byteplussdkvpc20250901/models/describe_security_groups_request.py +340 -0
- byteplussdkvpc20250901/models/describe_security_groups_response.py +253 -0
- byteplussdkvpc20250901/models/describe_subnet_attributes_request.py +124 -0
- byteplussdkvpc20250901/models/describe_subnet_attributes_response.py +539 -0
- byteplussdkvpc20250901/models/describe_subnets_request.py +438 -0
- byteplussdkvpc20250901/models/describe_subnets_response.py +253 -0
- byteplussdkvpc20250901/models/describe_vpc_attributes_request.py +124 -0
- byteplussdkvpc20250901/models/describe_vpc_attributes_response.py +565 -0
- byteplussdkvpc20250901/models/describe_vpcs_request.py +366 -0
- byteplussdkvpc20250901/models/describe_vpcs_response.py +253 -0
- byteplussdkvpc20250901/models/detach_network_interface_request.py +151 -0
- byteplussdkvpc20250901/models/detach_network_interface_response.py +149 -0
- byteplussdkvpc20250901/models/disassociate_route_table_request.py +176 -0
- byteplussdkvpc20250901/models/disassociate_route_table_response.py +149 -0
- byteplussdkvpc20250901/models/disassociate_vpc_cidr_block_request.py +150 -0
- byteplussdkvpc20250901/models/disassociate_vpc_cidr_block_response.py +149 -0
- byteplussdkvpc20250901/models/list_tags_for_resources_request.py +264 -0
- byteplussdkvpc20250901/models/list_tags_for_resources_response.py +175 -0
- byteplussdkvpc20250901/models/modify_network_interface_attributes_request.py +266 -0
- byteplussdkvpc20250901/models/modify_network_interface_attributes_response.py +149 -0
- byteplussdkvpc20250901/models/modify_route_entry_request.py +188 -0
- byteplussdkvpc20250901/models/modify_route_entry_response.py +123 -0
- byteplussdkvpc20250901/models/modify_route_table_attributes_request.py +188 -0
- byteplussdkvpc20250901/models/modify_route_table_attributes_response.py +123 -0
- byteplussdkvpc20250901/models/modify_security_group_attributes_request.py +176 -0
- byteplussdkvpc20250901/models/modify_security_group_attributes_response.py +123 -0
- byteplussdkvpc20250901/models/modify_security_group_rule_descriptions_egress_request.py +283 -0
- byteplussdkvpc20250901/models/modify_security_group_rule_descriptions_egress_response.py +123 -0
- byteplussdkvpc20250901/models/modify_security_group_rule_descriptions_ingress_request.py +283 -0
- byteplussdkvpc20250901/models/modify_security_group_rule_descriptions_ingress_response.py +123 -0
- byteplussdkvpc20250901/models/modify_subnet_attributes_request.py +188 -0
- byteplussdkvpc20250901/models/modify_subnet_attributes_response.py +149 -0
- byteplussdkvpc20250901/models/modify_vpc_attributes_request.py +214 -0
- byteplussdkvpc20250901/models/modify_vpc_attributes_response.py +149 -0
- byteplussdkvpc20250901/models/network_interface_set_for_describe_network_interfaces_output.py +695 -0
- byteplussdkvpc20250901/models/permission_for_describe_security_group_attributes_output.py +331 -0
- byteplussdkvpc20250901/models/private_ip_set_for_describe_network_interface_attributes_output.py +175 -0
- byteplussdkvpc20250901/models/private_ip_set_for_describe_network_interfaces_output.py +175 -0
- byteplussdkvpc20250901/models/private_ip_sets_for_describe_network_interface_attributes_output.py +123 -0
- byteplussdkvpc20250901/models/private_ip_sets_for_describe_network_interfaces_output.py +123 -0
- byteplussdkvpc20250901/models/resource_tag_for_list_tags_for_resources_output.py +201 -0
- byteplussdkvpc20250901/models/revoke_security_group_egress_request.py +283 -0
- byteplussdkvpc20250901/models/revoke_security_group_egress_response.py +149 -0
- byteplussdkvpc20250901/models/revoke_security_group_ingress_request.py +283 -0
- byteplussdkvpc20250901/models/revoke_security_group_ingress_response.py +149 -0
- byteplussdkvpc20250901/models/route_entry_for_describe_route_entry_list_output.py +357 -0
- byteplussdkvpc20250901/models/route_table_for_describe_subnet_attributes_output.py +149 -0
- byteplussdkvpc20250901/models/route_table_for_describe_subnets_output.py +149 -0
- byteplussdkvpc20250901/models/router_table_list_for_describe_route_table_list_output.py +435 -0
- byteplussdkvpc20250901/models/security_group_for_describe_security_groups_output.py +383 -0
- byteplussdkvpc20250901/models/subnet_for_describe_subnets_output.py +513 -0
- byteplussdkvpc20250901/models/tag_filter_for_describe_network_interfaces_input.py +149 -0
- byteplussdkvpc20250901/models/tag_filter_for_describe_route_table_list_input.py +149 -0
- byteplussdkvpc20250901/models/tag_filter_for_describe_security_groups_input.py +149 -0
- byteplussdkvpc20250901/models/tag_filter_for_describe_subnets_input.py +149 -0
- byteplussdkvpc20250901/models/tag_filter_for_describe_vpcs_input.py +149 -0
- byteplussdkvpc20250901/models/tag_filter_for_list_tags_for_resources_input.py +149 -0
- byteplussdkvpc20250901/models/tag_for_create_network_interface_input.py +149 -0
- byteplussdkvpc20250901/models/tag_for_create_route_table_input.py +149 -0
- byteplussdkvpc20250901/models/tag_for_create_security_group_input.py +149 -0
- byteplussdkvpc20250901/models/tag_for_create_subnet_input.py +149 -0
- byteplussdkvpc20250901/models/tag_for_create_vpc_input.py +149 -0
- byteplussdkvpc20250901/models/tag_for_describe_network_interface_attributes_output.py +149 -0
- byteplussdkvpc20250901/models/tag_for_describe_network_interfaces_output.py +149 -0
- byteplussdkvpc20250901/models/tag_for_describe_route_table_list_output.py +149 -0
- byteplussdkvpc20250901/models/tag_for_describe_security_group_attributes_output.py +149 -0
- byteplussdkvpc20250901/models/tag_for_describe_security_groups_output.py +149 -0
- byteplussdkvpc20250901/models/tag_for_describe_subnet_attributes_output.py +149 -0
- byteplussdkvpc20250901/models/tag_for_describe_subnets_output.py +149 -0
- byteplussdkvpc20250901/models/tag_for_describe_vpc_attributes_output.py +149 -0
- byteplussdkvpc20250901/models/tag_for_describe_vpcs_output.py +149 -0
- byteplussdkvpc20250901/models/tag_for_tag_resources_input.py +150 -0
- byteplussdkvpc20250901/models/tag_resources_request.py +183 -0
- byteplussdkvpc20250901/models/tag_resources_response.py +123 -0
- byteplussdkvpc20250901/models/unassign_private_ip_addresses_request.py +150 -0
- byteplussdkvpc20250901/models/unassign_private_ip_addresses_response.py +149 -0
- byteplussdkvpc20250901/models/untag_resources_request.py +183 -0
- byteplussdkvpc20250901/models/untag_resources_response.py +123 -0
- byteplussdkvpc20250901/models/vpc_for_describe_vpcs_output.py +539 -0
- {byteplus_python_sdk_v2-3.0.43.dist-info → byteplus_python_sdk_v2-3.0.45.dist-info}/WHEEL +0 -0
- {byteplus_python_sdk_v2-3.0.43.dist-info → byteplus_python_sdk_v2-3.0.45.dist-info}/licenses/LICENSE.txt +0 -0
- {byteplus_python_sdk_v2-3.0.43.dist-info → byteplus_python_sdk_v2-3.0.45.dist-info}/licenses/NOTICE.md +0 -0
{byteplus_python_sdk_v2-3.0.43.dist-info → byteplus_python_sdk_v2-3.0.45.dist-info}/top_level.txt
RENAMED
|
@@ -21,6 +21,7 @@ byteplussdkhbase
|
|
|
21
21
|
byteplussdkiam20210801
|
|
22
22
|
byteplussdkid
|
|
23
23
|
byteplussdkkafka
|
|
24
|
+
byteplussdkkickart
|
|
24
25
|
byteplussdkkms
|
|
25
26
|
byteplussdkllmshield
|
|
26
27
|
byteplussdkmilvus
|
|
@@ -46,4 +47,5 @@ byteplussdkvke
|
|
|
46
47
|
byteplussdkvmp
|
|
47
48
|
byteplussdkvod20250701
|
|
48
49
|
byteplussdkvpc
|
|
50
|
+
byteplussdkvpc20250901
|
|
49
51
|
byteplussdkvpn
|
byteplussdkcore/api_client.py
CHANGED
|
@@ -2,7 +2,10 @@
|
|
|
2
2
|
|
|
3
3
|
from __future__ import absolute_import
|
|
4
4
|
|
|
5
|
+
import copy
|
|
5
6
|
import datetime
|
|
7
|
+
import logging
|
|
8
|
+
import time
|
|
6
9
|
from multiprocessing.pool import ThreadPool
|
|
7
10
|
from time import sleep
|
|
8
11
|
|
|
@@ -16,6 +19,8 @@ from byteplussdkcore.interceptor import BuildRequestInterceptor, RuntimeOptionsI
|
|
|
16
19
|
Response, InterceptorChain
|
|
17
20
|
from byteplussdkcore.observability.debugger import sdk_core_logger, LogLevel
|
|
18
21
|
|
|
22
|
+
logger = logging.getLogger(__name__)
|
|
23
|
+
|
|
19
24
|
|
|
20
25
|
class ApiClient(object):
|
|
21
26
|
"""Generic API client for Swagger client library builds.
|
|
@@ -63,7 +68,7 @@ class ApiClient(object):
|
|
|
63
68
|
self.default_headers[header_name] = header_value
|
|
64
69
|
self.cookie = cookie
|
|
65
70
|
# Set default User-Agent.
|
|
66
|
-
self.user_agent = 'byteplus-python-sdk-v2/3.0.
|
|
71
|
+
self.user_agent = 'byteplus-python-sdk-v2/3.0.45'
|
|
67
72
|
self.client_side_validation = configuration.client_side_validation
|
|
68
73
|
|
|
69
74
|
self.interceptor_chain = InterceptorChain()
|
|
@@ -397,6 +402,219 @@ class ApiClient(object):
|
|
|
397
402
|
|
|
398
403
|
sdk_core_logger.debug_config("".join(sb))
|
|
399
404
|
|
|
405
|
+
def _sts_call(self, action, version, params,
|
|
406
|
+
host=None, scheme='https', region='cn-beijing',
|
|
407
|
+
timeout=30, service='sts',
|
|
408
|
+
max_retries=3, retry_interval=1,
|
|
409
|
+
provider_name="ApiClient"):
|
|
410
|
+
"""Invoke an STS federation endpoint (AssumeRoleWithOIDC / AssumeRoleWithSAML / etc.)
|
|
411
|
+
through the SDK's main REST stack while explicitly disabling signing.
|
|
412
|
+
|
|
413
|
+
This reuses `ApiClient.call_api` so TLS config (`verify_ssl`,
|
|
414
|
+
`ssl_ca_cert`, `cert_file`, `assert_hostname`), proxy (`http_proxy` /
|
|
415
|
+
`https_proxy` / env vars), connect/read timeouts, connection pooling
|
|
416
|
+
and observability are all honored exactly as for any other SDK API call.
|
|
417
|
+
|
|
418
|
+
NOTE: this method dispatches via a NEW `ApiClient(fresh)` (not via
|
|
419
|
+
`self`); changes to `ApiClient.__init__` / `call_api` / interceptors
|
|
420
|
+
affect this STS path too.
|
|
421
|
+
|
|
422
|
+
Signing is skipped by passing `auth_settings=None`, which causes
|
|
423
|
+
`SignRequestInterceptor.update_params_for_auth` to early-return. This
|
|
424
|
+
is correct because OIDC / SAML federation entry points are unsigned
|
|
425
|
+
by design (the OIDCToken / SAMLResp is the authentication material).
|
|
426
|
+
|
|
427
|
+
Recursion is broken by clearing `credential_provider` and setting
|
|
428
|
+
`ak` / `sk` to sentinel values on the fresh Configuration copy, so
|
|
429
|
+
the STS request does not itself invoke the provider that initiated
|
|
430
|
+
it.
|
|
431
|
+
|
|
432
|
+
`provider_name` is used only for log/error context (e.g.
|
|
433
|
+
"STSOIDCProvider") -- pass the calling provider's PROVIDER_NAME so
|
|
434
|
+
operators can trace which credential source initiated the STS call.
|
|
435
|
+
|
|
436
|
+
Returns the unwrapped `Result` dict from the STS response. Business
|
|
437
|
+
errors bubble up as `rest.ApiException` (matching master behavior).
|
|
438
|
+
"""
|
|
439
|
+
# Configuration() via the TypeWithDefault metaclass returns a shallow
|
|
440
|
+
# copy of the user's default configuration, so TLS/proxy/timeout
|
|
441
|
+
# settings propagate to the STS call.
|
|
442
|
+
fresh = Configuration()
|
|
443
|
+
# Break recursion on three fronts:
|
|
444
|
+
# 1. credential_provider=None so SignRequestInterceptor won't call
|
|
445
|
+
# back into the provider via get_credentials().
|
|
446
|
+
# 2. Non-empty ak/sk sentinel so the feature branch's
|
|
447
|
+
# SignRequestInterceptor does NOT auto-attach a
|
|
448
|
+
# DefaultCredentialProvider (which would recurse through the
|
|
449
|
+
# whole credential chain). The sentinel never reaches the wire
|
|
450
|
+
# because auth_settings=None short-circuits
|
|
451
|
+
# update_params_for_auth before signing.
|
|
452
|
+
fresh.credential_provider = None
|
|
453
|
+
fresh.ak = "_sts_bootstrap_unsigned"
|
|
454
|
+
fresh.sk = "_sts_bootstrap_unsigned"
|
|
455
|
+
fresh.session_token = ""
|
|
456
|
+
# Per-call overrides from the caller
|
|
457
|
+
if host:
|
|
458
|
+
fresh.host = host
|
|
459
|
+
fresh.scheme = scheme
|
|
460
|
+
fresh.region = region
|
|
461
|
+
fresh.read_timeout = timeout
|
|
462
|
+
|
|
463
|
+
# Retry: apply caller-level retry semantics to this STS call only.
|
|
464
|
+
# Deep-copy the retryer so we don't mutate the caller's default
|
|
465
|
+
# retryer (DEFAULT_RETRYER is a module-level singleton shared across
|
|
466
|
+
# Configurations). Configuration exposes retryer via a getter-only
|
|
467
|
+
# property; swap the underlying __retryer via name mangling.
|
|
468
|
+
fresh._Configuration__retryer = copy.deepcopy(fresh.retryer)
|
|
469
|
+
# Caller semantics: max_retries = TOTAL attempts (legacy from
|
|
470
|
+
# _do_http_request's for-loop). Configuration semantics:
|
|
471
|
+
# num_max_retries = retries AFTER the initial attempt. Convert.
|
|
472
|
+
fresh.num_max_retries = max(max_retries - 1, 0)
|
|
473
|
+
# retry_interval is seconds; Configuration uses ms.
|
|
474
|
+
# Collapse the exponential-backoff range to a fixed delay.
|
|
475
|
+
delay_ms = int(retry_interval * 1000)
|
|
476
|
+
fresh.min_retry_delay_ms = delay_ms
|
|
477
|
+
fresh.max_retry_delay_ms = delay_ms
|
|
478
|
+
|
|
479
|
+
# NOTE: NEW ApiClient(fresh), not self -- avoids re-entering caller's provider chain.
|
|
480
|
+
client = ApiClient(fresh)
|
|
481
|
+
# BuildRequestInterceptor parses resource_path by index:
|
|
482
|
+
# [1]=Action [2]=Version [3]=service
|
|
483
|
+
resource_path = '/{}/{}/{}/post/'.format(action, version, service)
|
|
484
|
+
logger.debug(
|
|
485
|
+
"%s: STS call %s %s region=%s host=%s",
|
|
486
|
+
provider_name, action, version, region, host or fresh.host,
|
|
487
|
+
)
|
|
488
|
+
return client.call_api(
|
|
489
|
+
resource_path,
|
|
490
|
+
'POST',
|
|
491
|
+
path_params={},
|
|
492
|
+
query_params=[],
|
|
493
|
+
header_params={
|
|
494
|
+
'Accept': 'application/json',
|
|
495
|
+
'Content-Type': 'application/x-www-form-urlencoded',
|
|
496
|
+
},
|
|
497
|
+
body=params,
|
|
498
|
+
post_params=[],
|
|
499
|
+
files={},
|
|
500
|
+
response_type=object,
|
|
501
|
+
auth_settings=None, # skip signing
|
|
502
|
+
async_req=False,
|
|
503
|
+
_return_http_data_only=True,
|
|
504
|
+
_preload_content=True,
|
|
505
|
+
collection_formats={},
|
|
506
|
+
)
|
|
507
|
+
|
|
508
|
+
def _do_http_request(self, url, method="GET", data=None, headers=None, timeout=None,
|
|
509
|
+
max_retries=1, retry_interval=0, request_name=None,
|
|
510
|
+
retry_on_5xx=True, provider_name="ApiClient"):
|
|
511
|
+
"""Invoke an arbitrary HTTP(S) endpoint through the SDK's RESTClient.
|
|
512
|
+
|
|
513
|
+
Routing through `RESTClientObject` (constructed from `Configuration()`)
|
|
514
|
+
ensures the transport honors the same TLS/proxy settings as every
|
|
515
|
+
other SDK API call:
|
|
516
|
+
- `verify_ssl`, `ssl_ca_cert`, `cert_file`, `key_file`,
|
|
517
|
+
`assert_hostname`
|
|
518
|
+
- `proxy` / `http_proxy` / `https_proxy` (plus HTTP_PROXY /
|
|
519
|
+
HTTPS_PROXY environment variables)
|
|
520
|
+
- `connect_timeout` / `read_timeout` / connection pool sizing
|
|
521
|
+
|
|
522
|
+
Unlike `_sts_call` (which goes through `ApiClient.call_api`), this
|
|
523
|
+
path skips the OpenAPI semantics layer (signing, Action/Version
|
|
524
|
+
path parsing, response unwrapping) -- it's meant for non-OpenAPI
|
|
525
|
+
endpoints such as the SSO OAuth token endpoint, the SSO Portal,
|
|
526
|
+
and ECS IMDSv2.
|
|
527
|
+
|
|
528
|
+
Args:
|
|
529
|
+
url: Fully-qualified request URL.
|
|
530
|
+
method: HTTP method.
|
|
531
|
+
data: Request body.
|
|
532
|
+
headers: Request headers dict.
|
|
533
|
+
timeout: Total request timeout (seconds).
|
|
534
|
+
max_retries: Total number of attempts (including the first).
|
|
535
|
+
retry_interval: Seconds to sleep between retries.
|
|
536
|
+
request_name: Human-readable name used in error messages.
|
|
537
|
+
retry_on_5xx: If True (default) retry on HTTP 5xx responses.
|
|
538
|
+
provider_name: Used only for log/error context.
|
|
539
|
+
|
|
540
|
+
Returns:
|
|
541
|
+
Response body as a decoded str.
|
|
542
|
+
|
|
543
|
+
Raises:
|
|
544
|
+
RuntimeError on non-2xx HTTP response or transport failure.
|
|
545
|
+
"""
|
|
546
|
+
import urllib3
|
|
547
|
+
from byteplussdkcore.rest import RESTClientObject, ApiException
|
|
548
|
+
|
|
549
|
+
attempts = max(max_retries, 1)
|
|
550
|
+
rest_client = RESTClientObject(Configuration())
|
|
551
|
+
|
|
552
|
+
last_error = None
|
|
553
|
+
for attempt in range(attempts):
|
|
554
|
+
try:
|
|
555
|
+
logger.debug(
|
|
556
|
+
"%s: RESTClient attempt %d/%d %s %s",
|
|
557
|
+
provider_name, attempt + 1, attempts, method, url,
|
|
558
|
+
)
|
|
559
|
+
r = rest_client.request(
|
|
560
|
+
method=method,
|
|
561
|
+
url=url,
|
|
562
|
+
body=data,
|
|
563
|
+
headers=headers,
|
|
564
|
+
_request_timeout=timeout,
|
|
565
|
+
)
|
|
566
|
+
body = r.data
|
|
567
|
+
if isinstance(body, bytes):
|
|
568
|
+
try:
|
|
569
|
+
body = body.decode('utf-8')
|
|
570
|
+
except (UnicodeDecodeError, AttributeError):
|
|
571
|
+
pass
|
|
572
|
+
return body
|
|
573
|
+
except ApiException as e:
|
|
574
|
+
status = e.status or 0
|
|
575
|
+
err_body = e.body
|
|
576
|
+
if isinstance(err_body, bytes):
|
|
577
|
+
try:
|
|
578
|
+
err_body = err_body.decode('utf-8')
|
|
579
|
+
except (UnicodeDecodeError, AttributeError):
|
|
580
|
+
err_body = repr(err_body)
|
|
581
|
+
if status == 0:
|
|
582
|
+
raise RuntimeError(
|
|
583
|
+
"{}: {} failed at '{}' (transport error): {}".format(
|
|
584
|
+
provider_name, request_name or "request", url, e.reason,
|
|
585
|
+
)
|
|
586
|
+
)
|
|
587
|
+
if retry_on_5xx and status >= 500:
|
|
588
|
+
last_error = RuntimeError(
|
|
589
|
+
"HTTP {}: {}".format(status, err_body)
|
|
590
|
+
)
|
|
591
|
+
logger.debug(
|
|
592
|
+
"%s: HTTP %s on attempt %d/%d: %s",
|
|
593
|
+
provider_name, status, attempt + 1, attempts, err_body,
|
|
594
|
+
)
|
|
595
|
+
if attempt < attempts - 1:
|
|
596
|
+
time.sleep(retry_interval)
|
|
597
|
+
continue
|
|
598
|
+
raise RuntimeError(
|
|
599
|
+
"{}: {} failed with HTTP {}: {}".format(
|
|
600
|
+
provider_name, request_name or "request", status, err_body,
|
|
601
|
+
)
|
|
602
|
+
)
|
|
603
|
+
except (urllib3.exceptions.HTTPError, IOError, OSError) as e:
|
|
604
|
+
last_error = e
|
|
605
|
+
logger.debug(
|
|
606
|
+
"%s: transport error on attempt %d/%d: %r",
|
|
607
|
+
provider_name, attempt + 1, attempts, e,
|
|
608
|
+
)
|
|
609
|
+
if attempt < attempts - 1:
|
|
610
|
+
time.sleep(retry_interval)
|
|
611
|
+
|
|
612
|
+
raise RuntimeError(
|
|
613
|
+
"{}: failed to call {} at '{}' after {} retries: {}".format(
|
|
614
|
+
provider_name, request_name or "request", url, attempts, last_error,
|
|
615
|
+
)
|
|
616
|
+
)
|
|
617
|
+
|
|
400
618
|
|
|
401
619
|
def metadata(self):
|
|
402
620
|
return self._metadata
|
|
@@ -1,4 +1,8 @@
|
|
|
1
1
|
from .static_provider import StaticCredentialProvider
|
|
2
2
|
from .sts_provider import StsCredentialProvider
|
|
3
3
|
from .sts_oidc_provider import StsOidcCredentialProvider
|
|
4
|
-
from .sts_saml_provider import StsSamlCredentialProvider
|
|
4
|
+
from .sts_saml_provider import StsSamlCredentialProvider
|
|
5
|
+
from .env_provider import EnvironmentVariableCredentialProvider
|
|
6
|
+
from .cli_config_provider import CLIConfigCredentialProvider
|
|
7
|
+
from .ecs_role_provider import EcsRoleCredentialProvider
|
|
8
|
+
from .default_provider import DefaultCredentialProvider
|