From 2d8df67ad56aeb2f8a1c8e3275a7732cda59af97 Mon Sep 17 00:00:00 2001 From: Swarn10 Date: Mon, 24 Jun 2024 12:53:25 +0000 Subject: [PATCH] Releasing version 3.44.0 Co-authored-by: Hamada Ibrahim Co-authored-by: Harsh Kumar Co-authored-by: Kanvi Pasricha Co-authored-by: Alex Le Co-authored-by: Nupur Gupta Co-authored-by: Karthik Kamath Co-authored-by: Mandy Tsai Co-authored-by: Pankaj Joshi Co-authored-by: Anup Singh Co-authored-by: Swarnava Sarkar --- CHANGELOG.rst | 53 + requirements.txt | 2 +- services/database_migration/__init__.py | 2 +- services/database_migration/src/__init__.py | 2 +- .../oci_cli_database_migration/__init__.py | 2 +- .../databasemigration_cli_extended.py | 549 +++-- .../generated/__init__.py | 2 +- .../generated/client_mappings.py | 2 +- .../generated/databasemigration_cli.py | 2152 ++++++++--------- services/database_migration/tests/__init__.py | 2 +- .../tests/util/generated/command_to_api.py | 6 - .../generated/dbbackups_cli.py | 72 + setup.py | 2 +- src/common_util/ignored_commands.py | 1 + src/oci_cli/version.py | 2 +- 15 files changed, 1419 insertions(+), 1432 deletions(-) diff --git a/CHANGELOG.rst b/CHANGELOG.rst index f5ee29ad9..22e536ec8 100644 --- a/CHANGELOG.rst +++ b/CHANGELOG.rst @@ -6,6 +6,59 @@ All notable changes to this project will be documented in this file. The format is based on `Keep a Changelog `__. +3.44.0 - 2024-06-25 +-------------------- +Changed +~~~~~~~ +* [BREAKING] OCI Database Migration Service + + * Deprecation of Agent resource for `database-migration`. Following commands have changed: + + * ``oci database-migration agent`` + * ``oci database-migration agent-image-summary`` + * ``oci database-migration agent-summary`` + * ``oci database-migration migration create-migration-aws-s3-data-transfer-medium-details`` + * ``oci database-migration migration create-migration-db-link-data-transfer-medium-details`` + * ``oci database-migration migration create-migration-nfs-data-transfer-medium-details`` + * ``oci database-migration migration create-migration-object-storage-data-transfer-medium-details`` + * ``oci database-migration migration update-migration-aws-s3-data-transfer-medium-details`` + * ``oci database-migration migration update-migration-db-link-data-transfer-medium-details`` + * ``oci database-migration migration update-migration-nfs-data-transfer-medium-details`` + * ``oci database-migration migration update-migration-object-storage-data-transfer-medium-details`` + * ``oci database-migration connection create`` + * ``oci database-migration connection update`` + * ``oci database-migration migration add`` + * ``oci database-migration migration clone`` + * ``oci database-migration migration create`` + * ``oci database-migration migration remove`` + * ``oci database-migration migration update`` + * ``oci database-migration migration-object-type-summary list`` + +Added +~~~~~ +* OCI Database Migration Service + + * Support for MySQL to MySQL homogeneous migration + + * ``oci database-migration connection create-mysql-connection`` + * ``oci database-migration connection create-oracle-connection`` + * ``oci database-migration connection update-mysql-connection`` + * ``oci database-migration connection update-oracle-connection`` + * ``oci database-migration migration add-mysql-objects`` + * ``oci database-migration migration add-oracle-objects`` + * ``oci database-migration migration clone-mysql-migration`` + * ``oci database-migration migration clone-oracle-migration`` + * ``oci database-migration migration create-mysql-migration`` + * ``oci database-migration migration create-oracle-migration`` + * ``oci database-migration migration remove-mysql-objects`` + * ``oci database-migration migration remove-oracle-objects`` + * ``oci database-migration migration update-mysql-migration`` + * ``oci database-migration migration update-oracle-migration`` + +* Support for manual cross-region backup copy in the HeatWave MySQL Service + + * ``oci mysql backup copy`` + 3.43.2 - 2024-06-18 -------------------- Added diff --git a/requirements.txt b/requirements.txt index de95f72e8..74635a17c 100644 --- a/requirements.txt +++ b/requirements.txt @@ -14,7 +14,7 @@ Jinja2==3.0.3 jmespath==0.10.0 ndg-httpsclient==0.4.2 mock==2.0.0 -oci==2.128.2 +oci==2.129.0 packaging==20.2 pluggy==0.13.0 py==1.11.0 diff --git a/services/database_migration/__init__.py b/services/database_migration/__init__.py index fe8fd3394..cd62a3ee1 100644 --- a/services/database_migration/__init__.py +++ b/services/database_migration/__init__.py @@ -1,4 +1,4 @@ # coding: utf-8 # Copyright (c) 2016, 2024, Oracle and/or its affiliates. All rights reserved. # This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license. -# NOTE: This class is auto generated by OracleSDKGenerator. DO NOT EDIT. API Version: 20210929 +# NOTE: This class is auto generated by OracleSDKGenerator. DO NOT EDIT. API Version: 20230518 diff --git a/services/database_migration/src/__init__.py b/services/database_migration/src/__init__.py index fe8fd3394..cd62a3ee1 100644 --- a/services/database_migration/src/__init__.py +++ b/services/database_migration/src/__init__.py @@ -1,4 +1,4 @@ # coding: utf-8 # Copyright (c) 2016, 2024, Oracle and/or its affiliates. All rights reserved. # This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license. -# NOTE: This class is auto generated by OracleSDKGenerator. DO NOT EDIT. API Version: 20210929 +# NOTE: This class is auto generated by OracleSDKGenerator. DO NOT EDIT. API Version: 20230518 diff --git a/services/database_migration/src/oci_cli_database_migration/__init__.py b/services/database_migration/src/oci_cli_database_migration/__init__.py index fe8fd3394..cd62a3ee1 100644 --- a/services/database_migration/src/oci_cli_database_migration/__init__.py +++ b/services/database_migration/src/oci_cli_database_migration/__init__.py @@ -1,4 +1,4 @@ # coding: utf-8 # Copyright (c) 2016, 2024, Oracle and/or its affiliates. All rights reserved. # This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license. -# NOTE: This class is auto generated by OracleSDKGenerator. DO NOT EDIT. API Version: 20210929 +# NOTE: This class is auto generated by OracleSDKGenerator. DO NOT EDIT. API Version: 20230518 diff --git a/services/database_migration/src/oci_cli_database_migration/databasemigration_cli_extended.py b/services/database_migration/src/oci_cli_database_migration/databasemigration_cli_extended.py index 3e3618068..413732230 100644 --- a/services/database_migration/src/oci_cli_database_migration/databasemigration_cli_extended.py +++ b/services/database_migration/src/oci_cli_database_migration/databasemigration_cli_extended.py @@ -1,112 +1,129 @@ -# # coding: utf-8 -# # Copyright (c) 2016, 2020, Oracle and/or its affiliates. All rights reserved. -# # This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license. -# -# from __future__ import print_function -# import click # noqa: F401 -# import json # noqa: F401 -# from services.database_migration.src.oci_cli_database_migration.generated import databasemigration_cli -# from oci_cli import cli_util # noqa: F401 -# from oci_cli import custom_types # noqa: F401 -# from oci_cli import json_skeleton_utils # noqa: F401 -# from oci_cli import cli_exceptions -# -# databasemigration_cli.database_migration_root_group.short_help = "Oracle Database Migration Service" -# -# # oci database-migration agent-image-summary -> oci database-migration agent-image +# Copyright (c) 2016, 2023, Oracle and/or its affiliates. +# +# This software is dual-licensed to you under the Universal Permissive License +# (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl and Apache License +# 2.0 as shown at https://www.apache.org/licenses/LICENSE-2.0. You may choose +# either license. +# +# If you elect to accept the software under the Apache License, Version 2.0, +# the following applies: +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# https://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# coding: utf-8 +from __future__ import print_function +import click # noqa: F401 +import json # noqa: F401 +from services.database_migration.src.oci_cli_database_migration.generated import databasemigration_cli +from oci_cli import cli_util # noqa: F401 +from oci_cli import custom_types # noqa: F401 +from oci_cli import json_skeleton_utils # noqa: F401 +from oci_cli import cli_exceptions + + +# oci database-migration agent-image-summary -> oci database-migration agent-image # cli_util.rename_command(databasemigration_cli, databasemigration_cli.database_migration_root_group, databasemigration_cli.agent_image_summary_group, "agent-image") -# -# -# # oci database-migration agent-image-summary list-agent-images -> oci database-migration agent-image-summary list + + +# oci database-migration agent-image-summary list-agent-images -> oci database-migration agent-image-summary list # cli_util.rename_command(databasemigration_cli, databasemigration_cli.agent_image_summary_group, databasemigration_cli.list_agent_images, "list") -# -# -# # oci database-migration agent-summary list-agents -> oci database-migration agent-summary list + + +# oci database-migration agent-summary list-agents -> oci database-migration agent-summary list # cli_util.rename_command(databasemigration_cli, databasemigration_cli.agent_summary_group, databasemigration_cli.list_agents, "list") -# -# -# # oci database-migration connection-summary list-connections -> oci database-migration connection-summary list -# cli_util.rename_command(databasemigration_cli, databasemigration_cli.connection_summary_group, databasemigration_cli.list_connections, "list") -# -# -# # oci database-migration job evaluate-migration -> oci database-migration job evaluate -# cli_util.rename_command(databasemigration_cli, databasemigration_cli.job_group, databasemigration_cli.evaluate_migration, "evaluate") -# -# -# # oci database-migration job start-migration -> oci database-migration job start -# cli_util.rename_command(databasemigration_cli, databasemigration_cli.job_group, databasemigration_cli.start_migration, "start") -# -# -# # oci database-migration job-output-summary -> oci database-migration job-output -# cli_util.rename_command(databasemigration_cli, databasemigration_cli.database_migration_root_group, databasemigration_cli.job_output_summary_group, "job-output") -# -# -# # oci database-migration job-output-summary list-job-outputs -> oci database-migration job-output-summary list -# cli_util.rename_command(databasemigration_cli, databasemigration_cli.job_output_summary_group, databasemigration_cli.list_job_outputs, "list") -# -# -# # oci database-migration job-summary list-jobs -> oci database-migration job-summary list -# cli_util.rename_command(databasemigration_cli, databasemigration_cli.job_summary_group, databasemigration_cli.list_jobs, "list") -# -# -# # oci database-migration migration-summary list-migrations -> oci database-migration migration-summary list -# cli_util.rename_command(databasemigration_cli, databasemigration_cli.migration_summary_group, databasemigration_cli.list_migrations, "list") -# -# -# # oci database-migration work-request-log-entry -> oci database-migration work-request-logs -# cli_util.rename_command(databasemigration_cli, databasemigration_cli.database_migration_root_group, databasemigration_cli.work_request_log_entry_group, "work-request-logs") -# -# -# # oci database-migration work-request-log-entry list-work-request-logs -> oci database-migration work-request-log-entry list -# cli_util.rename_command(databasemigration_cli, databasemigration_cli.work_request_log_entry_group, databasemigration_cli.list_work_request_logs, "list") -# -# -# # oci database-migration work-request-summary list-work-requests -> oci database-migration work-request-summary list -# cli_util.rename_command(databasemigration_cli, databasemigration_cli.work_request_summary_group, databasemigration_cli.list_work_requests, "list") -# -# -# # oci database-migration job evaluate-migration -> oci database-migration migration -# databasemigration_cli.job_group.commands.pop(databasemigration_cli.evaluate_migration.name) -# databasemigration_cli.migration_group.add_command(databasemigration_cli.evaluate_migration) -# -# -# # oci database-migration job start-migration -> oci database-migration migration -# databasemigration_cli.job_group.commands.pop(databasemigration_cli.start_migration.name) -# databasemigration_cli.migration_group.add_command(databasemigration_cli.start_migration) -# -# -# # oci database-migration agent-summary list-agents -> oci database-migration agent + + +# oci database-migration connection-summary list-connections -> oci database-migration connection-summary list +cli_util.rename_command(databasemigration_cli, databasemigration_cli.connection_summary_group, databasemigration_cli.list_connections, "list") + + +# oci database-migration job evaluate-migration -> oci database-migration job evaluate +cli_util.rename_command(databasemigration_cli, databasemigration_cli.job_group, databasemigration_cli.evaluate_migration, "evaluate") + + +# oci database-migration job start-migration -> oci database-migration job start +cli_util.rename_command(databasemigration_cli, databasemigration_cli.job_group, databasemigration_cli.start_migration, "start") + + +# oci database-migration job-output-summary -> oci database-migration job-output +cli_util.rename_command(databasemigration_cli, databasemigration_cli.database_migration_root_group, databasemigration_cli.job_output_summary_group, "job-output") + + +# oci database-migration job-output-summary list-job-outputs -> oci database-migration job-output-summary list +cli_util.rename_command(databasemigration_cli, databasemigration_cli.job_output_summary_group, databasemigration_cli.list_job_outputs, "list") + + +# oci database-migration job-summary list-jobs -> oci database-migration job-summary list +cli_util.rename_command(databasemigration_cli, databasemigration_cli.job_summary_group, databasemigration_cli.list_jobs, "list") + + +# oci database-migration migration-summary list-migrations -> oci database-migration migration-summary list +cli_util.rename_command(databasemigration_cli, databasemigration_cli.migration_summary_group, databasemigration_cli.list_migrations, "list") + + +# oci database-migration work-request-log-entry -> oci database-migration work-request-logs +cli_util.rename_command(databasemigration_cli, databasemigration_cli.database_migration_root_group, databasemigration_cli.work_request_log_entry_group, "work-request-logs") + + +# oci database-migration work-request-log-entry list-work-request-logs -> oci database-migration work-request-log-entry list +cli_util.rename_command(databasemigration_cli, databasemigration_cli.work_request_log_entry_group, databasemigration_cli.list_work_request_logs, "list") + + +# oci database-migration work-request-summary list-work-requests -> oci database-migration work-request-summary list +cli_util.rename_command(databasemigration_cli, databasemigration_cli.work_request_summary_group, databasemigration_cli.list_work_requests, "list") + + +# oci database-migration job evaluate-migration -> oci database-migration migration +databasemigration_cli.job_group.commands.pop(databasemigration_cli.evaluate_migration.name) +databasemigration_cli.migration_group.add_command(databasemigration_cli.evaluate_migration) + + +# oci database-migration job start-migration -> oci database-migration migration +databasemigration_cli.job_group.commands.pop(databasemigration_cli.start_migration.name) +databasemigration_cli.migration_group.add_command(databasemigration_cli.start_migration) + + +# oci database-migration agent-summary list-agents -> oci database-migration agent # databasemigration_cli.agent_summary_group.commands.pop(databasemigration_cli.list_agents.name) # databasemigration_cli.agent_group.add_command(databasemigration_cli.list_agents) -# -# -# # oci database-migration connection-summary list-connections -> oci database-migration connection -# databasemigration_cli.connection_summary_group.commands.pop(databasemigration_cli.list_connections.name) -# databasemigration_cli.connection_group.add_command(databasemigration_cli.list_connections) -# -# -# # oci database-migration job-summary list-jobs -> oci database-migration job -# databasemigration_cli.job_summary_group.commands.pop(databasemigration_cli.list_jobs.name) -# databasemigration_cli.job_group.add_command(databasemigration_cli.list_jobs) -# -# -# # oci database-migration migration-summary list-migrations -> oci database-migration migration -# databasemigration_cli.migration_summary_group.commands.pop(databasemigration_cli.list_migrations.name) -# databasemigration_cli.migration_group.add_command(databasemigration_cli.list_migrations) -# -# -# # oci database-migration work-request-summary list-work-requests -> oci database-migration work-request -# databasemigration_cli.work_request_summary_group.commands.pop(databasemigration_cli.list_work_requests.name) -# databasemigration_cli.work_request_group.add_command(databasemigration_cli.list_work_requests) -# -# # remove groups previously renamed + + +# oci database-migration connection-summary list-connections -> oci database-migration connection +databasemigration_cli.connection_summary_group.commands.pop(databasemigration_cli.list_connections.name) +databasemigration_cli.connection_group.add_command(databasemigration_cli.list_connections) + + +# oci database-migration job-summary list-jobs -> oci database-migration job +databasemigration_cli.job_summary_group.commands.pop(databasemigration_cli.list_jobs.name) +databasemigration_cli.job_group.add_command(databasemigration_cli.list_jobs) + + +# oci database-migration migration-summary list-migrations -> oci database-migration migration +databasemigration_cli.migration_summary_group.commands.pop(databasemigration_cli.list_migrations.name) +databasemigration_cli.migration_group.add_command(databasemigration_cli.list_migrations) + + +# oci database-migration work-request-summary list-work-requests -> oci database-migration work-request +databasemigration_cli.work_request_summary_group.commands.pop(databasemigration_cli.list_work_requests.name) +databasemigration_cli.work_request_group.add_command(databasemigration_cli.list_work_requests) + +# remove groups previously renamed # databasemigration_cli.database_migration_root_group.commands.pop(databasemigration_cli.agent_summary_group.name) -# databasemigration_cli.database_migration_root_group.commands.pop(databasemigration_cli.connection_summary_group.name) -# databasemigration_cli.database_migration_root_group.commands.pop(databasemigration_cli.job_summary_group.name) -# databasemigration_cli.database_migration_root_group.commands.pop(databasemigration_cli.migration_summary_group.name) -# databasemigration_cli.database_migration_root_group.commands.pop(databasemigration_cli.work_request_summary_group.name) -# -# +databasemigration_cli.database_migration_root_group.commands.pop(databasemigration_cli.connection_summary_group.name) +databasemigration_cli.database_migration_root_group.commands.pop(databasemigration_cli.job_summary_group.name) +databasemigration_cli.database_migration_root_group.commands.pop(databasemigration_cli.migration_summary_group.name) +databasemigration_cli.database_migration_root_group.commands.pop(databasemigration_cli.work_request_summary_group.name) + + # @cli_util.copy_params_from_generated_command(databasemigration_cli.update_agent, params_to_exclude=['version_parameterconflict']) # @databasemigration_cli.agent_group.command(name=databasemigration_cli.update_agent.name, help=databasemigration_cli.update_agent.help) # @cli_util.option('--agent-version', help=u"""ODMS Agent version""") @@ -129,116 +146,216 @@ # kwargs.pop('public_key_file') # # ctx.invoke(databasemigration_cli.update_agent, **kwargs) -# -# -# # oci database-migration connection create --tls-keystore-file --tls-wallet-file --ssh-details.sshkeyFile -# @cli_util.copy_params_from_generated_command(databasemigration_cli.create_connection, params_to_exclude=['manual_database_sub_type']) -# @databasemigration_cli.connection_group.command(name='create', help=databasemigration_cli.create_connection.help) -# @cli_util.option('--db-subtype', type=custom_types.CliCaseInsensitiveChoice(["ORACLE", "RDS_ORACLE"]), help="""Database manual connection subtype. This value can only be specified for manual connections.""") -# @cli_util.option('--tls-wallet-file', type=click.File('r'), help=u"""cwallet.sso fle path containing containing the TCPS/SSL certificate; base64 encoded String. Not required for source container database connections.""") -# @cli_util.option('--tls-keystore-file', type=click.File('r'), help=u"""keystore.jks file path; base64 encoded String content. Requires a TLS wallet to be specified. Not required for source container database connections.""") -# @cli_util.option('--sshkey-file', type=click.File('r'), help=u""" Private ssh key file.""") -# @click.pass_context -# @json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'connect-descriptor': {'module': 'database_migration', 'class': 'CreateConnectDescriptor'}, 'ssh-details': {'module': 'database_migration', 'class': 'CreateSshDetails'}, 'admin-credentials': {'module': 'database_migration', 'class': 'CreateAdminCredentials'}, 'private-endpoint': {'module': 'database_migration', 'class': 'CreatePrivateEndpoint'}, 'vault-details': {'module': 'database_migration', 'class': 'CreateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}, output_type={'module': 'database_migration', 'class': 'Connection'}) -# @cli_util.wrap_exceptions -# def create_connection(ctx, **kwargs): -# -# if 'db_subtype' in kwargs: -# kwargs['manual_database_sub_type'] = kwargs['db_subtype'] -# kwargs.pop('db_subtype') -# -# # read --sshkey-file into ssh_details['sshkey'] -# if 'sshkey_file' in kwargs and kwargs['sshkey_file'] is not None: -# ssh_details = {} -# if 'ssh_details' in kwargs and kwargs['ssh_details'] is not None: -# if ssh_details.get('sshkey') and ssh_details['sshkey'] is not None: -# raise cli_exceptions.RequiredValueNotInDefaultOrUserInputError('Cannot specify both --sshkey-file and sshDetails.sshkey.') -# ssh_details = kwargs['ssh_details'] -# sshkey_file = kwargs.get('sshkey_file') -# if sshkey_file: -# ssh_details['sshkey'] = sshkey_file.read() -# kwargs['ssh_details'] = json.dumps(ssh_details) -# kwargs.pop('sshkey_file') -# -# # create_connection read --tls-wallet using --tls-wallet-file -# if kwargs.get('tls_wallet') and kwargs.get('tls_wallet_file'): -# raise cli_exceptions.RequiredValueNotInDefaultOrUserInputError('Cannot specify both --tls-wallet and --tls-wallet-file.') -# -# tls_wallet_file = kwargs.get('tls_wallet_file') -# if tls_wallet_file: -# kwargs['tls_wallet'] = tls_wallet_file.read() -# -# kwargs.pop('tls_wallet_file') -# -# # create_connection read --tls-keystore using --tls-keystore-file -# if kwargs.get('tls_keystore') and kwargs.get('tls_keystore_file'): -# raise cli_exceptions.RequiredValueNotInDefaultOrUserInputError('Cannot specify both --tls-keystore or --tls-keystore-file.') -# -# tls_keystore_file = kwargs.get('tls_keystore_file') -# if tls_keystore_file: -# kwargs['tls_keystore'] = tls_keystore_file.read() -# -# kwargs.pop('tls_keystore_file') -# -# ctx.invoke(databasemigration_cli.create_connection, **kwargs) -# -# -# # oci database-migration connection update --tls-keystore-file --tls-wallet-file --ssh-details.sshkeyFile -# @cli_util.copy_params_from_generated_command(databasemigration_cli.update_connection, params_to_exclude=[]) -# @databasemigration_cli.connection_group.command(name='update', help=databasemigration_cli.update_connection.help) -# @cli_util.option('--tls-wallet-file', type=click.File('r'), help=u"""cwallet.sso file path containing containing the TCPS/SSL certificate; base64 encoded String. Not required for source container database connections.""") -# @cli_util.option('--tls-keystore-file', type=click.File('r'), help=u"""keystore.jks file path; base64 encoded String contents. Requires a TLS wallet to be specified. Not required for source container database connections.""") -# @cli_util.option('--sshkey-file', type=click.File('r'), help=u""" Private ssh key file.""") -# @click.pass_context -# @json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'connect-descriptor': {'module': 'database_migration', 'class': 'UpdateConnectDescriptor'}, 'ssh-details': {'module': 'database_migration', 'class': 'UpdateSshDetails'}, 'admin-credentials': {'module': 'database_migration', 'class': 'UpdateAdminCredentials'}, 'private-endpoint': {'module': 'database_migration', 'class': 'UpdatePrivateEndpoint'}, 'vault-details': {'module': 'database_migration', 'class': 'UpdateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}) -# @cli_util.wrap_exceptions -# def update_connection(ctx, **kwargs): -# # read --sshkey-file into ssh_details['sshkey'] -# if 'sshkey_file' in kwargs and kwargs['sshkey_file'] is not None: -# ssh_details = {} -# if 'ssh_details' in kwargs and kwargs['ssh_details'] is not None: -# if ssh_details.get('sshkey') and ssh_details['sshkey'] is not None: -# raise cli_exceptions.RequiredValueNotInDefaultOrUserInputError('Cannot specify both --sshkey-file and sshDetails.sshkey.') -# ssh_details = kwargs['ssh_details'] -# sshkey_file = kwargs.get('sshkey_file') -# if sshkey_file: -# ssh_details['sshkey'] = sshkey_file.read() -# kwargs['ssh_details'] = json.dumps(ssh_details) -# kwargs.pop('sshkey_file') -# -# # update_connection read --tls-wallet using --tls-wallet-file -# if kwargs.get('tls_wallet') and kwargs.get('tls_wallet_file'): -# raise cli_exceptions.RequiredValueNotInDefaultOrUserInputError('Cannot specify both --tls-wallet or --tls-wallet-file.') -# -# tls_wallet_file = kwargs.get('tls_wallet_file') -# if tls_wallet_file: -# kwargs['tls_wallet'] = tls_wallet_file.read() -# -# kwargs.pop('tls_wallet_file') -# -# # update_connection read --tls-keystore using --tls-keystore-file -# if kwargs.get('tls_keystore') and kwargs.get('tls_keystore_file'): -# raise cli_exceptions.RequiredValueNotInDefaultOrUserInputError('Cannot specify both --tls-keystore or --tls-keystore-file.') -# -# tls_keystore_file = kwargs.get('tls_keystore_file') -# if tls_keystore_file: -# kwargs['tls_keystore'] = tls_keystore_file.read() -# -# kwargs.pop('tls_keystore_file') -# -# ctx.invoke(databasemigration_cli.update_connection, **kwargs) -# -# -# # oci database-migration migration-object-type-summary list-migration-object-types -> oci database-migration migration-object-type-summary list -# cli_util.rename_command(databasemigration_cli, databasemigration_cli.migration_object_type_summary_group, databasemigration_cli.list_migration_object_types, "list") -# -# # oci database-migration excluded-object-summary list-excluded-objects -> oci database-migration excluded-object-summary list -# cli_util.rename_command(databasemigration_cli, databasemigration_cli.excluded_object_summary_group, databasemigration_cli.list_excluded_objects, "list") -# -# -# # oci database-migration migration-object-collection list-migration-objects -> oci database-migration migration-object-collection list -# cli_util.rename_command(databasemigration_cli, databasemigration_cli.migration_object_collection_group, databasemigration_cli.list_migration_objects, "list") -# -# -# # oci database-migration migration-object-collection -> oci database-migration migration-objects -# cli_util.rename_command(databasemigration_cli, databasemigration_cli.database_migration_root_group, databasemigration_cli.migration_object_collection_group, "migration-objects") + + +# oci database-migration connection create --tls-keystore-file --tls-wallet-file --ssh-details.sshkeyFile +@cli_util.copy_params_from_generated_command(databasemigration_cli.create_connection, params_to_exclude=['manual_database_sub_type']) +@databasemigration_cli.connection_group.command(name='create', help=databasemigration_cli.create_connection.help) +@cli_util.option('--db-subtype', type=custom_types.CliCaseInsensitiveChoice(["ORACLE", "RDS_ORACLE"]), help="""Database manual connection subtype. This value can only be specified for manual connections.""") +@cli_util.option('--tls-wallet-file', type=click.File('r'), help=u"""cwallet.sso fle path containing containing the TCPS/SSL certificate; base64 encoded String. Not required for source container database connections.""") +@cli_util.option('--tls-keystore-file', type=click.File('r'), help=u"""keystore.jks file path; base64 encoded String content. Requires a TLS wallet to be specified. Not required for source container database connections.""") +@cli_util.option('--sshkey-file', type=click.File('r'), help=u""" Private ssh key file.""") +@click.pass_context +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'connect-descriptor': {'module': 'database_migration', 'class': 'CreateConnectDescriptor'}, 'ssh-details': {'module': 'database_migration', 'class': 'CreateSshDetails'}, 'admin-credentials': {'module': 'database_migration', 'class': 'CreateAdminCredentials'}, 'private-endpoint': {'module': 'database_migration', 'class': 'CreatePrivateEndpoint'}, 'vault-details': {'module': 'database_migration', 'class': 'CreateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}, output_type={'module': 'database_migration', 'class': 'Connection'}) +@cli_util.wrap_exceptions +def create_connection(ctx, **kwargs): + + if 'db_subtype' in kwargs: + kwargs['manual_database_sub_type'] = kwargs['db_subtype'] + kwargs.pop('db_subtype') + + # read --sshkey-file into ssh_details['sshkey'] + if 'sshkey_file' in kwargs and kwargs['sshkey_file'] is not None: + ssh_details = {} + if 'ssh_details' in kwargs and kwargs['ssh_details'] is not None: + if ssh_details.get('sshkey') and ssh_details['sshkey'] is not None: + raise cli_exceptions.RequiredValueNotInDefaultOrUserInputError('Cannot specify both --sshkey-file and sshDetails.sshkey.') + ssh_details = kwargs['ssh_details'] + sshkey_file = kwargs.get('sshkey_file') + if sshkey_file: + ssh_details['sshkey'] = sshkey_file.read() + kwargs['ssh_details'] = json.dumps(ssh_details) + kwargs.pop('sshkey_file') + + # create_connection read --tls-wallet using --tls-wallet-file + if kwargs.get('tls_wallet') and kwargs.get('tls_wallet_file'): + raise cli_exceptions.RequiredValueNotInDefaultOrUserInputError('Cannot specify both --tls-wallet and --tls-wallet-file.') + + tls_wallet_file = kwargs.get('tls_wallet_file') + if tls_wallet_file: + kwargs['tls_wallet'] = tls_wallet_file.read() + + kwargs.pop('tls_wallet_file') + + # create_connection read --tls-keystore using --tls-keystore-file + if kwargs.get('tls_keystore') and kwargs.get('tls_keystore_file'): + raise cli_exceptions.RequiredValueNotInDefaultOrUserInputError('Cannot specify both --tls-keystore or --tls-keystore-file.') + + tls_keystore_file = kwargs.get('tls_keystore_file') + if tls_keystore_file: + kwargs['tls_keystore'] = tls_keystore_file.read() + + kwargs.pop('tls_keystore_file') + + ctx.invoke(databasemigration_cli.create_connection, **kwargs) + + +# oci database-migration connection update --tls-keystore-file --tls-wallet-file --ssh-details.sshkeyFile +@cli_util.copy_params_from_generated_command(databasemigration_cli.update_connection, params_to_exclude=[]) +@databasemigration_cli.connection_group.command(name='update', help=databasemigration_cli.update_connection.help) +@cli_util.option('--tls-wallet-file', type=click.File('r'), help=u"""cwallet.sso file path containing containing the TCPS/SSL certificate; base64 encoded String. Not required for source container database connections.""") +@cli_util.option('--tls-keystore-file', type=click.File('r'), help=u"""keystore.jks file path; base64 encoded String contents. Requires a TLS wallet to be specified. Not required for source container database connections.""") +@cli_util.option('--sshkey-file', type=click.File('r'), help=u""" Private ssh key file.""") +@click.pass_context +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'connect-descriptor': {'module': 'database_migration', 'class': 'UpdateConnectDescriptor'}, 'ssh-details': {'module': 'database_migration', 'class': 'UpdateSshDetails'}, 'admin-credentials': {'module': 'database_migration', 'class': 'UpdateAdminCredentials'}, 'private-endpoint': {'module': 'database_migration', 'class': 'UpdatePrivateEndpoint'}, 'vault-details': {'module': 'database_migration', 'class': 'UpdateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}) +@cli_util.wrap_exceptions +def update_connection(ctx, **kwargs): + # read --sshkey-file into ssh_details['sshkey'] + if 'sshkey_file' in kwargs and kwargs['sshkey_file'] is not None: + ssh_details = {} + if 'ssh_details' in kwargs and kwargs['ssh_details'] is not None: + if ssh_details.get('sshkey') and ssh_details['sshkey'] is not None: + raise cli_exceptions.RequiredValueNotInDefaultOrUserInputError('Cannot specify both --sshkey-file and sshDetails.sshkey.') + ssh_details = kwargs['ssh_details'] + sshkey_file = kwargs.get('sshkey_file') + if sshkey_file: + ssh_details['sshkey'] = sshkey_file.read() + kwargs['ssh_details'] = json.dumps(ssh_details) + kwargs.pop('sshkey_file') + + # update_connection read --tls-wallet using --tls-wallet-file + if kwargs.get('tls_wallet') and kwargs.get('tls_wallet_file'): + raise cli_exceptions.RequiredValueNotInDefaultOrUserInputError('Cannot specify both --tls-wallet or --tls-wallet-file.') + + tls_wallet_file = kwargs.get('tls_wallet_file') + if tls_wallet_file: + kwargs['tls_wallet'] = tls_wallet_file.read() + + kwargs.pop('tls_wallet_file') + + # update_connection read --tls-keystore using --tls-keystore-file + if kwargs.get('tls_keystore') and kwargs.get('tls_keystore_file'): + raise cli_exceptions.RequiredValueNotInDefaultOrUserInputError('Cannot specify both --tls-keystore or --tls-keystore-file.') + + tls_keystore_file = kwargs.get('tls_keystore_file') + if tls_keystore_file: + kwargs['tls_keystore'] = tls_keystore_file.read() + + kwargs.pop('tls_keystore_file') + + ctx.invoke(databasemigration_cli.update_connection, **kwargs) + + +# @cli_util.copy_params_from_generated_command(databasemigration_cli.create_agent, params_to_exclude=['version_parameterconflict']) +# @databasemigration_cli.agent_group.command(name=databasemigration_cli.create_agent.name, help=databasemigration_cli.create_agent.help) +@cli_util.option('--agent-version', required=True, help=u"""ODMS Agent version [required]""") +@click.pass_context +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}, output_type={'module': 'database_migration', 'class': 'Agent'}) +@cli_util.wrap_exceptions +def create_agent_extended(ctx, **kwargs): + if 'agent_version' in kwargs: + kwargs['version_parameterconflict'] = kwargs['agent_version'] + kwargs.pop('agent_version') + + ctx.invoke(databasemigration_cli.create_agent, **kwargs) + + +# oci database-migration migration-object-type-summary list-migration-object-types -> oci database-migration migration-object-type-summary list +cli_util.rename_command(databasemigration_cli, databasemigration_cli.migration_object_type_summary_group, databasemigration_cli.list_migration_object_types, "list") + +# oci database-migration excluded-object-summary list-excluded-objects -> oci database-migration excluded-object-summary list +cli_util.rename_command(databasemigration_cli, databasemigration_cli.excluded_object_summary_group, databasemigration_cli.list_excluded_objects, "list") + + +# oci database-migration migration-object-collection list-migration-objects -> oci database-migration migration-object-collection list +cli_util.rename_command(databasemigration_cli, databasemigration_cli.migration_object_collection_group, databasemigration_cli.list_migration_objects, "list") + + +# oci database-migration migration-object-collection -> oci database-migration migration-objects +cli_util.rename_command(databasemigration_cli, databasemigration_cli.database_migration_root_group, databasemigration_cli.migration_object_collection_group, "migration-objects") + + +# oci database-migration connection create-connection-create-mysql-connection-details -> oci database-migration connection create-mysql-connection +cli_util.rename_command(databasemigration_cli, databasemigration_cli.connection_group, databasemigration_cli.create_connection_create_mysql_connection_details, "create-mysql-connection") + + +# oci database-migration connection create-connection-create-oracle-connection-details -> oci database-migration connection create-oracle-connection +cli_util.rename_command(databasemigration_cli, databasemigration_cli.connection_group, databasemigration_cli.create_connection_create_oracle_connection_details, "create-oracle-connection") + + +# oci database-migration connection update-connection-update-mysql-connection-details -> oci database-migration connection update-mysql-connection +cli_util.rename_command(databasemigration_cli, databasemigration_cli.connection_group, databasemigration_cli.update_connection_update_mysql_connection_details, "update-mysql-connection") + + +# oci database-migration connection update-connection-update-oracle-connection-details -> oci database-migration connection update-oracle-connection +cli_util.rename_command(databasemigration_cli, databasemigration_cli.connection_group, databasemigration_cli.update_connection_update_oracle_connection_details, "update-oracle-connection") + + +# oci database-migration migration add-migration-objects-my-sql-migration-object-collection -> oci database-migration migration add-mysql-objects +cli_util.rename_command(databasemigration_cli, databasemigration_cli.migration_group, databasemigration_cli.add_migration_objects_my_sql_migration_object_collection, "add-mysql-objects") + + +# oci database-migration migration add-migration-objects-oracle-migration-object-collection -> oci database-migration migration add-oracle-objects +cli_util.rename_command(databasemigration_cli, databasemigration_cli.migration_group, databasemigration_cli.add_migration_objects_oracle_migration_object_collection, "add-oracle-objects") + + +# oci database-migration migration clone-migration-my-sql-clone-migration-details -> oci database-migration migration clone-mysql-migration +cli_util.rename_command(databasemigration_cli, databasemigration_cli.migration_group, databasemigration_cli.clone_migration_my_sql_clone_migration_details, "clone-mysql-migration") + + +# oci database-migration migration clone-migration-oracle-clone-migration-details -> oci database-migration migration clone-oracle-migration +cli_util.rename_command(databasemigration_cli, databasemigration_cli.migration_group, databasemigration_cli.clone_migration_oracle_clone_migration_details, "clone-oracle-migration") + + +# oci database-migration migration create-migration-create-my-sql-migration-details -> oci database-migration migration create-mysql-migration +cli_util.rename_command(databasemigration_cli, databasemigration_cli.migration_group, databasemigration_cli.create_migration_create_my_sql_migration_details, "create-mysql-migration") + + +# oci database-migration migration create-migration-create-oracle-migration-details -> oci database-migration migration create-oracle-migration +cli_util.rename_command(databasemigration_cli, databasemigration_cli.migration_group, databasemigration_cli.create_migration_create_oracle_migration_details, "create-oracle-migration") + + +# oci database-migration migration remove-migration-objects-my-sql-migration-object-collection -> oci database-migration migration remove-mysql-objects +cli_util.rename_command(databasemigration_cli, databasemigration_cli.migration_group, databasemigration_cli.remove_migration_objects_my_sql_migration_object_collection, "remove-mysql-objects") + + +# oci database-migration migration remove-migration-objects-oracle-migration-object-collection -> oci database-migration migration remove-oracle-objects +cli_util.rename_command(databasemigration_cli, databasemigration_cli.migration_group, databasemigration_cli.remove_migration_objects_oracle_migration_object_collection, "remove-oracle-objects") + + +# oci database-migration migration update-migration-update-my-sql-migration-details -> oci database-migration migration update-mysql-migration +cli_util.rename_command(databasemigration_cli, databasemigration_cli.migration_group, databasemigration_cli.update_migration_update_my_sql_migration_details, "update-mysql-migration") + + +# oci database-migration migration update-migration-update-oracle-migration-details -> oci database-migration migration update-oracle-migration +cli_util.rename_command(databasemigration_cli, databasemigration_cli.migration_group, databasemigration_cli.update_migration_update_oracle_migration_details, "update-oracle-migration") + + +# Remove add from oci database-migration migration +databasemigration_cli.migration_group.commands.pop(databasemigration_cli.add_migration_objects.name) + + +# Remove clone from oci database-migration migration +databasemigration_cli.migration_group.commands.pop(databasemigration_cli.clone_migration.name) + + +# Remove create from oci database-migration migration +databasemigration_cli.migration_group.commands.pop(databasemigration_cli.create_migration.name) + + +# Remove remove from oci database-migration migration +databasemigration_cli.migration_group.commands.pop(databasemigration_cli.remove_migration_objects.name) + + +# Remove update from oci database-migration migration +databasemigration_cli.migration_group.commands.pop(databasemigration_cli.update_migration.name) + + +# Remove list from oci database-migration migration-object-type-summary +databasemigration_cli.migration_object_type_summary_group.commands.pop(databasemigration_cli.list_migration_object_types.name) + +# Remove create from oci database-migration connection +databasemigration_cli.connection_group.commands.pop(databasemigration_cli.create_connection.name) + +# Remove update from oci database-migration connection +databasemigration_cli.connection_group.commands.pop(databasemigration_cli.update_connection.name) diff --git a/services/database_migration/src/oci_cli_database_migration/generated/__init__.py b/services/database_migration/src/oci_cli_database_migration/generated/__init__.py index fe8fd3394..cd62a3ee1 100644 --- a/services/database_migration/src/oci_cli_database_migration/generated/__init__.py +++ b/services/database_migration/src/oci_cli_database_migration/generated/__init__.py @@ -1,4 +1,4 @@ # coding: utf-8 # Copyright (c) 2016, 2024, Oracle and/or its affiliates. All rights reserved. # This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license. -# NOTE: This class is auto generated by OracleSDKGenerator. DO NOT EDIT. API Version: 20210929 +# NOTE: This class is auto generated by OracleSDKGenerator. DO NOT EDIT. API Version: 20230518 diff --git a/services/database_migration/src/oci_cli_database_migration/generated/client_mappings.py b/services/database_migration/src/oci_cli_database_migration/generated/client_mappings.py index 35a4ff006..f64e16b67 100644 --- a/services/database_migration/src/oci_cli_database_migration/generated/client_mappings.py +++ b/services/database_migration/src/oci_cli_database_migration/generated/client_mappings.py @@ -1,7 +1,7 @@ # coding: utf-8 # Copyright (c) 2016, 2024, Oracle and/or its affiliates. All rights reserved. # This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license. -# NOTE: This class is auto generated by OracleSDKGenerator. DO NOT EDIT. API Version: 20210929 +# NOTE: This class is auto generated by OracleSDKGenerator. DO NOT EDIT. API Version: 20230518 import oci from oci_cli.cli_clients import CLIENT_MAP diff --git a/services/database_migration/src/oci_cli_database_migration/generated/databasemigration_cli.py b/services/database_migration/src/oci_cli_database_migration/generated/databasemigration_cli.py index e14d33cc0..511d52010 100644 --- a/services/database_migration/src/oci_cli_database_migration/generated/databasemigration_cli.py +++ b/services/database_migration/src/oci_cli_database_migration/generated/databasemigration_cli.py @@ -1,7 +1,7 @@ # coding: utf-8 # Copyright (c) 2016, 2024, Oracle and/or its affiliates. All rights reserved. # This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license. -# NOTE: This class is auto generated by OracleSDKGenerator. DO NOT EDIT. API Version: 20210929 +# NOTE: This class is auto generated by OracleSDKGenerator. DO NOT EDIT. API Version: 20230518 from __future__ import print_function import click @@ -22,19 +22,13 @@ def database_migration_root_group(): pass -@click.command(cli_util.override('database_migration.agent_group.command_name', 'agent'), cls=CommandGroupWithAlias, help="""ODMS Agent Details""") -@cli_util.help_option_group -def agent_group(): - pass - - @click.command(cli_util.override('database_migration.work_request_summary_group.command_name', 'work-request-summary'), cls=CommandGroupWithAlias, help="""A summary of the status of a work request.""") @cli_util.help_option_group def work_request_summary_group(): pass -@click.command(cli_util.override('database_migration.migration_object_collection_group.command_name', 'migration-object-collection'), cls=CommandGroupWithAlias, help="""Database objects to migrate.""") +@click.command(cli_util.override('database_migration.migration_object_collection_group.command_name', 'migration-object-collection'), cls=CommandGroupWithAlias, help="""Common Migration Objects collection.""") @cli_util.help_option_group def migration_object_collection_group(): pass @@ -58,25 +52,13 @@ def work_request_group(): pass -@click.command(cli_util.override('database_migration.agent_summary_group.command_name', 'agent-summary'), cls=CommandGroupWithAlias, help="""ODMS Agent Details""") -@cli_util.help_option_group -def agent_summary_group(): - pass - - @click.command(cli_util.override('database_migration.migration_summary_group.command_name', 'migration-summary'), cls=CommandGroupWithAlias, help="""Migration resource""") @cli_util.help_option_group def migration_summary_group(): pass -@click.command(cli_util.override('database_migration.agent_image_summary_group.command_name', 'agent-image-summary'), cls=CommandGroupWithAlias, help="""Available ODMS Agent Images.""") -@cli_util.help_option_group -def agent_image_summary_group(): - pass - - -@click.command(cli_util.override('database_migration.connection_summary_group.command_name', 'connection-summary'), cls=CommandGroupWithAlias, help="""Database Connection Summary.""") +@click.command(cli_util.override('database_migration.connection_summary_group.command_name', 'connection-summary'), cls=CommandGroupWithAlias, help="""Represents the parameters common for all connections in list operation.""") @cli_util.help_option_group def connection_summary_group(): pass @@ -106,7 +88,7 @@ def migration_group(): pass -@click.command(cli_util.override('database_migration.connection_group.command_name', 'connection'), cls=CommandGroupWithAlias, help="""Database Connection resource used for migrations.""") +@click.command(cli_util.override('database_migration.connection_group.command_name', 'connection'), cls=CommandGroupWithAlias, help="""Represents the common details required for creating a new connection.""") @cli_util.help_option_group def connection_group(): pass @@ -124,15 +106,12 @@ def job_output_summary_group(): pass -database_migration_root_group.add_command(agent_group) database_migration_root_group.add_command(work_request_summary_group) database_migration_root_group.add_command(migration_object_collection_group) database_migration_root_group.add_command(work_request_log_entry_group) database_migration_root_group.add_command(excluded_object_summary_group) database_migration_root_group.add_command(work_request_group) -database_migration_root_group.add_command(agent_summary_group) database_migration_root_group.add_command(migration_summary_group) -database_migration_root_group.add_command(agent_image_summary_group) database_migration_root_group.add_command(connection_summary_group) database_migration_root_group.add_command(job_summary_group) database_migration_root_group.add_command(migration_object_type_summary_group) @@ -196,15 +175,46 @@ def abort_job(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_se @migration_group.command(name=cli_util.override('database_migration.add_migration_objects.command_name', 'add'), help=u"""Add excluded/included object to the list. \n[Command Reference](addMigrationObjects)""") @cli_util.option('--migration-id', required=True, help=u"""The OCID of the migration""") -@cli_util.option('--items', required=True, type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to exclude/include from migration""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--csv-text', help=u"""Database objects to exclude/include from migration in CSV format. The items field will be ignored if this field is not null.""") +@cli_util.option('--database-combination', required=True, type=custom_types.CliCaseInsensitiveChoice(["MYSQL", "ORACLE"]), help=u"""The combination of source and target databases participating in a migration. Example: ORACLE means the migration is meant for migrating Oracle source and target databases.""") +@cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") +@json_skeleton_utils.get_cli_json_input_option({}) +@cli_util.help_option +@click.pass_context +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={}) +@cli_util.wrap_exceptions +def add_migration_objects(ctx, from_json, migration_id, database_combination, if_match): + + if isinstance(migration_id, six.string_types) and len(migration_id.strip()) == 0: + raise click.UsageError('Parameter --migration-id cannot be whitespace or empty string') + + kwargs = {} + if if_match is not None: + kwargs['if_match'] = if_match + kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) + + _details = {} + _details['databaseCombination'] = database_combination + + client = cli_util.build_client('database_migration', 'database_migration', ctx) + result = client.add_migration_objects( + migration_id=migration_id, + add_migration_objects_details=_details, + **kwargs + ) + cli_util.render_response(result, ctx) + + +@migration_group.command(name=cli_util.override('database_migration.add_migration_objects_my_sql_migration_object_collection.command_name', 'add-migration-objects-my-sql-migration-object-collection'), help=u"""Add excluded/included object to the list. \n[Command Reference](addMigrationObjects)""") +@cli_util.option('--migration-id', required=True, help=u"""The OCID of the migration""") +@cli_util.option('--items', required=True, type=custom_types.CLI_COMPLEX_TYPE, help=u"""An array of database objects that are either included or excluded from the migration.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--bulk-include-exclude-data', help=u"""Specifies the database objects to be excluded from the migration in bulk. The definition accepts input in a CSV format, newline separated for each entry. More details can be found in the documentation.""") @cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") -@json_skeleton_utils.get_cli_json_input_option({'items': {'module': 'database_migration', 'class': 'list[MigrationObjectSummary]'}}) +@json_skeleton_utils.get_cli_json_input_option({'items': {'module': 'database_migration', 'class': 'list[MySqlDatabaseObjectSummary]'}}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'items': {'module': 'database_migration', 'class': 'list[MigrationObjectSummary]'}}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'items': {'module': 'database_migration', 'class': 'list[MySqlDatabaseObjectSummary]'}}) @cli_util.wrap_exceptions -def add_migration_objects(ctx, from_json, migration_id, items, csv_text, if_match): +def add_migration_objects_my_sql_migration_object_collection(ctx, from_json, migration_id, items, bulk_include_exclude_data, if_match): if isinstance(migration_id, six.string_types) and len(migration_id.strip()) == 0: raise click.UsageError('Parameter --migration-id cannot be whitespace or empty string') @@ -217,8 +227,10 @@ def add_migration_objects(ctx, from_json, migration_id, items, csv_text, if_matc _details = {} _details['items'] = cli_util.parse_json_parameter("items", items) - if csv_text is not None: - _details['csvText'] = csv_text + if bulk_include_exclude_data is not None: + _details['bulkIncludeExcludeData'] = bulk_include_exclude_data + + _details['databaseCombination'] = 'MYSQL' client = cli_util.build_client('database_migration', 'database_migration', ctx) result = client.add_migration_objects( @@ -229,19 +241,20 @@ def add_migration_objects(ctx, from_json, migration_id, items, csv_text, if_matc cli_util.render_response(result, ctx) -@agent_group.command(name=cli_util.override('database_migration.change_agent_compartment.command_name', 'change-compartment'), help=u"""Used to configure an ODMS Agent Compartment ID. \n[Command Reference](changeAgentCompartment)""") -@cli_util.option('--agent-id', required=True, help=u"""The OCID of the agent""") -@cli_util.option('--compartment-id', required=True, help=u"""The OCID of the compartment to move the resource to.""") +@migration_group.command(name=cli_util.override('database_migration.add_migration_objects_oracle_migration_object_collection.command_name', 'add-migration-objects-oracle-migration-object-collection'), help=u"""Add excluded/included object to the list. \n[Command Reference](addMigrationObjects)""") +@cli_util.option('--migration-id', required=True, help=u"""The OCID of the migration""") +@cli_util.option('--items', required=True, type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to exclude/include from migration""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--bulk-include-exclude-data', help=u"""Specifies the database objects to be excluded from the migration in bulk. The definition accepts input in a CSV format, newline separated for each entry. More details can be found in the documentation.""") @cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") -@json_skeleton_utils.get_cli_json_input_option({}) +@json_skeleton_utils.get_cli_json_input_option({'items': {'module': 'database_migration', 'class': 'list[OracleDatabaseObjectSummary]'}}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'items': {'module': 'database_migration', 'class': 'list[OracleDatabaseObjectSummary]'}}) @cli_util.wrap_exceptions -def change_agent_compartment(ctx, from_json, agent_id, compartment_id, if_match): +def add_migration_objects_oracle_migration_object_collection(ctx, from_json, migration_id, items, bulk_include_exclude_data, if_match): - if isinstance(agent_id, six.string_types) and len(agent_id.strip()) == 0: - raise click.UsageError('Parameter --agent-id cannot be whitespace or empty string') + if isinstance(migration_id, six.string_types) and len(migration_id.strip()) == 0: + raise click.UsageError('Parameter --migration-id cannot be whitespace or empty string') kwargs = {} if if_match is not None: @@ -249,20 +262,25 @@ def change_agent_compartment(ctx, from_json, agent_id, compartment_id, if_match) kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) _details = {} - _details['compartmentId'] = compartment_id + _details['items'] = cli_util.parse_json_parameter("items", items) + + if bulk_include_exclude_data is not None: + _details['bulkIncludeExcludeData'] = bulk_include_exclude_data + + _details['databaseCombination'] = 'ORACLE' client = cli_util.build_client('database_migration', 'database_migration', ctx) - result = client.change_agent_compartment( - agent_id=agent_id, - change_agent_compartment_details=_details, + result = client.add_migration_objects( + migration_id=migration_id, + add_migration_objects_details=_details, **kwargs ) cli_util.render_response(result, ctx) @connection_group.command(name=cli_util.override('database_migration.change_connection_compartment.command_name', 'change-compartment'), help=u"""Used to change the Database Connection compartment. \n[Command Reference](changeConnectionCompartment)""") -@cli_util.option('--connection-id', required=True, help=u"""The OCID of the database connection""") -@cli_util.option('--compartment-id', required=True, help=u"""The OCID of the compartment to move the resource to.""") +@cli_util.option('--connection-id', required=True, help=u"""The OCID of the database connection.""") +@cli_util.option('--compartment-id', required=True, help=u"""The OCID of the compartment.""") @cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") @json_skeleton_utils.get_cli_json_input_option({}) @cli_util.help_option @@ -293,7 +311,7 @@ def change_connection_compartment(ctx, from_json, connection_id, compartment_id, @migration_group.command(name=cli_util.override('database_migration.change_migration_compartment.command_name', 'change-compartment'), help=u"""Used to change the Migration compartment. \n[Command Reference](changeMigrationCompartment)""") @cli_util.option('--migration-id', required=True, help=u"""The OCID of the migration""") -@cli_util.option('--compartment-id', required=True, help=u"""The OCID of the compartment to move the resource to.""") +@cli_util.option('--compartment-id', required=True, help=u"""The OCID of the resource being referenced.""") @cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") @json_skeleton_utils.get_cli_json_input_option({}) @cli_util.help_option @@ -324,31 +342,23 @@ def change_migration_compartment(ctx, from_json, migration_id, compartment_id, i @migration_group.command(name=cli_util.override('database_migration.clone_migration.command_name', 'clone'), help=u"""Clone a configuration from an existing Migration. \n[Command Reference](cloneMigration)""") @cli_util.option('--migration-id', required=True, help=u"""The OCID of the migration""") -@cli_util.option('--source-database-connection-id', required=True, help=u"""The OCID of the Source Database Connection.""") -@cli_util.option('--target-database-connection-id', required=True, help=u"""The OCID of the Target Database Connection.""") -@cli_util.option('--display-name', help=u"""Migration Display Name""") -@cli_util.option('--compartment-id', help=u"""OCID of the compartment""") -@cli_util.option('--agent-id', help=u"""The OCID of the registered on-premises ODMS Agent. Only valid for Offline Logical Migrations.""") -@cli_util.option('--source-container-database-connection-id', help=u"""The OCID of the Source Container Database Connection. Only used for Online migrations. Only Connections of type Non-Autonomous can be used as source container databases.""") -@cli_util.option('--exclude-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to exclude from migration, cannot be specified alongside 'includeObjects' - -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--include-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to include from migration, cannot be specified alongside 'excludeObjects' - -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--vault-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only. Example: `{\"bar-key\": \"value\"}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--database-combination', required=True, type=custom_types.CliCaseInsensitiveChoice(["MYSQL", "ORACLE"]), help=u"""The combination of source and target databases participating in a migration. Example: ORACLE means the migration is meant for migrating Oracle source and target databases.""") +@cli_util.option('--source-database-connection-id', required=True, help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--target-database-connection-id', required=True, help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--display-name', help=u"""A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--compartment-id', help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {\"Department\": \"Finance\"}""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") @cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") @cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") @cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") -@json_skeleton_utils.get_cli_json_input_option({'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'vault-details': {'module': 'database_migration', 'class': 'CreateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}) +@json_skeleton_utils.get_cli_json_input_option({'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'vault-details': {'module': 'database_migration', 'class': 'CreateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}, output_type={'module': 'database_migration', 'class': 'Migration'}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}, output_type={'module': 'database_migration', 'class': 'Migration'}) @cli_util.wrap_exceptions -def clone_migration(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_seconds, migration_id, source_database_connection_id, target_database_connection_id, display_name, compartment_id, agent_id, source_container_database_connection_id, exclude_objects, include_objects, vault_details, freeform_tags, defined_tags, if_match): +def clone_migration(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_seconds, migration_id, database_combination, source_database_connection_id, target_database_connection_id, display_name, compartment_id, freeform_tags, defined_tags, if_match): if isinstance(migration_id, six.string_types) and len(migration_id.strip()) == 0: raise click.UsageError('Parameter --migration-id cannot be whitespace or empty string') @@ -359,6 +369,7 @@ def clone_migration(ctx, from_json, wait_for_state, max_wait_seconds, wait_inter kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) _details = {} + _details['databaseCombination'] = database_combination _details['sourceDatabaseConnectionId'] = source_database_connection_id _details['targetDatabaseConnectionId'] = target_database_connection_id @@ -368,21 +379,6 @@ def clone_migration(ctx, from_json, wait_for_state, max_wait_seconds, wait_inter if compartment_id is not None: _details['compartmentId'] = compartment_id - if agent_id is not None: - _details['agentId'] = agent_id - - if source_container_database_connection_id is not None: - _details['sourceContainerDatabaseConnectionId'] = source_container_database_connection_id - - if exclude_objects is not None: - _details['excludeObjects'] = cli_util.parse_json_parameter("exclude_objects", exclude_objects) - - if include_objects is not None: - _details['includeObjects'] = cli_util.parse_json_parameter("include_objects", include_objects) - - if vault_details is not None: - _details['vaultDetails'] = cli_util.parse_json_parameter("vault_details", vault_details) - if freeform_tags is not None: _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) @@ -425,97 +421,43 @@ def clone_migration(ctx, from_json, wait_for_state, max_wait_seconds, wait_inter cli_util.render_response(result, ctx) -@connection_group.command(name=cli_util.override('database_migration.connection_diagnostics.command_name', 'connection-diagnostics'), help=u"""Perform connection test for a database connection. \n[Command Reference](connectionDiagnostics)""") -@cli_util.option('--connection-id', required=True, help=u"""The OCID of the database connection""") -@cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") -@json_skeleton_utils.get_cli_json_input_option({}) -@cli_util.help_option -@click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={}, output_type={'module': 'database_migration', 'class': 'DiagnosticsResult'}) -@cli_util.wrap_exceptions -def connection_diagnostics(ctx, from_json, connection_id, if_match): - - if isinstance(connection_id, six.string_types) and len(connection_id.strip()) == 0: - raise click.UsageError('Parameter --connection-id cannot be whitespace or empty string') - - kwargs = {} - if if_match is not None: - kwargs['if_match'] = if_match - kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) - client = cli_util.build_client('database_migration', 'database_migration', ctx) - result = client.connection_diagnostics( - connection_id=connection_id, - **kwargs - ) - cli_util.render_response(result, ctx) - - -@connection_group.command(name=cli_util.override('database_migration.create_connection.command_name', 'create'), help=u"""Create a Database Connection resource that contains the details to connect to either a Source or Target Database in the migration. \n[Command Reference](createConnection)""") -@cli_util.option('--compartment-id', required=True, help=u"""OCID of the compartment""") -@cli_util.option('--database-type', required=True, type=custom_types.CliCaseInsensitiveChoice(["MANUAL", "AUTONOMOUS", "USER_MANAGED_OCI"]), help=u"""Database connection type.""") -@cli_util.option('--admin-credentials', required=True, type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--vault-details', required=True, type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--display-name', help=u"""Database Connection display name identifier.""") -@cli_util.option('--manual-database-sub-type', type=custom_types.CliCaseInsensitiveChoice(["ORACLE", "RDS_ORACLE"]), help=u"""Database manual connection subtype. This value can only be specified for manual connections.""") -@cli_util.option('--database-id', help=u"""The OCID of the cloud database. Required if the database connection type is Autonomous.""") -@cli_util.option('--connect-descriptor', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--certificate-tdn', help=u"""This name is the distinguished name used while creating the certificate on target database. Requires a TLS wallet to be specified. Not required for source container database connections.""") -@cli_util.option('--tls-wallet', help=u"""cwallet.sso containing containing the TCPS/SSL certificate; base64 encoded String. Not required for source container database connections.""") -@cli_util.option('--tls-keystore', help=u"""keystore.jks file contents; base64 encoded String. Requires a TLS wallet to be specified. Not required for source container database connections.""") -@cli_util.option('--ssh-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--replication-credentials', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--private-endpoint', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only. Example: `{\"bar-key\": \"value\"}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@migration_group.command(name=cli_util.override('database_migration.clone_migration_oracle_clone_migration_details.command_name', 'clone-migration-oracle-clone-migration-details'), help=u"""Clone a configuration from an existing Migration. \n[Command Reference](cloneMigration)""") +@cli_util.option('--migration-id', required=True, help=u"""The OCID of the migration""") +@cli_util.option('--source-database-connection-id', required=True, help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--target-database-connection-id', required=True, help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--display-name', help=u"""A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--compartment-id', help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {\"Department\": \"Finance\"}""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--nsg-ids', type=custom_types.CLI_COMPLEX_TYPE, help=u"""An array of Network Security Group OCIDs used to define network access for Connections.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--source-container-database-connection-id', help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") @cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") @cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") @cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") -@json_skeleton_utils.get_cli_json_input_option({'connect-descriptor': {'module': 'database_migration', 'class': 'CreateConnectDescriptor'}, 'ssh-details': {'module': 'database_migration', 'class': 'CreateSshDetails'}, 'admin-credentials': {'module': 'database_migration', 'class': 'CreateAdminCredentials'}, 'replication-credentials': {'module': 'database_migration', 'class': 'CreateAdminCredentials'}, 'private-endpoint': {'module': 'database_migration', 'class': 'CreatePrivateEndpoint'}, 'vault-details': {'module': 'database_migration', 'class': 'CreateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'nsg-ids': {'module': 'database_migration', 'class': 'list[string]'}}) +@json_skeleton_utils.get_cli_json_input_option({'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'connect-descriptor': {'module': 'database_migration', 'class': 'CreateConnectDescriptor'}, 'ssh-details': {'module': 'database_migration', 'class': 'CreateSshDetails'}, 'admin-credentials': {'module': 'database_migration', 'class': 'CreateAdminCredentials'}, 'replication-credentials': {'module': 'database_migration', 'class': 'CreateAdminCredentials'}, 'private-endpoint': {'module': 'database_migration', 'class': 'CreatePrivateEndpoint'}, 'vault-details': {'module': 'database_migration', 'class': 'CreateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'nsg-ids': {'module': 'database_migration', 'class': 'list[string]'}}, output_type={'module': 'database_migration', 'class': 'Connection'}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}, output_type={'module': 'database_migration', 'class': 'Migration'}) @cli_util.wrap_exceptions -def create_connection(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_seconds, compartment_id, database_type, admin_credentials, vault_details, display_name, manual_database_sub_type, database_id, connect_descriptor, certificate_tdn, tls_wallet, tls_keystore, ssh_details, replication_credentials, private_endpoint, freeform_tags, defined_tags, nsg_ids): +def clone_migration_oracle_clone_migration_details(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_seconds, migration_id, source_database_connection_id, target_database_connection_id, display_name, compartment_id, freeform_tags, defined_tags, source_container_database_connection_id, if_match): + + if isinstance(migration_id, six.string_types) and len(migration_id.strip()) == 0: + raise click.UsageError('Parameter --migration-id cannot be whitespace or empty string') kwargs = {} + if if_match is not None: + kwargs['if_match'] = if_match kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) _details = {} - _details['compartmentId'] = compartment_id - _details['databaseType'] = database_type - _details['adminCredentials'] = cli_util.parse_json_parameter("admin_credentials", admin_credentials) - _details['vaultDetails'] = cli_util.parse_json_parameter("vault_details", vault_details) + _details['sourceDatabaseConnectionId'] = source_database_connection_id + _details['targetDatabaseConnectionId'] = target_database_connection_id if display_name is not None: _details['displayName'] = display_name - if manual_database_sub_type is not None: - _details['manualDatabaseSubType'] = manual_database_sub_type - - if database_id is not None: - _details['databaseId'] = database_id - - if connect_descriptor is not None: - _details['connectDescriptor'] = cli_util.parse_json_parameter("connect_descriptor", connect_descriptor) - - if certificate_tdn is not None: - _details['certificateTdn'] = certificate_tdn - - if tls_wallet is not None: - _details['tlsWallet'] = tls_wallet - - if tls_keystore is not None: - _details['tlsKeystore'] = tls_keystore - - if ssh_details is not None: - _details['sshDetails'] = cli_util.parse_json_parameter("ssh_details", ssh_details) - - if replication_credentials is not None: - _details['replicationCredentials'] = cli_util.parse_json_parameter("replication_credentials", replication_credentials) - - if private_endpoint is not None: - _details['privateEndpoint'] = cli_util.parse_json_parameter("private_endpoint", private_endpoint) + if compartment_id is not None: + _details['compartmentId'] = compartment_id if freeform_tags is not None: _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) @@ -523,12 +465,15 @@ def create_connection(ctx, from_json, wait_for_state, max_wait_seconds, wait_int if defined_tags is not None: _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) - if nsg_ids is not None: - _details['nsgIds'] = cli_util.parse_json_parameter("nsg_ids", nsg_ids) + if source_container_database_connection_id is not None: + _details['sourceContainerDatabaseConnectionId'] = source_container_database_connection_id + + _details['databaseCombination'] = 'ORACLE' client = cli_util.build_client('database_migration', 'database_migration', ctx) - result = client.create_connection( - create_connection_details=_details, + result = client.clone_migration( + migration_id=migration_id, + clone_migration_details=_details, **kwargs ) if wait_for_state: @@ -561,91 +506,42 @@ def create_connection(ctx, from_json, wait_for_state, max_wait_seconds, wait_int cli_util.render_response(result, ctx) -@migration_group.command(name=cli_util.override('database_migration.create_migration.command_name', 'create'), help=u"""Create a Migration resource that contains all the details to perform the database migration operation, such as source and destination database details, credentials, etc. \n[Command Reference](createMigration)""") -@cli_util.option('--type', required=True, type=custom_types.CliCaseInsensitiveChoice(["ONLINE", "OFFLINE"]), help=u"""Migration type.""") -@cli_util.option('--compartment-id', required=True, help=u"""OCID of the compartment""") -@cli_util.option('--source-database-connection-id', required=True, help=u"""The OCID of the Source Database Connection.""") -@cli_util.option('--target-database-connection-id', required=True, help=u"""The OCID of the Target Database Connection.""") -@cli_util.option('--display-name', help=u"""Migration Display Name""") -@cli_util.option('--agent-id', help=u"""The OCID of the registered ODMS Agent. Only valid for Offline Logical Migrations.""") -@cli_util.option('--source-container-database-connection-id', help=u"""The OCID of the Source Container Database Connection. Only used for Online migrations. Only Connections of type Non-Autonomous can be used as source container databases.""") -@cli_util.option('--data-transfer-medium-details-v2', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--data-transfer-medium-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--dump-transfer-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--datapump-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--advisor-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--exclude-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to exclude from migration, cannot be specified alongside 'includeObjects' - -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--include-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to include from migration, cannot be specified alongside 'excludeObjects' - -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--csv-text', help=u"""Database objects to exclude/include from migration in CSV format. The excludeObjects and includeObjects fields will be ignored if this field is not null.""") -@cli_util.option('--golden-gate-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--golden-gate-service-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--vault-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only. Example: `{\"bar-key\": \"value\"}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@migration_group.command(name=cli_util.override('database_migration.clone_migration_my_sql_clone_migration_details.command_name', 'clone-migration-my-sql-clone-migration-details'), help=u"""Clone a configuration from an existing Migration. \n[Command Reference](cloneMigration)""") +@cli_util.option('--migration-id', required=True, help=u"""The OCID of the migration""") +@cli_util.option('--source-database-connection-id', required=True, help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--target-database-connection-id', required=True, help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--display-name', help=u"""A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--compartment-id', help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {\"Department\": \"Finance\"}""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") @cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") @cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") @cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") -@json_skeleton_utils.get_cli_json_input_option({'data-transfer-medium-details-v2': {'module': 'database_migration', 'class': 'DataTransferMediumDetailsV2'}, 'data-transfer-medium-details': {'module': 'database_migration', 'class': 'CreateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'CreateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'CreateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'CreateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'CreateGoldenGateDetails'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'CreateGoldenGateServiceDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'CreateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}) +@json_skeleton_utils.get_cli_json_input_option({'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'data-transfer-medium-details-v2': {'module': 'database_migration', 'class': 'DataTransferMediumDetailsV2'}, 'data-transfer-medium-details': {'module': 'database_migration', 'class': 'CreateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'CreateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'CreateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'CreateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'CreateGoldenGateDetails'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'CreateGoldenGateServiceDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'CreateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}, output_type={'module': 'database_migration', 'class': 'Migration'}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}, output_type={'module': 'database_migration', 'class': 'Migration'}) @cli_util.wrap_exceptions -def create_migration(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_seconds, type, compartment_id, source_database_connection_id, target_database_connection_id, display_name, agent_id, source_container_database_connection_id, data_transfer_medium_details_v2, data_transfer_medium_details, dump_transfer_details, datapump_settings, advisor_settings, exclude_objects, include_objects, csv_text, golden_gate_details, golden_gate_service_details, vault_details, freeform_tags, defined_tags): +def clone_migration_my_sql_clone_migration_details(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_seconds, migration_id, source_database_connection_id, target_database_connection_id, display_name, compartment_id, freeform_tags, defined_tags, if_match): + + if isinstance(migration_id, six.string_types) and len(migration_id.strip()) == 0: + raise click.UsageError('Parameter --migration-id cannot be whitespace or empty string') kwargs = {} + if if_match is not None: + kwargs['if_match'] = if_match kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) _details = {} - _details['type'] = type - _details['compartmentId'] = compartment_id _details['sourceDatabaseConnectionId'] = source_database_connection_id _details['targetDatabaseConnectionId'] = target_database_connection_id if display_name is not None: _details['displayName'] = display_name - if agent_id is not None: - _details['agentId'] = agent_id - - if source_container_database_connection_id is not None: - _details['sourceContainerDatabaseConnectionId'] = source_container_database_connection_id - - if data_transfer_medium_details_v2 is not None: - _details['dataTransferMediumDetailsV2'] = cli_util.parse_json_parameter("data_transfer_medium_details_v2", data_transfer_medium_details_v2) - - if data_transfer_medium_details is not None: - _details['dataTransferMediumDetails'] = cli_util.parse_json_parameter("data_transfer_medium_details", data_transfer_medium_details) - - if dump_transfer_details is not None: - _details['dumpTransferDetails'] = cli_util.parse_json_parameter("dump_transfer_details", dump_transfer_details) - - if datapump_settings is not None: - _details['datapumpSettings'] = cli_util.parse_json_parameter("datapump_settings", datapump_settings) - - if advisor_settings is not None: - _details['advisorSettings'] = cli_util.parse_json_parameter("advisor_settings", advisor_settings) - - if exclude_objects is not None: - _details['excludeObjects'] = cli_util.parse_json_parameter("exclude_objects", exclude_objects) - - if include_objects is not None: - _details['includeObjects'] = cli_util.parse_json_parameter("include_objects", include_objects) - - if csv_text is not None: - _details['csvText'] = csv_text - - if golden_gate_details is not None: - _details['goldenGateDetails'] = cli_util.parse_json_parameter("golden_gate_details", golden_gate_details) - - if golden_gate_service_details is not None: - _details['goldenGateServiceDetails'] = cli_util.parse_json_parameter("golden_gate_service_details", golden_gate_service_details) - - if vault_details is not None: - _details['vaultDetails'] = cli_util.parse_json_parameter("vault_details", vault_details) + if compartment_id is not None: + _details['compartmentId'] = compartment_id if freeform_tags is not None: _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) @@ -653,9 +549,12 @@ def create_migration(ctx, from_json, wait_for_state, max_wait_seconds, wait_inte if defined_tags is not None: _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) + _details['databaseCombination'] = 'MYSQL' + client = cli_util.build_client('database_migration', 'database_migration', ctx) - result = client.create_migration( - create_migration_details=_details, + result = client.clone_migration( + migration_id=migration_id, + clone_migration_details=_details, **kwargs ) if wait_for_state: @@ -688,89 +587,70 @@ def create_migration(ctx, from_json, wait_for_state, max_wait_seconds, wait_inte cli_util.render_response(result, ctx) -@migration_group.command(name=cli_util.override('database_migration.create_migration_nfs_data_transfer_medium_details.command_name', 'create-migration-nfs-data-transfer-medium-details'), help=u"""Create a Migration resource that contains all the details to perform the database migration operation, such as source and destination database details, credentials, etc. \n[Command Reference](createMigration)""") -@cli_util.option('--type', required=True, type=custom_types.CliCaseInsensitiveChoice(["ONLINE", "OFFLINE"]), help=u"""Migration type.""") -@cli_util.option('--compartment-id', required=True, help=u"""OCID of the compartment""") -@cli_util.option('--source-database-connection-id', required=True, help=u"""The OCID of the Source Database Connection.""") -@cli_util.option('--target-database-connection-id', required=True, help=u"""The OCID of the Target Database Connection.""") -@cli_util.option('--display-name', help=u"""Migration Display Name""") -@cli_util.option('--agent-id', help=u"""The OCID of the registered ODMS Agent. Only valid for Offline Logical Migrations.""") -@cli_util.option('--source-container-database-connection-id', help=u"""The OCID of the Source Container Database Connection. Only used for Online migrations. Only Connections of type Non-Autonomous can be used as source container databases.""") -@cli_util.option('--data-transfer-medium-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--dump-transfer-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--datapump-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--advisor-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--exclude-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to exclude from migration, cannot be specified alongside 'includeObjects' +@connection_group.command(name=cli_util.override('database_migration.connection_diagnostics.command_name', 'connection-diagnostics'), help=u"""Perform connection test for a database connection. \n[Command Reference](connectionDiagnostics)""") +@cli_util.option('--connection-id', required=True, help=u"""The OCID of the database connection.""") +@cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") +@json_skeleton_utils.get_cli_json_input_option({}) +@cli_util.help_option +@click.pass_context +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={}, output_type={'module': 'database_migration', 'class': 'DiagnosticsResult'}) +@cli_util.wrap_exceptions +def connection_diagnostics(ctx, from_json, connection_id, if_match): + + if isinstance(connection_id, six.string_types) and len(connection_id.strip()) == 0: + raise click.UsageError('Parameter --connection-id cannot be whitespace or empty string') + + kwargs = {} + if if_match is not None: + kwargs['if_match'] = if_match + kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) + client = cli_util.build_client('database_migration', 'database_migration', ctx) + result = client.connection_diagnostics( + connection_id=connection_id, + **kwargs + ) + cli_util.render_response(result, ctx) -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--include-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to include from migration, cannot be specified alongside 'excludeObjects' -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--csv-text', help=u"""Database objects to exclude/include from migration in CSV format. The excludeObjects and includeObjects fields will be ignored if this field is not null.""") -@cli_util.option('--golden-gate-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--golden-gate-service-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--vault-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only. Example: `{\"bar-key\": \"value\"}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@connection_group.command(name=cli_util.override('database_migration.create_connection.command_name', 'create'), help=u"""Create a Database Connection resource that contains the details to connect to either a Source or Target Database in the migration. \n[Command Reference](createConnection)""") +@cli_util.option('--connection-type', required=True, type=custom_types.CliCaseInsensitiveChoice(["MYSQL", "ORACLE"]), help=u"""Defines the type of connection. For example, ORACLE.""") +@cli_util.option('--display-name', required=True, help=u"""A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--compartment-id', required=True, help=u"""The OCID of the compartment.""") +@cli_util.option('--vault-id', required=True, help=u"""OCI resource ID.""") +@cli_util.option('--key-id', required=True, help=u"""The OCID of the key used in cryptographic operations.""") +@cli_util.option('--username', required=True, help=u"""The username (credential) used when creating or updating this resource.""") +@cli_util.option('--password', required=True, help=u"""The password (credential) used when creating or updating this resource.""") +@cli_util.option('--description', help=u"""A user-friendly description. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {\"Department\": \"Finance\"}""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--data-transfer-medium-details-v2-object-storage-bucket', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--subnet-id', help=u"""OCI resource ID.""") +@cli_util.option('--nsg-ids', type=custom_types.CLI_COMPLEX_TYPE, help=u"""An array of Network Security Group OCIDs used to define network access for Connections.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--replication-username', help=u"""The username (credential) used when creating or updating this resource.""") +@cli_util.option('--replication-password', help=u"""The password (credential) used when creating or updating this resource.""") @cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") @cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") @cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") -@json_skeleton_utils.get_cli_json_input_option({'data-transfer-medium-details': {'module': 'database_migration', 'class': 'CreateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'CreateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'CreateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'CreateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'CreateGoldenGateDetails'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'CreateGoldenGateServiceDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'CreateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details-v2-object-storage-bucket': {'module': 'database_migration', 'class': 'ObjectStoreBucket'}}) +@json_skeleton_utils.get_cli_json_input_option({'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'nsg-ids': {'module': 'database_migration', 'class': 'list[string]'}}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'data-transfer-medium-details': {'module': 'database_migration', 'class': 'CreateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'CreateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'CreateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'CreateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'CreateGoldenGateDetails'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'CreateGoldenGateServiceDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'CreateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details-v2-object-storage-bucket': {'module': 'database_migration', 'class': 'ObjectStoreBucket'}}, output_type={'module': 'database_migration', 'class': 'Migration'}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'nsg-ids': {'module': 'database_migration', 'class': 'list[string]'}}, output_type={'module': 'database_migration', 'class': 'Connection'}) @cli_util.wrap_exceptions -def create_migration_nfs_data_transfer_medium_details(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_seconds, type, compartment_id, source_database_connection_id, target_database_connection_id, display_name, agent_id, source_container_database_connection_id, data_transfer_medium_details, dump_transfer_details, datapump_settings, advisor_settings, exclude_objects, include_objects, csv_text, golden_gate_details, golden_gate_service_details, vault_details, freeform_tags, defined_tags, data_transfer_medium_details_v2_object_storage_bucket): +def create_connection(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_seconds, connection_type, display_name, compartment_id, vault_id, key_id, username, password, description, freeform_tags, defined_tags, subnet_id, nsg_ids, replication_username, replication_password): kwargs = {} kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) _details = {} - _details['dataTransferMediumDetailsV2'] = {} - _details['type'] = type + _details['connectionType'] = connection_type + _details['displayName'] = display_name _details['compartmentId'] = compartment_id - _details['sourceDatabaseConnectionId'] = source_database_connection_id - _details['targetDatabaseConnectionId'] = target_database_connection_id - - if display_name is not None: - _details['displayName'] = display_name - - if agent_id is not None: - _details['agentId'] = agent_id - - if source_container_database_connection_id is not None: - _details['sourceContainerDatabaseConnectionId'] = source_container_database_connection_id - - if data_transfer_medium_details is not None: - _details['dataTransferMediumDetails'] = cli_util.parse_json_parameter("data_transfer_medium_details", data_transfer_medium_details) - - if dump_transfer_details is not None: - _details['dumpTransferDetails'] = cli_util.parse_json_parameter("dump_transfer_details", dump_transfer_details) - - if datapump_settings is not None: - _details['datapumpSettings'] = cli_util.parse_json_parameter("datapump_settings", datapump_settings) - - if advisor_settings is not None: - _details['advisorSettings'] = cli_util.parse_json_parameter("advisor_settings", advisor_settings) - - if exclude_objects is not None: - _details['excludeObjects'] = cli_util.parse_json_parameter("exclude_objects", exclude_objects) - - if include_objects is not None: - _details['includeObjects'] = cli_util.parse_json_parameter("include_objects", include_objects) + _details['vaultId'] = vault_id + _details['keyId'] = key_id + _details['username'] = username + _details['password'] = password - if csv_text is not None: - _details['csvText'] = csv_text - - if golden_gate_details is not None: - _details['goldenGateDetails'] = cli_util.parse_json_parameter("golden_gate_details", golden_gate_details) - - if golden_gate_service_details is not None: - _details['goldenGateServiceDetails'] = cli_util.parse_json_parameter("golden_gate_service_details", golden_gate_service_details) - - if vault_details is not None: - _details['vaultDetails'] = cli_util.parse_json_parameter("vault_details", vault_details) + if description is not None: + _details['description'] = description if freeform_tags is not None: _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) @@ -778,14 +658,21 @@ def create_migration_nfs_data_transfer_medium_details(ctx, from_json, wait_for_s if defined_tags is not None: _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) - if data_transfer_medium_details_v2_object_storage_bucket is not None: - _details['dataTransferMediumDetailsV2']['objectStorageBucket'] = cli_util.parse_json_parameter("data_transfer_medium_details_v2_object_storage_bucket", data_transfer_medium_details_v2_object_storage_bucket) + if subnet_id is not None: + _details['subnetId'] = subnet_id + + if nsg_ids is not None: + _details['nsgIds'] = cli_util.parse_json_parameter("nsg_ids", nsg_ids) - _details['dataTransferMediumDetailsV2']['type'] = 'NFS' + if replication_username is not None: + _details['replicationUsername'] = replication_username + + if replication_password is not None: + _details['replicationPassword'] = replication_password client = cli_util.build_client('database_migration', 'database_migration', ctx) - result = client.create_migration( - create_migration_details=_details, + result = client.create_connection( + create_connection_details=_details, **kwargs ) if wait_for_state: @@ -818,104 +705,111 @@ def create_migration_nfs_data_transfer_medium_details(ctx, from_json, wait_for_s cli_util.render_response(result, ctx) -@migration_group.command(name=cli_util.override('database_migration.create_migration_object_storage_data_transfer_medium_details.command_name', 'create-migration-object-storage-data-transfer-medium-details'), help=u"""Create a Migration resource that contains all the details to perform the database migration operation, such as source and destination database details, credentials, etc. \n[Command Reference](createMigration)""") -@cli_util.option('--type', required=True, type=custom_types.CliCaseInsensitiveChoice(["ONLINE", "OFFLINE"]), help=u"""Migration type.""") -@cli_util.option('--compartment-id', required=True, help=u"""OCID of the compartment""") -@cli_util.option('--source-database-connection-id', required=True, help=u"""The OCID of the Source Database Connection.""") -@cli_util.option('--target-database-connection-id', required=True, help=u"""The OCID of the Target Database Connection.""") -@cli_util.option('--display-name', help=u"""Migration Display Name""") -@cli_util.option('--agent-id', help=u"""The OCID of the registered ODMS Agent. Only valid for Offline Logical Migrations.""") -@cli_util.option('--source-container-database-connection-id', help=u"""The OCID of the Source Container Database Connection. Only used for Online migrations. Only Connections of type Non-Autonomous can be used as source container databases.""") -@cli_util.option('--data-transfer-medium-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--dump-transfer-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--datapump-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--advisor-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--exclude-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to exclude from migration, cannot be specified alongside 'includeObjects' - -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--include-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to include from migration, cannot be specified alongside 'excludeObjects' - -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--csv-text', help=u"""Database objects to exclude/include from migration in CSV format. The excludeObjects and includeObjects fields will be ignored if this field is not null.""") -@cli_util.option('--golden-gate-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--golden-gate-service-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--vault-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only. Example: `{\"bar-key\": \"value\"}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@connection_group.command(name=cli_util.override('database_migration.create_connection_create_mysql_connection_details.command_name', 'create-connection-create-mysql-connection-details'), help=u"""Create a Database Connection resource that contains the details to connect to either a Source or Target Database in the migration. \n[Command Reference](createConnection)""") +@cli_util.option('--display-name', required=True, help=u"""A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--compartment-id', required=True, help=u"""The OCID of the compartment.""") +@cli_util.option('--vault-id', required=True, help=u"""OCI resource ID.""") +@cli_util.option('--key-id', required=True, help=u"""The OCID of the key used in cryptographic operations.""") +@cli_util.option('--username', required=True, help=u"""The username (credential) used when creating or updating this resource.""") +@cli_util.option('--password', required=True, help=u"""The password (credential) used when creating or updating this resource.""") +@cli_util.option('--technology-type', required=True, help=u"""The type of MySQL source or target connection. Example: OCI_MYSQL represents OCI MySQL HeatWave Database Service""") +@cli_util.option('--database-name', required=True, help=u"""The name of the database being referenced.""") +@cli_util.option('--security-protocol', required=True, help=u"""Security Type for MySQL.""") +@cli_util.option('--description', help=u"""A user-friendly description. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {\"Department\": \"Finance\"}""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--data-transfer-medium-details-v2-object-storage-bucket', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--subnet-id', help=u"""OCI resource ID.""") +@cli_util.option('--nsg-ids', type=custom_types.CLI_COMPLEX_TYPE, help=u"""An array of Network Security Group OCIDs used to define network access for Connections.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--replication-username', help=u"""The username (credential) used when creating or updating this resource.""") +@cli_util.option('--replication-password', help=u"""The password (credential) used when creating or updating this resource.""") +@cli_util.option('--host', help=u"""The IP Address of the host.""") +@cli_util.option('--port', type=click.INT, help=u"""The port to be used for the connection.""") +@cli_util.option('--ssl-mode', help=u"""SSL modes for MySQL.""") +@cli_util.option('--ssl-ca', help=u"""Database Certificate - The base64 encoded content of mysql.pem file containing the server public key (for 1 and 2-way SSL).""") +@cli_util.option('--ssl-crl', help=u"""Certificates revoked by certificate authorities (CA). Server certificate must not be on this list (for 1 and 2-way SSL). Note: This is an optional and that too only applicable if TLS/MTLS option is selected.""") +@cli_util.option('--ssl-cert', help=u"""Client Certificate - The base64 encoded content of client-cert.pem file containing the client public key (for 2-way SSL).""") +@cli_util.option('--ssl-key', help=u"""Client Key - The client-key.pem containing the client private key (for 2-way SSL).""") +@cli_util.option('--additional-attributes', type=custom_types.CLI_COMPLEX_TYPE, help=u"""An array of name-value pair attribute entries. + +This option is a JSON list with items of type NameValuePair. For documentation on NameValuePair please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20230518/datatypes/NameValuePair.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--db-system-id', help=u"""The OCID of the database system being referenced.""") @cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") @cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") @cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") -@json_skeleton_utils.get_cli_json_input_option({'data-transfer-medium-details': {'module': 'database_migration', 'class': 'CreateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'CreateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'CreateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'CreateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'CreateGoldenGateDetails'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'CreateGoldenGateServiceDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'CreateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details-v2-object-storage-bucket': {'module': 'database_migration', 'class': 'ObjectStoreBucket'}}) +@json_skeleton_utils.get_cli_json_input_option({'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'nsg-ids': {'module': 'database_migration', 'class': 'list[string]'}, 'additional-attributes': {'module': 'database_migration', 'class': 'list[NameValuePair]'}}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'data-transfer-medium-details': {'module': 'database_migration', 'class': 'CreateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'CreateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'CreateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'CreateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'CreateGoldenGateDetails'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'CreateGoldenGateServiceDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'CreateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details-v2-object-storage-bucket': {'module': 'database_migration', 'class': 'ObjectStoreBucket'}}, output_type={'module': 'database_migration', 'class': 'Migration'}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'nsg-ids': {'module': 'database_migration', 'class': 'list[string]'}, 'additional-attributes': {'module': 'database_migration', 'class': 'list[NameValuePair]'}}, output_type={'module': 'database_migration', 'class': 'Connection'}) @cli_util.wrap_exceptions -def create_migration_object_storage_data_transfer_medium_details(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_seconds, type, compartment_id, source_database_connection_id, target_database_connection_id, display_name, agent_id, source_container_database_connection_id, data_transfer_medium_details, dump_transfer_details, datapump_settings, advisor_settings, exclude_objects, include_objects, csv_text, golden_gate_details, golden_gate_service_details, vault_details, freeform_tags, defined_tags, data_transfer_medium_details_v2_object_storage_bucket): +def create_connection_create_mysql_connection_details(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_seconds, display_name, compartment_id, vault_id, key_id, username, password, technology_type, database_name, security_protocol, description, freeform_tags, defined_tags, subnet_id, nsg_ids, replication_username, replication_password, host, port, ssl_mode, ssl_ca, ssl_crl, ssl_cert, ssl_key, additional_attributes, db_system_id): kwargs = {} kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) _details = {} - _details['dataTransferMediumDetailsV2'] = {} - _details['type'] = type + _details['displayName'] = display_name _details['compartmentId'] = compartment_id - _details['sourceDatabaseConnectionId'] = source_database_connection_id - _details['targetDatabaseConnectionId'] = target_database_connection_id - - if display_name is not None: - _details['displayName'] = display_name + _details['vaultId'] = vault_id + _details['keyId'] = key_id + _details['username'] = username + _details['password'] = password + _details['technologyType'] = technology_type + _details['databaseName'] = database_name + _details['securityProtocol'] = security_protocol - if agent_id is not None: - _details['agentId'] = agent_id + if description is not None: + _details['description'] = description - if source_container_database_connection_id is not None: - _details['sourceContainerDatabaseConnectionId'] = source_container_database_connection_id + if freeform_tags is not None: + _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) - if data_transfer_medium_details is not None: - _details['dataTransferMediumDetails'] = cli_util.parse_json_parameter("data_transfer_medium_details", data_transfer_medium_details) + if defined_tags is not None: + _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) - if dump_transfer_details is not None: - _details['dumpTransferDetails'] = cli_util.parse_json_parameter("dump_transfer_details", dump_transfer_details) + if subnet_id is not None: + _details['subnetId'] = subnet_id - if datapump_settings is not None: - _details['datapumpSettings'] = cli_util.parse_json_parameter("datapump_settings", datapump_settings) + if nsg_ids is not None: + _details['nsgIds'] = cli_util.parse_json_parameter("nsg_ids", nsg_ids) - if advisor_settings is not None: - _details['advisorSettings'] = cli_util.parse_json_parameter("advisor_settings", advisor_settings) + if replication_username is not None: + _details['replicationUsername'] = replication_username - if exclude_objects is not None: - _details['excludeObjects'] = cli_util.parse_json_parameter("exclude_objects", exclude_objects) + if replication_password is not None: + _details['replicationPassword'] = replication_password - if include_objects is not None: - _details['includeObjects'] = cli_util.parse_json_parameter("include_objects", include_objects) + if host is not None: + _details['host'] = host - if csv_text is not None: - _details['csvText'] = csv_text + if port is not None: + _details['port'] = port - if golden_gate_details is not None: - _details['goldenGateDetails'] = cli_util.parse_json_parameter("golden_gate_details", golden_gate_details) + if ssl_mode is not None: + _details['sslMode'] = ssl_mode - if golden_gate_service_details is not None: - _details['goldenGateServiceDetails'] = cli_util.parse_json_parameter("golden_gate_service_details", golden_gate_service_details) + if ssl_ca is not None: + _details['sslCa'] = ssl_ca - if vault_details is not None: - _details['vaultDetails'] = cli_util.parse_json_parameter("vault_details", vault_details) + if ssl_crl is not None: + _details['sslCrl'] = ssl_crl - if freeform_tags is not None: - _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) + if ssl_cert is not None: + _details['sslCert'] = ssl_cert - if defined_tags is not None: - _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) + if ssl_key is not None: + _details['sslKey'] = ssl_key - if data_transfer_medium_details_v2_object_storage_bucket is not None: - _details['dataTransferMediumDetailsV2']['objectStorageBucket'] = cli_util.parse_json_parameter("data_transfer_medium_details_v2_object_storage_bucket", data_transfer_medium_details_v2_object_storage_bucket) + if additional_attributes is not None: + _details['additionalAttributes'] = cli_util.parse_json_parameter("additional_attributes", additional_attributes) - _details['dataTransferMediumDetailsV2']['type'] = 'OBJECT_STORAGE' + if db_system_id is not None: + _details['dbSystemId'] = db_system_id + + _details['connectionType'] = 'MYSQL' client = cli_util.build_client('database_migration', 'database_migration', ctx) - result = client.create_migration( - create_migration_details=_details, + result = client.create_connection( + create_connection_details=_details, **kwargs ) if wait_for_state: @@ -948,90 +842,164 @@ def create_migration_object_storage_data_transfer_medium_details(ctx, from_json, cli_util.render_response(result, ctx) -@migration_group.command(name=cli_util.override('database_migration.create_migration_db_link_data_transfer_medium_details.command_name', 'create-migration-db-link-data-transfer-medium-details'), help=u"""Create a Migration resource that contains all the details to perform the database migration operation, such as source and destination database details, credentials, etc. \n[Command Reference](createMigration)""") -@cli_util.option('--type', required=True, type=custom_types.CliCaseInsensitiveChoice(["ONLINE", "OFFLINE"]), help=u"""Migration type.""") -@cli_util.option('--compartment-id', required=True, help=u"""OCID of the compartment""") -@cli_util.option('--source-database-connection-id', required=True, help=u"""The OCID of the Source Database Connection.""") -@cli_util.option('--target-database-connection-id', required=True, help=u"""The OCID of the Target Database Connection.""") -@cli_util.option('--display-name', help=u"""Migration Display Name""") -@cli_util.option('--agent-id', help=u"""The OCID of the registered ODMS Agent. Only valid for Offline Logical Migrations.""") -@cli_util.option('--source-container-database-connection-id', help=u"""The OCID of the Source Container Database Connection. Only used for Online migrations. Only Connections of type Non-Autonomous can be used as source container databases.""") -@cli_util.option('--data-transfer-medium-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--dump-transfer-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--datapump-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--advisor-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--exclude-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to exclude from migration, cannot be specified alongside 'includeObjects' - -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--include-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to include from migration, cannot be specified alongside 'excludeObjects' - -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--csv-text', help=u"""Database objects to exclude/include from migration in CSV format. The excludeObjects and includeObjects fields will be ignored if this field is not null.""") -@cli_util.option('--golden-gate-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--golden-gate-service-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--vault-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only. Example: `{\"bar-key\": \"value\"}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@connection_group.command(name=cli_util.override('database_migration.create_connection_create_oracle_connection_details.command_name', 'create-connection-create-oracle-connection-details'), help=u"""Create a Database Connection resource that contains the details to connect to either a Source or Target Database in the migration. \n[Command Reference](createConnection)""") +@cli_util.option('--display-name', required=True, help=u"""A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--compartment-id', required=True, help=u"""The OCID of the compartment.""") +@cli_util.option('--vault-id', required=True, help=u"""OCI resource ID.""") +@cli_util.option('--key-id', required=True, help=u"""The OCID of the key used in cryptographic operations.""") +@cli_util.option('--username', required=True, help=u"""The username (credential) used when creating or updating this resource.""") +@cli_util.option('--password', required=True, help=u"""The password (credential) used when creating or updating this resource.""") +@cli_util.option('--technology-type', required=True, help=u"""The Oracle technology type.""") +@cli_util.option('--description', help=u"""A user-friendly description. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {\"Department\": \"Finance\"}""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--data-transfer-medium-details-v2-object-storage-bucket', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--data-transfer-medium-details-v2-name', help=u"""Name of database link from OCI database to on-premise database. ODMS will create link, if the link does not already exist.""") +@cli_util.option('--subnet-id', help=u"""OCI resource ID.""") +@cli_util.option('--nsg-ids', type=custom_types.CLI_COMPLEX_TYPE, help=u"""An array of Network Security Group OCIDs used to define network access for Connections.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--replication-username', help=u"""The username (credential) used when creating or updating this resource.""") +@cli_util.option('--replication-password', help=u"""The password (credential) used when creating or updating this resource.""") +@cli_util.option('--connection-string', help=u"""Connect descriptor or Easy Connect Naming method used to connect to a database.""") +@cli_util.option('--wallet', help=u"""The wallet contents used to make connections to a database. This attribute is expected to be base64 encoded.""") +@cli_util.option('--database-id', help=u"""The OCID of the database being referenced.""") +@cli_util.option('--ssh-host', help=u"""Name of the host the SSH key is valid for.""") +@cli_util.option('--ssh-key', help=u"""Private SSH key string.""") +@cli_util.option('--ssh-user', help=u"""The username (credential) used when creating or updating this resource.""") +@cli_util.option('--ssh-sudo-location', help=u"""Sudo location""") @cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") @cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") @cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") -@json_skeleton_utils.get_cli_json_input_option({'data-transfer-medium-details': {'module': 'database_migration', 'class': 'CreateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'CreateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'CreateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'CreateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'CreateGoldenGateDetails'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'CreateGoldenGateServiceDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'CreateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details-v2-object-storage-bucket': {'module': 'database_migration', 'class': 'ObjectStoreBucket'}}) +@json_skeleton_utils.get_cli_json_input_option({'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'nsg-ids': {'module': 'database_migration', 'class': 'list[string]'}}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'data-transfer-medium-details': {'module': 'database_migration', 'class': 'CreateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'CreateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'CreateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'CreateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'CreateGoldenGateDetails'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'CreateGoldenGateServiceDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'CreateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details-v2-object-storage-bucket': {'module': 'database_migration', 'class': 'ObjectStoreBucket'}}, output_type={'module': 'database_migration', 'class': 'Migration'}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'nsg-ids': {'module': 'database_migration', 'class': 'list[string]'}}, output_type={'module': 'database_migration', 'class': 'Connection'}) @cli_util.wrap_exceptions -def create_migration_db_link_data_transfer_medium_details(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_seconds, type, compartment_id, source_database_connection_id, target_database_connection_id, display_name, agent_id, source_container_database_connection_id, data_transfer_medium_details, dump_transfer_details, datapump_settings, advisor_settings, exclude_objects, include_objects, csv_text, golden_gate_details, golden_gate_service_details, vault_details, freeform_tags, defined_tags, data_transfer_medium_details_v2_object_storage_bucket, data_transfer_medium_details_v2_name): +def create_connection_create_oracle_connection_details(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_seconds, display_name, compartment_id, vault_id, key_id, username, password, technology_type, description, freeform_tags, defined_tags, subnet_id, nsg_ids, replication_username, replication_password, connection_string, wallet, database_id, ssh_host, ssh_key, ssh_user, ssh_sudo_location): kwargs = {} kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) _details = {} - _details['dataTransferMediumDetailsV2'] = {} - _details['type'] = type + _details['displayName'] = display_name _details['compartmentId'] = compartment_id - _details['sourceDatabaseConnectionId'] = source_database_connection_id - _details['targetDatabaseConnectionId'] = target_database_connection_id + _details['vaultId'] = vault_id + _details['keyId'] = key_id + _details['username'] = username + _details['password'] = password + _details['technologyType'] = technology_type - if display_name is not None: - _details['displayName'] = display_name + if description is not None: + _details['description'] = description - if agent_id is not None: - _details['agentId'] = agent_id + if freeform_tags is not None: + _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) - if source_container_database_connection_id is not None: - _details['sourceContainerDatabaseConnectionId'] = source_container_database_connection_id + if defined_tags is not None: + _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) - if data_transfer_medium_details is not None: - _details['dataTransferMediumDetails'] = cli_util.parse_json_parameter("data_transfer_medium_details", data_transfer_medium_details) + if subnet_id is not None: + _details['subnetId'] = subnet_id - if dump_transfer_details is not None: - _details['dumpTransferDetails'] = cli_util.parse_json_parameter("dump_transfer_details", dump_transfer_details) + if nsg_ids is not None: + _details['nsgIds'] = cli_util.parse_json_parameter("nsg_ids", nsg_ids) - if datapump_settings is not None: - _details['datapumpSettings'] = cli_util.parse_json_parameter("datapump_settings", datapump_settings) + if replication_username is not None: + _details['replicationUsername'] = replication_username - if advisor_settings is not None: - _details['advisorSettings'] = cli_util.parse_json_parameter("advisor_settings", advisor_settings) + if replication_password is not None: + _details['replicationPassword'] = replication_password - if exclude_objects is not None: - _details['excludeObjects'] = cli_util.parse_json_parameter("exclude_objects", exclude_objects) + if connection_string is not None: + _details['connectionString'] = connection_string - if include_objects is not None: - _details['includeObjects'] = cli_util.parse_json_parameter("include_objects", include_objects) + if wallet is not None: + _details['wallet'] = wallet + + if database_id is not None: + _details['databaseId'] = database_id + + if ssh_host is not None: + _details['sshHost'] = ssh_host + + if ssh_key is not None: + _details['sshKey'] = ssh_key + + if ssh_user is not None: + _details['sshUser'] = ssh_user + + if ssh_sudo_location is not None: + _details['sshSudoLocation'] = ssh_sudo_location + + _details['connectionType'] = 'ORACLE' + + client = cli_util.build_client('database_migration', 'database_migration', ctx) + result = client.create_connection( + create_connection_details=_details, + **kwargs + ) + if wait_for_state: - if csv_text is not None: - _details['csvText'] = csv_text + if hasattr(client, 'get_work_request') and callable(getattr(client, 'get_work_request')): + try: + wait_period_kwargs = {} + if max_wait_seconds is not None: + wait_period_kwargs['max_wait_seconds'] = max_wait_seconds + if wait_interval_seconds is not None: + wait_period_kwargs['max_interval_seconds'] = wait_interval_seconds + if 'opc-work-request-id' not in result.headers: + click.echo('Encountered error while waiting for work request to enter the specified state. Outputting last known resource state') + cli_util.render_response(result, ctx) + return + + click.echo('Action completed. Waiting until the work request has entered state: {}'.format(wait_for_state), file=sys.stderr) + result = oci.wait_until(client, client.get_work_request(result.headers['opc-work-request-id']), 'status', wait_for_state, **wait_period_kwargs) + except oci.exceptions.MaximumWaitTimeExceeded as e: + # If we fail, we should show an error, but we should still provide the information to the customer + click.echo('Failed to wait until the work request entered the specified state. Outputting last known resource state', file=sys.stderr) + cli_util.render_response(result, ctx) + sys.exit(2) + except Exception: + click.echo('Encountered error while waiting for work request to enter the specified state. Outputting last known resource state', file=sys.stderr) + cli_util.render_response(result, ctx) + raise + else: + click.echo('Unable to wait for the work request to enter the specified state', file=sys.stderr) + cli_util.render_response(result, ctx) + + +@migration_group.command(name=cli_util.override('database_migration.create_migration.command_name', 'create'), help=u"""Create a Migration resource that contains all the details to perform the database migration operation, such as source and destination database details, credentials, etc. \n[Command Reference](createMigration)""") +@cli_util.option('--compartment-id', required=True, help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--database-combination', required=True, type=custom_types.CliCaseInsensitiveChoice(["MYSQL", "ORACLE"]), help=u"""The combination of source and target databases participating in a migration. Example: ORACLE means the migration is meant for migrating Oracle source and target databases.""") +@cli_util.option('--type', required=True, type=custom_types.CliCaseInsensitiveChoice(["ONLINE", "OFFLINE"]), help=u"""The type of the migration to be performed. Example: ONLINE if no downtime is preferred for a migration. This method uses Oracle GoldenGate for replication.""") +@cli_util.option('--source-database-connection-id', required=True, help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--target-database-connection-id', required=True, help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--description', help=u"""A user-friendly description. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--display-name', help=u"""A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {\"Department\": \"Finance\"}""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") +@cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") +@cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") +@json_skeleton_utils.get_cli_json_input_option({'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}) +@cli_util.help_option +@click.pass_context +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}, output_type={'module': 'database_migration', 'class': 'Migration'}) +@cli_util.wrap_exceptions +def create_migration(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_seconds, compartment_id, database_combination, type, source_database_connection_id, target_database_connection_id, description, display_name, freeform_tags, defined_tags): + + kwargs = {} + kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) - if golden_gate_details is not None: - _details['goldenGateDetails'] = cli_util.parse_json_parameter("golden_gate_details", golden_gate_details) + _details = {} + _details['compartmentId'] = compartment_id + _details['databaseCombination'] = database_combination + _details['type'] = type + _details['sourceDatabaseConnectionId'] = source_database_connection_id + _details['targetDatabaseConnectionId'] = target_database_connection_id - if golden_gate_service_details is not None: - _details['goldenGateServiceDetails'] = cli_util.parse_json_parameter("golden_gate_service_details", golden_gate_service_details) + if description is not None: + _details['description'] = description - if vault_details is not None: - _details['vaultDetails'] = cli_util.parse_json_parameter("vault_details", vault_details) + if display_name is not None: + _details['displayName'] = display_name if freeform_tags is not None: _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) @@ -1039,14 +1007,6 @@ def create_migration_db_link_data_transfer_medium_details(ctx, from_json, wait_f if defined_tags is not None: _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) - if data_transfer_medium_details_v2_object_storage_bucket is not None: - _details['dataTransferMediumDetailsV2']['objectStorageBucket'] = cli_util.parse_json_parameter("data_transfer_medium_details_v2_object_storage_bucket", data_transfer_medium_details_v2_object_storage_bucket) - - if data_transfer_medium_details_v2_name is not None: - _details['dataTransferMediumDetailsV2']['name'] = data_transfer_medium_details_v2_name - - _details['dataTransferMediumDetailsV2']['type'] = 'DBLINK' - client = cli_util.build_client('database_migration', 'database_migration', ctx) result = client.create_migration( create_migration_details=_details, @@ -1082,72 +1042,63 @@ def create_migration_db_link_data_transfer_medium_details(ctx, from_json, wait_f cli_util.render_response(result, ctx) -@migration_group.command(name=cli_util.override('database_migration.create_migration_aws_s3_data_transfer_medium_details.command_name', 'create-migration-aws-s3-data-transfer-medium-details'), help=u"""Create a Migration resource that contains all the details to perform the database migration operation, such as source and destination database details, credentials, etc. \n[Command Reference](createMigration)""") -@cli_util.option('--type', required=True, type=custom_types.CliCaseInsensitiveChoice(["ONLINE", "OFFLINE"]), help=u"""Migration type.""") -@cli_util.option('--compartment-id', required=True, help=u"""OCID of the compartment""") -@cli_util.option('--source-database-connection-id', required=True, help=u"""The OCID of the Source Database Connection.""") -@cli_util.option('--target-database-connection-id', required=True, help=u"""The OCID of the Target Database Connection.""") -@cli_util.option('--display-name', help=u"""Migration Display Name""") -@cli_util.option('--agent-id', help=u"""The OCID of the registered ODMS Agent. Only valid for Offline Logical Migrations.""") -@cli_util.option('--source-container-database-connection-id', help=u"""The OCID of the Source Container Database Connection. Only used for Online migrations. Only Connections of type Non-Autonomous can be used as source container databases.""") +@migration_group.command(name=cli_util.override('database_migration.create_migration_create_my_sql_migration_details.command_name', 'create-migration-create-my-sql-migration-details'), help=u"""Create a Migration resource that contains all the details to perform the database migration operation, such as source and destination database details, credentials, etc. \n[Command Reference](createMigration)""") +@cli_util.option('--compartment-id', required=True, help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--type', required=True, type=custom_types.CliCaseInsensitiveChoice(["ONLINE", "OFFLINE"]), help=u"""The type of the migration to be performed. Example: ONLINE if no downtime is preferred for a migration. This method uses Oracle GoldenGate for replication.""") +@cli_util.option('--source-database-connection-id', required=True, help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--target-database-connection-id', required=True, help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--description', help=u"""A user-friendly description. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--display-name', help=u"""A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {\"Department\": \"Finance\"}""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--data-transfer-medium-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--dump-transfer-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--datapump-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--initial-load-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--advisor-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--exclude-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to exclude from migration, cannot be specified alongside 'includeObjects' -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +This option is a JSON list with items of type MySqlDatabaseObject. For documentation on MySqlDatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20230518/datatypes/MySqlDatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--include-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to include from migration, cannot be specified alongside 'excludeObjects' -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--csv-text', help=u"""Database objects to exclude/include from migration in CSV format. The excludeObjects and includeObjects fields will be ignored if this field is not null.""") -@cli_util.option('--golden-gate-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--golden-gate-service-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--vault-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only. Example: `{\"bar-key\": \"value\"}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--data-transfer-medium-details-v2-name', help=u"""S3 bucket name.""") -@cli_util.option('--data-transfer-medium-details-v2-region', help=u"""AWS region code where the S3 bucket is located. Region code should match the documented available regions: https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-regions-availability-zones.html#concepts-available-regions""") -@cli_util.option('--data-transfer-medium-details-v2-access-key-id', help=u"""AWS access key credentials identifier Details: https://docs.aws.amazon.com/general/latest/gr/aws-sec-cred-types.html#access-keys-and-secret-access-keys""") -@cli_util.option('--data-transfer-medium-details-v2-secret-access-key', help=u"""AWS secret access key credentials Details: https://docs.aws.amazon.com/general/latest/gr/aws-sec-cred-types.html#access-keys-and-secret-access-keys""") -@cli_util.option('--data-transfer-medium-details-v2-object-storage-bucket', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +This option is a JSON list with items of type MySqlDatabaseObject. For documentation on MySqlDatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20230518/datatypes/MySqlDatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--bulk-include-exclude-data', help=u"""Specifies the database objects to be excluded from the migration in bulk. The definition accepts input in a CSV format, newline separated for each entry. More details can be found in the documentation.""") +@cli_util.option('--hub-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--ggs-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") @cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") @cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") -@json_skeleton_utils.get_cli_json_input_option({'data-transfer-medium-details': {'module': 'database_migration', 'class': 'CreateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'CreateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'CreateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'CreateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'CreateGoldenGateDetails'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'CreateGoldenGateServiceDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'CreateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details-v2-object-storage-bucket': {'module': 'database_migration', 'class': 'ObjectStoreBucket'}}) +@json_skeleton_utils.get_cli_json_input_option({'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details': {'module': 'database_migration', 'class': 'CreateMySqlDataTransferMediumDetails'}, 'initial-load-settings': {'module': 'database_migration', 'class': 'CreateMySqlInitialLoadSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'CreateMySqlAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[MySqlDatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[MySqlDatabaseObject]'}, 'hub-details': {'module': 'database_migration', 'class': 'CreateGoldenGateHubDetails'}, 'ggs-details': {'module': 'database_migration', 'class': 'CreateMySqlGgsDeploymentDetails'}}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'data-transfer-medium-details': {'module': 'database_migration', 'class': 'CreateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'CreateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'CreateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'CreateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'CreateGoldenGateDetails'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'CreateGoldenGateServiceDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'CreateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details-v2-object-storage-bucket': {'module': 'database_migration', 'class': 'ObjectStoreBucket'}}, output_type={'module': 'database_migration', 'class': 'Migration'}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details': {'module': 'database_migration', 'class': 'CreateMySqlDataTransferMediumDetails'}, 'initial-load-settings': {'module': 'database_migration', 'class': 'CreateMySqlInitialLoadSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'CreateMySqlAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[MySqlDatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[MySqlDatabaseObject]'}, 'hub-details': {'module': 'database_migration', 'class': 'CreateGoldenGateHubDetails'}, 'ggs-details': {'module': 'database_migration', 'class': 'CreateMySqlGgsDeploymentDetails'}}, output_type={'module': 'database_migration', 'class': 'Migration'}) @cli_util.wrap_exceptions -def create_migration_aws_s3_data_transfer_medium_details(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_seconds, type, compartment_id, source_database_connection_id, target_database_connection_id, display_name, agent_id, source_container_database_connection_id, data_transfer_medium_details, dump_transfer_details, datapump_settings, advisor_settings, exclude_objects, include_objects, csv_text, golden_gate_details, golden_gate_service_details, vault_details, freeform_tags, defined_tags, data_transfer_medium_details_v2_name, data_transfer_medium_details_v2_region, data_transfer_medium_details_v2_access_key_id, data_transfer_medium_details_v2_secret_access_key, data_transfer_medium_details_v2_object_storage_bucket): +def create_migration_create_my_sql_migration_details(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_seconds, compartment_id, type, source_database_connection_id, target_database_connection_id, description, display_name, freeform_tags, defined_tags, data_transfer_medium_details, initial_load_settings, advisor_settings, exclude_objects, include_objects, bulk_include_exclude_data, hub_details, ggs_details): kwargs = {} kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) _details = {} - _details['dataTransferMediumDetailsV2'] = {} - _details['type'] = type _details['compartmentId'] = compartment_id + _details['type'] = type _details['sourceDatabaseConnectionId'] = source_database_connection_id _details['targetDatabaseConnectionId'] = target_database_connection_id + if description is not None: + _details['description'] = description + if display_name is not None: _details['displayName'] = display_name - if agent_id is not None: - _details['agentId'] = agent_id + if freeform_tags is not None: + _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) - if source_container_database_connection_id is not None: - _details['sourceContainerDatabaseConnectionId'] = source_container_database_connection_id + if defined_tags is not None: + _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) if data_transfer_medium_details is not None: _details['dataTransferMediumDetails'] = cli_util.parse_json_parameter("data_transfer_medium_details", data_transfer_medium_details) - if dump_transfer_details is not None: - _details['dumpTransferDetails'] = cli_util.parse_json_parameter("dump_transfer_details", dump_transfer_details) - - if datapump_settings is not None: - _details['datapumpSettings'] = cli_util.parse_json_parameter("datapump_settings", datapump_settings) + if initial_load_settings is not None: + _details['initialLoadSettings'] = cli_util.parse_json_parameter("initial_load_settings", initial_load_settings) if advisor_settings is not None: _details['advisorSettings'] = cli_util.parse_json_parameter("advisor_settings", advisor_settings) @@ -1158,40 +1109,16 @@ def create_migration_aws_s3_data_transfer_medium_details(ctx, from_json, wait_fo if include_objects is not None: _details['includeObjects'] = cli_util.parse_json_parameter("include_objects", include_objects) - if csv_text is not None: - _details['csvText'] = csv_text - - if golden_gate_details is not None: - _details['goldenGateDetails'] = cli_util.parse_json_parameter("golden_gate_details", golden_gate_details) - - if golden_gate_service_details is not None: - _details['goldenGateServiceDetails'] = cli_util.parse_json_parameter("golden_gate_service_details", golden_gate_service_details) + if bulk_include_exclude_data is not None: + _details['bulkIncludeExcludeData'] = bulk_include_exclude_data - if vault_details is not None: - _details['vaultDetails'] = cli_util.parse_json_parameter("vault_details", vault_details) + if hub_details is not None: + _details['hubDetails'] = cli_util.parse_json_parameter("hub_details", hub_details) - if freeform_tags is not None: - _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) - - if defined_tags is not None: - _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) - - if data_transfer_medium_details_v2_name is not None: - _details['dataTransferMediumDetailsV2']['name'] = data_transfer_medium_details_v2_name - - if data_transfer_medium_details_v2_region is not None: - _details['dataTransferMediumDetailsV2']['region'] = data_transfer_medium_details_v2_region - - if data_transfer_medium_details_v2_access_key_id is not None: - _details['dataTransferMediumDetailsV2']['accessKeyId'] = data_transfer_medium_details_v2_access_key_id + if ggs_details is not None: + _details['ggsDetails'] = cli_util.parse_json_parameter("ggs_details", ggs_details) - if data_transfer_medium_details_v2_secret_access_key is not None: - _details['dataTransferMediumDetailsV2']['secretAccessKey'] = data_transfer_medium_details_v2_secret_access_key - - if data_transfer_medium_details_v2_object_storage_bucket is not None: - _details['dataTransferMediumDetailsV2']['objectStorageBucket'] = cli_util.parse_json_parameter("data_transfer_medium_details_v2_object_storage_bucket", data_transfer_medium_details_v2_object_storage_bucket) - - _details['dataTransferMediumDetailsV2']['type'] = 'AWS_S3' + _details['databaseCombination'] = 'MYSQL' client = cli_util.build_client('database_migration', 'database_migration', ctx) result = client.create_migration( @@ -1228,30 +1155,91 @@ def create_migration_aws_s3_data_transfer_medium_details(ctx, from_json, wait_fo cli_util.render_response(result, ctx) -@agent_group.command(name=cli_util.override('database_migration.delete_agent.command_name', 'delete'), help=u"""Delete the ODMS Agent represented by the specified ODMS Agent ID. \n[Command Reference](deleteAgent)""") -@cli_util.option('--agent-id', required=True, help=u"""The OCID of the agent""") -@cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") -@cli_util.confirm_delete_option +@migration_group.command(name=cli_util.override('database_migration.create_migration_create_oracle_migration_details.command_name', 'create-migration-create-oracle-migration-details'), help=u"""Create a Migration resource that contains all the details to perform the database migration operation, such as source and destination database details, credentials, etc. \n[Command Reference](createMigration)""") +@cli_util.option('--compartment-id', required=True, help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--type', required=True, type=custom_types.CliCaseInsensitiveChoice(["ONLINE", "OFFLINE"]), help=u"""The type of the migration to be performed. Example: ONLINE if no downtime is preferred for a migration. This method uses Oracle GoldenGate for replication.""") +@cli_util.option('--source-database-connection-id', required=True, help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--target-database-connection-id', required=True, help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--description', help=u"""A user-friendly description. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--display-name', help=u"""A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {\"Department\": \"Finance\"}""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--data-transfer-medium-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--initial-load-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--advisor-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--hub-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--ggs-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--source-container-database-connection-id', help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--exclude-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to exclude from migration, cannot be specified alongside 'includeObjects' + +This option is a JSON list with items of type OracleDatabaseObject. For documentation on OracleDatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20230518/datatypes/OracleDatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--include-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to include from migration, cannot be specified alongside 'excludeObjects' + +This option is a JSON list with items of type OracleDatabaseObject. For documentation on OracleDatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20230518/datatypes/OracleDatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--bulk-include-exclude-data', help=u"""Specifies the database objects to be excluded from the migration in bulk. The definition accepts input in a CSV format, newline separated for each entry. More details can be found in the documentation.""") @cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") @cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") @cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") -@json_skeleton_utils.get_cli_json_input_option({}) +@json_skeleton_utils.get_cli_json_input_option({'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details': {'module': 'database_migration', 'class': 'CreateOracleDataTransferMediumDetails'}, 'initial-load-settings': {'module': 'database_migration', 'class': 'CreateOracleInitialLoadSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'CreateOracleAdvisorSettings'}, 'hub-details': {'module': 'database_migration', 'class': 'CreateGoldenGateHubDetails'}, 'ggs-details': {'module': 'database_migration', 'class': 'CreateOracleGgsDeploymentDetails'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[OracleDatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[OracleDatabaseObject]'}}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details': {'module': 'database_migration', 'class': 'CreateOracleDataTransferMediumDetails'}, 'initial-load-settings': {'module': 'database_migration', 'class': 'CreateOracleInitialLoadSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'CreateOracleAdvisorSettings'}, 'hub-details': {'module': 'database_migration', 'class': 'CreateGoldenGateHubDetails'}, 'ggs-details': {'module': 'database_migration', 'class': 'CreateOracleGgsDeploymentDetails'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[OracleDatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[OracleDatabaseObject]'}}, output_type={'module': 'database_migration', 'class': 'Migration'}) @cli_util.wrap_exceptions -def delete_agent(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_seconds, agent_id, if_match): - - if isinstance(agent_id, six.string_types) and len(agent_id.strip()) == 0: - raise click.UsageError('Parameter --agent-id cannot be whitespace or empty string') +def create_migration_create_oracle_migration_details(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_seconds, compartment_id, type, source_database_connection_id, target_database_connection_id, description, display_name, freeform_tags, defined_tags, data_transfer_medium_details, initial_load_settings, advisor_settings, hub_details, ggs_details, source_container_database_connection_id, exclude_objects, include_objects, bulk_include_exclude_data): kwargs = {} - if if_match is not None: - kwargs['if_match'] = if_match kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) + + _details = {} + _details['compartmentId'] = compartment_id + _details['type'] = type + _details['sourceDatabaseConnectionId'] = source_database_connection_id + _details['targetDatabaseConnectionId'] = target_database_connection_id + + if description is not None: + _details['description'] = description + + if display_name is not None: + _details['displayName'] = display_name + + if freeform_tags is not None: + _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) + + if defined_tags is not None: + _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) + + if data_transfer_medium_details is not None: + _details['dataTransferMediumDetails'] = cli_util.parse_json_parameter("data_transfer_medium_details", data_transfer_medium_details) + + if initial_load_settings is not None: + _details['initialLoadSettings'] = cli_util.parse_json_parameter("initial_load_settings", initial_load_settings) + + if advisor_settings is not None: + _details['advisorSettings'] = cli_util.parse_json_parameter("advisor_settings", advisor_settings) + + if hub_details is not None: + _details['hubDetails'] = cli_util.parse_json_parameter("hub_details", hub_details) + + if ggs_details is not None: + _details['ggsDetails'] = cli_util.parse_json_parameter("ggs_details", ggs_details) + + if source_container_database_connection_id is not None: + _details['sourceContainerDatabaseConnectionId'] = source_container_database_connection_id + + if exclude_objects is not None: + _details['excludeObjects'] = cli_util.parse_json_parameter("exclude_objects", exclude_objects) + + if include_objects is not None: + _details['includeObjects'] = cli_util.parse_json_parameter("include_objects", include_objects) + + if bulk_include_exclude_data is not None: + _details['bulkIncludeExcludeData'] = bulk_include_exclude_data + + _details['databaseCombination'] = 'ORACLE' + client = cli_util.build_client('database_migration', 'database_migration', ctx) - result = client.delete_agent( - agent_id=agent_id, + result = client.create_migration( + create_migration_details=_details, **kwargs ) if wait_for_state: @@ -1272,7 +1260,7 @@ def delete_agent(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval result = oci.wait_until(client, client.get_work_request(result.headers['opc-work-request-id']), 'status', wait_for_state, **wait_period_kwargs) except oci.exceptions.MaximumWaitTimeExceeded as e: # If we fail, we should show an error, but we should still provide the information to the customer - click.echo('Failed to wait until the work request entered the specified state. Please retrieve the work request to find its current state', file=sys.stderr) + click.echo('Failed to wait until the work request entered the specified state. Outputting last known resource state', file=sys.stderr) cli_util.render_response(result, ctx) sys.exit(2) except Exception: @@ -1285,7 +1273,7 @@ def delete_agent(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval @connection_group.command(name=cli_util.override('database_migration.delete_connection.command_name', 'delete'), help=u"""Deletes the Database Connection represented by the specified connection ID. \n[Command Reference](deleteConnection)""") -@cli_util.option('--connection-id', required=True, help=u"""The OCID of the database connection""") +@cli_util.option('--connection-id', required=True, help=u"""The OCID of the database connection.""") @cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") @cli_util.confirm_delete_option @cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") @@ -1537,30 +1525,8 @@ def get_advisor_report(ctx, from_json, job_id): cli_util.render_response(result, ctx) -@agent_group.command(name=cli_util.override('database_migration.get_agent.command_name', 'get'), help=u"""Display the ODMS Agent configuration. \n[Command Reference](getAgent)""") -@cli_util.option('--agent-id', required=True, help=u"""The OCID of the agent""") -@json_skeleton_utils.get_cli_json_input_option({}) -@cli_util.help_option -@click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={}, output_type={'module': 'database_migration', 'class': 'Agent'}) -@cli_util.wrap_exceptions -def get_agent(ctx, from_json, agent_id): - - if isinstance(agent_id, six.string_types) and len(agent_id.strip()) == 0: - raise click.UsageError('Parameter --agent-id cannot be whitespace or empty string') - - kwargs = {} - kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) - client = cli_util.build_client('database_migration', 'database_migration', ctx) - result = client.get_agent( - agent_id=agent_id, - **kwargs - ) - cli_util.render_response(result, ctx) - - @connection_group.command(name=cli_util.override('database_migration.get_connection.command_name', 'get'), help=u"""Display Database Connection details. \n[Command Reference](getConnection)""") -@cli_util.option('--connection-id', required=True, help=u"""The OCID of the database connection""") +@cli_util.option('--connection-id', required=True, help=u"""The OCID of the database connection.""") @json_skeleton_utils.get_cli_json_input_option({}) @cli_util.help_option @click.pass_context @@ -1695,29 +1661,48 @@ def get_work_request(ctx, from_json, work_request_id): cli_util.render_response(result, ctx) -@agent_image_summary_group.command(name=cli_util.override('database_migration.list_agent_images.command_name', 'list-agent-images'), help=u"""Get details of the ODMS Agent Images available to install on-premises. \n[Command Reference](listAgentImages)""") +@connection_summary_group.command(name=cli_util.override('database_migration.list_connections.command_name', 'list-connections'), help=u"""List all Database Connections. \n[Command Reference](listConnections)""") +@cli_util.option('--compartment-id', required=True, help=u"""The ID of the compartment in which to list resources.""") +@cli_util.option('--technology-type', type=custom_types.CliCaseInsensitiveChoice(["OCI_AUTONOMOUS_DATABASE", "OCI_MYSQL", "ORACLE_DATABASE", "ORACLE_EXADATA", "AMAZON_RDS_ORACLE", "AMAZON_AURORA_MYSQL", "AMAZON_RDS_MYSQL", "AZURE_MYSQL", "GOOGLE_CLOUD_SQL_MYSQL", "MYSQL_SERVER"]), multiple=True, help=u"""The array of technology types.""") +@cli_util.option('--connection-type', type=custom_types.CliCaseInsensitiveChoice(["MYSQL", "ORACLE"]), multiple=True, help=u"""The array of connection types.""") +@cli_util.option('--source-connection-id', help=u"""The OCID of the source database connection.""") +@cli_util.option('--display-name', help=u"""A filter to return only resources that match the entire display name given.""") @cli_util.option('--limit', type=click.INT, help=u"""The maximum number of items to return.""") @cli_util.option('--page', help=u"""The page token representing the page at which to start retrieving results. This is usually retrieved from a previous list call.""") +@cli_util.option('--sort-by', type=custom_types.CliCaseInsensitiveChoice(["timeCreated", "displayName"]), help=u"""The field to sort by. Only one sort order may be provided. Default order for timeCreated is descending. Default order for displayName is ascending. If no value is specified timeCreated is default.""") @cli_util.option('--sort-order', type=custom_types.CliCaseInsensitiveChoice(["ASC", "DESC"]), help=u"""The sort order to use, either 'asc' or 'desc'.""") +@cli_util.option('--lifecycle-state', type=custom_types.CliCaseInsensitiveChoice(["CREATING", "UPDATING", "ACTIVE", "INACTIVE", "DELETING", "DELETED", "FAILED"]), help=u"""The current state of the Database Migration Deployment.""") @cli_util.option('--all', 'all_pages', is_flag=True, help="""Fetches all pages of results. If you provide this option, then you cannot provide the --limit option.""") @cli_util.option('--page-size', type=click.INT, help="""When fetching results, the number of results to fetch per call. Only valid when used with --all or --limit, and ignored otherwise.""") @json_skeleton_utils.get_cli_json_input_option({}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={}, output_type={'module': 'database_migration', 'class': 'AgentImageCollection'}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={}, output_type={'module': 'database_migration', 'class': 'ConnectionCollection'}) @cli_util.wrap_exceptions -def list_agent_images(ctx, from_json, all_pages, page_size, limit, page, sort_order): +def list_connections(ctx, from_json, all_pages, page_size, compartment_id, technology_type, connection_type, source_connection_id, display_name, limit, page, sort_by, sort_order, lifecycle_state): if all_pages and limit: raise click.UsageError('If you provide the --all option you cannot provide the --limit option') kwargs = {} + if technology_type is not None and len(technology_type) > 0: + kwargs['technology_type'] = technology_type + if connection_type is not None and len(connection_type) > 0: + kwargs['connection_type'] = connection_type + if source_connection_id is not None: + kwargs['source_connection_id'] = source_connection_id + if display_name is not None: + kwargs['display_name'] = display_name if limit is not None: kwargs['limit'] = limit if page is not None: kwargs['page'] = page + if sort_by is not None: + kwargs['sort_by'] = sort_by if sort_order is not None: kwargs['sort_order'] = sort_order + if lifecycle_state is not None: + kwargs['lifecycle_state'] = lifecycle_state kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) client = cli_util.build_client('database_migration', 'database_migration', ctx) if all_pages: @@ -1725,170 +1710,53 @@ def list_agent_images(ctx, from_json, all_pages, page_size, limit, page, sort_or kwargs['limit'] = page_size result = cli_util.list_call_get_all_results( - client.list_agent_images, + client.list_connections, + compartment_id=compartment_id, **kwargs ) elif limit is not None: result = cli_util.list_call_get_up_to_limit( - client.list_agent_images, + client.list_connections, limit, page_size, + compartment_id=compartment_id, **kwargs ) else: - result = client.list_agent_images( + result = client.list_connections( + compartment_id=compartment_id, **kwargs ) cli_util.render_response(result, ctx) -@agent_summary_group.command(name=cli_util.override('database_migration.list_agents.command_name', 'list-agents'), help=u"""Display the name of all the existing ODMS Agents in the server. \n[Command Reference](listAgents)""") -@cli_util.option('--compartment-id', required=True, help=u"""The ID of the compartment in which to list resources.""") +@excluded_object_summary_group.command(name=cli_util.override('database_migration.list_excluded_objects.command_name', 'list-excluded-objects'), help=u"""List the excluded database objects. \n[Command Reference](listExcludedObjects)""") +@cli_util.option('--job-id', required=True, help=u"""The OCID of the job""") @cli_util.option('--limit', type=click.INT, help=u"""The maximum number of items to return.""") @cli_util.option('--page', help=u"""The page token representing the page at which to start retrieving results. This is usually retrieved from a previous list call.""") -@cli_util.option('--sort-by', type=custom_types.CliCaseInsensitiveChoice(["timeCreated", "displayName"]), help=u"""The field to sort by. Only one sort order may be provided. Default order for timeCreated is descending. Default order for displayName is ascending. If no value is specified timeCreated is default.""") @cli_util.option('--sort-order', type=custom_types.CliCaseInsensitiveChoice(["ASC", "DESC"]), help=u"""The sort order to use, either 'asc' or 'desc'.""") -@cli_util.option('--display-name', help=u"""A filter to return only resources that match the entire display name given.""") -@cli_util.option('--lifecycle-state', type=custom_types.CliCaseInsensitiveChoice(["CREATING", "UPDATING", "ACTIVE", "INACTIVE", "DELETING", "DELETED", "FAILED"]), help=u"""The current state of the Database Migration Deployment.""") +@cli_util.option('--sort-by', type=custom_types.CliCaseInsensitiveChoice(["type", "reasonCategory"]), help=u"""The field to sort by. Only one sort order may be provided. Default order for reasonCategory is ascending. If no value is specified reasonCategory is default.""") +@cli_util.option('--type', help=u"""Excluded object type.""") +@cli_util.option('--owner', help=u"""Excluded object owner""") +@cli_util.option('--object', help=u"""Excluded object name""") +@cli_util.option('--owner-contains', help=u"""Excluded object owner which contains provided value.""") +@cli_util.option('--object-contains', help=u"""Excluded object name which contains provided value.""") +@cli_util.option('--reason-category', type=custom_types.CliCaseInsensitiveChoice(["ORACLE_MAINTAINED", "GG_UNSUPPORTED", "USER_EXCLUDED", "MANDATORY_EXCLUDED", "USER_EXCLUDED_TYPE"]), help=u"""Reason category for the excluded object""") +@cli_util.option('--source-rule', help=u"""Exclude object rule that matches the excluded object, if applicable.""") @cli_util.option('--all', 'all_pages', is_flag=True, help="""Fetches all pages of results. If you provide this option, then you cannot provide the --limit option.""") @cli_util.option('--page-size', type=click.INT, help="""When fetching results, the number of results to fetch per call. Only valid when used with --all or --limit, and ignored otherwise.""") @json_skeleton_utils.get_cli_json_input_option({}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={}, output_type={'module': 'database_migration', 'class': 'AgentCollection'}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={}, output_type={'module': 'database_migration', 'class': 'ExcludedObjectSummaryCollection'}) @cli_util.wrap_exceptions -def list_agents(ctx, from_json, all_pages, page_size, compartment_id, limit, page, sort_by, sort_order, display_name, lifecycle_state): +def list_excluded_objects(ctx, from_json, all_pages, page_size, job_id, limit, page, sort_order, sort_by, type, owner, object, owner_contains, object_contains, reason_category, source_rule): if all_pages and limit: raise click.UsageError('If you provide the --all option you cannot provide the --limit option') - - kwargs = {} - if limit is not None: - kwargs['limit'] = limit - if page is not None: - kwargs['page'] = page - if sort_by is not None: - kwargs['sort_by'] = sort_by - if sort_order is not None: - kwargs['sort_order'] = sort_order - if display_name is not None: - kwargs['display_name'] = display_name - if lifecycle_state is not None: - kwargs['lifecycle_state'] = lifecycle_state - kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) - client = cli_util.build_client('database_migration', 'database_migration', ctx) - if all_pages: - if page_size: - kwargs['limit'] = page_size - - result = cli_util.list_call_get_all_results( - client.list_agents, - compartment_id=compartment_id, - **kwargs - ) - elif limit is not None: - result = cli_util.list_call_get_up_to_limit( - client.list_agents, - limit, - page_size, - compartment_id=compartment_id, - **kwargs - ) - else: - result = client.list_agents( - compartment_id=compartment_id, - **kwargs - ) - cli_util.render_response(result, ctx) - - -@connection_summary_group.command(name=cli_util.override('database_migration.list_connections.command_name', 'list-connections'), help=u"""List all Database Connections. \n[Command Reference](listConnections)""") -@cli_util.option('--compartment-id', required=True, help=u"""The ID of the compartment in which to list resources.""") -@cli_util.option('--display-name', help=u"""A filter to return only resources that match the entire display name given.""") -@cli_util.option('--limit', type=click.INT, help=u"""The maximum number of items to return.""") -@cli_util.option('--page', help=u"""The page token representing the page at which to start retrieving results. This is usually retrieved from a previous list call.""") -@cli_util.option('--sort-by', type=custom_types.CliCaseInsensitiveChoice(["timeCreated", "displayName"]), help=u"""The field to sort by. Only one sort order may be provided. Default order for timeCreated is descending. Default order for displayName is ascending. If no value is specified timeCreated is default.""") -@cli_util.option('--sort-order', type=custom_types.CliCaseInsensitiveChoice(["ASC", "DESC"]), help=u"""The sort order to use, either 'asc' or 'desc'.""") -@cli_util.option('--lifecycle-state', type=custom_types.CliCaseInsensitiveChoice(["CREATING", "UPDATING", "ACTIVE", "INACTIVE", "DELETING", "DELETED", "FAILED"]), help=u"""The current state of the Database Migration Deployment.""") -@cli_util.option('--all', 'all_pages', is_flag=True, help="""Fetches all pages of results. If you provide this option, then you cannot provide the --limit option.""") -@cli_util.option('--page-size', type=click.INT, help="""When fetching results, the number of results to fetch per call. Only valid when used with --all or --limit, and ignored otherwise.""") -@json_skeleton_utils.get_cli_json_input_option({}) -@cli_util.help_option -@click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={}, output_type={'module': 'database_migration', 'class': 'ConnectionCollection'}) -@cli_util.wrap_exceptions -def list_connections(ctx, from_json, all_pages, page_size, compartment_id, display_name, limit, page, sort_by, sort_order, lifecycle_state): - - if all_pages and limit: - raise click.UsageError('If you provide the --all option you cannot provide the --limit option') - - kwargs = {} - if display_name is not None: - kwargs['display_name'] = display_name - if limit is not None: - kwargs['limit'] = limit - if page is not None: - kwargs['page'] = page - if sort_by is not None: - kwargs['sort_by'] = sort_by - if sort_order is not None: - kwargs['sort_order'] = sort_order - if lifecycle_state is not None: - kwargs['lifecycle_state'] = lifecycle_state - kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) - client = cli_util.build_client('database_migration', 'database_migration', ctx) - if all_pages: - if page_size: - kwargs['limit'] = page_size - - result = cli_util.list_call_get_all_results( - client.list_connections, - compartment_id=compartment_id, - **kwargs - ) - elif limit is not None: - result = cli_util.list_call_get_up_to_limit( - client.list_connections, - limit, - page_size, - compartment_id=compartment_id, - **kwargs - ) - else: - result = client.list_connections( - compartment_id=compartment_id, - **kwargs - ) - cli_util.render_response(result, ctx) - - -@excluded_object_summary_group.command(name=cli_util.override('database_migration.list_excluded_objects.command_name', 'list-excluded-objects'), help=u"""List the excluded database objects. \n[Command Reference](listExcludedObjects)""") -@cli_util.option('--job-id', required=True, help=u"""The OCID of the job""") -@cli_util.option('--limit', type=click.INT, help=u"""The maximum number of items to return.""") -@cli_util.option('--page', help=u"""The page token representing the page at which to start retrieving results. This is usually retrieved from a previous list call.""") -@cli_util.option('--sort-order', type=custom_types.CliCaseInsensitiveChoice(["ASC", "DESC"]), help=u"""The sort order to use, either 'asc' or 'desc'.""") -@cli_util.option('--sort-by', type=custom_types.CliCaseInsensitiveChoice(["type", "reasonCategory"]), help=u"""The field to sort by. Only one sort order may be provided. Default order for reasonCategory is ascending. If no value is specified reasonCategory is default.""") -@cli_util.option('--type', help=u"""Excluded object type.""") -@cli_util.option('--owner', help=u"""Excluded object owner""") -@cli_util.option('--object', help=u"""Excluded object name""") -@cli_util.option('--owner-contains', help=u"""Excluded object owner which contains provided value.""") -@cli_util.option('--object-contains', help=u"""Excluded object name which contains provided value.""") -@cli_util.option('--reason-category', type=custom_types.CliCaseInsensitiveChoice(["ORACLE_MAINTAINED", "GG_UNSUPPORTED", "USER_EXCLUDED", "MANDATORY_EXCLUDED", "USER_EXCLUDED_TYPE"]), help=u"""Reason category for the excluded object""") -@cli_util.option('--source-rule', help=u"""Exclude object rule that matches the excluded object, if applicable.""") -@cli_util.option('--all', 'all_pages', is_flag=True, help="""Fetches all pages of results. If you provide this option, then you cannot provide the --limit option.""") -@cli_util.option('--page-size', type=click.INT, help="""When fetching results, the number of results to fetch per call. Only valid when used with --all or --limit, and ignored otherwise.""") -@json_skeleton_utils.get_cli_json_input_option({}) -@cli_util.help_option -@click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={}, output_type={'module': 'database_migration', 'class': 'ExcludedObjectSummaryCollection'}) -@cli_util.wrap_exceptions -def list_excluded_objects(ctx, from_json, all_pages, page_size, job_id, limit, page, sort_order, sort_by, type, owner, object, owner_contains, object_contains, reason_category, source_rule): - - if all_pages and limit: - raise click.UsageError('If you provide the --all option you cannot provide the --limit option') - - if isinstance(job_id, six.string_types) and len(job_id.strip()) == 0: - raise click.UsageError('Parameter --job-id cannot be whitespace or empty string') + + if isinstance(job_id, six.string_types) and len(job_id.strip()) == 0: + raise click.UsageError('Parameter --job-id cannot be whitespace or empty string') kwargs = {} if limit is not None: @@ -2052,6 +1920,7 @@ def list_jobs(ctx, from_json, all_pages, page_size, migration_id, display_name, @migration_object_type_summary_group.command(name=cli_util.override('database_migration.list_migration_object_types.command_name', 'list-migration-object-types'), help=u"""Display sample object types to exclude or include for a Migration. \n[Command Reference](listMigrationObjectTypes)""") +@cli_util.option('--connection-type', required=True, type=custom_types.CliCaseInsensitiveChoice(["MYSQL", "ORACLE"]), help=u"""The connection type for migration objects.""") @cli_util.option('--sort-by', type=custom_types.CliCaseInsensitiveChoice(["name"]), help=u"""The field to sort by. Only one sort order may be provided. Default order for name is custom based on it's usage frequency. If no value is specified name is default.""") @cli_util.option('--sort-order', type=custom_types.CliCaseInsensitiveChoice(["ASC", "DESC"]), help=u"""The sort order to use, either 'asc' or 'desc'.""") @cli_util.option('--limit', type=click.INT, help=u"""The maximum number of items to return.""") @@ -2063,7 +1932,7 @@ def list_jobs(ctx, from_json, all_pages, page_size, migration_id, display_name, @click.pass_context @json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={}, output_type={'module': 'database_migration', 'class': 'MigrationObjectTypeSummaryCollection'}) @cli_util.wrap_exceptions -def list_migration_object_types(ctx, from_json, all_pages, page_size, sort_by, sort_order, limit, page): +def list_migration_object_types(ctx, from_json, all_pages, page_size, connection_type, sort_by, sort_order, limit, page): if all_pages and limit: raise click.UsageError('If you provide the --all option you cannot provide the --limit option') @@ -2085,6 +1954,7 @@ def list_migration_object_types(ctx, from_json, all_pages, page_size, sort_by, s result = cli_util.list_call_get_all_results( client.list_migration_object_types, + connection_type=connection_type, **kwargs ) elif limit is not None: @@ -2092,10 +1962,12 @@ def list_migration_object_types(ctx, from_json, all_pages, page_size, sort_by, s client.list_migration_object_types, limit, page_size, + connection_type=connection_type, **kwargs ) else: result = client.list_migration_object_types( + connection_type=connection_type, **kwargs ) cli_util.render_response(result, ctx) @@ -2394,15 +2266,83 @@ def list_work_requests(ctx, from_json, all_pages, page_size, compartment_id, res @migration_group.command(name=cli_util.override('database_migration.remove_migration_objects.command_name', 'remove'), help=u"""Remove excluded/included objects. \n[Command Reference](removeMigrationObjects)""") @cli_util.option('--migration-id', required=True, help=u"""The OCID of the migration""") +@cli_util.option('--database-combination', required=True, type=custom_types.CliCaseInsensitiveChoice(["MYSQL", "ORACLE"]), help=u"""The combination of source and target databases participating in a migration. Example: ORACLE means the migration is meant for migrating Oracle source and target databases.""") +@cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") +@json_skeleton_utils.get_cli_json_input_option({}) +@cli_util.help_option +@click.pass_context +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={}) +@cli_util.wrap_exceptions +def remove_migration_objects(ctx, from_json, migration_id, database_combination, if_match): + + if isinstance(migration_id, six.string_types) and len(migration_id.strip()) == 0: + raise click.UsageError('Parameter --migration-id cannot be whitespace or empty string') + + kwargs = {} + if if_match is not None: + kwargs['if_match'] = if_match + kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) + + _details = {} + _details['databaseCombination'] = database_combination + + client = cli_util.build_client('database_migration', 'database_migration', ctx) + result = client.remove_migration_objects( + migration_id=migration_id, + remove_migration_objects_details=_details, + **kwargs + ) + cli_util.render_response(result, ctx) + + +@migration_group.command(name=cli_util.override('database_migration.remove_migration_objects_my_sql_migration_object_collection.command_name', 'remove-migration-objects-my-sql-migration-object-collection'), help=u"""Remove excluded/included objects. \n[Command Reference](removeMigrationObjects)""") +@cli_util.option('--migration-id', required=True, help=u"""The OCID of the migration""") +@cli_util.option('--items', required=True, type=custom_types.CLI_COMPLEX_TYPE, help=u"""An array of database objects that are either included or excluded from the migration.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--bulk-include-exclude-data', help=u"""Specifies the database objects to be excluded from the migration in bulk. The definition accepts input in a CSV format, newline separated for each entry. More details can be found in the documentation.""") +@cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") +@json_skeleton_utils.get_cli_json_input_option({'items': {'module': 'database_migration', 'class': 'list[MySqlDatabaseObjectSummary]'}}) +@cli_util.help_option +@click.pass_context +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'items': {'module': 'database_migration', 'class': 'list[MySqlDatabaseObjectSummary]'}}) +@cli_util.wrap_exceptions +def remove_migration_objects_my_sql_migration_object_collection(ctx, from_json, migration_id, items, bulk_include_exclude_data, if_match): + + if isinstance(migration_id, six.string_types) and len(migration_id.strip()) == 0: + raise click.UsageError('Parameter --migration-id cannot be whitespace or empty string') + + kwargs = {} + if if_match is not None: + kwargs['if_match'] = if_match + kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) + + _details = {} + _details['items'] = cli_util.parse_json_parameter("items", items) + + if bulk_include_exclude_data is not None: + _details['bulkIncludeExcludeData'] = bulk_include_exclude_data + + _details['databaseCombination'] = 'MYSQL' + + client = cli_util.build_client('database_migration', 'database_migration', ctx) + result = client.remove_migration_objects( + migration_id=migration_id, + remove_migration_objects_details=_details, + **kwargs + ) + cli_util.render_response(result, ctx) + + +@migration_group.command(name=cli_util.override('database_migration.remove_migration_objects_oracle_migration_object_collection.command_name', 'remove-migration-objects-oracle-migration-object-collection'), help=u"""Remove excluded/included objects. \n[Command Reference](removeMigrationObjects)""") +@cli_util.option('--migration-id', required=True, help=u"""The OCID of the migration""") @cli_util.option('--items', required=True, type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to exclude/include from migration""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--csv-text', help=u"""Database objects to exclude/include from migration in CSV format. The items field will be ignored if this field is not null.""") +@cli_util.option('--bulk-include-exclude-data', help=u"""Specifies the database objects to be excluded from the migration in bulk. The definition accepts input in a CSV format, newline separated for each entry. More details can be found in the documentation.""") @cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") -@json_skeleton_utils.get_cli_json_input_option({'items': {'module': 'database_migration', 'class': 'list[MigrationObjectSummary]'}}) +@json_skeleton_utils.get_cli_json_input_option({'items': {'module': 'database_migration', 'class': 'list[OracleDatabaseObjectSummary]'}}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'items': {'module': 'database_migration', 'class': 'list[MigrationObjectSummary]'}}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'items': {'module': 'database_migration', 'class': 'list[OracleDatabaseObjectSummary]'}}) @cli_util.wrap_exceptions -def remove_migration_objects(ctx, from_json, migration_id, items, csv_text, if_match): +def remove_migration_objects_oracle_migration_object_collection(ctx, from_json, migration_id, items, bulk_include_exclude_data, if_match): if isinstance(migration_id, six.string_types) and len(migration_id.strip()) == 0: raise click.UsageError('Parameter --migration-id cannot be whitespace or empty string') @@ -2415,8 +2355,10 @@ def remove_migration_objects(ctx, from_json, migration_id, items, csv_text, if_m _details = {} _details['items'] = cli_util.parse_json_parameter("items", items) - if csv_text is not None: - _details['csvText'] = csv_text + if bulk_include_exclude_data is not None: + _details['bulkIncludeExcludeData'] = bulk_include_exclude_data + + _details['databaseCombination'] = 'ORACLE' client = cli_util.build_client('database_migration', 'database_migration', ctx) result = client.remove_migration_objects( @@ -2430,7 +2372,7 @@ def remove_migration_objects(ctx, from_json, migration_id, items, csv_text, if_m @job_group.command(name=cli_util.override('database_migration.resume_job.command_name', 'resume'), help=u"""Resume a migration Job. \n[Command Reference](resumeJob)""") @cli_util.option('--job-id', required=True, help=u"""The OCID of the job""") @cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") -@cli_util.option('--wait-after', type=custom_types.CliCaseInsensitiveChoice(["ODMS_VALIDATE_TGT", "ODMS_VALIDATE_SRC", "ODMS_VALIDATE_PREMIGRATION_ADVISOR", "ODMS_VALIDATE_GG_HUB", "ODMS_VALIDATE_GG_SERVICE", "ODMS_VALIDATE_DATAPUMP_SETTINGS", "ODMS_VALIDATE_DATAPUMP_SETTINGS_SRC", "ODMS_VALIDATE_DATAPUMP_SETTINGS_TGT", "ODMS_VALIDATE_DATAPUMP_SRC", "ODMS_VALIDATE_DATAPUMP_ESTIMATE_SRC", "ODMS_INITIALIZE_GGS", "ODMS_VALIDATE", "ODMS_PREPARE", "ODMS_INITIAL_LOAD_EXPORT", "ODMS_DATA_UPLOAD", "ODMS_INITIAL_LOAD_IMPORT", "ODMS_POST_INITIAL_LOAD", "ODMS_PREPARE_REPLICATION_TARGET", "ODMS_MONITOR_REPLICATION_LAG", "ODMS_SWITCHOVER", "ODMS_CLEANUP"]), help=u"""Name of a migration phase. The Job will wait after executing this phase until Resume Job endpoint is called again.""") +@cli_util.option('--wait-after', type=custom_types.CliCaseInsensitiveChoice(["ODMS_VALIDATE_TGT", "ODMS_VALIDATE_SRC", "ODMS_VALIDATE_PREMIGRATION_ADVISOR", "ODMS_VALIDATE_GG_HUB", "ODMS_VALIDATE_DATAPUMP_SETTINGS", "ODMS_VALIDATE_DATAPUMP_SETTINGS_SRC", "ODMS_VALIDATE_DATAPUMP_SETTINGS_TGT", "ODMS_VALIDATE_DATAPUMP_SRC", "ODMS_VALIDATE_DATAPUMP_ESTIMATE_SRC", "ODMS_FETCH_METADATA_SRC", "ODMS_FETCH_METADATA_TGT", "ODMS_VALIDATE", "ODMS_PREPARE", "ODMS_INITIALIZE_REPLICATION_INFRASTRUCTURE", "ODMS_INITIAL_LOAD_EXPORT", "ODMS_DATA_UPLOAD", "ODMS_INITIAL_LOAD_EXPORT_DATA_UPLOAD", "ODMS_INITIAL_LOAD_IMPORT", "ODMS_POST_INITIAL_LOAD", "ODMS_PREPARE_REPLICATION_TARGET", "ODMS_MONITOR_REPLICATION_LAG", "ODMS_SWITCHOVER", "ODMS_CLEANUP"]), help=u"""Name of a migration phase. The Job will wait after executing this phase until Resume Job endpoint is called again.""") @cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "UNKNOWN", "TERMINATED", "FAILED", "SUCCEEDED", "WAITING", "CANCELING", "CANCELED"]), multiple=True, help="""This operation creates, modifies or deletes a resource that has a defined lifecycle state. Specify this option to perform the action and then wait until the resource reaches a given lifecycle state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") @cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the resource to reach the lifecycle state defined by --wait-for-state. Defaults to 1200 seconds.""") @cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the resource has reached the lifecycle state defined by --wait-for-state. Defaults to 30 seconds.""") @@ -2511,7 +2453,7 @@ def retrieve_supported_phases(ctx, from_json, migration_id): @job_group.command(name=cli_util.override('database_migration.start_migration.command_name', 'start-migration'), help=u"""Start Migration job. \n[Command Reference](startMigration)""") @cli_util.option('--migration-id', required=True, help=u"""The OCID of the migration""") @cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") -@cli_util.option('--wait-after', type=custom_types.CliCaseInsensitiveChoice(["ODMS_VALIDATE_TGT", "ODMS_VALIDATE_SRC", "ODMS_VALIDATE_PREMIGRATION_ADVISOR", "ODMS_VALIDATE_GG_HUB", "ODMS_VALIDATE_GG_SERVICE", "ODMS_VALIDATE_DATAPUMP_SETTINGS", "ODMS_VALIDATE_DATAPUMP_SETTINGS_SRC", "ODMS_VALIDATE_DATAPUMP_SETTINGS_TGT", "ODMS_VALIDATE_DATAPUMP_SRC", "ODMS_VALIDATE_DATAPUMP_ESTIMATE_SRC", "ODMS_INITIALIZE_GGS", "ODMS_VALIDATE", "ODMS_PREPARE", "ODMS_INITIAL_LOAD_EXPORT", "ODMS_DATA_UPLOAD", "ODMS_INITIAL_LOAD_IMPORT", "ODMS_POST_INITIAL_LOAD", "ODMS_PREPARE_REPLICATION_TARGET", "ODMS_MONITOR_REPLICATION_LAG", "ODMS_SWITCHOVER", "ODMS_CLEANUP"]), help=u"""Name of a migration phase. The Job will wait after executing this phase until the Resume Job endpoint is called.""") +@cli_util.option('--wait-after', type=custom_types.CliCaseInsensitiveChoice(["ODMS_VALIDATE_TGT", "ODMS_VALIDATE_SRC", "ODMS_VALIDATE_PREMIGRATION_ADVISOR", "ODMS_VALIDATE_GG_HUB", "ODMS_VALIDATE_DATAPUMP_SETTINGS", "ODMS_VALIDATE_DATAPUMP_SETTINGS_SRC", "ODMS_VALIDATE_DATAPUMP_SETTINGS_TGT", "ODMS_VALIDATE_DATAPUMP_SRC", "ODMS_VALIDATE_DATAPUMP_ESTIMATE_SRC", "ODMS_FETCH_METADATA_SRC", "ODMS_FETCH_METADATA_TGT", "ODMS_VALIDATE", "ODMS_PREPARE", "ODMS_INITIALIZE_REPLICATION_INFRASTRUCTURE", "ODMS_INITIAL_LOAD_EXPORT", "ODMS_DATA_UPLOAD", "ODMS_INITIAL_LOAD_EXPORT_DATA_UPLOAD", "ODMS_INITIAL_LOAD_IMPORT", "ODMS_POST_INITIAL_LOAD", "ODMS_PREPARE_REPLICATION_TARGET", "ODMS_MONITOR_REPLICATION_LAG", "ODMS_SWITCHOVER", "ODMS_CLEANUP"]), help=u"""Name of a migration phase. The Job will wait after executing this phase until the Resume Job endpoint is called.""") @cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") @cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") @cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") @@ -2571,31 +2513,38 @@ def start_migration(ctx, from_json, wait_for_state, max_wait_seconds, wait_inter cli_util.render_response(result, ctx) -@agent_group.command(name=cli_util.override('database_migration.update_agent.command_name', 'update'), help=u"""Modifies the ODMS Agent represented by the given ODMS Agent ID. \n[Command Reference](updateAgent)""") -@cli_util.option('--agent-id', required=True, help=u"""The OCID of the agent""") -@cli_util.option('--display-name', help=u"""ODMS Agent name""") -@cli_util.option('--stream-id', help=u"""The OCID of the Stream""") -@cli_util.option('--public-key', help=u"""ODMS Agent public key.""") -@cli_util.option('--version-parameterconflict', help=u"""ODMS Agent version""") -@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only. Example: `{\"bar-key\": \"value\"}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@connection_group.command(name=cli_util.override('database_migration.update_connection.command_name', 'update'), help=u"""Update Database Connection resource details. \n[Command Reference](updateConnection)""") +@cli_util.option('--connection-id', required=True, help=u"""The OCID of the database connection.""") +@cli_util.option('--connection-type', type=custom_types.CliCaseInsensitiveChoice(["MYSQL", "ORACLE"]), help=u"""Defines the type of connection. For example, ORACLE.""") +@cli_util.option('--display-name', help=u"""A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--description', help=u"""A user-friendly description. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {\"Department\": \"Finance\"}""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--vault-id', help=u"""OCI resource ID.""") +@cli_util.option('--key-id', help=u"""The OCID of the key used in cryptographic operations.""") +@cli_util.option('--subnet-id', help=u"""OCI resource ID.""") +@cli_util.option('--nsg-ids', type=custom_types.CLI_COMPLEX_TYPE, help=u"""An array of Network Security Group OCIDs used to define network access for Connections.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--username', help=u"""The username (credential) used when creating or updating this resource.""") +@cli_util.option('--password', help=u"""The password (credential) used when creating or updating this resource.""") +@cli_util.option('--replication-username', help=u"""The username (credential) used when creating or updating this resource.""") +@cli_util.option('--replication-password', help=u"""The password (credential) used when creating or updating this resource.""") @cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") @cli_util.option('--force', help="""Perform update without prompting for confirmation.""", is_flag=True) -@cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["CREATING", "UPDATING", "ACTIVE", "INACTIVE", "DELETING", "DELETED", "FAILED"]), multiple=True, help="""This operation creates, modifies or deletes a resource that has a defined lifecycle state. Specify this option to perform the action and then wait until the resource reaches a given lifecycle state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") -@cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the resource to reach the lifecycle state defined by --wait-for-state. Defaults to 1200 seconds.""") -@cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the resource has reached the lifecycle state defined by --wait-for-state. Defaults to 30 seconds.""") -@json_skeleton_utils.get_cli_json_input_option({'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}) +@cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") +@cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") +@cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") +@json_skeleton_utils.get_cli_json_input_option({'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'nsg-ids': {'module': 'database_migration', 'class': 'list[string]'}}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}, output_type={'module': 'database_migration', 'class': 'Agent'}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'nsg-ids': {'module': 'database_migration', 'class': 'list[string]'}}) @cli_util.wrap_exceptions -def update_agent(ctx, from_json, force, wait_for_state, max_wait_seconds, wait_interval_seconds, agent_id, display_name, stream_id, public_key, version_parameterconflict, freeform_tags, defined_tags, if_match): +def update_connection(ctx, from_json, force, wait_for_state, max_wait_seconds, wait_interval_seconds, connection_id, connection_type, display_name, description, freeform_tags, defined_tags, vault_id, key_id, subnet_id, nsg_ids, username, password, replication_username, replication_password, if_match): - if isinstance(agent_id, six.string_types) and len(agent_id.strip()) == 0: - raise click.UsageError('Parameter --agent-id cannot be whitespace or empty string') + if isinstance(connection_id, six.string_types) and len(connection_id.strip()) == 0: + raise click.UsageError('Parameter --connection-id cannot be whitespace or empty string') if not force: - if freeform_tags or defined_tags: - if not click.confirm("WARNING: Updates to freeform-tags and defined-tags will replace any existing values. Are you sure you want to continue?"): + if freeform_tags or defined_tags or nsg_ids: + if not click.confirm("WARNING: Updates to freeform-tags and defined-tags and nsg-ids will replace any existing values. Are you sure you want to continue?"): ctx.abort() kwargs = {} @@ -2605,17 +2554,14 @@ def update_agent(ctx, from_json, force, wait_for_state, max_wait_seconds, wait_i _details = {} + if connection_type is not None: + _details['connectionType'] = connection_type + if display_name is not None: _details['displayName'] = display_name - if stream_id is not None: - _details['streamId'] = stream_id - - if public_key is not None: - _details['publicKey'] = public_key - - if version_parameterconflict is not None: - _details['version'] = version_parameterconflict + if description is not None: + _details['description'] = description if freeform_tags is not None: _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) @@ -2623,71 +2569,104 @@ def update_agent(ctx, from_json, force, wait_for_state, max_wait_seconds, wait_i if defined_tags is not None: _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) + if vault_id is not None: + _details['vaultId'] = vault_id + + if key_id is not None: + _details['keyId'] = key_id + + if subnet_id is not None: + _details['subnetId'] = subnet_id + + if nsg_ids is not None: + _details['nsgIds'] = cli_util.parse_json_parameter("nsg_ids", nsg_ids) + + if username is not None: + _details['username'] = username + + if password is not None: + _details['password'] = password + + if replication_username is not None: + _details['replicationUsername'] = replication_username + + if replication_password is not None: + _details['replicationPassword'] = replication_password + client = cli_util.build_client('database_migration', 'database_migration', ctx) - result = client.update_agent( - agent_id=agent_id, - update_agent_details=_details, + result = client.update_connection( + connection_id=connection_id, + update_connection_details=_details, **kwargs ) if wait_for_state: - if hasattr(client, 'get_agent') and callable(getattr(client, 'get_agent')): + if hasattr(client, 'get_work_request') and callable(getattr(client, 'get_work_request')): try: wait_period_kwargs = {} if max_wait_seconds is not None: wait_period_kwargs['max_wait_seconds'] = max_wait_seconds if wait_interval_seconds is not None: wait_period_kwargs['max_interval_seconds'] = wait_interval_seconds + if 'opc-work-request-id' not in result.headers: + click.echo('Encountered error while waiting for work request to enter the specified state. Outputting last known resource state') + cli_util.render_response(result, ctx) + return - click.echo('Action completed. Waiting until the resource has entered state: {}'.format(wait_for_state), file=sys.stderr) - result = oci.wait_until(client, client.get_agent(result.data.id), 'lifecycle_state', wait_for_state, **wait_period_kwargs) + click.echo('Action completed. Waiting until the work request has entered state: {}'.format(wait_for_state), file=sys.stderr) + result = oci.wait_until(client, client.get_work_request(result.headers['opc-work-request-id']), 'status', wait_for_state, **wait_period_kwargs) except oci.exceptions.MaximumWaitTimeExceeded as e: # If we fail, we should show an error, but we should still provide the information to the customer - click.echo('Failed to wait until the resource entered the specified state. Outputting last known resource state', file=sys.stderr) + click.echo('Failed to wait until the work request entered the specified state. Outputting last known resource state', file=sys.stderr) cli_util.render_response(result, ctx) sys.exit(2) except Exception: - click.echo('Encountered error while waiting for resource to enter the specified state. Outputting last known resource state', file=sys.stderr) + click.echo('Encountered error while waiting for work request to enter the specified state. Outputting last known resource state', file=sys.stderr) cli_util.render_response(result, ctx) raise else: - click.echo('Unable to wait for the resource to enter the specified state', file=sys.stderr) + click.echo('Unable to wait for the work request to enter the specified state', file=sys.stderr) cli_util.render_response(result, ctx) -@connection_group.command(name=cli_util.override('database_migration.update_connection.command_name', 'update'), help=u"""Update Database Connection resource details. \n[Command Reference](updateConnection)""") -@cli_util.option('--connection-id', required=True, help=u"""The OCID of the database connection""") -@cli_util.option('--display-name', help=u"""Database Connection display name identifier.""") -@cli_util.option('--database-id', help=u"""The OCID of the cloud database.""") -@cli_util.option('--connect-descriptor', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--certificate-tdn', help=u"""This name is the distinguished name used while creating the certificate on target database. Not required for source container database connections.""") -@cli_util.option('--tls-wallet', help=u"""cwallet.sso containing containing the TCPS/SSL certificate; base64 encoded String. Not required for source container database connections.""") -@cli_util.option('--tls-keystore', help=u"""keystore.jks file contents; base64 encoded String. Not required for source container database connections.""") -@cli_util.option('--ssh-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--admin-credentials', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--replication-credentials', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--private-endpoint', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--vault-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only. Example: `{\"bar-key\": \"value\"}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@connection_group.command(name=cli_util.override('database_migration.update_connection_update_oracle_connection_details.command_name', 'update-connection-update-oracle-connection-details'), help=u"""Update Database Connection resource details. \n[Command Reference](updateConnection)""") +@cli_util.option('--connection-id', required=True, help=u"""The OCID of the database connection.""") +@cli_util.option('--display-name', help=u"""A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--description', help=u"""A user-friendly description. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {\"Department\": \"Finance\"}""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--vault-id', help=u"""OCI resource ID.""") +@cli_util.option('--key-id', help=u"""The OCID of the key used in cryptographic operations.""") +@cli_util.option('--subnet-id', help=u"""OCI resource ID.""") @cli_util.option('--nsg-ids', type=custom_types.CLI_COMPLEX_TYPE, help=u"""An array of Network Security Group OCIDs used to define network access for Connections.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--username', help=u"""The username (credential) used when creating or updating this resource.""") +@cli_util.option('--password', help=u"""The password (credential) used when creating or updating this resource.""") +@cli_util.option('--replication-username', help=u"""The username (credential) used when creating or updating this resource.""") +@cli_util.option('--replication-password', help=u"""The password (credential) used when creating or updating this resource.""") +@cli_util.option('--connection-string', help=u"""Connect descriptor or Easy Connect Naming method used to connect to a database.""") +@cli_util.option('--wallet', help=u"""The wallet contents used to make connections to a database. This attribute is expected to be base64 encoded.""") +@cli_util.option('--database-id', help=u"""The OCID of the database being referenced.""") +@cli_util.option('--ssh-host', help=u"""Name of the host the SSH key is valid for.""") +@cli_util.option('--ssh-key', help=u"""Private SSH key string.""") +@cli_util.option('--ssh-user', help=u"""The username (credential) used when creating or updating this resource.""") +@cli_util.option('--ssh-sudo-location', help=u"""Sudo location""") @cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") @cli_util.option('--force', help="""Perform update without prompting for confirmation.""", is_flag=True) @cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") @cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") @cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") -@json_skeleton_utils.get_cli_json_input_option({'connect-descriptor': {'module': 'database_migration', 'class': 'UpdateConnectDescriptor'}, 'ssh-details': {'module': 'database_migration', 'class': 'UpdateSshDetails'}, 'admin-credentials': {'module': 'database_migration', 'class': 'UpdateAdminCredentials'}, 'replication-credentials': {'module': 'database_migration', 'class': 'UpdateAdminCredentials'}, 'private-endpoint': {'module': 'database_migration', 'class': 'UpdatePrivateEndpoint'}, 'vault-details': {'module': 'database_migration', 'class': 'UpdateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'nsg-ids': {'module': 'database_migration', 'class': 'list[string]'}}) +@json_skeleton_utils.get_cli_json_input_option({'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'nsg-ids': {'module': 'database_migration', 'class': 'list[string]'}}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'connect-descriptor': {'module': 'database_migration', 'class': 'UpdateConnectDescriptor'}, 'ssh-details': {'module': 'database_migration', 'class': 'UpdateSshDetails'}, 'admin-credentials': {'module': 'database_migration', 'class': 'UpdateAdminCredentials'}, 'replication-credentials': {'module': 'database_migration', 'class': 'UpdateAdminCredentials'}, 'private-endpoint': {'module': 'database_migration', 'class': 'UpdatePrivateEndpoint'}, 'vault-details': {'module': 'database_migration', 'class': 'UpdateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'nsg-ids': {'module': 'database_migration', 'class': 'list[string]'}}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'nsg-ids': {'module': 'database_migration', 'class': 'list[string]'}}) @cli_util.wrap_exceptions -def update_connection(ctx, from_json, force, wait_for_state, max_wait_seconds, wait_interval_seconds, connection_id, display_name, database_id, connect_descriptor, certificate_tdn, tls_wallet, tls_keystore, ssh_details, admin_credentials, replication_credentials, private_endpoint, vault_details, freeform_tags, defined_tags, nsg_ids, if_match): +def update_connection_update_oracle_connection_details(ctx, from_json, force, wait_for_state, max_wait_seconds, wait_interval_seconds, connection_id, display_name, description, freeform_tags, defined_tags, vault_id, key_id, subnet_id, nsg_ids, username, password, replication_username, replication_password, connection_string, wallet, database_id, ssh_host, ssh_key, ssh_user, ssh_sudo_location, if_match): if isinstance(connection_id, six.string_types) and len(connection_id.strip()) == 0: raise click.UsageError('Parameter --connection-id cannot be whitespace or empty string') if not force: - if connect_descriptor or ssh_details or admin_credentials or replication_credentials or private_endpoint or vault_details or freeform_tags or defined_tags or nsg_ids: - if not click.confirm("WARNING: Updates to connect-descriptor and ssh-details and admin-credentials and replication-credentials and private-endpoint and vault-details and freeform-tags and defined-tags and nsg-ids will replace any existing values. Are you sure you want to continue?"): + if freeform_tags or defined_tags or nsg_ids: + if not click.confirm("WARNING: Updates to freeform-tags and defined-tags and nsg-ids will replace any existing values. Are you sure you want to continue?"): ctx.abort() kwargs = {} @@ -2700,44 +2679,61 @@ def update_connection(ctx, from_json, force, wait_for_state, max_wait_seconds, w if display_name is not None: _details['displayName'] = display_name - if database_id is not None: - _details['databaseId'] = database_id + if description is not None: + _details['description'] = description - if connect_descriptor is not None: - _details['connectDescriptor'] = cli_util.parse_json_parameter("connect_descriptor", connect_descriptor) + if freeform_tags is not None: + _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) - if certificate_tdn is not None: - _details['certificateTdn'] = certificate_tdn + if defined_tags is not None: + _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) - if tls_wallet is not None: - _details['tlsWallet'] = tls_wallet + if vault_id is not None: + _details['vaultId'] = vault_id - if tls_keystore is not None: - _details['tlsKeystore'] = tls_keystore + if key_id is not None: + _details['keyId'] = key_id - if ssh_details is not None: - _details['sshDetails'] = cli_util.parse_json_parameter("ssh_details", ssh_details) + if subnet_id is not None: + _details['subnetId'] = subnet_id - if admin_credentials is not None: - _details['adminCredentials'] = cli_util.parse_json_parameter("admin_credentials", admin_credentials) + if nsg_ids is not None: + _details['nsgIds'] = cli_util.parse_json_parameter("nsg_ids", nsg_ids) - if replication_credentials is not None: - _details['replicationCredentials'] = cli_util.parse_json_parameter("replication_credentials", replication_credentials) + if username is not None: + _details['username'] = username - if private_endpoint is not None: - _details['privateEndpoint'] = cli_util.parse_json_parameter("private_endpoint", private_endpoint) + if password is not None: + _details['password'] = password - if vault_details is not None: - _details['vaultDetails'] = cli_util.parse_json_parameter("vault_details", vault_details) + if replication_username is not None: + _details['replicationUsername'] = replication_username - if freeform_tags is not None: - _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) + if replication_password is not None: + _details['replicationPassword'] = replication_password - if defined_tags is not None: - _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) + if connection_string is not None: + _details['connectionString'] = connection_string - if nsg_ids is not None: - _details['nsgIds'] = cli_util.parse_json_parameter("nsg_ids", nsg_ids) + if wallet is not None: + _details['wallet'] = wallet + + if database_id is not None: + _details['databaseId'] = database_id + + if ssh_host is not None: + _details['sshHost'] = ssh_host + + if ssh_key is not None: + _details['sshKey'] = ssh_key + + if ssh_user is not None: + _details['sshUser'] = ssh_user + + if ssh_sudo_location is not None: + _details['sshSudoLocation'] = ssh_sudo_location + + _details['connectionType'] = 'ORACLE' client = cli_util.build_client('database_migration', 'database_migration', ctx) result = client.update_connection( @@ -2775,28 +2771,50 @@ def update_connection(ctx, from_json, force, wait_for_state, max_wait_seconds, w cli_util.render_response(result, ctx) -@job_group.command(name=cli_util.override('database_migration.update_job.command_name', 'update'), help=u"""Update Migration Job resource details. \n[Command Reference](updateJob)""") -@cli_util.option('--job-id', required=True, help=u"""The OCID of the job""") -@cli_util.option('--display-name', help=u"""Name of the job.""") -@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only. Example: `{\"bar-key\": \"value\"}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@connection_group.command(name=cli_util.override('database_migration.update_connection_update_mysql_connection_details.command_name', 'update-connection-update-mysql-connection-details'), help=u"""Update Database Connection resource details. \n[Command Reference](updateConnection)""") +@cli_util.option('--connection-id', required=True, help=u"""The OCID of the database connection.""") +@cli_util.option('--display-name', help=u"""A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--description', help=u"""A user-friendly description. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {\"Department\": \"Finance\"}""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--vault-id', help=u"""OCI resource ID.""") +@cli_util.option('--key-id', help=u"""The OCID of the key used in cryptographic operations.""") +@cli_util.option('--subnet-id', help=u"""OCI resource ID.""") +@cli_util.option('--nsg-ids', type=custom_types.CLI_COMPLEX_TYPE, help=u"""An array of Network Security Group OCIDs used to define network access for Connections.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--username', help=u"""The username (credential) used when creating or updating this resource.""") +@cli_util.option('--password', help=u"""The password (credential) used when creating or updating this resource.""") +@cli_util.option('--replication-username', help=u"""The username (credential) used when creating or updating this resource.""") +@cli_util.option('--replication-password', help=u"""The password (credential) used when creating or updating this resource.""") +@cli_util.option('--host', help=u"""The IP Address of the host.""") +@cli_util.option('--port', type=click.INT, help=u"""The port to be used for the connection.""") +@cli_util.option('--database-name', help=u"""The name of the database being referenced.""") +@cli_util.option('--security-protocol', help=u"""Security Type for MySQL.""") +@cli_util.option('--ssl-mode', help=u"""SSL modes for MySQL.""") +@cli_util.option('--ssl-ca', help=u"""Database Certificate - The base64 encoded content of mysql.pem file containing the server public key (for 1 and 2-way SSL).""") +@cli_util.option('--ssl-crl', help=u"""Certificates revoked by certificate authorities (CA). Server certificate must not be on this list (for 1 and 2-way SSL). Note: This is an optional and that too only applicable if TLS/MTLS option is selected.""") +@cli_util.option('--ssl-cert', help=u"""Client Certificate - The base64 encoded content of client-cert.pem file containing the client public key (for 2-way SSL).""") +@cli_util.option('--ssl-key', help=u"""Client Key - The client-key.pem containing the client private key (for 2-way SSL).""") +@cli_util.option('--additional-attributes', type=custom_types.CLI_COMPLEX_TYPE, help=u"""An array of name-value pair attribute entries. + +This option is a JSON list with items of type NameValuePair. For documentation on NameValuePair please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20230518/datatypes/NameValuePair.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--db-system-id', help=u"""The OCID of the database system being referenced.""") @cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") @cli_util.option('--force', help="""Perform update without prompting for confirmation.""", is_flag=True) -@cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "UNKNOWN", "TERMINATED", "FAILED", "SUCCEEDED", "WAITING", "CANCELING", "CANCELED"]), multiple=True, help="""This operation creates, modifies or deletes a resource that has a defined lifecycle state. Specify this option to perform the action and then wait until the resource reaches a given lifecycle state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") -@cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the resource to reach the lifecycle state defined by --wait-for-state. Defaults to 1200 seconds.""") -@cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the resource has reached the lifecycle state defined by --wait-for-state. Defaults to 30 seconds.""") -@json_skeleton_utils.get_cli_json_input_option({'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}) +@cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") +@cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") +@cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") +@json_skeleton_utils.get_cli_json_input_option({'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'nsg-ids': {'module': 'database_migration', 'class': 'list[string]'}, 'additional-attributes': {'module': 'database_migration', 'class': 'list[NameValuePair]'}}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}, output_type={'module': 'database_migration', 'class': 'Job'}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'nsg-ids': {'module': 'database_migration', 'class': 'list[string]'}, 'additional-attributes': {'module': 'database_migration', 'class': 'list[NameValuePair]'}}) @cli_util.wrap_exceptions -def update_job(ctx, from_json, force, wait_for_state, max_wait_seconds, wait_interval_seconds, job_id, display_name, freeform_tags, defined_tags, if_match): +def update_connection_update_mysql_connection_details(ctx, from_json, force, wait_for_state, max_wait_seconds, wait_interval_seconds, connection_id, display_name, description, freeform_tags, defined_tags, vault_id, key_id, subnet_id, nsg_ids, username, password, replication_username, replication_password, host, port, database_name, security_protocol, ssl_mode, ssl_ca, ssl_crl, ssl_cert, ssl_key, additional_attributes, db_system_id, if_match): - if isinstance(job_id, six.string_types) and len(job_id.strip()) == 0: - raise click.UsageError('Parameter --job-id cannot be whitespace or empty string') + if isinstance(connection_id, six.string_types) and len(connection_id.strip()) == 0: + raise click.UsageError('Parameter --connection-id cannot be whitespace or empty string') if not force: - if freeform_tags or defined_tags: - if not click.confirm("WARNING: Updates to freeform-tags and defined-tags will replace any existing values. Are you sure you want to continue?"): + if freeform_tags or defined_tags or nsg_ids or additional_attributes: + if not click.confirm("WARNING: Updates to freeform-tags and defined-tags and nsg-ids and additional-attributes will replace any existing values. Are you sure you want to continue?"): ctx.abort() kwargs = {} @@ -2809,152 +2827,78 @@ def update_job(ctx, from_json, force, wait_for_state, max_wait_seconds, wait_int if display_name is not None: _details['displayName'] = display_name + if description is not None: + _details['description'] = description + if freeform_tags is not None: _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) if defined_tags is not None: _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) - client = cli_util.build_client('database_migration', 'database_migration', ctx) - result = client.update_job( - job_id=job_id, - update_job_details=_details, - **kwargs - ) - if wait_for_state: + if vault_id is not None: + _details['vaultId'] = vault_id - if hasattr(client, 'get_job') and callable(getattr(client, 'get_job')): - try: - wait_period_kwargs = {} - if max_wait_seconds is not None: - wait_period_kwargs['max_wait_seconds'] = max_wait_seconds - if wait_interval_seconds is not None: - wait_period_kwargs['max_interval_seconds'] = wait_interval_seconds + if key_id is not None: + _details['keyId'] = key_id - click.echo('Action completed. Waiting until the resource has entered state: {}'.format(wait_for_state), file=sys.stderr) - result = oci.wait_until(client, client.get_job(result.data.id), 'lifecycle_state', wait_for_state, **wait_period_kwargs) - except oci.exceptions.MaximumWaitTimeExceeded as e: - # If we fail, we should show an error, but we should still provide the information to the customer - click.echo('Failed to wait until the resource entered the specified state. Outputting last known resource state', file=sys.stderr) - cli_util.render_response(result, ctx) - sys.exit(2) - except Exception: - click.echo('Encountered error while waiting for resource to enter the specified state. Outputting last known resource state', file=sys.stderr) - cli_util.render_response(result, ctx) - raise - else: - click.echo('Unable to wait for the resource to enter the specified state', file=sys.stderr) - cli_util.render_response(result, ctx) + if subnet_id is not None: + _details['subnetId'] = subnet_id + if nsg_ids is not None: + _details['nsgIds'] = cli_util.parse_json_parameter("nsg_ids", nsg_ids) -@migration_group.command(name=cli_util.override('database_migration.update_migration.command_name', 'update'), help=u"""Update Migration resource details. \n[Command Reference](updateMigration)""") -@cli_util.option('--migration-id', required=True, help=u"""The OCID of the migration""") -@cli_util.option('--type', type=custom_types.CliCaseInsensitiveChoice(["ONLINE", "OFFLINE"]), help=u"""Migration type.""") -@cli_util.option('--display-name', help=u"""Migration Display Name""") -@cli_util.option('--agent-id', help=u"""The OCID of the registered ODMS Agent.""") -@cli_util.option('--source-database-connection-id', help=u"""The OCID of the Source Database Connection.""") -@cli_util.option('--source-container-database-connection-id', help=u"""The OCID of the Source Container Database Connection. Only used for Online migrations. Only Connections of type Non-Autonomous can be used as source container databases. An empty value would remove the stored Connection ID.""") -@cli_util.option('--target-database-connection-id', help=u"""The OCID of the Target Database Connection.""") -@cli_util.option('--data-transfer-medium-details-v2', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--data-transfer-medium-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--dump-transfer-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--datapump-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--advisor-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--exclude-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to exclude from migration, cannot be specified alongside 'includeObjects'. If specified, the list will be replaced entirely. Empty list will remove stored excludeObjects details. + if username is not None: + _details['username'] = username -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--include-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to include from migration, cannot be specified alongside 'excludeObjects'. If specified, the list will be replaced entirely. Empty list will remove stored includeObjects details. + if password is not None: + _details['password'] = password -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--golden-gate-service-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--golden-gate-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--vault-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only. Example: `{\"bar-key\": \"value\"}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") -@cli_util.option('--force', help="""Perform update without prompting for confirmation.""", is_flag=True) -@cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") -@cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") -@cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") -@json_skeleton_utils.get_cli_json_input_option({'data-transfer-medium-details-v2': {'module': 'database_migration', 'class': 'DataTransferMediumDetailsV2'}, 'data-transfer-medium-details': {'module': 'database_migration', 'class': 'UpdateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'UpdateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'UpdateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'UpdateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateServiceDetails'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'UpdateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}) -@cli_util.help_option -@click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'data-transfer-medium-details-v2': {'module': 'database_migration', 'class': 'DataTransferMediumDetailsV2'}, 'data-transfer-medium-details': {'module': 'database_migration', 'class': 'UpdateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'UpdateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'UpdateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'UpdateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateServiceDetails'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'UpdateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}) -@cli_util.wrap_exceptions -def update_migration(ctx, from_json, force, wait_for_state, max_wait_seconds, wait_interval_seconds, migration_id, type, display_name, agent_id, source_database_connection_id, source_container_database_connection_id, target_database_connection_id, data_transfer_medium_details_v2, data_transfer_medium_details, dump_transfer_details, datapump_settings, advisor_settings, exclude_objects, include_objects, golden_gate_service_details, golden_gate_details, vault_details, freeform_tags, defined_tags, if_match): - - if isinstance(migration_id, six.string_types) and len(migration_id.strip()) == 0: - raise click.UsageError('Parameter --migration-id cannot be whitespace or empty string') - if not force: - if data_transfer_medium_details_v2 or data_transfer_medium_details or dump_transfer_details or datapump_settings or advisor_settings or exclude_objects or include_objects or golden_gate_service_details or golden_gate_details or vault_details or freeform_tags or defined_tags: - if not click.confirm("WARNING: Updates to data-transfer-medium-details-v2 and data-transfer-medium-details and dump-transfer-details and datapump-settings and advisor-settings and exclude-objects and include-objects and golden-gate-service-details and golden-gate-details and vault-details and freeform-tags and defined-tags will replace any existing values. Are you sure you want to continue?"): - ctx.abort() + if replication_username is not None: + _details['replicationUsername'] = replication_username - kwargs = {} - if if_match is not None: - kwargs['if_match'] = if_match - kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) + if replication_password is not None: + _details['replicationPassword'] = replication_password - _details = {} + if host is not None: + _details['host'] = host - if type is not None: - _details['type'] = type + if port is not None: + _details['port'] = port - if display_name is not None: - _details['displayName'] = display_name + if database_name is not None: + _details['databaseName'] = database_name - if agent_id is not None: - _details['agentId'] = agent_id + if security_protocol is not None: + _details['securityProtocol'] = security_protocol - if source_database_connection_id is not None: - _details['sourceDatabaseConnectionId'] = source_database_connection_id + if ssl_mode is not None: + _details['sslMode'] = ssl_mode - if source_container_database_connection_id is not None: - _details['sourceContainerDatabaseConnectionId'] = source_container_database_connection_id + if ssl_ca is not None: + _details['sslCa'] = ssl_ca - if target_database_connection_id is not None: - _details['targetDatabaseConnectionId'] = target_database_connection_id + if ssl_crl is not None: + _details['sslCrl'] = ssl_crl - if data_transfer_medium_details_v2 is not None: - _details['dataTransferMediumDetailsV2'] = cli_util.parse_json_parameter("data_transfer_medium_details_v2", data_transfer_medium_details_v2) + if ssl_cert is not None: + _details['sslCert'] = ssl_cert - if data_transfer_medium_details is not None: - _details['dataTransferMediumDetails'] = cli_util.parse_json_parameter("data_transfer_medium_details", data_transfer_medium_details) + if ssl_key is not None: + _details['sslKey'] = ssl_key - if dump_transfer_details is not None: - _details['dumpTransferDetails'] = cli_util.parse_json_parameter("dump_transfer_details", dump_transfer_details) + if additional_attributes is not None: + _details['additionalAttributes'] = cli_util.parse_json_parameter("additional_attributes", additional_attributes) - if datapump_settings is not None: - _details['datapumpSettings'] = cli_util.parse_json_parameter("datapump_settings", datapump_settings) + if db_system_id is not None: + _details['dbSystemId'] = db_system_id - if advisor_settings is not None: - _details['advisorSettings'] = cli_util.parse_json_parameter("advisor_settings", advisor_settings) - - if exclude_objects is not None: - _details['excludeObjects'] = cli_util.parse_json_parameter("exclude_objects", exclude_objects) - - if include_objects is not None: - _details['includeObjects'] = cli_util.parse_json_parameter("include_objects", include_objects) - - if golden_gate_service_details is not None: - _details['goldenGateServiceDetails'] = cli_util.parse_json_parameter("golden_gate_service_details", golden_gate_service_details) - - if golden_gate_details is not None: - _details['goldenGateDetails'] = cli_util.parse_json_parameter("golden_gate_details", golden_gate_details) - - if vault_details is not None: - _details['vaultDetails'] = cli_util.parse_json_parameter("vault_details", vault_details) - - if freeform_tags is not None: - _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) - - if defined_tags is not None: - _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) + _details['connectionType'] = 'MYSQL' client = cli_util.build_client('database_migration', 'database_migration', ctx) - result = client.update_migration( - migration_id=migration_id, - update_migration_details=_details, + result = client.update_connection( + connection_id=connection_id, + update_connection_details=_details, **kwargs ) if wait_for_state: @@ -2987,47 +2931,28 @@ def update_migration(ctx, from_json, force, wait_for_state, max_wait_seconds, wa cli_util.render_response(result, ctx) -@migration_group.command(name=cli_util.override('database_migration.update_migration_nfs_data_transfer_medium_details.command_name', 'update-migration-nfs-data-transfer-medium-details'), help=u"""Update Migration resource details. \n[Command Reference](updateMigration)""") -@cli_util.option('--migration-id', required=True, help=u"""The OCID of the migration""") -@cli_util.option('--type', type=custom_types.CliCaseInsensitiveChoice(["ONLINE", "OFFLINE"]), help=u"""Migration type.""") -@cli_util.option('--display-name', help=u"""Migration Display Name""") -@cli_util.option('--agent-id', help=u"""The OCID of the registered ODMS Agent.""") -@cli_util.option('--source-database-connection-id', help=u"""The OCID of the Source Database Connection.""") -@cli_util.option('--source-container-database-connection-id', help=u"""The OCID of the Source Container Database Connection. Only used for Online migrations. Only Connections of type Non-Autonomous can be used as source container databases. An empty value would remove the stored Connection ID.""") -@cli_util.option('--target-database-connection-id', help=u"""The OCID of the Target Database Connection.""") -@cli_util.option('--data-transfer-medium-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--dump-transfer-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--datapump-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--advisor-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--exclude-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to exclude from migration, cannot be specified alongside 'includeObjects'. If specified, the list will be replaced entirely. Empty list will remove stored excludeObjects details. - -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--include-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to include from migration, cannot be specified alongside 'excludeObjects'. If specified, the list will be replaced entirely. Empty list will remove stored includeObjects details. - -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--golden-gate-service-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--golden-gate-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--vault-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only. Example: `{\"bar-key\": \"value\"}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@job_group.command(name=cli_util.override('database_migration.update_job.command_name', 'update'), help=u"""Update Migration Job resource details. \n[Command Reference](updateJob)""") +@cli_util.option('--job-id', required=True, help=u"""The OCID of the job""") +@cli_util.option('--display-name', help=u"""Name of the job.""") +@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {\"Department\": \"Finance\"}""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") -@cli_util.option('--data-transfer-medium-details-v2-object-storage-bucket', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--force', help="""Perform update without prompting for confirmation.""", is_flag=True) -@cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") -@cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") -@cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") -@json_skeleton_utils.get_cli_json_input_option({'data-transfer-medium-details': {'module': 'database_migration', 'class': 'UpdateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'UpdateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'UpdateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'UpdateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateServiceDetails'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'UpdateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details-v2-object-storage-bucket': {'module': 'database_migration', 'class': 'ObjectStoreBucket'}}) +@cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "UNKNOWN", "TERMINATED", "FAILED", "SUCCEEDED", "WAITING", "CANCELING", "CANCELED"]), multiple=True, help="""This operation creates, modifies or deletes a resource that has a defined lifecycle state. Specify this option to perform the action and then wait until the resource reaches a given lifecycle state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") +@cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the resource to reach the lifecycle state defined by --wait-for-state. Defaults to 1200 seconds.""") +@cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the resource has reached the lifecycle state defined by --wait-for-state. Defaults to 30 seconds.""") +@json_skeleton_utils.get_cli_json_input_option({'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'data-transfer-medium-details': {'module': 'database_migration', 'class': 'UpdateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'UpdateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'UpdateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'UpdateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateServiceDetails'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'UpdateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details-v2-object-storage-bucket': {'module': 'database_migration', 'class': 'ObjectStoreBucket'}}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}, output_type={'module': 'database_migration', 'class': 'Job'}) @cli_util.wrap_exceptions -def update_migration_nfs_data_transfer_medium_details(ctx, from_json, force, wait_for_state, max_wait_seconds, wait_interval_seconds, migration_id, type, display_name, agent_id, source_database_connection_id, source_container_database_connection_id, target_database_connection_id, data_transfer_medium_details, dump_transfer_details, datapump_settings, advisor_settings, exclude_objects, include_objects, golden_gate_service_details, golden_gate_details, vault_details, freeform_tags, defined_tags, if_match, data_transfer_medium_details_v2_object_storage_bucket): +def update_job(ctx, from_json, force, wait_for_state, max_wait_seconds, wait_interval_seconds, job_id, display_name, freeform_tags, defined_tags, if_match): - if isinstance(migration_id, six.string_types) and len(migration_id.strip()) == 0: - raise click.UsageError('Parameter --migration-id cannot be whitespace or empty string') + if isinstance(job_id, six.string_types) and len(job_id.strip()) == 0: + raise click.UsageError('Parameter --job-id cannot be whitespace or empty string') if not force: - if data_transfer_medium_details or dump_transfer_details or datapump_settings or advisor_settings or exclude_objects or include_objects or golden_gate_service_details or golden_gate_details or vault_details or freeform_tags or defined_tags: - if not click.confirm("WARNING: Updates to data-transfer-medium-details and dump-transfer-details and datapump-settings and advisor-settings and exclude-objects and include-objects and golden-gate-service-details and golden-gate-details and vault-details and freeform-tags and defined-tags will replace any existing values. Are you sure you want to continue?"): + if freeform_tags or defined_tags: + if not click.confirm("WARNING: Updates to freeform-tags and defined-tags will replace any existing values. Are you sure you want to continue?"): ctx.abort() kwargs = {} @@ -3036,141 +2961,75 @@ def update_migration_nfs_data_transfer_medium_details(ctx, from_json, force, wai kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) _details = {} - _details['dataTransferMediumDetailsV2'] = {} - - if type is not None: - _details['type'] = type if display_name is not None: _details['displayName'] = display_name - if agent_id is not None: - _details['agentId'] = agent_id - - if source_database_connection_id is not None: - _details['sourceDatabaseConnectionId'] = source_database_connection_id - - if source_container_database_connection_id is not None: - _details['sourceContainerDatabaseConnectionId'] = source_container_database_connection_id - - if target_database_connection_id is not None: - _details['targetDatabaseConnectionId'] = target_database_connection_id - - if data_transfer_medium_details is not None: - _details['dataTransferMediumDetails'] = cli_util.parse_json_parameter("data_transfer_medium_details", data_transfer_medium_details) - - if dump_transfer_details is not None: - _details['dumpTransferDetails'] = cli_util.parse_json_parameter("dump_transfer_details", dump_transfer_details) - - if datapump_settings is not None: - _details['datapumpSettings'] = cli_util.parse_json_parameter("datapump_settings", datapump_settings) - - if advisor_settings is not None: - _details['advisorSettings'] = cli_util.parse_json_parameter("advisor_settings", advisor_settings) - - if exclude_objects is not None: - _details['excludeObjects'] = cli_util.parse_json_parameter("exclude_objects", exclude_objects) - - if include_objects is not None: - _details['includeObjects'] = cli_util.parse_json_parameter("include_objects", include_objects) - - if golden_gate_service_details is not None: - _details['goldenGateServiceDetails'] = cli_util.parse_json_parameter("golden_gate_service_details", golden_gate_service_details) - - if golden_gate_details is not None: - _details['goldenGateDetails'] = cli_util.parse_json_parameter("golden_gate_details", golden_gate_details) - - if vault_details is not None: - _details['vaultDetails'] = cli_util.parse_json_parameter("vault_details", vault_details) - if freeform_tags is not None: _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) if defined_tags is not None: _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) - if data_transfer_medium_details_v2_object_storage_bucket is not None: - _details['dataTransferMediumDetailsV2']['objectStorageBucket'] = cli_util.parse_json_parameter("data_transfer_medium_details_v2_object_storage_bucket", data_transfer_medium_details_v2_object_storage_bucket) - - _details['dataTransferMediumDetailsV2']['type'] = 'NFS' - client = cli_util.build_client('database_migration', 'database_migration', ctx) - result = client.update_migration( - migration_id=migration_id, - update_migration_details=_details, + result = client.update_job( + job_id=job_id, + update_job_details=_details, **kwargs ) if wait_for_state: - if hasattr(client, 'get_work_request') and callable(getattr(client, 'get_work_request')): + if hasattr(client, 'get_job') and callable(getattr(client, 'get_job')): try: wait_period_kwargs = {} if max_wait_seconds is not None: wait_period_kwargs['max_wait_seconds'] = max_wait_seconds if wait_interval_seconds is not None: wait_period_kwargs['max_interval_seconds'] = wait_interval_seconds - if 'opc-work-request-id' not in result.headers: - click.echo('Encountered error while waiting for work request to enter the specified state. Outputting last known resource state') - cli_util.render_response(result, ctx) - return - click.echo('Action completed. Waiting until the work request has entered state: {}'.format(wait_for_state), file=sys.stderr) - result = oci.wait_until(client, client.get_work_request(result.headers['opc-work-request-id']), 'status', wait_for_state, **wait_period_kwargs) + click.echo('Action completed. Waiting until the resource has entered state: {}'.format(wait_for_state), file=sys.stderr) + result = oci.wait_until(client, client.get_job(result.data.id), 'lifecycle_state', wait_for_state, **wait_period_kwargs) except oci.exceptions.MaximumWaitTimeExceeded as e: # If we fail, we should show an error, but we should still provide the information to the customer - click.echo('Failed to wait until the work request entered the specified state. Outputting last known resource state', file=sys.stderr) + click.echo('Failed to wait until the resource entered the specified state. Outputting last known resource state', file=sys.stderr) cli_util.render_response(result, ctx) sys.exit(2) except Exception: - click.echo('Encountered error while waiting for work request to enter the specified state. Outputting last known resource state', file=sys.stderr) + click.echo('Encountered error while waiting for resource to enter the specified state. Outputting last known resource state', file=sys.stderr) cli_util.render_response(result, ctx) raise else: - click.echo('Unable to wait for the work request to enter the specified state', file=sys.stderr) + click.echo('Unable to wait for the resource to enter the specified state', file=sys.stderr) cli_util.render_response(result, ctx) -@migration_group.command(name=cli_util.override('database_migration.update_migration_object_storage_data_transfer_medium_details.command_name', 'update-migration-object-storage-data-transfer-medium-details'), help=u"""Update Migration resource details. \n[Command Reference](updateMigration)""") +@migration_group.command(name=cli_util.override('database_migration.update_migration.command_name', 'update'), help=u"""Update Migration resource details. \n[Command Reference](updateMigration)""") @cli_util.option('--migration-id', required=True, help=u"""The OCID of the migration""") -@cli_util.option('--type', type=custom_types.CliCaseInsensitiveChoice(["ONLINE", "OFFLINE"]), help=u"""Migration type.""") -@cli_util.option('--display-name', help=u"""Migration Display Name""") -@cli_util.option('--agent-id', help=u"""The OCID of the registered ODMS Agent.""") -@cli_util.option('--source-database-connection-id', help=u"""The OCID of the Source Database Connection.""") -@cli_util.option('--source-container-database-connection-id', help=u"""The OCID of the Source Container Database Connection. Only used for Online migrations. Only Connections of type Non-Autonomous can be used as source container databases. An empty value would remove the stored Connection ID.""") -@cli_util.option('--target-database-connection-id', help=u"""The OCID of the Target Database Connection.""") -@cli_util.option('--data-transfer-medium-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--dump-transfer-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--datapump-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--advisor-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--exclude-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to exclude from migration, cannot be specified alongside 'includeObjects'. If specified, the list will be replaced entirely. Empty list will remove stored excludeObjects details. - -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--include-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to include from migration, cannot be specified alongside 'excludeObjects'. If specified, the list will be replaced entirely. Empty list will remove stored includeObjects details. - -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--golden-gate-service-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--golden-gate-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--vault-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only. Example: `{\"bar-key\": \"value\"}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--database-combination', required=True, type=custom_types.CliCaseInsensitiveChoice(["MYSQL", "ORACLE"]), help=u"""The combination of source and target databases participating in a migration. Example: ORACLE means the migration is meant for migrating Oracle source and target databases.""") +@cli_util.option('--description', help=u"""A user-friendly description. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--type', type=custom_types.CliCaseInsensitiveChoice(["ONLINE", "OFFLINE"]), help=u"""The type of the migration to be performed. Example: ONLINE if no downtime is preferred for a migration. This method uses Oracle GoldenGate for replication.""") +@cli_util.option('--display-name', help=u"""A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--source-database-connection-id', help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--target-database-connection-id', help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {\"Department\": \"Finance\"}""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") -@cli_util.option('--data-transfer-medium-details-v2-object-storage-bucket', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--force', help="""Perform update without prompting for confirmation.""", is_flag=True) @cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") @cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") @cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") -@json_skeleton_utils.get_cli_json_input_option({'data-transfer-medium-details': {'module': 'database_migration', 'class': 'UpdateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'UpdateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'UpdateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'UpdateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateServiceDetails'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'UpdateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details-v2-object-storage-bucket': {'module': 'database_migration', 'class': 'ObjectStoreBucket'}}) +@json_skeleton_utils.get_cli_json_input_option({'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'data-transfer-medium-details': {'module': 'database_migration', 'class': 'UpdateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'UpdateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'UpdateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'UpdateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateServiceDetails'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'UpdateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details-v2-object-storage-bucket': {'module': 'database_migration', 'class': 'ObjectStoreBucket'}}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}}) @cli_util.wrap_exceptions -def update_migration_object_storage_data_transfer_medium_details(ctx, from_json, force, wait_for_state, max_wait_seconds, wait_interval_seconds, migration_id, type, display_name, agent_id, source_database_connection_id, source_container_database_connection_id, target_database_connection_id, data_transfer_medium_details, dump_transfer_details, datapump_settings, advisor_settings, exclude_objects, include_objects, golden_gate_service_details, golden_gate_details, vault_details, freeform_tags, defined_tags, if_match, data_transfer_medium_details_v2_object_storage_bucket): +def update_migration(ctx, from_json, force, wait_for_state, max_wait_seconds, wait_interval_seconds, migration_id, database_combination, description, type, display_name, source_database_connection_id, target_database_connection_id, freeform_tags, defined_tags, if_match): if isinstance(migration_id, six.string_types) and len(migration_id.strip()) == 0: raise click.UsageError('Parameter --migration-id cannot be whitespace or empty string') if not force: - if data_transfer_medium_details or dump_transfer_details or datapump_settings or advisor_settings or exclude_objects or include_objects or golden_gate_service_details or golden_gate_details or vault_details or freeform_tags or defined_tags: - if not click.confirm("WARNING: Updates to data-transfer-medium-details and dump-transfer-details and datapump-settings and advisor-settings and exclude-objects and include-objects and golden-gate-service-details and golden-gate-details and vault-details and freeform-tags and defined-tags will replace any existing values. Are you sure you want to continue?"): + if freeform_tags or defined_tags: + if not click.confirm("WARNING: Updates to freeform-tags and defined-tags will replace any existing values. Are you sure you want to continue?"): ctx.abort() kwargs = {} @@ -3179,7 +3038,10 @@ def update_migration_object_storage_data_transfer_medium_details(ctx, from_json, kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) _details = {} - _details['dataTransferMediumDetailsV2'] = {} + _details['databaseCombination'] = database_combination + + if description is not None: + _details['description'] = description if type is not None: _details['type'] = type @@ -3187,56 +3049,18 @@ def update_migration_object_storage_data_transfer_medium_details(ctx, from_json, if display_name is not None: _details['displayName'] = display_name - if agent_id is not None: - _details['agentId'] = agent_id - if source_database_connection_id is not None: _details['sourceDatabaseConnectionId'] = source_database_connection_id - if source_container_database_connection_id is not None: - _details['sourceContainerDatabaseConnectionId'] = source_container_database_connection_id - if target_database_connection_id is not None: _details['targetDatabaseConnectionId'] = target_database_connection_id - if data_transfer_medium_details is not None: - _details['dataTransferMediumDetails'] = cli_util.parse_json_parameter("data_transfer_medium_details", data_transfer_medium_details) - - if dump_transfer_details is not None: - _details['dumpTransferDetails'] = cli_util.parse_json_parameter("dump_transfer_details", dump_transfer_details) - - if datapump_settings is not None: - _details['datapumpSettings'] = cli_util.parse_json_parameter("datapump_settings", datapump_settings) - - if advisor_settings is not None: - _details['advisorSettings'] = cli_util.parse_json_parameter("advisor_settings", advisor_settings) - - if exclude_objects is not None: - _details['excludeObjects'] = cli_util.parse_json_parameter("exclude_objects", exclude_objects) - - if include_objects is not None: - _details['includeObjects'] = cli_util.parse_json_parameter("include_objects", include_objects) - - if golden_gate_service_details is not None: - _details['goldenGateServiceDetails'] = cli_util.parse_json_parameter("golden_gate_service_details", golden_gate_service_details) - - if golden_gate_details is not None: - _details['goldenGateDetails'] = cli_util.parse_json_parameter("golden_gate_details", golden_gate_details) - - if vault_details is not None: - _details['vaultDetails'] = cli_util.parse_json_parameter("vault_details", vault_details) - if freeform_tags is not None: _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) if defined_tags is not None: _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) - if data_transfer_medium_details_v2_object_storage_bucket is not None: - _details['dataTransferMediumDetailsV2']['objectStorageBucket'] = cli_util.parse_json_parameter("data_transfer_medium_details_v2_object_storage_bucket", data_transfer_medium_details_v2_object_storage_bucket) - - _details['dataTransferMediumDetailsV2']['type'] = 'OBJECT_STORAGE' - client = cli_util.build_client('database_migration', 'database_migration', ctx) result = client.update_migration( migration_id=migration_id, @@ -3273,48 +3097,37 @@ def update_migration_object_storage_data_transfer_medium_details(ctx, from_json, cli_util.render_response(result, ctx) -@migration_group.command(name=cli_util.override('database_migration.update_migration_db_link_data_transfer_medium_details.command_name', 'update-migration-db-link-data-transfer-medium-details'), help=u"""Update Migration resource details. \n[Command Reference](updateMigration)""") +@migration_group.command(name=cli_util.override('database_migration.update_migration_update_my_sql_migration_details.command_name', 'update-migration-update-my-sql-migration-details'), help=u"""Update Migration resource details. \n[Command Reference](updateMigration)""") @cli_util.option('--migration-id', required=True, help=u"""The OCID of the migration""") -@cli_util.option('--type', type=custom_types.CliCaseInsensitiveChoice(["ONLINE", "OFFLINE"]), help=u"""Migration type.""") -@cli_util.option('--display-name', help=u"""Migration Display Name""") -@cli_util.option('--agent-id', help=u"""The OCID of the registered ODMS Agent.""") -@cli_util.option('--source-database-connection-id', help=u"""The OCID of the Source Database Connection.""") -@cli_util.option('--source-container-database-connection-id', help=u"""The OCID of the Source Container Database Connection. Only used for Online migrations. Only Connections of type Non-Autonomous can be used as source container databases. An empty value would remove the stored Connection ID.""") -@cli_util.option('--target-database-connection-id', help=u"""The OCID of the Target Database Connection.""") +@cli_util.option('--description', help=u"""A user-friendly description. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--type', type=custom_types.CliCaseInsensitiveChoice(["ONLINE", "OFFLINE"]), help=u"""The type of the migration to be performed. Example: ONLINE if no downtime is preferred for a migration. This method uses Oracle GoldenGate for replication.""") +@cli_util.option('--display-name', help=u"""A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--source-database-connection-id', help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--target-database-connection-id', help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {\"Department\": \"Finance\"}""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--data-transfer-medium-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--dump-transfer-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--datapump-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--initial-load-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--advisor-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--exclude-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to exclude from migration, cannot be specified alongside 'includeObjects'. If specified, the list will be replaced entirely. Empty list will remove stored excludeObjects details. - -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--include-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to include from migration, cannot be specified alongside 'excludeObjects'. If specified, the list will be replaced entirely. Empty list will remove stored includeObjects details. - -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--golden-gate-service-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--golden-gate-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--vault-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only. Example: `{\"bar-key\": \"value\"}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--hub-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--ggs-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") -@cli_util.option('--data-transfer-medium-details-v2-object-storage-bucket', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--data-transfer-medium-details-v2-name', help=u"""Name of database link from OCI database to on-premise database. ODMS will create link, if the link does not already exist.""") @cli_util.option('--force', help="""Perform update without prompting for confirmation.""", is_flag=True) @cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") @cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") @cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") -@json_skeleton_utils.get_cli_json_input_option({'data-transfer-medium-details': {'module': 'database_migration', 'class': 'UpdateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'UpdateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'UpdateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'UpdateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateServiceDetails'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'UpdateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details-v2-object-storage-bucket': {'module': 'database_migration', 'class': 'ObjectStoreBucket'}}) +@json_skeleton_utils.get_cli_json_input_option({'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details': {'module': 'database_migration', 'class': 'UpdateMySqlDataTransferMediumDetails'}, 'initial-load-settings': {'module': 'database_migration', 'class': 'UpdateMySqlInitialLoadSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'UpdateMySqlAdvisorSettings'}, 'hub-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateHubDetails'}, 'ggs-details': {'module': 'database_migration', 'class': 'UpdateMySqlGgsDeploymentDetails'}}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'data-transfer-medium-details': {'module': 'database_migration', 'class': 'UpdateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'UpdateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'UpdateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'UpdateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateServiceDetails'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'UpdateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details-v2-object-storage-bucket': {'module': 'database_migration', 'class': 'ObjectStoreBucket'}}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details': {'module': 'database_migration', 'class': 'UpdateMySqlDataTransferMediumDetails'}, 'initial-load-settings': {'module': 'database_migration', 'class': 'UpdateMySqlInitialLoadSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'UpdateMySqlAdvisorSettings'}, 'hub-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateHubDetails'}, 'ggs-details': {'module': 'database_migration', 'class': 'UpdateMySqlGgsDeploymentDetails'}}) @cli_util.wrap_exceptions -def update_migration_db_link_data_transfer_medium_details(ctx, from_json, force, wait_for_state, max_wait_seconds, wait_interval_seconds, migration_id, type, display_name, agent_id, source_database_connection_id, source_container_database_connection_id, target_database_connection_id, data_transfer_medium_details, dump_transfer_details, datapump_settings, advisor_settings, exclude_objects, include_objects, golden_gate_service_details, golden_gate_details, vault_details, freeform_tags, defined_tags, if_match, data_transfer_medium_details_v2_object_storage_bucket, data_transfer_medium_details_v2_name): +def update_migration_update_my_sql_migration_details(ctx, from_json, force, wait_for_state, max_wait_seconds, wait_interval_seconds, migration_id, description, type, display_name, source_database_connection_id, target_database_connection_id, freeform_tags, defined_tags, data_transfer_medium_details, initial_load_settings, advisor_settings, hub_details, ggs_details, if_match): if isinstance(migration_id, six.string_types) and len(migration_id.strip()) == 0: raise click.UsageError('Parameter --migration-id cannot be whitespace or empty string') if not force: - if data_transfer_medium_details or dump_transfer_details or datapump_settings or advisor_settings or exclude_objects or include_objects or golden_gate_service_details or golden_gate_details or vault_details or freeform_tags or defined_tags: - if not click.confirm("WARNING: Updates to data-transfer-medium-details and dump-transfer-details and datapump-settings and advisor-settings and exclude-objects and include-objects and golden-gate-service-details and golden-gate-details and vault-details and freeform-tags and defined-tags will replace any existing values. Are you sure you want to continue?"): + if freeform_tags or defined_tags or data_transfer_medium_details or initial_load_settings or advisor_settings or hub_details or ggs_details: + if not click.confirm("WARNING: Updates to freeform-tags and defined-tags and data-transfer-medium-details and initial-load-settings and advisor-settings and hub-details and ggs-details will replace any existing values. Are you sure you want to continue?"): ctx.abort() kwargs = {} @@ -3323,7 +3136,9 @@ def update_migration_db_link_data_transfer_medium_details(ctx, from_json, force, kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) _details = {} - _details['dataTransferMediumDetailsV2'] = {} + + if description is not None: + _details['description'] = description if type is not None: _details['type'] = type @@ -3331,58 +3146,34 @@ def update_migration_db_link_data_transfer_medium_details(ctx, from_json, force, if display_name is not None: _details['displayName'] = display_name - if agent_id is not None: - _details['agentId'] = agent_id - if source_database_connection_id is not None: _details['sourceDatabaseConnectionId'] = source_database_connection_id - if source_container_database_connection_id is not None: - _details['sourceContainerDatabaseConnectionId'] = source_container_database_connection_id - if target_database_connection_id is not None: _details['targetDatabaseConnectionId'] = target_database_connection_id + if freeform_tags is not None: + _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) + + if defined_tags is not None: + _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) + if data_transfer_medium_details is not None: _details['dataTransferMediumDetails'] = cli_util.parse_json_parameter("data_transfer_medium_details", data_transfer_medium_details) - if dump_transfer_details is not None: - _details['dumpTransferDetails'] = cli_util.parse_json_parameter("dump_transfer_details", dump_transfer_details) - - if datapump_settings is not None: - _details['datapumpSettings'] = cli_util.parse_json_parameter("datapump_settings", datapump_settings) + if initial_load_settings is not None: + _details['initialLoadSettings'] = cli_util.parse_json_parameter("initial_load_settings", initial_load_settings) if advisor_settings is not None: _details['advisorSettings'] = cli_util.parse_json_parameter("advisor_settings", advisor_settings) - if exclude_objects is not None: - _details['excludeObjects'] = cli_util.parse_json_parameter("exclude_objects", exclude_objects) - - if include_objects is not None: - _details['includeObjects'] = cli_util.parse_json_parameter("include_objects", include_objects) - - if golden_gate_service_details is not None: - _details['goldenGateServiceDetails'] = cli_util.parse_json_parameter("golden_gate_service_details", golden_gate_service_details) - - if golden_gate_details is not None: - _details['goldenGateDetails'] = cli_util.parse_json_parameter("golden_gate_details", golden_gate_details) - - if vault_details is not None: - _details['vaultDetails'] = cli_util.parse_json_parameter("vault_details", vault_details) + if hub_details is not None: + _details['hubDetails'] = cli_util.parse_json_parameter("hub_details", hub_details) - if freeform_tags is not None: - _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) - - if defined_tags is not None: - _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) - - if data_transfer_medium_details_v2_object_storage_bucket is not None: - _details['dataTransferMediumDetailsV2']['objectStorageBucket'] = cli_util.parse_json_parameter("data_transfer_medium_details_v2_object_storage_bucket", data_transfer_medium_details_v2_object_storage_bucket) + if ggs_details is not None: + _details['ggsDetails'] = cli_util.parse_json_parameter("ggs_details", ggs_details) - if data_transfer_medium_details_v2_name is not None: - _details['dataTransferMediumDetailsV2']['name'] = data_transfer_medium_details_v2_name - - _details['dataTransferMediumDetailsV2']['type'] = 'DBLINK' + _details['databaseCombination'] = 'MYSQL' client = cli_util.build_client('database_migration', 'database_migration', ctx) result = client.update_migration( @@ -3420,51 +3211,38 @@ def update_migration_db_link_data_transfer_medium_details(ctx, from_json, force, cli_util.render_response(result, ctx) -@migration_group.command(name=cli_util.override('database_migration.update_migration_aws_s3_data_transfer_medium_details.command_name', 'update-migration-aws-s3-data-transfer-medium-details'), help=u"""Update Migration resource details. \n[Command Reference](updateMigration)""") +@migration_group.command(name=cli_util.override('database_migration.update_migration_update_oracle_migration_details.command_name', 'update-migration-update-oracle-migration-details'), help=u"""Update Migration resource details. \n[Command Reference](updateMigration)""") @cli_util.option('--migration-id', required=True, help=u"""The OCID of the migration""") -@cli_util.option('--type', type=custom_types.CliCaseInsensitiveChoice(["ONLINE", "OFFLINE"]), help=u"""Migration type.""") -@cli_util.option('--display-name', help=u"""Migration Display Name""") -@cli_util.option('--agent-id', help=u"""The OCID of the registered ODMS Agent.""") -@cli_util.option('--source-database-connection-id', help=u"""The OCID of the Source Database Connection.""") -@cli_util.option('--source-container-database-connection-id', help=u"""The OCID of the Source Container Database Connection. Only used for Online migrations. Only Connections of type Non-Autonomous can be used as source container databases. An empty value would remove the stored Connection ID.""") -@cli_util.option('--target-database-connection-id', help=u"""The OCID of the Target Database Connection.""") +@cli_util.option('--description', help=u"""A user-friendly description. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--type', type=custom_types.CliCaseInsensitiveChoice(["ONLINE", "OFFLINE"]), help=u"""The type of the migration to be performed. Example: ONLINE if no downtime is preferred for a migration. This method uses Oracle GoldenGate for replication.""") +@cli_util.option('--display-name', help=u"""A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information.""") +@cli_util.option('--source-database-connection-id', help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--target-database-connection-id', help=u"""The OCID of the resource being referenced.""") +@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags. Example: {\"Department\": \"Finance\"}""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--data-transfer-medium-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--dump-transfer-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--datapump-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--initial-load-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--advisor-settings', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--exclude-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to exclude from migration, cannot be specified alongside 'includeObjects'. If specified, the list will be replaced entirely. Empty list will remove stored excludeObjects details. - -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--include-objects', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Database objects to include from migration, cannot be specified alongside 'excludeObjects'. If specified, the list will be replaced entirely. Empty list will remove stored includeObjects details. - -This option is a JSON list with items of type DatabaseObject. For documentation on DatabaseObject please see our API reference: https://docs.cloud.oracle.com/api/#/en/databasemigration/20210929/datatypes/DatabaseObject.""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--golden-gate-service-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--golden-gate-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--vault-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--freeform-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only. Example: `{\"bar-key\": \"value\"}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) -@cli_util.option('--defined-tags', type=custom_types.CLI_COMPLEX_TYPE, help=u"""Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{\"foo-namespace\": {\"bar-key\": \"value\"}}`""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--hub-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--ggs-details', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) +@cli_util.option('--source-container-database-connection-id', help=u"""The OCID of the resource being referenced.""") @cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `if-match` parameter to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") -@cli_util.option('--data-transfer-medium-details-v2-name', help=u"""S3 bucket name.""") -@cli_util.option('--data-transfer-medium-details-v2-region', help=u"""AWS region code where the S3 bucket is located. Region code should match the documented available regions: https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-regions-availability-zones.html#concepts-available-regions""") -@cli_util.option('--data-transfer-medium-details-v2-access-key-id', help=u"""AWS access key credentials identifier Details: https://docs.aws.amazon.com/general/latest/gr/aws-sec-cred-types.html#access-keys-and-secret-access-keys""") -@cli_util.option('--data-transfer-medium-details-v2-secret-access-key', help=u"""AWS secret access key credentials Details: https://docs.aws.amazon.com/general/latest/gr/aws-sec-cred-types.html#access-keys-and-secret-access-keys""") -@cli_util.option('--data-transfer-medium-details-v2-object-storage-bucket', type=custom_types.CLI_COMPLEX_TYPE, help=u"""""" + custom_types.cli_complex_type.COMPLEX_TYPE_HELP) @cli_util.option('--force', help="""Perform update without prompting for confirmation.""", is_flag=True) @cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "WAITING", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") @cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") @cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") -@json_skeleton_utils.get_cli_json_input_option({'data-transfer-medium-details': {'module': 'database_migration', 'class': 'UpdateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'UpdateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'UpdateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'UpdateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateServiceDetails'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'UpdateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details-v2-object-storage-bucket': {'module': 'database_migration', 'class': 'ObjectStoreBucket'}}) +@json_skeleton_utils.get_cli_json_input_option({'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details': {'module': 'database_migration', 'class': 'UpdateOracleDataTransferMediumDetails'}, 'initial-load-settings': {'module': 'database_migration', 'class': 'UpdateOracleInitialLoadSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'UpdateOracleAdvisorSettings'}, 'hub-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateHubDetails'}, 'ggs-details': {'module': 'database_migration', 'class': 'UpdateOracleGgsDeploymentDetails'}}) @cli_util.help_option @click.pass_context -@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'data-transfer-medium-details': {'module': 'database_migration', 'class': 'UpdateDataTransferMediumDetails'}, 'dump-transfer-details': {'module': 'database_migration', 'class': 'UpdateDumpTransferDetails'}, 'datapump-settings': {'module': 'database_migration', 'class': 'UpdateDataPumpSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'UpdateAdvisorSettings'}, 'exclude-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'include-objects': {'module': 'database_migration', 'class': 'list[DatabaseObject]'}, 'golden-gate-service-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateServiceDetails'}, 'golden-gate-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateDetails'}, 'vault-details': {'module': 'database_migration', 'class': 'UpdateVaultDetails'}, 'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details-v2-object-storage-bucket': {'module': 'database_migration', 'class': 'ObjectStoreBucket'}}) +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={'freeform-tags': {'module': 'database_migration', 'class': 'dict(str, string)'}, 'defined-tags': {'module': 'database_migration', 'class': 'dict(str, dict(str, object))'}, 'data-transfer-medium-details': {'module': 'database_migration', 'class': 'UpdateOracleDataTransferMediumDetails'}, 'initial-load-settings': {'module': 'database_migration', 'class': 'UpdateOracleInitialLoadSettings'}, 'advisor-settings': {'module': 'database_migration', 'class': 'UpdateOracleAdvisorSettings'}, 'hub-details': {'module': 'database_migration', 'class': 'UpdateGoldenGateHubDetails'}, 'ggs-details': {'module': 'database_migration', 'class': 'UpdateOracleGgsDeploymentDetails'}}) @cli_util.wrap_exceptions -def update_migration_aws_s3_data_transfer_medium_details(ctx, from_json, force, wait_for_state, max_wait_seconds, wait_interval_seconds, migration_id, type, display_name, agent_id, source_database_connection_id, source_container_database_connection_id, target_database_connection_id, data_transfer_medium_details, dump_transfer_details, datapump_settings, advisor_settings, exclude_objects, include_objects, golden_gate_service_details, golden_gate_details, vault_details, freeform_tags, defined_tags, if_match, data_transfer_medium_details_v2_name, data_transfer_medium_details_v2_region, data_transfer_medium_details_v2_access_key_id, data_transfer_medium_details_v2_secret_access_key, data_transfer_medium_details_v2_object_storage_bucket): +def update_migration_update_oracle_migration_details(ctx, from_json, force, wait_for_state, max_wait_seconds, wait_interval_seconds, migration_id, description, type, display_name, source_database_connection_id, target_database_connection_id, freeform_tags, defined_tags, data_transfer_medium_details, initial_load_settings, advisor_settings, hub_details, ggs_details, source_container_database_connection_id, if_match): if isinstance(migration_id, six.string_types) and len(migration_id.strip()) == 0: raise click.UsageError('Parameter --migration-id cannot be whitespace or empty string') if not force: - if data_transfer_medium_details or dump_transfer_details or datapump_settings or advisor_settings or exclude_objects or include_objects or golden_gate_service_details or golden_gate_details or vault_details or freeform_tags or defined_tags: - if not click.confirm("WARNING: Updates to data-transfer-medium-details and dump-transfer-details and datapump-settings and advisor-settings and exclude-objects and include-objects and golden-gate-service-details and golden-gate-details and vault-details and freeform-tags and defined-tags will replace any existing values. Are you sure you want to continue?"): + if freeform_tags or defined_tags or data_transfer_medium_details or initial_load_settings or advisor_settings or hub_details or ggs_details: + if not click.confirm("WARNING: Updates to freeform-tags and defined-tags and data-transfer-medium-details and initial-load-settings and advisor-settings and hub-details and ggs-details will replace any existing values. Are you sure you want to continue?"): ctx.abort() kwargs = {} @@ -3473,7 +3251,9 @@ def update_migration_aws_s3_data_transfer_medium_details(ctx, from_json, force, kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) _details = {} - _details['dataTransferMediumDetailsV2'] = {} + + if description is not None: + _details['description'] = description if type is not None: _details['type'] = type @@ -3481,67 +3261,37 @@ def update_migration_aws_s3_data_transfer_medium_details(ctx, from_json, force, if display_name is not None: _details['displayName'] = display_name - if agent_id is not None: - _details['agentId'] = agent_id - if source_database_connection_id is not None: _details['sourceDatabaseConnectionId'] = source_database_connection_id - if source_container_database_connection_id is not None: - _details['sourceContainerDatabaseConnectionId'] = source_container_database_connection_id - if target_database_connection_id is not None: _details['targetDatabaseConnectionId'] = target_database_connection_id - if data_transfer_medium_details is not None: - _details['dataTransferMediumDetails'] = cli_util.parse_json_parameter("data_transfer_medium_details", data_transfer_medium_details) - - if dump_transfer_details is not None: - _details['dumpTransferDetails'] = cli_util.parse_json_parameter("dump_transfer_details", dump_transfer_details) - - if datapump_settings is not None: - _details['datapumpSettings'] = cli_util.parse_json_parameter("datapump_settings", datapump_settings) - - if advisor_settings is not None: - _details['advisorSettings'] = cli_util.parse_json_parameter("advisor_settings", advisor_settings) - - if exclude_objects is not None: - _details['excludeObjects'] = cli_util.parse_json_parameter("exclude_objects", exclude_objects) - - if include_objects is not None: - _details['includeObjects'] = cli_util.parse_json_parameter("include_objects", include_objects) - - if golden_gate_service_details is not None: - _details['goldenGateServiceDetails'] = cli_util.parse_json_parameter("golden_gate_service_details", golden_gate_service_details) - - if golden_gate_details is not None: - _details['goldenGateDetails'] = cli_util.parse_json_parameter("golden_gate_details", golden_gate_details) - - if vault_details is not None: - _details['vaultDetails'] = cli_util.parse_json_parameter("vault_details", vault_details) - if freeform_tags is not None: _details['freeformTags'] = cli_util.parse_json_parameter("freeform_tags", freeform_tags) if defined_tags is not None: _details['definedTags'] = cli_util.parse_json_parameter("defined_tags", defined_tags) - if data_transfer_medium_details_v2_name is not None: - _details['dataTransferMediumDetailsV2']['name'] = data_transfer_medium_details_v2_name + if data_transfer_medium_details is not None: + _details['dataTransferMediumDetails'] = cli_util.parse_json_parameter("data_transfer_medium_details", data_transfer_medium_details) + + if initial_load_settings is not None: + _details['initialLoadSettings'] = cli_util.parse_json_parameter("initial_load_settings", initial_load_settings) - if data_transfer_medium_details_v2_region is not None: - _details['dataTransferMediumDetailsV2']['region'] = data_transfer_medium_details_v2_region + if advisor_settings is not None: + _details['advisorSettings'] = cli_util.parse_json_parameter("advisor_settings", advisor_settings) - if data_transfer_medium_details_v2_access_key_id is not None: - _details['dataTransferMediumDetailsV2']['accessKeyId'] = data_transfer_medium_details_v2_access_key_id + if hub_details is not None: + _details['hubDetails'] = cli_util.parse_json_parameter("hub_details", hub_details) - if data_transfer_medium_details_v2_secret_access_key is not None: - _details['dataTransferMediumDetailsV2']['secretAccessKey'] = data_transfer_medium_details_v2_secret_access_key + if ggs_details is not None: + _details['ggsDetails'] = cli_util.parse_json_parameter("ggs_details", ggs_details) - if data_transfer_medium_details_v2_object_storage_bucket is not None: - _details['dataTransferMediumDetailsV2']['objectStorageBucket'] = cli_util.parse_json_parameter("data_transfer_medium_details_v2_object_storage_bucket", data_transfer_medium_details_v2_object_storage_bucket) + if source_container_database_connection_id is not None: + _details['sourceContainerDatabaseConnectionId'] = source_container_database_connection_id - _details['dataTransferMediumDetailsV2']['type'] = 'AWS_S3' + _details['databaseCombination'] = 'ORACLE' client = cli_util.build_client('database_migration', 'database_migration', ctx) result = client.update_migration( diff --git a/services/database_migration/tests/__init__.py b/services/database_migration/tests/__init__.py index fe8fd3394..cd62a3ee1 100644 --- a/services/database_migration/tests/__init__.py +++ b/services/database_migration/tests/__init__.py @@ -1,4 +1,4 @@ # coding: utf-8 # Copyright (c) 2016, 2024, Oracle and/or its affiliates. All rights reserved. # This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license. -# NOTE: This class is auto generated by OracleSDKGenerator. DO NOT EDIT. API Version: 20210929 +# NOTE: This class is auto generated by OracleSDKGenerator. DO NOT EDIT. API Version: 20230518 diff --git a/services/database_migration/tests/util/generated/command_to_api.py b/services/database_migration/tests/util/generated/command_to_api.py index 7fb362903..6945f24cd 100644 --- a/services/database_migration/tests/util/generated/command_to_api.py +++ b/services/database_migration/tests/util/generated/command_to_api.py @@ -4,27 +4,22 @@ SDK_client_map = { "database_migration.abort_job": "oci.database_migration.DatabaseMigrationClient.abort_job", "database_migration.add_migration_objects": "oci.database_migration.DatabaseMigrationClient.add_migration_objects", - "database_migration.change_agent_compartment": "oci.database_migration.DatabaseMigrationClient.change_agent_compartment", "database_migration.change_connection_compartment": "oci.database_migration.DatabaseMigrationClient.change_connection_compartment", "database_migration.change_migration_compartment": "oci.database_migration.DatabaseMigrationClient.change_migration_compartment", "database_migration.clone_migration": "oci.database_migration.DatabaseMigrationClient.clone_migration", "database_migration.connection_diagnostics": "oci.database_migration.DatabaseMigrationClient.connection_diagnostics", "database_migration.create_connection": "oci.database_migration.DatabaseMigrationClient.create_connection", "database_migration.create_migration": "oci.database_migration.DatabaseMigrationClient.create_migration", - "database_migration.delete_agent": "oci.database_migration.DatabaseMigrationClient.delete_agent", "database_migration.delete_connection": "oci.database_migration.DatabaseMigrationClient.delete_connection", "database_migration.delete_job": "oci.database_migration.DatabaseMigrationClient.delete_job", "database_migration.delete_migration": "oci.database_migration.DatabaseMigrationClient.delete_migration", "database_migration.evaluate_migration": "oci.database_migration.DatabaseMigrationClient.evaluate_migration", "database_migration.get_advisor_report": "oci.database_migration.DatabaseMigrationClient.get_advisor_report", - "database_migration.get_agent": "oci.database_migration.DatabaseMigrationClient.get_agent", "database_migration.get_connection": "oci.database_migration.DatabaseMigrationClient.get_connection", "database_migration.get_job": "oci.database_migration.DatabaseMigrationClient.get_job", "database_migration.get_job_output_content": "oci.database_migration.DatabaseMigrationClient.get_job_output_content", "database_migration.get_migration": "oci.database_migration.DatabaseMigrationClient.get_migration", "database_migration.get_work_request": "oci.database_migration.DatabaseMigrationClient.get_work_request", - "database_migration.list_agent_images": "oci.database_migration.DatabaseMigrationClient.list_agent_images", - "database_migration.list_agents": "oci.database_migration.DatabaseMigrationClient.list_agents", "database_migration.list_connections": "oci.database_migration.DatabaseMigrationClient.list_connections", "database_migration.list_excluded_objects": "oci.database_migration.DatabaseMigrationClient.list_excluded_objects", "database_migration.list_job_outputs": "oci.database_migration.DatabaseMigrationClient.list_job_outputs", @@ -39,7 +34,6 @@ "database_migration.resume_job": "oci.database_migration.DatabaseMigrationClient.resume_job", "database_migration.retrieve_supported_phases": "oci.database_migration.DatabaseMigrationClient.retrieve_supported_phases", "database_migration.start_migration": "oci.database_migration.DatabaseMigrationClient.start_migration", - "database_migration.update_agent": "oci.database_migration.DatabaseMigrationClient.update_agent", "database_migration.update_connection": "oci.database_migration.DatabaseMigrationClient.update_connection", "database_migration.update_job": "oci.database_migration.DatabaseMigrationClient.update_job", "database_migration.update_migration": "oci.database_migration.DatabaseMigrationClient.update_migration", diff --git a/services/mysql/src/oci_cli_db_backups/generated/dbbackups_cli.py b/services/mysql/src/oci_cli_db_backups/generated/dbbackups_cli.py index b3502dc46..24f775225 100644 --- a/services/mysql/src/oci_cli_db_backups/generated/dbbackups_cli.py +++ b/services/mysql/src/oci_cli_db_backups/generated/dbbackups_cli.py @@ -97,6 +97,78 @@ def change_backup_compartment(ctx, from_json, wait_for_state, max_wait_seconds, cli_util.render_response(result, ctx) +@backup_group.command(name=cli_util.override('db_backups.copy_backup.command_name', 'copy'), help=u"""Creates a copy of a DB system backup available in the specified source region. \n[Command Reference](copyBackup)""") +@cli_util.option('--compartment-id', required=True, help=u"""The OCID of the compartment the DB system backup is to be copied to. + +**Note:** The compartment must be the same as the compartment of the DB system backup in the source region.""") +@cli_util.option('--source-backup-id', required=True, help=u"""The OCID of DB system backup to be copied.""") +@cli_util.option('--source-region', required=True, help=u"""The region identifier of the source region where the DB system backup exists. For more information, please see [Regions and Availability Domains].""") +@cli_util.option('--description', help=u"""A user-supplied description for the DB system backup. By default, the source backup description will be used.""") +@cli_util.option('--display-name', help=u"""A user-supplied display name for the DB system backup. By default, the source backup display name will be used.""") +@cli_util.option('--if-match', help=u"""For optimistic concurrency control. In the PUT or DELETE call for a resource, set the `If-Match` header to the value of the etag from a previous GET or POST response for that resource. The resource will be updated or deleted only if the etag you provide matches the resource's current etag value.""") +@cli_util.option('--wait-for-state', type=custom_types.CliCaseInsensitiveChoice(["ACCEPTED", "IN_PROGRESS", "FAILED", "SUCCEEDED", "CANCELING", "CANCELED"]), multiple=True, help="""This operation asynchronously creates, modifies or deletes a resource and uses a work request to track the progress of the operation. Specify this option to perform the action and then wait until the work request reaches a certain state. Multiple states can be specified, returning on the first state. For example, --wait-for-state SUCCEEDED --wait-for-state FAILED would return on whichever lifecycle state is reached first. If timeout is reached, a return code of 2 is returned. For any other error, a return code of 1 is returned.""") +@cli_util.option('--max-wait-seconds', type=click.INT, help="""The maximum time to wait for the work request to reach the state defined by --wait-for-state. Defaults to 1200 seconds.""") +@cli_util.option('--wait-interval-seconds', type=click.INT, help="""Check every --wait-interval-seconds to see whether the work request has reached the state defined by --wait-for-state. Defaults to 30 seconds.""") +@json_skeleton_utils.get_cli_json_input_option({}) +@cli_util.help_option +@click.pass_context +@json_skeleton_utils.json_skeleton_generation_handler(input_params_to_complex_types={}, output_type={'module': 'mysql', 'class': 'Backup'}) +@cli_util.wrap_exceptions +def copy_backup(ctx, from_json, wait_for_state, max_wait_seconds, wait_interval_seconds, compartment_id, source_backup_id, source_region, description, display_name, if_match): + + kwargs = {} + if if_match is not None: + kwargs['if_match'] = if_match + kwargs['opc_request_id'] = cli_util.use_or_generate_request_id(ctx.obj['request_id']) + + _details = {} + _details['compartmentId'] = compartment_id + _details['sourceBackupId'] = source_backup_id + _details['sourceRegion'] = source_region + + if description is not None: + _details['description'] = description + + if display_name is not None: + _details['displayName'] = display_name + + client = cli_util.build_client('mysql', 'db_backups', ctx) + result = client.copy_backup( + copy_backup_details=_details, + **kwargs + ) + if wait_for_state: + + client = cli_util.build_client('mysql', 'work_requests', ctx) + + if hasattr(client, 'get_work_request') and callable(getattr(client, 'get_work_request')): + try: + wait_period_kwargs = {} + if max_wait_seconds is not None: + wait_period_kwargs['max_wait_seconds'] = max_wait_seconds + if wait_interval_seconds is not None: + wait_period_kwargs['max_interval_seconds'] = wait_interval_seconds + if 'opc-work-request-id' not in result.headers: + click.echo('Encountered error while waiting for work request to enter the specified state. Outputting last known resource state') + cli_util.render_response(result, ctx) + return + + click.echo('Action completed. Waiting until the work request has entered state: {}'.format(wait_for_state), file=sys.stderr) + result = oci.wait_until(client, client.get_work_request(result.headers['opc-work-request-id']), 'status', wait_for_state, **wait_period_kwargs) + except oci.exceptions.MaximumWaitTimeExceeded as e: + # If we fail, we should show an error, but we should still provide the information to the customer + click.echo('Failed to wait until the work request entered the specified state. Outputting last known resource state', file=sys.stderr) + cli_util.render_response(result, ctx) + sys.exit(2) + except Exception: + click.echo('Encountered error while waiting for work request to enter the specified state. Outputting last known resource state', file=sys.stderr) + cli_util.render_response(result, ctx) + raise + else: + click.echo('Unable to wait for the work request to enter the specified state', file=sys.stderr) + cli_util.render_response(result, ctx) + + @backup_group.command(name=cli_util.override('db_backups.create_backup.command_name', 'create'), help=u"""Create a backup of a DB System. \n[Command Reference](createBackup)""") @cli_util.option('--db-system-id', required=True, help=u"""The OCID of the DB System the Backup is associated with.""") @cli_util.option('--display-name', help=u"""A user-supplied display name for the backup.""") diff --git a/setup.py b/setup.py index c7b19c7be..1cd7e0554 100644 --- a/setup.py +++ b/setup.py @@ -30,7 +30,7 @@ def open_relative(*path): readme = f.read() requires = [ - 'oci==2.128.2', + 'oci==2.129.0', 'arrow>=1.0.0', 'certifi', 'click==8.0.4', diff --git a/src/common_util/ignored_commands.py b/src/common_util/ignored_commands.py index 8b04610d5..ac2317648 100644 --- a/src/common_util/ignored_commands.py +++ b/src/common_util/ignored_commands.py @@ -244,6 +244,7 @@ ['database-management', 'managed-database', 'load-spb-from-awr-with-secret'], ['database-management', 'managed-database', 'load-spb-from-cc-with-password'], ['database-management', 'managed-database', 'load-spb-from-cc-with-secret'], + ['database-migration', 'migration-object-type-summary'], ] IGNORED_COMMANDS_DOCS = [ diff --git a/src/oci_cli/version.py b/src/oci_cli/version.py index 6545586dd..4f6e9eab9 100644 --- a/src/oci_cli/version.py +++ b/src/oci_cli/version.py @@ -2,4 +2,4 @@ # Copyright (c) 2016, 2021, Oracle and/or its affiliates. All rights reserved. # This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license. -__version__ = '3.43.2' +__version__ = '3.44.0'