From dd52f885f097543eeb036f79b13a3537639ce350 Mon Sep 17 00:00:00 2001 From: Shrey Kapoor Date: Fri, 23 Aug 2024 12:22:01 -0700 Subject: [PATCH 01/17] Added - Support for BDS - Kerb to IAM Automation --- .../Identity_Configuration/main.tf | 63 + examples/big_data_service/main.tf | 92 +- ...ds_instance_identity_configuration_test.go | 393 +++++++ .../bds_odh_instance_resource_test.go | 115 +- internal/provider/register_datasource.go | 4 - internal/provider/register_resource.go | 4 - ...ance_identity_configuration_data_source.go | 113 ++ ...nstance_identity_configuration_resource.go | 1037 +++++++++++++++++ ...nce_identity_configurations_data_source.go | 142 +++ internal/service/bds/bds_export.go | 46 +- internal/service/bds/register_datasource.go | 2 + internal/service/bds/register_resource.go | 1 + ...tance_identity_configuration.html.markdown | 59 + ...ance_identity_configurations.html.markdown | 72 ++ .../guides/resource_discovery.html.markdown | 59 +- website/docs/r/bds_bds_instance.html.markdown | 5 +- ...tance_identity_configuration.html.markdown | 106 ++ 17 files changed, 2191 insertions(+), 122 deletions(-) create mode 100755 examples/big_data_service/Identity_Configuration/main.tf create mode 100644 internal/integrationtest/bds_bds_instance_identity_configuration_test.go create mode 100644 internal/service/bds/bds_bds_instance_identity_configuration_data_source.go create mode 100644 internal/service/bds/bds_bds_instance_identity_configuration_resource.go create mode 100644 internal/service/bds/bds_bds_instance_identity_configurations_data_source.go create mode 100644 website/docs/d/bds_bds_instance_identity_configuration.html.markdown create mode 100644 website/docs/d/bds_bds_instance_identity_configurations.html.markdown create mode 100644 website/docs/r/bds_bds_instance_identity_configuration.html.markdown diff --git a/examples/big_data_service/Identity_Configuration/main.tf b/examples/big_data_service/Identity_Configuration/main.tf new file mode 100755 index 00000000000..67047407b2f --- /dev/null +++ b/examples/big_data_service/Identity_Configuration/main.tf @@ -0,0 +1,63 @@ +variable "bds_instance_id" { +} + +variable "cluster_admin_password" { +} + +variable "confidential_application_id" { +} + +variable "display_name" { + default = "identityDomainConfig" +} + +variable "identity_domain_id" { +} + +variable "activate_iam_user_sync_configuration_trigger" { + default = "false" +} + +variable "activate_upst_configuration_trigger" { + default = "false" +} + +variable "refresh_confidential_application_trigger" { + default = "false" +} + +variable "refresh_upst_token_exchange_keytab_trigger" { + default = "false" +} + +variable "is_posix_attributes_addition_required" { +default = "false" +} + +variable "confidential_application_id" { +} + +variable "vault_id" { +} + +resource "oci_bds_bds_instance_identity_configuration" "test_bds_instance_identity_configuration" { +bds_instance_id = var.bds_instance_id +cluster_admin_password = var.cluster_admin_password +confidential_application_id = var.confidential_application_id +display_name = var.display_name +identity_domain_id = var.identity_domain_id +activate_iam_user_sync_configuration_trigger = var.activate_iam_user_sync_configuration_trigger +activate_upst_configuration_trigger = var.activate_upst_configuration_trigger +refresh_confidential_application_trigger = var.refresh_confidential_application_trigger +refresh_upst_token_exchange_keytab_trigger = var.refresh_upst_token_exchange_keytab_trigger + +iam_user_sync_configuration_details { + is_posix_attributes_addition_required = var.is_posix_attributes_addition_required +} + +upst_configuration_details { + master_encryption_key_id = var.confidential_application_id + vault_id = var.vault_id +} + +} diff --git a/examples/big_data_service/main.tf b/examples/big_data_service/main.tf index 4622b83698c..41554f578f7 100644 --- a/examples/big_data_service/main.tf +++ b/examples/big_data_service/main.tf @@ -5,7 +5,7 @@ variable "tenancy_ocid" { } variable "cluster_profile" { - default = "HADOOP" +default = "HADOOP" } variable "user_ocid" { @@ -85,7 +85,7 @@ variable "bds_instance_nodes_shape" { } variable "bds_instance_worker_node_shape" { - default = "VM.DenseIO.E5.Flex" + default = "VM.Standard.Generic" } variable "bds_instance_compute_only_worker_node_shape" { @@ -148,7 +148,7 @@ resource "oci_bds_bds_instance" "test_bds_instance" { is_secure = var.bds_instance_is_secure kms_key_id = var.kms_key_id cluster_profile = var.cluster_profile - bootstrap_script_url = "https://objectstorage.us-ashburn-1.oraclecloud.com/p/Lk5JT9tnUIOG4yLm6S21QVR7m3Rm2uj1RAS2Olx5v14onLU2Y-b0lIc_N0RuUIge/n/idpbwtq1b3ta/b/bucket-20230214-1316/o/execute_bootstrap_script.sh" + bootstrap_script_url = "https://objectstorage.us-ashburn-1.oraclecloud.com/p/Lk5JT9tnUIOG4yLm6S21QVR7m3Rm2uj1RAS2Olx5v14onLU2Y-b0lIc_N0RuUIge/n/idpbwtq1b3ta/b/bucket-20230214-1316/o/execute_bootstrap_script.sh" master_node { #Required @@ -158,9 +158,9 @@ resource "oci_bds_bds_instance" "test_bds_instance" { block_volume_size_in_gbs = var.bds_instance_nodes_block_volume_size_in_gbs number_of_nodes = 1 shape_config { - memory_in_gbs = 120 - ocpus = 8 - } + memory_in_gbs = 120 + ocpus = 8 + } } util_node { @@ -171,50 +171,50 @@ resource "oci_bds_bds_instance" "test_bds_instance" { block_volume_size_in_gbs = var.bds_instance_nodes_block_volume_size_in_gbs number_of_nodes = 1 shape_config { - memory_in_gbs = 120 - ocpus = 8 - } + memory_in_gbs = 120 + ocpus = 8 + } } worker_node { #Required shape = var.bds_instance_worker_node_shape - subnet_id = var.subnet_id - number_of_nodes = 3 - shape_config { - memory_in_gbs = 120 - ocpus = 8 - nvmes = 1 - } - } - - edge_node { - #Required - shape = var.bds_instance_edge_node_shape - - subnet_id = var.subnet_id - block_volume_size_in_gbs = var.bds_instance_worker_nodes_block_volume_size_in_gbs - number_of_nodes = 1 - shape_config { - memory_in_gbs = var.bds_instance_edge_memory_per_node - ocpus = var.bds_instance_edge_ocpu_per_node - } - } - - compute_only_worker_node { - #Required - shape = var.bds_instance_compute_only_worker_node_shape - + block_volume_size_in_gbs = var.bds_instance_nodes_block_volume_size_in_gbs subnet_id = var.subnet_id - block_volume_size_in_gbs = var.bds_instance_worker_nodes_block_volume_size_in_gbs - number_of_nodes = 1 - shape_config { - memory_in_gbs = var.bds_instance_compute_only_worker_memory_per_node - ocpus = var.bds_instance_compute_only_worker_ocpu_per_node + number_of_nodes = 3 + shape_config { + memory_in_gbs = 120 + ocpus = 8 + } + } + + edge_node { + #Required + shape = var.bds_instance_edge_node_shape + + subnet_id = var.subnet_id + block_volume_size_in_gbs = var.bds_instance_worker_nodes_block_volume_size_in_gbs + number_of_nodes = 1 + shape_config { + memory_in_gbs = var.bds_instance_edge_memory_per_node + ocpus = var.bds_instance_edge_ocpu_per_node + } + } + + compute_only_worker_node { + #Required + shape = var.bds_instance_compute_only_worker_node_shape + + subnet_id = var.subnet_id + block_volume_size_in_gbs = var.bds_instance_worker_nodes_block_volume_size_in_gbs + number_of_nodes = 1 + shape_config { + memory_in_gbs = var.bds_instance_compute_only_worker_memory_per_node + ocpus = var.bds_instance_compute_only_worker_ocpu_per_node } } - ignore_existing_nodes_shape = ["worker", "master", "utility"] + ignore_existing_nodes_shape = ["worker", "master", "utility"] is_cloud_sql_configured = false @@ -224,7 +224,7 @@ resource "oci_bds_bds_instance" "test_bds_instance" { #Uncomment kafka_broker_node block for use of Kafka cluster #kafka_broker_node { - #Required + #Required # shape = var.bds_instance_compute_only_worker_node_shape # subnet_id = var.subnet_id @@ -237,10 +237,10 @@ resource "oci_bds_bds_instance" "test_bds_instance" { #} #Optional - #Uncomment this when running in home region (PHX) - # defined_tags = { - # "${oci_identity_tag_namespace.tag-namespace1.name}.${oci_identity_tag.tag1.name}" = var.bds_instance_defined_tags_value - # } +#Uncomment this when running in home region (PHX) +# defined_tags = { +# "${oci_identity_tag_namespace.tag-namespace1.name}.${oci_identity_tag.tag1.name}" = var.bds_instance_defined_tags_value +# } freeform_tags = var.bds_instance_freeform_tags network_config { #Optional diff --git a/internal/integrationtest/bds_bds_instance_identity_configuration_test.go b/internal/integrationtest/bds_bds_instance_identity_configuration_test.go new file mode 100644 index 00000000000..ca31da4f8b6 --- /dev/null +++ b/internal/integrationtest/bds_bds_instance_identity_configuration_test.go @@ -0,0 +1,393 @@ +// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. +// Licensed under the Mozilla Public License v2.0 + +package integrationtest + +import ( + "context" + "fmt" + "strconv" + "testing" + "time" + + "github.com/oracle/terraform-provider-oci/internal/resourcediscovery" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" + "github.com/hashicorp/terraform-plugin-sdk/v2/terraform" + oci_bds "github.com/oracle/oci-go-sdk/v65/bds" + "github.com/oracle/oci-go-sdk/v65/common" + + "github.com/oracle/terraform-provider-oci/httpreplay" + "github.com/oracle/terraform-provider-oci/internal/acctest" + tf_client "github.com/oracle/terraform-provider-oci/internal/client" + "github.com/oracle/terraform-provider-oci/internal/tfresource" + "github.com/oracle/terraform-provider-oci/internal/utils" +) + +var ( + NamespaceSingularDataSourceRepresentation = map[string]interface{}{ + "compartment_id": acctest.Representation{RepType: acctest.Optional, Create: `${var.compartment_id}`}, + } + BdsBdsInstanceIdentityConfigurationRequiredOnlyResource = BdsBdsInstanceIdentityConfigurationResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance_identity_configuration", "test_bds_instance_identity_configuration", acctest.Required, acctest.Create, BdsBdsInstanceIdentityConfigurationRepresentation) + + BdsBdsInstanceIdentityConfigurationResourceConfig = BdsBdsInstanceIdentityConfigurationResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance_identity_configuration", "test_bds_instance_identity_configuration", acctest.Optional, acctest.Update, BdsBdsInstanceIdentityConfigurationRepresentation) + + BdsBdsInstanceIdentityConfigurationSingularDataSourceRepresentation = map[string]interface{}{ + "bds_instance_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_bds_bds_instance.test_bds_instance.id}`}, + "identity_configuration_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_bds_bds_instance_identity_configuration.test_bds_instance_identity_configuration.id}`}, + } + + BdsBdsInstanceIdentityConfigurationDataSourceRepresentation = map[string]interface{}{ + "bds_instance_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_bds_bds_instance.test_bds_instance.id}`}, + "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id}`}, + "display_name": acctest.Representation{RepType: acctest.Optional, Create: `identityDomainConfig`}, + "state": acctest.Representation{RepType: acctest.Optional, Create: `ACTIVE`}, + "filter": acctest.RepresentationGroup{RepType: acctest.Required, Group: BdsBdsInstanceIdentityConfigurationDataSourceFilterRepresentation}} + BdsBdsInstanceIdentityConfigurationDataSourceFilterRepresentation = map[string]interface{}{ + "name": acctest.Representation{RepType: acctest.Required, Create: `id`}, + "values": acctest.Representation{RepType: acctest.Required, Create: []string{`${oci_bds_bds_instance_identity_configuration.test_bds_instance_identity_configuration.id}`}}, + } + + BdsBdsInstanceIdentityConfigurationRepresentation = map[string]interface{}{ + "bds_instance_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_bds_bds_instance.test_bds_instance.id}`}, + "cluster_admin_password": acctest.Representation{RepType: acctest.Required, Create: `T3JhY2xlVGVhbVVTQSExMjM=`}, + "confidential_application_id": acctest.Representation{RepType: acctest.Required, Create: `674459b3af89486da22ec1d2da61708f`}, + "display_name": acctest.Representation{RepType: acctest.Required, Create: `identityDomainConfig`}, + "identity_domain_id": acctest.Representation{RepType: acctest.Required, Create: `${var.identity_domain_id}`}, + "iam_user_sync_configuration_details": acctest.RepresentationGroup{RepType: acctest.Optional, Group: BdsBdsInstanceIdentityConfigurationIamUserSyncConfigurationDetailsRepresentation}, + "upst_configuration_details": acctest.RepresentationGroup{RepType: acctest.Optional, Group: BdsBdsInstanceIdentityConfigurationUpstConfigurationDetailsRepresentation}, + "activate_iam_user_sync_configuration_trigger": acctest.Representation{RepType: acctest.Optional, Create: `false`, Update: `true`}, + "activate_upst_configuration_trigger": acctest.Representation{RepType: acctest.Optional, Create: `false`, Update: `true`}, + "refresh_confidential_application_trigger": acctest.Representation{RepType: acctest.Optional, Create: `false`, Update: `true`}, + "refresh_upst_token_exchange_keytab_trigger": acctest.Representation{RepType: acctest.Optional, Create: `false`, Update: `true`}, + } + BdsBdsInstanceIdentityConfigurationIamUserSyncConfigurationDetailsRepresentation = map[string]interface{}{ + "is_posix_attributes_addition_required": acctest.Representation{RepType: acctest.Optional, Create: `false`, Update: `true`}, + } + BdsBdsInstanceIdentityConfigurationUpstConfigurationDetailsRepresentation = map[string]interface{}{ + "master_encryption_key_id": acctest.Representation{RepType: acctest.Optional, Create: `${var.master_encryption_key_id}`}, + "vault_id": acctest.Representation{RepType: acctest.Optional, Create: `${var.vault_id}`}, + } + + BdsBdsInstanceIdentityConfigurationResourceDependencies = acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance", "test_bds_instance", acctest.Optional, acctest.Create, bdsInstanceOdhRepresentation) + + acctest.GenerateResourceFromRepresentationMap("oci_core_subnet", "test_subnet", acctest.Required, acctest.Create, CoreSubnetRepresentation) + + acctest.GenerateResourceFromRepresentationMap("oci_core_vcn", "test_vcn", acctest.Required, acctest.Create, CoreVcnRepresentation) +) + +// issue-routing-tag: bds/default +func TestBdsBdsInstanceIdentityConfigurationResource_basic(t *testing.T) { + httpreplay.SetScenario("TestBdsBdsInstanceIdentityConfigurationResource_basic") + defer httpreplay.SaveScenario() + + config := acctest.ProviderTestConfig() + + compartmentId := utils.GetEnvSettingWithBlankDefault("compartment_ocid") + compartmentIdVariableStr := fmt.Sprintf("variable \"compartment_id\" { default = \"%s\" }\n", compartmentId) + + subnetId := utils.GetEnvSettingWithBlankDefault("subnet_ocid") + subnetIdVariableStr := fmt.Sprintf("variable \"subnet_id\" { default = \"%s\" }\n", subnetId) + + identityDomainId := utils.GetEnvSettingWithBlankDefault("identity_domain_ocid") + identityDomainIdVariableStr := fmt.Sprintf("variable \"identity_domain_id\" { default = \"%s\" }\n", identityDomainId) + + vaultId := utils.GetEnvSettingWithBlankDefault("vault_ocid") + vaultIdVariableStr := fmt.Sprintf("variable \"vault_id\" { default = \"%s\" }\n", vaultId) + + masterEncryptionKeyId := utils.GetEnvSettingWithBlankDefault("master_encryption_key_ocid") + masterEncryptionKeyIdVariableStr := fmt.Sprintf("variable \"master_encryption_key_id\" { default = \"%s\" }\n", masterEncryptionKeyId) + + resourceName := "oci_bds_bds_instance_identity_configuration.test_bds_instance_identity_configuration" + datasourceName := "data.oci_bds_bds_instance_identity_configurations.test_bds_instance_identity_configurations" + singularDatasourceName := "data.oci_bds_bds_instance_identity_configuration.test_bds_instance_identity_configuration" + + var resId, resId2 string + // Save TF content to Create resource with optional properties. This has to be exactly the same as the config part in the "create with optionals" step in the test. + acctest.SaveConfigContent(config+compartmentIdVariableStr+subnetIdVariableStr+BdsBdsInstanceIdentityConfigurationResourceDependencies+ + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance_identity_configuration", "test_bds_instance_identity_configuration", acctest.Optional, acctest.Create, BdsBdsInstanceIdentityConfigurationRepresentation), "bds", "bdsInstanceIdentityConfiguration", t) + //fmt.Printf(config + compartmentIdVariableStr + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance_identity_configuration", "test_bds_instance_identity_configuration", acctest.Optional, acctest.Update, BdsBdsInstanceIdentityConfigurationRepresentation)) + acctest.ResourceTest(t, testAccCheckBdsBdsInstanceIdentityConfigurationDestroy, []resource.TestStep{ + // verify Create + { + Config: config + compartmentIdVariableStr + subnetIdVariableStr + identityDomainIdVariableStr + vaultIdVariableStr + masterEncryptionKeyIdVariableStr + BdsBdsInstanceIdentityConfigurationResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance_identity_configuration", "test_bds_instance_identity_configuration", acctest.Required, acctest.Create, BdsBdsInstanceIdentityConfigurationRepresentation), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttrSet(resourceName, "bds_instance_id"), + resource.TestCheckResourceAttr(resourceName, "cluster_admin_password", "T3JhY2xlVGVhbVVTQSExMjM="), + resource.TestCheckResourceAttrSet(resourceName, "confidential_application_id"), + resource.TestCheckResourceAttr(resourceName, "display_name", "identityDomainConfig"), + resource.TestCheckResourceAttrSet(resourceName, "identity_domain_id"), + + func(s *terraform.State) (err error) { + resId, err = acctest.FromInstanceState(s, resourceName, "id") + return err + }, + ), + }, + + // delete before next Create + { + Config: config + compartmentIdVariableStr + subnetIdVariableStr + BdsBdsInstanceIdentityConfigurationResourceDependencies, + }, + // verify Create with optionals + { + Config: config + compartmentIdVariableStr + subnetIdVariableStr + identityDomainIdVariableStr + vaultIdVariableStr + masterEncryptionKeyIdVariableStr + BdsBdsInstanceIdentityConfigurationResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance_identity_configuration", "test_bds_instance_identity_configuration", acctest.Optional, acctest.Create, BdsBdsInstanceIdentityConfigurationRepresentation), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttrSet(resourceName, "bds_instance_id"), + resource.TestCheckResourceAttr(resourceName, "cluster_admin_password", "T3JhY2xlVGVhbVVTQSExMjM="), + resource.TestCheckResourceAttrSet(resourceName, "confidential_application_id"), + resource.TestCheckResourceAttr(resourceName, "display_name", "identityDomainConfig"), + resource.TestCheckResourceAttr(resourceName, "iam_user_sync_configuration_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "iam_user_sync_configuration_details.0.is_posix_attributes_addition_required", "false"), + resource.TestCheckResourceAttrSet(resourceName, "id"), + resource.TestCheckResourceAttrSet(resourceName, "identity_domain_id"), + resource.TestCheckResourceAttrSet(resourceName, "state"), + resource.TestCheckResourceAttrSet(resourceName, "time_created"), + resource.TestCheckResourceAttrSet(resourceName, "time_updated"), + resource.TestCheckResourceAttr(resourceName, "upst_configuration_details.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "upst_configuration_details.0.master_encryption_key_id"), + resource.TestCheckResourceAttrSet(resourceName, "upst_configuration_details.0.vault_id"), + + func(s *terraform.State) (err error) { + resId, err = acctest.FromInstanceState(s, resourceName, "id") + if isEnableExportCompartment, _ := strconv.ParseBool(utils.GetEnvSettingWithDefault("enable_export_compartment", "true")); isEnableExportCompartment { + if errExport := resourcediscovery.TestExportCompartmentWithResourceName(&resId, &compartmentId, resourceName); errExport != nil { + return errExport + } + } + return err + }, + ), + }, + + // verify updates to updatable parameters + { + Config: config + compartmentIdVariableStr + subnetIdVariableStr + identityDomainIdVariableStr + vaultIdVariableStr + masterEncryptionKeyIdVariableStr + BdsBdsInstanceIdentityConfigurationResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance_identity_configuration", "test_bds_instance_identity_configuration", acctest.Optional, acctest.Update, BdsBdsInstanceIdentityConfigurationRepresentation), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttrSet(resourceName, "bds_instance_id"), + resource.TestCheckResourceAttr(resourceName, "cluster_admin_password", "T3JhY2xlVGVhbVVTQSExMjM="), + resource.TestCheckResourceAttrSet(resourceName, "confidential_application_id"), + resource.TestCheckResourceAttr(resourceName, "display_name", "identityDomainConfig"), + resource.TestCheckResourceAttr(resourceName, "iam_user_sync_configuration_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "iam_user_sync_configuration_details.0.is_posix_attributes_addition_required", "true"), + resource.TestCheckResourceAttrSet(resourceName, "id"), + resource.TestCheckResourceAttrSet(resourceName, "identity_domain_id"), + resource.TestCheckResourceAttrSet(resourceName, "state"), + resource.TestCheckResourceAttrSet(resourceName, "time_created"), + resource.TestCheckResourceAttrSet(resourceName, "time_updated"), + resource.TestCheckResourceAttr(resourceName, "upst_configuration_details.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "upst_configuration_details.0.master_encryption_key_id"), + resource.TestCheckResourceAttrSet(resourceName, "upst_configuration_details.0.vault_id"), + + func(s *terraform.State) (err error) { + resId2, err = acctest.FromInstanceState(s, resourceName, "id") + if resId != resId2 { + return fmt.Errorf("Resource recreated when it was supposed to be updated.") + } + return err + }, + ), + }, + // verify datasource + { + Config: config + + acctest.GenerateDataSourceFromRepresentationMap("oci_bds_bds_instance_identity_configurations", "test_bds_instance_identity_configurations", acctest.Optional, acctest.Update, BdsBdsInstanceIdentityConfigurationDataSourceRepresentation) + + compartmentIdVariableStr + subnetIdVariableStr + identityDomainIdVariableStr + vaultIdVariableStr + masterEncryptionKeyIdVariableStr + BdsBdsInstanceIdentityConfigurationResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance_identity_configuration", "test_bds_instance_identity_configuration", acctest.Optional, acctest.Update, BdsBdsInstanceIdentityConfigurationRepresentation), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttrSet(datasourceName, "bds_instance_id"), + resource.TestCheckResourceAttr(datasourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttr(datasourceName, "display_name", "identityDomainConfig"), + resource.TestCheckResourceAttr(datasourceName, "state", "ACTIVE"), + + resource.TestCheckResourceAttr(datasourceName, "identity_configurations.#", "1"), + resource.TestCheckResourceAttr(datasourceName, "identity_configurations.0.display_name", "identityDomainConfig"), + resource.TestCheckResourceAttrSet(datasourceName, "identity_configurations.0.id"), + resource.TestCheckResourceAttrSet(datasourceName, "identity_configurations.0.state"), + ), + }, + // verify singular datasource + { + Config: config + + acctest.GenerateDataSourceFromRepresentationMap("oci_bds_bds_instance_identity_configuration", "test_bds_instance_identity_configuration", acctest.Required, acctest.Create, BdsBdsInstanceIdentityConfigurationSingularDataSourceRepresentation) + + compartmentIdVariableStr + subnetIdVariableStr + identityDomainIdVariableStr + vaultIdVariableStr + masterEncryptionKeyIdVariableStr + BdsBdsInstanceIdentityConfigurationResourceConfig, + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttrSet(singularDatasourceName, "bds_instance_id"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "identity_configuration_id"), + + resource.TestCheckResourceAttr(singularDatasourceName, "display_name", "identityDomainConfig"), + resource.TestCheckResourceAttr(singularDatasourceName, "iam_user_sync_configuration.#", "1"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "id"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "state"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "time_created"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "time_updated"), + resource.TestCheckResourceAttr(singularDatasourceName, "upst_configuration.#", "1"), + ), + }, + // verify resource import + { + Config: config + BdsBdsInstanceIdentityConfigurationRequiredOnlyResource, + ImportState: true, + ImportStateVerify: true, + ImportStateIdFunc: getBdsIdentityConfigurationCompositeId(resourceName), + ImportStateVerifyIgnore: []string{ + "cluster_admin_password", + "iam_user_sync_configuration_details", + "upst_configuration_details", + "activate_iam_user_sync_configuration_trigger", + "activate_upst_configuration_trigger", + "refresh_confidential_application_trigger", + "refresh_upst_token_exchange_keytab_trigger", + }, + ResourceName: resourceName, + }, + }) +} + +func testAccCheckBdsBdsInstanceIdentityConfigurationDestroy(s *terraform.State) error { + noResourceFound := true + client := acctest.TestAccProvider.Meta().(*tf_client.OracleClients).BdsClient() + for _, rs := range s.RootModule().Resources { + if rs.Type == "oci_bds_bds_instance_identity_configuration" { + noResourceFound = false + request := oci_bds.GetIdentityConfigurationRequest{} + + if value, ok := rs.Primary.Attributes["bds_instance_id"]; ok { + request.BdsInstanceId = &value + } + + if value, ok := rs.Primary.Attributes["id"]; ok { + request.IdentityConfigurationId = &value + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(true, "bds") + + response, err := client.GetIdentityConfiguration(context.Background(), request) + + if err == nil { + deletedLifecycleStates := map[string]bool{ + string(oci_bds.IdentityConfigurationLifecycleStateDeleted): true, + } + if _, ok := deletedLifecycleStates[string(response.LifecycleState)]; !ok { + //resource lifecycle state is not in expected deleted lifecycle states. + return fmt.Errorf("resource lifecycle state: %s is not in expected deleted lifecycle states", response.LifecycleState) + } + //resource lifecycle state is in expected deleted lifecycle states. continue with next one. + continue + } + + //Verify that exception is for '404 not found'. + if failure, isServiceError := common.IsServiceError(err); !isServiceError || failure.GetHTTPStatusCode() != 404 { + return err + } + } + } + if noResourceFound { + return fmt.Errorf("at least one resource was expected from the state file, but could not be found") + } + + return nil +} + +func init() { + if acctest.DependencyGraph == nil { + acctest.InitDependencyGraph() + } + if !acctest.InSweeperExcludeList("BdsBdsInstanceIdentityConfiguration") { + resource.AddTestSweepers("BdsBdsInstanceIdentityConfiguration", &resource.Sweeper{ + Name: "BdsBdsInstanceIdentityConfiguration", + Dependencies: acctest.DependencyGraph["bdsInstanceIdentityConfiguration"], + F: sweepBdsBdsInstanceIdentityConfigurationResource, + }) + } +} + +func sweepBdsBdsInstanceIdentityConfigurationResource(compartment string) error { + bdsClient := acctest.GetTestClients(&schema.ResourceData{}).BdsClient() + bdsInstanceIdentityConfigurationIds, err := getBdsBdsInstanceIdentityConfigurationIds(compartment) + if err != nil { + return err + } + for _, bdsInstanceIdentityConfigurationId := range bdsInstanceIdentityConfigurationIds { + if ok := acctest.SweeperDefaultResourceId[bdsInstanceIdentityConfigurationId]; !ok { + deleteIdentityConfigurationRequest := oci_bds.DeleteIdentityConfigurationRequest{} + + deleteIdentityConfigurationRequest.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(true, "bds") + _, error := bdsClient.DeleteIdentityConfiguration(context.Background(), deleteIdentityConfigurationRequest) + if error != nil { + fmt.Printf("Error deleting BdsInstanceIdentityConfiguration %s %s, It is possible that the resource is already deleted. Please verify manually \n", bdsInstanceIdentityConfigurationId, error) + continue + } + acctest.WaitTillCondition(acctest.TestAccProvider, &bdsInstanceIdentityConfigurationId, BdsBdsInstanceIdentityConfigurationSweepWaitCondition, time.Duration(3*time.Minute), + BdsBdsInstanceIdentityConfigurationSweepResponseFetchOperation, "bds", true) + } + } + return nil +} + +func getBdsBdsInstanceIdentityConfigurationIds(compartment string) ([]string, error) { + ids := acctest.GetResourceIdsToSweep(compartment, "BdsInstanceIdentityConfigurationId") + if ids != nil { + return ids, nil + } + var resourceIds []string + compartmentId := compartment + bdsClient := acctest.GetTestClients(&schema.ResourceData{}).BdsClient() + + listIdentityConfigurationsRequest := oci_bds.ListIdentityConfigurationsRequest{} + listIdentityConfigurationsRequest.CompartmentId = &compartmentId + + bdsInstanceIds, error := getBdsInstanceIds(compartment) + if error != nil { + return resourceIds, fmt.Errorf("Error getting bdsInstanceId required for BdsInstanceIdentityConfiguration resource requests \n") + } + for _, bdsInstanceId := range bdsInstanceIds { + listIdentityConfigurationsRequest.BdsInstanceId = &bdsInstanceId + + listIdentityConfigurationsRequest.LifecycleState = oci_bds.IdentityConfigurationLifecycleStateActive + listIdentityConfigurationsResponse, err := bdsClient.ListIdentityConfigurations(context.Background(), listIdentityConfigurationsRequest) + + if err != nil { + return resourceIds, fmt.Errorf("Error getting BdsInstanceIdentityConfiguration list for compartment id : %s , %s \n", compartmentId, err) + } + for _, bdsInstanceIdentityConfiguration := range listIdentityConfigurationsResponse.Items { + id := *bdsInstanceIdentityConfiguration.Id + resourceIds = append(resourceIds, id) + acctest.AddResourceIdToSweeperResourceIdMap(compartmentId, "BdsInstanceIdentityConfigurationId", id) + } + + } + return resourceIds, nil +} + +func BdsBdsInstanceIdentityConfigurationSweepWaitCondition(response common.OCIOperationResponse) bool { + // Only stop if the resource is available beyond 3 mins. As there could be an issue for the sweeper to delete the resource and manual intervention required. + if bdsInstanceIdentityConfigurationResponse, ok := response.Response.(oci_bds.GetIdentityConfigurationResponse); ok { + return bdsInstanceIdentityConfigurationResponse.LifecycleState != oci_bds.IdentityConfigurationLifecycleStateDeleted + } + return false +} + +func BdsBdsInstanceIdentityConfigurationSweepResponseFetchOperation(client *tf_client.OracleClients, resourceId *string, retryPolicy *common.RetryPolicy) error { + _, err := client.BdsClient().GetIdentityConfiguration(context.Background(), oci_bds.GetIdentityConfigurationRequest{RequestMetadata: common.RequestMetadata{ + RetryPolicy: retryPolicy, + }, + }) + return err +} + +func getBdsIdentityConfigurationCompositeId(resourceName string) resource.ImportStateIdFunc { + return func(s *terraform.State) (string, error) { + rs, ok := s.RootModule().Resources[resourceName] + if !ok { + return "", fmt.Errorf("not found: %s", resourceName) + } + + return fmt.Sprintf("bdsInstances/%s/identityConfigurations/%s", rs.Primary.Attributes["bds_instance_id"], rs.Primary.Attributes["id"]), nil + } +} diff --git a/internal/integrationtest/bds_odh_instance_resource_test.go b/internal/integrationtest/bds_odh_instance_resource_test.go index d3e7e058f47..18318d48478 100644 --- a/internal/integrationtest/bds_odh_instance_resource_test.go +++ b/internal/integrationtest/bds_odh_instance_resource_test.go @@ -132,7 +132,7 @@ var ( "shape_config": acctest.RepresentationGroup{RepType: acctest.Required, Group: bdsInstanceNodesWorkerShapeConfigRepresentation}, } bdsInstanceNodesWorkerShapeConfigRepresentation = map[string]interface{}{ - "memory_in_gbs": acctest.Representation{RepType: acctest.Required, Create: `96`, Update: `96`}, + "memory_in_gbs": acctest.Representation{RepType: acctest.Required, Create: `120`, Update: `120`}, "ocpus": acctest.Representation{RepType: acctest.Required, Create: `8`, Update: `8`}, "nvmes": acctest.Representation{RepType: acctest.Required, Create: `1`, Update: `1`}, } @@ -270,12 +270,10 @@ func TestResourceBdsOdhInstance(t *testing.T) { }, ), }, - // delete before next Create { Config: config + compartmentIdVariableStr + BdsInstanceOdhResourceDependencies + bootstrapScriptUrlVariableStr, }, - // verify Create, cluster will be force stopped after create { Config: config + compartmentIdVariableStr + kmsKeyIdVariableStr + subnetIdVariableStr + BdsInstanceOdhResourceDependencies + bootstrapScriptUrlVariableStr + bootstrapScriptUrlUVariableStr + @@ -326,12 +324,123 @@ func TestResourceBdsOdhInstance(t *testing.T) { resource.TestCheckResourceAttr(resourceName, "state", "ACTIVE"), ), }, + // delete before next Create + { + Config: config + compartmentIdVariableStr + BdsInstanceOdhResourceDependencies + bootstrapScriptUrlVariableStr, + }, + // Create cluster with HADOOP_EXTENDED + { + Config: config + compartmentIdVariableStr + kmsKeyIdVariableStr + subnetIdVariableStr + BdsInstanceOdhResourceDependencies + bootstrapScriptUrlVariableStr + bootstrapScriptUrlUVariableStr + + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance", "test_bds_instance", acctest.Optional, acctest.Create, + acctest.RepresentationCopyWithNewProperties(bdsInstanceOdhRepresentation, map[string]interface{}{ + "cluster_profile": acctest.Representation{RepType: acctest.Optional, Create: `HADOOP_EXTENDED`}, + "display_name": acctest.Representation{RepType: acctest.Required, Create: `hadext1`, Update: `hadext1`}, + })), + Check: resource.ComposeAggregateTestCheckFunc( + resource.TestCheckResourceAttr(resourceName, "cluster_admin_password", "T3JhY2xlVGVhbVVTQSExMjM="), + resource.TestCheckResourceAttrSet(resourceName, "cluster_public_key"), + resource.TestCheckResourceAttr(resourceName, "cluster_version", "ODH1"), + resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttr(resourceName, "is_high_availability", "true"), + resource.TestCheckResourceAttr(resourceName, "is_secure", "true"), + resource.TestCheckResourceAttrSet(resourceName, "nodes.0.node_type"), + resource.TestCheckResourceAttrSet(resourceName, "nodes.0.shape"), + resource.TestCheckResourceAttrSet(resourceName, "nodes.0.subnet_id"), + resource.TestCheckResourceAttr(resourceName, "state", "ACTIVE"), + func(s *terraform.State) (err error) { + resId, err = acctest.FromInstanceState(s, resourceName, "id") + return err + }, + ), + }, + // Add Kafka to cluster + { + Config: config + compartmentIdVariableStr + compartmentIdUVariableStr + kmsKeyIdVariableStr + subnetIdVariableStr + BdsInstanceOdhResourceDependencies + bootstrapScriptUrlVariableStr + bootstrapScriptUrlUVariableStr + kmsKeyIdUVariableStr + + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance", "test_bds_instance", acctest.Optional, acctest.Update, + acctest.RepresentationCopyWithNewProperties(bdsInstanceOdhRepresentation, map[string]interface{}{ + "is_kafka_configured": acctest.Representation{RepType: acctest.Required, Create: `false`, Update: `true`}, + "cluster_profile": acctest.Representation{RepType: acctest.Optional, Create: `HADOOP_EXTENDED`, Update: `HADOOP_EXTENDED`}, + "display_name": acctest.Representation{RepType: acctest.Required, Create: `hadext1`, Update: `hadext1`}, + "kafka_broker_node": acctest.RepresentationGroup{RepType: acctest.Required, Group: bdsInstanceKafkaBrokerNodeFlexShapeRepresentation}, + })), + Check: resource.ComposeAggregateTestCheckFunc( + resource.TestCheckResourceAttr(resourceName, "cluster_admin_password", "T3JhY2xlVGVhbVVTQSExMjM="), + resource.TestCheckResourceAttrSet(resourceName, "cluster_public_key"), + resource.TestCheckResourceAttr(resourceName, "cluster_version", "ODH1"), + resource.TestCheckResourceAttr(resourceName, "is_high_availability", "true"), + resource.TestCheckResourceAttr(resourceName, "is_secure", "true"), + resource.TestCheckResourceAttr(resourceName, "is_kafka_configured", "true"), + resource.TestCheckResourceAttrSet(resourceName, "nodes.0.node_type"), + resource.TestCheckResourceAttrSet(resourceName, "nodes.0.shape"), + resource.TestCheckResourceAttrSet(resourceName, "nodes.0.subnet_id"), + resource.TestCheckResourceAttr(resourceName, "state", "ACTIVE"), + ), + }, + // Remove Kafka to cluster + { + Config: config + compartmentIdVariableStr + compartmentIdUVariableStr + kmsKeyIdVariableStr + subnetIdVariableStr + BdsInstanceOdhResourceDependencies + bootstrapScriptUrlVariableStr + bootstrapScriptUrlUVariableStr + kmsKeyIdUVariableStr + + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance", "test_bds_instance", acctest.Optional, acctest.Update, + acctest.RepresentationCopyWithNewProperties(bdsInstanceOdhRepresentation, map[string]interface{}{ + "is_kafka_configured": acctest.Representation{RepType: acctest.Required, Create: `false`, Update: `false`}, + "cluster_profile": acctest.Representation{RepType: acctest.Optional, Create: `HADOOP_EXTENDED`, Update: `HADOOP_EXTENDED`}, + "display_name": acctest.Representation{RepType: acctest.Required, Create: `hadext1`, Update: `hadext1`}, + })), + Check: resource.ComposeAggregateTestCheckFunc( + resource.TestCheckResourceAttr(resourceName, "cluster_admin_password", "T3JhY2xlVGVhbVVTQSExMjM="), + resource.TestCheckResourceAttrSet(resourceName, "cluster_public_key"), + resource.TestCheckResourceAttr(resourceName, "cluster_version", "ODH1"), + resource.TestCheckResourceAttr(resourceName, "is_high_availability", "true"), + resource.TestCheckResourceAttr(resourceName, "is_secure", "true"), + resource.TestCheckResourceAttr(resourceName, "is_kafka_configured", "false"), + resource.TestCheckResourceAttrSet(resourceName, "nodes.0.node_type"), + resource.TestCheckResourceAttrSet(resourceName, "nodes.0.shape"), + resource.TestCheckResourceAttrSet(resourceName, "nodes.0.subnet_id"), + resource.TestCheckResourceAttr(resourceName, "state", "ACTIVE"), + ), + }, // delete before next Create { Config: config + compartmentIdVariableStr + BdsInstanceOdhResourceDependencies + bootstrapScriptUrlVariableStr, }, + // verify Create with required fields Kafka cluster + { + Config: config + compartmentIdVariableStr + kmsKeyIdVariableStr + subnetIdVariableStr + BdsInstanceOdhResourceDependencies + bootstrapScriptUrlVariableStr + + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance", "test_bds_instance", acctest.Required, acctest.Create, + acctest.RepresentationCopyWithNewProperties(bdsInstanceOdhRepresentation, map[string]interface{}{ + "is_kafka_configured": acctest.Representation{RepType: acctest.Required, Create: `false`, Update: `false`}, + "cluster_profile": acctest.Representation{RepType: acctest.Optional, Create: `KAFKA`, Update: `HADOOP_EXTENDED`}, + "display_name": acctest.Representation{RepType: acctest.Required, Create: `kafkacluster`, Update: `kafkacluster`}, + "kafka_broker_node": acctest.RepresentationGroup{RepType: acctest.Required, Group: bdsInstanceKafkaBrokerNodeFlexShapeRepresentation}, + })), + Check: resource.ComposeAggregateTestCheckFunc( + resource.TestCheckResourceAttr(resourceName, "cluster_admin_password", "T3JhY2xlVGVhbVVTQSExMjM="), + resource.TestCheckResourceAttrSet(resourceName, "cluster_public_key"), + resource.TestCheckResourceAttr(resourceName, "cluster_version", "ODH1"), + resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttr(resourceName, "is_high_availability", "true"), + resource.TestCheckResourceAttr(resourceName, "is_secure", "true"), + resource.TestCheckResourceAttr(resourceName, "is_kafka_configured", "false"), + resource.TestCheckResourceAttrSet(resourceName, "nodes.0.node_type"), + resource.TestCheckResourceAttrSet(resourceName, "nodes.0.shape"), + resource.TestCheckResourceAttrSet(resourceName, "nodes.0.subnet_id"), + + func(s *terraform.State) (err error) { + resId, err = acctest.FromInstanceState(s, resourceName, "id") + if isEnableExportCompartment, _ := strconv.ParseBool(utils.GetEnvSettingWithDefault("enable_export_compartment", "true")); isEnableExportCompartment { + if errExport := resourcediscovery.TestExportCompartmentWithResourceName(&resId, &compartmentId, resourceName); errExport != nil { + return errExport + } + } + return err + }, + ), + }, + // delete before next Create + { + Config: config + compartmentIdVariableStr + BdsInstanceOdhResourceDependencies + bootstrapScriptUrlVariableStr, + }, // verify Create with optionals { Config: config + compartmentIdVariableStr + kmsKeyIdVariableStr + subnetIdVariableStr + BdsInstanceOdhResourceDependencies + bootstrapScriptUrlVariableStr + diff --git a/internal/provider/register_datasource.go b/internal/provider/register_datasource.go index a29af650477..8720d610067 100644 --- a/internal/provider/register_datasource.go +++ b/internal/provider/register_datasource.go @@ -52,7 +52,6 @@ import ( tf_devops "github.com/oracle/terraform-provider-oci/internal/service/devops" tf_disaster_recovery "github.com/oracle/terraform-provider-oci/internal/service/disaster_recovery" tf_dns "github.com/oracle/terraform-provider-oci/internal/service/dns" - tf_em_warehouse "github.com/oracle/terraform-provider-oci/internal/service/em_warehouse" tf_email "github.com/oracle/terraform-provider-oci/internal/service/email" tf_events "github.com/oracle/terraform-provider-oci/internal/service/events" tf_file_storage "github.com/oracle/terraform-provider-oci/internal/service/file_storage" @@ -274,9 +273,6 @@ func init() { if common.CheckForEnabledServices("dns") { tf_dns.RegisterDatasource() } - if common.CheckForEnabledServices("emwarehouse") { - tf_em_warehouse.RegisterDatasource() - } if common.CheckForEnabledServices("email") { tf_email.RegisterDatasource() } diff --git a/internal/provider/register_resource.go b/internal/provider/register_resource.go index af280cfa64f..62b6f603535 100644 --- a/internal/provider/register_resource.go +++ b/internal/provider/register_resource.go @@ -52,7 +52,6 @@ import ( tf_devops "github.com/oracle/terraform-provider-oci/internal/service/devops" tf_disaster_recovery "github.com/oracle/terraform-provider-oci/internal/service/disaster_recovery" tf_dns "github.com/oracle/terraform-provider-oci/internal/service/dns" - tf_em_warehouse "github.com/oracle/terraform-provider-oci/internal/service/em_warehouse" tf_email "github.com/oracle/terraform-provider-oci/internal/service/email" tf_events "github.com/oracle/terraform-provider-oci/internal/service/events" tf_file_storage "github.com/oracle/terraform-provider-oci/internal/service/file_storage" @@ -274,9 +273,6 @@ func init() { if common.CheckForEnabledServices("dns") { tf_dns.RegisterResource() } - if common.CheckForEnabledServices("emwarehouse") { - tf_em_warehouse.RegisterResource() - } if common.CheckForEnabledServices("email") { tf_email.RegisterResource() } diff --git a/internal/service/bds/bds_bds_instance_identity_configuration_data_source.go b/internal/service/bds/bds_bds_instance_identity_configuration_data_source.go new file mode 100644 index 00000000000..d4437cecdd1 --- /dev/null +++ b/internal/service/bds/bds_bds_instance_identity_configuration_data_source.go @@ -0,0 +1,113 @@ +// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. +// Licensed under the Mozilla Public License v2.0 + +package bds + +import ( + "context" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" + oci_bds "github.com/oracle/oci-go-sdk/v65/bds" + + "github.com/oracle/terraform-provider-oci/internal/client" + "github.com/oracle/terraform-provider-oci/internal/tfresource" +) + +func BdsBdsInstanceIdentityConfigurationDataSource() *schema.Resource { + fieldMap := make(map[string]*schema.Schema) + fieldMap["bds_instance_id"] = &schema.Schema{ + Type: schema.TypeString, + Required: true, + } + fieldMap["identity_configuration_id"] = &schema.Schema{ + Type: schema.TypeString, + Required: true, + } + return tfresource.GetSingularDataSourceItemSchema(BdsBdsInstanceIdentityConfigurationResource(), fieldMap, readSingularBdsBdsInstanceIdentityConfiguration) +} + +func readSingularBdsBdsInstanceIdentityConfiguration(d *schema.ResourceData, m interface{}) error { + sync := &BdsBdsInstanceIdentityConfigurationDataSourceCrud{} + sync.D = d + sync.Client = m.(*client.OracleClients).BdsClient() + + return tfresource.ReadResource(sync) +} + +type BdsBdsInstanceIdentityConfigurationDataSourceCrud struct { + D *schema.ResourceData + Client *oci_bds.BdsClient + Res *oci_bds.GetIdentityConfigurationResponse +} + +func (s *BdsBdsInstanceIdentityConfigurationDataSourceCrud) VoidState() { + s.D.SetId("") +} + +func (s *BdsBdsInstanceIdentityConfigurationDataSourceCrud) Get() error { + request := oci_bds.GetIdentityConfigurationRequest{} + + if bdsInstanceId, ok := s.D.GetOkExists("bds_instance_id"); ok { + tmp := bdsInstanceId.(string) + request.BdsInstanceId = &tmp + } + + if identityConfigurationId, ok := s.D.GetOkExists("identity_configuration_id"); ok { + tmp := identityConfigurationId.(string) + request.IdentityConfigurationId = &tmp + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(false, "bds") + + response, err := s.Client.GetIdentityConfiguration(context.Background(), request) + if err != nil { + return err + } + + s.Res = &response + return nil +} + +func (s *BdsBdsInstanceIdentityConfigurationDataSourceCrud) SetData() error { + if s.Res == nil { + return nil + } + + s.D.SetId(*s.Res.Id) + + if s.Res.ConfidentialApplicationId != nil { + s.D.Set("confidential_application_id", *s.Res.ConfidentialApplicationId) + } + + if s.Res.DisplayName != nil { + s.D.Set("display_name", *s.Res.DisplayName) + } + + if s.Res.IamUserSyncConfiguration != nil { + s.D.Set("iam_user_sync_configuration", []interface{}{IamUserSyncConfigurationToMap(s.Res.IamUserSyncConfiguration)}) + } else { + s.D.Set("iam_user_sync_configuration", nil) + } + + if s.Res.IdentityDomainId != nil { + s.D.Set("identity_domain_id", *s.Res.IdentityDomainId) + } + + s.D.Set("state", s.Res.LifecycleState) + + if s.Res.TimeCreated != nil { + s.D.Set("time_created", s.Res.TimeCreated.String()) + } + + if s.Res.TimeUpdated != nil { + s.D.Set("time_updated", s.Res.TimeUpdated.String()) + } + + if s.Res.UpstConfiguration != nil { + s.D.Set("upst_configuration", []interface{}{UpstConfigurationToMap(s.Res.UpstConfiguration)}) + } else { + s.D.Set("upst_configuration", nil) + } + + return nil +} diff --git a/internal/service/bds/bds_bds_instance_identity_configuration_resource.go b/internal/service/bds/bds_bds_instance_identity_configuration_resource.go new file mode 100644 index 00000000000..17c7f039891 --- /dev/null +++ b/internal/service/bds/bds_bds_instance_identity_configuration_resource.go @@ -0,0 +1,1037 @@ +// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. +// Licensed under the Mozilla Public License v2.0 + +package bds + +import ( + "context" + "fmt" + "log" + "net/url" + "regexp" + "strings" + "time" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" + + oci_bds "github.com/oracle/oci-go-sdk/v65/bds" + oci_common "github.com/oracle/oci-go-sdk/v65/common" + + "github.com/oracle/terraform-provider-oci/internal/client" + "github.com/oracle/terraform-provider-oci/internal/tfresource" +) + +func BdsBdsInstanceIdentityConfigurationResource() *schema.Resource { + return &schema.Resource{ + Importer: &schema.ResourceImporter{ + State: schema.ImportStatePassthrough, + }, + Timeouts: tfresource.DefaultTimeout, + Create: createBdsBdsInstanceIdentityConfiguration, + Read: readBdsBdsInstanceIdentityConfiguration, + Update: updateBdsBdsInstanceIdentityConfiguration, + Delete: deleteBdsBdsInstanceIdentityConfiguration, + Schema: map[string]*schema.Schema{ + // Required + "bds_instance_id": { + Type: schema.TypeString, + Required: true, + ForceNew: true, + }, + "cluster_admin_password": { + Type: schema.TypeString, + Required: true, + Sensitive: true, + }, + "confidential_application_id": { + Type: schema.TypeString, + Required: true, + ForceNew: true, + }, + "display_name": { + Type: schema.TypeString, + Required: true, + ForceNew: true, + }, + "identity_domain_id": { + Type: schema.TypeString, + Required: true, + ForceNew: true, + }, + + // Optional + "iam_user_sync_configuration_details": { + Type: schema.TypeList, + Optional: true, + Computed: true, + MaxItems: 1, + MinItems: 1, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + + // Optional + "is_posix_attributes_addition_required": { + Type: schema.TypeBool, + Optional: true, + Computed: true, + }, + + // Computed + }, + }, + }, + "upst_configuration_details": { + Type: schema.TypeList, + Optional: true, + Computed: true, + MaxItems: 1, + MinItems: 1, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + + // Optional + "master_encryption_key_id": { + Type: schema.TypeString, + Optional: true, + Computed: true, + }, + "vault_id": { + Type: schema.TypeString, + Optional: true, + Computed: true, + }, + + // Computed + }, + }, + }, + "activate_iam_user_sync_configuration_trigger": { + Type: schema.TypeString, + Optional: true, + }, + "activate_upst_configuration_trigger": { + Type: schema.TypeString, + Optional: true, + }, + "refresh_confidential_application_trigger": { + Type: schema.TypeString, + Optional: true, + }, + "refresh_upst_token_exchange_keytab_trigger": { + Type: schema.TypeString, + Optional: true, + }, + + // Computed + "iam_user_sync_configuration": { + Type: schema.TypeList, + Computed: true, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + + // Optional + + // Computed + "is_posix_attributes_addition_required": { + Type: schema.TypeBool, + Computed: true, + }, + "state": { + Type: schema.TypeString, + Computed: true, + }, + "time_created": { + Type: schema.TypeString, + Computed: true, + }, + "time_updated": { + Type: schema.TypeString, + Computed: true, + }, + }, + }, + }, + "state": { + Type: schema.TypeString, + Computed: true, + }, + "time_created": { + Type: schema.TypeString, + Computed: true, + }, + "time_updated": { + Type: schema.TypeString, + Computed: true, + }, + "upst_configuration": { + Type: schema.TypeList, + Computed: true, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + + // Optional + + // Computed + "keytab_content": { + Type: schema.TypeString, + Computed: true, + }, + "master_encryption_key_id": { + Type: schema.TypeString, + Computed: true, + }, + "secret_id": { + Type: schema.TypeString, + Computed: true, + }, + "state": { + Type: schema.TypeString, + Computed: true, + }, + "time_created": { + Type: schema.TypeString, + Computed: true, + }, + "time_token_exchange_keytab_last_refreshed": { + Type: schema.TypeString, + Computed: true, + }, + "time_updated": { + Type: schema.TypeString, + Computed: true, + }, + "token_exchange_principal_name": { + Type: schema.TypeString, + Computed: true, + }, + "vault_id": { + Type: schema.TypeString, + Computed: true, + }, + }, + }, + }, + }, + } +} + +func createBdsBdsInstanceIdentityConfiguration(d *schema.ResourceData, m interface{}) error { + sync := &BdsBdsInstanceIdentityConfigurationResourceCrud{} + sync.D = d + sync.Client = m.(*client.OracleClients).BdsClient() + + if e := tfresource.CreateResource(d, sync); e != nil { + return e + } + return nil + +} + +func readBdsBdsInstanceIdentityConfiguration(d *schema.ResourceData, m interface{}) error { + sync := &BdsBdsInstanceIdentityConfigurationResourceCrud{} + sync.D = d + sync.Client = m.(*client.OracleClients).BdsClient() + return tfresource.ReadResource(sync) +} + +func updateBdsBdsInstanceIdentityConfiguration(d *schema.ResourceData, m interface{}) error { + + sync := &BdsBdsInstanceIdentityConfigurationResourceCrud{} + sync.D = d + sync.Client = m.(*client.OracleClients).BdsClient() + + if triggerVal, ok := sync.D.GetOkExists("activate_iam_user_sync_configuration_trigger"); ok && sync.D.HasChange("activate_iam_user_sync_configuration_trigger") { + if triggerVal.(string) == "true" { + err := sync.ActivateIamUserSyncConfiguration() + + if err != nil { + return err + } + } + } + + if triggerVal, ok := sync.D.GetOkExists("activate_upst_configuration_trigger"); ok && sync.D.HasChange("activate_upst_configuration_trigger") { + if triggerVal.(string) == "true" { + err := sync.ActivateUpstConfiguration() + + if err != nil { + return err + } + } + } + + if refreshTrigger, ok := sync.D.GetOkExists("refresh_confidential_application_trigger"); ok { + if refreshTrigger.(string) == "true" { + err := sync.RefreshConfidentialApplication() + if err != nil { + return err + } + } + } + + if refreshTrigger, ok := sync.D.GetOkExists("refresh_upst_token_exchange_keytab_trigger"); ok { + if refreshTrigger.(string) == "true" { + err := sync.RefreshUpstTokenExchangeKeytab() + if err != nil { + return err + } + } + } + + if _, ok := sync.D.GetOkExists("activate_iam_user_sync_configuration_trigger"); ok && sync.D.HasChange("activate_iam_user_sync_configuration_trigger") { + triggerVal := sync.D.Get("activate_iam_user_sync_configuration_trigger") + if triggerVal.(string) == "false" { + err := sync.DeactivateIamUserSyncConfiguration() + + if err != nil { + return err + } + } + } + + if _, ok := sync.D.GetOkExists("activate_upst_configuration_trigger"); ok && sync.D.HasChange("activate_upst_configuration_trigger") { + triggerVal := sync.D.Get("activate_upst_configuration_trigger") + if triggerVal.(string) == "false" { + err := sync.DeactivateUpstConfiguration() + + if err != nil { + return err + } + } + } + + if err := tfresource.UpdateResource(d, sync); err != nil { + return err + } + + return nil +} + +func deleteBdsBdsInstanceIdentityConfiguration(d *schema.ResourceData, m interface{}) error { + + sync := &BdsBdsInstanceIdentityConfigurationResourceCrud{} + sync.D = d + sync.Client = m.(*client.OracleClients).BdsClient() + sync.DisableNotFoundRetries = true + + return tfresource.DeleteResource(d, sync) +} + +type BdsBdsInstanceIdentityConfigurationResourceCrud struct { + tfresource.BaseCrud + Client *oci_bds.BdsClient + Res *oci_bds.IdentityConfiguration + DisableNotFoundRetries bool +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) ID() string { + return GetBdsInstanceIdentityConfigurationCompositeId(s.D.Get("bds_instance_id").(string), *s.Res.Id) +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) CreatedPending() []string { + return []string{} +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) CreatedTarget() []string { + return []string{ + string(oci_bds.IdentityConfigurationLifecycleStateActive), + } +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) DeletedPending() []string { + return []string{} +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) DeletedTarget() []string { + return []string{ + string(oci_bds.IdentityConfigurationLifecycleStateDeleted), + } +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) Create() error { + request := oci_bds.CreateIdentityConfigurationRequest{} + + if bdsInstanceId, ok := s.D.GetOkExists("bds_instance_id"); ok { + tmp := bdsInstanceId.(string) + request.BdsInstanceId = &tmp + } + + if clusterAdminPassword, ok := s.D.GetOkExists("cluster_admin_password"); ok { + tmp := clusterAdminPassword.(string) + request.ClusterAdminPassword = &tmp + } + + if confidentialApplicationId, ok := s.D.GetOkExists("confidential_application_id"); ok { + tmp := confidentialApplicationId.(string) + request.ConfidentialApplicationId = &tmp + } + + if displayName, ok := s.D.GetOkExists("display_name"); ok { + tmp := displayName.(string) + request.DisplayName = &tmp + } + + if _, ok := s.D.GetOkExists("activate_iam_user_sync_configuration_trigger"); ok { + triggerVal := s.D.Get("activate_iam_user_sync_configuration_trigger") + if iamUserSyncConfigurationDetails, ok := s.D.GetOkExists("iam_user_sync_configuration_details"); ok && triggerVal.(string) == "true" { + if tmpList := iamUserSyncConfigurationDetails.([]interface{}); len(tmpList) > 0 { + fieldKeyFormat := fmt.Sprintf("%s.%d.%%s", "iam_user_sync_configuration_details", 0) + tmp, err := s.mapToiamUserSyncConfigurationDetails(fieldKeyFormat) + if err != nil { + return err + } + request.IamUserSyncConfigurationDetails = &tmp + } + } + } + + if identityDomainId, ok := s.D.GetOkExists("identity_domain_id"); ok { + tmp := identityDomainId.(string) + request.IdentityDomainId = &tmp + } + + if _, ok := s.D.GetOkExists("activate_upst_configuration_trigger"); ok { + triggerVal := s.D.Get("activate_upst_configuration_trigger") + if upstConfigurationDetails, ok := s.D.GetOkExists("upst_configuration_details"); ok && triggerVal.(string) == "true" { + if tmpList := upstConfigurationDetails.([]interface{}); len(tmpList) > 0 { + fieldKeyFormat := fmt.Sprintf("%s.%d.%%s", "upst_configuration_details", 0) + tmp, err := s.mapToupstConfigurationDetails(fieldKeyFormat) + if err != nil { + return err + } + request.UpstConfigurationDetails = &tmp + } + } + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds") + + response, err := s.Client.CreateIdentityConfiguration(context.Background(), request) + if err != nil { + return err + } + + workId := response.OpcWorkRequestId + return s.getBdsInstanceIdentityConfigurationFromWorkRequest(workId, tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds"), oci_bds.ActionTypesCreated, s.D.Timeout(schema.TimeoutCreate)) +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) getBdsInstanceIdentityConfigurationFromWorkRequest(workId *string, retryPolicy *oci_common.RetryPolicy, + actionTypeEnum oci_bds.ActionTypesEnum, timeout time.Duration) error { + // Wait until it finishes + bdsInstanceIdentityConfigurationId, err := bdsInstanceIdentityConfigurationWaitForWorkRequest(workId, "bdsidentityconfig", + actionTypeEnum, timeout, s.DisableNotFoundRetries, s.Client) + if err != nil { + return err + } + s.D.SetId(*bdsInstanceIdentityConfigurationId) + return s.Get() +} + +func bdsInstanceIdentityConfigurationWorkRequestShouldRetryFunc(timeout time.Duration) func(response oci_common.OCIOperationResponse) bool { + startTime := time.Now() + stopTime := startTime.Add(timeout) + return func(response oci_common.OCIOperationResponse) bool { + + // Stop after timeout has elapsed + if time.Now().After(stopTime) { + return false + } + + // Make sure we stop on default rules + if tfresource.ShouldRetry(response, false, "bds", startTime) { + return true + } + + // Only stop if the time Finished is set + if workRequestResponse, ok := response.Response.(oci_bds.GetWorkRequestResponse); ok { + return workRequestResponse.TimeFinished == nil + } + return false + } +} + +func bdsInstanceIdentityConfigurationWaitForWorkRequest(wId *string, entityType string, action oci_bds.ActionTypesEnum, + timeout time.Duration, disableFoundRetries bool, client *oci_bds.BdsClient) (*string, error) { + retryPolicy := tfresource.GetRetryPolicy(disableFoundRetries, "bds") + retryPolicy.ShouldRetryOperation = bdsInstanceIdentityConfigurationWorkRequestShouldRetryFunc(timeout) + response := oci_bds.GetWorkRequestResponse{} + stateConf := &resource.StateChangeConf{ + Pending: []string{ + string(oci_bds.OperationStatusInProgress), + string(oci_bds.OperationStatusAccepted), + string(oci_bds.OperationStatusCanceling), + }, + Target: []string{ + string(oci_bds.OperationStatusSucceeded), + string(oci_bds.OperationStatusFailed), + string(oci_bds.OperationStatusCanceled), + }, + Refresh: func() (interface{}, string, error) { + var err error + response, err = client.GetWorkRequest(context.Background(), + oci_bds.GetWorkRequestRequest{ + WorkRequestId: wId, + RequestMetadata: oci_common.RequestMetadata{ + RetryPolicy: retryPolicy, + }, + }) + wr := &response.WorkRequest + return wr, string(wr.Status), err + }, + Timeout: timeout, + } + if _, e := stateConf.WaitForState(); e != nil { + return nil, e + } + + var identifier *string + // The work request response contains an array of objects that finished the operation + for _, res := range response.Resources { + if strings.Contains(strings.ToLower(*res.EntityType), entityType) { + if res.ActionType == action { + identifier = res.Identifier + break + } + } + } + // The workrequest may have failed, check for errors if identifier is not found or work failed or got cancelled + if identifier == nil || response.Status == oci_bds.OperationStatusFailed || response.Status == oci_bds.OperationStatusCanceled { + return nil, getErrorFromBdsBdsInstanceIdentityConfigurationWorkRequest(client, wId, retryPolicy, entityType, action) + } + return identifier, nil +} + +func getErrorFromBdsBdsInstanceIdentityConfigurationWorkRequest(client *oci_bds.BdsClient, workId *string, retryPolicy *oci_common.RetryPolicy, entityType string, action oci_bds.ActionTypesEnum) error { + response, err := client.ListWorkRequestErrors(context.Background(), + oci_bds.ListWorkRequestErrorsRequest{ + WorkRequestId: workId, + RequestMetadata: oci_common.RequestMetadata{ + RetryPolicy: retryPolicy, + }, + }) + if err != nil { + return err + } + + allErrs := make([]string, 0) + for _, wrkErr := range response.Items { + allErrs = append(allErrs, *wrkErr.Message) + } + errorMessage := strings.Join(allErrs, "\n") + + workRequestErr := fmt.Errorf("work request did not succeed, workId: %s, entity: %s, action: %s. Message: %s", *workId, entityType, action, errorMessage) + return workRequestErr +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) Get() error { + request := oci_bds.GetIdentityConfigurationRequest{} + + tmp := s.D.Id() + request.IdentityConfigurationId = &tmp + + if bdsInstanceId, ok := s.D.GetOkExists("bds_instance_id"); ok { + tmp := bdsInstanceId.(string) + request.BdsInstanceId = &tmp + } + + bdsInstanceId, identityConfigurationId, err := parseBdsInstanceIdentityConfigurationCompositeId(s.D.Id()) + if err == nil { + request.BdsInstanceId = &bdsInstanceId + request.IdentityConfigurationId = &identityConfigurationId + } else { + log.Printf("[WARN] Get() unable to parse current ID: %s", s.D.Id()) + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds") + + response, err := s.Client.GetIdentityConfiguration(context.Background(), request) + if err != nil { + return err + } + + s.Res = &response.IdentityConfiguration + return nil +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) Update() error { + request := oci_bds.UpdateIdentityConfigurationRequest{} + + if bdsInstanceId, ok := s.D.GetOkExists("bds_instance_id"); ok { + tmp := bdsInstanceId.(string) + request.BdsInstanceId = &tmp + } + + if clusterAdminPassword, ok := s.D.GetOkExists("cluster_admin_password"); ok { + tmp := clusterAdminPassword.(string) + request.ClusterAdminPassword = &tmp + } + + if iamUserSyncConfigurationDetails, ok := s.D.GetOkExists("iam_user_sync_configuration_details"); ok { + if tmpList := iamUserSyncConfigurationDetails.([]interface{}); len(tmpList) > 0 { + fieldKeyFormat := fmt.Sprintf("%s.%d.%%s", "iam_user_sync_configuration_details", 0) + tmp, err := s.mapToiamUserSyncConfigurationDetails(fieldKeyFormat) + if err != nil { + return err + } + request.IamUserSyncConfigurationDetails = &tmp + } + } + + tmp := s.D.Id() + request.IdentityConfigurationId = &tmp + + if upstConfigurationDetails, ok := s.D.GetOkExists("upst_configuration_details"); ok { + if tmpList := upstConfigurationDetails.([]interface{}); len(tmpList) > 0 { + fieldKeyFormat := fmt.Sprintf("%s.%d.%%s", "upst_configuration_details", 0) + tmp, err := s.mapToupstConfigurationDetails(fieldKeyFormat) + if err != nil { + return err + } + request.UpstConfigurationDetails = &tmp + } + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds") + + response, err := s.Client.UpdateIdentityConfiguration(context.Background(), request) + if err != nil { + return err + } + + workId := response.OpcWorkRequestId + return s.getBdsInstanceIdentityConfigurationFromWorkRequest(workId, tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds"), oci_bds.ActionTypesUpdated, s.D.Timeout(schema.TimeoutUpdate)) +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) Delete() error { + request := oci_bds.DeleteIdentityConfigurationRequest{} + + if bdsInstanceId, ok := s.D.GetOkExists("bds_instance_id"); ok { + tmp := bdsInstanceId.(string) + request.BdsInstanceId = &tmp + } + + tmp := s.D.Id() + request.IdentityConfigurationId = &tmp + + if trigger, ok := s.D.GetOkExists("activate_iam_user_sync_configuration_trigger"); ok { + if trigger.(string) == "true" { + err := s.DeactivateIamUserSyncConfiguration() + if err != nil { + return err + } + } + } + + if trigger, ok := s.D.GetOkExists("activate_upst_configuration_trigger"); ok { + if trigger.(string) == "true" { + err := s.DeactivateUpstConfiguration() + + if err != nil { + return err + } + } + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds") + + response, err := s.Client.DeleteIdentityConfiguration(context.Background(), request) + if err != nil { + return err + } + + workId := response.OpcWorkRequestId + // Wait until it finishes + _, delWorkRequestErr := bdsInstanceIdentityConfigurationWaitForWorkRequest(workId, "bdsidentityconfig", + oci_bds.ActionTypesDeleted, s.D.Timeout(schema.TimeoutDelete), s.DisableNotFoundRetries, s.Client) + return delWorkRequestErr +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) SetData() error { + bdsInstanceId, identityConfigurationId, err := parseBdsInstanceIdentityConfigurationCompositeId(s.D.Id()) + if err == nil { + s.D.Set("bds_instance_id", &bdsInstanceId) + s.D.SetId(identityConfigurationId) + + } else { + log.Printf("[WARN] SetData() unable to parse current ID: %s", s.D.Id()) + } + + if s.Res.ConfidentialApplicationId != nil { + s.D.Set("confidential_application_id", *s.Res.ConfidentialApplicationId) + } + + if s.Res.DisplayName != nil { + s.D.Set("display_name", *s.Res.DisplayName) + } + + if s.Res.IamUserSyncConfiguration != nil { + s.D.Set("iam_user_sync_configuration", []interface{}{IamUserSyncConfigurationToMap(s.Res.IamUserSyncConfiguration)}) + } else { + s.D.Set("iam_user_sync_configuration", nil) + } + + if s.Res.IdentityDomainId != nil { + s.D.Set("identity_domain_id", *s.Res.IdentityDomainId) + } + + s.D.Set("state", s.Res.LifecycleState) + + if s.Res.TimeCreated != nil { + s.D.Set("time_created", s.Res.TimeCreated.String()) + } + + if s.Res.TimeUpdated != nil { + s.D.Set("time_updated", s.Res.TimeUpdated.String()) + } + + if s.Res.UpstConfiguration != nil { + s.D.Set("upst_configuration", []interface{}{UpstConfigurationToMap(s.Res.UpstConfiguration)}) + } else { + s.D.Set("upst_configuration", nil) + } + return nil +} + +func GetBdsInstanceIdentityConfigurationCompositeId(bdsInstanceId string, identityConfigurationId string) string { + bdsInstanceId = url.PathEscape(bdsInstanceId) + identityConfigurationId = url.PathEscape(identityConfigurationId) + compositeId := "bdsInstances/" + bdsInstanceId + "/identityConfigurations/" + identityConfigurationId + return compositeId +} + +func parseBdsInstanceIdentityConfigurationCompositeId(compositeId string) (bdsInstanceId string, identityConfigurationId string, err error) { + parts := strings.Split(compositeId, "/") + match, _ := regexp.MatchString("bdsInstances/.*/identityConfigurations/.*", compositeId) + if !match || len(parts) != 4 { + err = fmt.Errorf("illegal compositeId %s encountered", compositeId) + return + } + bdsInstanceId, _ = url.PathUnescape(parts[1]) + identityConfigurationId, _ = url.PathUnescape(parts[3]) + return +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) ActivateIamUserSyncConfiguration() error { + request := oci_bds.ActivateIamUserSyncConfigurationRequest{} + + if bdsInstanceId, ok := s.D.GetOkExists("bds_instance_id"); ok { + tmp := bdsInstanceId.(string) + request.BdsInstanceId = &tmp + } + + if clusterAdminPassword, ok := s.D.GetOkExists("cluster_admin_password"); ok { + tmp := clusterAdminPassword.(string) + request.ClusterAdminPassword = &tmp + } + + tmp := s.D.Id() + request.IdentityConfigurationId = &tmp + + if isPosixAttributesAdditionRequired, ok := s.D.GetOkExists("iam_user_sync_configuration_details.0.is_posix_attributes_addition_required"); ok { + tmp := isPosixAttributesAdditionRequired.(bool) + request.IsPosixAttributesAdditionRequired = &tmp + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds") + + response, err := s.Client.ActivateIamUserSyncConfiguration(context.Background(), request) + if err != nil { + return err + } + + if waitErr := tfresource.WaitForUpdatedState(s.D, s); waitErr != nil { + return waitErr + } + + workId := response.OpcWorkRequestId + val := s.D.Get("activate_iam_user_sync_configuration_trigger") + s.D.Set("activate_iam_user_sync_configuration_trigger", val) + return s.getBdsInstanceIdentityConfigurationFromWorkRequest(workId, tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds"), oci_bds.ActionTypesUpdated, s.D.Timeout(schema.TimeoutCreate)) + +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) ActivateUpstConfiguration() error { + request := oci_bds.ActivateUpstConfigurationRequest{} + + if bdsInstanceId, ok := s.D.GetOkExists("bds_instance_id"); ok { + tmp := bdsInstanceId.(string) + request.BdsInstanceId = &tmp + } + + if clusterAdminPassword, ok := s.D.GetOkExists("cluster_admin_password"); ok { + tmp := clusterAdminPassword.(string) + request.ClusterAdminPassword = &tmp + } + + tmp := s.D.Id() + request.IdentityConfigurationId = &tmp + + if masterEncryptionKeyId, ok := s.D.GetOkExists("upst_configuration_details.0.master_encryption_key_id"); ok { + tmp := masterEncryptionKeyId.(string) + request.MasterEncryptionKeyId = &tmp + } + + if vaultId, ok := s.D.GetOkExists("upst_configuration_details.0.vault_id"); ok { + tmp := vaultId.(string) + request.VaultId = &tmp + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds") + + response, err := s.Client.ActivateUpstConfiguration(context.Background(), request) + if err != nil { + return err + } + + if waitErr := tfresource.WaitForUpdatedState(s.D, s); waitErr != nil { + return waitErr + } + + workId := response.OpcWorkRequestId + val := s.D.Get("activate_upst_configuration_trigger") + s.D.Set("activate_upst_configuration_trigger", val) + return s.getBdsInstanceIdentityConfigurationFromWorkRequest(workId, tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds"), oci_bds.ActionTypesUpdated, s.D.Timeout(schema.TimeoutCreate)) + +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) DeactivateIamUserSyncConfiguration() error { + request := oci_bds.DeactivateIamUserSyncConfigurationRequest{} + + tmp := s.D.Id() + request.IdentityConfigurationId = &tmp + + if bdsInstanceId, ok := s.D.GetOkExists("bds_instance_id"); ok { + tmp := bdsInstanceId.(string) + request.BdsInstanceId = &tmp + } + + if clusterAdminPassword, ok := s.D.GetOkExists("cluster_admin_password"); ok { + tmp := clusterAdminPassword.(string) + request.ClusterAdminPassword = &tmp + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds") + + response, err := s.Client.DeactivateIamUserSyncConfiguration(context.Background(), request) + if err != nil { + return err + } + + if waitErr := tfresource.WaitForUpdatedState(s.D, s); waitErr != nil { + return waitErr + } + workId := response.OpcWorkRequestId + val := s.D.Get("activate_iam_user_sync_configuration_trigger") + s.D.Set("activate_iam_user_sync_configuration_trigger", val) + return s.getBdsInstanceIdentityConfigurationFromWorkRequest(workId, tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds"), oci_bds.ActionTypesUpdated, s.D.Timeout(schema.TimeoutUpdate)) + +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) DeactivateUpstConfiguration() error { + request := oci_bds.DeactivateUpstConfigurationRequest{} + + if bdsInstanceId, ok := s.D.GetOkExists("bds_instance_id"); ok { + tmp := bdsInstanceId.(string) + request.BdsInstanceId = &tmp + } + + if clusterAdminPassword, ok := s.D.GetOkExists("cluster_admin_password"); ok { + tmp := clusterAdminPassword.(string) + request.ClusterAdminPassword = &tmp + } + + tmp := s.D.Id() + request.IdentityConfigurationId = &tmp + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds") + + response, err := s.Client.DeactivateUpstConfiguration(context.Background(), request) + if err != nil { + return err + } + + if waitErr := tfresource.WaitForUpdatedState(s.D, s); waitErr != nil { + return waitErr + } + workId := response.OpcWorkRequestId + val := s.D.Get("activate_upst_configuration_trigger") + s.D.Set("activate_upst_configuration_trigger", val) + return s.getBdsInstanceIdentityConfigurationFromWorkRequest(workId, tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds"), oci_bds.ActionTypesUpdated, s.D.Timeout(schema.TimeoutUpdate)) + +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) RefreshConfidentialApplication() error { + request := oci_bds.RefreshConfidentialApplicationRequest{} + + if bdsInstanceId, ok := s.D.GetOkExists("bds_instance_id"); ok { + tmp := bdsInstanceId.(string) + request.BdsInstanceId = &tmp + } + + if clusterAdminPassword, ok := s.D.GetOkExists("cluster_admin_password"); ok { + tmp := clusterAdminPassword.(string) + request.ClusterAdminPassword = &tmp + } + + tmp := s.D.Id() + request.IdentityConfigurationId = &tmp + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds") + + response, err := s.Client.RefreshConfidentialApplication(context.Background(), request) + if err != nil { + return err + } + + if waitErr := tfresource.WaitForUpdatedState(s.D, s); waitErr != nil { + return waitErr + } + workId := response.OpcWorkRequestId + + //s.D.Set("refresh_confidential_application_trigger", "false") + return s.getBdsInstanceIdentityConfigurationFromWorkRequest(workId, tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds"), oci_bds.ActionTypesUpdated, s.D.Timeout(schema.TimeoutCreate)) + +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) RefreshUpstTokenExchangeKeytab() error { + request := oci_bds.RefreshUpstTokenExchangeKeytabRequest{} + + if bdsInstanceId, ok := s.D.GetOkExists("bds_instance_id"); ok { + tmp := bdsInstanceId.(string) + request.BdsInstanceId = &tmp + } + + if clusterAdminPassword, ok := s.D.GetOkExists("cluster_admin_password"); ok { + tmp := clusterAdminPassword.(string) + request.ClusterAdminPassword = &tmp + } + + tmp := s.D.Id() + request.IdentityConfigurationId = &tmp + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds") + + response, err := s.Client.RefreshUpstTokenExchangeKeytab(context.Background(), request) + if err != nil { + return err + } + + if waitErr := tfresource.WaitForUpdatedState(s.D, s); waitErr != nil { + return waitErr + } + workId := response.OpcWorkRequestId + + //s.D.Set("refresh_upst_token_exchange_keytab_trigger", "false") + return s.getBdsInstanceIdentityConfigurationFromWorkRequest(workId, tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds"), oci_bds.ActionTypesUpdated, s.D.Timeout(schema.TimeoutCreate)) + +} + +func IamUserSyncConfigurationToMap(obj *oci_bds.IamUserSyncConfiguration) map[string]interface{} { + result := map[string]interface{}{} + + if obj.IsPosixAttributesAdditionRequired != nil { + result["is_posix_attributes_addition_required"] = bool(*obj.IsPosixAttributesAdditionRequired) + } + + result["state"] = string(obj.LifecycleState) + + if obj.TimeCreated != nil { + result["time_created"] = obj.TimeCreated.String() + } + + if obj.TimeUpdated != nil { + result["time_updated"] = obj.TimeUpdated.String() + } + return result +} + +func UpstConfigurationToMap(obj *oci_bds.UpstConfiguration) map[string]interface{} { + result := map[string]interface{}{} + + if obj.KeytabContent != nil { + result["keytab_content"] = string(*obj.KeytabContent) + } + + if obj.MasterEncryptionKeyId != nil { + result["master_encryption_key_id"] = string(*obj.MasterEncryptionKeyId) + } + + if obj.SecretId != nil { + result["secret_id"] = string(*obj.SecretId) + } + + result["state"] = string(obj.LifecycleState) + + if obj.TimeCreated != nil { + result["time_created"] = obj.TimeCreated.String() + } + + if obj.TimeTokenExchangeKeytabLastRefreshed != nil { + result["time_token_exchange_keytab_last_refreshed"] = obj.TimeTokenExchangeKeytabLastRefreshed.String() + } + + if obj.TimeUpdated != nil { + result["time_updated"] = obj.TimeUpdated.String() + } + + if obj.TokenExchangePrincipalName != nil { + result["token_exchange_principal_name"] = string(*obj.TokenExchangePrincipalName) + } + + if obj.VaultId != nil { + result["vault_id"] = string(*obj.VaultId) + } + return result +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) mapToiamUserSyncConfigurationDetails(fieldKeyFormat string) (oci_bds.IamUserSyncConfigurationDetails, error) { + result := oci_bds.IamUserSyncConfigurationDetails{} + + if isPosixAttributesAdditionRequired, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "is_posix_attributes_addition_required")); ok { + tmp := isPosixAttributesAdditionRequired.(bool) + result.IsPosixAttributesAdditionRequired = &tmp + } + return result, nil +} + +func iamUserSyncConfigurationDetailsToMap(obj *oci_bds.IamUserSyncConfigurationDetails) map[string]interface{} { + result := map[string]interface{}{} + + if obj.IsPosixAttributesAdditionRequired != nil { + result["is_posix_attributes_addition_required"] = bool(*obj.IsPosixAttributesAdditionRequired) + } + return result +} + +func (s *BdsBdsInstanceIdentityConfigurationResourceCrud) mapToupstConfigurationDetails(fieldKeyFormat string) (oci_bds.UpstConfigurationDetails, error) { + result := oci_bds.UpstConfigurationDetails{} + + if masterEncryptionKeyId, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "master_encryption_key_id")); ok { + tmp := masterEncryptionKeyId.(string) + result.MasterEncryptionKeyId = &tmp + } + + if vaultId, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "vault_id")); ok { + tmp := vaultId.(string) + result.VaultId = &tmp + } + return result, nil +} + +func upstConfigurationDetailsToMap(obj *oci_bds.UpstConfigurationDetails) map[string]interface{} { + result := map[string]interface{}{} + + if obj.MasterEncryptionKeyId != nil { + result["master_encryption_key_id"] = string(*obj.MasterEncryptionKeyId) + } + + if obj.VaultId != nil { + result["vault_id"] = string(*obj.VaultId) + } + return result +} diff --git a/internal/service/bds/bds_bds_instance_identity_configurations_data_source.go b/internal/service/bds/bds_bds_instance_identity_configurations_data_source.go new file mode 100644 index 00000000000..2770aa88c08 --- /dev/null +++ b/internal/service/bds/bds_bds_instance_identity_configurations_data_source.go @@ -0,0 +1,142 @@ +// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. +// Licensed under the Mozilla Public License v2.0 + +package bds + +import ( + "context" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" + oci_bds "github.com/oracle/oci-go-sdk/v65/bds" + + "github.com/oracle/terraform-provider-oci/internal/client" + "github.com/oracle/terraform-provider-oci/internal/tfresource" +) + +func BdsBdsInstanceIdentityConfigurationsDataSource() *schema.Resource { + return &schema.Resource{ + Read: readBdsBdsInstanceIdentityConfigurations, + Schema: map[string]*schema.Schema{ + "filter": tfresource.DataSourceFiltersSchema(), + "bds_instance_id": { + Type: schema.TypeString, + Required: true, + }, + "compartment_id": { + Type: schema.TypeString, + Required: true, + }, + "display_name": { + Type: schema.TypeString, + Optional: true, + }, + "state": { + Type: schema.TypeString, + Optional: true, + }, + "identity_configurations": { + Type: schema.TypeList, + Computed: true, + Elem: tfresource.GetDataSourceItemSchema(BdsBdsInstanceIdentityConfigurationResource()), + }, + }, + } +} + +func readBdsBdsInstanceIdentityConfigurations(d *schema.ResourceData, m interface{}) error { + sync := &BdsBdsInstanceIdentityConfigurationsDataSourceCrud{} + sync.D = d + sync.Client = m.(*client.OracleClients).BdsClient() + + return tfresource.ReadResource(sync) +} + +type BdsBdsInstanceIdentityConfigurationsDataSourceCrud struct { + D *schema.ResourceData + Client *oci_bds.BdsClient + Res *oci_bds.ListIdentityConfigurationsResponse +} + +func (s *BdsBdsInstanceIdentityConfigurationsDataSourceCrud) VoidState() { + s.D.SetId("") +} + +func (s *BdsBdsInstanceIdentityConfigurationsDataSourceCrud) Get() error { + request := oci_bds.ListIdentityConfigurationsRequest{} + + if bdsInstanceId, ok := s.D.GetOkExists("bds_instance_id"); ok { + tmp := bdsInstanceId.(string) + request.BdsInstanceId = &tmp + } + + if compartmentId, ok := s.D.GetOkExists("compartment_id"); ok { + tmp := compartmentId.(string) + request.CompartmentId = &tmp + } + + if displayName, ok := s.D.GetOkExists("display_name"); ok { + tmp := displayName.(string) + request.DisplayName = &tmp + } + + if state, ok := s.D.GetOkExists("state"); ok { + request.LifecycleState = oci_bds.IdentityConfigurationLifecycleStateEnum(state.(string)) + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(false, "bds") + + response, err := s.Client.ListIdentityConfigurations(context.Background(), request) + if err != nil { + return err + } + + s.Res = &response + request.Page = s.Res.OpcNextPage + + for request.Page != nil { + listResponse, err := s.Client.ListIdentityConfigurations(context.Background(), request) + if err != nil { + return err + } + + s.Res.Items = append(s.Res.Items, listResponse.Items...) + request.Page = listResponse.OpcNextPage + } + + return nil +} + +func (s *BdsBdsInstanceIdentityConfigurationsDataSourceCrud) SetData() error { + if s.Res == nil { + return nil + } + + s.D.SetId(tfresource.GenerateDataSourceHashID("BdsBdsInstanceIdentityConfigurationsDataSource-", BdsBdsInstanceIdentityConfigurationsDataSource(), s.D)) + resources := []map[string]interface{}{} + + for _, r := range s.Res.Items { + bdsInstanceIdentityConfiguration := map[string]interface{}{} + + if r.DisplayName != nil { + bdsInstanceIdentityConfiguration["display_name"] = *r.DisplayName + } + + if r.Id != nil { + bdsInstanceIdentityConfiguration["id"] = *r.Id + } + + bdsInstanceIdentityConfiguration["state"] = r.LifecycleState + + resources = append(resources, bdsInstanceIdentityConfiguration) + } + + if f, fOk := s.D.GetOkExists("filter"); fOk { + resources = tfresource.ApplyFilters(f.(*schema.Set), resources, BdsBdsInstanceIdentityConfigurationsDataSource().Schema["identity_configurations"].Elem.(*schema.Resource).Schema) + } + + if err := s.D.Set("identity_configurations", resources); err != nil { + return err + } + + return nil +} diff --git a/internal/service/bds/bds_export.go b/internal/service/bds/bds_export.go index 9c70c500f21..0d9cfc01193 100644 --- a/internal/service/bds/bds_export.go +++ b/internal/service/bds/bds_export.go @@ -10,9 +10,11 @@ import ( func init() { exportBdsBdsInstanceApiKeyHints.GetIdFn = getBdsBdsInstanceApiKeyId - exportBdsBdsInstanceResourcePrincipalConfigurationHints.GetIdFn = getBdsBdsInstanceResourcePrincipalConfigurationId + exportBdsBdsInstanceMetastoreConfigHints.GetIdFn = getBdsBdsInstanceMetastoreConfigId + exportBdsBdsInstanceIdentityConfigurationHints.GetIdFn = getBdsBdsInstanceIdentityConfigurationId exportBdsBdsInstanceApiKeyHints.ProcessDiscoveredResourcesFn = processBdsInstanceApiKeys exportBdsBdsInstanceMetastoreConfigHints.ProcessDiscoveredResourcesFn = processBdsInstanceMetastoreConfigs + exportBdsBdsInstanceIdentityConfigurationHints.ProcessDiscoveredResourcesFn = processBdsInstanceIdentityConfigurations tf_export.RegisterCompartmentGraphs("bds", bdsResourceGraph) } @@ -37,6 +39,14 @@ func processBdsInstanceApiKeys(ctx *tf_export.ResourceDiscoveryContext, resource } return resources, nil } +func processBdsInstanceIdentityConfigurations(ctx *tf_export.ResourceDiscoveryContext, resources []*tf_export.OCIResource) ([]*tf_export.OCIResource, error) { + for _, resource := range resources { + identityConfigurationId := resource.Id + bdsInstanceId := resource.SourceAttributes["bds_instance_id"].(string) + resource.ImportId = GetBdsInstanceIdentityConfigurationCompositeId(bdsInstanceId, identityConfigurationId) + } + return resources, nil +} func getBdsBdsInstanceApiKeyId(resource *tf_export.OCIResource) (string, error) { @@ -48,14 +58,24 @@ func getBdsBdsInstanceApiKeyId(resource *tf_export.OCIResource) (string, error) return GetBdsInstanceApiKeyCompositeId(apiKeyId, bdsInstanceId), nil } -func getBdsBdsInstanceResourcePrincipalConfigurationId(resource *tf_export.OCIResource) (string, error) { +func getBdsBdsInstanceMetastoreConfigId(resource *tf_export.OCIResource) (string, error) { bdsInstanceId := resource.Parent.Id - resourcePrincipalConfigurationId, ok := resource.SourceAttributes["resource_principal_configuration_id"].(string) + metastoreConfigId, ok := resource.SourceAttributes["metastore_config_id"].(string) if !ok { - return "", fmt.Errorf("[ERROR] unable to find resourcePrincipalConfigurationId for Bds BdsInstanceResourcePrincipalConfiguration") + return "", fmt.Errorf("[ERROR] unable to find metastoreConfigId for Bds BdsInstanceMetastoreConfig") } - return GetBdsInstanceResourcePrincipalConfigurationCompositeId(bdsInstanceId, resourcePrincipalConfigurationId), nil + return GetBdsInstanceMetastoreConfigCompositeId(bdsInstanceId, metastoreConfigId), nil +} + +func getBdsBdsInstanceIdentityConfigurationId(resource *tf_export.OCIResource) (string, error) { + + bdsInstanceId := resource.Parent.Id + identityConfigurationId, ok := resource.SourceAttributes["id"].(string) + if !ok { + return "", fmt.Errorf("[ERROR] unable to find identityConfigurationId for Bds BdsInstanceIdentityConfiguration") + } + return GetBdsInstanceIdentityConfigurationCompositeId(bdsInstanceId, identityConfigurationId), nil } // Hints for discovering and exporting this resource to configuration and state files @@ -91,14 +111,14 @@ var exportBdsBdsInstanceMetastoreConfigHints = &tf_export.TerraformResourceHints }, } -var exportBdsBdsInstanceResourcePrincipalConfigurationHints = &tf_export.TerraformResourceHints{ - ResourceClass: "oci_bds_bds_instance_resource_principal_configuration", - DatasourceClass: "oci_bds_bds_instance_resource_principal_configurations", - DatasourceItemsAttr: "resource_principal_configurations", - ResourceAbbreviation: "bds_instance_resource_principal_configuration", +var exportBdsBdsInstanceIdentityConfigurationHints = &tf_export.TerraformResourceHints{ + ResourceClass: "oci_bds_bds_instance_identity_configuration", + DatasourceClass: "oci_bds_bds_instance_identity_configurations", + DatasourceItemsAttr: "identity_configurations", + ResourceAbbreviation: "bds_instance_identity_configuration", RequireResourceRefresh: true, DiscoverableLifecycleStates: []string{ - string(oci_bds.ResourcePrincipalConfigurationLifecycleStateActive), + string(oci_bds.IdentityConfigurationLifecycleStateActive), }, } @@ -114,13 +134,13 @@ var bdsResourceGraph = tf_export.TerraformResourceGraph{ }, }, { - TerraformResourceHints: exportBdsBdsInstanceMetastoreConfigHints, + TerraformResourceHints: exportBdsBdsInstanceIdentityConfigurationHints, DatasourceQueryParams: map[string]string{ "bds_instance_id": "id", }, }, { - TerraformResourceHints: exportBdsBdsInstanceResourcePrincipalConfigurationHints, + TerraformResourceHints: exportBdsBdsInstanceMetastoreConfigHints, DatasourceQueryParams: map[string]string{ "bds_instance_id": "id", }, diff --git a/internal/service/bds/register_datasource.go b/internal/service/bds/register_datasource.go index d88fc030c2b..0f44e6ef052 100644 --- a/internal/service/bds/register_datasource.go +++ b/internal/service/bds/register_datasource.go @@ -12,6 +12,8 @@ func RegisterDatasource() { tfresource.RegisterDatasource("oci_bds_bds_instance_api_key", BdsBdsInstanceApiKeyDataSource()) tfresource.RegisterDatasource("oci_bds_bds_instance_api_keys", BdsBdsInstanceApiKeysDataSource()) tfresource.RegisterDatasource("oci_bds_bds_instance_get_os_patch", BdsBdsInstanceGetOsPatchDataSource()) + tfresource.RegisterDatasource("oci_bds_bds_instance_identity_configuration", BdsBdsInstanceIdentityConfigurationDataSource()) + tfresource.RegisterDatasource("oci_bds_bds_instance_identity_configurations", BdsBdsInstanceIdentityConfigurationsDataSource()) tfresource.RegisterDatasource("oci_bds_bds_instance_list_os_patches", BdsBdsInstanceListOsPatchesDataSource()) tfresource.RegisterDatasource("oci_bds_bds_instance_metastore_config", BdsBdsInstanceMetastoreConfigDataSource()) tfresource.RegisterDatasource("oci_bds_bds_instance_metastore_configs", BdsBdsInstanceMetastoreConfigsDataSource()) diff --git a/internal/service/bds/register_resource.go b/internal/service/bds/register_resource.go index 2cee6a6ce47..1008b4e9d71 100644 --- a/internal/service/bds/register_resource.go +++ b/internal/service/bds/register_resource.go @@ -9,6 +9,7 @@ func RegisterResource() { tfresource.RegisterResource("oci_bds_auto_scaling_configuration", BdsAutoScalingConfigurationResource()) tfresource.RegisterResource("oci_bds_bds_instance", BdsBdsInstanceResource()) tfresource.RegisterResource("oci_bds_bds_instance_api_key", BdsBdsInstanceApiKeyResource()) + tfresource.RegisterResource("oci_bds_bds_instance_identity_configuration", BdsBdsInstanceIdentityConfigurationResource()) tfresource.RegisterResource("oci_bds_bds_instance_metastore_config", BdsBdsInstanceMetastoreConfigResource()) tfresource.RegisterResource("oci_bds_bds_instance_operation_certificate_managements_management", BdsBdsInstanceOperationCertificateManagementsManagementResource()) tfresource.RegisterResource("oci_bds_bds_instance_patch_action", BdsBdsInstancePatchActionResource()) diff --git a/website/docs/d/bds_bds_instance_identity_configuration.html.markdown b/website/docs/d/bds_bds_instance_identity_configuration.html.markdown new file mode 100644 index 00000000000..8bade0c8173 --- /dev/null +++ b/website/docs/d/bds_bds_instance_identity_configuration.html.markdown @@ -0,0 +1,59 @@ +--- +subcategory: "Big Data Service" +layout: "oci" +page_title: "Oracle Cloud Infrastructure: oci_bds_bds_instance_identity_configuration" +sidebar_current: "docs-oci-datasource-bds-bds_instance_identity_configuration" +description: |- + Provides details about a specific Bds Instance Identity Configuration in Oracle Cloud Infrastructure Big Data Service service +--- + +# Data Source: oci_bds_bds_instance_identity_configuration +This data source provides details about a specific Bds Instance Identity Configuration resource in Oracle Cloud Infrastructure Big Data Service service. + +Get details of one identity config on the cluster + +## Example Usage + +```hcl +data "oci_bds_bds_instance_identity_configuration" "test_bds_instance_identity_configuration" { + #Required + bds_instance_id = oci_bds_bds_instance.test_bds_instance.id + identity_configuration_id = oci_audit_configuration.test_configuration.id +} +``` + +## Argument Reference + +The following arguments are supported: + +* `bds_instance_id` - (Required) The OCID of the cluster. +* `identity_configuration_id` - (Required) The OCID of the identity configuration + + +## Attributes Reference + +The following attributes are exported: + +* `confidential_application_id` - identity domain confidential application ID for the identity config +* `display_name` - the display name of the identity configuration +* `iam_user_sync_configuration` - Information about the IAM user sync configuration. + * `is_posix_attributes_addition_required` - whether to append POSIX attributes to IAM users + * `state` - Lifecycle state of the IAM user sync config + * `time_created` - Time when this IAM user sync config was created, shown as an RFC 3339 formatted datetime string. + * `time_updated` - Time when this IAM user sync config was updated, shown as an RFC 3339 formatted datetime string. +* `id` - The id of the identity config +* `identity_domain_id` - Identity domain to use for identity config +* `state` - Lifecycle state of the identity configuration +* `time_created` - Time when this identity configuration was created, shown as an RFC 3339 formatted datetime string. +* `time_updated` - Time when this identity configuration config was updated, shown as an RFC 3339 formatted datetime string. +* `upst_configuration` - Information about the UPST configuration. + * `keytab_content` - The kerberos keytab content used for creating identity propagation trust config, in base64 format + * `master_encryption_key_id` - Master Encryption key used for encrypting token exchange keytab. + * `secret_id` - Secret ID for token exchange keytab + * `state` - Lifecycle state of the UPST config + * `time_created` - Time when this UPST config was created, shown as an RFC 3339 formatted datetime string. + * `time_token_exchange_keytab_last_refreshed` - Time when the keytab for token exchange principal is last refreshed, shown as an RFC 3339 formatted datetime string. + * `time_updated` - Time when this UPST config was updated, shown as an RFC 3339 formatted datetime string. + * `token_exchange_principal_name` - Token exchange kerberos Principal name in cluster + * `vault_id` - The instance OCID of the node, which is the resource from which the node backup was acquired. + diff --git a/website/docs/d/bds_bds_instance_identity_configurations.html.markdown b/website/docs/d/bds_bds_instance_identity_configurations.html.markdown new file mode 100644 index 00000000000..df5b69e8522 --- /dev/null +++ b/website/docs/d/bds_bds_instance_identity_configurations.html.markdown @@ -0,0 +1,72 @@ +--- +subcategory: "Big Data Service" +layout: "oci" +page_title: "Oracle Cloud Infrastructure: oci_bds_bds_instance_identity_configurations" +sidebar_current: "docs-oci-datasource-bds-bds_instance_identity_configurations" +description: |- + Provides the list of Bds Instance Identity Configurations in Oracle Cloud Infrastructure Big Data Service service +--- + +# Data Source: oci_bds_bds_instance_identity_configurations +This data source provides the list of Bds Instance Identity Configurations in Oracle Cloud Infrastructure Big Data Service service. + +Returns a list of all identity configurations associated with this Big Data Service cluster. + + +## Example Usage + +```hcl +data "oci_bds_bds_instance_identity_configurations" "test_bds_instance_identity_configurations" { + #Required + bds_instance_id = oci_bds_bds_instance.test_bds_instance.id + compartment_id = var.compartment_id + + #Optional + display_name = var.bds_instance_identity_configuration_display_name + state = var.bds_instance_identity_configuration_state +} +``` + +## Argument Reference + +The following arguments are supported: + +* `bds_instance_id` - (Required) The OCID of the cluster. +* `compartment_id` - (Required) The OCID of the compartment. +* `display_name` - (Optional) A filter to return only resources that match the entire display name given. +* `state` - (Optional) The state of the identity config + + +## Attributes Reference + +The following attributes are exported: + +* `identity_configurations` - The list of identity_configurations. + +### BdsInstanceIdentityConfiguration Reference + +The following attributes are exported: + +* `confidential_application_id` - identity domain confidential application ID for the identity config +* `display_name` - the display name of the identity configuration +* `iam_user_sync_configuration` - Information about the IAM user sync configuration. + * `is_posix_attributes_addition_required` - whether to append POSIX attributes to IAM users + * `state` - Lifecycle state of the IAM user sync config + * `time_created` - Time when this IAM user sync config was created, shown as an RFC 3339 formatted datetime string. + * `time_updated` - Time when this IAM user sync config was updated, shown as an RFC 3339 formatted datetime string. +* `id` - The id of the identity config +* `identity_domain_id` - Identity domain to use for identity config +* `state` - Lifecycle state of the identity configuration +* `time_created` - Time when this identity configuration was created, shown as an RFC 3339 formatted datetime string. +* `time_updated` - Time when this identity configuration config was updated, shown as an RFC 3339 formatted datetime string. +* `upst_configuration` - Information about the UPST configuration. + * `keytab_content` - The kerberos keytab content used for creating identity propagation trust config, in base64 format + * `master_encryption_key_id` - Master Encryption key used for encrypting token exchange keytab. + * `secret_id` - Secret ID for token exchange keytab + * `state` - Lifecycle state of the UPST config + * `time_created` - Time when this UPST config was created, shown as an RFC 3339 formatted datetime string. + * `time_token_exchange_keytab_last_refreshed` - Time when the keytab for token exchange principal is last refreshed, shown as an RFC 3339 formatted datetime string. + * `time_updated` - Time when this UPST config was updated, shown as an RFC 3339 formatted datetime string. + * `token_exchange_principal_name` - Token exchange kerberos Principal name in cluster + * `vault_id` - The instance OCID of the node, which is the resource from which the node backup was acquired. + diff --git a/website/docs/guides/resource_discovery.html.markdown b/website/docs/guides/resource_discovery.html.markdown index 14e85d7f1a9..c2801ac6a38 100644 --- a/website/docs/guides/resource_discovery.html.markdown +++ b/website/docs/guides/resource_discovery.html.markdown @@ -157,7 +157,6 @@ Make sure the `output_path` is empty before running resource discovery * `dataflow` - Discovers dataflow resources within the specified compartment * `dataintegration` - Discovers dataintegration resources within the specified compartment * `datascience` - Discovers datascience resources within the specified compartment - * `delegate_access_control` - Discovers delegate_access_control resources within the specified compartment * `demand_signal` - Discovers demand_signal resources within the specified compartment * `desktops` - Discovers desktop pool resources within the specified compartment * `devops` - Discovers devops resources within the specified compartment @@ -166,11 +165,10 @@ Make sure the `output_path` is empty before running resource discovery * `email` - Discovers email_sender resources within the specified compartment * `events` - Discovers events resources within the specified compartment * `file_storage` - Discovers file_storage resources within the specified compartment - * `fleet_apps_management` - Discovers fleet_apps_management resources within the specified compartment + * `fleet_software_update` - Discovers fleet_software_update resources within the specified compartment * `functions` - Discovers functions resources within the specified compartment * `fusion_apps` - Discovers fusion_apps resources within the specified compartment * `generative_ai` - Discovers generative_ai resources within the specified compartment - * `generative_ai_agent` - Discovers generative_ai_agent resources within the specified compartment * `globally_distributed_database` - Discovers globally_distributed_database resources within the specified compartment * `golden_gate` - Discovers golden_gate resources within the specified compartment * `health_checks` - Discovers health_checks resources within the specified compartment @@ -214,7 +212,6 @@ Make sure the `output_path` is empty before running resource discovery * `resource_scheduler` - Discovers resource_scheduler resources within the specified compartment * `resourcemanager` - Discovers resourcemanager resources within the specified compartment * `sch` - Discovers sch resources within the specified compartment - * `security_attribute` - Discovers security attribute resources in the tenancy * `service_mesh` - Discovers service_mesh resources within the specified compartment * `stack_monitoring` - Discovers stack_monitoring resources within the specified compartment * `streaming` - Discovers streaming resources within the specified compartment @@ -227,7 +224,6 @@ Make sure the `output_path` is empty before running resource discovery * `waa` - Discovers waa resources within the specified compartment * `waas` - Discovers waas resources within the specified compartment * `waf` - Discovers waf resources within the specified compartment - * `zpr` - Discovers Zero Trust Packet Routing resources across the entire tenancy * `tf_version` - The version of terraform syntax to generate for configurations. Default is v0.12. The state file will be written in v0.12 only. The allowed values are: * 0.11 * 0.12 @@ -415,7 +411,7 @@ bds * oci\_bds\_auto\_scaling\_configuration * oci\_bds\_bds\_instance\_api\_key * oci\_bds\_bds\_instance\_metastore\_config -* oci\_bds\_bds\_instance\_resource\_principal\_configuration +* oci\_bds\_bds\_instance\_identity\_configuration blockchain @@ -430,10 +426,8 @@ budget capacity_management -* oci\_capacity\_management\_occ\_customer\_group * oci\_capacity\_management\_occ\_availability\_catalog * oci\_capacity\_management\_occ\_capacity\_request -* oci\_capacity\_management\_occ\_customer\_group\_occ\_customer certificates_management @@ -549,6 +543,7 @@ core * oci\_core\_vtap * oci\_core\_compute\_cluster * oci\_core\_compute\_capacity\_report +* oci\_core\_instance\_maintenance\_event * oci\_core\_compute\_capacity\_topology data_labeling_service @@ -586,15 +581,14 @@ data_safe * oci\_data\_safe\_sensitive\_data\_models\_sensitive\_column * oci\_data\_safe\_discovery\_job * oci\_data\_safe\_sdm\_masking\_policy\_difference -* oci\_data\_safe\_calculate\_audit\_volume\_available -* oci\_data\_safe\_calculate\_audit\_volume\_collected -* oci\_data\_safe\_generate\_on\_prem\_connector\_configuration * oci\_data\_safe\_security\_policy\_deployment * oci\_data\_safe\_security\_policy * oci\_data\_safe\_database\_security\_config * oci\_data\_safe\_sql\_firewall\_policy * oci\_data\_safe\_sql\_collection * oci\_data\_safe\_target\_database\_peer\_target\_database +* oci\_data\_safe\_calculate\_audit\_volume\_available +* oci\_data\_safe\_calculate\_audit\_volume\_collected database @@ -628,7 +622,6 @@ database * oci\_database\_application\_vip * oci\_database\_oneoff\_patch * oci\_database\_db\_node\_console\_history -* oci\_database\_autonomous\_database\_software\_image * oci\_database\_exascale\_db\_storage\_vault * oci\_database\_exadb\_vm\_cluster @@ -685,11 +678,6 @@ datascience * oci\_datascience\_pipeline * oci\_datascience\_data\_science\_private\_endpoint -delegate_access_control - -* oci\_delegate\_access\_control\_delegation\_subscription -* oci\_delegate\_access\_control\_delegation\_control - demand_signal * oci\_demand\_signal\_occ\_demand\_signal @@ -730,6 +718,9 @@ dns * oci\_dns\_steering\_policy\_attachment * oci\_dns\_tsig\_key * oci\_dns\_rrset +* oci\_dns\_resolver +* oci\_dns\_resolver\_endpoint +* oci\_dns\_view email @@ -752,17 +743,10 @@ file_storage * oci\_file\_storage\_filesystem\_snapshot\_policy * oci\_file\_storage\_outbound\_connector -fleet_apps_management +fleet_software_update -* oci\_fleet\_apps\_management\_task\_record -* oci\_fleet\_apps\_management\_maintenance\_window -* oci\_fleet\_apps\_management\_fleet -* oci\_fleet\_apps\_management\_scheduler\_definition -* oci\_fleet\_apps\_management\_property -* oci\_fleet\_apps\_management\_runbook -* oci\_fleet\_apps\_management\_platform\_configuration -* oci\_fleet\_apps\_management\_compliance\_policy\_rule -* oci\_fleet\_apps\_management\_patch +* oci\_fleet\_software\_update\_fsu\_cycle +* oci\_fleet\_software\_update\_fsu\_collection functions @@ -785,14 +769,6 @@ generative_ai * oci\_generative\_ai\_endpoint * oci\_generative\_ai\_model -generative_ai_agent - -* oci\_generative\_ai\_agent\_data\_source -* oci\_generative\_ai\_agent\_agent -* oci\_generative\_ai\_agent\_data\_ingestion\_job -* oci\_generative\_ai\_agent\_knowledge\_base -* oci\_generative\_ai\_agent\_agent\_endpoint - globally_distributed_database * oci\_globally\_distributed\_database\_private\_endpoint @@ -1156,11 +1132,6 @@ sch * oci\_sch\_service\_connector -security_attribute - -* oci\_security\_attribute\_security\_attribute\_namespace -* oci\_security\_attribute\_security\_attribute - service_mesh * oci\_service\_mesh\_virtual\_service @@ -1185,9 +1156,6 @@ stack_monitoring * oci\_stack\_monitoring\_metric\_extension * oci\_stack\_monitoring\_baselineable\_metric * oci\_stack\_monitoring\_process\_set -* oci\_stack\_monitoring\_maintenance\_window -* oci\_stack\_monitoring\_maintenance\_windows\_retry\_failed\_operation -* oci\_stack\_monitoring\_maintenance\_windows\_stop streaming @@ -1240,8 +1208,3 @@ waf * oci\_waf\_web\_app\_firewall\_policy * oci\_waf\_web\_app\_firewall * oci\_waf\_network\_address\_list - -zpr - -* oci\_zpr\_configuration -* oci\_zpr\_zpr\_policy diff --git a/website/docs/r/bds_bds_instance.html.markdown b/website/docs/r/bds_bds_instance.html.markdown index f4ec81c7ef0..6e2146f7ec0 100644 --- a/website/docs/r/bds_bds_instance.html.markdown +++ b/website/docs/r/bds_bds_instance.html.markdown @@ -167,10 +167,7 @@ The following arguments are supported: * `nvmes` - (Optional) The number of NVMe drives to be used for storage. A single drive has 6.8 TB available. * `ocpus` - (Optional) The total number of OCPUs available to the node. * `subnet_id` - (Required) The OCID of the subnet in which the node will be created. -* `state` - (Optional) (Updatable) The target state for the Bds Instance. Could be set to `ACTIVE` or `INACTIVE`. -* `execute_bootstrap_script_trigger` - (Optional) (Updatable) An optional property when incremented triggers Execute Bootstrap Script. Could be set to any integer value. -* `remove_kafka_trigger` - (Optional) (Updatable) An optional property when incremented triggers Remove Kafka. Could be set to any integer value. -* `install_os_patch_trigger` - (Optional) (Updatable) An optional property when incremented triggers Install Os Patch. Could be set to any integer value. +* `state` - (Optional) (Updatable) The target state for the Bds Instance. Could be set to `ACTIVE` or `INACTIVE`. * `is_force_stop_jobs` - (Optional) (Updatable) When setting state as `INACTIVE` for stopping a cluster, setting this flag to true forcefully stops the bds instance. * `is_kafka_configured` - (Optional) Boolean flag specifying whether or not Kafka should be configured. * `os_patch_version` - (Optional) (Updatable) The version of the patch to be upated. diff --git a/website/docs/r/bds_bds_instance_identity_configuration.html.markdown b/website/docs/r/bds_bds_instance_identity_configuration.html.markdown new file mode 100644 index 00000000000..ed814743b04 --- /dev/null +++ b/website/docs/r/bds_bds_instance_identity_configuration.html.markdown @@ -0,0 +1,106 @@ +--- +subcategory: "Big Data Service" +layout: "oci" +page_title: "Oracle Cloud Infrastructure: oci_bds_bds_instance_identity_configuration" +sidebar_current: "docs-oci-resource-bds-bds_instance_identity_configuration" +description: |- + Provides the Bds Instance Identity Configuration resource in Oracle Cloud Infrastructure Big Data Service service +--- + +# oci_bds_bds_instance_identity_configuration +This resource provides the Bds Instance Identity Configuration resource in Oracle Cloud Infrastructure Big Data Service service. + +Create an identity configuration for the cluster + +## Example Usage + +```hcl +resource "oci_bds_bds_instance_identity_configuration" "test_bds_instance_identity_configuration" { + #Required + bds_instance_id = oci_bds_bds_instance.test_bds_instance.id + cluster_admin_password = var.bds_instance_identity_configuration_cluster_admin_password + confidential_application_id = oci_dataflow_application.test_application.id + display_name = var.bds_instance_identity_configuration_display_name + identity_domain_id = oci_identity_domain.test_domain.id + + #Optional + iam_user_sync_configuration_details { + + #Optional + is_posix_attributes_addition_required = var.bds_instance_identity_configuration_iam_user_sync_configuration_details_is_posix_attributes_addition_required + } + upst_configuration_details { + + #Optional + master_encryption_key_id = oci_kms_key.test_key.id + vault_id = oci_kms_vault.test_vault.id + } +} +``` + +## Argument Reference + +The following arguments are supported: + +* `bds_instance_id` - (Required) The OCID of the cluster. +* `cluster_admin_password` - (Required) (Updatable) Base-64 encoded password for the cluster admin user. +* `confidential_application_id` - (Required) Identity domain confidential application ID for the identity config, required for creating identity configuration +* `display_name` - (Required) Display name of the identity configuration, required for creating identity configuration. +* `iam_user_sync_configuration_details` - (Optional) (Updatable) Details for activating/updating an IAM user sync configuration + * `is_posix_attributes_addition_required` - (Optional) (Updatable) whether posix attribute needs to be appended to users, required for updating IAM user sync configuration +* `identity_domain_id` - (Required) Identity domain OCID to use for identity config, required for creating identity configuration +* `upst_configuration_details` - (Optional) (Updatable) Details for activating/updating UPST config on the cluster + * `master_encryption_key_id` - (Optional) (Updatable) OCID of the master encryption key in vault for encrypting token exchange service principal keytab, required for activating UPST config + * `vault_id` - (Optional) (Updatable) OCID of the vault to store token exchange service principal keyta, required for activating UPST config +* `activate_iam_user_sync_configuration_trigger` - (Optional) (Updatable) An optional property when set to "true" triggers Activate Iam User Sync Configuration and when set to "false" triggers Deactivate Iam User Sync Configuration. +* `activate_upst_configuration_trigger` - (Optional) (Updatable) An optional property when set to "true" triggers Activate Upst Configuration and when set to "false" triggers Deactivate Upst Configuration. +* `refresh_confidential_application_trigger` - (Optional) (Updatable) An optional property when set to "true" triggers Refresh Confidential Application. +* `refresh_upst_token_exchange_keytab_trigger` - (Optional) (Updatable) An optional property when set to "true" triggers Refresh Upst Token Exchange Keytab. + + +** IMPORTANT ** +Any change to a property that does not support update will force the destruction and recreation of the resource with the new property values + +## Attributes Reference + +The following attributes are exported: + +* `confidential_application_id` - identity domain confidential application ID for the identity config +* `display_name` - the display name of the identity configuration +* `iam_user_sync_configuration` - Information about the IAM user sync configuration. + * `is_posix_attributes_addition_required` - whether to append POSIX attributes to IAM users + * `state` - Lifecycle state of the IAM user sync config + * `time_created` - Time when this IAM user sync config was created, shown as an RFC 3339 formatted datetime string. + * `time_updated` - Time when this IAM user sync config was updated, shown as an RFC 3339 formatted datetime string. +* `id` - The id of the identity config +* `identity_domain_id` - Identity domain to use for identity config +* `state` - Lifecycle state of the identity configuration +* `time_created` - Time when this identity configuration was created, shown as an RFC 3339 formatted datetime string. +* `time_updated` - Time when this identity configuration config was updated, shown as an RFC 3339 formatted datetime string. +* `upst_configuration` - Information about the UPST configuration. + * `keytab_content` - The kerberos keytab content used for creating identity propagation trust config, in base64 format + * `master_encryption_key_id` - Master Encryption key used for encrypting token exchange keytab. + * `secret_id` - Secret ID for token exchange keytab + * `state` - Lifecycle state of the UPST config + * `time_created` - Time when this UPST config was created, shown as an RFC 3339 formatted datetime string. + * `time_token_exchange_keytab_last_refreshed` - Time when the keytab for token exchange principal is last refreshed, shown as an RFC 3339 formatted datetime string. + * `time_updated` - Time when this UPST config was updated, shown as an RFC 3339 formatted datetime string. + * `token_exchange_principal_name` - Token exchange kerberos Principal name in cluster + * `vault_id` - The instance OCID of the node, which is the resource from which the node backup was acquired. + +## Timeouts + +The `timeouts` block allows you to specify [timeouts](https://registry.terraform.io/providers/oracle/oci/latest/docs/guides/changing_timeouts) for certain operations: + * `create` - (Defaults to 20 minutes), when creating the Bds Instance Identity Configuration + * `update` - (Defaults to 20 minutes), when updating the Bds Instance Identity Configuration + * `delete` - (Defaults to 20 minutes), when destroying the Bds Instance Identity Configuration + + +## Import + +BdsInstanceIdentityConfigurations can be imported using the `id`, e.g. + +``` +$ terraform import oci_bds_bds_instance_identity_configuration.test_bds_instance_identity_configuration "bdsInstances/{bdsInstanceId}/identityConfigurations/{identityConfigurationId}" +``` + From ab474e23f392019386dd5519d03bc7d57b2c7893 Mon Sep 17 00:00:00 2001 From: Yue Deng Date: Fri, 22 Nov 2024 13:31:39 -0600 Subject: [PATCH 02/17] Bug Fix - Fix terraform documentation for oci_database_exadb_vm_cluster resource --- website/docs/r/database_exadb_vm_cluster.html.markdown | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/website/docs/r/database_exadb_vm_cluster.html.markdown b/website/docs/r/database_exadb_vm_cluster.html.markdown index 2fa33f3bf1f..3caaad1033f 100644 --- a/website/docs/r/database_exadb_vm_cluster.html.markdown +++ b/website/docs/r/database_exadb_vm_cluster.html.markdown @@ -28,8 +28,8 @@ resource "oci_database_exadb_vm_cluster" "test_exadb_vm_cluster" { shape = var.exadb_vm_cluster_shape node_config { - enabled_ecpu_per_node = var.exadb_vm_cluster_enabled_ecpu_per_node - total_ecpu_per_node = var.exadb_vm_cluster_total_ecpu_per_node + enabled_ecpu_count_per_node = var.exadb_vm_cluster_enabled_ecpu_count_per_node + total_ecpu_count_per_node = var.exadb_vm_cluster_total_ecpu_count_per_node vm_file_system_storage_size_gbs_per_node = var.exadb_vm_cluster_vm_file_system_storage_size_in_gbs_per_node } @@ -194,9 +194,9 @@ The following attributes are exported: ## Timeouts The `timeouts` block allows you to specify [timeouts](https://registry.terraform.io/providers/oracle/oci/latest/docs/guides/changing_timeouts) for certain operations: - * `create` - (Defaults to 20 minutes), when creating the Exadb Vm Cluster - * `update` - (Defaults to 20 minutes), when updating the Exadb Vm Cluster - * `delete` - (Defaults to 20 minutes), when destroying the Exadb Vm Cluster + * `create` - (Defaults to 12 hours), when creating the Exadb Vm Cluster + * `update` - (Defaults to 12 hours), when updating the Exadb Vm Cluster + * `delete` - (Defaults to 12 hours), when destroying the Exadb Vm Cluster ## Import From 34e6edd6cb45160cdd637802ccc2cefda9a49290 Mon Sep 17 00:00:00 2001 From: Viral Sinha Date: Sun, 13 Oct 2024 21:16:52 -0400 Subject: [PATCH 03/17] Bug Fix - is_shareable attribute for data source `oci_core_volume_attachment' --- .../core_volume_attachments_data_source_test.go | 7 +++++++ .../core/core_volume_attachments_data_source.go | 12 ++++++++++++ website/docs/d/core_volume_attachments.html.markdown | 1 + 3 files changed, 20 insertions(+) diff --git a/internal/integrationtest/core_volume_attachments_data_source_test.go b/internal/integrationtest/core_volume_attachments_data_source_test.go index f9e627a8943..5cfda26226f 100644 --- a/internal/integrationtest/core_volume_attachments_data_source_test.go +++ b/internal/integrationtest/core_volume_attachments_data_source_test.go @@ -73,6 +73,7 @@ func (s *DatasourceCoreVolumeAttachmentTestSuite) TestAccDatasourceCoreVolumeAtt resource.TestCheckResourceAttrSet(s.ResourceName, "volume_attachments.0.time_created"), resource.TestCheckResourceAttrSet(s.ResourceName, "volume_attachments.0.volume_id"), resource.TestCheckResourceAttr(s.ResourceName, "volume_attachments.0.is_read_only", "false"), + resource.TestCheckResourceAttr(s.ResourceName, "volume_attachments.0.is_shareable", "false"), resource.TestCheckResourceAttrSet(s.ResourceName, "volume_attachments.0.ipv4"), resource.TestCheckResourceAttrSet(s.ResourceName, "volume_attachments.0.port"), resource.TestCheckResourceAttrSet(s.ResourceName, "volume_attachments.0.iqn"), @@ -91,6 +92,7 @@ type customVolumeAttachment struct { id string instanceId string isReadOnly bool + isShareable bool volumeId string displayName string timeCreated common.SDKTime @@ -122,6 +124,11 @@ func (m customVolumeAttachment) GetIsReadOnly() *bool { return &m.isReadOnly } +// GetIsShareable return IsShareable +func (m customVolumeAttachment) GetIsShareable() *bool { + return &m.isShareable +} + // GetLifecycleState returns LifecycleState func (m customVolumeAttachment) GetLifecycleState() oci_core.VolumeAttachmentLifecycleStateEnum { return m.state diff --git a/internal/service/core/core_volume_attachments_data_source.go b/internal/service/core/core_volume_attachments_data_source.go index 690b5b0d064..7afbfa1f264 100644 --- a/internal/service/core/core_volume_attachments_data_source.go +++ b/internal/service/core/core_volume_attachments_data_source.go @@ -158,6 +158,10 @@ func (s *CoreVolumeAttachmentsDataSourceCrud) SetData() error { result["is_read_only"] = bool(*v.IsReadOnly) } + if v.IsShareable != nil { + result["is_shareable"] = bool(*v.IsShareable) + } + if v.IsVolumeCreatedDuringLaunch != nil { result["is_volume_created_during_launch"] = bool(*v.IsVolumeCreatedDuringLaunch) } @@ -244,6 +248,10 @@ func (s *CoreVolumeAttachmentsDataSourceCrud) SetData() error { result["is_read_only"] = bool(*v.IsReadOnly) } + if v.IsShareable != nil { + result["is_shareable"] = bool(*v.IsShareable) + } + if v.IsVolumeCreatedDuringLaunch != nil { result["is_volume_created_during_launch"] = bool(*v.IsVolumeCreatedDuringLaunch) } @@ -298,6 +306,10 @@ func (s *CoreVolumeAttachmentsDataSourceCrud) SetData() error { result["is_read_only"] = bool(*v.IsReadOnly) } + if v.IsShareable != nil { + result["is_shareable"] = bool(*v.IsShareable) + } + if v.IsVolumeCreatedDuringLaunch != nil { result["is_volume_created_during_launch"] = bool(*v.IsVolumeCreatedDuringLaunch) } diff --git a/website/docs/d/core_volume_attachments.html.markdown b/website/docs/d/core_volume_attachments.html.markdown index 8f8bec4a010..566469bef25 100644 --- a/website/docs/d/core_volume_attachments.html.markdown +++ b/website/docs/d/core_volume_attachments.html.markdown @@ -67,6 +67,7 @@ The following attributes are exported: * `is_multipath` - Whether the Iscsi or Paravirtualized attachment is multipath or not, it is not applicable to NVMe attachment. * `is_pv_encryption_in_transit_enabled` - Whether in-transit encryption for the data volume's paravirtualized attachment is enabled or not. * `is_read_only` - Whether the attachment was created in read-only mode. +* `is_shareable` - Whether the attachment should be created in shareable mode. If an attachment is created in shareable mode, then other instances can attach the same volume, provided that they also create their attachments in shareable mode. Only certain volume types can be attached in shareable mode. Defaults to false if not specified. * `is_volume_created_during_launch` - Flag indicating if this volume was created for the customer as part of a simplified launch. Used to determine whether the volume requires deletion on instance termination. * `iscsi_login_state` - The iscsi login state of the volume attachment. For a Iscsi volume attachment, all iscsi sessions need to be all logged-in or logged-out to be in logged-in or logged-out state. * `multipath_devices` - A list of secondary multipath devices From 2ac8f914852eadcaa1adedb9f7e4e21d826276d4 Mon Sep 17 00:00:00 2001 From: Shrey Kapoor Date: Mon, 16 Dec 2024 17:19:41 -0800 Subject: [PATCH 04/17] Added - Support for BDS 3.0.29 Release - Feature Enhancements --- examples/big_data_service/main.tf | 102 +++---- .../bds_bds_cluster_version_test.go | 52 ++++ .../bds_bds_instance_api_key_test.go | 68 +++-- .../bds_bds_instance_patch_action_test.go | 62 ++--- .../bds_odh_instance_resource_test.go | 135 ++++++---- .../bds_bds_cluster_versions_data_source.go | 121 +++++++++ .../bds_bds_instance_api_key_data_source.go | 4 + .../bds/bds_bds_instance_api_key_resource.go | 15 ++ .../bds/bds_bds_instance_data_source.go | 6 + .../bds_bds_instance_patch_action_resource.go | 28 ++ .../service/bds/bds_bds_instance_resource.go | 251 +++++++++++++++++- internal/service/bds/register_datasource.go | 1 + .../d/bds_bds_cluster_versions.html.markdown | 41 +++ website/docs/d/bds_bds_instance.html.markdown | 3 + .../d/bds_bds_instance_api_key.html.markdown | 5 + .../d/bds_bds_instance_api_keys.html.markdown | 11 + .../docs/d/bds_bds_instances.html.markdown | 3 + website/docs/r/bds_bds_instance.html.markdown | 27 +- .../r/bds_bds_instance_api_key.html.markdown | 12 + ...ds_bds_instance_patch_action.html.markdown | 4 + 20 files changed, 765 insertions(+), 186 deletions(-) create mode 100644 internal/integrationtest/bds_bds_cluster_version_test.go create mode 100644 internal/service/bds/bds_bds_cluster_versions_data_source.go create mode 100644 website/docs/d/bds_bds_cluster_versions.html.markdown diff --git a/examples/big_data_service/main.tf b/examples/big_data_service/main.tf index 41554f578f7..3a7d4c65157 100644 --- a/examples/big_data_service/main.tf +++ b/examples/big_data_service/main.tf @@ -5,7 +5,7 @@ variable "tenancy_ocid" { } variable "cluster_profile" { -default = "HADOOP" + default = "HADOOP" } variable "user_ocid" { @@ -85,7 +85,7 @@ variable "bds_instance_nodes_shape" { } variable "bds_instance_worker_node_shape" { - default = "VM.Standard.Generic" + default = "VM.DenseIO.E5.Flex" } variable "bds_instance_compute_only_worker_node_shape" { @@ -148,7 +148,17 @@ resource "oci_bds_bds_instance" "test_bds_instance" { is_secure = var.bds_instance_is_secure kms_key_id = var.kms_key_id cluster_profile = var.cluster_profile - bootstrap_script_url = "https://objectstorage.us-ashburn-1.oraclecloud.com/p/Lk5JT9tnUIOG4yLm6S21QVR7m3Rm2uj1RAS2Olx5v14onLU2Y-b0lIc_N0RuUIge/n/idpbwtq1b3ta/b/bucket-20230214-1316/o/execute_bootstrap_script.sh" + bootstrap_script_url = "https://objectstorage.us-ashburn-1.oraclecloud.com/p/Lk5JT9tnUIOG4yLm6S21QVR7m3Rm2uj1RAS2Olx5v14onLU2Y-b0lIc_N0RuUIge/n/idpbwtq1b3ta/b/bucket-20230214-1316/o/execute_bootstrap_script.sh" + is_force_stop_jobs = "true" + state = "ACTIVE" + + start_cluster_shape_configs{ + node_type_shape_configs { + node_type = "WORKER" + shape = "VM.Standard.Generic" + + } + } master_node { #Required @@ -158,9 +168,9 @@ resource "oci_bds_bds_instance" "test_bds_instance" { block_volume_size_in_gbs = var.bds_instance_nodes_block_volume_size_in_gbs number_of_nodes = 1 shape_config { - memory_in_gbs = 120 - ocpus = 8 - } + memory_in_gbs = 120 + ocpus = 8 + } } util_node { @@ -171,50 +181,50 @@ resource "oci_bds_bds_instance" "test_bds_instance" { block_volume_size_in_gbs = var.bds_instance_nodes_block_volume_size_in_gbs number_of_nodes = 1 shape_config { - memory_in_gbs = 120 - ocpus = 8 - } + memory_in_gbs = 120 + ocpus = 8 + } } worker_node { #Required shape = var.bds_instance_worker_node_shape - block_volume_size_in_gbs = var.bds_instance_nodes_block_volume_size_in_gbs + subnet_id = var.subnet_id + number_of_nodes = 3 + shape_config { + memory_in_gbs = 120 + ocpus = 8 + nvmes = 1 + } + } + + edge_node { + #Required + shape = var.bds_instance_edge_node_shape + subnet_id = var.subnet_id - number_of_nodes = 3 - shape_config { - memory_in_gbs = 120 - ocpus = 8 - } - } - - edge_node { - #Required - shape = var.bds_instance_edge_node_shape - - subnet_id = var.subnet_id - block_volume_size_in_gbs = var.bds_instance_worker_nodes_block_volume_size_in_gbs - number_of_nodes = 1 - shape_config { - memory_in_gbs = var.bds_instance_edge_memory_per_node - ocpus = var.bds_instance_edge_ocpu_per_node - } - } - - compute_only_worker_node { - #Required - shape = var.bds_instance_compute_only_worker_node_shape - - subnet_id = var.subnet_id - block_volume_size_in_gbs = var.bds_instance_worker_nodes_block_volume_size_in_gbs - number_of_nodes = 1 - shape_config { - memory_in_gbs = var.bds_instance_compute_only_worker_memory_per_node - ocpus = var.bds_instance_compute_only_worker_ocpu_per_node + block_volume_size_in_gbs = var.bds_instance_worker_nodes_block_volume_size_in_gbs + number_of_nodes = 1 + shape_config { + memory_in_gbs = var.bds_instance_edge_memory_per_node + ocpus = var.bds_instance_edge_ocpu_per_node } } - ignore_existing_nodes_shape = ["worker", "master", "utility"] + compute_only_worker_node { + #Required + shape = var.bds_instance_compute_only_worker_node_shape + + subnet_id = var.subnet_id + block_volume_size_in_gbs = var.bds_instance_worker_nodes_block_volume_size_in_gbs + number_of_nodes = 1 + shape_config { + memory_in_gbs = var.bds_instance_compute_only_worker_memory_per_node + ocpus = var.bds_instance_compute_only_worker_ocpu_per_node + } + } + + ignore_existing_nodes_shape = ["worker", "master", "utility"] is_cloud_sql_configured = false @@ -224,7 +234,7 @@ resource "oci_bds_bds_instance" "test_bds_instance" { #Uncomment kafka_broker_node block for use of Kafka cluster #kafka_broker_node { - #Required + #Required # shape = var.bds_instance_compute_only_worker_node_shape # subnet_id = var.subnet_id @@ -237,10 +247,10 @@ resource "oci_bds_bds_instance" "test_bds_instance" { #} #Optional -#Uncomment this when running in home region (PHX) -# defined_tags = { -# "${oci_identity_tag_namespace.tag-namespace1.name}.${oci_identity_tag.tag1.name}" = var.bds_instance_defined_tags_value -# } + #Uncomment this when running in home region (PHX) + # defined_tags = { + # "${oci_identity_tag_namespace.tag-namespace1.name}.${oci_identity_tag.tag1.name}" = var.bds_instance_defined_tags_value + # } freeform_tags = var.bds_instance_freeform_tags network_config { #Optional diff --git a/internal/integrationtest/bds_bds_cluster_version_test.go b/internal/integrationtest/bds_bds_cluster_version_test.go new file mode 100644 index 00000000000..6d81350b52e --- /dev/null +++ b/internal/integrationtest/bds_bds_cluster_version_test.go @@ -0,0 +1,52 @@ +// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. +// Licensed under the Mozilla Public License v2.0 + +package integrationtest + +import ( + "fmt" + "testing" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" + + "github.com/oracle/terraform-provider-oci/httpreplay" + "github.com/oracle/terraform-provider-oci/internal/acctest" + + "github.com/oracle/terraform-provider-oci/internal/utils" +) + +var ( + BdsBdsClusterVersionDataSourceRepresentation = map[string]interface{}{} + + BdsBdsClusterVersionResourceConfig = "" +) + +// issue-routing-tag: bds/default +func TestBdsBdsClusterVersionResource_basic(t *testing.T) { + httpreplay.SetScenario("TestBdsBdsClusterVersionResource_basic") + defer httpreplay.SaveScenario() + + config := acctest.ProviderTestConfig() + + compartmentId := utils.GetEnvSettingWithBlankDefault("compartment_ocid") + compartmentIdVariableStr := fmt.Sprintf("variable \"compartment_id\" { default = \"%s\" }\n", compartmentId) + + datasourceName := "data.oci_bds_bds_cluster_versions.test_bds_cluster_versions" + + acctest.SaveConfigContent("", "", "", t) + + acctest.ResourceTest(t, nil, []resource.TestStep{ + // verify datasource + { + Config: config + + acctest.GenerateDataSourceFromRepresentationMap("oci_bds_bds_cluster_versions", "test_bds_cluster_versions", acctest.Required, acctest.Create, BdsBdsClusterVersionDataSourceRepresentation) + + compartmentIdVariableStr + BdsBdsClusterVersionResourceConfig, + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + + resource.TestCheckResourceAttrSet(datasourceName, "bds_cluster_versions.#"), + resource.TestCheckResourceAttrSet(datasourceName, "bds_cluster_versions.0.bds_version"), + resource.TestCheckResourceAttrSet(datasourceName, "bds_cluster_versions.0.odh_version"), + ), + }, + }) +} diff --git a/internal/integrationtest/bds_bds_instance_api_key_test.go b/internal/integrationtest/bds_bds_instance_api_key_test.go index 7c22b56f0d3..1d190f4ade1 100644 --- a/internal/integrationtest/bds_bds_instance_api_key_test.go +++ b/internal/integrationtest/bds_bds_instance_api_key_test.go @@ -34,32 +34,36 @@ var ( BdsBdsbdsInstanceApiKeySingularDataSourceRepresentation = map[string]interface{}{ "api_key_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_bds_bds_instance_api_key.test_bds_instance_api_key.id}`}, - "bds_instance_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_bds_bds_instance.test_bds_instance.id}`}, + "bds_instance_id": acctest.Representation{RepType: acctest.Required, Create: `${var.bdsinstance_id}`}, } BdsBdsbdsInstanceApiKeyDataSourceRepresentation = map[string]interface{}{ - "bds_instance_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_bds_bds_instance.test_bds_instance.id}`}, - // "display_name": Representation{RepType: Optional, Create: `keyAlias`}, - "state": acctest.Representation{RepType: acctest.Optional, Create: `ACTIVE`}, - // "user_id": Representation{RepType: Optional, Create: `${oci_identity_user.test_user.id}`}, - "filter": acctest.RepresentationGroup{RepType: acctest.Required, Group: BdsbdsInstanceApiKeyDataSourceFilterRepresentation}} + "bds_instance_id": acctest.Representation{RepType: acctest.Required, Create: `${var.bdsinstance_id}`}, + "state": acctest.Representation{RepType: acctest.Optional, Create: `ACTIVE`}, + "filter": acctest.RepresentationGroup{RepType: acctest.Required, Group: BdsbdsInstanceApiKeyDataSourceFilterRepresentation}} BdsbdsInstanceApiKeyDataSourceFilterRepresentation = map[string]interface{}{ "name": acctest.Representation{RepType: acctest.Required, Create: `id`}, "values": acctest.Representation{RepType: acctest.Required, Create: []string{`${oci_bds_bds_instance_api_key.test_bds_instance_api_key.id}`}}, } + BdsbdsInstanceApiKeyRequiredRepresentation = map[string]interface{}{ + "bds_instance_id": acctest.Representation{RepType: acctest.Required, Create: `${var.bdsinstance_id}`}, + "key_alias": acctest.Representation{RepType: acctest.Required, Create: `keyAlias`}, + "passphrase": acctest.Representation{RepType: acctest.Required, Create: `V2VsY29tZTFA`}, + "user_id": acctest.Representation{RepType: acctest.Required, Create: `${var.user_id}`}, + "default_region": acctest.Representation{RepType: acctest.Optional, Create: `us-ashburn-1`}, + "domain_ocid": acctest.Representation{RepType: acctest.Optional, Create: `${var.domain_ocid}`}, + } BdsbdsInstanceApiKeyRepresentation = map[string]interface{}{ - "bds_instance_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_bds_bds_instance.test_bds_instance.id}`}, + "bds_instance_id": acctest.Representation{RepType: acctest.Required, Create: `${var.bdsinstance_id}`}, "key_alias": acctest.Representation{RepType: acctest.Required, Create: `keyAlias`}, - "passphrase": acctest.Representation{RepType: acctest.Required, Create: `V2VsY29tZTE=`}, - "user_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_identity_user.test_user.id}`}, + "passphrase": acctest.Representation{RepType: acctest.Required, Create: `V2VsY29tZTFA`}, + "user_id": acctest.Representation{RepType: acctest.Required, Create: `${var.user_id}`}, "default_region": acctest.Representation{RepType: acctest.Optional, Create: `us-ashburn-1`}, + "domain_ocid": acctest.Representation{RepType: acctest.Optional, Create: `${var.domain_ocid}`}, } - BdsBdsInstanceApiKeyResourceDependencies = acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance", "test_bds_instance", acctest.Required, acctest.Create, bdsInstanceOdhRepresentation) + - acctest.GenerateResourceFromRepresentationMap("oci_core_subnet", "test_subnet", acctest.Required, acctest.Create, CoreSubnetRepresentation) + - acctest.GenerateResourceFromRepresentationMap("oci_core_vcn", "test_vcn", acctest.Required, acctest.Create, CoreVcnRepresentation) + - acctest.GenerateResourceFromRepresentationMap("oci_identity_user", "test_user", acctest.Required, acctest.Create, IdentityUserRepresentation) + BdsBdsInstanceApiKeyResourceDependencies = acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance", "test_bds_instance", acctest.Required, acctest.Create, bdsInstanceOdhRepresentation) ) // issue-routing-tag: bds/default @@ -72,6 +76,15 @@ func TestBdsBdsInstanceApiKeyResource_basic(t *testing.T) { compartmentId := utils.GetEnvSettingWithBlankDefault("compartment_ocid") compartmentIdVariableStr := fmt.Sprintf("variable \"compartment_id\" { default = \"%s\" }\n", compartmentId) + bdsinstanceId := utils.GetEnvSettingWithBlankDefault("bdsinstance_ocid") + bdsinstanceIdVariableStr := fmt.Sprintf("variable \"bdsinstance_id\" { default = \"%s\" }\n", bdsinstanceId) + + userId := utils.GetEnvSettingWithBlankDefault("user_ocid") + userIdVariableStr := fmt.Sprintf("variable \"user_id\" { default = \"%s\" }\n", userId) + + domainOcid := utils.GetEnvSettingWithBlankDefault("domain_ocid") + domainOcidVariableStr := fmt.Sprintf("variable \"domain_ocid\" { default = \"%s\" }\n", domainOcid) + resourceName := "oci_bds_bds_instance_api_key.test_bds_instance_api_key" datasourceName := "data.oci_bds_bds_instance_api_keys.test_bds_instance_api_keys" singularDatasourceName := "data.oci_bds_bds_instance_api_key.test_bds_instance_api_key" @@ -84,35 +97,32 @@ func TestBdsBdsInstanceApiKeyResource_basic(t *testing.T) { acctest.ResourceTest(t, testAccCheckBdsBdsInstanceApiKeyDestroy, []resource.TestStep{ // verify Create { - Config: config + compartmentIdVariableStr + BdsBdsInstanceApiKeyResourceDependencies + - acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance_api_key", "test_bds_instance_api_key", acctest.Required, acctest.Create, BdsbdsInstanceApiKeyRepresentation), + Config: config + compartmentIdVariableStr + bdsinstanceIdVariableStr + userIdVariableStr + domainOcidVariableStr + + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance_api_key", "test_bds_instance_api_key", acctest.Required, acctest.Create, BdsbdsInstanceApiKeyRequiredRepresentation), Check: acctest.ComposeAggregateTestCheckFuncWrapper( resource.TestCheckResourceAttrSet(resourceName, "bds_instance_id"), resource.TestCheckResourceAttr(resourceName, "key_alias", "keyAlias"), - resource.TestCheckResourceAttr(resourceName, "passphrase", "V2VsY29tZTE="), + resource.TestCheckResourceAttr(resourceName, "passphrase", "V2VsY29tZTFA"), resource.TestCheckResourceAttrSet(resourceName, "user_id"), ), }, // delete before next Create { - Config: config + compartmentIdVariableStr + BdsBdsInstanceApiKeyResourceDependencies, + Config: config + compartmentIdVariableStr, }, // verify Create with optionals { - Config: config + compartmentIdVariableStr + BdsBdsInstanceApiKeyResourceDependencies + + Config: config + compartmentIdVariableStr + bdsinstanceIdVariableStr + userIdVariableStr + domainOcidVariableStr + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance_api_key", "test_bds_instance_api_key", acctest.Optional, acctest.Create, BdsbdsInstanceApiKeyRepresentation), Check: acctest.ComposeAggregateTestCheckFuncWrapper( resource.TestCheckResourceAttrSet(resourceName, "bds_instance_id"), resource.TestCheckResourceAttr(resourceName, "default_region", "us-ashburn-1"), + resource.TestCheckResourceAttrSet(resourceName, "domain_ocid"), resource.TestCheckResourceAttrSet(resourceName, "fingerprint"), resource.TestCheckResourceAttrSet(resourceName, "id"), resource.TestCheckResourceAttr(resourceName, "key_alias", "keyAlias"), - resource.TestCheckResourceAttr(resourceName, "passphrase", "V2VsY29tZTE="), - resource.TestCheckResourceAttrSet(resourceName, "pemfilepath"), - resource.TestCheckResourceAttrSet(resourceName, "state"), - resource.TestCheckResourceAttrSet(resourceName, "tenant_id"), - resource.TestCheckResourceAttrSet(resourceName, "time_created"), + resource.TestCheckResourceAttr(resourceName, "passphrase", "V2VsY29tZTFA"), resource.TestCheckResourceAttrSet(resourceName, "user_id"), func(s *terraform.State) (err error) { @@ -131,14 +141,13 @@ func TestBdsBdsInstanceApiKeyResource_basic(t *testing.T) { { Config: config + acctest.GenerateDataSourceFromRepresentationMap("oci_bds_bds_instance_api_keys", "test_bds_instance_api_keys", acctest.Optional, acctest.Update, BdsBdsbdsInstanceApiKeyDataSourceRepresentation) + - compartmentIdVariableStr + BdsBdsInstanceApiKeyResourceDependencies + + compartmentIdVariableStr + bdsinstanceIdVariableStr + userIdVariableStr + domainOcidVariableStr + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance_api_key", "test_bds_instance_api_key", acctest.Optional, acctest.Update, BdsbdsInstanceApiKeyRepresentation), Check: acctest.ComposeAggregateTestCheckFuncWrapper( resource.TestCheckResourceAttrSet(datasourceName, "bds_instance_id"), - // resource.TestCheckResourceAttr(datasourceName, "display_name", "keyAlias"), + // resource.TestCheckResourceAttr(datasourceName, "display_name", "keyAlias"), resource.TestCheckResourceAttr(datasourceName, "state", "ACTIVE"), - // resource.TestCheckResourceAttrSet(datasourceName, "user_id"), - + // resource.TestCheckResourceAttrSet(datasourceName, "user_id"), resource.TestCheckResourceAttr(datasourceName, "bds_api_keys.#", "1"), resource.TestCheckResourceAttr(datasourceName, "bds_api_keys.0.default_region", "us-ashburn-1"), resource.TestCheckResourceAttrSet(datasourceName, "bds_api_keys.0.id"), @@ -151,12 +160,13 @@ func TestBdsBdsInstanceApiKeyResource_basic(t *testing.T) { { Config: config + acctest.GenerateDataSourceFromRepresentationMap("oci_bds_bds_instance_api_key", "test_bds_instance_api_key", acctest.Required, acctest.Create, BdsBdsbdsInstanceApiKeySingularDataSourceRepresentation) + - compartmentIdVariableStr + BdsBdsInstanceApiKeyResourceConfig, + compartmentIdVariableStr + bdsinstanceIdVariableStr + userIdVariableStr + domainOcidVariableStr + + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance_api_key", "test_bds_instance_api_key", acctest.Optional, acctest.Update, BdsbdsInstanceApiKeyRepresentation), Check: acctest.ComposeAggregateTestCheckFuncWrapper( resource.TestCheckResourceAttrSet(singularDatasourceName, "api_key_id"), resource.TestCheckResourceAttrSet(singularDatasourceName, "bds_instance_id"), - resource.TestCheckResourceAttr(singularDatasourceName, "default_region", "us-ashburn-1"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "domain_ocid"), resource.TestCheckResourceAttrSet(singularDatasourceName, "fingerprint"), resource.TestCheckResourceAttrSet(singularDatasourceName, "id"), resource.TestCheckResourceAttr(singularDatasourceName, "key_alias", "keyAlias"), diff --git a/internal/integrationtest/bds_bds_instance_patch_action_test.go b/internal/integrationtest/bds_bds_instance_patch_action_test.go index f860b103047..0dca84e76de 100644 --- a/internal/integrationtest/bds_bds_instance_patch_action_test.go +++ b/internal/integrationtest/bds_bds_instance_patch_action_test.go @@ -8,32 +8,31 @@ import ( "strconv" "testing" - "github.com/hashicorp/terraform-plugin-sdk/v2/terraform" - "github.com/oracle/terraform-provider-oci/internal/resourcediscovery" - "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" + "github.com/hashicorp/terraform-plugin-sdk/v2/terraform" "github.com/oracle/terraform-provider-oci/httpreplay" "github.com/oracle/terraform-provider-oci/internal/acctest" + "github.com/oracle/terraform-provider-oci/internal/resourcediscovery" "github.com/oracle/terraform-provider-oci/internal/utils" ) var ( - //BdsBdsInstancePatchActionRequiredOnlyResource = BdsBdsInstancePatchActionResourceDependencies + - //acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance_patch_action", "test_bds_instance_patch_action", acctest.Required, acctest.Create, BdsBdsInstancePatchActionRepresentation) - BdsBdsInstancePatchActionRepresentation = map[string]interface{}{ - "bds_instance_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_bds_bds_instance.test_bds_instance.id}`}, - "cluster_admin_password": acctest.Representation{RepType: acctest.Required, Create: `clusterAdminPassword`}, - "version": acctest.Representation{RepType: acctest.Required, Create: `version`}, + "bds_instance_id": acctest.Representation{RepType: acctest.Required, Create: `${var.bdsinstance_id}`}, + "cluster_admin_password": acctest.Representation{RepType: acctest.Required, Create: `T3JhY2xlVGVhbVVTQSExMjM=`}, + "version": acctest.Representation{RepType: acctest.Required, Create: `ODH-2.0.10.7-branch-ODH2-102024-7.tar.gz`}, "patching_config": acctest.RepresentationGroup{RepType: acctest.Required, Group: BdsBdsInstancePatchActionPatchingConfigRepresentation}, "timeouts": acctest.RepresentationGroup{RepType: acctest.Required, Group: PatchTimeoutsRepresentation}, } + BdsBdsInstancePatchActionPatchingConfigRepresentation = map[string]interface{}{ - "patching_config_strategy": acctest.Representation{RepType: acctest.Required, Create: `DOWNTIME_BASED`}, - "batch_size": acctest.Representation{RepType: acctest.Required, Create: `3`}, - "wait_time_between_batch_in_seconds": acctest.Representation{RepType: acctest.Required, Create: `600`}, - "wait_time_between_domain_in_seconds": acctest.Representation{RepType: acctest.Required, Create: `600`}, + "patching_config_strategy": acctest.Representation{RepType: acctest.Required, Create: `DOMAIN_BASED`}, + "tolerance_threshold_per_batch": acctest.Representation{RepType: acctest.Optional, Create: `1`}, + "tolerance_threshold_per_domain": acctest.Representation{RepType: acctest.Optional, Create: `1`}, + "batch_size": acctest.Representation{RepType: acctest.Required, Create: `5`}, + "wait_time_between_batch_in_seconds": acctest.Representation{RepType: acctest.Required, Create: `0`}, + "wait_time_between_domain_in_seconds": acctest.Representation{RepType: acctest.Required, Create: `0`}, } PatchTimeoutsRepresentation = map[string]interface{}{ @@ -41,10 +40,6 @@ var ( "update": acctest.Representation{RepType: acctest.Required, Create: `24h`}, "delete": acctest.Representation{RepType: acctest.Required, Create: `24h`}, } - - BdsBdsInstancePatchActionResourceDependencies = acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance", "test_bds_instance", acctest.Required, acctest.Create, bdsInstanceOdhRepresentation) + - acctest.GenerateResourceFromRepresentationMap("oci_core_subnet", "test_subnet", acctest.Required, acctest.Create, CoreSubnetRepresentation) + - acctest.GenerateResourceFromRepresentationMap("oci_core_vcn", "test_vcn", acctest.Required, acctest.Create, CoreVcnRepresentation) ) // issue-routing-tag: bds/default @@ -58,6 +53,9 @@ func TestBdsBdsInstancePatchActionResource_basic(t *testing.T) { compartmentId := utils.GetEnvSettingWithBlankDefault("compartment_ocid") compartmentIdVariableStr := fmt.Sprintf("variable \"compartment_id\" { default = \"%s\" }\n", compartmentId) + bdsinstanceId := utils.GetEnvSettingWithBlankDefault("bdsinstance_ocid") + bdsinstanceIdVariableStr := fmt.Sprintf("variable \"bdsinstance_id\" { default = \"%s\" }\n", bdsinstanceId) + resourceName := "oci_bds_bds_instance_patch_action.test_bds_instance_patch_action" var resId string @@ -68,32 +66,22 @@ func TestBdsBdsInstancePatchActionResource_basic(t *testing.T) { acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance_patch_action", "test_bds_instance_patch_action", acctest.Optional, acctest.Create, BdsBdsInstancePatchActionRepresentation), "bds", "bdsInstancePatchAction", t) acctest.ResourceTest(t, nil, []resource.TestStep{ - // verify Create - { - Config: config + compartmentIdVariableStr + - acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance_patch_action", "test_bds_instance_patch_action", acctest.Required, acctest.Create, BdsBdsInstancePatchActionRepresentation), - Check: acctest.ComposeAggregateTestCheckFuncWrapper( - resource.TestCheckResourceAttrSet(resourceName, "bds_instance_id"), - ), - }, - // delete before next Create - { - Config: config + compartmentIdVariableStr + BdsBdsInstancePatchActionResourceDependencies, - }, - // verify Create with optionals + // verify Create { - Config: config + compartmentIdVariableStr + BdsBdsInstancePatchActionResourceDependencies + + Config: config + compartmentIdVariableStr + bdsinstanceIdVariableStr + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance_patch_action", "test_bds_instance_patch_action", acctest.Optional, acctest.Create, BdsBdsInstancePatchActionRepresentation), Check: acctest.ComposeAggregateTestCheckFuncWrapper( resource.TestCheckResourceAttrSet(resourceName, "bds_instance_id"), - resource.TestCheckResourceAttr(resourceName, "cluster_admin_password", "clusterAdminPassword"), + resource.TestCheckResourceAttr(resourceName, "cluster_admin_password", "T3JhY2xlVGVhbVVTQSExMjM="), resource.TestCheckResourceAttr(resourceName, "patching_config.#", "1"), - resource.TestCheckResourceAttr(resourceName, "patching_config.0.batch_size", "3"), - resource.TestCheckResourceAttr(resourceName, "patching_config.0.patching_config_strategy", "DOWNTIME_BASED"), - resource.TestCheckResourceAttr(resourceName, "patching_config.0.wait_time_between_batch_in_seconds", "600"), - resource.TestCheckResourceAttr(resourceName, "patching_config.0.wait_time_between_domain_in_seconds", "600"), - resource.TestCheckResourceAttr(resourceName, "version", "version"), + resource.TestCheckResourceAttr(resourceName, "patching_config.0.batch_size", "5"), + resource.TestCheckResourceAttr(resourceName, "patching_config.0.patching_config_strategy", "DOMAIN_BASED"), + resource.TestCheckResourceAttr(resourceName, "patching_config.0.tolerance_threshold_per_batch", "1"), + resource.TestCheckResourceAttr(resourceName, "patching_config.0.tolerance_threshold_per_domain", "1"), + resource.TestCheckResourceAttr(resourceName, "patching_config.0.wait_time_between_batch_in_seconds", "0"), + resource.TestCheckResourceAttr(resourceName, "patching_config.0.wait_time_between_domain_in_seconds", "0"), + resource.TestCheckResourceAttr(resourceName, "version", "ODH-2.0.10.7-branch-ODH2-102024-7.tar.gz"), func(s *terraform.State) (err error) { resId, err = acctest.FromInstanceState(s, resourceName, "id") diff --git a/internal/integrationtest/bds_odh_instance_resource_test.go b/internal/integrationtest/bds_odh_instance_resource_test.go index 18318d48478..99dd05c6bde 100644 --- a/internal/integrationtest/bds_odh_instance_resource_test.go +++ b/internal/integrationtest/bds_odh_instance_resource_test.go @@ -59,27 +59,24 @@ var ( "block_volume_size_in_gbs": acctest.Representation{RepType: acctest.Required, Create: `150`}, "number_of_nodes": acctest.Representation{RepType: acctest.Required, Create: `3`, Update: `4`}, } - BdsBdsInstanceNetworkConfigRepresentation = map[string]interface{}{ - "cidr_block": acctest.Representation{RepType: acctest.Optional, Create: `111.112.0.0/16`}, - "is_nat_gateway_required": acctest.Representation{RepType: acctest.Optional, Create: `true`}, - } bdsInstanceOdhRepresentation = map[string]interface{}{ - "cluster_admin_password": acctest.Representation{RepType: acctest.Required, Create: `T3JhY2xlVGVhbVVTQSExMjM=`}, - "cluster_public_key": acctest.Representation{RepType: acctest.Required, Create: `ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDpUa4zUZKyU3AkW9yoJTBDO550wpWZOXdHswfRq75gbJ2ZYlMtifvwiO3qUL/RIZSC6e1wA5OL2LQ97UaHrLLPXgjvKGVIDRHqPkzTOayjJ4ZA7NPNhcu6f/OxhKkCYF3TAQObhMJmUSMrWSUeufaRIujDz1HHqazxOgFk09fj4i2dcGnfPcm32t8a9MzlsHSmgexYCUwxGisuuWTsnMgxbqsj6DaY51l+SEPi5tf10iFmUWqziF0eKDDQ/jHkwLJ8wgBJef9FSOmwJReHcBY+NviwFTatGj7Cwtnks6CVomsFD+rAMJ9uzM8SCv5agYunx07hnEXbR9r/TXqgXGfN bdsclusterkey@oracleoci.com`}, - "cluster_version": acctest.Representation{RepType: acctest.Required, Create: `ODH1`}, - "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id}`}, - "display_name": acctest.Representation{RepType: acctest.Required, Create: `displayName`, Update: `displayName2`}, - "is_high_availability": acctest.Representation{RepType: acctest.Required, Create: `true`}, - "is_secure": acctest.Representation{RepType: acctest.Required, Create: `true`}, - "cluster_profile": acctest.Representation{RepType: acctest.Optional, Create: `HADOOP`}, - "kerberos_realm_name": acctest.Representation{RepType: acctest.Optional, Create: `BDSCLOUDSERVICE.ORACLE.COM`}, - "master_node": acctest.RepresentationGroup{RepType: acctest.Required, Group: bdsInstanceNodeFlexShapeRepresentation}, - "util_node": acctest.RepresentationGroup{RepType: acctest.Required, Group: bdsInstanceNodeFlexShapeRepresentation}, - "worker_node": acctest.RepresentationGroup{RepType: acctest.Required, Group: bdsInstanceNodesOdhWorkerRepresentation}, - "bootstrap_script_url": acctest.Representation{RepType: acctest.Optional, Create: `${var.bootstrap_script_url}`, Update: `${var.bootstrap_script_urlU}`}, - "compute_only_worker_node": acctest.RepresentationGroup{RepType: acctest.Required, Group: bdsInstanceNodeFlexShapeRepresentation}, - "edge_node": acctest.RepresentationGroup{RepType: acctest.Required, Group: bdsInstanceNodeFlexShapeRepresentation}, + "cluster_admin_password": acctest.Representation{RepType: acctest.Required, Create: `T3JhY2xlVGVhbVVTQSExMjM=`}, + "cluster_public_key": acctest.Representation{RepType: acctest.Required, Create: `ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDpUa4zUZKyU3AkW9yoJTBDO550wpWZOXdHswfRq75gbJ2ZYlMtifvwiO3qUL/RIZSC6e1wA5OL2LQ97UaHrLLPXgjvKGVIDRHqPkzTOayjJ4ZA7NPNhcu6f/OxhKkCYF3TAQObhMJmUSMrWSUeufaRIujDz1HHqazxOgFk09fj4i2dcGnfPcm32t8a9MzlsHSmgexYCUwxGisuuWTsnMgxbqsj6DaY51l+SEPi5tf10iFmUWqziF0eKDDQ/jHkwLJ8wgBJef9FSOmwJReHcBY+NviwFTatGj7Cwtnks6CVomsFD+rAMJ9uzM8SCv5agYunx07hnEXbR9r/TXqgXGfN bdsclusterkey@oracleoci.com`}, + "cluster_version": acctest.Representation{RepType: acctest.Required, Create: `ODH2_0`}, + "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id}`}, + "display_name": acctest.Representation{RepType: acctest.Required, Create: `displayName`, Update: `displayName2`}, + "is_high_availability": acctest.Representation{RepType: acctest.Required, Create: `true`}, + "is_secure": acctest.Representation{RepType: acctest.Required, Create: `true`}, + "bds_cluster_version_summary": acctest.RepresentationGroup{RepType: acctest.Optional, Group: BdsBdsInstanceBdsClusterVersionSummaryRepresentation}, + "cluster_profile": acctest.Representation{RepType: acctest.Optional, Create: `HADOOP`}, + "kerberos_realm_name": acctest.Representation{RepType: acctest.Optional, Create: `BDSCLOUDSERVICE.ORACLE.COM`}, + "master_node": acctest.RepresentationGroup{RepType: acctest.Required, Group: bdsInstanceNodeFlexShapeRepresentation}, + "util_node": acctest.RepresentationGroup{RepType: acctest.Required, Group: bdsInstanceNodeFlexShapeRepresentation}, + "worker_node": acctest.RepresentationGroup{RepType: acctest.Required, Group: bdsInstanceNodesOdhWorkerRepresentation}, + "bootstrap_script_url": acctest.Representation{RepType: acctest.Optional, Create: `${var.bootstrap_script_url}`, Update: `${var.bootstrap_script_urlU}`}, + "compute_only_worker_node": acctest.RepresentationGroup{RepType: acctest.Required, Group: bdsInstanceNodeFlexShapeRepresentation}, + "edge_node": acctest.RepresentationGroup{RepType: acctest.Required, Group: bdsInstanceNodeFlexShapeRepresentation}, "is_cloud_sql_configured": acctest.Representation{RepType: acctest.Optional, Create: `false`}, "kms_key_id": acctest.Representation{RepType: acctest.Optional, Create: `${var.kms_key_id}`, Update: `${var.kms_key_id_for_update}`}, @@ -93,6 +90,20 @@ var ( //"os_patch_version": acctest.Representation{RepType: acctest.Optional, Update: `ol7.9-x86_64-1.28.0.619-0.0`}, // Test when patch is available } + bdsInstanceStartClusterShapeConfigRepresentation = map[string]interface{}{ + "node_type_shape_configs": acctest.RepresentationGroup{RepType: acctest.Optional, Group: bdsInstanceNodeTypeShapeConfigsRepresentation}, + } + + bdsInstanceNodeTypeShapeConfigsRepresentation = map[string]interface{}{ + "node_type": acctest.Representation{RepType: acctest.Optional, Create: `WORKER`}, + "shape": acctest.Representation{RepType: acctest.Optional, Create: `VM.Standard.E5.Flex`}, + } + + BdsBdsInstanceBdsClusterVersionSummaryRepresentation = map[string]interface{}{ + "bds_version": acctest.Representation{RepType: acctest.Required, Create: `3.0.26`}, + "odh_version": acctest.Representation{RepType: acctest.Optional, Create: `2.0.7`}, + } + bdsInstanceOdhWithFlexComputeAndRegularMasterUtilRepresentation = acctest.RepresentationCopyWithNewProperties(bdsInstanceOdhRepresentation, map[string]interface{}{ // Master & Util shape should be same @@ -126,15 +137,15 @@ var ( "number_of_nodes": acctest.Representation{RepType: acctest.Required, Create: `2`}, } bdsInstanceNodesOdhWorkerRepresentation = map[string]interface{}{ - "shape": acctest.Representation{RepType: acctest.Required, Create: `VM.DenseIO.E5.Flex`, Update: `VM.DenseIO.Generic`}, - "subnet_id": acctest.Representation{RepType: acctest.Required, Create: `${var.subnet_id}`}, - "number_of_nodes": acctest.Representation{RepType: acctest.Required, Create: `3`, Update: `4`}, - "shape_config": acctest.RepresentationGroup{RepType: acctest.Required, Group: bdsInstanceNodesWorkerShapeConfigRepresentation}, + "shape": acctest.Representation{RepType: acctest.Required, Create: `VM.Standard.E4.Flex`, Update: `VM.Standard.E5.Flex`}, + "subnet_id": acctest.Representation{RepType: acctest.Required, Create: `${var.subnet_id}`}, + "block_volume_size_in_gbs": acctest.Representation{RepType: acctest.Required, Create: `150`}, + "number_of_nodes": acctest.Representation{RepType: acctest.Required, Create: `3`, Update: `4`}, + "shape_config": acctest.RepresentationGroup{RepType: acctest.Required, Group: bdsInstanceNodesWorkerShapeConfigRepresentation}, } bdsInstanceNodesWorkerShapeConfigRepresentation = map[string]interface{}{ "memory_in_gbs": acctest.Representation{RepType: acctest.Required, Create: `120`, Update: `120`}, "ocpus": acctest.Representation{RepType: acctest.Required, Create: `8`, Update: `8`}, - "nvmes": acctest.Representation{RepType: acctest.Required, Create: `1`, Update: `1`}, } bdsInstanceNodeFlexShapeRepresentation = map[string]interface{}{ @@ -144,12 +155,7 @@ var ( "number_of_nodes": acctest.Representation{RepType: acctest.Required, Create: `2`}, "shape_config": acctest.RepresentationGroup{RepType: acctest.Required, Group: bdsInstanceNodesShapeConfigRepresentation}, } - bdsInstanceNodeDenseShapeRepresentation = map[string]interface{}{ - "shape": acctest.Representation{RepType: acctest.Required, Create: `VM.DenseIO.E4.Flex`}, - "subnet_id": acctest.Representation{RepType: acctest.Required, Create: `${var.subnet_id}`}, - "number_of_nodes": acctest.Representation{RepType: acctest.Required, Create: `3`, Update: `4`}, - "shape_config": acctest.RepresentationGroup{RepType: acctest.Required, Group: bdsInstanceNodesDenseShapeConfigRepresentation}, - } + bdsInstanceNodeFlex3ShapeRepresentation = map[string]interface{}{ "shape": acctest.Representation{RepType: acctest.Required, Create: `VM.Standard3.Flex`}, "subnet_id": acctest.Representation{RepType: acctest.Required, Create: `${var.subnet_id}`}, @@ -174,7 +180,7 @@ var ( "util_node": acctest.RepresentationGroup{RepType: acctest.Required, Group: bdsInstanceOdhWithUpdateMasterUtilRepresentation}, }) bdsInstanceOdhWithUpdateMasterUtilRepresentation = map[string]interface{}{ - "shape": acctest.Representation{RepType: acctest.Required, Create: `VM.Standard.E4.Flex`}, + "shape": acctest.Representation{RepType: acctest.Required, Create: `VM.Standard.E5.Flex`}, "subnet_id": acctest.Representation{RepType: acctest.Required, Create: `${var.subnet_id}`}, "block_volume_size_in_gbs": acctest.Representation{RepType: acctest.Required, Create: `150`}, "number_of_nodes": acctest.Representation{RepType: acctest.Required, Update: `3`}, @@ -182,10 +188,10 @@ var ( } bdsInstanceOdhNetworkConfigRepresentation = map[string]interface{}{ "cidr_block": acctest.Representation{RepType: acctest.Optional, Create: `111.112.0.0/16`}, - "is_nat_gateway_required": acctest.Representation{RepType: acctest.Required, Create: `true`}, + "is_nat_gateway_required": acctest.Representation{RepType: acctest.Required, Create: `true`, Update: `true`}, } bdsInstanceKafkaBrokerNodeFlexShapeRepresentation = map[string]interface{}{ - "shape": acctest.Representation{RepType: acctest.Required, Create: `VM.Standard.E4.Flex`}, + "shape": acctest.Representation{RepType: acctest.Required, Create: `VM.Standard.E5.Flex`}, "subnet_id": acctest.Representation{RepType: acctest.Required, Create: `${var.subnet_id}`}, "block_volume_size_in_gbs": acctest.Representation{RepType: acctest.Required, Create: `150`}, "number_of_kafka_nodes": acctest.Representation{RepType: acctest.Required, Create: `3`}, @@ -250,7 +256,7 @@ func TestResourceBdsOdhInstance(t *testing.T) { Check: resource.ComposeAggregateTestCheckFunc( resource.TestCheckResourceAttr(resourceName, "cluster_admin_password", "T3JhY2xlVGVhbVVTQSExMjM="), resource.TestCheckResourceAttrSet(resourceName, "cluster_public_key"), - resource.TestCheckResourceAttr(resourceName, "cluster_version", "ODH1"), + resource.TestCheckResourceAttr(resourceName, "cluster_version", "ODH2_0"), resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), resource.TestCheckResourceAttr(resourceName, "is_high_availability", "true"), resource.TestCheckResourceAttr(resourceName, "is_secure", "true"), @@ -285,7 +291,7 @@ func TestResourceBdsOdhInstance(t *testing.T) { Check: resource.ComposeAggregateTestCheckFunc( resource.TestCheckResourceAttr(resourceName, "cluster_admin_password", "T3JhY2xlVGVhbVVTQSExMjM="), resource.TestCheckResourceAttrSet(resourceName, "cluster_public_key"), - resource.TestCheckResourceAttr(resourceName, "cluster_version", "ODH1"), + resource.TestCheckResourceAttr(resourceName, "cluster_version", "ODH2_0"), resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), resource.TestCheckResourceAttr(resourceName, "is_high_availability", "true"), resource.TestCheckResourceAttr(resourceName, "is_secure", "true"), @@ -307,13 +313,14 @@ func TestResourceBdsOdhInstance(t *testing.T) { Config: config + compartmentIdVariableStr + kmsKeyIdVariableStr + subnetIdVariableStr + BdsInstanceOdhResourceDependencies + bootstrapScriptUrlVariableStr + bootstrapScriptUrlUVariableStr + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance", "test_bds_instance", acctest.Optional, acctest.Create, acctest.RepresentationCopyWithNewProperties(bdsInstanceOdhRepresentation, map[string]interface{}{ - "is_force_stop_jobs": acctest.Representation{RepType: acctest.Required, Create: `true`}, - "state": acctest.Representation{RepType: acctest.Required, Create: `ACTIVE`}, + "is_force_stop_jobs": acctest.Representation{RepType: acctest.Required, Create: `true`}, + "state": acctest.Representation{RepType: acctest.Required, Create: `ACTIVE`}, + "start_cluster_shape_configs": acctest.RepresentationGroup{RepType: acctest.Optional, Group: bdsInstanceStartClusterShapeConfigRepresentation}, })), Check: resource.ComposeAggregateTestCheckFunc( resource.TestCheckResourceAttr(resourceName, "cluster_admin_password", "T3JhY2xlVGVhbVVTQSExMjM="), resource.TestCheckResourceAttrSet(resourceName, "cluster_public_key"), - resource.TestCheckResourceAttr(resourceName, "cluster_version", "ODH1"), + resource.TestCheckResourceAttr(resourceName, "cluster_version", "ODH2_0"), resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), resource.TestCheckResourceAttr(resourceName, "is_high_availability", "true"), resource.TestCheckResourceAttr(resourceName, "is_secure", "true"), @@ -447,10 +454,13 @@ func TestResourceBdsOdhInstance(t *testing.T) { acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance", "test_bds_instance", acctest.Optional, acctest.Create, bdsInstanceOdhRepresentation), Check: resource.ComposeAggregateTestCheckFunc( resource.TestCheckResourceAttr(resourceName, "bootstrap_script_url", bootstrapScriptUrl), + resource.TestCheckResourceAttr(resourceName, "bds_cluster_version_summary.#", "1"), + resource.TestCheckResourceAttr(resourceName, "bds_cluster_version_summary.0.bds_version", "3.0.26"), + resource.TestCheckResourceAttr(resourceName, "bds_cluster_version_summary.0.odh_version", "2.0.7"), resource.TestCheckResourceAttr(resourceName, "cluster_admin_password", "T3JhY2xlVGVhbVVTQSExMjM="), resource.TestCheckResourceAttr(resourceName, "cluster_profile", "HADOOP"), resource.TestCheckResourceAttrSet(resourceName, "cluster_public_key"), - resource.TestCheckResourceAttr(resourceName, "cluster_version", "ODH1"), + resource.TestCheckResourceAttr(resourceName, "cluster_version", "ODH2_0"), resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), resource.TestCheckResourceAttr(resourceName, "display_name", "displayName"), resource.TestCheckResourceAttr(resourceName, "freeform_tags.%", "1"), @@ -474,10 +484,10 @@ func TestResourceBdsOdhInstance(t *testing.T) { resource.TestCheckResourceAttrSet(resourceName, "nodes.0.time_created"), resource.TestCheckResourceAttr(resourceName, "number_of_nodes", "11"), resource.TestCheckResourceAttrSet(resourceName, "state"), - resource.TestCheckResourceAttr(resourceName, "util_node.0.shape", "VM.Standard.E4.Flex"), - resource.TestCheckResourceAttr(resourceName, "master_node.0.shape", "VM.Standard.E4.Flex"), - resource.TestCheckResourceAttr(resourceName, "compute_only_worker_node.0.shape", "VM.Standard.E4.Flex"), - resource.TestCheckResourceAttr(resourceName, "edge_node.0.shape", "VM.Standard.E4.Flex"), + resource.TestCheckResourceAttr(resourceName, "util_node.0.shape", "VM.Standard.E5.Flex"), + resource.TestCheckResourceAttr(resourceName, "master_node.0.shape", "VM.Standard.E5.Flex"), + resource.TestCheckResourceAttr(resourceName, "compute_only_worker_node.0.shape", "VM.Standard.E5.Flex"), + resource.TestCheckResourceAttr(resourceName, "edge_node.0.shape", "VM.Standard.E5.Flex"), func(s *terraform.State) (err error) { resId, err = acctest.FromInstanceState(s, resourceName, "id") @@ -498,10 +508,13 @@ func TestResourceBdsOdhInstance(t *testing.T) { "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id_for_update}`}, })), Check: resource.ComposeAggregateTestCheckFunc( + resource.TestCheckResourceAttr(resourceName, "bds_cluster_version_summary.#", "1"), + resource.TestCheckResourceAttr(resourceName, "bds_cluster_version_summary.0.bds_version", "3.0.26"), + resource.TestCheckResourceAttr(resourceName, "bds_cluster_version_summary.0.odh_version", "2.0.7"), resource.TestCheckResourceAttr(resourceName, "cluster_admin_password", "T3JhY2xlVGVhbVVTQSExMjM="), resource.TestCheckResourceAttr(resourceName, "cluster_profile", "HADOOP"), resource.TestCheckResourceAttrSet(resourceName, "cluster_public_key"), - resource.TestCheckResourceAttr(resourceName, "cluster_version", "ODH1"), + resource.TestCheckResourceAttr(resourceName, "cluster_version", "ODH2_0"), resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentIdU), resource.TestCheckResourceAttr(resourceName, "display_name", "displayName"), resource.TestCheckResourceAttr(resourceName, "freeform_tags.%", "1"), @@ -528,8 +541,8 @@ func TestResourceBdsOdhInstance(t *testing.T) { resource.TestCheckResourceAttrSet(resourceName, "state"), resource.TestCheckResourceAttr(resourceName, "util_node.0.shape", "VM.Standard2.4"), resource.TestCheckResourceAttr(resourceName, "master_node.0.shape", "VM.Standard2.4"), - resource.TestCheckResourceAttr(resourceName, "compute_only_worker_node.0.shape", "VM.Standard.E4.Flex"), - resource.TestCheckResourceAttr(resourceName, "edge_node.0.shape", "VM.Standard.E4.Flex"), + resource.TestCheckResourceAttr(resourceName, "compute_only_worker_node.0.shape", "VM.Standard.E5.Flex"), + resource.TestCheckResourceAttr(resourceName, "edge_node.0.shape", "VM.Standard.E5.Flex"), func(s *terraform.State) (err error) { resId2, err = acctest.FromInstanceState(s, resourceName, "id") @@ -545,10 +558,13 @@ func TestResourceBdsOdhInstance(t *testing.T) { Config: config + compartmentIdVariableStr + kmsKeyIdUVariableStr + bootstrapScriptUrlVariableStr + bootstrapScriptUrlUVariableStr + subnetIdVariableStr + BdsInstanceOdhResourceDependencies + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance", "test_bds_instance", acctest.Optional, acctest.Update, bdsInstanceOdhWithRegularComputeAndFlexMasterUtilRepresentation), Check: resource.ComposeAggregateTestCheckFunc( + resource.TestCheckResourceAttr(resourceName, "bds_cluster_version_summary.#", "1"), + resource.TestCheckResourceAttr(resourceName, "bds_cluster_version_summary.0.bds_version", "3.0.26"), + resource.TestCheckResourceAttr(resourceName, "bds_cluster_version_summary.0.odh_version", "2.0.7"), resource.TestCheckResourceAttr(resourceName, "cluster_admin_password", "T3JhY2xlVGVhbVVTQSExMjM="), resource.TestCheckResourceAttr(resourceName, "cluster_profile", "HADOOP"), resource.TestCheckResourceAttrSet(resourceName, "cluster_public_key"), - resource.TestCheckResourceAttr(resourceName, "cluster_version", "ODH1"), + resource.TestCheckResourceAttr(resourceName, "cluster_version", "ODH2_0"), resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), resource.TestCheckResourceAttr(resourceName, "display_name", "displayName2"), resource.TestCheckResourceAttr(resourceName, "freeform_tags.%", "1"), @@ -573,10 +589,10 @@ func TestResourceBdsOdhInstance(t *testing.T) { resource.TestCheckResourceAttrSet(resourceName, "nodes.0.time_created"), resource.TestCheckResourceAttr(resourceName, "number_of_nodes", "12"), resource.TestCheckResourceAttrSet(resourceName, "state"), - resource.TestCheckResourceAttr(resourceName, "util_node.0.shape", "VM.Standard.E4.Flex"), - resource.TestCheckResourceAttr(resourceName, "master_node.0.shape", "VM.Standard.E4.Flex"), + resource.TestCheckResourceAttr(resourceName, "util_node.0.shape", "VM.Standard.E5.Flex"), + resource.TestCheckResourceAttr(resourceName, "master_node.0.shape", "VM.Standard.E5.Flex"), resource.TestCheckResourceAttr(resourceName, "compute_only_worker_node.0.shape", "VM.Standard2.4"), - resource.TestCheckResourceAttr(resourceName, "edge_node.0.shape", "VM.Standard.E4.Flex"), + resource.TestCheckResourceAttr(resourceName, "edge_node.0.shape", "VM.Standard.E5.Flex"), resource.TestCheckResourceAttr(resourceName, "worker_node.0.number_of_nodes", "4"), func(s *terraform.State) (err error) { @@ -593,10 +609,13 @@ func TestResourceBdsOdhInstance(t *testing.T) { Config: config + compartmentIdVariableStr + kmsKeyIdUVariableStr + bootstrapScriptUrlVariableStr + bootstrapScriptUrlUVariableStr + subnetIdVariableStr + BdsInstanceOdhResourceDependencies + acctest.GenerateResourceFromRepresentationMap("oci_bds_bds_instance", "test_bds_instance", acctest.Optional, acctest.Update, bdsInstanceOdhWithAddMasterUtilRepresentation), Check: resource.ComposeAggregateTestCheckFunc( + resource.TestCheckResourceAttr(resourceName, "bds_cluster_version_summary.#", "1"), + resource.TestCheckResourceAttr(resourceName, "bds_cluster_version_summary.0.bds_version", "3.0.26"), + resource.TestCheckResourceAttr(resourceName, "bds_cluster_version_summary.0.odh_version", "2.0.7"), resource.TestCheckResourceAttr(resourceName, "cluster_admin_password", "T3JhY2xlVGVhbVVTQSExMjM="), resource.TestCheckResourceAttr(resourceName, "cluster_profile", "HADOOP"), resource.TestCheckResourceAttrSet(resourceName, "cluster_public_key"), - resource.TestCheckResourceAttr(resourceName, "cluster_version", "ODH1"), + resource.TestCheckResourceAttr(resourceName, "cluster_version", "ODH2_0"), resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), resource.TestCheckResourceAttr(resourceName, "display_name", "displayName2"), resource.TestCheckResourceAttr(resourceName, "freeform_tags.%", "1"), @@ -621,10 +640,10 @@ func TestResourceBdsOdhInstance(t *testing.T) { resource.TestCheckResourceAttrSet(resourceName, "nodes.0.time_created"), resource.TestCheckResourceAttr(resourceName, "number_of_nodes", "14"), resource.TestCheckResourceAttrSet(resourceName, "state"), - resource.TestCheckResourceAttr(resourceName, "util_node.0.shape", "VM.Standard.E4.Flex"), - resource.TestCheckResourceAttr(resourceName, "master_node.0.shape", "VM.Standard.E4.Flex"), - resource.TestCheckResourceAttr(resourceName, "compute_only_worker_node.0.shape", "VM.Standard.E4.Flex"), - resource.TestCheckResourceAttr(resourceName, "edge_node.0.shape", "VM.Standard.E4.Flex"), + resource.TestCheckResourceAttr(resourceName, "util_node.0.shape", "VM.Standard.E5.Flex"), + resource.TestCheckResourceAttr(resourceName, "master_node.0.shape", "VM.Standard.E5.Flex"), + resource.TestCheckResourceAttr(resourceName, "compute_only_worker_node.0.shape", "VM.Standard.E5.Flex"), + resource.TestCheckResourceAttr(resourceName, "edge_node.0.shape", "VM.Standard.E5.Flex"), func(s *terraform.State) (err error) { resId2, err = acctest.FromInstanceState(s, resourceName, "id") @@ -649,7 +668,7 @@ func TestResourceBdsOdhInstance(t *testing.T) { resource.TestCheckResourceAttr(resourceName, "is_kafka_configured", "false"), resource.TestCheckResourceAttr(datasourceName, "bds_instances.#", "1"), resource.TestCheckResourceAttr(datasourceName, "bds_instances.0.cluster_profile", "HADOOP"), - resource.TestCheckResourceAttr(datasourceName, "bds_instances.0.cluster_version", "ODH1"), + resource.TestCheckResourceAttr(datasourceName, "bds_instances.0.cluster_version", "ODH2_0"), resource.TestCheckResourceAttr(datasourceName, "bds_instances.0.compartment_id", compartmentId), resource.TestCheckResourceAttr(datasourceName, "bds_instances.0.display_name", "displayName2"), resource.TestCheckResourceAttr(datasourceName, "bds_instances.0.freeform_tags.%", "1"), @@ -675,7 +694,7 @@ func TestResourceBdsOdhInstance(t *testing.T) { resource.TestCheckResourceAttr(singularDatasourceName, "cloud_sql_details.#", "0"), resource.TestCheckResourceAttr(singularDatasourceName, "cluster_details.#", "1"), resource.TestCheckResourceAttr(singularDatasourceName, "cluster_profile", "HADOOP"), - resource.TestCheckResourceAttr(singularDatasourceName, "cluster_version", "ODH1"), + resource.TestCheckResourceAttr(singularDatasourceName, "cluster_version", "ODH2_0"), resource.TestCheckResourceAttrSet(singularDatasourceName, "cluster_details.0.bd_cell_version"), resource.TestCheckResourceAttrSet(singularDatasourceName, "cluster_details.0.bds_version"), resource.TestCheckResourceAttrSet(singularDatasourceName, "cluster_details.0.csql_cell_version"), @@ -708,7 +727,7 @@ func TestResourceBdsOdhInstance(t *testing.T) { resource.TestCheckResourceAttr(singularDatasourceName, "nodes.0.node_type", "MASTER"), resource.TestCheckResourceAttrSet(singularDatasourceName, "nodes.0.nvmes"), resource.TestCheckResourceAttrSet(singularDatasourceName, "nodes.0.ocpus"), - resource.TestCheckResourceAttr(singularDatasourceName, "nodes.0.shape", "VM.Standard.E4.Flex"), + resource.TestCheckResourceAttr(singularDatasourceName, "nodes.0.shape", "VM.Standard.E5.Flex"), resource.TestCheckResourceAttrSet(singularDatasourceName, "nodes.0.node_type"), resource.TestCheckResourceAttrSet(singularDatasourceName, "nodes.0.shape"), resource.TestCheckResourceAttrSet(singularDatasourceName, "nodes.0.state"), diff --git a/internal/service/bds/bds_bds_cluster_versions_data_source.go b/internal/service/bds/bds_bds_cluster_versions_data_source.go new file mode 100644 index 00000000000..e9aeee9f147 --- /dev/null +++ b/internal/service/bds/bds_bds_cluster_versions_data_source.go @@ -0,0 +1,121 @@ +// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. +// Licensed under the Mozilla Public License v2.0 + +package bds + +import ( + "context" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" + oci_bds "github.com/oracle/oci-go-sdk/v65/bds" + + "github.com/oracle/terraform-provider-oci/internal/client" + "github.com/oracle/terraform-provider-oci/internal/tfresource" +) + +func BdsBdsClusterVersionsDataSource() *schema.Resource { + return &schema.Resource{ + Read: readBdsBdsClusterVersions, + Schema: map[string]*schema.Schema{ + "filter": tfresource.DataSourceFiltersSchema(), + "bds_cluster_versions": { + Type: schema.TypeList, + Computed: true, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + + // Optional + + // Computed + "bds_version": { + Type: schema.TypeString, + Computed: true, + }, + "odh_version": { + Type: schema.TypeString, + Computed: true, + }, + }, + }, + }, + }, + } +} + +func readBdsBdsClusterVersions(d *schema.ResourceData, m interface{}) error { + sync := &BdsBdsClusterVersionsDataSourceCrud{} + sync.D = d + sync.Client = m.(*client.OracleClients).BdsClient() + + return tfresource.ReadResource(sync) +} + +type BdsBdsClusterVersionsDataSourceCrud struct { + D *schema.ResourceData + Client *oci_bds.BdsClient + Res *oci_bds.ListBdsClusterVersionsResponse +} + +func (s *BdsBdsClusterVersionsDataSourceCrud) VoidState() { + s.D.SetId("") +} + +func (s *BdsBdsClusterVersionsDataSourceCrud) Get() error { + request := oci_bds.ListBdsClusterVersionsRequest{} + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(false, "bds") + + response, err := s.Client.ListBdsClusterVersions(context.Background(), request) + if err != nil { + return err + } + + s.Res = &response + request.Page = s.Res.OpcNextPage + + for request.Page != nil { + listResponse, err := s.Client.ListBdsClusterVersions(context.Background(), request) + if err != nil { + return err + } + + s.Res.Items = append(s.Res.Items, listResponse.Items...) + request.Page = listResponse.OpcNextPage + } + + return nil +} + +func (s *BdsBdsClusterVersionsDataSourceCrud) SetData() error { + if s.Res == nil { + return nil + } + + s.D.SetId(tfresource.GenerateDataSourceHashID("BdsBdsClusterVersionsDataSource-", BdsBdsClusterVersionsDataSource(), s.D)) + resources := []map[string]interface{}{} + + for _, r := range s.Res.Items { + bdsClusterVersion := map[string]interface{}{} + + if r.BdsVersion != nil { + bdsClusterVersion["bds_version"] = *r.BdsVersion + } + + if r.OdhVersion != nil { + bdsClusterVersion["odh_version"] = *r.OdhVersion + } + + resources = append(resources, bdsClusterVersion) + } + + if f, fOk := s.D.GetOkExists("filter"); fOk { + resources = tfresource.ApplyFilters(f.(*schema.Set), resources, BdsBdsClusterVersionsDataSource().Schema["bds_cluster_versions"].Elem.(*schema.Resource).Schema) + } + + if err := s.D.Set("bds_cluster_versions", resources); err != nil { + return err + } + + return nil +} diff --git a/internal/service/bds/bds_bds_instance_api_key_data_source.go b/internal/service/bds/bds_bds_instance_api_key_data_source.go index e03e9c147c7..821f32d64f1 100644 --- a/internal/service/bds/bds_bds_instance_api_key_data_source.go +++ b/internal/service/bds/bds_bds_instance_api_key_data_source.go @@ -79,6 +79,10 @@ func (s *BdsBdsInstanceApiKeyDataSourceCrud) SetData() error { s.D.Set("default_region", *s.Res.DefaultRegion) } + if s.Res.DomainOcid != nil { + s.D.Set("domain_ocid", *s.Res.DomainOcid) + } + if s.Res.Fingerprint != nil { s.D.Set("fingerprint", *s.Res.Fingerprint) } diff --git a/internal/service/bds/bds_bds_instance_api_key_resource.go b/internal/service/bds/bds_bds_instance_api_key_resource.go index 31c28b61b91..bf8fc3ffff4 100644 --- a/internal/service/bds/bds_bds_instance_api_key_resource.go +++ b/internal/service/bds/bds_bds_instance_api_key_resource.go @@ -63,6 +63,12 @@ func BdsBdsInstanceApiKeyResource() *schema.Resource { Computed: true, ForceNew: true, }, + "domain_ocid": { + Type: schema.TypeString, + Optional: true, + Computed: true, + ForceNew: true, + }, // Computed "fingerprint": { @@ -170,6 +176,11 @@ func (s *BdsBdsInstanceApiKeyResourceCrud) Create() error { request.DefaultRegion = &tmp } + if domainOcid, ok := s.D.GetOkExists("domain_ocid"); ok { + tmp := domainOcid.(string) + request.DomainOcid = &tmp + } + if keyAlias, ok := s.D.GetOkExists("key_alias"); ok { tmp := keyAlias.(string) request.KeyAlias = &tmp @@ -418,6 +429,10 @@ func (s *BdsBdsInstanceApiKeyResourceCrud) SetData() error { s.D.Set("default_region", *s.Res.DefaultRegion) } + if s.Res.DomainOcid != nil { + s.D.Set("domain_ocid", *s.Res.DomainOcid) + } + if s.Res.Fingerprint != nil { s.D.Set("fingerprint", *s.Res.Fingerprint) } diff --git a/internal/service/bds/bds_bds_instance_data_source.go b/internal/service/bds/bds_bds_instance_data_source.go index c388d6cbe14..5c0e8eb0c58 100644 --- a/internal/service/bds/bds_bds_instance_data_source.go +++ b/internal/service/bds/bds_bds_instance_data_source.go @@ -66,6 +66,12 @@ func (s *BdsBdsInstanceDataSourceCrud) SetData() error { s.D.SetId(*s.Res.Id) + if s.Res.BdsClusterVersionSummary != nil { + s.D.Set("bds_cluster_version_summary", []interface{}{BdsClusterVersionSummaryToMap(s.Res.BdsClusterVersionSummary)}) + } else { + s.D.Set("bds_cluster_version_summary", nil) + } + if s.Res.BootstrapScriptUrl != nil { s.D.Set("bootstrap_script_url", *s.Res.BootstrapScriptUrl) } diff --git a/internal/service/bds/bds_bds_instance_patch_action_resource.go b/internal/service/bds/bds_bds_instance_patch_action_resource.go index e24b879da4e..d050ea6fa33 100644 --- a/internal/service/bds/bds_bds_instance_patch_action_resource.go +++ b/internal/service/bds/bds_bds_instance_patch_action_resource.go @@ -79,6 +79,18 @@ func BdsBdsInstancePatchActionResource() *schema.Resource { Computed: true, ForceNew: true, }, + "tolerance_threshold_per_batch": { + Type: schema.TypeInt, + Optional: true, + Computed: true, + ForceNew: true, + }, + "tolerance_threshold_per_domain": { + Type: schema.TypeInt, + Optional: true, + Computed: true, + ForceNew: true, + }, "wait_time_between_batch_in_seconds": { Type: schema.TypeInt, Optional: true, @@ -302,6 +314,10 @@ func (s *BdsBdsInstancePatchActionResourceCrud) mapToOdhPatchingConfig(fieldKeyF tmp := batchSize.(int) details.BatchSize = &tmp } + if toleranceThresholdPerBatch, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "tolerance_threshold_per_batch")); ok { + tmp := toleranceThresholdPerBatch.(int) + details.ToleranceThresholdPerBatch = &tmp + } if waitTimeBetweenBatchInSeconds, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "wait_time_between_batch_in_seconds")); ok { tmp := waitTimeBetweenBatchInSeconds.(int) details.WaitTimeBetweenBatchInSeconds = &tmp @@ -309,6 +325,10 @@ func (s *BdsBdsInstancePatchActionResourceCrud) mapToOdhPatchingConfig(fieldKeyF baseObject = details case strings.ToLower("DOMAIN_BASED"): details := oci_bds.DomainBasedOdhPatchingConfig{} + if toleranceThresholdPerDomain, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "tolerance_threshold_per_domain")); ok { + tmp := toleranceThresholdPerDomain.(int) + details.ToleranceThresholdPerDomain = &tmp + } if waitTimeBetweenDomainInSeconds, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "wait_time_between_domain_in_seconds")); ok { tmp := waitTimeBetweenDomainInSeconds.(int) details.WaitTimeBetweenDomainInSeconds = &tmp @@ -333,12 +353,20 @@ func (s *BdsBdsInstancePatchActionResourceCrud) mapToOdhPatchingConfig(fieldKeyF result["batch_size"] = int(*v.BatchSize) } + if v.ToleranceThresholdPerBatch != nil { + result["tolerance_threshold_per_batch"] = int(*v.ToleranceThresholdPerBatch) + } + if v.WaitTimeBetweenBatchInSeconds != nil { result["wait_time_between_batch_in_seconds"] = int(*v.WaitTimeBetweenBatchInSeconds) } case oci_bds.DomainBasedOdhPatchingConfig: result["patching_config_strategy"] = "DOMAIN_BASED" + if v.ToleranceThresholdPerDomain != nil { + result["tolerance_threshold_per_domain"] = int(*v.ToleranceThresholdPerDomain) + } + if v.WaitTimeBetweenDomainInSeconds != nil { result["wait_time_between_domain_in_seconds"] = int(*v.WaitTimeBetweenDomainInSeconds) } diff --git a/internal/service/bds/bds_bds_instance_resource.go b/internal/service/bds/bds_bds_instance_resource.go index 5dc256c0ea2..81330efcbfc 100644 --- a/internal/service/bds/bds_bds_instance_resource.go +++ b/internal/service/bds/bds_bds_instance_resource.go @@ -72,6 +72,37 @@ func BdsBdsInstanceResource() *schema.Resource { Required: true, ForceNew: true, }, + "is_force_remove_enabled": { + Type: schema.TypeBool, + Optional: true, + }, + "start_cluster_shape_configs": { + Type: schema.TypeList, + Optional: true, + Computed: false, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + "node_type_shape_configs": { + Type: schema.TypeList, + Optional: true, + Computed: false, + MinItems: 1, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + "node_type": { + Type: schema.TypeString, + Optional: true, + }, + "shape": { + Type: schema.TypeString, + Optional: true, + }, + }, + }, + }, + }, + }, + }, "master_node": { Type: schema.TypeList, Required: true, @@ -537,6 +568,36 @@ func BdsBdsInstanceResource() *schema.Resource { }, }, }, + + // Optional + "bds_cluster_version_summary": { + Type: schema.TypeList, + Optional: true, + Computed: true, + ForceNew: true, + MaxItems: 1, + MinItems: 1, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + "bds_version": { + Type: schema.TypeString, + Required: true, + ForceNew: true, + }, + + // Optional + "odh_version": { + Type: schema.TypeString, + Optional: true, + Computed: true, + ForceNew: true, + }, + + // Computed + }, + }, + }, "cluster_profile": { Type: schema.TypeString, Optional: true, @@ -571,7 +632,6 @@ func BdsBdsInstanceResource() *schema.Resource { Type: schema.TypeList, Optional: true, Computed: true, - ForceNew: true, MaxItems: 1, MinItems: 1, Elem: &schema.Resource{ @@ -608,6 +668,10 @@ func BdsBdsInstanceResource() *schema.Resource { Type: schema.TypeBool, Optional: true, }, + "remove_node": { + Type: schema.TypeString, + Optional: true, + }, "os_patch_version": { Type: schema.TypeString, Optional: true, @@ -705,6 +769,10 @@ func BdsBdsInstanceResource() *schema.Resource { Type: schema.TypeString, Computed: true, }, + "odh_version": { + Type: schema.TypeString, + Computed: true, + }, "shape": { Type: schema.TypeString, Computed: true, @@ -925,12 +993,15 @@ func updateBdsBdsInstance(d *schema.ResourceData, m interface{}) error { sync.D.Set("state", oci_bds.BdsInstanceLifecycleStateActive) } - //if _, ok := sync.D.GetOkExists("os_patch_version"); ok { - // err := sync.InstallOsPatch() - // if err != nil { - // return err - // } - //} + if removeNode, ok := sync.D.GetOkExists("remove_node"); ok { + if removeNode != "" { + err := sync.RemoveNode() + if err != nil { + return err + } + } + + } if err := tfresource.UpdateResource(d, sync); err != nil { return err @@ -1006,6 +1077,29 @@ func (s *BdsBdsInstanceResourceCrud) DeletedTarget() []string { func (s *BdsBdsInstanceResourceCrud) Create() error { request := oci_bds.CreateBdsInstanceRequest{} + if _, ok := s.D.GetOkExists("start_cluster_shape_configs"); ok { + return fmt.Errorf("[ERROR] start_cluster_shape_configs is not permitted during create bds instance") + } + + if _, ok := s.D.GetOkExists("is_force_remove_enabled"); ok { + return fmt.Errorf("[ERROR] is_force_remove_enabled is not permitted during create bds instance") + } + + if _, ok := s.D.GetOkExists("remove_node"); ok { + return fmt.Errorf("[ERROR] remove_node is not permitted during create bds instance") + } + + if bdsClusterVersionSummary, ok := s.D.GetOkExists("bds_cluster_version_summary"); ok { + if tmpList := bdsClusterVersionSummary.([]interface{}); len(tmpList) > 0 { + fieldKeyFormat := fmt.Sprintf("%s.%d.%%s", "bds_cluster_version_summary", 0) + tmp, err := s.mapToBdsClusterVersionSummary(fieldKeyFormat) + if err != nil { + return err + } + request.BdsClusterVersionSummary = &tmp + } + } + if bootstrapScriptUrl, ok := s.D.GetOkExists("bootstrap_script_url"); ok { tmp := bootstrapScriptUrl.(string) request.BootstrapScriptUrl = &tmp @@ -1502,9 +1596,11 @@ func (s *BdsBdsInstanceResourceCrud) Update() error { isKafkaBrokerAdded = isKafkaBrokerAdded1 } - err := s.ExecuteBootstrapScript() - if err != nil { - return err + if _, ok := s.D.GetOkExists("bootstrap_script_url"); ok { + err := s.ExecuteBootstrapScript() + if err != nil { + return err + } } if compartment, ok := s.D.GetOkExists("compartment_id"); ok && s.D.HasChange("compartment_id") { @@ -1851,6 +1947,17 @@ func (s *BdsBdsInstanceResourceCrud) Update() error { request.KmsKeyId = &tmp } + if networkConfig, ok := s.D.GetOkExists("network_config"); ok && s.D.HasChange("network_config") { + if tmpList := networkConfig.([]interface{}); len(tmpList) > 0 { + fieldKeyFormat := fmt.Sprintf("%s.%d.%%s", "network_config", 0) + tmp, err := s.mapToNetworkConfig(fieldKeyFormat) + if err != nil { + return err + } + request.NetworkConfig = &tmp + } + } + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds") response, err := s.Client.UpdateBdsInstance(context.Background(), request) @@ -2016,6 +2123,12 @@ func (s *BdsBdsInstanceResourceCrud) Delete() error { } func (s *BdsBdsInstanceResourceCrud) SetData() error { + if s.Res.BdsClusterVersionSummary != nil { + s.D.Set("bds_cluster_version_summary", []interface{}{BdsClusterVersionSummaryToMap(s.Res.BdsClusterVersionSummary)}) + } else { + s.D.Set("bds_cluster_version_summary", nil) + } + if s.Res.BootstrapScriptUrl != nil { s.D.Set("bootstrap_script_url", *s.Res.BootstrapScriptUrl) } @@ -2149,6 +2262,17 @@ func (s *BdsBdsInstanceResourceCrud) StartBdsInstance() error { request.ClusterAdminPassword = &tmp } + if startClusterShapeConfigs, ok := s.D.GetOkExists("start_cluster_shape_configs"); ok { + if tmpList := startClusterShapeConfigs.([]interface{}); len(tmpList) > 0 { + fieldKeyFormat := fmt.Sprintf("%s.%d.%%s", "start_cluster_shape_configs", 0) + tmp, err := s.mapToStartClusterShapeConfigs(fieldKeyFormat) + if err != nil { + return err + } + request.StartClusterShapeConfigs = &tmp + } + } + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds") _, err := s.Client.StartBdsInstance(context.Background(), request) @@ -2290,7 +2414,6 @@ func (s *BdsBdsInstanceResourceCrud) deleteShapeConfigIfMissingInInput(node_type } } } - func (s *BdsBdsInstanceResourceCrud) RemoveKafka() error { request := oci_bds.RemoveKafkaRequest{} @@ -2317,6 +2440,112 @@ func (s *BdsBdsInstanceResourceCrud) RemoveKafka() error { return s.getBdsInstanceFromWorkRequest(workId, tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds"), oci_bds.ActionTypesUpdated, s.D.Timeout(schema.TimeoutUpdate)) } +func (s *BdsBdsInstanceResourceCrud) RemoveNode() error { + request := oci_bds.RemoveNodeRequest{} + + idTmp := s.D.Id() + request.BdsInstanceId = &idTmp + + if clusterAdminPassword, ok := s.D.GetOkExists("cluster_admin_password"); ok { + tmp := clusterAdminPassword.(string) + request.ClusterAdminPassword = &tmp + } + + if isForceRemoveEnabled, ok := s.D.GetOkExists("is_force_remove_enabled"); ok { + tmp := isForceRemoveEnabled.(bool) + request.IsForceRemoveEnabled = &tmp + } + + if nodeId, ok := s.D.GetOkExists("remove_node"); ok { + tmp := nodeId.(string) + request.NodeId = &tmp + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds") + + response, err := s.Client.RemoveNode(context.Background(), request) + if err != nil { + return err + } + + if waitErr := tfresource.WaitForUpdatedState(s.D, s); waitErr != nil { + return waitErr + } + + if err != nil { + return err + } + workId := response.OpcWorkRequestId + return s.getBdsInstanceFromWorkRequest(workId, tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "bds"), oci_bds.ActionTypesUpdated, s.D.Timeout(schema.TimeoutUpdate)) +} + +func (s *BdsBdsInstanceResourceCrud) mapToBdsClusterVersionSummary(fieldKeyFormat string) (oci_bds.BdsClusterVersionSummary, error) { + result := oci_bds.BdsClusterVersionSummary{} + + if bdsVersion, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "bds_version")); ok { + tmp := bdsVersion.(string) + result.BdsVersion = &tmp + } + + if odhVersion, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "odh_version")); ok { + tmp := odhVersion.(string) + result.OdhVersion = &tmp + } + + return result, nil +} + +func (s *BdsBdsInstanceResourceCrud) mapToStartClusterShapeConfigs(fieldKeyFormat string) (oci_bds.StartClusterShapeConfigs, error) { + request := oci_bds.StartClusterShapeConfigs{} + + if nodeTypeShapeConfigs, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "node_type_shape_configs")); ok { + interfaces := nodeTypeShapeConfigs.([]interface{}) + tmp := make([]oci_bds.NodeTypeShapeConfig, len(interfaces)) + for i := range interfaces { + stateDataIndex := i + fieldKeyFormatNextLevel := fmt.Sprintf("%s.%s.%d.%%s", "start_cluster_shape_configs.0", "node_type_shape_configs", stateDataIndex) + converted, err := s.mapToNodeTypeShapeConfig(fieldKeyFormatNextLevel) + if err != nil { + return request, err + } + tmp[i] = converted + + if len(tmp) != 0 || s.D.HasChange(fmt.Sprintf(fieldKeyFormat, "node_type_shape_configs")) { + request.NodeTypeShapeConfigs = tmp + } + } + } + return request, nil +} +func (s *BdsBdsInstanceResourceCrud) mapToNodeTypeShapeConfig(fieldKeyFormat string) (oci_bds.NodeTypeShapeConfig, error) { + request := oci_bds.NodeTypeShapeConfig{} + + if shape, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "shape")); ok { + tmp := shape.(string) + request.Shape = &tmp + } + if nodeType, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "node_type")); ok { + tmp := oci_bds.NodeNodeTypeEnum(nodeType.(string)) + request.NodeType = tmp + } + + return request, nil +} + +func BdsClusterVersionSummaryToMap(obj *oci_bds.BdsClusterVersionSummary) map[string]interface{} { + result := map[string]interface{}{} + + if obj.BdsVersion != nil { + result["bds_version"] = string(*obj.BdsVersion) + } + + if obj.OdhVersion != nil { + result["odh_version"] = string(*obj.OdhVersion) + } + + return result +} + func CloudSqlDetailsToMap(obj *oci_bds.CloudSqlDetails) map[string]interface{} { result := map[string]interface{}{} diff --git a/internal/service/bds/register_datasource.go b/internal/service/bds/register_datasource.go index 0f44e6ef052..e08c0127c2f 100644 --- a/internal/service/bds/register_datasource.go +++ b/internal/service/bds/register_datasource.go @@ -7,6 +7,7 @@ import "github.com/oracle/terraform-provider-oci/internal/tfresource" func RegisterDatasource() { tfresource.RegisterDatasource("oci_bds_auto_scaling_configuration", BdsAutoScalingConfigurationDataSource()) + tfresource.RegisterDatasource("oci_bds_bds_cluster_versions", BdsBdsClusterVersionsDataSource()) tfresource.RegisterDatasource("oci_bds_auto_scaling_configurations", BdsAutoScalingConfigurationsDataSource()) tfresource.RegisterDatasource("oci_bds_bds_instance", BdsBdsInstanceDataSource()) tfresource.RegisterDatasource("oci_bds_bds_instance_api_key", BdsBdsInstanceApiKeyDataSource()) diff --git a/website/docs/d/bds_bds_cluster_versions.html.markdown b/website/docs/d/bds_bds_cluster_versions.html.markdown new file mode 100644 index 00000000000..e56a2bf1493 --- /dev/null +++ b/website/docs/d/bds_bds_cluster_versions.html.markdown @@ -0,0 +1,41 @@ +--- +subcategory: "Big Data Service" +layout: "oci" +page_title: "Oracle Cloud Infrastructure: oci_bds_bds_cluster_versions" +sidebar_current: "docs-oci-datasource-bds-bds_cluster_versions" +description: |- + Provides the list of Bds Cluster Versions in Oracle Cloud Infrastructure Big Data Service service +--- + +# Data Source: oci_bds_bds_cluster_versions +This data source provides the list of Bds Cluster Versions in Oracle Cloud Infrastructure Big Data Service service. + +Returns a list of cluster versions with associated odh and bds versions. + + +## Example Usage + +```hcl +data "oci_bds_bds_cluster_versions" "test_bds_cluster_versions" { +} +``` + +## Argument Reference + +The following arguments are supported: + + + +## Attributes Reference + +The following attributes are exported: + +* `bds_cluster_versions` - The list of bds_cluster_versions. + +### BdsClusterVersion Reference + +The following attributes are exported: + +* `bds_version` - BDS version to be used for cluster creation +* `odh_version` - ODH version to be used for cluster creation + diff --git a/website/docs/d/bds_bds_instance.html.markdown b/website/docs/d/bds_bds_instance.html.markdown index 294b9d553bd..213a2adca95 100644 --- a/website/docs/d/bds_bds_instance.html.markdown +++ b/website/docs/d/bds_bds_instance.html.markdown @@ -32,6 +32,9 @@ The following arguments are supported: The following attributes are exported: +* `bds_cluster_version_summary` - Cluster version details including bds and odh version information. + * `bds_version` - BDS version to be used for cluster creation + * `odh_version` - ODH version to be used for cluster creation * `bootstrap_script_url` - pre-authenticated URL of the bootstrap script in Object Store that can be downloaded and executed. * `cloud_sql_details` - The information about added Cloud SQL capability * `block_volume_size_in_gbs` - The size of block volume in GB that needs to be attached to a given node. All the necessary details needed for attachment are managed by service itself. diff --git a/website/docs/d/bds_bds_instance_api_key.html.markdown b/website/docs/d/bds_bds_instance_api_key.html.markdown index 953196f0828..1da50bf4d35 100644 --- a/website/docs/d/bds_bds_instance_api_key.html.markdown +++ b/website/docs/d/bds_bds_instance_api_key.html.markdown @@ -34,7 +34,12 @@ The following arguments are supported: The following attributes are exported: +<<<<<<< ours +* `default_region` - The name of the region to establish the Object Storage endpoint which was set as part of key creation operation. If no region was provided this will be set to be the same region where the cluster lives. Example us-phoenix-1 . +* `domain_ocid` - Identity domain OCID ,where user is present. For default domain ,this field will be optional. +======= * `default_region` - The name of the region to establish the Object Storage endpoint which was set as part of key creation operation. If no region was provided this will be set to be the same region where the cluster lives. Example us-phoenix-1 . +>>>>>>> theirs * `fingerprint` - The fingerprint that corresponds to the public API key requested. * `id` - Identifier of the user's API key. * `key_alias` - User friendly identifier used to uniquely differentiate between different API keys. Only ASCII alphanumeric characters with no spaces allowed. diff --git a/website/docs/d/bds_bds_instance_api_keys.html.markdown b/website/docs/d/bds_bds_instance_api_keys.html.markdown index 953196f0828..853f0972e58 100644 --- a/website/docs/d/bds_bds_instance_api_keys.html.markdown +++ b/website/docs/d/bds_bds_instance_api_keys.html.markdown @@ -34,7 +34,18 @@ The following arguments are supported: The following attributes are exported: +<<<<<<< ours +* `bds_api_keys` - The list of bds_api_keys. + +### BdsInstanceApiKey Reference + +The following attributes are exported: + +* `default_region` - The name of the region to establish the Object Storage endpoint which was set as part of key creation operation. If no region was provided this will be set to be the same region where the cluster lives. Example us-phoenix-1 . +* `domain_ocid` - Identity domain OCID ,where user is present. For default domain ,this field will be optional. +======= * `default_region` - The name of the region to establish the Object Storage endpoint which was set as part of key creation operation. If no region was provided this will be set to be the same region where the cluster lives. Example us-phoenix-1 . +>>>>>>> theirs * `fingerprint` - The fingerprint that corresponds to the public API key requested. * `id` - Identifier of the user's API key. * `key_alias` - User friendly identifier used to uniquely differentiate between different API keys. Only ASCII alphanumeric characters with no spaces allowed. diff --git a/website/docs/d/bds_bds_instances.html.markdown b/website/docs/d/bds_bds_instances.html.markdown index 498cc4f87f8..5fed88d914e 100644 --- a/website/docs/d/bds_bds_instances.html.markdown +++ b/website/docs/d/bds_bds_instances.html.markdown @@ -45,6 +45,9 @@ The following attributes are exported: The following attributes are exported: +* `bds_cluster_version_summary` - Cluster version details including bds and odh version information. + * `bds_version` - BDS version to be used for cluster creation + * `odh_version` - ODH version to be used for cluster creation * `bootstrap_script_url` - pre-authenticated URL of the bootstrap script in Object Store that can be downloaded and executed. * `cloud_sql_details` - The information about added Cloud SQL capability * `block_volume_size_in_gbs` - The size of block volume in GB that needs to be attached to a given node. All the necessary details needed for attachment are managed by service itself. diff --git a/website/docs/r/bds_bds_instance.html.markdown b/website/docs/r/bds_bds_instance.html.markdown index 6e2146f7ec0..a9ec0a7976d 100644 --- a/website/docs/r/bds_bds_instance.html.markdown +++ b/website/docs/r/bds_bds_instance.html.markdown @@ -117,6 +117,13 @@ resource "oci_bds_bds_instance" "test_bds_instance" { } #Optional + bds_cluster_version_summary { + #Required + bds_version = var.bds_instance_bds_cluster_version_summary_bds_version + + #Optional + odh_version = var.bds_instance_bds_cluster_version_summary_odh_version + } bootstrap_script_url = var.bds_instance_bootstrap_script_url cluster_profile = var.bds_instance_cluster_profile defined_tags = var.bds_instance_defined_tags @@ -137,6 +144,9 @@ resource "oci_bds_bds_instance" "test_bds_instance" { The following arguments are supported: +* `bds_cluster_version_summary` - (Optional) Cluster version details including bds and odh version information. + * `bds_version` - (Required) BDS version to be used for cluster creation + * `odh_version` - (Optional) ODH version to be used for cluster creation * `bootstrap_script_url` - (Optional) (Updatable) Pre-authenticated URL of the script in Object Store that is downloaded and executed. * `cluster_admin_password` - (Required) Base-64 encoded password for the cluster (and Cloudera Manager) admin user. * `cluster_profile` - (Optional) Profile of the Big Data Service cluster. @@ -154,10 +164,9 @@ The following arguments are supported: * `is_secure` - (Required) Boolean flag specifying whether or not the cluster should be setup as secure. * `kerberos_realm_name` - (Optional) The user-defined kerberos realm name. * `kms_key_id` - (Optional) (Updatable) The OCID of the Key Management master encryption key. -* `network_config` - (Optional) Additional configuration of the user's network. - * `cidr_block` - (Optional) The CIDR IP address block of the VCN. - * `is_nat_gateway_required` - (Optional) A boolean flag whether to configure a NAT gateway. -* `state` - (Optional) (Updatable) The target state for the Bds Instance. Could be set to `ACTIVE` or `INACTIVE`. +* `network_config` - (Optional) (Updatable) Additional configuration of the user's network. + * `cidr_block` - (Optional) (Updatable) The CIDR IP address block of the VCN. + * `is_nat_gateway_required` - (Optional) (Updatable) A boolean flag whether to configure a NAT gateway. * `nodes` - (Required) The list of nodes in the Big Data Service cluster. * `block_volume_size_in_gbs` - (Required) The size of block volume in GB to be attached to a given node. All the details needed for attaching the block volume are managed by service itself. * `node_type` - (Required) The Big Data Service cluster node type. @@ -167,7 +176,12 @@ The following arguments are supported: * `nvmes` - (Optional) The number of NVMe drives to be used for storage. A single drive has 6.8 TB available. * `ocpus` - (Optional) The total number of OCPUs available to the node. * `subnet_id` - (Required) The OCID of the subnet in which the node will be created. -* `state` - (Optional) (Updatable) The target state for the Bds Instance. Could be set to `ACTIVE` or `INACTIVE`. +* `state` - (Optional) (Updatable) The target state for the Bds Instance. Could be set to `ACTIVE` or `INACTIVE`. +* `execute_bootstrap_script_trigger` - (Optional) (Updatable) An optional property when incremented triggers Execute Bootstrap Script. Could be set to any integer value. +* `install_os_patch_trigger` - (Optional) (Updatable) An optional property when incremented triggers Install Os Patch. Could be set to any integer value. +* `remove_kafka_trigger` - (Optional) (Updatable) An optional property when incremented triggers Remove Kafka. Could be set to any integer value. +* `remove_node` - (Optional) (Updatable) An optional property when used triggers Remove Node. Takes the node ocid as input. +* `install_os_patch_trigger` - (Optional) (Updatable) An optional property when incremented triggers Install Os Patch. Could be set to any integer value. * `is_force_stop_jobs` - (Optional) (Updatable) When setting state as `INACTIVE` for stopping a cluster, setting this flag to true forcefully stops the bds instance. * `is_kafka_configured` - (Optional) Boolean flag specifying whether or not Kafka should be configured. * `os_patch_version` - (Optional) (Updatable) The version of the patch to be upated. @@ -229,6 +243,9 @@ Any change to a property that does not support update will force the destruction The following attributes are exported: +* `bds_cluster_version_summary` - Cluster version details including bds and odh version information. + * `bds_version` - BDS version to be used for cluster creation + * `odh_version` - ODH version to be used for cluster creation * `bootstrap_script_url` - pre-authenticated URL of the bootstrap script in Object Store that can be downloaded and executed. * `cloud_sql_details` - The information about added Cloud SQL capability * `block_volume_size_in_gbs` - The size of block volume in GB that needs to be attached to a given node. All the necessary details needed for attachment are managed by service itself. diff --git a/website/docs/r/bds_bds_instance_api_key.html.markdown b/website/docs/r/bds_bds_instance_api_key.html.markdown index 9d75b6d8546..e3ae285ce76 100644 --- a/website/docs/r/bds_bds_instance_api_key.html.markdown +++ b/website/docs/r/bds_bds_instance_api_key.html.markdown @@ -25,6 +25,7 @@ resource "oci_bds_bds_instance_api_key" "test_bds_instance_api_key" { #Optional default_region = var.bds_instance_api_key_default_region + domain_ocid = var.bds_instance_api_key_domain_ocid } ``` @@ -33,8 +34,14 @@ resource "oci_bds_bds_instance_api_key" "test_bds_instance_api_key" { The following arguments are supported: * `bds_instance_id` - (Required) The OCID of the cluster. +<<<<<<< ours +* `default_region` - (Optional) The name of the region to establish the Object Storage endpoint. See https://docs.oracle.com/en-us/iaas/api/#/en/identity/20160918/Region/ for additional information. +* `domain_ocid` - (Optional) Identity domain OCID , where user is present. For default domain , this field will be optional. +* `key_alias` - (Required) User friendly identifier used to uniquely differentiate between different API keys associated with this Big Data Service cluster. Only ASCII alphanumeric characters with no spaces allowed. +======= * `default_region` - (Optional) The name of the region to establish the Object Storage endpoint. See https://docs.oracle.com/en-us/iaas/api/#/en/identity/20160918/Region/ for additional information. * `key_alias` - (Required) User friendly identifier used to uniquely differentiate between different API keys associated with this Big Data Service cluster. Only ASCII alphanumeric characters with no spaces allowed. +>>>>>>> theirs * `passphrase` - (Required) Base64 passphrase used to secure the private key which will be created on user behalf. * `user_id` - (Required) The OCID of the user for whom this new generated API key pair will be created. @@ -46,7 +53,12 @@ Any change to a property that does not support update will force the destruction The following attributes are exported: +<<<<<<< ours +* `default_region` - The name of the region to establish the Object Storage endpoint which was set as part of key creation operation. If no region was provided this will be set to be the same region where the cluster lives. Example us-phoenix-1 . +* `domain_ocid` - Identity domain OCID ,where user is present. For default domain ,this field will be optional. +======= * `default_region` - The name of the region to establish the Object Storage endpoint which was set as part of key creation operation. If no region was provided this will be set to be the same region where the cluster lives. Example us-phoenix-1 . +>>>>>>> theirs * `fingerprint` - The fingerprint that corresponds to the public API key requested. * `id` - Identifier of the user's API key. * `key_alias` - User friendly identifier used to uniquely differentiate between different API keys. Only ASCII alphanumeric characters with no spaces allowed. diff --git a/website/docs/r/bds_bds_instance_patch_action.html.markdown b/website/docs/r/bds_bds_instance_patch_action.html.markdown index 30a04996516..4a130f63443 100644 --- a/website/docs/r/bds_bds_instance_patch_action.html.markdown +++ b/website/docs/r/bds_bds_instance_patch_action.html.markdown @@ -29,6 +29,8 @@ resource "oci_bds_bds_instance_patch_action" "test_bds_instance_patch_action" { #Optional batch_size = var.bds_instance_patch_action_patching_config_batch_size + tolerance_threshold_per_batch = var.bds_instance_patch_action_patching_config_tolerance_threshold_per_batch + tolerance_threshold_per_domain = var.bds_instance_patch_action_patching_config_tolerance_threshold_per_domain wait_time_between_batch_in_seconds = var.bds_instance_patch_action_patching_config_wait_time_between_batch_in_seconds wait_time_between_domain_in_seconds = var.bds_instance_patch_action_patching_config_wait_time_between_domain_in_seconds } @@ -44,6 +46,8 @@ The following arguments are supported: * `patching_config` - (Optional) Detailed configurations for defining the behavior when installing ODH patches. If not provided, nodes will be patched with down time. * `batch_size` - (Required when patching_config_strategy=BATCHING_BASED) How many nodes to be patched in each iteration. * `patching_config_strategy` - (Required) Type of strategy used for detailed patching configuration + * `tolerance_threshold_per_batch` - (Applicable when patching_config_strategy=BATCHING_BASED) Acceptable number of failed-to-be-patched nodes in each batch. The maximum number of failed-to-patch nodes cannot exceed 20% of the number of non-utility and non-master nodes. + * `tolerance_threshold_per_domain` - (Applicable when patching_config_strategy=DOMAIN_BASED) Acceptable number of failed-to-be-patched nodes in each domain. The maximum number of failed-to-patch nodes cannot exceed 20% of the number of non-utility and non-master nodes. * `wait_time_between_batch_in_seconds` - (Required when patching_config_strategy=BATCHING_BASED) The wait time between batches in seconds. * `wait_time_between_domain_in_seconds` - (Required when patching_config_strategy=DOMAIN_BASED) The wait time between AD/FD in seconds. * `version` - (Required) The version of the patch to be installed. From e9e87dcfee9cf2cc855cb6822a896b7617af7bb3 Mon Sep 17 00:00:00 2001 From: Esteban Cabrera Date: Thu, 12 Dec 2024 16:22:56 -0500 Subject: [PATCH 05/17] Fixed Integration test TestResourceDatabaseDBSystemAmdVM --- .../db_systems/db_vm/db_vm_amd/data.tf | 23 + .../db_systems/db_vm/db_vm_amd/main.tf | 402 ++---------------- .../db_systems/db_vm/db_vm_amd/network.tf | 53 +++ .../db_systems/db_vm/db_vm_amd/provider.tf | 27 ++ .../db_systems/db_vm/db_vm_amd/tags.tf | 37 ++ .../db_systems/db_vm/db_vm_amd/variables.tf | 51 +++ ...database_db_system_resource_amd_vm_test.go | 42 +- 7 files changed, 252 insertions(+), 383 deletions(-) create mode 100644 examples/database/db_systems/db_vm/db_vm_amd/data.tf create mode 100644 examples/database/db_systems/db_vm/db_vm_amd/network.tf create mode 100644 examples/database/db_systems/db_vm/db_vm_amd/provider.tf create mode 100644 examples/database/db_systems/db_vm/db_vm_amd/tags.tf create mode 100644 examples/database/db_systems/db_vm/db_vm_amd/variables.tf diff --git a/examples/database/db_systems/db_vm/db_vm_amd/data.tf b/examples/database/db_systems/db_vm/db_vm_amd/data.tf new file mode 100644 index 00000000000..cd6b38f1abe --- /dev/null +++ b/examples/database/db_systems/db_vm/db_vm_amd/data.tf @@ -0,0 +1,23 @@ +# $Header$ +# +# Copyright (c) 2024, Oracle and/or its affiliates. All rights reserved. +# +# NAME +# data.tf +# +# USAGE +# Use the following path for the Example & Backward Compatibility tests: database/db_systems/db_vm/db_vm_amd +# NOTES +# Terraform Integration Test: TestResourceDatabaseDBSystemAmdVM +# +# FILE(S) +# database_db_system_resource_amd_vm_test.go +# +# MODIFIED MM/DD/YY +# escabrer 12/12/2024 - Created + + + +data "oci_identity_availability_domains" "test_availability_domains" { + compartment_id = var.tenancy_ocid +} \ No newline at end of file diff --git a/examples/database/db_systems/db_vm/db_vm_amd/main.tf b/examples/database/db_systems/db_vm/db_vm_amd/main.tf index 12e994b2f09..cfa84659797 100644 --- a/examples/database/db_systems/db_vm/db_vm_amd/main.tf +++ b/examples/database/db_systems/db_vm/db_vm_amd/main.tf @@ -1,369 +1,53 @@ -// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. -// Licensed under the Mozilla Public License v2.0 -variable "tenancy_ocid" { -} - -variable "user_ocid" { -} - -variable "fingerprint" { -} - -variable "private_key_path" { -} - -variable "region" { -} - -#variable "kms_key_id" { -#} +# $Header$ # -#variable "kms_key_version_id" { -#} +# Copyright (c) 2024, Oracle and/or its affiliates. All rights reserved. # -#variable "vault_id" { -#} - -variable "compartment_ocid" { -} - -variable "ssh_public_key" { -} - -variable "ssh_private_key" { -} - -# DBSystem specific -variable "db_system_shape" { - default = "VM.Standard.E4.Flex" -} - -variable "cpu_core_count" { - default = "2" -} - -variable "db_system_storage_volume_performance_mode" { - default = "BALANCED" -} - -variable "db_edition" { - default = "ENTERPRISE_EDITION" -} - -variable "db_admin_password" { - default = "BEstrO0ng_#12" -} - -variable "db_version" { - default = "19.24.0.0" -} - -variable "db_disk_redundancy" { - default = "NORMAL" -} - -variable "sparse_diskgroup" { - default = true -} - -variable "hostname" { - default = "myoracledb" -} - -variable "host_user_name" { - default = "opc" -} - -variable "n_character_set" { - default = "AL16UTF16" -} - -variable "character_set" { - default = "AL32UTF8" -} - -variable "db_workload" { - default = "OLTP" -} - -variable "pdb_name" { - default = "pdbName" -} - -variable "data_storage_size_in_gb" { - default = "256" -} - -variable "license_model" { - default = "LICENSE_INCLUDED" -} - -variable "node_count" { - default = "1" -} - -variable "test_database_software_image_ocid" { - -} - -provider "oci" { -# version = "4.70.0" - tenancy_ocid = var.tenancy_ocid - user_ocid = var.user_ocid - fingerprint = var.fingerprint - private_key_path = var.private_key_path - region = var.region -} - -data "oci_identity_availability_domain" "ad" { - compartment_id = var.tenancy_ocid - ad_number = 1 -} - -# Get DB node list -data "oci_database_db_nodes" "db_nodes" { - compartment_id = var.compartment_ocid - db_system_id = oci_database_db_system.test_db_system.id -} - -# Get DB node details -data "oci_database_db_node" "db_node_details" { - db_node_id = data.oci_database_db_nodes.db_nodes.db_nodes[0]["id"] -} - -# Gets the OCID of the first (default) vNIC -#data "oci_core_vnic" "db_node_vnic" { -# vnic_id = data.oci_database_db_node.db_node_details.vnic_id -#} - -data "oci_database_db_homes" "db_homes" { - compartment_id = var.compartment_ocid - db_system_id = oci_database_db_system.test_db_system.id -} - -data "oci_database_databases" "databases" { - compartment_id = var.compartment_ocid - db_home_id = data.oci_database_db_homes.db_homes.db_homes[0].db_home_id -} - -data "oci_database_db_versions" "test_db_versions_by_db_system_id" { - compartment_id = var.compartment_ocid - db_system_id = oci_database_db_system.test_db_system.id -} - -resource "oci_database_backup" "test_backup" { - database_id = data.oci_database_databases.databases.databases.0.id - display_name = "Monthly Backup" -} - -data "oci_database_db_system_shapes" "test_db_system_shapes" { - availability_domain = data.oci_identity_availability_domain.ad.name - compartment_id = var.compartment_ocid - - filter { - name = "shape" - values = [var.db_system_shape] - } -} - -data "oci_database_db_systems" "db_systems" { - compartment_id = var.compartment_ocid - - filter { - name = "id" - values = [oci_database_db_system.test_db_system.id] - } -} - -resource "oci_core_vcn" "vcn" { - cidr_block = "10.1.0.0/16" - compartment_id = var.compartment_ocid - display_name = "TFExampleVCNDBSystem" - dns_label = "tfexvcndbsys" -} - -resource "oci_core_subnet" "subnet" { - availability_domain = data.oci_identity_availability_domain.ad.name - cidr_block = "10.1.20.0/24" - display_name = "TFExampleSubnetDBSystem" - dns_label = "tfexsubdbsys" - security_list_ids = [oci_core_security_list.ExampleSecurityList.id] - compartment_id = var.compartment_ocid - vcn_id = oci_core_vcn.vcn.id - route_table_id = oci_core_route_table.route_table.id - dhcp_options_id = oci_core_vcn.vcn.default_dhcp_options_id -} - -resource "oci_core_subnet" "subnet_backup" { - availability_domain = data.oci_identity_availability_domain.ad.name - cidr_block = "10.1.1.0/24" - display_name = "TFExampleSubnetDBSystemBackup" - dns_label = "tfexsubdbsysbp" - security_list_ids = [oci_core_security_list.ExampleSecurityList.id] - compartment_id = var.compartment_ocid - vcn_id = oci_core_vcn.vcn.id - route_table_id = oci_core_route_table.route_table_backup.id - dhcp_options_id = oci_core_vcn.vcn.default_dhcp_options_id -} - -resource "oci_core_internet_gateway" "internet_gateway" { - compartment_id = var.compartment_ocid - display_name = "TFExampleIGDBSystem" - vcn_id = oci_core_vcn.vcn.id -} - -resource "oci_core_route_table" "route_table" { - compartment_id = var.compartment_ocid - vcn_id = oci_core_vcn.vcn.id - display_name = "TFExampleRouteTableDBSystem" - - route_rules { - destination = "0.0.0.0/0" - destination_type = "CIDR_BLOCK" - network_entity_id = oci_core_internet_gateway.internet_gateway.id - } -} - -resource "oci_core_route_table" "route_table_backup" { - compartment_id = var.compartment_ocid - vcn_id = oci_core_vcn.vcn.id - display_name = "TFExampleRouteTableDBSystemBackup" - - route_rules { - destination = "0.0.0.0/0" - destination_type = "CIDR_BLOCK" - network_entity_id = oci_core_internet_gateway.internet_gateway.id - } -} - -resource "oci_core_security_list" "ExampleSecurityList" { - compartment_id = var.compartment_ocid - vcn_id = oci_core_vcn.vcn.id - display_name = "TFExampleSecurityList" - - // allow outbound tcp traffic on all ports - egress_security_rules { - destination = "0.0.0.0/0" - protocol = "6" - } - - // allow outbound udp traffic on a port range - egress_security_rules { - destination = "0.0.0.0/0" - protocol = "17" // udp - stateless = true - } - - egress_security_rules { - destination = "0.0.0.0/0" - protocol = "1" - stateless = true - } - - // allow inbound ssh traffic from a specific port - ingress_security_rules { - protocol = "6" // tcp - source = "0.0.0.0/0" - stateless = false - } - - // allow inbound icmp traffic of a specific type - ingress_security_rules { - protocol = 1 - source = "0.0.0.0/0" - stateless = true - } -} +# NAME +# main.tf +# +# USAGE +# Use the following path for the Example & Backward Compatibility tests: database/db_systems/db_vm/db_vm_amd +# NOTES +# Terraform Integration Test: TestResourceDatabaseDBSystemAmdVM +# +# FILE(S) +# database_db_system_resource_amd_vm_test.go +# +# MODIFIED MM/DD/YY +# escabrer 12/12/2024 - Created -resource "oci_core_network_security_group" "test_network_security_group" { - compartment_id = var.compartment_ocid - vcn_id = oci_core_vcn.vcn.id - display_name = "displayName" -} -resource "oci_core_network_security_group" "test_network_security_group_backup" { +resource "oci_database_db_system" "test_amd_db_system" { + availability_domain = data.oci_identity_availability_domains.test_availability_domains.availability_domains.0.name compartment_id = var.compartment_ocid - vcn_id = oci_core_vcn.vcn.id - display_name = "displayName" -} - -resource "oci_database_db_system" "test_db_system" { - availability_domain = data.oci_identity_availability_domain.ad.name - compartment_id = var.compartment_ocid - database_edition = var.db_edition - + cpu_core_count = "2" + data_storage_size_in_gb = "256" + database_edition = "ENTERPRISE_EDITION" db_home { database { - admin_password = var.db_admin_password -# kms_key_version_id = var.kms_key_version_id -# kms_key_id = var.kms_key_id -# vault_id = var.vault_id - db_name = "aTFdbVm" - db_unique_name = "aTFdbVm_xyz" - character_set = var.character_set - ncharacter_set = var.n_character_set - db_workload = var.db_workload - pdb_name = var.pdb_name - + admin_password = var.admin_password + character_set = "AL32UTF8" db_backup_config { - auto_backup_enabled = false + auto_backup_enabled = "false" } + db_name = "tfDb" + db_workload = "OLTP" + kms_key_id = var.kms_key_id + ncharacter_set = "AL16UTF16" + pdb_name = "tfPdb" + vault_id = var.vault_id } - - db_version = "19.24.0.0" - display_name = "MyTFDBHomeVm" - } - - db_system_options { - storage_management = "LVM" - } - - disk_redundancy = var.db_disk_redundancy - shape = var.db_system_shape - cpu_core_count = var.cpu_core_count - storage_volume_performance_mode = var.db_system_storage_volume_performance_mode - subnet_id = oci_core_subnet.subnet.id - ssh_public_keys = [var.ssh_public_key] - display_name = "MyTFDBSystemVM" - hostname = var.hostname - data_storage_size_in_gb = var.data_storage_size_in_gb - license_model = var.license_model - node_count = data.oci_database_db_system_shapes.test_db_system_shapes.db_system_shapes[0]["minimum_node_count"] - nsg_ids = [oci_core_network_security_group.test_network_security_group_backup.id, oci_core_network_security_group.test_network_security_group.id] - - #To use defined_tags, set the values below to an existing tag namespace, refer to the identity example on how to create tag namespaces - #defined_tags = {"${oci_identity_tag_namespace.tag-namespace1.name}.${oci_identity_tag.tag1.name}" = "value"} - - freeform_tags = { - "Department" = "Finance" - } -} - -resource "oci_database_db_system" "db_system_bkup" { - source = "DB_BACKUP" - availability_domain = data.oci_identity_availability_domain.ad.name - compartment_id = var.compartment_ocid - subnet_id = oci_core_subnet.subnet.id - database_edition = var.db_edition - disk_redundancy = var.db_disk_redundancy - shape = var.db_system_shape - cpu_core_count= var.cpu_core_count - storage_volume_performance_mode= var.db_system_storage_volume_performance_mode - ssh_public_keys = [var.ssh_public_key] - hostname = var.hostname - data_storage_size_in_gb = var.data_storage_size_in_gb - license_model = var.license_model - node_count = data.oci_database_db_system_shapes.test_db_system_shapes.db_system_shapes[0]["minimum_node_count"] - display_name = "tfDbSystemFromBackupWithCustImg" - - db_home { - db_version = "19.24.0.0" -# database_software_image_id = var.test_database_software_image_ocid - database { - admin_password = "BEstrO0ng_#11" - backup_tde_password = "BEstrO0ng_#11" - backup_id = oci_database_backup.test_backup.id - db_name = "dbback" - } - } -} + db_version = "19.0.0.0" + display_name = "tfDbHome" + } + disk_redundancy = "NORMAL" + display_name = "tfExampleDbSystemAmd" + domain = oci_core_subnet.test_subnet.subnet_domain_name + hostname = "oracle-db" + kms_key_id = var.kms_key_id + license_model = "LICENSE_INCLUDED" + node_count = "1" + shape = "VM.Standard.E4.Flex" + ssh_public_keys = [var.ssh_public_key] + subnet_id = oci_core_subnet.test_subnet.id +} \ No newline at end of file diff --git a/examples/database/db_systems/db_vm/db_vm_amd/network.tf b/examples/database/db_systems/db_vm/db_vm_amd/network.tf new file mode 100644 index 00000000000..872f4d1b162 --- /dev/null +++ b/examples/database/db_systems/db_vm/db_vm_amd/network.tf @@ -0,0 +1,53 @@ +# $Header$ +# +# Copyright (c) 2024, Oracle and/or its affiliates. All rights reserved. +# NAME +# network.tf +# +# USAGE +# Use the following path for the Example & Backward Compatibility tests: database/db_systems/db_vm/db_vm_amd +# NOTES +# Terraform Integration Test: TestResourceDatabaseDBSystemAmdVM +# +# FILE(S) +# database_db_system_resource_amd_vm_test.go +# +# +# MODIFIED MM/DD/YY +# escabrer 12/12/2024 - Created + + +resource "oci_core_vcn" "test_vcn" { + cidr_block = "10.1.0.0/16" + compartment_id = var.compartment_ocid + display_name = "tfVcn" + dns_label = "tfvcn" +} + +resource "oci_core_route_table" "test_route_table" { + compartment_id = var.compartment_ocid + display_name = "tfRouteTable" + route_rules { + cidr_block = "0.0.0.0/0" + description = "Internal traffic for OCI Services" + network_entity_id = oci_core_internet_gateway.test_internet_gateway.id + } + vcn_id = oci_core_vcn.test_vcn.id +} + +resource "oci_core_internet_gateway" "test_internet_gateway" { + compartment_id = var.compartment_ocid + display_name = "tfInternetGateway" + vcn_id = oci_core_vcn.test_vcn.id +} + +resource "oci_core_subnet" "test_subnet" { + cidr_block = "10.1.20.0/24" + compartment_id = var.compartment_ocid + dhcp_options_id = oci_core_vcn.test_vcn.default_dhcp_options_id + display_name = "tfSubnet" + dns_label = "tfsubnet" + route_table_id = oci_core_route_table.test_route_table.id + security_list_ids = [oci_core_vcn.test_vcn.default_security_list_id] + vcn_id = oci_core_vcn.test_vcn.id +} \ No newline at end of file diff --git a/examples/database/db_systems/db_vm/db_vm_amd/provider.tf b/examples/database/db_systems/db_vm/db_vm_amd/provider.tf new file mode 100644 index 00000000000..11ad3d3df23 --- /dev/null +++ b/examples/database/db_systems/db_vm/db_vm_amd/provider.tf @@ -0,0 +1,27 @@ +# $Header$ +# +# Copyright (c) 2024, Oracle and/or its affiliates. All rights reserved. +# +# NAME +# provider.tf +# +# USAGE +# Use the following path for the Example & Backward Compatibility tests: database/db_systems/db_vm/db_vm_amd +# NOTES +# Terraform Integration Test: TestResourceDatabaseDBSystemAmdVM +# +# FILE(S) +# database_db_system_resource_amd_vm_test.go +# +# MODIFIED MM/DD/YY +# escabrer 12/12/2024 - Created + + + + +provider "oci" { + auth = "SecurityToken" + config_file_profile = "terraform-federation-test" + region = var.region + tenancy_ocid = var.compartment_ocid +} \ No newline at end of file diff --git a/examples/database/db_systems/db_vm/db_vm_amd/tags.tf b/examples/database/db_systems/db_vm/db_vm_amd/tags.tf new file mode 100644 index 00000000000..766e601a940 --- /dev/null +++ b/examples/database/db_systems/db_vm/db_vm_amd/tags.tf @@ -0,0 +1,37 @@ +# $Header$ +# +# Copyright (c) 2024, Oracle and/or its affiliates. All rights reserved. +# +# NAME +# tags.tf +# +# USAGE +# Use the following path for the Example & Backward Compatibility tests: database/db_systems/db_vm/db_vm_amd +# NOTES +# Terraform Integration Test: TestResourceDatabaseDBSystemAmdVM +# +# FILE(S) +# database_db_system_resource_amd_vm_test.go +# +# MODIFIED MM/DD/YY +# escabrer 12/12/2024 - Created + + + +resource "oci_identity_tag_namespace" "tag-namespace1" { + #Required + compartment_id = var.tenancy_ocid + description = "example tag namespace" + name = var.defined_tag_namespace_name != "" ? var.defined_tag_namespace_name : "example-tag-namespace-all" + + is_retired = false +} + +resource "oci_identity_tag" "tag1" { + #Required + description = "example tag" + name = "example-tag" + tag_namespace_id = oci_identity_tag_namespace.tag-namespace1.id + + is_retired = false +} \ No newline at end of file diff --git a/examples/database/db_systems/db_vm/db_vm_amd/variables.tf b/examples/database/db_systems/db_vm/db_vm_amd/variables.tf new file mode 100644 index 00000000000..9b5c761fc51 --- /dev/null +++ b/examples/database/db_systems/db_vm/db_vm_amd/variables.tf @@ -0,0 +1,51 @@ +# $Header$ +# +# Copyright (c) 2024, Oracle and/or its affiliates. All rights reserved. +# +# NAME +# variables.tf +# +# USAGE +# Use the following path for the Example & Backward Compatibility tests: database/db_systems/db_vm/db_vm_amd +# NOTES +# Terraform Integration Test: TestResourceDatabaseDBSystemAmdVM +# +# FILE(S) +# database_db_system_resource_amd_vm_test.go +# +# MODIFIED MM/DD/YY +# escabrer 12/12/2024 - Created + + + +variable "tenancy_ocid" { + type = string +} + +variable "ssh_public_key" { + type = string +} + +variable "region" { + type = string +} + +variable "compartment_ocid" { + type = string +} + +variable "defined_tag_namespace_name" { + default = "" +} + +variable "kms_key_id" { + type = string +} + +variable "vault_id" { + type = string +} + +variable "admin_password" { + type = string +} \ No newline at end of file diff --git a/internal/integrationtest/database_db_system_resource_amd_vm_test.go b/internal/integrationtest/database_db_system_resource_amd_vm_test.go index 8a21802c551..de00c81c58e 100644 --- a/internal/integrationtest/database_db_system_resource_amd_vm_test.go +++ b/internal/integrationtest/database_db_system_resource_amd_vm_test.go @@ -16,46 +16,45 @@ import ( ) var ( - amdDbSystemRepresentation = map[string]interface{}{ - "availability_domain": acctest.Representation{RepType: acctest.Required, Create: `${oci_core_subnet.t.availability_domain}`}, + DbSystemAmdRepresentation = map[string]interface{}{ + "availability_domain": acctest.Representation{RepType: acctest.Required, Create: `${data.oci_identity_availability_domains.test_availability_domains.availability_domains.0.name}`}, "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id}`}, - "subnet_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_core_subnet.t.id}`}, + "subnet_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_core_subnet.test_subnet.id}`}, "database_edition": acctest.Representation{RepType: acctest.Required, Create: `ENTERPRISE_EDITION`}, "disk_redundancy": acctest.Representation{RepType: acctest.Required, Create: `NORMAL`}, "shape": acctest.Representation{RepType: acctest.Required, Create: `VM.Standard.E4.Flex`}, "cpu_core_count": acctest.Representation{RepType: acctest.Required, Create: `2`}, "ssh_public_keys": acctest.Representation{RepType: acctest.Required, Create: []string{`ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCBDM0G21Tc6IOp6H5fwUVhVcxDxbwRwb9I53lXDdfqytw/pRAfXxDAzlw1jMEWofoVxTVDyqxcEg5yg4ImKFYHIDrZuU9eHv5SoHYJvI9r+Dqm9z52MmEyoTuC4dUyOs79V0oER5vLcjoMQIqmGSKMSlIMoFV2d+AV//RhJSpRPWGQ6lAVPYAiaVk3EzYacayetk1ZCEnMGPV0OV1UWqovm3aAGDozs7+9Isq44HEMyJwdBTYmBu3F8OA8gss2xkwaBgK3EQjCJIRBgczDwioT7RF5WG3IkwKsDTl2bV0p5f5SeX0U8SGHnni9uNoc9wPAWaleZr3Jcp1yIcRFR9YV`}}, - "domain": acctest.Representation{RepType: acctest.Required, Create: `${oci_core_subnet.t.subnet_domain_name}`}, + "domain": acctest.Representation{RepType: acctest.Required, Create: `${oci_core_subnet.test_subnet.subnet_domain_name}`}, "hostname": acctest.Representation{RepType: acctest.Required, Create: `myOracleDB`}, "data_storage_size_in_gb": acctest.Representation{RepType: acctest.Required, Create: `256`}, "license_model": acctest.Representation{RepType: acctest.Required, Create: `LICENSE_INCLUDED`}, "node_count": acctest.Representation{RepType: acctest.Required, Create: `1`}, - "display_name": acctest.Representation{RepType: acctest.Required, Create: `tfDbSystemTest`}, - "db_home": acctest.RepresentationGroup{RepType: acctest.Required, Group: amdDbHomeRepresentation}, + "display_name": acctest.Representation{RepType: acctest.Required, Create: `tfDbSystemAmd`}, + "db_home": acctest.RepresentationGroup{RepType: acctest.Required, Group: DbSystemAmdDbHomeGroup}, "kms_key_id": acctest.Representation{RepType: acctest.Required, Create: `${var.kms_key_id}`}, "kms_key_version_id": acctest.Representation{RepType: acctest.Required, Update: `${var.kms_key_version_id}`}, } - amdDbHomeRepresentation = map[string]interface{}{ - "db_version": acctest.Representation{RepType: acctest.Required, Create: `19.24.0.0`}, - "display_name": acctest.Representation{RepType: acctest.Required, Create: `dbHome1`}, - "database": acctest.RepresentationGroup{RepType: acctest.Required, Group: amdDatabaseRepresentation}, + DbSystemAmdDbHomeGroup = map[string]interface{}{ + "db_version": acctest.Representation{RepType: acctest.Required, Create: `19.0.0.0`}, + "display_name": acctest.Representation{RepType: acctest.Required, Create: `tfDbHome`}, + "database": acctest.RepresentationGroup{RepType: acctest.Required, Group: DbSystemAmdDatabaseGroup}, } - amdDatabaseRepresentation = map[string]interface{}{ + DbSystemAmdDatabaseGroup = map[string]interface{}{ "admin_password": acctest.Representation{RepType: acctest.Required, Create: `BEstrO0ng_#11`, Update: nil}, - "db_name": acctest.Representation{RepType: acctest.Required, Create: `aTFdb`}, + "db_name": acctest.Representation{RepType: acctest.Required, Create: `tfDb`}, "character_set": acctest.Representation{RepType: acctest.Required, Create: `AL32UTF8`}, "ncharacter_set": acctest.Representation{RepType: acctest.Required, Create: `AL16UTF16`}, "db_workload": acctest.Representation{RepType: acctest.Required, Create: `OLTP`}, - "pdb_name": acctest.Representation{RepType: acctest.Required, Create: `pdbName`}, - "db_backup_config": acctest.RepresentationGroup{RepType: acctest.Required, Group: amdDbBackupConfigRepresentation}, - "db_unique_name": acctest.Representation{RepType: acctest.Required, Create: `aTFdb_xyz`}, + "pdb_name": acctest.Representation{RepType: acctest.Required, Create: `tfPdb`}, + "db_backup_config": acctest.RepresentationGroup{RepType: acctest.Required, Group: DbSystemAmdDbBackupConfigGroup}, "kms_key_id": acctest.Representation{RepType: acctest.Required, Create: `${var.kms_key_id}`}, "vault_id": acctest.Representation{RepType: acctest.Required, Create: `${var.vault_id}`}, } - amdDbBackupConfigRepresentation = map[string]interface{}{ + DbSystemAmdDbBackupConfigGroup = map[string]interface{}{ "auto_backup_enabled": acctest.Representation{RepType: acctest.Required, Create: `false`}, } ) @@ -73,18 +72,14 @@ func TestResourceDatabaseDBSystemAmdVM(t *testing.T) { vaultId := utils.GetEnvSettingWithBlankDefault("vault_id") vaultIdVariableStr := fmt.Sprintf("variable \"vault_id\" { default = \"%s\" }\n", vaultId) - resourceName := "oci_database_db_system.t" - - // Save TF content to create resource with optional properties. This has to be exactly the same as the config part in the "create with optionals" step in the test. - acctest.SaveConfigContent(ResourceDatabaseBaseConfig+kmsKeyIdVariableStr+kmsKeyVersionIdVariableStr+vaultIdVariableStr+ - acctest.GenerateResourceFromRepresentationMap("oci_database_db_system", "t", acctest.Optional, acctest.Create, amdDbSystemRepresentation), "database", "dbSystem", t) + resourceName := "oci_database_db_system.test_amd_db_system" acctest.ResourceTest(t, nil, []resource.TestStep{ // verify create { Config: ResourceDatabaseBaseConfig + kmsKeyIdVariableStr + vaultIdVariableStr + kmsKeyVersionIdVariableStr + - acctest.GenerateResourceFromRepresentationMap("oci_database_db_system", "t", acctest.Required, acctest.Create, amdDbSystemRepresentation), + acctest.GenerateResourceFromRepresentationMap("oci_database_db_system", "test_amd_db_system", acctest.Optional, acctest.Create, DbSystemAmdRepresentation), Check: acctest.ComposeAggregateTestCheckFuncWrapper( // DB System Resource tests resource.TestCheckResourceAttrSet(resourceName, "id"), @@ -101,14 +96,13 @@ func TestResourceDatabaseDBSystemAmdVM(t *testing.T) { resource.TestCheckResourceAttr(resourceName, "node_count", "1"), resource.TestCheckResourceAttrSet(resourceName, "db_home.0.db_version"), resource.TestCheckResourceAttrSet(resourceName, "db_home.0.display_name"), - resource.TestCheckResourceAttr(ResourceDatabaseResourceName, "db_home.0.database.0.db_unique_name", "aTFdb_xyz"), resource.TestCheckResourceAttrSet(resourceName, "kms_key_id"), ), }, // verify update { Config: ResourceDatabaseBaseConfig + kmsKeyIdVariableStr + vaultIdVariableStr + kmsKeyVersionIdVariableStr + - acctest.GenerateResourceFromRepresentationMap("oci_database_db_system", "t", acctest.Required, acctest.Update, amdDbSystemRepresentation), + acctest.GenerateResourceFromRepresentationMap("oci_database_db_system", "test_amd_db_system", acctest.Optional, acctest.Update, DbSystemAmdRepresentation), Check: acctest.ComposeAggregateTestCheckFuncWrapper( // DB System Resource tests resource.TestCheckResourceAttr(resourceName, "kms_key_version_id", kmsKeyVersionId), From f9bee7e5e5da5a34f352277a0a1222562c4146e1 Mon Sep 17 00:00:00 2001 From: Kun Zheng Date: Fri, 8 Nov 2024 12:01:54 -0800 Subject: [PATCH 06/17] Added - Support Llama 3.2 unit shape in Generative AI service --- .../r/generative_ai_dedicated_ai_cluster.html.markdown | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/website/docs/r/generative_ai_dedicated_ai_cluster.html.markdown b/website/docs/r/generative_ai_dedicated_ai_cluster.html.markdown index 4b79f0cc111..7222f86cdf2 100644 --- a/website/docs/r/generative_ai_dedicated_ai_cluster.html.markdown +++ b/website/docs/r/generative_ai_dedicated_ai_cluster.html.markdown @@ -52,11 +52,14 @@ The following arguments are supported: * LARGE_COHERE_V2 * SMALL_COHERE * SMALL_COHERE_V2 + * SMALL_COHERE_4 * EMBED_COHERE * LLAMA2_70 * LARGE_GENERIC * LARGE_COHERE_V2_2 - * LARGE_GENERIC_4 + * LARGE_GENERIC_4 + * SMALL_GENERIC_V2 + * LARGE_GENERIC_2 ** IMPORTANT ** @@ -79,7 +82,7 @@ The following attributes are exported: * `lifecycle_details` - A message describing the current state with detail that can provide actionable information. * `previous_state` - Dedicated AI clusters are compute resources that you can use for fine-tuning custom models or for hosting endpoints for custom models. The clusters are dedicated to your models and not shared with users in other tenancies. - To use any of the API operations, you must be authorized in an IAM policy. If you're not authorized, talk to an administrator who gives Oracle Cloud Infrastructure resource access to users. See [Getting Started with Policies](https://docs.cloud.oracle.com/iaas/Content/Identity/policiesgs/get-started-with-policies.htm) and [Getting Access to Generative AI Resouces](https://docs.cloud.oracle.com/iaas/Content/generative-ai/iam-policies.htm). +To use any of the API operations, you must be authorized in an IAM policy. If you're not authorized, talk to an administrator who gives Oracle Cloud Infrastructure resource access to users. See [Getting Started with Policies](https://docs.cloud.oracle.com/iaas/Content/Identity/policiesgs/get-started-with-policies.htm) and [Getting Access to Generative AI Resouces](https://docs.cloud.oracle.com/iaas/Content/generative-ai/iam-policies.htm). * `state` - The current state of the dedicated AI cluster. * `system_tags` - System tags for this resource. Each key is predefined and scoped to a namespace. Example: `{"orcl-cloud.free-tier-retained": "true"}` * `time_created` - The date and time the dedicated AI cluster was created, in the format defined by RFC 3339 From 7ebc8ca01aabf87af9c4e7b20c46ecb328e8c999 Mon Sep 17 00:00:00 2001 From: Prabhu Thukkaram Date: Tue, 12 Nov 2024 09:24:29 +0000 Subject: [PATCH 07/17] Added - Support for Add ZeroETL as a resource in GoldenGate Cloud Service --- examples/goldengate/Pipeline/main.tf | 39 + ...lden_gate_pipeline_running_process_test.go | 56 + .../golden_gate_pipeline_schema_table_test.go | 66 + .../golden_gate_pipeline_schema_test.go | 56 + .../golden_gate_pipeline_test.go | 443 +++++++ .../golden_gate_recipe_test.go | 57 + .../service/golden_gate/golden_gate_export.go | 14 + .../golden_gate_pipeline_data_source.go | 161 +++ .../golden_gate_pipeline_resource.go | 1068 +++++++++++++++++ ..._pipeline_running_processes_data_source.go | 172 +++ ...gate_pipeline_schema_tables_data_source.go | 187 +++ ...olden_gate_pipeline_schemas_data_source.go | 161 +++ .../golden_gate_pipelines_data_source.go | 143 +++ .../golden_gate_recipes_data_source.go | 201 ++++ .../golden_gate/register_datasource.go | 6 + .../service/golden_gate/register_resource.go | 1 + .../docs/d/golden_gate_pipeline.html.markdown | 75 ++ ...e_pipeline_running_processes.html.markdown | 48 + ..._gate_pipeline_schema_tables.html.markdown | 55 + ...golden_gate_pipeline_schemas.html.markdown | 49 + .../d/golden_gate_pipelines.html.markdown | 89 ++ .../docs/d/golden_gate_recipes.html.markdown | 55 + .../d/golden_gate_trail_files.html.markdown | 3 +- .../golden_gate_trail_sequences.html.markdown | 3 +- .../guides/resource_discovery.html.markdown | 1 + .../r/golden_gate_connection.html.markdown | 2 +- .../docs/r/golden_gate_pipeline.html.markdown | 162 +++ 27 files changed, 3370 insertions(+), 3 deletions(-) create mode 100644 examples/goldengate/Pipeline/main.tf create mode 100644 internal/integrationtest/golden_gate_pipeline_running_process_test.go create mode 100644 internal/integrationtest/golden_gate_pipeline_schema_table_test.go create mode 100644 internal/integrationtest/golden_gate_pipeline_schema_test.go create mode 100644 internal/integrationtest/golden_gate_pipeline_test.go create mode 100644 internal/integrationtest/golden_gate_recipe_test.go create mode 100644 internal/service/golden_gate/golden_gate_pipeline_data_source.go create mode 100644 internal/service/golden_gate/golden_gate_pipeline_resource.go create mode 100644 internal/service/golden_gate/golden_gate_pipeline_running_processes_data_source.go create mode 100644 internal/service/golden_gate/golden_gate_pipeline_schema_tables_data_source.go create mode 100644 internal/service/golden_gate/golden_gate_pipeline_schemas_data_source.go create mode 100644 internal/service/golden_gate/golden_gate_pipelines_data_source.go create mode 100644 internal/service/golden_gate/golden_gate_recipes_data_source.go create mode 100644 website/docs/d/golden_gate_pipeline.html.markdown create mode 100644 website/docs/d/golden_gate_pipeline_running_processes.html.markdown create mode 100644 website/docs/d/golden_gate_pipeline_schema_tables.html.markdown create mode 100644 website/docs/d/golden_gate_pipeline_schemas.html.markdown create mode 100644 website/docs/d/golden_gate_pipelines.html.markdown create mode 100644 website/docs/d/golden_gate_recipes.html.markdown create mode 100644 website/docs/r/golden_gate_pipeline.html.markdown diff --git a/examples/goldengate/Pipeline/main.tf b/examples/goldengate/Pipeline/main.tf new file mode 100644 index 00000000000..3b6b6cbf4af --- /dev/null +++ b/examples/goldengate/Pipeline/main.tf @@ -0,0 +1,39 @@ +variable "tenancy_ocid" {} +variable "user_ocid" {} +variable "fingerprint" {} +variable "private_key_path" {} +variable "compartment_id" {} +variable "region" {} + +variable "source_connection_id" { } +variable "target_connection_id" { } +variable "display_name" { + default = "Pipeline display Name" +} +variable "license_model" { + default = "LICENSE_INCLUDED" +} +variable "recipe_type" { + default = "ZERO_ETL" +} + +provider "oci" { + tenancy_ocid = var.tenancy_ocid + user_ocid = var.user_ocid + fingerprint = var.fingerprint + private_key_path = var.private_key_path + region = var.region +} + +resource "oci_golden_gate_pipeline" "test_pipeline" { + compartment_id = var.compartment_id + display_name = var.display_name + license_model = var.license_model + recipe_type = var.recipe_type + source_connection_details { + connection_id = var.source_connection_id + } + target_connection_details { + connection_id = var.target_connection_id + } +} \ No newline at end of file diff --git a/internal/integrationtest/golden_gate_pipeline_running_process_test.go b/internal/integrationtest/golden_gate_pipeline_running_process_test.go new file mode 100644 index 00000000000..71ee66d7dbb --- /dev/null +++ b/internal/integrationtest/golden_gate_pipeline_running_process_test.go @@ -0,0 +1,56 @@ +// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. +// Licensed under the Mozilla Public License v2.0 + +package integrationtest + +import ( + "fmt" + "testing" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" + + "github.com/oracle/terraform-provider-oci/httpreplay" + "github.com/oracle/terraform-provider-oci/internal/acctest" + + "github.com/oracle/terraform-provider-oci/internal/utils" +) + +var ( + GoldenGatePipelineRunningProcessDataSourceRepresentation = map[string]interface{}{ + "pipeline_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_golden_gate_pipeline.test_pipeline.id}`}, + } + + GoldenGatePipelineRunningProcessResourceConfig = acctest.GenerateResourceFromRepresentationMap("oci_golden_gate_pipeline", "test_pipeline", acctest.Required, acctest.Create, GoldenGatePipelineRepresentation) +) + +// issue-routing-tag: golden_gate/default +func TestGoldenGatePipelineRunningProcessResource_basic(t *testing.T) { + httpreplay.SetScenario("TestGoldenGatePipelineRunningProcessResource_basic") + defer httpreplay.SaveScenario() + + config := acctest.ProviderTestConfig() + + makeVariableStr("source_connection_id", t) + + makeVariableStr("target_connection_id", t) + + compartmentId := utils.GetEnvSettingWithBlankDefault("compartment_ocid") + compartmentIdVariableStr := fmt.Sprintf("variable \"compartment_id\" { default = \"%s\" }\n", compartmentId) + + datasourceName := "data.oci_golden_gate_pipeline_running_processes.test_pipeline_running_processes" + + acctest.SaveConfigContent("", "", "", t) + + acctest.ResourceTest(t, nil, []resource.TestStep{ + // verify datasource + { + Config: config + + acctest.GenerateDataSourceFromRepresentationMap("oci_golden_gate_pipeline_running_processes", "test_pipeline_running_processes", acctest.Required, acctest.Create, GoldenGatePipelineRunningProcessDataSourceRepresentation) + + compartmentIdVariableStr + GoldenGatePipelineRunningProcessResourceConfig, + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttrSet(datasourceName, "pipeline_id"), + + resource.TestCheckResourceAttrSet(datasourceName, "pipeline_running_process_collection.#"), + resource.TestCheckResourceAttr(datasourceName, "pipeline_running_process_collection.0.items.#", "0"), + ), + }, + }) +} diff --git a/internal/integrationtest/golden_gate_pipeline_schema_table_test.go b/internal/integrationtest/golden_gate_pipeline_schema_table_test.go new file mode 100644 index 00000000000..b420ea034f6 --- /dev/null +++ b/internal/integrationtest/golden_gate_pipeline_schema_table_test.go @@ -0,0 +1,66 @@ +// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. +// Licensed under the Mozilla Public License v2.0 + +package integrationtest + +import ( + "fmt" + "testing" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" + + "github.com/oracle/terraform-provider-oci/httpreplay" + "github.com/oracle/terraform-provider-oci/internal/acctest" + + "github.com/oracle/terraform-provider-oci/internal/utils" +) + +var ( + GoldenGatePipelineSchemaTableDataSourceRepresentation = map[string]interface{}{ + "pipeline_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_golden_gate_pipeline.test_pipeline.id}`}, + "source_schema_name": acctest.Representation{RepType: acctest.Required, Create: `${var.source_schema}`}, + "target_schema_name": acctest.Representation{RepType: acctest.Required, Create: `${var.target_schema}`}, + } + + GoldenGatePipelineSchemaTableResourceConfig = acctest.GenerateResourceFromRepresentationMap("oci_golden_gate_pipeline", "test_pipeline", acctest.Required, acctest.Create, GoldenGatePipelineRepresentation) +) + +// issue-routing-tag: golden_gate/default +func TestGoldenGatePipelineSchemaTableResource_basic(t *testing.T) { + httpreplay.SetScenario("TestGoldenGatePipelineSchemaTableResource_basic") + defer httpreplay.SaveScenario() + + config := acctest.ProviderTestConfig() + + makeVariableStr("source_connection_id", t) + + makeVariableStr("target_connection_id", t) + + makeVariableStr("source_schema", t) + + makeVariableStr("target_schema", t) + + compartmentId := utils.GetEnvSettingWithBlankDefault("compartment_ocid") + sourceSchema := utils.GetEnvSettingWithBlankDefault("source_schema") + targetSchema := utils.GetEnvSettingWithBlankDefault("target_schema") + compartmentIdVariableStr := fmt.Sprintf("variable \"compartment_id\" { default = \"%s\" }\n", compartmentId) + + datasourceName := "data.oci_golden_gate_pipeline_schema_tables.test_pipeline_schema_tables" + + acctest.SaveConfigContent("", "", "", t) + + acctest.ResourceTest(t, nil, []resource.TestStep{ + // verify datasource + { + Config: config + + acctest.GenerateDataSourceFromRepresentationMap("oci_golden_gate_pipeline_schema_tables", "test_pipeline_schema_tables", acctest.Required, acctest.Create, GoldenGatePipelineSchemaTableDataSourceRepresentation) + + compartmentIdVariableStr + GoldenGatePipelineSchemaTableResourceConfig, + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttrSet(datasourceName, "pipeline_id"), + resource.TestCheckResourceAttr(datasourceName, "source_schema_name", sourceSchema), + resource.TestCheckResourceAttr(datasourceName, "target_schema_name", targetSchema), + + resource.TestCheckResourceAttrSet(datasourceName, "pipeline_schema_table_collection.#"), + resource.TestCheckResourceAttr(datasourceName, "pipeline_schema_table_collection.0.items.#", "2"), + resource.TestCheckResourceAttrSet(datasourceName, "pipeline_schema_table_collection.0.items.0.source_table_name"), + resource.TestCheckResourceAttrSet(datasourceName, "pipeline_schema_table_collection.0.items.0.target_table_name"), + ), + }, + }) +} diff --git a/internal/integrationtest/golden_gate_pipeline_schema_test.go b/internal/integrationtest/golden_gate_pipeline_schema_test.go new file mode 100644 index 00000000000..f0ad9273ead --- /dev/null +++ b/internal/integrationtest/golden_gate_pipeline_schema_test.go @@ -0,0 +1,56 @@ +// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. +// Licensed under the Mozilla Public License v2.0 + +package integrationtest + +import ( + "fmt" + "testing" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" + + "github.com/oracle/terraform-provider-oci/httpreplay" + "github.com/oracle/terraform-provider-oci/internal/acctest" + + "github.com/oracle/terraform-provider-oci/internal/utils" +) + +var ( + GoldenGatePipelineSchemaDataSourceRepresentation = map[string]interface{}{ + "pipeline_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_golden_gate_pipeline.test_pipeline.id}`}, + } + + GoldenGatePipelineSchemaResourceConfig = acctest.GenerateResourceFromRepresentationMap("oci_golden_gate_pipeline", "test_pipeline", acctest.Required, acctest.Create, GoldenGatePipelineRepresentation) +) + +// issue-routing-tag: golden_gate/default +func TestGoldenGatePipelineSchemaResource_basic(t *testing.T) { + httpreplay.SetScenario("TestGoldenGatePipelineSchemaResource_basic") + defer httpreplay.SaveScenario() + + config := acctest.ProviderTestConfig() + + makeVariableStr("source_connection_id", t) + + makeVariableStr("target_connection_id", t) + + compartmentId := utils.GetEnvSettingWithBlankDefault("compartment_ocid") + compartmentIdVariableStr := fmt.Sprintf("variable \"compartment_id\" { default = \"%s\" }\n", compartmentId) + + datasourceName := "data.oci_golden_gate_pipeline_schemas.test_pipeline_schemas" + + acctest.SaveConfigContent("", "", "", t) + + acctest.ResourceTest(t, nil, []resource.TestStep{ + // verify datasource + { + Config: config + + acctest.GenerateDataSourceFromRepresentationMap("oci_golden_gate_pipeline_schemas", "test_pipeline_schemas", acctest.Required, acctest.Create, GoldenGatePipelineSchemaDataSourceRepresentation) + + compartmentIdVariableStr + GoldenGatePipelineSchemaResourceConfig, + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttrSet(datasourceName, "pipeline_id"), + + resource.TestCheckResourceAttrSet(datasourceName, "pipeline_schema_collection.#"), + //resource.TestCheckResourceAttr(datasourceName, "pipeline_schema_collection.0.items.#", "1"), + ), + }, + }) +} diff --git a/internal/integrationtest/golden_gate_pipeline_test.go b/internal/integrationtest/golden_gate_pipeline_test.go new file mode 100644 index 00000000000..371f6a739da --- /dev/null +++ b/internal/integrationtest/golden_gate_pipeline_test.go @@ -0,0 +1,443 @@ +// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. +// Licensed under the Mozilla Public License v2.0 + +package integrationtest + +import ( + "context" + "fmt" + "testing" + "time" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" + "github.com/hashicorp/terraform-plugin-sdk/v2/terraform" + "github.com/oracle/oci-go-sdk/v65/common" + oci_golden_gate "github.com/oracle/oci-go-sdk/v65/goldengate" + + "github.com/oracle/terraform-provider-oci/httpreplay" + "github.com/oracle/terraform-provider-oci/internal/acctest" + tf_client "github.com/oracle/terraform-provider-oci/internal/client" + "github.com/oracle/terraform-provider-oci/internal/tfresource" + "github.com/oracle/terraform-provider-oci/internal/utils" +) + +var ( + GoldenGatePipelineRequiredOnlyResource = GoldenGatePipelineResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_golden_gate_pipeline", "test_pipeline", acctest.Required, acctest.Create, GoldenGatePipelineRepresentation) + + GoldenGatePipelineResourceConfig = GoldenGatePipelineResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_golden_gate_pipeline", "test_pipeline", acctest.Optional, acctest.Update, GoldenGatePipelineRepresentation) + + GoldenGatePipelineSingularDataSourceRepresentation = map[string]interface{}{ + "pipeline_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_golden_gate_pipeline.test_pipeline.id}`}, + } + + GoldenGatePipelineDataSourceRepresentation = map[string]interface{}{ + "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id}`}, + "display_name": acctest.Representation{RepType: acctest.Optional, Create: `displayName`, Update: `displayName2`}, + "lifecycle_sub_state": acctest.Representation{RepType: acctest.Optional, Create: `STOPPED`}, + "state": acctest.Representation{RepType: acctest.Optional, Create: `ACTIVE`}, + "filter": acctest.RepresentationGroup{RepType: acctest.Required, Group: GoldenGatePipelineDataSourceFilterRepresentation}} + GoldenGatePipelineDataSourceFilterRepresentation = map[string]interface{}{ + "name": acctest.Representation{RepType: acctest.Required, Create: `id`}, + "values": acctest.Representation{RepType: acctest.Required, Create: []string{`${oci_golden_gate_pipeline.test_pipeline.id}`}}, + } + + GoldenGatePipelineRepresentation = map[string]interface{}{ + "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id}`}, + "display_name": acctest.Representation{RepType: acctest.Required, Create: `displayName`, Update: `displayName2`}, + "license_model": acctest.Representation{RepType: acctest.Required, Create: `LICENSE_INCLUDED`}, + "recipe_type": acctest.Representation{RepType: acctest.Required, Create: `ZERO_ETL`}, + "source_connection_details": acctest.RepresentationGroup{RepType: acctest.Required, Group: GoldenGatePipelineSourceConnectionDetailsRepresentation}, + "target_connection_details": acctest.RepresentationGroup{RepType: acctest.Required, Group: GoldenGatePipelineTargetConnectionDetailsRepresentation}, + "description": acctest.Representation{RepType: acctest.Optional, Create: `description`, Update: `description2`}, + "freeform_tags": acctest.Representation{RepType: acctest.Optional, Create: map[string]string{"bar-key": "value"}, Update: map[string]string{"Department": "Accounting"}}, + //"locks": acctest.RepresentationGroup{RepType: acctest.Optional, Group: GoldenGatePipelineLocksRepresentation}, + "process_options": acctest.RepresentationGroup{RepType: acctest.Optional, Group: GoldenGatePipelineProcessOptionsRepresentation}, + } + GoldenGatePipelineSourceConnectionDetailsRepresentation = map[string]interface{}{ + //"connection_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_golden_gate_connection.test_connection.id}`}, + "connection_id": acctest.Representation{RepType: acctest.Required, Create: `${var.source_connection_id}`}, + } + GoldenGatePipelineTargetConnectionDetailsRepresentation = map[string]interface{}{ + //"connection_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_golden_gate_connection.test_connection.id}`}, + "connection_id": acctest.Representation{RepType: acctest.Required, Create: `${var.target_connection_id}`}, + } + //GoldenGatePipelineLocksRepresentation = map[string]interface{}{ + // "type": acctest.Representation{RepType: acctest.Required, Create: `FULL`}, + // "message": acctest.Representation{RepType: acctest.Optional, Create: `message`}, + //} + GoldenGatePipelineProcessOptionsRepresentation = map[string]interface{}{ + "initial_data_load": acctest.RepresentationGroup{RepType: acctest.Required, Group: GoldenGatePipelineProcessOptionsInitialDataLoadRepresentation}, + "replicate_schema_change": acctest.RepresentationGroup{RepType: acctest.Required, Group: GoldenGatePipelineProcessOptionsReplicateSchemaChangeRepresentation}, + "should_restart_on_failure": acctest.Representation{RepType: acctest.Required, Create: `ENABLED`, Update: `DISABLED`}, + } + GoldenGatePipelineProcessOptionsInitialDataLoadRepresentation = map[string]interface{}{ + "is_initial_load": acctest.Representation{RepType: acctest.Required, Create: `ENABLED`, Update: `DISABLED`}, + "action_on_existing_table": acctest.Representation{RepType: acctest.Optional, Create: `TRUNCATE`, Update: `REPLACE`}, + } + GoldenGatePipelineProcessOptionsReplicateSchemaChangeRepresentation = map[string]interface{}{ + "can_replicate_schema_change": acctest.Representation{RepType: acctest.Required, Create: `ENABLED`, Update: `DISABLED`}, + "action_on_ddl_error": acctest.Representation{RepType: acctest.Optional, Create: `TERMINATE`, Update: `DISCARD`}, + "action_on_dml_error": acctest.Representation{RepType: acctest.Optional, Create: `TERMINATE`, Update: `DISCARD`}, + } + + GoldenGatePipelineResourceDependencies = "" +) + +// issue-routing-tag: golden_gate/default +func TestGoldenGatePipelineResource_basic(t *testing.T) { + httpreplay.SetScenario("TestGoldenGatePipelineResource_basic") + defer httpreplay.SaveScenario() + + config := acctest.ProviderTestConfig() + + makeVariableStr("source_connection_id", t) + + makeVariableStr("target_connection_id", t) + + compartmentId := utils.GetEnvSettingWithBlankDefault("compartment_ocid") + compartmentIdVariableStr := fmt.Sprintf("variable \"compartment_id\" { default = \"%s\" }\n", compartmentId) + + compartmentIdU := utils.GetEnvSettingWithDefault("compartment_id_for_update", compartmentId) + compartmentIdUVariableStr := fmt.Sprintf("variable \"compartment_id_for_update\" { default = \"%s\" }\n", compartmentIdU) + + resourceName := "oci_golden_gate_pipeline.test_pipeline" + datasourceName := "data.oci_golden_gate_pipelines.test_pipelines" + singularDatasourceName := "data.oci_golden_gate_pipeline.test_pipeline" + + var resId, resId2 string + // Save TF content to Create resource with optional properties. This has to be exactly the same as the config part in the "create with optionals" step in the test. + acctest.SaveConfigContent(config+compartmentIdVariableStr+GoldenGatePipelineResourceDependencies+ + acctest.GenerateResourceFromRepresentationMap("oci_golden_gate_pipeline", "test_pipeline", acctest.Optional, acctest.Create, GoldenGatePipelineRepresentation), "goldengate", "pipeline", t) + + acctest.ResourceTest(t, testAccCheckGoldenGatePipelineDestroy, []resource.TestStep{ + // verify Create + { + Config: config + compartmentIdVariableStr + GoldenGatePipelineResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_golden_gate_pipeline", "test_pipeline", acctest.Required, acctest.Create, GoldenGatePipelineRepresentation), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttr(resourceName, "display_name", "displayName"), + resource.TestCheckResourceAttr(resourceName, "license_model", "LICENSE_INCLUDED"), + resource.TestCheckResourceAttr(resourceName, "recipe_type", "ZERO_ETL"), + resource.TestCheckResourceAttr(resourceName, "source_connection_details.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "source_connection_details.0.connection_id"), + resource.TestCheckResourceAttr(resourceName, "target_connection_details.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "target_connection_details.0.connection_id"), + + func(s *terraform.State) (err error) { + resId, err = acctest.FromInstanceState(s, resourceName, "id") + return err + }, + ), + }, + + // delete before next Create + { + Config: config + compartmentIdVariableStr + GoldenGatePipelineResourceDependencies, + }, + // verify Create with optionals + { + Config: config + compartmentIdVariableStr + GoldenGatePipelineResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_golden_gate_pipeline", "test_pipeline", acctest.Optional, acctest.Create, GoldenGatePipelineRepresentation), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttrSet(resourceName, "cpu_core_count"), + resource.TestCheckResourceAttr(resourceName, "description", "description"), + resource.TestCheckResourceAttr(resourceName, "display_name", "displayName"), + resource.TestCheckResourceAttr(resourceName, "freeform_tags.%", "1"), + resource.TestCheckResourceAttrSet(resourceName, "id"), + resource.TestCheckResourceAttrSet(resourceName, "is_auto_scaling_enabled"), + resource.TestCheckResourceAttr(resourceName, "license_model", "LICENSE_INCLUDED"), + resource.TestCheckResourceAttr(resourceName, "process_options.#", "1"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.initial_data_load.#", "1"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.initial_data_load.0.action_on_existing_table", "TRUNCATE"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.initial_data_load.0.is_initial_load", "ENABLED"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.replicate_schema_change.#", "1"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.replicate_schema_change.0.action_on_ddl_error", "TERMINATE"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.replicate_schema_change.0.action_on_dml_error", "TERMINATE"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.replicate_schema_change.0.can_replicate_schema_change", "ENABLED"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.should_restart_on_failure", "ENABLED"), + resource.TestCheckResourceAttr(resourceName, "recipe_type", "ZERO_ETL"), + resource.TestCheckResourceAttr(resourceName, "source_connection_details.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "source_connection_details.0.connection_id"), + resource.TestCheckResourceAttrSet(resourceName, "state"), + resource.TestCheckResourceAttr(resourceName, "target_connection_details.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "target_connection_details.0.connection_id"), + resource.TestCheckResourceAttrSet(resourceName, "time_created"), + resource.TestCheckResourceAttrSet(resourceName, "time_updated"), + + func(s *terraform.State) (err error) { + resId, err = acctest.FromInstanceState(s, resourceName, "id") + return err + }, + ), + }, + + // verify Update to the compartment (the compartment will be switched back in the next step) + { + Config: config + compartmentIdVariableStr + compartmentIdUVariableStr + GoldenGatePipelineResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_golden_gate_pipeline", "test_pipeline", acctest.Optional, acctest.Create, + acctest.RepresentationCopyWithNewProperties(GoldenGatePipelineRepresentation, map[string]interface{}{ + "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id_for_update}`}, + })), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentIdU), + resource.TestCheckResourceAttrSet(resourceName, "cpu_core_count"), + resource.TestCheckResourceAttr(resourceName, "description", "description"), + resource.TestCheckResourceAttr(resourceName, "display_name", "displayName"), + resource.TestCheckResourceAttr(resourceName, "freeform_tags.%", "1"), + resource.TestCheckResourceAttrSet(resourceName, "id"), + resource.TestCheckResourceAttrSet(resourceName, "is_auto_scaling_enabled"), + resource.TestCheckResourceAttr(resourceName, "license_model", "LICENSE_INCLUDED"), + resource.TestCheckResourceAttr(resourceName, "process_options.#", "1"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.initial_data_load.#", "1"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.initial_data_load.0.action_on_existing_table", "TRUNCATE"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.initial_data_load.0.is_initial_load", "ENABLED"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.replicate_schema_change.#", "1"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.replicate_schema_change.0.action_on_ddl_error", "TERMINATE"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.replicate_schema_change.0.action_on_dml_error", "TERMINATE"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.replicate_schema_change.0.can_replicate_schema_change", "ENABLED"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.should_restart_on_failure", "ENABLED"), + resource.TestCheckResourceAttr(resourceName, "recipe_type", "ZERO_ETL"), + resource.TestCheckResourceAttr(resourceName, "source_connection_details.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "source_connection_details.0.connection_id"), + resource.TestCheckResourceAttrSet(resourceName, "state"), + resource.TestCheckResourceAttr(resourceName, "target_connection_details.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "target_connection_details.0.connection_id"), + resource.TestCheckResourceAttrSet(resourceName, "time_created"), + resource.TestCheckResourceAttrSet(resourceName, "time_updated"), + + func(s *terraform.State) (err error) { + resId2, err = acctest.FromInstanceState(s, resourceName, "id") + if resId != resId2 { + return fmt.Errorf("resource recreated when it was supposed to be updated") + } + return err + }, + ), + }, + + // verify updates to updatable parameters + { + Config: config + compartmentIdVariableStr + GoldenGatePipelineResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_golden_gate_pipeline", "test_pipeline", acctest.Optional, acctest.Update, GoldenGatePipelineRepresentation), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttrSet(resourceName, "cpu_core_count"), + resource.TestCheckResourceAttr(resourceName, "description", "description2"), + resource.TestCheckResourceAttr(resourceName, "display_name", "displayName2"), + resource.TestCheckResourceAttr(resourceName, "freeform_tags.%", "1"), + resource.TestCheckResourceAttrSet(resourceName, "id"), + resource.TestCheckResourceAttrSet(resourceName, "is_auto_scaling_enabled"), + resource.TestCheckResourceAttr(resourceName, "license_model", "LICENSE_INCLUDED"), + resource.TestCheckResourceAttr(resourceName, "process_options.#", "1"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.initial_data_load.#", "1"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.initial_data_load.0.action_on_existing_table", "REPLACE"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.initial_data_load.0.is_initial_load", "DISABLED"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.replicate_schema_change.#", "1"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.replicate_schema_change.0.action_on_ddl_error", "DISCARD"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.replicate_schema_change.0.action_on_dml_error", "DISCARD"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.replicate_schema_change.0.can_replicate_schema_change", "DISABLED"), + resource.TestCheckResourceAttr(resourceName, "process_options.0.should_restart_on_failure", "DISABLED"), + resource.TestCheckResourceAttr(resourceName, "recipe_type", "ZERO_ETL"), + resource.TestCheckResourceAttr(resourceName, "source_connection_details.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "source_connection_details.0.connection_id"), + resource.TestCheckResourceAttrSet(resourceName, "state"), + resource.TestCheckResourceAttr(resourceName, "target_connection_details.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "target_connection_details.0.connection_id"), + resource.TestCheckResourceAttrSet(resourceName, "time_created"), + resource.TestCheckResourceAttrSet(resourceName, "time_updated"), + + func(s *terraform.State) (err error) { + resId2, err = acctest.FromInstanceState(s, resourceName, "id") + if resId != resId2 { + return fmt.Errorf("Resource recreated when it was supposed to be updated.") + } + return err + }, + ), + }, + // verify datasource + { + Config: config + + acctest.GenerateDataSourceFromRepresentationMap("oci_golden_gate_pipelines", "test_pipelines", acctest.Optional, acctest.Update, GoldenGatePipelineDataSourceRepresentation) + + compartmentIdVariableStr + GoldenGatePipelineResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_golden_gate_pipeline", "test_pipeline", acctest.Optional, acctest.Update, GoldenGatePipelineRepresentation), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(datasourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttr(datasourceName, "display_name", "displayName2"), + resource.TestCheckResourceAttr(datasourceName, "lifecycle_sub_state", "STOPPED"), + resource.TestCheckResourceAttr(datasourceName, "state", "ACTIVE"), + + resource.TestCheckResourceAttr(datasourceName, "pipeline_collection.#", "1"), + //resource.TestCheckResourceAttr(datasourceName, "pipeline_collection.0.items.#", "1"), + ), + }, + // verify singular datasource + { + Config: config + + acctest.GenerateDataSourceFromRepresentationMap("oci_golden_gate_pipeline", "test_pipeline", acctest.Required, acctest.Create, GoldenGatePipelineSingularDataSourceRepresentation) + + compartmentIdVariableStr + GoldenGatePipelineResourceConfig, + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttrSet(singularDatasourceName, "pipeline_id"), + + resource.TestCheckResourceAttr(singularDatasourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttrSet(singularDatasourceName, "cpu_core_count"), + resource.TestCheckResourceAttr(singularDatasourceName, "description", "description2"), + resource.TestCheckResourceAttr(singularDatasourceName, "display_name", "displayName2"), + resource.TestCheckResourceAttr(singularDatasourceName, "freeform_tags.%", "1"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "id"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "is_auto_scaling_enabled"), + resource.TestCheckResourceAttr(singularDatasourceName, "license_model", "LICENSE_INCLUDED"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "lifecycle_sub_state"), + resource.TestCheckResourceAttr(singularDatasourceName, "mapping_rules.#", "1"), + resource.TestCheckResourceAttr(singularDatasourceName, "process_options.#", "1"), + resource.TestCheckResourceAttr(singularDatasourceName, "process_options.0.initial_data_load.#", "1"), + resource.TestCheckResourceAttr(singularDatasourceName, "process_options.0.initial_data_load.0.action_on_existing_table", "REPLACE"), + resource.TestCheckResourceAttr(singularDatasourceName, "process_options.0.initial_data_load.0.is_initial_load", "DISABLED"), + resource.TestCheckResourceAttr(singularDatasourceName, "process_options.0.replicate_schema_change.#", "1"), + resource.TestCheckResourceAttr(singularDatasourceName, "process_options.0.replicate_schema_change.0.action_on_ddl_error", "DISCARD"), + resource.TestCheckResourceAttr(singularDatasourceName, "process_options.0.replicate_schema_change.0.action_on_dml_error", "DISCARD"), + resource.TestCheckResourceAttr(singularDatasourceName, "process_options.0.replicate_schema_change.0.can_replicate_schema_change", "DISABLED"), + resource.TestCheckResourceAttr(singularDatasourceName, "process_options.0.should_restart_on_failure", "DISABLED"), + resource.TestCheckResourceAttr(singularDatasourceName, "recipe_type", "ZERO_ETL"), + resource.TestCheckResourceAttr(singularDatasourceName, "source_connection_details.#", "1"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "state"), + resource.TestCheckResourceAttr(singularDatasourceName, "target_connection_details.#", "1"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "time_created"), + //resource.TestCheckResourceAttrSet(singularDatasourceName, "time_last_recorded"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "time_updated"), + ), + }, + // verify resource import + { + Config: config + GoldenGatePipelineRequiredOnlyResource, + ImportState: true, + ImportStateVerify: true, + ImportStateVerifyIgnore: []string{}, + ResourceName: resourceName, + }, + }) +} + +func testAccCheckGoldenGatePipelineDestroy(s *terraform.State) error { + noResourceFound := true + client := acctest.TestAccProvider.Meta().(*tf_client.OracleClients).GoldenGateClient() + for _, rs := range s.RootModule().Resources { + if rs.Type == "oci_golden_gate_pipeline" { + noResourceFound = false + request := oci_golden_gate.GetPipelineRequest{} + + tmp := rs.Primary.ID + request.PipelineId = &tmp + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(true, "golden_gate") + + response, err := client.GetPipeline(context.Background(), request) + + if err == nil { + deletedLifecycleStates := map[string]bool{ + string(oci_golden_gate.PipelineLifecycleStateDeleted): true, + } + if _, ok := deletedLifecycleStates[string(response.GetLifecycleState())]; !ok { + //resource lifecycle state is not in expected deleted lifecycle states. + return fmt.Errorf("resource lifecycle state: %s is not in expected deleted lifecycle states", response.GetLifecycleState()) + } + //resource lifecycle state is in expected deleted lifecycle states. continue with next one. + continue + } + + //Verify that exception is for '404 not found'. + if failure, isServiceError := common.IsServiceError(err); !isServiceError || failure.GetHTTPStatusCode() != 404 { + return err + } + } + } + if noResourceFound { + return fmt.Errorf("at least one resource was expected from the state file, but could not be found") + } + + return nil +} + +func init() { + if acctest.DependencyGraph == nil { + acctest.InitDependencyGraph() + } + if !acctest.InSweeperExcludeList("GoldenGatePipeline") { + resource.AddTestSweepers("GoldenGatePipeline", &resource.Sweeper{ + Name: "GoldenGatePipeline", + Dependencies: acctest.DependencyGraph["pipeline"], + F: sweepGoldenGatePipelineResource, + }) + } +} + +func sweepGoldenGatePipelineResource(compartment string) error { + goldenGateClient := acctest.GetTestClients(&schema.ResourceData{}).GoldenGateClient() + pipelineIds, err := getGoldenGatePipelineIds(compartment) + if err != nil { + return err + } + for _, pipelineId := range pipelineIds { + if ok := acctest.SweeperDefaultResourceId[pipelineId]; !ok { + deletePipelineRequest := oci_golden_gate.DeletePipelineRequest{} + + deletePipelineRequest.PipelineId = &pipelineId + + deletePipelineRequest.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(true, "golden_gate") + _, error := goldenGateClient.DeletePipeline(context.Background(), deletePipelineRequest) + if error != nil { + fmt.Printf("Error deleting Pipeline %s %s, It is possible that the resource is already deleted. Please verify manually \n", pipelineId, error) + continue + } + acctest.WaitTillCondition(acctest.TestAccProvider, &pipelineId, GoldenGatePipelineSweepWaitCondition, time.Duration(3*time.Minute), + GoldenGatePipelineSweepResponseFetchOperation, "golden_gate", true) + } + } + return nil +} + +func getGoldenGatePipelineIds(compartment string) ([]string, error) { + ids := acctest.GetResourceIdsToSweep(compartment, "PipelineId") + if ids != nil { + return ids, nil + } + var resourceIds []string + compartmentId := compartment + goldenGateClient := acctest.GetTestClients(&schema.ResourceData{}).GoldenGateClient() + + listPipelinesRequest := oci_golden_gate.ListPipelinesRequest{} + listPipelinesRequest.CompartmentId = &compartmentId + listPipelinesRequest.LifecycleState = oci_golden_gate.PipelineLifecycleStateActive + listPipelinesResponse, err := goldenGateClient.ListPipelines(context.Background(), listPipelinesRequest) + + if err != nil { + return resourceIds, fmt.Errorf("Error getting Pipeline list for compartment id : %s , %s \n", compartmentId, err) + } + for _, pipeline := range listPipelinesResponse.Items { + id := *pipeline.GetId() + resourceIds = append(resourceIds, id) + acctest.AddResourceIdToSweeperResourceIdMap(compartmentId, "PipelineId", id) + } + return resourceIds, nil +} + +func GoldenGatePipelineSweepWaitCondition(response common.OCIOperationResponse) bool { + // Only stop if the resource is available beyond 3 mins. As there could be an issue for the sweeper to delete the resource and manual intervention required. + if pipelineResponse, ok := response.Response.(oci_golden_gate.GetPipelineResponse); ok { + return pipelineResponse.GetLifecycleState() != oci_golden_gate.PipelineLifecycleStateDeleted + } + return false +} + +func GoldenGatePipelineSweepResponseFetchOperation(client *tf_client.OracleClients, resourceId *string, retryPolicy *common.RetryPolicy) error { + _, err := client.GoldenGateClient().GetPipeline(context.Background(), oci_golden_gate.GetPipelineRequest{ + PipelineId: resourceId, + RequestMetadata: common.RequestMetadata{ + RetryPolicy: retryPolicy, + }, + }) + return err +} diff --git a/internal/integrationtest/golden_gate_recipe_test.go b/internal/integrationtest/golden_gate_recipe_test.go new file mode 100644 index 00000000000..5370a1e1779 --- /dev/null +++ b/internal/integrationtest/golden_gate_recipe_test.go @@ -0,0 +1,57 @@ +// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. +// Licensed under the Mozilla Public License v2.0 + +package integrationtest + +import ( + "fmt" + "testing" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" + + "github.com/oracle/terraform-provider-oci/httpreplay" + "github.com/oracle/terraform-provider-oci/internal/acctest" + + "github.com/oracle/terraform-provider-oci/internal/utils" +) + +var ( + GoldenGateRecipeDataSourceRepresentation = map[string]interface{}{ + "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id}`}, + "display_name": acctest.Representation{RepType: acctest.Optional, Create: `displayName`}, + "recipe_type": acctest.Representation{RepType: acctest.Optional, Create: `ZERO_ETL`}, + } + + GoldenGateRecipeResourceConfig = "" +) + +// issue-routing-tag: golden_gate/default +func TestGoldenGateRecipeResource_basic(t *testing.T) { + httpreplay.SetScenario("TestGoldenGateRecipeResource_basic") + defer httpreplay.SaveScenario() + + config := acctest.ProviderTestConfig() + + compartmentId := utils.GetEnvSettingWithBlankDefault("compartment_ocid") + compartmentIdVariableStr := fmt.Sprintf("variable \"compartment_id\" { default = \"%s\" }\n", compartmentId) + + datasourceName := "data.oci_golden_gate_recipes.test_recipes" + + acctest.SaveConfigContent("", "", "", t) + + acctest.ResourceTest(t, nil, []resource.TestStep{ + // verify datasource + { + Config: config + + acctest.GenerateDataSourceFromRepresentationMap("oci_golden_gate_recipes", "test_recipes", acctest.Required, acctest.Create, GoldenGateRecipeDataSourceRepresentation) + + compartmentIdVariableStr + GoldenGateRecipeResourceConfig, + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(datasourceName, "compartment_id", compartmentId), + + resource.TestCheckResourceAttrSet(datasourceName, "recipe_summary_collection.#"), + resource.TestCheckResourceAttr(datasourceName, "recipe_summary_collection.0.items.#", "1"), + resource.TestCheckResourceAttr(datasourceName, "recipe_summary_collection.0.items.0.recipe_type", "ZERO_ETL"), + ), + }, + }) +} diff --git a/internal/service/golden_gate/golden_gate_export.go b/internal/service/golden_gate/golden_gate_export.go index f9a6cc6597c..b34cafe406a 100644 --- a/internal/service/golden_gate/golden_gate_export.go +++ b/internal/service/golden_gate/golden_gate_export.go @@ -104,6 +104,19 @@ var exportGoldenGateDeploymentCertificateHints = &tf_export.TerraformResourceHin }, } +var exportGoldenGatePipelineHints = &tf_export.TerraformResourceHints{ + ResourceClass: "oci_golden_gate_pipeline", + DatasourceClass: "oci_golden_gate_pipelines", + DatasourceItemsAttr: "pipeline_collection", + IsDatasourceCollection: true, + ResourceAbbreviation: "pipeline", + RequireResourceRefresh: true, + DiscoverableLifecycleStates: []string{ + string(oci_golden_gate.PipelineLifecycleStateActive), + string(oci_golden_gate.PipelineLifecycleStateNeedsAttention), + }, +} + var goldenGateResourceGraph = tf_export.TerraformResourceGraph{ "oci_identity_compartment": { {TerraformResourceHints: exportGoldenGateDatabaseRegistrationHints}, @@ -111,6 +124,7 @@ var goldenGateResourceGraph = tf_export.TerraformResourceGraph{ {TerraformResourceHints: exportGoldenGateDeploymentBackupHints}, {TerraformResourceHints: exportGoldenGateConnectionAssignmentHints}, {TerraformResourceHints: exportGoldenGateConnectionHints}, + {TerraformResourceHints: exportGoldenGatePipelineHints}, }, "oci_golden_gate_deployment": { { diff --git a/internal/service/golden_gate/golden_gate_pipeline_data_source.go b/internal/service/golden_gate/golden_gate_pipeline_data_source.go new file mode 100644 index 00000000000..a33e50e0659 --- /dev/null +++ b/internal/service/golden_gate/golden_gate_pipeline_data_source.go @@ -0,0 +1,161 @@ +// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. +// Licensed under the Mozilla Public License v2.0 + +package golden_gate + +import ( + "context" + "log" + "time" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" + oci_golden_gate "github.com/oracle/oci-go-sdk/v65/goldengate" + + "github.com/oracle/terraform-provider-oci/internal/client" + "github.com/oracle/terraform-provider-oci/internal/tfresource" +) + +func GoldenGatePipelineDataSource() *schema.Resource { + fieldMap := make(map[string]*schema.Schema) + fieldMap["pipeline_id"] = &schema.Schema{ + Type: schema.TypeString, + Required: true, + } + return tfresource.GetSingularDataSourceItemSchema(GoldenGatePipelineResource(), fieldMap, readSingularGoldenGatePipeline) +} + +func readSingularGoldenGatePipeline(d *schema.ResourceData, m interface{}) error { + sync := &GoldenGatePipelineDataSourceCrud{} + sync.D = d + sync.Client = m.(*client.OracleClients).GoldenGateClient() + + return tfresource.ReadResource(sync) +} + +type GoldenGatePipelineDataSourceCrud struct { + D *schema.ResourceData + Client *oci_golden_gate.GoldenGateClient + Res *oci_golden_gate.GetPipelineResponse +} + +func (s *GoldenGatePipelineDataSourceCrud) VoidState() { + s.D.SetId("") +} + +func (s *GoldenGatePipelineDataSourceCrud) Get() error { + request := oci_golden_gate.GetPipelineRequest{} + + if pipelineId, ok := s.D.GetOkExists("pipeline_id"); ok { + tmp := pipelineId.(string) + request.PipelineId = &tmp + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(false, "golden_gate") + + response, err := s.Client.GetPipeline(context.Background(), request) + if err != nil { + return err + } + + s.Res = &response + return nil +} + +func (s *GoldenGatePipelineDataSourceCrud) SetData() error { + if s.Res == nil { + return nil + } + + s.D.SetId(*s.Res.GetId()) + switch v := (s.Res.Pipeline).(type) { + case oci_golden_gate.ZeroEtlPipeline: + s.D.Set("recipe_type", "ZERO_ETL") + + mappingRules := []interface{}{} + for _, item := range v.MappingRules { + mappingRules = append(mappingRules, MappingRuleToMap(item)) + } + s.D.Set("mapping_rules", mappingRules) + + if v.ProcessOptions != nil { + s.D.Set("process_options", []interface{}{ProcessOptionsToMap(v.ProcessOptions)}) + } else { + s.D.Set("process_options", nil) + } + + if v.TimeLastRecorded != nil { + s.D.Set("time_last_recorded", v.TimeLastRecorded.Format(time.RFC3339Nano)) + } + + if v.CompartmentId != nil { + s.D.Set("compartment_id", *v.CompartmentId) + } + + if v.CpuCoreCount != nil { + s.D.Set("cpu_core_count", *v.CpuCoreCount) + } + + if v.DefinedTags != nil { + s.D.Set("defined_tags", tfresource.DefinedTagsToMap(v.DefinedTags)) + } + + if v.Description != nil { + s.D.Set("description", *v.Description) + } + + if v.DisplayName != nil { + s.D.Set("display_name", *v.DisplayName) + } + + s.D.Set("freeform_tags", v.FreeformTags) + + if v.IsAutoScalingEnabled != nil { + s.D.Set("is_auto_scaling_enabled", *v.IsAutoScalingEnabled) + } + + s.D.Set("license_model", v.LicenseModel) + + if v.LifecycleDetails != nil { + s.D.Set("lifecycle_details", *v.LifecycleDetails) + } + + s.D.Set("lifecycle_sub_state", v.LifecycleSubState) + + locks := []interface{}{} + for _, item := range v.Locks { + locks = append(locks, ResourceLockToMap(item)) + } + s.D.Set("locks", locks) + + if v.SourceConnectionDetails != nil { + s.D.Set("source_connection_details", []interface{}{SourcePipelineConnectionDetailsToMap(v.SourceConnectionDetails)}) + } else { + s.D.Set("source_connection_details", nil) + } + + s.D.Set("state", v.LifecycleState) + + if v.SystemTags != nil { + s.D.Set("system_tags", tfresource.SystemTagsToMap(v.SystemTags)) + } + + if v.TargetConnectionDetails != nil { + s.D.Set("target_connection_details", []interface{}{TargetPipelineConnectionDetailsToMap(v.TargetConnectionDetails)}) + } else { + s.D.Set("target_connection_details", nil) + } + + if v.TimeCreated != nil { + s.D.Set("time_created", v.TimeCreated.String()) + } + + if v.TimeUpdated != nil { + s.D.Set("time_updated", v.TimeUpdated.String()) + } + default: + log.Printf("[WARN] Received 'recipe_type' of unknown type %v", s.Res.Pipeline) + return nil + } + + return nil +} diff --git a/internal/service/golden_gate/golden_gate_pipeline_resource.go b/internal/service/golden_gate/golden_gate_pipeline_resource.go new file mode 100644 index 00000000000..5ff78b1ccf0 --- /dev/null +++ b/internal/service/golden_gate/golden_gate_pipeline_resource.go @@ -0,0 +1,1068 @@ +// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. +// Licensed under the Mozilla Public License v2.0 + +package golden_gate + +import ( + "context" + "fmt" + "log" + "strings" + "time" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/validation" + + oci_common "github.com/oracle/oci-go-sdk/v65/common" + oci_golden_gate "github.com/oracle/oci-go-sdk/v65/goldengate" + + "github.com/oracle/terraform-provider-oci/internal/client" + "github.com/oracle/terraform-provider-oci/internal/tfresource" +) + +func GoldenGatePipelineResource() *schema.Resource { + return &schema.Resource{ + Importer: &schema.ResourceImporter{ + State: schema.ImportStatePassthrough, + }, + Timeouts: tfresource.DefaultTimeout, + Create: createGoldenGatePipeline, + Read: readGoldenGatePipeline, + Update: updateGoldenGatePipeline, + Delete: deleteGoldenGatePipeline, + Schema: map[string]*schema.Schema{ + // Required + "compartment_id": { + Type: schema.TypeString, + Required: true, + }, + "display_name": { + Type: schema.TypeString, + Required: true, + }, + "license_model": { + Type: schema.TypeString, + Required: true, + }, + "recipe_type": { + Type: schema.TypeString, + Required: true, + DiffSuppressFunc: tfresource.EqualIgnoreCaseSuppressDiff, + ValidateFunc: validation.StringInSlice([]string{ + "ZERO_ETL", + }, true), + }, + "source_connection_details": { + Type: schema.TypeList, + Required: true, + ForceNew: true, + MaxItems: 1, + MinItems: 1, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + "connection_id": { + Type: schema.TypeString, + Required: true, + ForceNew: true, + }, + + // Optional + + // Computed + }, + }, + }, + "target_connection_details": { + Type: schema.TypeList, + Required: true, + ForceNew: true, + MaxItems: 1, + MinItems: 1, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + "connection_id": { + Type: schema.TypeString, + Required: true, + ForceNew: true, + }, + + // Optional + + // Computed + }, + }, + }, + + // Optional + "defined_tags": { + Type: schema.TypeMap, + Optional: true, + Computed: true, + DiffSuppressFunc: tfresource.DefinedTagsDiffSuppressFunction, + Elem: schema.TypeString, + }, + "description": { + Type: schema.TypeString, + Optional: true, + Computed: true, + }, + "freeform_tags": { + Type: schema.TypeMap, + Optional: true, + Computed: true, + Elem: schema.TypeString, + }, + "locks": { + Type: schema.TypeList, + Optional: true, + Computed: true, + ForceNew: true, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + "type": { + Type: schema.TypeString, + Required: true, + ForceNew: true, + }, + + // Optional + "message": { + Type: schema.TypeString, + Optional: true, + Computed: true, + ForceNew: true, + }, + + // Computed + }, + }, + }, + "process_options": { + Type: schema.TypeList, + Optional: true, + Computed: true, + MaxItems: 1, + MinItems: 1, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + "initial_data_load": { + Type: schema.TypeList, + Required: true, + MaxItems: 1, + MinItems: 1, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + "is_initial_load": { + Type: schema.TypeString, + Required: true, + }, + + // Optional + "action_on_existing_table": { + Type: schema.TypeString, + Optional: true, + Computed: true, + }, + + // Computed + }, + }, + }, + "replicate_schema_change": { + Type: schema.TypeList, + Required: true, + MaxItems: 1, + MinItems: 1, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + "can_replicate_schema_change": { + Type: schema.TypeString, + Required: true, + }, + + // Optional + "action_on_ddl_error": { + Type: schema.TypeString, + Optional: true, + Computed: true, + }, + "action_on_dml_error": { + Type: schema.TypeString, + Optional: true, + Computed: true, + }, + + // Computed + }, + }, + }, + "should_restart_on_failure": { + Type: schema.TypeString, + Required: true, + }, + + // Optional + + // Computed + }, + }, + }, + + // Computed + "cpu_core_count": { + Type: schema.TypeInt, + Computed: true, + }, + "is_auto_scaling_enabled": { + Type: schema.TypeBool, + Computed: true, + }, + "lifecycle_details": { + Type: schema.TypeString, + Computed: true, + }, + "lifecycle_sub_state": { + Type: schema.TypeString, + Computed: true, + }, + "mapping_rules": { + Type: schema.TypeList, + Computed: true, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + + // Optional + + // Computed + "mapping_type": { + Type: schema.TypeString, + Computed: true, + }, + "source": { + Type: schema.TypeString, + Computed: true, + }, + "target": { + Type: schema.TypeString, + Computed: true, + }, + }, + }, + }, + "state": { + Type: schema.TypeString, + Computed: true, + }, + "system_tags": { + Type: schema.TypeMap, + Computed: true, + Elem: schema.TypeString, + }, + "time_created": { + Type: schema.TypeString, + Computed: true, + }, + "time_last_recorded": { + Type: schema.TypeString, + Computed: true, + }, + "time_updated": { + Type: schema.TypeString, + Computed: true, + }, + }, + } +} + +func createGoldenGatePipeline(d *schema.ResourceData, m interface{}) error { + sync := &GoldenGatePipelineResourceCrud{} + sync.D = d + sync.Client = m.(*client.OracleClients).GoldenGateClient() + + return tfresource.CreateResource(d, sync) +} + +func readGoldenGatePipeline(d *schema.ResourceData, m interface{}) error { + sync := &GoldenGatePipelineResourceCrud{} + sync.D = d + sync.Client = m.(*client.OracleClients).GoldenGateClient() + + return tfresource.ReadResource(sync) +} + +func updateGoldenGatePipeline(d *schema.ResourceData, m interface{}) error { + sync := &GoldenGatePipelineResourceCrud{} + sync.D = d + sync.Client = m.(*client.OracleClients).GoldenGateClient() + + return tfresource.UpdateResource(d, sync) +} + +func deleteGoldenGatePipeline(d *schema.ResourceData, m interface{}) error { + sync := &GoldenGatePipelineResourceCrud{} + sync.D = d + sync.Client = m.(*client.OracleClients).GoldenGateClient() + sync.DisableNotFoundRetries = true + + return tfresource.DeleteResource(d, sync) +} + +type GoldenGatePipelineResourceCrud struct { + tfresource.BaseCrud + Client *oci_golden_gate.GoldenGateClient + Res *oci_golden_gate.Pipeline + DisableNotFoundRetries bool +} + +func (s *GoldenGatePipelineResourceCrud) ID() string { + pipeline := *s.Res + return *pipeline.GetId() +} + +func (s *GoldenGatePipelineResourceCrud) CreatedPending() []string { + return []string{ + string(oci_golden_gate.PipelineLifecycleStateCreating), + } +} + +func (s *GoldenGatePipelineResourceCrud) CreatedTarget() []string { + return []string{ + string(oci_golden_gate.PipelineLifecycleStateActive), + string(oci_golden_gate.PipelineLifecycleStateNeedsAttention), + } +} + +func (s *GoldenGatePipelineResourceCrud) DeletedPending() []string { + return []string{ + string(oci_golden_gate.PipelineLifecycleStateDeleting), + } +} + +func (s *GoldenGatePipelineResourceCrud) DeletedTarget() []string { + return []string{ + string(oci_golden_gate.PipelineLifecycleStateDeleted), + } +} + +func (s *GoldenGatePipelineResourceCrud) Create() error { + request := oci_golden_gate.CreatePipelineRequest{} + err := s.populateTopLevelPolymorphicCreatePipelineRequest(&request) + if err != nil { + return err + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "golden_gate") + + response, err := s.Client.CreatePipeline(context.Background(), request) + if err != nil { + return err + } + + workId := response.OpcWorkRequestId + var identifier *string + identifier = response.GetId() + if identifier != nil { + s.D.SetId(*identifier) + } + return s.getPipelineFromWorkRequest(workId, tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "golden_gate"), oci_golden_gate.ActionTypeCreated, s.D.Timeout(schema.TimeoutCreate)) +} + +func (s *GoldenGatePipelineResourceCrud) getPipelineFromWorkRequest(workId *string, retryPolicy *oci_common.RetryPolicy, + actionTypeEnum oci_golden_gate.ActionTypeEnum, timeout time.Duration) error { + + // Wait until it finishes + pipelineId, err := pipelineWaitForWorkRequest(workId, "pipeline", + actionTypeEnum, timeout, s.DisableNotFoundRetries, s.Client) + + if err != nil { + return err + } + s.D.SetId(*pipelineId) + + return s.Get() +} + +func pipelineWorkRequestShouldRetryFunc(timeout time.Duration) func(response oci_common.OCIOperationResponse) bool { + startTime := time.Now() + stopTime := startTime.Add(timeout) + return func(response oci_common.OCIOperationResponse) bool { + + // Stop after timeout has elapsed + if time.Now().After(stopTime) { + return false + } + + // Make sure we stop on default rules + if tfresource.ShouldRetry(response, false, "golden_gate", startTime) { + return true + } + + // Only stop if the time Finished is set + if workRequestResponse, ok := response.Response.(oci_golden_gate.GetWorkRequestResponse); ok { + return workRequestResponse.TimeFinished == nil + } + return false + } +} + +func pipelineWaitForWorkRequest(wId *string, entityType string, action oci_golden_gate.ActionTypeEnum, + timeout time.Duration, disableFoundRetries bool, client *oci_golden_gate.GoldenGateClient) (*string, error) { + retryPolicy := tfresource.GetRetryPolicy(disableFoundRetries, "golden_gate") + retryPolicy.ShouldRetryOperation = pipelineWorkRequestShouldRetryFunc(timeout) + + response := oci_golden_gate.GetWorkRequestResponse{} + stateConf := &resource.StateChangeConf{ + Pending: []string{ + string(oci_golden_gate.OperationStatusInProgress), + string(oci_golden_gate.OperationStatusAccepted), + }, + Target: []string{ + string(oci_golden_gate.OperationStatusSucceeded), + string(oci_golden_gate.OperationStatusFailed), + string(oci_golden_gate.OperationStatusCanceled), + }, + Refresh: func() (interface{}, string, error) { + var err error + response, err = client.GetWorkRequest(context.Background(), + oci_golden_gate.GetWorkRequestRequest{ + WorkRequestId: wId, + RequestMetadata: oci_common.RequestMetadata{ + RetryPolicy: retryPolicy, + }, + }) + wr := &response.WorkRequest + return wr, string(wr.Status), err + }, + Timeout: timeout, + } + if _, e := stateConf.WaitForState(); e != nil { + return nil, e + } + + var identifier *string + // The work request response contains an array of objects that finished the operation + for _, res := range response.Resources { + if strings.Contains(strings.ToLower(*res.EntityType), entityType) { + if res.ActionType == action { + identifier = res.Identifier + break + } + } + } + + // The workrequest may have failed, check for errors if identifier is not found or work failed or got cancelled + if identifier == nil || response.Status == oci_golden_gate.OperationStatusFailed || response.Status == oci_golden_gate.OperationStatusCanceled { + return nil, getErrorFromGoldenGatePipelineWorkRequest(client, wId, retryPolicy, entityType, action) + } + + return identifier, nil +} + +func getErrorFromGoldenGatePipelineWorkRequest(client *oci_golden_gate.GoldenGateClient, workId *string, retryPolicy *oci_common.RetryPolicy, entityType string, action oci_golden_gate.ActionTypeEnum) error { + response, err := client.ListWorkRequestErrors(context.Background(), + oci_golden_gate.ListWorkRequestErrorsRequest{ + WorkRequestId: workId, + RequestMetadata: oci_common.RequestMetadata{ + RetryPolicy: retryPolicy, + }, + }) + if err != nil { + return err + } + + allErrs := make([]string, 0) + for _, wrkErr := range response.Items { + allErrs = append(allErrs, *wrkErr.Message) + } + errorMessage := strings.Join(allErrs, "\n") + + workRequestErr := fmt.Errorf("work request did not succeed, workId: %s, entity: %s, action: %s. Message: %s", *workId, entityType, action, errorMessage) + + return workRequestErr +} + +func (s *GoldenGatePipelineResourceCrud) Get() error { + request := oci_golden_gate.GetPipelineRequest{} + + tmp := s.D.Id() + request.PipelineId = &tmp + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "golden_gate") + + response, err := s.Client.GetPipeline(context.Background(), request) + if err != nil { + return err + } + + s.Res = &response.Pipeline + return nil +} + +func (s *GoldenGatePipelineResourceCrud) Update() error { + if compartment, ok := s.D.GetOkExists("compartment_id"); ok && s.D.HasChange("compartment_id") { + oldRaw, newRaw := s.D.GetChange("compartment_id") + if newRaw != "" && oldRaw != "" { + err := s.updateCompartment(compartment) + if err != nil { + return err + } + } + } + request := oci_golden_gate.UpdatePipelineRequest{} + err := s.populateTopLevelPolymorphicUpdatePipelineRequest(&request) + if err != nil { + return err + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "golden_gate") + + response, err := s.Client.UpdatePipeline(context.Background(), request) + if err != nil { + return err + } + + workId := response.OpcWorkRequestId + return s.getPipelineFromWorkRequest(workId, tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "golden_gate"), oci_golden_gate.ActionTypeUpdated, s.D.Timeout(schema.TimeoutUpdate)) +} + +func (s *GoldenGatePipelineResourceCrud) Delete() error { + request := oci_golden_gate.DeletePipelineRequest{} + + if isLockOverride, ok := s.D.GetOkExists("is_lock_override"); ok { + tmp := isLockOverride.(bool) + request.IsLockOverride = &tmp + } + + tmp := s.D.Id() + request.PipelineId = &tmp + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "golden_gate") + + response, err := s.Client.DeletePipeline(context.Background(), request) + if err != nil { + return err + } + + workId := response.OpcWorkRequestId + // Wait until it finishes + _, delWorkRequestErr := pipelineWaitForWorkRequest(workId, "pipeline", + oci_golden_gate.ActionTypeDeleted, s.D.Timeout(schema.TimeoutDelete), s.DisableNotFoundRetries, s.Client) + return delWorkRequestErr +} + +func (s *GoldenGatePipelineResourceCrud) SetData() error { + switch v := (*s.Res).(type) { + case oci_golden_gate.ZeroEtlPipeline: + s.D.Set("recipe_type", "ZERO_ETL") + + mappingRules := []interface{}{} + for _, item := range v.MappingRules { + mappingRules = append(mappingRules, MappingRuleToMap(item)) + } + s.D.Set("mapping_rules", mappingRules) + + if v.ProcessOptions != nil { + s.D.Set("process_options", []interface{}{ProcessOptionsToMap(v.ProcessOptions)}) + } else { + s.D.Set("process_options", nil) + } + + if v.TimeLastRecorded != nil { + s.D.Set("time_last_recorded", v.TimeLastRecorded.Format(time.RFC3339Nano)) + } + + if v.CompartmentId != nil { + s.D.Set("compartment_id", *v.CompartmentId) + } + + if v.CpuCoreCount != nil { + s.D.Set("cpu_core_count", *v.CpuCoreCount) + } + + if v.DefinedTags != nil { + s.D.Set("defined_tags", tfresource.DefinedTagsToMap(v.DefinedTags)) + } + + if v.Description != nil { + s.D.Set("description", *v.Description) + } + + if v.DisplayName != nil { + s.D.Set("display_name", *v.DisplayName) + } + + s.D.Set("freeform_tags", v.FreeformTags) + + if v.Id != nil { + s.D.SetId(*v.Id) + } + + if v.IsAutoScalingEnabled != nil { + s.D.Set("is_auto_scaling_enabled", *v.IsAutoScalingEnabled) + } + + s.D.Set("license_model", v.LicenseModel) + + if v.LifecycleDetails != nil { + s.D.Set("lifecycle_details", *v.LifecycleDetails) + } + + s.D.Set("lifecycle_sub_state", v.LifecycleSubState) + + locks := []interface{}{} + for _, item := range v.Locks { + locks = append(locks, ResourceLockToMap(item)) + } + s.D.Set("locks", locks) + + if v.SourceConnectionDetails != nil { + s.D.Set("source_connection_details", []interface{}{SourcePipelineConnectionDetailsToMap(v.SourceConnectionDetails)}) + } else { + s.D.Set("source_connection_details", nil) + } + + s.D.Set("state", v.LifecycleState) + + if v.SystemTags != nil { + s.D.Set("system_tags", tfresource.SystemTagsToMap(v.SystemTags)) + } + + if v.TargetConnectionDetails != nil { + s.D.Set("target_connection_details", []interface{}{TargetPipelineConnectionDetailsToMap(v.TargetConnectionDetails)}) + } else { + s.D.Set("target_connection_details", nil) + } + + if v.TimeCreated != nil { + s.D.Set("time_created", v.TimeCreated.String()) + } + + if v.TimeUpdated != nil { + s.D.Set("time_updated", v.TimeUpdated.String()) + } + default: + log.Printf("[WARN] Received 'recipe_type' of unknown type %v", *s.Res) + return nil + } + return nil +} + +func (s *GoldenGatePipelineResourceCrud) mapToInitialDataLoad(fieldKeyFormat string) (oci_golden_gate.InitialDataLoad, error) { + result := oci_golden_gate.InitialDataLoad{} + + if actionOnExistingTable, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "action_on_existing_table")); ok { + result.ActionOnExistingTable = oci_golden_gate.InitialLoadActionEnum(actionOnExistingTable.(string)) + } + + if isInitialLoad, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "is_initial_load")); ok { + result.IsInitialLoad = oci_golden_gate.InitialDataLoadIsInitialLoadEnum(isInitialLoad.(string)) + } + + return result, nil +} + +func InitialDataLoadToMap(obj *oci_golden_gate.InitialDataLoad) map[string]interface{} { + result := map[string]interface{}{} + + result["action_on_existing_table"] = string(obj.ActionOnExistingTable) + + result["is_initial_load"] = string(obj.IsInitialLoad) + + return result +} + +func (s *GoldenGatePipelineResourceCrud) mapToMappingRule(fieldKeyFormat string) (oci_golden_gate.MappingRule, error) { + result := oci_golden_gate.MappingRule{} + + if mappingType, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "mapping_type")); ok { + result.MappingType = oci_golden_gate.MappingTypeEnum(mappingType.(string)) + } + + if source, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "source")); ok { + tmp := source.(string) + result.Source = &tmp + } + + if target, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "target")); ok { + tmp := target.(string) + result.Target = &tmp + } + + return result, nil +} + +func MappingRuleToMap(obj oci_golden_gate.MappingRule) map[string]interface{} { + result := map[string]interface{}{} + + result["mapping_type"] = string(obj.MappingType) + + if obj.Source != nil { + result["source"] = string(*obj.Source) + } + + if obj.Target != nil { + result["target"] = string(*obj.Target) + } + + return result +} + +func PipelineSummaryToMap(obj oci_golden_gate.PipelineSummary) map[string]interface{} { + result := map[string]interface{}{} + switch v := (obj).(type) { + case oci_golden_gate.ZeroEtlPipelineSummary: + result["recipe_type"] = "ZERO_ETL" + + if v.ProcessOptions != nil { + result["process_options"] = []interface{}{ProcessOptionsToMap(v.ProcessOptions)} + } + + if v.TimeLastRecorded != nil { + result["time_last_recorded"] = v.TimeLastRecorded.Format(time.RFC3339Nano) + } + default: + log.Printf("[WARN] Received 'recipe_type' of unknown type %v", obj) + return nil + } + + return result +} + +func (s *GoldenGatePipelineResourceCrud) mapToProcessOptions(fieldKeyFormat string) (oci_golden_gate.ProcessOptions, error) { + result := oci_golden_gate.ProcessOptions{} + + if initialDataLoad, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "initial_data_load")); ok { + if tmpList := initialDataLoad.([]interface{}); len(tmpList) > 0 { + fieldKeyFormatNextLevel := fmt.Sprintf("%s.%d.%%s", fmt.Sprintf(fieldKeyFormat, "initial_data_load"), 0) + tmp, err := s.mapToInitialDataLoad(fieldKeyFormatNextLevel) + if err != nil { + return result, fmt.Errorf("unable to convert initial_data_load, encountered error: %v", err) + } + result.InitialDataLoad = &tmp + } + } + + if replicateSchemaChange, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "replicate_schema_change")); ok { + if tmpList := replicateSchemaChange.([]interface{}); len(tmpList) > 0 { + fieldKeyFormatNextLevel := fmt.Sprintf("%s.%d.%%s", fmt.Sprintf(fieldKeyFormat, "replicate_schema_change"), 0) + tmp, err := s.mapToReplicateSchemaChange(fieldKeyFormatNextLevel) + if err != nil { + return result, fmt.Errorf("unable to convert replicate_schema_change, encountered error: %v", err) + } + result.ReplicateSchemaChange = &tmp + } + } + + if shouldRestartOnFailure, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "should_restart_on_failure")); ok { + result.ShouldRestartOnFailure = oci_golden_gate.ProcessOptionsShouldRestartOnFailureEnum(shouldRestartOnFailure.(string)) + } + + return result, nil +} + +func ProcessOptionsToMap(obj *oci_golden_gate.ProcessOptions) map[string]interface{} { + result := map[string]interface{}{} + + if obj.InitialDataLoad != nil { + result["initial_data_load"] = []interface{}{InitialDataLoadToMap(obj.InitialDataLoad)} + } + + if obj.ReplicateSchemaChange != nil { + result["replicate_schema_change"] = []interface{}{ReplicateSchemaChangeToMap(obj.ReplicateSchemaChange)} + } + + result["should_restart_on_failure"] = string(obj.ShouldRestartOnFailure) + + return result +} + +func (s *GoldenGatePipelineResourceCrud) mapToReplicateSchemaChange(fieldKeyFormat string) (oci_golden_gate.ReplicateSchemaChange, error) { + result := oci_golden_gate.ReplicateSchemaChange{} + + if actionOnDdlError, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "action_on_ddl_error")); ok { + result.ActionOnDdlError = oci_golden_gate.ReplicateDdlErrorActionEnum(actionOnDdlError.(string)) + } + + if actionOnDmlError, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "action_on_dml_error")); ok { + result.ActionOnDmlError = oci_golden_gate.ReplicateDmlErrorActionEnum(actionOnDmlError.(string)) + } + + if canReplicateSchemaChange, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "can_replicate_schema_change")); ok { + result.CanReplicateSchemaChange = oci_golden_gate.ReplicateSchemaChangeCanReplicateSchemaChangeEnum(canReplicateSchemaChange.(string)) + } + + return result, nil +} + +func ReplicateSchemaChangeToMap(obj *oci_golden_gate.ReplicateSchemaChange) map[string]interface{} { + result := map[string]interface{}{} + + result["action_on_ddl_error"] = string(obj.ActionOnDdlError) + + result["action_on_dml_error"] = string(obj.ActionOnDmlError) + + result["can_replicate_schema_change"] = string(obj.CanReplicateSchemaChange) + + return result +} + +func (s *GoldenGatePipelineResourceCrud) mapToResourceLock(fieldKeyFormat string) (oci_golden_gate.ResourceLock, error) { + result := oci_golden_gate.ResourceLock{} + + if message, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "message")); ok { + tmp := message.(string) + result.Message = &tmp + } + + if relatedResourceId, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "related_resource_id")); ok { + tmp := relatedResourceId.(string) + result.RelatedResourceId = &tmp + } + + if timeCreated, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "time_created")); ok { + tmp, err := time.Parse(time.RFC3339, timeCreated.(string)) + if err != nil { + return result, err + } + result.TimeCreated = &oci_common.SDKTime{Time: tmp} + } + + if type_, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "type")); ok { + result.Type = oci_golden_gate.ResourceLockTypeEnum(type_.(string)) + } + + return result, nil +} + +func (s *GoldenGatePipelineResourceCrud) mapToSourcePipelineConnectionDetails(fieldKeyFormat string) (oci_golden_gate.SourcePipelineConnectionDetails, error) { + result := oci_golden_gate.SourcePipelineConnectionDetails{} + + if connectionId, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "connection_id")); ok { + tmp := connectionId.(string) + result.ConnectionId = &tmp + } + + return result, nil +} + +func SourcePipelineConnectionDetailsToMap(obj *oci_golden_gate.SourcePipelineConnectionDetails) map[string]interface{} { + result := map[string]interface{}{} + + if obj.ConnectionId != nil { + result["connection_id"] = string(*obj.ConnectionId) + } + + return result +} + +func (s *GoldenGatePipelineResourceCrud) mapToTargetPipelineConnectionDetails(fieldKeyFormat string) (oci_golden_gate.TargetPipelineConnectionDetails, error) { + result := oci_golden_gate.TargetPipelineConnectionDetails{} + + if connectionId, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "connection_id")); ok { + tmp := connectionId.(string) + result.ConnectionId = &tmp + } + + return result, nil +} + +func TargetPipelineConnectionDetailsToMap(obj *oci_golden_gate.TargetPipelineConnectionDetails) map[string]interface{} { + result := map[string]interface{}{} + + if obj.ConnectionId != nil { + result["connection_id"] = string(*obj.ConnectionId) + } + + return result +} + +func (s *GoldenGatePipelineResourceCrud) populateTopLevelPolymorphicCreatePipelineRequest(request *oci_golden_gate.CreatePipelineRequest) error { + //discriminator + recipeTypeRaw, ok := s.D.GetOkExists("recipe_type") + var recipeType string + if ok { + recipeType = recipeTypeRaw.(string) + } else { + recipeType = "" // default value + } + switch strings.ToLower(recipeType) { + case strings.ToLower("ZERO_ETL"): + details := oci_golden_gate.CreateZeroEtlPipelineDetails{} + if processOptions, ok := s.D.GetOkExists("process_options"); ok { + if tmpList := processOptions.([]interface{}); len(tmpList) > 0 { + fieldKeyFormat := fmt.Sprintf("%s.%d.%%s", "process_options", 0) + tmp, err := s.mapToProcessOptions(fieldKeyFormat) + if err != nil { + return err + } + details.ProcessOptions = &tmp + } + } + if compartmentId, ok := s.D.GetOkExists("compartment_id"); ok { + tmp := compartmentId.(string) + details.CompartmentId = &tmp + } + if definedTags, ok := s.D.GetOkExists("defined_tags"); ok { + convertedDefinedTags, err := tfresource.MapToDefinedTags(definedTags.(map[string]interface{})) + if err != nil { + return err + } + details.DefinedTags = convertedDefinedTags + } + if description, ok := s.D.GetOkExists("description"); ok { + tmp := description.(string) + details.Description = &tmp + } + if displayName, ok := s.D.GetOkExists("display_name"); ok { + tmp := displayName.(string) + details.DisplayName = &tmp + } + if freeformTags, ok := s.D.GetOkExists("freeform_tags"); ok { + details.FreeformTags = tfresource.ObjectMapToStringMap(freeformTags.(map[string]interface{})) + } + if licenseModel, ok := s.D.GetOkExists("license_model"); ok { + details.LicenseModel = oci_golden_gate.LicenseModelEnum(licenseModel.(string)) + } + if locks, ok := s.D.GetOkExists("locks"); ok { + interfaces := locks.([]interface{}) + tmp := make([]oci_golden_gate.ResourceLock, len(interfaces)) + for i := range interfaces { + stateDataIndex := i + fieldKeyFormat := fmt.Sprintf("%s.%d.%%s", "locks", stateDataIndex) + converted, err := s.mapToResourceLock(fieldKeyFormat) + if err != nil { + return err + } + tmp[i] = converted + } + if len(tmp) != 0 || s.D.HasChange("locks") { + details.Locks = tmp + } + } + if sourceConnectionDetails, ok := s.D.GetOkExists("source_connection_details"); ok { + if tmpList := sourceConnectionDetails.([]interface{}); len(tmpList) > 0 { + fieldKeyFormat := fmt.Sprintf("%s.%d.%%s", "source_connection_details", 0) + tmp, err := s.mapToSourcePipelineConnectionDetails(fieldKeyFormat) + if err != nil { + return err + } + details.SourceConnectionDetails = &tmp + } + } + if targetConnectionDetails, ok := s.D.GetOkExists("target_connection_details"); ok { + if tmpList := targetConnectionDetails.([]interface{}); len(tmpList) > 0 { + fieldKeyFormat := fmt.Sprintf("%s.%d.%%s", "target_connection_details", 0) + tmp, err := s.mapToTargetPipelineConnectionDetails(fieldKeyFormat) + if err != nil { + return err + } + details.TargetConnectionDetails = &tmp + } + } + request.CreatePipelineDetails = details + default: + return fmt.Errorf("unknown recipe_type '%v' was specified", recipeType) + } + return nil +} + +func (s *GoldenGatePipelineResourceCrud) populateTopLevelPolymorphicUpdatePipelineRequest(request *oci_golden_gate.UpdatePipelineRequest) error { + //discriminator + recipeTypeRaw, ok := s.D.GetOkExists("recipe_type") + var recipeType string + if ok { + recipeType = recipeTypeRaw.(string) + } else { + recipeType = "" // default value + } + switch strings.ToLower(recipeType) { + case strings.ToLower("ZERO_ETL"): + details := oci_golden_gate.UpdateZeroEtlPipelineDetails{} + if mappingRules, ok := s.D.GetOkExists("mapping_rules"); ok { + interfaces := mappingRules.([]interface{}) + tmp := make([]oci_golden_gate.MappingRule, len(interfaces)) + for i := range interfaces { + stateDataIndex := i + fieldKeyFormat := fmt.Sprintf("%s.%d.%%s", "mapping_rules", stateDataIndex) + converted, err := s.mapToMappingRule(fieldKeyFormat) + if err != nil { + return err + } + tmp[i] = converted + } + if len(tmp) != 0 || s.D.HasChange("mapping_rules") { + details.MappingRules = tmp + } + } + if processOptions, ok := s.D.GetOkExists("process_options"); ok { + if tmpList := processOptions.([]interface{}); len(tmpList) > 0 { + fieldKeyFormat := fmt.Sprintf("%s.%d.%%s", "process_options", 0) + tmp, err := s.mapToProcessOptions(fieldKeyFormat) + if err != nil { + return err + } + details.ProcessOptions = &tmp + } + } + if definedTags, ok := s.D.GetOkExists("defined_tags"); ok { + convertedDefinedTags, err := tfresource.MapToDefinedTags(definedTags.(map[string]interface{})) + if err != nil { + return err + } + details.DefinedTags = convertedDefinedTags + } + if description, ok := s.D.GetOkExists("description"); ok { + tmp := description.(string) + details.Description = &tmp + } + if displayName, ok := s.D.GetOkExists("display_name"); ok { + tmp := displayName.(string) + details.DisplayName = &tmp + } + if freeformTags, ok := s.D.GetOkExists("freeform_tags"); ok { + details.FreeformTags = tfresource.ObjectMapToStringMap(freeformTags.(map[string]interface{})) + } + if licenseModel, ok := s.D.GetOkExists("license_model"); ok { + details.LicenseModel = oci_golden_gate.LicenseModelEnum(licenseModel.(string)) + } + tmp := s.D.Id() + request.PipelineId = &tmp + request.UpdatePipelineDetails = details + default: + return fmt.Errorf("unknown recipe_type '%v' was specified", recipeType) + } + return nil +} + +func (s *GoldenGatePipelineResourceCrud) updateCompartment(compartment interface{}) error { + changeCompartmentRequest := oci_golden_gate.ChangePipelineCompartmentRequest{} + + compartmentTmp := compartment.(string) + changeCompartmentRequest.CompartmentId = &compartmentTmp + + if isLockOverride, ok := s.D.GetOkExists("is_lock_override"); ok { + tmp := isLockOverride.(bool) + changeCompartmentRequest.IsLockOverride = &tmp + } + + idTmp := s.D.Id() + changeCompartmentRequest.PipelineId = &idTmp + + changeCompartmentRequest.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "golden_gate") + + response, err := s.Client.ChangePipelineCompartment(context.Background(), changeCompartmentRequest) + if err != nil { + return err + } + + workId := response.OpcWorkRequestId + return s.getPipelineFromWorkRequest(workId, tfresource.GetRetryPolicy(s.DisableNotFoundRetries, "golden_gate"), oci_golden_gate.ActionTypeUpdated, s.D.Timeout(schema.TimeoutUpdate)) +} diff --git a/internal/service/golden_gate/golden_gate_pipeline_running_processes_data_source.go b/internal/service/golden_gate/golden_gate_pipeline_running_processes_data_source.go new file mode 100644 index 00000000000..fd53620ed1b --- /dev/null +++ b/internal/service/golden_gate/golden_gate_pipeline_running_processes_data_source.go @@ -0,0 +1,172 @@ +// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. +// Licensed under the Mozilla Public License v2.0 + +package golden_gate + +import ( + "context" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" + oci_golden_gate "github.com/oracle/oci-go-sdk/v65/goldengate" + + "github.com/oracle/terraform-provider-oci/internal/client" + "github.com/oracle/terraform-provider-oci/internal/tfresource" +) + +func GoldenGatePipelineRunningProcessesDataSource() *schema.Resource { + return &schema.Resource{ + Read: readGoldenGatePipelineRunningProcesses, + Schema: map[string]*schema.Schema{ + "filter": tfresource.DataSourceFiltersSchema(), + "pipeline_id": { + Type: schema.TypeString, + Required: true, + }, + "pipeline_running_process_collection": { + Type: schema.TypeList, + Computed: true, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + + // Optional + + // Computed + "items": { + Type: schema.TypeList, + Computed: true, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + + // Optional + + // Computed + "last_record_lag_in_seconds": { + Type: schema.TypeFloat, + Computed: true, + }, + "name": { + Type: schema.TypeString, + Computed: true, + }, + "process_type": { + Type: schema.TypeString, + Computed: true, + }, + "status": { + Type: schema.TypeString, + Computed: true, + }, + "time_last_processed": { + Type: schema.TypeString, + Computed: true, + }, + }, + }, + }, + }, + }, + }, + }, + } +} + +func readGoldenGatePipelineRunningProcesses(d *schema.ResourceData, m interface{}) error { + sync := &GoldenGatePipelineRunningProcessesDataSourceCrud{} + sync.D = d + sync.Client = m.(*client.OracleClients).GoldenGateClient() + + return tfresource.ReadResource(sync) +} + +type GoldenGatePipelineRunningProcessesDataSourceCrud struct { + D *schema.ResourceData + Client *oci_golden_gate.GoldenGateClient + Res *oci_golden_gate.ListPipelineRunningProcessesResponse +} + +func (s *GoldenGatePipelineRunningProcessesDataSourceCrud) VoidState() { + s.D.SetId("") +} + +func (s *GoldenGatePipelineRunningProcessesDataSourceCrud) Get() error { + request := oci_golden_gate.ListPipelineRunningProcessesRequest{} + + if pipelineId, ok := s.D.GetOkExists("pipeline_id"); ok { + tmp := pipelineId.(string) + request.PipelineId = &tmp + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(false, "golden_gate") + + response, err := s.Client.ListPipelineRunningProcesses(context.Background(), request) + if err != nil { + return err + } + + s.Res = &response + request.Page = s.Res.OpcNextPage + + for request.Page != nil { + listResponse, err := s.Client.ListPipelineRunningProcesses(context.Background(), request) + if err != nil { + return err + } + + s.Res.Items = append(s.Res.Items, listResponse.Items...) + request.Page = listResponse.OpcNextPage + } + + return nil +} + +func (s *GoldenGatePipelineRunningProcessesDataSourceCrud) SetData() error { + if s.Res == nil { + return nil + } + + s.D.SetId(tfresource.GenerateDataSourceHashID("GoldenGatePipelineRunningProcessesDataSource-", GoldenGatePipelineRunningProcessesDataSource(), s.D)) + resources := []map[string]interface{}{} + pipelineRunningProcess := map[string]interface{}{} + + items := []interface{}{} + for _, item := range s.Res.Items { + items = append(items, PipelineRunningProcessSummaryToMap(item)) + } + pipelineRunningProcess["items"] = items + + if f, fOk := s.D.GetOkExists("filter"); fOk { + items = tfresource.ApplyFiltersInCollection(f.(*schema.Set), items, GoldenGatePipelineRunningProcessesDataSource().Schema["pipeline_running_process_collection"].Elem.(*schema.Resource).Schema) + pipelineRunningProcess["items"] = items + } + + resources = append(resources, pipelineRunningProcess) + if err := s.D.Set("pipeline_running_process_collection", resources); err != nil { + return err + } + + return nil +} + +func PipelineRunningProcessSummaryToMap(obj oci_golden_gate.PipelineRunningProcessSummary) map[string]interface{} { + result := map[string]interface{}{} + + if obj.LastRecordLagInSeconds != nil { + result["last_record_lag_in_seconds"] = float32(*obj.LastRecordLagInSeconds) + } + + if obj.Name != nil { + result["name"] = string(*obj.Name) + } + + result["process_type"] = string(obj.ProcessType) + + result["status"] = string(obj.Status) + + if obj.TimeLastProcessed != nil { + result["time_last_processed"] = obj.TimeLastProcessed.String() + } + + return result +} diff --git a/internal/service/golden_gate/golden_gate_pipeline_schema_tables_data_source.go b/internal/service/golden_gate/golden_gate_pipeline_schema_tables_data_source.go new file mode 100644 index 00000000000..3b94cd497f6 --- /dev/null +++ b/internal/service/golden_gate/golden_gate_pipeline_schema_tables_data_source.go @@ -0,0 +1,187 @@ +// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. +// Licensed under the Mozilla Public License v2.0 + +package golden_gate + +import ( + "context" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" + oci_golden_gate "github.com/oracle/oci-go-sdk/v65/goldengate" + + "github.com/oracle/terraform-provider-oci/internal/client" + "github.com/oracle/terraform-provider-oci/internal/tfresource" +) + +func GoldenGatePipelineSchemaTablesDataSource() *schema.Resource { + return &schema.Resource{ + Read: readGoldenGatePipelineSchemaTables, + Schema: map[string]*schema.Schema{ + "filter": tfresource.DataSourceFiltersSchema(), + "display_name": { + Type: schema.TypeString, + Optional: true, + }, + "pipeline_id": { + Type: schema.TypeString, + Required: true, + }, + "source_schema_name": { + Type: schema.TypeString, + Required: true, + }, + "target_schema_name": { + Type: schema.TypeString, + Required: true, + }, + "pipeline_schema_table_collection": { + Type: schema.TypeList, + Computed: true, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + + // Optional + + // Computed + "items": { + Type: schema.TypeList, + Computed: true, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + + // Optional + + // Computed + "source_table_name": { + Type: schema.TypeString, + Computed: true, + }, + "target_table_name": { + Type: schema.TypeString, + Computed: true, + }, + }, + }, + }, + "source_schema_name": { + Type: schema.TypeString, + Computed: true, + }, + "target_schema_name": { + Type: schema.TypeString, + Computed: true, + }, + }, + }, + }, + }, + } +} + +func readGoldenGatePipelineSchemaTables(d *schema.ResourceData, m interface{}) error { + sync := &GoldenGatePipelineSchemaTablesDataSourceCrud{} + sync.D = d + sync.Client = m.(*client.OracleClients).GoldenGateClient() + + return tfresource.ReadResource(sync) +} + +type GoldenGatePipelineSchemaTablesDataSourceCrud struct { + D *schema.ResourceData + Client *oci_golden_gate.GoldenGateClient + Res *oci_golden_gate.ListPipelineSchemaTablesResponse +} + +func (s *GoldenGatePipelineSchemaTablesDataSourceCrud) VoidState() { + s.D.SetId("") +} + +func (s *GoldenGatePipelineSchemaTablesDataSourceCrud) Get() error { + request := oci_golden_gate.ListPipelineSchemaTablesRequest{} + + if displayName, ok := s.D.GetOkExists("display_name"); ok { + tmp := displayName.(string) + request.DisplayName = &tmp + } + + if pipelineId, ok := s.D.GetOkExists("pipeline_id"); ok { + tmp := pipelineId.(string) + request.PipelineId = &tmp + } + + if sourceSchemaName, ok := s.D.GetOkExists("source_schema_name"); ok { + tmp := sourceSchemaName.(string) + request.SourceSchemaName = &tmp + } + + if targetSchemaName, ok := s.D.GetOkExists("target_schema_name"); ok { + tmp := targetSchemaName.(string) + request.TargetSchemaName = &tmp + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(false, "golden_gate") + + response, err := s.Client.ListPipelineSchemaTables(context.Background(), request) + if err != nil { + return err + } + + s.Res = &response + request.Page = s.Res.OpcNextPage + + for request.Page != nil { + listResponse, err := s.Client.ListPipelineSchemaTables(context.Background(), request) + if err != nil { + return err + } + + s.Res.Items = append(s.Res.Items, listResponse.Items...) + request.Page = listResponse.OpcNextPage + } + + return nil +} + +func (s *GoldenGatePipelineSchemaTablesDataSourceCrud) SetData() error { + if s.Res == nil { + return nil + } + + s.D.SetId(tfresource.GenerateDataSourceHashID("GoldenGatePipelineSchemaTablesDataSource-", GoldenGatePipelineSchemaTablesDataSource(), s.D)) + resources := []map[string]interface{}{} + pipelineSchemaTable := map[string]interface{}{} + + items := []interface{}{} + for _, item := range s.Res.Items { + items = append(items, PipelineSchemaTableSummaryToMap(item)) + } + pipelineSchemaTable["items"] = items + + if f, fOk := s.D.GetOkExists("filter"); fOk { + items = tfresource.ApplyFiltersInCollection(f.(*schema.Set), items, GoldenGatePipelineSchemaTablesDataSource().Schema["pipeline_schema_table_collection"].Elem.(*schema.Resource).Schema) + pipelineSchemaTable["items"] = items + } + + resources = append(resources, pipelineSchemaTable) + if err := s.D.Set("pipeline_schema_table_collection", resources); err != nil { + return err + } + + return nil +} + +func PipelineSchemaTableSummaryToMap(obj oci_golden_gate.PipelineSchemaTableSummary) map[string]interface{} { + result := map[string]interface{}{} + + if obj.SourceTableName != nil { + result["source_table_name"] = string(*obj.SourceTableName) + } + + if obj.TargetTableName != nil { + result["target_table_name"] = string(*obj.TargetTableName) + } + + return result +} diff --git a/internal/service/golden_gate/golden_gate_pipeline_schemas_data_source.go b/internal/service/golden_gate/golden_gate_pipeline_schemas_data_source.go new file mode 100644 index 00000000000..435c9c30884 --- /dev/null +++ b/internal/service/golden_gate/golden_gate_pipeline_schemas_data_source.go @@ -0,0 +1,161 @@ +// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. +// Licensed under the Mozilla Public License v2.0 + +package golden_gate + +import ( + "context" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" + oci_golden_gate "github.com/oracle/oci-go-sdk/v65/goldengate" + + "github.com/oracle/terraform-provider-oci/internal/client" + "github.com/oracle/terraform-provider-oci/internal/tfresource" +) + +func GoldenGatePipelineSchemasDataSource() *schema.Resource { + return &schema.Resource{ + Read: readGoldenGatePipelineSchemas, + Schema: map[string]*schema.Schema{ + "filter": tfresource.DataSourceFiltersSchema(), + "display_name": { + Type: schema.TypeString, + Optional: true, + }, + "pipeline_id": { + Type: schema.TypeString, + Required: true, + }, + "pipeline_schema_collection": { + Type: schema.TypeList, + Computed: true, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + + // Optional + + // Computed + "items": { + Type: schema.TypeList, + Computed: true, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + + // Optional + + // Computed + "source_schema_name": { + Type: schema.TypeString, + Computed: true, + }, + "target_schema_name": { + Type: schema.TypeString, + Computed: true, + }, + }, + }, + }, + }, + }, + }, + }, + } +} + +func readGoldenGatePipelineSchemas(d *schema.ResourceData, m interface{}) error { + sync := &GoldenGatePipelineSchemasDataSourceCrud{} + sync.D = d + sync.Client = m.(*client.OracleClients).GoldenGateClient() + + return tfresource.ReadResource(sync) +} + +type GoldenGatePipelineSchemasDataSourceCrud struct { + D *schema.ResourceData + Client *oci_golden_gate.GoldenGateClient + Res *oci_golden_gate.ListPipelineSchemasResponse +} + +func (s *GoldenGatePipelineSchemasDataSourceCrud) VoidState() { + s.D.SetId("") +} + +func (s *GoldenGatePipelineSchemasDataSourceCrud) Get() error { + request := oci_golden_gate.ListPipelineSchemasRequest{} + + if displayName, ok := s.D.GetOkExists("display_name"); ok { + tmp := displayName.(string) + request.DisplayName = &tmp + } + + if pipelineId, ok := s.D.GetOkExists("pipeline_id"); ok { + tmp := pipelineId.(string) + request.PipelineId = &tmp + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(false, "golden_gate") + + response, err := s.Client.ListPipelineSchemas(context.Background(), request) + if err != nil { + return err + } + + s.Res = &response + request.Page = s.Res.OpcNextPage + + for request.Page != nil { + listResponse, err := s.Client.ListPipelineSchemas(context.Background(), request) + if err != nil { + return err + } + + s.Res.Items = append(s.Res.Items, listResponse.Items...) + request.Page = listResponse.OpcNextPage + } + + return nil +} + +func (s *GoldenGatePipelineSchemasDataSourceCrud) SetData() error { + if s.Res == nil { + return nil + } + + s.D.SetId(tfresource.GenerateDataSourceHashID("GoldenGatePipelineSchemasDataSource-", GoldenGatePipelineSchemasDataSource(), s.D)) + resources := []map[string]interface{}{} + pipelineSchema := map[string]interface{}{} + + items := []interface{}{} + for _, item := range s.Res.Items { + items = append(items, PipelineSchemaSummaryToMap(item)) + } + pipelineSchema["items"] = items + + if f, fOk := s.D.GetOkExists("filter"); fOk { + items = tfresource.ApplyFiltersInCollection(f.(*schema.Set), items, GoldenGatePipelineSchemasDataSource().Schema["pipeline_schema_collection"].Elem.(*schema.Resource).Schema) + pipelineSchema["items"] = items + } + + resources = append(resources, pipelineSchema) + if err := s.D.Set("pipeline_schema_collection", resources); err != nil { + return err + } + + return nil +} + +func PipelineSchemaSummaryToMap(obj oci_golden_gate.PipelineSchemaSummary) map[string]interface{} { + result := map[string]interface{}{} + + if obj.SourceSchemaName != nil { + result["source_schema_name"] = string(*obj.SourceSchemaName) + } + + if obj.TargetSchemaName != nil { + result["target_schema_name"] = string(*obj.TargetSchemaName) + } + + return result +} diff --git a/internal/service/golden_gate/golden_gate_pipelines_data_source.go b/internal/service/golden_gate/golden_gate_pipelines_data_source.go new file mode 100644 index 00000000000..7ab760a53b8 --- /dev/null +++ b/internal/service/golden_gate/golden_gate_pipelines_data_source.go @@ -0,0 +1,143 @@ +// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. +// Licensed under the Mozilla Public License v2.0 + +package golden_gate + +import ( + "context" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" + oci_golden_gate "github.com/oracle/oci-go-sdk/v65/goldengate" + + "github.com/oracle/terraform-provider-oci/internal/client" + "github.com/oracle/terraform-provider-oci/internal/tfresource" +) + +func GoldenGatePipelinesDataSource() *schema.Resource { + return &schema.Resource{ + Read: readGoldenGatePipelines, + Schema: map[string]*schema.Schema{ + "filter": tfresource.DataSourceFiltersSchema(), + "compartment_id": { + Type: schema.TypeString, + Required: true, + }, + "display_name": { + Type: schema.TypeString, + Optional: true, + }, + "lifecycle_sub_state": { + Type: schema.TypeString, + Optional: true, + }, + "state": { + Type: schema.TypeString, + Optional: true, + }, + "pipeline_collection": { + Type: schema.TypeList, + Computed: true, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + + "items": { + Type: schema.TypeList, + Computed: true, + Elem: tfresource.GetDataSourceItemSchema(GoldenGatePipelineResource()), + }, + }, + }, + }, + }, + } +} + +func readGoldenGatePipelines(d *schema.ResourceData, m interface{}) error { + sync := &GoldenGatePipelinesDataSourceCrud{} + sync.D = d + sync.Client = m.(*client.OracleClients).GoldenGateClient() + + return tfresource.ReadResource(sync) +} + +type GoldenGatePipelinesDataSourceCrud struct { + D *schema.ResourceData + Client *oci_golden_gate.GoldenGateClient + Res *oci_golden_gate.ListPipelinesResponse +} + +func (s *GoldenGatePipelinesDataSourceCrud) VoidState() { + s.D.SetId("") +} + +func (s *GoldenGatePipelinesDataSourceCrud) Get() error { + request := oci_golden_gate.ListPipelinesRequest{} + + if compartmentId, ok := s.D.GetOkExists("compartment_id"); ok { + tmp := compartmentId.(string) + request.CompartmentId = &tmp + } + + if displayName, ok := s.D.GetOkExists("display_name"); ok { + tmp := displayName.(string) + request.DisplayName = &tmp + } + + if lifecycleSubState, ok := s.D.GetOkExists("lifecycle_sub_state"); ok { + request.LifecycleSubState = oci_golden_gate.ListPipelinesLifecycleSubStateEnum(lifecycleSubState.(string)) + } + + if state, ok := s.D.GetOkExists("state"); ok { + request.LifecycleState = oci_golden_gate.PipelineLifecycleStateEnum(state.(string)) + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(false, "golden_gate") + + response, err := s.Client.ListPipelines(context.Background(), request) + if err != nil { + return err + } + + s.Res = &response + request.Page = s.Res.OpcNextPage + + for request.Page != nil { + listResponse, err := s.Client.ListPipelines(context.Background(), request) + if err != nil { + return err + } + + s.Res.Items = append(s.Res.Items, listResponse.Items...) + request.Page = listResponse.OpcNextPage + } + + return nil +} + +func (s *GoldenGatePipelinesDataSourceCrud) SetData() error { + if s.Res == nil { + return nil + } + + s.D.SetId(tfresource.GenerateDataSourceHashID("GoldenGatePipelinesDataSource-", GoldenGatePipelinesDataSource(), s.D)) + resources := []map[string]interface{}{} + pipeline := map[string]interface{}{} + + items := []interface{}{} + for _, item := range s.Res.Items { + items = append(items, PipelineSummaryToMap(item)) + } + pipeline["items"] = items + + if f, fOk := s.D.GetOkExists("filter"); fOk { + items = tfresource.ApplyFiltersInCollection(f.(*schema.Set), items, GoldenGatePipelinesDataSource().Schema["pipeline_collection"].Elem.(*schema.Resource).Schema) + pipeline["items"] = items + } + + resources = append(resources, pipeline) + if err := s.D.Set("pipeline_collection", resources); err != nil { + return err + } + + return nil +} diff --git a/internal/service/golden_gate/golden_gate_recipes_data_source.go b/internal/service/golden_gate/golden_gate_recipes_data_source.go new file mode 100644 index 00000000000..21f2dfd4e0f --- /dev/null +++ b/internal/service/golden_gate/golden_gate_recipes_data_source.go @@ -0,0 +1,201 @@ +// Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved. +// Licensed under the Mozilla Public License v2.0 + +package golden_gate + +import ( + "context" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" + oci_golden_gate "github.com/oracle/oci-go-sdk/v65/goldengate" + + "github.com/oracle/terraform-provider-oci/internal/client" + "github.com/oracle/terraform-provider-oci/internal/tfresource" +) + +func GoldenGateRecipesDataSource() *schema.Resource { + return &schema.Resource{ + Read: readGoldenGateRecipes, + Schema: map[string]*schema.Schema{ + "filter": tfresource.DataSourceFiltersSchema(), + "compartment_id": { + Type: schema.TypeString, + Required: true, + }, + "display_name": { + Type: schema.TypeString, + Optional: true, + }, + "recipe_type": { + Type: schema.TypeString, + Optional: true, + }, + "recipe_summary_collection": { + Type: schema.TypeList, + Computed: true, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + + // Optional + + // Computed + "items": { + Type: schema.TypeList, + Computed: true, + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + // Required + + // Optional + + // Computed + "description": { + Type: schema.TypeString, + Computed: true, + }, + "display_name": { + Type: schema.TypeString, + Computed: true, + }, + "name": { + Type: schema.TypeString, + Computed: true, + }, + "recipe_type": { + Type: schema.TypeString, + Computed: true, + }, + "supported_source_technology_types": { + Type: schema.TypeList, + Computed: true, + Elem: &schema.Schema{ + Type: schema.TypeString, + }, + }, + "supported_target_technology_types": { + Type: schema.TypeList, + Computed: true, + Elem: &schema.Schema{ + Type: schema.TypeString, + }, + }, + }, + }, + }, + }, + }, + }, + }, + } +} + +func readGoldenGateRecipes(d *schema.ResourceData, m interface{}) error { + sync := &GoldenGateRecipesDataSourceCrud{} + sync.D = d + sync.Client = m.(*client.OracleClients).GoldenGateClient() + + return tfresource.ReadResource(sync) +} + +type GoldenGateRecipesDataSourceCrud struct { + D *schema.ResourceData + Client *oci_golden_gate.GoldenGateClient + Res *oci_golden_gate.ListRecipesResponse +} + +func (s *GoldenGateRecipesDataSourceCrud) VoidState() { + s.D.SetId("") +} + +func (s *GoldenGateRecipesDataSourceCrud) Get() error { + request := oci_golden_gate.ListRecipesRequest{} + + if compartmentId, ok := s.D.GetOkExists("compartment_id"); ok { + tmp := compartmentId.(string) + request.CompartmentId = &tmp + } + + if displayName, ok := s.D.GetOkExists("display_name"); ok { + tmp := displayName.(string) + request.DisplayName = &tmp + } + + if recipeType, ok := s.D.GetOkExists("recipe_type"); ok { + request.RecipeType = oci_golden_gate.ListRecipesRecipeTypeEnum(recipeType.(string)) + } + + request.RequestMetadata.RetryPolicy = tfresource.GetRetryPolicy(false, "golden_gate") + + response, err := s.Client.ListRecipes(context.Background(), request) + if err != nil { + return err + } + + s.Res = &response + request.Page = s.Res.OpcNextPage + + for request.Page != nil { + listResponse, err := s.Client.ListRecipes(context.Background(), request) + if err != nil { + return err + } + + s.Res.Items = append(s.Res.Items, listResponse.Items...) + request.Page = listResponse.OpcNextPage + } + + return nil +} + +func (s *GoldenGateRecipesDataSourceCrud) SetData() error { + if s.Res == nil { + return nil + } + + s.D.SetId(tfresource.GenerateDataSourceHashID("GoldenGateRecipesDataSource-", GoldenGateRecipesDataSource(), s.D)) + resources := []map[string]interface{}{} + recipe := map[string]interface{}{} + + items := []interface{}{} + for _, item := range s.Res.Items { + items = append(items, RecipeSummaryToMap(item)) + } + recipe["items"] = items + + if f, fOk := s.D.GetOkExists("filter"); fOk { + items = tfresource.ApplyFiltersInCollection(f.(*schema.Set), items, GoldenGateRecipesDataSource().Schema["recipe_summary_collection"].Elem.(*schema.Resource).Schema) + recipe["items"] = items + } + + resources = append(resources, recipe) + if err := s.D.Set("recipe_summary_collection", resources); err != nil { + return err + } + + return nil +} + +func RecipeSummaryToMap(obj oci_golden_gate.RecipeSummary) map[string]interface{} { + result := map[string]interface{}{} + + if obj.Description != nil { + result["description"] = string(*obj.Description) + } + + if obj.DisplayName != nil { + result["display_name"] = string(*obj.DisplayName) + } + + if obj.Name != nil { + result["name"] = string(*obj.Name) + } + + result["recipe_type"] = string(obj.RecipeType) + + result["supported_source_technology_types"] = obj.SupportedSourceTechnologyTypes + + result["supported_target_technology_types"] = obj.SupportedTargetTechnologyTypes + + return result +} diff --git a/internal/service/golden_gate/register_datasource.go b/internal/service/golden_gate/register_datasource.go index e07793e87d1..777716e1744 100644 --- a/internal/service/golden_gate/register_datasource.go +++ b/internal/service/golden_gate/register_datasource.go @@ -26,6 +26,12 @@ func RegisterDatasource() { tfresource.RegisterDatasource("oci_golden_gate_deployments", GoldenGateDeploymentsDataSource()) tfresource.RegisterDatasource("oci_golden_gate_message", GoldenGateMessageDataSource()) tfresource.RegisterDatasource("oci_golden_gate_messages", GoldenGateMessagesDataSource()) + tfresource.RegisterDatasource("oci_golden_gate_pipeline", GoldenGatePipelineDataSource()) + tfresource.RegisterDatasource("oci_golden_gate_pipeline_running_processes", GoldenGatePipelineRunningProcessesDataSource()) + tfresource.RegisterDatasource("oci_golden_gate_pipeline_schema_tables", GoldenGatePipelineSchemaTablesDataSource()) + tfresource.RegisterDatasource("oci_golden_gate_pipeline_schemas", GoldenGatePipelineSchemasDataSource()) + tfresource.RegisterDatasource("oci_golden_gate_pipelines", GoldenGatePipelinesDataSource()) + tfresource.RegisterDatasource("oci_golden_gate_recipes", GoldenGateRecipesDataSource()) tfresource.RegisterDatasource("oci_golden_gate_trail_file", GoldenGateTrailFileDataSource()) tfresource.RegisterDatasource("oci_golden_gate_trail_files", GoldenGateTrailFilesDataSource()) tfresource.RegisterDatasource("oci_golden_gate_trail_sequence", GoldenGateTrailSequenceDataSource()) diff --git a/internal/service/golden_gate/register_resource.go b/internal/service/golden_gate/register_resource.go index c7ffb0ade0a..854aab32518 100644 --- a/internal/service/golden_gate/register_resource.go +++ b/internal/service/golden_gate/register_resource.go @@ -12,4 +12,5 @@ func RegisterResource() { tfresource.RegisterResource("oci_golden_gate_deployment", GoldenGateDeploymentResource()) tfresource.RegisterResource("oci_golden_gate_deployment_backup", GoldenGateDeploymentBackupResource()) tfresource.RegisterResource("oci_golden_gate_deployment_certificate", GoldenGateDeploymentCertificateResource()) + tfresource.RegisterResource("oci_golden_gate_pipeline", GoldenGatePipelineResource()) } diff --git a/website/docs/d/golden_gate_pipeline.html.markdown b/website/docs/d/golden_gate_pipeline.html.markdown new file mode 100644 index 00000000000..7ff08e92210 --- /dev/null +++ b/website/docs/d/golden_gate_pipeline.html.markdown @@ -0,0 +1,75 @@ +--- +subcategory: "Golden Gate" +layout: "oci" +page_title: "Oracle Cloud Infrastructure: oci_golden_gate_pipeline" +sidebar_current: "docs-oci-datasource-golden_gate-pipeline" +description: |- + Provides details about a specific Pipeline in Oracle Cloud Infrastructure Golden Gate service +--- + +# Data Source: oci_golden_gate_pipeline +This data source provides details about a specific Pipeline resource in Oracle Cloud Infrastructure Golden Gate service. + +Retrieves a Pipeline details. + + +## Example Usage + +```hcl +data "oci_golden_gate_pipeline" "test_pipeline" { + #Required + pipeline_id = oci_golden_gate_pipeline.test_pipeline.id +} +``` + +## Argument Reference + +The following arguments are supported: + +* `pipeline_id` - (Required) The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the pipeline created. + + +## Attributes Reference + +The following attributes are exported: + +* `compartment_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment being referenced. +* `cpu_core_count` - The Minimum number of OCPUs to be made available for this Deployment. +* `defined_tags` - Tags defined for this resource. Each key is predefined and scoped to a namespace. Example: `{"foo-namespace.bar-key": "value"}` +* `description` - Metadata about this specific object. +* `display_name` - An object's Display Name. +* `freeform_tags` - A simple key-value pair that is applied without any predefined name, type, or scope. Exists for cross-compatibility only. Example: `{"bar-key": "value"}` +* `id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the pipeline. This option applies when retrieving a pipeline. +* `is_auto_scaling_enabled` - Indicates if auto scaling is enabled for the Deployment's CPU core count. +* `license_model` - The Oracle license model that applies to a Deployment. +* `lifecycle_details` - Describes the object's current state in detail. For example, it can be used to provide actionable information for a resource in a Failed state. +* `lifecycle_sub_state` - Possible lifecycle substates when retrieving a pipeline. +* `locks` - Locks associated with this resource. + * `message` - A message added by the creator of the lock. This is typically used to give an indication of why the resource is locked. + * `related_resource_id` - The id of the resource that is locking this resource. Indicates that deleting this resource will remove the lock. + * `time_created` - When the lock was created. + * `type` - Type of the lock. +* `mapping_rules` - Mapping for source/target schema/tables for the pipeline data replication. + * `mapping_type` - Defines the exclude/include rules of source and target schemas and tables when replicating from source to target. This option applies when creating and updating a pipeline. + * `source` - The source schema/table combination for replication to target. + * `target` - The target schema/table combination for replication from the source. +* `process_options` - Required pipeline options to configure the replication process (Extract or Replicat). + * `initial_data_load` - Options required for the pipeline Initial Data Load. If enabled, copies existing data from source to target before replication. + * `action_on_existing_table` - Action upon existing tables in target when initial Data Load is set i.e., isInitialLoad=true. + * `is_initial_load` - If ENABLED, then existing source data is also synchronized to the target when creating or updating the pipeline. + * `replicate_schema_change` - Options required for pipeline Initial Data Load. If enabled, copies existing data from source to target before replication. + * `action_on_ddl_error` - Action upon DDL Error (active only if 'Replicate schema changes (DDL)' is selected) i.e canReplicateSchemaChange=true + * `action_on_dml_error` - Action upon DML Error (active only if 'Replicate schema changes (DDL)' is selected) i.e canReplicateSchemaChange=true + * `can_replicate_schema_change` - If ENABLED, then addition or removal of schema is also replicated, apart from individual tables and records when creating or updating the pipeline. + * `should_restart_on_failure` - If ENABLED, then the replication process restarts itself upon failure. This option applies when creating or updating a pipeline. +* `recipe_type` - The type of the recipe +* `source_connection_details` - The source connection details for creating a pipeline. + * `connection_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the connection being referenced. +* `state` - Lifecycle state of the pipeline. +* `system_tags` - The system tags associated with this resource, if any. The system tags are set by Oracle Cloud Infrastructure services. Each key is predefined and scoped to namespaces. For more information, see [Resource Tags](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). Example: `{orcl-cloud: {free-tier-retain: true}}` +* `target_connection_details` - The target connection details for creating a pipeline. + * `connection_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the connection being referenced. +* `time_created` - The time the resource was created. The format is defined by [RFC3339](https://tools.ietf.org/html/rfc3339), such as `2016-08-25T21:10:29.600Z`. +* `time_last_recorded` - When the resource was last updated. This option applies when retrieving a pipeline. The format is defined by [RFC3339](https://tools.ietf.org/html/rfc3339), such as `2024-07-25T21:10:29.600Z`. +* `time_updated` - The time the resource was last updated. The format is defined by [RFC3339](https://tools.ietf.org/html/rfc3339), such as `2016-08-25T21:10:29.600Z`. + diff --git a/website/docs/d/golden_gate_pipeline_running_processes.html.markdown b/website/docs/d/golden_gate_pipeline_running_processes.html.markdown new file mode 100644 index 00000000000..37f6e340cf6 --- /dev/null +++ b/website/docs/d/golden_gate_pipeline_running_processes.html.markdown @@ -0,0 +1,48 @@ +--- +subcategory: "Golden Gate" +layout: "oci" +page_title: "Oracle Cloud Infrastructure: oci_golden_gate_pipeline_running_processes" +sidebar_current: "docs-oci-datasource-golden_gate-pipeline_running_processes" +description: |- + Provides the list of Pipeline Running Processes in Oracle Cloud Infrastructure Golden Gate service +--- + +# Data Source: oci_golden_gate_pipeline_running_processes +This data source provides the list of Pipeline Running Processes in Oracle Cloud Infrastructure Golden Gate service. + +Retrieves a Pipeline's running replication process's status like extracts/replicats. + + +## Example Usage + +```hcl +data "oci_golden_gate_pipeline_running_processes" "test_pipeline_running_processes" { + #Required + pipeline_id = oci_golden_gate_pipeline.test_pipeline.id +} +``` + +## Argument Reference + +The following arguments are supported: + +* `pipeline_id` - (Required) The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the pipeline created. + + +## Attributes Reference + +The following attributes are exported: + +* `pipeline_running_process_collection` - The list of pipeline_running_process_collection. + +### PipelineRunningProcess Reference + +The following attributes are exported: + +* `items` - The list of replication processes and their details. + * `last_record_lag_in_seconds` - The latency, in seconds, of a process running in a replication. This option applies when retrieving running processes. + * `name` - An object's Display Name. + * `process_type` - The type of process running in a replication. For example, Extract or Replicat. This option applies when retrieving running processes. + * `status` - The status of the Extract or Replicat process. This option applies when retrieving running processes. + * `time_last_processed` - The date and time the last record was processed by an Extract or Replicat. This option applies when retrieving running processes. The format is defined by [RFC3339](https://tools.ietf.org/html/rfc3339), such as `2024-07-25T21:10:29.600Z`. + diff --git a/website/docs/d/golden_gate_pipeline_schema_tables.html.markdown b/website/docs/d/golden_gate_pipeline_schema_tables.html.markdown new file mode 100644 index 00000000000..ed513eabcfc --- /dev/null +++ b/website/docs/d/golden_gate_pipeline_schema_tables.html.markdown @@ -0,0 +1,55 @@ +--- +subcategory: "Golden Gate" +layout: "oci" +page_title: "Oracle Cloud Infrastructure: oci_golden_gate_pipeline_schema_tables" +sidebar_current: "docs-oci-datasource-golden_gate-pipeline_schema_tables" +description: |- + Provides the list of Pipeline Schema Tables in Oracle Cloud Infrastructure Golden Gate service +--- + +# Data Source: oci_golden_gate_pipeline_schema_tables +This data source provides the list of Pipeline Schema Tables in Oracle Cloud Infrastructure Golden Gate service. + +Returns an array of tables under the given schemas of the pipeline for given source and target schemas passed as query params. + + +## Example Usage + +```hcl +data "oci_golden_gate_pipeline_schema_tables" "test_pipeline_schema_tables" { + #Required + pipeline_id = oci_golden_gate_pipeline.test_pipeline.id + source_schema_name = var.pipeline_schema_table_source_schema_name + target_schema_name = var.pipeline_schema_table_target_schema_name + + #Optional + display_name = var.pipeline_schema_table_display_name +} +``` + +## Argument Reference + +The following arguments are supported: + +* `display_name` - (Optional) A filter to return only the resources that match the entire 'displayName' given. +* `pipeline_id` - (Required) The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the pipeline created. +* `source_schema_name` - (Required) Name of the source schema obtained from get schema endpoint of the created pipeline. +* `target_schema_name` - (Required) Name of the target schema obtained from get schema endpoint of the created pipeline. + + +## Attributes Reference + +The following attributes are exported: + +* `pipeline_schema_table_collection` - The list of pipeline_schema_table_collection. + +### PipelineSchemaTable Reference + +The following attributes are exported: + +* `items` - Array of source or target schema tables of a pipeline's assigned connection. + * `source_table_name` - The table name from the schema of database connection. + * `target_table_name` - The table name from the schema of database connection. +* `source_schema_name` - The schema name from the database connection. +* `target_schema_name` - The schema name from the database connection. + diff --git a/website/docs/d/golden_gate_pipeline_schemas.html.markdown b/website/docs/d/golden_gate_pipeline_schemas.html.markdown new file mode 100644 index 00000000000..f59e56844ba --- /dev/null +++ b/website/docs/d/golden_gate_pipeline_schemas.html.markdown @@ -0,0 +1,49 @@ +--- +subcategory: "Golden Gate" +layout: "oci" +page_title: "Oracle Cloud Infrastructure: oci_golden_gate_pipeline_schemas" +sidebar_current: "docs-oci-datasource-golden_gate-pipeline_schemas" +description: |- + Provides the list of Pipeline Schemas in Oracle Cloud Infrastructure Golden Gate service +--- + +# Data Source: oci_golden_gate_pipeline_schemas +This data source provides the list of Pipeline Schemas in Oracle Cloud Infrastructure Golden Gate service. + +Returns an array of schemas based on mapping rules for a pipeline. + + +## Example Usage + +```hcl +data "oci_golden_gate_pipeline_schemas" "test_pipeline_schemas" { + #Required + pipeline_id = oci_golden_gate_pipeline.test_pipeline.id + + #Optional + display_name = var.pipeline_schema_display_name +} +``` + +## Argument Reference + +The following arguments are supported: + +* `display_name` - (Optional) A filter to return only the resources that match the entire 'displayName' given. +* `pipeline_id` - (Required) The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the pipeline created. + + +## Attributes Reference + +The following attributes are exported: + +* `pipeline_schema_collection` - The list of pipeline_schema_collection. + +### PipelineSchema Reference + +The following attributes are exported: + +* `items` - Array of pipeline schemas + * `source_schema_name` - The schema name from the database connection. + * `target_schema_name` - The schema name from the database connection. + diff --git a/website/docs/d/golden_gate_pipelines.html.markdown b/website/docs/d/golden_gate_pipelines.html.markdown new file mode 100644 index 00000000000..c51151be940 --- /dev/null +++ b/website/docs/d/golden_gate_pipelines.html.markdown @@ -0,0 +1,89 @@ +--- +subcategory: "Golden Gate" +layout: "oci" +page_title: "Oracle Cloud Infrastructure: oci_golden_gate_pipelines" +sidebar_current: "docs-oci-datasource-golden_gate-pipelines" +description: |- + Provides the list of Pipelines in Oracle Cloud Infrastructure Golden Gate service +--- + +# Data Source: oci_golden_gate_pipelines +This data source provides the list of Pipelines in Oracle Cloud Infrastructure Golden Gate service. + +Lists the Pipelines in the compartment. + + +## Example Usage + +```hcl +data "oci_golden_gate_pipelines" "test_pipelines" { + #Required + compartment_id = var.compartment_id + + #Optional + display_name = var.pipeline_display_name + lifecycle_sub_state = var.pipeline_lifecycle_sub_state + state = var.pipeline_state +} +``` + +## Argument Reference + +The following arguments are supported: + +* `compartment_id` - (Required) The OCID of the compartment that contains the work request. Work requests should be scoped to the same compartment as the resource the work request affects. If the work request concerns multiple resources, and those resources are not in the same compartment, it is up to the service team to pick the primary resource whose compartment should be used. +* `display_name` - (Optional) A filter to return only the resources that match the entire 'displayName' given. +* `lifecycle_sub_state` - (Optional) A filtered list of pipelines to return for a given lifecycleSubState. +* `state` - (Optional) A filtered list of pipelines to return for a given lifecycleState. + + +## Attributes Reference + +The following attributes are exported: + +* `pipeline_collection` - The list of pipeline_collection. + +### Pipeline Reference + +The following attributes are exported: + +* `compartment_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment being referenced. +* `cpu_core_count` - The Minimum number of OCPUs to be made available for this Deployment. +* `defined_tags` - Tags defined for this resource. Each key is predefined and scoped to a namespace. Example: `{"foo-namespace.bar-key": "value"}` +* `description` - Metadata about this specific object. +* `display_name` - An object's Display Name. +* `freeform_tags` - A simple key-value pair that is applied without any predefined name, type, or scope. Exists for cross-compatibility only. Example: `{"bar-key": "value"}` +* `id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the pipeline. This option applies when retrieving a pipeline. +* `is_auto_scaling_enabled` - Indicates if auto scaling is enabled for the Deployment's CPU core count. +* `license_model` - The Oracle license model that applies to a Deployment. +* `lifecycle_details` - Describes the object's current state in detail. For example, it can be used to provide actionable information for a resource in a Failed state. +* `lifecycle_sub_state` - Possible lifecycle substates when retrieving a pipeline. +* `locks` - Locks associated with this resource. + * `message` - A message added by the creator of the lock. This is typically used to give an indication of why the resource is locked. + * `related_resource_id` - The id of the resource that is locking this resource. Indicates that deleting this resource will remove the lock. + * `time_created` - When the lock was created. + * `type` - Type of the lock. +* `mapping_rules` - Mapping for source/target schema/tables for the pipeline data replication. + * `mapping_type` - Defines the exclude/include rules of source and target schemas and tables when replicating from source to target. This option applies when creating and updating a pipeline. + * `source` - The source schema/table combination for replication to target. + * `target` - The target schema/table combination for replication from the source. +* `process_options` - Required pipeline options to configure the replication process (Extract or Replicat). + * `initial_data_load` - Options required for the pipeline Initial Data Load. If enabled, copies existing data from source to target before replication. + * `action_on_existing_table` - Action upon existing tables in target when initial Data Load is set i.e., isInitialLoad=true. + * `is_initial_load` - If ENABLED, then existing source data is also synchronized to the target when creating or updating the pipeline. + * `replicate_schema_change` - Options required for pipeline Initial Data Load. If enabled, copies existing data from source to target before replication. + * `action_on_ddl_error` - Action upon DDL Error (active only if 'Replicate schema changes (DDL)' is selected) i.e canReplicateSchemaChange=true + * `action_on_dml_error` - Action upon DML Error (active only if 'Replicate schema changes (DDL)' is selected) i.e canReplicateSchemaChange=true + * `can_replicate_schema_change` - If ENABLED, then addition or removal of schema is also replicated, apart from individual tables and records when creating or updating the pipeline. + * `should_restart_on_failure` - If ENABLED, then the replication process restarts itself upon failure. This option applies when creating or updating a pipeline. +* `recipe_type` - The type of the recipe +* `source_connection_details` - The source connection details for creating a pipeline. + * `connection_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the connection being referenced. +* `state` - Lifecycle state of the pipeline. +* `system_tags` - The system tags associated with this resource, if any. The system tags are set by Oracle Cloud Infrastructure services. Each key is predefined and scoped to namespaces. For more information, see [Resource Tags](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). Example: `{orcl-cloud: {free-tier-retain: true}}` +* `target_connection_details` - The target connection details for creating a pipeline. + * `connection_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the connection being referenced. +* `time_created` - The time the resource was created. The format is defined by [RFC3339](https://tools.ietf.org/html/rfc3339), such as `2016-08-25T21:10:29.600Z`. +* `time_last_recorded` - When the resource was last updated. This option applies when retrieving a pipeline. The format is defined by [RFC3339](https://tools.ietf.org/html/rfc3339), such as `2024-07-25T21:10:29.600Z`. +* `time_updated` - The time the resource was last updated. The format is defined by [RFC3339](https://tools.ietf.org/html/rfc3339), such as `2016-08-25T21:10:29.600Z`. + diff --git a/website/docs/d/golden_gate_recipes.html.markdown b/website/docs/d/golden_gate_recipes.html.markdown new file mode 100644 index 00000000000..d3591481d72 --- /dev/null +++ b/website/docs/d/golden_gate_recipes.html.markdown @@ -0,0 +1,55 @@ +--- +subcategory: "Golden Gate" +layout: "oci" +page_title: "Oracle Cloud Infrastructure: oci_golden_gate_recipes" +sidebar_current: "docs-oci-datasource-golden_gate-recipes" +description: |- + Provides the list of Recipes in Oracle Cloud Infrastructure Golden Gate service +--- + +# Data Source: oci_golden_gate_recipes +This data source provides the list of Recipes in Oracle Cloud Infrastructure Golden Gate service. + +Returns an array of Recipe Summary. + + +## Example Usage + +```hcl +data "oci_golden_gate_recipes" "test_recipes" { + #Required + compartment_id = var.compartment_id + + #Optional + display_name = var.recipe_display_name + recipe_type = var.recipe_recipe_type +} +``` + +## Argument Reference + +The following arguments are supported: + +* `compartment_id` - (Required) The OCID of the compartment that contains the work request. Work requests should be scoped to the same compartment as the resource the work request affects. If the work request concerns multiple resources, and those resources are not in the same compartment, it is up to the service team to pick the primary resource whose compartment should be used. +* `display_name` - (Optional) A filter to return only the resources that match the entire 'displayName' given. +* `recipe_type` - (Optional) The pipeline's recipe type. The default value is ZERO_ETL. + + +## Attributes Reference + +The following attributes are exported: + +* `recipe_summary_collection` - The list of recipe_summary_collection. + +### Recipe Reference + +The following attributes are exported: + +* `items` - Array of Recipe Summary + * `description` - Metadata about this specific object. + * `display_name` - An object's Display Name. + * `name` - An object's Display Name. + * `recipe_type` - The type of the recipe + * `supported_source_technology_types` - Array of supported technology types for this recipe. + * `supported_target_technology_types` - Array of supported technology types for this recipe. + diff --git a/website/docs/d/golden_gate_trail_files.html.markdown b/website/docs/d/golden_gate_trail_files.html.markdown index 3bce8dca8c3..92cce37d9b8 100644 --- a/website/docs/d/golden_gate_trail_files.html.markdown +++ b/website/docs/d/golden_gate_trail_files.html.markdown @@ -10,7 +10,8 @@ description: |- # Data Source: oci_golden_gate_trail_files This data source provides the list of Trail Files in Oracle Cloud Infrastructure Golden Gate service. -Lists the TrailFiles for a deployment. Deprecated: Please access trail file management functions directly on OGG console which are available since version Oracle GoldenGate 23c. +Lists the TrailFiles for a deployment. +Deprecated: Please access trail file management functions directly on OGG console which are available since version Oracle GoldenGate 23c. ## Example Usage diff --git a/website/docs/d/golden_gate_trail_sequences.html.markdown b/website/docs/d/golden_gate_trail_sequences.html.markdown index 45b6572a9df..447392fbeb1 100644 --- a/website/docs/d/golden_gate_trail_sequences.html.markdown +++ b/website/docs/d/golden_gate_trail_sequences.html.markdown @@ -10,7 +10,8 @@ description: |- # Data Source: oci_golden_gate_trail_sequences This data source provides the list of Trail Sequences in Oracle Cloud Infrastructure Golden Gate service. -Lists the Trail Sequences for a TrailFile in a given deployment. Deprecated: Please access trail file management functions directly on OGG console which are available since version Oracle GoldenGate 23c. +Lists the Trail Sequences for a TrailFile in a given deployment. +Deprecated: Please access trail file management functions directly on OGG console which are available since version Oracle GoldenGate 23c. ## Example Usage diff --git a/website/docs/guides/resource_discovery.html.markdown b/website/docs/guides/resource_discovery.html.markdown index c2801ac6a38..82cff99a573 100644 --- a/website/docs/guides/resource_discovery.html.markdown +++ b/website/docs/guides/resource_discovery.html.markdown @@ -782,6 +782,7 @@ golden_gate * oci\_golden\_gate\_connection\_assignment * oci\_golden\_gate\_connection * oci\_golden\_gate\_deployment\_certificate +* oci\_golden\_gate\_pipeline health_checks diff --git a/website/docs/r/golden_gate_connection.html.markdown b/website/docs/r/golden_gate_connection.html.markdown index 51dddbdc6b3..f7f5e2c495d 100644 --- a/website/docs/r/golden_gate_connection.html.markdown +++ b/website/docs/r/golden_gate_connection.html.markdown @@ -227,7 +227,7 @@ The following arguments are supported: * `ssl_client_keystoredb` - (Applicable when connection_type=DB2) (Updatable) The base64 encoded keystore file created at the client containing the server certificate / CA root certificate. * `ssl_client_keystoredb_secret_id` - (Applicable when connection_type=DB2) (Updatable) The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the Secret where the keystore file stored, which created at the client containing the server certificate / CA root certificate. Note: When provided, 'sslClientKeystoredb' field must not be provided. * `ssl_crl` - (Applicable when connection_type=MYSQL | POSTGRESQL) (Updatable) The base64 encoded list of certificates revoked by the trusted certificate authorities (Trusted CA). Note: This is an optional property and only applicable if TLS/MTLS option is selected. -* `ssl_key` - (Applicable when connection_type=MYSQL | POSTGRESQL) (Updatable) Client Key – The base64 encoded content of a .pem or .crt filecontaining the client private key (for 2-way SSL). +* `ssl_key` - (Applicable when connection_type=MYSQL | POSTGRESQL) (Updatable) Client Key - The base64 encoded content of a .pem or .crt file containing the client private key (for 2-way SSL). * `ssl_key_password` - (Applicable when connection_type=JAVA_MESSAGE_SERVICE | KAFKA | KAFKA_SCHEMA_REGISTRY) (Updatable) The password for the cert inside of the KeyStore. In case it differs from the KeyStore password, it should be provided. * `ssl_key_password_secret_id` - (Applicable when connection_type=JAVA_MESSAGE_SERVICE | KAFKA | KAFKA_SCHEMA_REGISTRY) (Updatable) The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the Secret where the password is stored for the cert inside of the Keystore. In case it differs from the KeyStore password, it should be provided. Note: When provided, 'sslKeyPassword' field must not be provided. * `ssl_key_secret_id` - (Applicable when connection_type=MYSQL | POSTGRESQL) (Updatable) The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the Secret that stores the Client Key diff --git a/website/docs/r/golden_gate_pipeline.html.markdown b/website/docs/r/golden_gate_pipeline.html.markdown new file mode 100644 index 00000000000..486957fd696 --- /dev/null +++ b/website/docs/r/golden_gate_pipeline.html.markdown @@ -0,0 +1,162 @@ +--- +subcategory: "Golden Gate" +layout: "oci" +page_title: "Oracle Cloud Infrastructure: oci_golden_gate_pipeline" +sidebar_current: "docs-oci-resource-golden_gate-pipeline" +description: |- + Provides the Pipeline resource in Oracle Cloud Infrastructure Golden Gate service +--- + +# oci_golden_gate_pipeline +This resource provides the Pipeline resource in Oracle Cloud Infrastructure Golden Gate service. + +Creates a new Pipeline. + + +## Example Usage + +```hcl +resource "oci_golden_gate_pipeline" "test_pipeline" { + #Required + compartment_id = var.compartment_id + display_name = var.pipeline_display_name + license_model = var.pipeline_license_model + recipe_type = var.pipeline_recipe_type + source_connection_details { + #Required + connection_id = oci_golden_gate_connection.test_connection.id + } + target_connection_details { + #Required + connection_id = oci_golden_gate_connection.test_connection.id + } + + #Optional + defined_tags = {"foo-namespace.bar-key"= "value"} + description = var.pipeline_description + freeform_tags = {"bar-key"= "value"} + locks { + #Required + type = var.pipeline_locks_type + + #Optional + message = var.pipeline_locks_message + related_resource_id = oci_cloud_guard_resource.test_resource.id + time_created = var.pipeline_locks_time_created + } + process_options { + #Required + initial_data_load { + #Required + is_initial_load = var.pipeline_process_options_initial_data_load_is_initial_load + + #Optional + action_on_existing_table = var.pipeline_process_options_initial_data_load_action_on_existing_table + } + replicate_schema_change { + #Required + can_replicate_schema_change = var.pipeline_process_options_replicate_schema_change_can_replicate_schema_change + + #Optional + action_on_ddl_error = var.pipeline_process_options_replicate_schema_change_action_on_ddl_error + action_on_dml_error = var.pipeline_process_options_replicate_schema_change_action_on_dml_error + } + should_restart_on_failure = var.pipeline_process_options_should_restart_on_failure + } +} +``` + +## Argument Reference + +The following arguments are supported: + +* `compartment_id` - (Required) (Updatable) The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment being referenced. +* `defined_tags` - (Optional) (Updatable) Tags defined for this resource. Each key is predefined and scoped to a namespace. Example: `{"foo-namespace.bar-key": "value"}` +* `description` - (Optional) (Updatable) Metadata about this specific object. +* `display_name` - (Required) (Updatable) An object's Display Name. +* `freeform_tags` - (Optional) (Updatable) A simple key-value pair that is applied without any predefined name, type, or scope. Exists for cross-compatibility only. Example: `{"bar-key": "value"}` +* `license_model` - (Required) (Updatable) The Oracle license model that applies to a Deployment. +* `locks` - (Optional) Locks associated with this resource. + * `message` - (Optional) A message added by the creator of the lock. This is typically used to give an indication of why the resource is locked. + * `related_resource_id` - (Optional) The id of the resource that is locking this resource. Indicates that deleting this resource will remove the lock. + * `time_created` - (Optional) When the lock was created. + * `type` - (Required) Type of the lock. +* `process_options` - (Optional) (Updatable) Required pipeline options to configure the replication process (Extract or Replicat). + * `initial_data_load` - (Required) (Updatable) Options required for the pipeline Initial Data Load. If enabled, copies existing data from source to target before replication. + * `action_on_existing_table` - (Optional) (Updatable) Action upon existing tables in target when initial Data Load is set i.e., isInitialLoad=true. + * `is_initial_load` - (Required) (Updatable) If ENABLED, then existing source data is also synchronized to the target when creating or updating the pipeline. + * `replicate_schema_change` - (Required) (Updatable) Options required for pipeline Initial Data Load. If enabled, copies existing data from source to target before replication. + * `action_on_ddl_error` - (Optional) (Updatable) Action upon DDL Error (active only if 'Replicate schema changes (DDL)' is selected) i.e canReplicateSchemaChange=true + * `action_on_dml_error` - (Optional) (Updatable) Action upon DML Error (active only if 'Replicate schema changes (DDL)' is selected) i.e canReplicateSchemaChange=true + * `can_replicate_schema_change` - (Required) (Updatable) If ENABLED, then addition or removal of schema is also replicated, apart from individual tables and records when creating or updating the pipeline. + * `should_restart_on_failure` - (Required) (Updatable) If ENABLED, then the replication process restarts itself upon failure. This option applies when creating or updating a pipeline. +* `recipe_type` - (Required) (Updatable) The type of the recipe +* `source_connection_details` - (Required) The source connection details for creating a pipeline. + * `connection_id` - (Required) The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the connection being referenced. +* `target_connection_details` - (Required) The target connection details for creating a pipeline. + * `connection_id` - (Required) The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the connection being referenced. + + +** IMPORTANT ** +Any change to a property that does not support update will force the destruction and recreation of the resource with the new property values + +## Attributes Reference + +The following attributes are exported: + +* `compartment_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment being referenced. +* `cpu_core_count` - The Minimum number of OCPUs to be made available for this Deployment. +* `defined_tags` - Tags defined for this resource. Each key is predefined and scoped to a namespace. Example: `{"foo-namespace.bar-key": "value"}` +* `description` - Metadata about this specific object. +* `display_name` - An object's Display Name. +* `freeform_tags` - A simple key-value pair that is applied without any predefined name, type, or scope. Exists for cross-compatibility only. Example: `{"bar-key": "value"}` +* `id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the pipeline. This option applies when retrieving a pipeline. +* `is_auto_scaling_enabled` - Indicates if auto scaling is enabled for the Deployment's CPU core count. +* `license_model` - The Oracle license model that applies to a Deployment. +* `lifecycle_details` - Describes the object's current state in detail. For example, it can be used to provide actionable information for a resource in a Failed state. +* `lifecycle_sub_state` - Possible lifecycle substates when retrieving a pipeline. +* `locks` - Locks associated with this resource. + * `message` - A message added by the creator of the lock. This is typically used to give an indication of why the resource is locked. + * `related_resource_id` - The id of the resource that is locking this resource. Indicates that deleting this resource will remove the lock. + * `time_created` - When the lock was created. + * `type` - Type of the lock. +* `mapping_rules` - Mapping for source/target schema/tables for the pipeline data replication. + * `mapping_type` - Defines the exclude/include rules of source and target schemas and tables when replicating from source to target. This option applies when creating and updating a pipeline. + * `source` - The source schema/table combination for replication to target. + * `target` - The target schema/table combination for replication from the source. +* `process_options` - Required pipeline options to configure the replication process (Extract or Replicat). + * `initial_data_load` - Options required for the pipeline Initial Data Load. If enabled, copies existing data from source to target before replication. + * `action_on_existing_table` - Action upon existing tables in target when initial Data Load is set i.e., isInitialLoad=true. + * `is_initial_load` - If ENABLED, then existing source data is also synchronized to the target when creating or updating the pipeline. + * `replicate_schema_change` - Options required for pipeline Initial Data Load. If enabled, copies existing data from source to target before replication. + * `action_on_ddl_error` - Action upon DDL Error (active only if 'Replicate schema changes (DDL)' is selected) i.e canReplicateSchemaChange=true + * `action_on_dml_error` - Action upon DML Error (active only if 'Replicate schema changes (DDL)' is selected) i.e canReplicateSchemaChange=true + * `can_replicate_schema_change` - If ENABLED, then addition or removal of schema is also replicated, apart from individual tables and records when creating or updating the pipeline. + * `should_restart_on_failure` - If ENABLED, then the replication process restarts itself upon failure. This option applies when creating or updating a pipeline. +* `recipe_type` - The type of the recipe +* `source_connection_details` - The source connection details for creating a pipeline. + * `connection_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the connection being referenced. +* `state` - Lifecycle state of the pipeline. +* `system_tags` - The system tags associated with this resource, if any. The system tags are set by Oracle Cloud Infrastructure services. Each key is predefined and scoped to namespaces. For more information, see [Resource Tags](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). Example: `{orcl-cloud: {free-tier-retain: true}}` +* `target_connection_details` - The target connection details for creating a pipeline. + * `connection_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the connection being referenced. +* `time_created` - The time the resource was created. The format is defined by [RFC3339](https://tools.ietf.org/html/rfc3339), such as `2016-08-25T21:10:29.600Z`. +* `time_last_recorded` - When the resource was last updated. This option applies when retrieving a pipeline. The format is defined by [RFC3339](https://tools.ietf.org/html/rfc3339), such as `2024-07-25T21:10:29.600Z`. +* `time_updated` - The time the resource was last updated. The format is defined by [RFC3339](https://tools.ietf.org/html/rfc3339), such as `2016-08-25T21:10:29.600Z`. + +## Timeouts + +The `timeouts` block allows you to specify [timeouts](https://registry.terraform.io/providers/oracle/oci/latest/docs/guides/changing_timeouts) for certain operations: + * `create` - (Defaults to 20 minutes), when creating the Pipeline + * `update` - (Defaults to 20 minutes), when updating the Pipeline + * `delete` - (Defaults to 20 minutes), when destroying the Pipeline + + +## Import + +Pipelines can be imported using the `id`, e.g. + +``` +$ terraform import oci_golden_gate_pipeline.test_pipeline "id" +``` + From 4fd5b9d47097c985dd94c6d2afae4669b5fece6a Mon Sep 17 00:00:00 2001 From: Tam Nguyen Date: Thu, 5 Dec 2024 10:44:18 -0800 Subject: [PATCH 08/17] Added - Support for Data Science: Support Private Endpoint Access for Model Deployment --- .../model_deployment/model_deployment.tf | 85 +++- ...ence_data_science_private_endpoint_test.go | 229 +++++++++ ..._model_deployment_private_endpoint_test.go | 458 ++++++++++++++++++ .../datascience_model_deployment_test.go | 4 +- .../datascience_model_deployment_resource.go | 20 + .../docs/d/datascience_job_run.html.markdown | 6 +- .../docs/d/datascience_job_runs.html.markdown | 6 +- .../docs/d/datascience_model.html.markdown | 8 +- ...datascience_model_deployment.html.markdown | 119 ++--- ...atascience_model_deployments.html.markdown | 7 +- .../docs/d/datascience_models.html.markdown | 8 +- .../docs/r/datascience_job_run.html.markdown | 8 +- .../docs/r/datascience_model.html.markdown | 16 +- ...datascience_model_deployment.html.markdown | 5 +- 14 files changed, 877 insertions(+), 102 deletions(-) create mode 100644 internal/integrationtest/datascience_model_deployment_private_endpoint_test.go diff --git a/examples/datascience/model_deployment/model_deployment.tf b/examples/datascience/model_deployment/model_deployment.tf index 725f6f834f1..164ac109196 100644 --- a/examples/datascience/model_deployment/model_deployment.tf +++ b/examples/datascience/model_deployment/model_deployment.tf @@ -3,27 +3,21 @@ // These variables would commonly be defined as environment variables or sourced in a .env file -variable "tenancy_ocid" { -} - variable "user_ocid" { } -variable "fingerprint" { +variable "region" { } -variable "private_key_path" { -} - -variable "region" { +variable config_file_profile { } provider "oci" { region = var.region - tenancy_ocid = var.tenancy_ocid user_ocid = var.user_ocid - fingerprint = var.fingerprint - private_key_path = var.private_key_path +// version = "6.19.0" + auth = "SecurityToken" + config_file_profile = var.config_file_profile } variable "compartment_ocid" { @@ -207,6 +201,12 @@ variable "model_deployment_model_deployment_configuration_details_environment_co variable "model_egress_id" { } +# Private Networking +variable "model_deployment_display_name_for_private_network" { + default = "terraform-testing-private-model-deployment" +} +variable "private_endpoint_id" {} + # A model deployment resource configurations for creating a new model deployment with scaling policy type = FIXED SIZE resource "oci_datascience_model_deployment" "tf_model_deployment" { # Required @@ -491,6 +491,67 @@ resource "oci_datascience_model_deployment" "tf_model_deployment_custom_networki display_name = var.model_deployment_display_name } +# A model deployment resource configurations for creating a new model deployment with Private Networking +resource "oci_datascience_model_deployment" "tf_model_deployment_private_networking" { + # Required + compartment_id = var.compartment_ocid + model_deployment_configuration_details { + # Required + deployment_type = var.model_deployment_model_deployment_configuration_details_deployment_type + model_configuration_details { + # Required + instance_configuration { + # Required + instance_shape_name = var.shape + + #Optional + model_deployment_instance_shape_config_details { + + #Optional + cpu_baseline = var.model_deployment_model_deployment_configuration_details_model_configuration_details_instance_configuration_model_deployment_instance_shape_config_details_cpu_baseline + memory_in_gbs = var.model_deployment_model_configuration_details_instance_configuration_model_deployment_instance_shape_config_details_memory_in_gbs + ocpus = var.model_deployment_model_configuration_details_instance_configuration_model_deployment_instance_shape_config_details_ocpus + } + + # Required + subnet_id = oci_core_subnet.tf_subnet.id + private_endpoint_id = var.private_endpoint_id + } + model_id = var.model_egress_id + + # Optional + bandwidth_mbps = var.model_deployment_model_deployment_configuration_details_model_configuration_details_bandwidth_mbps + maximum_bandwidth_mbps = var.model_deployment_model_deployment_configuration_details_model_configuration_details_maximum_bandwidth_mbps + + scaling_policy { + # Required + instance_count = var.model_deployment_model_deployment_configuration_details_model_configuration_details_scaling_policy_instance_count + policy_type = var.model_deployment_model_deployment_configuration_details_model_configuration_details_scaling_policy_policy_type + } + } + } + project_id = var.project_ocid + + # Optional + category_log_details { + + # Optional + access { + # Required + log_group_id = var.log_group_id + log_id = var.access_log_id + } + predict { + # Required + log_group_id = var.log_group_id + log_id = var.predict_log_id + } + } + # Optional + description = var.model_deployment_description + display_name = var.model_deployment_display_name_for_private_network +} + # The data resource for a list of model deployments in a specified compartment data "oci_datascience_model_deployments" "tf_model_deployments" { # Required @@ -513,4 +574,4 @@ resource "oci_core_subnet" "tf_subnet" { resource "oci_core_vcn" "tf_vcn" { cidr_block = "10.0.0.0/16" compartment_id = var.compartment_ocid -} \ No newline at end of file +} diff --git a/internal/integrationtest/datascience_data_science_private_endpoint_test.go b/internal/integrationtest/datascience_data_science_private_endpoint_test.go index ca580276646..6dcc1bbe8de 100644 --- a/internal/integrationtest/datascience_data_science_private_endpoint_test.go +++ b/internal/integrationtest/datascience_data_science_private_endpoint_test.go @@ -31,9 +31,18 @@ var ( DataSciencePrivateEndpointResourceConfig = DataSciencePrivateEndpointResourceDependencies + acctest.GenerateResourceFromRepresentationMap("oci_datascience_private_endpoint", "test_data_science_private_endpoint", acctest.Optional, acctest.Update, DataSciencePrivateEndpointRepresentation) + DataScienceMDPrivateEndpointRequiredOnlyResource = DataSciencePrivateEndpointResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_datascience_private_endpoint", "test_data_science_md_private_endpoint", acctest.Required, acctest.Create, DataScienceMDPrivateEndpointRepresentation) + + DataScienceMDPrivateEndpointResourceConfig = DataSciencePrivateEndpointResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_datascience_private_endpoint", "test_data_science_md_private_endpoint", acctest.Optional, acctest.Update, DataScienceMDPrivateEndpointRepresentation) + DataSciencePrivateEndpointSingularDataSourceRepresentation = map[string]interface{}{ "data_science_private_endpoint_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_datascience_private_endpoint.test_data_science_private_endpoint.id}`}, } + DataScienceMDPrivateEndpointSingularDataSourceRepresentation = map[string]interface{}{ + "data_science_private_endpoint_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_datascience_private_endpoint.test_data_science_md_private_endpoint.id}`}, + } DataSciencePrivateEndpointDataSourceRepresentation = map[string]interface{}{ "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id}`}, @@ -43,11 +52,24 @@ var ( "state": acctest.Representation{RepType: acctest.Optional, Create: `ACTIVE`}, "filter": acctest.RepresentationGroup{RepType: acctest.Required, Group: DataSciencePrivateEndpointDataSourceFilterRepresentation}} + DataScienceMDPrivateEndpointDataSourceRepresentation = map[string]interface{}{ + "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id}`}, + "created_by": acctest.Representation{RepType: acctest.Optional, Create: `${var.user_id}`}, + "data_science_resource_type": acctest.Representation{RepType: acctest.Optional, Create: `MODEL_DEPLOYMENT`}, + "display_name": acctest.Representation{RepType: acctest.Optional, Create: `MD_PE`, Update: `Updated_MD_PE`}, + "state": acctest.Representation{RepType: acctest.Optional, Create: `ACTIVE`}, + "filter": acctest.RepresentationGroup{RepType: acctest.Required, Group: DataScienceMDPrivateEndpointDataSourceFilterRepresentation}} + DataSciencePrivateEndpointDataSourceFilterRepresentation = map[string]interface{}{ "name": acctest.Representation{RepType: acctest.Required, Create: `id`}, "values": acctest.Representation{RepType: acctest.Required, Create: []string{`${oci_datascience_private_endpoint.test_data_science_private_endpoint.id}`}}, } + DataScienceMDPrivateEndpointDataSourceFilterRepresentation = map[string]interface{}{ + "name": acctest.Representation{RepType: acctest.Required, Create: `id`}, + "values": acctest.Representation{RepType: acctest.Required, Create: []string{`${oci_datascience_private_endpoint.test_data_science_md_private_endpoint.id}`}}, + } + DataSciencePrivateEndpointRepresentation = map[string]interface{}{ "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id}`}, "data_science_resource_type": acctest.Representation{RepType: acctest.Required, Create: `NOTEBOOK_SESSION`}, @@ -60,6 +82,18 @@ var ( "lifecycle": acctest.RepresentationGroup{RepType: acctest.Optional, Group: dataSciencePrivateEndpointIgnoreRepresentation}, } + DataScienceMDPrivateEndpointRepresentation = map[string]interface{}{ + "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id}`}, + "data_science_resource_type": acctest.Representation{RepType: acctest.Required, Create: `MODEL_DEPLOYMENT`}, + "subnet_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_core_subnet.test_subnet.id}`}, + "defined_tags": acctest.Representation{RepType: acctest.Optional, Create: `${map("${oci_identity_tag_namespace.tag-namespace1.name}.${oci_identity_tag.tag1.name}", "value")}`, Update: `${map("${oci_identity_tag_namespace.tag-namespace1.name}.${oci_identity_tag.tag1.name}", "updatedValue")}`}, + "description": acctest.Representation{RepType: acctest.Optional, Create: `description`, Update: `description2`}, + "display_name": acctest.Representation{RepType: acctest.Optional, Create: `MD_PE`, Update: `Updated_MD_PE`}, + "freeform_tags": acctest.Representation{RepType: acctest.Optional, Create: map[string]string{"Department": "Finance"}, Update: map[string]string{"Department": "Accounting"}}, + "sub_domain": acctest.Representation{RepType: acctest.Optional, Create: `subDomain`}, + "lifecycle": acctest.RepresentationGroup{RepType: acctest.Optional, Group: dataSciencePrivateEndpointIgnoreRepresentation}, + } + dataSciencePrivateEndpointIgnoreRepresentation = map[string]interface{}{ "ignore_changes": acctest.Representation{RepType: acctest.Required, Create: []string{`defined_tags`}}, } @@ -266,6 +300,201 @@ func TestDatascienceDataSciencePrivateEndpointResource_basic(t *testing.T) { }) } +func TestDatascienceDataScienceMDPrivateEndpointResource_basic(t *testing.T) { + httpreplay.SetScenario("TestDatascienceDataScienceMDPrivateEndpointResource_basic") + defer httpreplay.SaveScenario() + + config := acctest.ProviderTestConfig() + + compartmentId := utils.GetEnvSettingWithBlankDefault("compartment_ocid") + compartmentIdVariableStr := fmt.Sprintf("variable \"compartment_id\" { default = \"%s\" }\n", compartmentId) + + compartmentIdU := utils.GetEnvSettingWithDefault("compartment_id_for_update", compartmentId) + compartmentIdUVariableStr := fmt.Sprintf("variable \"compartment_id_for_update\" { default = \"%s\" }\n", compartmentIdU) + + userId := utils.GetEnvSettingWithBlankDefault("user_ocid") + userIdVariableStr := fmt.Sprintf("variable \"user_id\" { default = \"%s\" }\n", userId) + + resourceName := "oci_datascience_private_endpoint.test_data_science_md_private_endpoint" + datasourceName := "data.oci_datascience_private_endpoints.test_data_science_md_private_endpoint" + singularDatasourceName := "data.oci_datascience_private_endpoint.test_data_science_md_private_endpoint" + + var resId, resId2 string + // Save TF content to Create resource with optional properties. This has to be exactly the same as the config part in the "create with optionals" step in the test. + acctest.SaveConfigContent(config+compartmentIdVariableStr+DataSciencePrivateEndpointResourceDependencies+ + acctest.GenerateResourceFromRepresentationMap("oci_datascience_private_endpoint", "test_data_science_md_private_endpoint", acctest.Optional, acctest.Create, DataScienceMDPrivateEndpointRepresentation), "datascience", "dataSciencePrivateEndpoint", t) + + acctest.ResourceTest(t, testAccCheckDatascienceDataSciencePrivateEndpointDestroy, []resource.TestStep{ + // 0. verify Create + { + Config: config + compartmentIdVariableStr + DataSciencePrivateEndpointResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_datascience_private_endpoint", "test_data_science_md_private_endpoint", acctest.Required, acctest.Create, DataScienceMDPrivateEndpointRepresentation), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttr(resourceName, "data_science_resource_type", "MODEL_DEPLOYMENT"), + resource.TestCheckResourceAttrSet(resourceName, "subnet_id"), + + func(s *terraform.State) (err error) { + resId, err = acctest.FromInstanceState(s, resourceName, "id") + return err + }, + ), + }, + + // 1. delete before next Create + { + Config: config + compartmentIdVariableStr + DataSciencePrivateEndpointResourceDependencies, + }, + // 2. verify Create with optionals + { + Config: config + compartmentIdVariableStr + DataSciencePrivateEndpointResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_datascience_private_endpoint", "test_data_science_md_private_endpoint", acctest.Optional, acctest.Create, DataScienceMDPrivateEndpointRepresentation), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttrSet(resourceName, "created_by"), + resource.TestCheckResourceAttr(resourceName, "data_science_resource_type", "MODEL_DEPLOYMENT"), + resource.TestCheckResourceAttr(resourceName, "description", "description"), + resource.TestCheckResourceAttr(resourceName, "display_name", "MD_PE"), + resource.TestCheckResourceAttrSet(resourceName, "fqdn"), + resource.TestCheckResourceAttr(resourceName, "freeform_tags.%", "1"), + resource.TestCheckResourceAttrSet(resourceName, "id"), + resource.TestCheckResourceAttrSet(resourceName, "state"), + resource.TestCheckResourceAttr(resourceName, "sub_domain", "subDomain"), + resource.TestCheckResourceAttrSet(resourceName, "subnet_id"), + resource.TestCheckResourceAttrSet(resourceName, "time_created"), + resource.TestCheckResourceAttrSet(resourceName, "time_updated"), + + func(s *terraform.State) (err error) { + resId, err = acctest.FromInstanceState(s, resourceName, "id") + if isEnableExportCompartment, _ := strconv.ParseBool(utils.GetEnvSettingWithDefault("enable_export_compartment", "false")); isEnableExportCompartment { + if errExport := resourcediscovery.TestExportCompartmentWithResourceName(&resId, &compartmentId, resourceName); errExport != nil { + return errExport + } + } + return err + }, + ), + }, + + // 3. verify Update to the compartment (the compartment will be switched back in the next step) + { + Config: config + compartmentIdVariableStr + compartmentIdUVariableStr + DataSciencePrivateEndpointResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_datascience_private_endpoint", "test_data_science_md_private_endpoint", acctest.Optional, acctest.Create, + acctest.RepresentationCopyWithNewProperties(DataScienceMDPrivateEndpointRepresentation, map[string]interface{}{ + "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id_for_update}`}, + })), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentIdU), + resource.TestCheckResourceAttrSet(resourceName, "created_by"), + resource.TestCheckResourceAttr(resourceName, "data_science_resource_type", "MODEL_DEPLOYMENT"), + resource.TestCheckResourceAttr(resourceName, "description", "description"), + resource.TestCheckResourceAttr(resourceName, "display_name", "MD_PE"), + resource.TestCheckResourceAttrSet(resourceName, "fqdn"), + resource.TestCheckResourceAttr(resourceName, "freeform_tags.%", "1"), + resource.TestCheckResourceAttrSet(resourceName, "id"), + resource.TestCheckResourceAttrSet(resourceName, "state"), + resource.TestCheckResourceAttr(resourceName, "sub_domain", "subDomain"), + resource.TestCheckResourceAttrSet(resourceName, "subnet_id"), + resource.TestCheckResourceAttrSet(resourceName, "time_created"), + resource.TestCheckResourceAttrSet(resourceName, "time_updated"), + + func(s *terraform.State) (err error) { + resId2, err = acctest.FromInstanceState(s, resourceName, "id") + if resId != resId2 { + return fmt.Errorf("resource recreated when it was supposed to be updated") + } + return err + }, + ), + }, + + // 4. verify updates to updatable parameters + { + Config: config + compartmentIdVariableStr + DataSciencePrivateEndpointResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_datascience_private_endpoint", "test_data_science_md_private_endpoint", acctest.Optional, acctest.Update, DataScienceMDPrivateEndpointRepresentation), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttrSet(resourceName, "created_by"), + resource.TestCheckResourceAttr(resourceName, "data_science_resource_type", "MODEL_DEPLOYMENT"), + resource.TestCheckResourceAttr(resourceName, "description", "description2"), + resource.TestCheckResourceAttr(resourceName, "display_name", "Updated_MD_PE"), + resource.TestCheckResourceAttrSet(resourceName, "fqdn"), + resource.TestCheckResourceAttr(resourceName, "freeform_tags.%", "1"), + resource.TestCheckResourceAttrSet(resourceName, "id"), + resource.TestCheckResourceAttrSet(resourceName, "state"), + resource.TestCheckResourceAttr(resourceName, "sub_domain", "subDomain"), + resource.TestCheckResourceAttrSet(resourceName, "subnet_id"), + resource.TestCheckResourceAttrSet(resourceName, "time_created"), + resource.TestCheckResourceAttrSet(resourceName, "time_updated"), + + func(s *terraform.State) (err error) { + resId2, err = acctest.FromInstanceState(s, resourceName, "id") + if resId != resId2 { + return fmt.Errorf("Resource recreated when it was supposed to be updated.") + } + return err + }, + ), + }, + // 5. verify datasource + { + Config: config + + acctest.GenerateDataSourceFromRepresentationMap("oci_datascience_private_endpoints", "test_data_science_md_private_endpoint", acctest.Optional, acctest.Update, DataScienceMDPrivateEndpointDataSourceRepresentation) + + compartmentIdVariableStr + userIdVariableStr + DataSciencePrivateEndpointResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_datascience_private_endpoint", "test_data_science_md_private_endpoint", acctest.Optional, acctest.Update, DataScienceMDPrivateEndpointRepresentation), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(datasourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttr(datasourceName, "data_science_resource_type", "MODEL_DEPLOYMENT"), + resource.TestCheckResourceAttr(datasourceName, "display_name", "Updated_MD_PE"), + resource.TestCheckResourceAttr(datasourceName, "state", "ACTIVE"), + + resource.TestCheckResourceAttr(datasourceName, "data_science_private_endpoints.#", "1"), + resource.TestCheckResourceAttr(datasourceName, "data_science_private_endpoints.0.compartment_id", compartmentId), + resource.TestCheckResourceAttr(datasourceName, "data_science_private_endpoints.0.data_science_resource_type", "MODEL_DEPLOYMENT"), + resource.TestCheckResourceAttr(datasourceName, "data_science_private_endpoints.0.display_name", "Updated_MD_PE"), + resource.TestCheckResourceAttrSet(datasourceName, "data_science_private_endpoints.0.fqdn"), + resource.TestCheckResourceAttr(datasourceName, "data_science_private_endpoints.0.freeform_tags.%", "1"), + resource.TestCheckResourceAttrSet(datasourceName, "data_science_private_endpoints.0.id"), + resource.TestCheckResourceAttrSet(datasourceName, "data_science_private_endpoints.0.state"), + resource.TestCheckResourceAttrSet(datasourceName, "data_science_private_endpoints.0.subnet_id"), + resource.TestCheckResourceAttrSet(datasourceName, "data_science_private_endpoints.0.time_created"), + resource.TestCheckResourceAttrSet(datasourceName, "data_science_private_endpoints.0.time_updated"), + ), + }, + // 6. verify singular datasource + { + Config: config + + acctest.GenerateDataSourceFromRepresentationMap("oci_datascience_private_endpoint", "test_data_science_md_private_endpoint", acctest.Required, acctest.Create, DataScienceMDPrivateEndpointSingularDataSourceRepresentation) + + compartmentIdVariableStr + DataScienceMDPrivateEndpointResourceConfig, + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttrSet(singularDatasourceName, "data_science_private_endpoint_id"), + + resource.TestCheckResourceAttr(singularDatasourceName, "compartment_id", compartmentId), + // resource.TestCheckResourceAttrSet(singularDatasourceName, "created_by"), + resource.TestCheckResourceAttr(singularDatasourceName, "data_science_resource_type", "MODEL_DEPLOYMENT"), + resource.TestCheckResourceAttr(singularDatasourceName, "description", "description2"), + resource.TestCheckResourceAttr(singularDatasourceName, "display_name", "Updated_MD_PE"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "fqdn"), + resource.TestCheckResourceAttr(singularDatasourceName, "freeform_tags.%", "1"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "id"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "state"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "time_created"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "time_updated"), + ), + }, + // 7. verify resource import + { + Config: config + DataScienceMDPrivateEndpointRequiredOnlyResource, + ImportState: true, + ImportStateVerify: true, + ImportStateVerifyIgnore: []string{ + "sub_domain", + }, + ResourceName: resourceName, + }, + }) +} + func testAccCheckDatascienceDataSciencePrivateEndpointDestroy(s *terraform.State) error { noResourceFound := true client := acctest.TestAccProvider.Meta().(*tf_client.OracleClients).DataScienceClient() diff --git a/internal/integrationtest/datascience_model_deployment_private_endpoint_test.go b/internal/integrationtest/datascience_model_deployment_private_endpoint_test.go new file mode 100644 index 00000000000..52d820be1a7 --- /dev/null +++ b/internal/integrationtest/datascience_model_deployment_private_endpoint_test.go @@ -0,0 +1,458 @@ +package integrationtest + +import ( + "fmt" + "strconv" + "testing" + + "github.com/oracle/terraform-provider-oci/internal/acctest" + "github.com/oracle/terraform-provider-oci/internal/resourcediscovery" + + "github.com/oracle/terraform-provider-oci/internal/utils" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" + "github.com/hashicorp/terraform-plugin-sdk/v2/terraform" + "github.com/oracle/terraform-provider-oci/httpreplay" +) + +var ( + DatasciencePrivateModelDeploymentRequiredOnlyResource = DatasciencePrivateModelDeploymentResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_datascience_model_deployment", "test_model_deployment", acctest.Required, acctest.Create, DatasciencePrivateModelDeploymentRepresentation) + + DatasciencePrivateModelDeploymentResourceConfig = DatasciencePrivateModelDeploymentResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_datascience_model_deployment", "test_model_deployment", acctest.Optional, acctest.Update, DatasciencePrivateModelDeploymentRepresentation) + + DatascienceDatasciencePrivateModelDeploymentSingularDataSourceRepresentation = map[string]interface{}{ + "model_deployment_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_datascience_model_deployment.test_model_deployment.id}`}, + } + + DatascienceDatasciencePrivateModelDeploymentDataSourceRepresentation = map[string]interface{}{ + "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id}`}, + "created_by": acctest.Representation{RepType: acctest.Optional, Create: `${oci_datascience_model_deployment.test_model_deployment.created_by}`}, + "display_name": acctest.Representation{RepType: acctest.Optional, Create: `displayName`, Update: `displayName2`}, + "id": acctest.Representation{RepType: acctest.Optional, Create: `${oci_datascience_model_deployment.test_model_deployment.id}`}, + "project_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_datascience_project.test_project.id}`}, + "state": acctest.Representation{RepType: acctest.Optional, Create: `ACTIVE`}, + "filter": acctest.RepresentationGroup{RepType: acctest.Required, Group: DatascienceModelDeploymentDataSourceFilterRepresentation}} + + DatasciencePrivateModelDeploymentRepresentation = map[string]interface{}{ + "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id}`}, + "model_deployment_configuration_details": acctest.RepresentationGroup{RepType: acctest.Required, Group: DatasciencePrivateModelDeploymentModelDeploymentConfigurationDetailsRepresentation}, + "project_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_datascience_project.test_project.id}`}, + "category_log_details": acctest.RepresentationGroup{RepType: acctest.Optional, Group: DatascienceModelDeploymentCategoryLogDetailsRepresentation}, + "defined_tags": acctest.Representation{RepType: acctest.Optional, Create: `${map("${oci_identity_tag_namespace.tag-namespace1.name}.${oci_identity_tag.tag1.name}", "value")}`, Update: `${map("${oci_identity_tag_namespace.tag-namespace1.name}.${oci_identity_tag.tag1.name}", "updatedValue")}`}, + "description": acctest.Representation{RepType: acctest.Optional, Create: `description`, Update: `description2`}, + "display_name": acctest.Representation{RepType: acctest.Optional, Create: `displayName`, Update: `displayName2`}, + "freeform_tags": acctest.Representation{RepType: acctest.Optional, Create: map[string]string{"Department": "Finance"}, Update: map[string]string{"Department": "Accounting"}}, + "lifecycle": acctest.RepresentationGroup{RepType: acctest.Optional, Group: definedTagsIgnoreMDRepresentation}, + } + + DatasciencePrivateModelDeploymentModelDeploymentConfigurationDetailsModelConfigurationDetailsInstanceConfigurationRepresentation = map[string]interface{}{ + "instance_shape_name": acctest.Representation{RepType: acctest.Required, Create: `VM.Standard.E4.Flex`, Update: `VM.Standard.E3.Flex`}, + "model_deployment_instance_shape_config_details": acctest.RepresentationGroup{RepType: acctest.Optional, Group: DatascienceModelDeploymentModelDeploymentConfigurationDetailsModelConfigurationDetailsInstanceConfigurationModelDeploymentInstanceShapeConfigDetailsRepresentation}, + "private_endpoint_id": acctest.Representation{RepType: acctest.Optional, Create: `${oci_datascience_private_endpoint.test_md_private_endpoint.id}`}, + "subnet_id": acctest.Representation{RepType: acctest.Optional, Create: `${oci_core_subnet.test_subnet.id}`}, + } + + DatasciencePrivateModelDeploymentModelDeploymentConfigurationDetailsModelConfigurationDetailsRepresentation = map[string]interface{}{ + "instance_configuration": acctest.RepresentationGroup{RepType: acctest.Required, Group: DatasciencePrivateModelDeploymentModelDeploymentConfigurationDetailsModelConfigurationDetailsInstanceConfigurationRepresentation}, + "model_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_datascience_model.test_model.id}`, Update: `${oci_datascience_model.test_model_update.id}`}, + "bandwidth_mbps": acctest.Representation{RepType: acctest.Optional, Create: `10`}, + "maximum_bandwidth_mbps": acctest.Representation{RepType: acctest.Optional, Create: `10`}, + "scaling_policy": acctest.RepresentationGroup{RepType: acctest.Optional, Group: DatascienceModelDeploymentModelDeploymentConfigurationDetailsModelConfigurationDetailsScalingPolicyRepresentation}, + } + + DatasciencePrivateModelDeploymentModelDeploymentConfigurationDetailsRepresentation = map[string]interface{}{ + "deployment_type": acctest.Representation{RepType: acctest.Required, Create: `SINGLE_MODEL`}, + "model_configuration_details": acctest.RepresentationGroup{RepType: acctest.Required, Group: DatasciencePrivateModelDeploymentModelDeploymentConfigurationDetailsModelConfigurationDetailsRepresentation}, + } + + DatasciencePrivateModelDeploymentResourceDependencies = acctest.GenerateResourceFromRepresentationMap("oci_datascience_model", "test_model", acctest.Optional, acctest.Create, modelForModelDeploymentRepresentation) + + acctest.GenerateResourceFromRepresentationMap("oci_datascience_model", "test_model_update", acctest.Optional, acctest.Create, modelForUpdateModelDeploymentRepresentation) + + acctest.GenerateResourceFromRepresentationMap("oci_core_subnet", "test_subnet", acctest.Required, acctest.Create, ModelDeploymentCoreSubnetRepresentation) + + acctest.GenerateResourceFromRepresentationMap("oci_core_vcn", "test_vcn", acctest.Required, acctest.Create, CoreVcnRepresentation) + + acctest.GenerateResourceFromRepresentationMap("oci_datascience_private_endpoint", "test_md_private_endpoint", acctest.Required, acctest.Create, DataScienceMDPrivateEndpointRepresentation) + + acctest.GenerateResourceFromRepresentationMap("oci_datascience_project", "test_project", acctest.Required, acctest.Create, DatascienceProjectRepresentation) + + DefinedTagsDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_logging_log_group", "test_log_group", acctest.Required, acctest.Create, logGroupMDRepresentation) + + acctest.GenerateResourceFromRepresentationMap("oci_logging_log", "test_access_log", acctest.Required, acctest.Create, customAccessLogRepresentation) + + acctest.GenerateResourceFromRepresentationMap("oci_logging_log", "test_predict_log", acctest.Required, acctest.Create, customPredictLogRepresentation) + + acctest.GenerateResourceFromRepresentationMap("oci_logging_log_group", "test_update_log_group", acctest.Required, acctest.Create, logGroupUpdateMDRepresentation) +) + +func TestDatasciencePrivateModelDeploymentResource_basic(t *testing.T) { + httpreplay.SetScenario("TestDatasciencePrivateModelDeploymentResource_basic") + defer httpreplay.SaveScenario() + + config := acctest.ProviderTestConfig() + + compartmentId := utils.GetEnvSettingWithBlankDefault("compartment_ocid") + compartmentIdVariableStr := fmt.Sprintf("variable \"compartment_id\" { default = \"%s\" }\n", compartmentId) + + compartmentIdU := utils.GetEnvSettingWithDefault("compartment_id_for_update", compartmentId) + compartmentIdUVariableStr := fmt.Sprintf("variable \"compartment_id_for_update\" { default = \"%s\" }\n", compartmentIdU) + + resourceName := "oci_datascience_model_deployment.test_model_deployment" + datasourceName := "data.oci_datascience_model_deployments.test_model_deployments" + singularDatasourceName := "data.oci_datascience_model_deployment.test_model_deployment" + + var resId, resId2 string + + acctest.ResourceTest(t, testAccCheckDatascienceModelDeploymentDestroy, []resource.TestStep{ + // 0. verify Create with optionals + { + Config: config + compartmentIdVariableStr + DatasciencePrivateModelDeploymentResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_datascience_model_deployment", "test_model_deployment", acctest.Optional, acctest.Create, DatasciencePrivateModelDeploymentRepresentation), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(resourceName, "category_log_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "category_log_details.0.access.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.access.0.log_group_id"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.access.0.log_id"), + resource.TestCheckResourceAttr(resourceName, "category_log_details.0.predict.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.predict.0.log_group_id"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.predict.0.log_id"), + resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttrSet(resourceName, "created_by"), + resource.TestCheckResourceAttr(resourceName, "description", "description"), + resource.TestCheckResourceAttr(resourceName, "display_name", "displayName"), + resource.TestCheckResourceAttr(resourceName, "freeform_tags.%", "1"), + resource.TestCheckResourceAttrSet(resourceName, "id"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.deployment_type", "SINGLE_MODEL"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.bandwidth_mbps", "10"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.instance_shape_name"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.cpu_baseline", "BASELINE_1_8"), + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.private_endpoint_id"), + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.subnet_id"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.maximum_bandwidth_mbps", "10"), + + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.memory_in_gbs", "6"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.ocpus", "1"), + + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.model_id"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.0.instance_count", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.0.policy_type", "FIXED_SIZE"), + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_url"), + resource.TestCheckResourceAttrSet(resourceName, "project_id"), + resource.TestCheckResourceAttrSet(resourceName, "time_created"), + + func(s *terraform.State) (err error) { + resId, err = acctest.FromInstanceState(s, resourceName, "id") + if isEnableExportCompartment, _ := strconv.ParseBool(utils.GetEnvSettingWithDefault("enable_export_compartment", "true")); isEnableExportCompartment { + if errExport := resourcediscovery.TestExportCompartmentWithResourceName(&resId, &compartmentId, resourceName); errExport != nil { + return errExport + } + } + return err + }, + )}, + + // 1. verify Deactivate model deployment + { + Config: config + compartmentIdVariableStr + compartmentIdUVariableStr + DatasciencePrivateModelDeploymentResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_datascience_model_deployment", "test_model_deployment", acctest.Optional, acctest.Create, + acctest.RepresentationCopyWithNewProperties(DatascienceModelDeploymentRepresentation, map[string]interface{}{ + "state": acctest.Representation{RepType: acctest.Optional, Create: `INACTIVE`}, + })), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(resourceName, "category_log_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "category_log_details.0.access.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.access.0.log_group_id"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.access.0.log_id"), + resource.TestCheckResourceAttr(resourceName, "category_log_details.0.predict.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.predict.0.log_group_id"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.predict.0.log_id"), + resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttrSet(resourceName, "created_by"), + resource.TestCheckResourceAttr(resourceName, "description", "description"), + resource.TestCheckResourceAttr(resourceName, "display_name", "displayName"), + resource.TestCheckResourceAttr(resourceName, "freeform_tags.%", "1"), + resource.TestCheckResourceAttrSet(resourceName, "id"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.deployment_type", "SINGLE_MODEL"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.bandwidth_mbps", "10"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.maximum_bandwidth_mbps", "10"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.instance_shape_name"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.cpu_baseline", "BASELINE_1_8"), + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.model_id"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.0.instance_count", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.0.policy_type", "FIXED_SIZE"), + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_url"), + resource.TestCheckResourceAttrSet(resourceName, "project_id"), + resource.TestCheckResourceAttrSet(resourceName, "time_created"), + resource.TestCheckResourceAttr(resourceName, "state", "INACTIVE"), + + func(s *terraform.State) (err error) { + resId2, err = acctest.FromInstanceState(s, resourceName, "id") + if resId != resId2 { + return fmt.Errorf("resource recreated when it was supposed to be updated") + } + return err + }, + ), + }, + + // 2. verify Activate model deployment + { + Config: config + compartmentIdVariableStr + compartmentIdUVariableStr + DatasciencePrivateModelDeploymentResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_datascience_model_deployment", "test_model_deployment", acctest.Optional, acctest.Create, + acctest.RepresentationCopyWithNewProperties(DatasciencePrivateModelDeploymentRepresentation, map[string]interface{}{ + "state": acctest.Representation{RepType: acctest.Optional, Create: `ACTIVE`}, + })), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(resourceName, "category_log_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "category_log_details.0.access.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.access.0.log_group_id"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.access.0.log_id"), + resource.TestCheckResourceAttr(resourceName, "category_log_details.0.predict.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.predict.0.log_group_id"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.predict.0.log_id"), + resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttrSet(resourceName, "created_by"), + resource.TestCheckResourceAttr(resourceName, "description", "description"), + resource.TestCheckResourceAttr(resourceName, "display_name", "displayName"), + resource.TestCheckResourceAttr(resourceName, "freeform_tags.%", "1"), + resource.TestCheckResourceAttrSet(resourceName, "id"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.deployment_type", "SINGLE_MODEL"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.bandwidth_mbps", "10"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.maximum_bandwidth_mbps", "10"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.instance_shape_name"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.cpu_baseline", "BASELINE_1_8"), + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.model_id"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.0.instance_count", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.0.policy_type", "FIXED_SIZE"), + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_url"), + resource.TestCheckResourceAttrSet(resourceName, "project_id"), + resource.TestCheckResourceAttrSet(resourceName, "time_created"), + resource.TestCheckResourceAttr(resourceName, "state", "ACTIVE"), + + func(s *terraform.State) (err error) { + resId2, err = acctest.FromInstanceState(s, resourceName, "id") + if resId != resId2 { + return fmt.Errorf("resource recreated when it was supposed to be updated") + } + return err + }, + ), + }, + + // 3. verify Update to the compartment (the compartment will be switched back in the next step) + { + Config: config + compartmentIdVariableStr + compartmentIdUVariableStr + DatasciencePrivateModelDeploymentResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_datascience_model_deployment", "test_model_deployment", acctest.Optional, acctest.Create, + acctest.RepresentationCopyWithNewProperties(DatasciencePrivateModelDeploymentRepresentation, map[string]interface{}{ + "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id_for_update}`}, + })), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(resourceName, "category_log_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "category_log_details.0.access.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.access.0.log_group_id"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.access.0.log_id"), + resource.TestCheckResourceAttr(resourceName, "category_log_details.0.predict.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.predict.0.log_group_id"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.predict.0.log_id"), + resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentIdU), + resource.TestCheckResourceAttrSet(resourceName, "created_by"), + resource.TestCheckResourceAttr(resourceName, "description", "description"), + resource.TestCheckResourceAttr(resourceName, "display_name", "displayName"), + resource.TestCheckResourceAttr(resourceName, "freeform_tags.%", "1"), + resource.TestCheckResourceAttrSet(resourceName, "id"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.deployment_type", "SINGLE_MODEL"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.bandwidth_mbps", "10"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.instance_shape_name"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.cpu_baseline", "BASELINE_1_8"), + + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.private_endpoint_id"), + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.subnet_id"), + + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.maximum_bandwidth_mbps", "10"), + + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.memory_in_gbs", "6"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.ocpus", "1"), + + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.model_id"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.0.instance_count", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.0.policy_type", "FIXED_SIZE"), + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_url"), + resource.TestCheckResourceAttrSet(resourceName, "project_id"), + resource.TestCheckResourceAttrSet(resourceName, "time_created"), + + func(s *terraform.State) (err error) { + resId2, err = acctest.FromInstanceState(s, resourceName, "id") + if resId != resId2 { + return fmt.Errorf("resource recreated when it was supposed to be updated") + } + return err + }, + ), + }, + + // 4. verify updates to updatable parameters + { + Config: config + compartmentIdVariableStr + DatasciencePrivateModelDeploymentResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_datascience_model_deployment", "test_model_deployment", acctest.Optional, acctest.Update, DatasciencePrivateModelDeploymentRepresentation), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(resourceName, "category_log_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "category_log_details.0.access.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.access.0.log_group_id"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.access.0.log_id"), + resource.TestCheckResourceAttr(resourceName, "category_log_details.0.predict.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.predict.0.log_group_id"), + resource.TestCheckResourceAttrSet(resourceName, "category_log_details.0.predict.0.log_id"), + resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttrSet(resourceName, "created_by"), + resource.TestCheckResourceAttr(resourceName, "description", "description2"), + resource.TestCheckResourceAttr(resourceName, "display_name", "displayName2"), + resource.TestCheckResourceAttr(resourceName, "freeform_tags.%", "1"), + resource.TestCheckResourceAttrSet(resourceName, "id"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.deployment_type", "SINGLE_MODEL"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.bandwidth_mbps", "10"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.#", "1"), + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.instance_shape_name"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.cpu_baseline", "BASELINE_1_2"), + + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.private_endpoint_id"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.maximum_bandwidth_mbps", "10"), + + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.memory_in_gbs", "12"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.ocpus", "2"), + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.subnet_id"), + + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.model_id"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.#", "1"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.0.instance_count", "2"), + resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.0.policy_type", "FIXED_SIZE"), + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_url"), + resource.TestCheckResourceAttrSet(resourceName, "project_id"), + resource.TestCheckResourceAttrSet(resourceName, "time_created"), + + func(s *terraform.State) (err error) { + resId2, err = acctest.FromInstanceState(s, resourceName, "id") + if resId != resId2 { + return fmt.Errorf("Resource recreated when it was supposed to be updated.") + } + return err + }, + ), + }, + + // 5. verify datasource - list model deployments + { + Config: config + + acctest.GenerateDataSourceFromRepresentationMap("oci_datascience_model_deployments", "test_model_deployments", acctest.Optional, acctest.Update, DatascienceDatasciencePrivateModelDeploymentDataSourceRepresentation) + + compartmentIdVariableStr + DatasciencePrivateModelDeploymentResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_datascience_model_deployment", "test_model_deployment", acctest.Optional, acctest.Update, DatasciencePrivateModelDeploymentRepresentation), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(datasourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttr(datasourceName, "display_name", "displayName2"), + resource.TestCheckResourceAttrSet(datasourceName, "id"), + resource.TestCheckResourceAttrSet(datasourceName, "project_id"), + resource.TestCheckResourceAttr(datasourceName, "state", "ACTIVE"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.#", "1"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.category_log_details.#", "1"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.category_log_details.0.access.#", "1"), + resource.TestCheckResourceAttrSet(datasourceName, "model_deployments.0.category_log_details.0.access.0.log_group_id"), + resource.TestCheckResourceAttrSet(datasourceName, "model_deployments.0.category_log_details.0.access.0.log_id"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.category_log_details.0.predict.#", "1"), + resource.TestCheckResourceAttrSet(datasourceName, "model_deployments.0.category_log_details.0.predict.0.log_group_id"), + resource.TestCheckResourceAttrSet(datasourceName, "model_deployments.0.category_log_details.0.predict.0.log_id"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.compartment_id", compartmentId), + resource.TestCheckResourceAttrSet(datasourceName, "model_deployments.0.created_by"), + //resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.description", "description2"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.display_name", "displayName2"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.freeform_tags.%", "1"), + resource.TestCheckResourceAttrSet(datasourceName, "model_deployments.0.id"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.model_deployment_configuration_details.#", "1"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.deployment_type", "SINGLE_MODEL"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.#", "1"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.0.bandwidth_mbps", "10"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.#", "1"), + resource.TestCheckResourceAttrSet(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.instance_shape_name"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.#", "1"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.cpu_baseline", "BASELINE_1_2"), + + resource.TestCheckResourceAttrSet(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.private_endpoint_id"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.0.maximum_bandwidth_mbps", "10"), + + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.memory_in_gbs", "12"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.ocpus", "2"), + resource.TestCheckResourceAttrSet(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.subnet_id"), + + resource.TestCheckResourceAttrSet(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.0.model_id"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.#", "1"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.0.instance_count", "2"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.0.policy_type", "FIXED_SIZE"), + resource.TestCheckResourceAttrSet(datasourceName, "model_deployments.0.model_deployment_url"), + resource.TestCheckResourceAttrSet(datasourceName, "model_deployments.0.project_id"), + resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.state", "ACTIVE"), + resource.TestCheckResourceAttrSet(datasourceName, "model_deployments.0.time_created"), + ), + }, + + // 6. verify singular datasource - get model deployment + { + Config: config + + acctest.GenerateDataSourceFromRepresentationMap("oci_datascience_model_deployment", "test_model_deployment", acctest.Required, acctest.Create, DatascienceDatasciencePrivateModelDeploymentSingularDataSourceRepresentation) + + compartmentIdVariableStr + DatasciencePrivateModelDeploymentResourceConfig, + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttrSet(singularDatasourceName, "model_deployment_id"), + + resource.TestCheckResourceAttr(singularDatasourceName, "category_log_details.#", "1"), + resource.TestCheckResourceAttr(singularDatasourceName, "category_log_details.0.access.#", "1"), + resource.TestCheckResourceAttr(singularDatasourceName, "category_log_details.0.predict.#", "1"), + resource.TestCheckResourceAttr(singularDatasourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttrSet(singularDatasourceName, "created_by"), + resource.TestCheckResourceAttr(singularDatasourceName, "display_name", "displayName2"), + resource.TestCheckResourceAttr(singularDatasourceName, "freeform_tags.%", "1"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "id"), + resource.TestCheckResourceAttr(singularDatasourceName, "model_deployment_configuration_details.#", "1"), + resource.TestCheckResourceAttr(singularDatasourceName, "model_deployment_configuration_details.0.deployment_type", "SINGLE_MODEL"), + resource.TestCheckResourceAttr(singularDatasourceName, "model_deployment_configuration_details.0.model_configuration_details.#", "1"), + resource.TestCheckResourceAttr(singularDatasourceName, "model_deployment_configuration_details.0.model_configuration_details.0.bandwidth_mbps", "10"), + resource.TestCheckResourceAttr(singularDatasourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.#", "1"), + resource.TestCheckResourceAttr(singularDatasourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.#", "1"), + resource.TestCheckResourceAttr(singularDatasourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.cpu_baseline", "BASELINE_1_2"), + resource.TestCheckResourceAttr(singularDatasourceName, "model_deployment_configuration_details.0.model_configuration_details.0.maximum_bandwidth_mbps", "10"), + resource.TestCheckResourceAttr(singularDatasourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.#", "1"), + resource.TestCheckResourceAttr(singularDatasourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.0.instance_count", "2"), + resource.TestCheckResourceAttr(singularDatasourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.0.policy_type", "FIXED_SIZE"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "model_deployment_url"), + resource.TestCheckNoResourceAttr(singularDatasourceName, "model_deployment_system_data.#"), + resource.TestCheckResourceAttr(singularDatasourceName, "state", "ACTIVE"), + resource.TestCheckResourceAttrSet(singularDatasourceName, "time_created"), + ), + }, + + // 7. verify resource import + { + Config: config + DatasciencePrivateModelDeploymentRequiredOnlyResource, + ImportState: true, + ImportStateVerify: true, + ImportStateVerifyIgnore: []string{ + "description", + }, + ResourceName: resourceName, + }, + }) +} diff --git a/internal/integrationtest/datascience_model_deployment_test.go b/internal/integrationtest/datascience_model_deployment_test.go index dc72dc06155..c5a6bf213dd 100644 --- a/internal/integrationtest/datascience_model_deployment_test.go +++ b/internal/integrationtest/datascience_model_deployment_test.go @@ -463,6 +463,7 @@ func TestDatascienceModelDeploymentResource_basic(t *testing.T) { resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.memory_in_gbs", "12"), resource.TestCheckResourceAttr(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.ocpus", "2"), + resource.TestCheckResourceAttrSet(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.subnet_id"), resource.TestCheckResourceAttrSet(resourceName, "model_deployment_configuration_details.0.model_configuration_details.0.model_id"), @@ -521,6 +522,7 @@ func TestDatascienceModelDeploymentResource_basic(t *testing.T) { resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.memory_in_gbs", "12"), resource.TestCheckResourceAttr(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.model_deployment_instance_shape_config_details.0.ocpus", "2"), + resource.TestCheckResourceAttrSet(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.0.instance_configuration.0.subnet_id"), resource.TestCheckResourceAttrSet(datasourceName, "model_deployments.0.model_deployment_configuration_details.0.model_configuration_details.0.model_id"), @@ -563,7 +565,7 @@ func TestDatascienceModelDeploymentResource_basic(t *testing.T) { resource.TestCheckResourceAttr(singularDatasourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.0.instance_count", "2"), resource.TestCheckResourceAttr(singularDatasourceName, "model_deployment_configuration_details.0.model_configuration_details.0.scaling_policy.0.policy_type", "FIXED_SIZE"), resource.TestCheckResourceAttrSet(singularDatasourceName, "model_deployment_url"), - resource.TestCheckNoResourceAttr(singularDatasourceName, "model_deployment_system_data"), + resource.TestCheckNoResourceAttr(singularDatasourceName, "model_deployment_system_data.#"), resource.TestCheckResourceAttr(singularDatasourceName, "state", "ACTIVE"), resource.TestCheckResourceAttrSet(singularDatasourceName, "time_created"), ), diff --git a/internal/service/datascience/datascience_model_deployment_resource.go b/internal/service/datascience/datascience_model_deployment_resource.go index 0aa446f802f..11b9c982d15 100644 --- a/internal/service/datascience/datascience_model_deployment_resource.go +++ b/internal/service/datascience/datascience_model_deployment_resource.go @@ -110,6 +110,11 @@ func DatascienceModelDeploymentResource() *schema.Resource { }, }, }, + "private_endpoint_id": { + Type: schema.TypeString, + Optional: true, + Computed: true, + }, "subnet_id": { Type: schema.TypeString, Optional: true, @@ -1304,6 +1309,13 @@ func (s *DatascienceModelDeploymentResourceCrud) mapToInstanceConfiguration(fiel } } + if privateEndpointId, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "private_endpoint_id")); ok { + tmp := privateEndpointId.(string) + if tmp != "" { + result.PrivateEndpointId = &tmp + } + } + if subnetId, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "subnet_id")); ok { tmp := subnetId.(string) result.SubnetId = &tmp @@ -1323,6 +1335,14 @@ func InstanceConfigurationToMap(obj *oci_datascience.InstanceConfiguration) map[ result["model_deployment_instance_shape_config_details"] = []interface{}{ModelDeploymentInstanceShapeConfigDetailsToMap(obj.ModelDeploymentInstanceShapeConfigDetails)} } + if obj.PrivateEndpointId != nil { + if *obj.PrivateEndpointId == "" { + result["private_endpoint_id"] = nil + } else { + result["private_endpoint_id"] = string(*obj.PrivateEndpointId) + } + } + if obj.SubnetId != nil { if *obj.SubnetId == "" { result["subnet_id"] = nil diff --git a/website/docs/d/datascience_job_run.html.markdown b/website/docs/d/datascience_job_run.html.markdown index 260631a7fbd..8bee1e9673f 100644 --- a/website/docs/d/datascience_job_run.html.markdown +++ b/website/docs/d/datascience_job_run.html.markdown @@ -32,7 +32,7 @@ The following arguments are supported: The following attributes are exported: -* `compartment_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment where you want to create the job. +* `compartment_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment where you want to create the job run. * `created_by` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the user who created the job run. * `defined_tags` - Defined tags for this resource. Each key is predefined and scoped to a namespace. See [Resource Tags](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). Example: `{"Operations.CostCenter": "42"}` * `display_name` - A user-friendly display name for the resource. @@ -50,7 +50,7 @@ The following attributes are exported: * `image_digest` - The digest of the container image. For example, `sha256:881303a6b2738834d795a32b4a98eb0e5e3d1cad590a712d1e04f9b2fa90a030` * `image_signature_id` - OCID of the container image signature * `job_environment_type` - The environment configuration type used for job runtime. -* `job_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the job run. +* `job_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the job. * `job_infrastructure_configuration_details` - The job infrastructure configuration details (shape, block storage, etc.) * `block_storage_size_in_gbs` - The size of the block storage volume to attach to the instance running the job * `job_infrastructure_type` - The infrastructure type used for job run. @@ -77,7 +77,7 @@ The following attributes are exported: * `log_details` - Customer logging details for job run. * `log_group_id` - The log group id for where log objects will be for job runs. * `log_id` - The log id of the log object the job run logs will be shipped to. -* `project_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the project to associate the job with. +* `project_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the project to associate the job run with. * `state` - The state of the job run. * `time_accepted` - The date and time the job run was accepted in the timestamp format defined by [RFC3339](https://tools.ietf.org/html/rfc3339). * `time_finished` - The date and time the job run request was finished in the timestamp format defined by [RFC3339](https://tools.ietf.org/html/rfc3339). diff --git a/website/docs/d/datascience_job_runs.html.markdown b/website/docs/d/datascience_job_runs.html.markdown index 3540fcc5212..a95d747a920 100644 --- a/website/docs/d/datascience_job_runs.html.markdown +++ b/website/docs/d/datascience_job_runs.html.markdown @@ -50,7 +50,7 @@ The following attributes are exported: The following attributes are exported: -* `compartment_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment where you want to create the job. +* `compartment_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment where you want to create the job run. * `created_by` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the user who created the job run. * `defined_tags` - Defined tags for this resource. Each key is predefined and scoped to a namespace. See [Resource Tags](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). Example: `{"Operations.CostCenter": "42"}` * `display_name` - A user-friendly display name for the resource. @@ -68,7 +68,7 @@ The following attributes are exported: * `image_digest` - The digest of the container image. For example, `sha256:881303a6b2738834d795a32b4a98eb0e5e3d1cad590a712d1e04f9b2fa90a030` * `image_signature_id` - OCID of the container image signature * `job_environment_type` - The environment configuration type used for job runtime. -* `job_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the job run. +* `job_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the job. * `job_infrastructure_configuration_details` - The job infrastructure configuration details (shape, block storage, etc.) * `block_storage_size_in_gbs` - The size of the block storage volume to attach to the instance running the job * `job_infrastructure_type` - The infrastructure type used for job run. @@ -95,7 +95,7 @@ The following attributes are exported: * `log_details` - Customer logging details for job run. * `log_group_id` - The log group id for where log objects will be for job runs. * `log_id` - The log id of the log object the job run logs will be shipped to. -* `project_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the project to associate the job with. +* `project_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the project to associate the job run with. * `state` - The state of the job run. * `time_accepted` - The date and time the job run was accepted in the timestamp format defined by [RFC3339](https://tools.ietf.org/html/rfc3339). * `time_finished` - The date and time the job run request was finished in the timestamp format defined by [RFC3339](https://tools.ietf.org/html/rfc3339). diff --git a/website/docs/d/datascience_model.html.markdown b/website/docs/d/datascience_model.html.markdown index 6ce29f30bd0..c07ce1735ea 100644 --- a/website/docs/d/datascience_model.html.markdown +++ b/website/docs/d/datascience_model.html.markdown @@ -43,7 +43,7 @@ The following attributes are exported: * `compartment_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the model's compartment. * `created_by` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the user who created the model. * `custom_metadata_list` - An array of custom metadata details for the model. - * `category` - Category of model metadata which should be null for defined metadata.For custom metadata is should be one of the following values "Performance,Training Profile,Training and Validation Datasets,Training Environment,other". + * `category` - Category of model metadata which should be null for defined metadata.For custom metadata is should be one of the following values "Performance,Training Profile,Training and Validation Datasets,Training Environment,Reports,Readme,other". * `description` - Description of model metadata * `key` - Key of the model Metadata. The key can either be user defined or Oracle Cloud Infrastructure defined. List of Oracle Cloud Infrastructure defined keys: * useCaseType @@ -51,12 +51,12 @@ The following attributes are exported: * libraryVersion * estimatorClass * hyperParameters - * testartifactresults + * testArtifactresults * `value` - Allowed values for useCaseType: binary_classification, regression, multinomial_classification, clustering, recommender, dimensionality_reduction/representation, time_series_forecasting, anomaly_detection, topic_modeling, ner, sentiment_analysis, image_classification, object_localization, other Allowed values for libraryName: scikit-learn, xgboost, tensorflow, pytorch, mxnet, keras, lightGBM, pymc3, pyOD, spacy, prophet, sktime, statsmodels, cuml, oracle_automl, h2o, transformers, nltk, emcee, pystan, bert, gensim, flair, word2vec, ensemble, other * `defined_metadata_list` - An array of defined metadata details for the model. - * `category` - Category of model metadata which should be null for defined metadata.For custom metadata is should be one of the following values "Performance,Training Profile,Training and Validation Datasets,Training Environment,other". + * `category` - Category of model metadata which should be null for defined metadata.For custom metadata is should be one of the following values "Performance,Training Profile,Training and Validation Datasets,Training Environment,Reports,Readme,other". * `description` - Description of model metadata * `key` - Key of the model Metadata. The key can either be user defined or Oracle Cloud Infrastructure defined. List of Oracle Cloud Infrastructure defined keys: * useCaseType @@ -64,7 +64,7 @@ The following attributes are exported: * libraryVersion * estimatorClass * hyperParameters - * testartifactresults + * testArtifactresults * `value` - Allowed values for useCaseType: binary_classification, regression, multinomial_classification, clustering, recommender, dimensionality_reduction/representation, time_series_forecasting, anomaly_detection, topic_modeling, ner, sentiment_analysis, image_classification, object_localization, other Allowed values for libraryName: scikit-learn, xgboost, tensorflow, pytorch, mxnet, keras, lightGBM, pymc3, pyOD, spacy, prophet, sktime, statsmodels, cuml, oracle_automl, h2o, transformers, nltk, emcee, pystan, bert, gensim, flair, word2vec, ensemble, other diff --git a/website/docs/d/datascience_model_deployment.html.markdown b/website/docs/d/datascience_model_deployment.html.markdown index ee65bba64b1..49c50aff07f 100644 --- a/website/docs/d/datascience_model_deployment.html.markdown +++ b/website/docs/d/datascience_model_deployment.html.markdown @@ -59,65 +59,66 @@ The following attributes are exported: * `image_digest` - The digest of the container image. For example, `sha256:881303a6b2738834d795a32b4a98eb0e5e3d1cad590a712d1e04f9b2fa90a030` * `server_port` - The port on which the web server serving the inference is running. The port can be anything between `1024` and `65535`. The following ports cannot be used `24224`, `8446`, `8447`. * `model_configuration_details` - The model configuration details. - * `bandwidth_mbps` - The minimum network bandwidth for the model deployment. - * `instance_configuration` - The model deployment instance configuration - * `instance_shape_name` - The shape used to launch the model deployment instances. - * `model_deployment_instance_shape_config_details` - Details for the model-deployment instance shape configuration. - * `cpu_baseline` - The baseline OCPU utilization for a subcore burstable VM instance. If this attribute is left blank, it will default to `BASELINE_1_1`. The following values are supported: BASELINE_1_8 - baseline usage is 1/8 of an OCPU. BASELINE_1_2 - baseline usage is 1/2 of an OCPU. BASELINE_1_1 - baseline usage is an entire OCPU. This represents a non-burstable instance. - * `memory_in_gbs` - A model-deployment instance of type VM.Standard.E3.Flex or VM.Standard.E4.Flex allows the memory to be specified with in the range of 6 to 1024 GB. VM.Standard3.Flex memory range is between 6 to 512 GB and VM.Optimized3.Flex memory range is between 6 to 256 GB. - * `ocpus` - A model-deployment instance of type VM.Standard.E3.Flex or VM.Standard.E4.Flex allows the ocpu count to be specified with in the range of 1 to 64 ocpu. VM.Standard3.Flex OCPU range is between 1 to 32 ocpu and for VM.Optimized3.Flex OCPU range is 1 to 18 ocpu. - * `subnet_id` - A model deployment instance is provided with a VNIC for network access. This specifies the [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the subnet to create a VNIC in. The subnet should be in a VCN with a NAT/SGW gateway for egress. - * `maximum_bandwidth_mbps` - The maximum network bandwidth for the model deployment. - * `model_id` - The OCID of the model you want to deploy. - * `scaling_policy` - The scaling policy to apply to each model of the deployment. - * `auto_scaling_policies` - The list of autoscaling policy details. - * `auto_scaling_policy_type` - The type of autoscaling policy. - * `initial_instance_count` - For a threshold-based autoscaling policy, this value is the initial number of instances to launch in the model deployment immediately after autoscaling is enabled. Note that anytime this value is updated, the number of instances will be reset to this value. After autoscaling retrieves performance metrics, the number of instances is automatically adjusted from this initial number to a number that is based on the limits that you set. - * `maximum_instance_count` - For a threshold-based autoscaling policy, this value is the maximum number of instances the model deployment is allowed to increase to (scale out). - * `minimum_instance_count` - For a threshold-based autoscaling policy, this value is the minimum number of instances the model deployment is allowed to decrease to (scale in). - * `rules` - The list of autoscaling policy rules. - * `metric_expression_rule_type` - The metric expression for creating the alarm used to trigger autoscaling actions on the model deployment. - - The following values are supported: - * `PREDEFINED_EXPRESSION`: An expression built using CPU or Memory metrics emitted by the Model Deployment Monitoring. - * `CUSTOM_EXPRESSION`: A custom Monitoring Query Language (MQL) expression. - * `metric_type` - Metric type - * `scale_in_configuration` - The scaling configuration for the predefined metric expression rule. - * `instance_count_adjustment` - The value is used for adjusting the count of instances by. - * `pending_duration` - The period of time that the condition defined in the alarm must persist before the alarm state changes from "OK" to "FIRING" or vice versa. For example, a value of 5 minutes means that the alarm must persist in breaching the condition for five minutes before the alarm updates its state to "FIRING"; likewise, the alarm must persist in not breaching the condition for five minutes before the alarm updates its state to "OK." - - The duration is specified as a string in ISO 8601 format (`PT10M` for ten minutes or `PT1H` for one hour). Minimum: PT3M. Maximum: PT1H. Default: PT3M. - * `query` - The Monitoring Query Language (MQL) expression to evaluate for the alarm. The Alarms feature of the Monitoring service interprets results for each returned time series as Boolean values, where zero represents false and a non-zero value represents true. A true value means that the trigger rule condition has been met. The query must specify a metric, statistic, interval, and trigger rule (threshold or absence). Supported values for interval: `1m`-`60m` (also `1h`). You can optionally specify dimensions and grouping functions. Supported grouping functions: `grouping()`, `groupBy()`. - - Example of threshold alarm: - - ----- - - CPUUtilization[1m]{resourceId = "MODEL_DEPLOYMENT_OCID"}.grouping().mean() < 25 CPUUtilization[1m]{resourceId = "MODEL_DEPLOYMENT_OCID"}.grouping().mean() > 75 - - ----- - * `scaling_configuration_type` - The type of scaling configuration. - * `threshold` - A metric value at which the scaling operation will be triggered. - * `scale_out_configuration` - The scaling configuration for the predefined metric expression rule. - * `instance_count_adjustment` - The value is used for adjusting the count of instances by. - * `pending_duration` - The period of time that the condition defined in the alarm must persist before the alarm state changes from "OK" to "FIRING" or vice versa. For example, a value of 5 minutes means that the alarm must persist in breaching the condition for five minutes before the alarm updates its state to "FIRING"; likewise, the alarm must persist in not breaching the condition for five minutes before the alarm updates its state to "OK." - - The duration is specified as a string in ISO 8601 format (`PT10M` for ten minutes or `PT1H` for one hour). Minimum: PT3M. Maximum: PT1H. Default: PT3M. - * `query` - The Monitoring Query Language (MQL) expression to evaluate for the alarm. The Alarms feature of the Monitoring service interprets results for each returned time series as Boolean values, where zero represents false and a non-zero value represents true. A true value means that the trigger rule condition has been met. The query must specify a metric, statistic, interval, and trigger rule (threshold or absence). Supported values for interval: `1m`-`60m` (also `1h`). You can optionally specify dimensions and grouping functions. Supported grouping functions: `grouping()`, `groupBy()`. - - Example of threshold alarm: - - ----- - - CPUUtilization[1m]{resourceId = "MODEL_DEPLOYMENT_OCID"}.grouping().mean() < 25 CPUUtilization[1m]{resourceId = "MODEL_DEPLOYMENT_OCID"}.grouping().mean() > 75 - - ----- - * `scaling_configuration_type` - The type of scaling configuration. - * `threshold` - A metric value at which the scaling operation will be triggered. - * `cool_down_in_seconds` - For threshold-based autoscaling policies, this value is the minimum period of time to wait between scaling actions. The cooldown period gives the system time to stabilize before rescaling. The minimum value is 600 seconds, which is also the default. The cooldown period starts when the model deployment becomes ACTIVE after the scaling operation. - * `instance_count` - The number of instances for the model deployment. - * `is_enabled` - Whether the autoscaling policy is enabled. - * `policy_type` - The type of scaling policy. + * `bandwidth_mbps` - The minimum network bandwidth for the model deployment. + * `instance_configuration` - The model deployment instance configuration + * `instance_shape_name` - The shape used to launch the model deployment instances. + * `model_deployment_instance_shape_config_details` - Details for the model-deployment instance shape configuration. + * `cpu_baseline` - The baseline OCPU utilization for a subcore burstable VM instance. If this attribute is left blank, it will default to `BASELINE_1_1`. The following values are supported: BASELINE_1_8 - baseline usage is 1/8 of an OCPU. BASELINE_1_2 - baseline usage is 1/2 of an OCPU. BASELINE_1_1 - baseline usage is an entire OCPU. This represents a non-burstable instance. + * `memory_in_gbs` - A model-deployment instance of type VM.Standard.E3.Flex or VM.Standard.E4.Flex allows the memory to be specified with in the range of 6 to 1024 GB. VM.Standard3.Flex memory range is between 6 to 512 GB and VM.Optimized3.Flex memory range is between 6 to 256 GB. + * `ocpus` - A model-deployment instance of type VM.Standard.E3.Flex or VM.Standard.E4.Flex allows the ocpu count to be specified with in the range of 1 to 64 ocpu. VM.Standard3.Flex OCPU range is between 1 to 32 ocpu and for VM.Optimized3.Flex OCPU range is 1 to 18 ocpu. + * `private_endpoint_id` - The OCID of a Data Science private endpoint. + * `subnet_id` - A model deployment instance is provided with a VNIC for network access. This specifies the [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the subnet to create a VNIC in. The subnet should be in a VCN with a NAT/SGW gateway for egress. + * `maximum_bandwidth_mbps` - The maximum network bandwidth for the model deployment. + * `model_id` - The OCID of the model you want to deploy. + * `scaling_policy` - The scaling policy to apply to each model of the deployment. + * `auto_scaling_policies` - The list of autoscaling policy details. + * `auto_scaling_policy_type` - The type of autoscaling policy. + * `initial_instance_count` - For a threshold-based autoscaling policy, this value is the initial number of instances to launch in the model deployment immediately after autoscaling is enabled. Note that anytime this value is updated, the number of instances will be reset to this value. After autoscaling retrieves performance metrics, the number of instances is automatically adjusted from this initial number to a number that is based on the limits that you set. + * `maximum_instance_count` - For a threshold-based autoscaling policy, this value is the maximum number of instances the model deployment is allowed to increase to (scale out). + * `minimum_instance_count` - For a threshold-based autoscaling policy, this value is the minimum number of instances the model deployment is allowed to decrease to (scale in). + * `rules` - The list of autoscaling policy rules. + * `metric_expression_rule_type` - The metric expression for creating the alarm used to trigger autoscaling actions on the model deployment. + + The following values are supported: + * `PREDEFINED_EXPRESSION`: An expression built using CPU or Memory metrics emitted by the Model Deployment Monitoring. + * `CUSTOM_EXPRESSION`: A custom Monitoring Query Language (MQL) expression. + * `metric_type` - Metric type + * `scale_in_configuration` - The scaling configuration for the predefined metric expression rule. + * `instance_count_adjustment` - The value is used for adjusting the count of instances by. + * `pending_duration` - The period of time that the condition defined in the alarm must persist before the alarm state changes from "OK" to "FIRING" or vice versa. For example, a value of 5 minutes means that the alarm must persist in breaching the condition for five minutes before the alarm updates its state to "FIRING"; likewise, the alarm must persist in not breaching the condition for five minutes before the alarm updates its state to "OK." + + The duration is specified as a string in ISO 8601 format (`PT10M` for ten minutes or `PT1H` for one hour). Minimum: PT3M. Maximum: PT1H. Default: PT3M. + * `query` - The Monitoring Query Language (MQL) expression to evaluate for the alarm. The Alarms feature of the Monitoring service interprets results for each returned time series as Boolean values, where zero represents false and a non-zero value represents true. A true value means that the trigger rule condition has been met. The query must specify a metric, statistic, interval, and trigger rule (threshold or absence). Supported values for interval: `1m`-`60m` (also `1h`). You can optionally specify dimensions and grouping functions. Supported grouping functions: `grouping()`, `groupBy()`. + + Example of threshold alarm: + + ----- + + CPUUtilization[1m]{resourceId = "MODEL_DEPLOYMENT_OCID"}.grouping().mean() < 25 CPUUtilization[1m]{resourceId = "MODEL_DEPLOYMENT_OCID"}.grouping().mean() > 75 + + ----- + * `scaling_configuration_type` - The type of scaling configuration. + * `threshold` - A metric value at which the scaling operation will be triggered. + * `scale_out_configuration` - The scaling configuration for the predefined metric expression rule. + * `instance_count_adjustment` - The value is used for adjusting the count of instances by. + * `pending_duration` - The period of time that the condition defined in the alarm must persist before the alarm state changes from "OK" to "FIRING" or vice versa. For example, a value of 5 minutes means that the alarm must persist in breaching the condition for five minutes before the alarm updates its state to "FIRING"; likewise, the alarm must persist in not breaching the condition for five minutes before the alarm updates its state to "OK." + + The duration is specified as a string in ISO 8601 format (`PT10M` for ten minutes or `PT1H` for one hour). Minimum: PT3M. Maximum: PT1H. Default: PT3M. + * `query` - The Monitoring Query Language (MQL) expression to evaluate for the alarm. The Alarms feature of the Monitoring service interprets results for each returned time series as Boolean values, where zero represents false and a non-zero value represents true. A true value means that the trigger rule condition has been met. The query must specify a metric, statistic, interval, and trigger rule (threshold or absence). Supported values for interval: `1m`-`60m` (also `1h`). You can optionally specify dimensions and grouping functions. Supported grouping functions: `grouping()`, `groupBy()`. + + Example of threshold alarm: + + ----- + + CPUUtilization[1m]{resourceId = "MODEL_DEPLOYMENT_OCID"}.grouping().mean() < 25 CPUUtilization[1m]{resourceId = "MODEL_DEPLOYMENT_OCID"}.grouping().mean() > 75 + + ----- + * `scaling_configuration_type` - The type of scaling configuration. + * `threshold` - A metric value at which the scaling operation will be triggered. + * `cool_down_in_seconds` - For threshold-based autoscaling policies, this value is the minimum period of time to wait between scaling actions. The cooldown period gives the system time to stabilize before rescaling. The minimum value is 600 seconds, which is also the default. The cooldown period starts when the model deployment becomes ACTIVE after the scaling operation. + * `instance_count` - The number of instances for the model deployment. + * `is_enabled` - Whether the autoscaling policy is enabled. + * `policy_type` - The type of scaling policy. * `model_deployment_system_data` - Model deployment system data. * `current_instance_count` - This value is the current count of the model deployment instances. * `system_infra_type` - The infrastructure type of the model deployment. diff --git a/website/docs/d/datascience_model_deployments.html.markdown b/website/docs/d/datascience_model_deployments.html.markdown index 8d809231db1..c2555d99301 100644 --- a/website/docs/d/datascience_model_deployments.html.markdown +++ b/website/docs/d/datascience_model_deployments.html.markdown @@ -82,9 +82,10 @@ The following attributes are exported: * `instance_configuration` - The model deployment instance configuration * `instance_shape_name` - The shape used to launch the model deployment instances. * `model_deployment_instance_shape_config_details` - Details for the model-deployment instance shape configuration. - * `cpu_baseline` - The baseline OCPU utilization for a subcore burstable VM instance. If this attribute is left blank, it will default to `BASELINE_1_1`. The following values are supported: BASELINE_1_8 - baseline usage is 1/8 of an OCPU. BASELINE_1_2 - baseline usage is 1/2 of an OCPU. BASELINE_1_1 - baseline usage is an entire OCPU. This represents a non-burstable instance. - * `memory_in_gbs` - A model-deployment instance of type VM.Standard.E3.Flex or VM.Standard.E4.Flex allows the memory to be specified with in the range of 6 to 1024 GB. VM.Standard3.Flex memory range is between 6 to 512 GB and VM.Optimized3.Flex memory range is between 6 to 256 GB. - * `ocpus` - A model-deployment instance of type VM.Standard.E3.Flex or VM.Standard.E4.Flex allows the ocpu count to be specified with in the range of 1 to 64 ocpu. VM.Standard3.Flex OCPU range is between 1 to 32 ocpu and for VM.Optimized3.Flex OCPU range is 1 to 18 ocpu. + * `cpu_baseline` - The baseline OCPU utilization for a subcore burstable VM instance. If this attribute is left blank, it will default to `BASELINE_1_1`. The following values are supported: BASELINE_1_8 - baseline usage is 1/8 of an OCPU. BASELINE_1_2 - baseline usage is 1/2 of an OCPU. BASELINE_1_1 - baseline usage is an entire OCPU. This represents a non-burstable instance. + * `memory_in_gbs` - A model-deployment instance of type VM.Standard.E3.Flex or VM.Standard.E4.Flex allows the memory to be specified with in the range of 6 to 1024 GB. VM.Standard3.Flex memory range is between 6 to 512 GB and VM.Optimized3.Flex memory range is between 6 to 256 GB. + * `ocpus` - A model-deployment instance of type VM.Standard.E3.Flex or VM.Standard.E4.Flex allows the ocpu count to be specified with in the range of 1 to 64 ocpu. VM.Standard3.Flex OCPU range is between 1 to 32 ocpu and for VM.Optimized3.Flex OCPU range is 1 to 18 ocpu. + * `private_endpoint_id` - The OCID of a Data Science private endpoint. * `subnet_id` - A model deployment instance is provided with a VNIC for network access. This specifies the [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the subnet to create a VNIC in. The subnet should be in a VCN with a NAT/SGW gateway for egress. * `maximum_bandwidth_mbps` - The maximum network bandwidth for the model deployment. * `model_id` - The OCID of the model you want to deploy. diff --git a/website/docs/d/datascience_models.html.markdown b/website/docs/d/datascience_models.html.markdown index 0e3e9dffb14..201b524ae06 100644 --- a/website/docs/d/datascience_models.html.markdown +++ b/website/docs/d/datascience_models.html.markdown @@ -62,7 +62,7 @@ The following attributes are exported: * `compartment_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the model's compartment. * `created_by` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the user who created the model. * `custom_metadata_list` - An array of custom metadata details for the model. - * `category` - Category of model metadata which should be null for defined metadata.For custom metadata is should be one of the following values "Performance,Training Profile,Training and Validation Datasets,Training Environment,other". + * `category` - Category of model metadata which should be null for defined metadata.For custom metadata is should be one of the following values "Performance,Training Profile,Training and Validation Datasets,Training Environment,Reports,Readme,other". * `description` - Description of model metadata * `key` - Key of the model Metadata. The key can either be user defined or Oracle Cloud Infrastructure defined. List of Oracle Cloud Infrastructure defined keys: * useCaseType @@ -70,12 +70,12 @@ The following attributes are exported: * libraryVersion * estimatorClass * hyperParameters - * testartifactresults + * testArtifactresults * `value` - Allowed values for useCaseType: binary_classification, regression, multinomial_classification, clustering, recommender, dimensionality_reduction/representation, time_series_forecasting, anomaly_detection, topic_modeling, ner, sentiment_analysis, image_classification, object_localization, other Allowed values for libraryName: scikit-learn, xgboost, tensorflow, pytorch, mxnet, keras, lightGBM, pymc3, pyOD, spacy, prophet, sktime, statsmodels, cuml, oracle_automl, h2o, transformers, nltk, emcee, pystan, bert, gensim, flair, word2vec, ensemble, other * `defined_metadata_list` - An array of defined metadata details for the model. - * `category` - Category of model metadata which should be null for defined metadata.For custom metadata is should be one of the following values "Performance,Training Profile,Training and Validation Datasets,Training Environment,other". + * `category` - Category of model metadata which should be null for defined metadata.For custom metadata is should be one of the following values "Performance,Training Profile,Training and Validation Datasets,Training Environment,Reports,Readme,other". * `description` - Description of model metadata * `key` - Key of the model Metadata. The key can either be user defined or Oracle Cloud Infrastructure defined. List of Oracle Cloud Infrastructure defined keys: * useCaseType @@ -83,7 +83,7 @@ The following attributes are exported: * libraryVersion * estimatorClass * hyperParameters - * testartifactresults + * testArtifactresults * `value` - Allowed values for useCaseType: binary_classification, regression, multinomial_classification, clustering, recommender, dimensionality_reduction/representation, time_series_forecasting, anomaly_detection, topic_modeling, ner, sentiment_analysis, image_classification, object_localization, other Allowed values for libraryName: scikit-learn, xgboost, tensorflow, pytorch, mxnet, keras, lightGBM, pymc3, pyOD, spacy, prophet, sktime, statsmodels, cuml, oracle_automl, h2o, transformers, nltk, emcee, pystan, bert, gensim, flair, word2vec, ensemble, other diff --git a/website/docs/r/datascience_job_run.html.markdown b/website/docs/r/datascience_job_run.html.markdown index 55e4d04bb87..0704f18ce65 100644 --- a/website/docs/r/datascience_job_run.html.markdown +++ b/website/docs/r/datascience_job_run.html.markdown @@ -86,7 +86,7 @@ The following arguments are supported: * `log_group_id` - (Optional) The log group id for where log objects are for job runs. * `log_id` - (Optional) The log id the job run will push logs too. * `opc_parent_rpt_url` - (Optional) URL to fetch the Resource Principal Token from the parent resource. -* `project_id` - (Required) The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the project to associate the job with. +* `project_id` - (Required) The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the project to associate the job run with. ** IMPORTANT ** @@ -96,7 +96,7 @@ Any change to a property that does not support update will force the destruction The following attributes are exported: -* `compartment_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment where you want to create the job. +* `compartment_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment where you want to create the job run. * `created_by` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the user who created the job run. * `defined_tags` - Defined tags for this resource. Each key is predefined and scoped to a namespace. See [Resource Tags](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). Example: `{"Operations.CostCenter": "42"}` * `display_name` - A user-friendly display name for the resource. @@ -114,7 +114,7 @@ The following attributes are exported: * `image_digest` - The digest of the container image. For example, `sha256:881303a6b2738834d795a32b4a98eb0e5e3d1cad590a712d1e04f9b2fa90a030` * `image_signature_id` - OCID of the container image signature * `job_environment_type` - The environment configuration type used for job runtime. -* `job_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the job run. +* `job_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the job. * `job_infrastructure_configuration_details` - The job infrastructure configuration details (shape, block storage, etc.) * `block_storage_size_in_gbs` - The size of the block storage volume to attach to the instance running the job * `job_infrastructure_type` - The infrastructure type used for job run. @@ -141,7 +141,7 @@ The following attributes are exported: * `log_details` - Customer logging details for job run. * `log_group_id` - The log group id for where log objects will be for job runs. * `log_id` - The log id of the log object the job run logs will be shipped to. -* `project_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the project to associate the job with. +* `project_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the project to associate the job run with. * `state` - The state of the job run. * `time_accepted` - The date and time the job run was accepted in the timestamp format defined by [RFC3339](https://tools.ietf.org/html/rfc3339). * `time_finished` - The date and time the job run request was finished in the timestamp format defined by [RFC3339](https://tools.ietf.org/html/rfc3339). diff --git a/website/docs/r/datascience_model.html.markdown b/website/docs/r/datascience_model.html.markdown index 2dfba0ae7d0..826ddaec053 100644 --- a/website/docs/r/datascience_model.html.markdown +++ b/website/docs/r/datascience_model.html.markdown @@ -73,7 +73,7 @@ The following arguments are supported: * `is_backup_enabled` - (Required) (Updatable) Boolean flag representing whether backup needs to be enabled/disabled for the model. * `compartment_id` - (Required) (Updatable) The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment to create the model in. * `custom_metadata_list` - (Optional) (Updatable) An array of custom metadata details for the model. - * `category` - (Optional) (Updatable) Category of model metadata which should be null for defined metadata.For custom metadata is should be one of the following values "Performance,Training Profile,Training and Validation Datasets,Training Environment,other". + * `category` - (Optional) (Updatable) Category of model metadata which should be null for defined metadata.For custom metadata is should be one of the following values "Performance,Training Profile,Training and Validation Datasets,Training Environment,Reports,Readme,other". * `description` - (Optional) (Updatable) Description of model metadata * `key` - (Optional) (Updatable) Key of the model Metadata. The key can either be user defined or Oracle Cloud Infrastructure defined. List of Oracle Cloud Infrastructure defined keys: * useCaseType @@ -81,12 +81,12 @@ The following arguments are supported: * libraryVersion * estimatorClass * hyperParameters - * testartifactresults + * testArtifactresults * `value` - (Optional) (Updatable) Allowed values for useCaseType: binary_classification, regression, multinomial_classification, clustering, recommender, dimensionality_reduction/representation, time_series_forecasting, anomaly_detection, topic_modeling, ner, sentiment_analysis, image_classification, object_localization, other Allowed values for libraryName: scikit-learn, xgboost, tensorflow, pytorch, mxnet, keras, lightGBM, pymc3, pyOD, spacy, prophet, sktime, statsmodels, cuml, oracle_automl, h2o, transformers, nltk, emcee, pystan, bert, gensim, flair, word2vec, ensemble, other * `defined_metadata_list` - (Optional) (Updatable) An array of defined metadata details for the model. - * `category` - (Optional) (Updatable) Category of model metadata which should be null for defined metadata.For custom metadata is should be one of the following values "Performance,Training Profile,Training and Validation Datasets,Training Environment,other". + * `category` - (Optional) (Updatable) Category of model metadata which should be null for defined metadata.For custom metadata is should be one of the following values "Performance,Training Profile,Training and Validation Datasets,Training Environment,Reports,Readme,other". * `description` - (Optional) (Updatable) Description of model metadata * `key` - (Optional) (Updatable) Key of the model Metadata. The key can either be user defined or Oracle Cloud Infrastructure defined. List of Oracle Cloud Infrastructure defined keys: * useCaseType @@ -94,7 +94,7 @@ The following arguments are supported: * libraryVersion * estimatorClass * hyperParameters - * testartifactresults + * testArtifactresults * `value` - (Optional) (Updatable) Allowed values for useCaseType: binary_classification, regression, multinomial_classification, clustering, recommender, dimensionality_reduction/representation, time_series_forecasting, anomaly_detection, topic_modeling, ner, sentiment_analysis, image_classification, object_localization, other Allowed values for libraryName: scikit-learn, xgboost, tensorflow, pytorch, mxnet, keras, lightGBM, pymc3, pyOD, spacy, prophet, sktime, statsmodels, cuml, oracle_automl, h2o, transformers, nltk, emcee, pystan, bert, gensim, flair, word2vec, ensemble, other @@ -132,7 +132,7 @@ The following attributes are exported: * `compartment_id` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the model's compartment. * `created_by` - The [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the user who created the model. * `custom_metadata_list` - An array of custom metadata details for the model. - * `category` - Category of model metadata which should be null for defined metadata.For custom metadata is should be one of the following values "Performance,Training Profile,Training and Validation Datasets,Training Environment,other". + * `category` - Category of model metadata which should be null for defined metadata.For custom metadata is should be one of the following values "Performance,Training Profile,Training and Validation Datasets,Training Environment,Reports,Readme,other". * `description` - Description of model metadata * `key` - Key of the model Metadata. The key can either be user defined or Oracle Cloud Infrastructure defined. List of Oracle Cloud Infrastructure defined keys: * useCaseType @@ -140,12 +140,12 @@ The following attributes are exported: * libraryVersion * estimatorClass * hyperParameters - * testartifactresults + * testArtifactresults * `value` - Allowed values for useCaseType: binary_classification, regression, multinomial_classification, clustering, recommender, dimensionality_reduction/representation, time_series_forecasting, anomaly_detection, topic_modeling, ner, sentiment_analysis, image_classification, object_localization, other Allowed values for libraryName: scikit-learn, xgboost, tensorflow, pytorch, mxnet, keras, lightGBM, pymc3, pyOD, spacy, prophet, sktime, statsmodels, cuml, oracle_automl, h2o, transformers, nltk, emcee, pystan, bert, gensim, flair, word2vec, ensemble, other * `defined_metadata_list` - An array of defined metadata details for the model. - * `category` - Category of model metadata which should be null for defined metadata.For custom metadata is should be one of the following values "Performance,Training Profile,Training and Validation Datasets,Training Environment,other". + * `category` - Category of model metadata which should be null for defined metadata.For custom metadata is should be one of the following values "Performance,Training Profile,Training and Validation Datasets,Training Environment,Reports,Readme,other". * `description` - Description of model metadata * `key` - Key of the model Metadata. The key can either be user defined or Oracle Cloud Infrastructure defined. List of Oracle Cloud Infrastructure defined keys: * useCaseType @@ -153,7 +153,7 @@ The following attributes are exported: * libraryVersion * estimatorClass * hyperParameters - * testartifactresults + * testArtifactresults * `value` - Allowed values for useCaseType: binary_classification, regression, multinomial_classification, clustering, recommender, dimensionality_reduction/representation, time_series_forecasting, anomaly_detection, topic_modeling, ner, sentiment_analysis, image_classification, object_localization, other Allowed values for libraryName: scikit-learn, xgboost, tensorflow, pytorch, mxnet, keras, lightGBM, pymc3, pyOD, spacy, prophet, sktime, statsmodels, cuml, oracle_automl, h2o, transformers, nltk, emcee, pystan, bert, gensim, flair, word2vec, ensemble, other diff --git a/website/docs/r/datascience_model_deployment.html.markdown b/website/docs/r/datascience_model_deployment.html.markdown index bdbbc984824..75b271e6e0c 100644 --- a/website/docs/r/datascience_model_deployment.html.markdown +++ b/website/docs/r/datascience_model_deployment.html.markdown @@ -35,6 +35,7 @@ resource "oci_datascience_model_deployment" "test_model_deployment" { memory_in_gbs = var.model_deployment_model_deployment_configuration_details_model_configuration_details_instance_configuration_model_deployment_instance_shape_config_details_memory_in_gbs ocpus = var.model_deployment_model_deployment_configuration_details_model_configuration_details_instance_configuration_model_deployment_instance_shape_config_details_ocpus } + private_endpoint_id = oci_datascience_private_endpoint.test_private_endpoint.id subnet_id = oci_core_subnet.test_subnet.id } model_id = oci_datascience_model.test_model.id @@ -159,7 +160,8 @@ The following arguments are supported: * `model_deployment_instance_shape_config_details` - (Optional) (Updatable) Details for the model-deployment instance shape configuration. * `cpu_baseline` - (Optional) (Updatable) The baseline OCPU utilization for a subcore burstable VM instance. If this attribute is left blank, it will default to `BASELINE_1_1`. The following values are supported: BASELINE_1_8 - baseline usage is 1/8 of an OCPU. BASELINE_1_2 - baseline usage is 1/2 of an OCPU. BASELINE_1_1 - baseline usage is an entire OCPU. This represents a non-burstable instance. * `memory_in_gbs` - (Optional) (Updatable) A model-deployment instance of type VM.Standard.E3.Flex or VM.Standard.E4.Flex allows the memory to be specified with in the range of 6 to 1024 GB. VM.Standard3.Flex memory range is between 6 to 512 GB and VM.Optimized3.Flex memory range is between 6 to 256 GB. - * `ocpus` - (Optional) (Updatable) A model-deployment instance of type VM.Standard.E3.Flex or VM.Standard.E4.Flex allows the ocpu count to be specified with in the range of 1 to 64 ocpu. VM.Standard3.Flex OCPU range is between 1 to 32 ocpu and for VM.Optimized3.Flex OCPU range is 1 to 18 ocpu. + * `ocpus` - (Optional) (Updatable) A model-deployment instance of type VM.Standard.E3.Flex or VM.Standard.E4.Flex allows the ocpu count to be specified with in the range of 1 to 64 ocpu. VM.Standard3.Flex OCPU range is between 1 to 32 ocpu and for VM.Optimized3.Flex OCPU range is 1 to 18 ocpu. + * `private_endpoint_id` - (Optional) (Updatable) The OCID of a Data Science private endpoint. * `subnet_id` - (Optional) (Updatable) A model deployment instance is provided with a VNIC for network access. This specifies the [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the subnet to create a VNIC in. The subnet should be in a VCN with a NAT/SGW gateway for egress. * `maximum_bandwidth_mbps` - (Optional) (Updatable) The maximum network bandwidth for the model deployment. * `model_id` - (Required) (Updatable) The OCID of the model you want to deploy. @@ -258,6 +260,7 @@ The following attributes are exported: * `cpu_baseline` - The baseline OCPU utilization for a subcore burstable VM instance. If this attribute is left blank, it will default to `BASELINE_1_1`. The following values are supported: BASELINE_1_8 - baseline usage is 1/8 of an OCPU. BASELINE_1_2 - baseline usage is 1/2 of an OCPU. BASELINE_1_1 - baseline usage is an entire OCPU. This represents a non-burstable instance. * `memory_in_gbs` - A model-deployment instance of type VM.Standard.E3.Flex or VM.Standard.E4.Flex allows the memory to be specified with in the range of 6 to 1024 GB. VM.Standard3.Flex memory range is between 6 to 512 GB and VM.Optimized3.Flex memory range is between 6 to 256 GB. * `ocpus` - A model-deployment instance of type VM.Standard.E3.Flex or VM.Standard.E4.Flex allows the ocpu count to be specified with in the range of 1 to 64 ocpu. VM.Standard3.Flex OCPU range is between 1 to 32 ocpu and for VM.Optimized3.Flex OCPU range is 1 to 18 ocpu. + * `private_endpoint_id` - The OCID of a Data Science private endpoint. * `subnet_id` - A model deployment instance is provided with a VNIC for network access. This specifies the [OCID](https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the subnet to create a VNIC in. The subnet should be in a VCN with a NAT/SGW gateway for egress. * `maximum_bandwidth_mbps` - The maximum network bandwidth for the model deployment. * `model_id` - The OCID of the model you want to deploy. From 23ccd4fdd961f15cc13a581a43e7990017ebaaf0 Mon Sep 17 00:00:00 2001 From: Pranjal Yadav Date: Tue, 22 Oct 2024 10:52:09 +0530 Subject: [PATCH 09/17] Added - Support for Extend OBP cloud service to include new SKUs for Digital Assets editions --- website/docs/d/blockchain_blockchain_platform.html.markdown | 2 +- website/docs/d/blockchain_blockchain_platforms.html.markdown | 2 +- website/docs/r/blockchain_blockchain_platform.html.markdown | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/website/docs/d/blockchain_blockchain_platform.html.markdown b/website/docs/d/blockchain_blockchain_platform.html.markdown index 5252b4636bb..897c8beaadf 100644 --- a/website/docs/d/blockchain_blockchain_platform.html.markdown +++ b/website/docs/d/blockchain_blockchain_platform.html.markdown @@ -49,7 +49,7 @@ The following attributes are exported: * `peer_key` - peer identifier * `role` - Peer role * `state` - The current state of the peer. -* `compute_shape` - Compute shape - STANDARD or ENTERPRISE_SMALL or ENTERPRISE_MEDIUM or ENTERPRISE_LARGE or ENTERPRISE_EXTRA_LARGE or ENTERPRISE_CUSTOM +* `compute_shape` - Compute shape - STANDARD or ENTERPRISE_SMALL or ENTERPRISE_MEDIUM or ENTERPRISE_LARGE or ENTERPRISE_EXTRA_LARGE or ENTERPRISE_CUSTOM or DIGITAL_ASSETS_MEDIUM or DIGITAL_ASSETS_LARGE or DIGITAL_ASSETS_EXTRA_LARGE * `defined_tags` - Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{"foo-namespace.bar-key": "value"}` * `description` - Platform Instance Description * `display_name` - Platform Instance Display name, can be renamed diff --git a/website/docs/d/blockchain_blockchain_platforms.html.markdown b/website/docs/d/blockchain_blockchain_platforms.html.markdown index 33d5312ddc8..720ff074bd2 100644 --- a/website/docs/d/blockchain_blockchain_platforms.html.markdown +++ b/website/docs/d/blockchain_blockchain_platforms.html.markdown @@ -61,7 +61,7 @@ The following attributes are exported: * `peer_key` - peer identifier * `role` - Peer role * `state` - The current state of the peer. -* `compute_shape` - Compute shape - STANDARD or ENTERPRISE_SMALL or ENTERPRISE_MEDIUM or ENTERPRISE_LARGE or ENTERPRISE_EXTRA_LARGE or ENTERPRISE_CUSTOM +* `compute_shape` - Compute shape - STANDARD or ENTERPRISE_SMALL or ENTERPRISE_MEDIUM or ENTERPRISE_LARGE or ENTERPRISE_EXTRA_LARGE or ENTERPRISE_CUSTOM or DIGITAL_ASSETS_MEDIUM or DIGITAL_ASSETS_LARGE or DIGITAL_ASSETS_EXTRA_LARGE * `defined_tags` - Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{"foo-namespace.bar-key": "value"}` * `description` - Platform Instance Description * `display_name` - Platform Instance Display name, can be renamed diff --git a/website/docs/r/blockchain_blockchain_platform.html.markdown b/website/docs/r/blockchain_blockchain_platform.html.markdown index 918de8bdc26..d1d0f617035 100644 --- a/website/docs/r/blockchain_blockchain_platform.html.markdown +++ b/website/docs/r/blockchain_blockchain_platform.html.markdown @@ -78,7 +78,7 @@ The following attributes are exported: * `peer_key` - peer identifier * `role` - Peer role * `state` - The current state of the peer. -* `compute_shape` - Compute shape - STANDARD or ENTERPRISE_SMALL or ENTERPRISE_MEDIUM or ENTERPRISE_LARGE or ENTERPRISE_EXTRA_LARGE or ENTERPRISE_CUSTOM +* `compute_shape` - Compute shape - STANDARD or ENTERPRISE_SMALL or ENTERPRISE_MEDIUM or ENTERPRISE_LARGE or ENTERPRISE_EXTRA_LARGE or ENTERPRISE_CUSTOM or DIGITAL_ASSETS_MEDIUM or DIGITAL_ASSETS_LARGE or DIGITAL_ASSETS_EXTRA_LARGE * `defined_tags` - Defined tags for this resource. Each key is predefined and scoped to a namespace. Example: `{"foo-namespace.bar-key": "value"}` * `description` - Platform Instance Description * `display_name` - Platform Instance Display name, can be renamed From 93e9c7d241d3359ea5f4e115e9338805d1dbf09b Mon Sep 17 00:00:00 2001 From: rgorle Date: Tue, 26 Nov 2024 11:02:48 +0530 Subject: [PATCH 10/17] Added - Support for StackMonitoring: Metric Extensions : Advanced Support and Integration --- .../metric_extensions/metric_extension.tf | 44 +++ .../metric_extension_on_given_resource.tf | 4 +- .../metric_extension_test.tf | 4 +- .../stack_monitoring_metric_extension_test.go | 315 ++++++++++++++++-- ...ck_monitoring_metric_extension_resource.go | 150 +++++++++ ...onitoring_metric_extensions_data_source.go | 11 +- ..._monitoring_metric_extension.html.markdown | 12 +- ...monitoring_metric_extensions.html.markdown | 19 +- ..._monitoring_metric_extension.html.markdown | 30 +- 9 files changed, 535 insertions(+), 54 deletions(-) diff --git a/examples/stack_monitoring/metric_extensions/metric_extension.tf b/examples/stack_monitoring/metric_extensions/metric_extension.tf index 2aa5a3ac03a..909f92ec4db 100644 --- a/examples/stack_monitoring/metric_extensions/metric_extension.tf +++ b/examples/stack_monitoring/metric_extensions/metric_extension.tf @@ -56,3 +56,47 @@ data "oci_stack_monitoring_metric_extension" "test_metric_extension_example" { #Required metric_extension_id = oci_stack_monitoring_metric_extension.test_metric_extension_example.id } + +resource "oci_stack_monitoring_metric_extension" "test_metric_extension_example_http" { + #Required + compartment_id = var.compartment_ocid + name = "ME_MetricExtensionTerraformExampleHttp" + resource_type = "oracle_goldengate_admin_server" + display_name = "Golden Gate IO Read Performance" + collection_recurrences = "FREQ=MINUTELY;INTERVAL=10" + metric_list { + name = "IoReadBytes" + display_name = "IO Read Bytes" + is_dimension = false + data_type = "NUMBER" + is_hidden = true + metric_category = "AVAILABILITY" + } + metric_list { + name = "IOReadRate" + display_name = "IO Read Rate" + is_dimension = false + data_type = "NUMBER" + is_hidden = false + metric_category = "AVAILABILITY" + compute_expression = "(IoReadBytes > 0 ? (__interval == 0 ? 0 : (IoReadBytes > _IoReadBytes ? (((IoReadBytes - _IoReadBytes) / __interval) / (1024 * 1024)) : 0)) : 0)" + } + query_properties { + collection_method = "HTTP" + url = "%pm_server_url%/services/v2/mpoints/%api_process_name%/processPerformance" + response_content_type = "APPLICATION_JSON" + protocol_type = "HTTPS" + script_details { + name = "ioRead_performance.js" + content = "ZnVuY3Rpb24gcnVuTWV0aG9kKG1ldHJpY09ic2VydmF0aW9uLCBzb3VyY2VQcm9wcykKewogICAgbGV0IHJlc3BvbnNlX3JhdyA9IEpTT04ucGFyc2UobWV0cmljT2JzZXJ2YXRpb24pOwogICAgbGV0IHJlc3BvbnNlID0gcmVzcG9uc2VfcmF3LnJlc3BvbnNlOwogICAgbGV0IGlvUmVhZEJ5dGVzID0gcmVzcG9uc2VbImlvUmVhZEJ5dGVzIl07CiAgICByZXR1cm4gW1tpb1JlYWRCeXRlc11dOwp9" + } + } + #Optional + description = "Collects count of instances in 'UP' status in staging compartments from monitoring table" + publish_trigger = var.publish_trigger +} + +data "oci_stack_monitoring_metric_extension" "test_metric_extension_example_http" { + # Required + metric_extension_id = oci_stack_monitoring_metric_extension.test_metric_extension_example_http.id +} diff --git a/examples/stack_monitoring/metric_extensions_on_given_resources_management/metric_extension_on_given_resource.tf b/examples/stack_monitoring/metric_extensions_on_given_resources_management/metric_extension_on_given_resource.tf index 9dfa2ea38c8..9a518aae863 100644 --- a/examples/stack_monitoring/metric_extensions_on_given_resources_management/metric_extension_on_given_resource.tf +++ b/examples/stack_monitoring/metric_extensions_on_given_resources_management/metric_extension_on_given_resource.tf @@ -81,6 +81,7 @@ resource "oci_stack_monitoring_monitored_resource" "test_monitored_resource_enab display_name = "ResourceMetricExtEnableTerraformExample" host_name = var.stack_mon_hostname_resource1 management_agent_id = var.stack_mon_management_agent_id_resource1 + license = "ENTERPRISE_EDITION" properties { name = "osName" value = "Linux" @@ -95,7 +96,8 @@ resource "oci_stack_monitoring_monitored_resource" "test_monitored_resource_enab credentials, properties, external_id, - defined_tags] + defined_tags, + system_tags] } } diff --git a/examples/stack_monitoring/metric_extensions_test_management/metric_extension_test.tf b/examples/stack_monitoring/metric_extensions_test_management/metric_extension_test.tf index e9f73db8dca..f124a8e2a57 100644 --- a/examples/stack_monitoring/metric_extensions_test_management/metric_extension_test.tf +++ b/examples/stack_monitoring/metric_extensions_test_management/metric_extension_test.tf @@ -79,6 +79,7 @@ resource "oci_stack_monitoring_monitored_resource" "test_monitored_resource_metr display_name = "metricExtensionTestTerraformExample" host_name = var.stack_mon_hostname_resource1 management_agent_id = var.stack_mon_management_agent_id_resource1 + license = "ENTERPRISE_EDITION" properties { name = "osName" value = "Linux" @@ -93,7 +94,8 @@ resource "oci_stack_monitoring_monitored_resource" "test_monitored_resource_metr credentials, properties, external_id, - defined_tags] + defined_tags, + system_tags] } } diff --git a/internal/integrationtest/stack_monitoring_metric_extension_test.go b/internal/integrationtest/stack_monitoring_metric_extension_test.go index a0543ac4343..8c8e8ae1549 100644 --- a/internal/integrationtest/stack_monitoring_metric_extension_test.go +++ b/internal/integrationtest/stack_monitoring_metric_extension_test.go @@ -30,19 +30,21 @@ var ( acctest.GenerateResourceFromRepresentationMap("oci_stack_monitoring_metric_extension", "test_metric_extension", acctest.Required, acctest.Create, StackMonitoringMetricExtensionRepresentation) StackMonitoringMetricExtensionResourceConfig = StackMonitoringMetricExtensionResourceDependencies + - acctest.GenerateResourceFromRepresentationMap("oci_stack_monitoring_metric_extension", "test_metric_extension", acctest.Optional, acctest.Update, StackMonitoringMetricExtensionRepresentation) + acctest.GenerateResourceFromRepresentationMap("oci_stack_monitoring_metric_extension", "test_metric_extension", acctest.Optional, acctest.Update, StackMonitoringMetricExtensionInParamRepresentation) StackMonitoringMetricExtensionSingularDataSourceRepresentation = map[string]interface{}{ "metric_extension_id": acctest.Representation{RepType: acctest.Required, Create: `${oci_stack_monitoring_metric_extension.test_metric_extension.id}`}, } StackMonitoringMetricExtensionDataSourceRepresentation = map[string]interface{}{ - "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id}`}, - "name": acctest.Representation{RepType: acctest.Optional, Create: `ME_CountOfRunningInstances`}, - "resource_type": acctest.Representation{RepType: acctest.Optional, Create: `ebs_instance`}, - "state": acctest.Representation{RepType: acctest.Optional, Create: `ACTIVE`}, - "status": acctest.Representation{RepType: acctest.Optional, Create: `DRAFT`}, - "filter": acctest.RepresentationGroup{RepType: acctest.Required, Group: StackMonitoringMetricExtensionDataSourceFilterRepresentation}} + "compartment_id": acctest.Representation{RepType: acctest.Optional, Create: `${var.compartment_id}`}, + "metric_extension_id": acctest.Representation{RepType: acctest.Optional, Create: `${oci_stack_monitoring_metric_extension.test_metric_extension.id}`}, + "name": acctest.Representation{RepType: acctest.Optional, Create: `ME_CountOfRunningInstances`}, + "resource_type": acctest.Representation{RepType: acctest.Optional, Create: `ebs_instance`}, + "state": acctest.Representation{RepType: acctest.Optional, Create: `ACTIVE`}, + "status": acctest.Representation{RepType: acctest.Optional, Create: `DRAFT`}, + "filter": acctest.RepresentationGroup{RepType: acctest.Required, Group: StackMonitoringMetricExtensionDataSourceFilterRepresentation}, + } StackMonitoringMetricExtensionDataSourceFilterRepresentation = map[string]interface{}{ "name": acctest.Representation{RepType: acctest.Required, Create: `id`}, @@ -60,6 +62,7 @@ var ( "description": acctest.Representation{RepType: acctest.Optional, Create: `Collects count of instances in 'UP' status in staging compartments from monitoring table`, Update: `Gives value 1 when All servers are in 'UP' status in production compartments in monitoring table`}, "publish_trigger": acctest.Representation{RepType: acctest.Optional, Create: `false`, Update: `false`}, } + StackMonitoringMetricExtensionMetricListRepresentation = map[string]interface{}{ "data_type": acctest.Representation{RepType: acctest.Required, Create: `NUMBER`}, "name": acctest.Representation{RepType: acctest.Required, Create: `CountOfRunningInstances`, Update: `AllServerStatus`}, @@ -70,6 +73,7 @@ var ( "metric_category": acctest.Representation{RepType: acctest.Optional, Create: `AVAILABILITY`, Update: `UTILIZATION`}, "unit": acctest.Representation{RepType: acctest.Optional, Create: `count`, Update: ` `}, } + StackMonitoringMetricExtensionQueryPropertiesRepresentation = map[string]interface{}{ "collection_method": acctest.Representation{RepType: acctest.Required, Create: `SQL`}, "in_param_details": acctest.RepresentationGroup{RepType: acctest.Optional, Group: StackMonitoringMetricExtensionQueryPropertiesInParamDetailsRepresentation}, @@ -77,17 +81,45 @@ var ( "sql_details": acctest.RepresentationGroup{RepType: acctest.Required, Group: StackMonitoringMetricExtensionQueryPropertiesSqlDetailsRepresentation}, "sql_type": acctest.Representation{RepType: acctest.Required, Create: `STATEMENT`, Update: `STATEMENT`}, } + StackMonitoringMetricExtensionQueryPropertiesInParamDetailsRepresentation = map[string]interface{}{ "in_param_position": acctest.Representation{RepType: acctest.Optional, Create: `1`, Update: `2`}, "in_param_value": acctest.Representation{RepType: acctest.Optional, Create: `staging`, Update: `production`}, } + StackMonitoringMetricExtensionQueryPropertiesOutParamDetailsRepresentation = map[string]interface{}{ + "out_param_name": acctest.Representation{RepType: acctest.Optional, Create: `outParamName`, Update: `outParamName2`}, "out_param_position": acctest.Representation{RepType: acctest.Optional, Create: `2`, Update: `3`}, "out_param_type": acctest.Representation{RepType: acctest.Optional, Create: `SQL_CURSOR`, Update: `ARRAY`}, } StackMonitoringMetricExtensionQueryPropertiesSqlDetailsRepresentation = map[string]interface{}{ - "content": acctest.Representation{RepType: acctest.Required, Create: `U0VMRUNUIGNvdW50KGluc3RhbmNlX2lkKSBGUk9NIG1vbml0b3JpbmdfdGFibGUgV0hFUkUgc3RhdHVzID0gJ1VQJyBBTkQgY29tcGFydG1lbnRfdHlwZSA9IDox`, Update: `U0VMRUNUIGNvdW50KGluc3RhbmNlX2lkKSBGUk9NIG1vbml0b3JpbmdfdGFibGUgV0hFUkUgc3RhdHVzID0gJ1VQJyBBTkQgY29tcGFydG1lbnRfdHlwZSA9IDoy`}, + "content": acctest.Representation{RepType: acctest.Required, Create: `U0VMRUNUIGNvdW50KGluc3RhbmNlX2lkKSBGUk9NIG1vbml0b3JpbmdfdGFibGUgV0hFUkUgc3RhdHVzID0gJ1VQJw==`, Update: `U0VMRUNUIGNvdW50KGluc3RhbmNlX2lkKSBGUk9NIG1vbml0b3JpbmdfdGFibGUgV0hFUkUgc3RhdHVzID0gJ1VQJw==`}, + "script_file_name": acctest.Representation{RepType: acctest.Optional, Create: `No-File`, Update: ` `}, + } + + StackMonitoringMetricExtensionInParamRepresentation = map[string]interface{}{ + "collection_recurrences": acctest.Representation{RepType: acctest.Required, Create: `FREQ=MINUTELY;INTERVAL=10`, Update: `FREQ=MINUTELY;INTERVAL=5`}, + "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id}`}, + "display_name": acctest.Representation{RepType: acctest.Required, Create: `Count of Running Instances`, Update: `All Server Instances Running Factor`}, + "metric_list": acctest.RepresentationGroup{RepType: acctest.Required, Group: StackMonitoringMetricExtensionMetricListRepresentation}, + "name": acctest.Representation{RepType: acctest.Required, Create: `ME_CountOfRunningInstances`}, + "query_properties": acctest.RepresentationGroup{RepType: acctest.Required, Group: StackMonitoringMetricExtensionQueryPropertiesInParamRepresentation}, + "resource_type": acctest.Representation{RepType: acctest.Required, Create: `ebs_instance`}, + "description": acctest.Representation{RepType: acctest.Optional, Create: `Collects count of instances in 'UP' status in staging compartments from monitoring table`, Update: `Gives value 1 when All servers are in 'UP' status in production compartments in monitoring table`}, + "publish_trigger": acctest.Representation{RepType: acctest.Optional, Create: `false`, Update: `false`}, + } + + StackMonitoringMetricExtensionQueryPropertiesInParamRepresentation = map[string]interface{}{ + "collection_method": acctest.Representation{RepType: acctest.Required, Create: `SQL`}, + "in_param_details": acctest.RepresentationGroup{RepType: acctest.Optional, Group: StackMonitoringMetricExtensionQueryPropertiesInParamDetailsRepresentation}, + "out_param_details": acctest.RepresentationGroup{RepType: acctest.Optional, Group: StackMonitoringMetricExtensionQueryPropertiesOutParamDetailsRepresentation}, + "sql_details": acctest.RepresentationGroup{RepType: acctest.Required, Group: StackMonitoringMetricExtensionQueryPropertiesSqlDetailsInParamRepresentation}, + "sql_type": acctest.Representation{RepType: acctest.Required, Create: `STATEMENT`, Update: `STATEMENT`}, + } + + StackMonitoringMetricExtensionQueryPropertiesSqlDetailsInParamRepresentation = map[string]interface{}{ + "content": acctest.Representation{RepType: acctest.Required, Create: `U0VMRUNUIGNvdW50KGluc3RhbmNlX2lkKSBpbnRvIDoyIEZST00gbW9uaXRvcmluZ190YWJsZSBXSEVSRSBzdGF0dXMgPSAnVVAnIEFORCBjb21wYXJ0bWVudF90eXBlID0gOjE=`, Update: `U0VMRUNUIGNvdW50KGluc3RhbmNlX2lkKSBpbnRvIDozIEZST00gbW9uaXRvcmluZ190YWJsZSBXSEVSRSBzdGF0dXMgPSAnVVAnIEFORCBjb21wYXJ0bWVudF90eXBlID0gOjI=`}, "script_file_name": acctest.Representation{RepType: acctest.Optional, Create: `No-File`, Update: ` `}, } @@ -146,6 +178,7 @@ var ( "metric_category": acctest.Representation{RepType: acctest.Optional, Create: `UTILIZATION`}, "unit": acctest.Representation{RepType: acctest.Optional, Create: `percent`}, } + StackMonitoringMetricExtensionQueryPropertiesForPublishRepresentation = map[string]interface{}{ "collection_method": acctest.Representation{RepType: acctest.Required, Create: `OS_COMMAND`}, "command": acctest.Representation{RepType: acctest.Optional, Create: `/bin/bash`}, @@ -173,12 +206,14 @@ var ( "description": acctest.Representation{RepType: acctest.Optional, Create: `Collects TotalPhysicalMemoryInGB for server named PIA in Giga bytes`, Update: `Collects TotalPhysicalMemoryInGB for server named PIA in GBs`}, "publish_trigger": acctest.Representation{RepType: acctest.Optional, Create: `false`, Update: `false`}, } + StackMonitoringMetricExtensionJmxMetricList0Representation = map[string]interface{}{ "data_type": acctest.Representation{RepType: acctest.Required, Create: `NUMBER`}, "name": acctest.Representation{RepType: acctest.Required, Create: `TotalPhysicalMemorySize`, Update: `TotalPhysicalMemorySizeInBytes`}, "is_dimension": acctest.Representation{RepType: acctest.Optional, Create: `false`, Update: `false`}, "is_hidden": acctest.Representation{RepType: acctest.Optional, Create: `true`, Update: `true`}, } + StackMonitoringMetricExtensionJmxMetricList1Representation = map[string]interface{}{ "data_type": acctest.Representation{RepType: acctest.Required, Create: `NUMBER`}, "name": acctest.Representation{RepType: acctest.Required, Create: `TotalPhysicalMemorySizeGigaBytes`, Update: `TotalPhysicalMemorySizeGB`}, @@ -187,6 +222,7 @@ var ( "is_dimension": acctest.Representation{RepType: acctest.Optional, Create: `false`, Update: `false`}, "is_hidden": acctest.Representation{RepType: acctest.Optional, Create: `false`, Update: `false`}, } + StackMonitoringMetricExtensionJmxQueryPropertiesRepresentation = map[string]interface{}{ "collection_method": acctest.Representation{RepType: acctest.Required, Create: `JMX`}, "managed_bean_query": acctest.Representation{RepType: acctest.Required, Create: `java.lang:type=OperatingSystem,Location=PIA`}, @@ -194,6 +230,50 @@ var ( "auto_row_prefix": acctest.Representation{RepType: acctest.Optional, Create: `PseudoKey`}, } + StackMonitoringMetricExtensionHttpRequiredOnlyResource = StackMonitoringMetricExtensionResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_stack_monitoring_metric_extension", "test_metric_extension_http", acctest.Required, acctest.Create, StackMonitoringMetricExtensionHttpRepresentation) + + StackMonitoringMetricExtensionHttpRepresentation = map[string]interface{}{ + "collection_recurrences": acctest.Representation{RepType: acctest.Required, Create: `FREQ=MINUTELY;INTERVAL=10`, Update: `FREQ=MINUTELY;INTERVAL=5`}, + "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id}`}, + "display_name": acctest.Representation{RepType: acctest.Required, Create: `IO Performance`, Update: `IO Process Performance`}, + "metric_list": []acctest.RepresentationGroup{{RepType: acctest.Required, Group: StackMonitoringMetricExtensionHttpMetricList0Representation}, {RepType: acctest.Required, Group: StackMonitoringMetricExtensionHttpMetricList1Representation}}, + "name": acctest.Representation{RepType: acctest.Required, Create: `ME_GoldenGateIoPerformance`}, + "query_properties": acctest.RepresentationGroup{RepType: acctest.Required, Group: StackMonitoringMetricExtensionHttpQueryPropertiesRepresentation}, + "resource_type": acctest.Representation{RepType: acctest.Required, Create: `oracle_goldengate_admin_server`}, + "description": acctest.Representation{RepType: acctest.Optional, Create: `Collects IO Performance Data`, Update: `Collects IO Process Performance Data`}, + "publish_trigger": acctest.Representation{RepType: acctest.Optional, Create: `false`, Update: `false`}, + } + + StackMonitoringMetricExtensionHttpMetricList0Representation = map[string]interface{}{ + "data_type": acctest.Representation{RepType: acctest.Required, Create: `NUMBER`}, + "name": acctest.Representation{RepType: acctest.Required, Create: `IoReadBytes`, Update: `IoProcessReadBytes`}, + "is_dimension": acctest.Representation{RepType: acctest.Optional, Create: `false`, Update: `false`}, + "is_hidden": acctest.Representation{RepType: acctest.Optional, Create: `true`, Update: `true`}, + } + + StackMonitoringMetricExtensionHttpMetricList1Representation = map[string]interface{}{ + "data_type": acctest.Representation{RepType: acctest.Required, Create: `NUMBER`}, + "name": acctest.Representation{RepType: acctest.Required, Create: `IoReadRate`, Update: `IoProcessReadRate`}, + "compute_expression": acctest.Representation{RepType: acctest.Optional, Create: `(IoReadBytes > 0 ? (__interval == 0 ? 0 : (IoReadBytes > _IoReadBytes ? (((IoReadBytes - _IoReadBytes) / __interval) / (1024 * 1024)) : 0)) : 0)`, Update: `(IoProcessReadBytes > 0 ? (__interval == 0 ? 0 : (IoProcessReadBytes > _IoProcessReadBytes ? (((IoProcessReadBytes - _IoProcessReadBytes) / __interval) / (1024 * 1024)) : 0)) : 0)`}, + "display_name": acctest.Representation{RepType: acctest.Optional, Create: `IO Read Rate`, Update: `IO Process Read Rate`}, + "is_dimension": acctest.Representation{RepType: acctest.Optional, Create: `false`, Update: `false`}, + "is_hidden": acctest.Representation{RepType: acctest.Optional, Create: `false`, Update: `false`}, + } + + StackMonitoringMetricExtensionHttpQueryPropertiesRepresentation = map[string]interface{}{ + "collection_method": acctest.Representation{RepType: acctest.Required, Create: `HTTP`}, + "url": acctest.Representation{RepType: acctest.Required, Create: `%pm_server_url%/services/v2/mpoints/%api_process_name%/processPerformance`, Update: `url2`}, + "protocol_type": acctest.Representation{RepType: acctest.Optional, Create: `HTTPS`, Update: `HTTPS`}, + "response_content_type": acctest.Representation{RepType: acctest.Required, Create: `APPLICATION_JSON`, Update: `TEXT_HTML`}, + "script_details": acctest.RepresentationGroup{RepType: acctest.Required, Group: StackMonitoringMetricExtensionHttpQueryPropertiesScriptDetailsRepresentation}, + } + + StackMonitoringMetricExtensionHttpQueryPropertiesScriptDetailsRepresentation = map[string]interface{}{ + "content": acctest.Representation{RepType: acctest.Required, Create: `ZnVuY3Rpb24gcnVuTWV0aG9kKG1ldHJpY09ic2VydmF0aW9uLCBzb3VyY2VQcm9wcykKewogICAgbGV0IHJlc3BvbnNlX3JhdyA9IEpTT04ucGFyc2UobWV0cmljT2JzZXJ2YXRpb24pOwogICAgbGV0IHJlc3BvbnNlID0gcmVzcG9uc2VfcmF3LnJlc3BvbnNlOwogICAgbGV0IGlvUmVhZEJ5dGVzID0gcmVzcG9uc2VbImlvUmVhZEJ5dGVzIl07CiAgICByZXR1cm4gW1tpb1JlYWRCeXRlc11dOwp9`}, + "name": acctest.Representation{RepType: acctest.Required, Create: `process_performance.js`}, + } + StackMonitoringMetricExtensionResourceDependencies = "" ) @@ -217,9 +297,10 @@ func TestStackMonitoringMetricExtensionResource_basic(t *testing.T) { resourceNameForPublish := "oci_stack_monitoring_metric_extension.test_metric_extension_for_publish" var resId, resId2, resId3, resId4 string + // Save TF content to Create resource with optional properties. This has to be exactly the same as the config part in the "create with optionals" step in the test. acctest.SaveConfigContent(config+compartmentIdVariableStr+StackMonitoringMetricExtensionResourceDependencies+ - acctest.GenerateResourceFromRepresentationMap("oci_stack_monitoring_metric_extension", "test_metric_extension", acctest.Optional, acctest.Create, StackMonitoringMetricExtensionRepresentation), "stackmonitoring", "metricExtension", t) + acctest.GenerateResourceFromRepresentationMap("oci_stack_monitoring_metric_extension", "test_metric_extension", acctest.Optional, acctest.Create, StackMonitoringMetricExtensionInParamRepresentation), "stackmonitoring", "metricExtension", t) acctest.ResourceTest(t, testAccCheckStackMonitoringMetricExtensionDestroy, []resource.TestStep{ // verify Create @@ -237,7 +318,7 @@ func TestStackMonitoringMetricExtensionResource_basic(t *testing.T) { resource.TestCheckResourceAttr(resourceName, "query_properties.#", "1"), resource.TestCheckResourceAttr(resourceName, "query_properties.0.collection_method", "SQL"), resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_details.#", "1"), - resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_details.0.content", "U0VMRUNUIGNvdW50KGluc3RhbmNlX2lkKSBGUk9NIG1vbml0b3JpbmdfdGFibGUgV0hFUkUgc3RhdHVzID0gJ1VQJyBBTkQgY29tcGFydG1lbnRfdHlwZSA9IDox"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_details.0.content", "U0VMRUNUIGNvdW50KGluc3RhbmNlX2lkKSBGUk9NIG1vbml0b3JpbmdfdGFibGUgV0hFUkUgc3RhdHVzID0gJ1VQJw=="), resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_type", "STATEMENT"), resource.TestCheckResourceAttr(resourceName, "resource_type", "ebs_instance"), resource.TestCheckResourceAttr(resourceName, "status", "DRAFT"), @@ -253,25 +334,26 @@ func TestStackMonitoringMetricExtensionResource_basic(t *testing.T) { { Config: config + compartmentIdVariableStr + StackMonitoringMetricExtensionResourceDependencies, }, + // verify Create with optionals { Config: config + compartmentIdVariableStr + StackMonitoringMetricExtensionResourceDependencies + - acctest.GenerateResourceFromRepresentationMap("oci_stack_monitoring_metric_extension", "test_metric_extension", acctest.Optional, acctest.Create, StackMonitoringMetricExtensionRepresentation), + acctest.GenerateResourceFromRepresentationMap("oci_stack_monitoring_metric_extension", "test_metric_extension", acctest.Optional, acctest.Create, StackMonitoringMetricExtensionInParamRepresentation), Check: acctest.ComposeAggregateTestCheckFuncWrapper( resource.TestCheckResourceAttrSet(resourceName, "collection_method"), resource.TestCheckResourceAttr(resourceName, "collection_recurrences", "FREQ=MINUTELY;INTERVAL=10"), resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), - resource.TestCheckResourceAttr(resourceName, "description", "Collects count of instances in 'UP' status in staging compartments from monitoring table"), resource.TestCheckResourceAttr(resourceName, "display_name", "Count of Running Instances"), + resource.TestCheckResourceAttr(resourceName, "description", "Collects count of instances in 'UP' status in staging compartments from monitoring table"), resource.TestCheckResourceAttrSet(resourceName, "id"), resource.TestCheckResourceAttr(resourceName, "metric_list.#", "1"), - resource.TestCheckResourceAttr(resourceName, "metric_list.0.compute_expression", "CountOfRunningInstances - _CountOfRunningInstances"), resource.TestCheckResourceAttr(resourceName, "metric_list.0.data_type", "NUMBER"), + resource.TestCheckResourceAttr(resourceName, "metric_list.0.name", "CountOfRunningInstances"), + resource.TestCheckResourceAttr(resourceName, "metric_list.0.compute_expression", "CountOfRunningInstances - _CountOfRunningInstances"), resource.TestCheckResourceAttr(resourceName, "metric_list.0.display_name", "Count of Running Instances"), resource.TestCheckResourceAttr(resourceName, "metric_list.0.is_dimension", "false"), resource.TestCheckResourceAttr(resourceName, "metric_list.0.is_hidden", "false"), resource.TestCheckResourceAttr(resourceName, "metric_list.0.metric_category", "AVAILABILITY"), - resource.TestCheckResourceAttr(resourceName, "metric_list.0.name", "CountOfRunningInstances"), resource.TestCheckResourceAttr(resourceName, "metric_list.0.unit", "count"), resource.TestCheckResourceAttr(resourceName, "name", "ME_CountOfRunningInstances"), resource.TestCheckResourceAttr(resourceName, "query_properties.#", "1"), @@ -280,10 +362,11 @@ func TestStackMonitoringMetricExtensionResource_basic(t *testing.T) { resource.TestCheckResourceAttr(resourceName, "query_properties.0.in_param_details.0.in_param_position", "1"), resource.TestCheckResourceAttr(resourceName, "query_properties.0.in_param_details.0.in_param_value", "staging"), resource.TestCheckResourceAttr(resourceName, "query_properties.0.out_param_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.out_param_details.0.out_param_name", "outParamName"), resource.TestCheckResourceAttr(resourceName, "query_properties.0.out_param_details.0.out_param_position", "2"), resource.TestCheckResourceAttr(resourceName, "query_properties.0.out_param_details.0.out_param_type", "SQL_CURSOR"), resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_details.#", "1"), - resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_details.0.content", "U0VMRUNUIGNvdW50KGluc3RhbmNlX2lkKSBGUk9NIG1vbml0b3JpbmdfdGFibGUgV0hFUkUgc3RhdHVzID0gJ1VQJyBBTkQgY29tcGFydG1lbnRfdHlwZSA9IDox"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_details.0.content", "U0VMRUNUIGNvdW50KGluc3RhbmNlX2lkKSBpbnRvIDoyIEZST00gbW9uaXRvcmluZ190YWJsZSBXSEVSRSBzdGF0dXMgPSAnVVAnIEFORCBjb21wYXJ0bWVudF90eXBlID0gOjE="), resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_details.0.script_file_name", "No-File"), resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_type", "STATEMENT"), resource.TestCheckResourceAttr(resourceName, "resource_type", "ebs_instance"), @@ -306,31 +389,37 @@ func TestStackMonitoringMetricExtensionResource_basic(t *testing.T) { { Config: config + compartmentIdVariableStr + compartmentIdUVariableStr + StackMonitoringMetricExtensionResourceDependencies + acctest.GenerateResourceFromRepresentationMap("oci_stack_monitoring_metric_extension", "test_metric_extension", acctest.Optional, acctest.Create, - acctest.RepresentationCopyWithNewProperties(StackMonitoringMetricExtensionRepresentation, map[string]interface{}{ + acctest.RepresentationCopyWithNewProperties(StackMonitoringMetricExtensionInParamRepresentation, map[string]interface{}{ "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id_for_update}`}, })), Check: acctest.ComposeAggregateTestCheckFuncWrapper( resource.TestCheckResourceAttrSet(resourceName, "collection_method"), resource.TestCheckResourceAttr(resourceName, "collection_recurrences", "FREQ=MINUTELY;INTERVAL=10"), resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentIdU), - resource.TestCheckResourceAttr(resourceName, "description", "Collects count of instances in 'UP' status in staging compartments from monitoring table"), resource.TestCheckResourceAttr(resourceName, "display_name", "Count of Running Instances"), + resource.TestCheckResourceAttr(resourceName, "description", "Collects count of instances in 'UP' status in staging compartments from monitoring table"), resource.TestCheckResourceAttrSet(resourceName, "id"), resource.TestCheckResourceAttr(resourceName, "metric_list.#", "1"), - resource.TestCheckResourceAttr(resourceName, "metric_list.0.compute_expression", "CountOfRunningInstances - _CountOfRunningInstances"), resource.TestCheckResourceAttr(resourceName, "metric_list.0.data_type", "NUMBER"), + resource.TestCheckResourceAttr(resourceName, "metric_list.0.name", "CountOfRunningInstances"), + resource.TestCheckResourceAttr(resourceName, "metric_list.0.compute_expression", "CountOfRunningInstances - _CountOfRunningInstances"), resource.TestCheckResourceAttr(resourceName, "metric_list.0.display_name", "Count of Running Instances"), resource.TestCheckResourceAttr(resourceName, "metric_list.0.is_dimension", "false"), resource.TestCheckResourceAttr(resourceName, "metric_list.0.is_hidden", "false"), resource.TestCheckResourceAttr(resourceName, "metric_list.0.metric_category", "AVAILABILITY"), - resource.TestCheckResourceAttr(resourceName, "metric_list.0.name", "CountOfRunningInstances"), resource.TestCheckResourceAttr(resourceName, "metric_list.0.unit", "count"), resource.TestCheckResourceAttr(resourceName, "name", "ME_CountOfRunningInstances"), resource.TestCheckResourceAttr(resourceName, "query_properties.#", "1"), resource.TestCheckResourceAttr(resourceName, "query_properties.0.collection_method", "SQL"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.in_param_details.#", "1"), resource.TestCheckResourceAttr(resourceName, "query_properties.0.in_param_details.0.in_param_position", "1"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.in_param_details.0.in_param_value", "staging"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.out_param_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.out_param_details.0.out_param_name", "outParamName"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.out_param_details.0.out_param_position", "2"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.out_param_details.0.out_param_type", "SQL_CURSOR"), resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_details.#", "1"), - resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_details.0.content", "U0VMRUNUIGNvdW50KGluc3RhbmNlX2lkKSBGUk9NIG1vbml0b3JpbmdfdGFibGUgV0hFUkUgc3RhdHVzID0gJ1VQJyBBTkQgY29tcGFydG1lbnRfdHlwZSA9IDox"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_details.0.content", "U0VMRUNUIGNvdW50KGluc3RhbmNlX2lkKSBpbnRvIDoyIEZST00gbW9uaXRvcmluZ190YWJsZSBXSEVSRSBzdGF0dXMgPSAnVVAnIEFORCBjb21wYXJ0bWVudF90eXBlID0gOjE="), resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_details.0.script_file_name", "No-File"), resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_type", "STATEMENT"), resource.TestCheckResourceAttr(resourceName, "resource_type", "ebs_instance"), @@ -350,22 +439,22 @@ func TestStackMonitoringMetricExtensionResource_basic(t *testing.T) { // verify updates to updatable parameters { Config: config + compartmentIdVariableStr + StackMonitoringMetricExtensionResourceDependencies + - acctest.GenerateResourceFromRepresentationMap("oci_stack_monitoring_metric_extension", "test_metric_extension", acctest.Optional, acctest.Update, StackMonitoringMetricExtensionRepresentation), + acctest.GenerateResourceFromRepresentationMap("oci_stack_monitoring_metric_extension", "test_metric_extension", acctest.Optional, acctest.Update, StackMonitoringMetricExtensionInParamRepresentation), Check: acctest.ComposeAggregateTestCheckFuncWrapper( resource.TestCheckResourceAttrSet(resourceName, "collection_method"), resource.TestCheckResourceAttr(resourceName, "collection_recurrences", "FREQ=MINUTELY;INTERVAL=5"), resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), - resource.TestCheckResourceAttr(resourceName, "description", "Gives value 1 when All servers are in 'UP' status in production compartments in monitoring table"), resource.TestCheckResourceAttr(resourceName, "display_name", "All Server Instances Running Factor"), + resource.TestCheckResourceAttr(resourceName, "description", "Gives value 1 when All servers are in 'UP' status in production compartments in monitoring table"), resource.TestCheckResourceAttrSet(resourceName, "id"), resource.TestCheckResourceAttr(resourceName, "metric_list.#", "1"), - resource.TestCheckResourceAttr(resourceName, "metric_list.0.compute_expression", "(AllServerStatus >= _AllServerStatus) ? 1 : 0"), resource.TestCheckResourceAttr(resourceName, "metric_list.0.data_type", "NUMBER"), + resource.TestCheckResourceAttr(resourceName, "metric_list.0.name", "AllServerStatus"), + resource.TestCheckResourceAttr(resourceName, "metric_list.0.compute_expression", "(AllServerStatus >= _AllServerStatus) ? 1 : 0"), resource.TestCheckResourceAttr(resourceName, "metric_list.0.display_name", "All Server Running Factor"), resource.TestCheckResourceAttr(resourceName, "metric_list.0.is_dimension", "false"), resource.TestCheckResourceAttr(resourceName, "metric_list.0.is_hidden", "false"), resource.TestCheckResourceAttr(resourceName, "metric_list.0.metric_category", "UTILIZATION"), - resource.TestCheckResourceAttr(resourceName, "metric_list.0.name", "AllServerStatus"), resource.TestCheckResourceAttr(resourceName, "metric_list.0.unit", " "), resource.TestCheckResourceAttr(resourceName, "name", "ME_CountOfRunningInstances"), resource.TestCheckResourceAttr(resourceName, "query_properties.#", "1"), @@ -374,10 +463,11 @@ func TestStackMonitoringMetricExtensionResource_basic(t *testing.T) { resource.TestCheckResourceAttr(resourceName, "query_properties.0.in_param_details.0.in_param_position", "2"), resource.TestCheckResourceAttr(resourceName, "query_properties.0.in_param_details.0.in_param_value", "production"), resource.TestCheckResourceAttr(resourceName, "query_properties.0.out_param_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.out_param_details.0.out_param_name", "outParamName2"), resource.TestCheckResourceAttr(resourceName, "query_properties.0.out_param_details.0.out_param_position", "3"), resource.TestCheckResourceAttr(resourceName, "query_properties.0.out_param_details.0.out_param_type", "ARRAY"), resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_details.#", "1"), - resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_details.0.content", "U0VMRUNUIGNvdW50KGluc3RhbmNlX2lkKSBGUk9NIG1vbml0b3JpbmdfdGFibGUgV0hFUkUgc3RhdHVzID0gJ1VQJyBBTkQgY29tcGFydG1lbnRfdHlwZSA9IDoy"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_details.0.content", "U0VMRUNUIGNvdW50KGluc3RhbmNlX2lkKSBpbnRvIDozIEZST00gbW9uaXRvcmluZ190YWJsZSBXSEVSRSBzdGF0dXMgPSAnVVAnIEFORCBjb21wYXJ0bWVudF90eXBlID0gOjI="), resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_details.0.script_file_name", " "), resource.TestCheckResourceAttr(resourceName, "query_properties.0.sql_type", "STATEMENT"), resource.TestCheckResourceAttr(resourceName, "resource_type", "ebs_instance"), @@ -387,7 +477,7 @@ func TestStackMonitoringMetricExtensionResource_basic(t *testing.T) { func(s *terraform.State) (err error) { resId2, err = acctest.FromInstanceState(s, resourceName, "id") if resId != resId2 { - return fmt.Errorf("Resource recreated when it was supposed to be updated.") + return fmt.Errorf("resource recreated when it was supposed to be updated") } return err }, @@ -399,9 +489,10 @@ func TestStackMonitoringMetricExtensionResource_basic(t *testing.T) { Config: config + acctest.GenerateDataSourceFromRepresentationMap("oci_stack_monitoring_metric_extensions", "test_metric_extensions", acctest.Optional, acctest.Update, StackMonitoringMetricExtensionDataSourceRepresentation) + compartmentIdVariableStr + StackMonitoringMetricExtensionResourceDependencies + - acctest.GenerateResourceFromRepresentationMap("oci_stack_monitoring_metric_extension", "test_metric_extension", acctest.Optional, acctest.Update, StackMonitoringMetricExtensionRepresentation), + acctest.GenerateResourceFromRepresentationMap("oci_stack_monitoring_metric_extension", "test_metric_extension", acctest.Optional, acctest.Update, StackMonitoringMetricExtensionInParamRepresentation), Check: acctest.ComposeAggregateTestCheckFuncWrapper( resource.TestCheckResourceAttr(datasourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttrSet(datasourceName, "metric_extension_id"), resource.TestCheckResourceAttr(datasourceName, "name", "ME_CountOfRunningInstances"), resource.TestCheckResourceAttr(datasourceName, "resource_type", "ebs_instance"), resource.TestCheckResourceAttr(datasourceName, "state", "ACTIVE"), @@ -418,13 +509,12 @@ func TestStackMonitoringMetricExtensionResource_basic(t *testing.T) { compartmentIdVariableStr + StackMonitoringMetricExtensionResourceConfig, Check: acctest.ComposeAggregateTestCheckFuncWrapper( resource.TestCheckResourceAttrSet(singularDatasourceName, "metric_extension_id"), - resource.TestCheckResourceAttrSet(singularDatasourceName, "collection_method"), resource.TestCheckResourceAttr(singularDatasourceName, "collection_recurrences", "FREQ=MINUTELY;INTERVAL=5"), resource.TestCheckResourceAttr(singularDatasourceName, "compartment_id", compartmentId), resource.TestCheckResourceAttrSet(singularDatasourceName, "created_by"), - resource.TestCheckResourceAttr(singularDatasourceName, "description", "Gives value 1 when All servers are in 'UP' status in production compartments in monitoring table"), resource.TestCheckResourceAttr(singularDatasourceName, "display_name", "All Server Instances Running Factor"), + resource.TestCheckResourceAttr(singularDatasourceName, "description", "Gives value 1 when All servers are in 'UP' status in production compartments in monitoring table"), resource.TestCheckResourceAttr(singularDatasourceName, "enabled_on_resources.#", "0"), resource.TestCheckResourceAttr(singularDatasourceName, "enabled_on_resources_count", "0"), resource.TestCheckResourceAttrSet(singularDatasourceName, "id"), @@ -444,10 +534,11 @@ func TestStackMonitoringMetricExtensionResource_basic(t *testing.T) { resource.TestCheckResourceAttr(singularDatasourceName, "query_properties.0.in_param_details.0.in_param_position", "2"), resource.TestCheckResourceAttr(singularDatasourceName, "query_properties.0.in_param_details.0.in_param_value", "production"), resource.TestCheckResourceAttr(singularDatasourceName, "query_properties.0.out_param_details.#", "1"), + resource.TestCheckResourceAttr(singularDatasourceName, "query_properties.0.out_param_details.0.out_param_name", "outParamName2"), resource.TestCheckResourceAttr(singularDatasourceName, "query_properties.0.out_param_details.0.out_param_position", "3"), resource.TestCheckResourceAttr(singularDatasourceName, "query_properties.0.out_param_details.0.out_param_type", "ARRAY"), resource.TestCheckResourceAttr(singularDatasourceName, "query_properties.0.sql_details.#", "1"), - resource.TestCheckResourceAttr(singularDatasourceName, "query_properties.0.sql_details.0.content", "U0VMRUNUIGNvdW50KGluc3RhbmNlX2lkKSBGUk9NIG1vbml0b3JpbmdfdGFibGUgV0hFUkUgc3RhdHVzID0gJ1VQJyBBTkQgY29tcGFydG1lbnRfdHlwZSA9IDoy"), + resource.TestCheckResourceAttr(singularDatasourceName, "query_properties.0.sql_details.0.content", "U0VMRUNUIGNvdW50KGluc3RhbmNlX2lkKSBpbnRvIDozIEZST00gbW9uaXRvcmluZ190YWJsZSBXSEVSRSBzdGF0dXMgPSAnVVAnIEFORCBjb21wYXJ0bWVudF90eXBlID0gOjI="), resource.TestCheckResourceAttr(singularDatasourceName, "query_properties.0.sql_details.0.script_file_name", " "), resource.TestCheckResourceAttr(singularDatasourceName, "query_properties.0.sql_type", "STATEMENT"), resource.TestCheckResourceAttr(singularDatasourceName, "resource_type", "ebs_instance"), @@ -737,7 +828,7 @@ func TestStackMonitoringMetricExtensionResource_jmx(t *testing.T) { func(s *terraform.State) (err error) { resId2, err = acctest.FromInstanceState(s, resourceName, "id") if resId != resId2 { - return fmt.Errorf("Resource recreated when it was supposed to be updated.") + return fmt.Errorf("resource recreated when it was supposed to be updated") } return err }, @@ -760,6 +851,168 @@ func TestStackMonitoringMetricExtensionResource_jmx(t *testing.T) { }) } +func TestStackMonitoringMetricExtensionResource_http(t *testing.T) { + httpreplay.SetScenario("TestStackMonitoringMetricExtensionResource_http") + defer httpreplay.SaveScenario() + + config := acctest.ProviderTestConfig() + + compartmentId := utils.GetEnvSettingWithBlankDefault("compartment_ocid") + compartmentIdVariableStr := fmt.Sprintf("variable \"compartment_id\" { default = \"%s\" }\n", compartmentId) + + resourceName := "oci_stack_monitoring_metric_extension.test_metric_extension_http" + + var resId, resId2 string + // Save TF content to Create resource with optional properties. This has to be exactly the same as the config part in the "create with optionals" step in the test. + acctest.SaveConfigContent(config+compartmentIdVariableStr+StackMonitoringMetricExtensionResourceDependencies+ + acctest.GenerateResourceFromRepresentationMap("oci_stack_monitoring_metric_extension", "test_metric_extension_http", acctest.Optional, acctest.Create, StackMonitoringMetricExtensionHttpRepresentation), "stackmonitoring", "metricExtension", t) + + acctest.ResourceTest(t, testAccCheckStackMonitoringMetricExtensionDestroy, []resource.TestStep{ + // verify Create + { + Config: config + compartmentIdVariableStr + StackMonitoringMetricExtensionResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_stack_monitoring_metric_extension", "test_metric_extension_http", acctest.Required, acctest.Create, StackMonitoringMetricExtensionHttpRepresentation), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(resourceName, "collection_recurrences", "FREQ=MINUTELY;INTERVAL=10"), + resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttr(resourceName, "display_name", "IO Performance"), + resource.TestCheckResourceAttr(resourceName, "metric_list.#", "2"), + resource.TestCheckResourceAttr(resourceName, "metric_list.0.data_type", "NUMBER"), + resource.TestCheckResourceAttr(resourceName, "metric_list.0.name", "IoReadBytes"), + resource.TestCheckResourceAttr(resourceName, "metric_list.1.data_type", "NUMBER"), + resource.TestCheckResourceAttr(resourceName, "metric_list.1.name", "IoReadRate"), + resource.TestCheckResourceAttr(resourceName, "name", "ME_GoldenGateIoPerformance"), + resource.TestCheckResourceAttr(resourceName, "query_properties.#", "1"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.collection_method", "HTTP"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.url", "%pm_server_url%/services/v2/mpoints/%api_process_name%/processPerformance"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.response_content_type", "APPLICATION_JSON"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.script_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.script_details.0.content", "ZnVuY3Rpb24gcnVuTWV0aG9kKG1ldHJpY09ic2VydmF0aW9uLCBzb3VyY2VQcm9wcykKewogICAgbGV0IHJlc3BvbnNlX3JhdyA9IEpTT04ucGFyc2UobWV0cmljT2JzZXJ2YXRpb24pOwogICAgbGV0IHJlc3BvbnNlID0gcmVzcG9uc2VfcmF3LnJlc3BvbnNlOwogICAgbGV0IGlvUmVhZEJ5dGVzID0gcmVzcG9uc2VbImlvUmVhZEJ5dGVzIl07CiAgICByZXR1cm4gW1tpb1JlYWRCeXRlc11dOwp9"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.script_details.0.name", "process_performance.js"), + resource.TestCheckResourceAttr(resourceName, "resource_type", "oracle_goldengate_admin_server"), + resource.TestCheckResourceAttr(resourceName, "status", "DRAFT"), + + func(s *terraform.State) (err error) { + resId, err = acctest.FromInstanceState(s, resourceName, "id") + return err + }, + ), + }, + + // delete before next Create + { + Config: config + compartmentIdVariableStr + StackMonitoringMetricExtensionResourceDependencies, + }, + // verify Create with optionals + { + Config: config + compartmentIdVariableStr + StackMonitoringMetricExtensionResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_stack_monitoring_metric_extension", "test_metric_extension_http", acctest.Optional, acctest.Create, StackMonitoringMetricExtensionHttpRepresentation), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttrSet(resourceName, "collection_method"), + resource.TestCheckResourceAttr(resourceName, "collection_recurrences", "FREQ=MINUTELY;INTERVAL=10"), + resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttr(resourceName, "display_name", "IO Performance"), + resource.TestCheckResourceAttr(resourceName, "description", "Collects IO Performance Data"), + resource.TestCheckResourceAttrSet(resourceName, "id"), + resource.TestCheckResourceAttr(resourceName, "metric_list.#", "2"), + resource.TestCheckResourceAttr(resourceName, "metric_list.0.data_type", "NUMBER"), + resource.TestCheckResourceAttr(resourceName, "metric_list.0.name", "IoReadBytes"), + resource.TestCheckResourceAttr(resourceName, "metric_list.0.is_hidden", "true"), + resource.TestCheckResourceAttr(resourceName, "metric_list.0.is_dimension", "false"), + resource.TestCheckResourceAttr(resourceName, "metric_list.1.data_type", "NUMBER"), + resource.TestCheckResourceAttr(resourceName, "metric_list.1.name", "IoReadRate"), + resource.TestCheckResourceAttr(resourceName, "metric_list.1.compute_expression", "(IoReadBytes > 0 ? (__interval == 0 ? 0 : (IoReadBytes > _IoReadBytes ? (((IoReadBytes - _IoReadBytes) / __interval) / (1024 * 1024)) : 0)) : 0)"), + resource.TestCheckResourceAttr(resourceName, "metric_list.1.display_name", "IO Read Rate"), + resource.TestCheckResourceAttr(resourceName, "metric_list.1.is_hidden", "false"), + resource.TestCheckResourceAttr(resourceName, "metric_list.1.is_dimension", "false"), + resource.TestCheckResourceAttr(resourceName, "name", "ME_GoldenGateIoPerformance"), + resource.TestCheckResourceAttr(resourceName, "query_properties.#", "1"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.collection_method", "HTTP"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.url", "%pm_server_url%/services/v2/mpoints/%api_process_name%/processPerformance"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.response_content_type", "APPLICATION_JSON"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.protocol_type", "HTTPS"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.script_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.script_details.0.content", "ZnVuY3Rpb24gcnVuTWV0aG9kKG1ldHJpY09ic2VydmF0aW9uLCBzb3VyY2VQcm9wcykKewogICAgbGV0IHJlc3BvbnNlX3JhdyA9IEpTT04ucGFyc2UobWV0cmljT2JzZXJ2YXRpb24pOwogICAgbGV0IHJlc3BvbnNlID0gcmVzcG9uc2VfcmF3LnJlc3BvbnNlOwogICAgbGV0IGlvUmVhZEJ5dGVzID0gcmVzcG9uc2VbImlvUmVhZEJ5dGVzIl07CiAgICByZXR1cm4gW1tpb1JlYWRCeXRlc11dOwp9"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.script_details.0.name", "process_performance.js"), + resource.TestCheckResourceAttr(resourceName, "resource_type", "oracle_goldengate_admin_server"), + resource.TestCheckResourceAttr(resourceName, "status", "DRAFT"), + resource.TestCheckResourceAttrSet(resourceName, "status"), + resource.TestCheckResourceAttrSet(resourceName, "tenant_id"), + + func(s *terraform.State) (err error) { + resId, err = acctest.FromInstanceState(s, resourceName, "id") + if isEnableExportCompartment, _ := strconv.ParseBool(utils.GetEnvSettingWithDefault("enable_export_compartment", "true")); isEnableExportCompartment { + if errExport := resourcediscovery.TestExportCompartmentWithResourceName(&resId, &compartmentId, resourceName); errExport != nil { + return errExport + } + } + return err + }, + ), + }, + + // verify updates to updatable parameters + { + Config: config + compartmentIdVariableStr + StackMonitoringMetricExtensionResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_stack_monitoring_metric_extension", "test_metric_extension_http", acctest.Optional, acctest.Update, StackMonitoringMetricExtensionHttpRepresentation), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttrSet(resourceName, "collection_method"), + resource.TestCheckResourceAttr(resourceName, "collection_recurrences", "FREQ=MINUTELY;INTERVAL=5"), + resource.TestCheckResourceAttr(resourceName, "compartment_id", compartmentId), + resource.TestCheckResourceAttr(resourceName, "display_name", "IO Process Performance"), + resource.TestCheckResourceAttr(resourceName, "description", "Collects IO Process Performance Data"), + resource.TestCheckResourceAttrSet(resourceName, "id"), + resource.TestCheckResourceAttr(resourceName, "metric_list.#", "2"), + resource.TestCheckResourceAttr(resourceName, "metric_list.0.data_type", "NUMBER"), + resource.TestCheckResourceAttr(resourceName, "metric_list.0.name", "IoProcessReadBytes"), + resource.TestCheckResourceAttr(resourceName, "metric_list.0.is_hidden", "true"), + resource.TestCheckResourceAttr(resourceName, "metric_list.0.is_dimension", "false"), + resource.TestCheckResourceAttr(resourceName, "metric_list.1.data_type", "NUMBER"), + resource.TestCheckResourceAttr(resourceName, "metric_list.1.name", "IoProcessReadRate"), + resource.TestCheckResourceAttr(resourceName, "metric_list.1.compute_expression", "(IoProcessReadBytes > 0 ? (__interval == 0 ? 0 : (IoProcessReadBytes > _IoProcessReadBytes ? (((IoProcessReadBytes - _IoProcessReadBytes) / __interval) / (1024 * 1024)) : 0)) : 0)"), + resource.TestCheckResourceAttr(resourceName, "metric_list.1.display_name", "IO Process Read Rate"), + resource.TestCheckResourceAttr(resourceName, "metric_list.1.is_hidden", "false"), + resource.TestCheckResourceAttr(resourceName, "metric_list.1.is_dimension", "false"), + resource.TestCheckResourceAttr(resourceName, "name", "ME_GoldenGateIoPerformance"), + resource.TestCheckResourceAttr(resourceName, "query_properties.#", "1"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.collection_method", "HTTP"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.url", "url2"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.response_content_type", "TEXT_HTML"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.protocol_type", "HTTPS"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.script_details.#", "1"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.script_details.0.content", "ZnVuY3Rpb24gcnVuTWV0aG9kKG1ldHJpY09ic2VydmF0aW9uLCBzb3VyY2VQcm9wcykKewogICAgbGV0IHJlc3BvbnNlX3JhdyA9IEpTT04ucGFyc2UobWV0cmljT2JzZXJ2YXRpb24pOwogICAgbGV0IHJlc3BvbnNlID0gcmVzcG9uc2VfcmF3LnJlc3BvbnNlOwogICAgbGV0IGlvUmVhZEJ5dGVzID0gcmVzcG9uc2VbImlvUmVhZEJ5dGVzIl07CiAgICByZXR1cm4gW1tpb1JlYWRCeXRlc11dOwp9"), + resource.TestCheckResourceAttr(resourceName, "query_properties.0.script_details.0.name", "process_performance.js"), + resource.TestCheckResourceAttr(resourceName, "resource_type", "oracle_goldengate_admin_server"), + resource.TestCheckResourceAttr(resourceName, "status", "DRAFT"), + resource.TestCheckResourceAttrSet(resourceName, "status"), + resource.TestCheckResourceAttrSet(resourceName, "tenant_id"), + + func(s *terraform.State) (err error) { + resId2, err = acctest.FromInstanceState(s, resourceName, "id") + if resId != resId2 { + return fmt.Errorf("resource recreated when it was supposed to be updated") + } + return err + }, + ), + }, + + // verify resource import + { + Config: config + StackMonitoringMetricExtensionHttpRequiredOnlyResource, + ImportState: true, + ImportStateVerify: true, + ImportStateVerifyIgnore: []string{}, + ResourceName: resourceName, + }, + + // delete http resource from previous step + { + Config: config + compartmentIdVariableStr + StackMonitoringMetricExtensionResourceDependencies, + }, + }) +} + func testAccCheckStackMonitoringMetricExtensionDestroy(s *terraform.State) error { noResourceFound := true client := acctest.TestAccProvider.Meta().(*tf_client.OracleClients).StackMonitoringClient() diff --git a/internal/service/stack_monitoring/stack_monitoring_metric_extension_resource.go b/internal/service/stack_monitoring/stack_monitoring_metric_extension_resource.go index 54707c6008f..fbe8cf1344a 100644 --- a/internal/service/stack_monitoring/stack_monitoring_metric_extension_resource.go +++ b/internal/service/stack_monitoring/stack_monitoring_metric_extension_resource.go @@ -111,6 +111,7 @@ func StackMonitoringMetricExtensionResource() *schema.Resource { Required: true, DiffSuppressFunc: tfresource.EqualIgnoreCaseSuppressDiff, ValidateFunc: validation.StringInSlice([]string{ + "HTTP", "JMX", "OS_COMMAND", "SQL", @@ -191,6 +192,11 @@ func StackMonitoringMetricExtensionResource() *schema.Resource { // Required // Optional + "out_param_name": { + Type: schema.TypeString, + Optional: true, + Computed: true, + }, "out_param_position": { Type: schema.TypeInt, Required: true, @@ -204,6 +210,16 @@ func StackMonitoringMetricExtensionResource() *schema.Resource { }, }, }, + "protocol_type": { + Type: schema.TypeString, + Optional: true, + Computed: true, + }, + "response_content_type": { + Type: schema.TypeString, + Optional: true, + Computed: true, + }, "script_details": { Type: schema.TypeList, Optional: true, @@ -263,6 +279,11 @@ func StackMonitoringMetricExtensionResource() *schema.Resource { Optional: true, Computed: true, }, + "url": { + Type: schema.TypeString, + Optional: true, + Computed: true, + }, // Computed }, @@ -779,6 +800,52 @@ func EnabledResourceDetailsToMap(obj oci_stack_monitoring.EnabledResourceDetails return result } +func (s *StackMonitoringMetricExtensionResourceCrud) mapToHttpScriptFileDetails(fieldKeyFormat string) (oci_stack_monitoring.HttpScriptFileDetails, error) { + result := oci_stack_monitoring.HttpScriptFileDetails{} + + if content, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "content")); ok { + tmp := content.(string) + result.Content = &tmp + } + + if name, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "name")); ok { + tmp := name.(string) + result.Name = &tmp + } + + return result, nil +} + +func (s *StackMonitoringMetricExtensionResourceCrud) mapToUpdateHttpScriptFileDetails(fieldKeyFormat string) (oci_stack_monitoring.UpdateHttpScriptFileDetails, error) { + result := oci_stack_monitoring.UpdateHttpScriptFileDetails{} + + if content, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "content")); ok { + tmp := content.(string) + result.Content = &tmp + } + + if name, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "name")); ok { + tmp := name.(string) + result.Name = &tmp + } + + return result, nil +} + +func HttpScriptFileDetailsToMap(obj *oci_stack_monitoring.HttpScriptFileDetails) map[string]interface{} { + result := map[string]interface{}{} + + if obj.Content != nil { + result["content"] = string(*obj.Content) + } + + if obj.Name != nil { + result["name"] = string(*obj.Name) + } + + return result +} + func (s *StackMonitoringMetricExtensionResourceCrud) mapToMetric(fieldKeyFormat string) (oci_stack_monitoring.Metric, error) { result := oci_stack_monitoring.Metric{} @@ -868,6 +935,29 @@ func (s *StackMonitoringMetricExtensionResourceCrud) mapToMetricExtensionQueryPr collectionMethod = "" // default value } switch strings.ToLower(collectionMethod) { + case strings.ToLower("HTTP"): + details := oci_stack_monitoring.HttpUpdateQueryProperties{} + if protocolType, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "protocol_type")); ok { + details.ProtocolType = oci_stack_monitoring.HttpProtocolTypesEnum(protocolType.(string)) + } + if responseContentType, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "response_content_type")); ok { + details.ResponseContentType = oci_stack_monitoring.HttpResponseContentTypesEnum(responseContentType.(string)) + } + if scriptDetails, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "script_details")); ok { + if tmpList := scriptDetails.([]interface{}); len(tmpList) > 0 { + fieldKeyFormatNextLevel := fmt.Sprintf("%s.%d.%%s", fmt.Sprintf(fieldKeyFormat, "script_details"), 0) + tmp, err := s.mapToUpdateHttpScriptFileDetails(fieldKeyFormatNextLevel) + if err != nil { + return details, fmt.Errorf("unable to convert script_details, encountered error: %v", err) + } + details.ScriptDetails = &tmp + } + } + if url, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "url")); ok { + tmp := url.(string) + details.Url = &tmp + } + baseObject = details case strings.ToLower("JMX"): details := oci_stack_monitoring.JmxUpdateQueryProperties{} if autoRowPrefix, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "auto_row_prefix")); ok { @@ -979,6 +1069,29 @@ func (s *StackMonitoringMetricExtensionResourceCrud) mapToMetricExtensionUpdateQ collectionMethod = "" // default value } switch strings.ToLower(collectionMethod) { + case strings.ToLower("HTTP"): + details := oci_stack_monitoring.HttpUpdateQueryProperties{} + if protocolType, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "protocol_type")); ok { + details.ProtocolType = oci_stack_monitoring.HttpProtocolTypesEnum(protocolType.(string)) + } + if responseContentType, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "response_content_type")); ok { + details.ResponseContentType = oci_stack_monitoring.HttpResponseContentTypesEnum(responseContentType.(string)) + } + if scriptDetails, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "script_details")); ok { + if tmpList := scriptDetails.([]interface{}); len(tmpList) > 0 { + fieldKeyFormatNextLevel := fmt.Sprintf("%s.%d.%%s", fmt.Sprintf(fieldKeyFormat, "script_details"), 0) + tmp, err := s.mapToUpdateHttpScriptFileDetails(fieldKeyFormatNextLevel) + if err != nil { + return details, fmt.Errorf("unable to convert script_details, encountered error: %v", err) + } + details.ScriptDetails = &tmp + } + } + if url, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "url")); ok { + tmp := url.(string) + details.Url = &tmp + } + baseObject = details case strings.ToLower("JMX"): details := oci_stack_monitoring.JmxUpdateQueryProperties{} if autoRowPrefix, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "auto_row_prefix")); ok { @@ -1082,6 +1195,20 @@ func (s *StackMonitoringMetricExtensionResourceCrud) mapToMetricExtensionUpdateQ func MetricExtensionQueryPropertiesToMap(obj *oci_stack_monitoring.MetricExtensionQueryProperties) map[string]interface{} { result := map[string]interface{}{} switch v := (*obj).(type) { + case oci_stack_monitoring.HttpQueryProperties: + result["collection_method"] = "HTTP" + + result["protocol_type"] = string(v.ProtocolType) + + result["response_content_type"] = string(v.ResponseContentType) + + if v.ScriptDetails != nil { + result["script_details"] = []interface{}{HttpScriptFileDetailsToMap(v.ScriptDetails)} + } + + if v.Url != nil { + result["url"] = string(*v.Url) + } case oci_stack_monitoring.JmxQueryProperties: result["collection_method"] = "JMX" @@ -1297,6 +1424,11 @@ func SqlInParamDetailsToMap(obj oci_stack_monitoring.SqlInParamDetails) map[stri func (s *StackMonitoringMetricExtensionResourceCrud) mapToSqlOutParamDetails(fieldKeyFormat string) (oci_stack_monitoring.SqlOutParamDetails, error) { result := oci_stack_monitoring.SqlOutParamDetails{} + if outParamName, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "out_param_name")); ok { + tmp := outParamName.(string) + result.OutParamName = &tmp + } + if outParamPosition, ok := s.D.GetOkExists(fmt.Sprintf(fieldKeyFormat, "out_param_position")); ok { tmp := outParamPosition.(int) result.OutParamPosition = &tmp @@ -1312,6 +1444,10 @@ func (s *StackMonitoringMetricExtensionResourceCrud) mapToSqlOutParamDetails(fie func SqlOutParamDetailsToMap(obj *oci_stack_monitoring.SqlOutParamDetails) map[string]interface{} { result := map[string]interface{}{} + if obj.OutParamName != nil { + result["out_param_name"] = string(*obj.OutParamName) + } + if obj.OutParamPosition != nil { result["out_param_position"] = int(*obj.OutParamPosition) } @@ -1321,6 +1457,20 @@ func SqlOutParamDetailsToMap(obj *oci_stack_monitoring.SqlOutParamDetails) map[s return result } +func UpdateHttpScriptFileDetailsToMap(obj *oci_stack_monitoring.UpdateHttpScriptFileDetails) map[string]interface{} { + result := map[string]interface{}{} + + if obj.Content != nil { + result["content"] = string(*obj.Content) + } + + if obj.Name != nil { + result["name"] = string(*obj.Name) + } + + return result +} + func (s *StackMonitoringMetricExtensionResourceCrud) updateCompartment(compartment interface{}) error { changeCompartmentRequest := oci_stack_monitoring.ChangeMetricExtensionCompartmentRequest{} diff --git a/internal/service/stack_monitoring/stack_monitoring_metric_extensions_data_source.go b/internal/service/stack_monitoring/stack_monitoring_metric_extensions_data_source.go index 06f15ac7256..acc82f8341c 100644 --- a/internal/service/stack_monitoring/stack_monitoring_metric_extensions_data_source.go +++ b/internal/service/stack_monitoring/stack_monitoring_metric_extensions_data_source.go @@ -20,12 +20,16 @@ func StackMonitoringMetricExtensionsDataSource() *schema.Resource { "filter": tfresource.DataSourceFiltersSchema(), "compartment_id": { Type: schema.TypeString, - Required: true, + Optional: true, }, "enabled_on_resource_id": { Type: schema.TypeString, Optional: true, }, + "metric_extension_id": { + Type: schema.TypeString, + Optional: true, + }, "name": { Type: schema.TypeString, Optional: true, @@ -91,6 +95,11 @@ func (s *StackMonitoringMetricExtensionsDataSourceCrud) Get() error { request.EnabledOnResourceId = &tmp } + if metricExtensionId, ok := s.D.GetOkExists("id"); ok { + tmp := metricExtensionId.(string) + request.MetricExtensionId = &tmp + } + if name, ok := s.D.GetOkExists("name"); ok { tmp := name.(string) request.Name = &tmp diff --git a/website/docs/d/stack_monitoring_metric_extension.html.markdown b/website/docs/d/stack_monitoring_metric_extension.html.markdown index c0ec5558763..e624a33eae3 100644 --- a/website/docs/d/stack_monitoring_metric_extension.html.markdown +++ b/website/docs/d/stack_monitoring_metric_extension.html.markdown @@ -67,16 +67,20 @@ The following attributes are exported: * `jmx_attributes` - List of JMX attributes or Metric Service Table columns separated by semi-colon * `managed_bean_query` - JMX Managed Bean Query or Metric Service Table name * `out_param_details` - Position and SQL Type of PL/SQL OUT parameter - * `out_param_position` - Position of PL/SQL procedure OUT parameter - * `out_param_type` - SQL Type of PL/SQL procedure OUT parameter - * `script_details` - Script details applicable to any OS Command based Metric Extension which needs to run a script to collect data - * `content` - Content of the script file as base64 encoded string + * `out_param_name` - Name of the Out Parameter + * `out_param_position` - Position of PL/SQL procedure OUT parameter. The value of this property is ignored during update, if "outParamType" is set to NO_OUT_PARAM value. + * `out_param_type` - SQL Type of PL/SQL procedure OUT parameter. During the update, to completely remove the out parameter, use the value NO_OUT_PARAM. In that case, the value of "outParamPosition" will be ignored. + * `protocol_type` - Supported protocol of resources to be associated with this metric extension. This is optional and defaults to HTTPS, which uses secure connection to the URL + * `response_content_type` - Type of content response given by the http(s) URL + * `script_details` - Script details applicable to any OS Command/HTTP based Metric Extension which needs to run a script to collect data. For removing it during OS Command based Metric Extension update, set its "content" property to an empty string. In that case, "name" property value is ignored. + * `content` - Content of the script/JavaScript file as base64 encoded string * `name` - Name of the script file * `sql_details` - Details of Sql content which needs to execute to collect Metric Extension data * `content` - Sql statement or script file content as base64 encoded string * `script_file_name` - If a script needs to be executed, then provide file name of the script * `sql_type` - Type of SQL data collection method i.e. either a Statement or SQL Script File * `starts_with` - String prefix used to identify metric output of the OS Command + * `url` - Http(s) end point URL * `resource_type` - Resource type to which Metric Extension applies * `resource_uri` - The URI path that the user can do a GET on to access the metric extension metadata * `state` - The current lifecycle state of the metric extension diff --git a/website/docs/d/stack_monitoring_metric_extensions.html.markdown b/website/docs/d/stack_monitoring_metric_extensions.html.markdown index a2f87c15544..a2b39c42e7c 100644 --- a/website/docs/d/stack_monitoring_metric_extensions.html.markdown +++ b/website/docs/d/stack_monitoring_metric_extensions.html.markdown @@ -16,11 +16,11 @@ Returns a list of metric extensions ```hcl data "oci_stack_monitoring_metric_extensions" "test_metric_extensions" { - #Required - compartment_id = var.compartment_id #Optional + compartment_id = var.compartment_id enabled_on_resource_id = oci_usage_proxy_resource.test_resource.id + metric_extension_id = oci_stack_monitoring_metric_extension.test_metric_extension.id name = var.metric_extension_name resource_type = var.metric_extension_resource_type state = var.metric_extension_state @@ -32,8 +32,9 @@ data "oci_stack_monitoring_metric_extensions" "test_metric_extensions" { The following arguments are supported: -* `compartment_id` - (Required) The ID of the compartment in which data is listed. +* `compartment_id` - (Optional) The ID of the compartment in which data is listed. * `enabled_on_resource_id` - (Optional) A filter to return metric extensions based on input resource Id on which metric extension is enabled +* `metric_extension_id` - (Optional) Identifier for the metric extension * `name` - (Optional) A filter to return resources based on name. * `resource_type` - (Optional) A filter to return resources based on resource type. * `state` - (Optional) A filter to return metric extensions based on Lifecycle State @@ -85,16 +86,20 @@ The following attributes are exported: * `jmx_attributes` - List of JMX attributes or Metric Service Table columns separated by semi-colon * `managed_bean_query` - JMX Managed Bean Query or Metric Service Table name * `out_param_details` - Position and SQL Type of PL/SQL OUT parameter - * `out_param_position` - Position of PL/SQL procedure OUT parameter - * `out_param_type` - SQL Type of PL/SQL procedure OUT parameter - * `script_details` - Script details applicable to any OS Command based Metric Extension which needs to run a script to collect data - * `content` - Content of the script file as base64 encoded string + * `out_param_name` - Name of the Out Parameter + * `out_param_position` - Position of PL/SQL procedure OUT parameter. The value of this property is ignored during update, if "outParamType" is set to NO_OUT_PARAM value. + * `out_param_type` - SQL Type of PL/SQL procedure OUT parameter. During the update, to completely remove the out parameter, use the value NO_OUT_PARAM. In that case, the value of "outParamPosition" will be ignored. + * `protocol_type` - Supported protocol of resources to be associated with this metric extension. This is optional and defaults to HTTPS, which uses secure connection to the URL + * `response_content_type` - Type of content response given by the http(s) URL + * `script_details` - Script details applicable to any OS Command/HTTP based Metric Extension which needs to run a script to collect data. For removing it during OS Command based Metric Extension update, set its "content" property to an empty string. In that case, "name" property value is ignored. + * `content` - Content of the script/JavaScript file as base64 encoded string * `name` - Name of the script file * `sql_details` - Details of Sql content which needs to execute to collect Metric Extension data * `content` - Sql statement or script file content as base64 encoded string * `script_file_name` - If a script needs to be executed, then provide file name of the script * `sql_type` - Type of SQL data collection method i.e. either a Statement or SQL Script File * `starts_with` - String prefix used to identify metric output of the OS Command + * `url` - Http(s) end point URL * `resource_type` - Resource type to which Metric Extension applies * `resource_uri` - The URI path that the user can do a GET on to access the metric extension metadata * `state` - The current lifecycle state of the metric extension diff --git a/website/docs/r/stack_monitoring_metric_extension.html.markdown b/website/docs/r/stack_monitoring_metric_extension.html.markdown index 33fadf9e8b1..53233c6580e 100644 --- a/website/docs/r/stack_monitoring_metric_extension.html.markdown +++ b/website/docs/r/stack_monitoring_metric_extension.html.markdown @@ -57,9 +57,12 @@ resource "oci_stack_monitoring_metric_extension" "test_metric_extension" { out_param_details { #Optional + out_param_name = var.metric_extension_query_properties_out_param_details_out_param_name out_param_position = var.metric_extension_query_properties_out_param_details_out_param_position out_param_type = var.metric_extension_query_properties_out_param_details_out_param_type } + protocol_type = var.metric_extension_query_properties_protocol_type + response_content_type = var.metric_extension_query_properties_response_content_type script_details { #Optional @@ -74,6 +77,7 @@ resource "oci_stack_monitoring_metric_extension" "test_metric_extension" { } sql_type = var.metric_extension_query_properties_sql_type starts_with = var.metric_extension_query_properties_starts_with + url = var.metric_extension_query_properties_url } resource_type = var.metric_extension_resource_type @@ -114,16 +118,20 @@ The following arguments are supported: * `jmx_attributes` - (Required when collection_method=JMX) (Updatable) List of JMX attributes or Metric Service Table columns separated by semi-colon * `managed_bean_query` - (Required when collection_method=JMX) (Updatable) JMX Managed Bean Query or Metric Service Table name * `out_param_details` - (Applicable when collection_method=SQL) (Updatable) Position and SQL Type of PL/SQL OUT parameter - * `out_param_position` - (Required when collection_method=SQL) (Updatable) Position of PL/SQL procedure OUT parameter - * `out_param_type` - (Required when collection_method=SQL) (Updatable) SQL Type of PL/SQL procedure OUT parameter - * `script_details` - (Applicable when collection_method=OS_COMMAND) (Updatable) Script details applicable to any OS Command based Metric Extension which needs to run a script to collect data - * `content` - (Required when collection_method=OS_COMMAND) (Updatable) Content of the script file as base64 encoded string - * `name` - (Required when collection_method=OS_COMMAND) (Updatable) Name of the script file + * `out_param_name` - (Applicable when collection_method=SQL) (Updatable) Name of the Out Parameter + * `out_param_position` - (Required when collection_method=SQL) (Updatable) Position of PL/SQL procedure OUT parameter. The value of this property is ignored during update, if "outParamType" is set to NO_OUT_PARAM value. + * `out_param_type` - (Required when collection_method=SQL) (Updatable) SQL Type of PL/SQL procedure OUT parameter. During the update, to completely remove the out parameter, use the value NO_OUT_PARAM. In that case, the value of "outParamPosition" will be ignored. + * `protocol_type` - (Applicable when collection_method=HTTP) (Updatable) Supported protocol of resources to be associated with this metric extension. This is optional and defaults to HTTPS, which uses secure connection to the URL + * `response_content_type` - (Required when collection_method=HTTP) (Updatable) Type of content response given by the http(s) URL + * `script_details` - (Required when collection_method=HTTP | OS_COMMAND) (Updatable) Script details applicable to any OS Command/HTTP based Metric Extension which needs to run a script to collect data. For removing it during OS Command based Metric Extension update, set its "content" property to an empty string. In that case, "name" property value is ignored. + * `content` - (Required when collection_method=HTTP | OS_COMMAND) (Updatable) Content of the script/JavaScript file as base64 encoded string + * `name` - (Required when collection_method=HTTP | OS_COMMAND) (Updatable) Name of the script file * `sql_details` - (Required when collection_method=SQL) (Updatable) Details of Sql content which needs to execute to collect Metric Extension data * `content` - (Required when collection_method=SQL) (Updatable) Sql statement or script file content as base64 encoded string * `script_file_name` - (Applicable when collection_method=SQL) (Updatable) If a script needs to be executed, then provide file name of the script * `sql_type` - (Required when collection_method=SQL) (Updatable) Type of SQL data collection method i.e. either a Statement or SQL Script File * `starts_with` - (Applicable when collection_method=OS_COMMAND) (Updatable) String prefix used to identify metric output of the OS Command + * `url` - (Required when collection_method=HTTP) (Updatable) Http(s) end point URL * `resource_type` - (Required) Resource type to which Metric Extension applies * `publish_trigger` - (Optional) (Updatable) An optional property when set to `true` triggers Publish of a metric extension. Once set to `true`, it cannot be changed back to `false`. Update of publish_trigger cannot be combined with other updates in the same request. A metric extension cannot be tested and its definition cannot be updated once it is marked published or publish_trigger is updated to `true`. @@ -170,16 +178,20 @@ The following attributes are exported: * `jmx_attributes` - List of JMX attributes or Metric Service Table columns separated by semi-colon * `managed_bean_query` - JMX Managed Bean Query or Metric Service Table name * `out_param_details` - Position and SQL Type of PL/SQL OUT parameter - * `out_param_position` - Position of PL/SQL procedure OUT parameter - * `out_param_type` - SQL Type of PL/SQL procedure OUT parameter - * `script_details` - Script details applicable to any OS Command based Metric Extension which needs to run a script to collect data - * `content` - Content of the script file as base64 encoded string + * `out_param_name` - Name of the Out Parameter + * `out_param_position` - Position of PL/SQL procedure OUT parameter. The value of this property is ignored during update, if "outParamType" is set to NO_OUT_PARAM value. + * `out_param_type` - SQL Type of PL/SQL procedure OUT parameter. During the update, to completely remove the out parameter, use the value NO_OUT_PARAM. In that case, the value of "outParamPosition" will be ignored. + * `protocol_type` - Supported protocol of resources to be associated with this metric extension. This is optional and defaults to HTTPS, which uses secure connection to the URL + * `response_content_type` - Type of content response given by the http(s) URL + * `script_details` - Script details applicable to any OS Command/HTTP based Metric Extension which needs to run a script to collect data. For removing it during OS Command based Metric Extension update, set its "content" property to an empty string. In that case, "name" property value is ignored. + * `content` - Content of the script/JavaScript file as base64 encoded string * `name` - Name of the script file * `sql_details` - Details of Sql content which needs to execute to collect Metric Extension data * `content` - Sql statement or script file content as base64 encoded string * `script_file_name` - If a script needs to be executed, then provide file name of the script * `sql_type` - Type of SQL data collection method i.e. either a Statement or SQL Script File * `starts_with` - String prefix used to identify metric output of the OS Command + * `url` - Http(s) end point URL * `resource_type` - Resource type to which Metric Extension applies * `resource_uri` - The URI path that the user can do a GET on to access the metric extension metadata * `state` - The current lifecycle state of the metric extension From 11dffb20f44c85d00171bd48827188a7e1bd7d41 Mon Sep 17 00:00:00 2001 From: Xiaodi Tao Date: Fri, 9 Aug 2024 15:43:09 -0700 Subject: [PATCH 11/17] Added - Support for ADB-S: Backup Retention Lock --- examples/database/adb/autonomous_database.tf | 14 +++ ...ous_database_lock_backup_retention_test.go | 90 +++++++++++++++++++ ...atabase_autonomous_database_data_source.go | 4 + .../database_autonomous_database_resource.go | 46 ++++++++++ ...autonomous_databases_clones_data_source.go | 8 ++ ...tabase_autonomous_databases_data_source.go | 4 + ...database_autonomous_database.html.markdown | 1 + ...atabase_autonomous_databases.html.markdown | 1 + ..._autonomous_databases_clones.html.markdown | 1 + ...database_autonomous_database.html.markdown | 3 + 10 files changed, 172 insertions(+) create mode 100644 internal/integrationtest/database_autonomous_database_lock_backup_retention_test.go diff --git a/examples/database/adb/autonomous_database.tf b/examples/database/adb/autonomous_database.tf index 907a0203978..290a96f880b 100644 --- a/examples/database/adb/autonomous_database.tf +++ b/examples/database/adb/autonomous_database.tf @@ -128,6 +128,20 @@ resource "oci_database_autonomous_database" "test_autonomous_database_apex" { is_free_tier = "false" } +resource "oci_database_autonomous_database" "test_autonomous_database_bck_ret_lock" { + admin_password = random_string.autonomous_database_admin_password.result + compartment_id = var.compartment_ocid + compute_count = "2.0" + compute_model = "ECPU" + data_storage_size_in_tbs = "1" + db_name = "adbBckRetLock" + db_version = "19c" + license_model = "LICENSE_INCLUDED" + is_free_tier = "false" + is_backup_retention_locked = "false" +} + + resource "oci_database_autonomous_database" "test_autonomous_database_bck_ret_days" { admin_password = random_string.autonomous_database_admin_password.result compartment_id = var.compartment_ocid diff --git a/internal/integrationtest/database_autonomous_database_lock_backup_retention_test.go b/internal/integrationtest/database_autonomous_database_lock_backup_retention_test.go new file mode 100644 index 00000000000..ea97ba44e09 --- /dev/null +++ b/internal/integrationtest/database_autonomous_database_lock_backup_retention_test.go @@ -0,0 +1,90 @@ +package integrationtest + +import ( + "fmt" + "testing" + + "github.com/oracle/terraform-provider-oci/internal/acctest" + "github.com/oracle/terraform-provider-oci/internal/utils" + + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" + "github.com/oracle/terraform-provider-oci/httpreplay" +) + +var ( + DatabaseAutonomousDatabaseRepresentationLockBckRetention = map[string]interface{}{ + "compartment_id": acctest.Representation{RepType: acctest.Required, Create: `${var.compartment_id}`}, + "compute_model": acctest.Representation{RepType: acctest.Required, Create: `ECPU`}, + "compute_count": acctest.Representation{RepType: acctest.Required, Create: `4.0`}, + "data_storage_size_in_tbs": acctest.Representation{RepType: acctest.Required, Create: `1`}, + "db_name": acctest.Representation{RepType: acctest.Required, Create: adbName}, + "admin_password": acctest.Representation{RepType: acctest.Required, Create: `BEstrO0ng_#11`, Update: `BEstrO0ng_#12`}, + "db_version": acctest.Representation{RepType: acctest.Optional, Create: `${data.oci_database_autonomous_db_versions.test_autonomous_db_versions.autonomous_db_versions.0.version}`}, + "db_workload": acctest.Representation{RepType: acctest.Optional, Create: `OLTP`}, + "character_set": acctest.Representation{RepType: acctest.Optional, Create: `AL32UTF8`}, + "display_name": acctest.Representation{RepType: acctest.Optional, Create: `example_autonomous_database`}, + "freeform_tags": acctest.Representation{RepType: acctest.Optional, Create: map[string]string{"Department": "Finance"}, Update: map[string]string{"Department": "Accounting"}}, + "is_auto_scaling_enabled": acctest.Representation{RepType: acctest.Optional, Create: `false`}, + "is_auto_scaling_for_storage_enabled": acctest.Representation{RepType: acctest.Optional, Create: `false`}, + "is_dedicated": acctest.Representation{RepType: acctest.Optional, Create: `false`}, + "is_mtls_connection_required": acctest.Representation{RepType: acctest.Optional, Create: `false`}, + "is_backup_retention_locked": acctest.Representation{RepType: acctest.Optional, Create: `false`}, + "autonomous_maintenance_schedule_type": acctest.Representation{RepType: acctest.Optional, Create: `REGULAR`}, + "is_preview_version_with_service_terms_accepted": acctest.Representation{RepType: acctest.Optional, Create: `false`}, + "customer_contacts": acctest.RepresentationGroup{RepType: acctest.Optional, Group: DatabaseAutonomousDatabaseCustomerContactsRepresentation}, + "license_model": acctest.Representation{RepType: acctest.Optional, Create: `LICENSE_INCLUDED`}, + "whitelisted_ips": acctest.Representation{RepType: acctest.Optional, Create: []string{`1.1.1.1/28`}}, + "operations_insights_status": acctest.Representation{RepType: acctest.Optional, Create: `NOT_ENABLED`, Update: `ENABLED`}, + "timeouts": acctest.RepresentationGroup{RepType: acctest.Required, Group: autonomousDatabaseTimeoutsRepresentation}, + "ncharacter_set": acctest.Representation{RepType: acctest.Optional, Create: `AL16UTF16`}, + "state": acctest.Representation{RepType: acctest.Optional, Create: `AVAILABLE`}, + } + + DatabaseAutonomousDatabaseResourceDependenciesLockBckRetention = DefinedTagsDependencies + KeyResourceDependencyConfigDbaas + + acctest.GenerateDataSourceFromRepresentationMap("oci_database_autonomous_db_versions", "test_autonomous_db_versions", acctest.Required, acctest.Create, DatabaseDatabaseAutonomousDbVersionDataSourceRepresentation) + + acctest.GenerateDataSourceFromRepresentationMap("oci_database_autonomous_db_versions", "test_autonomous_dw_versions", acctest.Required, acctest.Create, + acctest.RepresentationCopyWithNewProperties(DatabaseDatabaseAutonomousDbVersionDataSourceRepresentation, map[string]interface{}{ + "db_workload": acctest.Representation{RepType: acctest.Required, Create: `DW`}})) +) + +func TestDatabaseAutonomousDatabaseResource_lock_backup_retention(t *testing.T) { + httpreplay.SetScenario("TestDatabaseAutonomousDatabaseResource_lock_backup_retention") + defer httpreplay.SaveScenario() + + config := acctest.ProviderTestConfig() + + compartmentId := utils.GetEnvSettingWithBlankDefault("compartment_ocid") + compartmentIdVariableStr := fmt.Sprintf("variable \"compartment_id\" { default = \"%s\" }\n", compartmentId) + + okvSecret = utils.GetEnvSettingWithBlankDefault("okv_secret") + OkvSecretVariableStr = fmt.Sprintf("variable \"okv_secret\" { default = \"%s\" }\n", okvSecret) + + resourceName := "oci_database_autonomous_database.test_autonomous_database" + + acctest.SaveConfigContent(config+compartmentIdVariableStr+DatabaseAutonomousDatabaseResourceDependenciesLockBckRetention+ + acctest.GenerateResourceFromRepresentationMap("oci_database_autonomous_database", "test_autonomous_database", acctest.Optional, acctest.Create, DatabaseAutonomousDatabaseRepresentationLockBckRetention), "database", "autonomousDatabase", t) + + acctest.ResourceTest(t, testAccCheckDatabaseAutonomousDatabaseDestroy, []resource.TestStep{ + //0. Verify Create + { + Config: config + compartmentIdVariableStr + DatabaseAutonomousDatabaseResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_database_autonomous_database", "test_autonomous_database", acctest.Optional, acctest.Create, DatabaseAutonomousDatabaseRepresentationLockBckRetention), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(resourceName, "compute_model", "ECPU"), + resource.TestCheckResourceAttr(resourceName, "is_backup_retention_locked", "false"), + ), + }, + + //1. update backup retention from false to true + { + Config: config + compartmentIdVariableStr + DatabaseAutonomousDatabaseResourceDependencies + + acctest.GenerateResourceFromRepresentationMap("oci_database_autonomous_database", "test_autonomous_database", acctest.Optional, acctest.Update, + acctest.RepresentationCopyWithRemovedProperties(acctest.RepresentationCopyWithNewProperties(DatabaseAutonomousDatabaseRepresentationLockBckRetention, map[string]interface{}{ + "is_backup_retention_locked": acctest.Representation{RepType: acctest.Optional, Create: `false`, Update: `true`}, + }), []string{"admin_password", "customer_contacts", "freeform_tags", "display_name"})), + Check: acctest.ComposeAggregateTestCheckFuncWrapper( + resource.TestCheckResourceAttr(resourceName, "is_backup_retention_locked", "true"), + ), + }, + }) +} diff --git a/internal/service/database/database_autonomous_database_data_source.go b/internal/service/database/database_autonomous_database_data_source.go index 7c5ace7dadc..95109a60609 100644 --- a/internal/service/database/database_autonomous_database_data_source.go +++ b/internal/service/database/database_autonomous_database_data_source.go @@ -253,6 +253,10 @@ func (s *DatabaseAutonomousDatabaseDataSourceCrud) SetData() error { s.D.Set("is_auto_scaling_for_storage_enabled", *s.Res.IsAutoScalingForStorageEnabled) } + if s.Res.IsBackupRetentionLocked != nil { + s.D.Set("is_backup_retention_locked", *s.Res.IsBackupRetentionLocked) + } + if s.Res.IsDataGuardEnabled != nil { s.D.Set("is_data_guard_enabled", *s.Res.IsDataGuardEnabled) } diff --git a/internal/service/database/database_autonomous_database_resource.go b/internal/service/database/database_autonomous_database_resource.go index 2f274ce61ce..52e41843d82 100644 --- a/internal/service/database/database_autonomous_database_resource.go +++ b/internal/service/database/database_autonomous_database_resource.go @@ -363,6 +363,11 @@ func DatabaseAutonomousDatabaseResource() *schema.Resource { Optional: true, Computed: true, }, + "is_backup_retention_locked": { + Type: schema.TypeBool, + Optional: true, + Computed: true, + }, "is_data_guard_enabled": { Type: schema.TypeBool, Optional: true, @@ -1957,6 +1962,11 @@ func (s *DatabaseAutonomousDatabaseResourceCrud) Update() error { request.IsAutoScalingForStorageEnabled = &tmp } + if isBackupRetentionLocked, ok := s.D.GetOkExists("is_backup_retention_locked"); ok && s.D.HasChange("is_backup_retention_locked") { + tmp := isBackupRetentionLocked.(bool) + request.IsBackupRetentionLocked = &tmp + } + if isDataGuardEnabled, ok := s.D.GetOkExists("is_data_guard_enabled"); ok && s.D.HasChange("is_data_guard_enabled") { tmp := isDataGuardEnabled.(bool) request.IsDataGuardEnabled = &tmp @@ -2401,6 +2411,10 @@ func (s *DatabaseAutonomousDatabaseResourceCrud) SetData() error { s.D.Set("is_auto_scaling_for_storage_enabled", *s.Res.IsAutoScalingForStorageEnabled) } + if s.Res.IsBackupRetentionLocked != nil { + s.D.Set("is_backup_retention_locked", *s.Res.IsBackupRetentionLocked) + } + if s.Res.IsDataGuardEnabled != nil { s.D.Set("is_data_guard_enabled", *s.Res.IsDataGuardEnabled) } @@ -3420,6 +3434,10 @@ func (s *DatabaseAutonomousDatabaseResourceCrud) populateTopLevelPolymorphicCrea tmp := isAutoScalingForStorageEnabled.(bool) details.IsAutoScalingForStorageEnabled = &tmp } + if isBackupRetentionLocked, ok := s.D.GetOkExists("is_backup_retention_locked"); ok { + tmp := isBackupRetentionLocked.(bool) + details.IsBackupRetentionLocked = &tmp + } if _, ok := s.D.GetOkExists("is_data_guard_enabled"); ok { details.IsDataGuardEnabled = nil } @@ -3721,6 +3739,10 @@ func (s *DatabaseAutonomousDatabaseResourceCrud) populateTopLevelPolymorphicCrea tmp := isAutoScalingForStorageEnabled.(bool) details.IsAutoScalingForStorageEnabled = &tmp } + if isBackupRetentionLocked, ok := s.D.GetOkExists("is_backup_retention_locked"); ok { + tmp := isBackupRetentionLocked.(bool) + details.IsBackupRetentionLocked = &tmp + } if _, ok := s.D.GetOkExists("is_data_guard_enabled"); ok { details.IsDataGuardEnabled = nil } @@ -4017,6 +4039,10 @@ func (s *DatabaseAutonomousDatabaseResourceCrud) populateTopLevelPolymorphicCrea tmp := isAutoScalingForStorageEnabled.(bool) details.IsAutoScalingForStorageEnabled = &tmp } + if isBackupRetentionLocked, ok := s.D.GetOkExists("is_backup_retention_locked"); ok { + tmp := isBackupRetentionLocked.(bool) + details.IsBackupRetentionLocked = &tmp + } if _, ok := s.D.GetOkExists("is_data_guard_enabled"); ok { details.IsDataGuardEnabled = nil } @@ -4305,6 +4331,10 @@ func (s *DatabaseAutonomousDatabaseResourceCrud) populateTopLevelPolymorphicCrea tmp := isAutoScalingEnabled.(bool) details.IsAutoScalingEnabled = &tmp } + if isBackupRetentionLocked, ok := s.D.GetOkExists("is_backup_retention_locked"); ok { + tmp := isBackupRetentionLocked.(bool) + details.IsBackupRetentionLocked = &tmp + } if _, ok := s.D.GetOkExists("is_data_guard_enabled"); ok { details.IsDataGuardEnabled = nil } @@ -4585,6 +4615,10 @@ func (s *DatabaseAutonomousDatabaseResourceCrud) populateTopLevelPolymorphicCrea tmp := isAutoScalingForStorageEnabled.(bool) details.IsAutoScalingForStorageEnabled = &tmp } + if isBackupRetentionLocked, ok := s.D.GetOkExists("is_backup_retention_locked"); ok { + tmp := isBackupRetentionLocked.(bool) + details.IsBackupRetentionLocked = &tmp + } if isDataGuardEnabled, ok := s.D.GetOkExists("is_data_guard_enabled"); ok { tmp := isDataGuardEnabled.(bool) details.IsDataGuardEnabled = &tmp @@ -4833,6 +4867,10 @@ func (s *DatabaseAutonomousDatabaseResourceCrud) populateTopLevelPolymorphicCrea tmp := isAutoScalingForStorageEnabled.(bool) details.IsAutoScalingForStorageEnabled = &tmp } + if isBackupRetentionLocked, ok := s.D.GetOkExists("is_backup_retention_locked"); ok { + tmp := isBackupRetentionLocked.(bool) + details.IsBackupRetentionLocked = &tmp + } if _, ok := s.D.GetOkExists("is_data_guard_enabled"); ok { details.IsDataGuardEnabled = nil } @@ -5113,6 +5151,10 @@ func (s *DatabaseAutonomousDatabaseResourceCrud) populateTopLevelPolymorphicCrea tmp := isAutoScalingForStorageEnabled.(bool) details.IsAutoScalingForStorageEnabled = &tmp } + if isBackupRetentionLocked, ok := s.D.GetOkExists("is_backup_retention_locked"); ok { + tmp := isBackupRetentionLocked.(bool) + details.IsBackupRetentionLocked = &tmp + } if _, ok := s.D.GetOkExists("is_data_guard_enabled"); ok { details.IsDataGuardEnabled = nil } @@ -5396,6 +5438,10 @@ func (s *DatabaseAutonomousDatabaseResourceCrud) populateTopLevelPolymorphicCrea tmp := isAutoScalingForStorageEnabled.(bool) details.IsAutoScalingForStorageEnabled = &tmp } + if isBackupRetentionLocked, ok := s.D.GetOkExists("is_backup_retention_locked"); ok { + tmp := isBackupRetentionLocked.(bool) + details.IsBackupRetentionLocked = &tmp + } if _, ok := s.D.GetOkExists("is_data_guard_enabled"); ok { details.IsDataGuardEnabled = nil } diff --git a/internal/service/database/database_autonomous_databases_clones_data_source.go b/internal/service/database/database_autonomous_databases_clones_data_source.go index dea0d807ea9..2c7dc09c454 100644 --- a/internal/service/database/database_autonomous_databases_clones_data_source.go +++ b/internal/service/database/database_autonomous_databases_clones_data_source.go @@ -577,6 +577,10 @@ func DatabaseAutonomousDatabasesClonesDataSource() *schema.Resource { Type: schema.TypeBool, Computed: true, }, + "is_backup_retention_locked": { + Type: schema.TypeBool, + Computed: true, + }, "is_data_guard_enabled": { Type: schema.TypeBool, Computed: true, @@ -1399,6 +1403,10 @@ func (s *DatabaseAutonomousDatabasesClonesDataSourceCrud) SetData() error { autonomousDatabasesClone["is_auto_scaling_for_storage_enabled"] = *r.IsAutoScalingForStorageEnabled } + if r.IsBackupRetentionLocked != nil { + autonomousDatabasesClone["is_backup_retention_locked"] = *r.IsBackupRetentionLocked + } + if r.IsDataGuardEnabled != nil { autonomousDatabasesClone["is_data_guard_enabled"] = *r.IsDataGuardEnabled } diff --git a/internal/service/database/database_autonomous_databases_data_source.go b/internal/service/database/database_autonomous_databases_data_source.go index bec2f61fac0..7c0d391b5ae 100644 --- a/internal/service/database/database_autonomous_databases_data_source.go +++ b/internal/service/database/database_autonomous_databases_data_source.go @@ -376,6 +376,10 @@ func (s *DatabaseAutonomousDatabasesDataSourceCrud) SetData() error { autonomousDatabase["is_auto_scaling_for_storage_enabled"] = *r.IsAutoScalingForStorageEnabled } + if r.IsBackupRetentionLocked != nil { + autonomousDatabase["is_backup_retention_locked"] = *r.IsBackupRetentionLocked + } + if r.IsDataGuardEnabled != nil { autonomousDatabase["is_data_guard_enabled"] = *r.IsDataGuardEnabled } diff --git a/website/docs/d/database_autonomous_database.html.markdown b/website/docs/d/database_autonomous_database.html.markdown index 328e596fe83..a688a40b5e4 100644 --- a/website/docs/d/database_autonomous_database.html.markdown +++ b/website/docs/d/database_autonomous_database.html.markdown @@ -155,6 +155,7 @@ The following attributes are exported: This property is applicable only to Autonomous Databases on the Exadata Cloud@Customer platform. For Autonomous Database Serverless instances, `whitelistedIps` is used. * `is_auto_scaling_enabled` - Indicates if auto scaling is enabled for the Autonomous Database CPU core count. The default value is `TRUE`. * `is_auto_scaling_for_storage_enabled` - Indicates if auto scaling is enabled for the Autonomous Database storage. The default value is `FALSE`. +* `is_backup_retention_locked` - Indicates if the Autonomous Database is backup retention locked. * `is_data_guard_enabled` - **Deprecated.** Indicates whether the Autonomous Database has local (in-region) Data Guard enabled. Not applicable to cross-region Autonomous Data Guard associations, or to Autonomous Databases using dedicated Exadata infrastructure or Exadata Cloud@Customer infrastructure. * `is_dedicated` - True if the database uses [dedicated Exadata infrastructure](https://docs.oracle.com/en/cloud/paas/autonomous-database/index.html). * `is_dev_tier` - Autonomous Database for Developers are free Autonomous Databases that developers can use to build and test new applications.With Autonomous these database instancess instances, you can try new Autonomous Database features for free and apply them to ongoing or new development projects. Developer database comes with limited resources and is, therefore, not suitable for large-scale testing and production deployments. When you need more compute or storage resources, you can transition to a paid database licensing by cloning your developer database into a regular Autonomous Database. See [Autonomous Database documentation](https://docs.oracle.com/en/cloud/paas/autonomous-database/dedicated/eddjo/index.html) for more details. diff --git a/website/docs/d/database_autonomous_databases.html.markdown b/website/docs/d/database_autonomous_databases.html.markdown index e520b4481fe..d8dd18d1ebd 100644 --- a/website/docs/d/database_autonomous_databases.html.markdown +++ b/website/docs/d/database_autonomous_databases.html.markdown @@ -182,6 +182,7 @@ The following attributes are exported: This property is applicable only to Autonomous Databases on the Exadata Cloud@Customer platform. For Autonomous Database Serverless instances, `whitelistedIps` is used. * `is_auto_scaling_enabled` - Indicates if auto scaling is enabled for the Autonomous Database CPU core count. The default value is `TRUE`. * `is_auto_scaling_for_storage_enabled` - Indicates if auto scaling is enabled for the Autonomous Database storage. The default value is `FALSE`. +* `is_backup_retention_locked` - Indicates if the Autonomous Database is backup retention locked. * `is_data_guard_enabled` - **Deprecated.** Indicates whether the Autonomous Database has local (in-region) Data Guard enabled. Not applicable to cross-region Autonomous Data Guard associations, or to Autonomous Databases using dedicated Exadata infrastructure or Exadata Cloud@Customer infrastructure. * `is_dedicated` - True if the database uses [dedicated Exadata infrastructure](https://docs.oracle.com/en/cloud/paas/autonomous-database/index.html). * `is_free_tier` - Indicates if this is an Always Free resource. The default value is false. Note that Always Free Autonomous Databases have 1 CPU and 20GB of memory. For Always Free databases, memory and CPU cannot be scaled. diff --git a/website/docs/d/database_autonomous_databases_clones.html.markdown b/website/docs/d/database_autonomous_databases_clones.html.markdown index c9ff8a6e641..c75efd0f04b 100644 --- a/website/docs/d/database_autonomous_databases_clones.html.markdown +++ b/website/docs/d/database_autonomous_databases_clones.html.markdown @@ -171,6 +171,7 @@ The following attributes are exported: This property is applicable only to Autonomous Databases on the Exadata Cloud@Customer platform. For Autonomous Database Serverless instances, `whitelistedIps` is used. * `is_auto_scaling_enabled` - Indicates if auto scaling is enabled for the Autonomous Database CPU core count. The default value is `TRUE`. * `is_auto_scaling_for_storage_enabled` - Indicates if auto scaling is enabled for the Autonomous Database storage. The default value is `FALSE`. +* `is_backup_retention_locked` - Indicates if the Autonomous Database is backup retention locked. * `is_data_guard_enabled` - **Deprecated.** Indicates whether the Autonomous Database has local (in-region) Data Guard enabled. Not applicable to cross-region Autonomous Data Guard associations, or to Autonomous Databases using dedicated Exadata infrastructure or Exadata Cloud@Customer infrastructure. * `is_dedicated` - True if the database uses [dedicated Exadata infrastructure](https://docs.oracle.com/en/cloud/paas/autonomous-database/index.html). * `is_dev_tier` - Autonomous Database for Developers are free Autonomous Databases that developers can use to build and test new applications.With Autonomous these database instancess instances, you can try new Autonomous Database features for free and apply them to ongoing or new development projects. Developer database comes with limited resources and is, therefore, not suitable for large-scale testing and production deployments. When you need more compute or storage resources, you can transition to a paid database licensing by cloning your developer database into a regular Autonomous Database. See [Autonomous Database documentation](https://docs.oracle.com/en/cloud/paas/autonomous-database/dedicated/eddjo/index.html) for more details. diff --git a/website/docs/r/database_autonomous_database.html.markdown b/website/docs/r/database_autonomous_database.html.markdown index cbd5ebe740e..7f2e36b59d5 100644 --- a/website/docs/r/database_autonomous_database.html.markdown +++ b/website/docs/r/database_autonomous_database.html.markdown @@ -84,6 +84,7 @@ resource "oci_database_autonomous_database" "test_autonomous_database" { is_access_control_enabled = var.autonomous_database_is_access_control_enabled is_auto_scaling_enabled = var.autonomous_database_is_auto_scaling_enabled is_auto_scaling_for_storage_enabled = var.autonomous_database_is_auto_scaling_for_storage_enabled + is_backup_retention_locked = var.autonomous_database_is_backup_retention_locked is_data_guard_enabled = var.autonomous_database_is_data_guard_enabled is_dedicated = var.autonomous_database_is_dedicated is_dev_tier = var.autonomous_database_is_dev_tier @@ -218,6 +219,7 @@ The following arguments are supported: This property is applicable only to Autonomous Databases on the Exadata Cloud@Customer platform. For Autonomous Database Serverless instances, `whitelistedIps` is used. * `is_auto_scaling_enabled` - (Optional) (Updatable) Indicates if auto scaling is enabled for the Autonomous Database CPU core count. The default value is `TRUE`. * `is_auto_scaling_for_storage_enabled` - (Optional) (Updatable) Indicates if auto scaling is enabled for the Autonomous Database storage. The default value is `FALSE`. +* `is_backup_retention_locked` - (Optional) (Updatable) True if the Autonomous Database is backup retention locked. * `is_data_guard_enabled` - (Optional) (Updatable) **Deprecated.** Indicates whether the Autonomous Database has local (in-region) Data Guard enabled. Not applicable to cross-region Autonomous Data Guard associations, or to Autonomous Databases using dedicated Exadata infrastructure or Exadata Cloud@Customer infrastructure. * `is_dedicated` - (Optional) True if the database is on [dedicated Exadata infrastructure](https://docs.oracle.com/en/cloud/paas/autonomous-database/index.html). * `is_dev_tier` - (Optional) (Updatable) Autonomous Database for Developers are free Autonomous Databases that developers can use to build and test new applications.With Autonomous these database instancess instances, you can try new Autonomous Database features for free and apply them to ongoing or new development projects. Developer database comes with limited resources and is, therefore, not suitable for large-scale testing and production deployments. When you need more compute or storage resources, you can transition to a paid database licensing by cloning your developer database into a regular Autonomous Database. See [Autonomous Database documentation](https://docs.oracle.com/en/cloud/paas/autonomous-database/dedicated/eddjo/index.html) for more details. @@ -467,6 +469,7 @@ The following attributes are exported: This property is applicable only to Autonomous Databases on the Exadata Cloud@Customer platform. For Autonomous Database Serverless instances, `whitelistedIps` is used. * `is_auto_scaling_enabled` - Indicates if auto scaling is enabled for the Autonomous Database CPU core count. The default value is `TRUE`. * `is_auto_scaling_for_storage_enabled` - Indicates if auto scaling is enabled for the Autonomous Database storage. The default value is `FALSE`. +* `is_backup_retention_locked` - Indicates if the Autonomous Database is backup retention locked. * `is_data_guard_enabled` - **Deprecated.** Indicates whether the Autonomous Database has local (in-region) Data Guard enabled. Not applicable to cross-region Autonomous Data Guard associations, or to Autonomous Databases using dedicated Exadata infrastructure or Exadata Cloud@Customer infrastructure. * `is_dedicated` - True if the database uses [dedicated Exadata infrastructure](https://docs.oracle.com/en/cloud/paas/autonomous-database/index.html). * `is_dev_tier` - Autonomous Database for Developers are free Autonomous Databases that developers can use to build and test new applications.With Autonomous these database instancess instances, you can try new Autonomous Database features for free and apply them to ongoing or new development projects. Developer database comes with limited resources and is, therefore, not suitable for large-scale testing and production deployments. When you need more compute or storage resources, you can transition to a paid database licensing by cloning your developer database into a regular Autonomous Database. See [Autonomous Database documentation](https://docs.oracle.com/en/cloud/paas/autonomous-database/dedicated/eddjo/index.html) for more details. From ad2154fdc3151f1e3e4000484372288afdac7d2d Mon Sep 17 00:00:00 2001 From: Viral Sinha Date: Tue, 17 Dec 2024 10:16:05 -0800 Subject: [PATCH 12/17] Vendored - oci-go-sdk v65.81.1 changes for existing & new services --- .../aivision_aiservicevision_client.go | 176 ++++ .../v65/aivision/analyze_video_result.go | 73 ++ .../cancel_video_job_request_response.go | 94 ++ .../v65/aivision/create_video_job_details.go | 109 ++ .../create_video_job_request_response.go | 100 ++ .../get_video_job_request_response.go | 93 ++ .../v65/aivision/object_property.go | 44 + .../oci-go-sdk/v65/aivision/video_face.go | 39 + .../aivision/video_face_detection_feature.go | 61 ++ .../v65/aivision/video_face_frame.go | 50 + .../v65/aivision/video_face_segment.go | 43 + .../oci-go-sdk/v65/aivision/video_feature.go | 147 +++ .../oci-go-sdk/v65/aivision/video_job.go | 265 +++++ .../oci-go-sdk/v65/aivision/video_label.go | 42 + .../aivision/video_label_detection_feature.go | 61 ++ .../v65/aivision/video_label_segment.go | 40 + .../oci-go-sdk/v65/aivision/video_metadata.go | 48 + .../oci-go-sdk/v65/aivision/video_object.go | 42 + .../video_object_detection_feature.go | 61 ++ .../v65/aivision/video_object_frame.go | 44 + .../v65/aivision/video_object_segment.go | 43 + .../aivision/video_object_tracking_feature.go | 61 ++ .../oci-go-sdk/v65/aivision/video_segment.go | 42 + .../oci-go-sdk/v65/aivision/video_text.go | 42 + .../aivision/video_text_detection_feature.go | 55 + .../v65/aivision/video_text_frame.go | 44 + .../v65/aivision/video_text_segment.go | 43 + .../v65/aivision/video_tracked_object.go | 47 + .../video_tracked_object_properties.go | 39 + .../aivision/video_tracked_object_segment.go | 43 + .../v65/aivision/video_tracking_frame.go | 47 + ...ate_iam_user_sync_configuration_details.go | 42 + ...ser_sync_configuration_request_response.go | 110 ++ .../activate_upst_configuration_details.go | 45 + ...ate_upst_configuration_request_response.go | 110 ++ .../bds/batching_based_odh_patching_config.go | 3 + .../oracle/oci-go-sdk/v65/bds/bds_api_key.go | 3 + .../oracle/oci-go-sdk/v65/bds/bds_client.go | 764 +++++++++++++- .../v65/bds/bds_cluster_version_summary.go | 42 + .../oracle/oci-go-sdk/v65/bds/bds_instance.go | 2 + .../v65/bds/create_bds_api_key_details.go | 3 + .../v65/bds/create_bds_instance_details.go | 2 + .../create_identity_configuration_details.go | 52 + ...identity_configuration_request_response.go | 100 ++ ...ate_iam_user_sync_configuration_details.go | 39 + ...ser_sync_configuration_request_response.go | 110 ++ .../deactivate_upst_configuration_details.go | 39 + ...ate_upst_configuration_request_response.go | 110 ++ ...identity_configuration_request_response.go | 100 ++ .../bds/domain_based_odh_patching_config.go | 3 + ...identity_configuration_request_response.go | 198 ++++ .../v65/bds/iam_user_sync_configuration.go | 109 ++ .../iam_user_sync_configuration_details.go | 39 + .../v65/bds/identity_configuration.go | 106 ++ .../v65/bds/identity_configuration_summary.go | 48 + ...t_bds_cluster_versions_request_response.go | 190 ++++ ...dentity_configurations_request_response.go | 209 ++++ .../v65/bds/node_type_shape_config.go | 46 + .../oci-go-sdk/v65/bds/operation_types.go | 36 + ...efresh_confidential_application_details.go | 39 + ...nfidential_application_request_response.go | 110 ++ ...resh_upst_token_exchange_keytab_details.go | 39 + ..._token_exchange_keytab_request_response.go | 110 ++ .../v65/bds/start_bds_instance_details.go | 2 + .../v65/bds/start_cluster_shape_configs.go | 39 + .../v65/bds/update_bds_instance_details.go | 2 + .../update_identity_configuration_details.go | 43 + ...identity_configuration_request_response.go | 110 ++ .../oci-go-sdk/v65/bds/upst_configuration.go | 124 +++ .../v65/bds/upst_configuration_details.go | 42 + .../v65/blockchain/blockchain_platform.go | 50 +- .../oci-go-sdk/v65/blockchain/work_request.go | 58 +- .../v65/blockchain/work_request_summary.go | 58 +- .../v65/cloudbridge/aws_asset_source.go | 192 ++++ .../cloudbridge/aws_asset_source_summary.go | 171 +++ .../v65/cloudbridge/aws_ebs_asset.go | 166 +++ .../v65/cloudbridge/aws_ebs_asset_details.go | 37 + .../v65/cloudbridge/aws_ebs_properties.go | 69 ++ .../v65/cloudbridge/aws_ec2_asset.go | 174 +++ .../v65/cloudbridge/aws_ec2_asset_details.go | 45 + .../v65/cloudbridge/aws_ec2_properties.go | 133 +++ .../create_aws_asset_source_details.go | 150 +++ .../create_aws_ebs_asset_details.go | 121 +++ .../create_aws_ec2_asset_details.go | 129 +++ .../v65/cloudbridge/group_identifier.go | 42 + .../cloudbridge/instance_network_interface.go | 78 ++ .../instance_network_interface_association.go | 51 + .../instance_network_interface_attachment.go | 54 + .../instance_private_ip_address.go | 46 + .../v65/cloudbridge/instance_state.go | 42 + ...upported_cloud_regions_request_response.go | 241 +++++ .../v65/cloudbridge/monthly_cost_summary.go | 42 + .../oci-go-sdk/v65/cloudbridge/placement.go | 60 ++ .../supported_cloud_region_collection.go | 39 + .../supported_cloud_region_lifecycle_state.go | 56 + .../supported_cloud_region_summary.go | 61 ++ .../oracle/oci-go-sdk/v65/cloudbridge/tag.go | 42 + .../update_aws_asset_source_details.go | 119 +++ .../update_aws_ebs_asset_details.go | 89 ++ .../update_aws_ec2_asset_details.go | 97 ++ .../v65/cloudbridge/volume_attachment.go | 51 + .../oracle/oci-go-sdk/v65/common/version.go | 2 +- .../v65/database/autonomous_database.go | 6 + .../database/autonomous_database_summary.go | 6 + .../create_autonomous_database_base.go | 10 + ...reate_autonomous_database_clone_details.go | 11 + .../create_autonomous_database_details.go | 11 + ...autonomous_database_from_backup_details.go | 11 + ..._database_from_backup_timestamp_details.go | 11 + ..._autonomous_database_data_guard_details.go | 11 + ..._cross_region_disaster_recovery_details.go | 11 + ...cross_tenancy_disaster_recovery_details.go | 11 + ...hable_autonomous_database_clone_details.go | 11 + .../undelete_autonomous_database_details.go | 11 + .../update_autonomous_database_details.go | 6 + .../v65/datascience/create_job_run_details.go | 4 +- .../datascience/data_science_resource_type.go | 4 + .../v65/datascience/instance_configuration.go | 3 + .../oci-go-sdk/v65/datascience/job_run.go | 6 +- .../v65/datascience/job_run_summary.go | 10 +- .../oci-go-sdk/v65/datascience/job_summary.go | 2 +- ...ence_private_endpoints_request_response.go | 4 + .../oci-go-sdk/v65/datascience/metadata.go | 4 +- .../v65/generativeaiagent/action_type.go | 2 - .../oci-go-sdk/v65/generativeaiagent/agent.go | 5 +- .../v65/generativeaiagent/agent_collection.go | 5 +- .../v65/generativeaiagent/agent_endpoint.go | 5 +- .../agent_endpoint_collection.go | 5 +- .../agent_endpoint_summary.go | 5 +- .../v65/generativeaiagent/agent_summary.go | 5 +- .../generativeaiagent/basic_auth_secret.go | 5 +- .../change_agent_compartment_details.go | 5 +- ...ange_agent_endpoint_compartment_details.go | 5 +- ...ange_knowledge_base_compartment_details.go | 5 +- .../content_moderation_config.go | 2 - .../generativeaiagent/create_agent_details.go | 5 +- .../create_agent_endpoint_details.go | 5 +- .../create_data_ingestion_job_details.go | 5 +- .../create_data_source_details.go | 5 +- .../create_knowledge_base_details.go | 5 +- .../generativeaiagent/data_ingestion_job.go | 8 +- .../data_ingestion_job_collection.go | 5 +- .../data_ingestion_job_statistics.go | 5 +- .../data_ingestion_job_summary.go | 5 +- .../v65/generativeaiagent/data_source.go | 5 +- .../data_source_collection.go | 5 +- .../generativeaiagent/data_source_config.go | 19 +- .../generativeaiagent/data_source_summary.go | 5 +- .../generativeaiagent/database_connection.go | 5 +- .../generativeaiagent/database_function.go | 5 +- .../database_tool_connection.go | 5 +- .../generativeaiagent/default_index_config.go | 5 +- .../generativeaiagent_client.go | 101 +- .../v65/generativeaiagent/idcs_secret.go | 5 +- .../oci-go-sdk/v65/generativeaiagent/index.go | 5 +- .../v65/generativeaiagent/index_config.go | 5 +- .../v65/generativeaiagent/index_schema.go | 5 +- .../v65/generativeaiagent/knowledge_base.go | 34 +- .../knowledge_base_collection.go | 5 +- .../knowledge_base_statistics.go | 43 + .../knowledge_base_summary.go | 5 +- .../object_storage_prefix.go | 5 +- .../generativeaiagent/oci_database_config.go | 5 +- .../oci_object_storage_data_source_config.go | 15 +- .../oci_open_search_index_config.go | 5 +- .../v65/generativeaiagent/operation_status.go | 2 - .../v65/generativeaiagent/operation_type.go | 14 +- .../v65/generativeaiagent/secret_detail.go | 5 +- .../v65/generativeaiagent/session_config.go | 5 +- .../v65/generativeaiagent/sort_order.go | 2 - .../generativeaiagent/update_agent_details.go | 5 +- .../update_agent_endpoint_details.go | 5 +- .../update_data_source_details.go | 5 +- .../update_knowledge_base_details.go | 5 +- .../v65/generativeaiagent/work_request.go | 5 +- .../generativeaiagent/work_request_error.go | 5 +- .../work_request_error_collection.go | 5 +- .../work_request_log_entry.go | 5 +- .../work_request_log_entry_collection.go | 5 +- .../work_request_resource.go | 5 +- .../work_request_resource_metadata_key.go | 2 - .../generativeaiagent/work_request_summary.go | 5 +- .../work_request_summary_collection.go | 5 +- .../change_pipeline_compartment_details.go | 39 + ...e_pipeline_compartment_request_response.go | 109 ++ .../create_mysql_connection_details.go | 2 +- .../v65/goldengate/create_pipeline_details.go | 171 +++ .../create_pipeline_request_response.go | 103 ++ .../create_zero_etl_pipeline_details.go | 129 +++ .../default_start_pipeline_details.go | 51 + .../default_stop_pipeline_details.go | 51 + ...efault_test_pipeline_connection_details.go | 55 + .../delete_pipeline_request_response.go | 100 ++ .../get_pipeline_request_response.go | 93 ++ .../v65/goldengate/goldengate_client.go | 993 ++++++++++++++++-- .../v65/goldengate/initial_data_load.go | 90 ++ .../v65/goldengate/initial_load_action.go | 64 ++ ...e_initialization_steps_request_response.go | 93 ++ ...line_running_processes_request_response.go | 199 ++++ ...pipeline_schema_tables_request_response.go | 208 ++++ .../list_pipeline_schemas_request_response.go | 202 ++++ .../list_pipelines_request_response.go | 271 +++++ .../list_recipes_request_response.go | 249 +++++ .../oci-go-sdk/v65/goldengate/mapping_rule.go | 50 + .../oci-go-sdk/v65/goldengate/mapping_type.go | 56 + .../v65/goldengate/operation_type.go | 24 + .../oci-go-sdk/v65/goldengate/pipeline.go | 335 ++++++ .../v65/goldengate/pipeline_collection.go | 66 ++ .../pipeline_initialization_step.go | 59 ++ .../pipeline_initialization_steps.go | 39 + .../pipeline_lifecycle_sub_state.go | 68 ++ .../pipeline_running_process_collection.go | 39 + .../pipeline_running_process_summary.go | 58 + .../goldengate/pipeline_schema_collection.go | 39 + .../v65/goldengate/pipeline_schema_summary.go | 44 + .../pipeline_schema_table_collection.go | 45 + .../pipeline_schema_table_summary.go | 44 + .../v65/goldengate/pipeline_summary.go | 273 +++++ .../v65/goldengate/process_options.go | 87 ++ .../v65/goldengate/process_status_type.go | 60 ++ .../oci-go-sdk/v65/goldengate/process_type.go | 56 + .../v65/goldengate/recipe_summary.go | 57 + .../goldengate/recipe_summary_collection.go | 39 + .../oci-go-sdk/v65/goldengate/recipe_type.go | 52 + .../goldengate/replicate_ddl_error_action.go | 60 ++ .../goldengate/replicate_dml_error_action.go | 60 ++ .../v65/goldengate/replicate_schema_change.go | 96 ++ .../v65/goldengate/severity_type.go | 60 ++ .../source_pipeline_connection_details.go | 40 + .../v65/goldengate/start_pipeline_details.go | 77 ++ .../start_pipeline_request_response.go | 109 ++ .../v65/goldengate/start_pipeline_type.go | 52 + .../oci-go-sdk/v65/goldengate/step_message.go | 55 + .../v65/goldengate/step_status_type.go | 64 ++ .../v65/goldengate/stop_pipeline_details.go | 77 ++ .../stop_pipeline_request_response.go | 109 ++ .../v65/goldengate/stop_pipeline_type.go | 52 + .../target_pipeline_connection_details.go | 40 + .../test_pipeline_connection_details.go | 77 ++ .../test_pipeline_connection_error.go | 48 + ...st_pipeline_connection_request_response.go | 108 ++ .../test_pipeline_connection_result.go | 90 ++ .../test_pipeline_connection_type.go | 52 + .../update_mysql_connection_details.go | 2 +- .../v65/goldengate/update_pipeline_details.go | 133 +++ .../update_pipeline_request_response.go | 103 ++ .../update_zero_etl_pipeline_details.go | 102 ++ .../v65/goldengate/zero_etl_pipeline.go | 220 ++++ .../goldengate/zero_etl_pipeline_summary.go | 217 ++++ .../stackmonitoring/http_protocol_types.go | 56 + .../stackmonitoring/http_query_properties.go | 68 ++ .../http_response_content_types.go | 64 ++ .../http_script_file_details.go | 42 + .../http_update_query_properties.go | 68 ++ ...list_metric_extensions_request_response.go | 25 +- .../metric_extension_collection_methods.go | 4 + .../metric_extension_query_properties.go | 4 + .../metric_extension_sort_by.go | 16 +- ...etric_extension_update_query_properties.go | 4 + .../stackmonitoring/script_file_details.go | 2 +- .../stackmonitoring/sql_out_param_details.go | 7 +- .../stackmonitoring/sql_out_param_types.go | 16 +- .../update_http_script_file_details.go | 42 + 263 files changed, 15743 insertions(+), 511 deletions(-) create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/analyze_video_result.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/cancel_video_job_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/create_video_job_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/create_video_job_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/get_video_job_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/object_property.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_face.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_face_detection_feature.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_face_frame.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_face_segment.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_feature.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_job.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_label.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_label_detection_feature.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_label_segment.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_metadata.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object_detection_feature.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object_frame.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object_segment.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object_tracking_feature.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_segment.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_text.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_text_detection_feature.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_text_frame.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_text_segment.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_tracked_object.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_tracked_object_properties.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_tracked_object_segment.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_tracking_frame.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/activate_iam_user_sync_configuration_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/activate_iam_user_sync_configuration_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/activate_upst_configuration_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/activate_upst_configuration_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/bds_cluster_version_summary.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/create_identity_configuration_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/create_identity_configuration_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/deactivate_iam_user_sync_configuration_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/deactivate_iam_user_sync_configuration_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/deactivate_upst_configuration_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/deactivate_upst_configuration_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/delete_identity_configuration_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/get_identity_configuration_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/iam_user_sync_configuration.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/iam_user_sync_configuration_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/identity_configuration.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/identity_configuration_summary.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/list_bds_cluster_versions_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/list_identity_configurations_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/node_type_shape_config.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/refresh_confidential_application_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/refresh_confidential_application_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/refresh_upst_token_exchange_keytab_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/refresh_upst_token_exchange_keytab_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/start_cluster_shape_configs.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/update_identity_configuration_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/update_identity_configuration_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/upst_configuration.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/bds/upst_configuration_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_asset_source.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_asset_source_summary.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ebs_asset.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ebs_asset_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ebs_properties.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ec2_asset.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ec2_asset_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ec2_properties.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/create_aws_asset_source_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/create_aws_ebs_asset_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/create_aws_ec2_asset_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/group_identifier.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_network_interface.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_network_interface_association.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_network_interface_attachment.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_private_ip_address.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_state.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/list_supported_cloud_regions_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/monthly_cost_summary.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/placement.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/supported_cloud_region_collection.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/supported_cloud_region_lifecycle_state.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/supported_cloud_region_summary.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/tag.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/update_aws_asset_source_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/update_aws_ebs_asset_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/update_aws_ec2_asset_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/volume_attachment.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/knowledge_base_statistics.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/change_pipeline_compartment_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/change_pipeline_compartment_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/create_pipeline_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/create_pipeline_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/create_zero_etl_pipeline_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/default_start_pipeline_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/default_stop_pipeline_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/default_test_pipeline_connection_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/delete_pipeline_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/get_pipeline_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/initial_data_load.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/initial_load_action.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipeline_initialization_steps_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipeline_running_processes_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipeline_schema_tables_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipeline_schemas_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipelines_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_recipes_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/mapping_rule.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/mapping_type.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_collection.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_initialization_step.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_initialization_steps.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_lifecycle_sub_state.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_running_process_collection.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_running_process_summary.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_schema_collection.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_schema_summary.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_schema_table_collection.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_schema_table_summary.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_summary.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/process_options.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/process_status_type.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/process_type.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/recipe_summary.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/recipe_summary_collection.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/recipe_type.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/replicate_ddl_error_action.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/replicate_dml_error_action.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/replicate_schema_change.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/severity_type.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/source_pipeline_connection_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/start_pipeline_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/start_pipeline_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/start_pipeline_type.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/step_message.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/step_status_type.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/stop_pipeline_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/stop_pipeline_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/stop_pipeline_type.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/target_pipeline_connection_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_error.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_result.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_type.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/update_pipeline_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/update_pipeline_request_response.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/update_zero_etl_pipeline_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/zero_etl_pipeline.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/goldengate/zero_etl_pipeline_summary.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_protocol_types.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_query_properties.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_response_content_types.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_script_file_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_update_query_properties.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/update_http_script_file_details.go diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/aivision_aiservicevision_client.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/aivision_aiservicevision_client.go index f4a2f8bebd9..405505cd4d9 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/aivision_aiservicevision_client.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/aivision_aiservicevision_client.go @@ -321,6 +321,63 @@ func (client AIServiceVisionClient) cancelImageJob(ctx context.Context, request return response, err } +// CancelVideoJob Cancel a video analysis job. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/aivision/CancelVideoJob.go.html to see an example of how to use CancelVideoJob API. +func (client AIServiceVisionClient) CancelVideoJob(ctx context.Context, request CancelVideoJobRequest) (response CancelVideoJobResponse, err error) { + var ociResponse common.OCIResponse + policy := common.NoRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + ociResponse, err = common.Retry(ctx, request, client.cancelVideoJob, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = CancelVideoJobResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = CancelVideoJobResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(CancelVideoJobResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into CancelVideoJobResponse") + } + return +} + +// cancelVideoJob implements the OCIOperation interface (enables retrying operations) +func (client AIServiceVisionClient) cancelVideoJob(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodPost, "/videoJobs/{videoJobId}/actions/cancel", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response CancelVideoJobResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/vision/20220125/VideoJob/CancelVideoJob" + err = common.PostProcessServiceError(err, "AIServiceVision", "CancelVideoJob", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + // CancelWorkRequest Cancel the work request with the given ID. // // # See also @@ -740,6 +797,68 @@ func (client AIServiceVisionClient) createProject(ctx context.Context, request c return response, err } +// CreateVideoJob Create a video analysis job with given inputs and features. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/aivision/CreateVideoJob.go.html to see an example of how to use CreateVideoJob API. +func (client AIServiceVisionClient) CreateVideoJob(ctx context.Context, request CreateVideoJobRequest) (response CreateVideoJobResponse, err error) { + var ociResponse common.OCIResponse + policy := common.NoRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + + if !(request.OpcRetryToken != nil && *request.OpcRetryToken != "") { + request.OpcRetryToken = common.String(common.RetryToken()) + } + + ociResponse, err = common.Retry(ctx, request, client.createVideoJob, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = CreateVideoJobResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = CreateVideoJobResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(CreateVideoJobResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into CreateVideoJobResponse") + } + return +} + +// createVideoJob implements the OCIOperation interface (enables retrying operations) +func (client AIServiceVisionClient) createVideoJob(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodPost, "/videoJobs", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response CreateVideoJobResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/vision/20220125/VideoJob/CreateVideoJob" + err = common.PostProcessServiceError(err, "AIServiceVision", "CreateVideoJob", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + // DeleteModel Delete a model by identifier. // // # See also @@ -1082,6 +1201,63 @@ func (client AIServiceVisionClient) getProject(ctx context.Context, request comm return response, err } +// GetVideoJob Get details of a video analysis job. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/aivision/GetVideoJob.go.html to see an example of how to use GetVideoJob API. +func (client AIServiceVisionClient) GetVideoJob(ctx context.Context, request GetVideoJobRequest) (response GetVideoJobResponse, err error) { + var ociResponse common.OCIResponse + policy := common.NoRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + ociResponse, err = common.Retry(ctx, request, client.getVideoJob, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = GetVideoJobResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = GetVideoJobResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(GetVideoJobResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into GetVideoJobResponse") + } + return +} + +// getVideoJob implements the OCIOperation interface (enables retrying operations) +func (client AIServiceVisionClient) getVideoJob(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodGet, "/videoJobs/{videoJobId}", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response GetVideoJobResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/vision/20220125/VideoJob/GetVideoJob" + err = common.PostProcessServiceError(err, "AIServiceVision", "GetVideoJob", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + // GetWorkRequest Gets the status of the work request with the given ID. // // # See also diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/analyze_video_result.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/analyze_video_result.go new file mode 100644 index 00000000000..468db355c03 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/analyze_video_result.go @@ -0,0 +1,73 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// AnalyzeVideoResult Video analysis results. +type AnalyzeVideoResult struct { + VideoMetadata *VideoMetadata `mandatory:"true" json:"videoMetadata"` + + // Detected labels in a video. + VideoLabels []VideoLabel `mandatory:"false" json:"videoLabels"` + + // Detected objects in a video. + VideoObjects []VideoObject `mandatory:"false" json:"videoObjects"` + + // Tracked objects in a video. + VideoTrackedObjects []VideoTrackedObject `mandatory:"false" json:"videoTrackedObjects"` + + // Detected text in a video. + VideoText []VideoText `mandatory:"false" json:"videoText"` + + // Detected faces in a video. + VideoFaces []VideoFace `mandatory:"false" json:"videoFaces"` + + // The ontologyClasses of video labels. + OntologyClasses []OntologyClass `mandatory:"false" json:"ontologyClasses"` + + // Label Detection model version. + LabelDetectionModelVersion *string `mandatory:"false" json:"labelDetectionModelVersion"` + + // Object Detection model version. + ObjectDetectionModelVersion *string `mandatory:"false" json:"objectDetectionModelVersion"` + + // Object Tracking model version. + ObjectTrackingModelVersion *string `mandatory:"false" json:"objectTrackingModelVersion"` + + // Text Detection model version. + TextDetectionModelVersion *string `mandatory:"false" json:"textDetectionModelVersion"` + + // Face Detection model version. + FaceDetectionModelVersion *string `mandatory:"false" json:"faceDetectionModelVersion"` + + // Array of possible errors. + Errors []ProcessingError `mandatory:"false" json:"errors"` +} + +func (m AnalyzeVideoResult) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m AnalyzeVideoResult) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/cancel_video_job_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/cancel_video_job_request_response.go new file mode 100644 index 00000000000..4990bf2c164 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/cancel_video_job_request_response.go @@ -0,0 +1,94 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// CancelVideoJobRequest wrapper for the CancelVideoJob operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/aivision/CancelVideoJob.go.html to see an example of how to use CancelVideoJobRequest. +type CancelVideoJobRequest struct { + + // Video job id. + VideoJobId *string `mandatory:"true" contributesTo:"path" name:"videoJobId"` + + // 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. + IfMatch *string `mandatory:"false" contributesTo:"header" name:"if-match"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request CancelVideoJobRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request CancelVideoJobRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request CancelVideoJobRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request CancelVideoJobRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request CancelVideoJobRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// CancelVideoJobResponse wrapper for the CancelVideoJob operation +type CancelVideoJobResponse struct { + + // The underlying http response + RawResponse *http.Response + + // A unique Oracle-assigned identifier for the request. If you need to contact + // Oracle about a particular request, please provide the request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` +} + +func (response CancelVideoJobResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response CancelVideoJobResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/create_video_job_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/create_video_job_details.go new file mode 100644 index 00000000000..29e0a398e02 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/create_video_job_details.go @@ -0,0 +1,109 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// CreateVideoJobDetails Details about the video analysis. +type CreateVideoJobDetails struct { + InputLocation InputLocation `mandatory:"true" json:"inputLocation"` + + // a list of video analysis features. + Features []VideoFeature `mandatory:"true" json:"features"` + + OutputLocation *OutputLocation `mandatory:"true" json:"outputLocation"` + + // Compartment identifier from the requester. + CompartmentId *string `mandatory:"false" json:"compartmentId"` + + // Video job display name. + DisplayName *string `mandatory:"false" json:"displayName"` + + // A simple key-value pair that is applied without any predefined name, type, or scope. It exists for cross-compatibility only. + // For example: `{"bar-key": "value"}` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + + // Defined tags for this resource. Each key is predefined and scoped to a namespace. + // For example: `{"foo-namespace": {"bar-key": "value"}}` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` +} + +func (m CreateVideoJobDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m CreateVideoJobDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// UnmarshalJSON unmarshals from json +func (m *CreateVideoJobDetails) UnmarshalJSON(data []byte) (e error) { + model := struct { + CompartmentId *string `json:"compartmentId"` + DisplayName *string `json:"displayName"` + FreeformTags map[string]string `json:"freeformTags"` + DefinedTags map[string]map[string]interface{} `json:"definedTags"` + InputLocation inputlocation `json:"inputLocation"` + Features []videofeature `json:"features"` + OutputLocation *OutputLocation `json:"outputLocation"` + }{} + + e = json.Unmarshal(data, &model) + if e != nil { + return + } + var nn interface{} + m.CompartmentId = model.CompartmentId + + m.DisplayName = model.DisplayName + + m.FreeformTags = model.FreeformTags + + m.DefinedTags = model.DefinedTags + + nn, e = model.InputLocation.UnmarshalPolymorphicJSON(model.InputLocation.JsonData) + if e != nil { + return + } + if nn != nil { + m.InputLocation = nn.(InputLocation) + } else { + m.InputLocation = nil + } + + m.Features = make([]VideoFeature, len(model.Features)) + for i, n := range model.Features { + nn, e = n.UnmarshalPolymorphicJSON(n.JsonData) + if e != nil { + return e + } + if nn != nil { + m.Features[i] = nn.(VideoFeature) + } else { + m.Features[i] = nil + } + } + m.OutputLocation = model.OutputLocation + + return +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/create_video_job_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/create_video_job_request_response.go new file mode 100644 index 00000000000..3bea1d26186 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/create_video_job_request_response.go @@ -0,0 +1,100 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// CreateVideoJobRequest wrapper for the CreateVideoJob operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/aivision/CreateVideoJob.go.html to see an example of how to use CreateVideoJobRequest. +type CreateVideoJobRequest struct { + + // Details about the video analysis. + CreateVideoJobDetails `contributesTo:"body"` + + // A token that uniquely identifies a request so it can be retried in case of a timeout or + // server error without the risk of executing that same action again. Retry tokens expire after 24 + // hours, but can be invalidated before then due to conflicting operations. For example, if a resource + // has been deleted and purged from the system, then a retry of the original creation request + // might be rejected. + OpcRetryToken *string `mandatory:"false" contributesTo:"header" name:"opc-retry-token"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request CreateVideoJobRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request CreateVideoJobRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request CreateVideoJobRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request CreateVideoJobRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request CreateVideoJobRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// CreateVideoJobResponse wrapper for the CreateVideoJob operation +type CreateVideoJobResponse struct { + + // The underlying http response + RawResponse *http.Response + + // The VideoJob instance + VideoJob `presentIn:"body"` + + // For optimistic concurrency control. See `if-match`. + Etag *string `presentIn:"header" name:"etag"` + + // A unique Oracle-assigned identifier for the request. If you need to contact + // Oracle about a particular request, please provide the request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` +} + +func (response CreateVideoJobResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response CreateVideoJobResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/get_video_job_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/get_video_job_request_response.go new file mode 100644 index 00000000000..e39fcf1158d --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/get_video_job_request_response.go @@ -0,0 +1,93 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// GetVideoJobRequest wrapper for the GetVideoJob operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/aivision/GetVideoJob.go.html to see an example of how to use GetVideoJobRequest. +type GetVideoJobRequest struct { + + // Video job id. + VideoJobId *string `mandatory:"true" contributesTo:"path" name:"videoJobId"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request GetVideoJobRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request GetVideoJobRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request GetVideoJobRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request GetVideoJobRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request GetVideoJobRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// GetVideoJobResponse wrapper for the GetVideoJob operation +type GetVideoJobResponse struct { + + // The underlying http response + RawResponse *http.Response + + // The VideoJob instance + VideoJob `presentIn:"body"` + + // For optimistic concurrency control. See `if-match`. + Etag *string `presentIn:"header" name:"etag"` + + // A unique Oracle-assigned identifier for the request. If you need to contact + // Oracle about a particular request, please provide the request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` +} + +func (response GetVideoJobResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response GetVideoJobResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/object_property.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/object_property.go new file mode 100644 index 00000000000..8f88604edf1 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/object_property.go @@ -0,0 +1,44 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// ObjectProperty A property of a tracked object in a frame. +type ObjectProperty struct { + + // Property name + Name *string `mandatory:"true" json:"name"` + + // The confidence score, between 0 and 1. + Confidence *float32 `mandatory:"true" json:"confidence"` + + BoundingPolygon *BoundingPolygon `mandatory:"true" json:"boundingPolygon"` +} + +func (m ObjectProperty) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m ObjectProperty) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_face.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_face.go new file mode 100644 index 00000000000..a939c68552c --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_face.go @@ -0,0 +1,39 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoFace Detected face in a video. +type VideoFace struct { + + // Face segments in a video. + Segments []VideoFaceSegment `mandatory:"true" json:"segments"` +} + +func (m VideoFace) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoFace) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_face_detection_feature.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_face_detection_feature.go new file mode 100644 index 00000000000..798e807abb4 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_face_detection_feature.go @@ -0,0 +1,61 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoFaceDetectionFeature Video face detection feature +type VideoFaceDetectionFeature struct { + + // The maximum number of results per frame to return. + MaxResults *int `mandatory:"false" json:"maxResults"` + + // Whether or not return face landmarks. + IsLandmarkRequired *bool `mandatory:"false" json:"isLandmarkRequired"` + + // The minimum confidence score, between 0 and 1, + // when the value is set, results with lower confidence will not be returned. + MinConfidence *float32 `mandatory:"false" json:"minConfidence"` +} + +func (m VideoFaceDetectionFeature) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoFaceDetectionFeature) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m VideoFaceDetectionFeature) MarshalJSON() (buff []byte, e error) { + type MarshalTypeVideoFaceDetectionFeature VideoFaceDetectionFeature + s := struct { + DiscriminatorParam string `json:"featureType"` + MarshalTypeVideoFaceDetectionFeature + }{ + "FACE_DETECTION", + (MarshalTypeVideoFaceDetectionFeature)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_face_frame.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_face_frame.go new file mode 100644 index 00000000000..1ac80baaf6e --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_face_frame.go @@ -0,0 +1,50 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoFaceFrame A face frame. +type VideoFaceFrame struct { + + // Time offset(Milliseconds) in the video. + TimeOffsetMs *int `mandatory:"true" json:"timeOffsetMs"` + + // The confidence score, between 0 and 1. + Confidence *float32 `mandatory:"true" json:"confidence"` + + // The quality score of the face detected, between 0 and 1. + QualityScore *float32 `mandatory:"true" json:"qualityScore"` + + BoundingPolygon *BoundingPolygon `mandatory:"true" json:"boundingPolygon"` + + // Face landmarks. + Landmarks []Landmark `mandatory:"false" json:"landmarks"` +} + +func (m VideoFaceFrame) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoFaceFrame) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_face_segment.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_face_segment.go new file mode 100644 index 00000000000..5e7bbf612e1 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_face_segment.go @@ -0,0 +1,43 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoFaceSegment A face segment in a video. +type VideoFaceSegment struct { + VideoSegment *VideoSegment `mandatory:"true" json:"videoSegment"` + + // The confidence score, between 0 and 1. + Confidence *float32 `mandatory:"true" json:"confidence"` + + // Face frames in a segment. + Frames []VideoFaceFrame `mandatory:"true" json:"frames"` +} + +func (m VideoFaceSegment) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoFaceSegment) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_feature.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_feature.go new file mode 100644 index 00000000000..6f8f523cbb0 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_feature.go @@ -0,0 +1,147 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoFeature Details about a video feature request. +type VideoFeature interface { +} + +type videofeature struct { + JsonData []byte + FeatureType string `json:"featureType"` +} + +// UnmarshalJSON unmarshals json +func (m *videofeature) UnmarshalJSON(data []byte) error { + m.JsonData = data + type Unmarshalervideofeature videofeature + s := struct { + Model Unmarshalervideofeature + }{} + err := json.Unmarshal(data, &s.Model) + if err != nil { + return err + } + m.FeatureType = s.Model.FeatureType + + return err +} + +// UnmarshalPolymorphicJSON unmarshals polymorphic json +func (m *videofeature) UnmarshalPolymorphicJSON(data []byte) (interface{}, error) { + + if data == nil || string(data) == "null" { + return nil, nil + } + + var err error + switch m.FeatureType { + case "OBJECT_DETECTION": + mm := VideoObjectDetectionFeature{} + err = json.Unmarshal(data, &mm) + return mm, err + case "FACE_DETECTION": + mm := VideoFaceDetectionFeature{} + err = json.Unmarshal(data, &mm) + return mm, err + case "TEXT_DETECTION": + mm := VideoTextDetectionFeature{} + err = json.Unmarshal(data, &mm) + return mm, err + case "OBJECT_TRACKING": + mm := VideoObjectTrackingFeature{} + err = json.Unmarshal(data, &mm) + return mm, err + case "LABEL_DETECTION": + mm := VideoLabelDetectionFeature{} + err = json.Unmarshal(data, &mm) + return mm, err + default: + common.Logf("Recieved unsupported enum value for VideoFeature: %s.", m.FeatureType) + return *m, nil + } +} + +func (m videofeature) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m videofeature) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// VideoFeatureFeatureTypeEnum Enum with underlying type: string +type VideoFeatureFeatureTypeEnum string + +// Set of constants representing the allowable values for VideoFeatureFeatureTypeEnum +const ( + VideoFeatureFeatureTypeLabelDetection VideoFeatureFeatureTypeEnum = "LABEL_DETECTION" + VideoFeatureFeatureTypeObjectDetection VideoFeatureFeatureTypeEnum = "OBJECT_DETECTION" + VideoFeatureFeatureTypeTextDetection VideoFeatureFeatureTypeEnum = "TEXT_DETECTION" + VideoFeatureFeatureTypeFaceDetection VideoFeatureFeatureTypeEnum = "FACE_DETECTION" + VideoFeatureFeatureTypeObjectTracking VideoFeatureFeatureTypeEnum = "OBJECT_TRACKING" +) + +var mappingVideoFeatureFeatureTypeEnum = map[string]VideoFeatureFeatureTypeEnum{ + "LABEL_DETECTION": VideoFeatureFeatureTypeLabelDetection, + "OBJECT_DETECTION": VideoFeatureFeatureTypeObjectDetection, + "TEXT_DETECTION": VideoFeatureFeatureTypeTextDetection, + "FACE_DETECTION": VideoFeatureFeatureTypeFaceDetection, + "OBJECT_TRACKING": VideoFeatureFeatureTypeObjectTracking, +} + +var mappingVideoFeatureFeatureTypeEnumLowerCase = map[string]VideoFeatureFeatureTypeEnum{ + "label_detection": VideoFeatureFeatureTypeLabelDetection, + "object_detection": VideoFeatureFeatureTypeObjectDetection, + "text_detection": VideoFeatureFeatureTypeTextDetection, + "face_detection": VideoFeatureFeatureTypeFaceDetection, + "object_tracking": VideoFeatureFeatureTypeObjectTracking, +} + +// GetVideoFeatureFeatureTypeEnumValues Enumerates the set of values for VideoFeatureFeatureTypeEnum +func GetVideoFeatureFeatureTypeEnumValues() []VideoFeatureFeatureTypeEnum { + values := make([]VideoFeatureFeatureTypeEnum, 0) + for _, v := range mappingVideoFeatureFeatureTypeEnum { + values = append(values, v) + } + return values +} + +// GetVideoFeatureFeatureTypeEnumStringValues Enumerates the set of values in String for VideoFeatureFeatureTypeEnum +func GetVideoFeatureFeatureTypeEnumStringValues() []string { + return []string{ + "LABEL_DETECTION", + "OBJECT_DETECTION", + "TEXT_DETECTION", + "FACE_DETECTION", + "OBJECT_TRACKING", + } +} + +// GetMappingVideoFeatureFeatureTypeEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingVideoFeatureFeatureTypeEnum(val string) (VideoFeatureFeatureTypeEnum, bool) { + enum, ok := mappingVideoFeatureFeatureTypeEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_job.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_job.go new file mode 100644 index 00000000000..64c369df2af --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_job.go @@ -0,0 +1,265 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoJob Job details for a video analysis. +type VideoJob struct { + + // Id of the job. + Id *string `mandatory:"true" json:"id"` + + // The ocid of the compartment that starts the job. + CompartmentId *string `mandatory:"true" json:"compartmentId"` + + // a list of document analysis features. + Features []VideoFeature `mandatory:"true" json:"features"` + + // Job accepted time. + TimeAccepted *common.SDKTime `mandatory:"true" json:"timeAccepted"` + + OutputLocation *OutputLocation `mandatory:"true" json:"outputLocation"` + + // The current state of the batch document job. + LifecycleState VideoJobLifecycleStateEnum `mandatory:"true" json:"lifecycleState"` + + // Video job display name. + DisplayName *string `mandatory:"false" json:"displayName"` + + InputLocation InputLocation `mandatory:"false" json:"inputLocation"` + + // Job started time. + TimeStarted *common.SDKTime `mandatory:"false" json:"timeStarted"` + + // Job finished time. + TimeFinished *common.SDKTime `mandatory:"false" json:"timeFinished"` + + // How much progress the operation has made, vs the total amount of work that must be performed. + PercentComplete *float32 `mandatory:"false" json:"percentComplete"` + + // Detailed status of FAILED state. + LifecycleDetails VideoJobLifecycleDetailsEnum `mandatory:"false" json:"lifecycleDetails,omitempty"` + + // A simple key-value pair that is applied without any predefined name, type, or scope. It exists for cross-compatibility only. + // For example: `{"bar-key": "value"}` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + + // Defined tags for this resource. Each key is predefined and scoped to a namespace. + // For example: `{"foo-namespace": {"bar-key": "value"}}` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` + + // Usage of system tag keys. These predefined keys are scoped to namespaces. + // For example: `{"orcl-cloud": {"free-tier-retained": "true"}}` + SystemTags map[string]map[string]interface{} `mandatory:"false" json:"systemTags"` +} + +func (m VideoJob) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoJob) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingVideoJobLifecycleStateEnum(string(m.LifecycleState)); !ok && m.LifecycleState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", m.LifecycleState, strings.Join(GetVideoJobLifecycleStateEnumStringValues(), ","))) + } + + if _, ok := GetMappingVideoJobLifecycleDetailsEnum(string(m.LifecycleDetails)); !ok && m.LifecycleDetails != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleDetails: %s. Supported values are: %s.", m.LifecycleDetails, strings.Join(GetVideoJobLifecycleDetailsEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// UnmarshalJSON unmarshals from json +func (m *VideoJob) UnmarshalJSON(data []byte) (e error) { + model := struct { + DisplayName *string `json:"displayName"` + InputLocation inputlocation `json:"inputLocation"` + TimeStarted *common.SDKTime `json:"timeStarted"` + TimeFinished *common.SDKTime `json:"timeFinished"` + PercentComplete *float32 `json:"percentComplete"` + LifecycleDetails VideoJobLifecycleDetailsEnum `json:"lifecycleDetails"` + FreeformTags map[string]string `json:"freeformTags"` + DefinedTags map[string]map[string]interface{} `json:"definedTags"` + SystemTags map[string]map[string]interface{} `json:"systemTags"` + Id *string `json:"id"` + CompartmentId *string `json:"compartmentId"` + Features []videofeature `json:"features"` + TimeAccepted *common.SDKTime `json:"timeAccepted"` + OutputLocation *OutputLocation `json:"outputLocation"` + LifecycleState VideoJobLifecycleStateEnum `json:"lifecycleState"` + }{} + + e = json.Unmarshal(data, &model) + if e != nil { + return + } + var nn interface{} + m.DisplayName = model.DisplayName + + nn, e = model.InputLocation.UnmarshalPolymorphicJSON(model.InputLocation.JsonData) + if e != nil { + return + } + if nn != nil { + m.InputLocation = nn.(InputLocation) + } else { + m.InputLocation = nil + } + + m.TimeStarted = model.TimeStarted + + m.TimeFinished = model.TimeFinished + + m.PercentComplete = model.PercentComplete + + m.LifecycleDetails = model.LifecycleDetails + + m.FreeformTags = model.FreeformTags + + m.DefinedTags = model.DefinedTags + + m.SystemTags = model.SystemTags + + m.Id = model.Id + + m.CompartmentId = model.CompartmentId + + m.Features = make([]VideoFeature, len(model.Features)) + for i, n := range model.Features { + nn, e = n.UnmarshalPolymorphicJSON(n.JsonData) + if e != nil { + return e + } + if nn != nil { + m.Features[i] = nn.(VideoFeature) + } else { + m.Features[i] = nil + } + } + m.TimeAccepted = model.TimeAccepted + + m.OutputLocation = model.OutputLocation + + m.LifecycleState = model.LifecycleState + + return +} + +// VideoJobLifecycleStateEnum Enum with underlying type: string +type VideoJobLifecycleStateEnum string + +// Set of constants representing the allowable values for VideoJobLifecycleStateEnum +const ( + VideoJobLifecycleStateSucceeded VideoJobLifecycleStateEnum = "SUCCEEDED" + VideoJobLifecycleStateFailed VideoJobLifecycleStateEnum = "FAILED" + VideoJobLifecycleStateAccepted VideoJobLifecycleStateEnum = "ACCEPTED" + VideoJobLifecycleStateCanceled VideoJobLifecycleStateEnum = "CANCELED" + VideoJobLifecycleStateInProgress VideoJobLifecycleStateEnum = "IN_PROGRESS" + VideoJobLifecycleStateCanceling VideoJobLifecycleStateEnum = "CANCELING" +) + +var mappingVideoJobLifecycleStateEnum = map[string]VideoJobLifecycleStateEnum{ + "SUCCEEDED": VideoJobLifecycleStateSucceeded, + "FAILED": VideoJobLifecycleStateFailed, + "ACCEPTED": VideoJobLifecycleStateAccepted, + "CANCELED": VideoJobLifecycleStateCanceled, + "IN_PROGRESS": VideoJobLifecycleStateInProgress, + "CANCELING": VideoJobLifecycleStateCanceling, +} + +var mappingVideoJobLifecycleStateEnumLowerCase = map[string]VideoJobLifecycleStateEnum{ + "succeeded": VideoJobLifecycleStateSucceeded, + "failed": VideoJobLifecycleStateFailed, + "accepted": VideoJobLifecycleStateAccepted, + "canceled": VideoJobLifecycleStateCanceled, + "in_progress": VideoJobLifecycleStateInProgress, + "canceling": VideoJobLifecycleStateCanceling, +} + +// GetVideoJobLifecycleStateEnumValues Enumerates the set of values for VideoJobLifecycleStateEnum +func GetVideoJobLifecycleStateEnumValues() []VideoJobLifecycleStateEnum { + values := make([]VideoJobLifecycleStateEnum, 0) + for _, v := range mappingVideoJobLifecycleStateEnum { + values = append(values, v) + } + return values +} + +// GetVideoJobLifecycleStateEnumStringValues Enumerates the set of values in String for VideoJobLifecycleStateEnum +func GetVideoJobLifecycleStateEnumStringValues() []string { + return []string{ + "SUCCEEDED", + "FAILED", + "ACCEPTED", + "CANCELED", + "IN_PROGRESS", + "CANCELING", + } +} + +// GetMappingVideoJobLifecycleStateEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingVideoJobLifecycleStateEnum(val string) (VideoJobLifecycleStateEnum, bool) { + enum, ok := mappingVideoJobLifecycleStateEnumLowerCase[strings.ToLower(val)] + return enum, ok +} + +// VideoJobLifecycleDetailsEnum Enum with underlying type: string +type VideoJobLifecycleDetailsEnum string + +// Set of constants representing the allowable values for VideoJobLifecycleDetailsEnum +const ( + VideoJobLifecycleDetailsPartiallySucceeded VideoJobLifecycleDetailsEnum = "PARTIALLY_SUCCEEDED" + VideoJobLifecycleDetailsCompletelyFailed VideoJobLifecycleDetailsEnum = "COMPLETELY_FAILED" +) + +var mappingVideoJobLifecycleDetailsEnum = map[string]VideoJobLifecycleDetailsEnum{ + "PARTIALLY_SUCCEEDED": VideoJobLifecycleDetailsPartiallySucceeded, + "COMPLETELY_FAILED": VideoJobLifecycleDetailsCompletelyFailed, +} + +var mappingVideoJobLifecycleDetailsEnumLowerCase = map[string]VideoJobLifecycleDetailsEnum{ + "partially_succeeded": VideoJobLifecycleDetailsPartiallySucceeded, + "completely_failed": VideoJobLifecycleDetailsCompletelyFailed, +} + +// GetVideoJobLifecycleDetailsEnumValues Enumerates the set of values for VideoJobLifecycleDetailsEnum +func GetVideoJobLifecycleDetailsEnumValues() []VideoJobLifecycleDetailsEnum { + values := make([]VideoJobLifecycleDetailsEnum, 0) + for _, v := range mappingVideoJobLifecycleDetailsEnum { + values = append(values, v) + } + return values +} + +// GetVideoJobLifecycleDetailsEnumStringValues Enumerates the set of values in String for VideoJobLifecycleDetailsEnum +func GetVideoJobLifecycleDetailsEnumStringValues() []string { + return []string{ + "PARTIALLY_SUCCEEDED", + "COMPLETELY_FAILED", + } +} + +// GetMappingVideoJobLifecycleDetailsEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingVideoJobLifecycleDetailsEnum(val string) (VideoJobLifecycleDetailsEnum, bool) { + enum, ok := mappingVideoJobLifecycleDetailsEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_label.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_label.go new file mode 100644 index 00000000000..91cc7c97d90 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_label.go @@ -0,0 +1,42 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoLabel Detected label in a video. +type VideoLabel struct { + + // Detected label name. + Name *string `mandatory:"true" json:"name"` + + // Label segments in a video. + Segments []VideoLabelSegment `mandatory:"true" json:"segments"` +} + +func (m VideoLabel) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoLabel) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_label_detection_feature.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_label_detection_feature.go new file mode 100644 index 00000000000..aee575fe010 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_label_detection_feature.go @@ -0,0 +1,61 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoLabelDetectionFeature Video label detection feature +type VideoLabelDetectionFeature struct { + + // The minimum confidence score, between 0 and 1, + // when the value is set, results with lower confidence will not be returned. + MinConfidence *float32 `mandatory:"false" json:"minConfidence"` + + // The maximum number of results per video frame to return. + MaxResults *int `mandatory:"false" json:"maxResults"` + + // The custom model ID. + ModelId *string `mandatory:"false" json:"modelId"` +} + +func (m VideoLabelDetectionFeature) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoLabelDetectionFeature) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m VideoLabelDetectionFeature) MarshalJSON() (buff []byte, e error) { + type MarshalTypeVideoLabelDetectionFeature VideoLabelDetectionFeature + s := struct { + DiscriminatorParam string `json:"featureType"` + MarshalTypeVideoLabelDetectionFeature + }{ + "LABEL_DETECTION", + (MarshalTypeVideoLabelDetectionFeature)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_label_segment.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_label_segment.go new file mode 100644 index 00000000000..ca2955002ad --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_label_segment.go @@ -0,0 +1,40 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoLabelSegment A label segment in a video. +type VideoLabelSegment struct { + VideoSegment *VideoSegment `mandatory:"true" json:"videoSegment"` + + // The confidence score, between 0 and 1. + Confidence *float32 `mandatory:"true" json:"confidence"` +} + +func (m VideoLabelSegment) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoLabelSegment) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_metadata.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_metadata.go new file mode 100644 index 00000000000..0972b561180 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_metadata.go @@ -0,0 +1,48 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoMetadata Video information. +type VideoMetadata struct { + + // Total number of frames. + FrameCount *int `mandatory:"true" json:"frameCount"` + + // Video framerate. + FrameRate *float32 `mandatory:"true" json:"frameRate"` + + // Width of each frame. + FrameWidth *int `mandatory:"true" json:"frameWidth"` + + // Height of each frame. + FrameHeight *int `mandatory:"true" json:"frameHeight"` +} + +func (m VideoMetadata) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoMetadata) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object.go new file mode 100644 index 00000000000..79728d80d10 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object.go @@ -0,0 +1,42 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoObject Detected object in a video. +type VideoObject struct { + + // Detected object name. + Name *string `mandatory:"true" json:"name"` + + // Object segments in a video. + Segments []VideoObjectSegment `mandatory:"true" json:"segments"` +} + +func (m VideoObject) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoObject) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object_detection_feature.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object_detection_feature.go new file mode 100644 index 00000000000..e39ed35f7f7 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object_detection_feature.go @@ -0,0 +1,61 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoObjectDetectionFeature Video object detection feature +type VideoObjectDetectionFeature struct { + + // The minimum confidence score, between 0 and 1, + // when the value is set, results with lower confidence will not be returned. + MinConfidence *float32 `mandatory:"false" json:"minConfidence"` + + // The maximum number of results per frame to return. + MaxResults *int `mandatory:"false" json:"maxResults"` + + // The custom model ID. + ModelId *string `mandatory:"false" json:"modelId"` +} + +func (m VideoObjectDetectionFeature) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoObjectDetectionFeature) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m VideoObjectDetectionFeature) MarshalJSON() (buff []byte, e error) { + type MarshalTypeVideoObjectDetectionFeature VideoObjectDetectionFeature + s := struct { + DiscriminatorParam string `json:"featureType"` + MarshalTypeVideoObjectDetectionFeature + }{ + "OBJECT_DETECTION", + (MarshalTypeVideoObjectDetectionFeature)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object_frame.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object_frame.go new file mode 100644 index 00000000000..1b7e2d92741 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object_frame.go @@ -0,0 +1,44 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoObjectFrame An object frame. +type VideoObjectFrame struct { + + // Time offset(Milliseconds) in the video. + TimeOffsetMs *int `mandatory:"true" json:"timeOffsetMs"` + + // The confidence score, between 0 and 1. + Confidence *float32 `mandatory:"true" json:"confidence"` + + BoundingPolygon *BoundingPolygon `mandatory:"true" json:"boundingPolygon"` +} + +func (m VideoObjectFrame) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoObjectFrame) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object_segment.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object_segment.go new file mode 100644 index 00000000000..d34feaff6c3 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object_segment.go @@ -0,0 +1,43 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoObjectSegment An object segment in a video. +type VideoObjectSegment struct { + VideoSegment *VideoSegment `mandatory:"true" json:"videoSegment"` + + // The confidence score, between 0 and 1. + Confidence *float32 `mandatory:"true" json:"confidence"` + + // Object frame in a segment. + Frames []VideoObjectFrame `mandatory:"true" json:"frames"` +} + +func (m VideoObjectSegment) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoObjectSegment) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object_tracking_feature.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object_tracking_feature.go new file mode 100644 index 00000000000..bf73197b266 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_object_tracking_feature.go @@ -0,0 +1,61 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoObjectTrackingFeature Video object tracking feature +type VideoObjectTrackingFeature struct { + + // The minimum confidence score, between 0 and 1, + // when the value is set, results with lower confidence will not be returned. + MinConfidence *float32 `mandatory:"false" json:"minConfidence"` + + // The maximum number of results per frame to return. + MaxResults *int `mandatory:"false" json:"maxResults"` + + // The custom model ID. + ModelId *string `mandatory:"false" json:"modelId"` +} + +func (m VideoObjectTrackingFeature) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoObjectTrackingFeature) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m VideoObjectTrackingFeature) MarshalJSON() (buff []byte, e error) { + type MarshalTypeVideoObjectTrackingFeature VideoObjectTrackingFeature + s := struct { + DiscriminatorParam string `json:"featureType"` + MarshalTypeVideoObjectTrackingFeature + }{ + "OBJECT_TRACKING", + (MarshalTypeVideoObjectTrackingFeature)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_segment.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_segment.go new file mode 100644 index 00000000000..48793a9c638 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_segment.go @@ -0,0 +1,42 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoSegment A sequence of frames that was (or appears to be) continuously captured for a label/object/text?. +type VideoSegment struct { + + // Video start time offset(Milliseconds). + StartTimeOffsetMs *int `mandatory:"true" json:"startTimeOffsetMs"` + + // Video end time offset(Milliseconds). + EndTimeOffsetMs *int `mandatory:"true" json:"endTimeOffsetMs"` +} + +func (m VideoSegment) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoSegment) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_text.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_text.go new file mode 100644 index 00000000000..460544ead15 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_text.go @@ -0,0 +1,42 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoText Detected text in a video. +type VideoText struct { + + // Detected text. + Text *string `mandatory:"true" json:"text"` + + // Text segments in a video. + Segments []VideoTextSegment `mandatory:"true" json:"segments"` +} + +func (m VideoText) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoText) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_text_detection_feature.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_text_detection_feature.go new file mode 100644 index 00000000000..dbe85539dcb --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_text_detection_feature.go @@ -0,0 +1,55 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoTextDetectionFeature Video text detection feature +type VideoTextDetectionFeature struct { + + // The minimum confidence score, between 0 and 1, + // when the value is set, results with lower confidence will not be returned. + MinConfidence *float32 `mandatory:"false" json:"minConfidence"` +} + +func (m VideoTextDetectionFeature) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoTextDetectionFeature) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m VideoTextDetectionFeature) MarshalJSON() (buff []byte, e error) { + type MarshalTypeVideoTextDetectionFeature VideoTextDetectionFeature + s := struct { + DiscriminatorParam string `json:"featureType"` + MarshalTypeVideoTextDetectionFeature + }{ + "TEXT_DETECTION", + (MarshalTypeVideoTextDetectionFeature)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_text_frame.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_text_frame.go new file mode 100644 index 00000000000..8be10d808e8 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_text_frame.go @@ -0,0 +1,44 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoTextFrame A text frame. +type VideoTextFrame struct { + + // Time offset(Milliseconds) in the video. + TimeOffsetMs *int `mandatory:"true" json:"timeOffsetMs"` + + // The confidence score, between 0 and 1. + Confidence *float32 `mandatory:"true" json:"confidence"` + + BoundingPolygon *BoundingPolygon `mandatory:"true" json:"boundingPolygon"` +} + +func (m VideoTextFrame) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoTextFrame) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_text_segment.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_text_segment.go new file mode 100644 index 00000000000..27d962f9722 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_text_segment.go @@ -0,0 +1,43 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoTextSegment A text segment in a video. +type VideoTextSegment struct { + VideoSegment *VideoSegment `mandatory:"true" json:"videoSegment"` + + // The confidence score, between 0 and 1. + Confidence *float32 `mandatory:"true" json:"confidence"` + + // Text frame in a segment. + Frames []VideoTextFrame `mandatory:"true" json:"frames"` +} + +func (m VideoTextSegment) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoTextSegment) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_tracked_object.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_tracked_object.go new file mode 100644 index 00000000000..3f2239f6636 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_tracked_object.go @@ -0,0 +1,47 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoTrackedObject Tracked object in a video. +type VideoTrackedObject struct { + + // Name of the object category label. + Name *string `mandatory:"true" json:"name"` + + // Unique identifier for the object. + ObjectId *int `mandatory:"true" json:"objectId"` + + // Segments for the tracked object. + Segments []VideoTrackedObjectSegment `mandatory:"true" json:"segments"` + + Properties *VideoTrackedObjectProperties `mandatory:"false" json:"properties"` +} + +func (m VideoTrackedObject) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoTrackedObject) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_tracked_object_properties.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_tracked_object_properties.go new file mode 100644 index 00000000000..b6c74583d6d --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_tracked_object_properties.go @@ -0,0 +1,39 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoTrackedObjectProperties Properties of a tracked object in a video. +type VideoTrackedObjectProperties struct { + + // The axle count value of a tracked vehicle. + AxleCount *int `mandatory:"false" json:"axleCount"` +} + +func (m VideoTrackedObjectProperties) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoTrackedObjectProperties) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_tracked_object_segment.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_tracked_object_segment.go new file mode 100644 index 00000000000..c98485961da --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_tracked_object_segment.go @@ -0,0 +1,43 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoTrackedObjectSegment A segment of a tracked object in a video. +type VideoTrackedObjectSegment struct { + VideoSegment *VideoSegment `mandatory:"true" json:"videoSegment"` + + // The confidence score, between 0 and 1. + Confidence *float32 `mandatory:"true" json:"confidence"` + + // Frames within the segment. + Frames []VideoTrackingFrame `mandatory:"true" json:"frames"` +} + +func (m VideoTrackedObjectSegment) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoTrackedObjectSegment) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_tracking_frame.go b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_tracking_frame.go new file mode 100644 index 00000000000..1a40aaa4d32 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/aivision/video_tracking_frame.go @@ -0,0 +1,47 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Vision API +// +// Using Vision, you can upload images to detect and classify objects in them. If you have lots of images, you can process them in batch using asynchronous API endpoints. Vision's features are thematically split between Document AI for document-centric images, and Image Analysis for object and scene-based images. Pretrained models and custom models are supported. +// + +package aivision + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VideoTrackingFrame A frame capturing a tracked object. +type VideoTrackingFrame struct { + + // Time offset(Milliseconds) of the frame. + TimeOffsetMs *int `mandatory:"true" json:"timeOffsetMs"` + + // The confidence score, between 0 and 1. + Confidence *float32 `mandatory:"true" json:"confidence"` + + BoundingPolygon *BoundingPolygon `mandatory:"true" json:"boundingPolygon"` + + // Properties associated with the tracked object in the frame. + Properties []ObjectProperty `mandatory:"false" json:"properties"` +} + +func (m VideoTrackingFrame) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VideoTrackingFrame) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/activate_iam_user_sync_configuration_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/activate_iam_user_sync_configuration_details.go new file mode 100644 index 00000000000..9cfae80bafd --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/activate_iam_user_sync_configuration_details.go @@ -0,0 +1,42 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Big Data Service API +// +// REST API for Oracle Big Data Service. Use this API to build, deploy, and manage fully elastic Big Data Service clusters. Build on Hadoop, Spark and Data Science distributions, which can be fully integrated with existing enterprise data in Oracle Database and Oracle applications. +// + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// ActivateIamUserSyncConfigurationDetails Details for activating IAM user sync configuration +type ActivateIamUserSyncConfigurationDetails struct { + + // Base-64 encoded password for the cluster admin user. + ClusterAdminPassword *string `mandatory:"true" json:"clusterAdminPassword"` + + // whether posix attribute needs to be appended to users + IsPosixAttributesAdditionRequired *bool `mandatory:"false" json:"isPosixAttributesAdditionRequired"` +} + +func (m ActivateIamUserSyncConfigurationDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m ActivateIamUserSyncConfigurationDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/activate_iam_user_sync_configuration_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/activate_iam_user_sync_configuration_request_response.go new file mode 100644 index 00000000000..6a4796d06a1 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/activate_iam_user_sync_configuration_request_response.go @@ -0,0 +1,110 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// ActivateIamUserSyncConfigurationRequest wrapper for the ActivateIamUserSyncConfiguration operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/ActivateIamUserSyncConfiguration.go.html to see an example of how to use ActivateIamUserSyncConfigurationRequest. +type ActivateIamUserSyncConfigurationRequest struct { + + // The OCID of the cluster. + BdsInstanceId *string `mandatory:"true" contributesTo:"path" name:"bdsInstanceId"` + + // The OCID of the identity configuration + IdentityConfigurationId *string `mandatory:"true" contributesTo:"path" name:"identityConfigurationId"` + + // Details for activating a new IAM user sync config. + ActivateIamUserSyncConfigurationDetails `contributesTo:"body"` + + // A token that uniquely identifies a request so it can be retried in case of a timeout or + // server error, without risk of executing that same action again. Retry tokens expire after 24 + // hours but can be invalidated before then due to conflicting operations. For example, if a resource + // has been deleted and purged from the system, then a retry of the original creation request + // might be rejected. + OpcRetryToken *string `mandatory:"false" contributesTo:"header" name:"opc-retry-token"` + + // 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. + IfMatch *string `mandatory:"false" contributesTo:"header" name:"if-match"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request ActivateIamUserSyncConfigurationRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request ActivateIamUserSyncConfigurationRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request ActivateIamUserSyncConfigurationRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request ActivateIamUserSyncConfigurationRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request ActivateIamUserSyncConfigurationRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// ActivateIamUserSyncConfigurationResponse wrapper for the ActivateIamUserSyncConfiguration operation +type ActivateIamUserSyncConfigurationResponse struct { + + // The underlying http response + RawResponse *http.Response + + // Unique Oracle-assigned identifier for the request. If you need to contact + // Oracle about a request, provide this request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // Unique Oracle-assigned identifier for the asynchronous request. You can use this to query status of the asynchronous operation. + OpcWorkRequestId *string `presentIn:"header" name:"opc-work-request-id"` +} + +func (response ActivateIamUserSyncConfigurationResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response ActivateIamUserSyncConfigurationResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/activate_upst_configuration_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/activate_upst_configuration_details.go new file mode 100644 index 00000000000..9fc0813c630 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/activate_upst_configuration_details.go @@ -0,0 +1,45 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Big Data Service API +// +// REST API for Oracle Big Data Service. Use this API to build, deploy, and manage fully elastic Big Data Service clusters. Build on Hadoop, Spark and Data Science distributions, which can be fully integrated with existing enterprise data in Oracle Database and Oracle applications. +// + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// ActivateUpstConfigurationDetails Details for activating UPST config on the cluster +type ActivateUpstConfigurationDetails struct { + + // Base-64 encoded password for the cluster admin user. + ClusterAdminPassword *string `mandatory:"true" json:"clusterAdminPassword"` + + // OCID of the vault to store token exchange service principal keyta, required for creating UPST configb + VaultId *string `mandatory:"true" json:"vaultId"` + + // OCID of the master encryption key in vault for encrypting token exchange service principal keytab, required for creating UPST config + MasterEncryptionKeyId *string `mandatory:"true" json:"masterEncryptionKeyId"` +} + +func (m ActivateUpstConfigurationDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m ActivateUpstConfigurationDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/activate_upst_configuration_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/activate_upst_configuration_request_response.go new file mode 100644 index 00000000000..51f95a17985 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/activate_upst_configuration_request_response.go @@ -0,0 +1,110 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// ActivateUpstConfigurationRequest wrapper for the ActivateUpstConfiguration operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/ActivateUpstConfiguration.go.html to see an example of how to use ActivateUpstConfigurationRequest. +type ActivateUpstConfigurationRequest struct { + + // The OCID of the cluster. + BdsInstanceId *string `mandatory:"true" contributesTo:"path" name:"bdsInstanceId"` + + // The OCID of the identity configuration + IdentityConfigurationId *string `mandatory:"true" contributesTo:"path" name:"identityConfigurationId"` + + // Details for activating UPST config + ActivateUpstConfigurationDetails `contributesTo:"body"` + + // A token that uniquely identifies a request so it can be retried in case of a timeout or + // server error, without risk of executing that same action again. Retry tokens expire after 24 + // hours but can be invalidated before then due to conflicting operations. For example, if a resource + // has been deleted and purged from the system, then a retry of the original creation request + // might be rejected. + OpcRetryToken *string `mandatory:"false" contributesTo:"header" name:"opc-retry-token"` + + // 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. + IfMatch *string `mandatory:"false" contributesTo:"header" name:"if-match"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request ActivateUpstConfigurationRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request ActivateUpstConfigurationRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request ActivateUpstConfigurationRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request ActivateUpstConfigurationRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request ActivateUpstConfigurationRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// ActivateUpstConfigurationResponse wrapper for the ActivateUpstConfiguration operation +type ActivateUpstConfigurationResponse struct { + + // The underlying http response + RawResponse *http.Response + + // Unique Oracle-assigned identifier for the request. If you need to contact + // Oracle about a request, provide this request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // Unique Oracle-assigned identifier for the asynchronous request. You can use this to query status of the asynchronous operation. + OpcWorkRequestId *string `presentIn:"header" name:"opc-work-request-id"` +} + +func (response ActivateUpstConfigurationResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response ActivateUpstConfigurationResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/batching_based_odh_patching_config.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/batching_based_odh_patching_config.go index d8d63a9379b..b6f7779fa94 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/bds/batching_based_odh_patching_config.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/batching_based_odh_patching_config.go @@ -24,6 +24,9 @@ type BatchingBasedOdhPatchingConfig struct { // The wait time between batches in seconds. WaitTimeBetweenBatchInSeconds *int `mandatory:"true" json:"waitTimeBetweenBatchInSeconds"` + + // Acceptable number of failed-to-be-patched nodes in each batch. The maximum number of failed-to-patch nodes cannot exceed 20% of the number of non-utility and non-master nodes. + ToleranceThresholdPerBatch *int `mandatory:"false" json:"toleranceThresholdPerBatch"` } func (m BatchingBasedOdhPatchingConfig) String() string { diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/bds_api_key.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/bds_api_key.go index 8f5e511aca9..2c5c3e18a00 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/bds/bds_api_key.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/bds_api_key.go @@ -46,6 +46,9 @@ type BdsApiKey struct { // The time the API key was created, shown as an RFC 3339 formatted datetime string. TimeCreated *common.SDKTime `mandatory:"false" json:"timeCreated"` + + // Identity domain OCID ,where user is present. For default domain ,this field will be optional. + DomainOcid *string `mandatory:"false" json:"domainOcid"` } func (m BdsApiKey) String() string { diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/bds_client.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/bds_client.go index 9ebc455438d..aa0a06b0ae2 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/bds/bds_client.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/bds_client.go @@ -153,6 +153,130 @@ func (client BdsClient) activateBdsMetastoreConfiguration(ctx context.Context, r return response, err } +// ActivateIamUserSyncConfiguration Activate IAM user sync configuration for the given identity configuration +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/ActivateIamUserSyncConfiguration.go.html to see an example of how to use ActivateIamUserSyncConfiguration API. +func (client BdsClient) ActivateIamUserSyncConfiguration(ctx context.Context, request ActivateIamUserSyncConfigurationRequest) (response ActivateIamUserSyncConfigurationResponse, err error) { + var ociResponse common.OCIResponse + policy := common.NoRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + + if !(request.OpcRetryToken != nil && *request.OpcRetryToken != "") { + request.OpcRetryToken = common.String(common.RetryToken()) + } + + ociResponse, err = common.Retry(ctx, request, client.activateIamUserSyncConfiguration, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = ActivateIamUserSyncConfigurationResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = ActivateIamUserSyncConfigurationResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(ActivateIamUserSyncConfigurationResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into ActivateIamUserSyncConfigurationResponse") + } + return +} + +// activateIamUserSyncConfiguration implements the OCIOperation interface (enables retrying operations) +func (client BdsClient) activateIamUserSyncConfiguration(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodPost, "/bdsInstances/{bdsInstanceId}/identityConfigurations/{identityConfigurationId}/actions/activateIamUserSyncConfiguration", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response ActivateIamUserSyncConfigurationResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/bigdata/20190531/IdentityConfiguration/ActivateIamUserSyncConfiguration" + err = common.PostProcessServiceError(err, "Bds", "ActivateIamUserSyncConfiguration", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + +// ActivateUpstConfiguration Activate UPST configuration for the given identity configuration +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/ActivateUpstConfiguration.go.html to see an example of how to use ActivateUpstConfiguration API. +func (client BdsClient) ActivateUpstConfiguration(ctx context.Context, request ActivateUpstConfigurationRequest) (response ActivateUpstConfigurationResponse, err error) { + var ociResponse common.OCIResponse + policy := common.NoRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + + if !(request.OpcRetryToken != nil && *request.OpcRetryToken != "") { + request.OpcRetryToken = common.String(common.RetryToken()) + } + + ociResponse, err = common.Retry(ctx, request, client.activateUpstConfiguration, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = ActivateUpstConfigurationResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = ActivateUpstConfigurationResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(ActivateUpstConfigurationResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into ActivateUpstConfigurationResponse") + } + return +} + +// activateUpstConfiguration implements the OCIOperation interface (enables retrying operations) +func (client BdsClient) activateUpstConfiguration(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodPost, "/bdsInstances/{bdsInstanceId}/identityConfigurations/{identityConfigurationId}/actions/activateUpstConfiguration", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response ActivateUpstConfigurationResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/bigdata/20190531/IdentityConfiguration/ActivateUpstConfiguration" + err = common.PostProcessServiceError(err, "Bds", "ActivateUpstConfiguration", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + // AddAutoScalingConfiguration Add an autoscale configuration to the cluster. // // # See also @@ -1021,6 +1145,68 @@ func (client BdsClient) createBdsMetastoreConfiguration(ctx context.Context, req return response, err } +// CreateIdentityConfiguration Create an identity configuration for the cluster +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/CreateIdentityConfiguration.go.html to see an example of how to use CreateIdentityConfiguration API. +func (client BdsClient) CreateIdentityConfiguration(ctx context.Context, request CreateIdentityConfigurationRequest) (response CreateIdentityConfigurationResponse, err error) { + var ociResponse common.OCIResponse + policy := common.NoRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + + if !(request.OpcRetryToken != nil && *request.OpcRetryToken != "") { + request.OpcRetryToken = common.String(common.RetryToken()) + } + + ociResponse, err = common.Retry(ctx, request, client.createIdentityConfiguration, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = CreateIdentityConfigurationResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = CreateIdentityConfigurationResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(CreateIdentityConfigurationResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into CreateIdentityConfigurationResponse") + } + return +} + +// createIdentityConfiguration implements the OCIOperation interface (enables retrying operations) +func (client BdsClient) createIdentityConfiguration(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodPost, "/bdsInstances/{bdsInstanceId}/identityConfigurations", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response CreateIdentityConfigurationResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/bigdata/20190531/IdentityConfiguration/CreateIdentityConfiguration" + err = common.PostProcessServiceError(err, "Bds", "CreateIdentityConfiguration", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + // CreateNodeBackupConfiguration Add a node volume backup configuration to the cluster for an indicated node type or node. // // # See also @@ -1207,6 +1393,130 @@ func (client BdsClient) createResourcePrincipalConfiguration(ctx context.Context return response, err } +// DeactivateIamUserSyncConfiguration Deactivate the IAM user sync configuration. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/DeactivateIamUserSyncConfiguration.go.html to see an example of how to use DeactivateIamUserSyncConfiguration API. +func (client BdsClient) DeactivateIamUserSyncConfiguration(ctx context.Context, request DeactivateIamUserSyncConfigurationRequest) (response DeactivateIamUserSyncConfigurationResponse, err error) { + var ociResponse common.OCIResponse + policy := common.NoRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + + if !(request.OpcRetryToken != nil && *request.OpcRetryToken != "") { + request.OpcRetryToken = common.String(common.RetryToken()) + } + + ociResponse, err = common.Retry(ctx, request, client.deactivateIamUserSyncConfiguration, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = DeactivateIamUserSyncConfigurationResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = DeactivateIamUserSyncConfigurationResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(DeactivateIamUserSyncConfigurationResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into DeactivateIamUserSyncConfigurationResponse") + } + return +} + +// deactivateIamUserSyncConfiguration implements the OCIOperation interface (enables retrying operations) +func (client BdsClient) deactivateIamUserSyncConfiguration(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodPost, "/bdsInstances/{bdsInstanceId}/identityConfigurations/{identityConfigurationId}/actions/deactivateIamUserSyncConfiguration", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response DeactivateIamUserSyncConfigurationResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/bigdata/20190531/IdentityConfiguration/DeactivateIamUserSyncConfiguration" + err = common.PostProcessServiceError(err, "Bds", "DeactivateIamUserSyncConfiguration", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + +// DeactivateUpstConfiguration Deactivate the UPST configuration represented by the provided ID. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/DeactivateUpstConfiguration.go.html to see an example of how to use DeactivateUpstConfiguration API. +func (client BdsClient) DeactivateUpstConfiguration(ctx context.Context, request DeactivateUpstConfigurationRequest) (response DeactivateUpstConfigurationResponse, err error) { + var ociResponse common.OCIResponse + policy := common.NoRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + + if !(request.OpcRetryToken != nil && *request.OpcRetryToken != "") { + request.OpcRetryToken = common.String(common.RetryToken()) + } + + ociResponse, err = common.Retry(ctx, request, client.deactivateUpstConfiguration, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = DeactivateUpstConfigurationResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = DeactivateUpstConfigurationResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(DeactivateUpstConfigurationResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into DeactivateUpstConfigurationResponse") + } + return +} + +// deactivateUpstConfiguration implements the OCIOperation interface (enables retrying operations) +func (client BdsClient) deactivateUpstConfiguration(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodPost, "/bdsInstances/{bdsInstanceId}/identityConfigurations/{identityConfigurationId}/actions/deactivateUpstConfiguration", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response DeactivateUpstConfigurationResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/bigdata/20190531/IdentityConfiguration/DeactivateUpstConfiguration" + err = common.PostProcessServiceError(err, "Bds", "DeactivateUpstConfiguration", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + // DeleteBdsApiKey Deletes the user's API key represented by the provided ID. // // # See also @@ -1378,6 +1688,63 @@ func (client BdsClient) deleteBdsMetastoreConfiguration(ctx context.Context, req return response, err } +// DeleteIdentityConfiguration Delete the identity configuration represented by the provided ID. Deletion is only allowed if this identity configuration is not associated with any active IAM user sync configuration or UPST configuration. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/DeleteIdentityConfiguration.go.html to see an example of how to use DeleteIdentityConfiguration API. +func (client BdsClient) DeleteIdentityConfiguration(ctx context.Context, request DeleteIdentityConfigurationRequest) (response DeleteIdentityConfigurationResponse, err error) { + var ociResponse common.OCIResponse + policy := common.NoRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + ociResponse, err = common.Retry(ctx, request, client.deleteIdentityConfiguration, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = DeleteIdentityConfigurationResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = DeleteIdentityConfigurationResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(DeleteIdentityConfigurationResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into DeleteIdentityConfigurationResponse") + } + return +} + +// deleteIdentityConfiguration implements the OCIOperation interface (enables retrying operations) +func (client BdsClient) deleteIdentityConfiguration(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodDelete, "/bdsInstances/{bdsInstanceId}/identityConfigurations/{identityConfigurationId}", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response DeleteIdentityConfigurationResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/bigdata/20190531/IdentityConfiguration/DeleteIdentityConfiguration" + err = common.PostProcessServiceError(err, "Bds", "DeleteIdentityConfiguration", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + // DeleteNodeBackup Delete the NodeBackup represented by the provided ID. // // # See also @@ -1888,22 +2255,79 @@ func (client BdsClient) GetBdsInstance(ctx context.Context, request GetBdsInstan return } -// getBdsInstance implements the OCIOperation interface (enables retrying operations) -func (client BdsClient) getBdsInstance(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { +// getBdsInstance implements the OCIOperation interface (enables retrying operations) +func (client BdsClient) getBdsInstance(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodGet, "/bdsInstances/{bdsInstanceId}", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response GetBdsInstanceResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/bigdata/20190531/BdsInstance/GetBdsInstance" + err = common.PostProcessServiceError(err, "Bds", "GetBdsInstance", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + +// GetBdsMetastoreConfiguration Returns the BDS Metastore configuration information for the given ID. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/GetBdsMetastoreConfiguration.go.html to see an example of how to use GetBdsMetastoreConfiguration API. +func (client BdsClient) GetBdsMetastoreConfiguration(ctx context.Context, request GetBdsMetastoreConfigurationRequest) (response GetBdsMetastoreConfigurationResponse, err error) { + var ociResponse common.OCIResponse + policy := common.NoRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + ociResponse, err = common.Retry(ctx, request, client.getBdsMetastoreConfiguration, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = GetBdsMetastoreConfigurationResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = GetBdsMetastoreConfigurationResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(GetBdsMetastoreConfigurationResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into GetBdsMetastoreConfigurationResponse") + } + return +} + +// getBdsMetastoreConfiguration implements the OCIOperation interface (enables retrying operations) +func (client BdsClient) getBdsMetastoreConfiguration(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { - httpRequest, err := request.HTTPRequest(http.MethodGet, "/bdsInstances/{bdsInstanceId}", binaryReqBody, extraHeaders) + httpRequest, err := request.HTTPRequest(http.MethodGet, "/bdsInstances/{bdsInstanceId}/metastoreConfigs/{metastoreConfigId}", binaryReqBody, extraHeaders) if err != nil { return nil, err } - var response GetBdsInstanceResponse + var response GetBdsMetastoreConfigurationResponse var httpResponse *http.Response httpResponse, err = client.Call(ctx, &httpRequest) defer common.CloseBodyIfValid(httpResponse) response.RawResponse = httpResponse if err != nil { - apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/bigdata/20190531/BdsInstance/GetBdsInstance" - err = common.PostProcessServiceError(err, "Bds", "GetBdsInstance", apiReferenceLink) + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/bigdata/20190531/BdsMetastoreConfiguration/GetBdsMetastoreConfiguration" + err = common.PostProcessServiceError(err, "Bds", "GetBdsMetastoreConfiguration", apiReferenceLink) return response, err } @@ -1911,12 +2335,12 @@ func (client BdsClient) getBdsInstance(ctx context.Context, request common.OCIRe return response, err } -// GetBdsMetastoreConfiguration Returns the BDS Metastore configuration information for the given ID. +// GetIdentityConfiguration Get details of one identity config on the cluster // // # See also // -// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/GetBdsMetastoreConfiguration.go.html to see an example of how to use GetBdsMetastoreConfiguration API. -func (client BdsClient) GetBdsMetastoreConfiguration(ctx context.Context, request GetBdsMetastoreConfigurationRequest) (response GetBdsMetastoreConfigurationResponse, err error) { +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/GetIdentityConfiguration.go.html to see an example of how to use GetIdentityConfiguration API. +func (client BdsClient) GetIdentityConfiguration(ctx context.Context, request GetIdentityConfigurationRequest) (response GetIdentityConfigurationResponse, err error) { var ociResponse common.OCIResponse policy := common.NoRetryPolicy() if client.RetryPolicy() != nil { @@ -1925,42 +2349,42 @@ func (client BdsClient) GetBdsMetastoreConfiguration(ctx context.Context, reques if request.RetryPolicy() != nil { policy = *request.RetryPolicy() } - ociResponse, err = common.Retry(ctx, request, client.getBdsMetastoreConfiguration, policy) + ociResponse, err = common.Retry(ctx, request, client.getIdentityConfiguration, policy) if err != nil { if ociResponse != nil { if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { opcRequestId := httpResponse.Header.Get("opc-request-id") - response = GetBdsMetastoreConfigurationResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + response = GetIdentityConfigurationResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} } else { - response = GetBdsMetastoreConfigurationResponse{} + response = GetIdentityConfigurationResponse{} } } return } - if convertedResponse, ok := ociResponse.(GetBdsMetastoreConfigurationResponse); ok { + if convertedResponse, ok := ociResponse.(GetIdentityConfigurationResponse); ok { response = convertedResponse } else { - err = fmt.Errorf("failed to convert OCIResponse into GetBdsMetastoreConfigurationResponse") + err = fmt.Errorf("failed to convert OCIResponse into GetIdentityConfigurationResponse") } return } -// getBdsMetastoreConfiguration implements the OCIOperation interface (enables retrying operations) -func (client BdsClient) getBdsMetastoreConfiguration(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { +// getIdentityConfiguration implements the OCIOperation interface (enables retrying operations) +func (client BdsClient) getIdentityConfiguration(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { - httpRequest, err := request.HTTPRequest(http.MethodGet, "/bdsInstances/{bdsInstanceId}/metastoreConfigs/{metastoreConfigId}", binaryReqBody, extraHeaders) + httpRequest, err := request.HTTPRequest(http.MethodGet, "/bdsInstances/{bdsInstanceId}/identityConfigurations/{identityConfigurationId}", binaryReqBody, extraHeaders) if err != nil { return nil, err } - var response GetBdsMetastoreConfigurationResponse + var response GetIdentityConfigurationResponse var httpResponse *http.Response httpResponse, err = client.Call(ctx, &httpRequest) defer common.CloseBodyIfValid(httpResponse) response.RawResponse = httpResponse if err != nil { - apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/bigdata/20190531/BdsMetastoreConfiguration/GetBdsMetastoreConfiguration" - err = common.PostProcessServiceError(err, "Bds", "GetBdsMetastoreConfiguration", apiReferenceLink) + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/bigdata/20190531/IdentityConfiguration/GetIdentityConfiguration" + err = common.PostProcessServiceError(err, "Bds", "GetIdentityConfiguration", apiReferenceLink) return response, err } @@ -2553,6 +2977,63 @@ func (client BdsClient) listBdsApiKeys(ctx context.Context, request common.OCIRe return response, err } +// ListBdsClusterVersions Returns a list of cluster versions with associated odh and bds versions. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/ListBdsClusterVersions.go.html to see an example of how to use ListBdsClusterVersions API. +func (client BdsClient) ListBdsClusterVersions(ctx context.Context, request ListBdsClusterVersionsRequest) (response ListBdsClusterVersionsResponse, err error) { + var ociResponse common.OCIResponse + policy := common.NoRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + ociResponse, err = common.Retry(ctx, request, client.listBdsClusterVersions, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = ListBdsClusterVersionsResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = ListBdsClusterVersionsResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(ListBdsClusterVersionsResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into ListBdsClusterVersionsResponse") + } + return +} + +// listBdsClusterVersions implements the OCIOperation interface (enables retrying operations) +func (client BdsClient) listBdsClusterVersions(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodGet, "/bdsClusterVersions", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response ListBdsClusterVersionsResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/bigdata/20190531/BdsClusterVersionSummary/ListBdsClusterVersions" + err = common.PostProcessServiceError(err, "Bds", "ListBdsClusterVersions", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + // ListBdsInstances Returns a list of all Big Data Service clusters in a compartment. // // # See also @@ -2667,6 +3148,63 @@ func (client BdsClient) listBdsMetastoreConfigurations(ctx context.Context, requ return response, err } +// ListIdentityConfigurations Returns a list of all identity configurations associated with this Big Data Service cluster. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/ListIdentityConfigurations.go.html to see an example of how to use ListIdentityConfigurations API. +func (client BdsClient) ListIdentityConfigurations(ctx context.Context, request ListIdentityConfigurationsRequest) (response ListIdentityConfigurationsResponse, err error) { + var ociResponse common.OCIResponse + policy := common.NoRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + ociResponse, err = common.Retry(ctx, request, client.listIdentityConfigurations, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = ListIdentityConfigurationsResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = ListIdentityConfigurationsResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(ListIdentityConfigurationsResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into ListIdentityConfigurationsResponse") + } + return +} + +// listIdentityConfigurations implements the OCIOperation interface (enables retrying operations) +func (client BdsClient) listIdentityConfigurations(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodGet, "/bdsInstances/{bdsInstanceId}/identityConfigurations", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response ListIdentityConfigurationsResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/bigdata/20190531/IdentityConfiguration/ListIdentityConfigurations" + err = common.PostProcessServiceError(err, "Bds", "ListIdentityConfigurations", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + // ListNodeBackupConfigurations Returns information about the NodeBackupConfigurations. // // # See also @@ -3242,6 +3780,130 @@ func (client BdsClient) listWorkRequests(ctx context.Context, request common.OCI return response, err } +// RefreshConfidentialApplication Refresh confidential application for the given identity configuration in case of any update to the confidential application (e.g. regenerated client secret) +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/RefreshConfidentialApplication.go.html to see an example of how to use RefreshConfidentialApplication API. +func (client BdsClient) RefreshConfidentialApplication(ctx context.Context, request RefreshConfidentialApplicationRequest) (response RefreshConfidentialApplicationResponse, err error) { + var ociResponse common.OCIResponse + policy := common.NoRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + + if !(request.OpcRetryToken != nil && *request.OpcRetryToken != "") { + request.OpcRetryToken = common.String(common.RetryToken()) + } + + ociResponse, err = common.Retry(ctx, request, client.refreshConfidentialApplication, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = RefreshConfidentialApplicationResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = RefreshConfidentialApplicationResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(RefreshConfidentialApplicationResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into RefreshConfidentialApplicationResponse") + } + return +} + +// refreshConfidentialApplication implements the OCIOperation interface (enables retrying operations) +func (client BdsClient) refreshConfidentialApplication(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodPost, "/bdsInstances/{bdsInstanceId}/identityConfigurations/{identityConfigurationId}/actions/refreshConfidentialApplication", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response RefreshConfidentialApplicationResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/bigdata/20190531/IdentityConfiguration/RefreshConfidentialApplication" + err = common.PostProcessServiceError(err, "Bds", "RefreshConfidentialApplication", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + +// RefreshUpstTokenExchangeKeytab Refresh token exchange kerberos principal keytab for the UPST enabled identity configuration +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/RefreshUpstTokenExchangeKeytab.go.html to see an example of how to use RefreshUpstTokenExchangeKeytab API. +func (client BdsClient) RefreshUpstTokenExchangeKeytab(ctx context.Context, request RefreshUpstTokenExchangeKeytabRequest) (response RefreshUpstTokenExchangeKeytabResponse, err error) { + var ociResponse common.OCIResponse + policy := common.NoRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + + if !(request.OpcRetryToken != nil && *request.OpcRetryToken != "") { + request.OpcRetryToken = common.String(common.RetryToken()) + } + + ociResponse, err = common.Retry(ctx, request, client.refreshUpstTokenExchangeKeytab, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = RefreshUpstTokenExchangeKeytabResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = RefreshUpstTokenExchangeKeytabResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(RefreshUpstTokenExchangeKeytabResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into RefreshUpstTokenExchangeKeytabResponse") + } + return +} + +// refreshUpstTokenExchangeKeytab implements the OCIOperation interface (enables retrying operations) +func (client BdsClient) refreshUpstTokenExchangeKeytab(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodPost, "/bdsInstances/{bdsInstanceId}/identityConfigurations/{identityConfigurationId}/actions/refreshUpstTokenExchangeKeytab", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response RefreshUpstTokenExchangeKeytabResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/bigdata/20190531/IdentityConfiguration/RefreshUpstTokenExchangeKeytab" + err = common.PostProcessServiceError(err, "Bds", "RefreshUpstTokenExchangeKeytab", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + // RemoveAutoScalingConfiguration Deletes an autoscale configuration. // // # See also @@ -4194,6 +4856,68 @@ func (client BdsClient) updateBdsMetastoreConfiguration(ctx context.Context, req return response, err } +// UpdateIdentityConfiguration Update the IAM user sync and UPST configuration for the specified identity configuration +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/UpdateIdentityConfiguration.go.html to see an example of how to use UpdateIdentityConfiguration API. +func (client BdsClient) UpdateIdentityConfiguration(ctx context.Context, request UpdateIdentityConfigurationRequest) (response UpdateIdentityConfigurationResponse, err error) { + var ociResponse common.OCIResponse + policy := common.NoRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + + if !(request.OpcRetryToken != nil && *request.OpcRetryToken != "") { + request.OpcRetryToken = common.String(common.RetryToken()) + } + + ociResponse, err = common.Retry(ctx, request, client.updateIdentityConfiguration, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = UpdateIdentityConfigurationResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = UpdateIdentityConfigurationResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(UpdateIdentityConfigurationResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into UpdateIdentityConfigurationResponse") + } + return +} + +// updateIdentityConfiguration implements the OCIOperation interface (enables retrying operations) +func (client BdsClient) updateIdentityConfiguration(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodPut, "/bdsInstances/{bdsInstanceId}/identityConfigurations/{identityConfigurationId}", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response UpdateIdentityConfigurationResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/bigdata/20190531/IdentityConfiguration/UpdateIdentityConfiguration" + err = common.PostProcessServiceError(err, "Bds", "UpdateIdentityConfiguration", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + // UpdateNodeBackupConfiguration Updates fields on NodeBackupConfiguration, including the name, the schedule. // // # See also diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/bds_cluster_version_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/bds_cluster_version_summary.go new file mode 100644 index 00000000000..5cd1d111e9f --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/bds_cluster_version_summary.go @@ -0,0 +1,42 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Big Data Service API +// +// REST API for Oracle Big Data Service. Use this API to build, deploy, and manage fully elastic Big Data Service clusters. Build on Hadoop, Spark and Data Science distributions, which can be fully integrated with existing enterprise data in Oracle Database and Oracle applications. +// + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// BdsClusterVersionSummary Cluster version details including bds and odh version information. +type BdsClusterVersionSummary struct { + + // BDS version to be used for cluster creation + BdsVersion *string `mandatory:"true" json:"bdsVersion"` + + // ODH version to be used for cluster creation + OdhVersion *string `mandatory:"false" json:"odhVersion"` +} + +func (m BdsClusterVersionSummary) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m BdsClusterVersionSummary) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/bds_instance.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/bds_instance.go index 572b2c8a4c2..09276ee6367 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/bds/bds_instance.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/bds_instance.go @@ -85,6 +85,8 @@ type BdsInstance struct { // Profile of the Big Data Service cluster. ClusterProfile BdsInstanceClusterProfileEnum `mandatory:"false" json:"clusterProfile,omitempty"` + + BdsClusterVersionSummary *BdsClusterVersionSummary `mandatory:"false" json:"bdsClusterVersionSummary"` } func (m BdsInstance) String() string { diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/create_bds_api_key_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/create_bds_api_key_details.go index 8d192dcddac..d6db1f9d848 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/bds/create_bds_api_key_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/create_bds_api_key_details.go @@ -31,6 +31,9 @@ type CreateBdsApiKeyDetails struct { // The name of the region to establish the Object Storage endpoint. See https://docs.oracle.com/en-us/iaas/api/#/en/identity/20160918/Region/ // for additional information. DefaultRegion *string `mandatory:"false" json:"defaultRegion"` + + // Identity domain OCID , where user is present. For default domain , this field will be optional. + DomainOcid *string `mandatory:"false" json:"domainOcid"` } func (m CreateBdsApiKeyDetails) String() string { diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/create_bds_instance_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/create_bds_instance_details.go index 9c509da1577..0bcb2d6ad88 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/bds/create_bds_instance_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/create_bds_instance_details.go @@ -63,6 +63,8 @@ type CreateBdsInstanceDetails struct { // Profile of the Big Data Service cluster. ClusterProfile BdsInstanceClusterProfileEnum `mandatory:"false" json:"clusterProfile,omitempty"` + + BdsClusterVersionSummary *BdsClusterVersionSummary `mandatory:"false" json:"bdsClusterVersionSummary"` } func (m CreateBdsInstanceDetails) String() string { diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/create_identity_configuration_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/create_identity_configuration_details.go new file mode 100644 index 00000000000..06d1ddc65c4 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/create_identity_configuration_details.go @@ -0,0 +1,52 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Big Data Service API +// +// REST API for Oracle Big Data Service. Use this API to build, deploy, and manage fully elastic Big Data Service clusters. Build on Hadoop, Spark and Data Science distributions, which can be fully integrated with existing enterprise data in Oracle Database and Oracle applications. +// + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// CreateIdentityConfigurationDetails Details for creating the identity configuration. +type CreateIdentityConfigurationDetails struct { + + // Base-64 encoded password for the cluster admin user. + ClusterAdminPassword *string `mandatory:"true" json:"clusterAdminPassword"` + + // Display name of the identity configuration, required for creating identity configuration. + DisplayName *string `mandatory:"true" json:"displayName"` + + // Identity domain OCID to use for identity config, required for creating identity configuration + IdentityDomainId *string `mandatory:"true" json:"identityDomainId"` + + // Identity domain confidential application ID for the identity config, required for creating identity configuration + ConfidentialApplicationId *string `mandatory:"true" json:"confidentialApplicationId"` + + UpstConfigurationDetails *UpstConfigurationDetails `mandatory:"false" json:"upstConfigurationDetails"` + + IamUserSyncConfigurationDetails *IamUserSyncConfigurationDetails `mandatory:"false" json:"iamUserSyncConfigurationDetails"` +} + +func (m CreateIdentityConfigurationDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m CreateIdentityConfigurationDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/create_identity_configuration_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/create_identity_configuration_request_response.go new file mode 100644 index 00000000000..6ef71823366 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/create_identity_configuration_request_response.go @@ -0,0 +1,100 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// CreateIdentityConfigurationRequest wrapper for the CreateIdentityConfiguration operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/CreateIdentityConfiguration.go.html to see an example of how to use CreateIdentityConfigurationRequest. +type CreateIdentityConfigurationRequest struct { + + // The OCID of the cluster. + BdsInstanceId *string `mandatory:"true" contributesTo:"path" name:"bdsInstanceId"` + + // Details for creating an identity configuration + CreateIdentityConfigurationDetails `contributesTo:"body"` + + // A token that uniquely identifies a request so it can be retried in case of a timeout or + // server error, without risk of executing that same action again. Retry tokens expire after 24 + // hours but can be invalidated before then due to conflicting operations. For example, if a resource + // has been deleted and purged from the system, then a retry of the original creation request + // might be rejected. + OpcRetryToken *string `mandatory:"false" contributesTo:"header" name:"opc-retry-token"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request CreateIdentityConfigurationRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request CreateIdentityConfigurationRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request CreateIdentityConfigurationRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request CreateIdentityConfigurationRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request CreateIdentityConfigurationRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// CreateIdentityConfigurationResponse wrapper for the CreateIdentityConfiguration operation +type CreateIdentityConfigurationResponse struct { + + // The underlying http response + RawResponse *http.Response + + // Unique Oracle-assigned identifier for the request. If you need to contact + // Oracle about a request, provide this request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // Unique Oracle-assigned identifier for the asynchronous request. You can use this to query status of the asynchronous operation. + OpcWorkRequestId *string `presentIn:"header" name:"opc-work-request-id"` +} + +func (response CreateIdentityConfigurationResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response CreateIdentityConfigurationResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/deactivate_iam_user_sync_configuration_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/deactivate_iam_user_sync_configuration_details.go new file mode 100644 index 00000000000..845bc49d6e0 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/deactivate_iam_user_sync_configuration_details.go @@ -0,0 +1,39 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Big Data Service API +// +// REST API for Oracle Big Data Service. Use this API to build, deploy, and manage fully elastic Big Data Service clusters. Build on Hadoop, Spark and Data Science distributions, which can be fully integrated with existing enterprise data in Oracle Database and Oracle applications. +// + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// DeactivateIamUserSyncConfigurationDetails Details for deactivating an IAM user sync configuration +type DeactivateIamUserSyncConfigurationDetails struct { + + // Base-64 encoded password for the cluster admin user. + ClusterAdminPassword *string `mandatory:"true" json:"clusterAdminPassword"` +} + +func (m DeactivateIamUserSyncConfigurationDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m DeactivateIamUserSyncConfigurationDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/deactivate_iam_user_sync_configuration_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/deactivate_iam_user_sync_configuration_request_response.go new file mode 100644 index 00000000000..71d8ff75434 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/deactivate_iam_user_sync_configuration_request_response.go @@ -0,0 +1,110 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// DeactivateIamUserSyncConfigurationRequest wrapper for the DeactivateIamUserSyncConfiguration operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/DeactivateIamUserSyncConfiguration.go.html to see an example of how to use DeactivateIamUserSyncConfigurationRequest. +type DeactivateIamUserSyncConfigurationRequest struct { + + // The OCID of the cluster. + BdsInstanceId *string `mandatory:"true" contributesTo:"path" name:"bdsInstanceId"` + + // The OCID of the identity configuration + IdentityConfigurationId *string `mandatory:"true" contributesTo:"path" name:"identityConfigurationId"` + + // Details for deactivating the IAM user sync config + DeactivateIamUserSyncConfigurationDetails `contributesTo:"body"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // 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. + IfMatch *string `mandatory:"false" contributesTo:"header" name:"if-match"` + + // A token that uniquely identifies a request so it can be retried in case of a timeout or + // server error, without risk of executing that same action again. Retry tokens expire after 24 + // hours but can be invalidated before then due to conflicting operations. For example, if a resource + // has been deleted and purged from the system, then a retry of the original creation request + // might be rejected. + OpcRetryToken *string `mandatory:"false" contributesTo:"header" name:"opc-retry-token"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request DeactivateIamUserSyncConfigurationRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request DeactivateIamUserSyncConfigurationRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request DeactivateIamUserSyncConfigurationRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request DeactivateIamUserSyncConfigurationRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request DeactivateIamUserSyncConfigurationRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// DeactivateIamUserSyncConfigurationResponse wrapper for the DeactivateIamUserSyncConfiguration operation +type DeactivateIamUserSyncConfigurationResponse struct { + + // The underlying http response + RawResponse *http.Response + + // Unique Oracle-assigned identifier for the request. If you need to contact + // Oracle about a request, provide this request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // Unique Oracle-assigned identifier for the asynchronous request. You can use this to query status of the asynchronous operation. + OpcWorkRequestId *string `presentIn:"header" name:"opc-work-request-id"` +} + +func (response DeactivateIamUserSyncConfigurationResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response DeactivateIamUserSyncConfigurationResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/deactivate_upst_configuration_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/deactivate_upst_configuration_details.go new file mode 100644 index 00000000000..5daf66643bc --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/deactivate_upst_configuration_details.go @@ -0,0 +1,39 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Big Data Service API +// +// REST API for Oracle Big Data Service. Use this API to build, deploy, and manage fully elastic Big Data Service clusters. Build on Hadoop, Spark and Data Science distributions, which can be fully integrated with existing enterprise data in Oracle Database and Oracle applications. +// + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// DeactivateUpstConfigurationDetails Details for deleting UPST config from cluster +type DeactivateUpstConfigurationDetails struct { + + // Base-64 encoded password for the cluster admin user. + ClusterAdminPassword *string `mandatory:"true" json:"clusterAdminPassword"` +} + +func (m DeactivateUpstConfigurationDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m DeactivateUpstConfigurationDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/deactivate_upst_configuration_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/deactivate_upst_configuration_request_response.go new file mode 100644 index 00000000000..22fe33fbd5d --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/deactivate_upst_configuration_request_response.go @@ -0,0 +1,110 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// DeactivateUpstConfigurationRequest wrapper for the DeactivateUpstConfiguration operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/DeactivateUpstConfiguration.go.html to see an example of how to use DeactivateUpstConfigurationRequest. +type DeactivateUpstConfigurationRequest struct { + + // The OCID of the cluster. + BdsInstanceId *string `mandatory:"true" contributesTo:"path" name:"bdsInstanceId"` + + // The OCID of the identity configuration + IdentityConfigurationId *string `mandatory:"true" contributesTo:"path" name:"identityConfigurationId"` + + // Details for deactivating the UPST config + DeactivateUpstConfigurationDetails `contributesTo:"body"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // A token that uniquely identifies a request so it can be retried in case of a timeout or + // server error, without risk of executing that same action again. Retry tokens expire after 24 + // hours but can be invalidated before then due to conflicting operations. For example, if a resource + // has been deleted and purged from the system, then a retry of the original creation request + // might be rejected. + OpcRetryToken *string `mandatory:"false" contributesTo:"header" name:"opc-retry-token"` + + // 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. + IfMatch *string `mandatory:"false" contributesTo:"header" name:"if-match"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request DeactivateUpstConfigurationRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request DeactivateUpstConfigurationRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request DeactivateUpstConfigurationRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request DeactivateUpstConfigurationRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request DeactivateUpstConfigurationRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// DeactivateUpstConfigurationResponse wrapper for the DeactivateUpstConfiguration operation +type DeactivateUpstConfigurationResponse struct { + + // The underlying http response + RawResponse *http.Response + + // Unique Oracle-assigned identifier for the request. If you need to contact + // Oracle about a request, provide this request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // Unique Oracle-assigned identifier for the asynchronous request. You can use this to query status of the asynchronous operation. + OpcWorkRequestId *string `presentIn:"header" name:"opc-work-request-id"` +} + +func (response DeactivateUpstConfigurationResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response DeactivateUpstConfigurationResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/delete_identity_configuration_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/delete_identity_configuration_request_response.go new file mode 100644 index 00000000000..cf7d43fecf9 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/delete_identity_configuration_request_response.go @@ -0,0 +1,100 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// DeleteIdentityConfigurationRequest wrapper for the DeleteIdentityConfiguration operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/DeleteIdentityConfiguration.go.html to see an example of how to use DeleteIdentityConfigurationRequest. +type DeleteIdentityConfigurationRequest struct { + + // The OCID of the cluster. + BdsInstanceId *string `mandatory:"true" contributesTo:"path" name:"bdsInstanceId"` + + // The OCID of the identity configuration + IdentityConfigurationId *string `mandatory:"true" contributesTo:"path" name:"identityConfigurationId"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // 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. + IfMatch *string `mandatory:"false" contributesTo:"header" name:"if-match"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request DeleteIdentityConfigurationRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request DeleteIdentityConfigurationRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request DeleteIdentityConfigurationRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request DeleteIdentityConfigurationRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request DeleteIdentityConfigurationRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// DeleteIdentityConfigurationResponse wrapper for the DeleteIdentityConfiguration operation +type DeleteIdentityConfigurationResponse struct { + + // The underlying http response + RawResponse *http.Response + + // Unique Oracle-assigned identifier for the request. If you need to contact + // Oracle about a request, provide this request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // Unique Oracle-assigned identifier for the asynchronous request. You can use this to query status of the asynchronous operation. + OpcWorkRequestId *string `presentIn:"header" name:"opc-work-request-id"` +} + +func (response DeleteIdentityConfigurationResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response DeleteIdentityConfigurationResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/domain_based_odh_patching_config.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/domain_based_odh_patching_config.go index bf9e25eb44d..0afe5094887 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/bds/domain_based_odh_patching_config.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/domain_based_odh_patching_config.go @@ -21,6 +21,9 @@ type DomainBasedOdhPatchingConfig struct { // The wait time between AD/FD in seconds. WaitTimeBetweenDomainInSeconds *int `mandatory:"true" json:"waitTimeBetweenDomainInSeconds"` + + // Acceptable number of failed-to-be-patched nodes in each domain. The maximum number of failed-to-patch nodes cannot exceed 20% of the number of non-utility and non-master nodes. + ToleranceThresholdPerDomain *int `mandatory:"false" json:"toleranceThresholdPerDomain"` } func (m DomainBasedOdhPatchingConfig) String() string { diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/get_identity_configuration_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/get_identity_configuration_request_response.go new file mode 100644 index 00000000000..1fa9ed1ddf7 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/get_identity_configuration_request_response.go @@ -0,0 +1,198 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// GetIdentityConfigurationRequest wrapper for the GetIdentityConfiguration operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/GetIdentityConfiguration.go.html to see an example of how to use GetIdentityConfigurationRequest. +type GetIdentityConfigurationRequest struct { + + // The OCID of the cluster. + BdsInstanceId *string `mandatory:"true" contributesTo:"path" name:"bdsInstanceId"` + + // The OCID of the identity configuration + IdentityConfigurationId *string `mandatory:"true" contributesTo:"path" name:"identityConfigurationId"` + + // The page token representing the page at which to start retrieving results. This is usually retrieved from a previous list call. + Page *string `mandatory:"false" contributesTo:"query" name:"page"` + + // The maximum number of items to return. + Limit *int `mandatory:"false" contributesTo:"query" name:"limit"` + + // 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. + SortBy GetIdentityConfigurationSortByEnum `mandatory:"false" contributesTo:"query" name:"sortBy" omitEmpty:"true"` + + // The sort order to use, either 'asc' or 'desc'. + SortOrder GetIdentityConfigurationSortOrderEnum `mandatory:"false" contributesTo:"query" name:"sortOrder" omitEmpty:"true"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request GetIdentityConfigurationRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request GetIdentityConfigurationRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request GetIdentityConfigurationRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request GetIdentityConfigurationRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request GetIdentityConfigurationRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingGetIdentityConfigurationSortByEnum(string(request.SortBy)); !ok && request.SortBy != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for SortBy: %s. Supported values are: %s.", request.SortBy, strings.Join(GetGetIdentityConfigurationSortByEnumStringValues(), ","))) + } + if _, ok := GetMappingGetIdentityConfigurationSortOrderEnum(string(request.SortOrder)); !ok && request.SortOrder != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for SortOrder: %s. Supported values are: %s.", request.SortOrder, strings.Join(GetGetIdentityConfigurationSortOrderEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// GetIdentityConfigurationResponse wrapper for the GetIdentityConfiguration operation +type GetIdentityConfigurationResponse struct { + + // The underlying http response + RawResponse *http.Response + + // A list of IdentityConfiguration instances + IdentityConfiguration `presentIn:"body"` + + // Unique Oracle-assigned identifier for the request. If you need to contact + // Oracle about a request, provide this request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // For optimistic concurrency control. See `if-match`. + Etag *string `presentIn:"header" name:"etag"` +} + +func (response GetIdentityConfigurationResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response GetIdentityConfigurationResponse) HTTPResponse() *http.Response { + return response.RawResponse +} + +// GetIdentityConfigurationSortByEnum Enum with underlying type: string +type GetIdentityConfigurationSortByEnum string + +// Set of constants representing the allowable values for GetIdentityConfigurationSortByEnum +const ( + GetIdentityConfigurationSortByTimecreated GetIdentityConfigurationSortByEnum = "timeCreated" + GetIdentityConfigurationSortByDisplayname GetIdentityConfigurationSortByEnum = "displayName" +) + +var mappingGetIdentityConfigurationSortByEnum = map[string]GetIdentityConfigurationSortByEnum{ + "timeCreated": GetIdentityConfigurationSortByTimecreated, + "displayName": GetIdentityConfigurationSortByDisplayname, +} + +var mappingGetIdentityConfigurationSortByEnumLowerCase = map[string]GetIdentityConfigurationSortByEnum{ + "timecreated": GetIdentityConfigurationSortByTimecreated, + "displayname": GetIdentityConfigurationSortByDisplayname, +} + +// GetGetIdentityConfigurationSortByEnumValues Enumerates the set of values for GetIdentityConfigurationSortByEnum +func GetGetIdentityConfigurationSortByEnumValues() []GetIdentityConfigurationSortByEnum { + values := make([]GetIdentityConfigurationSortByEnum, 0) + for _, v := range mappingGetIdentityConfigurationSortByEnum { + values = append(values, v) + } + return values +} + +// GetGetIdentityConfigurationSortByEnumStringValues Enumerates the set of values in String for GetIdentityConfigurationSortByEnum +func GetGetIdentityConfigurationSortByEnumStringValues() []string { + return []string{ + "timeCreated", + "displayName", + } +} + +// GetMappingGetIdentityConfigurationSortByEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingGetIdentityConfigurationSortByEnum(val string) (GetIdentityConfigurationSortByEnum, bool) { + enum, ok := mappingGetIdentityConfigurationSortByEnumLowerCase[strings.ToLower(val)] + return enum, ok +} + +// GetIdentityConfigurationSortOrderEnum Enum with underlying type: string +type GetIdentityConfigurationSortOrderEnum string + +// Set of constants representing the allowable values for GetIdentityConfigurationSortOrderEnum +const ( + GetIdentityConfigurationSortOrderAsc GetIdentityConfigurationSortOrderEnum = "ASC" + GetIdentityConfigurationSortOrderDesc GetIdentityConfigurationSortOrderEnum = "DESC" +) + +var mappingGetIdentityConfigurationSortOrderEnum = map[string]GetIdentityConfigurationSortOrderEnum{ + "ASC": GetIdentityConfigurationSortOrderAsc, + "DESC": GetIdentityConfigurationSortOrderDesc, +} + +var mappingGetIdentityConfigurationSortOrderEnumLowerCase = map[string]GetIdentityConfigurationSortOrderEnum{ + "asc": GetIdentityConfigurationSortOrderAsc, + "desc": GetIdentityConfigurationSortOrderDesc, +} + +// GetGetIdentityConfigurationSortOrderEnumValues Enumerates the set of values for GetIdentityConfigurationSortOrderEnum +func GetGetIdentityConfigurationSortOrderEnumValues() []GetIdentityConfigurationSortOrderEnum { + values := make([]GetIdentityConfigurationSortOrderEnum, 0) + for _, v := range mappingGetIdentityConfigurationSortOrderEnum { + values = append(values, v) + } + return values +} + +// GetGetIdentityConfigurationSortOrderEnumStringValues Enumerates the set of values in String for GetIdentityConfigurationSortOrderEnum +func GetGetIdentityConfigurationSortOrderEnumStringValues() []string { + return []string{ + "ASC", + "DESC", + } +} + +// GetMappingGetIdentityConfigurationSortOrderEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingGetIdentityConfigurationSortOrderEnum(val string) (GetIdentityConfigurationSortOrderEnum, bool) { + enum, ok := mappingGetIdentityConfigurationSortOrderEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/iam_user_sync_configuration.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/iam_user_sync_configuration.go new file mode 100644 index 00000000000..16d4b2d29db --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/iam_user_sync_configuration.go @@ -0,0 +1,109 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Big Data Service API +// +// REST API for Oracle Big Data Service. Use this API to build, deploy, and manage fully elastic Big Data Service clusters. Build on Hadoop, Spark and Data Science distributions, which can be fully integrated with existing enterprise data in Oracle Database and Oracle applications. +// + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// IamUserSyncConfiguration Information about the IAM user sync configuration. +type IamUserSyncConfiguration struct { + + // whether to append POSIX attributes to IAM users + IsPosixAttributesAdditionRequired *bool `mandatory:"true" json:"isPosixAttributesAdditionRequired"` + + // Lifecycle state of the IAM user sync config + LifecycleState IamUserSyncConfigurationLifecycleStateEnum `mandatory:"true" json:"lifecycleState"` + + // Time when this IAM user sync config was created, shown as an RFC 3339 formatted datetime string. + TimeCreated *common.SDKTime `mandatory:"true" json:"timeCreated"` + + // Time when this IAM user sync config was updated, shown as an RFC 3339 formatted datetime string. + TimeUpdated *common.SDKTime `mandatory:"true" json:"timeUpdated"` +} + +func (m IamUserSyncConfiguration) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m IamUserSyncConfiguration) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingIamUserSyncConfigurationLifecycleStateEnum(string(m.LifecycleState)); !ok && m.LifecycleState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", m.LifecycleState, strings.Join(GetIamUserSyncConfigurationLifecycleStateEnumStringValues(), ","))) + } + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// IamUserSyncConfigurationLifecycleStateEnum Enum with underlying type: string +type IamUserSyncConfigurationLifecycleStateEnum string + +// Set of constants representing the allowable values for IamUserSyncConfigurationLifecycleStateEnum +const ( + IamUserSyncConfigurationLifecycleStateCreating IamUserSyncConfigurationLifecycleStateEnum = "CREATING" + IamUserSyncConfigurationLifecycleStateActive IamUserSyncConfigurationLifecycleStateEnum = "ACTIVE" + IamUserSyncConfigurationLifecycleStateInactive IamUserSyncConfigurationLifecycleStateEnum = "INACTIVE" + IamUserSyncConfigurationLifecycleStateDeleting IamUserSyncConfigurationLifecycleStateEnum = "DELETING" + IamUserSyncConfigurationLifecycleStateUpdating IamUserSyncConfigurationLifecycleStateEnum = "UPDATING" + IamUserSyncConfigurationLifecycleStateFailed IamUserSyncConfigurationLifecycleStateEnum = "FAILED" +) + +var mappingIamUserSyncConfigurationLifecycleStateEnum = map[string]IamUserSyncConfigurationLifecycleStateEnum{ + "CREATING": IamUserSyncConfigurationLifecycleStateCreating, + "ACTIVE": IamUserSyncConfigurationLifecycleStateActive, + "INACTIVE": IamUserSyncConfigurationLifecycleStateInactive, + "DELETING": IamUserSyncConfigurationLifecycleStateDeleting, + "UPDATING": IamUserSyncConfigurationLifecycleStateUpdating, + "FAILED": IamUserSyncConfigurationLifecycleStateFailed, +} + +var mappingIamUserSyncConfigurationLifecycleStateEnumLowerCase = map[string]IamUserSyncConfigurationLifecycleStateEnum{ + "creating": IamUserSyncConfigurationLifecycleStateCreating, + "active": IamUserSyncConfigurationLifecycleStateActive, + "inactive": IamUserSyncConfigurationLifecycleStateInactive, + "deleting": IamUserSyncConfigurationLifecycleStateDeleting, + "updating": IamUserSyncConfigurationLifecycleStateUpdating, + "failed": IamUserSyncConfigurationLifecycleStateFailed, +} + +// GetIamUserSyncConfigurationLifecycleStateEnumValues Enumerates the set of values for IamUserSyncConfigurationLifecycleStateEnum +func GetIamUserSyncConfigurationLifecycleStateEnumValues() []IamUserSyncConfigurationLifecycleStateEnum { + values := make([]IamUserSyncConfigurationLifecycleStateEnum, 0) + for _, v := range mappingIamUserSyncConfigurationLifecycleStateEnum { + values = append(values, v) + } + return values +} + +// GetIamUserSyncConfigurationLifecycleStateEnumStringValues Enumerates the set of values in String for IamUserSyncConfigurationLifecycleStateEnum +func GetIamUserSyncConfigurationLifecycleStateEnumStringValues() []string { + return []string{ + "CREATING", + "ACTIVE", + "INACTIVE", + "DELETING", + "UPDATING", + "FAILED", + } +} + +// GetMappingIamUserSyncConfigurationLifecycleStateEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingIamUserSyncConfigurationLifecycleStateEnum(val string) (IamUserSyncConfigurationLifecycleStateEnum, bool) { + enum, ok := mappingIamUserSyncConfigurationLifecycleStateEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/iam_user_sync_configuration_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/iam_user_sync_configuration_details.go new file mode 100644 index 00000000000..240ada05f86 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/iam_user_sync_configuration_details.go @@ -0,0 +1,39 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Big Data Service API +// +// REST API for Oracle Big Data Service. Use this API to build, deploy, and manage fully elastic Big Data Service clusters. Build on Hadoop, Spark and Data Science distributions, which can be fully integrated with existing enterprise data in Oracle Database and Oracle applications. +// + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// IamUserSyncConfigurationDetails Details for activating/updating an IAM user sync configuration +type IamUserSyncConfigurationDetails struct { + + // whether posix attribute needs to be appended to users, required for updating IAM user sync configuration + IsPosixAttributesAdditionRequired *bool `mandatory:"false" json:"isPosixAttributesAdditionRequired"` +} + +func (m IamUserSyncConfigurationDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m IamUserSyncConfigurationDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/identity_configuration.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/identity_configuration.go new file mode 100644 index 00000000000..ffc00e99f74 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/identity_configuration.go @@ -0,0 +1,106 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Big Data Service API +// +// REST API for Oracle Big Data Service. Use this API to build, deploy, and manage fully elastic Big Data Service clusters. Build on Hadoop, Spark and Data Science distributions, which can be fully integrated with existing enterprise data in Oracle Database and Oracle applications. +// + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// IdentityConfiguration Details about the identity configuration +type IdentityConfiguration struct { + + // The id of the UPST config + Id *string `mandatory:"true" json:"id"` + + // the display name of the identity configuration + DisplayName *string `mandatory:"true" json:"displayName"` + + // Identity domain to use for identity config + IdentityDomainId *string `mandatory:"true" json:"identityDomainId"` + + // identity domain confidential application ID for the identity config + ConfidentialApplicationId *string `mandatory:"true" json:"confidentialApplicationId"` + + // Lifecycle state of the identity configuration + LifecycleState IdentityConfigurationLifecycleStateEnum `mandatory:"true" json:"lifecycleState"` + + // Time when this identity configuration was created, shown as an RFC 3339 formatted datetime string. + TimeCreated *common.SDKTime `mandatory:"true" json:"timeCreated"` + + // Time when this identity configuration config was updated, shown as an RFC 3339 formatted datetime string. + TimeUpdated *common.SDKTime `mandatory:"true" json:"timeUpdated"` + + IamUserSyncConfiguration *IamUserSyncConfiguration `mandatory:"false" json:"iamUserSyncConfiguration"` + + UpstConfiguration *UpstConfiguration `mandatory:"false" json:"upstConfiguration"` +} + +func (m IdentityConfiguration) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m IdentityConfiguration) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingIdentityConfigurationLifecycleStateEnum(string(m.LifecycleState)); !ok && m.LifecycleState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", m.LifecycleState, strings.Join(GetIdentityConfigurationLifecycleStateEnumStringValues(), ","))) + } + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// IdentityConfigurationLifecycleStateEnum Enum with underlying type: string +type IdentityConfigurationLifecycleStateEnum string + +// Set of constants representing the allowable values for IdentityConfigurationLifecycleStateEnum +const ( + IdentityConfigurationLifecycleStateActive IdentityConfigurationLifecycleStateEnum = "ACTIVE" + IdentityConfigurationLifecycleStateDeleted IdentityConfigurationLifecycleStateEnum = "DELETED" +) + +var mappingIdentityConfigurationLifecycleStateEnum = map[string]IdentityConfigurationLifecycleStateEnum{ + "ACTIVE": IdentityConfigurationLifecycleStateActive, + "DELETED": IdentityConfigurationLifecycleStateDeleted, +} + +var mappingIdentityConfigurationLifecycleStateEnumLowerCase = map[string]IdentityConfigurationLifecycleStateEnum{ + "active": IdentityConfigurationLifecycleStateActive, + "deleted": IdentityConfigurationLifecycleStateDeleted, +} + +// GetIdentityConfigurationLifecycleStateEnumValues Enumerates the set of values for IdentityConfigurationLifecycleStateEnum +func GetIdentityConfigurationLifecycleStateEnumValues() []IdentityConfigurationLifecycleStateEnum { + values := make([]IdentityConfigurationLifecycleStateEnum, 0) + for _, v := range mappingIdentityConfigurationLifecycleStateEnum { + values = append(values, v) + } + return values +} + +// GetIdentityConfigurationLifecycleStateEnumStringValues Enumerates the set of values in String for IdentityConfigurationLifecycleStateEnum +func GetIdentityConfigurationLifecycleStateEnumStringValues() []string { + return []string{ + "ACTIVE", + "DELETED", + } +} + +// GetMappingIdentityConfigurationLifecycleStateEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingIdentityConfigurationLifecycleStateEnum(val string) (IdentityConfigurationLifecycleStateEnum, bool) { + enum, ok := mappingIdentityConfigurationLifecycleStateEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/identity_configuration_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/identity_configuration_summary.go new file mode 100644 index 00000000000..a5e4a26ac45 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/identity_configuration_summary.go @@ -0,0 +1,48 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Big Data Service API +// +// REST API for Oracle Big Data Service. Use this API to build, deploy, and manage fully elastic Big Data Service clusters. Build on Hadoop, Spark and Data Science distributions, which can be fully integrated with existing enterprise data in Oracle Database and Oracle applications. +// + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// IdentityConfigurationSummary Summary of the identity config +type IdentityConfigurationSummary struct { + + // The id of the identity config + Id *string `mandatory:"true" json:"id"` + + // Display name of the identity config + DisplayName *string `mandatory:"true" json:"displayName"` + + // Lifecycle state of the identity config + LifecycleState IdentityConfigurationLifecycleStateEnum `mandatory:"true" json:"lifecycleState"` +} + +func (m IdentityConfigurationSummary) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m IdentityConfigurationSummary) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingIdentityConfigurationLifecycleStateEnum(string(m.LifecycleState)); !ok && m.LifecycleState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", m.LifecycleState, strings.Join(GetIdentityConfigurationLifecycleStateEnumStringValues(), ","))) + } + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/list_bds_cluster_versions_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/list_bds_cluster_versions_request_response.go new file mode 100644 index 00000000000..d18e42155ed --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/list_bds_cluster_versions_request_response.go @@ -0,0 +1,190 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// ListBdsClusterVersionsRequest wrapper for the ListBdsClusterVersions operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/ListBdsClusterVersions.go.html to see an example of how to use ListBdsClusterVersionsRequest. +type ListBdsClusterVersionsRequest struct { + + // The page token representing the page at which to start retrieving results. This is usually retrieved from a previous list call. + Page *string `mandatory:"false" contributesTo:"query" name:"page"` + + // The maximum number of items to return. + Limit *int `mandatory:"false" contributesTo:"query" name:"limit"` + + // The field to sort by. Only one sort order may be provided. If no value is specified bdsVersion is default. + SortBy ListBdsClusterVersionsSortByEnum `mandatory:"false" contributesTo:"query" name:"sortBy" omitEmpty:"true"` + + // The sort order to use, either 'asc' or 'desc'. + SortOrder ListBdsClusterVersionsSortOrderEnum `mandatory:"false" contributesTo:"query" name:"sortOrder" omitEmpty:"true"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request ListBdsClusterVersionsRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request ListBdsClusterVersionsRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request ListBdsClusterVersionsRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request ListBdsClusterVersionsRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request ListBdsClusterVersionsRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingListBdsClusterVersionsSortByEnum(string(request.SortBy)); !ok && request.SortBy != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for SortBy: %s. Supported values are: %s.", request.SortBy, strings.Join(GetListBdsClusterVersionsSortByEnumStringValues(), ","))) + } + if _, ok := GetMappingListBdsClusterVersionsSortOrderEnum(string(request.SortOrder)); !ok && request.SortOrder != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for SortOrder: %s. Supported values are: %s.", request.SortOrder, strings.Join(GetListBdsClusterVersionsSortOrderEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// ListBdsClusterVersionsResponse wrapper for the ListBdsClusterVersions operation +type ListBdsClusterVersionsResponse struct { + + // The underlying http response + RawResponse *http.Response + + // A list of []BdsClusterVersionSummary instances + Items []BdsClusterVersionSummary `presentIn:"body"` + + // Unique Oracle-assigned identifier for the request. If you need to contact + // Oracle about a request, provide this request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // For pagination of a list of items. When paging through a list, if this header appears in the response, + // then a partial list might have been returned. Include this value as the `page` parameter for the + // subsequent GET request to get the next batch of items. + OpcNextPage *string `presentIn:"header" name:"opc-next-page"` +} + +func (response ListBdsClusterVersionsResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response ListBdsClusterVersionsResponse) HTTPResponse() *http.Response { + return response.RawResponse +} + +// ListBdsClusterVersionsSortByEnum Enum with underlying type: string +type ListBdsClusterVersionsSortByEnum string + +// Set of constants representing the allowable values for ListBdsClusterVersionsSortByEnum +const ( + ListBdsClusterVersionsSortByBdsversion ListBdsClusterVersionsSortByEnum = "bdsVersion" +) + +var mappingListBdsClusterVersionsSortByEnum = map[string]ListBdsClusterVersionsSortByEnum{ + "bdsVersion": ListBdsClusterVersionsSortByBdsversion, +} + +var mappingListBdsClusterVersionsSortByEnumLowerCase = map[string]ListBdsClusterVersionsSortByEnum{ + "bdsversion": ListBdsClusterVersionsSortByBdsversion, +} + +// GetListBdsClusterVersionsSortByEnumValues Enumerates the set of values for ListBdsClusterVersionsSortByEnum +func GetListBdsClusterVersionsSortByEnumValues() []ListBdsClusterVersionsSortByEnum { + values := make([]ListBdsClusterVersionsSortByEnum, 0) + for _, v := range mappingListBdsClusterVersionsSortByEnum { + values = append(values, v) + } + return values +} + +// GetListBdsClusterVersionsSortByEnumStringValues Enumerates the set of values in String for ListBdsClusterVersionsSortByEnum +func GetListBdsClusterVersionsSortByEnumStringValues() []string { + return []string{ + "bdsVersion", + } +} + +// GetMappingListBdsClusterVersionsSortByEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListBdsClusterVersionsSortByEnum(val string) (ListBdsClusterVersionsSortByEnum, bool) { + enum, ok := mappingListBdsClusterVersionsSortByEnumLowerCase[strings.ToLower(val)] + return enum, ok +} + +// ListBdsClusterVersionsSortOrderEnum Enum with underlying type: string +type ListBdsClusterVersionsSortOrderEnum string + +// Set of constants representing the allowable values for ListBdsClusterVersionsSortOrderEnum +const ( + ListBdsClusterVersionsSortOrderAsc ListBdsClusterVersionsSortOrderEnum = "ASC" + ListBdsClusterVersionsSortOrderDesc ListBdsClusterVersionsSortOrderEnum = "DESC" +) + +var mappingListBdsClusterVersionsSortOrderEnum = map[string]ListBdsClusterVersionsSortOrderEnum{ + "ASC": ListBdsClusterVersionsSortOrderAsc, + "DESC": ListBdsClusterVersionsSortOrderDesc, +} + +var mappingListBdsClusterVersionsSortOrderEnumLowerCase = map[string]ListBdsClusterVersionsSortOrderEnum{ + "asc": ListBdsClusterVersionsSortOrderAsc, + "desc": ListBdsClusterVersionsSortOrderDesc, +} + +// GetListBdsClusterVersionsSortOrderEnumValues Enumerates the set of values for ListBdsClusterVersionsSortOrderEnum +func GetListBdsClusterVersionsSortOrderEnumValues() []ListBdsClusterVersionsSortOrderEnum { + values := make([]ListBdsClusterVersionsSortOrderEnum, 0) + for _, v := range mappingListBdsClusterVersionsSortOrderEnum { + values = append(values, v) + } + return values +} + +// GetListBdsClusterVersionsSortOrderEnumStringValues Enumerates the set of values in String for ListBdsClusterVersionsSortOrderEnum +func GetListBdsClusterVersionsSortOrderEnumStringValues() []string { + return []string{ + "ASC", + "DESC", + } +} + +// GetMappingListBdsClusterVersionsSortOrderEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListBdsClusterVersionsSortOrderEnum(val string) (ListBdsClusterVersionsSortOrderEnum, bool) { + enum, ok := mappingListBdsClusterVersionsSortOrderEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/list_identity_configurations_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/list_identity_configurations_request_response.go new file mode 100644 index 00000000000..d4626ddf7a6 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/list_identity_configurations_request_response.go @@ -0,0 +1,209 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// ListIdentityConfigurationsRequest wrapper for the ListIdentityConfigurations operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/ListIdentityConfigurations.go.html to see an example of how to use ListIdentityConfigurationsRequest. +type ListIdentityConfigurationsRequest struct { + + // The OCID of the cluster. + BdsInstanceId *string `mandatory:"true" contributesTo:"path" name:"bdsInstanceId"` + + // The OCID of the compartment. + CompartmentId *string `mandatory:"true" contributesTo:"query" name:"compartmentId"` + + // The page token representing the page at which to start retrieving results. This is usually retrieved from a previous list call. + Page *string `mandatory:"false" contributesTo:"query" name:"page"` + + // The maximum number of items to return. + Limit *int `mandatory:"false" contributesTo:"query" name:"limit"` + + // 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. + SortBy ListIdentityConfigurationsSortByEnum `mandatory:"false" contributesTo:"query" name:"sortBy" omitEmpty:"true"` + + // The sort order to use, either 'asc' or 'desc'. + SortOrder ListIdentityConfigurationsSortOrderEnum `mandatory:"false" contributesTo:"query" name:"sortOrder" omitEmpty:"true"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // The state of the identity config + LifecycleState IdentityConfigurationLifecycleStateEnum `mandatory:"false" contributesTo:"query" name:"lifecycleState" omitEmpty:"true"` + + // A filter to return only resources that match the entire display name given. + DisplayName *string `mandatory:"false" contributesTo:"query" name:"displayName"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request ListIdentityConfigurationsRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request ListIdentityConfigurationsRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request ListIdentityConfigurationsRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request ListIdentityConfigurationsRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request ListIdentityConfigurationsRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingListIdentityConfigurationsSortByEnum(string(request.SortBy)); !ok && request.SortBy != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for SortBy: %s. Supported values are: %s.", request.SortBy, strings.Join(GetListIdentityConfigurationsSortByEnumStringValues(), ","))) + } + if _, ok := GetMappingListIdentityConfigurationsSortOrderEnum(string(request.SortOrder)); !ok && request.SortOrder != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for SortOrder: %s. Supported values are: %s.", request.SortOrder, strings.Join(GetListIdentityConfigurationsSortOrderEnumStringValues(), ","))) + } + if _, ok := GetMappingIdentityConfigurationLifecycleStateEnum(string(request.LifecycleState)); !ok && request.LifecycleState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", request.LifecycleState, strings.Join(GetIdentityConfigurationLifecycleStateEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// ListIdentityConfigurationsResponse wrapper for the ListIdentityConfigurations operation +type ListIdentityConfigurationsResponse struct { + + // The underlying http response + RawResponse *http.Response + + // A list of []IdentityConfigurationSummary instances + Items []IdentityConfigurationSummary `presentIn:"body"` + + // Unique Oracle-assigned identifier for the request. If you need to contact + // Oracle about a request, provide this request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // For pagination of a list of items. When paging through a list, if this header appears in the response, + // then a partial list might have been returned. Include this value as the `page` parameter for the + // subsequent GET request to get the next batch of items. + OpcNextPage *string `presentIn:"header" name:"opc-next-page"` +} + +func (response ListIdentityConfigurationsResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response ListIdentityConfigurationsResponse) HTTPResponse() *http.Response { + return response.RawResponse +} + +// ListIdentityConfigurationsSortByEnum Enum with underlying type: string +type ListIdentityConfigurationsSortByEnum string + +// Set of constants representing the allowable values for ListIdentityConfigurationsSortByEnum +const ( + ListIdentityConfigurationsSortByTimecreated ListIdentityConfigurationsSortByEnum = "timeCreated" + ListIdentityConfigurationsSortByDisplayname ListIdentityConfigurationsSortByEnum = "displayName" +) + +var mappingListIdentityConfigurationsSortByEnum = map[string]ListIdentityConfigurationsSortByEnum{ + "timeCreated": ListIdentityConfigurationsSortByTimecreated, + "displayName": ListIdentityConfigurationsSortByDisplayname, +} + +var mappingListIdentityConfigurationsSortByEnumLowerCase = map[string]ListIdentityConfigurationsSortByEnum{ + "timecreated": ListIdentityConfigurationsSortByTimecreated, + "displayname": ListIdentityConfigurationsSortByDisplayname, +} + +// GetListIdentityConfigurationsSortByEnumValues Enumerates the set of values for ListIdentityConfigurationsSortByEnum +func GetListIdentityConfigurationsSortByEnumValues() []ListIdentityConfigurationsSortByEnum { + values := make([]ListIdentityConfigurationsSortByEnum, 0) + for _, v := range mappingListIdentityConfigurationsSortByEnum { + values = append(values, v) + } + return values +} + +// GetListIdentityConfigurationsSortByEnumStringValues Enumerates the set of values in String for ListIdentityConfigurationsSortByEnum +func GetListIdentityConfigurationsSortByEnumStringValues() []string { + return []string{ + "timeCreated", + "displayName", + } +} + +// GetMappingListIdentityConfigurationsSortByEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListIdentityConfigurationsSortByEnum(val string) (ListIdentityConfigurationsSortByEnum, bool) { + enum, ok := mappingListIdentityConfigurationsSortByEnumLowerCase[strings.ToLower(val)] + return enum, ok +} + +// ListIdentityConfigurationsSortOrderEnum Enum with underlying type: string +type ListIdentityConfigurationsSortOrderEnum string + +// Set of constants representing the allowable values for ListIdentityConfigurationsSortOrderEnum +const ( + ListIdentityConfigurationsSortOrderAsc ListIdentityConfigurationsSortOrderEnum = "ASC" + ListIdentityConfigurationsSortOrderDesc ListIdentityConfigurationsSortOrderEnum = "DESC" +) + +var mappingListIdentityConfigurationsSortOrderEnum = map[string]ListIdentityConfigurationsSortOrderEnum{ + "ASC": ListIdentityConfigurationsSortOrderAsc, + "DESC": ListIdentityConfigurationsSortOrderDesc, +} + +var mappingListIdentityConfigurationsSortOrderEnumLowerCase = map[string]ListIdentityConfigurationsSortOrderEnum{ + "asc": ListIdentityConfigurationsSortOrderAsc, + "desc": ListIdentityConfigurationsSortOrderDesc, +} + +// GetListIdentityConfigurationsSortOrderEnumValues Enumerates the set of values for ListIdentityConfigurationsSortOrderEnum +func GetListIdentityConfigurationsSortOrderEnumValues() []ListIdentityConfigurationsSortOrderEnum { + values := make([]ListIdentityConfigurationsSortOrderEnum, 0) + for _, v := range mappingListIdentityConfigurationsSortOrderEnum { + values = append(values, v) + } + return values +} + +// GetListIdentityConfigurationsSortOrderEnumStringValues Enumerates the set of values in String for ListIdentityConfigurationsSortOrderEnum +func GetListIdentityConfigurationsSortOrderEnumStringValues() []string { + return []string{ + "ASC", + "DESC", + } +} + +// GetMappingListIdentityConfigurationsSortOrderEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListIdentityConfigurationsSortOrderEnum(val string) (ListIdentityConfigurationsSortOrderEnum, bool) { + enum, ok := mappingListIdentityConfigurationsSortOrderEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/node_type_shape_config.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/node_type_shape_config.go new file mode 100644 index 00000000000..7ed40d0e169 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/node_type_shape_config.go @@ -0,0 +1,46 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Big Data Service API +// +// REST API for Oracle Big Data Service. Use this API to build, deploy, and manage fully elastic Big Data Service clusters. Build on Hadoop, Spark and Data Science distributions, which can be fully integrated with existing enterprise data in Oracle Database and Oracle applications. +// + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// NodeTypeShapeConfig Shape configuration at node type level. Start cluster will start all nodes as is if no config is specified. +type NodeTypeShapeConfig struct { + + // The Big Data Service cluster node type. + NodeType NodeNodeTypeEnum `mandatory:"true" json:"nodeType"` + + // Shape of the node. This has to be specified when starting the cluster. Defaults to wn0 for homogeneous clusters and remains empty for heterogeneous clusters. + // If provided, all nodes in the node type will adopt the specified shape; otherwise, nodes retain their original shapes. + Shape *string `mandatory:"true" json:"shape"` +} + +func (m NodeTypeShapeConfig) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m NodeTypeShapeConfig) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingNodeNodeTypeEnum(string(m.NodeType)); !ok && m.NodeType != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for NodeType: %s. Supported values are: %s.", m.NodeType, strings.Join(GetNodeNodeTypeEnumStringValues(), ","))) + } + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/operation_types.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/operation_types.go index c11a4ba8dc9..8b17f6ba4c4 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/bds/operation_types.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/operation_types.go @@ -67,6 +67,15 @@ const ( OperationTypesDeleteResourcePrincipalConfiguration OperationTypesEnum = "DELETE_RESOURCE_PRINCIPAL_CONFIGURATION" OperationTypesUpdateResourcePrincipalConfiguration OperationTypesEnum = "UPDATE_RESOURCE_PRINCIPAL_CONFIGURATION" OperationTypesRefreshResourcePrincipal OperationTypesEnum = "REFRESH_RESOURCE_PRINCIPAL" + OperationTypesCreateIdentityConfig OperationTypesEnum = "CREATE_IDENTITY_CONFIG" + OperationTypesDeleteIdentityConfig OperationTypesEnum = "DELETE_IDENTITY_CONFIG" + OperationTypesUpdateIdentityConfig OperationTypesEnum = "UPDATE_IDENTITY_CONFIG" + OperationTypesActivateUpstConfig OperationTypesEnum = "ACTIVATE_UPST_CONFIG" + OperationTypesDeactivateUpstConfig OperationTypesEnum = "DEACTIVATE_UPST_CONFIG" + OperationTypesRefreshConfidentialApplication OperationTypesEnum = "REFRESH_CONFIDENTIAL_APPLICATION" + OperationTypesRefreshTokenExchangeKeytab OperationTypesEnum = "REFRESH_TOKEN_EXCHANGE_KEYTAB" + OperationTypesActivateIamUserSyncConfig OperationTypesEnum = "ACTIVATE_IAM_USER_SYNC_CONFIG" + OperationTypesDeactivateIamUserSyncConfig OperationTypesEnum = "DEACTIVATE_IAM_USER_SYNC_CONFIG" ) var mappingOperationTypesEnum = map[string]OperationTypesEnum{ @@ -119,6 +128,15 @@ var mappingOperationTypesEnum = map[string]OperationTypesEnum{ "DELETE_RESOURCE_PRINCIPAL_CONFIGURATION": OperationTypesDeleteResourcePrincipalConfiguration, "UPDATE_RESOURCE_PRINCIPAL_CONFIGURATION": OperationTypesUpdateResourcePrincipalConfiguration, "REFRESH_RESOURCE_PRINCIPAL": OperationTypesRefreshResourcePrincipal, + "CREATE_IDENTITY_CONFIG": OperationTypesCreateIdentityConfig, + "DELETE_IDENTITY_CONFIG": OperationTypesDeleteIdentityConfig, + "UPDATE_IDENTITY_CONFIG": OperationTypesUpdateIdentityConfig, + "ACTIVATE_UPST_CONFIG": OperationTypesActivateUpstConfig, + "DEACTIVATE_UPST_CONFIG": OperationTypesDeactivateUpstConfig, + "REFRESH_CONFIDENTIAL_APPLICATION": OperationTypesRefreshConfidentialApplication, + "REFRESH_TOKEN_EXCHANGE_KEYTAB": OperationTypesRefreshTokenExchangeKeytab, + "ACTIVATE_IAM_USER_SYNC_CONFIG": OperationTypesActivateIamUserSyncConfig, + "DEACTIVATE_IAM_USER_SYNC_CONFIG": OperationTypesDeactivateIamUserSyncConfig, } var mappingOperationTypesEnumLowerCase = map[string]OperationTypesEnum{ @@ -171,6 +189,15 @@ var mappingOperationTypesEnumLowerCase = map[string]OperationTypesEnum{ "delete_resource_principal_configuration": OperationTypesDeleteResourcePrincipalConfiguration, "update_resource_principal_configuration": OperationTypesUpdateResourcePrincipalConfiguration, "refresh_resource_principal": OperationTypesRefreshResourcePrincipal, + "create_identity_config": OperationTypesCreateIdentityConfig, + "delete_identity_config": OperationTypesDeleteIdentityConfig, + "update_identity_config": OperationTypesUpdateIdentityConfig, + "activate_upst_config": OperationTypesActivateUpstConfig, + "deactivate_upst_config": OperationTypesDeactivateUpstConfig, + "refresh_confidential_application": OperationTypesRefreshConfidentialApplication, + "refresh_token_exchange_keytab": OperationTypesRefreshTokenExchangeKeytab, + "activate_iam_user_sync_config": OperationTypesActivateIamUserSyncConfig, + "deactivate_iam_user_sync_config": OperationTypesDeactivateIamUserSyncConfig, } // GetOperationTypesEnumValues Enumerates the set of values for OperationTypesEnum @@ -234,6 +261,15 @@ func GetOperationTypesEnumStringValues() []string { "DELETE_RESOURCE_PRINCIPAL_CONFIGURATION", "UPDATE_RESOURCE_PRINCIPAL_CONFIGURATION", "REFRESH_RESOURCE_PRINCIPAL", + "CREATE_IDENTITY_CONFIG", + "DELETE_IDENTITY_CONFIG", + "UPDATE_IDENTITY_CONFIG", + "ACTIVATE_UPST_CONFIG", + "DEACTIVATE_UPST_CONFIG", + "REFRESH_CONFIDENTIAL_APPLICATION", + "REFRESH_TOKEN_EXCHANGE_KEYTAB", + "ACTIVATE_IAM_USER_SYNC_CONFIG", + "DEACTIVATE_IAM_USER_SYNC_CONFIG", } } diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/refresh_confidential_application_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/refresh_confidential_application_details.go new file mode 100644 index 00000000000..bdbe870eddf --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/refresh_confidential_application_details.go @@ -0,0 +1,39 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Big Data Service API +// +// REST API for Oracle Big Data Service. Use this API to build, deploy, and manage fully elastic Big Data Service clusters. Build on Hadoop, Spark and Data Science distributions, which can be fully integrated with existing enterprise data in Oracle Database and Oracle applications. +// + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// RefreshConfidentialApplicationDetails Details for refreshing confidential application +type RefreshConfidentialApplicationDetails struct { + + // Base-64 encoded password for the cluster admin user. + ClusterAdminPassword *string `mandatory:"true" json:"clusterAdminPassword"` +} + +func (m RefreshConfidentialApplicationDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m RefreshConfidentialApplicationDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/refresh_confidential_application_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/refresh_confidential_application_request_response.go new file mode 100644 index 00000000000..4d7318ef760 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/refresh_confidential_application_request_response.go @@ -0,0 +1,110 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// RefreshConfidentialApplicationRequest wrapper for the RefreshConfidentialApplication operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/RefreshConfidentialApplication.go.html to see an example of how to use RefreshConfidentialApplicationRequest. +type RefreshConfidentialApplicationRequest struct { + + // The OCID of the cluster. + BdsInstanceId *string `mandatory:"true" contributesTo:"path" name:"bdsInstanceId"` + + // The OCID of the identity configuration + IdentityConfigurationId *string `mandatory:"true" contributesTo:"path" name:"identityConfigurationId"` + + // Details for refreshing confidential application + RefreshConfidentialApplicationDetails `contributesTo:"body"` + + // A token that uniquely identifies a request so it can be retried in case of a timeout or + // server error, without risk of executing that same action again. Retry tokens expire after 24 + // hours but can be invalidated before then due to conflicting operations. For example, if a resource + // has been deleted and purged from the system, then a retry of the original creation request + // might be rejected. + OpcRetryToken *string `mandatory:"false" contributesTo:"header" name:"opc-retry-token"` + + // 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. + IfMatch *string `mandatory:"false" contributesTo:"header" name:"if-match"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request RefreshConfidentialApplicationRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request RefreshConfidentialApplicationRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request RefreshConfidentialApplicationRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request RefreshConfidentialApplicationRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request RefreshConfidentialApplicationRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// RefreshConfidentialApplicationResponse wrapper for the RefreshConfidentialApplication operation +type RefreshConfidentialApplicationResponse struct { + + // The underlying http response + RawResponse *http.Response + + // Unique Oracle-assigned identifier for the request. If you need to contact + // Oracle about a request, provide this request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // Unique Oracle-assigned identifier for the asynchronous request. You can use this to query status of the asynchronous operation. + OpcWorkRequestId *string `presentIn:"header" name:"opc-work-request-id"` +} + +func (response RefreshConfidentialApplicationResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response RefreshConfidentialApplicationResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/refresh_upst_token_exchange_keytab_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/refresh_upst_token_exchange_keytab_details.go new file mode 100644 index 00000000000..77ee3663a71 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/refresh_upst_token_exchange_keytab_details.go @@ -0,0 +1,39 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Big Data Service API +// +// REST API for Oracle Big Data Service. Use this API to build, deploy, and manage fully elastic Big Data Service clusters. Build on Hadoop, Spark and Data Science distributions, which can be fully integrated with existing enterprise data in Oracle Database and Oracle applications. +// + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// RefreshUpstTokenExchangeKeytabDetails Details for refreshing User Principal Session (UPST) token exchange keytab +type RefreshUpstTokenExchangeKeytabDetails struct { + + // Base-64 encoded password for the cluster admin user. + ClusterAdminPassword *string `mandatory:"true" json:"clusterAdminPassword"` +} + +func (m RefreshUpstTokenExchangeKeytabDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m RefreshUpstTokenExchangeKeytabDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/refresh_upst_token_exchange_keytab_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/refresh_upst_token_exchange_keytab_request_response.go new file mode 100644 index 00000000000..c780e929e2b --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/refresh_upst_token_exchange_keytab_request_response.go @@ -0,0 +1,110 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// RefreshUpstTokenExchangeKeytabRequest wrapper for the RefreshUpstTokenExchangeKeytab operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/RefreshUpstTokenExchangeKeytab.go.html to see an example of how to use RefreshUpstTokenExchangeKeytabRequest. +type RefreshUpstTokenExchangeKeytabRequest struct { + + // The OCID of the cluster. + BdsInstanceId *string `mandatory:"true" contributesTo:"path" name:"bdsInstanceId"` + + // The OCID of the identity configuration + IdentityConfigurationId *string `mandatory:"true" contributesTo:"path" name:"identityConfigurationId"` + + // Details for refreshing User Principal Session (UPST) token exchange keytab + RefreshUpstTokenExchangeKeytabDetails `contributesTo:"body"` + + // A token that uniquely identifies a request so it can be retried in case of a timeout or + // server error, without risk of executing that same action again. Retry tokens expire after 24 + // hours but can be invalidated before then due to conflicting operations. For example, if a resource + // has been deleted and purged from the system, then a retry of the original creation request + // might be rejected. + OpcRetryToken *string `mandatory:"false" contributesTo:"header" name:"opc-retry-token"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // 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. + IfMatch *string `mandatory:"false" contributesTo:"header" name:"if-match"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request RefreshUpstTokenExchangeKeytabRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request RefreshUpstTokenExchangeKeytabRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request RefreshUpstTokenExchangeKeytabRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request RefreshUpstTokenExchangeKeytabRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request RefreshUpstTokenExchangeKeytabRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// RefreshUpstTokenExchangeKeytabResponse wrapper for the RefreshUpstTokenExchangeKeytab operation +type RefreshUpstTokenExchangeKeytabResponse struct { + + // The underlying http response + RawResponse *http.Response + + // Unique Oracle-assigned identifier for the request. If you need to contact + // Oracle about a request, provide this request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // Unique Oracle-assigned identifier for the asynchronous request. You can use this to query status of the asynchronous operation. + OpcWorkRequestId *string `presentIn:"header" name:"opc-work-request-id"` +} + +func (response RefreshUpstTokenExchangeKeytabResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response RefreshUpstTokenExchangeKeytabResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/start_bds_instance_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/start_bds_instance_details.go index fba6785365c..cdc092e6a0f 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/bds/start_bds_instance_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/start_bds_instance_details.go @@ -20,6 +20,8 @@ type StartBdsInstanceDetails struct { // Base-64 encoded password for the cluster admin user. ClusterAdminPassword *string `mandatory:"true" json:"clusterAdminPassword"` + + StartClusterShapeConfigs *StartClusterShapeConfigs `mandatory:"false" json:"startClusterShapeConfigs"` } func (m StartBdsInstanceDetails) String() string { diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/start_cluster_shape_configs.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/start_cluster_shape_configs.go new file mode 100644 index 00000000000..bb67c485ae5 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/start_cluster_shape_configs.go @@ -0,0 +1,39 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Big Data Service API +// +// REST API for Oracle Big Data Service. Use this API to build, deploy, and manage fully elastic Big Data Service clusters. Build on Hadoop, Spark and Data Science distributions, which can be fully integrated with existing enterprise data in Oracle Database and Oracle applications. +// + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// StartClusterShapeConfigs The shape configuration to be used to start the cluster. If the value is not set, the start cluster operation will try to start the cluster as is. +type StartClusterShapeConfigs struct { + + // Shape configurations for each node type. + NodeTypeShapeConfigs []NodeTypeShapeConfig `mandatory:"true" json:"nodeTypeShapeConfigs"` +} + +func (m StartClusterShapeConfigs) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m StartClusterShapeConfigs) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/update_bds_instance_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/update_bds_instance_details.go index 788cd3d725a..7be9d0bc80b 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/bds/update_bds_instance_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/update_bds_instance_details.go @@ -34,6 +34,8 @@ type UpdateBdsInstanceDetails struct { // The OCID of the Key Management master encryption key. KmsKeyId *string `mandatory:"false" json:"kmsKeyId"` + + NetworkConfig *NetworkConfig `mandatory:"false" json:"networkConfig"` } func (m UpdateBdsInstanceDetails) String() string { diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/update_identity_configuration_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/update_identity_configuration_details.go new file mode 100644 index 00000000000..249a7a98176 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/update_identity_configuration_details.go @@ -0,0 +1,43 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Big Data Service API +// +// REST API for Oracle Big Data Service. Use this API to build, deploy, and manage fully elastic Big Data Service clusters. Build on Hadoop, Spark and Data Science distributions, which can be fully integrated with existing enterprise data in Oracle Database and Oracle applications. +// + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// UpdateIdentityConfigurationDetails Details for updating identity config on the cluster +type UpdateIdentityConfigurationDetails struct { + + // Base-64 encoded password for the cluster admin user. + ClusterAdminPassword *string `mandatory:"true" json:"clusterAdminPassword"` + + UpstConfigurationDetails *UpstConfigurationDetails `mandatory:"false" json:"upstConfigurationDetails"` + + IamUserSyncConfigurationDetails *IamUserSyncConfigurationDetails `mandatory:"false" json:"iamUserSyncConfigurationDetails"` +} + +func (m UpdateIdentityConfigurationDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m UpdateIdentityConfigurationDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/update_identity_configuration_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/update_identity_configuration_request_response.go new file mode 100644 index 00000000000..ca07aceee59 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/update_identity_configuration_request_response.go @@ -0,0 +1,110 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// UpdateIdentityConfigurationRequest wrapper for the UpdateIdentityConfiguration operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/bds/UpdateIdentityConfiguration.go.html to see an example of how to use UpdateIdentityConfigurationRequest. +type UpdateIdentityConfigurationRequest struct { + + // The OCID of the cluster. + BdsInstanceId *string `mandatory:"true" contributesTo:"path" name:"bdsInstanceId"` + + // The OCID of the identity configuration + IdentityConfigurationId *string `mandatory:"true" contributesTo:"path" name:"identityConfigurationId"` + + // Details for updating an identity configuration + UpdateIdentityConfigurationDetails `contributesTo:"body"` + + // A token that uniquely identifies a request so it can be retried in case of a timeout or + // server error, without risk of executing that same action again. Retry tokens expire after 24 + // hours but can be invalidated before then due to conflicting operations. For example, if a resource + // has been deleted and purged from the system, then a retry of the original creation request + // might be rejected. + OpcRetryToken *string `mandatory:"false" contributesTo:"header" name:"opc-retry-token"` + + // 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. + IfMatch *string `mandatory:"false" contributesTo:"header" name:"if-match"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request UpdateIdentityConfigurationRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request UpdateIdentityConfigurationRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request UpdateIdentityConfigurationRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request UpdateIdentityConfigurationRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request UpdateIdentityConfigurationRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// UpdateIdentityConfigurationResponse wrapper for the UpdateIdentityConfiguration operation +type UpdateIdentityConfigurationResponse struct { + + // The underlying http response + RawResponse *http.Response + + // Unique Oracle-assigned identifier for the request. If you need to contact + // Oracle about a request, provide this request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // Unique Oracle-assigned identifier for the asynchronous request. You can use this to query status of the asynchronous operation. + OpcWorkRequestId *string `presentIn:"header" name:"opc-work-request-id"` +} + +func (response UpdateIdentityConfigurationResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response UpdateIdentityConfigurationResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/upst_configuration.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/upst_configuration.go new file mode 100644 index 00000000000..decac52f09d --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/upst_configuration.go @@ -0,0 +1,124 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Big Data Service API +// +// REST API for Oracle Big Data Service. Use this API to build, deploy, and manage fully elastic Big Data Service clusters. Build on Hadoop, Spark and Data Science distributions, which can be fully integrated with existing enterprise data in Oracle Database and Oracle applications. +// + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// UpstConfiguration Information about the UPST configuration. +type UpstConfiguration struct { + + // The instance OCID of the node, which is the resource from which the node backup was acquired. + VaultId *string `mandatory:"true" json:"vaultId"` + + // Master Encryption key used for encrypting token exchange keytab. + MasterEncryptionKeyId *string `mandatory:"true" json:"masterEncryptionKeyId"` + + // Secret ID for token exchange keytab + SecretId *string `mandatory:"true" json:"secretId"` + + // Time when the keytab for token exchange principal is last refreshed, shown as an RFC 3339 formatted datetime string. + TimeTokenExchangeKeytabLastRefreshed *common.SDKTime `mandatory:"true" json:"timeTokenExchangeKeytabLastRefreshed"` + + // Lifecycle state of the UPST config + LifecycleState UpstConfigurationLifecycleStateEnum `mandatory:"true" json:"lifecycleState"` + + // Time when this UPST config was created, shown as an RFC 3339 formatted datetime string. + TimeCreated *common.SDKTime `mandatory:"true" json:"timeCreated"` + + // Time when this UPST config was updated, shown as an RFC 3339 formatted datetime string. + TimeUpdated *common.SDKTime `mandatory:"true" json:"timeUpdated"` + + // The kerberos keytab content used for creating identity propagation trust config, in base64 format + KeytabContent *string `mandatory:"true" json:"keytabContent"` + + // Token exchange kerberos Principal name in cluster + TokenExchangePrincipalName *string `mandatory:"false" json:"tokenExchangePrincipalName"` +} + +func (m UpstConfiguration) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m UpstConfiguration) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingUpstConfigurationLifecycleStateEnum(string(m.LifecycleState)); !ok && m.LifecycleState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", m.LifecycleState, strings.Join(GetUpstConfigurationLifecycleStateEnumStringValues(), ","))) + } + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// UpstConfigurationLifecycleStateEnum Enum with underlying type: string +type UpstConfigurationLifecycleStateEnum string + +// Set of constants representing the allowable values for UpstConfigurationLifecycleStateEnum +const ( + UpstConfigurationLifecycleStateCreating UpstConfigurationLifecycleStateEnum = "CREATING" + UpstConfigurationLifecycleStateActive UpstConfigurationLifecycleStateEnum = "ACTIVE" + UpstConfigurationLifecycleStateDeleting UpstConfigurationLifecycleStateEnum = "DELETING" + UpstConfigurationLifecycleStateInactive UpstConfigurationLifecycleStateEnum = "INACTIVE" + UpstConfigurationLifecycleStateUpdating UpstConfigurationLifecycleStateEnum = "UPDATING" + UpstConfigurationLifecycleStateFailed UpstConfigurationLifecycleStateEnum = "FAILED" +) + +var mappingUpstConfigurationLifecycleStateEnum = map[string]UpstConfigurationLifecycleStateEnum{ + "CREATING": UpstConfigurationLifecycleStateCreating, + "ACTIVE": UpstConfigurationLifecycleStateActive, + "DELETING": UpstConfigurationLifecycleStateDeleting, + "INACTIVE": UpstConfigurationLifecycleStateInactive, + "UPDATING": UpstConfigurationLifecycleStateUpdating, + "FAILED": UpstConfigurationLifecycleStateFailed, +} + +var mappingUpstConfigurationLifecycleStateEnumLowerCase = map[string]UpstConfigurationLifecycleStateEnum{ + "creating": UpstConfigurationLifecycleStateCreating, + "active": UpstConfigurationLifecycleStateActive, + "deleting": UpstConfigurationLifecycleStateDeleting, + "inactive": UpstConfigurationLifecycleStateInactive, + "updating": UpstConfigurationLifecycleStateUpdating, + "failed": UpstConfigurationLifecycleStateFailed, +} + +// GetUpstConfigurationLifecycleStateEnumValues Enumerates the set of values for UpstConfigurationLifecycleStateEnum +func GetUpstConfigurationLifecycleStateEnumValues() []UpstConfigurationLifecycleStateEnum { + values := make([]UpstConfigurationLifecycleStateEnum, 0) + for _, v := range mappingUpstConfigurationLifecycleStateEnum { + values = append(values, v) + } + return values +} + +// GetUpstConfigurationLifecycleStateEnumStringValues Enumerates the set of values in String for UpstConfigurationLifecycleStateEnum +func GetUpstConfigurationLifecycleStateEnumStringValues() []string { + return []string{ + "CREATING", + "ACTIVE", + "DELETING", + "INACTIVE", + "UPDATING", + "FAILED", + } +} + +// GetMappingUpstConfigurationLifecycleStateEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingUpstConfigurationLifecycleStateEnum(val string) (UpstConfigurationLifecycleStateEnum, bool) { + enum, ok := mappingUpstConfigurationLifecycleStateEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/bds/upst_configuration_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/bds/upst_configuration_details.go new file mode 100644 index 00000000000..07d2ad9a2e5 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/bds/upst_configuration_details.go @@ -0,0 +1,42 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Big Data Service API +// +// REST API for Oracle Big Data Service. Use this API to build, deploy, and manage fully elastic Big Data Service clusters. Build on Hadoop, Spark and Data Science distributions, which can be fully integrated with existing enterprise data in Oracle Database and Oracle applications. +// + +package bds + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// UpstConfigurationDetails Details for activating/updating UPST config on the cluster +type UpstConfigurationDetails struct { + + // OCID of the vault to store token exchange service principal keyta, required for activating UPST config + VaultId *string `mandatory:"false" json:"vaultId"` + + // OCID of the master encryption key in vault for encrypting token exchange service principal keytab, required for activating UPST config + MasterEncryptionKeyId *string `mandatory:"false" json:"masterEncryptionKeyId"` +} + +func (m UpstConfigurationDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m UpstConfigurationDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/blockchain/blockchain_platform.go b/vendor/github.com/oracle/oci-go-sdk/v65/blockchain/blockchain_platform.go index e95f9f34f54..a20516a09f1 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/blockchain/blockchain_platform.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/blockchain/blockchain_platform.go @@ -30,7 +30,7 @@ type BlockchainPlatform struct { // Role of platform - FOUNDER or PARTICIPANT PlatformRole BlockchainPlatformPlatformRoleEnum `mandatory:"true" json:"platformRole"` - // Compute shape - STANDARD or ENTERPRISE_SMALL or ENTERPRISE_MEDIUM or ENTERPRISE_LARGE or ENTERPRISE_EXTRA_LARGE or ENTERPRISE_CUSTOM + // Compute shape - STANDARD or ENTERPRISE_SMALL or ENTERPRISE_MEDIUM or ENTERPRISE_LARGE or ENTERPRISE_EXTRA_LARGE or ENTERPRISE_CUSTOM or DIGITAL_ASSETS_MEDIUM or DIGITAL_ASSETS_LARGE or DIGITAL_ASSETS_EXTRA_LARGE ComputeShape BlockchainPlatformComputeShapeEnum `mandatory:"true" json:"computeShape"` // Platform Instance Description @@ -172,30 +172,39 @@ type BlockchainPlatformComputeShapeEnum string // Set of constants representing the allowable values for BlockchainPlatformComputeShapeEnum const ( - BlockchainPlatformComputeShapeStandard BlockchainPlatformComputeShapeEnum = "STANDARD" - BlockchainPlatformComputeShapeEnterpriseSmall BlockchainPlatformComputeShapeEnum = "ENTERPRISE_SMALL" - BlockchainPlatformComputeShapeEnterpriseMedium BlockchainPlatformComputeShapeEnum = "ENTERPRISE_MEDIUM" - BlockchainPlatformComputeShapeEnterpriseLarge BlockchainPlatformComputeShapeEnum = "ENTERPRISE_LARGE" - BlockchainPlatformComputeShapeEnterpriseExtraLarge BlockchainPlatformComputeShapeEnum = "ENTERPRISE_EXTRA_LARGE" - BlockchainPlatformComputeShapeEnterpriseCustom BlockchainPlatformComputeShapeEnum = "ENTERPRISE_CUSTOM" + BlockchainPlatformComputeShapeStandard BlockchainPlatformComputeShapeEnum = "STANDARD" + BlockchainPlatformComputeShapeEnterpriseSmall BlockchainPlatformComputeShapeEnum = "ENTERPRISE_SMALL" + BlockchainPlatformComputeShapeEnterpriseMedium BlockchainPlatformComputeShapeEnum = "ENTERPRISE_MEDIUM" + BlockchainPlatformComputeShapeEnterpriseLarge BlockchainPlatformComputeShapeEnum = "ENTERPRISE_LARGE" + BlockchainPlatformComputeShapeEnterpriseExtraLarge BlockchainPlatformComputeShapeEnum = "ENTERPRISE_EXTRA_LARGE" + BlockchainPlatformComputeShapeEnterpriseCustom BlockchainPlatformComputeShapeEnum = "ENTERPRISE_CUSTOM" + BlockchainPlatformComputeShapeDigitalAssetsMedium BlockchainPlatformComputeShapeEnum = "DIGITAL_ASSETS_MEDIUM" + BlockchainPlatformComputeShapeDigitalAssetsLarge BlockchainPlatformComputeShapeEnum = "DIGITAL_ASSETS_LARGE" + BlockchainPlatformComputeShapeDigitalAssetsExtraLarge BlockchainPlatformComputeShapeEnum = "DIGITAL_ASSETS_EXTRA_LARGE" ) var mappingBlockchainPlatformComputeShapeEnum = map[string]BlockchainPlatformComputeShapeEnum{ - "STANDARD": BlockchainPlatformComputeShapeStandard, - "ENTERPRISE_SMALL": BlockchainPlatformComputeShapeEnterpriseSmall, - "ENTERPRISE_MEDIUM": BlockchainPlatformComputeShapeEnterpriseMedium, - "ENTERPRISE_LARGE": BlockchainPlatformComputeShapeEnterpriseLarge, - "ENTERPRISE_EXTRA_LARGE": BlockchainPlatformComputeShapeEnterpriseExtraLarge, - "ENTERPRISE_CUSTOM": BlockchainPlatformComputeShapeEnterpriseCustom, + "STANDARD": BlockchainPlatformComputeShapeStandard, + "ENTERPRISE_SMALL": BlockchainPlatformComputeShapeEnterpriseSmall, + "ENTERPRISE_MEDIUM": BlockchainPlatformComputeShapeEnterpriseMedium, + "ENTERPRISE_LARGE": BlockchainPlatformComputeShapeEnterpriseLarge, + "ENTERPRISE_EXTRA_LARGE": BlockchainPlatformComputeShapeEnterpriseExtraLarge, + "ENTERPRISE_CUSTOM": BlockchainPlatformComputeShapeEnterpriseCustom, + "DIGITAL_ASSETS_MEDIUM": BlockchainPlatformComputeShapeDigitalAssetsMedium, + "DIGITAL_ASSETS_LARGE": BlockchainPlatformComputeShapeDigitalAssetsLarge, + "DIGITAL_ASSETS_EXTRA_LARGE": BlockchainPlatformComputeShapeDigitalAssetsExtraLarge, } var mappingBlockchainPlatformComputeShapeEnumLowerCase = map[string]BlockchainPlatformComputeShapeEnum{ - "standard": BlockchainPlatformComputeShapeStandard, - "enterprise_small": BlockchainPlatformComputeShapeEnterpriseSmall, - "enterprise_medium": BlockchainPlatformComputeShapeEnterpriseMedium, - "enterprise_large": BlockchainPlatformComputeShapeEnterpriseLarge, - "enterprise_extra_large": BlockchainPlatformComputeShapeEnterpriseExtraLarge, - "enterprise_custom": BlockchainPlatformComputeShapeEnterpriseCustom, + "standard": BlockchainPlatformComputeShapeStandard, + "enterprise_small": BlockchainPlatformComputeShapeEnterpriseSmall, + "enterprise_medium": BlockchainPlatformComputeShapeEnterpriseMedium, + "enterprise_large": BlockchainPlatformComputeShapeEnterpriseLarge, + "enterprise_extra_large": BlockchainPlatformComputeShapeEnterpriseExtraLarge, + "enterprise_custom": BlockchainPlatformComputeShapeEnterpriseCustom, + "digital_assets_medium": BlockchainPlatformComputeShapeDigitalAssetsMedium, + "digital_assets_large": BlockchainPlatformComputeShapeDigitalAssetsLarge, + "digital_assets_extra_large": BlockchainPlatformComputeShapeDigitalAssetsExtraLarge, } // GetBlockchainPlatformComputeShapeEnumValues Enumerates the set of values for BlockchainPlatformComputeShapeEnum @@ -216,6 +225,9 @@ func GetBlockchainPlatformComputeShapeEnumStringValues() []string { "ENTERPRISE_LARGE", "ENTERPRISE_EXTRA_LARGE", "ENTERPRISE_CUSTOM", + "DIGITAL_ASSETS_MEDIUM", + "DIGITAL_ASSETS_LARGE", + "DIGITAL_ASSETS_EXTRA_LARGE", } } diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/blockchain/work_request.go b/vendor/github.com/oracle/oci-go-sdk/v65/blockchain/work_request.go index a813cfbb689..61acba41487 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/blockchain/work_request.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/blockchain/work_request.go @@ -78,39 +78,42 @@ type WorkRequestOperationTypeEnum string // Set of constants representing the allowable values for WorkRequestOperationTypeEnum const ( - WorkRequestOperationTypeCreatePlatform WorkRequestOperationTypeEnum = "CREATE_PLATFORM" - WorkRequestOperationTypeUpdatePlatform WorkRequestOperationTypeEnum = "UPDATE_PLATFORM" - WorkRequestOperationTypeUpgradePlatform WorkRequestOperationTypeEnum = "UPGRADE_PLATFORM" - WorkRequestOperationTypeDeletePlatform WorkRequestOperationTypeEnum = "DELETE_PLATFORM" - WorkRequestOperationTypeScalePlatform WorkRequestOperationTypeEnum = "SCALE_PLATFORM" - WorkRequestOperationTypeStartPlatform WorkRequestOperationTypeEnum = "START_PLATFORM" - WorkRequestOperationTypeStopPlatform WorkRequestOperationTypeEnum = "STOP_PLATFORM" - WorkRequestOperationTypeCustomizePlatform WorkRequestOperationTypeEnum = "CUSTOMIZE_PLATFORM" - WorkRequestOperationTypeScaleStorage WorkRequestOperationTypeEnum = "SCALE_STORAGE" + WorkRequestOperationTypeCreatePlatform WorkRequestOperationTypeEnum = "CREATE_PLATFORM" + WorkRequestOperationTypeUpdatePlatform WorkRequestOperationTypeEnum = "UPDATE_PLATFORM" + WorkRequestOperationTypeUpgradePlatform WorkRequestOperationTypeEnum = "UPGRADE_PLATFORM" + WorkRequestOperationTypeDeletePlatform WorkRequestOperationTypeEnum = "DELETE_PLATFORM" + WorkRequestOperationTypeScalePlatform WorkRequestOperationTypeEnum = "SCALE_PLATFORM" + WorkRequestOperationTypeStartPlatform WorkRequestOperationTypeEnum = "START_PLATFORM" + WorkRequestOperationTypeStopPlatform WorkRequestOperationTypeEnum = "STOP_PLATFORM" + WorkRequestOperationTypeCustomizePlatform WorkRequestOperationTypeEnum = "CUSTOMIZE_PLATFORM" + WorkRequestOperationTypeScaleStorage WorkRequestOperationTypeEnum = "SCALE_STORAGE" + WorkRequestOperationTypeWorkrequestCleanup WorkRequestOperationTypeEnum = "WORKREQUEST_CLEANUP" ) var mappingWorkRequestOperationTypeEnum = map[string]WorkRequestOperationTypeEnum{ - "CREATE_PLATFORM": WorkRequestOperationTypeCreatePlatform, - "UPDATE_PLATFORM": WorkRequestOperationTypeUpdatePlatform, - "UPGRADE_PLATFORM": WorkRequestOperationTypeUpgradePlatform, - "DELETE_PLATFORM": WorkRequestOperationTypeDeletePlatform, - "SCALE_PLATFORM": WorkRequestOperationTypeScalePlatform, - "START_PLATFORM": WorkRequestOperationTypeStartPlatform, - "STOP_PLATFORM": WorkRequestOperationTypeStopPlatform, - "CUSTOMIZE_PLATFORM": WorkRequestOperationTypeCustomizePlatform, - "SCALE_STORAGE": WorkRequestOperationTypeScaleStorage, + "CREATE_PLATFORM": WorkRequestOperationTypeCreatePlatform, + "UPDATE_PLATFORM": WorkRequestOperationTypeUpdatePlatform, + "UPGRADE_PLATFORM": WorkRequestOperationTypeUpgradePlatform, + "DELETE_PLATFORM": WorkRequestOperationTypeDeletePlatform, + "SCALE_PLATFORM": WorkRequestOperationTypeScalePlatform, + "START_PLATFORM": WorkRequestOperationTypeStartPlatform, + "STOP_PLATFORM": WorkRequestOperationTypeStopPlatform, + "CUSTOMIZE_PLATFORM": WorkRequestOperationTypeCustomizePlatform, + "SCALE_STORAGE": WorkRequestOperationTypeScaleStorage, + "WORKREQUEST_CLEANUP": WorkRequestOperationTypeWorkrequestCleanup, } var mappingWorkRequestOperationTypeEnumLowerCase = map[string]WorkRequestOperationTypeEnum{ - "create_platform": WorkRequestOperationTypeCreatePlatform, - "update_platform": WorkRequestOperationTypeUpdatePlatform, - "upgrade_platform": WorkRequestOperationTypeUpgradePlatform, - "delete_platform": WorkRequestOperationTypeDeletePlatform, - "scale_platform": WorkRequestOperationTypeScalePlatform, - "start_platform": WorkRequestOperationTypeStartPlatform, - "stop_platform": WorkRequestOperationTypeStopPlatform, - "customize_platform": WorkRequestOperationTypeCustomizePlatform, - "scale_storage": WorkRequestOperationTypeScaleStorage, + "create_platform": WorkRequestOperationTypeCreatePlatform, + "update_platform": WorkRequestOperationTypeUpdatePlatform, + "upgrade_platform": WorkRequestOperationTypeUpgradePlatform, + "delete_platform": WorkRequestOperationTypeDeletePlatform, + "scale_platform": WorkRequestOperationTypeScalePlatform, + "start_platform": WorkRequestOperationTypeStartPlatform, + "stop_platform": WorkRequestOperationTypeStopPlatform, + "customize_platform": WorkRequestOperationTypeCustomizePlatform, + "scale_storage": WorkRequestOperationTypeScaleStorage, + "workrequest_cleanup": WorkRequestOperationTypeWorkrequestCleanup, } // GetWorkRequestOperationTypeEnumValues Enumerates the set of values for WorkRequestOperationTypeEnum @@ -134,6 +137,7 @@ func GetWorkRequestOperationTypeEnumStringValues() []string { "STOP_PLATFORM", "CUSTOMIZE_PLATFORM", "SCALE_STORAGE", + "WORKREQUEST_CLEANUP", } } diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/blockchain/work_request_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/blockchain/work_request_summary.go index 55c96fab235..11c726136f2 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/blockchain/work_request_summary.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/blockchain/work_request_summary.go @@ -78,39 +78,42 @@ type WorkRequestSummaryOperationTypeEnum string // Set of constants representing the allowable values for WorkRequestSummaryOperationTypeEnum const ( - WorkRequestSummaryOperationTypeCreatePlatform WorkRequestSummaryOperationTypeEnum = "CREATE_PLATFORM" - WorkRequestSummaryOperationTypeUpdatePlatform WorkRequestSummaryOperationTypeEnum = "UPDATE_PLATFORM" - WorkRequestSummaryOperationTypeUpgradePlatform WorkRequestSummaryOperationTypeEnum = "UPGRADE_PLATFORM" - WorkRequestSummaryOperationTypeDeletePlatform WorkRequestSummaryOperationTypeEnum = "DELETE_PLATFORM" - WorkRequestSummaryOperationTypeScalePlatform WorkRequestSummaryOperationTypeEnum = "SCALE_PLATFORM" - WorkRequestSummaryOperationTypeStartPlatform WorkRequestSummaryOperationTypeEnum = "START_PLATFORM" - WorkRequestSummaryOperationTypeStopPlatform WorkRequestSummaryOperationTypeEnum = "STOP_PLATFORM" - WorkRequestSummaryOperationTypeCustomizePlatform WorkRequestSummaryOperationTypeEnum = "CUSTOMIZE_PLATFORM" - WorkRequestSummaryOperationTypeScaleStorage WorkRequestSummaryOperationTypeEnum = "SCALE_STORAGE" + WorkRequestSummaryOperationTypeCreatePlatform WorkRequestSummaryOperationTypeEnum = "CREATE_PLATFORM" + WorkRequestSummaryOperationTypeUpdatePlatform WorkRequestSummaryOperationTypeEnum = "UPDATE_PLATFORM" + WorkRequestSummaryOperationTypeUpgradePlatform WorkRequestSummaryOperationTypeEnum = "UPGRADE_PLATFORM" + WorkRequestSummaryOperationTypeDeletePlatform WorkRequestSummaryOperationTypeEnum = "DELETE_PLATFORM" + WorkRequestSummaryOperationTypeScalePlatform WorkRequestSummaryOperationTypeEnum = "SCALE_PLATFORM" + WorkRequestSummaryOperationTypeStartPlatform WorkRequestSummaryOperationTypeEnum = "START_PLATFORM" + WorkRequestSummaryOperationTypeStopPlatform WorkRequestSummaryOperationTypeEnum = "STOP_PLATFORM" + WorkRequestSummaryOperationTypeCustomizePlatform WorkRequestSummaryOperationTypeEnum = "CUSTOMIZE_PLATFORM" + WorkRequestSummaryOperationTypeScaleStorage WorkRequestSummaryOperationTypeEnum = "SCALE_STORAGE" + WorkRequestSummaryOperationTypeWorkrequestCleanup WorkRequestSummaryOperationTypeEnum = "WORKREQUEST_CLEANUP" ) var mappingWorkRequestSummaryOperationTypeEnum = map[string]WorkRequestSummaryOperationTypeEnum{ - "CREATE_PLATFORM": WorkRequestSummaryOperationTypeCreatePlatform, - "UPDATE_PLATFORM": WorkRequestSummaryOperationTypeUpdatePlatform, - "UPGRADE_PLATFORM": WorkRequestSummaryOperationTypeUpgradePlatform, - "DELETE_PLATFORM": WorkRequestSummaryOperationTypeDeletePlatform, - "SCALE_PLATFORM": WorkRequestSummaryOperationTypeScalePlatform, - "START_PLATFORM": WorkRequestSummaryOperationTypeStartPlatform, - "STOP_PLATFORM": WorkRequestSummaryOperationTypeStopPlatform, - "CUSTOMIZE_PLATFORM": WorkRequestSummaryOperationTypeCustomizePlatform, - "SCALE_STORAGE": WorkRequestSummaryOperationTypeScaleStorage, + "CREATE_PLATFORM": WorkRequestSummaryOperationTypeCreatePlatform, + "UPDATE_PLATFORM": WorkRequestSummaryOperationTypeUpdatePlatform, + "UPGRADE_PLATFORM": WorkRequestSummaryOperationTypeUpgradePlatform, + "DELETE_PLATFORM": WorkRequestSummaryOperationTypeDeletePlatform, + "SCALE_PLATFORM": WorkRequestSummaryOperationTypeScalePlatform, + "START_PLATFORM": WorkRequestSummaryOperationTypeStartPlatform, + "STOP_PLATFORM": WorkRequestSummaryOperationTypeStopPlatform, + "CUSTOMIZE_PLATFORM": WorkRequestSummaryOperationTypeCustomizePlatform, + "SCALE_STORAGE": WorkRequestSummaryOperationTypeScaleStorage, + "WORKREQUEST_CLEANUP": WorkRequestSummaryOperationTypeWorkrequestCleanup, } var mappingWorkRequestSummaryOperationTypeEnumLowerCase = map[string]WorkRequestSummaryOperationTypeEnum{ - "create_platform": WorkRequestSummaryOperationTypeCreatePlatform, - "update_platform": WorkRequestSummaryOperationTypeUpdatePlatform, - "upgrade_platform": WorkRequestSummaryOperationTypeUpgradePlatform, - "delete_platform": WorkRequestSummaryOperationTypeDeletePlatform, - "scale_platform": WorkRequestSummaryOperationTypeScalePlatform, - "start_platform": WorkRequestSummaryOperationTypeStartPlatform, - "stop_platform": WorkRequestSummaryOperationTypeStopPlatform, - "customize_platform": WorkRequestSummaryOperationTypeCustomizePlatform, - "scale_storage": WorkRequestSummaryOperationTypeScaleStorage, + "create_platform": WorkRequestSummaryOperationTypeCreatePlatform, + "update_platform": WorkRequestSummaryOperationTypeUpdatePlatform, + "upgrade_platform": WorkRequestSummaryOperationTypeUpgradePlatform, + "delete_platform": WorkRequestSummaryOperationTypeDeletePlatform, + "scale_platform": WorkRequestSummaryOperationTypeScalePlatform, + "start_platform": WorkRequestSummaryOperationTypeStartPlatform, + "stop_platform": WorkRequestSummaryOperationTypeStopPlatform, + "customize_platform": WorkRequestSummaryOperationTypeCustomizePlatform, + "scale_storage": WorkRequestSummaryOperationTypeScaleStorage, + "workrequest_cleanup": WorkRequestSummaryOperationTypeWorkrequestCleanup, } // GetWorkRequestSummaryOperationTypeEnumValues Enumerates the set of values for WorkRequestSummaryOperationTypeEnum @@ -134,6 +137,7 @@ func GetWorkRequestSummaryOperationTypeEnumStringValues() []string { "STOP_PLATFORM", "CUSTOMIZE_PLATFORM", "SCALE_STORAGE", + "WORKREQUEST_CLEANUP", } } diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_asset_source.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_asset_source.go new file mode 100644 index 00000000000..98d91488ce4 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_asset_source.go @@ -0,0 +1,192 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// AwsAssetSource AWS asset source. Used for discovery of EC2 instances and EBS volumes registered for the AWS account. +type AwsAssetSource struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the resource. + Id *string `mandatory:"true" json:"id"` + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the compartment for the resource. + CompartmentId *string `mandatory:"true" json:"compartmentId"` + + // A user-friendly name for the asset source. Does not have to be unique, and it's mutable. + // Avoid entering confidential information. + DisplayName *string `mandatory:"true" json:"displayName"` + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the environment. + EnvironmentId *string `mandatory:"true" json:"environmentId"` + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the inventory that will contain created assets. + InventoryId *string `mandatory:"true" json:"inventoryId"` + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the compartment that is going to be used to create assets. + AssetsCompartmentId *string `mandatory:"true" json:"assetsCompartmentId"` + + // The detailed state of the asset source. + LifecycleDetails *string `mandatory:"true" json:"lifecycleDetails"` + + // The time when the asset source was created in the RFC3339 format. + TimeCreated *common.SDKTime `mandatory:"true" json:"timeCreated"` + + // The point in time that the asset source was last updated in the RFC3339 format. + TimeUpdated *common.SDKTime `mandatory:"true" json:"timeUpdated"` + + DiscoveryCredentials *AssetSourceCredentials `mandatory:"true" json:"discoveryCredentials"` + + // AWS region information, from where the resources are discovered. + AwsRegion *string `mandatory:"true" json:"awsRegion"` + + // The key of customer's aws account to be discovered/migrated. + AwsAccountKey *string `mandatory:"true" json:"awsAccountKey"` + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of an attached discovery schedule. + DiscoveryScheduleId *string `mandatory:"false" json:"discoveryScheduleId"` + + // The freeform tags associated with this resource, if any. Each tag is a simple key-value pair with no + // predefined name, type, or namespace/scope. For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Department": "Finance"}` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + + // The defined tags associated with this resource, if any. Each key is predefined and scoped to namespaces. + // For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Operations": {"CostCenter": "42"}}` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` + + // The system tags associated with this resource, if any. The system tags are set by Oracle cloud infrastructure services. Each key is predefined and scoped to namespaces. + // For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{orcl-cloud: {free-tier-retain: true}}` + SystemTags map[string]map[string]interface{} `mandatory:"false" json:"systemTags"` + + ReplicationCredentials *AssetSourceCredentials `mandatory:"false" json:"replicationCredentials"` + + // Flag indicating whether historical metrics are collected for assets, originating from this asset source. + AreHistoricalMetricsCollected *bool `mandatory:"false" json:"areHistoricalMetricsCollected"` + + // Flag indicating whether real-time metrics are collected for assets, originating from this asset source. + AreRealtimeMetricsCollected *bool `mandatory:"false" json:"areRealtimeMetricsCollected"` + + // Flag indicating whether cost data collection is enabled for assets, originating from this asset source. + IsCostInformationCollected *bool `mandatory:"false" json:"isCostInformationCollected"` + + // The current state of the asset source. + LifecycleState AssetSourceLifecycleStateEnum `mandatory:"true" json:"lifecycleState"` +} + +// GetId returns Id +func (m AwsAssetSource) GetId() *string { + return m.Id +} + +// GetCompartmentId returns CompartmentId +func (m AwsAssetSource) GetCompartmentId() *string { + return m.CompartmentId +} + +// GetDisplayName returns DisplayName +func (m AwsAssetSource) GetDisplayName() *string { + return m.DisplayName +} + +// GetEnvironmentId returns EnvironmentId +func (m AwsAssetSource) GetEnvironmentId() *string { + return m.EnvironmentId +} + +// GetInventoryId returns InventoryId +func (m AwsAssetSource) GetInventoryId() *string { + return m.InventoryId +} + +// GetAssetsCompartmentId returns AssetsCompartmentId +func (m AwsAssetSource) GetAssetsCompartmentId() *string { + return m.AssetsCompartmentId +} + +// GetDiscoveryScheduleId returns DiscoveryScheduleId +func (m AwsAssetSource) GetDiscoveryScheduleId() *string { + return m.DiscoveryScheduleId +} + +// GetLifecycleState returns LifecycleState +func (m AwsAssetSource) GetLifecycleState() AssetSourceLifecycleStateEnum { + return m.LifecycleState +} + +// GetLifecycleDetails returns LifecycleDetails +func (m AwsAssetSource) GetLifecycleDetails() *string { + return m.LifecycleDetails +} + +// GetTimeCreated returns TimeCreated +func (m AwsAssetSource) GetTimeCreated() *common.SDKTime { + return m.TimeCreated +} + +// GetTimeUpdated returns TimeUpdated +func (m AwsAssetSource) GetTimeUpdated() *common.SDKTime { + return m.TimeUpdated +} + +// GetFreeformTags returns FreeformTags +func (m AwsAssetSource) GetFreeformTags() map[string]string { + return m.FreeformTags +} + +// GetDefinedTags returns DefinedTags +func (m AwsAssetSource) GetDefinedTags() map[string]map[string]interface{} { + return m.DefinedTags +} + +// GetSystemTags returns SystemTags +func (m AwsAssetSource) GetSystemTags() map[string]map[string]interface{} { + return m.SystemTags +} + +func (m AwsAssetSource) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m AwsAssetSource) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if _, ok := GetMappingAssetSourceLifecycleStateEnum(string(m.LifecycleState)); !ok && m.LifecycleState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", m.LifecycleState, strings.Join(GetAssetSourceLifecycleStateEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m AwsAssetSource) MarshalJSON() (buff []byte, e error) { + type MarshalTypeAwsAssetSource AwsAssetSource + s := struct { + DiscriminatorParam string `json:"type"` + MarshalTypeAwsAssetSource + }{ + "AWS", + (MarshalTypeAwsAssetSource)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_asset_source_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_asset_source_summary.go new file mode 100644 index 00000000000..21c58c1f12c --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_asset_source_summary.go @@ -0,0 +1,171 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// AwsAssetSourceSummary Summary of an AWS asset source provided in the list. +type AwsAssetSourceSummary struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the resource. + Id *string `mandatory:"true" json:"id"` + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the compartment for the resource. + CompartmentId *string `mandatory:"true" json:"compartmentId"` + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the environment. + EnvironmentId *string `mandatory:"true" json:"environmentId"` + + // A user-friendly name for the asset source. Does not have to be unique, and it's mutable. + // Avoid entering confidential information. + DisplayName *string `mandatory:"true" json:"displayName"` + + // The detailed state of the asset source. + LifecycleDetails *string `mandatory:"true" json:"lifecycleDetails"` + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the inventory that will contain created assets. + InventoryId *string `mandatory:"true" json:"inventoryId"` + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the compartment that is going to be used to create assets. + AssetsCompartmentId *string `mandatory:"true" json:"assetsCompartmentId"` + + // AWS region information, from where the resources are discovered. + AwsRegion *string `mandatory:"true" json:"awsRegion"` + + // The key of customer's aws account to be discovered/migrated. + AwsAccountKey *string `mandatory:"true" json:"awsAccountKey"` + + // The time when the asset source was created in RFC3339 format. + TimeCreated *common.SDKTime `mandatory:"false" json:"timeCreated"` + + // The point in time that the asset source was last updated in RFC3339 format. + TimeUpdated *common.SDKTime `mandatory:"false" json:"timeUpdated"` + + // The freeform tags associated with this resource, if any. Each tag is a simple key-value pair with no + // predefined name, type, or namespace/scope. For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Department": "Finance"}` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + + // The defined tags associated with this resource, if any. Each key is predefined and scoped to namespaces. + // For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Operations": {"CostCenter": "42"}}` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` + + // The system tags associated with this resource, if any. The system tags are set by Oracle cloud infrastructure services. Each key is predefined and scoped to namespaces. + // For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{orcl-cloud: {free-tier-retain: true}}` + SystemTags map[string]map[string]interface{} `mandatory:"false" json:"systemTags"` + + // The current state of the asset source. + LifecycleState AssetSourceLifecycleStateEnum `mandatory:"true" json:"lifecycleState"` +} + +// GetId returns Id +func (m AwsAssetSourceSummary) GetId() *string { + return m.Id +} + +// GetCompartmentId returns CompartmentId +func (m AwsAssetSourceSummary) GetCompartmentId() *string { + return m.CompartmentId +} + +// GetEnvironmentId returns EnvironmentId +func (m AwsAssetSourceSummary) GetEnvironmentId() *string { + return m.EnvironmentId +} + +// GetDisplayName returns DisplayName +func (m AwsAssetSourceSummary) GetDisplayName() *string { + return m.DisplayName +} + +// GetLifecycleState returns LifecycleState +func (m AwsAssetSourceSummary) GetLifecycleState() AssetSourceLifecycleStateEnum { + return m.LifecycleState +} + +// GetLifecycleDetails returns LifecycleDetails +func (m AwsAssetSourceSummary) GetLifecycleDetails() *string { + return m.LifecycleDetails +} + +// GetInventoryId returns InventoryId +func (m AwsAssetSourceSummary) GetInventoryId() *string { + return m.InventoryId +} + +// GetAssetsCompartmentId returns AssetsCompartmentId +func (m AwsAssetSourceSummary) GetAssetsCompartmentId() *string { + return m.AssetsCompartmentId +} + +// GetTimeCreated returns TimeCreated +func (m AwsAssetSourceSummary) GetTimeCreated() *common.SDKTime { + return m.TimeCreated +} + +// GetTimeUpdated returns TimeUpdated +func (m AwsAssetSourceSummary) GetTimeUpdated() *common.SDKTime { + return m.TimeUpdated +} + +// GetFreeformTags returns FreeformTags +func (m AwsAssetSourceSummary) GetFreeformTags() map[string]string { + return m.FreeformTags +} + +// GetDefinedTags returns DefinedTags +func (m AwsAssetSourceSummary) GetDefinedTags() map[string]map[string]interface{} { + return m.DefinedTags +} + +// GetSystemTags returns SystemTags +func (m AwsAssetSourceSummary) GetSystemTags() map[string]map[string]interface{} { + return m.SystemTags +} + +func (m AwsAssetSourceSummary) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m AwsAssetSourceSummary) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if _, ok := GetMappingAssetSourceLifecycleStateEnum(string(m.LifecycleState)); !ok && m.LifecycleState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", m.LifecycleState, strings.Join(GetAssetSourceLifecycleStateEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m AwsAssetSourceSummary) MarshalJSON() (buff []byte, e error) { + type MarshalTypeAwsAssetSourceSummary AwsAssetSourceSummary + s := struct { + DiscriminatorParam string `json:"type"` + MarshalTypeAwsAssetSourceSummary + }{ + "AWS", + (MarshalTypeAwsAssetSourceSummary)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ebs_asset.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ebs_asset.go new file mode 100644 index 00000000000..4efe59b9ff1 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ebs_asset.go @@ -0,0 +1,166 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// AwsEbsAsset AWS EBS type of asset. +type AwsEbsAsset struct { + + // Inventory ID to which an asset belongs to. + InventoryId *string `mandatory:"true" json:"inventoryId"` + + // Asset OCID that is immutable on creation. + Id *string `mandatory:"true" json:"id"` + + // The OCID of the compartment to which an asset belongs to. + CompartmentId *string `mandatory:"true" json:"compartmentId"` + + // The source key that the asset belongs to. + SourceKey *string `mandatory:"true" json:"sourceKey"` + + // The key of the asset from the external environment. + ExternalAssetKey *string `mandatory:"true" json:"externalAssetKey"` + + // The time when the asset was created. An RFC3339 formatted datetime string. + TimeCreated *common.SDKTime `mandatory:"true" json:"timeCreated"` + + // The time when the asset was updated. An RFC3339 formatted datetime string. + TimeUpdated *common.SDKTime `mandatory:"true" json:"timeUpdated"` + + AwsEbs *AwsEbsProperties `mandatory:"true" json:"awsEbs"` + + // Asset display name. + DisplayName *string `mandatory:"false" json:"displayName"` + + // List of asset source OCID. + AssetSourceIds []string `mandatory:"false" json:"assetSourceIds"` + + // The freeform tags associated with this resource, if any. Each tag is a simple key-value pair with no + // predefined name, type, or namespace/scope. For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Department": "Finance"}` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + + // The defined tags associated with this resource, if any. Each key is predefined and scoped to namespaces. + // For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Operations": {"CostCenter": "42"}}` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` + + // The system tags associated with this resource, if any. The system tags are set by Oracle cloud infrastructure services. Each key is predefined and scoped to namespaces. + // For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{orcl-cloud: {free-tier-retain: true}}` + SystemTags map[string]map[string]interface{} `mandatory:"false" json:"systemTags"` + + // The current state of the asset. + LifecycleState AssetLifecycleStateEnum `mandatory:"true" json:"lifecycleState"` +} + +// GetDisplayName returns DisplayName +func (m AwsEbsAsset) GetDisplayName() *string { + return m.DisplayName +} + +// GetInventoryId returns InventoryId +func (m AwsEbsAsset) GetInventoryId() *string { + return m.InventoryId +} + +// GetId returns Id +func (m AwsEbsAsset) GetId() *string { + return m.Id +} + +// GetCompartmentId returns CompartmentId +func (m AwsEbsAsset) GetCompartmentId() *string { + return m.CompartmentId +} + +// GetSourceKey returns SourceKey +func (m AwsEbsAsset) GetSourceKey() *string { + return m.SourceKey +} + +// GetExternalAssetKey returns ExternalAssetKey +func (m AwsEbsAsset) GetExternalAssetKey() *string { + return m.ExternalAssetKey +} + +// GetTimeCreated returns TimeCreated +func (m AwsEbsAsset) GetTimeCreated() *common.SDKTime { + return m.TimeCreated +} + +// GetTimeUpdated returns TimeUpdated +func (m AwsEbsAsset) GetTimeUpdated() *common.SDKTime { + return m.TimeUpdated +} + +// GetAssetSourceIds returns AssetSourceIds +func (m AwsEbsAsset) GetAssetSourceIds() []string { + return m.AssetSourceIds +} + +// GetLifecycleState returns LifecycleState +func (m AwsEbsAsset) GetLifecycleState() AssetLifecycleStateEnum { + return m.LifecycleState +} + +// GetFreeformTags returns FreeformTags +func (m AwsEbsAsset) GetFreeformTags() map[string]string { + return m.FreeformTags +} + +// GetDefinedTags returns DefinedTags +func (m AwsEbsAsset) GetDefinedTags() map[string]map[string]interface{} { + return m.DefinedTags +} + +// GetSystemTags returns SystemTags +func (m AwsEbsAsset) GetSystemTags() map[string]map[string]interface{} { + return m.SystemTags +} + +func (m AwsEbsAsset) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m AwsEbsAsset) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if _, ok := GetMappingAssetLifecycleStateEnum(string(m.LifecycleState)); !ok && m.LifecycleState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", m.LifecycleState, strings.Join(GetAssetLifecycleStateEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m AwsEbsAsset) MarshalJSON() (buff []byte, e error) { + type MarshalTypeAwsEbsAsset AwsEbsAsset + s := struct { + DiscriminatorParam string `json:"assetType"` + MarshalTypeAwsEbsAsset + }{ + "AWS_EBS", + (MarshalTypeAwsEbsAsset)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ebs_asset_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ebs_asset_details.go new file mode 100644 index 00000000000..ecc3c6802bd --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ebs_asset_details.go @@ -0,0 +1,37 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// AwsEbsAssetDetails AWS EBS type of asset. +type AwsEbsAssetDetails struct { + AwsEbs *AwsEbsProperties `mandatory:"true" json:"awsEbs"` +} + +func (m AwsEbsAssetDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m AwsEbsAssetDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ebs_properties.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ebs_properties.go new file mode 100644 index 00000000000..27dbc700948 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ebs_properties.go @@ -0,0 +1,69 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// AwsEbsProperties AWS EBS volume related properties. +type AwsEbsProperties struct { + + // Indicates whether the volume is encrypted. + IsEncrypted *bool `mandatory:"true" json:"isEncrypted"` + + // Indicates whether Amazon EBS Multi-Attach is enabled. + IsMultiAttachEnabled *bool `mandatory:"true" json:"isMultiAttachEnabled"` + + // The size of the volume, in GiBs. + SizeInGiBs *int `mandatory:"true" json:"sizeInGiBs"` + + // The ID of the volume. + VolumeKey *string `mandatory:"true" json:"volumeKey"` + + // The volume type. + VolumeType *string `mandatory:"true" json:"volumeType"` + + // Information about the volume attachments. + Attachments []VolumeAttachment `mandatory:"false" json:"attachments"` + + // The Availability Zone for the volume. + AvailabilityZone *string `mandatory:"false" json:"availabilityZone"` + + // The number of I/O operations per second. + Iops *int `mandatory:"false" json:"iops"` + + // The volume state. + Status *string `mandatory:"false" json:"status"` + + // Any tags assigned to the volume. + Tags []Tag `mandatory:"false" json:"tags"` + + // The throughput that the volume supports, in MiB/s. + Throughput *int `mandatory:"false" json:"throughput"` +} + +func (m AwsEbsProperties) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m AwsEbsProperties) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ec2_asset.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ec2_asset.go new file mode 100644 index 00000000000..086caff6b9d --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ec2_asset.go @@ -0,0 +1,174 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// AwsEc2Asset AWS EC2 type of asset. +type AwsEc2Asset struct { + + // Inventory ID to which an asset belongs to. + InventoryId *string `mandatory:"true" json:"inventoryId"` + + // Asset OCID that is immutable on creation. + Id *string `mandatory:"true" json:"id"` + + // The OCID of the compartment to which an asset belongs to. + CompartmentId *string `mandatory:"true" json:"compartmentId"` + + // The source key that the asset belongs to. + SourceKey *string `mandatory:"true" json:"sourceKey"` + + // The key of the asset from the external environment. + ExternalAssetKey *string `mandatory:"true" json:"externalAssetKey"` + + // The time when the asset was created. An RFC3339 formatted datetime string. + TimeCreated *common.SDKTime `mandatory:"true" json:"timeCreated"` + + // The time when the asset was updated. An RFC3339 formatted datetime string. + TimeUpdated *common.SDKTime `mandatory:"true" json:"timeUpdated"` + + Compute *ComputeProperties `mandatory:"true" json:"compute"` + + Vm *VmProperties `mandatory:"true" json:"vm"` + + AwsEc2 *AwsEc2Properties `mandatory:"true" json:"awsEc2"` + + // Asset display name. + DisplayName *string `mandatory:"false" json:"displayName"` + + // List of asset source OCID. + AssetSourceIds []string `mandatory:"false" json:"assetSourceIds"` + + // The freeform tags associated with this resource, if any. Each tag is a simple key-value pair with no + // predefined name, type, or namespace/scope. For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Department": "Finance"}` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + + // The defined tags associated with this resource, if any. Each key is predefined and scoped to namespaces. + // For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Operations": {"CostCenter": "42"}}` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` + + // The system tags associated with this resource, if any. The system tags are set by Oracle cloud infrastructure services. Each key is predefined and scoped to namespaces. + // For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{orcl-cloud: {free-tier-retain: true}}` + SystemTags map[string]map[string]interface{} `mandatory:"false" json:"systemTags"` + + AwsEc2Cost *MonthlyCostSummary `mandatory:"false" json:"awsEc2Cost"` + + AttachedEbsVolumesCost *MonthlyCostSummary `mandatory:"false" json:"attachedEbsVolumesCost"` + + // The current state of the asset. + LifecycleState AssetLifecycleStateEnum `mandatory:"true" json:"lifecycleState"` +} + +// GetDisplayName returns DisplayName +func (m AwsEc2Asset) GetDisplayName() *string { + return m.DisplayName +} + +// GetInventoryId returns InventoryId +func (m AwsEc2Asset) GetInventoryId() *string { + return m.InventoryId +} + +// GetId returns Id +func (m AwsEc2Asset) GetId() *string { + return m.Id +} + +// GetCompartmentId returns CompartmentId +func (m AwsEc2Asset) GetCompartmentId() *string { + return m.CompartmentId +} + +// GetSourceKey returns SourceKey +func (m AwsEc2Asset) GetSourceKey() *string { + return m.SourceKey +} + +// GetExternalAssetKey returns ExternalAssetKey +func (m AwsEc2Asset) GetExternalAssetKey() *string { + return m.ExternalAssetKey +} + +// GetTimeCreated returns TimeCreated +func (m AwsEc2Asset) GetTimeCreated() *common.SDKTime { + return m.TimeCreated +} + +// GetTimeUpdated returns TimeUpdated +func (m AwsEc2Asset) GetTimeUpdated() *common.SDKTime { + return m.TimeUpdated +} + +// GetAssetSourceIds returns AssetSourceIds +func (m AwsEc2Asset) GetAssetSourceIds() []string { + return m.AssetSourceIds +} + +// GetLifecycleState returns LifecycleState +func (m AwsEc2Asset) GetLifecycleState() AssetLifecycleStateEnum { + return m.LifecycleState +} + +// GetFreeformTags returns FreeformTags +func (m AwsEc2Asset) GetFreeformTags() map[string]string { + return m.FreeformTags +} + +// GetDefinedTags returns DefinedTags +func (m AwsEc2Asset) GetDefinedTags() map[string]map[string]interface{} { + return m.DefinedTags +} + +// GetSystemTags returns SystemTags +func (m AwsEc2Asset) GetSystemTags() map[string]map[string]interface{} { + return m.SystemTags +} + +func (m AwsEc2Asset) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m AwsEc2Asset) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if _, ok := GetMappingAssetLifecycleStateEnum(string(m.LifecycleState)); !ok && m.LifecycleState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", m.LifecycleState, strings.Join(GetAssetLifecycleStateEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m AwsEc2Asset) MarshalJSON() (buff []byte, e error) { + type MarshalTypeAwsEc2Asset AwsEc2Asset + s := struct { + DiscriminatorParam string `json:"assetType"` + MarshalTypeAwsEc2Asset + }{ + "AWS_EC2", + (MarshalTypeAwsEc2Asset)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ec2_asset_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ec2_asset_details.go new file mode 100644 index 00000000000..4e5a1e9a88f --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ec2_asset_details.go @@ -0,0 +1,45 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// AwsEc2AssetDetails AWS EC2 type of asset. +type AwsEc2AssetDetails struct { + Compute *ComputeProperties `mandatory:"true" json:"compute"` + + Vm *VmProperties `mandatory:"true" json:"vm"` + + AwsEc2 *AwsEc2Properties `mandatory:"true" json:"awsEc2"` + + AwsEc2Cost *MonthlyCostSummary `mandatory:"false" json:"awsEc2Cost"` + + AttachedEbsVolumesCost *MonthlyCostSummary `mandatory:"false" json:"attachedEbsVolumesCost"` +} + +func (m AwsEc2AssetDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m AwsEc2AssetDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ec2_properties.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ec2_properties.go new file mode 100644 index 00000000000..58bd09aec0b --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/aws_ec2_properties.go @@ -0,0 +1,133 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// AwsEc2Properties AWS virtual machine related properties. +type AwsEc2Properties struct { + + // The architecture of the image. + Architecture *string `mandatory:"true" json:"architecture"` + + // The ID of the instance. + InstanceKey *string `mandatory:"true" json:"instanceKey"` + + // The instance type. + InstanceType *string `mandatory:"true" json:"instanceType"` + + // The device name of the root device volume. + RootDeviceName *string `mandatory:"true" json:"rootDeviceName"` + + State *InstanceState `mandatory:"true" json:"state"` + + // The boot mode of the instance. + BootMode *string `mandatory:"false" json:"bootMode"` + + // The ID of the Capacity Reservation. + CapacityReservationKey *string `mandatory:"false" json:"capacityReservationKey"` + + // Indicates if the elastic inference accelerators attached to an instance + AreElasticInferenceAcceleratorsPresent *bool `mandatory:"false" json:"areElasticInferenceAcceleratorsPresent"` + + // Indicates whether the instance is enabled for AWS Nitro Enclaves. + IsEnclaveOptions *bool `mandatory:"false" json:"isEnclaveOptions"` + + // Indicates whether the instance is enabled for hibernation. + IsHibernationOptions *bool `mandatory:"false" json:"isHibernationOptions"` + + // The ID of the AMI used to launch the instance. + ImageKey *string `mandatory:"false" json:"imageKey"` + + // Indicates whether this is a Spot Instance or a Scheduled Instance. + InstanceLifecycle *string `mandatory:"false" json:"instanceLifecycle"` + + // The public IPv4 address, or the Carrier IP address assigned to the instance. + IpAddress *string `mandatory:"false" json:"ipAddress"` + + // The IPv6 address assigned to the instance. + Ipv6Address *string `mandatory:"false" json:"ipv6Address"` + + // The kernel associated with this instance, if applicable. + KernelKey *string `mandatory:"false" json:"kernelKey"` + + // The time the instance was launched. + TimeLaunch *common.SDKTime `mandatory:"false" json:"timeLaunch"` + + // The license configurations for the instance. + Licenses []string `mandatory:"false" json:"licenses"` + + // Provides information on the recovery and maintenance options of your instance. + MaintenanceOptions *string `mandatory:"false" json:"maintenanceOptions"` + + // The monitoring for the instance. + Monitoring *string `mandatory:"false" json:"monitoring"` + + // The network interfaces for the instance. + NetworkInterfaces []InstanceNetworkInterface `mandatory:"false" json:"networkInterfaces"` + + Placement *Placement `mandatory:"false" json:"placement"` + + // (IPv4 only) The private DNS hostname name assigned to the instance. + PrivateDnsName *string `mandatory:"false" json:"privateDnsName"` + + // The private IPv4 address assigned to the instance. + PrivateIpAddress *string `mandatory:"false" json:"privateIpAddress"` + + // The root device type used by the AMI. The AMI can use an EBS volume or an instance store volume. + RootDeviceType *string `mandatory:"false" json:"rootDeviceType"` + + // The security groups for the instance. + SecurityGroups []GroupIdentifier `mandatory:"false" json:"securityGroups"` + + // Indicates whether source/destination checking is enabled. + IsSourceDestCheck *bool `mandatory:"false" json:"isSourceDestCheck"` + + // If the request is a Spot Instance request, this value will be true. + IsSpotInstance *bool `mandatory:"false" json:"isSpotInstance"` + + // Specifies whether enhanced networking with the Intel 82599 Virtual Function interface is enabled. + SriovNetSupport *string `mandatory:"false" json:"sriovNetSupport"` + + // EC2-VPC The ID of the subnet in which the instance is running. + SubnetKey *string `mandatory:"false" json:"subnetKey"` + + // Any tags assigned to the instance. + Tags []Tag `mandatory:"false" json:"tags"` + + // If the instance is configured for NitroTPM support, the value is v2.0. + TpmSupport *string `mandatory:"false" json:"tpmSupport"` + + // The virtualization type of the instance. + VirtualizationType *string `mandatory:"false" json:"virtualizationType"` + + // EC2-VPC The ID of the VPC in which the instance is running. + VpcKey *string `mandatory:"false" json:"vpcKey"` +} + +func (m AwsEc2Properties) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m AwsEc2Properties) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/create_aws_asset_source_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/create_aws_asset_source_details.go new file mode 100644 index 00000000000..2a458729d5d --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/create_aws_asset_source_details.go @@ -0,0 +1,150 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// CreateAwsAssetSourceDetails AWS asset source creation request. +type CreateAwsAssetSourceDetails struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the compartment for the resource. + CompartmentId *string `mandatory:"true" json:"compartmentId"` + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the environment. + EnvironmentId *string `mandatory:"true" json:"environmentId"` + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the inventory that will contain created assets. + InventoryId *string `mandatory:"true" json:"inventoryId"` + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the compartment that is going to be used to create assets. + AssetsCompartmentId *string `mandatory:"true" json:"assetsCompartmentId"` + + DiscoveryCredentials *AssetSourceCredentials `mandatory:"true" json:"discoveryCredentials"` + + // AWS region information, from where the resources are discovered. + AwsRegion *string `mandatory:"true" json:"awsRegion"` + + // The key of customer's aws account to be discovered/migrated. + AwsAccountKey *string `mandatory:"true" json:"awsAccountKey"` + + // A user-friendly name for the asset source. Does not have to be unique, and it's mutable. + // Avoid entering confidential information. The name is generated by the service if it is not + // explicitly provided. + DisplayName *string `mandatory:"false" json:"displayName"` + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the discovery schedule that is going to be attached to the created asset. + DiscoveryScheduleId *string `mandatory:"false" json:"discoveryScheduleId"` + + // The freeform tags associated with this resource, if any. Each tag is a simple key-value pair with no + // predefined name, type, or namespace/scope. For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Department": "Finance"}` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + + // The defined tags associated with this resource, if any. Each key is predefined and scoped to namespaces. + // For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Operations": {"CostCenter": "42"}}` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` + + // The system tags associated with this resource, if any. The system tags are set by Oracle cloud infrastructure services. Each key is predefined and scoped to namespaces. + // For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{orcl-cloud: {free-tier-retain: true}}` + SystemTags map[string]map[string]interface{} `mandatory:"false" json:"systemTags"` + + ReplicationCredentials *AssetSourceCredentials `mandatory:"false" json:"replicationCredentials"` + + // Flag indicating whether historical metrics are collected for assets, originating from this asset source. + AreHistoricalMetricsCollected *bool `mandatory:"false" json:"areHistoricalMetricsCollected"` + + // Flag indicating whether real-time metrics are collected for assets, originating from this asset source. + AreRealtimeMetricsCollected *bool `mandatory:"false" json:"areRealtimeMetricsCollected"` + + // Flag indicating whether cost data collection is enabled for assets, originating from this asset source. + IsCostInformationCollected *bool `mandatory:"false" json:"isCostInformationCollected"` +} + +// GetDisplayName returns DisplayName +func (m CreateAwsAssetSourceDetails) GetDisplayName() *string { + return m.DisplayName +} + +// GetCompartmentId returns CompartmentId +func (m CreateAwsAssetSourceDetails) GetCompartmentId() *string { + return m.CompartmentId +} + +// GetEnvironmentId returns EnvironmentId +func (m CreateAwsAssetSourceDetails) GetEnvironmentId() *string { + return m.EnvironmentId +} + +// GetInventoryId returns InventoryId +func (m CreateAwsAssetSourceDetails) GetInventoryId() *string { + return m.InventoryId +} + +// GetAssetsCompartmentId returns AssetsCompartmentId +func (m CreateAwsAssetSourceDetails) GetAssetsCompartmentId() *string { + return m.AssetsCompartmentId +} + +// GetDiscoveryScheduleId returns DiscoveryScheduleId +func (m CreateAwsAssetSourceDetails) GetDiscoveryScheduleId() *string { + return m.DiscoveryScheduleId +} + +// GetFreeformTags returns FreeformTags +func (m CreateAwsAssetSourceDetails) GetFreeformTags() map[string]string { + return m.FreeformTags +} + +// GetDefinedTags returns DefinedTags +func (m CreateAwsAssetSourceDetails) GetDefinedTags() map[string]map[string]interface{} { + return m.DefinedTags +} + +// GetSystemTags returns SystemTags +func (m CreateAwsAssetSourceDetails) GetSystemTags() map[string]map[string]interface{} { + return m.SystemTags +} + +func (m CreateAwsAssetSourceDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m CreateAwsAssetSourceDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m CreateAwsAssetSourceDetails) MarshalJSON() (buff []byte, e error) { + type MarshalTypeCreateAwsAssetSourceDetails CreateAwsAssetSourceDetails + s := struct { + DiscriminatorParam string `json:"type"` + MarshalTypeCreateAwsAssetSourceDetails + }{ + "AWS", + (MarshalTypeCreateAwsAssetSourceDetails)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/create_aws_ebs_asset_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/create_aws_ebs_asset_details.go new file mode 100644 index 00000000000..e770cc81d3a --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/create_aws_ebs_asset_details.go @@ -0,0 +1,121 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// CreateAwsEbsAssetDetails Create AWS EBS type of asset. +type CreateAwsEbsAssetDetails struct { + + // Inventory ID to which an asset belongs. + InventoryId *string `mandatory:"true" json:"inventoryId"` + + // The OCID of the compartment that the asset belongs to. + CompartmentId *string `mandatory:"true" json:"compartmentId"` + + // The source key to which the asset belongs. + SourceKey *string `mandatory:"true" json:"sourceKey"` + + // The key of the asset from the external environment. + ExternalAssetKey *string `mandatory:"true" json:"externalAssetKey"` + + AwsEbs *AwsEbsProperties `mandatory:"true" json:"awsEbs"` + + // Asset display name. + DisplayName *string `mandatory:"false" json:"displayName"` + + // List of asset source OCID. + AssetSourceIds []string `mandatory:"false" json:"assetSourceIds"` + + // The freeform tags associated with this resource, if any. Each tag is a simple key-value pair with no + // predefined name, type, or namespace/scope. For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Department": "Finance"}` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + + // The defined tags associated with this resource, if any. Each key is predefined and scoped to namespaces. + // For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Operations": {"CostCenter": "42"}}` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` +} + +// GetDisplayName returns DisplayName +func (m CreateAwsEbsAssetDetails) GetDisplayName() *string { + return m.DisplayName +} + +// GetInventoryId returns InventoryId +func (m CreateAwsEbsAssetDetails) GetInventoryId() *string { + return m.InventoryId +} + +// GetCompartmentId returns CompartmentId +func (m CreateAwsEbsAssetDetails) GetCompartmentId() *string { + return m.CompartmentId +} + +// GetSourceKey returns SourceKey +func (m CreateAwsEbsAssetDetails) GetSourceKey() *string { + return m.SourceKey +} + +// GetExternalAssetKey returns ExternalAssetKey +func (m CreateAwsEbsAssetDetails) GetExternalAssetKey() *string { + return m.ExternalAssetKey +} + +// GetAssetSourceIds returns AssetSourceIds +func (m CreateAwsEbsAssetDetails) GetAssetSourceIds() []string { + return m.AssetSourceIds +} + +// GetFreeformTags returns FreeformTags +func (m CreateAwsEbsAssetDetails) GetFreeformTags() map[string]string { + return m.FreeformTags +} + +// GetDefinedTags returns DefinedTags +func (m CreateAwsEbsAssetDetails) GetDefinedTags() map[string]map[string]interface{} { + return m.DefinedTags +} + +func (m CreateAwsEbsAssetDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m CreateAwsEbsAssetDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m CreateAwsEbsAssetDetails) MarshalJSON() (buff []byte, e error) { + type MarshalTypeCreateAwsEbsAssetDetails CreateAwsEbsAssetDetails + s := struct { + DiscriminatorParam string `json:"assetType"` + MarshalTypeCreateAwsEbsAssetDetails + }{ + "AWS_EBS", + (MarshalTypeCreateAwsEbsAssetDetails)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/create_aws_ec2_asset_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/create_aws_ec2_asset_details.go new file mode 100644 index 00000000000..5f037132ca3 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/create_aws_ec2_asset_details.go @@ -0,0 +1,129 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// CreateAwsEc2AssetDetails Create AWS EC2 VM type of asset. +type CreateAwsEc2AssetDetails struct { + + // Inventory ID to which an asset belongs. + InventoryId *string `mandatory:"true" json:"inventoryId"` + + // The OCID of the compartment that the asset belongs to. + CompartmentId *string `mandatory:"true" json:"compartmentId"` + + // The source key to which the asset belongs. + SourceKey *string `mandatory:"true" json:"sourceKey"` + + // The key of the asset from the external environment. + ExternalAssetKey *string `mandatory:"true" json:"externalAssetKey"` + + Compute *ComputeProperties `mandatory:"true" json:"compute"` + + Vm *VmProperties `mandatory:"true" json:"vm"` + + AwsEc2 *AwsEc2Properties `mandatory:"true" json:"awsEc2"` + + // Asset display name. + DisplayName *string `mandatory:"false" json:"displayName"` + + // List of asset source OCID. + AssetSourceIds []string `mandatory:"false" json:"assetSourceIds"` + + // The freeform tags associated with this resource, if any. Each tag is a simple key-value pair with no + // predefined name, type, or namespace/scope. For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Department": "Finance"}` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + + // The defined tags associated with this resource, if any. Each key is predefined and scoped to namespaces. + // For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Operations": {"CostCenter": "42"}}` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` + + AwsEc2Cost *MonthlyCostSummary `mandatory:"false" json:"awsEc2Cost"` + + AttachedEbsVolumesCost *MonthlyCostSummary `mandatory:"false" json:"attachedEbsVolumesCost"` +} + +// GetDisplayName returns DisplayName +func (m CreateAwsEc2AssetDetails) GetDisplayName() *string { + return m.DisplayName +} + +// GetInventoryId returns InventoryId +func (m CreateAwsEc2AssetDetails) GetInventoryId() *string { + return m.InventoryId +} + +// GetCompartmentId returns CompartmentId +func (m CreateAwsEc2AssetDetails) GetCompartmentId() *string { + return m.CompartmentId +} + +// GetSourceKey returns SourceKey +func (m CreateAwsEc2AssetDetails) GetSourceKey() *string { + return m.SourceKey +} + +// GetExternalAssetKey returns ExternalAssetKey +func (m CreateAwsEc2AssetDetails) GetExternalAssetKey() *string { + return m.ExternalAssetKey +} + +// GetAssetSourceIds returns AssetSourceIds +func (m CreateAwsEc2AssetDetails) GetAssetSourceIds() []string { + return m.AssetSourceIds +} + +// GetFreeformTags returns FreeformTags +func (m CreateAwsEc2AssetDetails) GetFreeformTags() map[string]string { + return m.FreeformTags +} + +// GetDefinedTags returns DefinedTags +func (m CreateAwsEc2AssetDetails) GetDefinedTags() map[string]map[string]interface{} { + return m.DefinedTags +} + +func (m CreateAwsEc2AssetDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m CreateAwsEc2AssetDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m CreateAwsEc2AssetDetails) MarshalJSON() (buff []byte, e error) { + type MarshalTypeCreateAwsEc2AssetDetails CreateAwsEc2AssetDetails + s := struct { + DiscriminatorParam string `json:"assetType"` + MarshalTypeCreateAwsEc2AssetDetails + }{ + "AWS_EC2", + (MarshalTypeCreateAwsEc2AssetDetails)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/group_identifier.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/group_identifier.go new file mode 100644 index 00000000000..5f6cdc984d9 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/group_identifier.go @@ -0,0 +1,42 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// GroupIdentifier Describes a security group. +type GroupIdentifier struct { + + // The ID of the security group. + GroupKey *string `mandatory:"false" json:"groupKey"` + + // The name of the security group. + GroupName *string `mandatory:"false" json:"groupName"` +} + +func (m GroupIdentifier) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m GroupIdentifier) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_network_interface.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_network_interface.go new file mode 100644 index 00000000000..d081eae117d --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_network_interface.go @@ -0,0 +1,78 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// InstanceNetworkInterface Describes a network interface. +type InstanceNetworkInterface struct { + Association *InstanceNetworkInterfaceAssociation `mandatory:"false" json:"association"` + + Attachment *InstanceNetworkInterfaceAttachment `mandatory:"false" json:"attachment"` + + // The description. + Description *string `mandatory:"false" json:"description"` + + // The security groups. + SecurityGroups []GroupIdentifier `mandatory:"false" json:"securityGroups"` + + // The type of network interface. + InterfaceType *string `mandatory:"false" json:"interfaceType"` + + // The IPv4 delegated prefixes that are assigned to the network interface. + Ipv4Prefixes []string `mandatory:"false" json:"ipv4Prefixes"` + + // The IPv6 addresses associated with the network interface. + Ipv6Addresses []string `mandatory:"false" json:"ipv6Addresses"` + + // The IPv6 delegated prefixes that are assigned to the network interface. + Ipv6Prefixes []string `mandatory:"false" json:"ipv6Prefixes"` + + // The MAC address. + MacAddress *string `mandatory:"false" json:"macAddress"` + + // The ID of the network interface. + NetworkInterfaceKey *string `mandatory:"false" json:"networkInterfaceKey"` + + // The ID of the AWS account that created the network interface. + OwnerKey *string `mandatory:"false" json:"ownerKey"` + + // The private IPv4 addresses associated with the network interface. + PrivateIpAddresses []InstancePrivateIpAddress `mandatory:"false" json:"privateIpAddresses"` + + // Indicates whether source/destination checking is enabled. + IsSourceDestCheck *bool `mandatory:"false" json:"isSourceDestCheck"` + + // The status of the network interface. + Status *string `mandatory:"false" json:"status"` + + // The ID of the subnet. + SubnetKey *string `mandatory:"false" json:"subnetKey"` +} + +func (m InstanceNetworkInterface) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m InstanceNetworkInterface) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_network_interface_association.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_network_interface_association.go new file mode 100644 index 00000000000..5914e83db82 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_network_interface_association.go @@ -0,0 +1,51 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// InstanceNetworkInterfaceAssociation Describes association information for an Elastic IP address (IPv4). +type InstanceNetworkInterfaceAssociation struct { + + // The carrier IP address associated with the network interface. + CarrierIp *string `mandatory:"false" json:"carrierIp"` + + // The customer-owned IP address associated with the network interface. + CustomerOwnedIp *string `mandatory:"false" json:"customerOwnedIp"` + + // The ID of the owner of the Elastic IP address. + IpOwnerKey *string `mandatory:"false" json:"ipOwnerKey"` + + // The public DNS name. + PublicDnsName *string `mandatory:"false" json:"publicDnsName"` + + // The public IP address or Elastic IP address bound to the network interface. + PublicIp *string `mandatory:"false" json:"publicIp"` +} + +func (m InstanceNetworkInterfaceAssociation) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m InstanceNetworkInterfaceAssociation) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_network_interface_attachment.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_network_interface_attachment.go new file mode 100644 index 00000000000..c96dd9e2233 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_network_interface_attachment.go @@ -0,0 +1,54 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// InstanceNetworkInterfaceAttachment Describes a network interface attachment. +type InstanceNetworkInterfaceAttachment struct { + + // The ID of the network interface attachment. + AttachmentKey *string `mandatory:"false" json:"attachmentKey"` + + // The timestamp when the attachment initiated. + TimeAttach *common.SDKTime `mandatory:"false" json:"timeAttach"` + + // Indicates whether the network interface is deleted when the instance is terminated. + IsDeleteOnTermination *bool `mandatory:"false" json:"isDeleteOnTermination"` + + // The index of the device on the instance for the network interface attachment. + DeviceIndex *int `mandatory:"false" json:"deviceIndex"` + + // The index of the network card. + NetworkCardIndex *int `mandatory:"false" json:"networkCardIndex"` + + // The attachment state. + Status *string `mandatory:"false" json:"status"` +} + +func (m InstanceNetworkInterfaceAttachment) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m InstanceNetworkInterfaceAttachment) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_private_ip_address.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_private_ip_address.go new file mode 100644 index 00000000000..d7bca8576ce --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_private_ip_address.go @@ -0,0 +1,46 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// InstancePrivateIpAddress Describes a private IPv4 address. +type InstancePrivateIpAddress struct { + Association *InstanceNetworkInterfaceAssociation `mandatory:"false" json:"association"` + + // Indicates whether this IPv4 address is the primary private IP address of the network interface. + IsPrimary *bool `mandatory:"false" json:"isPrimary"` + + // The private IPv4 DNS name. + PrivateDnsName *string `mandatory:"false" json:"privateDnsName"` + + // The private IPv4 address of the network interface. + PrivateIpAddress *string `mandatory:"false" json:"privateIpAddress"` +} + +func (m InstancePrivateIpAddress) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m InstancePrivateIpAddress) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_state.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_state.go new file mode 100644 index 00000000000..3686f7f462e --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/instance_state.go @@ -0,0 +1,42 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// InstanceState Describes the current state of an instance. +type InstanceState struct { + + // The state of the instance as a 16-bit unsigned integer. + Code *int `mandatory:"false" json:"code"` + + // The current state of the instance. + Name *string `mandatory:"false" json:"name"` +} + +func (m InstanceState) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m InstanceState) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/list_supported_cloud_regions_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/list_supported_cloud_regions_request_response.go new file mode 100644 index 00000000000..7ba5887aaa9 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/list_supported_cloud_regions_request_response.go @@ -0,0 +1,241 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package cloudbridge + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// ListSupportedCloudRegionsRequest wrapper for the ListSupportedCloudRegions operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/cloudbridge/ListSupportedCloudRegions.go.html to see an example of how to use ListSupportedCloudRegionsRequest. +type ListSupportedCloudRegionsRequest struct { + + // The asset source type. + AssetSourceType ListSupportedCloudRegionsAssetSourceTypeEnum `mandatory:"false" contributesTo:"query" name:"assetSourceType" omitEmpty:"true"` + + // A filter to return only supported cloud regions which name contains given nameContains as sub-string. + NameContains *string `mandatory:"false" contributesTo:"query" name:"nameContains"` + + // The field to sort by. Only one sort order may be provided. By default, name is in ascending order. + SortBy ListSupportedCloudRegionsSortByEnum `mandatory:"false" contributesTo:"query" name:"sortBy" omitEmpty:"true"` + + // The sort order to use, either 'ASC' or 'DESC'. + SortOrder ListSupportedCloudRegionsSortOrderEnum `mandatory:"false" contributesTo:"query" name:"sortOrder" omitEmpty:"true"` + + // The maximum number of items to return. + Limit *int `mandatory:"false" contributesTo:"query" name:"limit"` + + // A token representing the position at which to start retrieving results. This must come from the `opc-next-page` header field of a previous response. + Page *string `mandatory:"false" contributesTo:"query" name:"page"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request ListSupportedCloudRegionsRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request ListSupportedCloudRegionsRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request ListSupportedCloudRegionsRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request ListSupportedCloudRegionsRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request ListSupportedCloudRegionsRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingListSupportedCloudRegionsAssetSourceTypeEnum(string(request.AssetSourceType)); !ok && request.AssetSourceType != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for AssetSourceType: %s. Supported values are: %s.", request.AssetSourceType, strings.Join(GetListSupportedCloudRegionsAssetSourceTypeEnumStringValues(), ","))) + } + if _, ok := GetMappingListSupportedCloudRegionsSortByEnum(string(request.SortBy)); !ok && request.SortBy != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for SortBy: %s. Supported values are: %s.", request.SortBy, strings.Join(GetListSupportedCloudRegionsSortByEnumStringValues(), ","))) + } + if _, ok := GetMappingListSupportedCloudRegionsSortOrderEnum(string(request.SortOrder)); !ok && request.SortOrder != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for SortOrder: %s. Supported values are: %s.", request.SortOrder, strings.Join(GetListSupportedCloudRegionsSortOrderEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// ListSupportedCloudRegionsResponse wrapper for the ListSupportedCloudRegions operation +type ListSupportedCloudRegionsResponse struct { + + // The underlying http response + RawResponse *http.Response + + // A list of SupportedCloudRegionCollection instances + SupportedCloudRegionCollection `presentIn:"body"` + + // Unique Oracle-assigned identifier for the request. If you need to contact + // Oracle about a particular request, please provide the request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // For pagination of a list of items. When paging through a list, if this header appears in the response, + // then a partial list might have been returned. Include this value as the `page` parameter for the + // subsequent GET request to get the next batch of items. + OpcNextPage *string `presentIn:"header" name:"opc-next-page"` +} + +func (response ListSupportedCloudRegionsResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response ListSupportedCloudRegionsResponse) HTTPResponse() *http.Response { + return response.RawResponse +} + +// ListSupportedCloudRegionsAssetSourceTypeEnum Enum with underlying type: string +type ListSupportedCloudRegionsAssetSourceTypeEnum string + +// Set of constants representing the allowable values for ListSupportedCloudRegionsAssetSourceTypeEnum +const ( + ListSupportedCloudRegionsAssetSourceTypeVmware ListSupportedCloudRegionsAssetSourceTypeEnum = "VMWARE" + ListSupportedCloudRegionsAssetSourceTypeAws ListSupportedCloudRegionsAssetSourceTypeEnum = "AWS" +) + +var mappingListSupportedCloudRegionsAssetSourceTypeEnum = map[string]ListSupportedCloudRegionsAssetSourceTypeEnum{ + "VMWARE": ListSupportedCloudRegionsAssetSourceTypeVmware, + "AWS": ListSupportedCloudRegionsAssetSourceTypeAws, +} + +var mappingListSupportedCloudRegionsAssetSourceTypeEnumLowerCase = map[string]ListSupportedCloudRegionsAssetSourceTypeEnum{ + "vmware": ListSupportedCloudRegionsAssetSourceTypeVmware, + "aws": ListSupportedCloudRegionsAssetSourceTypeAws, +} + +// GetListSupportedCloudRegionsAssetSourceTypeEnumValues Enumerates the set of values for ListSupportedCloudRegionsAssetSourceTypeEnum +func GetListSupportedCloudRegionsAssetSourceTypeEnumValues() []ListSupportedCloudRegionsAssetSourceTypeEnum { + values := make([]ListSupportedCloudRegionsAssetSourceTypeEnum, 0) + for _, v := range mappingListSupportedCloudRegionsAssetSourceTypeEnum { + values = append(values, v) + } + return values +} + +// GetListSupportedCloudRegionsAssetSourceTypeEnumStringValues Enumerates the set of values in String for ListSupportedCloudRegionsAssetSourceTypeEnum +func GetListSupportedCloudRegionsAssetSourceTypeEnumStringValues() []string { + return []string{ + "VMWARE", + "AWS", + } +} + +// GetMappingListSupportedCloudRegionsAssetSourceTypeEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListSupportedCloudRegionsAssetSourceTypeEnum(val string) (ListSupportedCloudRegionsAssetSourceTypeEnum, bool) { + enum, ok := mappingListSupportedCloudRegionsAssetSourceTypeEnumLowerCase[strings.ToLower(val)] + return enum, ok +} + +// ListSupportedCloudRegionsSortByEnum Enum with underlying type: string +type ListSupportedCloudRegionsSortByEnum string + +// Set of constants representing the allowable values for ListSupportedCloudRegionsSortByEnum +const ( + ListSupportedCloudRegionsSortByName ListSupportedCloudRegionsSortByEnum = "name" +) + +var mappingListSupportedCloudRegionsSortByEnum = map[string]ListSupportedCloudRegionsSortByEnum{ + "name": ListSupportedCloudRegionsSortByName, +} + +var mappingListSupportedCloudRegionsSortByEnumLowerCase = map[string]ListSupportedCloudRegionsSortByEnum{ + "name": ListSupportedCloudRegionsSortByName, +} + +// GetListSupportedCloudRegionsSortByEnumValues Enumerates the set of values for ListSupportedCloudRegionsSortByEnum +func GetListSupportedCloudRegionsSortByEnumValues() []ListSupportedCloudRegionsSortByEnum { + values := make([]ListSupportedCloudRegionsSortByEnum, 0) + for _, v := range mappingListSupportedCloudRegionsSortByEnum { + values = append(values, v) + } + return values +} + +// GetListSupportedCloudRegionsSortByEnumStringValues Enumerates the set of values in String for ListSupportedCloudRegionsSortByEnum +func GetListSupportedCloudRegionsSortByEnumStringValues() []string { + return []string{ + "name", + } +} + +// GetMappingListSupportedCloudRegionsSortByEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListSupportedCloudRegionsSortByEnum(val string) (ListSupportedCloudRegionsSortByEnum, bool) { + enum, ok := mappingListSupportedCloudRegionsSortByEnumLowerCase[strings.ToLower(val)] + return enum, ok +} + +// ListSupportedCloudRegionsSortOrderEnum Enum with underlying type: string +type ListSupportedCloudRegionsSortOrderEnum string + +// Set of constants representing the allowable values for ListSupportedCloudRegionsSortOrderEnum +const ( + ListSupportedCloudRegionsSortOrderAsc ListSupportedCloudRegionsSortOrderEnum = "ASC" + ListSupportedCloudRegionsSortOrderDesc ListSupportedCloudRegionsSortOrderEnum = "DESC" +) + +var mappingListSupportedCloudRegionsSortOrderEnum = map[string]ListSupportedCloudRegionsSortOrderEnum{ + "ASC": ListSupportedCloudRegionsSortOrderAsc, + "DESC": ListSupportedCloudRegionsSortOrderDesc, +} + +var mappingListSupportedCloudRegionsSortOrderEnumLowerCase = map[string]ListSupportedCloudRegionsSortOrderEnum{ + "asc": ListSupportedCloudRegionsSortOrderAsc, + "desc": ListSupportedCloudRegionsSortOrderDesc, +} + +// GetListSupportedCloudRegionsSortOrderEnumValues Enumerates the set of values for ListSupportedCloudRegionsSortOrderEnum +func GetListSupportedCloudRegionsSortOrderEnumValues() []ListSupportedCloudRegionsSortOrderEnum { + values := make([]ListSupportedCloudRegionsSortOrderEnum, 0) + for _, v := range mappingListSupportedCloudRegionsSortOrderEnum { + values = append(values, v) + } + return values +} + +// GetListSupportedCloudRegionsSortOrderEnumStringValues Enumerates the set of values in String for ListSupportedCloudRegionsSortOrderEnum +func GetListSupportedCloudRegionsSortOrderEnumStringValues() []string { + return []string{ + "ASC", + "DESC", + } +} + +// GetMappingListSupportedCloudRegionsSortOrderEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListSupportedCloudRegionsSortOrderEnum(val string) (ListSupportedCloudRegionsSortOrderEnum, bool) { + enum, ok := mappingListSupportedCloudRegionsSortOrderEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/monthly_cost_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/monthly_cost_summary.go new file mode 100644 index 00000000000..f8862adc49f --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/monthly_cost_summary.go @@ -0,0 +1,42 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// MonthlyCostSummary Cost information for monthly maintenance. +type MonthlyCostSummary struct { + + // Monthly costs for maintenance of this asset. + Amount *float64 `mandatory:"true" json:"amount"` + + // Currency code + CurrencyCode *string `mandatory:"true" json:"currencyCode"` +} + +func (m MonthlyCostSummary) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m MonthlyCostSummary) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/placement.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/placement.go new file mode 100644 index 00000000000..a0eeeef07b2 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/placement.go @@ -0,0 +1,60 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// Placement Describes the placement of an instance. +type Placement struct { + + // The affinity setting for the instance on the Dedicated Host. + Affinity *string `mandatory:"false" json:"affinity"` + + // The Availability Zone of the instance. + AvailabilityZone *string `mandatory:"false" json:"availabilityZone"` + + // The name of the placement group the instance is in. + GroupName *string `mandatory:"false" json:"groupName"` + + // The ID of the Dedicated Host on which the instance resides. + HostKey *string `mandatory:"false" json:"hostKey"` + + // The ARN of the host resource group in which to launch the instances. + HostResourceGroupArn *string `mandatory:"false" json:"hostResourceGroupArn"` + + // The number of the partition that the instance is in. + PartitionNumber *int `mandatory:"false" json:"partitionNumber"` + + // Reserved for future use. + SpreadDomain *string `mandatory:"false" json:"spreadDomain"` + + // The tenancy of the instance (if the instance is running in a VPC). + Tenancy *string `mandatory:"false" json:"tenancy"` +} + +func (m Placement) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m Placement) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/supported_cloud_region_collection.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/supported_cloud_region_collection.go new file mode 100644 index 00000000000..5ad3ca78a99 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/supported_cloud_region_collection.go @@ -0,0 +1,39 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// SupportedCloudRegionCollection Collection of supported cloud regions. +type SupportedCloudRegionCollection struct { + + // List of supported cloud regions. + Items []SupportedCloudRegionSummary `mandatory:"true" json:"items"` +} + +func (m SupportedCloudRegionCollection) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m SupportedCloudRegionCollection) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/supported_cloud_region_lifecycle_state.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/supported_cloud_region_lifecycle_state.go new file mode 100644 index 00000000000..95577bbb378 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/supported_cloud_region_lifecycle_state.go @@ -0,0 +1,56 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "strings" +) + +// SupportedCloudRegionLifecycleStateEnum Enum with underlying type: string +type SupportedCloudRegionLifecycleStateEnum string + +// Set of constants representing the allowable values for SupportedCloudRegionLifecycleStateEnum +const ( + SupportedCloudRegionLifecycleStateActive SupportedCloudRegionLifecycleStateEnum = "ACTIVE" + SupportedCloudRegionLifecycleStateInactive SupportedCloudRegionLifecycleStateEnum = "INACTIVE" +) + +var mappingSupportedCloudRegionLifecycleStateEnum = map[string]SupportedCloudRegionLifecycleStateEnum{ + "ACTIVE": SupportedCloudRegionLifecycleStateActive, + "INACTIVE": SupportedCloudRegionLifecycleStateInactive, +} + +var mappingSupportedCloudRegionLifecycleStateEnumLowerCase = map[string]SupportedCloudRegionLifecycleStateEnum{ + "active": SupportedCloudRegionLifecycleStateActive, + "inactive": SupportedCloudRegionLifecycleStateInactive, +} + +// GetSupportedCloudRegionLifecycleStateEnumValues Enumerates the set of values for SupportedCloudRegionLifecycleStateEnum +func GetSupportedCloudRegionLifecycleStateEnumValues() []SupportedCloudRegionLifecycleStateEnum { + values := make([]SupportedCloudRegionLifecycleStateEnum, 0) + for _, v := range mappingSupportedCloudRegionLifecycleStateEnum { + values = append(values, v) + } + return values +} + +// GetSupportedCloudRegionLifecycleStateEnumStringValues Enumerates the set of values in String for SupportedCloudRegionLifecycleStateEnum +func GetSupportedCloudRegionLifecycleStateEnumStringValues() []string { + return []string{ + "ACTIVE", + "INACTIVE", + } +} + +// GetMappingSupportedCloudRegionLifecycleStateEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingSupportedCloudRegionLifecycleStateEnum(val string) (SupportedCloudRegionLifecycleStateEnum, bool) { + enum, ok := mappingSupportedCloudRegionLifecycleStateEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/supported_cloud_region_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/supported_cloud_region_summary.go new file mode 100644 index 00000000000..1bcfb726af7 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/supported_cloud_region_summary.go @@ -0,0 +1,61 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// SupportedCloudRegionSummary Summary of the supported cloud region. +type SupportedCloudRegionSummary struct { + + // The asset source type associated with the supported cloud region. + AssetSourceType AssetSourceTypeEnum `mandatory:"true" json:"assetSourceType"` + + // The supported cloud region name. + Name *string `mandatory:"true" json:"name"` + + // The current state of the supported cloud region. + LifecycleState SupportedCloudRegionLifecycleStateEnum `mandatory:"true" json:"lifecycleState"` + + // The freeform tags associated with this resource, if any. Each tag is a simple key-value pair with no + // predefined name, type, or namespace/scope. For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Department": "Finance"}` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + + // The defined tags associated with this resource, if any. Each key is predefined and scoped to namespaces. + // For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Operations": {"CostCenter": "42"}}` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` +} + +func (m SupportedCloudRegionSummary) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m SupportedCloudRegionSummary) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingAssetSourceTypeEnum(string(m.AssetSourceType)); !ok && m.AssetSourceType != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for AssetSourceType: %s. Supported values are: %s.", m.AssetSourceType, strings.Join(GetAssetSourceTypeEnumStringValues(), ","))) + } + if _, ok := GetMappingSupportedCloudRegionLifecycleStateEnum(string(m.LifecycleState)); !ok && m.LifecycleState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", m.LifecycleState, strings.Join(GetSupportedCloudRegionLifecycleStateEnumStringValues(), ","))) + } + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/tag.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/tag.go new file mode 100644 index 00000000000..334284f8ada --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/tag.go @@ -0,0 +1,42 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// Tag Describes a tag. +type Tag struct { + + // The key of the tag. + Key *string `mandatory:"false" json:"key"` + + // The value of the tag. + Value *string `mandatory:"false" json:"value"` +} + +func (m Tag) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m Tag) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/update_aws_asset_source_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/update_aws_asset_source_details.go new file mode 100644 index 00000000000..3e483f60a94 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/update_aws_asset_source_details.go @@ -0,0 +1,119 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// UpdateAwsAssetSourceDetails AWS asset source update request. +type UpdateAwsAssetSourceDetails struct { + + // A user-friendly name for the asset source. Does not have to be unique, and it's mutable. + // Avoid entering confidential information. + DisplayName *string `mandatory:"false" json:"displayName"` + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the compartment that is going to be used to create assets. + AssetsCompartmentId *string `mandatory:"false" json:"assetsCompartmentId"` + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the discovery schedule that is going to be assigned to an asset source. + DiscoveryScheduleId *string `mandatory:"false" json:"discoveryScheduleId"` + + // The freeform tags associated with this resource, if any. Each tag is a simple key-value pair with no + // predefined name, type, or namespace/scope. For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Department": "Finance"}` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + + // The defined tags associated with this resource, if any. Each key is predefined and scoped to namespaces. + // For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Operations": {"CostCenter": "42"}}` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` + + // The system tags associated with this resource, if any. The system tags are set by Oracle cloud infrastructure services. Each key is predefined and scoped to namespaces. + // For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{orcl-cloud: {free-tier-retain: true}}` + SystemTags map[string]map[string]interface{} `mandatory:"false" json:"systemTags"` + + DiscoveryCredentials *AssetSourceCredentials `mandatory:"false" json:"discoveryCredentials"` + + ReplicationCredentials *AssetSourceCredentials `mandatory:"false" json:"replicationCredentials"` + + // Flag indicating whether historical metrics are collected for assets, originating from this asset source. + AreHistoricalMetricsCollected *bool `mandatory:"false" json:"areHistoricalMetricsCollected"` + + // Flag indicating whether real-time metrics are collected for assets, originating from this asset source. + AreRealtimeMetricsCollected *bool `mandatory:"false" json:"areRealtimeMetricsCollected"` + + // Flag indicating whether cost data collection is enabled for assets, originating from this asset source. + IsCostInformationCollected *bool `mandatory:"false" json:"isCostInformationCollected"` +} + +// GetDisplayName returns DisplayName +func (m UpdateAwsAssetSourceDetails) GetDisplayName() *string { + return m.DisplayName +} + +// GetAssetsCompartmentId returns AssetsCompartmentId +func (m UpdateAwsAssetSourceDetails) GetAssetsCompartmentId() *string { + return m.AssetsCompartmentId +} + +// GetDiscoveryScheduleId returns DiscoveryScheduleId +func (m UpdateAwsAssetSourceDetails) GetDiscoveryScheduleId() *string { + return m.DiscoveryScheduleId +} + +// GetFreeformTags returns FreeformTags +func (m UpdateAwsAssetSourceDetails) GetFreeformTags() map[string]string { + return m.FreeformTags +} + +// GetDefinedTags returns DefinedTags +func (m UpdateAwsAssetSourceDetails) GetDefinedTags() map[string]map[string]interface{} { + return m.DefinedTags +} + +// GetSystemTags returns SystemTags +func (m UpdateAwsAssetSourceDetails) GetSystemTags() map[string]map[string]interface{} { + return m.SystemTags +} + +func (m UpdateAwsAssetSourceDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m UpdateAwsAssetSourceDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m UpdateAwsAssetSourceDetails) MarshalJSON() (buff []byte, e error) { + type MarshalTypeUpdateAwsAssetSourceDetails UpdateAwsAssetSourceDetails + s := struct { + DiscriminatorParam string `json:"type"` + MarshalTypeUpdateAwsAssetSourceDetails + }{ + "AWS", + (MarshalTypeUpdateAwsAssetSourceDetails)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/update_aws_ebs_asset_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/update_aws_ebs_asset_details.go new file mode 100644 index 00000000000..e00f831c633 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/update_aws_ebs_asset_details.go @@ -0,0 +1,89 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// UpdateAwsEbsAssetDetails The information of AWS EBS asset to be updated. +type UpdateAwsEbsAssetDetails struct { + + // Asset display name. + DisplayName *string `mandatory:"false" json:"displayName"` + + // List of asset source OCID. + AssetSourceIds []string `mandatory:"false" json:"assetSourceIds"` + + // The freeform tags associated with this resource, if any. Each tag is a simple key-value pair with no + // predefined name, type, or namespace/scope. For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Department": "Finance"}` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + + // The defined tags associated with this resource, if any. Each key is predefined and scoped to namespaces. + // For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Operations": {"CostCenter": "42"}}` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` + + AwsEbs *AwsEbsProperties `mandatory:"false" json:"awsEbs"` +} + +// GetDisplayName returns DisplayName +func (m UpdateAwsEbsAssetDetails) GetDisplayName() *string { + return m.DisplayName +} + +// GetAssetSourceIds returns AssetSourceIds +func (m UpdateAwsEbsAssetDetails) GetAssetSourceIds() []string { + return m.AssetSourceIds +} + +// GetFreeformTags returns FreeformTags +func (m UpdateAwsEbsAssetDetails) GetFreeformTags() map[string]string { + return m.FreeformTags +} + +// GetDefinedTags returns DefinedTags +func (m UpdateAwsEbsAssetDetails) GetDefinedTags() map[string]map[string]interface{} { + return m.DefinedTags +} + +func (m UpdateAwsEbsAssetDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m UpdateAwsEbsAssetDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m UpdateAwsEbsAssetDetails) MarshalJSON() (buff []byte, e error) { + type MarshalTypeUpdateAwsEbsAssetDetails UpdateAwsEbsAssetDetails + s := struct { + DiscriminatorParam string `json:"assetType"` + MarshalTypeUpdateAwsEbsAssetDetails + }{ + "AWS_EBS", + (MarshalTypeUpdateAwsEbsAssetDetails)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/update_aws_ec2_asset_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/update_aws_ec2_asset_details.go new file mode 100644 index 00000000000..749f1dae786 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/update_aws_ec2_asset_details.go @@ -0,0 +1,97 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// UpdateAwsEc2AssetDetails The information of AWS VM asset to be updated. +type UpdateAwsEc2AssetDetails struct { + + // Asset display name. + DisplayName *string `mandatory:"false" json:"displayName"` + + // List of asset source OCID. + AssetSourceIds []string `mandatory:"false" json:"assetSourceIds"` + + // The freeform tags associated with this resource, if any. Each tag is a simple key-value pair with no + // predefined name, type, or namespace/scope. For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Department": "Finance"}` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + + // The defined tags associated with this resource, if any. Each key is predefined and scoped to namespaces. + // For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{"Operations": {"CostCenter": "42"}}` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` + + Compute *ComputeProperties `mandatory:"false" json:"compute"` + + Vm *VmProperties `mandatory:"false" json:"vm"` + + AwsEc2 *AwsEc2Properties `mandatory:"false" json:"awsEc2"` + + AwsEc2Cost *MonthlyCostSummary `mandatory:"false" json:"awsEc2Cost"` + + AttachedEbsVolumesCost *MonthlyCostSummary `mandatory:"false" json:"attachedEbsVolumesCost"` +} + +// GetDisplayName returns DisplayName +func (m UpdateAwsEc2AssetDetails) GetDisplayName() *string { + return m.DisplayName +} + +// GetAssetSourceIds returns AssetSourceIds +func (m UpdateAwsEc2AssetDetails) GetAssetSourceIds() []string { + return m.AssetSourceIds +} + +// GetFreeformTags returns FreeformTags +func (m UpdateAwsEc2AssetDetails) GetFreeformTags() map[string]string { + return m.FreeformTags +} + +// GetDefinedTags returns DefinedTags +func (m UpdateAwsEc2AssetDetails) GetDefinedTags() map[string]map[string]interface{} { + return m.DefinedTags +} + +func (m UpdateAwsEc2AssetDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m UpdateAwsEc2AssetDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m UpdateAwsEc2AssetDetails) MarshalJSON() (buff []byte, e error) { + type MarshalTypeUpdateAwsEc2AssetDetails UpdateAwsEc2AssetDetails + s := struct { + DiscriminatorParam string `json:"assetType"` + MarshalTypeUpdateAwsEc2AssetDetails + }{ + "AWS_EC2", + (MarshalTypeUpdateAwsEc2AssetDetails)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/volume_attachment.go b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/volume_attachment.go new file mode 100644 index 00000000000..54ffadb292a --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/cloudbridge/volume_attachment.go @@ -0,0 +1,51 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Oracle Cloud Bridge API +// +// API for Oracle Cloud Bridge service. +// + +package cloudbridge + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// VolumeAttachment Describes volume attachment details. +type VolumeAttachment struct { + + // Indicates whether the EBS volume is deleted on instance termination. + IsDeleteOnTermination *bool `mandatory:"false" json:"isDeleteOnTermination"` + + // The device name. + Device *string `mandatory:"false" json:"device"` + + // The ID of the instance. + InstanceKey *string `mandatory:"false" json:"instanceKey"` + + // The attachment state of the volume. + Status *string `mandatory:"false" json:"status"` + + // The ID of the volume. + VolumeKey *string `mandatory:"false" json:"volumeKey"` +} + +func (m VolumeAttachment) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m VolumeAttachment) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/common/version.go b/vendor/github.com/oracle/oci-go-sdk/v65/common/version.go index af27c280860..4ae2ce0c527 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/common/version.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/common/version.go @@ -12,7 +12,7 @@ import ( const ( major = "65" - minor = "79" + minor = "81" patch = "0" tag = "" ) diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/database/autonomous_database.go b/vendor/github.com/oracle/oci-go-sdk/v65/database/autonomous_database.go index d92a13bea33..3054e1cfff2 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/database/autonomous_database.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/database/autonomous_database.go @@ -149,6 +149,9 @@ type AutonomousDatabase struct { // The Autonomous Container Database OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm). Used only by Autonomous Database on Dedicated Exadata Infrastructure. AutonomousContainerDatabaseId *string `mandatory:"false" json:"autonomousContainerDatabaseId"` + // Indicates if the Autonomous Database is backup retention locked. + IsBackupRetentionLocked *bool `mandatory:"false" json:"isBackupRetentionLocked"` + // The date and time the Autonomous Database was most recently undeleted. TimeUndeleted *common.SDKTime `mandatory:"false" json:"timeUndeleted"` @@ -577,6 +580,7 @@ func (m *AutonomousDatabase) UnmarshalJSON(data []byte) (e error) { InfrastructureType AutonomousDatabaseInfrastructureTypeEnum `json:"infrastructureType"` IsDedicated *bool `json:"isDedicated"` AutonomousContainerDatabaseId *string `json:"autonomousContainerDatabaseId"` + IsBackupRetentionLocked *bool `json:"isBackupRetentionLocked"` TimeUndeleted *common.SDKTime `json:"timeUndeleted"` TimeCreated *common.SDKTime `json:"timeCreated"` DisplayName *string `json:"displayName"` @@ -749,6 +753,8 @@ func (m *AutonomousDatabase) UnmarshalJSON(data []byte) (e error) { m.AutonomousContainerDatabaseId = model.AutonomousContainerDatabaseId + m.IsBackupRetentionLocked = model.IsBackupRetentionLocked + m.TimeUndeleted = model.TimeUndeleted m.TimeCreated = model.TimeCreated diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/database/autonomous_database_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/database/autonomous_database_summary.go index ee2c0787c36..90f7039dd03 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/database/autonomous_database_summary.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/database/autonomous_database_summary.go @@ -151,6 +151,9 @@ type AutonomousDatabaseSummary struct { // The Autonomous Container Database OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm). Used only by Autonomous Database on Dedicated Exadata Infrastructure. AutonomousContainerDatabaseId *string `mandatory:"false" json:"autonomousContainerDatabaseId"` + // Indicates if the Autonomous Database is backup retention locked. + IsBackupRetentionLocked *bool `mandatory:"false" json:"isBackupRetentionLocked"` + // The date and time the Autonomous Database was most recently undeleted. TimeUndeleted *common.SDKTime `mandatory:"false" json:"timeUndeleted"` @@ -579,6 +582,7 @@ func (m *AutonomousDatabaseSummary) UnmarshalJSON(data []byte) (e error) { InfrastructureType AutonomousDatabaseSummaryInfrastructureTypeEnum `json:"infrastructureType"` IsDedicated *bool `json:"isDedicated"` AutonomousContainerDatabaseId *string `json:"autonomousContainerDatabaseId"` + IsBackupRetentionLocked *bool `json:"isBackupRetentionLocked"` TimeUndeleted *common.SDKTime `json:"timeUndeleted"` TimeCreated *common.SDKTime `json:"timeCreated"` DisplayName *string `json:"displayName"` @@ -751,6 +755,8 @@ func (m *AutonomousDatabaseSummary) UnmarshalJSON(data []byte) (e error) { m.AutonomousContainerDatabaseId = model.AutonomousContainerDatabaseId + m.IsBackupRetentionLocked = model.IsBackupRetentionLocked + m.TimeUndeleted = model.TimeUndeleted m.TimeCreated = model.TimeCreated diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_base.go b/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_base.go index 763beecef49..c635edcc3d6 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_base.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_base.go @@ -256,6 +256,9 @@ type CreateAutonomousDatabaseBase interface { // This cannot be updated in parallel with any of the following: licenseModel, dbEdition, cpuCoreCount, computeCount, computeModel, whitelistedIps, isMTLSConnectionRequired, openMode, permissionLevel, dbWorkload, privateEndpointLabel, nsgIds, dbVersion, isRefreshable, dbName, scheduledOperations, isLocalDataGuardEnabled, or isFreeTier. GetDbToolsDetails() []DatabaseTool + // True if the Autonomous Database is backup retention locked. + GetIsBackupRetentionLocked() *bool + // The OCI vault secret [/Content/General/Concepts/identifiers.htm]OCID. // This cannot be used in conjunction with adminPassword. GetSecretId() *string @@ -315,6 +318,7 @@ type createautonomousdatabasebase struct { IsAutoScalingForStorageEnabled *bool `mandatory:"false" json:"isAutoScalingForStorageEnabled"` DatabaseEdition AutonomousDatabaseSummaryDatabaseEditionEnum `mandatory:"false" json:"databaseEdition,omitempty"` DbToolsDetails []DatabaseTool `mandatory:"false" json:"dbToolsDetails"` + IsBackupRetentionLocked *bool `mandatory:"false" json:"isBackupRetentionLocked"` SecretId *string `mandatory:"false" json:"secretId"` SecretVersionNumber *int `mandatory:"false" json:"secretVersionNumber"` CompartmentId *string `mandatory:"true" json:"compartmentId"` @@ -382,6 +386,7 @@ func (m *createautonomousdatabasebase) UnmarshalJSON(data []byte) error { m.IsAutoScalingForStorageEnabled = s.Model.IsAutoScalingForStorageEnabled m.DatabaseEdition = s.Model.DatabaseEdition m.DbToolsDetails = s.Model.DbToolsDetails + m.IsBackupRetentionLocked = s.Model.IsBackupRetentionLocked m.SecretId = s.Model.SecretId m.SecretVersionNumber = s.Model.SecretVersionNumber m.Source = s.Model.Source @@ -685,6 +690,11 @@ func (m createautonomousdatabasebase) GetDbToolsDetails() []DatabaseTool { return m.DbToolsDetails } +// GetIsBackupRetentionLocked returns IsBackupRetentionLocked +func (m createautonomousdatabasebase) GetIsBackupRetentionLocked() *bool { + return m.IsBackupRetentionLocked +} + // GetSecretId returns SecretId func (m createautonomousdatabasebase) GetSecretId() *string { return m.SecretId diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_clone_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_clone_details.go index d99284791fa..1a39cbda25d 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_clone_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_clone_details.go @@ -227,6 +227,9 @@ type CreateAutonomousDatabaseCloneDetails struct { // This cannot be updated in parallel with any of the following: licenseModel, dbEdition, cpuCoreCount, computeCount, computeModel, whitelistedIps, isMTLSConnectionRequired, openMode, permissionLevel, dbWorkload, privateEndpointLabel, nsgIds, dbVersion, isRefreshable, dbName, scheduledOperations, isLocalDataGuardEnabled, or isFreeTier. DbToolsDetails []DatabaseTool `mandatory:"false" json:"dbToolsDetails"` + // True if the Autonomous Database is backup retention locked. + IsBackupRetentionLocked *bool `mandatory:"false" json:"isBackupRetentionLocked"` + // The OCI vault secret [/Content/General/Concepts/identifiers.htm]OCID. // This cannot be used in conjunction with adminPassword. SecretId *string `mandatory:"false" json:"secretId"` @@ -513,6 +516,11 @@ func (m CreateAutonomousDatabaseCloneDetails) GetDbToolsDetails() []DatabaseTool return m.DbToolsDetails } +// GetIsBackupRetentionLocked returns IsBackupRetentionLocked +func (m CreateAutonomousDatabaseCloneDetails) GetIsBackupRetentionLocked() *bool { + return m.IsBackupRetentionLocked +} + // GetSecretId returns SecretId func (m CreateAutonomousDatabaseCloneDetails) GetSecretId() *string { return m.SecretId @@ -623,6 +631,7 @@ func (m *CreateAutonomousDatabaseCloneDetails) UnmarshalJSON(data []byte) (e err IsAutoScalingForStorageEnabled *bool `json:"isAutoScalingForStorageEnabled"` DatabaseEdition AutonomousDatabaseSummaryDatabaseEditionEnum `json:"databaseEdition"` DbToolsDetails []DatabaseTool `json:"dbToolsDetails"` + IsBackupRetentionLocked *bool `json:"isBackupRetentionLocked"` SecretId *string `json:"secretId"` SecretVersionNumber *int `json:"secretVersionNumber"` CompartmentId *string `json:"compartmentId"` @@ -741,6 +750,8 @@ func (m *CreateAutonomousDatabaseCloneDetails) UnmarshalJSON(data []byte) (e err m.DbToolsDetails = make([]DatabaseTool, len(model.DbToolsDetails)) copy(m.DbToolsDetails, model.DbToolsDetails) + m.IsBackupRetentionLocked = model.IsBackupRetentionLocked + m.SecretId = model.SecretId m.SecretVersionNumber = model.SecretVersionNumber diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_details.go index a5a4568484d..55dda4e0dd6 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_details.go @@ -224,6 +224,9 @@ type CreateAutonomousDatabaseDetails struct { // This cannot be updated in parallel with any of the following: licenseModel, dbEdition, cpuCoreCount, computeCount, computeModel, whitelistedIps, isMTLSConnectionRequired, openMode, permissionLevel, dbWorkload, privateEndpointLabel, nsgIds, dbVersion, isRefreshable, dbName, scheduledOperations, isLocalDataGuardEnabled, or isFreeTier. DbToolsDetails []DatabaseTool `mandatory:"false" json:"dbToolsDetails"` + // True if the Autonomous Database is backup retention locked. + IsBackupRetentionLocked *bool `mandatory:"false" json:"isBackupRetentionLocked"` + // The OCI vault secret [/Content/General/Concepts/identifiers.htm]OCID. // This cannot be used in conjunction with adminPassword. SecretId *string `mandatory:"false" json:"secretId"` @@ -507,6 +510,11 @@ func (m CreateAutonomousDatabaseDetails) GetDbToolsDetails() []DatabaseTool { return m.DbToolsDetails } +// GetIsBackupRetentionLocked returns IsBackupRetentionLocked +func (m CreateAutonomousDatabaseDetails) GetIsBackupRetentionLocked() *bool { + return m.IsBackupRetentionLocked +} + // GetSecretId returns SecretId func (m CreateAutonomousDatabaseDetails) GetSecretId() *string { return m.SecretId @@ -614,6 +622,7 @@ func (m *CreateAutonomousDatabaseDetails) UnmarshalJSON(data []byte) (e error) { IsAutoScalingForStorageEnabled *bool `json:"isAutoScalingForStorageEnabled"` DatabaseEdition AutonomousDatabaseSummaryDatabaseEditionEnum `json:"databaseEdition"` DbToolsDetails []DatabaseTool `json:"dbToolsDetails"` + IsBackupRetentionLocked *bool `json:"isBackupRetentionLocked"` SecretId *string `json:"secretId"` SecretVersionNumber *int `json:"secretVersionNumber"` CompartmentId *string `json:"compartmentId"` @@ -730,6 +739,8 @@ func (m *CreateAutonomousDatabaseDetails) UnmarshalJSON(data []byte) (e error) { m.DbToolsDetails = make([]DatabaseTool, len(model.DbToolsDetails)) copy(m.DbToolsDetails, model.DbToolsDetails) + m.IsBackupRetentionLocked = model.IsBackupRetentionLocked + m.SecretId = model.SecretId m.SecretVersionNumber = model.SecretVersionNumber diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_from_backup_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_from_backup_details.go index 77d8b49f073..6fb5867212b 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_from_backup_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_from_backup_details.go @@ -227,6 +227,9 @@ type CreateAutonomousDatabaseFromBackupDetails struct { // This cannot be updated in parallel with any of the following: licenseModel, dbEdition, cpuCoreCount, computeCount, computeModel, whitelistedIps, isMTLSConnectionRequired, openMode, permissionLevel, dbWorkload, privateEndpointLabel, nsgIds, dbVersion, isRefreshable, dbName, scheduledOperations, isLocalDataGuardEnabled, or isFreeTier. DbToolsDetails []DatabaseTool `mandatory:"false" json:"dbToolsDetails"` + // True if the Autonomous Database is backup retention locked. + IsBackupRetentionLocked *bool `mandatory:"false" json:"isBackupRetentionLocked"` + // The OCI vault secret [/Content/General/Concepts/identifiers.htm]OCID. // This cannot be used in conjunction with adminPassword. SecretId *string `mandatory:"false" json:"secretId"` @@ -513,6 +516,11 @@ func (m CreateAutonomousDatabaseFromBackupDetails) GetDbToolsDetails() []Databas return m.DbToolsDetails } +// GetIsBackupRetentionLocked returns IsBackupRetentionLocked +func (m CreateAutonomousDatabaseFromBackupDetails) GetIsBackupRetentionLocked() *bool { + return m.IsBackupRetentionLocked +} + // GetSecretId returns SecretId func (m CreateAutonomousDatabaseFromBackupDetails) GetSecretId() *string { return m.SecretId @@ -623,6 +631,7 @@ func (m *CreateAutonomousDatabaseFromBackupDetails) UnmarshalJSON(data []byte) ( IsAutoScalingForStorageEnabled *bool `json:"isAutoScalingForStorageEnabled"` DatabaseEdition AutonomousDatabaseSummaryDatabaseEditionEnum `json:"databaseEdition"` DbToolsDetails []DatabaseTool `json:"dbToolsDetails"` + IsBackupRetentionLocked *bool `json:"isBackupRetentionLocked"` SecretId *string `json:"secretId"` SecretVersionNumber *int `json:"secretVersionNumber"` CompartmentId *string `json:"compartmentId"` @@ -741,6 +750,8 @@ func (m *CreateAutonomousDatabaseFromBackupDetails) UnmarshalJSON(data []byte) ( m.DbToolsDetails = make([]DatabaseTool, len(model.DbToolsDetails)) copy(m.DbToolsDetails, model.DbToolsDetails) + m.IsBackupRetentionLocked = model.IsBackupRetentionLocked + m.SecretId = model.SecretId m.SecretVersionNumber = model.SecretVersionNumber diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_from_backup_timestamp_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_from_backup_timestamp_details.go index 88605268863..8374ed57d3d 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_from_backup_timestamp_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/database/create_autonomous_database_from_backup_timestamp_details.go @@ -227,6 +227,9 @@ type CreateAutonomousDatabaseFromBackupTimestampDetails struct { // This cannot be updated in parallel with any of the following: licenseModel, dbEdition, cpuCoreCount, computeCount, computeModel, whitelistedIps, isMTLSConnectionRequired, openMode, permissionLevel, dbWorkload, privateEndpointLabel, nsgIds, dbVersion, isRefreshable, dbName, scheduledOperations, isLocalDataGuardEnabled, or isFreeTier. DbToolsDetails []DatabaseTool `mandatory:"false" json:"dbToolsDetails"` + // True if the Autonomous Database is backup retention locked. + IsBackupRetentionLocked *bool `mandatory:"false" json:"isBackupRetentionLocked"` + // The OCI vault secret [/Content/General/Concepts/identifiers.htm]OCID. // This cannot be used in conjunction with adminPassword. SecretId *string `mandatory:"false" json:"secretId"` @@ -519,6 +522,11 @@ func (m CreateAutonomousDatabaseFromBackupTimestampDetails) GetDbToolsDetails() return m.DbToolsDetails } +// GetIsBackupRetentionLocked returns IsBackupRetentionLocked +func (m CreateAutonomousDatabaseFromBackupTimestampDetails) GetIsBackupRetentionLocked() *bool { + return m.IsBackupRetentionLocked +} + // GetSecretId returns SecretId func (m CreateAutonomousDatabaseFromBackupTimestampDetails) GetSecretId() *string { return m.SecretId @@ -629,6 +637,7 @@ func (m *CreateAutonomousDatabaseFromBackupTimestampDetails) UnmarshalJSON(data IsAutoScalingForStorageEnabled *bool `json:"isAutoScalingForStorageEnabled"` DatabaseEdition AutonomousDatabaseSummaryDatabaseEditionEnum `json:"databaseEdition"` DbToolsDetails []DatabaseTool `json:"dbToolsDetails"` + IsBackupRetentionLocked *bool `json:"isBackupRetentionLocked"` SecretId *string `json:"secretId"` SecretVersionNumber *int `json:"secretVersionNumber"` Timestamp *common.SDKTime `json:"timestamp"` @@ -749,6 +758,8 @@ func (m *CreateAutonomousDatabaseFromBackupTimestampDetails) UnmarshalJSON(data m.DbToolsDetails = make([]DatabaseTool, len(model.DbToolsDetails)) copy(m.DbToolsDetails, model.DbToolsDetails) + m.IsBackupRetentionLocked = model.IsBackupRetentionLocked + m.SecretId = model.SecretId m.SecretVersionNumber = model.SecretVersionNumber diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/database/create_cross_region_autonomous_database_data_guard_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/database/create_cross_region_autonomous_database_data_guard_details.go index 3a2a0f802f8..2ed619b14cc 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/database/create_cross_region_autonomous_database_data_guard_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/database/create_cross_region_autonomous_database_data_guard_details.go @@ -246,6 +246,9 @@ type CreateCrossRegionAutonomousDatabaseDataGuardDetails struct { // This cannot be updated in parallel with any of the following: licenseModel, dbEdition, cpuCoreCount, computeCount, computeModel, whitelistedIps, isMTLSConnectionRequired, openMode, permissionLevel, dbWorkload, privateEndpointLabel, nsgIds, dbVersion, isRefreshable, dbName, scheduledOperations, isLocalDataGuardEnabled, or isFreeTier. DbToolsDetails []DatabaseTool `mandatory:"false" json:"dbToolsDetails"` + // True if the Autonomous Database is backup retention locked. + IsBackupRetentionLocked *bool `mandatory:"false" json:"isBackupRetentionLocked"` + // The OCI vault secret [/Content/General/Concepts/identifiers.htm]OCID. // This cannot be used in conjunction with adminPassword. SecretId *string `mandatory:"false" json:"secretId"` @@ -529,6 +532,11 @@ func (m CreateCrossRegionAutonomousDatabaseDataGuardDetails) GetDbToolsDetails() return m.DbToolsDetails } +// GetIsBackupRetentionLocked returns IsBackupRetentionLocked +func (m CreateCrossRegionAutonomousDatabaseDataGuardDetails) GetIsBackupRetentionLocked() *bool { + return m.IsBackupRetentionLocked +} + // GetSecretId returns SecretId func (m CreateCrossRegionAutonomousDatabaseDataGuardDetails) GetSecretId() *string { return m.SecretId @@ -636,6 +644,7 @@ func (m *CreateCrossRegionAutonomousDatabaseDataGuardDetails) UnmarshalJSON(data IsAutoScalingForStorageEnabled *bool `json:"isAutoScalingForStorageEnabled"` DatabaseEdition AutonomousDatabaseSummaryDatabaseEditionEnum `json:"databaseEdition"` DbToolsDetails []DatabaseTool `json:"dbToolsDetails"` + IsBackupRetentionLocked *bool `json:"isBackupRetentionLocked"` SecretId *string `json:"secretId"` SecretVersionNumber *int `json:"secretVersionNumber"` CompartmentId *string `json:"compartmentId"` @@ -753,6 +762,8 @@ func (m *CreateCrossRegionAutonomousDatabaseDataGuardDetails) UnmarshalJSON(data m.DbToolsDetails = make([]DatabaseTool, len(model.DbToolsDetails)) copy(m.DbToolsDetails, model.DbToolsDetails) + m.IsBackupRetentionLocked = model.IsBackupRetentionLocked + m.SecretId = model.SecretId m.SecretVersionNumber = model.SecretVersionNumber diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/database/create_cross_region_disaster_recovery_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/database/create_cross_region_disaster_recovery_details.go index 9c5f1974636..fb29e6dc880 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/database/create_cross_region_disaster_recovery_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/database/create_cross_region_disaster_recovery_details.go @@ -248,6 +248,9 @@ type CreateCrossRegionDisasterRecoveryDetails struct { // This cannot be updated in parallel with any of the following: licenseModel, dbEdition, cpuCoreCount, computeCount, computeModel, whitelistedIps, isMTLSConnectionRequired, openMode, permissionLevel, dbWorkload, privateEndpointLabel, nsgIds, dbVersion, isRefreshable, dbName, scheduledOperations, isLocalDataGuardEnabled, or isFreeTier. DbToolsDetails []DatabaseTool `mandatory:"false" json:"dbToolsDetails"` + // True if the Autonomous Database is backup retention locked. + IsBackupRetentionLocked *bool `mandatory:"false" json:"isBackupRetentionLocked"` + // The OCI vault secret [/Content/General/Concepts/identifiers.htm]OCID. // This cannot be used in conjunction with adminPassword. SecretId *string `mandatory:"false" json:"secretId"` @@ -539,6 +542,11 @@ func (m CreateCrossRegionDisasterRecoveryDetails) GetDbToolsDetails() []Database return m.DbToolsDetails } +// GetIsBackupRetentionLocked returns IsBackupRetentionLocked +func (m CreateCrossRegionDisasterRecoveryDetails) GetIsBackupRetentionLocked() *bool { + return m.IsBackupRetentionLocked +} + // GetSecretId returns SecretId func (m CreateCrossRegionDisasterRecoveryDetails) GetSecretId() *string { return m.SecretId @@ -649,6 +657,7 @@ func (m *CreateCrossRegionDisasterRecoveryDetails) UnmarshalJSON(data []byte) (e IsAutoScalingForStorageEnabled *bool `json:"isAutoScalingForStorageEnabled"` DatabaseEdition AutonomousDatabaseSummaryDatabaseEditionEnum `json:"databaseEdition"` DbToolsDetails []DatabaseTool `json:"dbToolsDetails"` + IsBackupRetentionLocked *bool `json:"isBackupRetentionLocked"` SecretId *string `json:"secretId"` SecretVersionNumber *int `json:"secretVersionNumber"` IsReplicateAutomaticBackups *bool `json:"isReplicateAutomaticBackups"` @@ -768,6 +777,8 @@ func (m *CreateCrossRegionDisasterRecoveryDetails) UnmarshalJSON(data []byte) (e m.DbToolsDetails = make([]DatabaseTool, len(model.DbToolsDetails)) copy(m.DbToolsDetails, model.DbToolsDetails) + m.IsBackupRetentionLocked = model.IsBackupRetentionLocked + m.SecretId = model.SecretId m.SecretVersionNumber = model.SecretVersionNumber diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/database/create_cross_tenancy_disaster_recovery_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/database/create_cross_tenancy_disaster_recovery_details.go index cd2b8b5493f..de574b03a80 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/database/create_cross_tenancy_disaster_recovery_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/database/create_cross_tenancy_disaster_recovery_details.go @@ -249,6 +249,9 @@ type CreateCrossTenancyDisasterRecoveryDetails struct { // This cannot be updated in parallel with any of the following: licenseModel, dbEdition, cpuCoreCount, computeCount, computeModel, whitelistedIps, isMTLSConnectionRequired, openMode, permissionLevel, dbWorkload, privateEndpointLabel, nsgIds, dbVersion, isRefreshable, dbName, scheduledOperations, isLocalDataGuardEnabled, or isFreeTier. DbToolsDetails []DatabaseTool `mandatory:"false" json:"dbToolsDetails"` + // True if the Autonomous Database is backup retention locked. + IsBackupRetentionLocked *bool `mandatory:"false" json:"isBackupRetentionLocked"` + // The OCI vault secret [/Content/General/Concepts/identifiers.htm]OCID. // This cannot be used in conjunction with adminPassword. SecretId *string `mandatory:"false" json:"secretId"` @@ -540,6 +543,11 @@ func (m CreateCrossTenancyDisasterRecoveryDetails) GetDbToolsDetails() []Databas return m.DbToolsDetails } +// GetIsBackupRetentionLocked returns IsBackupRetentionLocked +func (m CreateCrossTenancyDisasterRecoveryDetails) GetIsBackupRetentionLocked() *bool { + return m.IsBackupRetentionLocked +} + // GetSecretId returns SecretId func (m CreateCrossTenancyDisasterRecoveryDetails) GetSecretId() *string { return m.SecretId @@ -650,6 +658,7 @@ func (m *CreateCrossTenancyDisasterRecoveryDetails) UnmarshalJSON(data []byte) ( IsAutoScalingForStorageEnabled *bool `json:"isAutoScalingForStorageEnabled"` DatabaseEdition AutonomousDatabaseSummaryDatabaseEditionEnum `json:"databaseEdition"` DbToolsDetails []DatabaseTool `json:"dbToolsDetails"` + IsBackupRetentionLocked *bool `json:"isBackupRetentionLocked"` SecretId *string `json:"secretId"` SecretVersionNumber *int `json:"secretVersionNumber"` IsReplicateAutomaticBackups *bool `json:"isReplicateAutomaticBackups"` @@ -769,6 +778,8 @@ func (m *CreateCrossTenancyDisasterRecoveryDetails) UnmarshalJSON(data []byte) ( m.DbToolsDetails = make([]DatabaseTool, len(model.DbToolsDetails)) copy(m.DbToolsDetails, model.DbToolsDetails) + m.IsBackupRetentionLocked = model.IsBackupRetentionLocked + m.SecretId = model.SecretId m.SecretVersionNumber = model.SecretVersionNumber diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/database/create_refreshable_autonomous_database_clone_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/database/create_refreshable_autonomous_database_clone_details.go index bba3afa6886..baa9f9c7b07 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/database/create_refreshable_autonomous_database_clone_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/database/create_refreshable_autonomous_database_clone_details.go @@ -227,6 +227,9 @@ type CreateRefreshableAutonomousDatabaseCloneDetails struct { // This cannot be updated in parallel with any of the following: licenseModel, dbEdition, cpuCoreCount, computeCount, computeModel, whitelistedIps, isMTLSConnectionRequired, openMode, permissionLevel, dbWorkload, privateEndpointLabel, nsgIds, dbVersion, isRefreshable, dbName, scheduledOperations, isLocalDataGuardEnabled, or isFreeTier. DbToolsDetails []DatabaseTool `mandatory:"false" json:"dbToolsDetails"` + // True if the Autonomous Database is backup retention locked. + IsBackupRetentionLocked *bool `mandatory:"false" json:"isBackupRetentionLocked"` + // The OCI vault secret [/Content/General/Concepts/identifiers.htm]OCID. // This cannot be used in conjunction with adminPassword. SecretId *string `mandatory:"false" json:"secretId"` @@ -526,6 +529,11 @@ func (m CreateRefreshableAutonomousDatabaseCloneDetails) GetDbToolsDetails() []D return m.DbToolsDetails } +// GetIsBackupRetentionLocked returns IsBackupRetentionLocked +func (m CreateRefreshableAutonomousDatabaseCloneDetails) GetIsBackupRetentionLocked() *bool { + return m.IsBackupRetentionLocked +} + // GetSecretId returns SecretId func (m CreateRefreshableAutonomousDatabaseCloneDetails) GetSecretId() *string { return m.SecretId @@ -639,6 +647,7 @@ func (m *CreateRefreshableAutonomousDatabaseCloneDetails) UnmarshalJSON(data []b IsAutoScalingForStorageEnabled *bool `json:"isAutoScalingForStorageEnabled"` DatabaseEdition AutonomousDatabaseSummaryDatabaseEditionEnum `json:"databaseEdition"` DbToolsDetails []DatabaseTool `json:"dbToolsDetails"` + IsBackupRetentionLocked *bool `json:"isBackupRetentionLocked"` SecretId *string `json:"secretId"` SecretVersionNumber *int `json:"secretVersionNumber"` RefreshableMode CreateRefreshableAutonomousDatabaseCloneDetailsRefreshableModeEnum `json:"refreshableMode"` @@ -761,6 +770,8 @@ func (m *CreateRefreshableAutonomousDatabaseCloneDetails) UnmarshalJSON(data []b m.DbToolsDetails = make([]DatabaseTool, len(model.DbToolsDetails)) copy(m.DbToolsDetails, model.DbToolsDetails) + m.IsBackupRetentionLocked = model.IsBackupRetentionLocked + m.SecretId = model.SecretId m.SecretVersionNumber = model.SecretVersionNumber diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/database/undelete_autonomous_database_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/database/undelete_autonomous_database_details.go index dde044f2114..01fe35a162e 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/database/undelete_autonomous_database_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/database/undelete_autonomous_database_details.go @@ -227,6 +227,9 @@ type UndeleteAutonomousDatabaseDetails struct { // This cannot be updated in parallel with any of the following: licenseModel, dbEdition, cpuCoreCount, computeCount, computeModel, whitelistedIps, isMTLSConnectionRequired, openMode, permissionLevel, dbWorkload, privateEndpointLabel, nsgIds, dbVersion, isRefreshable, dbName, scheduledOperations, isLocalDataGuardEnabled, or isFreeTier. DbToolsDetails []DatabaseTool `mandatory:"false" json:"dbToolsDetails"` + // True if the Autonomous Database is backup retention locked. + IsBackupRetentionLocked *bool `mandatory:"false" json:"isBackupRetentionLocked"` + // The OCI vault secret [/Content/General/Concepts/identifiers.htm]OCID. // This cannot be used in conjunction with adminPassword. SecretId *string `mandatory:"false" json:"secretId"` @@ -510,6 +513,11 @@ func (m UndeleteAutonomousDatabaseDetails) GetDbToolsDetails() []DatabaseTool { return m.DbToolsDetails } +// GetIsBackupRetentionLocked returns IsBackupRetentionLocked +func (m UndeleteAutonomousDatabaseDetails) GetIsBackupRetentionLocked() *bool { + return m.IsBackupRetentionLocked +} + // GetSecretId returns SecretId func (m UndeleteAutonomousDatabaseDetails) GetSecretId() *string { return m.SecretId @@ -617,6 +625,7 @@ func (m *UndeleteAutonomousDatabaseDetails) UnmarshalJSON(data []byte) (e error) IsAutoScalingForStorageEnabled *bool `json:"isAutoScalingForStorageEnabled"` DatabaseEdition AutonomousDatabaseSummaryDatabaseEditionEnum `json:"databaseEdition"` DbToolsDetails []DatabaseTool `json:"dbToolsDetails"` + IsBackupRetentionLocked *bool `json:"isBackupRetentionLocked"` SecretId *string `json:"secretId"` SecretVersionNumber *int `json:"secretVersionNumber"` CompartmentId *string `json:"compartmentId"` @@ -734,6 +743,8 @@ func (m *UndeleteAutonomousDatabaseDetails) UnmarshalJSON(data []byte) (e error) m.DbToolsDetails = make([]DatabaseTool, len(model.DbToolsDetails)) copy(m.DbToolsDetails, model.DbToolsDetails) + m.IsBackupRetentionLocked = model.IsBackupRetentionLocked + m.SecretId = model.SecretId m.SecretVersionNumber = model.SecretVersionNumber diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/database/update_autonomous_database_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/database/update_autonomous_database_details.go index 289090dd7e6..fe47fc54dda 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/database/update_autonomous_database_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/database/update_autonomous_database_details.go @@ -252,6 +252,9 @@ type UpdateAutonomousDatabaseDetails struct { ResourcePoolSummary *ResourcePoolSummary `mandatory:"false" json:"resourcePoolSummary"` + // True if the Autonomous Database is backup retention locked. + IsBackupRetentionLocked *bool `mandatory:"false" json:"isBackupRetentionLocked"` + // The list of scheduled operations. Consists of values such as dayOfWeek, scheduledStartTime, scheduledStopTime. // This cannot be updated in parallel with any of the following: licenseModel, dbEdition, cpuCoreCount, computeCount, computeModel, whitelistedIps, isMTLSConnectionRequired, openMode, permissionLevel, dbWorkload, privateEndpointLabel, nsgIds, dbVersion, isRefreshable, dbName, dbToolsDetails, isLocalDataGuardEnabled, or isFreeTier. ScheduledOperations []ScheduledOperationDetails `mandatory:"false" json:"scheduledOperations"` @@ -361,6 +364,7 @@ func (m *UpdateAutonomousDatabaseDetails) UnmarshalJSON(data []byte) (e error) { IsMtlsConnectionRequired *bool `json:"isMtlsConnectionRequired"` ResourcePoolLeaderId *string `json:"resourcePoolLeaderId"` ResourcePoolSummary *ResourcePoolSummary `json:"resourcePoolSummary"` + IsBackupRetentionLocked *bool `json:"isBackupRetentionLocked"` ScheduledOperations []ScheduledOperationDetails `json:"scheduledOperations"` IsAutoScalingForStorageEnabled *bool `json:"isAutoScalingForStorageEnabled"` DatabaseEdition AutonomousDatabaseSummaryDatabaseEditionEnum `json:"databaseEdition"` @@ -465,6 +469,8 @@ func (m *UpdateAutonomousDatabaseDetails) UnmarshalJSON(data []byte) (e error) { m.ResourcePoolSummary = model.ResourcePoolSummary + m.IsBackupRetentionLocked = model.IsBackupRetentionLocked + m.ScheduledOperations = make([]ScheduledOperationDetails, len(model.ScheduledOperations)) copy(m.ScheduledOperations, model.ScheduledOperations) m.IsAutoScalingForStorageEnabled = model.IsAutoScalingForStorageEnabled diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/datascience/create_job_run_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/datascience/create_job_run_details.go index 8a5b5650225..766dbf4de7e 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/datascience/create_job_run_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/datascience/create_job_run_details.go @@ -19,10 +19,10 @@ import ( // CreateJobRunDetails Parameters needed to create a new job run. type CreateJobRunDetails struct { - // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the project to associate the job with. + // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the project to associate the job run with. ProjectId *string `mandatory:"true" json:"projectId"` - // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment where you want to create the job. + // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment where you want to create the job run. CompartmentId *string `mandatory:"true" json:"compartmentId"` // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the job to create a run for. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/datascience/data_science_resource_type.go b/vendor/github.com/oracle/oci-go-sdk/v65/datascience/data_science_resource_type.go index 89be7889a08..3c55cd75cf6 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/datascience/data_science_resource_type.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/datascience/data_science_resource_type.go @@ -19,14 +19,17 @@ type DataScienceResourceTypeEnum string // Set of constants representing the allowable values for DataScienceResourceTypeEnum const ( DataScienceResourceTypeNotebookSession DataScienceResourceTypeEnum = "NOTEBOOK_SESSION" + DataScienceResourceTypeModelDeployment DataScienceResourceTypeEnum = "MODEL_DEPLOYMENT" ) var mappingDataScienceResourceTypeEnum = map[string]DataScienceResourceTypeEnum{ "NOTEBOOK_SESSION": DataScienceResourceTypeNotebookSession, + "MODEL_DEPLOYMENT": DataScienceResourceTypeModelDeployment, } var mappingDataScienceResourceTypeEnumLowerCase = map[string]DataScienceResourceTypeEnum{ "notebook_session": DataScienceResourceTypeNotebookSession, + "model_deployment": DataScienceResourceTypeModelDeployment, } // GetDataScienceResourceTypeEnumValues Enumerates the set of values for DataScienceResourceTypeEnum @@ -42,6 +45,7 @@ func GetDataScienceResourceTypeEnumValues() []DataScienceResourceTypeEnum { func GetDataScienceResourceTypeEnumStringValues() []string { return []string{ "NOTEBOOK_SESSION", + "MODEL_DEPLOYMENT", } } diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/datascience/instance_configuration.go b/vendor/github.com/oracle/oci-go-sdk/v65/datascience/instance_configuration.go index 1517c280682..cfe401bb962 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/datascience/instance_configuration.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/datascience/instance_configuration.go @@ -25,6 +25,9 @@ type InstanceConfiguration struct { // A model deployment instance is provided with a VNIC for network access. This specifies the OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the subnet to create a VNIC in. The subnet should be in a VCN with a NAT/SGW gateway for egress. SubnetId *string `mandatory:"false" json:"subnetId"` + + // The OCID of a Data Science private endpoint. + PrivateEndpointId *string `mandatory:"false" json:"privateEndpointId"` } func (m InstanceConfiguration) String() string { diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/datascience/job_run.go b/vendor/github.com/oracle/oci-go-sdk/v65/datascience/job_run.go index cc6b2248aae..5e1bb36a5db 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/datascience/job_run.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/datascience/job_run.go @@ -28,13 +28,13 @@ type JobRun struct { // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the user who created the job run. CreatedBy *string `mandatory:"true" json:"createdBy"` - // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the project to associate the job with. + // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the project to associate the job run with. ProjectId *string `mandatory:"true" json:"projectId"` - // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment where you want to create the job. + // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment where you want to create the job run. CompartmentId *string `mandatory:"true" json:"compartmentId"` - // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the job run. + // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the job. JobId *string `mandatory:"true" json:"jobId"` JobConfigurationOverrideDetails JobConfigurationDetails `mandatory:"true" json:"jobConfigurationOverrideDetails"` diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/datascience/job_run_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/datascience/job_run_summary.go index 1779c565087..b97f9b2b70d 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/datascience/job_run_summary.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/datascience/job_run_summary.go @@ -15,7 +15,7 @@ import ( "strings" ) -// JobRunSummary Summary information for a Job. +// JobRunSummary Summary information for a job run. type JobRunSummary struct { // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the job run. @@ -27,16 +27,16 @@ type JobRunSummary struct { // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the user who created the job run. CreatedBy *string `mandatory:"true" json:"createdBy"` - // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the project to associate the job with. + // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the project to associate the job run with. ProjectId *string `mandatory:"true" json:"projectId"` - // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment where you want to create the job. + // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment where you want to create the job run. CompartmentId *string `mandatory:"true" json:"compartmentId"` - // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the job run. + // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the job. JobId *string `mandatory:"true" json:"jobId"` - // The state of the job. + // The state of the job run. LifecycleState JobRunLifecycleStateEnum `mandatory:"true" json:"lifecycleState"` // The date and time the job run request was started in the timestamp format defined by RFC3339 (https://tools.ietf.org/html/rfc3339). diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/datascience/job_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/datascience/job_summary.go index 82dc6676fe5..e51eabab2fe 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/datascience/job_summary.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/datascience/job_summary.go @@ -15,7 +15,7 @@ import ( "strings" ) -// JobSummary Summary information for a Job. +// JobSummary Summary information for a job. type JobSummary struct { // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the job. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/datascience/list_data_science_private_endpoints_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/datascience/list_data_science_private_endpoints_request_response.go index f668ec3a8ed..66cd21e677c 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/datascience/list_data_science_private_endpoints_request_response.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/datascience/list_data_science_private_endpoints_request_response.go @@ -285,14 +285,17 @@ type ListDataSciencePrivateEndpointsDataScienceResourceTypeEnum string // Set of constants representing the allowable values for ListDataSciencePrivateEndpointsDataScienceResourceTypeEnum const ( ListDataSciencePrivateEndpointsDataScienceResourceTypeNotebookSession ListDataSciencePrivateEndpointsDataScienceResourceTypeEnum = "NOTEBOOK_SESSION" + ListDataSciencePrivateEndpointsDataScienceResourceTypeModelDeployment ListDataSciencePrivateEndpointsDataScienceResourceTypeEnum = "MODEL_DEPLOYMENT" ) var mappingListDataSciencePrivateEndpointsDataScienceResourceTypeEnum = map[string]ListDataSciencePrivateEndpointsDataScienceResourceTypeEnum{ "NOTEBOOK_SESSION": ListDataSciencePrivateEndpointsDataScienceResourceTypeNotebookSession, + "MODEL_DEPLOYMENT": ListDataSciencePrivateEndpointsDataScienceResourceTypeModelDeployment, } var mappingListDataSciencePrivateEndpointsDataScienceResourceTypeEnumLowerCase = map[string]ListDataSciencePrivateEndpointsDataScienceResourceTypeEnum{ "notebook_session": ListDataSciencePrivateEndpointsDataScienceResourceTypeNotebookSession, + "model_deployment": ListDataSciencePrivateEndpointsDataScienceResourceTypeModelDeployment, } // GetListDataSciencePrivateEndpointsDataScienceResourceTypeEnumValues Enumerates the set of values for ListDataSciencePrivateEndpointsDataScienceResourceTypeEnum @@ -308,6 +311,7 @@ func GetListDataSciencePrivateEndpointsDataScienceResourceTypeEnumValues() []Lis func GetListDataSciencePrivateEndpointsDataScienceResourceTypeEnumStringValues() []string { return []string{ "NOTEBOOK_SESSION", + "MODEL_DEPLOYMENT", } } diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/datascience/metadata.go b/vendor/github.com/oracle/oci-go-sdk/v65/datascience/metadata.go index f44f36d2d8b..7470be3a3d0 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/datascience/metadata.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/datascience/metadata.go @@ -25,7 +25,7 @@ type Metadata struct { // * libraryVersion // * estimatorClass // * hyperParameters - // * testartifactresults + // * testArtifactresults Key *string `mandatory:"false" json:"key"` // Allowed values for useCaseType: @@ -41,7 +41,7 @@ type Metadata struct { // Description of model metadata Description *string `mandatory:"false" json:"description"` - // Category of model metadata which should be null for defined metadata.For custom metadata is should be one of the following values "Performance,Training Profile,Training and Validation Datasets,Training Environment,other". + // Category of model metadata which should be null for defined metadata.For custom metadata is should be one of the following values "Performance,Training Profile,Training and Validation Datasets,Training Environment,Reports,Readme,other". Category *string `mandatory:"false" json:"category"` } diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/action_type.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/action_type.go index 2328fd981a8..4f9d2849068 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/action_type.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/action_type.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent.go index cd8beef8627..cdc6010da6d 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// Agent **Agent** -// An agent is an LLM-based autonomous system that understands and generates human-like text, enabling natural-language processing interactions. OCI Generative AI Agents supports retrieval-augmented generation (RAG) agents. A RAG agent connects to a data source, retrieves data, and augments model responses with the information from the data sources to generate more relevant responses. +// Agent An agent is an LLM-based autonomous system that understands and generates human-like text, enabling natural-language processing interactions. OCI Generative AI Agents supports retrieval-augmented generation (RAG) agents. A RAG agent connects to a data source, retrieves data, and augments model responses with the information from the data sources to generate more relevant responses. // To use any of the API operations, you must be authorized in an IAM policy. If you're not authorized, talk to an administrator. If you're an administrator who needs to write policies to give users access, see Getting Started with Policies (https://docs.cloud.oracle.com/iaas/Content/Identity/policiesgs/get-started-with-policies.htm). type Agent struct { diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_collection.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_collection.go index 641f84b160d..4eae5dce0e8 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_collection.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_collection.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// AgentCollection **AgentCollection** -// Results of an agent search. Contains both AgentSummary items and other information, such as metadata. +// AgentCollection Results of an agent search. Contains both AgentSummary items and other information, such as metadata. type AgentCollection struct { // List of agents. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_endpoint.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_endpoint.go index b72742963f7..4c07e1c1a97 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_endpoint.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_endpoint.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// AgentEndpoint **AgentEndpoint** -// The endpoint to access a deployed agent. +// AgentEndpoint The endpoint to access a deployed agent. // To use any of the API operations, you must be authorized in an IAM policy. If you're not authorized, talk to an administrator. If you're an administrator who needs to write policies to give users access, see Getting Started with Policies (https://docs.cloud.oracle.com/iaas/Content/Identity/policiesgs/get-started-with-policies.htm). type AgentEndpoint struct { diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_endpoint_collection.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_endpoint_collection.go index 7bd1effb3e2..d627b1f3272 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_endpoint_collection.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_endpoint_collection.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// AgentEndpointCollection **AgentEndpointCollection** -// Results of an agentEndpoint search. Contains both AgentEndpointSummary items and other information, such as metadata. +// AgentEndpointCollection Results of an agentEndpoint search. Contains both AgentEndpointSummary items and other information, such as metadata. type AgentEndpointCollection struct { // List of endpoints. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_endpoint_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_endpoint_summary.go index 78a78795de7..682189df509 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_endpoint_summary.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_endpoint_summary.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// AgentEndpointSummary **AgentEndpointSummary** -// Summary information about an endpoint. +// AgentEndpointSummary Summary information about an endpoint. type AgentEndpointSummary struct { // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the AgentEndpoint. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_summary.go index 8f82430a7ae..504a2c86f52 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_summary.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/agent_summary.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// AgentSummary **AgentSummary** -// Summary information about an agent. +// AgentSummary Summary information about an agent. type AgentSummary struct { // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the Agent. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/basic_auth_secret.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/basic_auth_secret.go index 46e987b184f..d393c12c1eb 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/basic_auth_secret.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/basic_auth_secret.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -22,8 +20,7 @@ import ( "strings" ) -// BasicAuthSecret **BasicAuthSecret** -// The details of Basic authentication configured as in OpenSearch. +// BasicAuthSecret The details of Basic authentication configured as in OpenSearch. type BasicAuthSecret struct { // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the secret for basic authentication. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/change_agent_compartment_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/change_agent_compartment_details.go index 61a16c70826..6690b7029c2 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/change_agent_compartment_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/change_agent_compartment_details.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// ChangeAgentCompartmentDetails **ChangeAgentCompartmentDetails** -// The configuration details for the move operation. +// ChangeAgentCompartmentDetails The configuration details for the move operation. type ChangeAgentCompartmentDetails struct { // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment to move the agent to. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/change_agent_endpoint_compartment_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/change_agent_endpoint_compartment_details.go index a52fd237d38..2a25627680e 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/change_agent_endpoint_compartment_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/change_agent_endpoint_compartment_details.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// ChangeAgentEndpointCompartmentDetails **ChangeAgentEndpointCompartmentDetails** -// The configuration details for the move operation. +// ChangeAgentEndpointCompartmentDetails The configuration details for the move operation. type ChangeAgentEndpointCompartmentDetails struct { // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment to move the endpoint to. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/change_knowledge_base_compartment_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/change_knowledge_base_compartment_details.go index 6d1839cde9c..9d175475fe4 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/change_knowledge_base_compartment_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/change_knowledge_base_compartment_details.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// ChangeKnowledgeBaseCompartmentDetails **ChangeKnowledgeBaseCompartmentDetails** -// The configuration details for the move operation. +// ChangeKnowledgeBaseCompartmentDetails The configuration details for the move operation. type ChangeKnowledgeBaseCompartmentDetails struct { // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment to move the KnowledgeBase to. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/content_moderation_config.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/content_moderation_config.go index 8e12542e206..7ae95c0284c 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/content_moderation_config.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/content_moderation_config.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_agent_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_agent_details.go index 2e0d12ab89a..19c02bfdcfe 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_agent_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_agent_details.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// CreateAgentDetails **CreateAgentDetails** -// The data to create an agent. +// CreateAgentDetails The data to create an agent. type CreateAgentDetails struct { // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment to create the agent in. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_agent_endpoint_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_agent_endpoint_details.go index 9a38de8e3db..72b3d6a45f1 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_agent_endpoint_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_agent_endpoint_details.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// CreateAgentEndpointDetails **CreateAgentEndpointDetails** -// The data to create an endpoint. +// CreateAgentEndpointDetails The data to create an endpoint. type CreateAgentEndpointDetails struct { // The OCID of the agent that this endpoint is associated with. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_data_ingestion_job_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_data_ingestion_job_details.go index 31e23d924a9..d20590568a0 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_data_ingestion_job_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_data_ingestion_job_details.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// CreateDataIngestionJobDetails **CreateDataIngestionJobDetails** -// The data to create a data ingestion job. +// CreateDataIngestionJobDetails The data to create a data ingestion job. type CreateDataIngestionJobDetails struct { // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the parent DataSource. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_data_source_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_data_source_details.go index 55156af8d24..9a69bffcd1d 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_data_source_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_data_source_details.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -22,8 +20,7 @@ import ( "strings" ) -// CreateDataSourceDetails **CreateDataSourceDetails** -// The data to create a data source. +// CreateDataSourceDetails The data to create a data source. type CreateDataSourceDetails struct { // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the parent KnowledgeBase. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_knowledge_base_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_knowledge_base_details.go index dda845cfb05..98900f60f74 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_knowledge_base_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/create_knowledge_base_details.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -22,8 +20,7 @@ import ( "strings" ) -// CreateKnowledgeBaseDetails **CreateKnowledgeBaseDetails** -// The data to create a knowledge base. +// CreateKnowledgeBaseDetails The data to create a knowledge base. type CreateKnowledgeBaseDetails struct { IndexConfig IndexConfig `mandatory:"true" json:"indexConfig"` diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_ingestion_job.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_ingestion_job.go index 8ef0ea9b41a..55ca7b7d23b 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_ingestion_job.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_ingestion_job.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// DataIngestionJob **DataIngestionJob** -// When you create a data source, you specify the location of the data files. To make those files usable by an agent, you must download them into the agent's associated knowledge base, a process known as data ingestion. Data ingestion is a process that extracts data from data source documents, converts it into a structured format suitable for analysis, and then stores it in a knowledge base. +// DataIngestionJob When you create a data source, you specify the location of the data files. To make those files usable by an agent, you must download them into the agent's associated knowledge base, a process known as data ingestion. Data ingestion is a process that extracts data from data source documents, converts it into a structured format suitable for analysis, and then stores it in a knowledge base. // To use any of the API operations, you must be authorized in an IAM policy. If you're not authorized, talk to an administrator. If you're an administrator who needs to write policies to give users access, see Getting Started with Policies (https://docs.cloud.oracle.com/iaas/Content/Identity/policiesgs/get-started-with-policies.htm). type DataIngestionJob struct { @@ -60,6 +57,9 @@ type DataIngestionJob struct { // A user-friendly name. Does not have to be unique, and it's changeable. Description *string `mandatory:"false" json:"description"` + // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the parent KnowledgeBase. + KnowledgeBaseId *string `mandatory:"false" json:"knowledgeBaseId"` + // The date and time the data ingestion job was updated, in the format defined by RFC 3339 (https://tools.ietf.org/html/rfc3339). // Example: `2016-08-25T21:10:29.600Z` TimeUpdated *common.SDKTime `mandatory:"false" json:"timeUpdated"` diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_ingestion_job_collection.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_ingestion_job_collection.go index 99945f1d689..4eadd69ea49 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_ingestion_job_collection.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_ingestion_job_collection.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// DataIngestionJobCollection **DataIngestionJobCollection** -// Results of a data ingestion job search. Contains both DataIngestionJobSummary items and other information, such as metadata. +// DataIngestionJobCollection Results of a data ingestion job search. Contains both DataIngestionJobSummary items and other information, such as metadata. type DataIngestionJobCollection struct { // List of data ingestion jobs. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_ingestion_job_statistics.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_ingestion_job_statistics.go index 96aaf025979..69e183a8596 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_ingestion_job_statistics.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_ingestion_job_statistics.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// DataIngestionJobStatistics **DataIngestionJobStatistics** -// The statistics of data ingestion job. +// DataIngestionJobStatistics The statistics of data ingestion job. type DataIngestionJobStatistics struct { // The number of files that have failed during the ingestion. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_ingestion_job_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_ingestion_job_summary.go index 82122f253d5..77b2a5ae572 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_ingestion_job_summary.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_ingestion_job_summary.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// DataIngestionJobSummary **DataIngestionJobSummary** -// Summary information about a data ingestion job. +// DataIngestionJobSummary Summary information about a data ingestion job. type DataIngestionJobSummary struct { // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the data ingestion job. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_source.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_source.go index f8bdb022e47..61a0061e316 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_source.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_source.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -22,8 +20,7 @@ import ( "strings" ) -// DataSource **DataSource** -// A data source points to the source of your data. After you add a data source to a knowledge base, you must ingest the data source's data, so that agents using the knowledge base can refer to the data. +// DataSource A data source points to the source of your data. After you add a data source to a knowledge base, you must ingest the data source's data, so that agents using the knowledge base can refer to the data. // To use any of the API operations, you must be authorized in an IAM policy. If you're not authorized, talk to an administrator. If you're an administrator who needs to write policies to give users access, see Getting Started with Policies (https://docs.cloud.oracle.com/iaas/Content/Identity/policiesgs/get-started-with-policies.htm). type DataSource struct { diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_source_collection.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_source_collection.go index 65f3e799a0d..580d8ea5ccb 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_source_collection.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_source_collection.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// DataSourceCollection **DataSourceCollection** -// Results of a dataSource search. Contains both DataSourceSummary items and other information, such as metadata. +// DataSourceCollection Results of a dataSource search. Contains both DataSourceSummary items and other information, such as metadata. type DataSourceCollection struct { // List of data sources. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_source_config.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_source_config.go index 889ffc8b503..05b46340479 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_source_config.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_source_config.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -22,14 +20,17 @@ import ( "strings" ) -// DataSourceConfig **DataSourceConfig** -// The details of data source. +// DataSourceConfig The details of data source. type DataSourceConfig interface { + + // Flag to enable or disable multi modality such as image processing while ingestion of data. True enable the processing and false exclude the multi modality contents during ingestion. + GetShouldEnableMultiModality() *bool } type datasourceconfig struct { - JsonData []byte - DataSourceConfigType string `json:"dataSourceConfigType"` + JsonData []byte + ShouldEnableMultiModality *bool `mandatory:"false" json:"shouldEnableMultiModality"` + DataSourceConfigType string `json:"dataSourceConfigType"` } // UnmarshalJSON unmarshals json @@ -43,6 +44,7 @@ func (m *datasourceconfig) UnmarshalJSON(data []byte) error { if err != nil { return err } + m.ShouldEnableMultiModality = s.Model.ShouldEnableMultiModality m.DataSourceConfigType = s.Model.DataSourceConfigType return err @@ -67,6 +69,11 @@ func (m *datasourceconfig) UnmarshalPolymorphicJSON(data []byte) (interface{}, e } } +// GetShouldEnableMultiModality returns ShouldEnableMultiModality +func (m datasourceconfig) GetShouldEnableMultiModality() *bool { + return m.ShouldEnableMultiModality +} + func (m datasourceconfig) String() string { return common.PointerString(m) } diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_source_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_source_summary.go index f978d0604c8..a93146bc4e9 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_source_summary.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/data_source_summary.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// DataSourceSummary **DataSourceSummary** -// Summary information about a data source. +// DataSourceSummary Summary information about a data source. type DataSourceSummary struct { // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the data source. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/database_connection.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/database_connection.go index eebf33fc140..09f39247767 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/database_connection.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/database_connection.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -22,8 +20,7 @@ import ( "strings" ) -// DatabaseConnection **DatabaseConnection** -// The connection type for Databases. +// DatabaseConnection The connection type for Databases. type DatabaseConnection interface { } diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/database_function.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/database_function.go index 25cb86b767b..fcd2630c63d 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/database_function.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/database_function.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// DatabaseFunction **DatabaseFunction** -// The details of Database function. +// DatabaseFunction The details of Database function. type DatabaseFunction struct { // The name of the Database function. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/database_tool_connection.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/database_tool_connection.go index cf7c91b8070..38b0ba52d01 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/database_tool_connection.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/database_tool_connection.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -22,8 +20,7 @@ import ( "strings" ) -// DatabaseToolConnection **DatabaseToolConnection** -// The details of the customer Database Tools Connection. +// DatabaseToolConnection The details of the customer Database Tools Connection. type DatabaseToolConnection struct { // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the Database Tools Connection. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/default_index_config.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/default_index_config.go index c29cf653ed5..f829508f979 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/default_index_config.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/default_index_config.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -22,8 +20,7 @@ import ( "strings" ) -// DefaultIndexConfig **DefaultIndexConfig** -// The default index is service managed vector store on behalf of the customer. +// DefaultIndexConfig The default index is service managed vector store on behalf of the customer. type DefaultIndexConfig struct { // Whether to enable Hybrid search in service managed OpenSearch. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/generativeaiagent_client.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/generativeaiagent_client.go index ecb49257e64..f8c250d9b16 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/generativeaiagent_client.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/generativeaiagent_client.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -97,8 +95,7 @@ func (client *GenerativeAiAgentClient) ConfigurationProvider() *common.Configura return client.config } -// CancelWorkRequest **CancelWorkRequest** -// Cancels a work request. +// CancelWorkRequest Cancels a work request. // // # See also // @@ -156,8 +153,7 @@ func (client GenerativeAiAgentClient) cancelWorkRequest(ctx context.Context, req return response, err } -// ChangeAgentCompartment **ChangeAgentCompartment** -// Moves an agent into a different compartment within the same tenancy. For information about moving resources between +// ChangeAgentCompartment Moves an agent into a different compartment within the same tenancy. For information about moving resources between // compartments, see Moving Resources to a Different Compartment (https://docs.cloud.oracle.com/iaas/Content/Identity/Tasks/managingcompartments.htm#moveRes). // // # See also @@ -221,8 +217,7 @@ func (client GenerativeAiAgentClient) changeAgentCompartment(ctx context.Context return response, err } -// ChangeAgentEndpointCompartment **ChangeAgentEndpointCompartment** -// Moves an endpoint into a different compartment within the same tenancy. For information about moving resources between +// ChangeAgentEndpointCompartment Moves an endpoint into a different compartment within the same tenancy. For information about moving resources between // compartments, see Moving Resources to a Different Compartment (https://docs.cloud.oracle.com/iaas/Content/Identity/Tasks/managingcompartments.htm#moveRes). // // # See also @@ -286,8 +281,7 @@ func (client GenerativeAiAgentClient) changeAgentEndpointCompartment(ctx context return response, err } -// ChangeKnowledgeBaseCompartment **ChangeKnowledgeBaseCompartment** -// Moves a knowledge base into a different compartment within the same tenancy. For information about moving resources between +// ChangeKnowledgeBaseCompartment Moves a knowledge base into a different compartment within the same tenancy. For information about moving resources between // compartments, see Moving Resources to a Different Compartment (https://docs.cloud.oracle.com/iaas/Content/Identity/Tasks/managingcompartments.htm#moveRes). // // # See also @@ -351,8 +345,7 @@ func (client GenerativeAiAgentClient) changeKnowledgeBaseCompartment(ctx context return response, err } -// CreateAgent **CreateAgent** -// Creates an agent. +// CreateAgent Creates an agent. // // # See also // @@ -415,8 +408,7 @@ func (client GenerativeAiAgentClient) createAgent(ctx context.Context, request c return response, err } -// CreateAgentEndpoint **CreateAgentEndpoint** -// Creates an endpoint. +// CreateAgentEndpoint Creates an endpoint. // // # See also // @@ -479,8 +471,7 @@ func (client GenerativeAiAgentClient) createAgentEndpoint(ctx context.Context, r return response, err } -// CreateDataIngestionJob **CreateDataIngestionJob** -// Creates a data ingestion job. +// CreateDataIngestionJob Creates a data ingestion job. // // # See also // @@ -543,8 +534,7 @@ func (client GenerativeAiAgentClient) createDataIngestionJob(ctx context.Context return response, err } -// CreateDataSource **CreateDataSource** -// Creates a data source. +// CreateDataSource Creates a data source. // // # See also // @@ -607,8 +597,7 @@ func (client GenerativeAiAgentClient) createDataSource(ctx context.Context, requ return response, err } -// CreateKnowledgeBase **CreateKnowledgeBase** -// Creates a knowledge base. +// CreateKnowledgeBase Creates a knowledge base. // // # See also // @@ -671,8 +660,7 @@ func (client GenerativeAiAgentClient) createKnowledgeBase(ctx context.Context, r return response, err } -// DeleteAgent **DeleteAgent** -// Deletes an agent. +// DeleteAgent Deletes an agent. // // # See also // @@ -730,8 +718,7 @@ func (client GenerativeAiAgentClient) deleteAgent(ctx context.Context, request c return response, err } -// DeleteAgentEndpoint **DeleteAgentEndpoint** -// Deletes an endpoint. +// DeleteAgentEndpoint Deletes an endpoint. // // # See also // @@ -789,8 +776,7 @@ func (client GenerativeAiAgentClient) deleteAgentEndpoint(ctx context.Context, r return response, err } -// DeleteDataIngestionJob **DeleteDataIngestionJob** -// Deletes a data ingestion job. +// DeleteDataIngestionJob Deletes a data ingestion job. // // # See also // @@ -848,8 +834,7 @@ func (client GenerativeAiAgentClient) deleteDataIngestionJob(ctx context.Context return response, err } -// DeleteDataSource **DeleteDataSource** -// Deletes a data source. +// DeleteDataSource Deletes a data source. // // # See also // @@ -907,8 +892,7 @@ func (client GenerativeAiAgentClient) deleteDataSource(ctx context.Context, requ return response, err } -// DeleteKnowledgeBase **DeleteKnowledgeBase** -// Deletes a knowledge base. +// DeleteKnowledgeBase Deletes a knowledge base. // // # See also // @@ -966,8 +950,7 @@ func (client GenerativeAiAgentClient) deleteKnowledgeBase(ctx context.Context, r return response, err } -// GetAgent **GetAgent** -// Gets information about an agent. +// GetAgent Gets information about an agent. // // # See also // @@ -1025,8 +1008,7 @@ func (client GenerativeAiAgentClient) getAgent(ctx context.Context, request comm return response, err } -// GetAgentEndpoint **GetAgentEndpoint** -// Gets information about an endpoint. +// GetAgentEndpoint Gets information about an endpoint. // // # See also // @@ -1084,8 +1066,7 @@ func (client GenerativeAiAgentClient) getAgentEndpoint(ctx context.Context, requ return response, err } -// GetDataIngestionJob **GetDataIngestionJob** -// Gets information about a data ingestion job. +// GetDataIngestionJob Gets information about a data ingestion job. // // # See also // @@ -1143,8 +1124,7 @@ func (client GenerativeAiAgentClient) getDataIngestionJob(ctx context.Context, r return response, err } -// GetDataIngestionJobLogContent **GetDataIngestionJobLogContent** -// Returns the raw log file for the specified data ingestion job in text format. +// GetDataIngestionJobLogContent Returns the raw log file for the specified data ingestion job in text format. // // # See also // @@ -1201,8 +1181,7 @@ func (client GenerativeAiAgentClient) getDataIngestionJobLogContent(ctx context. return response, err } -// GetDataSource **GetDataSource** -// Gets information about a data source. +// GetDataSource Gets information about a data source. // // # See also // @@ -1260,8 +1239,7 @@ func (client GenerativeAiAgentClient) getDataSource(ctx context.Context, request return response, err } -// GetKnowledgeBase **GetKnowledgeBase** -// Gets information about a knowledge base. +// GetKnowledgeBase Gets information about a knowledge base. // // # See also // @@ -1319,8 +1297,7 @@ func (client GenerativeAiAgentClient) getKnowledgeBase(ctx context.Context, requ return response, err } -// GetWorkRequest **GetWorkRequest** -// Gets the details of a work request. +// GetWorkRequest Gets the details of a work request. // // # See also // @@ -1378,8 +1355,7 @@ func (client GenerativeAiAgentClient) getWorkRequest(ctx context.Context, reques return response, err } -// ListAgentEndpoints **ListAgentEndpoints** -// Gets a list of endpoints. +// ListAgentEndpoints Gets a list of endpoints. // // # See also // @@ -1437,8 +1413,7 @@ func (client GenerativeAiAgentClient) listAgentEndpoints(ctx context.Context, re return response, err } -// ListAgents **ListAgents** -// Gets a list of agents. +// ListAgents Gets a list of agents. // // # See also // @@ -1496,8 +1471,7 @@ func (client GenerativeAiAgentClient) listAgents(ctx context.Context, request co return response, err } -// ListDataIngestionJobs **ListDataIngestionJobs** -// Gets a list of data ingestion jobs. +// ListDataIngestionJobs Gets a list of data ingestion jobs. // // # See also // @@ -1555,8 +1529,7 @@ func (client GenerativeAiAgentClient) listDataIngestionJobs(ctx context.Context, return response, err } -// ListDataSources **ListDataSources** -// Gets a list of data sources. +// ListDataSources Gets a list of data sources. // // # See also // @@ -1614,8 +1587,7 @@ func (client GenerativeAiAgentClient) listDataSources(ctx context.Context, reque return response, err } -// ListKnowledgeBases **ListKnowledgeBases** -// Gets a list of knowledge bases. +// ListKnowledgeBases Gets a list of knowledge bases. // // # See also // @@ -1673,8 +1645,7 @@ func (client GenerativeAiAgentClient) listKnowledgeBases(ctx context.Context, re return response, err } -// ListWorkRequestErrors **ListWorkRequestErrors** -// Lists the errors for a work request. +// ListWorkRequestErrors Lists the errors for a work request. // // # See also // @@ -1732,8 +1703,7 @@ func (client GenerativeAiAgentClient) listWorkRequestErrors(ctx context.Context, return response, err } -// ListWorkRequestLogs **ListWorkRequestLogs** -// Lists the logs for a work request. +// ListWorkRequestLogs Lists the logs for a work request. // // # See also // @@ -1791,8 +1761,7 @@ func (client GenerativeAiAgentClient) listWorkRequestLogs(ctx context.Context, r return response, err } -// ListWorkRequests **ListWorkRequests** -// Lists the work requests in a compartment. +// ListWorkRequests Lists the work requests in a compartment. // // # See also // @@ -1850,8 +1819,7 @@ func (client GenerativeAiAgentClient) listWorkRequests(ctx context.Context, requ return response, err } -// UpdateAgent **UpdateAgent** -// Updates an agent. +// UpdateAgent Updates an agent. // // # See also // @@ -1909,8 +1877,7 @@ func (client GenerativeAiAgentClient) updateAgent(ctx context.Context, request c return response, err } -// UpdateAgentEndpoint **UpdateAgentEndpoint** -// Updates an endpoint. +// UpdateAgentEndpoint Updates an endpoint. // // # See also // @@ -1968,8 +1935,7 @@ func (client GenerativeAiAgentClient) updateAgentEndpoint(ctx context.Context, r return response, err } -// UpdateDataSource **UpdateDataSource** -// Updates a data source. +// UpdateDataSource Updates a data source. // // # See also // @@ -2027,8 +1993,7 @@ func (client GenerativeAiAgentClient) updateDataSource(ctx context.Context, requ return response, err } -// UpdateKnowledgeBase **UpdateKnowledgeBase** -// Updates a knowledge base. +// UpdateKnowledgeBase Updates a knowledge base. // // # See also // diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/idcs_secret.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/idcs_secret.go index 17990946db2..de690dd6413 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/idcs_secret.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/idcs_secret.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -22,8 +20,7 @@ import ( "strings" ) -// IdcsSecret **IdcsSecret** -// The details of IDCS configured as OpenID setting in OpenSearch. +// IdcsSecret The details of IDCS configured as OpenID setting in OpenSearch. type IdcsSecret struct { // The URL represent authentication url of the IDCS. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/index.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/index.go index 8d3f3646fa0..9c9900c3c4f 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/index.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/index.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// Index **Index** -// OCI OpenSearch index details. +// Index OCI OpenSearch index details. type Index struct { // The index name in opensearch. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/index_config.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/index_config.go index f093cd15ffb..3a2eef2795f 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/index_config.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/index_config.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -22,8 +20,7 @@ import ( "strings" ) -// IndexConfig **IndexConfig** -// The index configuration of Knowledge bases. +// IndexConfig The index configuration of Knowledge bases. type IndexConfig interface { } diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/index_schema.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/index_schema.go index 00672596db0..510a6714919 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/index_schema.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/index_schema.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// IndexSchema **IndexSchema** -// The index schema details. +// IndexSchema The index schema details. type IndexSchema struct { // Body key name. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/knowledge_base.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/knowledge_base.go index 2faa8d70853..0c803c3fa40 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/knowledge_base.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/knowledge_base.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -22,8 +20,7 @@ import ( "strings" ) -// KnowledgeBase **KnowledgeBase** -// A knowledge base is the base for all the data sources that an agent can use to retrieve information for its responses. +// KnowledgeBase A knowledge base is the base for all the data sources that an agent can use to retrieve information for its responses. // To use any of the API operations, you must be authorized in an IAM policy. If you're not authorized, talk to an administrator. If you're an administrator who needs to write policies to give users access, see Getting Started with Policies (https://docs.cloud.oracle.com/iaas/Content/Identity/policiesgs/get-started-with-policies.htm). type KnowledgeBase struct { @@ -58,6 +55,8 @@ type KnowledgeBase struct { // A description of the knowledge base. Description *string `mandatory:"false" json:"description"` + KnowledgeBaseStatistics *KnowledgeBaseStatistics `mandatory:"false" json:"knowledgeBaseStatistics"` + // The date and time the knowledge base was updated, in the format defined by RFC 3339 (https://tools.ietf.org/html/rfc3339). // Example: `2016-08-25T21:10:29.600Z` TimeUpdated *common.SDKTime `mandatory:"false" json:"timeUpdated"` @@ -93,18 +92,19 @@ func (m KnowledgeBase) ValidateEnumValue() (bool, error) { // UnmarshalJSON unmarshals from json func (m *KnowledgeBase) UnmarshalJSON(data []byte) (e error) { model := struct { - Description *string `json:"description"` - TimeUpdated *common.SDKTime `json:"timeUpdated"` - LifecycleDetails *string `json:"lifecycleDetails"` - SystemTags map[string]map[string]interface{} `json:"systemTags"` - Id *string `json:"id"` - DisplayName *string `json:"displayName"` - CompartmentId *string `json:"compartmentId"` - IndexConfig indexconfig `json:"indexConfig"` - TimeCreated *common.SDKTime `json:"timeCreated"` - LifecycleState KnowledgeBaseLifecycleStateEnum `json:"lifecycleState"` - FreeformTags map[string]string `json:"freeformTags"` - DefinedTags map[string]map[string]interface{} `json:"definedTags"` + Description *string `json:"description"` + KnowledgeBaseStatistics *KnowledgeBaseStatistics `json:"knowledgeBaseStatistics"` + TimeUpdated *common.SDKTime `json:"timeUpdated"` + LifecycleDetails *string `json:"lifecycleDetails"` + SystemTags map[string]map[string]interface{} `json:"systemTags"` + Id *string `json:"id"` + DisplayName *string `json:"displayName"` + CompartmentId *string `json:"compartmentId"` + IndexConfig indexconfig `json:"indexConfig"` + TimeCreated *common.SDKTime `json:"timeCreated"` + LifecycleState KnowledgeBaseLifecycleStateEnum `json:"lifecycleState"` + FreeformTags map[string]string `json:"freeformTags"` + DefinedTags map[string]map[string]interface{} `json:"definedTags"` }{} e = json.Unmarshal(data, &model) @@ -114,6 +114,8 @@ func (m *KnowledgeBase) UnmarshalJSON(data []byte) (e error) { var nn interface{} m.Description = model.Description + m.KnowledgeBaseStatistics = model.KnowledgeBaseStatistics + m.TimeUpdated = model.TimeUpdated m.LifecycleDetails = model.LifecycleDetails diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/knowledge_base_collection.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/knowledge_base_collection.go index 9b89b2c538a..7e7fab28d16 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/knowledge_base_collection.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/knowledge_base_collection.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// KnowledgeBaseCollection **KnowledgeBaseCollection** -// Results of a knowledge base search. Contains both KnowledgeBaseSummary items and other information, such as metadata. +// KnowledgeBaseCollection Results of a knowledge base search. Contains both KnowledgeBaseSummary items and other information, such as metadata. type KnowledgeBaseCollection struct { // List of knowledge bases. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/knowledge_base_statistics.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/knowledge_base_statistics.go new file mode 100644 index 00000000000..0b021789c8f --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/knowledge_base_statistics.go @@ -0,0 +1,43 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Generative AI Agents Management API +// +// OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. +// OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. +// Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. +// For creating and managing client chat sessions see the /EN/generative-ai-agents-client/latest/. +// To learn more about the service, see the Generative AI Agents documentation (https://docs.cloud.oracle.com/iaas/Content/generative-ai-agents/home.htm). +// + +package generativeaiagent + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// KnowledgeBaseStatistics Statistics for Default Knowledge Base. +type KnowledgeBaseStatistics struct { + + // Knowledge Base size in bytes. + SizeInBytes *int `mandatory:"false" json:"sizeInBytes"` +} + +func (m KnowledgeBaseStatistics) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m KnowledgeBaseStatistics) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/knowledge_base_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/knowledge_base_summary.go index 74ef0957f05..acf1e7dc903 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/knowledge_base_summary.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/knowledge_base_summary.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// KnowledgeBaseSummary **KnowledgeBaseSummary** -// Summary information about a knowledge base. +// KnowledgeBaseSummary Summary information about a knowledge base. type KnowledgeBaseSummary struct { // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the knowledge base. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/object_storage_prefix.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/object_storage_prefix.go index e2efd2ff88d..f67351277ac 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/object_storage_prefix.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/object_storage_prefix.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// ObjectStoragePrefix **ObjectStoragePrefix** -// The details of OCI Object Storage object. +// ObjectStoragePrefix The details of OCI Object Storage object. type ObjectStoragePrefix struct { // The namespace name of an object. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/oci_database_config.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/oci_database_config.go index 78b545262c7..19c79bbc3c9 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/oci_database_config.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/oci_database_config.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -22,8 +20,7 @@ import ( "strings" ) -// OciDatabaseConfig **OciDatabaseConfig** -// The details of the customer Database Connection. +// OciDatabaseConfig The details of the customer Database Connection. type OciDatabaseConfig struct { DatabaseConnection DatabaseConnection `mandatory:"true" json:"databaseConnection"` diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/oci_object_storage_data_source_config.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/oci_object_storage_data_source_config.go index b2d2f2f0698..b6b210447e8 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/oci_object_storage_data_source_config.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/oci_object_storage_data_source_config.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -22,12 +20,19 @@ import ( "strings" ) -// OciObjectStorageDataSourceConfig **OciObjectStorageDataSourceConfig** -// The details of OCI Search with OpenSearch data source information. +// OciObjectStorageDataSourceConfig The details of OCI Search with OpenSearch data source information. type OciObjectStorageDataSourceConfig struct { + // Flag to enable or disable multi modality such as image processing while ingestion of data. True enable the processing and false exclude the multi modality contents during ingestion. + ShouldEnableMultiModality *bool `mandatory:"false" json:"shouldEnableMultiModality"` + // The locations of data items in Object Storage, can either be an object (File) or a prefix (folder). - ObjectStoragePrefixes []ObjectStoragePrefix `mandatory:"true" json:"objectStoragePrefixes"` + ObjectStoragePrefixes []ObjectStoragePrefix `mandatory:"false" json:"objectStoragePrefixes"` +} + +// GetShouldEnableMultiModality returns ShouldEnableMultiModality +func (m OciObjectStorageDataSourceConfig) GetShouldEnableMultiModality() *bool { + return m.ShouldEnableMultiModality } func (m OciObjectStorageDataSourceConfig) String() string { diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/oci_open_search_index_config.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/oci_open_search_index_config.go index a5a01a4f5a7..4ba9a6ccdcf 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/oci_open_search_index_config.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/oci_open_search_index_config.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -22,8 +20,7 @@ import ( "strings" ) -// OciOpenSearchIndexConfig **OciOpenSearchIndexConfig** -// The details of customer managed OCI OpenSearch. +// OciOpenSearchIndexConfig The details of customer managed OCI OpenSearch. type OciOpenSearchIndexConfig struct { // The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the OpenSearch Cluster. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/operation_status.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/operation_status.go index 3a8fc0e8c0f..511b4efbbef 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/operation_status.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/operation_status.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/operation_type.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/operation_type.go index ee7c264b25f..063190bdd09 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/operation_type.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/operation_type.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -41,6 +39,9 @@ const ( OperationTypeMoveKnowledgeBase OperationTypeEnum = "MOVE_KNOWLEDGE_BASE" OperationTypeCreateDataIngestionJob OperationTypeEnum = "CREATE_DATA_INGESTION_JOB" OperationTypeDeleteDataIngestionJob OperationTypeEnum = "DELETE_DATA_INGESTION_JOB" + OperationTypeCreateTool OperationTypeEnum = "CREATE_TOOL" + OperationTypeUpdateTool OperationTypeEnum = "UPDATE_TOOL" + OperationTypeDeleteTool OperationTypeEnum = "DELETE_TOOL" ) var mappingOperationTypeEnum = map[string]OperationTypeEnum{ @@ -61,6 +62,9 @@ var mappingOperationTypeEnum = map[string]OperationTypeEnum{ "MOVE_KNOWLEDGE_BASE": OperationTypeMoveKnowledgeBase, "CREATE_DATA_INGESTION_JOB": OperationTypeCreateDataIngestionJob, "DELETE_DATA_INGESTION_JOB": OperationTypeDeleteDataIngestionJob, + "CREATE_TOOL": OperationTypeCreateTool, + "UPDATE_TOOL": OperationTypeUpdateTool, + "DELETE_TOOL": OperationTypeDeleteTool, } var mappingOperationTypeEnumLowerCase = map[string]OperationTypeEnum{ @@ -81,6 +85,9 @@ var mappingOperationTypeEnumLowerCase = map[string]OperationTypeEnum{ "move_knowledge_base": OperationTypeMoveKnowledgeBase, "create_data_ingestion_job": OperationTypeCreateDataIngestionJob, "delete_data_ingestion_job": OperationTypeDeleteDataIngestionJob, + "create_tool": OperationTypeCreateTool, + "update_tool": OperationTypeUpdateTool, + "delete_tool": OperationTypeDeleteTool, } // GetOperationTypeEnumValues Enumerates the set of values for OperationTypeEnum @@ -112,6 +119,9 @@ func GetOperationTypeEnumStringValues() []string { "MOVE_KNOWLEDGE_BASE", "CREATE_DATA_INGESTION_JOB", "DELETE_DATA_INGESTION_JOB", + "CREATE_TOOL", + "UPDATE_TOOL", + "DELETE_TOOL", } } diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/secret_detail.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/secret_detail.go index c413e7868c2..f98e90fb1ac 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/secret_detail.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/secret_detail.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -22,8 +20,7 @@ import ( "strings" ) -// SecretDetail **SecretDetail** -// The details of configured security configuration on OpenSearch. +// SecretDetail The details of configured security configuration on OpenSearch. type SecretDetail interface { } diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/session_config.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/session_config.go index 554e302292f..e5f9e4ef804 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/session_config.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/session_config.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// SessionConfig **SessionConfig** -// Session Configuration on AgentEndpoint. +// SessionConfig Session Configuration on AgentEndpoint. type SessionConfig struct { // The session will become inactive after this timeout. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/sort_order.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/sort_order.go index a64222411dd..2c77773c9c1 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/sort_order.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/sort_order.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/update_agent_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/update_agent_details.go index 4136e2d1f67..5117bfbbb2b 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/update_agent_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/update_agent_details.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// UpdateAgentDetails **UpdateAgentDetails** -// The data to update an agent. +// UpdateAgentDetails The data to update an agent. type UpdateAgentDetails struct { // A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/update_agent_endpoint_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/update_agent_endpoint_details.go index 77da636d60f..667a9387eca 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/update_agent_endpoint_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/update_agent_endpoint_details.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// UpdateAgentEndpointDetails **UpdateAgentEndpointDetails** -// The data to update an endpoint. +// UpdateAgentEndpointDetails The data to update an endpoint. type UpdateAgentEndpointDetails struct { // A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/update_data_source_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/update_data_source_details.go index 1378556d8ad..bbedc26f0d4 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/update_data_source_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/update_data_source_details.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -22,8 +20,7 @@ import ( "strings" ) -// UpdateDataSourceDetails **UpdateDataSourceDetails** -// The data to update a data source. +// UpdateDataSourceDetails The data to update a data source. type UpdateDataSourceDetails struct { // A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/update_knowledge_base_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/update_knowledge_base_details.go index 3fdf432527e..adc3b944c0c 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/update_knowledge_base_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/update_knowledge_base_details.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -22,8 +20,7 @@ import ( "strings" ) -// UpdateKnowledgeBaseDetails **UpdateKnowledgeBaseDetails** -// The data to update a knowledge base. +// UpdateKnowledgeBaseDetails The data to update a knowledge base. type UpdateKnowledgeBaseDetails struct { // A user-friendly name. Does not have to be unique, and it's changeable. Avoid entering confidential information. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request.go index d0f3ed91f9c..6ab40d8ec6f 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// WorkRequest **WorkRequest** -// An asynchronous work request. Work requests help you monitor long-running operations. When you start a long-running operation, +// WorkRequest An asynchronous work request. Work requests help you monitor long-running operations. When you start a long-running operation, // the service creates a work request. A work request is an activity log that lets you track each step in the operation's // progress. Each work request has an OCID that lets you interact with it programmatically and use it for automation. type WorkRequest struct { diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_error.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_error.go index 65bd929f303..9ed9bece241 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_error.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_error.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// WorkRequestError **WorkRequestError** -// An error encountered while performing an operation that is tracked by a work request. +// WorkRequestError An error encountered while performing an operation that is tracked by a work request. type WorkRequestError struct { // A machine-usable code for the error that occurred. For a list of error codes, see diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_error_collection.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_error_collection.go index c1cf0f8ea8f..c9ce24c5881 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_error_collection.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_error_collection.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// WorkRequestErrorCollection **WorkRequestErrorCollection** -// A list of work request errors. Can contain both errors and other information, such as metadata. +// WorkRequestErrorCollection A list of work request errors. Can contain both errors and other information, such as metadata. type WorkRequestErrorCollection struct { // A list of work request errors. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_log_entry.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_log_entry.go index 06cc29763c0..81b1e90927e 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_log_entry.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_log_entry.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// WorkRequestLogEntry **WorkRequestLogEntry** -// A log message from performing an operation that is tracked by a work request. +// WorkRequestLogEntry A log message from performing an operation that is tracked by a work request. type WorkRequestLogEntry struct { // A human-readable log message. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_log_entry_collection.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_log_entry_collection.go index a67c49dc10d..9dec3fc782b 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_log_entry_collection.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_log_entry_collection.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// WorkRequestLogEntryCollection **WorkRequestLogEntryCollection** -// A list of work request logs. Can contain both logs and other information, such as metadata. +// WorkRequestLogEntryCollection A list of work request logs. Can contain both logs and other information, such as metadata. type WorkRequestLogEntryCollection struct { // A list of work request log entries. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_resource.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_resource.go index 9bca2f0f3c9..0575c19e5b0 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_resource.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_resource.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// WorkRequestResource **WorkRequestResource** -// A resource created or operated on by a work request. +// WorkRequestResource A resource created or operated on by a work request. type WorkRequestResource struct { // The resource type that the work request affects. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_resource_metadata_key.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_resource_metadata_key.go index f83421e9646..b4033fabc74 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_resource_metadata_key.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_resource_metadata_key.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_summary.go index 737d37d493e..bfdfe9e7f23 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_summary.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_summary.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// WorkRequestSummary **WorkRequestSummary** -// Summary information about an asynchronous work request. +// WorkRequestSummary Summary information about an asynchronous work request. type WorkRequestSummary struct { // The asynchronous operation tracked by this work request. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_summary_collection.go b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_summary_collection.go index 2a5049c55ef..657748adee2 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_summary_collection.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/generativeaiagent/work_request_summary_collection.go @@ -4,8 +4,6 @@ // Generative AI Agents Management API // -// **Generative AI Agents API** -// // OCI Generative AI Agents is a fully managed service that combines the power of large language models (LLMs) with an intelligent retrieval system to create contextually relevant answers by searching your knowledge base, making your AI applications smart and efficient. // OCI Generative AI Agents supports several ways to onboard your data and then allows you and your customers to interact with your data using a chat interface or API. // Use the Generative AI Agents API to create and manage agents, knowledge bases, data sources, endpoints, data ingestion jobs, and work requests. @@ -21,8 +19,7 @@ import ( "strings" ) -// WorkRequestSummaryCollection **WorkRequestSummaryCollection** -// A list of work requests. Can contain both work requests and other information, such as metadata. +// WorkRequestSummaryCollection A list of work requests. Can contain both work requests and other information, such as metadata. type WorkRequestSummaryCollection struct { // A list of work requests. diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/change_pipeline_compartment_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/change_pipeline_compartment_details.go new file mode 100644 index 00000000000..96785e188e3 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/change_pipeline_compartment_details.go @@ -0,0 +1,39 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// ChangePipelineCompartmentDetails The new compartment for a Pipeline. +type ChangePipelineCompartmentDetails struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the compartment being referenced. + CompartmentId *string `mandatory:"true" json:"compartmentId"` +} + +func (m ChangePipelineCompartmentDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m ChangePipelineCompartmentDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/change_pipeline_compartment_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/change_pipeline_compartment_request_response.go new file mode 100644 index 00000000000..811b1fa32c5 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/change_pipeline_compartment_request_response.go @@ -0,0 +1,109 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// ChangePipelineCompartmentRequest wrapper for the ChangePipelineCompartment operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ChangePipelineCompartment.go.html to see an example of how to use ChangePipelineCompartmentRequest. +type ChangePipelineCompartmentRequest struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the pipeline created. + PipelineId *string `mandatory:"true" contributesTo:"path" name:"pipelineId"` + + // Properties to change the compartment of a Pipeline. + ChangePipelineCompartmentDetails `contributesTo:"body"` + + // 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 is updated or deleted only if the etag you provide matches the + // resource's current etag value. + IfMatch *string `mandatory:"false" contributesTo:"header" name:"if-match"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Whether to override locks (if any exist). + IsLockOverride *bool `mandatory:"false" contributesTo:"query" name:"isLockOverride"` + + // A token that uniquely identifies a request so it can be retried, in case of a timeout or server error, + // without the risk of executing that same action again. Retry tokens expire after 24 hours but can be + // invalidated before then due to conflicting operations. For example, if a resource was deleted and purged + // from the system, then a retry of the original creation request is rejected. + OpcRetryToken *string `mandatory:"false" contributesTo:"header" name:"opc-retry-token"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request ChangePipelineCompartmentRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request ChangePipelineCompartmentRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request ChangePipelineCompartmentRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request ChangePipelineCompartmentRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request ChangePipelineCompartmentRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// ChangePipelineCompartmentResponse wrapper for the ChangePipelineCompartment operation +type ChangePipelineCompartmentResponse struct { + + // The underlying http response + RawResponse *http.Response + + // A unique Oracle-assigned identifier for an asynchronous request. You can use this to query + // status of the asynchronous operation. + OpcWorkRequestId *string `presentIn:"header" name:"opc-work-request-id"` + + // A unique Oracle-assigned identifier for the request. If you need to contact Oracle about a + // particular request, please include the request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` +} + +func (response ChangePipelineCompartmentResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response ChangePipelineCompartmentResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/create_mysql_connection_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/create_mysql_connection_details.go index 2a98a4a4f5e..f2ec7751b3c 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/create_mysql_connection_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/create_mysql_connection_details.go @@ -95,7 +95,7 @@ type CreateMysqlConnectionDetails struct { // containing the client public key (for 2-way SSL). SslCert *string `mandatory:"false" json:"sslCert"` - // Client Key – The base64 encoded content of a .pem or .crt file containing the client private key (for 2-way SSL). + // Client Key - The base64 encoded content of a .pem or .crt file containing the client private key (for 2-way SSL). SslKey *string `mandatory:"false" json:"sslKey"` // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the Secret that stores the Client Key diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/create_pipeline_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/create_pipeline_details.go new file mode 100644 index 00000000000..b45fcf14e8a --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/create_pipeline_details.go @@ -0,0 +1,171 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// CreatePipelineDetails Details with which to create a pipeline. +type CreatePipelineDetails interface { + + // An object's Display Name. + GetDisplayName() *string + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the compartment being referenced. + GetCompartmentId() *string + + // The Oracle license model that applies to a Deployment. + GetLicenseModel() LicenseModelEnum + + GetSourceConnectionDetails() *SourcePipelineConnectionDetails + + GetTargetConnectionDetails() *TargetPipelineConnectionDetails + + // Metadata about this specific object. + GetDescription() *string + + // A simple key-value pair that is applied without any predefined name, type, or scope. Exists + // for cross-compatibility only. + // Example: `{"bar-key": "value"}` + GetFreeformTags() map[string]string + + // Tags defined for this resource. Each key is predefined and scoped to a namespace. + // Example: `{"foo-namespace": {"bar-key": "value"}}` + GetDefinedTags() map[string]map[string]interface{} + + // Locks associated with this resource. + GetLocks() []ResourceLock +} + +type createpipelinedetails struct { + JsonData []byte + Description *string `mandatory:"false" json:"description"` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` + Locks []ResourceLock `mandatory:"false" json:"locks"` + DisplayName *string `mandatory:"true" json:"displayName"` + CompartmentId *string `mandatory:"true" json:"compartmentId"` + LicenseModel LicenseModelEnum `mandatory:"true" json:"licenseModel"` + SourceConnectionDetails *SourcePipelineConnectionDetails `mandatory:"true" json:"sourceConnectionDetails"` + TargetConnectionDetails *TargetPipelineConnectionDetails `mandatory:"true" json:"targetConnectionDetails"` + RecipeType string `json:"recipeType"` +} + +// UnmarshalJSON unmarshals json +func (m *createpipelinedetails) UnmarshalJSON(data []byte) error { + m.JsonData = data + type Unmarshalercreatepipelinedetails createpipelinedetails + s := struct { + Model Unmarshalercreatepipelinedetails + }{} + err := json.Unmarshal(data, &s.Model) + if err != nil { + return err + } + m.DisplayName = s.Model.DisplayName + m.CompartmentId = s.Model.CompartmentId + m.LicenseModel = s.Model.LicenseModel + m.SourceConnectionDetails = s.Model.SourceConnectionDetails + m.TargetConnectionDetails = s.Model.TargetConnectionDetails + m.Description = s.Model.Description + m.FreeformTags = s.Model.FreeformTags + m.DefinedTags = s.Model.DefinedTags + m.Locks = s.Model.Locks + m.RecipeType = s.Model.RecipeType + + return err +} + +// UnmarshalPolymorphicJSON unmarshals polymorphic json +func (m *createpipelinedetails) UnmarshalPolymorphicJSON(data []byte) (interface{}, error) { + + if data == nil || string(data) == "null" { + return nil, nil + } + + var err error + switch m.RecipeType { + case "ZERO_ETL": + mm := CreateZeroEtlPipelineDetails{} + err = json.Unmarshal(data, &mm) + return mm, err + default: + common.Logf("Recieved unsupported enum value for CreatePipelineDetails: %s.", m.RecipeType) + return *m, nil + } +} + +// GetDescription returns Description +func (m createpipelinedetails) GetDescription() *string { + return m.Description +} + +// GetFreeformTags returns FreeformTags +func (m createpipelinedetails) GetFreeformTags() map[string]string { + return m.FreeformTags +} + +// GetDefinedTags returns DefinedTags +func (m createpipelinedetails) GetDefinedTags() map[string]map[string]interface{} { + return m.DefinedTags +} + +// GetLocks returns Locks +func (m createpipelinedetails) GetLocks() []ResourceLock { + return m.Locks +} + +// GetDisplayName returns DisplayName +func (m createpipelinedetails) GetDisplayName() *string { + return m.DisplayName +} + +// GetCompartmentId returns CompartmentId +func (m createpipelinedetails) GetCompartmentId() *string { + return m.CompartmentId +} + +// GetLicenseModel returns LicenseModel +func (m createpipelinedetails) GetLicenseModel() LicenseModelEnum { + return m.LicenseModel +} + +// GetSourceConnectionDetails returns SourceConnectionDetails +func (m createpipelinedetails) GetSourceConnectionDetails() *SourcePipelineConnectionDetails { + return m.SourceConnectionDetails +} + +// GetTargetConnectionDetails returns TargetConnectionDetails +func (m createpipelinedetails) GetTargetConnectionDetails() *TargetPipelineConnectionDetails { + return m.TargetConnectionDetails +} + +func (m createpipelinedetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m createpipelinedetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingLicenseModelEnum(string(m.LicenseModel)); !ok && m.LicenseModel != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LicenseModel: %s. Supported values are: %s.", m.LicenseModel, strings.Join(GetLicenseModelEnumStringValues(), ","))) + } + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/create_pipeline_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/create_pipeline_request_response.go new file mode 100644 index 00000000000..1e89662a035 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/create_pipeline_request_response.go @@ -0,0 +1,103 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// CreatePipelineRequest wrapper for the CreatePipeline operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/CreatePipeline.go.html to see an example of how to use CreatePipelineRequest. +type CreatePipelineRequest struct { + + // Specification of the pipeline to create. + CreatePipelineDetails `contributesTo:"body"` + + // A token that uniquely identifies a request so it can be retried, in case of a timeout or server error, + // without the risk of executing that same action again. Retry tokens expire after 24 hours but can be + // invalidated before then due to conflicting operations. For example, if a resource was deleted and purged + // from the system, then a retry of the original creation request is rejected. + OpcRetryToken *string `mandatory:"false" contributesTo:"header" name:"opc-retry-token"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request CreatePipelineRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request CreatePipelineRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request CreatePipelineRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request CreatePipelineRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request CreatePipelineRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// CreatePipelineResponse wrapper for the CreatePipeline operation +type CreatePipelineResponse struct { + + // The underlying http response + RawResponse *http.Response + + // The Pipeline instance + Pipeline `presentIn:"body"` + + // A unique Oracle-assigned identifier for an asynchronous request. You can use this to query + // status of the asynchronous operation. + OpcWorkRequestId *string `presentIn:"header" name:"opc-work-request-id"` + + // A unique Oracle-assigned identifier for the request. If you need to contact Oracle about a + // particular request, please include the request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // For optimistic concurrency control. See `if-match`. + Etag *string `presentIn:"header" name:"etag"` +} + +func (response CreatePipelineResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response CreatePipelineResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/create_zero_etl_pipeline_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/create_zero_etl_pipeline_details.go new file mode 100644 index 00000000000..3751a16d87a --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/create_zero_etl_pipeline_details.go @@ -0,0 +1,129 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// CreateZeroEtlPipelineDetails Creation details for a new ZeroETL pipeline. +type CreateZeroEtlPipelineDetails struct { + + // An object's Display Name. + DisplayName *string `mandatory:"true" json:"displayName"` + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the compartment being referenced. + CompartmentId *string `mandatory:"true" json:"compartmentId"` + + SourceConnectionDetails *SourcePipelineConnectionDetails `mandatory:"true" json:"sourceConnectionDetails"` + + TargetConnectionDetails *TargetPipelineConnectionDetails `mandatory:"true" json:"targetConnectionDetails"` + + // Metadata about this specific object. + Description *string `mandatory:"false" json:"description"` + + // A simple key-value pair that is applied without any predefined name, type, or scope. Exists + // for cross-compatibility only. + // Example: `{"bar-key": "value"}` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + + // Tags defined for this resource. Each key is predefined and scoped to a namespace. + // Example: `{"foo-namespace": {"bar-key": "value"}}` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` + + // Locks associated with this resource. + Locks []ResourceLock `mandatory:"false" json:"locks"` + + ProcessOptions *ProcessOptions `mandatory:"false" json:"processOptions"` + + // The Oracle license model that applies to a Deployment. + LicenseModel LicenseModelEnum `mandatory:"true" json:"licenseModel"` +} + +// GetDisplayName returns DisplayName +func (m CreateZeroEtlPipelineDetails) GetDisplayName() *string { + return m.DisplayName +} + +// GetDescription returns Description +func (m CreateZeroEtlPipelineDetails) GetDescription() *string { + return m.Description +} + +// GetCompartmentId returns CompartmentId +func (m CreateZeroEtlPipelineDetails) GetCompartmentId() *string { + return m.CompartmentId +} + +// GetLicenseModel returns LicenseModel +func (m CreateZeroEtlPipelineDetails) GetLicenseModel() LicenseModelEnum { + return m.LicenseModel +} + +// GetFreeformTags returns FreeformTags +func (m CreateZeroEtlPipelineDetails) GetFreeformTags() map[string]string { + return m.FreeformTags +} + +// GetDefinedTags returns DefinedTags +func (m CreateZeroEtlPipelineDetails) GetDefinedTags() map[string]map[string]interface{} { + return m.DefinedTags +} + +// GetLocks returns Locks +func (m CreateZeroEtlPipelineDetails) GetLocks() []ResourceLock { + return m.Locks +} + +// GetSourceConnectionDetails returns SourceConnectionDetails +func (m CreateZeroEtlPipelineDetails) GetSourceConnectionDetails() *SourcePipelineConnectionDetails { + return m.SourceConnectionDetails +} + +// GetTargetConnectionDetails returns TargetConnectionDetails +func (m CreateZeroEtlPipelineDetails) GetTargetConnectionDetails() *TargetPipelineConnectionDetails { + return m.TargetConnectionDetails +} + +func (m CreateZeroEtlPipelineDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m CreateZeroEtlPipelineDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if _, ok := GetMappingLicenseModelEnum(string(m.LicenseModel)); !ok && m.LicenseModel != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LicenseModel: %s. Supported values are: %s.", m.LicenseModel, strings.Join(GetLicenseModelEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m CreateZeroEtlPipelineDetails) MarshalJSON() (buff []byte, e error) { + type MarshalTypeCreateZeroEtlPipelineDetails CreateZeroEtlPipelineDetails + s := struct { + DiscriminatorParam string `json:"recipeType"` + MarshalTypeCreateZeroEtlPipelineDetails + }{ + "ZERO_ETL", + (MarshalTypeCreateZeroEtlPipelineDetails)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/default_start_pipeline_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/default_start_pipeline_details.go new file mode 100644 index 00000000000..cbb6eed218a --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/default_start_pipeline_details.go @@ -0,0 +1,51 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// DefaultStartPipelineDetails Attribute details for a default pipeline start. +type DefaultStartPipelineDetails struct { +} + +func (m DefaultStartPipelineDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m DefaultStartPipelineDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m DefaultStartPipelineDetails) MarshalJSON() (buff []byte, e error) { + type MarshalTypeDefaultStartPipelineDetails DefaultStartPipelineDetails + s := struct { + DiscriminatorParam string `json:"type"` + MarshalTypeDefaultStartPipelineDetails + }{ + "DEFAULT", + (MarshalTypeDefaultStartPipelineDetails)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/default_stop_pipeline_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/default_stop_pipeline_details.go new file mode 100644 index 00000000000..a5b11b65cbe --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/default_stop_pipeline_details.go @@ -0,0 +1,51 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// DefaultStopPipelineDetails Attribute details for a default pipeline stop. +type DefaultStopPipelineDetails struct { +} + +func (m DefaultStopPipelineDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m DefaultStopPipelineDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m DefaultStopPipelineDetails) MarshalJSON() (buff []byte, e error) { + type MarshalTypeDefaultStopPipelineDetails DefaultStopPipelineDetails + s := struct { + DiscriminatorParam string `json:"type"` + MarshalTypeDefaultStopPipelineDetails + }{ + "DEFAULT", + (MarshalTypeDefaultStopPipelineDetails)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/default_test_pipeline_connection_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/default_test_pipeline_connection_details.go new file mode 100644 index 00000000000..f245a28ad44 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/default_test_pipeline_connection_details.go @@ -0,0 +1,55 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// DefaultTestPipelineConnectionDetails Additional attribute with which to test the pipeline's connection. The connectionId must be one of the pipeline's assigned connections. +type DefaultTestPipelineConnectionDetails struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the connection being + // referenced. + ConnectionId *string `mandatory:"true" json:"connectionId"` +} + +func (m DefaultTestPipelineConnectionDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m DefaultTestPipelineConnectionDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m DefaultTestPipelineConnectionDetails) MarshalJSON() (buff []byte, e error) { + type MarshalTypeDefaultTestPipelineConnectionDetails DefaultTestPipelineConnectionDetails + s := struct { + DiscriminatorParam string `json:"type"` + MarshalTypeDefaultTestPipelineConnectionDetails + }{ + "DEFAULT", + (MarshalTypeDefaultTestPipelineConnectionDetails)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/delete_pipeline_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/delete_pipeline_request_response.go new file mode 100644 index 00000000000..64fd432b81e --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/delete_pipeline_request_response.go @@ -0,0 +1,100 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// DeletePipelineRequest wrapper for the DeletePipeline operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/DeletePipeline.go.html to see an example of how to use DeletePipelineRequest. +type DeletePipelineRequest struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the pipeline created. + PipelineId *string `mandatory:"true" contributesTo:"path" name:"pipelineId"` + + // 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 is updated or deleted only if the etag you provide matches the + // resource's current etag value. + IfMatch *string `mandatory:"false" contributesTo:"header" name:"if-match"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Whether to override locks (if any exist). + IsLockOverride *bool `mandatory:"false" contributesTo:"query" name:"isLockOverride"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request DeletePipelineRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request DeletePipelineRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request DeletePipelineRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request DeletePipelineRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request DeletePipelineRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// DeletePipelineResponse wrapper for the DeletePipeline operation +type DeletePipelineResponse struct { + + // The underlying http response + RawResponse *http.Response + + // A unique Oracle-assigned identifier for an asynchronous request. You can use this to query + // status of the asynchronous operation. + OpcWorkRequestId *string `presentIn:"header" name:"opc-work-request-id"` + + // A unique Oracle-assigned identifier for the request. If you need to contact Oracle about a + // particular request, please include the request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` +} + +func (response DeletePipelineResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response DeletePipelineResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/get_pipeline_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/get_pipeline_request_response.go new file mode 100644 index 00000000000..2c7e7699154 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/get_pipeline_request_response.go @@ -0,0 +1,93 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// GetPipelineRequest wrapper for the GetPipeline operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/GetPipeline.go.html to see an example of how to use GetPipelineRequest. +type GetPipelineRequest struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the pipeline created. + PipelineId *string `mandatory:"true" contributesTo:"path" name:"pipelineId"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request GetPipelineRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request GetPipelineRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request GetPipelineRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request GetPipelineRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request GetPipelineRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// GetPipelineResponse wrapper for the GetPipeline operation +type GetPipelineResponse struct { + + // The underlying http response + RawResponse *http.Response + + // The Pipeline instance + Pipeline `presentIn:"body"` + + // For optimistic concurrency control. See `if-match`. + Etag *string `presentIn:"header" name:"etag"` + + // A unique Oracle-assigned identifier for the request. If you need to contact Oracle about a + // particular request, please include the request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` +} + +func (response GetPipelineResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response GetPipelineResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/goldengate_client.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/goldengate_client.go index 726f0a835aa..ce966fe2b78 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/goldengate_client.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/goldengate_client.go @@ -714,6 +714,72 @@ func (client GoldenGateClient) changeDeploymentCompartment(ctx context.Context, return response, err } +// ChangePipelineCompartment Moves the Pipeline into a different compartment within the same tenancy. When +// provided, If-Match is checked against ETag values of the resource. For information about +// moving resources between compartments, see Moving Resources Between +// Compartments (https://docs.cloud.oracle.com/iaas/Content/Identity/Tasks/managingcompartments.htm#moveRes). +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ChangePipelineCompartment.go.html to see an example of how to use ChangePipelineCompartment API. +// A default retry strategy applies to this operation ChangePipelineCompartment() +func (client GoldenGateClient) ChangePipelineCompartment(ctx context.Context, request ChangePipelineCompartmentRequest) (response ChangePipelineCompartmentResponse, err error) { + var ociResponse common.OCIResponse + policy := common.DefaultRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + + if !(request.OpcRetryToken != nil && *request.OpcRetryToken != "") { + request.OpcRetryToken = common.String(common.RetryToken()) + } + + ociResponse, err = common.Retry(ctx, request, client.changePipelineCompartment, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = ChangePipelineCompartmentResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = ChangePipelineCompartmentResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(ChangePipelineCompartmentResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into ChangePipelineCompartmentResponse") + } + return +} + +// changePipelineCompartment implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) changePipelineCompartment(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodPost, "/pipelines/{pipelineId}/actions/changeCompartment", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response ChangePipelineCompartmentResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/Pipeline/ChangePipelineCompartment" + err = common.PostProcessServiceError(err, "GoldenGate", "ChangePipelineCompartment", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + // CollectDeploymentDiagnostic Collects the diagnostic of a Deployment. When provided, If-Match is checked against ETag values of the resource. // // # See also @@ -1219,6 +1285,69 @@ func (client GoldenGateClient) createDeploymentBackup(ctx context.Context, reque return response, err } +// CreatePipeline Creates a new Pipeline. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/CreatePipeline.go.html to see an example of how to use CreatePipeline API. +// A default retry strategy applies to this operation CreatePipeline() +func (client GoldenGateClient) CreatePipeline(ctx context.Context, request CreatePipelineRequest) (response CreatePipelineResponse, err error) { + var ociResponse common.OCIResponse + policy := common.DefaultRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + + if !(request.OpcRetryToken != nil && *request.OpcRetryToken != "") { + request.OpcRetryToken = common.String(common.RetryToken()) + } + + ociResponse, err = common.Retry(ctx, request, client.createPipeline, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = CreatePipelineResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = CreatePipelineResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(CreatePipelineResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into CreatePipelineResponse") + } + return +} + +// createPipeline implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) createPipeline(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodPost, "/pipelines", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response CreatePipelineResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/Pipeline/CreatePipeline" + err = common.PostProcessServiceError(err, "GoldenGate", "CreatePipeline", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponseWithPolymorphicBody(httpResponse, &response, &pipeline{}) + return response, err +} + // DeleteCertificate Deletes the certificate from truststore. // // # See also @@ -1568,6 +1697,64 @@ func (client GoldenGateClient) deleteDeploymentBackup(ctx context.Context, reque return response, err } +// DeletePipeline Deletes a Pipeline. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/DeletePipeline.go.html to see an example of how to use DeletePipeline API. +// A default retry strategy applies to this operation DeletePipeline() +func (client GoldenGateClient) DeletePipeline(ctx context.Context, request DeletePipelineRequest) (response DeletePipelineResponse, err error) { + var ociResponse common.OCIResponse + policy := common.DefaultRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + ociResponse, err = common.Retry(ctx, request, client.deletePipeline, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = DeletePipelineResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = DeletePipelineResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(DeletePipelineResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into DeletePipelineResponse") + } + return +} + +// deletePipeline implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) deletePipeline(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodDelete, "/pipelines/{pipelineId}", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response DeletePipelineResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/Pipeline/DeletePipeline" + err = common.PostProcessServiceError(err, "GoldenGate", "DeletePipeline", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + // DeploymentWalletExists Checks if a wallet is already present in the deployment. When provided, If-Match is checked against ETag values of the resource. // // # See also @@ -2164,6 +2351,64 @@ func (client GoldenGateClient) getDeploymentUpgrade(ctx context.Context, request return response, err } +// GetPipeline Retrieves a Pipeline details. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/GetPipeline.go.html to see an example of how to use GetPipeline API. +// A default retry strategy applies to this operation GetPipeline() +func (client GoldenGateClient) GetPipeline(ctx context.Context, request GetPipelineRequest) (response GetPipelineResponse, err error) { + var ociResponse common.OCIResponse + policy := common.DefaultRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + ociResponse, err = common.Retry(ctx, request, client.getPipeline, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = GetPipelineResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = GetPipelineResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(GetPipelineResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into GetPipelineResponse") + } + return +} + +// getPipeline implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) getPipeline(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodGet, "/pipelines/{pipelineId}", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response GetPipelineResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/Pipeline/GetPipeline" + err = common.PostProcessServiceError(err, "GoldenGate", "GetPipeline", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponseWithPolymorphicBody(httpResponse, &response, &pipeline{}) + return response, err +} + // GetWorkRequest Retrieve the WorkRequest identified by the given OCID. // // # See also @@ -2982,13 +3227,13 @@ func (client GoldenGateClient) listMessages(ctx context.Context, request common. return response, err } -// ListTrailFiles Lists the TrailFiles for a deployment. Deprecated: Please access trail file management functions directly on OGG console which are available since version Oracle GoldenGate 23c. +// ListPipelineInitializationSteps Retrieves a Pipeline recipe steps and its progress details. // // # See also // -// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListTrailFiles.go.html to see an example of how to use ListTrailFiles API. -// A default retry strategy applies to this operation ListTrailFiles() -func (client GoldenGateClient) ListTrailFiles(ctx context.Context, request ListTrailFilesRequest) (response ListTrailFilesResponse, err error) { +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListPipelineInitializationSteps.go.html to see an example of how to use ListPipelineInitializationSteps API. +// A default retry strategy applies to this operation ListPipelineInitializationSteps() +func (client GoldenGateClient) ListPipelineInitializationSteps(ctx context.Context, request ListPipelineInitializationStepsRequest) (response ListPipelineInitializationStepsResponse, err error) { var ociResponse common.OCIResponse policy := common.DefaultRetryPolicy() if client.RetryPolicy() != nil { @@ -2997,42 +3242,42 @@ func (client GoldenGateClient) ListTrailFiles(ctx context.Context, request ListT if request.RetryPolicy() != nil { policy = *request.RetryPolicy() } - ociResponse, err = common.Retry(ctx, request, client.listTrailFiles, policy) + ociResponse, err = common.Retry(ctx, request, client.listPipelineInitializationSteps, policy) if err != nil { if ociResponse != nil { if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { opcRequestId := httpResponse.Header.Get("opc-request-id") - response = ListTrailFilesResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + response = ListPipelineInitializationStepsResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} } else { - response = ListTrailFilesResponse{} + response = ListPipelineInitializationStepsResponse{} } } return } - if convertedResponse, ok := ociResponse.(ListTrailFilesResponse); ok { + if convertedResponse, ok := ociResponse.(ListPipelineInitializationStepsResponse); ok { response = convertedResponse } else { - err = fmt.Errorf("failed to convert OCIResponse into ListTrailFilesResponse") + err = fmt.Errorf("failed to convert OCIResponse into ListPipelineInitializationStepsResponse") } return } -// listTrailFiles implements the OCIOperation interface (enables retrying operations) -func (client GoldenGateClient) listTrailFiles(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { +// listPipelineInitializationSteps implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) listPipelineInitializationSteps(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { - httpRequest, err := request.HTTPRequest(http.MethodGet, "/trailFiles", binaryReqBody, extraHeaders) + httpRequest, err := request.HTTPRequest(http.MethodGet, "/pipelines/{pipelineId}/initializationSteps", binaryReqBody, extraHeaders) if err != nil { return nil, err } - var response ListTrailFilesResponse + var response ListPipelineInitializationStepsResponse var httpResponse *http.Response httpResponse, err = client.Call(ctx, &httpRequest) defer common.CloseBodyIfValid(httpResponse) response.RawResponse = httpResponse if err != nil { - apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/TrailFileSummary/ListTrailFiles" - err = common.PostProcessServiceError(err, "GoldenGate", "ListTrailFiles", apiReferenceLink) + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/Pipeline/ListPipelineInitializationSteps" + err = common.PostProcessServiceError(err, "GoldenGate", "ListPipelineInitializationSteps", apiReferenceLink) return response, err } @@ -3040,13 +3285,13 @@ func (client GoldenGateClient) listTrailFiles(ctx context.Context, request commo return response, err } -// ListTrailSequences Lists the Trail Sequences for a TrailFile in a given deployment. Deprecated: Please access trail file management functions directly on OGG console which are available since version Oracle GoldenGate 23c. +// ListPipelineRunningProcesses Retrieves a Pipeline's running replication process's status like extracts/replicats. // // # See also // -// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListTrailSequences.go.html to see an example of how to use ListTrailSequences API. -// A default retry strategy applies to this operation ListTrailSequences() -func (client GoldenGateClient) ListTrailSequences(ctx context.Context, request ListTrailSequencesRequest) (response ListTrailSequencesResponse, err error) { +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListPipelineRunningProcesses.go.html to see an example of how to use ListPipelineRunningProcesses API. +// A default retry strategy applies to this operation ListPipelineRunningProcesses() +func (client GoldenGateClient) ListPipelineRunningProcesses(ctx context.Context, request ListPipelineRunningProcessesRequest) (response ListPipelineRunningProcessesResponse, err error) { var ociResponse common.OCIResponse policy := common.DefaultRetryPolicy() if client.RetryPolicy() != nil { @@ -3055,42 +3300,42 @@ func (client GoldenGateClient) ListTrailSequences(ctx context.Context, request L if request.RetryPolicy() != nil { policy = *request.RetryPolicy() } - ociResponse, err = common.Retry(ctx, request, client.listTrailSequences, policy) + ociResponse, err = common.Retry(ctx, request, client.listPipelineRunningProcesses, policy) if err != nil { if ociResponse != nil { if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { opcRequestId := httpResponse.Header.Get("opc-request-id") - response = ListTrailSequencesResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + response = ListPipelineRunningProcessesResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} } else { - response = ListTrailSequencesResponse{} + response = ListPipelineRunningProcessesResponse{} } } return } - if convertedResponse, ok := ociResponse.(ListTrailSequencesResponse); ok { + if convertedResponse, ok := ociResponse.(ListPipelineRunningProcessesResponse); ok { response = convertedResponse } else { - err = fmt.Errorf("failed to convert OCIResponse into ListTrailSequencesResponse") + err = fmt.Errorf("failed to convert OCIResponse into ListPipelineRunningProcessesResponse") } return } -// listTrailSequences implements the OCIOperation interface (enables retrying operations) -func (client GoldenGateClient) listTrailSequences(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { +// listPipelineRunningProcesses implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) listPipelineRunningProcesses(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { - httpRequest, err := request.HTTPRequest(http.MethodGet, "/trailSequences", binaryReqBody, extraHeaders) + httpRequest, err := request.HTTPRequest(http.MethodGet, "/pipelines/{pipelineId}/runningProcesses", binaryReqBody, extraHeaders) if err != nil { return nil, err } - var response ListTrailSequencesResponse + var response ListPipelineRunningProcessesResponse var httpResponse *http.Response httpResponse, err = client.Call(ctx, &httpRequest) defer common.CloseBodyIfValid(httpResponse) response.RawResponse = httpResponse if err != nil { - apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/TrailSequenceSummary/ListTrailSequences" - err = common.PostProcessServiceError(err, "GoldenGate", "ListTrailSequences", apiReferenceLink) + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/Pipeline/ListPipelineRunningProcesses" + err = common.PostProcessServiceError(err, "GoldenGate", "ListPipelineRunningProcesses", apiReferenceLink) return response, err } @@ -3098,13 +3343,13 @@ func (client GoldenGateClient) listTrailSequences(ctx context.Context, request c return response, err } -// ListWorkRequestErrors Lists work request errors. +// ListPipelineSchemaTables Returns an array of tables under the given schemas of the pipeline for given source and target schemas passed as query params. // // # See also // -// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListWorkRequestErrors.go.html to see an example of how to use ListWorkRequestErrors API. -// A default retry strategy applies to this operation ListWorkRequestErrors() -func (client GoldenGateClient) ListWorkRequestErrors(ctx context.Context, request ListWorkRequestErrorsRequest) (response ListWorkRequestErrorsResponse, err error) { +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListPipelineSchemaTables.go.html to see an example of how to use ListPipelineSchemaTables API. +// A default retry strategy applies to this operation ListPipelineSchemaTables() +func (client GoldenGateClient) ListPipelineSchemaTables(ctx context.Context, request ListPipelineSchemaTablesRequest) (response ListPipelineSchemaTablesResponse, err error) { var ociResponse common.OCIResponse policy := common.DefaultRetryPolicy() if client.RetryPolicy() != nil { @@ -3113,42 +3358,42 @@ func (client GoldenGateClient) ListWorkRequestErrors(ctx context.Context, reques if request.RetryPolicy() != nil { policy = *request.RetryPolicy() } - ociResponse, err = common.Retry(ctx, request, client.listWorkRequestErrors, policy) + ociResponse, err = common.Retry(ctx, request, client.listPipelineSchemaTables, policy) if err != nil { if ociResponse != nil { if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { opcRequestId := httpResponse.Header.Get("opc-request-id") - response = ListWorkRequestErrorsResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + response = ListPipelineSchemaTablesResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} } else { - response = ListWorkRequestErrorsResponse{} + response = ListPipelineSchemaTablesResponse{} } } return } - if convertedResponse, ok := ociResponse.(ListWorkRequestErrorsResponse); ok { + if convertedResponse, ok := ociResponse.(ListPipelineSchemaTablesResponse); ok { response = convertedResponse } else { - err = fmt.Errorf("failed to convert OCIResponse into ListWorkRequestErrorsResponse") + err = fmt.Errorf("failed to convert OCIResponse into ListPipelineSchemaTablesResponse") } return } -// listWorkRequestErrors implements the OCIOperation interface (enables retrying operations) -func (client GoldenGateClient) listWorkRequestErrors(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { +// listPipelineSchemaTables implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) listPipelineSchemaTables(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { - httpRequest, err := request.HTTPRequest(http.MethodGet, "/workRequests/{workRequestId}/errors", binaryReqBody, extraHeaders) + httpRequest, err := request.HTTPRequest(http.MethodGet, "/pipelines/{pipelineId}/schemaTables", binaryReqBody, extraHeaders) if err != nil { return nil, err } - var response ListWorkRequestErrorsResponse + var response ListPipelineSchemaTablesResponse var httpResponse *http.Response httpResponse, err = client.Call(ctx, &httpRequest) defer common.CloseBodyIfValid(httpResponse) response.RawResponse = httpResponse if err != nil { - apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/WorkRequestError/ListWorkRequestErrors" - err = common.PostProcessServiceError(err, "GoldenGate", "ListWorkRequestErrors", apiReferenceLink) + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/Pipeline/ListPipelineSchemaTables" + err = common.PostProcessServiceError(err, "GoldenGate", "ListPipelineSchemaTables", apiReferenceLink) return response, err } @@ -3156,13 +3401,13 @@ func (client GoldenGateClient) listWorkRequestErrors(ctx context.Context, reques return response, err } -// ListWorkRequestLogs Lists work request logs. +// ListPipelineSchemas Returns an array of schemas based on mapping rules for a pipeline. // // # See also // -// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListWorkRequestLogs.go.html to see an example of how to use ListWorkRequestLogs API. -// A default retry strategy applies to this operation ListWorkRequestLogs() -func (client GoldenGateClient) ListWorkRequestLogs(ctx context.Context, request ListWorkRequestLogsRequest) (response ListWorkRequestLogsResponse, err error) { +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListPipelineSchemas.go.html to see an example of how to use ListPipelineSchemas API. +// A default retry strategy applies to this operation ListPipelineSchemas() +func (client GoldenGateClient) ListPipelineSchemas(ctx context.Context, request ListPipelineSchemasRequest) (response ListPipelineSchemasResponse, err error) { var ociResponse common.OCIResponse policy := common.DefaultRetryPolicy() if client.RetryPolicy() != nil { @@ -3171,42 +3416,42 @@ func (client GoldenGateClient) ListWorkRequestLogs(ctx context.Context, request if request.RetryPolicy() != nil { policy = *request.RetryPolicy() } - ociResponse, err = common.Retry(ctx, request, client.listWorkRequestLogs, policy) + ociResponse, err = common.Retry(ctx, request, client.listPipelineSchemas, policy) if err != nil { if ociResponse != nil { if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { opcRequestId := httpResponse.Header.Get("opc-request-id") - response = ListWorkRequestLogsResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + response = ListPipelineSchemasResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} } else { - response = ListWorkRequestLogsResponse{} + response = ListPipelineSchemasResponse{} } } return } - if convertedResponse, ok := ociResponse.(ListWorkRequestLogsResponse); ok { + if convertedResponse, ok := ociResponse.(ListPipelineSchemasResponse); ok { response = convertedResponse } else { - err = fmt.Errorf("failed to convert OCIResponse into ListWorkRequestLogsResponse") + err = fmt.Errorf("failed to convert OCIResponse into ListPipelineSchemasResponse") } return } -// listWorkRequestLogs implements the OCIOperation interface (enables retrying operations) -func (client GoldenGateClient) listWorkRequestLogs(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { +// listPipelineSchemas implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) listPipelineSchemas(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { - httpRequest, err := request.HTTPRequest(http.MethodGet, "/workRequests/{workRequestId}/logs", binaryReqBody, extraHeaders) + httpRequest, err := request.HTTPRequest(http.MethodGet, "/pipelines/{pipelineId}/schemas", binaryReqBody, extraHeaders) if err != nil { return nil, err } - var response ListWorkRequestLogsResponse + var response ListPipelineSchemasResponse var httpResponse *http.Response httpResponse, err = client.Call(ctx, &httpRequest) defer common.CloseBodyIfValid(httpResponse) response.RawResponse = httpResponse if err != nil { - apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/WorkRequestLogEntry/ListWorkRequestLogs" - err = common.PostProcessServiceError(err, "GoldenGate", "ListWorkRequestLogs", apiReferenceLink) + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/Pipeline/ListPipelineSchemas" + err = common.PostProcessServiceError(err, "GoldenGate", "ListPipelineSchemas", apiReferenceLink) return response, err } @@ -3214,13 +3459,13 @@ func (client GoldenGateClient) listWorkRequestLogs(ctx context.Context, request return response, err } -// ListWorkRequests Lists the work requests in the compartment. +// ListPipelines Lists the Pipelines in the compartment. // // # See also // -// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListWorkRequests.go.html to see an example of how to use ListWorkRequests API. -// A default retry strategy applies to this operation ListWorkRequests() -func (client GoldenGateClient) ListWorkRequests(ctx context.Context, request ListWorkRequestsRequest) (response ListWorkRequestsResponse, err error) { +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListPipelines.go.html to see an example of how to use ListPipelines API. +// A default retry strategy applies to this operation ListPipelines() +func (client GoldenGateClient) ListPipelines(ctx context.Context, request ListPipelinesRequest) (response ListPipelinesResponse, err error) { var ociResponse common.OCIResponse policy := common.DefaultRetryPolicy() if client.RetryPolicy() != nil { @@ -3229,42 +3474,392 @@ func (client GoldenGateClient) ListWorkRequests(ctx context.Context, request Lis if request.RetryPolicy() != nil { policy = *request.RetryPolicy() } - ociResponse, err = common.Retry(ctx, request, client.listWorkRequests, policy) + ociResponse, err = common.Retry(ctx, request, client.listPipelines, policy) if err != nil { if ociResponse != nil { if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { opcRequestId := httpResponse.Header.Get("opc-request-id") - response = ListWorkRequestsResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + response = ListPipelinesResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} } else { - response = ListWorkRequestsResponse{} + response = ListPipelinesResponse{} } } return } - if convertedResponse, ok := ociResponse.(ListWorkRequestsResponse); ok { + if convertedResponse, ok := ociResponse.(ListPipelinesResponse); ok { response = convertedResponse } else { - err = fmt.Errorf("failed to convert OCIResponse into ListWorkRequestsResponse") + err = fmt.Errorf("failed to convert OCIResponse into ListPipelinesResponse") } return } -// listWorkRequests implements the OCIOperation interface (enables retrying operations) -func (client GoldenGateClient) listWorkRequests(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { +// listPipelines implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) listPipelines(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { - httpRequest, err := request.HTTPRequest(http.MethodGet, "/workRequests", binaryReqBody, extraHeaders) + httpRequest, err := request.HTTPRequest(http.MethodGet, "/pipelines", binaryReqBody, extraHeaders) if err != nil { return nil, err } - var response ListWorkRequestsResponse + var response ListPipelinesResponse var httpResponse *http.Response httpResponse, err = client.Call(ctx, &httpRequest) defer common.CloseBodyIfValid(httpResponse) response.RawResponse = httpResponse if err != nil { - apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/WorkRequest/ListWorkRequests" - err = common.PostProcessServiceError(err, "GoldenGate", "ListWorkRequests", apiReferenceLink) + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/Pipeline/ListPipelines" + err = common.PostProcessServiceError(err, "GoldenGate", "ListPipelines", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + +// ListRecipes Returns an array of Recipe Summary. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListRecipes.go.html to see an example of how to use ListRecipes API. +// A default retry strategy applies to this operation ListRecipes() +func (client GoldenGateClient) ListRecipes(ctx context.Context, request ListRecipesRequest) (response ListRecipesResponse, err error) { + var ociResponse common.OCIResponse + policy := common.DefaultRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + ociResponse, err = common.Retry(ctx, request, client.listRecipes, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = ListRecipesResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = ListRecipesResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(ListRecipesResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into ListRecipesResponse") + } + return +} + +// listRecipes implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) listRecipes(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodGet, "/recipes", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response ListRecipesResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/RecipeSummaryCollection/ListRecipes" + err = common.PostProcessServiceError(err, "GoldenGate", "ListRecipes", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + +// ListTrailFiles Lists the TrailFiles for a deployment. +// Deprecated: Please access trail file management functions directly on OGG console which are available since version Oracle GoldenGate 23c. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListTrailFiles.go.html to see an example of how to use ListTrailFiles API. +// A default retry strategy applies to this operation ListTrailFiles() +func (client GoldenGateClient) ListTrailFiles(ctx context.Context, request ListTrailFilesRequest) (response ListTrailFilesResponse, err error) { + var ociResponse common.OCIResponse + policy := common.DefaultRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + ociResponse, err = common.Retry(ctx, request, client.listTrailFiles, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = ListTrailFilesResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = ListTrailFilesResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(ListTrailFilesResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into ListTrailFilesResponse") + } + return +} + +// listTrailFiles implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) listTrailFiles(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodGet, "/trailFiles", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response ListTrailFilesResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/TrailFileSummary/ListTrailFiles" + err = common.PostProcessServiceError(err, "GoldenGate", "ListTrailFiles", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + +// ListTrailSequences Lists the Trail Sequences for a TrailFile in a given deployment. +// Deprecated: Please access trail file management functions directly on OGG console which are available since version Oracle GoldenGate 23c. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListTrailSequences.go.html to see an example of how to use ListTrailSequences API. +// A default retry strategy applies to this operation ListTrailSequences() +func (client GoldenGateClient) ListTrailSequences(ctx context.Context, request ListTrailSequencesRequest) (response ListTrailSequencesResponse, err error) { + var ociResponse common.OCIResponse + policy := common.DefaultRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + ociResponse, err = common.Retry(ctx, request, client.listTrailSequences, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = ListTrailSequencesResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = ListTrailSequencesResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(ListTrailSequencesResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into ListTrailSequencesResponse") + } + return +} + +// listTrailSequences implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) listTrailSequences(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodGet, "/trailSequences", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response ListTrailSequencesResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/TrailSequenceSummary/ListTrailSequences" + err = common.PostProcessServiceError(err, "GoldenGate", "ListTrailSequences", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + +// ListWorkRequestErrors Lists work request errors. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListWorkRequestErrors.go.html to see an example of how to use ListWorkRequestErrors API. +// A default retry strategy applies to this operation ListWorkRequestErrors() +func (client GoldenGateClient) ListWorkRequestErrors(ctx context.Context, request ListWorkRequestErrorsRequest) (response ListWorkRequestErrorsResponse, err error) { + var ociResponse common.OCIResponse + policy := common.DefaultRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + ociResponse, err = common.Retry(ctx, request, client.listWorkRequestErrors, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = ListWorkRequestErrorsResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = ListWorkRequestErrorsResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(ListWorkRequestErrorsResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into ListWorkRequestErrorsResponse") + } + return +} + +// listWorkRequestErrors implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) listWorkRequestErrors(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodGet, "/workRequests/{workRequestId}/errors", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response ListWorkRequestErrorsResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/WorkRequestError/ListWorkRequestErrors" + err = common.PostProcessServiceError(err, "GoldenGate", "ListWorkRequestErrors", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + +// ListWorkRequestLogs Lists work request logs. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListWorkRequestLogs.go.html to see an example of how to use ListWorkRequestLogs API. +// A default retry strategy applies to this operation ListWorkRequestLogs() +func (client GoldenGateClient) ListWorkRequestLogs(ctx context.Context, request ListWorkRequestLogsRequest) (response ListWorkRequestLogsResponse, err error) { + var ociResponse common.OCIResponse + policy := common.DefaultRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + ociResponse, err = common.Retry(ctx, request, client.listWorkRequestLogs, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = ListWorkRequestLogsResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = ListWorkRequestLogsResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(ListWorkRequestLogsResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into ListWorkRequestLogsResponse") + } + return +} + +// listWorkRequestLogs implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) listWorkRequestLogs(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodGet, "/workRequests/{workRequestId}/logs", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response ListWorkRequestLogsResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/WorkRequestLogEntry/ListWorkRequestLogs" + err = common.PostProcessServiceError(err, "GoldenGate", "ListWorkRequestLogs", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + +// ListWorkRequests Lists the work requests in the compartment. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListWorkRequests.go.html to see an example of how to use ListWorkRequests API. +// A default retry strategy applies to this operation ListWorkRequests() +func (client GoldenGateClient) ListWorkRequests(ctx context.Context, request ListWorkRequestsRequest) (response ListWorkRequestsResponse, err error) { + var ociResponse common.OCIResponse + policy := common.DefaultRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + ociResponse, err = common.Retry(ctx, request, client.listWorkRequests, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = ListWorkRequestsResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = ListWorkRequestsResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(ListWorkRequestsResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into ListWorkRequestsResponse") + } + return +} + +// listWorkRequests implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) listWorkRequests(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodGet, "/workRequests", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response ListWorkRequestsResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/WorkRequest/ListWorkRequests" + err = common.PostProcessServiceError(err, "GoldenGate", "ListWorkRequests", apiReferenceLink) return response, err } @@ -3819,6 +4414,69 @@ func (client GoldenGateClient) startDeployment(ctx context.Context, request comm return response, err } +// StartPipeline Starts the pipeline for data replication. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/StartPipeline.go.html to see an example of how to use StartPipeline API. +// A default retry strategy applies to this operation StartPipeline() +func (client GoldenGateClient) StartPipeline(ctx context.Context, request StartPipelineRequest) (response StartPipelineResponse, err error) { + var ociResponse common.OCIResponse + policy := common.DefaultRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + + if !(request.OpcRetryToken != nil && *request.OpcRetryToken != "") { + request.OpcRetryToken = common.String(common.RetryToken()) + } + + ociResponse, err = common.Retry(ctx, request, client.startPipeline, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = StartPipelineResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = StartPipelineResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(StartPipelineResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into StartPipelineResponse") + } + return +} + +// startPipeline implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) startPipeline(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodPost, "/pipelines/{pipelineId}/actions/start", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response StartPipelineResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/Pipeline/StartPipeline" + err = common.PostProcessServiceError(err, "GoldenGate", "StartPipeline", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + // StopDeployment Stops a Deployment. When provided, If-Match is checked against ETag values of the resource. // // # See also @@ -3882,6 +4540,69 @@ func (client GoldenGateClient) stopDeployment(ctx context.Context, request commo return response, err } +// StopPipeline Stops the pipeline for data replication. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/StopPipeline.go.html to see an example of how to use StopPipeline API. +// A default retry strategy applies to this operation StopPipeline() +func (client GoldenGateClient) StopPipeline(ctx context.Context, request StopPipelineRequest) (response StopPipelineResponse, err error) { + var ociResponse common.OCIResponse + policy := common.DefaultRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + + if !(request.OpcRetryToken != nil && *request.OpcRetryToken != "") { + request.OpcRetryToken = common.String(common.RetryToken()) + } + + ociResponse, err = common.Retry(ctx, request, client.stopPipeline, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = StopPipelineResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = StopPipelineResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(StopPipelineResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into StopPipelineResponse") + } + return +} + +// stopPipeline implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) stopPipeline(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodPost, "/pipelines/{pipelineId}/actions/stop", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response StopPipelineResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/Pipeline/StopPipeline" + err = common.PostProcessServiceError(err, "GoldenGate", "StopPipeline", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + // TestConnectionAssignment Tests the connectivity between given GoldenGate deployment and one of the associated database / service. // When provided, If-Match is checked against ETag values of the resource. // @@ -3946,6 +4667,70 @@ func (client GoldenGateClient) testConnectionAssignment(ctx context.Context, req return response, err } +// TestPipelineConnection Tests pipeline connections against pipeline to verify the connectivity. +// When provided, If-Match is checked against ETag values of the resource. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/TestPipelineConnection.go.html to see an example of how to use TestPipelineConnection API. +// A default retry strategy applies to this operation TestPipelineConnection() +func (client GoldenGateClient) TestPipelineConnection(ctx context.Context, request TestPipelineConnectionRequest) (response TestPipelineConnectionResponse, err error) { + var ociResponse common.OCIResponse + policy := common.DefaultRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + + if !(request.OpcRetryToken != nil && *request.OpcRetryToken != "") { + request.OpcRetryToken = common.String(common.RetryToken()) + } + + ociResponse, err = common.Retry(ctx, request, client.testPipelineConnection, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = TestPipelineConnectionResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = TestPipelineConnectionResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(TestPipelineConnectionResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into TestPipelineConnectionResponse") + } + return +} + +// testPipelineConnection implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) testPipelineConnection(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodPost, "/pipelines/{pipelineId}/actions/testConnection", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response TestPipelineConnectionResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/Pipeline/TestPipelineConnection" + err = common.PostProcessServiceError(err, "GoldenGate", "TestPipelineConnection", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + // UpdateConnection Updates the Connection. // // # See also @@ -4179,6 +4964,64 @@ func (client GoldenGateClient) updateDeploymentBackup(ctx context.Context, reque return response, err } +// UpdatePipeline Updates the Pipeline. +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/UpdatePipeline.go.html to see an example of how to use UpdatePipeline API. +// A default retry strategy applies to this operation UpdatePipeline() +func (client GoldenGateClient) UpdatePipeline(ctx context.Context, request UpdatePipelineRequest) (response UpdatePipelineResponse, err error) { + var ociResponse common.OCIResponse + policy := common.DefaultRetryPolicy() + if client.RetryPolicy() != nil { + policy = *client.RetryPolicy() + } + if request.RetryPolicy() != nil { + policy = *request.RetryPolicy() + } + ociResponse, err = common.Retry(ctx, request, client.updatePipeline, policy) + if err != nil { + if ociResponse != nil { + if httpResponse := ociResponse.HTTPResponse(); httpResponse != nil { + opcRequestId := httpResponse.Header.Get("opc-request-id") + response = UpdatePipelineResponse{RawResponse: httpResponse, OpcRequestId: &opcRequestId} + } else { + response = UpdatePipelineResponse{} + } + } + return + } + if convertedResponse, ok := ociResponse.(UpdatePipelineResponse); ok { + response = convertedResponse + } else { + err = fmt.Errorf("failed to convert OCIResponse into UpdatePipelineResponse") + } + return +} + +// updatePipeline implements the OCIOperation interface (enables retrying operations) +func (client GoldenGateClient) updatePipeline(ctx context.Context, request common.OCIRequest, binaryReqBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (common.OCIResponse, error) { + + httpRequest, err := request.HTTPRequest(http.MethodPut, "/pipelines/{pipelineId}", binaryReqBody, extraHeaders) + if err != nil { + return nil, err + } + + var response UpdatePipelineResponse + var httpResponse *http.Response + httpResponse, err = client.Call(ctx, &httpRequest) + defer common.CloseBodyIfValid(httpResponse) + response.RawResponse = httpResponse + if err != nil { + apiReferenceLink := "https://docs.oracle.com/iaas/api/#/en/goldengate/20200407/Pipeline/UpdatePipeline" + err = common.PostProcessServiceError(err, "GoldenGate", "UpdatePipeline", apiReferenceLink) + return response, err + } + + err = common.UnmarshalResponse(httpResponse, &response) + return response, err +} + // UpgradeDeployment Upgrade a Deployment. When provided, If-Match is checked against ETag values of the resource. // // # See also diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/initial_data_load.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/initial_data_load.go new file mode 100644 index 00000000000..01b0a71431d --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/initial_data_load.go @@ -0,0 +1,90 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// InitialDataLoad Options required for the pipeline Initial Data Load. If enabled, copies existing data from source to target before replication. +type InitialDataLoad struct { + + // If ENABLED, then existing source data is also synchronized to the target when creating or updating the pipeline. + IsInitialLoad InitialDataLoadIsInitialLoadEnum `mandatory:"true" json:"isInitialLoad"` + + // Action upon existing tables in target when initial Data Load is set i.e., isInitialLoad=true. + ActionOnExistingTable InitialLoadActionEnum `mandatory:"false" json:"actionOnExistingTable,omitempty"` +} + +func (m InitialDataLoad) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m InitialDataLoad) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingInitialDataLoadIsInitialLoadEnum(string(m.IsInitialLoad)); !ok && m.IsInitialLoad != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for IsInitialLoad: %s. Supported values are: %s.", m.IsInitialLoad, strings.Join(GetInitialDataLoadIsInitialLoadEnumStringValues(), ","))) + } + + if _, ok := GetMappingInitialLoadActionEnum(string(m.ActionOnExistingTable)); !ok && m.ActionOnExistingTable != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for ActionOnExistingTable: %s. Supported values are: %s.", m.ActionOnExistingTable, strings.Join(GetInitialLoadActionEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// InitialDataLoadIsInitialLoadEnum Enum with underlying type: string +type InitialDataLoadIsInitialLoadEnum string + +// Set of constants representing the allowable values for InitialDataLoadIsInitialLoadEnum +const ( + InitialDataLoadIsInitialLoadEnabled InitialDataLoadIsInitialLoadEnum = "ENABLED" + InitialDataLoadIsInitialLoadDisabled InitialDataLoadIsInitialLoadEnum = "DISABLED" +) + +var mappingInitialDataLoadIsInitialLoadEnum = map[string]InitialDataLoadIsInitialLoadEnum{ + "ENABLED": InitialDataLoadIsInitialLoadEnabled, + "DISABLED": InitialDataLoadIsInitialLoadDisabled, +} + +var mappingInitialDataLoadIsInitialLoadEnumLowerCase = map[string]InitialDataLoadIsInitialLoadEnum{ + "enabled": InitialDataLoadIsInitialLoadEnabled, + "disabled": InitialDataLoadIsInitialLoadDisabled, +} + +// GetInitialDataLoadIsInitialLoadEnumValues Enumerates the set of values for InitialDataLoadIsInitialLoadEnum +func GetInitialDataLoadIsInitialLoadEnumValues() []InitialDataLoadIsInitialLoadEnum { + values := make([]InitialDataLoadIsInitialLoadEnum, 0) + for _, v := range mappingInitialDataLoadIsInitialLoadEnum { + values = append(values, v) + } + return values +} + +// GetInitialDataLoadIsInitialLoadEnumStringValues Enumerates the set of values in String for InitialDataLoadIsInitialLoadEnum +func GetInitialDataLoadIsInitialLoadEnumStringValues() []string { + return []string{ + "ENABLED", + "DISABLED", + } +} + +// GetMappingInitialDataLoadIsInitialLoadEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingInitialDataLoadIsInitialLoadEnum(val string) (InitialDataLoadIsInitialLoadEnum, bool) { + enum, ok := mappingInitialDataLoadIsInitialLoadEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/initial_load_action.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/initial_load_action.go new file mode 100644 index 00000000000..d9f5320f01d --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/initial_load_action.go @@ -0,0 +1,64 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "strings" +) + +// InitialLoadActionEnum Enum with underlying type: string +type InitialLoadActionEnum string + +// Set of constants representing the allowable values for InitialLoadActionEnum +const ( + InitialLoadActionTruncate InitialLoadActionEnum = "TRUNCATE" + InitialLoadActionReplace InitialLoadActionEnum = "REPLACE" + InitialLoadActionAppend InitialLoadActionEnum = "APPEND" + InitialLoadActionSkip InitialLoadActionEnum = "SKIP" +) + +var mappingInitialLoadActionEnum = map[string]InitialLoadActionEnum{ + "TRUNCATE": InitialLoadActionTruncate, + "REPLACE": InitialLoadActionReplace, + "APPEND": InitialLoadActionAppend, + "SKIP": InitialLoadActionSkip, +} + +var mappingInitialLoadActionEnumLowerCase = map[string]InitialLoadActionEnum{ + "truncate": InitialLoadActionTruncate, + "replace": InitialLoadActionReplace, + "append": InitialLoadActionAppend, + "skip": InitialLoadActionSkip, +} + +// GetInitialLoadActionEnumValues Enumerates the set of values for InitialLoadActionEnum +func GetInitialLoadActionEnumValues() []InitialLoadActionEnum { + values := make([]InitialLoadActionEnum, 0) + for _, v := range mappingInitialLoadActionEnum { + values = append(values, v) + } + return values +} + +// GetInitialLoadActionEnumStringValues Enumerates the set of values in String for InitialLoadActionEnum +func GetInitialLoadActionEnumStringValues() []string { + return []string{ + "TRUNCATE", + "REPLACE", + "APPEND", + "SKIP", + } +} + +// GetMappingInitialLoadActionEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingInitialLoadActionEnum(val string) (InitialLoadActionEnum, bool) { + enum, ok := mappingInitialLoadActionEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipeline_initialization_steps_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipeline_initialization_steps_request_response.go new file mode 100644 index 00000000000..d8ce1ee3f40 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipeline_initialization_steps_request_response.go @@ -0,0 +1,93 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// ListPipelineInitializationStepsRequest wrapper for the ListPipelineInitializationSteps operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListPipelineInitializationSteps.go.html to see an example of how to use ListPipelineInitializationStepsRequest. +type ListPipelineInitializationStepsRequest struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the pipeline created. + PipelineId *string `mandatory:"true" contributesTo:"path" name:"pipelineId"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request ListPipelineInitializationStepsRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request ListPipelineInitializationStepsRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request ListPipelineInitializationStepsRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request ListPipelineInitializationStepsRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request ListPipelineInitializationStepsRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// ListPipelineInitializationStepsResponse wrapper for the ListPipelineInitializationSteps operation +type ListPipelineInitializationStepsResponse struct { + + // The underlying http response + RawResponse *http.Response + + // The PipelineInitializationSteps instance + PipelineInitializationSteps `presentIn:"body"` + + // For optimistic concurrency control. See `if-match`. + Etag *string `presentIn:"header" name:"etag"` + + // A unique Oracle-assigned identifier for the request. If you need to contact Oracle about a + // particular request, please include the request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` +} + +func (response ListPipelineInitializationStepsResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response ListPipelineInitializationStepsResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipeline_running_processes_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipeline_running_processes_request_response.go new file mode 100644 index 00000000000..0845b590c7e --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipeline_running_processes_request_response.go @@ -0,0 +1,199 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// ListPipelineRunningProcessesRequest wrapper for the ListPipelineRunningProcesses operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListPipelineRunningProcesses.go.html to see an example of how to use ListPipelineRunningProcessesRequest. +type ListPipelineRunningProcessesRequest struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the pipeline created. + PipelineId *string `mandatory:"true" contributesTo:"path" name:"pipelineId"` + + // The maximum number of items to return. + Limit *int `mandatory:"false" contributesTo:"query" name:"limit"` + + // The page token representing the page at which to start retrieving results. This is usually + // retrieved from a previous list call. + Page *string `mandatory:"false" contributesTo:"query" name:"page"` + + // The sort order to use, either 'asc' or 'desc'. + SortOrder ListPipelineRunningProcessesSortOrderEnum `mandatory:"false" contributesTo:"query" name:"sortOrder" omitEmpty:"true"` + + // The field to sort by. Only one sort order can be provided. Default order for 'timeCreated' is + // descending. Default order for 'displayName' is ascending. If no value is specified + // timeCreated is the default. + SortBy ListPipelineRunningProcessesSortByEnum `mandatory:"false" contributesTo:"query" name:"sortBy" omitEmpty:"true"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request ListPipelineRunningProcessesRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request ListPipelineRunningProcessesRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request ListPipelineRunningProcessesRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request ListPipelineRunningProcessesRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request ListPipelineRunningProcessesRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingListPipelineRunningProcessesSortOrderEnum(string(request.SortOrder)); !ok && request.SortOrder != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for SortOrder: %s. Supported values are: %s.", request.SortOrder, strings.Join(GetListPipelineRunningProcessesSortOrderEnumStringValues(), ","))) + } + if _, ok := GetMappingListPipelineRunningProcessesSortByEnum(string(request.SortBy)); !ok && request.SortBy != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for SortBy: %s. Supported values are: %s.", request.SortBy, strings.Join(GetListPipelineRunningProcessesSortByEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// ListPipelineRunningProcessesResponse wrapper for the ListPipelineRunningProcesses operation +type ListPipelineRunningProcessesResponse struct { + + // The underlying http response + RawResponse *http.Response + + // A list of PipelineRunningProcessCollection instances + PipelineRunningProcessCollection `presentIn:"body"` + + // The page token represents the page to start retrieving results. This is usually retrieved + // from a previous list call. + OpcNextPage *string `presentIn:"header" name:"opc-next-page"` + + // A unique Oracle-assigned identifier for the request. If you need to contact Oracle about a + // particular request, please include the request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` +} + +func (response ListPipelineRunningProcessesResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response ListPipelineRunningProcessesResponse) HTTPResponse() *http.Response { + return response.RawResponse +} + +// ListPipelineRunningProcessesSortOrderEnum Enum with underlying type: string +type ListPipelineRunningProcessesSortOrderEnum string + +// Set of constants representing the allowable values for ListPipelineRunningProcessesSortOrderEnum +const ( + ListPipelineRunningProcessesSortOrderAsc ListPipelineRunningProcessesSortOrderEnum = "ASC" + ListPipelineRunningProcessesSortOrderDesc ListPipelineRunningProcessesSortOrderEnum = "DESC" +) + +var mappingListPipelineRunningProcessesSortOrderEnum = map[string]ListPipelineRunningProcessesSortOrderEnum{ + "ASC": ListPipelineRunningProcessesSortOrderAsc, + "DESC": ListPipelineRunningProcessesSortOrderDesc, +} + +var mappingListPipelineRunningProcessesSortOrderEnumLowerCase = map[string]ListPipelineRunningProcessesSortOrderEnum{ + "asc": ListPipelineRunningProcessesSortOrderAsc, + "desc": ListPipelineRunningProcessesSortOrderDesc, +} + +// GetListPipelineRunningProcessesSortOrderEnumValues Enumerates the set of values for ListPipelineRunningProcessesSortOrderEnum +func GetListPipelineRunningProcessesSortOrderEnumValues() []ListPipelineRunningProcessesSortOrderEnum { + values := make([]ListPipelineRunningProcessesSortOrderEnum, 0) + for _, v := range mappingListPipelineRunningProcessesSortOrderEnum { + values = append(values, v) + } + return values +} + +// GetListPipelineRunningProcessesSortOrderEnumStringValues Enumerates the set of values in String for ListPipelineRunningProcessesSortOrderEnum +func GetListPipelineRunningProcessesSortOrderEnumStringValues() []string { + return []string{ + "ASC", + "DESC", + } +} + +// GetMappingListPipelineRunningProcessesSortOrderEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListPipelineRunningProcessesSortOrderEnum(val string) (ListPipelineRunningProcessesSortOrderEnum, bool) { + enum, ok := mappingListPipelineRunningProcessesSortOrderEnumLowerCase[strings.ToLower(val)] + return enum, ok +} + +// ListPipelineRunningProcessesSortByEnum Enum with underlying type: string +type ListPipelineRunningProcessesSortByEnum string + +// Set of constants representing the allowable values for ListPipelineRunningProcessesSortByEnum +const ( + ListPipelineRunningProcessesSortByTimecreated ListPipelineRunningProcessesSortByEnum = "timeCreated" + ListPipelineRunningProcessesSortByDisplayname ListPipelineRunningProcessesSortByEnum = "displayName" +) + +var mappingListPipelineRunningProcessesSortByEnum = map[string]ListPipelineRunningProcessesSortByEnum{ + "timeCreated": ListPipelineRunningProcessesSortByTimecreated, + "displayName": ListPipelineRunningProcessesSortByDisplayname, +} + +var mappingListPipelineRunningProcessesSortByEnumLowerCase = map[string]ListPipelineRunningProcessesSortByEnum{ + "timecreated": ListPipelineRunningProcessesSortByTimecreated, + "displayname": ListPipelineRunningProcessesSortByDisplayname, +} + +// GetListPipelineRunningProcessesSortByEnumValues Enumerates the set of values for ListPipelineRunningProcessesSortByEnum +func GetListPipelineRunningProcessesSortByEnumValues() []ListPipelineRunningProcessesSortByEnum { + values := make([]ListPipelineRunningProcessesSortByEnum, 0) + for _, v := range mappingListPipelineRunningProcessesSortByEnum { + values = append(values, v) + } + return values +} + +// GetListPipelineRunningProcessesSortByEnumStringValues Enumerates the set of values in String for ListPipelineRunningProcessesSortByEnum +func GetListPipelineRunningProcessesSortByEnumStringValues() []string { + return []string{ + "timeCreated", + "displayName", + } +} + +// GetMappingListPipelineRunningProcessesSortByEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListPipelineRunningProcessesSortByEnum(val string) (ListPipelineRunningProcessesSortByEnum, bool) { + enum, ok := mappingListPipelineRunningProcessesSortByEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipeline_schema_tables_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipeline_schema_tables_request_response.go new file mode 100644 index 00000000000..f6dc4506530 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipeline_schema_tables_request_response.go @@ -0,0 +1,208 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// ListPipelineSchemaTablesRequest wrapper for the ListPipelineSchemaTables operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListPipelineSchemaTables.go.html to see an example of how to use ListPipelineSchemaTablesRequest. +type ListPipelineSchemaTablesRequest struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the pipeline created. + PipelineId *string `mandatory:"true" contributesTo:"path" name:"pipelineId"` + + // Name of the source schema obtained from get schema endpoint of the created pipeline. + SourceSchemaName *string `mandatory:"true" contributesTo:"query" name:"sourceSchemaName"` + + // Name of the target schema obtained from get schema endpoint of the created pipeline. + TargetSchemaName *string `mandatory:"true" contributesTo:"query" name:"targetSchemaName"` + + // A filter to return only the resources that match the entire 'displayName' given. + DisplayName *string `mandatory:"false" contributesTo:"query" name:"displayName"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // The maximum number of items to return. + Limit *int `mandatory:"false" contributesTo:"query" name:"limit"` + + // The page token representing the page at which to start retrieving results. This is usually + // retrieved from a previous list call. + Page *string `mandatory:"false" contributesTo:"query" name:"page"` + + // The sort order to use, either 'asc' or 'desc'. + SortOrder ListPipelineSchemaTablesSortOrderEnum `mandatory:"false" contributesTo:"query" name:"sortOrder" omitEmpty:"true"` + + // The field to sort by. Only one sort order can be provided. Default order for 'timeCreated' is + // descending. Default order for 'displayName' is ascending. If no value is specified + // timeCreated is the default. + SortBy ListPipelineSchemaTablesSortByEnum `mandatory:"false" contributesTo:"query" name:"sortBy" omitEmpty:"true"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request ListPipelineSchemaTablesRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request ListPipelineSchemaTablesRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request ListPipelineSchemaTablesRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request ListPipelineSchemaTablesRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request ListPipelineSchemaTablesRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingListPipelineSchemaTablesSortOrderEnum(string(request.SortOrder)); !ok && request.SortOrder != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for SortOrder: %s. Supported values are: %s.", request.SortOrder, strings.Join(GetListPipelineSchemaTablesSortOrderEnumStringValues(), ","))) + } + if _, ok := GetMappingListPipelineSchemaTablesSortByEnum(string(request.SortBy)); !ok && request.SortBy != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for SortBy: %s. Supported values are: %s.", request.SortBy, strings.Join(GetListPipelineSchemaTablesSortByEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// ListPipelineSchemaTablesResponse wrapper for the ListPipelineSchemaTables operation +type ListPipelineSchemaTablesResponse struct { + + // The underlying http response + RawResponse *http.Response + + // A list of PipelineSchemaTableCollection instances + PipelineSchemaTableCollection `presentIn:"body"` + + // A unique Oracle-assigned identifier for the request. If you need to contact Oracle about a + // particular request, please include the request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // The page token represents the page to start retrieving results. This is usually retrieved + // from a previous list call. + OpcNextPage *string `presentIn:"header" name:"opc-next-page"` +} + +func (response ListPipelineSchemaTablesResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response ListPipelineSchemaTablesResponse) HTTPResponse() *http.Response { + return response.RawResponse +} + +// ListPipelineSchemaTablesSortOrderEnum Enum with underlying type: string +type ListPipelineSchemaTablesSortOrderEnum string + +// Set of constants representing the allowable values for ListPipelineSchemaTablesSortOrderEnum +const ( + ListPipelineSchemaTablesSortOrderAsc ListPipelineSchemaTablesSortOrderEnum = "ASC" + ListPipelineSchemaTablesSortOrderDesc ListPipelineSchemaTablesSortOrderEnum = "DESC" +) + +var mappingListPipelineSchemaTablesSortOrderEnum = map[string]ListPipelineSchemaTablesSortOrderEnum{ + "ASC": ListPipelineSchemaTablesSortOrderAsc, + "DESC": ListPipelineSchemaTablesSortOrderDesc, +} + +var mappingListPipelineSchemaTablesSortOrderEnumLowerCase = map[string]ListPipelineSchemaTablesSortOrderEnum{ + "asc": ListPipelineSchemaTablesSortOrderAsc, + "desc": ListPipelineSchemaTablesSortOrderDesc, +} + +// GetListPipelineSchemaTablesSortOrderEnumValues Enumerates the set of values for ListPipelineSchemaTablesSortOrderEnum +func GetListPipelineSchemaTablesSortOrderEnumValues() []ListPipelineSchemaTablesSortOrderEnum { + values := make([]ListPipelineSchemaTablesSortOrderEnum, 0) + for _, v := range mappingListPipelineSchemaTablesSortOrderEnum { + values = append(values, v) + } + return values +} + +// GetListPipelineSchemaTablesSortOrderEnumStringValues Enumerates the set of values in String for ListPipelineSchemaTablesSortOrderEnum +func GetListPipelineSchemaTablesSortOrderEnumStringValues() []string { + return []string{ + "ASC", + "DESC", + } +} + +// GetMappingListPipelineSchemaTablesSortOrderEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListPipelineSchemaTablesSortOrderEnum(val string) (ListPipelineSchemaTablesSortOrderEnum, bool) { + enum, ok := mappingListPipelineSchemaTablesSortOrderEnumLowerCase[strings.ToLower(val)] + return enum, ok +} + +// ListPipelineSchemaTablesSortByEnum Enum with underlying type: string +type ListPipelineSchemaTablesSortByEnum string + +// Set of constants representing the allowable values for ListPipelineSchemaTablesSortByEnum +const ( + ListPipelineSchemaTablesSortByTimecreated ListPipelineSchemaTablesSortByEnum = "timeCreated" + ListPipelineSchemaTablesSortByDisplayname ListPipelineSchemaTablesSortByEnum = "displayName" +) + +var mappingListPipelineSchemaTablesSortByEnum = map[string]ListPipelineSchemaTablesSortByEnum{ + "timeCreated": ListPipelineSchemaTablesSortByTimecreated, + "displayName": ListPipelineSchemaTablesSortByDisplayname, +} + +var mappingListPipelineSchemaTablesSortByEnumLowerCase = map[string]ListPipelineSchemaTablesSortByEnum{ + "timecreated": ListPipelineSchemaTablesSortByTimecreated, + "displayname": ListPipelineSchemaTablesSortByDisplayname, +} + +// GetListPipelineSchemaTablesSortByEnumValues Enumerates the set of values for ListPipelineSchemaTablesSortByEnum +func GetListPipelineSchemaTablesSortByEnumValues() []ListPipelineSchemaTablesSortByEnum { + values := make([]ListPipelineSchemaTablesSortByEnum, 0) + for _, v := range mappingListPipelineSchemaTablesSortByEnum { + values = append(values, v) + } + return values +} + +// GetListPipelineSchemaTablesSortByEnumStringValues Enumerates the set of values in String for ListPipelineSchemaTablesSortByEnum +func GetListPipelineSchemaTablesSortByEnumStringValues() []string { + return []string{ + "timeCreated", + "displayName", + } +} + +// GetMappingListPipelineSchemaTablesSortByEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListPipelineSchemaTablesSortByEnum(val string) (ListPipelineSchemaTablesSortByEnum, bool) { + enum, ok := mappingListPipelineSchemaTablesSortByEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipeline_schemas_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipeline_schemas_request_response.go new file mode 100644 index 00000000000..35519ca45c0 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipeline_schemas_request_response.go @@ -0,0 +1,202 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// ListPipelineSchemasRequest wrapper for the ListPipelineSchemas operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListPipelineSchemas.go.html to see an example of how to use ListPipelineSchemasRequest. +type ListPipelineSchemasRequest struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the pipeline created. + PipelineId *string `mandatory:"true" contributesTo:"path" name:"pipelineId"` + + // A filter to return only the resources that match the entire 'displayName' given. + DisplayName *string `mandatory:"false" contributesTo:"query" name:"displayName"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // The maximum number of items to return. + Limit *int `mandatory:"false" contributesTo:"query" name:"limit"` + + // The page token representing the page at which to start retrieving results. This is usually + // retrieved from a previous list call. + Page *string `mandatory:"false" contributesTo:"query" name:"page"` + + // The sort order to use, either 'asc' or 'desc'. + SortOrder ListPipelineSchemasSortOrderEnum `mandatory:"false" contributesTo:"query" name:"sortOrder" omitEmpty:"true"` + + // The field to sort by. Only one sort order can be provided. Default order for 'timeCreated' is + // descending. Default order for 'displayName' is ascending. If no value is specified + // timeCreated is the default. + SortBy ListPipelineSchemasSortByEnum `mandatory:"false" contributesTo:"query" name:"sortBy" omitEmpty:"true"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request ListPipelineSchemasRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request ListPipelineSchemasRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request ListPipelineSchemasRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request ListPipelineSchemasRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request ListPipelineSchemasRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingListPipelineSchemasSortOrderEnum(string(request.SortOrder)); !ok && request.SortOrder != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for SortOrder: %s. Supported values are: %s.", request.SortOrder, strings.Join(GetListPipelineSchemasSortOrderEnumStringValues(), ","))) + } + if _, ok := GetMappingListPipelineSchemasSortByEnum(string(request.SortBy)); !ok && request.SortBy != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for SortBy: %s. Supported values are: %s.", request.SortBy, strings.Join(GetListPipelineSchemasSortByEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// ListPipelineSchemasResponse wrapper for the ListPipelineSchemas operation +type ListPipelineSchemasResponse struct { + + // The underlying http response + RawResponse *http.Response + + // A list of PipelineSchemaCollection instances + PipelineSchemaCollection `presentIn:"body"` + + // A unique Oracle-assigned identifier for the request. If you need to contact Oracle about a + // particular request, please include the request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // The page token represents the page to start retrieving results. This is usually retrieved + // from a previous list call. + OpcNextPage *string `presentIn:"header" name:"opc-next-page"` +} + +func (response ListPipelineSchemasResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response ListPipelineSchemasResponse) HTTPResponse() *http.Response { + return response.RawResponse +} + +// ListPipelineSchemasSortOrderEnum Enum with underlying type: string +type ListPipelineSchemasSortOrderEnum string + +// Set of constants representing the allowable values for ListPipelineSchemasSortOrderEnum +const ( + ListPipelineSchemasSortOrderAsc ListPipelineSchemasSortOrderEnum = "ASC" + ListPipelineSchemasSortOrderDesc ListPipelineSchemasSortOrderEnum = "DESC" +) + +var mappingListPipelineSchemasSortOrderEnum = map[string]ListPipelineSchemasSortOrderEnum{ + "ASC": ListPipelineSchemasSortOrderAsc, + "DESC": ListPipelineSchemasSortOrderDesc, +} + +var mappingListPipelineSchemasSortOrderEnumLowerCase = map[string]ListPipelineSchemasSortOrderEnum{ + "asc": ListPipelineSchemasSortOrderAsc, + "desc": ListPipelineSchemasSortOrderDesc, +} + +// GetListPipelineSchemasSortOrderEnumValues Enumerates the set of values for ListPipelineSchemasSortOrderEnum +func GetListPipelineSchemasSortOrderEnumValues() []ListPipelineSchemasSortOrderEnum { + values := make([]ListPipelineSchemasSortOrderEnum, 0) + for _, v := range mappingListPipelineSchemasSortOrderEnum { + values = append(values, v) + } + return values +} + +// GetListPipelineSchemasSortOrderEnumStringValues Enumerates the set of values in String for ListPipelineSchemasSortOrderEnum +func GetListPipelineSchemasSortOrderEnumStringValues() []string { + return []string{ + "ASC", + "DESC", + } +} + +// GetMappingListPipelineSchemasSortOrderEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListPipelineSchemasSortOrderEnum(val string) (ListPipelineSchemasSortOrderEnum, bool) { + enum, ok := mappingListPipelineSchemasSortOrderEnumLowerCase[strings.ToLower(val)] + return enum, ok +} + +// ListPipelineSchemasSortByEnum Enum with underlying type: string +type ListPipelineSchemasSortByEnum string + +// Set of constants representing the allowable values for ListPipelineSchemasSortByEnum +const ( + ListPipelineSchemasSortByTimecreated ListPipelineSchemasSortByEnum = "timeCreated" + ListPipelineSchemasSortByDisplayname ListPipelineSchemasSortByEnum = "displayName" +) + +var mappingListPipelineSchemasSortByEnum = map[string]ListPipelineSchemasSortByEnum{ + "timeCreated": ListPipelineSchemasSortByTimecreated, + "displayName": ListPipelineSchemasSortByDisplayname, +} + +var mappingListPipelineSchemasSortByEnumLowerCase = map[string]ListPipelineSchemasSortByEnum{ + "timecreated": ListPipelineSchemasSortByTimecreated, + "displayname": ListPipelineSchemasSortByDisplayname, +} + +// GetListPipelineSchemasSortByEnumValues Enumerates the set of values for ListPipelineSchemasSortByEnum +func GetListPipelineSchemasSortByEnumValues() []ListPipelineSchemasSortByEnum { + values := make([]ListPipelineSchemasSortByEnum, 0) + for _, v := range mappingListPipelineSchemasSortByEnum { + values = append(values, v) + } + return values +} + +// GetListPipelineSchemasSortByEnumStringValues Enumerates the set of values in String for ListPipelineSchemasSortByEnum +func GetListPipelineSchemasSortByEnumStringValues() []string { + return []string{ + "timeCreated", + "displayName", + } +} + +// GetMappingListPipelineSchemasSortByEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListPipelineSchemasSortByEnum(val string) (ListPipelineSchemasSortByEnum, bool) { + enum, ok := mappingListPipelineSchemasSortByEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipelines_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipelines_request_response.go new file mode 100644 index 00000000000..d694329f770 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_pipelines_request_response.go @@ -0,0 +1,271 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// ListPipelinesRequest wrapper for the ListPipelines operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListPipelines.go.html to see an example of how to use ListPipelinesRequest. +type ListPipelinesRequest struct { + + // The OCID of the compartment that contains the work request. Work requests should be scoped + // to the same compartment as the resource the work request affects. If the work request concerns + // multiple resources, and those resources are not in the same compartment, it is up to the service team + // to pick the primary resource whose compartment should be used. + CompartmentId *string `mandatory:"true" contributesTo:"query" name:"compartmentId"` + + // A filtered list of pipelines to return for a given lifecycleState. + LifecycleState PipelineLifecycleStateEnum `mandatory:"false" contributesTo:"query" name:"lifecycleState" omitEmpty:"true"` + + // A filtered list of pipelines to return for a given lifecycleSubState. + LifecycleSubState ListPipelinesLifecycleSubStateEnum `mandatory:"false" contributesTo:"query" name:"lifecycleSubState" omitEmpty:"true"` + + // A filter to return only the resources that match the entire 'displayName' given. + DisplayName *string `mandatory:"false" contributesTo:"query" name:"displayName"` + + // The maximum number of items to return. + Limit *int `mandatory:"false" contributesTo:"query" name:"limit"` + + // The page token representing the page at which to start retrieving results. This is usually + // retrieved from a previous list call. + Page *string `mandatory:"false" contributesTo:"query" name:"page"` + + // The sort order to use, either 'asc' or 'desc'. + SortOrder ListPipelinesSortOrderEnum `mandatory:"false" contributesTo:"query" name:"sortOrder" omitEmpty:"true"` + + // The field to sort by. Only one sort order can be provided. Default order for 'timeCreated' is + // descending. Default order for 'displayName' is ascending. If no value is specified + // timeCreated is the default. + SortBy ListPipelinesSortByEnum `mandatory:"false" contributesTo:"query" name:"sortBy" omitEmpty:"true"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request ListPipelinesRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request ListPipelinesRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request ListPipelinesRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request ListPipelinesRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request ListPipelinesRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingPipelineLifecycleStateEnum(string(request.LifecycleState)); !ok && request.LifecycleState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", request.LifecycleState, strings.Join(GetPipelineLifecycleStateEnumStringValues(), ","))) + } + if _, ok := GetMappingListPipelinesLifecycleSubStateEnum(string(request.LifecycleSubState)); !ok && request.LifecycleSubState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleSubState: %s. Supported values are: %s.", request.LifecycleSubState, strings.Join(GetListPipelinesLifecycleSubStateEnumStringValues(), ","))) + } + if _, ok := GetMappingListPipelinesSortOrderEnum(string(request.SortOrder)); !ok && request.SortOrder != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for SortOrder: %s. Supported values are: %s.", request.SortOrder, strings.Join(GetListPipelinesSortOrderEnumStringValues(), ","))) + } + if _, ok := GetMappingListPipelinesSortByEnum(string(request.SortBy)); !ok && request.SortBy != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for SortBy: %s. Supported values are: %s.", request.SortBy, strings.Join(GetListPipelinesSortByEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// ListPipelinesResponse wrapper for the ListPipelines operation +type ListPipelinesResponse struct { + + // The underlying http response + RawResponse *http.Response + + // A list of PipelineCollection instances + PipelineCollection `presentIn:"body"` + + // A unique Oracle-assigned identifier for the request. If you need to contact Oracle about a + // particular request, please include the request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // The page token represents the page to start retrieving results. This is usually retrieved + // from a previous list call. + OpcNextPage *string `presentIn:"header" name:"opc-next-page"` +} + +func (response ListPipelinesResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response ListPipelinesResponse) HTTPResponse() *http.Response { + return response.RawResponse +} + +// ListPipelinesLifecycleSubStateEnum Enum with underlying type: string +type ListPipelinesLifecycleSubStateEnum string + +// Set of constants representing the allowable values for ListPipelinesLifecycleSubStateEnum +const ( + ListPipelinesLifecycleSubStateStarting ListPipelinesLifecycleSubStateEnum = "STARTING" + ListPipelinesLifecycleSubStateStopping ListPipelinesLifecycleSubStateEnum = "STOPPING" + ListPipelinesLifecycleSubStateStopped ListPipelinesLifecycleSubStateEnum = "STOPPED" + ListPipelinesLifecycleSubStateMoving ListPipelinesLifecycleSubStateEnum = "MOVING" + ListPipelinesLifecycleSubStateRunning ListPipelinesLifecycleSubStateEnum = "RUNNING" +) + +var mappingListPipelinesLifecycleSubStateEnum = map[string]ListPipelinesLifecycleSubStateEnum{ + "STARTING": ListPipelinesLifecycleSubStateStarting, + "STOPPING": ListPipelinesLifecycleSubStateStopping, + "STOPPED": ListPipelinesLifecycleSubStateStopped, + "MOVING": ListPipelinesLifecycleSubStateMoving, + "RUNNING": ListPipelinesLifecycleSubStateRunning, +} + +var mappingListPipelinesLifecycleSubStateEnumLowerCase = map[string]ListPipelinesLifecycleSubStateEnum{ + "starting": ListPipelinesLifecycleSubStateStarting, + "stopping": ListPipelinesLifecycleSubStateStopping, + "stopped": ListPipelinesLifecycleSubStateStopped, + "moving": ListPipelinesLifecycleSubStateMoving, + "running": ListPipelinesLifecycleSubStateRunning, +} + +// GetListPipelinesLifecycleSubStateEnumValues Enumerates the set of values for ListPipelinesLifecycleSubStateEnum +func GetListPipelinesLifecycleSubStateEnumValues() []ListPipelinesLifecycleSubStateEnum { + values := make([]ListPipelinesLifecycleSubStateEnum, 0) + for _, v := range mappingListPipelinesLifecycleSubStateEnum { + values = append(values, v) + } + return values +} + +// GetListPipelinesLifecycleSubStateEnumStringValues Enumerates the set of values in String for ListPipelinesLifecycleSubStateEnum +func GetListPipelinesLifecycleSubStateEnumStringValues() []string { + return []string{ + "STARTING", + "STOPPING", + "STOPPED", + "MOVING", + "RUNNING", + } +} + +// GetMappingListPipelinesLifecycleSubStateEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListPipelinesLifecycleSubStateEnum(val string) (ListPipelinesLifecycleSubStateEnum, bool) { + enum, ok := mappingListPipelinesLifecycleSubStateEnumLowerCase[strings.ToLower(val)] + return enum, ok +} + +// ListPipelinesSortOrderEnum Enum with underlying type: string +type ListPipelinesSortOrderEnum string + +// Set of constants representing the allowable values for ListPipelinesSortOrderEnum +const ( + ListPipelinesSortOrderAsc ListPipelinesSortOrderEnum = "ASC" + ListPipelinesSortOrderDesc ListPipelinesSortOrderEnum = "DESC" +) + +var mappingListPipelinesSortOrderEnum = map[string]ListPipelinesSortOrderEnum{ + "ASC": ListPipelinesSortOrderAsc, + "DESC": ListPipelinesSortOrderDesc, +} + +var mappingListPipelinesSortOrderEnumLowerCase = map[string]ListPipelinesSortOrderEnum{ + "asc": ListPipelinesSortOrderAsc, + "desc": ListPipelinesSortOrderDesc, +} + +// GetListPipelinesSortOrderEnumValues Enumerates the set of values for ListPipelinesSortOrderEnum +func GetListPipelinesSortOrderEnumValues() []ListPipelinesSortOrderEnum { + values := make([]ListPipelinesSortOrderEnum, 0) + for _, v := range mappingListPipelinesSortOrderEnum { + values = append(values, v) + } + return values +} + +// GetListPipelinesSortOrderEnumStringValues Enumerates the set of values in String for ListPipelinesSortOrderEnum +func GetListPipelinesSortOrderEnumStringValues() []string { + return []string{ + "ASC", + "DESC", + } +} + +// GetMappingListPipelinesSortOrderEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListPipelinesSortOrderEnum(val string) (ListPipelinesSortOrderEnum, bool) { + enum, ok := mappingListPipelinesSortOrderEnumLowerCase[strings.ToLower(val)] + return enum, ok +} + +// ListPipelinesSortByEnum Enum with underlying type: string +type ListPipelinesSortByEnum string + +// Set of constants representing the allowable values for ListPipelinesSortByEnum +const ( + ListPipelinesSortByTimecreated ListPipelinesSortByEnum = "timeCreated" + ListPipelinesSortByDisplayname ListPipelinesSortByEnum = "displayName" +) + +var mappingListPipelinesSortByEnum = map[string]ListPipelinesSortByEnum{ + "timeCreated": ListPipelinesSortByTimecreated, + "displayName": ListPipelinesSortByDisplayname, +} + +var mappingListPipelinesSortByEnumLowerCase = map[string]ListPipelinesSortByEnum{ + "timecreated": ListPipelinesSortByTimecreated, + "displayname": ListPipelinesSortByDisplayname, +} + +// GetListPipelinesSortByEnumValues Enumerates the set of values for ListPipelinesSortByEnum +func GetListPipelinesSortByEnumValues() []ListPipelinesSortByEnum { + values := make([]ListPipelinesSortByEnum, 0) + for _, v := range mappingListPipelinesSortByEnum { + values = append(values, v) + } + return values +} + +// GetListPipelinesSortByEnumStringValues Enumerates the set of values in String for ListPipelinesSortByEnum +func GetListPipelinesSortByEnumStringValues() []string { + return []string{ + "timeCreated", + "displayName", + } +} + +// GetMappingListPipelinesSortByEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListPipelinesSortByEnum(val string) (ListPipelinesSortByEnum, bool) { + enum, ok := mappingListPipelinesSortByEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_recipes_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_recipes_request_response.go new file mode 100644 index 00000000000..b609a58a352 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/list_recipes_request_response.go @@ -0,0 +1,249 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// ListRecipesRequest wrapper for the ListRecipes operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/ListRecipes.go.html to see an example of how to use ListRecipesRequest. +type ListRecipesRequest struct { + + // The OCID of the compartment that contains the work request. Work requests should be scoped + // to the same compartment as the resource the work request affects. If the work request concerns + // multiple resources, and those resources are not in the same compartment, it is up to the service team + // to pick the primary resource whose compartment should be used. + CompartmentId *string `mandatory:"true" contributesTo:"query" name:"compartmentId"` + + // The pipeline's recipe type. The default value is ZERO_ETL. + RecipeType ListRecipesRecipeTypeEnum `mandatory:"false" contributesTo:"query" name:"recipeType" omitEmpty:"true"` + + // A filter to return only the resources that match the entire 'displayName' given. + DisplayName *string `mandatory:"false" contributesTo:"query" name:"displayName"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // The maximum number of items to return. + Limit *int `mandatory:"false" contributesTo:"query" name:"limit"` + + // The page token representing the page at which to start retrieving results. This is usually + // retrieved from a previous list call. + Page *string `mandatory:"false" contributesTo:"query" name:"page"` + + // The sort order to use, either 'asc' or 'desc'. + SortOrder ListRecipesSortOrderEnum `mandatory:"false" contributesTo:"query" name:"sortOrder" omitEmpty:"true"` + + // The field to sort by. Only one sort order can be provided. Default order for 'timeCreated' is + // descending. Default order for 'displayName' is ascending. If no value is specified + // timeCreated is the default. + SortBy ListRecipesSortByEnum `mandatory:"false" contributesTo:"query" name:"sortBy" omitEmpty:"true"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request ListRecipesRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request ListRecipesRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request ListRecipesRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request ListRecipesRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request ListRecipesRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingListRecipesRecipeTypeEnum(string(request.RecipeType)); !ok && request.RecipeType != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for RecipeType: %s. Supported values are: %s.", request.RecipeType, strings.Join(GetListRecipesRecipeTypeEnumStringValues(), ","))) + } + if _, ok := GetMappingListRecipesSortOrderEnum(string(request.SortOrder)); !ok && request.SortOrder != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for SortOrder: %s. Supported values are: %s.", request.SortOrder, strings.Join(GetListRecipesSortOrderEnumStringValues(), ","))) + } + if _, ok := GetMappingListRecipesSortByEnum(string(request.SortBy)); !ok && request.SortBy != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for SortBy: %s. Supported values are: %s.", request.SortBy, strings.Join(GetListRecipesSortByEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// ListRecipesResponse wrapper for the ListRecipes operation +type ListRecipesResponse struct { + + // The underlying http response + RawResponse *http.Response + + // A list of RecipeSummaryCollection instances + RecipeSummaryCollection `presentIn:"body"` + + // A unique Oracle-assigned identifier for the request. If you need to contact Oracle about a + // particular request, please include the request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // The page token represents the page to start retrieving results. This is usually retrieved + // from a previous list call. + OpcNextPage *string `presentIn:"header" name:"opc-next-page"` +} + +func (response ListRecipesResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response ListRecipesResponse) HTTPResponse() *http.Response { + return response.RawResponse +} + +// ListRecipesRecipeTypeEnum Enum with underlying type: string +type ListRecipesRecipeTypeEnum string + +// Set of constants representing the allowable values for ListRecipesRecipeTypeEnum +const ( + ListRecipesRecipeTypeZeroEtl ListRecipesRecipeTypeEnum = "ZERO_ETL" +) + +var mappingListRecipesRecipeTypeEnum = map[string]ListRecipesRecipeTypeEnum{ + "ZERO_ETL": ListRecipesRecipeTypeZeroEtl, +} + +var mappingListRecipesRecipeTypeEnumLowerCase = map[string]ListRecipesRecipeTypeEnum{ + "zero_etl": ListRecipesRecipeTypeZeroEtl, +} + +// GetListRecipesRecipeTypeEnumValues Enumerates the set of values for ListRecipesRecipeTypeEnum +func GetListRecipesRecipeTypeEnumValues() []ListRecipesRecipeTypeEnum { + values := make([]ListRecipesRecipeTypeEnum, 0) + for _, v := range mappingListRecipesRecipeTypeEnum { + values = append(values, v) + } + return values +} + +// GetListRecipesRecipeTypeEnumStringValues Enumerates the set of values in String for ListRecipesRecipeTypeEnum +func GetListRecipesRecipeTypeEnumStringValues() []string { + return []string{ + "ZERO_ETL", + } +} + +// GetMappingListRecipesRecipeTypeEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListRecipesRecipeTypeEnum(val string) (ListRecipesRecipeTypeEnum, bool) { + enum, ok := mappingListRecipesRecipeTypeEnumLowerCase[strings.ToLower(val)] + return enum, ok +} + +// ListRecipesSortOrderEnum Enum with underlying type: string +type ListRecipesSortOrderEnum string + +// Set of constants representing the allowable values for ListRecipesSortOrderEnum +const ( + ListRecipesSortOrderAsc ListRecipesSortOrderEnum = "ASC" + ListRecipesSortOrderDesc ListRecipesSortOrderEnum = "DESC" +) + +var mappingListRecipesSortOrderEnum = map[string]ListRecipesSortOrderEnum{ + "ASC": ListRecipesSortOrderAsc, + "DESC": ListRecipesSortOrderDesc, +} + +var mappingListRecipesSortOrderEnumLowerCase = map[string]ListRecipesSortOrderEnum{ + "asc": ListRecipesSortOrderAsc, + "desc": ListRecipesSortOrderDesc, +} + +// GetListRecipesSortOrderEnumValues Enumerates the set of values for ListRecipesSortOrderEnum +func GetListRecipesSortOrderEnumValues() []ListRecipesSortOrderEnum { + values := make([]ListRecipesSortOrderEnum, 0) + for _, v := range mappingListRecipesSortOrderEnum { + values = append(values, v) + } + return values +} + +// GetListRecipesSortOrderEnumStringValues Enumerates the set of values in String for ListRecipesSortOrderEnum +func GetListRecipesSortOrderEnumStringValues() []string { + return []string{ + "ASC", + "DESC", + } +} + +// GetMappingListRecipesSortOrderEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListRecipesSortOrderEnum(val string) (ListRecipesSortOrderEnum, bool) { + enum, ok := mappingListRecipesSortOrderEnumLowerCase[strings.ToLower(val)] + return enum, ok +} + +// ListRecipesSortByEnum Enum with underlying type: string +type ListRecipesSortByEnum string + +// Set of constants representing the allowable values for ListRecipesSortByEnum +const ( + ListRecipesSortByTimecreated ListRecipesSortByEnum = "timeCreated" + ListRecipesSortByDisplayname ListRecipesSortByEnum = "displayName" +) + +var mappingListRecipesSortByEnum = map[string]ListRecipesSortByEnum{ + "timeCreated": ListRecipesSortByTimecreated, + "displayName": ListRecipesSortByDisplayname, +} + +var mappingListRecipesSortByEnumLowerCase = map[string]ListRecipesSortByEnum{ + "timecreated": ListRecipesSortByTimecreated, + "displayname": ListRecipesSortByDisplayname, +} + +// GetListRecipesSortByEnumValues Enumerates the set of values for ListRecipesSortByEnum +func GetListRecipesSortByEnumValues() []ListRecipesSortByEnum { + values := make([]ListRecipesSortByEnum, 0) + for _, v := range mappingListRecipesSortByEnum { + values = append(values, v) + } + return values +} + +// GetListRecipesSortByEnumStringValues Enumerates the set of values in String for ListRecipesSortByEnum +func GetListRecipesSortByEnumStringValues() []string { + return []string{ + "timeCreated", + "displayName", + } +} + +// GetMappingListRecipesSortByEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingListRecipesSortByEnum(val string) (ListRecipesSortByEnum, bool) { + enum, ok := mappingListRecipesSortByEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/mapping_rule.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/mapping_rule.go new file mode 100644 index 00000000000..4d6003ed412 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/mapping_rule.go @@ -0,0 +1,50 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// MappingRule Mapping rule for source and target schemas for the pipeline data replication. +// For example: +// "{mappingType: INCLUDE, source: HR.*, target: HR.*}" for rule "Include HR.*" which will include all the tables under HR schema. +type MappingRule struct { + + // Defines the exclude/include rules of source and target schemas and tables when replicating from source to target. This option applies when creating and updating a pipeline. + MappingType MappingTypeEnum `mandatory:"true" json:"mappingType"` + + // The source schema/table combination for replication to target. + Source *string `mandatory:"true" json:"source"` + + // The target schema/table combination for replication from the source. + Target *string `mandatory:"false" json:"target"` +} + +func (m MappingRule) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m MappingRule) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingMappingTypeEnum(string(m.MappingType)); !ok && m.MappingType != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for MappingType: %s. Supported values are: %s.", m.MappingType, strings.Join(GetMappingTypeEnumStringValues(), ","))) + } + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/mapping_type.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/mapping_type.go new file mode 100644 index 00000000000..0149cd7bbf2 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/mapping_type.go @@ -0,0 +1,56 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "strings" +) + +// MappingTypeEnum Enum with underlying type: string +type MappingTypeEnum string + +// Set of constants representing the allowable values for MappingTypeEnum +const ( + MappingTypeInclude MappingTypeEnum = "INCLUDE" + MappingTypeExclude MappingTypeEnum = "EXCLUDE" +) + +var mappingMappingTypeEnum = map[string]MappingTypeEnum{ + "INCLUDE": MappingTypeInclude, + "EXCLUDE": MappingTypeExclude, +} + +var mappingMappingTypeEnumLowerCase = map[string]MappingTypeEnum{ + "include": MappingTypeInclude, + "exclude": MappingTypeExclude, +} + +// GetMappingTypeEnumValues Enumerates the set of values for MappingTypeEnum +func GetMappingTypeEnumValues() []MappingTypeEnum { + values := make([]MappingTypeEnum, 0) + for _, v := range mappingMappingTypeEnum { + values = append(values, v) + } + return values +} + +// GetMappingTypeEnumStringValues Enumerates the set of values in String for MappingTypeEnum +func GetMappingTypeEnumStringValues() []string { + return []string{ + "INCLUDE", + "EXCLUDE", + } +} + +// GetMappingMappingTypeEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingMappingTypeEnum(val string) (MappingTypeEnum, bool) { + enum, ok := mappingMappingTypeEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/operation_type.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/operation_type.go index 66baa21b7cb..3ab3342a906 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/operation_type.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/operation_type.go @@ -50,6 +50,12 @@ const ( OperationTypeGoldengateDeploymentUpgradeSnooze OperationTypeEnum = "GOLDENGATE_DEPLOYMENT_UPGRADE_SNOOZE" OperationTypeGoldengateDeploymentCertificateCreate OperationTypeEnum = "GOLDENGATE_DEPLOYMENT_CERTIFICATE_CREATE" OperationTypeGoldengateDeploymentCertificateDelete OperationTypeEnum = "GOLDENGATE_DEPLOYMENT_CERTIFICATE_DELETE" + OperationTypeGoldengatePipelineCreate OperationTypeEnum = "GOLDENGATE_PIPELINE_CREATE" + OperationTypeGoldengatePipelineStart OperationTypeEnum = "GOLDENGATE_PIPELINE_START" + OperationTypeGoldengatePipelineStop OperationTypeEnum = "GOLDENGATE_PIPELINE_STOP" + OperationTypeGoldengatePipelineUpdate OperationTypeEnum = "GOLDENGATE_PIPELINE_UPDATE" + OperationTypeGoldengatePipelineDelete OperationTypeEnum = "GOLDENGATE_PIPELINE_DELETE" + OperationTypeGoldengatePipelineMove OperationTypeEnum = "GOLDENGATE_PIPELINE_MOVE" ) var mappingOperationTypeEnum = map[string]OperationTypeEnum{ @@ -85,6 +91,12 @@ var mappingOperationTypeEnum = map[string]OperationTypeEnum{ "GOLDENGATE_DEPLOYMENT_UPGRADE_SNOOZE": OperationTypeGoldengateDeploymentUpgradeSnooze, "GOLDENGATE_DEPLOYMENT_CERTIFICATE_CREATE": OperationTypeGoldengateDeploymentCertificateCreate, "GOLDENGATE_DEPLOYMENT_CERTIFICATE_DELETE": OperationTypeGoldengateDeploymentCertificateDelete, + "GOLDENGATE_PIPELINE_CREATE": OperationTypeGoldengatePipelineCreate, + "GOLDENGATE_PIPELINE_START": OperationTypeGoldengatePipelineStart, + "GOLDENGATE_PIPELINE_STOP": OperationTypeGoldengatePipelineStop, + "GOLDENGATE_PIPELINE_UPDATE": OperationTypeGoldengatePipelineUpdate, + "GOLDENGATE_PIPELINE_DELETE": OperationTypeGoldengatePipelineDelete, + "GOLDENGATE_PIPELINE_MOVE": OperationTypeGoldengatePipelineMove, } var mappingOperationTypeEnumLowerCase = map[string]OperationTypeEnum{ @@ -120,6 +132,12 @@ var mappingOperationTypeEnumLowerCase = map[string]OperationTypeEnum{ "goldengate_deployment_upgrade_snooze": OperationTypeGoldengateDeploymentUpgradeSnooze, "goldengate_deployment_certificate_create": OperationTypeGoldengateDeploymentCertificateCreate, "goldengate_deployment_certificate_delete": OperationTypeGoldengateDeploymentCertificateDelete, + "goldengate_pipeline_create": OperationTypeGoldengatePipelineCreate, + "goldengate_pipeline_start": OperationTypeGoldengatePipelineStart, + "goldengate_pipeline_stop": OperationTypeGoldengatePipelineStop, + "goldengate_pipeline_update": OperationTypeGoldengatePipelineUpdate, + "goldengate_pipeline_delete": OperationTypeGoldengatePipelineDelete, + "goldengate_pipeline_move": OperationTypeGoldengatePipelineMove, } // GetOperationTypeEnumValues Enumerates the set of values for OperationTypeEnum @@ -166,6 +184,12 @@ func GetOperationTypeEnumStringValues() []string { "GOLDENGATE_DEPLOYMENT_UPGRADE_SNOOZE", "GOLDENGATE_DEPLOYMENT_CERTIFICATE_CREATE", "GOLDENGATE_DEPLOYMENT_CERTIFICATE_DELETE", + "GOLDENGATE_PIPELINE_CREATE", + "GOLDENGATE_PIPELINE_START", + "GOLDENGATE_PIPELINE_STOP", + "GOLDENGATE_PIPELINE_UPDATE", + "GOLDENGATE_PIPELINE_DELETE", + "GOLDENGATE_PIPELINE_MOVE", } } diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline.go new file mode 100644 index 00000000000..ea5dd122002 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline.go @@ -0,0 +1,335 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// Pipeline Represents the metadata details of a pipeline in the same compartment. +type Pipeline interface { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the pipeline. This option applies when retrieving a pipeline. + GetId() *string + + // An object's Display Name. + GetDisplayName() *string + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the compartment being referenced. + GetCompartmentId() *string + + // The Oracle license model that applies to a Deployment. + GetLicenseModel() LicenseModelEnum + + // The Minimum number of OCPUs to be made available for this Deployment. + GetCpuCoreCount() *int + + // Indicates if auto scaling is enabled for the Deployment's CPU core count. + GetIsAutoScalingEnabled() *bool + + GetSourceConnectionDetails() *SourcePipelineConnectionDetails + + GetTargetConnectionDetails() *TargetPipelineConnectionDetails + + // Lifecycle state of the pipeline. + GetLifecycleState() PipelineLifecycleStateEnum + + // The time the resource was created. The format is defined by + // RFC3339 (https://tools.ietf.org/html/rfc3339), such as `2016-08-25T21:10:29.600Z`. + GetTimeCreated() *common.SDKTime + + // The time the resource was last updated. The format is defined by + // RFC3339 (https://tools.ietf.org/html/rfc3339), such as `2016-08-25T21:10:29.600Z`. + GetTimeUpdated() *common.SDKTime + + // Metadata about this specific object. + GetDescription() *string + + // A simple key-value pair that is applied without any predefined name, type, or scope. Exists + // for cross-compatibility only. + // Example: `{"bar-key": "value"}` + GetFreeformTags() map[string]string + + // Tags defined for this resource. Each key is predefined and scoped to a namespace. + // Example: `{"foo-namespace": {"bar-key": "value"}}` + GetDefinedTags() map[string]map[string]interface{} + + // The system tags associated with this resource, if any. The system tags are set by Oracle + // Cloud Infrastructure services. Each key is predefined and scoped to namespaces. For more + // information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{orcl-cloud: {free-tier-retain: true}}` + GetSystemTags() map[string]map[string]interface{} + + // Locks associated with this resource. + GetLocks() []ResourceLock + + // Possible lifecycle substates when retrieving a pipeline. + GetLifecycleSubState() PipelineLifecycleSubStateEnum + + // Describes the object's current state in detail. For example, it can be used to provide + // actionable information for a resource in a Failed state. + GetLifecycleDetails() *string +} + +type pipeline struct { + JsonData []byte + Description *string `mandatory:"false" json:"description"` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` + SystemTags map[string]map[string]interface{} `mandatory:"false" json:"systemTags"` + Locks []ResourceLock `mandatory:"false" json:"locks"` + LifecycleSubState PipelineLifecycleSubStateEnum `mandatory:"false" json:"lifecycleSubState,omitempty"` + LifecycleDetails *string `mandatory:"false" json:"lifecycleDetails"` + Id *string `mandatory:"true" json:"id"` + DisplayName *string `mandatory:"true" json:"displayName"` + CompartmentId *string `mandatory:"true" json:"compartmentId"` + LicenseModel LicenseModelEnum `mandatory:"true" json:"licenseModel"` + CpuCoreCount *int `mandatory:"true" json:"cpuCoreCount"` + IsAutoScalingEnabled *bool `mandatory:"true" json:"isAutoScalingEnabled"` + SourceConnectionDetails *SourcePipelineConnectionDetails `mandatory:"true" json:"sourceConnectionDetails"` + TargetConnectionDetails *TargetPipelineConnectionDetails `mandatory:"true" json:"targetConnectionDetails"` + LifecycleState PipelineLifecycleStateEnum `mandatory:"true" json:"lifecycleState"` + TimeCreated *common.SDKTime `mandatory:"true" json:"timeCreated"` + TimeUpdated *common.SDKTime `mandatory:"true" json:"timeUpdated"` + RecipeType string `json:"recipeType"` +} + +// UnmarshalJSON unmarshals json +func (m *pipeline) UnmarshalJSON(data []byte) error { + m.JsonData = data + type Unmarshalerpipeline pipeline + s := struct { + Model Unmarshalerpipeline + }{} + err := json.Unmarshal(data, &s.Model) + if err != nil { + return err + } + m.Id = s.Model.Id + m.DisplayName = s.Model.DisplayName + m.CompartmentId = s.Model.CompartmentId + m.LicenseModel = s.Model.LicenseModel + m.CpuCoreCount = s.Model.CpuCoreCount + m.IsAutoScalingEnabled = s.Model.IsAutoScalingEnabled + m.SourceConnectionDetails = s.Model.SourceConnectionDetails + m.TargetConnectionDetails = s.Model.TargetConnectionDetails + m.LifecycleState = s.Model.LifecycleState + m.TimeCreated = s.Model.TimeCreated + m.TimeUpdated = s.Model.TimeUpdated + m.Description = s.Model.Description + m.FreeformTags = s.Model.FreeformTags + m.DefinedTags = s.Model.DefinedTags + m.SystemTags = s.Model.SystemTags + m.Locks = s.Model.Locks + m.LifecycleSubState = s.Model.LifecycleSubState + m.LifecycleDetails = s.Model.LifecycleDetails + m.RecipeType = s.Model.RecipeType + + return err +} + +// UnmarshalPolymorphicJSON unmarshals polymorphic json +func (m *pipeline) UnmarshalPolymorphicJSON(data []byte) (interface{}, error) { + + if data == nil || string(data) == "null" { + return nil, nil + } + + var err error + switch m.RecipeType { + case "ZERO_ETL": + mm := ZeroEtlPipeline{} + err = json.Unmarshal(data, &mm) + return mm, err + default: + common.Logf("Recieved unsupported enum value for Pipeline: %s.", m.RecipeType) + return *m, nil + } +} + +// GetDescription returns Description +func (m pipeline) GetDescription() *string { + return m.Description +} + +// GetFreeformTags returns FreeformTags +func (m pipeline) GetFreeformTags() map[string]string { + return m.FreeformTags +} + +// GetDefinedTags returns DefinedTags +func (m pipeline) GetDefinedTags() map[string]map[string]interface{} { + return m.DefinedTags +} + +// GetSystemTags returns SystemTags +func (m pipeline) GetSystemTags() map[string]map[string]interface{} { + return m.SystemTags +} + +// GetLocks returns Locks +func (m pipeline) GetLocks() []ResourceLock { + return m.Locks +} + +// GetLifecycleSubState returns LifecycleSubState +func (m pipeline) GetLifecycleSubState() PipelineLifecycleSubStateEnum { + return m.LifecycleSubState +} + +// GetLifecycleDetails returns LifecycleDetails +func (m pipeline) GetLifecycleDetails() *string { + return m.LifecycleDetails +} + +// GetId returns Id +func (m pipeline) GetId() *string { + return m.Id +} + +// GetDisplayName returns DisplayName +func (m pipeline) GetDisplayName() *string { + return m.DisplayName +} + +// GetCompartmentId returns CompartmentId +func (m pipeline) GetCompartmentId() *string { + return m.CompartmentId +} + +// GetLicenseModel returns LicenseModel +func (m pipeline) GetLicenseModel() LicenseModelEnum { + return m.LicenseModel +} + +// GetCpuCoreCount returns CpuCoreCount +func (m pipeline) GetCpuCoreCount() *int { + return m.CpuCoreCount +} + +// GetIsAutoScalingEnabled returns IsAutoScalingEnabled +func (m pipeline) GetIsAutoScalingEnabled() *bool { + return m.IsAutoScalingEnabled +} + +// GetSourceConnectionDetails returns SourceConnectionDetails +func (m pipeline) GetSourceConnectionDetails() *SourcePipelineConnectionDetails { + return m.SourceConnectionDetails +} + +// GetTargetConnectionDetails returns TargetConnectionDetails +func (m pipeline) GetTargetConnectionDetails() *TargetPipelineConnectionDetails { + return m.TargetConnectionDetails +} + +// GetLifecycleState returns LifecycleState +func (m pipeline) GetLifecycleState() PipelineLifecycleStateEnum { + return m.LifecycleState +} + +// GetTimeCreated returns TimeCreated +func (m pipeline) GetTimeCreated() *common.SDKTime { + return m.TimeCreated +} + +// GetTimeUpdated returns TimeUpdated +func (m pipeline) GetTimeUpdated() *common.SDKTime { + return m.TimeUpdated +} + +func (m pipeline) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m pipeline) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingLicenseModelEnum(string(m.LicenseModel)); !ok && m.LicenseModel != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LicenseModel: %s. Supported values are: %s.", m.LicenseModel, strings.Join(GetLicenseModelEnumStringValues(), ","))) + } + if _, ok := GetMappingPipelineLifecycleStateEnum(string(m.LifecycleState)); !ok && m.LifecycleState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", m.LifecycleState, strings.Join(GetPipelineLifecycleStateEnumStringValues(), ","))) + } + + if _, ok := GetMappingPipelineLifecycleSubStateEnum(string(m.LifecycleSubState)); !ok && m.LifecycleSubState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleSubState: %s. Supported values are: %s.", m.LifecycleSubState, strings.Join(GetPipelineLifecycleSubStateEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// PipelineLifecycleStateEnum Enum with underlying type: string +type PipelineLifecycleStateEnum string + +// Set of constants representing the allowable values for PipelineLifecycleStateEnum +const ( + PipelineLifecycleStateCreating PipelineLifecycleStateEnum = "CREATING" + PipelineLifecycleStateUpdating PipelineLifecycleStateEnum = "UPDATING" + PipelineLifecycleStateActive PipelineLifecycleStateEnum = "ACTIVE" + PipelineLifecycleStateNeedsAttention PipelineLifecycleStateEnum = "NEEDS_ATTENTION" + PipelineLifecycleStateDeleting PipelineLifecycleStateEnum = "DELETING" + PipelineLifecycleStateDeleted PipelineLifecycleStateEnum = "DELETED" + PipelineLifecycleStateFailed PipelineLifecycleStateEnum = "FAILED" +) + +var mappingPipelineLifecycleStateEnum = map[string]PipelineLifecycleStateEnum{ + "CREATING": PipelineLifecycleStateCreating, + "UPDATING": PipelineLifecycleStateUpdating, + "ACTIVE": PipelineLifecycleStateActive, + "NEEDS_ATTENTION": PipelineLifecycleStateNeedsAttention, + "DELETING": PipelineLifecycleStateDeleting, + "DELETED": PipelineLifecycleStateDeleted, + "FAILED": PipelineLifecycleStateFailed, +} + +var mappingPipelineLifecycleStateEnumLowerCase = map[string]PipelineLifecycleStateEnum{ + "creating": PipelineLifecycleStateCreating, + "updating": PipelineLifecycleStateUpdating, + "active": PipelineLifecycleStateActive, + "needs_attention": PipelineLifecycleStateNeedsAttention, + "deleting": PipelineLifecycleStateDeleting, + "deleted": PipelineLifecycleStateDeleted, + "failed": PipelineLifecycleStateFailed, +} + +// GetPipelineLifecycleStateEnumValues Enumerates the set of values for PipelineLifecycleStateEnum +func GetPipelineLifecycleStateEnumValues() []PipelineLifecycleStateEnum { + values := make([]PipelineLifecycleStateEnum, 0) + for _, v := range mappingPipelineLifecycleStateEnum { + values = append(values, v) + } + return values +} + +// GetPipelineLifecycleStateEnumStringValues Enumerates the set of values in String for PipelineLifecycleStateEnum +func GetPipelineLifecycleStateEnumStringValues() []string { + return []string{ + "CREATING", + "UPDATING", + "ACTIVE", + "NEEDS_ATTENTION", + "DELETING", + "DELETED", + "FAILED", + } +} + +// GetMappingPipelineLifecycleStateEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingPipelineLifecycleStateEnum(val string) (PipelineLifecycleStateEnum, bool) { + enum, ok := mappingPipelineLifecycleStateEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_collection.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_collection.go new file mode 100644 index 00000000000..2ab568b7faf --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_collection.go @@ -0,0 +1,66 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// PipelineCollection List of pipeline summary objects. +type PipelineCollection struct { + + // An array of Pipeline summaries. + Items []PipelineSummary `mandatory:"true" json:"items"` +} + +func (m PipelineCollection) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m PipelineCollection) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// UnmarshalJSON unmarshals from json +func (m *PipelineCollection) UnmarshalJSON(data []byte) (e error) { + model := struct { + Items []pipelinesummary `json:"items"` + }{} + + e = json.Unmarshal(data, &model) + if e != nil { + return + } + var nn interface{} + m.Items = make([]PipelineSummary, len(model.Items)) + for i, n := range model.Items { + nn, e = n.UnmarshalPolymorphicJSON(n.JsonData) + if e != nil { + return e + } + if nn != nil { + m.Items[i] = nn.(PipelineSummary) + } else { + m.Items[i] = nil + } + } + return +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_initialization_step.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_initialization_step.go new file mode 100644 index 00000000000..a58e10dfbde --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_initialization_step.go @@ -0,0 +1,59 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// PipelineInitializationStep The step and its progress based on the recipe type. +type PipelineInitializationStep struct { + + // An object's Display Name. + Name *string `mandatory:"true" json:"name"` + + // Status of the steps in a recipe. This option applies during pipeline initialization. + Status StepStatusTypeEnum `mandatory:"true" json:"status"` + + // Shows the percentage complete of each recipe step during pipeline initialization. + PercentComplete *int `mandatory:"true" json:"percentComplete"` + + // The date and time the request was started. The format is defined by + // RFC3339 (https://tools.ietf.org/html/rfc3339), such as `2016-08-25T21:10:29.600Z`. + TimeStarted *common.SDKTime `mandatory:"true" json:"timeStarted"` + + // The date and time the request was finished. The format is defined by + // RFC3339 (https://tools.ietf.org/html/rfc3339), such as `2016-08-25T21:10:29.600Z`. + TimeFinished *common.SDKTime `mandatory:"true" json:"timeFinished"` + + // The list of messages for each step while running. + Messages []StepMessage `mandatory:"false" json:"messages"` +} + +func (m PipelineInitializationStep) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m PipelineInitializationStep) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingStepStatusTypeEnum(string(m.Status)); !ok && m.Status != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for Status: %s. Supported values are: %s.", m.Status, strings.Join(GetStepStatusTypeEnumStringValues(), ","))) + } + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_initialization_steps.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_initialization_steps.go new file mode 100644 index 00000000000..236722dcd08 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_initialization_steps.go @@ -0,0 +1,39 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// PipelineInitializationSteps The steps and their progress, based on the recipe type. +type PipelineInitializationSteps struct { + + // The sequence of pipeline steps based on the recipe type. + Items []PipelineInitializationStep `mandatory:"true" json:"items"` +} + +func (m PipelineInitializationSteps) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m PipelineInitializationSteps) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_lifecycle_sub_state.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_lifecycle_sub_state.go new file mode 100644 index 00000000000..05bb6e02ccf --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_lifecycle_sub_state.go @@ -0,0 +1,68 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "strings" +) + +// PipelineLifecycleSubStateEnum Enum with underlying type: string +type PipelineLifecycleSubStateEnum string + +// Set of constants representing the allowable values for PipelineLifecycleSubStateEnum +const ( + PipelineLifecycleSubStateStarting PipelineLifecycleSubStateEnum = "STARTING" + PipelineLifecycleSubStateStopping PipelineLifecycleSubStateEnum = "STOPPING" + PipelineLifecycleSubStateStopped PipelineLifecycleSubStateEnum = "STOPPED" + PipelineLifecycleSubStateMoving PipelineLifecycleSubStateEnum = "MOVING" + PipelineLifecycleSubStateRunning PipelineLifecycleSubStateEnum = "RUNNING" +) + +var mappingPipelineLifecycleSubStateEnum = map[string]PipelineLifecycleSubStateEnum{ + "STARTING": PipelineLifecycleSubStateStarting, + "STOPPING": PipelineLifecycleSubStateStopping, + "STOPPED": PipelineLifecycleSubStateStopped, + "MOVING": PipelineLifecycleSubStateMoving, + "RUNNING": PipelineLifecycleSubStateRunning, +} + +var mappingPipelineLifecycleSubStateEnumLowerCase = map[string]PipelineLifecycleSubStateEnum{ + "starting": PipelineLifecycleSubStateStarting, + "stopping": PipelineLifecycleSubStateStopping, + "stopped": PipelineLifecycleSubStateStopped, + "moving": PipelineLifecycleSubStateMoving, + "running": PipelineLifecycleSubStateRunning, +} + +// GetPipelineLifecycleSubStateEnumValues Enumerates the set of values for PipelineLifecycleSubStateEnum +func GetPipelineLifecycleSubStateEnumValues() []PipelineLifecycleSubStateEnum { + values := make([]PipelineLifecycleSubStateEnum, 0) + for _, v := range mappingPipelineLifecycleSubStateEnum { + values = append(values, v) + } + return values +} + +// GetPipelineLifecycleSubStateEnumStringValues Enumerates the set of values in String for PipelineLifecycleSubStateEnum +func GetPipelineLifecycleSubStateEnumStringValues() []string { + return []string{ + "STARTING", + "STOPPING", + "STOPPED", + "MOVING", + "RUNNING", + } +} + +// GetMappingPipelineLifecycleSubStateEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingPipelineLifecycleSubStateEnum(val string) (PipelineLifecycleSubStateEnum, bool) { + enum, ok := mappingPipelineLifecycleSubStateEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_running_process_collection.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_running_process_collection.go new file mode 100644 index 00000000000..5821f88f63e --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_running_process_collection.go @@ -0,0 +1,39 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// PipelineRunningProcessCollection The complete replication process and its details. +type PipelineRunningProcessCollection struct { + + // The list of replication processes and their details. + Items []PipelineRunningProcessSummary `mandatory:"true" json:"items"` +} + +func (m PipelineRunningProcessCollection) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m PipelineRunningProcessCollection) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_running_process_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_running_process_summary.go new file mode 100644 index 00000000000..c4c7ff1ea74 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_running_process_summary.go @@ -0,0 +1,58 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// PipelineRunningProcessSummary Each replication process and their summary details. +type PipelineRunningProcessSummary struct { + + // An object's Display Name. + Name *string `mandatory:"true" json:"name"` + + // The type of process running in a replication. For example, Extract or Replicat. This option applies when retrieving running processes. + ProcessType ProcessTypeEnum `mandatory:"true" json:"processType"` + + // The status of the Extract or Replicat process. This option applies when retrieving running processes. + Status ProcessStatusTypeEnum `mandatory:"true" json:"status"` + + // The latency, in seconds, of a process running in a replication. This option applies when retrieving running processes. + LastRecordLagInSeconds *float32 `mandatory:"true" json:"lastRecordLagInSeconds"` + + // The date and time the last record was processed by an Extract or Replicat. This option applies when retrieving running processes. + // The format is defined by RFC3339 (https://tools.ietf.org/html/rfc3339), such as `2024-07-25T21:10:29.600Z`. + TimeLastProcessed *common.SDKTime `mandatory:"true" json:"timeLastProcessed"` +} + +func (m PipelineRunningProcessSummary) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m PipelineRunningProcessSummary) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingProcessTypeEnum(string(m.ProcessType)); !ok && m.ProcessType != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for ProcessType: %s. Supported values are: %s.", m.ProcessType, strings.Join(GetProcessTypeEnumStringValues(), ","))) + } + if _, ok := GetMappingProcessStatusTypeEnum(string(m.Status)); !ok && m.Status != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for Status: %s. Supported values are: %s.", m.Status, strings.Join(GetProcessStatusTypeEnumStringValues(), ","))) + } + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_schema_collection.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_schema_collection.go new file mode 100644 index 00000000000..df84c0eefbb --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_schema_collection.go @@ -0,0 +1,39 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// PipelineSchemaCollection The list of schemas present in the source/target connection database of a pipeline. +type PipelineSchemaCollection struct { + + // Array of pipeline schemas + Items []PipelineSchemaSummary `mandatory:"true" json:"items"` +} + +func (m PipelineSchemaCollection) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m PipelineSchemaCollection) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_schema_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_schema_summary.go new file mode 100644 index 00000000000..de5539441f4 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_schema_summary.go @@ -0,0 +1,44 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// PipelineSchemaSummary List of source and target schemas of a pipeline's assigned connection. +// 1. If there is no explicit mapping defined for the pipeline then only matched source and target schema names will be returned. +// 2. If there are explicit mappings defined for the pipeline then along with the mapped source and target schema names, the matched source and target schema names also will be returned. +type PipelineSchemaSummary struct { + + // The schema name from the database connection. + SourceSchemaName *string `mandatory:"true" json:"sourceSchemaName"` + + // The schema name from the database connection. + TargetSchemaName *string `mandatory:"true" json:"targetSchemaName"` +} + +func (m PipelineSchemaSummary) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m PipelineSchemaSummary) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_schema_table_collection.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_schema_table_collection.go new file mode 100644 index 00000000000..544f67a884e --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_schema_table_collection.go @@ -0,0 +1,45 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// PipelineSchemaTableCollection List of source or target schema tables of a pipeline's assigned connection. +type PipelineSchemaTableCollection struct { + + // Array of source or target schema tables of a pipeline's assigned connection. + Items []PipelineSchemaTableSummary `mandatory:"true" json:"items"` + + // The schema name from the database connection. + SourceSchemaName *string `mandatory:"false" json:"sourceSchemaName"` + + // The schema name from the database connection. + TargetSchemaName *string `mandatory:"false" json:"targetSchemaName"` +} + +func (m PipelineSchemaTableCollection) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m PipelineSchemaTableCollection) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_schema_table_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_schema_table_summary.go new file mode 100644 index 00000000000..0911a0cddf4 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_schema_table_summary.go @@ -0,0 +1,44 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// PipelineSchemaTableSummary Summary of source or target schema tables of a pipeline's assigned connection. +// 1. If there is no explicit mapping defined for the pipeline then only matched source and target schema's table names will be returned +// 2. If there are explicit mappings defined for the pipeline then along with the mapped source and target schema's table names, the matched source and target schema's table names also will be returned. +type PipelineSchemaTableSummary struct { + + // The table name from the schema of database connection. + SourceTableName *string `mandatory:"true" json:"sourceTableName"` + + // The table name from the schema of database connection. + TargetTableName *string `mandatory:"true" json:"targetTableName"` +} + +func (m PipelineSchemaTableSummary) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m PipelineSchemaTableSummary) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_summary.go new file mode 100644 index 00000000000..cfef09a03b9 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/pipeline_summary.go @@ -0,0 +1,273 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// PipelineSummary Summary details of the pipeline. +type PipelineSummary interface { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the pipeline. This option applies when retrieving a pipeline. + GetId() *string + + // An object's Display Name. + GetDisplayName() *string + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the compartment being referenced. + GetCompartmentId() *string + + GetSourceConnectionDetails() *SourcePipelineConnectionDetails + + GetTargetConnectionDetails() *TargetPipelineConnectionDetails + + // The Oracle license model that applies to a Deployment. + GetLicenseModel() LicenseModelEnum + + // The Minimum number of OCPUs to be made available for this Deployment. + GetCpuCoreCount() *int + + // Indicates if auto scaling is enabled for the Deployment's CPU core count. + GetIsAutoScalingEnabled() *bool + + // Lifecycle state for the pipeline summary. + GetLifecycleState() PipelineLifecycleStateEnum + + // The time the resource was created. The format is defined by + // RFC3339 (https://tools.ietf.org/html/rfc3339), such as `2016-08-25T21:10:29.600Z`. + GetTimeCreated() *common.SDKTime + + // The time the resource was last updated. The format is defined by + // RFC3339 (https://tools.ietf.org/html/rfc3339), such as `2016-08-25T21:10:29.600Z`. + GetTimeUpdated() *common.SDKTime + + // Metadata about this specific object. + GetDescription() *string + + // A simple key-value pair that is applied without any predefined name, type, or scope. Exists + // for cross-compatibility only. + // Example: `{"bar-key": "value"}` + GetFreeformTags() map[string]string + + // Tags defined for this resource. Each key is predefined and scoped to a namespace. + // Example: `{"foo-namespace": {"bar-key": "value"}}` + GetDefinedTags() map[string]map[string]interface{} + + // The system tags associated with this resource, if any. The system tags are set by Oracle + // Cloud Infrastructure services. Each key is predefined and scoped to namespaces. For more + // information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{orcl-cloud: {free-tier-retain: true}}` + GetSystemTags() map[string]map[string]interface{} + + // Locks associated with this resource. + GetLocks() []ResourceLock + + // Possible lifecycle substates when retrieving a pipeline. + GetLifecycleSubState() PipelineLifecycleSubStateEnum + + // Describes the object's current state in detail. For example, it can be used to provide + // actionable information for a resource in a Failed state. + GetLifecycleDetails() *string +} + +type pipelinesummary struct { + JsonData []byte + Description *string `mandatory:"false" json:"description"` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` + SystemTags map[string]map[string]interface{} `mandatory:"false" json:"systemTags"` + Locks []ResourceLock `mandatory:"false" json:"locks"` + LifecycleSubState PipelineLifecycleSubStateEnum `mandatory:"false" json:"lifecycleSubState,omitempty"` + LifecycleDetails *string `mandatory:"false" json:"lifecycleDetails"` + Id *string `mandatory:"true" json:"id"` + DisplayName *string `mandatory:"true" json:"displayName"` + CompartmentId *string `mandatory:"true" json:"compartmentId"` + SourceConnectionDetails *SourcePipelineConnectionDetails `mandatory:"true" json:"sourceConnectionDetails"` + TargetConnectionDetails *TargetPipelineConnectionDetails `mandatory:"true" json:"targetConnectionDetails"` + LicenseModel LicenseModelEnum `mandatory:"true" json:"licenseModel"` + CpuCoreCount *int `mandatory:"true" json:"cpuCoreCount"` + IsAutoScalingEnabled *bool `mandatory:"true" json:"isAutoScalingEnabled"` + LifecycleState PipelineLifecycleStateEnum `mandatory:"true" json:"lifecycleState"` + TimeCreated *common.SDKTime `mandatory:"true" json:"timeCreated"` + TimeUpdated *common.SDKTime `mandatory:"true" json:"timeUpdated"` + RecipeType string `json:"recipeType"` +} + +// UnmarshalJSON unmarshals json +func (m *pipelinesummary) UnmarshalJSON(data []byte) error { + m.JsonData = data + type Unmarshalerpipelinesummary pipelinesummary + s := struct { + Model Unmarshalerpipelinesummary + }{} + err := json.Unmarshal(data, &s.Model) + if err != nil { + return err + } + m.Id = s.Model.Id + m.DisplayName = s.Model.DisplayName + m.CompartmentId = s.Model.CompartmentId + m.SourceConnectionDetails = s.Model.SourceConnectionDetails + m.TargetConnectionDetails = s.Model.TargetConnectionDetails + m.LicenseModel = s.Model.LicenseModel + m.CpuCoreCount = s.Model.CpuCoreCount + m.IsAutoScalingEnabled = s.Model.IsAutoScalingEnabled + m.LifecycleState = s.Model.LifecycleState + m.TimeCreated = s.Model.TimeCreated + m.TimeUpdated = s.Model.TimeUpdated + m.Description = s.Model.Description + m.FreeformTags = s.Model.FreeformTags + m.DefinedTags = s.Model.DefinedTags + m.SystemTags = s.Model.SystemTags + m.Locks = s.Model.Locks + m.LifecycleSubState = s.Model.LifecycleSubState + m.LifecycleDetails = s.Model.LifecycleDetails + m.RecipeType = s.Model.RecipeType + + return err +} + +// UnmarshalPolymorphicJSON unmarshals polymorphic json +func (m *pipelinesummary) UnmarshalPolymorphicJSON(data []byte) (interface{}, error) { + + if data == nil || string(data) == "null" { + return nil, nil + } + + var err error + switch m.RecipeType { + case "ZERO_ETL": + mm := ZeroEtlPipelineSummary{} + err = json.Unmarshal(data, &mm) + return mm, err + default: + common.Logf("Recieved unsupported enum value for PipelineSummary: %s.", m.RecipeType) + return *m, nil + } +} + +// GetDescription returns Description +func (m pipelinesummary) GetDescription() *string { + return m.Description +} + +// GetFreeformTags returns FreeformTags +func (m pipelinesummary) GetFreeformTags() map[string]string { + return m.FreeformTags +} + +// GetDefinedTags returns DefinedTags +func (m pipelinesummary) GetDefinedTags() map[string]map[string]interface{} { + return m.DefinedTags +} + +// GetSystemTags returns SystemTags +func (m pipelinesummary) GetSystemTags() map[string]map[string]interface{} { + return m.SystemTags +} + +// GetLocks returns Locks +func (m pipelinesummary) GetLocks() []ResourceLock { + return m.Locks +} + +// GetLifecycleSubState returns LifecycleSubState +func (m pipelinesummary) GetLifecycleSubState() PipelineLifecycleSubStateEnum { + return m.LifecycleSubState +} + +// GetLifecycleDetails returns LifecycleDetails +func (m pipelinesummary) GetLifecycleDetails() *string { + return m.LifecycleDetails +} + +// GetId returns Id +func (m pipelinesummary) GetId() *string { + return m.Id +} + +// GetDisplayName returns DisplayName +func (m pipelinesummary) GetDisplayName() *string { + return m.DisplayName +} + +// GetCompartmentId returns CompartmentId +func (m pipelinesummary) GetCompartmentId() *string { + return m.CompartmentId +} + +// GetSourceConnectionDetails returns SourceConnectionDetails +func (m pipelinesummary) GetSourceConnectionDetails() *SourcePipelineConnectionDetails { + return m.SourceConnectionDetails +} + +// GetTargetConnectionDetails returns TargetConnectionDetails +func (m pipelinesummary) GetTargetConnectionDetails() *TargetPipelineConnectionDetails { + return m.TargetConnectionDetails +} + +// GetLicenseModel returns LicenseModel +func (m pipelinesummary) GetLicenseModel() LicenseModelEnum { + return m.LicenseModel +} + +// GetCpuCoreCount returns CpuCoreCount +func (m pipelinesummary) GetCpuCoreCount() *int { + return m.CpuCoreCount +} + +// GetIsAutoScalingEnabled returns IsAutoScalingEnabled +func (m pipelinesummary) GetIsAutoScalingEnabled() *bool { + return m.IsAutoScalingEnabled +} + +// GetLifecycleState returns LifecycleState +func (m pipelinesummary) GetLifecycleState() PipelineLifecycleStateEnum { + return m.LifecycleState +} + +// GetTimeCreated returns TimeCreated +func (m pipelinesummary) GetTimeCreated() *common.SDKTime { + return m.TimeCreated +} + +// GetTimeUpdated returns TimeUpdated +func (m pipelinesummary) GetTimeUpdated() *common.SDKTime { + return m.TimeUpdated +} + +func (m pipelinesummary) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m pipelinesummary) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingLicenseModelEnum(string(m.LicenseModel)); !ok && m.LicenseModel != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LicenseModel: %s. Supported values are: %s.", m.LicenseModel, strings.Join(GetLicenseModelEnumStringValues(), ","))) + } + if _, ok := GetMappingPipelineLifecycleStateEnum(string(m.LifecycleState)); !ok && m.LifecycleState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", m.LifecycleState, strings.Join(GetPipelineLifecycleStateEnumStringValues(), ","))) + } + + if _, ok := GetMappingPipelineLifecycleSubStateEnum(string(m.LifecycleSubState)); !ok && m.LifecycleSubState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleSubState: %s. Supported values are: %s.", m.LifecycleSubState, strings.Join(GetPipelineLifecycleSubStateEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/process_options.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/process_options.go new file mode 100644 index 00000000000..2a9fbc642cc --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/process_options.go @@ -0,0 +1,87 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// ProcessOptions Required pipeline options to configure the replication process (Extract or Replicat). +type ProcessOptions struct { + InitialDataLoad *InitialDataLoad `mandatory:"true" json:"initialDataLoad"` + + ReplicateSchemaChange *ReplicateSchemaChange `mandatory:"true" json:"replicateSchemaChange"` + + // If ENABLED, then the replication process restarts itself upon failure. This option applies when creating or updating a pipeline. + ShouldRestartOnFailure ProcessOptionsShouldRestartOnFailureEnum `mandatory:"true" json:"shouldRestartOnFailure"` +} + +func (m ProcessOptions) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m ProcessOptions) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingProcessOptionsShouldRestartOnFailureEnum(string(m.ShouldRestartOnFailure)); !ok && m.ShouldRestartOnFailure != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for ShouldRestartOnFailure: %s. Supported values are: %s.", m.ShouldRestartOnFailure, strings.Join(GetProcessOptionsShouldRestartOnFailureEnumStringValues(), ","))) + } + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// ProcessOptionsShouldRestartOnFailureEnum Enum with underlying type: string +type ProcessOptionsShouldRestartOnFailureEnum string + +// Set of constants representing the allowable values for ProcessOptionsShouldRestartOnFailureEnum +const ( + ProcessOptionsShouldRestartOnFailureEnabled ProcessOptionsShouldRestartOnFailureEnum = "ENABLED" + ProcessOptionsShouldRestartOnFailureDisabled ProcessOptionsShouldRestartOnFailureEnum = "DISABLED" +) + +var mappingProcessOptionsShouldRestartOnFailureEnum = map[string]ProcessOptionsShouldRestartOnFailureEnum{ + "ENABLED": ProcessOptionsShouldRestartOnFailureEnabled, + "DISABLED": ProcessOptionsShouldRestartOnFailureDisabled, +} + +var mappingProcessOptionsShouldRestartOnFailureEnumLowerCase = map[string]ProcessOptionsShouldRestartOnFailureEnum{ + "enabled": ProcessOptionsShouldRestartOnFailureEnabled, + "disabled": ProcessOptionsShouldRestartOnFailureDisabled, +} + +// GetProcessOptionsShouldRestartOnFailureEnumValues Enumerates the set of values for ProcessOptionsShouldRestartOnFailureEnum +func GetProcessOptionsShouldRestartOnFailureEnumValues() []ProcessOptionsShouldRestartOnFailureEnum { + values := make([]ProcessOptionsShouldRestartOnFailureEnum, 0) + for _, v := range mappingProcessOptionsShouldRestartOnFailureEnum { + values = append(values, v) + } + return values +} + +// GetProcessOptionsShouldRestartOnFailureEnumStringValues Enumerates the set of values in String for ProcessOptionsShouldRestartOnFailureEnum +func GetProcessOptionsShouldRestartOnFailureEnumStringValues() []string { + return []string{ + "ENABLED", + "DISABLED", + } +} + +// GetMappingProcessOptionsShouldRestartOnFailureEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingProcessOptionsShouldRestartOnFailureEnum(val string) (ProcessOptionsShouldRestartOnFailureEnum, bool) { + enum, ok := mappingProcessOptionsShouldRestartOnFailureEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/process_status_type.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/process_status_type.go new file mode 100644 index 00000000000..06bc001983e --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/process_status_type.go @@ -0,0 +1,60 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "strings" +) + +// ProcessStatusTypeEnum Enum with underlying type: string +type ProcessStatusTypeEnum string + +// Set of constants representing the allowable values for ProcessStatusTypeEnum +const ( + ProcessStatusTypeStopped ProcessStatusTypeEnum = "STOPPED" + ProcessStatusTypeRunning ProcessStatusTypeEnum = "RUNNING" + ProcessStatusTypeError ProcessStatusTypeEnum = "ERROR" +) + +var mappingProcessStatusTypeEnum = map[string]ProcessStatusTypeEnum{ + "STOPPED": ProcessStatusTypeStopped, + "RUNNING": ProcessStatusTypeRunning, + "ERROR": ProcessStatusTypeError, +} + +var mappingProcessStatusTypeEnumLowerCase = map[string]ProcessStatusTypeEnum{ + "stopped": ProcessStatusTypeStopped, + "running": ProcessStatusTypeRunning, + "error": ProcessStatusTypeError, +} + +// GetProcessStatusTypeEnumValues Enumerates the set of values for ProcessStatusTypeEnum +func GetProcessStatusTypeEnumValues() []ProcessStatusTypeEnum { + values := make([]ProcessStatusTypeEnum, 0) + for _, v := range mappingProcessStatusTypeEnum { + values = append(values, v) + } + return values +} + +// GetProcessStatusTypeEnumStringValues Enumerates the set of values in String for ProcessStatusTypeEnum +func GetProcessStatusTypeEnumStringValues() []string { + return []string{ + "STOPPED", + "RUNNING", + "ERROR", + } +} + +// GetMappingProcessStatusTypeEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingProcessStatusTypeEnum(val string) (ProcessStatusTypeEnum, bool) { + enum, ok := mappingProcessStatusTypeEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/process_type.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/process_type.go new file mode 100644 index 00000000000..a65bc202db1 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/process_type.go @@ -0,0 +1,56 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "strings" +) + +// ProcessTypeEnum Enum with underlying type: string +type ProcessTypeEnum string + +// Set of constants representing the allowable values for ProcessTypeEnum +const ( + ProcessTypeExtract ProcessTypeEnum = "EXTRACT" + ProcessTypeReplicat ProcessTypeEnum = "REPLICAT" +) + +var mappingProcessTypeEnum = map[string]ProcessTypeEnum{ + "EXTRACT": ProcessTypeExtract, + "REPLICAT": ProcessTypeReplicat, +} + +var mappingProcessTypeEnumLowerCase = map[string]ProcessTypeEnum{ + "extract": ProcessTypeExtract, + "replicat": ProcessTypeReplicat, +} + +// GetProcessTypeEnumValues Enumerates the set of values for ProcessTypeEnum +func GetProcessTypeEnumValues() []ProcessTypeEnum { + values := make([]ProcessTypeEnum, 0) + for _, v := range mappingProcessTypeEnum { + values = append(values, v) + } + return values +} + +// GetProcessTypeEnumStringValues Enumerates the set of values in String for ProcessTypeEnum +func GetProcessTypeEnumStringValues() []string { + return []string{ + "EXTRACT", + "REPLICAT", + } +} + +// GetMappingProcessTypeEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingProcessTypeEnum(val string) (ProcessTypeEnum, bool) { + enum, ok := mappingProcessTypeEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/recipe_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/recipe_summary.go new file mode 100644 index 00000000000..1b36e2b3333 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/recipe_summary.go @@ -0,0 +1,57 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// RecipeSummary The list of recipe details to create pipelines. +type RecipeSummary struct { + + // The type of the recipe + RecipeType RecipeTypeEnum `mandatory:"true" json:"recipeType"` + + // An object's Display Name. + Name *string `mandatory:"true" json:"name"` + + // An object's Display Name. + DisplayName *string `mandatory:"true" json:"displayName"` + + // Array of supported technology types for this recipe. + SupportedSourceTechnologyTypes []TechnologyTypeEnum `mandatory:"true" json:"supportedSourceTechnologyTypes"` + + // Array of supported technology types for this recipe. + SupportedTargetTechnologyTypes []TechnologyTypeEnum `mandatory:"true" json:"supportedTargetTechnologyTypes"` + + // Metadata about this specific object. + Description *string `mandatory:"false" json:"description"` +} + +func (m RecipeSummary) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m RecipeSummary) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingRecipeTypeEnum(string(m.RecipeType)); !ok && m.RecipeType != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for RecipeType: %s. Supported values are: %s.", m.RecipeType, strings.Join(GetRecipeTypeEnumStringValues(), ","))) + } + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/recipe_summary_collection.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/recipe_summary_collection.go new file mode 100644 index 00000000000..943cfaf34c1 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/recipe_summary_collection.go @@ -0,0 +1,39 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// RecipeSummaryCollection The list of Recipe objects. +type RecipeSummaryCollection struct { + + // Array of Recipe Summary + Items []RecipeSummary `mandatory:"true" json:"items"` +} + +func (m RecipeSummaryCollection) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m RecipeSummaryCollection) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/recipe_type.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/recipe_type.go new file mode 100644 index 00000000000..49c9e0faa5d --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/recipe_type.go @@ -0,0 +1,52 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "strings" +) + +// RecipeTypeEnum Enum with underlying type: string +type RecipeTypeEnum string + +// Set of constants representing the allowable values for RecipeTypeEnum +const ( + RecipeTypeZeroEtl RecipeTypeEnum = "ZERO_ETL" +) + +var mappingRecipeTypeEnum = map[string]RecipeTypeEnum{ + "ZERO_ETL": RecipeTypeZeroEtl, +} + +var mappingRecipeTypeEnumLowerCase = map[string]RecipeTypeEnum{ + "zero_etl": RecipeTypeZeroEtl, +} + +// GetRecipeTypeEnumValues Enumerates the set of values for RecipeTypeEnum +func GetRecipeTypeEnumValues() []RecipeTypeEnum { + values := make([]RecipeTypeEnum, 0) + for _, v := range mappingRecipeTypeEnum { + values = append(values, v) + } + return values +} + +// GetRecipeTypeEnumStringValues Enumerates the set of values in String for RecipeTypeEnum +func GetRecipeTypeEnumStringValues() []string { + return []string{ + "ZERO_ETL", + } +} + +// GetMappingRecipeTypeEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingRecipeTypeEnum(val string) (RecipeTypeEnum, bool) { + enum, ok := mappingRecipeTypeEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/replicate_ddl_error_action.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/replicate_ddl_error_action.go new file mode 100644 index 00000000000..0a3b824a8d9 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/replicate_ddl_error_action.go @@ -0,0 +1,60 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "strings" +) + +// ReplicateDdlErrorActionEnum Enum with underlying type: string +type ReplicateDdlErrorActionEnum string + +// Set of constants representing the allowable values for ReplicateDdlErrorActionEnum +const ( + ReplicateDdlErrorActionTerminate ReplicateDdlErrorActionEnum = "TERMINATE" + ReplicateDdlErrorActionDiscard ReplicateDdlErrorActionEnum = "DISCARD" + ReplicateDdlErrorActionIgnore ReplicateDdlErrorActionEnum = "IGNORE" +) + +var mappingReplicateDdlErrorActionEnum = map[string]ReplicateDdlErrorActionEnum{ + "TERMINATE": ReplicateDdlErrorActionTerminate, + "DISCARD": ReplicateDdlErrorActionDiscard, + "IGNORE": ReplicateDdlErrorActionIgnore, +} + +var mappingReplicateDdlErrorActionEnumLowerCase = map[string]ReplicateDdlErrorActionEnum{ + "terminate": ReplicateDdlErrorActionTerminate, + "discard": ReplicateDdlErrorActionDiscard, + "ignore": ReplicateDdlErrorActionIgnore, +} + +// GetReplicateDdlErrorActionEnumValues Enumerates the set of values for ReplicateDdlErrorActionEnum +func GetReplicateDdlErrorActionEnumValues() []ReplicateDdlErrorActionEnum { + values := make([]ReplicateDdlErrorActionEnum, 0) + for _, v := range mappingReplicateDdlErrorActionEnum { + values = append(values, v) + } + return values +} + +// GetReplicateDdlErrorActionEnumStringValues Enumerates the set of values in String for ReplicateDdlErrorActionEnum +func GetReplicateDdlErrorActionEnumStringValues() []string { + return []string{ + "TERMINATE", + "DISCARD", + "IGNORE", + } +} + +// GetMappingReplicateDdlErrorActionEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingReplicateDdlErrorActionEnum(val string) (ReplicateDdlErrorActionEnum, bool) { + enum, ok := mappingReplicateDdlErrorActionEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/replicate_dml_error_action.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/replicate_dml_error_action.go new file mode 100644 index 00000000000..bc9ca4f7250 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/replicate_dml_error_action.go @@ -0,0 +1,60 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "strings" +) + +// ReplicateDmlErrorActionEnum Enum with underlying type: string +type ReplicateDmlErrorActionEnum string + +// Set of constants representing the allowable values for ReplicateDmlErrorActionEnum +const ( + ReplicateDmlErrorActionTerminate ReplicateDmlErrorActionEnum = "TERMINATE" + ReplicateDmlErrorActionDiscard ReplicateDmlErrorActionEnum = "DISCARD" + ReplicateDmlErrorActionIgnore ReplicateDmlErrorActionEnum = "IGNORE" +) + +var mappingReplicateDmlErrorActionEnum = map[string]ReplicateDmlErrorActionEnum{ + "TERMINATE": ReplicateDmlErrorActionTerminate, + "DISCARD": ReplicateDmlErrorActionDiscard, + "IGNORE": ReplicateDmlErrorActionIgnore, +} + +var mappingReplicateDmlErrorActionEnumLowerCase = map[string]ReplicateDmlErrorActionEnum{ + "terminate": ReplicateDmlErrorActionTerminate, + "discard": ReplicateDmlErrorActionDiscard, + "ignore": ReplicateDmlErrorActionIgnore, +} + +// GetReplicateDmlErrorActionEnumValues Enumerates the set of values for ReplicateDmlErrorActionEnum +func GetReplicateDmlErrorActionEnumValues() []ReplicateDmlErrorActionEnum { + values := make([]ReplicateDmlErrorActionEnum, 0) + for _, v := range mappingReplicateDmlErrorActionEnum { + values = append(values, v) + } + return values +} + +// GetReplicateDmlErrorActionEnumStringValues Enumerates the set of values in String for ReplicateDmlErrorActionEnum +func GetReplicateDmlErrorActionEnumStringValues() []string { + return []string{ + "TERMINATE", + "DISCARD", + "IGNORE", + } +} + +// GetMappingReplicateDmlErrorActionEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingReplicateDmlErrorActionEnum(val string) (ReplicateDmlErrorActionEnum, bool) { + enum, ok := mappingReplicateDmlErrorActionEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/replicate_schema_change.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/replicate_schema_change.go new file mode 100644 index 00000000000..71723acb724 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/replicate_schema_change.go @@ -0,0 +1,96 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// ReplicateSchemaChange Options required for pipeline Initial Data Load. If enabled, copies existing data from source to target before replication. +type ReplicateSchemaChange struct { + + // If ENABLED, then addition or removal of schema is also replicated, apart from individual tables and records when creating or updating the pipeline. + CanReplicateSchemaChange ReplicateSchemaChangeCanReplicateSchemaChangeEnum `mandatory:"true" json:"canReplicateSchemaChange"` + + // Action upon DDL Error (active only if 'Replicate schema changes (DDL)' is selected) i.e canReplicateSchemaChange=true + ActionOnDdlError ReplicateDdlErrorActionEnum `mandatory:"false" json:"actionOnDdlError,omitempty"` + + // Action upon DML Error (active only if 'Replicate schema changes (DDL)' is selected) i.e canReplicateSchemaChange=true + ActionOnDmlError ReplicateDmlErrorActionEnum `mandatory:"false" json:"actionOnDmlError,omitempty"` +} + +func (m ReplicateSchemaChange) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m ReplicateSchemaChange) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingReplicateSchemaChangeCanReplicateSchemaChangeEnum(string(m.CanReplicateSchemaChange)); !ok && m.CanReplicateSchemaChange != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for CanReplicateSchemaChange: %s. Supported values are: %s.", m.CanReplicateSchemaChange, strings.Join(GetReplicateSchemaChangeCanReplicateSchemaChangeEnumStringValues(), ","))) + } + + if _, ok := GetMappingReplicateDdlErrorActionEnum(string(m.ActionOnDdlError)); !ok && m.ActionOnDdlError != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for ActionOnDdlError: %s. Supported values are: %s.", m.ActionOnDdlError, strings.Join(GetReplicateDdlErrorActionEnumStringValues(), ","))) + } + if _, ok := GetMappingReplicateDmlErrorActionEnum(string(m.ActionOnDmlError)); !ok && m.ActionOnDmlError != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for ActionOnDmlError: %s. Supported values are: %s.", m.ActionOnDmlError, strings.Join(GetReplicateDmlErrorActionEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// ReplicateSchemaChangeCanReplicateSchemaChangeEnum Enum with underlying type: string +type ReplicateSchemaChangeCanReplicateSchemaChangeEnum string + +// Set of constants representing the allowable values for ReplicateSchemaChangeCanReplicateSchemaChangeEnum +const ( + ReplicateSchemaChangeCanReplicateSchemaChangeEnabled ReplicateSchemaChangeCanReplicateSchemaChangeEnum = "ENABLED" + ReplicateSchemaChangeCanReplicateSchemaChangeDisabled ReplicateSchemaChangeCanReplicateSchemaChangeEnum = "DISABLED" +) + +var mappingReplicateSchemaChangeCanReplicateSchemaChangeEnum = map[string]ReplicateSchemaChangeCanReplicateSchemaChangeEnum{ + "ENABLED": ReplicateSchemaChangeCanReplicateSchemaChangeEnabled, + "DISABLED": ReplicateSchemaChangeCanReplicateSchemaChangeDisabled, +} + +var mappingReplicateSchemaChangeCanReplicateSchemaChangeEnumLowerCase = map[string]ReplicateSchemaChangeCanReplicateSchemaChangeEnum{ + "enabled": ReplicateSchemaChangeCanReplicateSchemaChangeEnabled, + "disabled": ReplicateSchemaChangeCanReplicateSchemaChangeDisabled, +} + +// GetReplicateSchemaChangeCanReplicateSchemaChangeEnumValues Enumerates the set of values for ReplicateSchemaChangeCanReplicateSchemaChangeEnum +func GetReplicateSchemaChangeCanReplicateSchemaChangeEnumValues() []ReplicateSchemaChangeCanReplicateSchemaChangeEnum { + values := make([]ReplicateSchemaChangeCanReplicateSchemaChangeEnum, 0) + for _, v := range mappingReplicateSchemaChangeCanReplicateSchemaChangeEnum { + values = append(values, v) + } + return values +} + +// GetReplicateSchemaChangeCanReplicateSchemaChangeEnumStringValues Enumerates the set of values in String for ReplicateSchemaChangeCanReplicateSchemaChangeEnum +func GetReplicateSchemaChangeCanReplicateSchemaChangeEnumStringValues() []string { + return []string{ + "ENABLED", + "DISABLED", + } +} + +// GetMappingReplicateSchemaChangeCanReplicateSchemaChangeEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingReplicateSchemaChangeCanReplicateSchemaChangeEnum(val string) (ReplicateSchemaChangeCanReplicateSchemaChangeEnum, bool) { + enum, ok := mappingReplicateSchemaChangeCanReplicateSchemaChangeEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/severity_type.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/severity_type.go new file mode 100644 index 00000000000..a925ff13cdb --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/severity_type.go @@ -0,0 +1,60 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "strings" +) + +// SeverityTypeEnum Enum with underlying type: string +type SeverityTypeEnum string + +// Set of constants representing the allowable values for SeverityTypeEnum +const ( + SeverityTypeInfo SeverityTypeEnum = "INFO" + SeverityTypeError SeverityTypeEnum = "ERROR" + SeverityTypeWarning SeverityTypeEnum = "WARNING" +) + +var mappingSeverityTypeEnum = map[string]SeverityTypeEnum{ + "INFO": SeverityTypeInfo, + "ERROR": SeverityTypeError, + "WARNING": SeverityTypeWarning, +} + +var mappingSeverityTypeEnumLowerCase = map[string]SeverityTypeEnum{ + "info": SeverityTypeInfo, + "error": SeverityTypeError, + "warning": SeverityTypeWarning, +} + +// GetSeverityTypeEnumValues Enumerates the set of values for SeverityTypeEnum +func GetSeverityTypeEnumValues() []SeverityTypeEnum { + values := make([]SeverityTypeEnum, 0) + for _, v := range mappingSeverityTypeEnum { + values = append(values, v) + } + return values +} + +// GetSeverityTypeEnumStringValues Enumerates the set of values in String for SeverityTypeEnum +func GetSeverityTypeEnumStringValues() []string { + return []string{ + "INFO", + "ERROR", + "WARNING", + } +} + +// GetMappingSeverityTypeEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingSeverityTypeEnum(val string) (SeverityTypeEnum, bool) { + enum, ok := mappingSeverityTypeEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/source_pipeline_connection_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/source_pipeline_connection_details.go new file mode 100644 index 00000000000..772644f883b --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/source_pipeline_connection_details.go @@ -0,0 +1,40 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// SourcePipelineConnectionDetails The source connection details for creating a pipeline. +type SourcePipelineConnectionDetails struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the connection being + // referenced. + ConnectionId *string `mandatory:"true" json:"connectionId"` +} + +func (m SourcePipelineConnectionDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m SourcePipelineConnectionDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/start_pipeline_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/start_pipeline_details.go new file mode 100644 index 00000000000..c712edcdca9 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/start_pipeline_details.go @@ -0,0 +1,77 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// StartPipelineDetails Details with which to start a pipeline. +type StartPipelineDetails interface { +} + +type startpipelinedetails struct { + JsonData []byte + Type string `json:"type"` +} + +// UnmarshalJSON unmarshals json +func (m *startpipelinedetails) UnmarshalJSON(data []byte) error { + m.JsonData = data + type Unmarshalerstartpipelinedetails startpipelinedetails + s := struct { + Model Unmarshalerstartpipelinedetails + }{} + err := json.Unmarshal(data, &s.Model) + if err != nil { + return err + } + m.Type = s.Model.Type + + return err +} + +// UnmarshalPolymorphicJSON unmarshals polymorphic json +func (m *startpipelinedetails) UnmarshalPolymorphicJSON(data []byte) (interface{}, error) { + + if data == nil || string(data) == "null" { + return nil, nil + } + + var err error + switch m.Type { + case "DEFAULT": + mm := DefaultStartPipelineDetails{} + err = json.Unmarshal(data, &mm) + return mm, err + default: + common.Logf("Recieved unsupported enum value for StartPipelineDetails: %s.", m.Type) + return *m, nil + } +} + +func (m startpipelinedetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m startpipelinedetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/start_pipeline_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/start_pipeline_request_response.go new file mode 100644 index 00000000000..8c1cac9c0cf --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/start_pipeline_request_response.go @@ -0,0 +1,109 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// StartPipelineRequest wrapper for the StartPipeline operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/StartPipeline.go.html to see an example of how to use StartPipelineRequest. +type StartPipelineRequest struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the pipeline created. + PipelineId *string `mandatory:"true" contributesTo:"path" name:"pipelineId"` + + // Details to start Pipeline. + StartPipelineDetails `contributesTo:"body"` + + // 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 is updated or deleted only if the etag you provide matches the + // resource's current etag value. + IfMatch *string `mandatory:"false" contributesTo:"header" name:"if-match"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // A token that uniquely identifies a request so it can be retried, in case of a timeout or server error, + // without the risk of executing that same action again. Retry tokens expire after 24 hours but can be + // invalidated before then due to conflicting operations. For example, if a resource was deleted and purged + // from the system, then a retry of the original creation request is rejected. + OpcRetryToken *string `mandatory:"false" contributesTo:"header" name:"opc-retry-token"` + + // Whether to override locks (if any exist). + IsLockOverride *bool `mandatory:"false" contributesTo:"query" name:"isLockOverride"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request StartPipelineRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request StartPipelineRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request StartPipelineRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request StartPipelineRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request StartPipelineRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// StartPipelineResponse wrapper for the StartPipeline operation +type StartPipelineResponse struct { + + // The underlying http response + RawResponse *http.Response + + // A unique Oracle-assigned identifier for an asynchronous request. You can use this to query + // status of the asynchronous operation. + OpcWorkRequestId *string `presentIn:"header" name:"opc-work-request-id"` + + // A unique Oracle-assigned identifier for the request. If you need to contact Oracle about a + // particular request, please include the request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` +} + +func (response StartPipelineResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response StartPipelineResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/start_pipeline_type.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/start_pipeline_type.go new file mode 100644 index 00000000000..5077c966328 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/start_pipeline_type.go @@ -0,0 +1,52 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "strings" +) + +// StartPipelineTypeEnum Enum with underlying type: string +type StartPipelineTypeEnum string + +// Set of constants representing the allowable values for StartPipelineTypeEnum +const ( + StartPipelineTypeDefault StartPipelineTypeEnum = "DEFAULT" +) + +var mappingStartPipelineTypeEnum = map[string]StartPipelineTypeEnum{ + "DEFAULT": StartPipelineTypeDefault, +} + +var mappingStartPipelineTypeEnumLowerCase = map[string]StartPipelineTypeEnum{ + "default": StartPipelineTypeDefault, +} + +// GetStartPipelineTypeEnumValues Enumerates the set of values for StartPipelineTypeEnum +func GetStartPipelineTypeEnumValues() []StartPipelineTypeEnum { + values := make([]StartPipelineTypeEnum, 0) + for _, v := range mappingStartPipelineTypeEnum { + values = append(values, v) + } + return values +} + +// GetStartPipelineTypeEnumStringValues Enumerates the set of values in String for StartPipelineTypeEnum +func GetStartPipelineTypeEnumStringValues() []string { + return []string{ + "DEFAULT", + } +} + +// GetMappingStartPipelineTypeEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingStartPipelineTypeEnum(val string) (StartPipelineTypeEnum, bool) { + enum, ok := mappingStartPipelineTypeEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/step_message.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/step_message.go new file mode 100644 index 00000000000..ee667751084 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/step_message.go @@ -0,0 +1,55 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// StepMessage Contents of a step message. +type StepMessage struct { + + // The status message of the steps in a recipe during pipeline initialization. + // https://docs.oracle.com/en/middleware/goldengate/core/23/oggra/rest-endpoints.html + Message *string `mandatory:"true" json:"message"` + + // The code returned when GoldenGate reports an error while running a step during pipeline initialization. + // https://docs.oracle.com/en/middleware/goldengate/core/23/error-messages/ogg-00001-ogg-40000.html#GUID-97FF7AA7-7A5C-4AA7-B29F-3CC8D26761F2 + Code *string `mandatory:"true" json:"code"` + + // Date and time of a message issued by steps in a recipe during pipeline initialization. + // The format is defined by RFC3339 (https://tools.ietf.org/html/rfc3339), such as `2024-07-25T21:10:29.600Z`. + Timestamp *common.SDKTime `mandatory:"true" json:"timestamp"` + + // The severity returned when calling GoldenGate API messages for a step in a recipe during pipeline initialization. + // https://docs.oracle.com/en/middleware/goldengate/core/23/oggra/rest-endpoints.html + Severity SeverityTypeEnum `mandatory:"true" json:"severity"` +} + +func (m StepMessage) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m StepMessage) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingSeverityTypeEnum(string(m.Severity)); !ok && m.Severity != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for Severity: %s. Supported values are: %s.", m.Severity, strings.Join(GetSeverityTypeEnumStringValues(), ","))) + } + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/step_status_type.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/step_status_type.go new file mode 100644 index 00000000000..2a30b9b7450 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/step_status_type.go @@ -0,0 +1,64 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "strings" +) + +// StepStatusTypeEnum Enum with underlying type: string +type StepStatusTypeEnum string + +// Set of constants representing the allowable values for StepStatusTypeEnum +const ( + StepStatusTypePending StepStatusTypeEnum = "PENDING" + StepStatusTypeInProgress StepStatusTypeEnum = "IN_PROGRESS" + StepStatusTypeCompleted StepStatusTypeEnum = "COMPLETED" + StepStatusTypeFailed StepStatusTypeEnum = "FAILED" +) + +var mappingStepStatusTypeEnum = map[string]StepStatusTypeEnum{ + "PENDING": StepStatusTypePending, + "IN_PROGRESS": StepStatusTypeInProgress, + "COMPLETED": StepStatusTypeCompleted, + "FAILED": StepStatusTypeFailed, +} + +var mappingStepStatusTypeEnumLowerCase = map[string]StepStatusTypeEnum{ + "pending": StepStatusTypePending, + "in_progress": StepStatusTypeInProgress, + "completed": StepStatusTypeCompleted, + "failed": StepStatusTypeFailed, +} + +// GetStepStatusTypeEnumValues Enumerates the set of values for StepStatusTypeEnum +func GetStepStatusTypeEnumValues() []StepStatusTypeEnum { + values := make([]StepStatusTypeEnum, 0) + for _, v := range mappingStepStatusTypeEnum { + values = append(values, v) + } + return values +} + +// GetStepStatusTypeEnumStringValues Enumerates the set of values in String for StepStatusTypeEnum +func GetStepStatusTypeEnumStringValues() []string { + return []string{ + "PENDING", + "IN_PROGRESS", + "COMPLETED", + "FAILED", + } +} + +// GetMappingStepStatusTypeEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingStepStatusTypeEnum(val string) (StepStatusTypeEnum, bool) { + enum, ok := mappingStepStatusTypeEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/stop_pipeline_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/stop_pipeline_details.go new file mode 100644 index 00000000000..6ca5e6a4527 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/stop_pipeline_details.go @@ -0,0 +1,77 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// StopPipelineDetails Details for a pipeline stop. +type StopPipelineDetails interface { +} + +type stoppipelinedetails struct { + JsonData []byte + Type string `json:"type"` +} + +// UnmarshalJSON unmarshals json +func (m *stoppipelinedetails) UnmarshalJSON(data []byte) error { + m.JsonData = data + type Unmarshalerstoppipelinedetails stoppipelinedetails + s := struct { + Model Unmarshalerstoppipelinedetails + }{} + err := json.Unmarshal(data, &s.Model) + if err != nil { + return err + } + m.Type = s.Model.Type + + return err +} + +// UnmarshalPolymorphicJSON unmarshals polymorphic json +func (m *stoppipelinedetails) UnmarshalPolymorphicJSON(data []byte) (interface{}, error) { + + if data == nil || string(data) == "null" { + return nil, nil + } + + var err error + switch m.Type { + case "DEFAULT": + mm := DefaultStopPipelineDetails{} + err = json.Unmarshal(data, &mm) + return mm, err + default: + common.Logf("Recieved unsupported enum value for StopPipelineDetails: %s.", m.Type) + return *m, nil + } +} + +func (m stoppipelinedetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m stoppipelinedetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/stop_pipeline_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/stop_pipeline_request_response.go new file mode 100644 index 00000000000..34620058004 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/stop_pipeline_request_response.go @@ -0,0 +1,109 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// StopPipelineRequest wrapper for the StopPipeline operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/StopPipeline.go.html to see an example of how to use StopPipelineRequest. +type StopPipelineRequest struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the pipeline created. + PipelineId *string `mandatory:"true" contributesTo:"path" name:"pipelineId"` + + // Details to stop the pipeline. + StopPipelineDetails `contributesTo:"body"` + + // 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 is updated or deleted only if the etag you provide matches the + // resource's current etag value. + IfMatch *string `mandatory:"false" contributesTo:"header" name:"if-match"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // A token that uniquely identifies a request so it can be retried, in case of a timeout or server error, + // without the risk of executing that same action again. Retry tokens expire after 24 hours but can be + // invalidated before then due to conflicting operations. For example, if a resource was deleted and purged + // from the system, then a retry of the original creation request is rejected. + OpcRetryToken *string `mandatory:"false" contributesTo:"header" name:"opc-retry-token"` + + // Whether to override locks (if any exist). + IsLockOverride *bool `mandatory:"false" contributesTo:"query" name:"isLockOverride"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request StopPipelineRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request StopPipelineRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request StopPipelineRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request StopPipelineRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request StopPipelineRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// StopPipelineResponse wrapper for the StopPipeline operation +type StopPipelineResponse struct { + + // The underlying http response + RawResponse *http.Response + + // A unique Oracle-assigned identifier for an asynchronous request. You can use this to query + // status of the asynchronous operation. + OpcWorkRequestId *string `presentIn:"header" name:"opc-work-request-id"` + + // A unique Oracle-assigned identifier for the request. If you need to contact Oracle about a + // particular request, please include the request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` +} + +func (response StopPipelineResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response StopPipelineResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/stop_pipeline_type.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/stop_pipeline_type.go new file mode 100644 index 00000000000..9242a0a5acc --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/stop_pipeline_type.go @@ -0,0 +1,52 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "strings" +) + +// StopPipelineTypeEnum Enum with underlying type: string +type StopPipelineTypeEnum string + +// Set of constants representing the allowable values for StopPipelineTypeEnum +const ( + StopPipelineTypeDefault StopPipelineTypeEnum = "DEFAULT" +) + +var mappingStopPipelineTypeEnum = map[string]StopPipelineTypeEnum{ + "DEFAULT": StopPipelineTypeDefault, +} + +var mappingStopPipelineTypeEnumLowerCase = map[string]StopPipelineTypeEnum{ + "default": StopPipelineTypeDefault, +} + +// GetStopPipelineTypeEnumValues Enumerates the set of values for StopPipelineTypeEnum +func GetStopPipelineTypeEnumValues() []StopPipelineTypeEnum { + values := make([]StopPipelineTypeEnum, 0) + for _, v := range mappingStopPipelineTypeEnum { + values = append(values, v) + } + return values +} + +// GetStopPipelineTypeEnumStringValues Enumerates the set of values in String for StopPipelineTypeEnum +func GetStopPipelineTypeEnumStringValues() []string { + return []string{ + "DEFAULT", + } +} + +// GetMappingStopPipelineTypeEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingStopPipelineTypeEnum(val string) (StopPipelineTypeEnum, bool) { + enum, ok := mappingStopPipelineTypeEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/target_pipeline_connection_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/target_pipeline_connection_details.go new file mode 100644 index 00000000000..8af1675e30c --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/target_pipeline_connection_details.go @@ -0,0 +1,40 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// TargetPipelineConnectionDetails The target connection details for creating a pipeline. +type TargetPipelineConnectionDetails struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the connection being + // referenced. + ConnectionId *string `mandatory:"true" json:"connectionId"` +} + +func (m TargetPipelineConnectionDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m TargetPipelineConnectionDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_details.go new file mode 100644 index 00000000000..f8a2b0d1412 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_details.go @@ -0,0 +1,77 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// TestPipelineConnectionDetails Details about testing the pipeline's assigned connection. +type TestPipelineConnectionDetails interface { +} + +type testpipelineconnectiondetails struct { + JsonData []byte + Type string `json:"type"` +} + +// UnmarshalJSON unmarshals json +func (m *testpipelineconnectiondetails) UnmarshalJSON(data []byte) error { + m.JsonData = data + type Unmarshalertestpipelineconnectiondetails testpipelineconnectiondetails + s := struct { + Model Unmarshalertestpipelineconnectiondetails + }{} + err := json.Unmarshal(data, &s.Model) + if err != nil { + return err + } + m.Type = s.Model.Type + + return err +} + +// UnmarshalPolymorphicJSON unmarshals polymorphic json +func (m *testpipelineconnectiondetails) UnmarshalPolymorphicJSON(data []byte) (interface{}, error) { + + if data == nil || string(data) == "null" { + return nil, nil + } + + var err error + switch m.Type { + case "DEFAULT": + mm := DefaultTestPipelineConnectionDetails{} + err = json.Unmarshal(data, &mm) + return mm, err + default: + common.Logf("Recieved unsupported enum value for TestPipelineConnectionDetails: %s.", m.Type) + return *m, nil + } +} + +func (m testpipelineconnectiondetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m testpipelineconnectiondetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_error.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_error.go new file mode 100644 index 00000000000..0da46770131 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_error.go @@ -0,0 +1,48 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// TestPipelineConnectionError The error returned when a pipeline connection fails to connect. +type TestPipelineConnectionError struct { + + // A short error code that defines the error, meant for programmatic parsing. + Code *string `mandatory:"true" json:"code"` + + // A human-readable error string. + Message *string `mandatory:"true" json:"message"` + + // The text describing the root cause of the reported issue. + Issue *string `mandatory:"false" json:"issue"` + + // The text describing the action required to fix the issue. + Action *string `mandatory:"false" json:"action"` +} + +func (m TestPipelineConnectionError) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m TestPipelineConnectionError) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_request_response.go new file mode 100644 index 00000000000..82027178017 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_request_response.go @@ -0,0 +1,108 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// TestPipelineConnectionRequest wrapper for the TestPipelineConnection operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/TestPipelineConnection.go.html to see an example of how to use TestPipelineConnectionRequest. +type TestPipelineConnectionRequest struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the pipeline created. + PipelineId *string `mandatory:"true" contributesTo:"path" name:"pipelineId"` + + // Additional metadata required to test the connection assigned to the pipeline. + TestPipelineConnectionDetails `contributesTo:"body"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // 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 is updated or deleted only if the etag you provide matches the + // resource's current etag value. + IfMatch *string `mandatory:"false" contributesTo:"header" name:"if-match"` + + // A token that uniquely identifies a request so it can be retried, in case of a timeout or server error, + // without the risk of executing that same action again. Retry tokens expire after 24 hours but can be + // invalidated before then due to conflicting operations. For example, if a resource was deleted and purged + // from the system, then a retry of the original creation request is rejected. + OpcRetryToken *string `mandatory:"false" contributesTo:"header" name:"opc-retry-token"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request TestPipelineConnectionRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request TestPipelineConnectionRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request TestPipelineConnectionRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request TestPipelineConnectionRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request TestPipelineConnectionRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// TestPipelineConnectionResponse wrapper for the TestPipelineConnection operation +type TestPipelineConnectionResponse struct { + + // The underlying http response + RawResponse *http.Response + + // The TestPipelineConnectionResult instance + TestPipelineConnectionResult `presentIn:"body"` + + // A unique Oracle-assigned identifier for the request. If you need to contact Oracle about a + // particular request, please include the request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` + + // For optimistic concurrency control. See `if-match`. + Etag *string `presentIn:"header" name:"etag"` +} + +func (response TestPipelineConnectionResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response TestPipelineConnectionResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_result.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_result.go new file mode 100644 index 00000000000..ba48b087830 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_result.go @@ -0,0 +1,90 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// TestPipelineConnectionResult Result of the connectivity test performed on a pipeline's assigned connection. +type TestPipelineConnectionResult struct { + + // Type of result, either Succeeded, Failed, or Timed out. + ResultType TestPipelineConnectionResultResultTypeEnum `mandatory:"true" json:"resultType"` + + Error *TestPipelineConnectionError `mandatory:"false" json:"error"` +} + +func (m TestPipelineConnectionResult) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m TestPipelineConnectionResult) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingTestPipelineConnectionResultResultTypeEnum(string(m.ResultType)); !ok && m.ResultType != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for ResultType: %s. Supported values are: %s.", m.ResultType, strings.Join(GetTestPipelineConnectionResultResultTypeEnumStringValues(), ","))) + } + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// TestPipelineConnectionResultResultTypeEnum Enum with underlying type: string +type TestPipelineConnectionResultResultTypeEnum string + +// Set of constants representing the allowable values for TestPipelineConnectionResultResultTypeEnum +const ( + TestPipelineConnectionResultResultTypeSucceeded TestPipelineConnectionResultResultTypeEnum = "SUCCEEDED" + TestPipelineConnectionResultResultTypeFailed TestPipelineConnectionResultResultTypeEnum = "FAILED" + TestPipelineConnectionResultResultTypeTimedOut TestPipelineConnectionResultResultTypeEnum = "TIMED_OUT" +) + +var mappingTestPipelineConnectionResultResultTypeEnum = map[string]TestPipelineConnectionResultResultTypeEnum{ + "SUCCEEDED": TestPipelineConnectionResultResultTypeSucceeded, + "FAILED": TestPipelineConnectionResultResultTypeFailed, + "TIMED_OUT": TestPipelineConnectionResultResultTypeTimedOut, +} + +var mappingTestPipelineConnectionResultResultTypeEnumLowerCase = map[string]TestPipelineConnectionResultResultTypeEnum{ + "succeeded": TestPipelineConnectionResultResultTypeSucceeded, + "failed": TestPipelineConnectionResultResultTypeFailed, + "timed_out": TestPipelineConnectionResultResultTypeTimedOut, +} + +// GetTestPipelineConnectionResultResultTypeEnumValues Enumerates the set of values for TestPipelineConnectionResultResultTypeEnum +func GetTestPipelineConnectionResultResultTypeEnumValues() []TestPipelineConnectionResultResultTypeEnum { + values := make([]TestPipelineConnectionResultResultTypeEnum, 0) + for _, v := range mappingTestPipelineConnectionResultResultTypeEnum { + values = append(values, v) + } + return values +} + +// GetTestPipelineConnectionResultResultTypeEnumStringValues Enumerates the set of values in String for TestPipelineConnectionResultResultTypeEnum +func GetTestPipelineConnectionResultResultTypeEnumStringValues() []string { + return []string{ + "SUCCEEDED", + "FAILED", + "TIMED_OUT", + } +} + +// GetMappingTestPipelineConnectionResultResultTypeEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingTestPipelineConnectionResultResultTypeEnum(val string) (TestPipelineConnectionResultResultTypeEnum, bool) { + enum, ok := mappingTestPipelineConnectionResultResultTypeEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_type.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_type.go new file mode 100644 index 00000000000..503aa1ecdd6 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/test_pipeline_connection_type.go @@ -0,0 +1,52 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "strings" +) + +// TestPipelineConnectionTypeEnum Enum with underlying type: string +type TestPipelineConnectionTypeEnum string + +// Set of constants representing the allowable values for TestPipelineConnectionTypeEnum +const ( + TestPipelineConnectionTypeDefault TestPipelineConnectionTypeEnum = "DEFAULT" +) + +var mappingTestPipelineConnectionTypeEnum = map[string]TestPipelineConnectionTypeEnum{ + "DEFAULT": TestPipelineConnectionTypeDefault, +} + +var mappingTestPipelineConnectionTypeEnumLowerCase = map[string]TestPipelineConnectionTypeEnum{ + "default": TestPipelineConnectionTypeDefault, +} + +// GetTestPipelineConnectionTypeEnumValues Enumerates the set of values for TestPipelineConnectionTypeEnum +func GetTestPipelineConnectionTypeEnumValues() []TestPipelineConnectionTypeEnum { + values := make([]TestPipelineConnectionTypeEnum, 0) + for _, v := range mappingTestPipelineConnectionTypeEnum { + values = append(values, v) + } + return values +} + +// GetTestPipelineConnectionTypeEnumStringValues Enumerates the set of values in String for TestPipelineConnectionTypeEnum +func GetTestPipelineConnectionTypeEnumStringValues() []string { + return []string{ + "DEFAULT", + } +} + +// GetMappingTestPipelineConnectionTypeEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingTestPipelineConnectionTypeEnum(val string) (TestPipelineConnectionTypeEnum, bool) { + enum, ok := mappingTestPipelineConnectionTypeEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/update_mysql_connection_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/update_mysql_connection_details.go index 3d6e74aa829..4c66115c683 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/update_mysql_connection_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/update_mysql_connection_details.go @@ -89,7 +89,7 @@ type UpdateMysqlConnectionDetails struct { // containing the client public key (for 2-way SSL). SslCert *string `mandatory:"false" json:"sslCert"` - // Client Key – The base64 encoded content of a .pem or .crt file containing the client private key (for 2-way SSL). + // Client Key - The base64 encoded content of a .pem or .crt file containing the client private key (for 2-way SSL). SslKey *string `mandatory:"false" json:"sslKey"` // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the Secret that stores the Client Key diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/update_pipeline_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/update_pipeline_details.go new file mode 100644 index 00000000000..3d7f51769dd --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/update_pipeline_details.go @@ -0,0 +1,133 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// UpdatePipelineDetails Information with which to update a pipeline. +type UpdatePipelineDetails interface { + + // An object's Display Name. + GetDisplayName() *string + + // Metadata about this specific object. + GetDescription() *string + + // The Oracle license model that applies to a Deployment. + GetLicenseModel() LicenseModelEnum + + // A simple key-value pair that is applied without any predefined name, type, or scope. Exists + // for cross-compatibility only. + // Example: `{"bar-key": "value"}` + GetFreeformTags() map[string]string + + // Tags defined for this resource. Each key is predefined and scoped to a namespace. + // Example: `{"foo-namespace": {"bar-key": "value"}}` + GetDefinedTags() map[string]map[string]interface{} +} + +type updatepipelinedetails struct { + JsonData []byte + DisplayName *string `mandatory:"false" json:"displayName"` + Description *string `mandatory:"false" json:"description"` + LicenseModel LicenseModelEnum `mandatory:"false" json:"licenseModel,omitempty"` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` + RecipeType string `json:"recipeType"` +} + +// UnmarshalJSON unmarshals json +func (m *updatepipelinedetails) UnmarshalJSON(data []byte) error { + m.JsonData = data + type Unmarshalerupdatepipelinedetails updatepipelinedetails + s := struct { + Model Unmarshalerupdatepipelinedetails + }{} + err := json.Unmarshal(data, &s.Model) + if err != nil { + return err + } + m.DisplayName = s.Model.DisplayName + m.Description = s.Model.Description + m.LicenseModel = s.Model.LicenseModel + m.FreeformTags = s.Model.FreeformTags + m.DefinedTags = s.Model.DefinedTags + m.RecipeType = s.Model.RecipeType + + return err +} + +// UnmarshalPolymorphicJSON unmarshals polymorphic json +func (m *updatepipelinedetails) UnmarshalPolymorphicJSON(data []byte) (interface{}, error) { + + if data == nil || string(data) == "null" { + return nil, nil + } + + var err error + switch m.RecipeType { + case "ZERO_ETL": + mm := UpdateZeroEtlPipelineDetails{} + err = json.Unmarshal(data, &mm) + return mm, err + default: + common.Logf("Recieved unsupported enum value for UpdatePipelineDetails: %s.", m.RecipeType) + return *m, nil + } +} + +// GetDisplayName returns DisplayName +func (m updatepipelinedetails) GetDisplayName() *string { + return m.DisplayName +} + +// GetDescription returns Description +func (m updatepipelinedetails) GetDescription() *string { + return m.Description +} + +// GetLicenseModel returns LicenseModel +func (m updatepipelinedetails) GetLicenseModel() LicenseModelEnum { + return m.LicenseModel +} + +// GetFreeformTags returns FreeformTags +func (m updatepipelinedetails) GetFreeformTags() map[string]string { + return m.FreeformTags +} + +// GetDefinedTags returns DefinedTags +func (m updatepipelinedetails) GetDefinedTags() map[string]map[string]interface{} { + return m.DefinedTags +} + +func (m updatepipelinedetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m updatepipelinedetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if _, ok := GetMappingLicenseModelEnum(string(m.LicenseModel)); !ok && m.LicenseModel != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LicenseModel: %s. Supported values are: %s.", m.LicenseModel, strings.Join(GetLicenseModelEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/update_pipeline_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/update_pipeline_request_response.go new file mode 100644 index 00000000000..2b1eda8793d --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/update_pipeline_request_response.go @@ -0,0 +1,103 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +package goldengate + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "net/http" + "strings" +) + +// UpdatePipelineRequest wrapper for the UpdatePipeline operation +// +// # See also +// +// Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/goldengate/UpdatePipeline.go.html to see an example of how to use UpdatePipelineRequest. +type UpdatePipelineRequest struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the pipeline created. + PipelineId *string `mandatory:"true" contributesTo:"path" name:"pipelineId"` + + // The existing pipeline specifications to apply. + UpdatePipelineDetails `contributesTo:"body"` + + // 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 is updated or deleted only if the etag you provide matches the + // resource's current etag value. + IfMatch *string `mandatory:"false" contributesTo:"header" name:"if-match"` + + // The client request ID for tracing. + OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` + + // Whether to override locks (if any exist). + IsLockOverride *bool `mandatory:"false" contributesTo:"query" name:"isLockOverride"` + + // Metadata about the request. This information will not be transmitted to the service, but + // represents information that the SDK will consume to drive retry behavior. + RequestMetadata common.RequestMetadata +} + +func (request UpdatePipelineRequest) String() string { + return common.PointerString(request) +} + +// HTTPRequest implements the OCIRequest interface +func (request UpdatePipelineRequest) HTTPRequest(method, path string, binaryRequestBody *common.OCIReadSeekCloser, extraHeaders map[string]string) (http.Request, error) { + + _, err := request.ValidateEnumValue() + if err != nil { + return http.Request{}, err + } + return common.MakeDefaultHTTPRequestWithTaggedStructAndExtraHeaders(method, path, request, extraHeaders) +} + +// BinaryRequestBody implements the OCIRequest interface +func (request UpdatePipelineRequest) BinaryRequestBody() (*common.OCIReadSeekCloser, bool) { + + return nil, false + +} + +// RetryPolicy implements the OCIRetryableRequest interface. This retrieves the specified retry policy. +func (request UpdatePipelineRequest) RetryPolicy() *common.RetryPolicy { + return request.RequestMetadata.RetryPolicy +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (request UpdatePipelineRequest) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// UpdatePipelineResponse wrapper for the UpdatePipeline operation +type UpdatePipelineResponse struct { + + // The underlying http response + RawResponse *http.Response + + // A unique Oracle-assigned identifier for an asynchronous request. You can use this to query + // status of the asynchronous operation. + OpcWorkRequestId *string `presentIn:"header" name:"opc-work-request-id"` + + // A unique Oracle-assigned identifier for the request. If you need to contact Oracle about a + // particular request, please include the request ID. + OpcRequestId *string `presentIn:"header" name:"opc-request-id"` +} + +func (response UpdatePipelineResponse) String() string { + return common.PointerString(response) +} + +// HTTPResponse implements the OCIResponse interface +func (response UpdatePipelineResponse) HTTPResponse() *http.Response { + return response.RawResponse +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/update_zero_etl_pipeline_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/update_zero_etl_pipeline_details.go new file mode 100644 index 00000000000..2a0f66114d0 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/update_zero_etl_pipeline_details.go @@ -0,0 +1,102 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// UpdateZeroEtlPipelineDetails Information to update for an existing ZeroETL pipeline. +type UpdateZeroEtlPipelineDetails struct { + + // An object's Display Name. + DisplayName *string `mandatory:"false" json:"displayName"` + + // Metadata about this specific object. + Description *string `mandatory:"false" json:"description"` + + // A simple key-value pair that is applied without any predefined name, type, or scope. Exists + // for cross-compatibility only. + // Example: `{"bar-key": "value"}` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + + // Tags defined for this resource. Each key is predefined and scoped to a namespace. + // Example: `{"foo-namespace": {"bar-key": "value"}}` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` + + ProcessOptions *ProcessOptions `mandatory:"false" json:"processOptions"` + + // Mapping for source/target schema/tables for the pipeline data replication. + MappingRules []MappingRule `mandatory:"false" json:"mappingRules"` + + // The Oracle license model that applies to a Deployment. + LicenseModel LicenseModelEnum `mandatory:"false" json:"licenseModel,omitempty"` +} + +// GetDisplayName returns DisplayName +func (m UpdateZeroEtlPipelineDetails) GetDisplayName() *string { + return m.DisplayName +} + +// GetDescription returns Description +func (m UpdateZeroEtlPipelineDetails) GetDescription() *string { + return m.Description +} + +// GetLicenseModel returns LicenseModel +func (m UpdateZeroEtlPipelineDetails) GetLicenseModel() LicenseModelEnum { + return m.LicenseModel +} + +// GetFreeformTags returns FreeformTags +func (m UpdateZeroEtlPipelineDetails) GetFreeformTags() map[string]string { + return m.FreeformTags +} + +// GetDefinedTags returns DefinedTags +func (m UpdateZeroEtlPipelineDetails) GetDefinedTags() map[string]map[string]interface{} { + return m.DefinedTags +} + +func (m UpdateZeroEtlPipelineDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m UpdateZeroEtlPipelineDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if _, ok := GetMappingLicenseModelEnum(string(m.LicenseModel)); !ok && m.LicenseModel != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LicenseModel: %s. Supported values are: %s.", m.LicenseModel, strings.Join(GetLicenseModelEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m UpdateZeroEtlPipelineDetails) MarshalJSON() (buff []byte, e error) { + type MarshalTypeUpdateZeroEtlPipelineDetails UpdateZeroEtlPipelineDetails + s := struct { + DiscriminatorParam string `json:"recipeType"` + MarshalTypeUpdateZeroEtlPipelineDetails + }{ + "ZERO_ETL", + (MarshalTypeUpdateZeroEtlPipelineDetails)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/zero_etl_pipeline.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/zero_etl_pipeline.go new file mode 100644 index 00000000000..d4a4349640b --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/zero_etl_pipeline.go @@ -0,0 +1,220 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// ZeroEtlPipeline The details of a ZeroETL pipeline. +type ZeroEtlPipeline struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the pipeline. This option applies when retrieving a pipeline. + Id *string `mandatory:"true" json:"id"` + + // An object's Display Name. + DisplayName *string `mandatory:"true" json:"displayName"` + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the compartment being referenced. + CompartmentId *string `mandatory:"true" json:"compartmentId"` + + // The Minimum number of OCPUs to be made available for this Deployment. + CpuCoreCount *int `mandatory:"true" json:"cpuCoreCount"` + + // Indicates if auto scaling is enabled for the Deployment's CPU core count. + IsAutoScalingEnabled *bool `mandatory:"true" json:"isAutoScalingEnabled"` + + SourceConnectionDetails *SourcePipelineConnectionDetails `mandatory:"true" json:"sourceConnectionDetails"` + + TargetConnectionDetails *TargetPipelineConnectionDetails `mandatory:"true" json:"targetConnectionDetails"` + + // The time the resource was created. The format is defined by + // RFC3339 (https://tools.ietf.org/html/rfc3339), such as `2016-08-25T21:10:29.600Z`. + TimeCreated *common.SDKTime `mandatory:"true" json:"timeCreated"` + + // The time the resource was last updated. The format is defined by + // RFC3339 (https://tools.ietf.org/html/rfc3339), such as `2016-08-25T21:10:29.600Z`. + TimeUpdated *common.SDKTime `mandatory:"true" json:"timeUpdated"` + + // Metadata about this specific object. + Description *string `mandatory:"false" json:"description"` + + // A simple key-value pair that is applied without any predefined name, type, or scope. Exists + // for cross-compatibility only. + // Example: `{"bar-key": "value"}` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + + // Tags defined for this resource. Each key is predefined and scoped to a namespace. + // Example: `{"foo-namespace": {"bar-key": "value"}}` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` + + // The system tags associated with this resource, if any. The system tags are set by Oracle + // Cloud Infrastructure services. Each key is predefined and scoped to namespaces. For more + // information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{orcl-cloud: {free-tier-retain: true}}` + SystemTags map[string]map[string]interface{} `mandatory:"false" json:"systemTags"` + + // Locks associated with this resource. + Locks []ResourceLock `mandatory:"false" json:"locks"` + + // Describes the object's current state in detail. For example, it can be used to provide + // actionable information for a resource in a Failed state. + LifecycleDetails *string `mandatory:"false" json:"lifecycleDetails"` + + // Mapping for source/target schema/tables for the pipeline data replication. + MappingRules []MappingRule `mandatory:"false" json:"mappingRules"` + + ProcessOptions *ProcessOptions `mandatory:"false" json:"processOptions"` + + // When the resource was last updated. This option applies when retrieving a pipeline. The format is defined by + // RFC3339 (https://tools.ietf.org/html/rfc3339), such as `2024-07-25T21:10:29.600Z`. + TimeLastRecorded *common.SDKTime `mandatory:"false" json:"timeLastRecorded"` + + // The Oracle license model that applies to a Deployment. + LicenseModel LicenseModelEnum `mandatory:"true" json:"licenseModel"` + + // Lifecycle state of the pipeline. + LifecycleState PipelineLifecycleStateEnum `mandatory:"true" json:"lifecycleState"` + + // Possible lifecycle substates when retrieving a pipeline. + LifecycleSubState PipelineLifecycleSubStateEnum `mandatory:"false" json:"lifecycleSubState,omitempty"` +} + +// GetId returns Id +func (m ZeroEtlPipeline) GetId() *string { + return m.Id +} + +// GetDisplayName returns DisplayName +func (m ZeroEtlPipeline) GetDisplayName() *string { + return m.DisplayName +} + +// GetDescription returns Description +func (m ZeroEtlPipeline) GetDescription() *string { + return m.Description +} + +// GetCompartmentId returns CompartmentId +func (m ZeroEtlPipeline) GetCompartmentId() *string { + return m.CompartmentId +} + +// GetLicenseModel returns LicenseModel +func (m ZeroEtlPipeline) GetLicenseModel() LicenseModelEnum { + return m.LicenseModel +} + +// GetCpuCoreCount returns CpuCoreCount +func (m ZeroEtlPipeline) GetCpuCoreCount() *int { + return m.CpuCoreCount +} + +// GetIsAutoScalingEnabled returns IsAutoScalingEnabled +func (m ZeroEtlPipeline) GetIsAutoScalingEnabled() *bool { + return m.IsAutoScalingEnabled +} + +// GetSourceConnectionDetails returns SourceConnectionDetails +func (m ZeroEtlPipeline) GetSourceConnectionDetails() *SourcePipelineConnectionDetails { + return m.SourceConnectionDetails +} + +// GetTargetConnectionDetails returns TargetConnectionDetails +func (m ZeroEtlPipeline) GetTargetConnectionDetails() *TargetPipelineConnectionDetails { + return m.TargetConnectionDetails +} + +// GetFreeformTags returns FreeformTags +func (m ZeroEtlPipeline) GetFreeformTags() map[string]string { + return m.FreeformTags +} + +// GetDefinedTags returns DefinedTags +func (m ZeroEtlPipeline) GetDefinedTags() map[string]map[string]interface{} { + return m.DefinedTags +} + +// GetSystemTags returns SystemTags +func (m ZeroEtlPipeline) GetSystemTags() map[string]map[string]interface{} { + return m.SystemTags +} + +// GetLocks returns Locks +func (m ZeroEtlPipeline) GetLocks() []ResourceLock { + return m.Locks +} + +// GetLifecycleState returns LifecycleState +func (m ZeroEtlPipeline) GetLifecycleState() PipelineLifecycleStateEnum { + return m.LifecycleState +} + +// GetLifecycleSubState returns LifecycleSubState +func (m ZeroEtlPipeline) GetLifecycleSubState() PipelineLifecycleSubStateEnum { + return m.LifecycleSubState +} + +// GetLifecycleDetails returns LifecycleDetails +func (m ZeroEtlPipeline) GetLifecycleDetails() *string { + return m.LifecycleDetails +} + +// GetTimeCreated returns TimeCreated +func (m ZeroEtlPipeline) GetTimeCreated() *common.SDKTime { + return m.TimeCreated +} + +// GetTimeUpdated returns TimeUpdated +func (m ZeroEtlPipeline) GetTimeUpdated() *common.SDKTime { + return m.TimeUpdated +} + +func (m ZeroEtlPipeline) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m ZeroEtlPipeline) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if _, ok := GetMappingLicenseModelEnum(string(m.LicenseModel)); !ok && m.LicenseModel != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LicenseModel: %s. Supported values are: %s.", m.LicenseModel, strings.Join(GetLicenseModelEnumStringValues(), ","))) + } + if _, ok := GetMappingPipelineLifecycleStateEnum(string(m.LifecycleState)); !ok && m.LifecycleState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", m.LifecycleState, strings.Join(GetPipelineLifecycleStateEnumStringValues(), ","))) + } + if _, ok := GetMappingPipelineLifecycleSubStateEnum(string(m.LifecycleSubState)); !ok && m.LifecycleSubState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleSubState: %s. Supported values are: %s.", m.LifecycleSubState, strings.Join(GetPipelineLifecycleSubStateEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m ZeroEtlPipeline) MarshalJSON() (buff []byte, e error) { + type MarshalTypeZeroEtlPipeline ZeroEtlPipeline + s := struct { + DiscriminatorParam string `json:"recipeType"` + MarshalTypeZeroEtlPipeline + }{ + "ZERO_ETL", + (MarshalTypeZeroEtlPipeline)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/zero_etl_pipeline_summary.go b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/zero_etl_pipeline_summary.go new file mode 100644 index 00000000000..ac83c19789a --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/goldengate/zero_etl_pipeline_summary.go @@ -0,0 +1,217 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// GoldenGate API +// +// Use the Oracle Cloud Infrastructure GoldenGate APIs to perform data replication operations. +// + +package goldengate + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// ZeroEtlPipelineSummary Summary of the ZeroETL pipeline. +type ZeroEtlPipelineSummary struct { + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the pipeline. This option applies when retrieving a pipeline. + Id *string `mandatory:"true" json:"id"` + + // An object's Display Name. + DisplayName *string `mandatory:"true" json:"displayName"` + + // The OCID (https://docs.cloud.oracle.com/Content/General/Concepts/identifiers.htm) of the compartment being referenced. + CompartmentId *string `mandatory:"true" json:"compartmentId"` + + SourceConnectionDetails *SourcePipelineConnectionDetails `mandatory:"true" json:"sourceConnectionDetails"` + + TargetConnectionDetails *TargetPipelineConnectionDetails `mandatory:"true" json:"targetConnectionDetails"` + + // The Minimum number of OCPUs to be made available for this Deployment. + CpuCoreCount *int `mandatory:"true" json:"cpuCoreCount"` + + // Indicates if auto scaling is enabled for the Deployment's CPU core count. + IsAutoScalingEnabled *bool `mandatory:"true" json:"isAutoScalingEnabled"` + + // The time the resource was created. The format is defined by + // RFC3339 (https://tools.ietf.org/html/rfc3339), such as `2016-08-25T21:10:29.600Z`. + TimeCreated *common.SDKTime `mandatory:"true" json:"timeCreated"` + + // The time the resource was last updated. The format is defined by + // RFC3339 (https://tools.ietf.org/html/rfc3339), such as `2016-08-25T21:10:29.600Z`. + TimeUpdated *common.SDKTime `mandatory:"true" json:"timeUpdated"` + + ProcessOptions *ProcessOptions `mandatory:"true" json:"processOptions"` + + // Metadata about this specific object. + Description *string `mandatory:"false" json:"description"` + + // A simple key-value pair that is applied without any predefined name, type, or scope. Exists + // for cross-compatibility only. + // Example: `{"bar-key": "value"}` + FreeformTags map[string]string `mandatory:"false" json:"freeformTags"` + + // Tags defined for this resource. Each key is predefined and scoped to a namespace. + // Example: `{"foo-namespace": {"bar-key": "value"}}` + DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"` + + // The system tags associated with this resource, if any. The system tags are set by Oracle + // Cloud Infrastructure services. Each key is predefined and scoped to namespaces. For more + // information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm). + // Example: `{orcl-cloud: {free-tier-retain: true}}` + SystemTags map[string]map[string]interface{} `mandatory:"false" json:"systemTags"` + + // Locks associated with this resource. + Locks []ResourceLock `mandatory:"false" json:"locks"` + + // Describes the object's current state in detail. For example, it can be used to provide + // actionable information for a resource in a Failed state. + LifecycleDetails *string `mandatory:"false" json:"lifecycleDetails"` + + // When the resource was last updated. This option applies when retrieving a pipeline. The format is defined by + // RFC3339 (https://tools.ietf.org/html/rfc3339), such as `2024-07-25T21:10:29.600Z`. + TimeLastRecorded *common.SDKTime `mandatory:"false" json:"timeLastRecorded"` + + // Lifecycle state for the pipeline summary. + LifecycleState PipelineLifecycleStateEnum `mandatory:"true" json:"lifecycleState"` + + // The Oracle license model that applies to a Deployment. + LicenseModel LicenseModelEnum `mandatory:"true" json:"licenseModel"` + + // Possible lifecycle substates when retrieving a pipeline. + LifecycleSubState PipelineLifecycleSubStateEnum `mandatory:"false" json:"lifecycleSubState,omitempty"` +} + +// GetId returns Id +func (m ZeroEtlPipelineSummary) GetId() *string { + return m.Id +} + +// GetDisplayName returns DisplayName +func (m ZeroEtlPipelineSummary) GetDisplayName() *string { + return m.DisplayName +} + +// GetDescription returns Description +func (m ZeroEtlPipelineSummary) GetDescription() *string { + return m.Description +} + +// GetCompartmentId returns CompartmentId +func (m ZeroEtlPipelineSummary) GetCompartmentId() *string { + return m.CompartmentId +} + +// GetSourceConnectionDetails returns SourceConnectionDetails +func (m ZeroEtlPipelineSummary) GetSourceConnectionDetails() *SourcePipelineConnectionDetails { + return m.SourceConnectionDetails +} + +// GetTargetConnectionDetails returns TargetConnectionDetails +func (m ZeroEtlPipelineSummary) GetTargetConnectionDetails() *TargetPipelineConnectionDetails { + return m.TargetConnectionDetails +} + +// GetFreeformTags returns FreeformTags +func (m ZeroEtlPipelineSummary) GetFreeformTags() map[string]string { + return m.FreeformTags +} + +// GetLicenseModel returns LicenseModel +func (m ZeroEtlPipelineSummary) GetLicenseModel() LicenseModelEnum { + return m.LicenseModel +} + +// GetCpuCoreCount returns CpuCoreCount +func (m ZeroEtlPipelineSummary) GetCpuCoreCount() *int { + return m.CpuCoreCount +} + +// GetIsAutoScalingEnabled returns IsAutoScalingEnabled +func (m ZeroEtlPipelineSummary) GetIsAutoScalingEnabled() *bool { + return m.IsAutoScalingEnabled +} + +// GetDefinedTags returns DefinedTags +func (m ZeroEtlPipelineSummary) GetDefinedTags() map[string]map[string]interface{} { + return m.DefinedTags +} + +// GetSystemTags returns SystemTags +func (m ZeroEtlPipelineSummary) GetSystemTags() map[string]map[string]interface{} { + return m.SystemTags +} + +// GetLocks returns Locks +func (m ZeroEtlPipelineSummary) GetLocks() []ResourceLock { + return m.Locks +} + +// GetLifecycleState returns LifecycleState +func (m ZeroEtlPipelineSummary) GetLifecycleState() PipelineLifecycleStateEnum { + return m.LifecycleState +} + +// GetLifecycleSubState returns LifecycleSubState +func (m ZeroEtlPipelineSummary) GetLifecycleSubState() PipelineLifecycleSubStateEnum { + return m.LifecycleSubState +} + +// GetLifecycleDetails returns LifecycleDetails +func (m ZeroEtlPipelineSummary) GetLifecycleDetails() *string { + return m.LifecycleDetails +} + +// GetTimeCreated returns TimeCreated +func (m ZeroEtlPipelineSummary) GetTimeCreated() *common.SDKTime { + return m.TimeCreated +} + +// GetTimeUpdated returns TimeUpdated +func (m ZeroEtlPipelineSummary) GetTimeUpdated() *common.SDKTime { + return m.TimeUpdated +} + +func (m ZeroEtlPipelineSummary) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m ZeroEtlPipelineSummary) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if _, ok := GetMappingPipelineLifecycleStateEnum(string(m.LifecycleState)); !ok && m.LifecycleState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", m.LifecycleState, strings.Join(GetPipelineLifecycleStateEnumStringValues(), ","))) + } + if _, ok := GetMappingLicenseModelEnum(string(m.LicenseModel)); !ok && m.LicenseModel != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LicenseModel: %s. Supported values are: %s.", m.LicenseModel, strings.Join(GetLicenseModelEnumStringValues(), ","))) + } + if _, ok := GetMappingPipelineLifecycleSubStateEnum(string(m.LifecycleSubState)); !ok && m.LifecycleSubState != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleSubState: %s. Supported values are: %s.", m.LifecycleSubState, strings.Join(GetPipelineLifecycleSubStateEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m ZeroEtlPipelineSummary) MarshalJSON() (buff []byte, e error) { + type MarshalTypeZeroEtlPipelineSummary ZeroEtlPipelineSummary + s := struct { + DiscriminatorParam string `json:"recipeType"` + MarshalTypeZeroEtlPipelineSummary + }{ + "ZERO_ETL", + (MarshalTypeZeroEtlPipelineSummary)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_protocol_types.go b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_protocol_types.go new file mode 100644 index 00000000000..a010bea8a3a --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_protocol_types.go @@ -0,0 +1,56 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Stack Monitoring API +// +// Stack Monitoring API. +// + +package stackmonitoring + +import ( + "strings" +) + +// HttpProtocolTypesEnum Enum with underlying type: string +type HttpProtocolTypesEnum string + +// Set of constants representing the allowable values for HttpProtocolTypesEnum +const ( + HttpProtocolTypesHttp HttpProtocolTypesEnum = "HTTP" + HttpProtocolTypesHttps HttpProtocolTypesEnum = "HTTPS" +) + +var mappingHttpProtocolTypesEnum = map[string]HttpProtocolTypesEnum{ + "HTTP": HttpProtocolTypesHttp, + "HTTPS": HttpProtocolTypesHttps, +} + +var mappingHttpProtocolTypesEnumLowerCase = map[string]HttpProtocolTypesEnum{ + "http": HttpProtocolTypesHttp, + "https": HttpProtocolTypesHttps, +} + +// GetHttpProtocolTypesEnumValues Enumerates the set of values for HttpProtocolTypesEnum +func GetHttpProtocolTypesEnumValues() []HttpProtocolTypesEnum { + values := make([]HttpProtocolTypesEnum, 0) + for _, v := range mappingHttpProtocolTypesEnum { + values = append(values, v) + } + return values +} + +// GetHttpProtocolTypesEnumStringValues Enumerates the set of values in String for HttpProtocolTypesEnum +func GetHttpProtocolTypesEnumStringValues() []string { + return []string{ + "HTTP", + "HTTPS", + } +} + +// GetMappingHttpProtocolTypesEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingHttpProtocolTypesEnum(val string) (HttpProtocolTypesEnum, bool) { + enum, ok := mappingHttpProtocolTypesEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_query_properties.go b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_query_properties.go new file mode 100644 index 00000000000..6a1bf3daf9a --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_query_properties.go @@ -0,0 +1,68 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Stack Monitoring API +// +// Stack Monitoring API. +// + +package stackmonitoring + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// HttpQueryProperties Query properties applicable to HTTP type of collection method +type HttpQueryProperties struct { + + // Http(s) end point URL + Url *string `mandatory:"true" json:"url"` + + ScriptDetails *HttpScriptFileDetails `mandatory:"true" json:"scriptDetails"` + + // Type of content response given by the http(s) URL + ResponseContentType HttpResponseContentTypesEnum `mandatory:"true" json:"responseContentType"` + + // Supported protocol of resources to be associated with this metric extension. This is optional and defaults to HTTPS, which uses secure connection to the URL + ProtocolType HttpProtocolTypesEnum `mandatory:"false" json:"protocolType,omitempty"` +} + +func (m HttpQueryProperties) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m HttpQueryProperties) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if _, ok := GetMappingHttpResponseContentTypesEnum(string(m.ResponseContentType)); !ok && m.ResponseContentType != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for ResponseContentType: %s. Supported values are: %s.", m.ResponseContentType, strings.Join(GetHttpResponseContentTypesEnumStringValues(), ","))) + } + if _, ok := GetMappingHttpProtocolTypesEnum(string(m.ProtocolType)); !ok && m.ProtocolType != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for ProtocolType: %s. Supported values are: %s.", m.ProtocolType, strings.Join(GetHttpProtocolTypesEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m HttpQueryProperties) MarshalJSON() (buff []byte, e error) { + type MarshalTypeHttpQueryProperties HttpQueryProperties + s := struct { + DiscriminatorParam string `json:"collectionMethod"` + MarshalTypeHttpQueryProperties + }{ + "HTTP", + (MarshalTypeHttpQueryProperties)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_response_content_types.go b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_response_content_types.go new file mode 100644 index 00000000000..5dc0d4fe988 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_response_content_types.go @@ -0,0 +1,64 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Stack Monitoring API +// +// Stack Monitoring API. +// + +package stackmonitoring + +import ( + "strings" +) + +// HttpResponseContentTypesEnum Enum with underlying type: string +type HttpResponseContentTypesEnum string + +// Set of constants representing the allowable values for HttpResponseContentTypesEnum +const ( + HttpResponseContentTypesTextPlain HttpResponseContentTypesEnum = "TEXT_PLAIN" + HttpResponseContentTypesTextHtml HttpResponseContentTypesEnum = "TEXT_HTML" + HttpResponseContentTypesApplicationJson HttpResponseContentTypesEnum = "APPLICATION_JSON" + HttpResponseContentTypesApplicationXml HttpResponseContentTypesEnum = "APPLICATION_XML" +) + +var mappingHttpResponseContentTypesEnum = map[string]HttpResponseContentTypesEnum{ + "TEXT_PLAIN": HttpResponseContentTypesTextPlain, + "TEXT_HTML": HttpResponseContentTypesTextHtml, + "APPLICATION_JSON": HttpResponseContentTypesApplicationJson, + "APPLICATION_XML": HttpResponseContentTypesApplicationXml, +} + +var mappingHttpResponseContentTypesEnumLowerCase = map[string]HttpResponseContentTypesEnum{ + "text_plain": HttpResponseContentTypesTextPlain, + "text_html": HttpResponseContentTypesTextHtml, + "application_json": HttpResponseContentTypesApplicationJson, + "application_xml": HttpResponseContentTypesApplicationXml, +} + +// GetHttpResponseContentTypesEnumValues Enumerates the set of values for HttpResponseContentTypesEnum +func GetHttpResponseContentTypesEnumValues() []HttpResponseContentTypesEnum { + values := make([]HttpResponseContentTypesEnum, 0) + for _, v := range mappingHttpResponseContentTypesEnum { + values = append(values, v) + } + return values +} + +// GetHttpResponseContentTypesEnumStringValues Enumerates the set of values in String for HttpResponseContentTypesEnum +func GetHttpResponseContentTypesEnumStringValues() []string { + return []string{ + "TEXT_PLAIN", + "TEXT_HTML", + "APPLICATION_JSON", + "APPLICATION_XML", + } +} + +// GetMappingHttpResponseContentTypesEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingHttpResponseContentTypesEnum(val string) (HttpResponseContentTypesEnum, bool) { + enum, ok := mappingHttpResponseContentTypesEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_script_file_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_script_file_details.go new file mode 100644 index 00000000000..ff82d6940bd --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_script_file_details.go @@ -0,0 +1,42 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Stack Monitoring API +// +// Stack Monitoring API. +// + +package stackmonitoring + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// HttpScriptFileDetails JavaScript file details which is used to convert http(s) response into metric data +type HttpScriptFileDetails struct { + + // Name of the script file + Name *string `mandatory:"true" json:"name"` + + // Content of the JavaScript file as base64 encoded string + Content *string `mandatory:"true" json:"content"` +} + +func (m HttpScriptFileDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m HttpScriptFileDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_update_query_properties.go b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_update_query_properties.go new file mode 100644 index 00000000000..35bd25ae9fa --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/http_update_query_properties.go @@ -0,0 +1,68 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Stack Monitoring API +// +// Stack Monitoring API. +// + +package stackmonitoring + +import ( + "encoding/json" + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// HttpUpdateQueryProperties Query properties applicable to HTTP type of collection method +type HttpUpdateQueryProperties struct { + + // Http(s) end point URL + Url *string `mandatory:"false" json:"url"` + + ScriptDetails *UpdateHttpScriptFileDetails `mandatory:"false" json:"scriptDetails"` + + // Type of content response given by the http(s) URL + ResponseContentType HttpResponseContentTypesEnum `mandatory:"false" json:"responseContentType,omitempty"` + + // Supported protocol of resources to be associated with this metric extension. This is optional and defaults to HTTPS, which uses secure connection to the URL + ProtocolType HttpProtocolTypesEnum `mandatory:"false" json:"protocolType,omitempty"` +} + +func (m HttpUpdateQueryProperties) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m HttpUpdateQueryProperties) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if _, ok := GetMappingHttpResponseContentTypesEnum(string(m.ResponseContentType)); !ok && m.ResponseContentType != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for ResponseContentType: %s. Supported values are: %s.", m.ResponseContentType, strings.Join(GetHttpResponseContentTypesEnumStringValues(), ","))) + } + if _, ok := GetMappingHttpProtocolTypesEnum(string(m.ProtocolType)); !ok && m.ProtocolType != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for ProtocolType: %s. Supported values are: %s.", m.ProtocolType, strings.Join(GetHttpProtocolTypesEnumStringValues(), ","))) + } + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// MarshalJSON marshals to json representation +func (m HttpUpdateQueryProperties) MarshalJSON() (buff []byte, e error) { + type MarshalTypeHttpUpdateQueryProperties HttpUpdateQueryProperties + s := struct { + DiscriminatorParam string `json:"collectionMethod"` + MarshalTypeHttpUpdateQueryProperties + }{ + "HTTP", + (MarshalTypeHttpUpdateQueryProperties)(m), + } + + return json.Marshal(&s) +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/list_metric_extensions_request_response.go b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/list_metric_extensions_request_response.go index 68c0b9bbb12..92672b71736 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/list_metric_extensions_request_response.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/list_metric_extensions_request_response.go @@ -18,9 +18,6 @@ import ( // Click https://docs.cloud.oracle.com/en-us/iaas/tools/go-sdk-examples/latest/stackmonitoring/ListMetricExtensions.go.html to see an example of how to use ListMetricExtensionsRequest. type ListMetricExtensionsRequest struct { - // The ID of the compartment in which data is listed. - CompartmentId *string `mandatory:"true" contributesTo:"query" name:"compartmentId"` - // For list pagination. The maximum number of results per page, or items to return in a // paginated "List" call. For important details about how pagination works, see // List Pagination (https://docs.cloud.oracle.com/iaas/Content/API/Concepts/usingapi.htm#nine). @@ -38,6 +35,9 @@ type ListMetricExtensionsRequest struct { // The sort order to use, either ascending (`ASC`) or descending (`DESC`). SortOrder ListMetricExtensionsSortOrderEnum `mandatory:"false" contributesTo:"query" name:"sortOrder" omitEmpty:"true"` + // The ID of the compartment in which data is listed. + CompartmentId *string `mandatory:"false" contributesTo:"query" name:"compartmentId"` + // A filter to return resources based on resource type. ResourceType *string `mandatory:"false" contributesTo:"query" name:"resourceType"` @@ -53,6 +53,9 @@ type ListMetricExtensionsRequest struct { // A filter to return metric extensions based on input resource Id on which metric extension is enabled EnabledOnResourceId *string `mandatory:"false" contributesTo:"query" name:"enabledOnResourceId"` + // Identifier for the metric extension + MetricExtensionId *string `mandatory:"false" contributesTo:"query" name:"metricExtensionId"` + // Unique Oracle-assigned identifier for the request. If you need to contact Oracle about a // particular request, please provide the request ID. OpcRequestId *string `mandatory:"false" contributesTo:"header" name:"opc-request-id"` @@ -144,18 +147,21 @@ type ListMetricExtensionsSortByEnum string // Set of constants representing the allowable values for ListMetricExtensionsSortByEnum const ( - ListMetricExtensionsSortByName ListMetricExtensionsSortByEnum = "NAME" - ListMetricExtensionsSortByTimeCreated ListMetricExtensionsSortByEnum = "TIME_CREATED" + ListMetricExtensionsSortByName ListMetricExtensionsSortByEnum = "NAME" + ListMetricExtensionsSortByTimeCreated ListMetricExtensionsSortByEnum = "TIME_CREATED" + ListMetricExtensionsSortByEnabledOnResourceCount ListMetricExtensionsSortByEnum = "ENABLED_ON_RESOURCE_COUNT" ) var mappingListMetricExtensionsSortByEnum = map[string]ListMetricExtensionsSortByEnum{ - "NAME": ListMetricExtensionsSortByName, - "TIME_CREATED": ListMetricExtensionsSortByTimeCreated, + "NAME": ListMetricExtensionsSortByName, + "TIME_CREATED": ListMetricExtensionsSortByTimeCreated, + "ENABLED_ON_RESOURCE_COUNT": ListMetricExtensionsSortByEnabledOnResourceCount, } var mappingListMetricExtensionsSortByEnumLowerCase = map[string]ListMetricExtensionsSortByEnum{ - "name": ListMetricExtensionsSortByName, - "time_created": ListMetricExtensionsSortByTimeCreated, + "name": ListMetricExtensionsSortByName, + "time_created": ListMetricExtensionsSortByTimeCreated, + "enabled_on_resource_count": ListMetricExtensionsSortByEnabledOnResourceCount, } // GetListMetricExtensionsSortByEnumValues Enumerates the set of values for ListMetricExtensionsSortByEnum @@ -172,6 +178,7 @@ func GetListMetricExtensionsSortByEnumStringValues() []string { return []string{ "NAME", "TIME_CREATED", + "ENABLED_ON_RESOURCE_COUNT", } } diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/metric_extension_collection_methods.go b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/metric_extension_collection_methods.go index 319ac9c9b28..f80b101db82 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/metric_extension_collection_methods.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/metric_extension_collection_methods.go @@ -21,18 +21,21 @@ const ( MetricExtensionCollectionMethodsOsCommand MetricExtensionCollectionMethodsEnum = "OS_COMMAND" MetricExtensionCollectionMethodsSql MetricExtensionCollectionMethodsEnum = "SQL" MetricExtensionCollectionMethodsJmx MetricExtensionCollectionMethodsEnum = "JMX" + MetricExtensionCollectionMethodsHttp MetricExtensionCollectionMethodsEnum = "HTTP" ) var mappingMetricExtensionCollectionMethodsEnum = map[string]MetricExtensionCollectionMethodsEnum{ "OS_COMMAND": MetricExtensionCollectionMethodsOsCommand, "SQL": MetricExtensionCollectionMethodsSql, "JMX": MetricExtensionCollectionMethodsJmx, + "HTTP": MetricExtensionCollectionMethodsHttp, } var mappingMetricExtensionCollectionMethodsEnumLowerCase = map[string]MetricExtensionCollectionMethodsEnum{ "os_command": MetricExtensionCollectionMethodsOsCommand, "sql": MetricExtensionCollectionMethodsSql, "jmx": MetricExtensionCollectionMethodsJmx, + "http": MetricExtensionCollectionMethodsHttp, } // GetMetricExtensionCollectionMethodsEnumValues Enumerates the set of values for MetricExtensionCollectionMethodsEnum @@ -50,6 +53,7 @@ func GetMetricExtensionCollectionMethodsEnumStringValues() []string { "OS_COMMAND", "SQL", "JMX", + "HTTP", } } diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/metric_extension_query_properties.go b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/metric_extension_query_properties.go index 97afa6eaf01..a24eb98bacb 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/metric_extension_query_properties.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/metric_extension_query_properties.go @@ -62,6 +62,10 @@ func (m *metricextensionqueryproperties) UnmarshalPolymorphicJSON(data []byte) ( mm := JmxQueryProperties{} err = json.Unmarshal(data, &mm) return mm, err + case "HTTP": + mm := HttpQueryProperties{} + err = json.Unmarshal(data, &mm) + return mm, err default: common.Logf("Recieved unsupported enum value for MetricExtensionQueryProperties: %s.", m.CollectionMethod) return *m, nil diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/metric_extension_sort_by.go b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/metric_extension_sort_by.go index 7eb15bd8354..fc8003bcaa7 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/metric_extension_sort_by.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/metric_extension_sort_by.go @@ -18,18 +18,21 @@ type MetricExtensionSortByEnum string // Set of constants representing the allowable values for MetricExtensionSortByEnum const ( - MetricExtensionSortByName MetricExtensionSortByEnum = "NAME" - MetricExtensionSortByTimeCreated MetricExtensionSortByEnum = "TIME_CREATED" + MetricExtensionSortByName MetricExtensionSortByEnum = "NAME" + MetricExtensionSortByTimeCreated MetricExtensionSortByEnum = "TIME_CREATED" + MetricExtensionSortByEnabledOnResourceCount MetricExtensionSortByEnum = "ENABLED_ON_RESOURCE_COUNT" ) var mappingMetricExtensionSortByEnum = map[string]MetricExtensionSortByEnum{ - "NAME": MetricExtensionSortByName, - "TIME_CREATED": MetricExtensionSortByTimeCreated, + "NAME": MetricExtensionSortByName, + "TIME_CREATED": MetricExtensionSortByTimeCreated, + "ENABLED_ON_RESOURCE_COUNT": MetricExtensionSortByEnabledOnResourceCount, } var mappingMetricExtensionSortByEnumLowerCase = map[string]MetricExtensionSortByEnum{ - "name": MetricExtensionSortByName, - "time_created": MetricExtensionSortByTimeCreated, + "name": MetricExtensionSortByName, + "time_created": MetricExtensionSortByTimeCreated, + "enabled_on_resource_count": MetricExtensionSortByEnabledOnResourceCount, } // GetMetricExtensionSortByEnumValues Enumerates the set of values for MetricExtensionSortByEnum @@ -46,6 +49,7 @@ func GetMetricExtensionSortByEnumStringValues() []string { return []string{ "NAME", "TIME_CREATED", + "ENABLED_ON_RESOURCE_COUNT", } } diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/metric_extension_update_query_properties.go b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/metric_extension_update_query_properties.go index 7577f1d5b33..84b71ac4b13 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/metric_extension_update_query_properties.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/metric_extension_update_query_properties.go @@ -62,6 +62,10 @@ func (m *metricextensionupdatequeryproperties) UnmarshalPolymorphicJSON(data []b mm := OsCommandUpdateQueryProperties{} err = json.Unmarshal(data, &mm) return mm, err + case "HTTP": + mm := HttpUpdateQueryProperties{} + err = json.Unmarshal(data, &mm) + return mm, err default: common.Logf("Recieved unsupported enum value for MetricExtensionUpdateQueryProperties: %s.", m.CollectionMethod) return *m, nil diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/script_file_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/script_file_details.go index 855fb2b186f..d31e0630c85 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/script_file_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/script_file_details.go @@ -15,7 +15,7 @@ import ( "strings" ) -// ScriptFileDetails Script details applicable to any OS Command based Metric Extension which needs to run a script to collect data +// ScriptFileDetails Script details applicable to any OS Command based Metric Extension which needs to run a script to collect data. For removing it during update, set its "content" property to an empty string. In that case, "name" property value is ignored. type ScriptFileDetails struct { // Name of the script file diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/sql_out_param_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/sql_out_param_details.go index 3b75c1c9fae..3330d39200a 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/sql_out_param_details.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/sql_out_param_details.go @@ -18,11 +18,14 @@ import ( // SqlOutParamDetails Position and SQL Type of PL/SQL OUT parameter type SqlOutParamDetails struct { - // Position of PL/SQL procedure OUT parameter + // Position of PL/SQL procedure OUT parameter. The value of this property is ignored during update, if "outParamType" is set to NO_OUT_PARAM value. OutParamPosition *int `mandatory:"true" json:"outParamPosition"` - // SQL Type of PL/SQL procedure OUT parameter + // SQL Type of PL/SQL procedure OUT parameter. During the update, to completely remove the out parameter, use the value NO_OUT_PARAM. In that case, the value of "outParamPosition" will be ignored. OutParamType SqlOutParamTypesEnum `mandatory:"true" json:"outParamType"` + + // Name of the Out Parameter + OutParamName *string `mandatory:"false" json:"outParamName"` } func (m SqlOutParamDetails) String() string { diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/sql_out_param_types.go b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/sql_out_param_types.go index cf5f19d7547..679f38ee65a 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/sql_out_param_types.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/sql_out_param_types.go @@ -18,18 +18,21 @@ type SqlOutParamTypesEnum string // Set of constants representing the allowable values for SqlOutParamTypesEnum const ( - SqlOutParamTypesSqlCursor SqlOutParamTypesEnum = "SQL_CURSOR" - SqlOutParamTypesArray SqlOutParamTypesEnum = "ARRAY" + SqlOutParamTypesSqlCursor SqlOutParamTypesEnum = "SQL_CURSOR" + SqlOutParamTypesArray SqlOutParamTypesEnum = "ARRAY" + SqlOutParamTypesNoOutParam SqlOutParamTypesEnum = "NO_OUT_PARAM" ) var mappingSqlOutParamTypesEnum = map[string]SqlOutParamTypesEnum{ - "SQL_CURSOR": SqlOutParamTypesSqlCursor, - "ARRAY": SqlOutParamTypesArray, + "SQL_CURSOR": SqlOutParamTypesSqlCursor, + "ARRAY": SqlOutParamTypesArray, + "NO_OUT_PARAM": SqlOutParamTypesNoOutParam, } var mappingSqlOutParamTypesEnumLowerCase = map[string]SqlOutParamTypesEnum{ - "sql_cursor": SqlOutParamTypesSqlCursor, - "array": SqlOutParamTypesArray, + "sql_cursor": SqlOutParamTypesSqlCursor, + "array": SqlOutParamTypesArray, + "no_out_param": SqlOutParamTypesNoOutParam, } // GetSqlOutParamTypesEnumValues Enumerates the set of values for SqlOutParamTypesEnum @@ -46,6 +49,7 @@ func GetSqlOutParamTypesEnumStringValues() []string { return []string{ "SQL_CURSOR", "ARRAY", + "NO_OUT_PARAM", } } diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/update_http_script_file_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/update_http_script_file_details.go new file mode 100644 index 00000000000..09a37de5196 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/stackmonitoring/update_http_script_file_details.go @@ -0,0 +1,42 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Stack Monitoring API +// +// Stack Monitoring API. +// + +package stackmonitoring + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// UpdateHttpScriptFileDetails JavaScript file details which is used to convert http(s) response into metric data +type UpdateHttpScriptFileDetails struct { + + // Name of the script file + Name *string `mandatory:"false" json:"name"` + + // Content of the JavaScript file as base64 encoded string + Content *string `mandatory:"false" json:"content"` +} + +func (m UpdateHttpScriptFileDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m UpdateHttpScriptFileDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} From 7db3e877b486a193ffdcc320c5eab7d5a4134c4e Mon Sep 17 00:00:00 2001 From: Viral Sinha Date: Tue, 17 Dec 2024 15:31:32 -0800 Subject: [PATCH 13/17] Finalize changelog and release for version v6.21.0 --- CHANGELOG.md | 15 +++++++++++++++ internal/globalvar/version.go | 4 ++-- website/oci.erb | 24 ++++++++++++++++++++++++ 3 files changed, 41 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index a521d467e8b..e0d5501cd33 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,18 @@ +## 6.21.0 (Unreleased) + +### Added +- Support for ADB-S: Backup Retention Lock +- Support for StackMonitoring: Metric Extensions : Advanced Support and Integration +- Support for Extend OBP cloud service to include new SKUs for Digital Assets editions +- Support for Data Science: Support Private Endpoint Access for Model Deployment +- Support for Add ZeroETL as a resource in GoldenGate Cloud Service +- Support Llama 3.2 unit shape in Generative AI service +- Support for BDS 3.0.29 Release - Feature Enhancements +- Support for BDS - Kerb to IAM Automation +### Bug Fix + +- Fix terraform documentation for oci_database_exadb_vm_cluster resource + ## 6.20.0 (December 11, 2024) ### Added diff --git a/internal/globalvar/version.go b/internal/globalvar/version.go index b875de40be8..6ac1cc901a9 100644 --- a/internal/globalvar/version.go +++ b/internal/globalvar/version.go @@ -7,9 +7,9 @@ import ( "log" ) -const Version = "6.20.0" +const Version = "6.21.0" -const ReleaseDate = "2024-12-11" +const ReleaseDate = "2024-12-22" func PrintVersion() { log.Printf("[INFO] terraform-provider-oci %s\n", Version) diff --git a/website/oci.erb b/website/oci.erb index 4dbfee8c1fb..613684a7f97 100644 --- a/website/oci.erb +++ b/website/oci.erb @@ -769,6 +769,9 @@
  • oci_bds_auto_scaling_configuration
  • +
  • + oci_bds_bds_cluster_versions +
  • oci_bds_bds_instance
  • @@ -5401,6 +5404,24 @@
  • oci_golden_gate_messages
  • +
  • + oci_golden_gate_pipeline +
  • +
  • + oci_golden_gate_pipeline_running_processes +
  • +
  • + oci_golden_gate_pipeline_schema_tables +
  • +
  • + oci_golden_gate_pipeline_schemas +
  • +
  • + oci_golden_gate_pipelines +
  • +
  • + oci_golden_gate_recipes +
  • oci_golden_gate_trail_file
  • @@ -5436,6 +5457,9 @@
  • oci_golden_gate_deployment_certificate
  • +
  • + oci_golden_gate_pipeline +
  • From 2b43ce2dea6bbadd2726dfd5db6d606fc02ce004 Mon Sep 17 00:00:00 2001 From: Rakshith Siddanahalli Date: Wed, 18 Dec 2024 13:58:44 -0800 Subject: [PATCH 14/17] Exempted - Updating code coverage to match with actual --- coverage/coverage_test.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/coverage/coverage_test.go b/coverage/coverage_test.go index bd55e0e130c..2ae47238481 100644 --- a/coverage/coverage_test.go +++ b/coverage/coverage_test.go @@ -14,7 +14,7 @@ import ( var totalRgx = regexp.MustCompile(`total:\s+\(statements\)\s+([^"]*)%`) -const CodeCoverageThreshold = 57 +const CodeCoverageThreshold = 55.9 func TestCoverage(t *testing.T) { if os.Getenv("CHECK_COVERAGE") != "true" { From 63703153fcb6a383689773198d60905650a5799b Mon Sep 17 00:00:00 2001 From: DevOps Pipeline Date: Wed, 18 Dec 2024 20:24:55 +0000 Subject: [PATCH 15/17] Vendored - oci-go-sdk for release version v65 --- go.mod | 4 +- go.sum | 2 + .../oracle/oci-go-sdk/v65/common/version.go | 2 +- .../v65/visualbuilder/attachment_details.go | 100 ++++++++++++++++++ .../v65/visualbuilder/idcs_info_details.go | 53 ++++++++++ vendor/modules.txt | 2 +- 6 files changed, 159 insertions(+), 4 deletions(-) create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/visualbuilder/attachment_details.go create mode 100644 vendor/github.com/oracle/oci-go-sdk/v65/visualbuilder/idcs_info_details.go diff --git a/go.mod b/go.mod index 44426c1d0a1..fe97d16728b 100644 --- a/go.mod +++ b/go.mod @@ -52,7 +52,7 @@ require ( github.com/mitchellh/mapstructure v1.5.0 // indirect github.com/mitchellh/reflectwalk v1.0.2 // indirect github.com/oklog/run v1.0.0 // indirect - github.com/oracle/oci-go-sdk/v65 v65.76.0 + github.com/oracle/oci-go-sdk/v65 v65.81.1 github.com/pmezard/go-difflib v1.0.0 // indirect github.com/sony/gobreaker v0.5.0 // indirect github.com/vmihailenco/msgpack v4.0.4+incompatible // indirect @@ -68,6 +68,6 @@ require ( ) // Uncomment this line to get OCI Go SDK from local source instead of github -replace github.com/oracle/oci-go-sdk/v65 v65.76.0 => ./vendor/github.com/oracle/oci-go-sdk +//replace github.com/oracle/oci-go-sdk => ../../oracle/oci-go-sdk go 1.21 diff --git a/go.sum b/go.sum index 648510a4c77..d01f085556a 100644 --- a/go.sum +++ b/go.sum @@ -140,6 +140,8 @@ github.com/oklog/run v1.0.0/go.mod h1:dlhp/R75TPv97u0XWUtDeV/lRKWPKSdTuV0TZvrmrQ github.com/onsi/ginkgo v1.6.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= github.com/onsi/ginkgo v1.7.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= github.com/onsi/gomega v1.4.3/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY= +github.com/oracle/oci-go-sdk/v65 v65.81.1 h1:JYc47bk8n/MUchA2KHu1ggsCQzlJZQLJ+tTKfOho00E= +github.com/oracle/oci-go-sdk/v65 v65.81.1/go.mod h1:IBEV9l1qBzUpo7zgGaRUhbB05BVfcDGYRFBCPlTcPp0= github.com/pjbgf/sha1cd v0.3.0 h1:4D5XXmUUBUl/xQ6IjCkEAbqXskkq/4O7LmGn0AqMDs4= github.com/pjbgf/sha1cd v0.3.0/go.mod h1:nZ1rrWOcGJ5uZgEEVL1VUM9iRQiZvWdbZjkKyFzPPsI= github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/common/version.go b/vendor/github.com/oracle/oci-go-sdk/v65/common/version.go index 4ae2ce0c527..fc13b59bc44 100644 --- a/vendor/github.com/oracle/oci-go-sdk/v65/common/version.go +++ b/vendor/github.com/oracle/oci-go-sdk/v65/common/version.go @@ -13,7 +13,7 @@ import ( const ( major = "65" minor = "81" - patch = "0" + patch = "1" tag = "" ) diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/visualbuilder/attachment_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/visualbuilder/attachment_details.go new file mode 100644 index 00000000000..c0c4596ef0d --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/visualbuilder/attachment_details.go @@ -0,0 +1,100 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Visual Builder API +// +// Oracle Visual Builder enables developers to quickly build web and mobile applications. With a visual development environment that makes it easy to connect to Oracle data and third-party REST services, developers can build modern, consumer-grade applications in a fraction of the time it would take in other tools. +// The Visual Builder Instance Management API allows users to create and manage a Visual Builder instance. +// + +package visualbuilder + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// AttachmentDetails Description of an attachments for this instance +type AttachmentDetails struct { + + // The role of the target attachment. + // * `PARENT` - The target instance is the parent of this attachment. + // * `CHILD` - The target instance is the child of this attachment. + TargetRole AttachmentDetailsTargetRoleEnum `mandatory:"true" json:"targetRole"` + + // * If role == `PARENT`, the attached instance was created by this service instance + // * If role == `CHILD`, this instance was created from attached instance on behalf of a user + IsImplicit *bool `mandatory:"true" json:"isImplicit"` + + // The OCID of the target instance (which could be any other OCI PaaS/SaaS resource), to which this instance is attached. + TargetId *string `mandatory:"true" json:"targetId"` + + // The dataplane instance URL of the attached instance + TargetInstanceUrl *string `mandatory:"true" json:"targetInstanceUrl"` + + // The type of the target instance, such as "FUSION". + TargetServiceType *string `mandatory:"true" json:"targetServiceType"` +} + +func (m AttachmentDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m AttachmentDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + if _, ok := GetMappingAttachmentDetailsTargetRoleEnum(string(m.TargetRole)); !ok && m.TargetRole != "" { + errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for TargetRole: %s. Supported values are: %s.", m.TargetRole, strings.Join(GetAttachmentDetailsTargetRoleEnumStringValues(), ","))) + } + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} + +// AttachmentDetailsTargetRoleEnum Enum with underlying type: string +type AttachmentDetailsTargetRoleEnum string + +// Set of constants representing the allowable values for AttachmentDetailsTargetRoleEnum +const ( + AttachmentDetailsTargetRoleParent AttachmentDetailsTargetRoleEnum = "PARENT" + AttachmentDetailsTargetRoleChild AttachmentDetailsTargetRoleEnum = "CHILD" +) + +var mappingAttachmentDetailsTargetRoleEnum = map[string]AttachmentDetailsTargetRoleEnum{ + "PARENT": AttachmentDetailsTargetRoleParent, + "CHILD": AttachmentDetailsTargetRoleChild, +} + +var mappingAttachmentDetailsTargetRoleEnumLowerCase = map[string]AttachmentDetailsTargetRoleEnum{ + "parent": AttachmentDetailsTargetRoleParent, + "child": AttachmentDetailsTargetRoleChild, +} + +// GetAttachmentDetailsTargetRoleEnumValues Enumerates the set of values for AttachmentDetailsTargetRoleEnum +func GetAttachmentDetailsTargetRoleEnumValues() []AttachmentDetailsTargetRoleEnum { + values := make([]AttachmentDetailsTargetRoleEnum, 0) + for _, v := range mappingAttachmentDetailsTargetRoleEnum { + values = append(values, v) + } + return values +} + +// GetAttachmentDetailsTargetRoleEnumStringValues Enumerates the set of values in String for AttachmentDetailsTargetRoleEnum +func GetAttachmentDetailsTargetRoleEnumStringValues() []string { + return []string{ + "PARENT", + "CHILD", + } +} + +// GetMappingAttachmentDetailsTargetRoleEnum performs case Insensitive comparison on enum value and return the desired enum +func GetMappingAttachmentDetailsTargetRoleEnum(val string) (AttachmentDetailsTargetRoleEnum, bool) { + enum, ok := mappingAttachmentDetailsTargetRoleEnumLowerCase[strings.ToLower(val)] + return enum, ok +} diff --git a/vendor/github.com/oracle/oci-go-sdk/v65/visualbuilder/idcs_info_details.go b/vendor/github.com/oracle/oci-go-sdk/v65/visualbuilder/idcs_info_details.go new file mode 100644 index 00000000000..a0695e4b513 --- /dev/null +++ b/vendor/github.com/oracle/oci-go-sdk/v65/visualbuilder/idcs_info_details.go @@ -0,0 +1,53 @@ +// Copyright (c) 2016, 2018, 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. +// Code generated. DO NOT EDIT. + +// Visual Builder API +// +// Oracle Visual Builder enables developers to quickly build web and mobile applications. With a visual development environment that makes it easy to connect to Oracle data and third-party REST services, developers can build modern, consumer-grade applications in a fraction of the time it would take in other tools. +// The Visual Builder Instance Management API allows users to create and manage a Visual Builder instance. +// + +package visualbuilder + +import ( + "fmt" + "github.com/oracle/oci-go-sdk/v65/common" + "strings" +) + +// IdcsInfoDetails Information for IDCS access +type IdcsInfoDetails struct { + + // URL for the location of the IDCS Application (used by IDCS APIs) + IdcsAppLocationUrl *string `mandatory:"true" json:"idcsAppLocationUrl"` + + // The IDCS application display name associated with the instance + IdcsAppDisplayName *string `mandatory:"true" json:"idcsAppDisplayName"` + + // The IDCS application ID associated with the instance + IdcsAppId *string `mandatory:"true" json:"idcsAppId"` + + // The IDCS application name associated with the instance + IdcsAppName *string `mandatory:"true" json:"idcsAppName"` + + // The URL used as the primary audience for visual builder flows in this instance + // type: string + InstancePrimaryAudienceUrl *string `mandatory:"true" json:"instancePrimaryAudienceUrl"` +} + +func (m IdcsInfoDetails) String() string { + return common.PointerString(m) +} + +// ValidateEnumValue returns an error when providing an unsupported enum value +// This function is being called during constructing API request process +// Not recommended for calling this function directly +func (m IdcsInfoDetails) ValidateEnumValue() (bool, error) { + errMessage := []string{} + + if len(errMessage) > 0 { + return true, fmt.Errorf(strings.Join(errMessage, "\n")) + } + return false, nil +} diff --git a/vendor/modules.txt b/vendor/modules.txt index 8dc650dd2c1..6d0050851b1 100644 --- a/vendor/modules.txt +++ b/vendor/modules.txt @@ -225,7 +225,7 @@ github.com/mitchellh/reflectwalk # github.com/oklog/run v1.0.0 ## explicit github.com/oklog/run -# github.com/oracle/oci-go-sdk/v65 v65.76.0 => ./vendor/github.com/oracle/oci-go-sdk +# github.com/oracle/oci-go-sdk/v65 v65.81.1 ## explicit; go 1.13 github.com/oracle/oci-go-sdk/v65/adm github.com/oracle/oci-go-sdk/v65/aianomalydetection From 4c639339b6e5c000665e3825f8de80bba513c2fa Mon Sep 17 00:00:00 2001 From: Viral Sinha Date: Thu, 19 Dec 2024 10:39:32 -0800 Subject: [PATCH 16/17] Added - Release for v6.21.0 --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index e0d5501cd33..1478231c747 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,4 +1,4 @@ -## 6.21.0 (Unreleased) +## 6.21.0 (December 19, 2024) ### Added - Support for ADB-S: Backup Retention Lock From bf2e26827be87ea23d16270ccb4154aec7bf901d Mon Sep 17 00:00:00 2001 From: tf-oci-pub Date: Thu, 19 Dec 2024 20:00:51 +0000 Subject: [PATCH 17/17] Added - README.md of service examples with magic button --- examples/zips/adm.zip | Bin 3439 -> 3439 bytes examples/zips/aiAnomalyDetection.zip | Bin 3302 -> 3302 bytes examples/zips/aiDocument.zip | Bin 1793 -> 1793 bytes examples/zips/aiLanguage.zip | Bin 1682 -> 1682 bytes examples/zips/aiVision.zip | Bin 1655 -> 1655 bytes examples/zips/always_free.zip | Bin 3850 -> 3850 bytes examples/zips/analytics.zip | Bin 2766 -> 2766 bytes examples/zips/announcements_service.zip | Bin 2718 -> 2718 bytes examples/zips/api_gateway.zip | Bin 27065 -> 27065 bytes examples/zips/apm.zip | Bin 47791 -> 47791 bytes examples/zips/appmgmt_control.zip | Bin 2681 -> 2681 bytes examples/zips/artifacts.zip | Bin 7102 -> 7102 bytes examples/zips/audit.zip | Bin 1804 -> 1804 bytes examples/zips/autoscaling.zip | Bin 5681 -> 5681 bytes examples/zips/bastion.zip | Bin 4998 -> 4998 bytes examples/zips/big_data_service.zip | Bin 13161 -> 14061 bytes examples/zips/blockchain.zip | Bin 1898 -> 1898 bytes examples/zips/budget.zip | Bin 3741 -> 3741 bytes examples/zips/capacity_management.zip | Bin 18114 -> 18114 bytes examples/zips/certificatesManagement.zip | Bin 10431 -> 10431 bytes examples/zips/cloudBridge.zip | Bin 9949 -> 9949 bytes examples/zips/cloudMigrations.zip | Bin 8429 -> 8429 bytes examples/zips/cloudguard.zip | Bin 26197 -> 26197 bytes examples/zips/cluster_placement_groups.zip | Bin 3160 -> 3160 bytes examples/zips/compute.zip | Bin 55573 -> 55573 bytes examples/zips/computecloudatcustomer.zip | Bin 4199 -> 4199 bytes examples/zips/computeinstanceagent.zip | Bin 3311 -> 3311 bytes examples/zips/concepts.zip | Bin 4864 -> 4864 bytes examples/zips/container_engine.zip | Bin 25520 -> 25520 bytes examples/zips/container_instances.zip | Bin 3326 -> 3326 bytes examples/zips/database.zip | Bin 171217 -> 173152 bytes examples/zips/databaseTools.zip | Bin 6461 -> 6461 bytes examples/zips/databasemanagement.zip | Bin 19637 -> 19637 bytes examples/zips/databasemigration.zip | Bin 8500 -> 8500 bytes examples/zips/datacatalog.zip | Bin 3256 -> 3256 bytes examples/zips/dataflow.zip | Bin 4617 -> 4617 bytes examples/zips/dataintegration.zip | Bin 18640 -> 18640 bytes examples/zips/datalabeling.zip | Bin 2175 -> 2175 bytes examples/zips/datasafe.zip | Bin 80723 -> 80723 bytes examples/zips/datascience.zip | Bin 50964 -> 51056 bytes examples/zips/delegation_management.zip | Bin 9452 -> 9452 bytes examples/zips/demand_signal.zip | Bin 2083 -> 2083 bytes examples/zips/desktops.zip | Bin 19295 -> 19295 bytes examples/zips/devops.zip | Bin 46272 -> 46272 bytes examples/zips/disaster_recovery.zip | Bin 12843 -> 12843 bytes examples/zips/dns.zip | Bin 13725 -> 13725 bytes examples/zips/em_warehouse.zip | Bin 1379 -> 1379 bytes examples/zips/email.zip | Bin 5650 -> 5650 bytes examples/zips/events.zip | Bin 1807 -> 1807 bytes examples/zips/fast_connect.zip | Bin 8373 -> 8373 bytes examples/zips/fleet_apps_management.zip | Bin 7373 -> 7373 bytes examples/zips/fleetsoftwareupdate.zip | Bin 5324 -> 5324 bytes examples/zips/functions.zip | Bin 3475 -> 3475 bytes examples/zips/fusionapps.zip | Bin 12261 -> 12261 bytes examples/zips/generative_ai.zip | Bin 4773 -> 4773 bytes examples/zips/generative_ai_agent.zip | Bin 4911 -> 4911 bytes .../zips/globally_distributed_database.zip | Bin 20571 -> 20571 bytes examples/zips/goldengate.zip | Bin 7407 -> 8131 bytes examples/zips/health_checks.zip | Bin 8826 -> 8826 bytes examples/zips/id6.zip | Bin 1003 -> 1003 bytes examples/zips/identity.zip | Bin 16317 -> 16317 bytes examples/zips/identity_data_plane.zip | Bin 1948 -> 1948 bytes examples/zips/identity_domains.zip | Bin 69993 -> 69993 bytes examples/zips/integration.zip | Bin 2683 -> 2683 bytes examples/zips/jms.zip | Bin 11220 -> 11220 bytes examples/zips/jms_java_downloads.zip | Bin 6918 -> 6918 bytes examples/zips/kms.zip | Bin 9520 -> 9520 bytes examples/zips/license_manager.zip | Bin 5213 -> 5213 bytes examples/zips/limits.zip | Bin 3707 -> 3707 bytes examples/zips/load_balancer.zip | Bin 6839 -> 6839 bytes examples/zips/log_analytics.zip | Bin 18960 -> 18960 bytes examples/zips/logging.zip | Bin 9687 -> 9687 bytes examples/zips/management_agent.zip | Bin 4134 -> 4134 bytes examples/zips/management_dashboard.zip | Bin 5585 -> 5585 bytes examples/zips/marketplace.zip | Bin 3062 -> 3062 bytes examples/zips/media_services.zip | Bin 9090 -> 9090 bytes examples/zips/metering_computation.zip | Bin 7270 -> 7270 bytes examples/zips/monitoring.zip | Bin 5315 -> 5315 bytes examples/zips/mysql.zip | Bin 7758 -> 7758 bytes examples/zips/network_firewall.zip | Bin 12995 -> 12995 bytes examples/zips/network_load_balancer.zip | Bin 7197 -> 7197 bytes examples/zips/networking.zip | Bin 42171 -> 42171 bytes examples/zips/nosql.zip | Bin 5136 -> 5136 bytes examples/zips/notifications.zip | Bin 6649 -> 6649 bytes examples/zips/object_storage.zip | Bin 11843 -> 11843 bytes examples/zips/ocvp.zip | Bin 4736 -> 4736 bytes examples/zips/onesubscription.zip | Bin 7807 -> 7807 bytes examples/zips/opa.zip | Bin 1703 -> 1703 bytes examples/zips/opensearch.zip | Bin 2613 -> 2613 bytes examples/zips/operator_access_control.zip | Bin 6928 -> 6928 bytes examples/zips/opsi.zip | Bin 35410 -> 35410 bytes examples/zips/optimizer.zip | Bin 2339 -> 2339 bytes .../zips/oracle_cloud_vmware_solution.zip | Bin 3979 -> 3979 bytes examples/zips/oracle_content_experience.zip | Bin 2090 -> 2090 bytes examples/zips/oracle_digital_assistant.zip | Bin 3038 -> 3038 bytes examples/zips/os_management_hub.zip | Bin 15606 -> 15606 bytes examples/zips/osmanagement.zip | Bin 8224 -> 8224 bytes examples/zips/osp_gateway.zip | Bin 3540 -> 3540 bytes examples/zips/osub_billing_schedule.zip | Bin 1704 -> 1704 bytes .../zips/osub_organization_subscription.zip | Bin 1757 -> 1757 bytes examples/zips/osub_subscription.zip | Bin 1795 -> 1795 bytes examples/zips/osub_usage.zip | Bin 1749 -> 1749 bytes examples/zips/pic.zip | Bin 8004 -> 8004 bytes examples/zips/psql.zip | Bin 3528 -> 3528 bytes examples/zips/queue.zip | Bin 2767 -> 2767 bytes examples/zips/recovery.zip | Bin 4365 -> 4365 bytes examples/zips/redis.zip | Bin 2401 -> 2401 bytes examples/zips/resourcemanager.zip | Bin 6565 -> 6565 bytes examples/zips/resourcescheduler.zip | Bin 2177 -> 2177 bytes examples/zips/security_attribute.zip | Bin 2048 -> 2048 bytes examples/zips/serviceManagerProxy.zip | Bin 1691 -> 1691 bytes examples/zips/service_catalog.zip | Bin 3854 -> 3854 bytes examples/zips/service_connector_hub.zip | Bin 2891 -> 2891 bytes examples/zips/service_mesh.zip | Bin 9180 -> 9180 bytes examples/zips/stack_monitoring.zip | Bin 23415 -> 23958 bytes examples/zips/storage.zip | Bin 30335 -> 30335 bytes examples/zips/streaming.zip | Bin 2116 -> 2116 bytes examples/zips/usage_proxy.zip | Bin 3238 -> 3238 bytes examples/zips/vault_secret.zip | Bin 1999 -> 1999 bytes examples/zips/vbs_inst.zip | Bin 1788 -> 1788 bytes examples/zips/visual_builder.zip | Bin 2691 -> 2691 bytes examples/zips/vn_monitoring.zip | Bin 3703 -> 3703 bytes .../zips/vulnerability_scanning_service.zip | Bin 2339 -> 2339 bytes examples/zips/web_app_acceleration.zip | Bin 2374 -> 2374 bytes examples/zips/web_app_firewall.zip | Bin 2909 -> 2909 bytes ..._application_acceleration_and_security.zip | Bin 6483 -> 6483 bytes examples/zips/zpr.zip | Bin 1702 -> 1702 bytes 127 files changed, 0 insertions(+), 0 deletions(-) diff --git a/examples/zips/adm.zip b/examples/zips/adm.zip index 7805e0eea97d984082c832a3242aa6b4d3428708..1e845e94064e24566910d03470d6d56f86045b05 100644 GIT binary patch delta 553 zcmaDa^_*wLO@bJ8 ziPI3Pipk%exM;4)M~_Y>Ifj7)OOaNkds=C;DE3?7)1%eifFD?^xejoSscGK6V1 mJPx>(AxxXc<4%k+c3yi;tUhIB1A3T&9S9dNF)-`|+YbO_t9{D= delta 553 zcmaDa^EyFKk^qlFNW%aC delta 299 zcmaDR`Am{Gz?+$civa{2jk_oE8mUwoM5b2*acKoN10%~zW(Ee9dY~*wod}TT0IN&3 z76GXPVPth1H~BC!1I?Mt$YhCC!Dc_E8|+{enp_T8RZOns+6h)*$?c$oZa&x@j7)OO daF2&P-qx#Vi(BRZQN`vI(r9gw;X`-F&b+7@6dl p;Vzkcj@6MEWrl3_#3-A@=BA0&QdTyg-3%;1*v81fkje_;0RZ&INc{i+ delta 320 zcmZqVYvkh%@MdP=VgLb0gtQJb>=7ZhA$Rx)M ocgf^{N0GUrnr~m)} delta 320 zcmbQlJBgP!z?+$civa{2jk_oEYN=EjM5b2*acKoN10%~zW(Ee9dY~*wod}TT0IQ2O z76GXPVPth17r8Ss1I?NIhS3nKg3X3Z=OHSXSuC)snC#E88EgbAtA!G}`CxZ2GRZN+ oT{1bI)sYxwhgj{2QKro1ris;3RyLsB3@kv{#>l|%jRnL506`5xumAu6 diff --git a/examples/zips/aiVision.zip b/examples/zips/aiVision.zip index 3b3479055e33796357c2351113800b81e842915e..befa0cdfb8ef3151ab5aadb4872deb4e74eeb76d 100644 GIT binary patch delta 299 zcmey)^PPt`z?+$civa{A7EGSVtD%x#oswP%#HAJ742&!gjG1-n~BiM*fEM`jR=7ZhA$Rx)M ccgbWgR(oQUt!A|)Mj02IivYT%ljGPV0kVoinE(I) diff --git a/examples/zips/always_free.zip b/examples/zips/always_free.zip index 1dfa3f945230488e95b51fa863df7c76c23577f5..071f8b6be02cc8982b4f4b9501ee8c92b7d07852 100644 GIT binary patch delta 299 zcmeB@>yqOQ@MdP=VgLb&1(PT8YOCZ|r=%AGacKoN10%~zW(Ee92B0iRod}TT0IQ2J z5doEw@mk^p&?Nt6Hp delta 299 zcmeB@>yqOQ@MdP=VgLb0k?GYyTw1}+z{v8FnSp_&9w-Y^Cjz87!0KX5 zL_q357+KxMB_52-KyxO)XEeg9V6!QcEf-itDUT&q6_XF~Yym5%ndQOx#z?+$civa{A7EGSVtErM-oswP%#HAJ742&!F4d_A!Rv>)B$iQ%g1H=OW DMlxGK delta 392 zcmX>ndQOx#z?+$civa{2jk_oEYN}KkM5b2*acKoN10%~zW(Ee9dY~*wod}TT0IQ2K z5&@|LVPth17bGw;1I?Mt%!FORW=|$ph>D5K23U>Qe3hA-1#HG+c5|#MChKu*f+*lH zS3-9I*rkk2a?EhIPPXB6AV%3dqLfYIvLnW@1TI%itWINP1G0Pz5- CQ&Y+S diff --git a/examples/zips/announcements_service.zip b/examples/zips/announcements_service.zip index 4ab5fec939b15b069ace26d5c2fcf0c3e573f708..021c21f2b583c99f8085880459abb0eb9e199222 100644 GIT binary patch delta 393 zcmbOyI!}~0z?+$civa{A7EGSVYpRl8oswP%#HAJ742&!R zI4hyM0PIpmCOKxfTPI)T@F7N-GiNX{%64#i5u;3nD^L@w+gRCvPGn#OLUkqvhC~h! F4*+;PT73Wj delta 393 zcmbOyI!}~0z?+$civa{2jk_oEnyOS9M5b2*acKoN10%~zW(Ee9dY~*wod}TT0IN&0 z69K6MVPth1cZ4xA1I?K%$mEJu!R9QcP>6~{%r@9n2(dUbgUyIwcgCt>@_P1tUb F0|3>{QwIP5 diff --git a/examples/zips/api_gateway.zip b/examples/zips/api_gateway.zip index ddf67dc7310e707d4d940bd74b2888aca3d941f3..08c332cb2921db6dba6765794adf1b30d1f7532d 100644 GIT binary patch delta 2443 zcmdmanQ`Z3M&1B#W)?065Rh0fc_Od2N`7@pdLa;(R&X;gvbQX8Av@xX`Y+^--KaQWc8IIG6x1g7i3{lC32Ar; zMlQH|C#?k-387q*-z!K1^>I(;PvjKmWMIY~uo4rQ!R}oyZB3ke*<_rsyEjHg8|Gd! z;*5HtV2j--Q^hBYU{}c~n-gbLxw0L0qfRR8LR>XhNNuvbh6HiOMQgZXH*Sl@BuIF9 z>KGGe)B+tV>_)xQ35FQuVxUi)QPT}fu^aWkpr1()lsz^qx-;FHk%7UCiGe|G@~HJS~Va zYLXWYlcK%k1i>cNL|bCDYx2qHtzZR>F_uc`g$}Ts3GilQl4FJ!ca!hLc;QwC&x4aa zVgqq2LzuQZHUPIWglW2Q;kcC{Oj{P`fm<2EG=X@3+{zH9HOBkkR)#R`eS9QtWeC%< z5?pXALzs3U!5gkp174EOk0tNCwLL2NhJ~GwuU64-1aufl^C~$B;yHQgxeb9 zr6=D_HYCPGgOp(0$`B?lO>xAn3=wu5sdy3-!nC4PTVhPRnCeW7GP5)%+{zG^&Pv0R zf)QTeP7fo-wB~d_+{zH9eNGR>tqkF|tPD5Y$`Gbq%D`h9LYZf#y8wErGWF=lHC)#>1FI? zEX+XDC%@;mBF-pZ9!Km(E#mpX3N~u4kR5SG{TK4aZd9BwJH%C83Tl)4#0B*6gfu(^ zBNtq~lhy)^gix-@?-ith`nV_aCvu8&GB9HgSc!?uVD~PUwkFQKY%)&R-5VpL4Rfy< zaYj8+u*Ghasp1nxu&ZR0&51LrT-gr0Q74skA+DM$q&8VzLxMQtqBUHx8@EMc5+uAl zb&QEKYJrXwcB9_u1VfB+G0-Q@sObi#*o}H%(9a|Y${rgQ-I;F9$iQI6#K0go`5>Fb z_koTSF32ZhM>LN{rh=lJNvD!flQ5 z(v$Bd8xmupK}s-gWe5|Ora0nOh6p>3R6L0ZVOmkDEitBDOm!wknOT|>Ze<8dXQkmu z!3ZyKr-u<^T64M|Ze!mQn!F%W5&(s@ B8VLXZ diff --git a/examples/zips/apm.zip b/examples/zips/apm.zip index 70636e8abef5d06f28e8615b1f265b65ee496f37..ace1a45b91f2b0025f4579bbbc931163a7027f4b 100644 GIT binary patch delta 3643 zcmb7_TS!x39Kd&V+OnBW)0R_bsVkcrW#DGza^w{})x0Fkpv;#{q6Dc3kqROqw+|Jw zmKU6JZcev!PK4;ehoH+tWF$dB&I@LR=7O&c~SOky#;^tda|artXMq#>ec9`@(0_kFTOreUER!tJ)H> z*`^L8meHxiNlkcFN78my6&O^Zmoh0zPl;9=PjassRQoNNFszD{1EO%XA@Ad*+OR$F&m~PAK9T&q(b{lL%Qp$BYHwwU!-Pw=*V3J`VNjU!t2;(~P+fNk ztL!u%=c*i3Kg^f$s_Pax+sNKN4VMa95$LPt0wHF7{{?)^mHx3m52aLv-uomd&bRR_ zz`HV_!+Uq%TVTC`!6Ld84fm_@D%<^BR`vRUo=&B;*5g&<)`zUBd?*)B+#V`niRZ%w zSOUe5IKwOSWF(I+8~JD<*5oyfR|a} zI^eiO#=xeTJVnO9=9p|JV_++B){-%>`JJs~3~XhtGBO4>kBe$pyQZjYcc-XqCYu7K zx-~TUwYpD`F{pNBT7iDKi^wQc+%Vll#?~8+G#E3}NQ1qYX(nTko6$p+o6?~`Up`!h&e$3l0%0mn0c?EnA( delta 3643 zcmb7_TS!x39Kd&V+OnCqvgOoS>dK~eF>tfma^w|UH7^M>2=gWDp#-~7Ar*u|ZXYV9 zEiX9d+?;OdoCwi_4?&lQ$Vh^Mpb_Lll)XgI&Q9!a@qNdyjq`BWZ@>TboX@i=@T>}A zt1E<}4Ls(f+t*=<&D?Q0zrOiu=xS|~^7x|9LLN_aBlPQE9O~{-qI`Qyb_`EQ!&~ec zE^lJUAI-!^V!l3+5i-}>1bhvAw?N1cQc)qDs!3FgSIvritm>RZOQ(7!If_?hMw^A< ztZqs7)2ZG`HF(wTjVe}EE8EMZip&bRWffc?GU(@MUUeZM zn{8@eQYoEEoZN_4wIy$3Rl$BGdMT5l^pt3o=_L26LABqu5{6ZtazGTWmhnEGO!yDy zhg5>|pu)v=@KYM)h8xli__A&3Q<89c#++kx9bCvU;#C={MYd97P9aKDZ|2g$J_SS1 zG}G=bZxT{?qtO{Hnu*5323d zvC5m4<6M=4>WAeLUUl7?$TqUON6n>zRs?&hxIl4%TOD3CW_!r0$_8`s#N9z1OFSPc zz!E5a*cD!(C&PJk*(8n>Vog5tNG1E~agP=#|2>1khag{|5JskLwQDITWVV-)F__#_ zdo>x0#6+605;6w1p|J`w2DVL(axwi3T%HH_%`&rkltZ@UUj`vxl8f5TO?Y_rPwF$X%9B*#O%{F(Iri82j)y}sE4wG$A>Bm4Z8H3#P^Cc?m UfhUd%oqIfW==(E7+eVqY-)dAlNdN!< diff --git a/examples/zips/appmgmt_control.zip b/examples/zips/appmgmt_control.zip index f3d69a154a474b237e68e19d2f9233557f65439f..b665226d06a1ed6585964a3d93517a4811cc1460 100644 GIT binary patch delta 532 zcmew<@>7I2z?+$civa{A7EGSVtFMw@oswP%#HAJ742&!>JpsssS^RJ z=Kz~`+)D&x9tb0ww^^03f{__$;p7EO7T8t1Ve*Bjuwn5e%C5;PSpu*d#mj07G0KtAy@Wu-_S(7I2z?+$civa{2jk_oE>Z?>5M5b2*acKoN10%~zW(Ee9dY~+-x&&u@>O_F* zIl$%}_Ywh_2g1naZB}KhU}OebIC%k+1$Gs0n0z5BY*;*rvTO26mH_NV@v_=NjPhl( z#j0ZRJhts%*F><}Dxtd->~}^cIc9h$P2SEPh+7%l^OLnWB8XA8gu@NDGK8f(oZ+~Y XAuMg>j3Y)FE0?zbx=$x3a7h9H2`F+P diff --git a/examples/zips/artifacts.zip b/examples/zips/artifacts.zip index 211c93cafbd7deb426a8cda5763cd0174f15c9e9..e14cd2cfc8cec74646993a765df5074ee44d01fc 100644 GIT binary patch delta 1156 zcmdmIzR#RDz?+$civa{A7EGSVtErM-oswP%#HAJ742&!>Y^<0sS^RJ z=K!0x%}WGi9tb0ww^@Xdm5CW>;ba+RGonnIT*mBx)u_p*m~Fr&ak4mLRj@gMa)OeNPOHCHpi-BvWCb8uxoCMm@A=2CpdX9GRZN+6VhZ8 zQ8(Pm;OS%X9MK5e$`GcBiMilbhA^#0%#RplZ^Qy|D??ZsFHV$c=fyLKF)dQUAGb1u z7fwlJ6Qe9#vV|CBeO_F* zIl$&^^AZ7>2g1naZ5ClPmoYnFHEQxHW*e|coGi{*6>Lsm`OXMd z5yj>}oL&3aqOcpK!=3>#YC4A_aYp^&h{bMHE+;Pw*j2T>Wmr{AX6Ks%Rxppx2&;n4 zPxzc6uF(>(CC)Y70wLIq`YiAq5+8Sk&9SPOtRb=i?3&vm=1S<%2~Hl2OmfWdgf!Vi z)D5>Xc>0(;M>GPrGK6VjVlKFqAxx_g^CL#t8?iv#$`F>uixXwqdGQQlOpBE8$E^(E zg;NsQ#3&1wY#~P3Ur7ht%8-02<&9ez!fj`yl88|jAnmG&HHEOU0TT)XKM>vlvd(}E GW&i-Q!1!|j diff --git a/examples/zips/audit.zip b/examples/zips/audit.zip index 894af7801676c86c3926760eae74171c8e48c384..1aaa96874f6cf971a6277409e41afe46c2095c52 100644 GIT binary patch delta 320 zcmeC->*3=K@MdP=VgLb&1(PT8s;cByr=%AGacKoN10%~zW(Ee92B0iRod}TT0ILhr z69K6MVPth1XE-r31I?Lymr)0+g3Yo_)l6U&vssL>s+jzUWgS?-WL9G(bo0UPU}TbG phP!0)3sxIql)1545u*3=K@MdP=VgLb0oswP%#HAJ742&!xP|Cunm-e7(lD(3M2gSdUJ zAa=J;ekHgGY{YyaOC|K60S6%?lN>WV5GVfDC(|>HQZR)fWgPW354Ci^f*BX!~*~!bgORw delta 702 zcmdm}vr&gPz?+$civa{2jk_oEYO7QlM5b2*acKoN10%~zW(Ee9dY~*wod}TT0IQ2J z69K6MVPtg^mtA278Z)_;(HN`z<|B*^j9?Y+%$C?yOktkO1Xf|fW`bQs4VyEgAkdab z(aXDL`7<#vl(H}|C{9k~mzey5T@bq-UXB=usX1Jx*i~%hn#}^XH<%xXiaGrMAa0*4 zh~4dzUkPpk8!=zVQVBh1z(L5!B*zR7#L2&eT!>MYAnZttvctme#3<7daUw?91QAza llzkU*CPrC|C{fA|in?oJ4L4RcVDK?;0%12WJx&k;@c=I^o&f*= diff --git a/examples/zips/bastion.zip b/examples/zips/bastion.zip index 45493bf05e1e76c9a83193ccfda13c03cc2e3483..5b7f96ad55c197116013450b3a448d9ae58aa35b 100644 GIT binary patch delta 590 zcmZouZ&T+D@MdP=VgLb&1(PT8s;lHzr=%AGacKoN10%~zW(Ee92B0iRod}TT0IQ2I z6alFNVPth1=i0L{1I?LypTz*Hg3ZdTPK;m`8En{%*u0kQG80%uGp8w rj513>J7Sd06eP;DUxL=em=-QXlxaJJoQW|_R@gxRJwPVs3QGb2WdW0- delta 590 zcmZouZ&T+D@MdP=VgLb0ME56k?GYyTw1}+z{v8FnSp_&9w-Y^Cjz87!0I9l zML_C67+KxMx%Mo~KyxPFXEDI4V6!r-6C+qf1{-!GHm_y7%mh}^%&CjjjLAnhw}BPZ za^W!I5Z673C5w4Xu^aJ*XD!%>IlM+#6>NUQI|t&5MgdbLbZ>%#gON#&86F^$ZwS~E qqs&s!ju>S#1&K24m!LHY|YAtj1_L%quTp`Uv{_mBD9^L)>F&hp%I=AH9|=N4mq5YuL0>Eg?#ByW)y zCxtk<_|Tt#qfmf>=^Y3Fn8N9ASIZGJ|0c&pm*2F^qweKe;w?RY@@|MTd}aXA6;co& zl?{<7At24QQJtV@#$}WhSb1ZpTVRc~QJYzse_Exx1#P(3>4=v<(LdN;i{#}@bP4b! z_!CK9a^_|b0Q46ht?b>(HBr^Wn*jj!f&ln*xBubA5S zM#{5(pGES)I^Z)!H8Hx+PPjUHjIqd2T3))JB62du66YGKto5h8*wV8PSf-}=XWsmj z&Fq_U#K+O4XSBWj$2LK1&^`^or;E)8X;r z=k;CYAXZZ9at`C2yDx|z6COG+Ug5j*{t;Nv{?^vrB$6kgLduO0<5mBLDcBG}8*z}B z|E^*e>ilX|!c+3$=oAQt+=c>=nIJNV8W1PK89C$Z407!_y0`zCww{^s~sG_!P=-S ze&(NLm=9Oo7z&KgS{r4HxC`Q-9}ZS0Yj^q`X90jnH~@$&Rgm!iD;0{9un75U-!tRX z%PH)mxrGmRcK!%8jlrMY@$yY@uO-ggZ0KS^v7A1a$&=4dyObml3#E$@h1~DP(Z>%O z)#j=-7HYExDs^6Ie#=U*#mI2_)iZUKNpnr_*aH#s$1A`(g)2Vq?5=a(mf82D(pz7r}m&5n&)Pz+NxAcAb*6Z9weNP;DTj>)R zM8=pbnA(nCm$-dnm}c(Tb#xR>v7-vIh0GAK619men8llw$$b;b{l)W5-NnA8Mn;bc z^X*jTYutJYzr)o&dP+YP>;qfXC{bzMl`Y4A5Fch{l^+=PIM!D$7tlhUSE#PWygzgn zHJpYEyFhwWwE3=QrQkzi$gT0fTA746Sm)#GCqqMe`IBxPo0=Z-BFJ9XIcIP5_=5h2 zN6(0#IxBn4-$OlTc8@IP&w4&P)Kxw;s8ZD0`|$4ZgWwS}1nzOdi2DKzUopsqcU$yt zu;4`5gy*6Kj18cgR)=mBkTbv7coK!wlPahdx>7#6#S7Wbb3*{?~WAly-DJu>6+T9hU8goq!_1%pZwV^ zqt5zzz;?e^m&JSbV?WPs8*_`&&ToPCOnZtd`hl`kDstZXigcqxoS2{DmBaFz^>{KI zn2}H9VyKEQF{|tf66(@Xl5tZY)~eY`FjOsvhkCe(uKSXDy_p~ zi(mY{jyRFiT%!z|8R{ZL!5R&B5SyNtM7wwgk89L{GJ(lvCs$<=SZ?hbKnkB9DN$-* z%%srqadu)vJ+T#%8kJB+QDBQ%IA72;bM(b?8d6N9;~R%g1V8yo-t-76%zc=c5P_W4#(u7WHYQXJe>D!mmjr!Z70$pHXZX&sNwif@!+%d+m#MUH zE>o$1zwAJtr-Uhco5XqSWlY2&AKP|pV-}*Os=}xwsaomvi^D&*YFnJ&%Iyja^D~|P z&UYhr&~(IdtLWRS)}_~(MR;)KDn&s$BQN-0&0IHnYWvNfY?&q~$l?;{>0q%?pybM0 z6zXnnuP0ghM8Lv6G3|6fUTaWVgnI3cQ=_NyhmrbfXH&OPb45|LyT!iq<=0tXL0v@X z?|f(GuU&DXqfS4i(%yk`fa?h0N}&4Vg2zzOCb++c$5h!`|)6owBOxmNrLE z8G4_ph)N>q7P!v6xVb1))ZmyF9u<<8=C?g&J5Y z+!OB;Qzwe|H!=JpLA6U-{CGe-XNEg1R}1}>Tj}kE-)grXK zr+&?nQ@S7*rS6TEXyg4738~?Ch>XLr9y!rzzS-F&(lGrsr z>?u;$VN0KNdO!Q?TJDcZ6}Tlg*i%#Zk^9y}-v~nT{On|sP->$8?S$ysjP)591wku= z4rLN$yuR4VhA56`i}l5R)1IUEt}phRrX&3qrN3!+q;)q!6Ol1oU+g!{TNX|!mJzgB zXZSETWBxhM{5hYkIBdoC)zb{Xw;VwFa05(4C_*R%d4%>l{FRRFZ)$#9n=Auo!RO^=x$+*VOvr}@1c1qb+XLr>!!_$Dyvlu_$n_< z|H~3n+W?1_h#gU);Dy;Zxopwa7G=$Un^KCI0QsKLj`mm_9%BYNgVOx=FW)n00KLr5bq2E+`9NA@-e*F)Vc6V0* delta 3694 zcmb7`dpMK*AIEoKjL|fjH6(e;afT3jHfKthi5ZfF3XwS#%TiB>de9Vd2&F_0qZ1+} zp_B-1NDpQ4>~Y*hIkn%YD^I^met!3^`;YtD=kxl$Kkv_dUH5zB=&+9%!5SkMMp$MD; zg82v1Wx$4OBGDtkCM%=bz-K{AC^AHUZK!(?qm@x2LQUUPab;EMwwmHPPyl!pJARBw z{(UB}uZZuI6chkZrvv3=`Q0#jr6_FWb6BDez)O-lg;nW~*2%0*HgBEn%D4k?dFT@E z50w7O6>X?J-v*OMTdeJ{c(l#RC=Ocio84U5oohom$eFH;DwL}Pi}POsGGa=@%RmSK zDBDO6Qczp5n9fkxOq*dc2`SevD!m3e{#J7C>sZD`td*5VRU@~Y5m9FD*q8o%w%iNl zSkrvb-cRZE*zBePX9A}7$@>8osl&(lKJ-b+=17?RV+mawUk5eeR6@f&`=&;TEtzE~ z&FcuVg-szM6#R zAT!JPXi0Ure-b0?u&o7*wkk_ZGT!q~59p+2Wkh~g0G@qu4~}_B{nhmnbLJoRr0dfj zp%7f*!ScP^oM8?E=bbx(-)xO|C7|68Cl#PnDoZOBgDtfm?B0i|i_EJvj2DZo%DKv| zY&@UxsD^m(iwn(-d8X$v0S$|=d&e>N>zJ)YL^JA5@wzT}q9HU`a{T&U3T~&j%r%jn zr2JT^5*6#3FBefuHWC{kPlx`5JbN z#Ob)1_`$LCLh7|=EZ4z-{)qzxbDwVXy2HjAJKtsyOD8+JVv1wljNM}f-?yV8!bj)r zkLGu993HydDb5J$Z!@Y~=cU=;^KUg>xrw^n|f5h~MIn zO83k8ghaim9|#Mv&k_x9X)OY`_Uql%xZUpSHe1wnKOofUSy#~*Mg(d4dDficrd9b_ z>#lpiOCf<~mz%;w?oDLW6#{F$f9%i;B*Pkh!&_i>(csple$x^BhC+8i{P_CMoNQ!!(Gzi z52bZGpXu95^bYjQpx0~dXghhCGP1?uFl5|2(eYidjqk13`Dul$Y@BU_mA&LH`yAKZ zf@FO>O)_6L-6JF6tgo?NhABuoeKsX|ueL-B{&2w|xLo>;S37&cj62^Di8A`4(G=kr3slqj0@(=Q4IKXvVMt-@IA>5^sU$N$2P z_roXLB2Q$FhnwbeD)wI-g*P5N=2J8bCXKF=(>yClywmfg6 zTDd)?z7-^#E=Y*UHYEsXy&g-PO2ykwYNq^ATt=USiqC1kMP2DWZH?{73_DJ|&p zk!Cx2wdhMt`ZgU%VH3y@kumPzvEv=q3<8MAXaj73OvInwXnE2YDWsX>5U&C5gf!<) zA?%M{j#h*W4=6Ic<+~fg{PNy;=eWflm@`Xhqa>Ld)nvDZtRKW#1wRZJ7=B+ODE`Ti zqYE2jc?1^!E$l3fU`kCnM_ z#8(aS^c{(|XoyF)c}|m^<|bcUu$`2$NmSLyj0N2Dgo0kg~h0f)zjA0G(+Gc85x6(+nG8F38@Aq{YT0^1LCau z4k_N@nlXC)W1r6bW$NU)4*Vw}lS4Cfd2Q1Yx1+?B)%_^O$xrC<@Q_FMVW;@BQ?|zj z#?z7l`)3p37a_7XggG9=0OO=NAA)sJCK2mYwJBs^&lDB_y~>u3yQ;5PTcRl2XH;-C zI9%w&LVYMj@-pu!r8z8I2sL^xQa2DJxmCMt-6NixiMSn*$C=Uh+^w&>kG4r%sreuK z7h+{Q$OH_4*Ko)z>Fb!A;^xm%gL$T^$3-_%usq%;#nZ5URMF(EnrSp4nt|eguTVqd zfUbGtg+QoA=C$Nu2B27>)$B7<=0kW094aehoenbY+mL1HwUMjqjbx7{jZ?22LLO!F zobuVU!o6JHo?f+_+brN@of@xCa{8J^k?55wFcM`Zvx#83+&MSTkNT zdjn~L2$7b3C8t0n#F@;Lw0245;|rVf^+8or0T@KZO^nEWxvit4h>t~`qJ*Yu4v&2qx9c$9QQU6hodP$!&l49%GH2Y`y z9c$&z_E&XM?kD`gS5C4f{J?>fZmmD{B-{k2c!G;*?MFPJ|E_{t`J(}N_?h$)%3oECF1{UV=D2q?;13n#GX0q5FF*ibJwI^keFyR%0oS9k zsDA;a@c-|EeiE0CUSdUUU(>!A+tHwz?;Ubdt2(nh$a3@r05<LRTiKA1NGe+vj6}9 diff --git a/examples/zips/blockchain.zip b/examples/zips/blockchain.zip index 5c76d681901a94edf52724c825b110c2957a0e3b..ea0f5ffd668852609ae0fd1395c35849688a9df0 100644 GIT binary patch delta 299 zcmaFG_ll12YnZ?)?yy*3RWVtEbrV>@T~-Svbo0UPU}TbG dhP!04Ih!Lf%4V_I6Qk@mo0|Z-rIQ2MB>{TDL<9f; diff --git a/examples/zips/budget.zip b/examples/zips/budget.zip index da4638fe8456d587f15203f927719408a24ea6ff..46e91570588b7b678a984642c60138a6837e5e92 100644 GIT binary patch delta 570 zcmbO$J6D!Bz?+$civa{A7EGSVtEQ4)oswP%#HAJ742&!>cTDXsS^RJ z=K!0x*9tb0wx0#Lc6*Du?!pWam^s%cjV|8Q%tEgf#!Kz~NA+|MO1%>RoMtB?z zcTA+dNoDy-pnrP#85ray9u%JZm|YmF(VMwAZa|#(l-ooJ-SObSU}TbGh6meZYaTb; z%HR%|yqL$A7-d4dw!|na3xf=cI|%r>ty14>Pa>;YKC~hHKm) F9sppyg9iWr delta 570 zcmbO$J6D!Bz?+$civa{2jk_oEs;N{OM5b2*acKoN10%~zW(Ee9dY~+-x^N48>O_F* zIl$&^wif}J2g1naZDwP9#mo$}aPnssee5dCSREO`DyrB_u&S7Rh;0p6K_R=Y5gtdw z9TTZd zGPnaKFXr(jMwt+=EiuXpd7W@8L%8iKuQhIE2)7yWIcZ|`DJvV$!wl>|xRHs0;TkuH F2LL0Nc$EME diff --git a/examples/zips/capacity_management.zip b/examples/zips/capacity_management.zip index 36dcc7e0cd032ac37da5c99b1c6e1f4a972b7427..3780a6e4c5a9d0cda58f001c633e714c505be1a9 100644 GIT binary patch delta 2350 zcmX@q%Xp}lkvG7bnT3l11SA$rp2%ygl3$&YUI@gc72FJrEH9ZE7+4yBvZ(4(yz!|M z0jlQ!n|C=)1Y{lvBb&F`mywl~8EE0;P_}5IOqzU!trNRZh3rL)V56RK1Q2Ib6lW23 zqaJW>g%~x1+nqS0n0ex`8&%3Pmj&!9Q9)ngjA|3i#%>g=&`XG`J_>shXH=X>5_Y4m zi0pzGHBl^>IHNek%ds0ZS^N^js0_(a;*5GIS%clELMdS;a9Fj=*kD(2UB(MynTlK> zahA=LE5>e=g8UX0!Zcq;>B;ZS{ctNqm>6#{9k()si4vA^xRoJHn_=02TN%PM zE2~i4$`Gb)w93J)3}KqRbu?~e2-EghSK?NNFfH6B9JexrX%}n?a4SQYHo;YTa;>c! zZlwqlpW3$KR)#RK$1WMSGK6V@_Fcp%+iUNITN%PqO^0~g$`F>Wa%jY@3}KqDV%?wUA$t)c*r;b50mK;<#aV>i zs0W-|Ax6#Mb|=m#W}Z0gMwRl+WdXZNRM3|=quK_}hR)#Rm z$|@AMGK6Uxt#WWHLzrf79gSNV!n8fsmAI85ObfRO$E^%u+69{e+{zH9O>mW-Tx;uw zTPecCr?#!Ql_5;*u}j9S3}Kp}eHSsx_S$>lR)(-t(;*(WGK8h892#*eLzw34n2B2% z!n7NXQ;AX5@8p478N$+^P6@b`AuO$SZYD;Vf{Q>e8L@sS^RJ z=Kz~`E>Hwy9tb0wx7nES2rDzt!pXnbe2Fq?ayEM^cB7uK-vJvnG2L)-G#{^KXb2|* zGagUC9XDBv4~Oge`Ia++U1up^kKNK90Z)jE8-fnRx!*>}2fI;ogaVnsmVFQjBF?BZ z(IV_dy%CLqxXM%9i#VgUizi|?N=G6LVpOYSFmXoxku1S(REtz1#Hbh2p2QgyDie?0 zs1q{&5Tm5zT(GK`TqL&*9GKejE=uUB4xEY^ndF$^>3#A<`9R#t5GjR4As)9fglVk` z(YTc%Ok+|k#;put+C+Kj$(t0-a4SWa$fbnGeF$aUO1`*FLsM zOnauBfLj^Dv<#I7+{zH9aj8b&R)#RGMKvF{GK6WOYKgd&AxxX0)`VLb!ZaK8aNNoe irfpTvB}SQxMvx}f6wJy7OvntvK-kO4z#tO_F* zIl$(f3lssF2g1naZ8l~+!paP^aPluUU!qK!oXwt!-KZz*cfdwXOgEey&Bv=58p6rI zjK>pj$4%Da!{NGqzU7Qy*I5eKW4E+Nz!Re4hM)s+?za*0!EV$Xp+F|EWgkR>h%+ip zvV%9x#3(5_7py8K7s+h{2d1{XixPUO1E*p}COKw!dY?Q|J`lGuL`q>%h{vrAVOpy~ zG;U=G)0h;CaVtZZHc?)B@+L(y+)5E9aw*|)A3|BTk}q!45ElPZ^24nRVOo}Q6mDe* z)1E0O;8un(EkmUNw=#rjT&fYcl_5-PQO(D#3}Kq6S|V;`2-9Y$HQ`ooswP%#HAJ742&!>SE0CsS^RJ z=K!0x-B|==9tb0wx0#Re6(cjy!pXmx?1(aHax8N&cB76kYche2`Y52TpPrgmQmh{u z!pXpl#~*O_O?G3m!fxsmHdlzLYkAZr7pSmKX6NK3&Y>2Z?%0i-%qh+ccIa9j3*wC8 zO_F* zIl$&^cNPJe2g1naZRTTq#mEe_aPn^^JEBaQ9LpSx-KZnXnoMA$J_@Mor>EwX6zhkE za56CC@dw;}lik>?u$wxC%@tzmS{}8@1uCqQ**STMbEpNUJ9Z-{bBZ&A9lDmsf;gi% zdEKxZmCXAa5`2mLCfHT1}mpp(jFcqGn{0V}>XH$x8CB zxRoJNO{aVyZeb~_R)#PwOCb@rGK6Vw6&!FYLzw2T=z&`q!nB==Zn%{pOjA?} z#jOn4H0jBkm9%jyg_}4@IfMvRlgpHya4SRD`&L1E@>gY5+)Cm0PPS1YGF+r5A5>JsemsS^RJ z=Kz~`$X^6x9tb0ww^@~O4Kp*)!pT=y?1?gIvN>xYcBAI7+A)ERy31}uoKdzM-Z+fn zaAgA<^@Ps?y9xt-S4Oak3IQwPEW0M)hQla9RfxMIgk6X;>VR-GcBAw~)SyO*`4DH+ z39(%4MtO=agn00+ge_JTlkFt8f4%)2_;8;#P(*EkQmCw=#rjcjT*yQC6wot%)^-u(AOY3Ijh7egLwbOM-X+ DH4zWS delta 1165 zcmaFs_|}m(z?+$civa{2jk_oE>Z?>5M5b2*acKoN10%~zW(Ee9dY~+-x&%9X>O_F* zIl$%}@)rS_2g1naZB}Jm!^{k{aPk!vd!kI5Y|a{p-KaUNc1&QS?y}nuXOu06Hx8pX zT-m@zJ>j#!uEK!dl@Y9>LcoeR%dQEy;V?>272@s)VHe_zIv^a4-6(w#HK9r0MVX`1 z&n;|4%}E2%eA76U2{malWYvtON2`}qf;6=LS_G!!_7bJu7O{CCL+R z=&owyuwM-)=)y*fVY2G6aZyqAS|W6+Cl;QpYCZfwE2mnr2Iy3rElyTdY-&zcUFmR> ziPs$gRwjPgeRRVF#}HZd!eLT|ZFZfaQ#qW2WYulwxxXqKa*F%C)Q2ss{_YP~R1Cvw z8ODk9HWPA*=JxHX{8!g|-Pcsx+qa=k&q2D}B~Of;d)+gyE`Kj=>nV z&83qthHa`$9>%ckP9_Rt*!Cq;rom>jeK3ZHRz)-VmOT!mc#mO;tWaW1A{Bs3^95E}x~bWhO4rU>_#JZM)w()H`|T58|_M%H)j> z5|d-2_%%aAI2oAn_zCXT$pU;4*lnocD`NvY_N#~?agOy8b;EAd649v;qikfnh%;)H zOdxin_+|Up!LC}MVo#h=%&KA7jmlMJVFnvjqG60(#cmCIMzD&%nij-a7OCZd-Kecv z5)jKS=$a8{l$M?gcB7i~f?-CfPS#7{F(*2*BX|9Ga?536UW8ZrcB8`F z%pnPPg0CfUM!ogLk#NKPwnO4YFwmMfqY46}u)FGBU@ydjd0`e}xWeC$cq9brCLzu=C6OUUN!nEcXU);(NrhSS@Ax2q6 ztRrq^2ut%5q$hui)yAz9VX<>u7;a?<6ZMm%Ctr)x#H|!zqGEgyZe^$@Zipw!#NWi3 zn4jQ=+hTS($pyDEglSWg;&3ZNm?oMWh+7%L uw2ovvDH&lJQ;It=re&w#NumhTKBjmQV_HmV1~JN>rMd~AmvxhE(j);v%0H(7 diff --git a/examples/zips/cluster_placement_groups.zip b/examples/zips/cluster_placement_groups.zip index cec0ca2761d37e69eed5823bfc983d7995fbc554..c7644668b19f27783440991cbddb5d32223bc39e 100644 GIT binary patch delta 445 zcmca1aYKSPz?+$civa{A7EGSVYoU@~oswP%#HAJ742&!@fq=d*7E8==90 z!-#4QTZkpQIo*`d-3ayzBa<96+&7bzx!j3S*2CpbjIzI6zQicY;SM22*&}XW0dy}+ Iw&#%q0QzukZvX%Q delta 445 zcmca1aYKSPz?+$civa{2jk_oETBuYSM5b2*acKoN10%~zW(Ee9dY~*wod}TT0ISQi z6alFNVPth1x9Kr41I?NIoXHWZg3UI}L5yG(6ItxBt9Zf!HA9r$4XcXD`Rv=kMrd&0 zFru2n7GlY6PB$fVH-i1b$Rx)M_swKwE_Y&-^>FzUqwFu2FEPq;xI>6h_K4e80No3d H?Rg{tO_F4L diff --git a/examples/zips/compute.zip b/examples/zips/compute.zip index 4ef4262c0995275a9de9c83f6270859a792d2523..a1aa4d46acfd6e6e72cbdcb1f8b2d78bfb64b7cb 100644 GIT binary patch delta 4931 zcmb7`drVVT9LHO33x!g2rJG{GMPD-@-~VzIIbxiK z=M{q9K()rF=X?IG=Sr3)`*FM>s^PYSl+X~ji!P;>y(1N*TIGA_#6x*6COQJrVP=7f z19Yj^6_0V;waNsTRF5)^D%Bkv>Mw*{ml=fy-RjL{hXN&>Nby&TicY9^Qzczv>Q0=f zU6TrnZbp+!m)i8~eYp^x)ft^of6TlM9$t+$g|7L9wh?Q_>ayrWqwWmnbNw(T4HmyK zri`xSj>(n@@yp_i=!7Z$Gu(jSH;GQPFr<id~1Bkb@sQBSF-fYc@=;ZgR1r1l~&~KLKsd}!6ns0G--lN5IBK_C}++c5A zC7md&--tD8Z8>z}s_g+L_&s#~t^)0w4MKNM%EgMcdR?Hv2D&P$Zip3X@j=6Oy6r+k zBp&z2_6$0)w{f%T8DF{h%VhNzj^0*lkYQet3f@P?Cx1M8tw|w~%xy$E^#=ZBWu)b} z{Y2s$wW}IW-B0Q!q!1ElKg&qq_p`qS2*eL9JLm}{w0@1($1j(5Y=bOzqtp7PI^Rzs znU*1apD$7cTJH!%s)ZnQ+M%GkeC#;n7vd{ZRqL6!=lGX@TKn?44J)VmsVs{>jmD?L z*3LN2p7sm4O;+btv5_E`Q;(Ce{hv6)uvtey6w2rfgUQ)D88`9mPBUIzyIq+usW#U^ zdI{xUh2kW&R|@Ea{Yn8R6nVs9%~tY7j`!y~l!*TPCYb($ws$4jm--mn?Ob08HobF| z{(*qv`n!YyyWO7_wYGKqfiM(H{USJW7Lx}IY>f2BF;K_Gh?;I(i%JIL*(g!`XmB3{ z3mAHtjS*wpq87CbC9qLq{PWN&Y>X&chBMe0Q5zo4Wn)Cm>(L^;dn+3yis#(>*%(p$ z+nvM4h?@D@K{iIzmae6yIuYT_L z`+J?=xh-8>OBbgy8aP>y#P`!De{e<>^V}PWChH0QIo_z0NM(09iA2`K|NCFAEL)7z z@Vr9M>#x-K^nB01^;}8PBtMQfMAh6jkP;f?cG9KPvbUvzRGWM^op>Pc!9+(u8q6$E zv7avWs^SrjyG9uglj>HcQl+|rL;Z!YYcnFzfJeQlz9$#LvpS;U>yBEs!o#c9Cet-P*EV9!7+ofvXw;qLe6DAsQ(^I& zqD$yXp6D!@5Wg(0kWQH6F5w0QC*{(K>Lj^xxkWo*;Y?%{(WN$LCSbF}If-=Qe2yOX zu9}NNJ!5PB$2?@^?xSkjFXZAHd|FUI1zgg?e%ukMITCe_hr~cfFwCf@E7lp`!HGUR zlnAR?ekr5;7fM5gVL;vGd2};%#RMj9zsyK5qtb)VtJItf3#ZIX-!sTzP85dWJ98Q} z8noH+g#dhOVE}Pettx)FO*h)I!=3zItwQc{9s0HES*o5Zy!soQo%e`=PNW?@ha2pz zEvFL&bsMlojV+r_T(RB91iy#Q+)<#tGePLiak*HrR;~*aSWj0)mGv<~E#9x+Mz@`> zkHF*ps3DzB>}lMjddgQW-`(`jFATk<)*$1YA_csUOpkwm_)4=vBAMNQbn12d%gTtV z*BXu`yk4`S@x=Y4Zbk|rf%a331b#d9OMpOp-@2WiKz!R*czyi*$@Z;~#cpy~-&E)M zNhDJ;r0?}bsz7V)fk-tUgqrLMy30rQgMJ~tGF7yljD3cG`N!2SuUWTzs-MWxa4`y> z4qH3pIFGcS!)>xUwup@cxtzKkjP3u}u^yXs1Vo~A=X#i2gOhO+-*Q^;>e}VXfJvQq z9iW#`{$(gmQhPa{PBdK3=Y%2;*{xYhzQ}R@e1{UyA72O4U(og}C;LJ#W4oR1EyAX^ zuh2gbP;6hPFkrX(QX^Nljz14ZgVZmaBWE$G-^j*Df9(CWY>cSs#0r7ugswwk>E;>tH+^CB{DuzQo3eVwF3cjS)4sJBN)CHSdTP={;N6C{aA^*~i9+ z;$NO@Hb&GeR}Zi;qPBQ7jg1kt=ZEwVtYyf+#)zrkut@EQsdd=GRwLNG;W7wTGg8dP zNNnDbJT^v5caK&;F!$(AHbzW!W4UaMn7%i57=rnam$ETp+B6R8=?~-kA!@}FBAJpD zToWQ)AXx0R61FM9KE4LbREv@)H$oIoOoF!4-N}52TJaPJ>ze{)n{wR*G3~s51cL3D z7P$b(lyppsoCktwW<=CT!dv|UR+myui zKnx?Mr8hw5VG@Sv=Rs$+YaX=pLl#691j*F402*@d0_gfJUo2#om(*=!u@Zvi-8=-r Y25y47kg^2AK3mFJyZQ?Z{katOH}YeVEC2ui diff --git a/examples/zips/computecloudatcustomer.zip b/examples/zips/computecloudatcustomer.zip index d081c2e40e708add8b7fa54fe914fa66873bc0c3..4b273798997261a8cb65e5d244729c0426d6062d 100644 GIT binary patch delta 532 zcmaE^@LYj6z?+$civa{A7EGSVYo?N4oswP%#HAJ742&!>e2)8sS^RJ z=Kz~`Crt!o9tb0ww>gZ_hJ_hu;pC~T_SjXtVD(`Ht1xE|Cd#hK>)5lf8>PdsfEjGm zd2Sc1DkiJ*>;x-#%;Tbj?pCnh8JXmm;h{9ylQ$l>GPvg_pW-bcMp*)%FK%TBOV9Hq Z;#P*RG>E@~7-etxg9OlhI@wP^5&(NWfCT^m delta 532 zcmaE^@LYj6z?+$civa{2jk_oEnyFM8M5b2*acKoN10%~zW(Ee9dY~+-y7WMN>O_F* zIl$)KNfQB?2g1naZ4P6!VPOVZIC(0oJ$4l@SbZ45D$Ln~iLz_*I`%B=M(J=YUl*ciPdeaY(OV6umWKa69Yp# G*nR+hOjWc1 diff --git a/examples/zips/concepts.zip b/examples/zips/concepts.zip index 6a63881e5467a8431d4e32c4d4e9c7acc1241d74..a99eb0e747fa9670359f49c796a0cc0d955412bc 100644 GIT binary patch delta 873 zcmZorYf$42@MdP=VgLb&1(PT8YN+H_r=%AGacKoN10%~zW(Ee92B0jex=0&*>O_F* zIl$)abQS@b2g1naZ5Cj(W?}|fIN6Wclqi!XFK2eZZq#q)yNqC?ZnN59RWVtY?FU$a z2D=Yd1)DqADcz4^fpNtF)imVI_Mw10OMJI3I zlANr^&4b+nKW;WifQ0j!VO24CA@6#yFM|2Zl+eQy96yXqa?J3UoV=RP3%4@3GbfAl z2jW(SFs+N<8MiWoY47>{h*1_V;6seEvjS1XDDxDw$E^(Eg;j$7xRoKiAT1O|jIzl> ZE}B?lft3vy84TP&xQvB?!G#aR0{~FM%5MMw delta 873 zcmZorYf$42@MdP=VgLb0{dF46{{IuW3H z4zPJUokc+AfiSXpn*|uHnV5kVPWEFqCCa49%b6Xp8}*y{E+g2e+pKn2RZP}p`vF#< z!R~`q!R8M33WyQRoQBv{cyKyFRP=H=8sP~cxX&Xe-rctBCnE!cA}a%f(PTkR(a9UQ zBq!@}^I*5YkDCn=AmO}bSXE43$h#iwi(o!8CG_wF#}6Zu95Xy7C$Hx7!mSMM%*o>X zfw+|+OzYxz#;put+IxOKVwA-T_zc(M&1B#W)?065Rh0fc_OcYN`7@pdLa;(R&X;gvb?*W)j3H(u@cCd@ae(gyM8#@BFYGEf zg;bcqwit-wuw{~HAjBQd#N3GUbbvSxPj3|8#tybDOWuh%qb|sMVt2Q$LJ1q#s3mGH z#2Lk-jw7J6)x%i8Mjg@iAkHWQ9e?bunyixwan)}lOYABxNK_0l$|glc5u=PRI)WHw9np9!MFa?244!a91V~K` zo&Z6Z_A@4c7`J7|hT~R-Fzrcf5N>4%w?)L^i3Nmdm*c{SG0i(ZmKbHH;@xp8Ls)8@ z5QC_`9!Danl()2xzxHL>P; TRyI&kBMpR3JPZsG;UFFWg&F&e delta 2100 zcmdmRoN>c(M&1B#W)?065O6f^p2%yUQfUyGUJb;h72FJrEH9ZE7+C6ovZ(43?e+1f z69KB{0GSsl$@l4AE-M4W8_~%h#S|t*@K5~5BLdP1!pJskmSe19Wd>@QJe$n{pBvz2 zPyWy5i`}RM_9;wYqrP)`V^EaQL$Rk3%d$V zAr)q@Ee4`EY?&k)2yw?VF*o8o9UzXw(;LONv4btkl6NA`s0;F**xjwGP{IZ_YKfW) zaYpf|;|S<%^)ME&QAe~rh%?GS#~-_^ChMd^T=mL)#w96N}ipe~Fn*~AH36xD?Kxy(q z6WPgc{dkG9UC!SgyX}SkpCMjN54Tf7&z3;T0=yZSHNw5dp#$gD2b&0a6o# zCqNLU{fr49#%@B2LKKyNyGpE delta 320 zcmew-`A?EJz?+$civa{2jk_oE8mm+qM5b2*acKoN10%~zW(Ee9dY~*wod}TT0IN%} z5dowwp@-_RZO15wF9icm)lVZ-F&b+7@6dl p;VzlHf!m81WimV-#3*ay@z=y^DJvV$ZUz=0T*b)1V8;#O0RXkuL(BjG diff --git a/examples/zips/database.zip b/examples/zips/database.zip index 2d48ab1eb51835443382125dd50daf55bda5fbb8..866d5655df7dc9bad3b58f1624d2781fc0393bb8 100644 GIT binary patch delta 25913 zcmb7Mc|26>|DSX0J5h*amo?e4lYL*ZFEK>c>`R4)ltR{#Q=wF3DJ9aNR7xpjYtbTG ztEiB)k$z|9+-sVCGrs3`U;etE&-?l8&+~kq&zb%f*3mnx91hlW^sE@-KY?<50mnMY z$fSUvX!tLF2O9>Ue@}~$xK4NsLw~FBmVt~ z+{g$x19b4x_${E)a%(Rk;m?EG)S-TXRR~lSy(V>vS$YO~(qi+>>eMMrSi+cy6wpjJ zAc3D+#UbnBj8a8B8_y={pje*$h+q>d45(A+@gAfj33h)K4Gb~={@vLt%mc zAlMq=6za>K6BcA4X{#&_NaLra1krgwQQDe1-a+Y=^c=ADJnp{C-_`;9-UdJ2APfWZ z;fLk8sq)~b3;Ri$56Ih6C1~8Juo5Iu*elUk_MFlY4ibfxt|e6r{P7ln#%sD?5u9cN zmF4tY$_6~Ap&2^D9fr;%!oQ>YpS&T*?zG`%ssc8;ZjvR%9bW5|B)-p;1%KW`V7ax) zkdqdU)FB-#w;+)94m#+dxE#%?LxnnyB6(Bqpa^lBfoy2g9)H%=j4C8yMjVJkk|M>O zy3-n;yWa*liP2OyfcTa~1-PNJ zNoZgobtpn2C%|3&*_T)t$=(2he5jMh2Bjj=_ceqDMQ~_5BT2T=C_m~L$6J``@aGLk zRKz+U1JxUY%y{J>M*QzM#{Wg%KMM?4W_MVdoblSk~>f zLZJs-dL)X&0akop&i^j9Mz`m|&NRjS4{rN$&2l2!2a zmH)*ktz|Sc;ySh!5ib5X4YS=jeuIIOKRJ~&%r;W_h(u8DAX)f|RX28POh{B*?0VEY zya#)gO!zjqsE1-d;Ek&UsTu(vRTWEG>ur?|Rf0zK>UD@h*cuutH`Nr7k`bz7 z0VSYRBVYx7^ep{gp_^3H5<{Vz(=jmJAGkS7&2opx^TouK!#gDZv4|+8a^C<9FDBz_RNv0 zVU~(n{&Q#Q1cF6Mjnaef5Vg67Xq=#ys#nm619cpVL*R>-TFV^($QzB;D^n#jHyn>S z^HzU7dJM)GO3ecVAqN$J2NLxISMvXJfB5@w*a*J1LN-eKaf{_-A)hWTkK0pKtx@Ft zCT3DX!@0clPZc@=AM1%SFyc#RxX>-pJ44-ijjEqjSV^H7ykNW@l|jy|P2IZ>E-d>& zXlx!3Sh5Hs&To6b`ly)5gph#17^S#vOVRhYiC|T>6gY;xQfBWQnUyus$>kV$eeT6W zEZ0!s(8_c2-mUG&_JqpUc=+=_`{;W6>ip}Ag5lDdSyI2}?)h%joVTvd>@AE|$?ziR z)rV*RJ&ze|aCSJ~8@NKpCi>v`w*ofPsqx!A)6mORtB>-o7o@naa$avi`UPX|J3aE^gZujj7yR6?8*(Na2F@A5p?Pb4Lw~o zTyDP>k6#(QaB`vI*ho>^*Rv1vvd0oXz5Sgv``N!w*rL|HFw0)0K>UWu+l$fZ*Zq(5 zPQ5i1xoKMb?%BhK8#eij9nF+lQ15=7nV!b-Lgg-Z+=?fo>kpQyNbIo2M9DDj_Ijc$ zXZg`x!K)>xL88W~XW(>Afc0tTOq=A+R^`JgHI{pm?4^0MhW$cMnvPujcIW*D38^#% z&-m)S<~T*i=on$`h7-NgQ)?-XxgK}<4;{h6u2lx%3NBsvivt(n7w7jsTp3?r8wPIR z&X}5)XFRm|#L)IinG;O$Ph6{4)~?c3e6{USU$>cbjjPq~B$-L3HnqLVcWsV+>#ks_ z3ow7P(W2xVq8Q3=r;Lf?WJ{rG!t54p#I#LrG z)1k9DI;U{vxlm9iv*C%(r{{ZWeq8((cei^@+6edAaF6G0=LYIcuN5dh>3qh2v`({m zkN&E)NdZ#&IYr}@Pp6rZ7929>!xM}EoXRvcV)X$M=9+y}9`A;o%y z`itrMnT_!YCJN6=ivqTNxIFc`BQSlF#6eBV-}58AiB8QwjjA)x7lx?po4+*q?9m|R z$s3OQBfU6-tNYZqKI1Nb7;+E0hv}@`Ljm^JLG{6_1yppEcfO>1{|qZNIp}}rxOggE zL;J~sB8QwQ`;uGl_}lR^%wBtHw;%l)?9H(zqfU5da}Vz1NBUPBFZ^0`#KY2>#5e4# z-z&0L`ny-3K)s=TjZ)E6isY@+lB3AFMdYp zd>FY)NK%s3xg3;O(w^ium-qO)4%fZ&Kjz+U`yy=lh%NJFqiw|j<$|5Agj4OIWr}Ny zcdokWay0P$?Ckrr+gQYy7*=2rbdrho-XJ0*oyO8ap#15(&J(?`%yQL`)BSb z@AvBu23~&~@t-32*ADXM$Ue^f>GsB^N$stRhoH>O_ChwuFSz!gL>)NLbwX<7M4YTy zmGjQd6kf?Bl^+{pgHj~j`1!O{PyApM1q0sCc@UNl$jUKHaaD;ASi$m1iVqd}qMc-{0D-@Zq*ozf;^A z%9z+}_ehL%YMFoYd4I6f0DM*6)22Fg@JrwYm-jJ&cT8g}Tb~S-^ah-DF9iJd5GuuM z`u8fX3Ms~^&^?!FQ;<+H=4Dv@h_QL9d|Gva<7TL-MbGB364O^l?UM`=ueLDyyBe-i zx%WCuuDAlbZQuE>BR4k|^H-1Zwglb%c}O-_JC@yYYmwh2`h5Z^=9;Ps+g3l-YLt$=mfku^QKF5=#q zQ0u0GEXA~mFI;`jeSseqd?QPk-N4bBFzMDC{R*YJwkJa@Zi*f?eN~Ws@V(XB(a;OM zXM8W{>Y9Jp6Y@*W<Z9>m%Tlv$o3+~z2e>) zriLOj4Lfdyp6i>NRw+E}tGG7h7rwG?L}AZ&%$i$gRquLF>`+b$^`7*8s2=|9(6G=1 zbF@+NyH&RmBZTr_9{83ybztM!`<$&$uk1?d{yLuaAYMp&B${*D>&>h)zu=(A_V+yV zer*~;zru7iuke*-287{^&0gKD-x$2Js&Fz%{6Hepqg(1*x63^5#w%?FP9GiFwdL32 zMytt9TP(M)j(e}vekSzY+9zt(yxf{8EwA&Rz1Z}K%Up9uf3?A3CO@ngz4o{Cp$pP& z{`+3-68Y(r{zTCyZugE?1_9G=7j~IutC;P$SGnOc^hRIf_ocMQ+e%yWL^N_jM}7m8 zSu#O4rmzLhl6eOFn7j}q$_?<5Dq=)nTw-KQ*#D@9m4%VSdU$)}os)2gpkjE!iY_0% zuj1PuDAgT#@4+v`>y-`5kP+ClkmkaDtJz(G8RItNGyMG$(3EKM<&}Y;_ilP)@AqRTg21| zo9*jl*l9VZqg^h>rB64 zQ*6UJx^ivxW9(*br^ZATI^SdShezC4;;gpq?YI}Q{*CWpw&Xq5M#s`3nmpBoo>!_E z9op-EDof*{aY5*hr=Wuw4u2=SMr4%j;^nf6lDI;<=f7TX-tBYzthLHVpj$|zu<+d` zv#{Z+950U+-hKBsU>6p0e~3A1`UPfO%F3v%t8!~{Z27vb*?3i04sNf=h}1jj@@)kj zKUi(TvXx>=wv0>8lq5XgP}A}(z_lMN<;X2J@|@mvQC_@)GR!GZTM~G?-$LCX%d!tck8F-&S_-Ehxy(fc{0*}EU~S# z&A7oUh`n~-KqT%$==y^-iC=wvw$vV4_eyQZ3smoU^L$tT)87+wRfoEujKuvNs;V1n z_3ugAj<|6~RS)pl1lS%fOGuVn=p3vqG2gv7XtJA*GFl4)gXZqSd-zehe@|L*enJ0h z)81F`Pms<#y(onX{0H?9F69R=CJ?SS7(V3u+2wtn+gYAJ=6zoKqetac#f*fAcfJp1AKxn1 z$`4>FJeVYCKjx#RXMHQ$eX7xMC^X{qGQt5=JA!gIrG5&+V^SD_q5eFX?vr%+NjUpwE}y+kMp-Z2 zDLA!yG8xKj=ylw4v-P7w>z@3dcMqs7$V%X>T8C=Li;}bKE zTwB$o*(;7-@;^Vj-J%=JsT_TBE&N%@3_qJ4;ahFZ6XnJ4hnr(ReGxwSO4j7%L?$B= z4okOD4-5ucU;xlv7olKAfcj;b(8CDGA}>Ebxd2C0H$y0r8=&4vh0Y5CD+$xwKrpGd z4tWUzhE%Vq1ekC)LIZbw4ba^p6DpsY2f+zoK)Px`-N7IW)GZEB?^2PU6`){AfO-p? za90vgCp8lwKpLR_q(s0<111Pfl?*_=jY0s{0pCd-M`%G2Fh^&^ASGHZ=~nvZK?E{U z23)AyuTB|AL8MYt0jM{v2}LS^IYKk63fNJ{F;oN8kXM9%TZ^lpdToFKoes~mfnch* zkc$q`NbC_nY`OsTM;$0w7icDRroYy8-7JLt`hXrv%Y(ZEaDQ_ZjB3B z(%a(PjF0mV_>kKIzb(o`hPnVfO8V3ylPwLP=4FN1dv&9JTpia|e z1ONz4k1-7zNXG=IAgRWotPw&yVLV}mde6YEpn5}CztJd=1ClqTC8&cb5Q;P%+spy# zojrn}1z?BJgjxaAyJ>`8D?ksS;j#s&xA6&BTR;(^$+xFL1C7}Oy`*+ey@LdVbq9F= zLyvIj^%r)pGSuz>tb@v9Kn_}suzx#%kl|(;rX|#E2JA>}L}<|kpx!P^x zfi2YCc+MTrMsOy*XszY$4ZK0D1HbC1qDu+LmsZJ}^ab?(eTF5zbMd0@B|}+3G_r{B zE(owjTH|90MWcGKopV9>NkRbXO8~`a*_n_Z3Roc)8VUobzmO7C!vPUCQVu&O0;W{0 z2-PJ5A4w!-JAh3pH13$hW6YoX)>2y%BM$Xv0aE|L4n8|+Wkl;vpdHa@cM?GT)rZiR z1ibOHpjrZeh{H6G(K=KdIR@NEBn&R6b*Shp2TBox zZ97FnM5yZ&&_>cCs{%k?xM>VyExigr^A$iGRqGSdD}m?82?d@OFhp0%I?mAACsob@ zSHwuN!NXDN=+LZs0P3%BgrhwG8)A&=K0skPw52Kn564JAeN*s;zqTI`S&oHl9KU{A z#(Ccl3?iAkbN+gy7W|&oZUjYs1J*!O4}sORT4x`S2oQpkKh zlT4pTBE5jo=_l{w)Eeqir5ClWrEPV7jYLWb)#tQJYq~u!3{r6pu6+C{(rw;vgy9w*ZA}8mp)tC>2IGK2#8DluWg3G-#r`{;YQ}m=DV$h;Ln$N*5 zU9f4Q$&7C9u;mszMZVTm9QlVg$Bm@~U9#;{Rtw+O6IAYTX1Dhl-~vCRw5caXXD8=d zaqK4(UyZ#LM_+J$lEdZjZIFi!t8M zSigq-mc*q*9Gmco4vX>mBRrp+@H}2Q3uhm{zHKpUQ;ZdBFHQ?m8@(T^HO=PF6NWo< zaB;)Q-x&(!tCBbBb;_hgRm&?kVlNA_Ox)e{^kJ>#$+Y!Y7XO=x?mW3ETayCp3S>@o zD70XzZLW(+(J{AloS3-cdH?9?jGzuq+5KbdJ!ji$Quejuj(`4c{pRe-O}fSB&p(c> zT6v)OxKq&s+^4$_I^su_F5aqD#%I6HTDfk4yTr$E%ziwJZ{I+XN|Pv=8<9>7+gmJS`ZGuKYFVB}=49%Fu=P>(qP$nxj@RtN`rUq9e7K~8 zQPO{6#m&=U`+(9cQD=ofS--~&88NPw4$lkhJ92{@lc1XwtFqib(`j%0l5j2}`CbQ~ zbsmS)hGs^lW)0g3Ho3N}1ltc5*9lJ2)!mv0x4z}ia@Wdh{rLnJ+~%a;QM#hp7|Zt5 zj;~*S=Xjf2-I#&3ejDK7Y*^^{{Ae85ihU?xlU(@&Of z6p2V5Xmlj}=D~@0=S+_}t?e8g^13hn`o|-eD!Kf*>QjW7@{xH3k96#ypZ69cjj}qP z1LCd1d9CkW-3gUo&kw^Iar3Gz+#B~P!knW};`5>C z#J(pdZ!(yyh)xx9v+S7|HXM9E8Ps+^fioI7!#XWwS=(B!%#bdpyzpD=QpO2~*H1SJ zuidP#xFPVCLdD*m{cbKMqibX#+f`RDPBgi;e$;EYc(dzKn5A(+YOROr+>2CIX)mcU@R%pG%hKb z)?`s#=<&#CuN;Thoqn;AhK8bm^SRbHwtcMgeS3O@E|}-|?j+AqN15R*EkEmLd#}nr zQI3o<+^3db@@wS%PZ!nVS{BaA@p`A; z5Kmml4B98}zdtH%XR&0#0}s31je(qkz!^oU1sxYXxpnhf4X~YEo#h%?orhp2MltT2FE)==SP+_i)8&d1b7KoFcRyT^Tvy{q!W*;3Yzs zgVstNH+fsQczyT1iypg*4hg=$H_f-^{Qdm9YK;L>hqbH-shZ`ZT6o;HMc+HW3V&bH zADG!u@ol{UyBR-}_iJ5{cCe2D#PHTUr8rL_<-5#PVc(|9>3d?=-T(A)6HbZoS6=#8 z!GZllooDmfO{W|i4ML}~wVd6;Rd0PRIG#Nub;Egbvr#P0tAdcuzzhQMJPEY zZ>4KeaU;6#48B;rBg+vG^U=X|W!J9rbk9(YoYfC;vDD&gx~N+A!HkZhefp*Ij8tpo zoyv0YF|nP=9o{C+XY-8KX3FxEyVK*gTQwUhsxfp&zkcRgH{+jZ>cdnHX*Oa976-~i zhGhvw?MF1epBit;ORmHhbrHY@zf7g*V9KZD*f4YfXuwj)8NFJ7-{JmxJi$#d_=<%Omb*vp>oTtqO_ zZ{c-2_h{ZMuEqa=ip_ey-RrupC7$&;IyA<){%K5?^uvImutlG^n6SZF(bDA8tWUpb z|LFSpIXAgx;Gra)=Yn1w|Aw=xcllh$>DkY={IEOz@OAWI1NSj}OfqZda3hn7id>CR>piWTw#)=DM$!aN zY=jsd1pmtgKJ+6%eQ=a8{PExG0{kh(Ms$iWPt&-xgVbjL>N8Y?vKgQsQ8jv& zR;%LHEHI7GG|vIX)Lp^#71)f>1bhRG(8=BPjn<7q^E*(2T&xD>Y4s{K7XbM7MQkeS zF4A(+kwqY!B-J5ikou<|P0rvQMDDd9sEtnU6cD7|03i&3;6H&wM-RGDw^Rf@*og$r zi zOl~d2X@fSj>ByijwLx9lbYwh39nb;|U9ApihK6p1E@(`fjx3+fURdcuU2q+3VzQ7g zbU}MGbhdh+EgHHjdduOFg&ebjg|yHIRndT!>4Vv{>ByjU+hEW@15kxFFA?SsMPJR=*bx&^s-Du;Hm0oKE8ls^~GXkB_(0wxk{b|#Y?U!T>VrkQn z<@;p}I?<*hAIU&h(r_DhJG|C8AfPu8>$au#sz*sbNYL;L)8oC=O=^U)UNZNR0r@%GBjy4@x z4@YZs_Pb+^E<;Ui(BWONS*|jW^&picN89Df5}84-0niAi*Q7@?vNvBjYbcv&7c8o zIy9hzIH-pl&iOE88I-yer=Y&p~Pfp7jkt`&sfF?SlE1;du=yE~d1++w?bdAe$ zN|S|L?Yf*YWFsDMT`mX7bf6o$TAbvD4sXs4^hBd?v^zSyNq5i{4c=A{&S(jn#a0>Y(DWv?sK*HKgl=9E1eRR0wiR!;) zY-J|ll1#cZWxX8eQmDamx#WN9{|Jl0aAQ7hnqeh@Lbw2s#{fm}SiVubBn%HIZIXaL zu%%EN%eI8X4xM8JSe7*;b=h<%Wc$oVL^MJpmfbo+TNFGaAt#B!7*U87w2}y-2XSo! z*=c9xQd~oN@TD7c5+O24LAYg^mUMuKM`CcD48qhG3^K~NI4|cJ@^ZpKFlY83oW$v2 zv@tm5;K98PPP&WmA7u<;Wy!KY!$BY~8Y6miUEa76hFT3z9{n37NJ{^Z`vcA^800}? z$=qOAwc`p)oGWO{uw+S!NZmjY4PR6su@H0>Jt+hf0(>E{Fi;J;7Xoslk@gqN1L~?1 z*HDFQL(y4Gs(-~TZP-L&u*LK!!cJ-enWro8{bel*kL4DyM zH*GhQbtR8iV=x*Nx(XQ~NbsyR_p-V!fkC^s!|q-K)klKz#93>!_MUzk;o}55Pab~M zG@+1TuPIRmMd*$pAcWF+$KLSX`T`f(A26UX1(=ID5lj~vi~u>&*pn?1w&!gNB9jgz zU;?nClz=?e{kJ;LEs0>LZiXUJ@ZwE2M0zC<4ko0Wo>0R1ES&J{kMW6b;IAD zh@=gDi~^a_AkD-Kj*G%b4`C!33M(>gCf1R)ke)4SgS7u(4Z8umgbkL366}C8bRv4W z3nMv?h__4dj0SXecfjL=S$(+O~b5zN(0yxpK2@cAuTz|)srrQ#nFtj!n zT#Y86ykcQNzIrZk@Kg}(@d}IZ<;S6W z@gQ~}K+OOW6LAa{we_vzVa7Z%BeXvrTtVAfe>q$t{NELMq2KW!1De>4(~X0F5C-v@ zDuuE3{DF2o2z6OIo&c+$7>O7Ro}8CNBZbywo&7v)7>tk^2BSbB#p9@dbrMEdQ9^i4 zv7>MTy=K5*)>B~FB>#)W3*AoyxzHH)S0b#=p%g@&>pK9UW#fkIkcb^H-_L*eNR#2` zccAmgjmxXEiAST0a0shV$nUxv5d((ffdqDfe6$rHZ!>oAFg}=&y2QCc-kOR9xib%UoXikvhRcW${#~OCMfVf79%qe zyO-cJ!bJR*Wci(vT%3o9i+K!?79;WrLh>1)8k*cCe`50Yso~mFA{_ivp8Wv*e+g~M ziP1mXgFa(K#0^l^3)ClhGxo4&^l%E^hX2GUN{h}bL|eOIfCFU^kizchYlIITIu)cH zt7Ow!9)L}|_z%YS!{XHOn(!Hb$+uF}id-ifwh%6=-JW~bkCeh14@ zvB35(h>*(D04p?d5Z$r#&tJ8qJfaKFEy3}lJml~)e&y|4WvX5%Ayk(ez6k*ZP*c06DN#OyO#wIbJmbKm)~;9a;6aZo^X&? zBn}oYbHO8*T2jxnofF|yDnfV1iaWYGP!zUpH*8zVYrh275)vm=TZFFmy(ogEujl@Q z^D!GJiq6&$srC)>5}ElR;>hy7NOjCct2_IRmmqj*) z!x7jRwQK$mq+0+)`?y3N!p30!eTjiZgCBVBi2Q*F&t{`~U(r7b%hD%>a7G?Qcc(N~ z3W!%^!eHJCV=#&oJ`s}nLk4|uaQSx;vPoo1U@^`s{lOejvRtAsd6nX2O6wn4kT+C} z1_=)SEpZlTs07_*-eFDjTr;fMych=KPoY^XC7KAds}xj{rTR3>0N)$o-*JKeOAo|g KI*Hv!%>Mz+ST3Rf delta 24603 zcmbVU2VBkX_rIT~y-RziohI$H_t4Z%i;9N!K15eyh`w-;{M6IEe8T0}jWCNB%Dr9en!}BnJnZ0X`)*9K$>u0thE78Tq8C0Ev$D z`zLY>Gvo;|AfgF@Kx01Hb4Y|nU_={g792vM4lx?grufLn#7Gu4!>UW0!kR6bg+u{Q z_d;@nDIqQuFHejn5;*uQXoH6EZAKM)y}*n%g$aKV16i?~LUb?|3hzKwKPzsI%}`|X*q8^jpCd!TQZ-abMa5$ zHn+t_xX#>@O!#*^|Fcsl(fZEZgQkKl-WDooq|M$(A}!vVozQ46GM{h?=7haFZA>?Z zKr$ww$!#e%C?0n^+E7vM!)UxUxv3L+{Mr7)J~--aOB<8fCmG!b8NRevt!2>nDnyQ_ zWBno1mJkm21MZXrqKJF=2@n1GXv6;WcST{{R#?)eIJm-=l^iZpVLsUW5)~d!8;Y35 z4e?fd2qxu2%8Ed%gJ_c{t#hR!TX0mR>@u9Ra>dvw<5E{);s_(EF--#XasN6x7>n0`LIXxQ(-DIm*A?X8kbMw4 zp{MxYbL`v(g-aWdgXcFN%)K1&{yu^JbtgvW_|n$vL5?uGYu*mvn92t*xGX1rza(sUMA2vH$=A!0d7);jy!l# zc?8)}dl?B?b>f7c5>`S;1)Uw0`s6LT+NqT$wCyFO*Qb^Lq}PG!#Wbl}Bx|h5IApgF znhyLIue9!>V-Zj7Dpa|YIy!#4R(Fw!yrqf{(DobQ>482nL6e(&`53!#(yGMB_~ax_ z%xAqH=OLw-2qf7@;Rqw^L=g;F-X91F|5Gab9gBqcLrG+LFAgoG?J3=QWz?vU20CV+ zYS>2JqwsBRAV<);&PRB9l<7Z2*^#4kwk6xKgN%Hn2+_^BQrLyqg|_rwGC;FA*LB+26baC41g#sKs1I+@c5=(E8v|(2th+@= zP~R<12J-H2l+0ndfjBLf7k1BwM3DFqAc)Kc8edr04AP8LT0HV;qFguco;yOcoO5^$rMreiP)pWN3HJz zgR}R{^k|RumQU24Dp% zmWD4FxDwRd=KJ*}tFzzPvE=q`FYk0~zFcR#K8^Khm(u2!Rb%pUtirGO#&q{Wtp_e%rjOOx|v@whwkOm81`ITXY))5!T!|u}I0?;cMZ0i5Ta-H3v*p$5-RG zwmeTZ{U|K2vZFspvgq4~)Xa}RUwpV^Ty;kyPO}j<)o@Aj&k|;RpZC5`$w;_7xO8hu zvX&_Cm8wCj>K}5(rfgj!19lD#XG#qmLZy|@PrJbn^nF%um8!*c@mh}^H#~CPwBniI ztCca8WlXm-bYCnzs2?xJVrsizzfVR=m4KJBR5?Ftb|8TqdYj|+ts1}>zL-U zh`kl54{zoMuW%W6ia&qjdGh;&7vEwb`}FBs`&rmKy=)6_i7@DPdVk=^ceYEqk|3!r z;E3;jSaFzF{6anV5>`KbuZh}CQzrvtpD}yyH$B99E$^+Cxh|j3!_w@ieCRUUDUB`K zoaVEY(b?ZG;UaT1qs*9lIaS$q2%SvkwOQ!xadzuFp?jQNWqHF2;f4pBlyV2X9$#S3 z;k;gOufG0+$ft-%mu2sM6x*}zw)bNX_q5-603lv$y}F z%4^NI2&*y1TdKnwj1OApEV|4eb9#lX(11~$WM9#u{qb(sdeYB`<2yJmKxX=nS$92c zJOpcB_Wr)!=4_V7MWe5pYue7$lyLhirZ7Jg(n&a@-8h)tnK$xWwEtqQ@184nBU62) z#VZ~}wBSqQB2F*Nf0O&7J|k1X$+4{dVQ=nW?}_{&29YH(!UJ7lgwF!ir`CLS6PS|q zQID&4Q`Yyp!rwclf3>^au`>Vucju)WxlY_U7RA5G%5|)#X_?K=kzFo&i#mduEn`ne z8tHGER=umHYkgX>UbXgW*cvLWHp{mvQPV3PnEHyzX6kEFqJ0+-`%K`VCX|UP~L}*F8x8WJwhM$WjA~e$xr;&ujBvoY&5DTETDa8S~@U7~;2I zm9c2r9Or%|4}Z8h=lcjt>vA6!NgD}OXNfw-j!nA0axYkJ4e*z@j^+q>uh_)su;{qK zazD{ZA+a~d1)uEViH=H*-*dI7JGfc>!jW>>D5pJQ11SWz*(l%odwZI;9p0EE6dSVZ zRZoUqX0yZfEjv6m_bFDSC&w5SZy450%6C!w@y&GcHy5~`0sm^Ngq+5&(!fh%Z4^d&ohSWIrk0@K_|w+;YZlCh<$5r-5&))BRmP&y8zE zrDZLyYS1nIFyVA6RH45`Zwu#RrTbBMky@s6x7U{2?bhb#nf&Ztx2yAb+@Tf`?rHIv zl8_BEyv=KZo^MMEJmBfG<&?>aFWpZ~2n`p%=iW^Vc1Fl@lzv`IJ;Y<2ja%-7jF-opS#u z{&i2WpX>ng1-0Xq%)h|7#MZSx$-@eU!J@S-w zcF6)&mo0-{`J)ZR8l6RbDz0)X+){XKb4FH1YAq+aEYKIsv&msvJ%0Dw!%tsIr*i9d zT=??htzLw&q{2CgDTQ@rS53tOf`uH;Yi4HJ;lFNND-*Nwkt=(|o%|;KLjT!5HJ_G& z%U?MR%y-saJYWBKnd(B#k11Mi6Q|Ceul|@=Z*U&&nr z7}AF9u(>Tpo8BVyYC~x66L!#rylA?OctRJ-fXKHsg}V!`7$LXtg#aGe35mdE91tJ8 zTN~nrll39mwSlHhjY9ZD7 zFs}tfyRi$ewSdl$Nt7)i+8qJn7E7oOHDHl7o%JVfv4)sYnr$|aKTU0jziglo)Qz>z z`LBFJ_R%*8cJm=$dihB9GQl#A&;t0F9mGu=;f@^yp$He<^oC&sVU`90A1vtr(Y`^$ z<_^$)vbp09^wjingrd-f#*5Jy6$_*TGQmn}XrLO-ETaQWlyZh#(1t{uD@6OgOzd-o zOi=9iiH}~&AlUbq3E7q6gyCJRap0s8p#oJSNgxNSj2D-NF4>}{Kg)A5%B;A z^cw(nT@N_vb-Lgep3oh#+J0Jiag{AjP*2_MJ>ZFY=5 zs%h^-whz)78d)a-OK$}HutqxIrl&M9C;%FP$QNRUtD5!dNbf?52ZytR`2rwiINb+g zgO8^Jak}g+fshfog8{z_p{HG7DD)g%Hl#(Yjcv!(gwe^c#CKtk3Ho}3xEb414_q2U zXLAzY#6V7{Zboqs?S>R_M;zpc?g_)TrJMOUa5!;Wxa{SjK@JPQjgSpZ8u-LUXp)@$kZAkohj54R4}Lcu@ciz({T;0cG4<;-OD1H1t>FB)BvMW?AY1PrQRj;hQ+8%TwA(Pm^O;a5`bH%mDEes$!aT99LlpG_!pa0oX9E_x zp>jV9GD8!Xa1OoQyD72*#t7_;TS=9L&dK$~^ zf;v%+k?Sb!rxK#UZU~^uV6u;1(Nen)x{0c@_5i)2<>mpX29*_EPe&j4PCe94RvCFG zbHjq<=Gc8mZ9X)rj;+mnlygl~IHI4PgWmQ-kI)k2m(5(Of&u4bpA}N`Dw;eCz0xwJ>bZ<#d%7+E&graP_LEn~CI_w4bTPm`(_dZx%-f#ZwMSg;tP>% zpT)NE9^P(48~Eq>qNJRw+pg?vugMnL^}=BvbU9OCP(XCyn`dpl*UHvwGlgfEuWvn*c=bRus_tT0)iWCnJXh#a5l7oIcovC0 zef9#3XZiTts`-xFb?AsitqS|9=hR%b^2S9DG4>bf;49OqYrS!T`<^<#G~?rFV5nRB zl*?W@@U_EDiGf&)ixC@mr<27B*9h4A=EQ&HRLvP6K2~xnl$AUX(ZF;eY{4c^PMK$X zaMb$ZO}bV*nyjVuStIB1Mbmdqzt`u?bRTUjUVbeESE&Yw!+ne!w!u&=R zHr)KQH!q5*Q0C%kX^(YVjd$+R8gx{Oat*n{(_OT(^XCDP)QSpU*QWTrHy?8- z@^-yeH0B9)Y5RCpSu1>H_ANp7pw(4-BDiGqh!>jtjDI}netPR!5_i}syup!NE8mKO zEW*r!1A>v;GG${gY`uFhUeaU3*k+B2Fh!|Lt0NZrR z%+p42EdQNvXIhe?%4%?RF~=e={Lx&y<-blDO{H))k2Bup9RQ~ZUZ4D>Ukp2sZ}>ja zKKS%e@rva{*X-7es5cVl^v)^rcRKF#uE&QI3uE1HQWo<4Nplf|#S`sZGc{Cu}E{>fwt|1ZzmB?|WrWvWbG$1`~- zCbNB%H)v*Yk$Yp9BFpOh!E|>(O*8jd%h$C{gPG6-cgXB3l};nEWnFE%KX2@n&b*8- zIj*$s(+scDu!-+Y*=H<$_dL8_Zs^r+Tc;!Oqro>f>`}O-v}KKkqrl#R;|B>pujot< ziZDE5t}L^*y~48X;P-*^Rnv;mi`02j@Re%Xnr?y4w?ZG(BquaJs++d6k`vO9FSN%! z-lUPJ_l0?IsK;3P+3BPL7T^0>PaRJ*GO#a?uV?T2RhJYkQW%zv&;9E5L9{_dJa&&x z^5TvmJLaL~8y>zGiEh;R+#7gj+bQX{x6YL$3NT&U*ZlsG-Qc>2$o(~a4JW*>8)jN1 z;iV5VYw>O8+LRz|efMeS8Q!w~wq;U6ptdzfN;#wQwpz2*QK|NqYO;G;7S;E9^*QFX zat6G*t5El$)iW&4CF2F>QdE&@wX=*vF!*vFcQ~r;fd8|VU~pfyaq4) zc=ao`+~OE~vUx!ox14Uu(X5=>psI_S&LgX$+3{B@G%RIL7*{=pRr)5D%S#pU)o$$X zcv~QPvqfM-$AaV}qv}b6T1{W&BJuFuObQ#@D|+H}3VC z{&SIM@l93=0!w7ib_Sk5nd#vWHO(}0OjTacT`wYx=aP2viN#j;oo~83o4ts71V*zg z1(y9RpE+MXqx&l`DQfi9Wr?5+5oe9YlECdr{AzJQ^+BWVH$Eh+EWvmB+?$BSdoJ93 z^-U*xqM=x(M9Q6J!?)5cCbn?yz6gA;i9p&waPSp;#l)d>?gN+CzwR&W7=MzP=G}7E zBca~(91-l?yQwO9dCs$|t97K5e6&g%@foE<7EE%TY%xzi*5_NN9RA`dI+VMh&FI^T zT~7TXGIFIqUEZc7v`zAr_kEN#l4NOX^;5SzE~3v{erl|BjkGgIS0b#x;m)9^Baasm zKI?SDn*(3m`M%uay&T6dKejlg?xuI>d8baxz|T^E!dx_rl_{mp+>x;wu<(3VL0@_;HjtvG}K! zXy9n3{+E!>)^F!LGd#A%X@@R3>vq4}XZO*JGihRii&XG9<+jcw=C10s!}Yc{+}!tm zhEGLB1(n=zYt}RnXymFsUQ{)n#8drRt$YKwm+z0}`vd7UqpzV2-#}L!OUbs^&E;p7 z`I<}aXRk{B(V6EP_<4PFgu}7@>TH!aN8JOWL(^|~*x)^1g53OpQB#Sl*Y%W~XCD++ zH+;^_E}OVphd*$7fb)Js=9_Z(IX+V)Bpmi@29 zjL+o%yexLLcK9=M+iQS2mDSuH+3&{FW;#X>|C}96RFi|1OVU@a>L0K9wYsBm!)=45 z>j^riTe1>bC%a<(E(+Q#<1&G?OmBKJ%Q66`+@%A;J4JKBLL*(n^;&xnmy+?Y{8DT$DV%;mJDp~HW zENN4{6{jbzNcdguFsY55jSN4S>i^OG+Vo80*Zt8)Q{AfaEDp3hJiNA1s`YU7O5-!L z0VVm@7NlNF-afgsE4MIX|5W6|^NLG6V!}N4#YXnNa6dNwi+stU)Fsg)5bf7p;_VSA z4J{_^#~^*$#T{V`;v>@#km3&RxeqbIx1T|x*h(Uf=XCB0#KPxDNklH}){H~6XA+2) z$DwqzTq93ZkY&qk0}FI9&e{4EMlFz=MDATjkk|8Ngl2z1RDT467p~a`l<8i+L?)o` zsCI&rSnuF5lk_e<9h1-^6m8-yy_>cD6f{D%6`9EV$IWX9*r%r9tsfxT182lvAAa8$ zkXdYfZ0n}-8KONP`FoxR_MV1l4_FX8rlGrNvHP*VQ)~=zKMx}zAz1_-=0ye(&36D6 z_{I*vLD%;$zC!O%Z$11DSj?|e^h4Sr2s|I` zQVsa%tuAcN4Yrc~hzzHhVzXb1hn~lad4M|V&30a}g0}tYeBcaaW69J3{(o&VQZ9dX z0>B!Zl8pi&g|-3)fKOcT6AMRDl?S8OiH(gW*g z`j^P554uo^{iZ-qmS(>Z0#Xc=h|(|vHuUKzhxQILu#7$(1&_fT7}KYt;Dwq4dn|M} z%z-TyI&BMJMW2qM-}S9P9B#1y%JhjTO3qpUS1fd~mcSVc-4o0C@F+_56e3DSS^;e= zpdD6VD}6c&sBtU;nr{u3&?lx?K4=a6u+Vwg0ADP0cWgia7P@7&*yMKE0w4N#6r;`U zfH@Yry>`G83!R8PSV^Cb;=dYu5JI1hqMwulSWcggf=6%w!Sv}Ucvl#8uW=N zpm;~%MW603P(CMYprKCld6FXhfzx~|NTG9EHlLCdx~^rw4T~{`&LEsV9R=@#Gf2Wh z=j8%ou+WWRq)TuGarE&hi$cy3l5W^?M4}ruC%$sSwoN14vEe;&pD#U7j3MWyM34D$ z6NR|300_fRJb*QQH&K?+YB`9&LU&_12&GR)5$@s%VzJN-c>)XibQJw8ys#Y|Oi{;c*55Z!CD5f`B6yx_3eI1r5c|!NJ(@ZUke~&ng64ytIa3^NUU>Hn~Sb z=R24w_R6lDkB$;Al`H2faVT_RtL7_RD0J1Uu$5NQVc6vE2?Ig&0>Z#mQ3iEEd2S!3FM&{s!J&K=qOGEp&TYcJ3FkmgkJb5SO?$0JYci{x=Q z%YTrN<|A%@_DWt75~jo8=32xa7f}+u0?Zu?IO#iq5(K1b3dqT#Ov7prvl2#~;Ugr@ z{69Ed;}hdjBg4WI|J8*Q!$;iwc$E=LN#jZSRE7u0Q*?sY#sPja458(By-i;qff7T8 z0d=Y1J}LYGXRZoyD_~j~STY{5vPx-=ndkozri-a!V@e%vP6XPR{mh<#XyC6wW`d7v zLtGd&FCy{jYoUCP697N`aF|;Um@g4wl37A#a!UC3J*uPFy&G zY&mu$e6*<)|GAW+2ppUYc(FKgTQZ`EkO|7!gZu*v6ITktBx3f5IL{Qohei8$1F=EN z5zSSRsZMJu?eXSwa2)V08%P{u`0%A7y0}@Q%!ns3HNmP#Or2J9OroUeVa|EC%v|jG zacSvA1|l2x0g?!*ZMbhehbRVbOanYvoOvt_(WS|5&U#iD88^nNi>{iMkrtv$0usu< zQ#;~bBq0Yn&LK)-G>kHyjKe8WEe>!dfk`|6IjxK-FZod>mjA}gg)PK z0Hpg1IOqo7-2#Njlgya++60M{$$gGnydr?{DPmj&9vBm`;99v<9?FcqRq z@bxf=2ct0Zno6xE36miWEze(DQFdUmaWeA#12|j4XP5Q|TriH7a(e;&K%#`fEQ#qe%48q5G7R}L4s83KGQ*9-EuqrieLboId7`@^ zYd$^ZRvLbih3JuxKF3KO=w_#H0fo~k8{uTiKsmQ$16eFgH%Ux7*(eiR4iLt&WcK|- z+5E_Pro)GPcL0^iS8`A!d=8MrBEBOB5pSPQv9=-?aA09n&qWxcHd7ekrXolOV+6N) z{%q_=4h;ijfu}J*BL4Gx;z)ly=IfDuQQHr@fJiH09t!V3< zCQKyT1S;|XD;Ccz%0sx9l~8jF!iNZu3`X}P+2$5cAg*B}eKiD?MUkZ>SZTOnJ0y-3 z?A;DSZN%5d*l;)#DzMAjQLxN>pnxUnq|Ur6xQaMA3qdoZLW-?Gk&ahG^7G~h%4Tug zjCko7Jjcfi&({1)7N;;@Co$iznqy{xxwZgSEH<=z4rH81^zTR9OMR7e7G78>OI9;%aBR!RX31mVdhNEov?bL6!c5GkD6^Tr6pK+-EScy@~< zQ2-7p0$i9SY8D}!Cb#D}MX?xIO=7Ck`k7)MREpRqHZd3*r;w*Q7TM~$$Tf_*(l8pOb`sWd6zPhK1A*s%ScyzA3StQXsv$@! z6O;dfBM(KYV%Y%XN_>1A)drpGn}nD!M)R_A#1zw)e=x(75HCjNRuXgjt3Q~9rvBwV zP6-uqP5<-FA5KJOECuKrOo`B10wOkWlA4nT9wmT9^w}wbk*ObXuzTtctx0o`m|L5F ze%~5(9Y6CoCLHh?;=&lE{LIrlmyzIKgap4SRb(i?r&d*kzL69kZQX$w8TOHylRWIn zjfH&%VTX>u&D()IytHDzD=EdVu@#6&pD%xiZ2AESU<{>U5_9`s%nM*u7+XOc1taX; zGt{ydz^7nr-KO?!3+00m=kG@HDD^#2^CyalWM(;xri4}^y3G7S`N(t9ZcJeQ_AJGT z-6ZA(0Nzs#Bw$xIz>YaCl@&Ls@o)n+%vL>;I3XnPB3<1D_F^fG9S+jc)V)q9ma)PO% zCi^c$Hu$Xoz*o25`>%U zfD-)_O7SDPNQf08>r5WGHQNoCut?{~IB7%*_sxh8sgu#|KhTcs#?}~lx*Ksofe7k4 z-aSAbiwcy1VI1!FV-KPc(k(tDN-+qTA;$W4b88QxMWf7bURjLcWTg?7qRxWDy^z4+ z)TtKY`@-K?0&uVrz}gU8;A{_%Ay+;k^3JM51z4g&0i4}C-|O7m5>q|h{w}}Kr`xB< zGgTcBEFWWqWA-7>k^lbG2RH9ST;#EMj_;@*a8RSyOJhQ8z~Oq4KZ2`pxPyjBsNntw DWs>{> diff --git a/examples/zips/databaseTools.zip b/examples/zips/databaseTools.zip index 8c80913838e4e0f8cf6efeb9443e4187c4db4b28..99c07af6c8c2c92fc00e676681cf7c26476df2cc 100644 GIT binary patch delta 858 zcmdmMwAY9?z?+$civa{A7EGSVtE-Y>f%iBsS^RJ z=K!0x%|QfY9tb0wx0#D^1}ihr!pTe7tcWscGBdj;cB2y5UonA=^5rrn&Zs3^cG!*j z##O=$HY%6Tf;gj2^0{I+N{Rmo#8sR^X4q8(3%N6bEt@NBja9|uH^N)M3Kol4E1`!V zI7S$msyOimH?!>tT%*yJms9=MeuOtTXU$E^%u+IBHV+{zH9Ns0U5 xR)#RGL);CwGK6U##Dj@ZmMY;wjIz@bo|;%Aft3vy7Yy7$IGKfkVG7881^}M8#v1?t delta 858 zcmdmMwAY9?z?+$civa{2jk_oE>Z(*4M5b2*acKoN10%~zW(Ee9dY~+-x;PVj>O_F* zIl$&^a}WWU2g1naZRTQ}!O9G@aPm?%E22!A%*^hI-KYfiS4?1|e7TH?GinK!9d@I> zag{KGjmqV-AkL_he6HAyQsRFCaTTYK8Fm%HLhg)U%jODOV^uNvjqnz*g2f`%O6Va7 zjuA#CIc9j=O%ip&tqL9^lT$?fa4UlwHu;LE2X18u)9l2;aVtZZwq48-w=#rjQsO?i xl_5;)5O>3^3}M;_@nB+OdIT+|4|UnT*UpizlDw(zVV_Nh03J$RBlKmUGw{ z7@pZOFsM%~l%M>cNdUVg%FHX-p_Z88^B&x}lQp?*u^Uyzy^slPlpLQmaYohhIbk>I zGM_Og*eFg33*wAQm9WQd)D8)Dh^v61IQhL4CvnEfNaOHiuCzEaG`#e5N{We(lgSU| za2RPM-wKK6T?$sjxlTgS5xZw|6+KwNuG^tzja>!1x(CFv=lZ&n>oqutvv9Qrjx_pP zqaG3*wK_J$8Fg338N16&bT>dE>bbrtaYi{9;BeIhgHI4w0X;d%i&dS-oH+TO2@V7G zOpn465ir&hNr?3T3mmb&(4rOMMok-Y;=J2pV~0KDuGu_?#OVP$2dpY4i`Z`gCyUee z4oc|d47mJaWRhcsmvobL9h`A1LzD!Q9K3KVLzs5aQF^kZqb6>p2oqBry>Tl;HqiyQ zGK6X7PDGiu#L1Hw)A*eOa4SQ&tqW^bggq!l884l@<&~m_$~_FJuB6CC6t?oKdxWPS}mQ z%xBCAHi}cif;gj6CG4>qwL^j(;woS$PJS=NNt|&q(l|VsD=p3p4KF>Nl49cHWb#8f z97Y<+w?g81mx2{>u9Hx7#O~Q#MGsc6>vpJFV^_hh?g6pvxxVh?dJPWZEL^RDBaQyn zsD}hct&ROxV zgA#f<11`T9ndF$^CEa9Q2WQ;M5GBDR2QS>p5T;#pl%6cLP&xaG*W; zB8#48Xb2|*GakJnK=mA8JB|m7fYgC7vK^cC7$-3^106B>FiSWN6|DA5U=;=IR@hbS zV|Ql+tKi@?RUyVTlM^{zuo^XaC+7pONprZYi8JXpmpfLIHivO1vVo1-CFn$)Q3^tl z*p2EH`UVMsHqlV*D&C7avVbi!ma@mHVse|*7O(BK0rR7fU9***nd0rWVXEUhRB0N#V_8~^|S delta 1003 zcmdnuw8e=xz?+$civa{2jk_oE8X8p^M5b2*acKoN10%~zW(Ee9dY~+dx=64FD4{+1 zB8#48Xb2|*GakJnK-C;zJB|m7fYgC7vK^cC7$-3^106B>FiSWN6|DA5U=;=IR@hbS zV|Ql+tKi@?RUyVTlM^{zuo^XaC+7pONprZYi8JXpmpfLIHivO1vVo1-CFn$)Q3^tl z*p2EH`UVMsHqlV*D&C7avVbi!ma@mHVse|*7O(qim8)Dly6=Wj$~!L%6M3))}`lgxg-o2H{qQFfB&T6Sp#iX~*S4aVtZZ iW+xwjTN%Q%4f5&4D6>>ZCPvvl1z!R5IGrr5C>h1j+L diff --git a/examples/zips/datacatalog.zip b/examples/zips/datacatalog.zip index f59abbd1c3c054f28983d68afb5298cf8853d062..d153d5e8aa2432041d48a57449b1c573ed6270eb 100644 GIT binary patch delta 515 zcmdlXxkHjSz?+$civa{A7EGSVtF4k>oswP%#HAJ742&!^o3}E~X9TMVXU3soKC>G{#S0cA>}Ke(o@WA?F^R(r ztAfd19LvCVeCDvkuE2qFGg!elPD>?pFMz$u$Rx)M_w3|AE>~id?cj1EMwtvZQOX*) Y9f&dQ5w{C5$~<`71<-vuc|MOM0JE2W9rgaKWt%9^#WV1)Xs#L%6L^ OFh~I13zI(xN&*025^UN4 delta 452 zcmeBF=~Uqj@MdP=VgLb0H>eFcn}`uz3qp1v6NMK3fP;R!v^c7LU~^xLuqa zRag~lp3cF@0=8>5k3DgA{p0b%Zd42}3nSR5WWG@BD$ekkaDY`Xi#rl$S%$a|R--20 z(|ZjzX`4g{Rt1~oBu_GdRlJh+CC;vBnFy>#!2@xdY&KQ}n@#2ZLws(o;7Oca^VLiy z>njONwsqna=VV~UkxqmsZ!ozD_QY?+6zo>b6-^ugUum>$LJP;21rjEm5c^bJ8huzaM!|pH*?Kcn=;(AWRg<7qiFIJ=Aso{)% z7*++F%?u_%>^f~^i&e#B8RPZfkUnSZMx0|TOaif+gd99Qrg2ymZT@Gf3(4bpmbOah zMFhCWVPukHh8Iqgdo5#eD?`K?k5vXS%BES>;Z}yQ)XX{ww=#sKyR37GQRZpWfm<2E z($6-&xRoI+O|p$3M%f+PWZcRSmL}Ty<5q^S^paf^G0Obx@q`<~(o6Qy#F*yqkVcHM z>kgH;l_4z6c9x#p>u7^pDZ;m}9r1Vrp)B92h#1qDo!xLNLv~*{Ze<8dUpq=q{_pHg zjM5AjqTKh##Ra!%2=^tq2H;kPaNiYIqT)8tErl4P(7wqAOa)jKY~I3D!3dNU5TBbXcoJvVd^MBF z`bq+mZJl__H0*4}`64GlNMGyG|R~VpTC&#&|tAq|X_<5$6~SlR)eyAqP*7X&hEXoBx^WLh`ttrL7Wr z5dki87@6dl;f2%WUdveA$`EnJW0gUSvT0UzxRoI+HM35_tqfu5F6&%klzG~8;8upP z^s|jGZe<8dlWZf1QFg~R8MiWorHOX_xRoI+y<`_fj50raJmH40^pbrvF{b%Dq!FX+ zxXDEIwwalvgG!hK1u0l1YR+;_#5sJIPuOCiRz>u%n-l_A{b;vRxq8NzM5+~bK+ aX6=!qiM3>6Wdjya4DvuYn;%G9f_MNh@ERfj diff --git a/examples/zips/datalabeling.zip b/examples/zips/datalabeling.zip index 5dffa326ee17e1d6f54a09549ca1f1c49b4d9cee..560e1d355312c08e1855f23848dcf408f45e826b 100644 GIT binary patch delta 393 zcmew_@Lzy8z?+$civa{A7EGSVtD}-%oswP%#HAJ742&!6KkF#z8TT;hn zrG)MRuuB=4Znv2M5b2*acKoN10%~zW(Ee9dY~*wod}TT0IQ3& z5do{3Q1IcB(9C*NZ8B1V}TyE8G$RSFl08u=MDA8mKCawk-T_bk1 z<6;uZ+L&w6c;sLe6Dzxz#3M$NET*EtP0Xr90h4IrHQT>woZf7HJ@p35KPcbt)8F^{ zy?(EMzw+EI)wx@$VfizaDp!T{qiM&j!$ya#c)D`Y6ZG%uHEs%|x~fztR3`ebzp=yj zz6--2bUET1SDg~(6uBsrHlFgMPdiKW(zqvot@CzJD7qc-g3EzJ08PNq;}YV37d_~T zf*q9fIlQaOFutmxYWb>I_*$h07qnC&g(6Cc&0WFxZ^}SFX@TD@a$flavMl1|7KPV1 zy4&*K>Ir_$F-sn&QZHqi>zyBgp}u!sBad3?()LhUG7MGgCQxMvsq zmOOHy-yIgpa{mc1RF{9gJW3Z(rnKaXDJU0)8Vp(`k6NpBW2olf3>a!4xJn+iIAj}h z@Ihz_3^iAmBaeDdH;RS-f_@eZl^eEF9(69vX$TcD9frz?tdK_?j?^*-&ySu8L!}wY zkn29h{aa5r^>PVD{q1xx@aeBEcJ{9d|0H0B~J-SGq>m2h93*5E10+_`4 z#y`lT`i+a3#KEOuxG6ql9O$I(aKw?Ao}MdI3PlbrZawx$aL49&z5F6c3GHl=#ta$< zZ`HP>AeijQN%Q219Z8oMu{C8L4CR%&RUUOHwU(hS==C_?9F`2;pwdP63o_Da7;e+1 zRfeB&4#x}36NUXsGclJfq+2INVHh@>{Ud?B5q~kMR$hM5WDk}L#jop09YQ{KG~9Xh zMtq6tzof#tX&UM2(L(j%Q*JQzu9bS+`<@>$IUpZAf0`pK{2Qk=$m{o+K9qos8B<`W zZ!^l|QL{7OVxdrH11q;WTTrjh-c_+U>LUGUnjYc-)(3&q>gc zw?N)y-6LBVvpLwhD^7SI-w75tURi>bj9yyl~j71`Qu&>PaIO_pJ>NK89TxAz(QI~MkO9} z*5EUFUJ?O&l*P)gUQo82#l*`^PeR?1H~1_VSuU94)|Q8`iQ#04o|xTHoDq1ulz!UK z5+>ZWG7q)`f2b4`zq%^zVGN@1>1ul}3)^?kxfVec zZ*suiJsO5%C4cg5OT zSG;eD8WxoEO9bb{l-dr49b7sMhALSmI37+eGh5?J=J_HQu;Ye0L5^*xJId-Wvwkj2 z-9PHL$Zt#as-ey+wUje?LHP9sw=wXF!;OHF8wCN~0*Jt=(YsQI5;=;(0A9p`^EN_u*PaGj#3 z+Z-(Ss=UrAXHunOhCZmpt;*qKfd;t=pG$7cWco}^lVP*n>=SddyXgXMjtWH@T_6;D znIh#kaHi=TgX`91!*XHEx~1|ck3XJds0-`UVW=q^O65^|H?%z5l2jP#g=WFU@R#OX zmh4$AX)x5AEhX}*0yeE?s-D}N1w-B4yhI+g_RoYJTz#!MXI89S)3Z zYBG?}Xyk}vciJ;zp`CN&qrGHjGuybV7CnBdEx?XZ@XHV5^0WWsze-CHg1`?~(`g+(l-bECWipLeccsLaFpFx1}P69JuA;_4r-sam$sj+ratBSEWt<)fiid13t+9CE@RwqK&q%c-P2n*`Ip`fR4W{!h=o z%+`A13*cyU@e4uqmVcSUszACZ(swj!9NXh!M<%Fy1TC|o=UoPt+Qil${G#gZNQB0( z1l{7wSC~&BDx6y##h-t~Pg2tw_J9Yb1!!tg+eFJ95nDpN>1(nxPl(T)9_n0 zTAW_sBLVP{Z=&V5@BTMKhZz0rLr$gIadGe^JX8K*sWEnjTLX{awl zY{qFdeZ^ukPV4P^Ol-z!^M80&Y{qG*Pm4!gA0sy9#O2pP`o6!u3_@FdV~^O3>zmX+ zM{LHm9qMlon^|e3Rg1KE(ZE=-El0jRFjs75MPlP%w%Cl*b`6$`&8##s%!>+4zL_qz z<;a~k*NM$I@&h$Rmi(9^w&lnJKh}%QI5I7qA}fB165Dd*zMo3OW>zFN{A?rIoc7Ak zCJ1fDEgNOdX@_ssL1?+RZIn5uy?=WtfJQDVY4B=(i51&&Walpn#Aepukr;1^EdDi4 zY|D|a{aPV5vm)`>JM+b6oYrxtMQmoJkq{p$aMfKKCpkx+yt^ENyyQTUPu@!q+j8Wo zdyBD}EA!blkA2UA+plu(I){4!n-V$8|(rzC> z(PCSxK$3<~nb?jqyKLHV-UJ7<9>SxW{D|0&^9q${iP(QtXZ( z!x*8?SBm}N312h}hb7PP;jrW} z4r<9pe-tAYz_Yx^AK94XxKQbuK&k=|OC3x@@Ga0^%Ysk3?%AJSs9*Y{z*wf?@jJkCvPcK?Vr) z>kw2VwzE2IIboKC!cLgZP+I}AG6~J~S>m<1<1gz#X-+J=oi+-#+jtZ#np(ZBVUUY_ zQI9r@o%xN^T2dVbEAY-RTMe8;={%MxUYv`3H5@jI(c3{5gtsXIb~A8^w3TICUsEJn zC0>{NYuV|z(XgFfKN_^tmQym)06Qf&7;K%A+#%fmSQ(Q6C4JEsn*(x*ToAc@U8uMq3k|)o~)dTp@+y5ajI&d2O7n z%Qw%8gm_TYiKTnJ9S`bWI}&UiD^`armED>E%Z~m8Tb0e3(zRtzBCH|aOawPXE!mI+ z>kU0gpx$6{er+<$`F|yYoVUEFCRU=mHdX8Sjd({c0bsW({uLHT~4{=V1m z^?UvMm1l1%&)!rH%b#JdbWun@>2Vv{hK&wwh&3*Jn*Lq2+Esy+SL_uEWfT3^hwSj( z??ds2T@LvA703A5Ma~L)D^K~-r=29aG4{#dYQ5|fif#uy|5CsZKzLxR8{MHJjP(<2eQ&$lFyM2JKw7?%0IcNU_GB4uk8i`js zxLNbx;t77;Axj>oR4rke>zp2ep?+{$Est8^-2OmW5)4)2Do}OIbvaX&;yw?CI_&BvjkOetj^{21`y)&SC^L>~CErx$F6kzUpED{S|2Vqzz>=y0ur6aLJ{9fm}{ zGv$#Bd~dT*mibM9p}PF? z2k(a@!%%ayIr6CYwWC=0&+BHwP`RNicM9e-WgRS&vlCamIdx=YynK- zJi{~csD8sDCUI~{C~k@i9tS$9I~;HXrl;p}r9zQIi(7}?Z(?nsvQcuif3u)I#Q5c3zCcg+^Z^U0ts*#spG})cyLh&0qQj3tc4Gnj0 zodI8@`Y$T6cB)!>dbCh|So(FQ-lal^d*AmZ&34Ee&ztH13;+75_44|?rwt`wV@5g* z^<74(JZe_v+bk5SY+&V9WeY0zMD{)AtyH=BGl$zywNWz#Rl9ZO9>yG85{G;9Y&i)! z^5)CCtbJq?W3~iYcEu47IJ3CSWG-!btJ?Md4bP@k!6B8uAwZLO$;YWbj0L_VhzCK#rRo$ zm(L6;z5wSN1EfczaaDPOyzsr{B}}+WMILMio~aNNzp66zK@1}CsVZA83tM;1z8X#y zZ?MB&J!+ia?T){w@|Ra^s)}RFGzW%~R8JHR4)yM8`QZ%j(+3{NS`@{w(jn37=Ylmg zE_m-^6)Y&{77Naa^qLNa9b7UMhALSqI37+cHCf_I=K3IKu;cn#L5{7fJ;LfQvu+Md z-9PI#$!|;5%Aw9HwUpC&f%uJj*D>&l!? z+@vQVQOE(uY`0~^LfdD{M|<)17PfI&tvdWvyT1*i;G^w=aDUVuqjZ1xEeT!_sg@eA z3J2}f!xE%sXQRC2dpk!m$<0kP#=A5yT+^;%dEAvG>i-sZc?;czQ=6~8yXVslV`M<&d7Be=x*`bUS`f zaJbHRXCh;^zAG3;PriGNS#-VsC@f;ho$KWt_@Z+;LuDSyhoSy)=qY(r*5Lw%+R+sc zL;c(}MIM!NB*}8Xk%1`W3C`gQAEwG94M!XQczsag&(i{JInb0JCCcOTKB{Mm&yAL5 zV-+szcC#TFqPhj|w_fQUnh5B`5?l9pb>-3pHq2ZZ9}8OLs~-=w%JXZ-;Natau>CR~ zpCj-6vEzlzd-}>~OQ_nGh(3Et@P1(M)L6z0`CLBcc=6|Z%%_s(Od?GGsxz7L`ae7K z3R~-mFM*@cg)arwTlQ5Bs{-kwNZ-+@a7>T04Vj?o5wy(mp7$77Y7?7(^o^{uArTtC z7IcftUt>nqt{G3#l9975d)N1kAP6<*w+(3x48;Q_K6rVjXFOc4k(}K3NjW`+r{cG( zH8`!nTLR$2-$u!A-@R{#4l(-Khn!5Y;o|h^MM1Q~|8tgQ#NF=`V97Q6lHeUk$E6(B zlx|;69QFU7tmsFV{29nD$lmhV4i{dTDmLR^t=_v*C^qA?$g5MtW}No?)qJrTr=h+K zu^FdT_Z5rHIIXwuF|iq^&HM2=u^FeKJ`EmqZH(BI6PH~B>HFc@QV4C;_1$7Ku5VKR zY_S>FcCf!*Y-XX6HVx9?g#%;7wjBA+z#Ore1&IxV*{SR*#$$PZN%S@Kh|*p?&r|5PV7JYt?pZP8wD0b{458_N(cmNZQ^ls77;FM%^-#QO2u}Z*=5y^^CsA#wGbZNuQ6g~Rk^d?Y zr1D6L1A>&ExmZY#1AFLT+ovJlxgf}tNT$0Y=qN^9+z@0IBgJkA zGK>-Ge1+H_p72G(Kzz+(7kA6N{LFRF%U+~A9Li0ybKnve9t6|(L6qclFw#Sy z-vpx~v7NYe-cntiU@%tu=5CrSn*(cyTWBwJ_KyMsEjM5Z;Dx*v-H>!djMbeN7Q) zrFdQLuX(3qN5gh{?P$*p@SMqhNiOo>S8xys&6%=Og#|g=pB`-H5ifu7!tl zZ)r$f3`&4#{4@rEUjLY9i@I3YY;iOe*5zm`&Vz{TFj$-DERGZD* zUA}o%#K(c6PR!lwoj6eU+7@r^Sg|-{uI#pWSa$TsTdQo&l&&qi6JQPTMgq7YYRI}o zSa0Y_1oZ~9^9@Nb=l`7qa^C!+nruo&X^^xVNCsW9%p=C$6j(&>q`)FtHy%O043VDk as8BEap~*od{U@K@^iN@-LeY0w`t5&TI6MIW diff --git a/examples/zips/datascience.zip b/examples/zips/datascience.zip index eea64e79a092a5a76038855f9a90f38def439d45..7a1042010d6abe58fd151d72deb8abfb1e1ce40e 100644 GIT binary patch delta 4459 zcmb7H2{=@H8$ZSp&9z0w7$oc1*OW045yloFt|fa}!(>a0J;{D#CwrDemd3uekfjKv zY-KBJgd%R=P}j}(a6jM7bI$Y3Gw=I*fA4nA?;jgM{5gV{^1LcB$zfpY!vy~|7NRvWVnRR=POgmD%i>o= zP?(jeERI~Cg_dA!uu0Mfbs-0Ueq#WT0;Ba9LwMrag-Fw=L>X0W^E4E3wykXWUt40wUU}^g|vEfpwF>0 zxxLJvI(|Y}!9Q4MPz(PGg;s!dWcVl>(|;E_icHeJ*7n0HP3fg8dMTld(QjS@r6ee2 zbt-2`lbsRnDWUKcy=pZ6c_8fjFmpK4|JOoly= zxP`_yr>NhY#`YNwpu^s*a#+4JBey_%t-11&y<4TMHJw0wli%pl2{;jMP_)e$p$C@H zVD!$k-^Cv>=CKL>E6lB4)-KNFjJr-?mF{rn>P*+--P9~e0l5!XLeEDic%4brFS#N! zj_-{Ruuq`Vj!UbhIWtN`8y$P!7$Y*n?}|aS@KWS;qsD}ADJP% zu^1$mLHg(-MH)Hlp=9THq)0?7r;+S+0py+R2`38)XJ)2g{T}>0tt)(1O9e0Y{EBif zCxb%hVHA$Nx%T`qnoeSD09jojHO%rz-W;c5=Mxd?i}v(^iW1M1 zYLrAcM&1ad^#Lj$X{dYY4lz@`ma_I?q#el+L6MaqAqC8u>*jq)U+Z2BVbLGGKk225 zCz&ogT1?odpt^gy2lzB-TGDRP>r1S8x}!dtEI+_ie`Ead5Ux}c_?)OPKRUHj$0fee z`r6Z=UL7H zoDY`|RZyFYR9}kzG&Hg){#bXk13)KXFJ~b^rb??oO~EC#^*qw(W2c*KMK;TZDP?9Z zQEE2fq-*m3$PxFdry1cEyY(17Dj?PVwS+d&T2C2=xdl^yD4x?L_$DSV#$A#FEKOMN z`skOc(MZD2Sy-wh51S{tPObC;?m=}UxSDRw(vmHsz|(VsIo+;lURk00X!v|pWzgAi zt@kNxi4mKY>tsqgs1~M{?z2m6)uSrNF%>p`+~a%7>Wc08Vu`s&43Ip9;{t9ZTrnc- zt@pl84tg=DtC}0}^@dvJRou~v8sMLe2?=z1hKVmiW=V>iepHTWVopb_Yj%*h>h{|t zqRbuRoSsjCz1id3$65V_Xwa<^4sIgltr_egP6B9N=fsz9)!ON^A;|1oWcSRYD${rm z;WCl;D}660lOY3VwR-Jqt%4)+^XJu`b5^cwZFxo-4He_a&dCK|^Lh<79+_|( zgV@Y?p;*UK8D&p(g9^ne^D6=4^qnmHcQYxqN0%|Tv=RM>D)?4wmIpsPiil6l_KLyL z^?T^7Nrfx*dFX^Ityo;w`R-yCdIDCcfv{6BvVcx9-Wag%ygSx9jEcDwtQz1b9G&Ol z#d@JS{8*2lA(Y1!7z|Yp%&}VQJls}t zj1xM;r}A>%8-G_XM9Z`|p`@>Ry2AuV>*iOuH0V%N#dp(qRJeVVee7P>hE)l67Og+q zr~D`GD%tlCOcc!K;f(58lk7H`T(xnD0;kVi_7gjUmRj1WOJnuD)+cr1z%OoDRXfS+cs(VzM?uLVZvHIr~CGz@Q99Km0 zIn(4;JFwj+*T}8ua%-rw?)SHu)f3LfQ5)0E{etk3M-L>$%lz+1iMvm=`kv#?R7|xa z{h%LJYX72?rslbETV8HR801ZAmMBt)nbIJw8ao{tsv#;EQWWfjv3E`v;wssj>@q@ zIUYX?zIc@T5+@5;ubIU;eRW zFkOgBY)h}~qqFD<>W6$wj~UopHcr)n0DvVa0EiJ34vXw#?eaXnzgRZei##?loZ?QYz1{@Z~bPQB8s5ck&R%0 zp45T#AULY0xF6t2#CAxmi`?E8tuD7A+ZKARsJ$(Ogbg9!5BHzKlHB9u-d6ubJsgzy zH|jgB04G4{y#Xa+Rf)GNZXT&weu@YHP7)f%x?S9z4L)@`3Txx zH5cA#&How@&?-@8?+Ck!fk@ehyKTy^vS;H@?2R*r?;zPOdu^@Mo)#cQUFo(#eVr8h ze+zv=Zs%2rAgsjy%nH07a}cwjdc%X5K^pV~_YJz!yx&d^U{HhhL4em95Rf(@(5#7# zM^}gR=kenABg{@_J3&C>Mg-)z@Rkc1`RML*8{$6;y*~aSeg+K;fr8* z6Bl@?nRb8TJJm9XM0>{g5H{t*Apqdtm3y}!wb2~}Nwzx46zM6!WFSLH^*M9(yS8tpE delta 4148 zcma)92{csg8^2~4W8bq(gzU)@3S((LV;D=3EnAdzk|kM_CRrjvZfLCWQI@idwIYKI zSsF_zOH#5_L@1>4AHI(2f7CH^?#!7pzvX$K=e_6t-nn?_wRk9ti6NAh5m=6rAuyzZfUj9K$01fS1C;-snssH|tv(wlfuFjZyU2pyRRj)#jW(5YN8iM?AeZ*FX zAC92BkU&KW{HP!Y6>PoZMR@oQH~>tV0e~7v^5+A!;T#}>#Dix5pnp)Av2*Yq+Ru(( zx+R>E%5ro@Y-q54y3u&J{~#xC4AL)D#66~Zpe+}J#ny|w4AnD8k-kdI)J_?%# z5fun9p)4c{@QR{zWIhxO;r#DUT~vF*Rv3HYWj;h#>9X8PL+1kg3txifgsgP;3*2O_ z_@y{k^Y8k!yPXoErm|YIVs~m~pLuC}Ls3^QQ(@PHm`Lt-L9XF!Gwt3efRxzUL?bY< z`=a{6C_vV;Dg|92Xo}BXehfKt>8|IZ!+X?h910e~R+e>y13saL*;P5xcy`qG9*HK# z6&7~GjQp)qjs0u?1Cw)P*2}6fQ`|3?I!B61x4`JO@chjiYOb+J@RVPXc%Hdfw9+>R3-vJY{cFgX? z5%X@yihUL(u_EPY2|kK=I(0-?LFtoatKyF{#(jO=9J0~9#+_Z~rDJ-6F>x2T+K=X5 za|sJ?y%i)AwDXjteeSZVXrGVLC$x!-wV`i#nkp-cj_iu^^;D`0j*9#sn}VLoLmABZms#$c1&i z&0s1l3{u|@JQ#tq-;D39n$5fd!;7Ew6RS_okok^zHLNH(T9y+UYu zc-7Nein-!Ar{1~3nL*>qmHA$n))&!`6)qVoRBDUe;L|VW35OsZHHrc@Hikx>Q_cQs z6U}q4>*U(-1d1r8Zg2pH92{4v5t_l-cQ?KE!q}!(@svv{_US9o_j!-rjm*hFR}Uqx zjQOwCt+C2oKQp|>tUWx;9A)KiI-Q|vx$L$}`_@thkia`UAk&@)&*pz+2G%8Noot-cGds%GId{tE3MI(e^ z$2&%zvgpT7#fC(TguPXRQo<;vco_!_jI$`sYGM-pDe)a@kN&>={9de7t6KS~_#0>& z0d(Tw*{<>>*|cPIocSo{Ba+LWG2t_)=i(fAhF9byR+H1AgO1}8DV8{c_->VNlCBrq zxf8OYk9(!vmv(h~a^s;K7aNNAsD(lJ^BffM#QEG~ z=6uHF!p(h2<(W0(BOo$SQ-aWAi*a{KTF$GxdgQdZj)zLX^%9@{`P!qBq&Cc;Yj{^b z1m8YI@UZb*w&fD#?Xj0fyM(#0WL=Kn-B+>7*ydIyWV15cVUA9^}bPaoJ_KS9^5?%{Mr-s40gpN`y6L5tz_X}8vv4j&x8 zdxnnQ!i(a>DB{QEen<1UwhvNHu(pah2S&P6t2`>xk%VOW+$UUmtG6gJ)bMWkZBfZ+ zO{Vm~ebZ6S!S@V$Gecg^+)7sAez@nRc2$XbtW|`4Vvz=yjYnboao#r_^EqwHMHT1x zsdoum%EHOK3k@~U)#!Vd!!^p&nf9{Io1>IFN4nyzUtLo>6NsN| zyP#K%?kMVEOmTYDPSh+WPRIm`kEMz3YsUu0lSga)l%2~bAK%?0r`}pwS1CZ2uED&F#nM&{*Z^bsVN1%o|`~9dHpSe4l%$M!tfLJK~Z~4 zSOsby3&TbpGDRNT8c`Z_0I`91X{olY>;-CA>HbMd5%Eh=6kpWVII%OakPS2t}^;YGOk@Iu4FsJ+P6!7awV~ZBvpfab_e=r%q3rJS+ z?Gf3V5Rd@N4Wc$21~OSOZj%^HCHDO!x?An|EAeM%K2V9SzMGD#zMR`6Iy567SpN;; zbAOJ%l78;3M^w^k;0Ebi^IwMWlR+Ibz}$_sPPe96xvu<&eQqt{+lIRZy5gg;Q!$d0PMgFijJ_Z zsDIM?g#6#del7;*W}j&e0RU$@0Fe4^F-JGVKnj^2{6N_522&s-AgmedRe+fp+Z}Z} tm6TeuL86e^w$Z+%Rs^K9ZiApz&o29?y-x>Q@6rzH`!E9ll-95R`X9i0`$7N! diff --git a/examples/zips/delegation_management.zip b/examples/zips/delegation_management.zip index 045f0df72d51aa03fac022c21311752f3746698c..9390a90fb8be2e01caf52f6495c10cb7b5276f69 100644 GIT binary patch delta 1498 zcmaFk`Noqsz?+$civa{A7EGSVYpRl8oswP%#HAJ742&!L$L!lM96;HWzWLLR>eC z$Co%Gxp{GfSsSk}6WDdv`0cQ}UqiqPVp*wRAaRzx63oYLRIZRQ#Hhu>;lvpwCsK{w zsI?*wAVy6Pb0f~EUt*EijY=2)3Nb2P(iy9Y$=f7%g2Sjt%2^3L)qxW=Ba<96Jo!(a zFE2g$lavE)rHBL=B3+7G8N$TZ(q*`nAxvwQS&ds6!n6R{Fx<)zrk#+@#;putTBuwu zZeeEDeH$`Gc>DBuY38hZl$`Ga%D~I4#hA{1=ayl`}ic|tMv8G^FHef<#5C+0xpxwz*ARYh;`C?)K delta 1498 zcmaFk`Noqsz?+$civa{2jk_oEnyOS9M5b2*acKoN10%~zW(Ee9dY~+dy2-P63??5C z6PT>e$gZUy8p6rIj7OUYP&)_M`0ME+Aax*&Z2aaR#t)3lK>H`VGH2j(0NkX>7n$c` zH>!!H9AeZTRuAHg%3zDdZq!Y-2xhRWOt|8SGip0mw*)p10s~;`ekZeAQ=*2e401a{puemm^$*AVc6SXL?+NStM_1oN>Ql`CWnF>0}JIB`bFiBw}Z zYOTlvh*1;7+=w&kmslirqteB{LX3)+bjGS;@;1qx;4mtZa#li5b>KwJ$Rx)MPyUnV z%S%uGB;|lxDIx)eNSESPhA{E9bQx}C2-BKnR^wKNFfBkf47W0bX(wc}aVtZZ7AlvE zTN%Q%Cvr1!D?^wzUp^YQGK6U|3V6Z|p=`5)4{p;CmMSX7<5q?+ZINOvZeo%~0S~hDXbo0UPU}TbG ohP!0)EjE8*lzFqe5Tk4(yQd~rOIg`~b~CU5;e190hCDD20FxI<^#A|> delta 320 zcmZ21uvmaMz?+$civa{2jk_oE>Z(*4M5b2*acKoN10%~zW(Ee9dY~*wod}TT0IQ30 z6alFNVPth1H)}I91I?NIkl75Yg3a12?u=j+rL5LiRZKp@x(%$Lmd#oT-F&b+7@6dl o;Vzkci_M=HW!~&A#3S$ArH(006Nt}{Qv*} diff --git a/examples/zips/desktops.zip b/examples/zips/desktops.zip index f912c830861184dd835382815fa0890013fc1f49..cc0a47d91118f4bd8551b032b70e608cdafe20eb 100644 GIT binary patch delta 2117 zcmcaVjq(08M&1B#W)?065Rh0fc_OcdN`7@pdLa;(R&X;gvb02ka`mHGLr}RQY4DtC-5q22n9j0J}Rj z2`*y;J7cA|BX%SHYi(efyiN+DYP(braRIC=9gE$#dD7ev7p;-$$F9O(_9#S!xO^OT z6`k^nAfcV|6TwF*mIYu^S_2?GABohK(6k6_YpFYz4a{%hpT@J*R=QI3trBGrTaE ze8|?B7-i~qp}3VHviLl^1Y(pa*tZj-?4*4nG0J=#Vu(?8$|0T@W!{c{#3{- zcPFCUcGSrqw`qvTGIJ&>cy~Bw<2DTuS*|W~iBZPlnnR4TNv`R{D3f->6K)8fE_Vwe z$~5;_VwBBtk0VBzlt&{m%JzCh5~Iw*lc=cQ=IKR@X-Zzc#3-BSWlxN@s9 delta 2117 zcmcaVjq(08M&1B#W)?065O6f^p2(}AQfUyGUJb;h72FJrEH9ZE7+C6ovZ(4JO^H*t z$sM0M5umvoAbTgvG6so&ECyj@izm;M{yVvWiH{kiXd+W3Rz;iTm#pF#kTfr{LvNcme&uQQ+&d4Ok3@;2O zAF_2OMwz-@C~jqlEI!XJff!{9_U*(dJ87Rtj4~gG7-E#2a)>8JnYW`KG0Jv3W)Y*z z-H9l-9d+`@Z5kr7%$$h|-W|@_xJ^SumaEHLVwADC<`AQ7l509K%B0=!gd4)A%iV&A zGR-}f7-h5E-*D=?T`#zo4Y1w=Zg2y6m_Z7@J# zi-7`%B8&~$xQ%fe)VR51aYh%DB|42+_66f5W)a0rjf*q$gYA3f`%H7r@j&{4@XPP{ zpYxpa^juj{URhCUv(iP?I>GZ3Fp7G$p{#_kaJ*y%@vd z{N22l1wy}6`bu)m zR=ooE>&;CCd@4m?BU#lQ*o0NKRB_|1x7SFqe34Tp5#i^ z7iwdd^a(2>0LAIv{Y`^bc?!G?*OiF^3seqd&g4^d znJq+>e43oel!f`GB;#9eNwe|QT2AXA)^gRSAHb^Bj0`@NHS=Y%>Sksk-T~w8d_L9u z?mDt6E+-zVRx_SOJrllR4`vVLn*~nGN**O#S^f@eoG!@Q#`uzwRhA#_x6R&F2!cf| z2*oH-7mB_r(4+XNpvP&0aN458HL}EDlr{J$iYi$bF3-*X&Ay??O5TmmqFUUe`?eQ| z1S%>SlCIyql48D{Z!B#mnq0nRkKr2;UQx)WnyM%#s^nvQ$xfLXQF|}q3H4(YMe)ys z@=VR320e<7RkK3Dcqy&6Msamnp>>!Zad-I}1sY8bmx}y8=TB|1JamrKQpWDjwSVCa zT&*XMU6(v`K0K7pT8(@ZQS{+#;ugD{hr93$G&EC+4K^?1GuhC(ja3Y`?$g#d76_@H zYI}~Hs;SM6&+BzfFbZ<{qMb|L+&4J2BZX`o>+r&Bo$pNM3m9;Wa$Opa{V83Sy5p1w z=C$L$;1yi%G7{4ub@zg#xX^73`S1HwdhaTfn?%@Dts{|+!IsuIGU*uDzI7z=VCJ4| zItE2A_LR{vC~E4>pkrX0?Jc5XV0*eRjgEnBpf8t>fz2D`(=o8UfnMRk{Q9}F9qEs! z+aTL=e+my~c3SBeEa9rNfsR2@>p%q^1KX{EP9Dthb`1{}JjlQxTj8V*eKwfNW86Me z#e;n^w2ueNIl-_&zVA*H^4P4y)pQJOcZOf%!CFo-`U(vTICYe61MJeNIvy;0Q(vV7oKJu*nNWp4mDw%b2Zzdd+d| z@W347f+#JBZcQIb1faSfL6i$2wt2OS|u&~qps|*!{ Jv)!J*{szD(hcW;F delta 5692 zcma);YfzL`7{}k;cNbAvf(c98O#xkqMlK`EVAIk7$we?Oa*0LQ1u|AF5;Q<5P5{GR_g z&pFSYD@*DtOKM$4s;pThxqjjzk9X;UHq}O0?1!A6s)MT~m1aqnBu#_!zyIc5jO1~C zPTo`T&Bpn;e6G*KK8LLOO(i=El6z_s&*V-eOfOK~z0e&(Sx8V=F}v1aShRA_glt^#ACB-IIYcZvTS<6wKdVs2y)6&FL*7TRzs+;NgbO%g3bH!A% zJFD2L=&Ts3T26bGbdLE1KbSqpHw&DWr5q$&N$xgkoXpGF!ugVNt1LgblHBq{osd69VOLk;xgzvdXC)AJSh~l3K z<(iuQH3kw9rR9Z!@lw3c8ZOjjm9E45h_lPzsK{_)h*ISD89%he?xAy}5*fQcSN=se zaJia2b{+1a^WmXX-fG-OkwhHMWNxve_i!7XfyR2ISbzN@J(D$!TX@A_>ppFa=7Esv zsix=Hsp^{S^t@j82q69rAF_SHOZWySw>vy?c0uc5iFrI z6UU(F#m*8OgQDiHG#mrlbXNh6f$iz;6dVIvUw1Z+fz6BL;uzT8B(I2IzCA+Oj`YOf zHpsTvlO%#A^jdKYmT&zRRrsJyFvsD=;vUNEq`23KI=~wF>W0w z7r{Om*eil%o#5CY-*+eSMQql=eK-cTJAfz3Evh+|+I9kz>Lp{F@3g`yvy=CmG)W}WH5i-K+C2xrEDt##yp zh|Ms%8^^$QX0#c{9?qsGC1XP0Hdn`l^5u`egcpWXM}dR zZ-#ThAYbUL&LP&xaG*a~ zkkv>tG=!6Z8IN8Opn49l9jBv3K1-_p^hNCsqXrKmSqjz^(!w&l2kPSXE5U zR^J8=SQQO>CG@liOsfIjj7)OO@SHKZRU;U;GI-*i{7WN~7-g-RF~lfi)=DNuS%+2< zG0J$fJ#Z^S__Rzr5VtafPhV=M6Qit1Cz=>#?{%VxQI@TnNQ|;~x(UQ6E6_{Dtqc($ z-}T&aD?tG=!6Z8IN8OplS}V9jBv3K1-_p^hNCsqXrKmSqjz^(!w&l2kPSXE5U zR^J8=SQQO>CG@liPVbCNa?J3YF}YPE7`HNb;-36VBa;|qt(q~!C}Y-2CPrC@RuVDF zc(grmD?|9SOgj*_GK5cGYNr#UtVk!C7-jEuqKHwJt(!=UvUj=(#3(D!OU11W5g_07 z+;J;I1W1B@EHTRN>k}2cK?VWDn0CYLzaxm792g zT{ARW?2)m0xLpVwtNBGSb{|d2ex|B9P%izgm@-rzDdxy3yIYXMML78vsV#EuBTcztnj50nwFWkxy0aB%BjawNa zK(6b#5u?mrACKD*mTuIRp1eJt?cNd|a=7-8{Y154bNB9zG);_(I|P?`*V zahrxv_R%nq7-cC&cuYgM?XnRbpCT+ZF~$@92xSY5iHcVa6QYzAn79+;)0-w%#3(a0 Zwb#U&rCHg4Ih#QW2rYo&;;#+j0RRCQ-PHg9 delta 1980 zcmbQ6JvW;-z?+$civa{2jk_oEDyvi)M5b2*acKoN10%~zW(Ee9dY~+dy2%?v6YMI4Im;nt^m5x^S8_)*o zJzWTgbM6bBgE(h{s1|XS{S(Cz!tP?w5RMYZ5q|T_fbLSi*T(U3Uj>{Y}Ox$qcKP{t8wIm(XE7*WNp zV)7r=m*DjALd_Dpk4)9qK-~L8LkGJG6-`H|kF>DI)#SBW>%f-8X&Wk`XC`niWn_|L zMnu#`Z42DW5Yfb~<4laQ0-aD|ls(t6Cq|ivt^+a3R_Qtsql{0_3%4>vfK=&O<5q?U zkn4JG#3-}Z$Ky7Hr5m-SC-2jjCC0?R`b5PLveKZUtMp=px9@7wRyKIEVrwB_;jPXQ2LfHaiqT-dqgeYYNCho-e^rndwG0IF$ Y?KQDxX;wC1&SsDTLJMHH_-liB0F~Ca2><{9 diff --git a/examples/zips/em_warehouse.zip b/examples/zips/em_warehouse.zip index f2a293c8e530725ba834ed3db8e70daaa8198bd1..80c3a6df4e166477fcd3366a5f71546f290a6d68 100644 GIT binary patch delta 319 zcmaFN^_Yt{z?+$civa{A7EGSVtD}-%oswP%#HAJ742&!m@L4&8LZ$Kvy~FM@nB~#GRZN+ p9Wq&o#giCiy)4eeDEq|Xp^4Q}RyLsB3@ku6jgf(2J1|ff7yxaVN$3Co delta 319 zcmaFN^_Yt{z?+$civa{2jk_oE>Znv2M5b2*acKoN10%~zW(Ee9dY~*wod}TT0IQ3& z76GXPVPtg^*VHltjhU>&Xo^*Sb19=2BUr^DCM&EeCJQic1}iwmY^8*5JlGkGOmfU{ phfG#t@gzoBFN-rV%097pXkxXLl?`Y&0}BvNV`O014h$3q1^^c!L+}6q diff --git a/examples/zips/email.zip b/examples/zips/email.zip index ad7a89fddcfc4d2cd2e223c94de1d3350cef92e9..d49fac5ce86095c9722f8b9b24d084538dc3c523 100644 GIT binary patch delta 918 zcmbQFGf9Uxz?+$civa{A7EGSVtE!S;oswP%#HAJ742&!mFpe>Q* zYfE%L0iASras#i}}Do#6hmyi#;J#0g#?!qL`5vO zHg*+rxUWN0l<^v4RWW%l?^>`ka`|+yD_F~S5Uik(-yExg&3pJSK zGRZN+<7x5}L1$u=c?#JPqim&+6EVtog{_HEmL=>+jIy)Bw!|pY5wRggS(k_9MUh3Z* delta 918 zcmbQFGf9Uxz?+$civa{2jk_oEs;X2PM5b2*acKoN10%~zW(Ee9dY~*wod}TT0ILf# z6#=OOVPtg^=kI3*8Z$YO(EzLb=B14Jj9?Yw%qG}X#4|5|s9<8%#je7cwU3b(XiH@I z+7jJQKquXu+`ua~d4{lnI41)$HfK$iX8#YiRhB~^yO{|b#SmMsaq3}LA;IMYQ4!0n zja|hY?&}a0WxU2%RZQN?yB6$>Ts|G_3fA%+1S=@yH^-`A^B(>S5Igz>jg`mWaA)VvQ_THej4F@Bm>A3j;%gAczM5@b%3! diff --git a/examples/zips/events.zip b/examples/zips/events.zip index 09a131bd2eb1263ff09687cf06773ab640a770ca..f5d5a9a1777f95075a94403f67d6a5cb45890103 100644 GIT binary patch delta 320 zcmeC@>*wPQ@MdP=VgLb&1(PT8s;T5xr=%AGacKoN10%~zW(Ee92B0iRod}TT0ILhv z6#=OOVPth1XOuEA1I?K%z^so|!RBCQCq}S}87wAPRZM=svL38p603<4y7^#tFfz$8 p!(B4@1**wPQ@MdP=VgLb031Za&x@j7)OO oaFy6GFLWRVw5dmbJE0WDJvV$ZUz=0EMsI~Xl4cR0D@LSBme*a diff --git a/examples/zips/fast_connect.zip b/examples/zips/fast_connect.zip index 61c5f745d8096caf9b9665a42fa29f69cf7ed0c7..78c2d9766dd42e67d2a0789df030c460b497ce38 100644 GIT binary patch delta 1119 zcmdn$xYdz2z?+$civa{A7EGSVtD}-%oswP%#HAJ742&!Znv2M5b2*acKoN10%~zW(Ee9dY~*wod}TT0IQ3& z69K6MVPth1*M~DR1I?Mt$zqOG!Q>E@-+Vv?k@lH73?V?XId~^4a?4DfFUL2zUz$st zlYtqVxtmw8CPED6;q<|3@a7!O<&0pf#kietsNgn+s940~j9tY~9!`h~Rz6egD*X7| zAS$NwTVPl5n14M)#Z*B*tSTmd7yJlz=xZTg>qd;SH?lFrD9e(ICPvwFIidn2 aS>B5n)6UBW6Qj&U!9xH&g-o8KAPE4s&;a)U diff --git a/examples/zips/fleet_apps_management.zip b/examples/zips/fleet_apps_management.zip index 7ffe659480f315c319a66a0339e54075c13d89b6..3a202de6d05f65aee9c3d6ab93b56cfa1505a371 100644 GIT binary patch delta 1023 zcmX?WdDfCQz?+$civa{A7EGSVYpRl8oswP%#HAJ742&!LyEw7)&-7 zmsICuV8)|f1gMV#Z0@yS5s*3%MmBe|En^@fGtlD66PfI=t9Z=h4^d&t;)Ty`aJwci zW=X_ulmzQj7La9=xU7jYDW1z2yGh%)62T@-mg4sy&Zsv2SnNi9=jUSvhX98#cFQKm z3vUA}kPz`9&aMs-9HISQWDz7Rr-(T#p~nR{jv1NcnBl2m@=viS+{zFEUMikQjItl% zKDd=3EKQS$z^x2n=>v&;+{zH96-s*IR)#R`j$|NiWeC&!rNVG4Lzs44Dw`N(A<{%y k`cq7L@*`<`VoY?FNz}v|udHmq=w;vqLL(rnRSd)f0JzlcZU6uP delta 1023 zcmX?WdDfCQz?+$civa{2jk_oEnyOS9M5b2*acKoN10%~zW(Ee9dY~+dy2%nE29wRj zCDl0@nDM9=0qWxbn|m!-1f&jxkQW8NxJwsW9Bi5T+fM$|goxh%`}_ j{uGm*{7BlK7!#dk5;d{LD=Ql?dKq|u&x%JrpL&(hw1UO{@XJ$_5M13i0AZ&sMyHm zi(Q2f_cMqszj<-k62x~5VurMUBUUpe7YOVGJ3~j%Q3>6j;P7B%l4FL4$mD*(NMe+6 z2@$2NRVa`c(|!nf5u+?cIGPw`4~2=cG(^N-6KjC5vH`;dm_RrfW&%@w{ ATmS$7 diff --git a/examples/zips/functions.zip b/examples/zips/functions.zip index 15e999188b3e48e74fbe3cf0393480b19b902966..cd961dc73d11169791ab4b9fcb8fc8aef276767e 100644 GIT binary patch delta 393 zcmbO%Jz1JJz?+$civa{A7EGSVtErM-oswP%#HAJ742&!i@ zy3|Ba<96+^v)UaXS#BEP=>Y{`3sS^RJ z=Kz~`saXVM9tb0ww>gv1mXR4~;ba{Vv&r|Fc!)A>GCy-1cH1!LRHv}nkqB}Vw8@E6LCgO z62TGQETTst?mi>#N}N%q5~Ze{TNI=NbTB5q{} z)AUpVa4SQYwm>BZw=yKtRFiNkLzuQnbrNo62-DKkB5^B2nD$Vu9=9@tX-(?UxRoJH z`>)=NTN%Q%B^pGTrl^U>G=!zcG#!btR8uP!w=#rjE3`UrD?@lePepoiuC^&|r3e#` zXcHCvK{~<2n08#J7`HNn`(kwCa4SQ&?T&6YZeO_F* zIl$&!Y8C;R2g1naZO&x0Wn>0gI9W%;Z1R039->T}%+DN$-MB_(J&19eSVD+1N{h7x zt5K6P8Ra%VV3mg$$HeYUoN3at*@$`D@AQ<0vWt8I!~DZ<1f z+C)WvkWMf$rXANQ#;pwDz8Kv&+{zGcyQABUTN%Q%PCYN&$`Gb~)r%)aS((0@0D4}X Id`4dq0Pppr6aWAK diff --git a/examples/zips/generative_ai.zip b/examples/zips/generative_ai.zip index 2faf55f20501711e6e9d1994d00e82dcb660a66c..0bf38b826fe4e761aaa310d0a0cbd62cd864d2ea 100644 GIT binary patch delta 590 zcmZ3gx>S`nz?+$civa{A7EGSVtE-YABCGeo#t zu&c=7x&<-AlLxyyH&5j`08tUaXN}d2$;fo0?x!J3l|I`M%igWqP$=%S`nz?+$civa{2jk_oE>Z(*4M5b2*acKoN10%~zW(Ee9dY~*wod}TT0IQ3$ z5CN$JVPtg^S3O_`8Z)_<(G08n=Ie~^j9?Xt%$C?y?(4&Zb8iO}KvYEVSz|S0@^Zc{U`yiot(DNd2@VcMCOKw!fK1-a??#L= pWdRprlywTY6Qk^tfHN`5!UcnfQFdC8C@&Zbc?zHh$mAX&NdWNVhQt5> diff --git a/examples/zips/generative_ai_agent.zip b/examples/zips/generative_ai_agent.zip index 46e46c4bc73027247f8443295edc3283276ac794..a6ff8803dcdb5278a0569026fa80f229095008ee 100644 GIT binary patch delta 756 zcmZ3lwqA`lz?+$civa{A7EGSVYpjxAoswP%#HAJ742&!l0>lVcR%`4krmz-4RB*E6 zFe8y&7ouV!hYfZ!9&-3YR2XyFV^`6}bsM50g~tP{ipd9f{(`-7fERmUOcv$a4pwlU z&ru0Iq`)D{$Rx)M57Ws;{Qkr!Tg>l6j50xiAYzoY3V0Hu>;rM8r3iWvW7-8lUt*Nm f3xyG*Y`c)ZCf49(WdnvX0~ZiRvM?|l-~;ghbzZ4g diff --git a/examples/zips/globally_distributed_database.zip b/examples/zips/globally_distributed_database.zip index f96e5d8045765b1f92009333d6e97e61bccba66f..81d733f02fc22443fc8c13936166cc01f46620f1 100644 GIT binary patch delta 1777 zcmcb;fbsSMM&1B#W)?065Rh0fc_Oc^N`7@pdLa;(R&X;gvbH@UGEK#*VDmdBbw;oX36@-}Dkjflxd&EI#ae+? z!Dco#DKoJkBhFAPpgF_EoQEVqkd8&A^a0 z*^tL)@_9FTaZUziY<}6SZMcUC?2<&0Z0rU<5D{SktN1Q~!!s3k0#QLfxmX^%Yv5sjLSY(qyNVQb8NmTp)bF$NA}}tqSSH(922Qs3=EoHX@YrBg zsl;w5C^o=eT(5=0+DL6XR% zPnw&{qzYI#;VF2sp1m7ZgEn{AheA^50|#%cDkj@I9spa#p|M%f})qAX2!>mtT9VfRX6l&y0o$_w5e z<+x2l#KIGgJlx6GK`nMO;356WI0w6mER$o9U^2GM!>VHPR?B*@CFWMx zlji0!sR9;GcnY4ZXYYp9pv@ijp^y~%z`+} z`A)gGl_4DThKWiy-?6QeBFrJ5LJzg*ggQMSmHC`;4bx`;7N*u9b%W$WCD@`ATV zId0PsvGBwr54SQzER=W>>ommr8oT}HL>O_RyJS;V-N?zAU+0$&yFA-061Zv_y7O^ diff --git a/examples/zips/goldengate.zip b/examples/zips/goldengate.zip index ef13de816c23012b54dcb18970b6401625673b25..c1729307a8a6ee6cdd862c868c924d87c36f0285 100644 GIT binary patch delta 2075 zcmaEFdDxyez?+$civa{A7EGSVtEG}(oswP%#HAJ742&!L%y#t4?f? z!lzaQsD}e=<~}zOkeMKiZ02SO#>0$)KuaTmD&atO@&PV!hk(q2)SS$`RQ=EpP6lQ? zE`r+Hot&@E74l4+>ez!Y%g8c>W zCa*mmB1=Q-&F(6235$y|A38EA^yxcUo}!JiTi^V7Haoq|ocViKeMXDbf`@KBXSh_e zf9wlA9JA}&i}x?ZQ=`6|(-sb^7rn$LH=*|72^s$Rt2b?!``E4|gX#8;s+_5&lOtB_ z-CNb@6OkOi!W5)DWp3kdvBUR!LiS#+Nogzh*vjSbs5QQ{LH3IOsfA%|iopeaA)(*0 zRWE!wVWl0I&*OKzwzw|y#>YMOdu3-G-gJHO0{IOFyWXz9Kl{1+wLSBa+@J1|o#Il@ zZ@Rb2>2!s{JlP2!oi&9`)meY4WKHALbkd&aq?R!^zU`XPL`~fvww*pjbB-o=<;`l{ z8s=@XrdLmIf0^v`_54T6Wh!U~sBOxcd@8(8iqO`C1|_x`(kdH!YF`Q%ZPOd`ALWLXJbbs{5lvN^L2_H@(E ze4UvYm~JK~vYX;df$&s4c^A7SK85f^G+CU(0lS^q94<^?J2!FRa1|5xZHS5oyvEqg zQ0H@E1e=k=Z%>?a&hz8QI+_A|AeOxlG9%6?Ct+Lcu9_??3NdQ6s0CIPlfR2@1Uq}R zn1vFStP|kP$Rx*%2y9kyU);(NL0uvqVnEn5w6fucxT-HaTZe|QLdpi@QU#coAr6Au zgjzB%NPvqPU_rsKq)~%;@8U0x|-aumyQc}E7Kp^TO+iwcX$x4-un}haeZomdVE?1&Pt| z6R2Yi4@ifPK2bpjw=DA9;SCQ=fstUs#K0hn5+}F#!ND^_iqD?J>Qhk-$W;jLqu zAlRJWQc}3hLAWP4VRzGdpj(`{85j&u+;b9Uj_BliX`-TQt+X`LBN3qO;*O_F* zIl$)aa}xoX2g1naZI)m>%*YJ1aB>Ex>SQif0isNsY{zPY-MBv1>&#H&Oz{~7_vqw< zoR;_$!hJAVj>`eNokd(OOkg{A^5Ae4C+}^Dis$^s*v-%rZ~_Oz#AwyY=Vis!IT@Jo z1V6%2*938dtAWrSh?Va}%!u=!r>HGL_t< rDhxGC#0g(4B8)=GASg!76P;Wruc?XEIjn4;i021FTOezW7>EY|>~JGi diff --git a/examples/zips/health_checks.zip b/examples/zips/health_checks.zip index 4f20eac56bbb66ea9304ea87afebe3159e6a4ffb..8745580bbddf6ccc18e6f995d8da4b2171b53a2d 100644 GIT binary patch delta 1398 zcmez6^2>!cz?+$civa{A7EGSVtE-Y>f$``sS^RJ z=Kz~`DnR5!$vrHQ*vhFygOzb7L& zT=Ka!Cie&k84(jCkyqZIxGsi(4C1@rqE5sGWuh34 z$UY}_2ojW&C9SbqHu;g{7H~+;l(JSr_dn3f0p5&Ea?J3QKlz(f7;a^V)R!lngRtk6mDe*(|8pFa4SQ&tzHpNgdvo1D0vE?r@P6C GN|FGhKuse6 delta 1398 zcmez6^2>!cz?+$civa{2jk_oE>Z(*4M5b2*acKoN10%~zW(Ee9dY~+-x;PJf>O_F* zIl$(fiV*>s2g1naZMI^3$;1q_aPn_aqsjYNxHUsVI2oAnSPeIFat})+b~AsnOb44e zF-~K$z8ufw^|JgV82g_chg0)8{z9CZ&uvANrzfA~_QdW&EuMuCqt5Y}VOJr+@5u-b zmwaxG$vpx>M#Kb3fK*b1udBFutg23>P z1VuaysDZUcD+rnr85fcDGiDWLGBPl<0#k_@R5$Zs1tEPnJ9)M zvd@Vff&}GcNo%Z@O@1V~1sswyrL2|E{SWkUfHxzP95X!SPyQwqhFcjT_2o%t;Z}w) zjaN~6vZ#zHZlwqlb7azSD?^z0RfZ_{<;oJ}zMrxlxGhDvEmg27kO Gk|Y3#ATz}P diff --git a/examples/zips/id6.zip b/examples/zips/id6.zip index 9991bf45887a46c3c5caab6099598a84a72484bd..4116b247e84483e4b6ae4b741d32b56c95a443e5 100644 GIT binary patch delta 247 zcmaFO{+gXPz?+$civa{A7EGSVtE`e=oswP%#HAJ742&!$Fc~VL>jvAx$Rx)Mw`a0CvlTJQnwjl2 Wv6{xp1~im`83+X!85oW-fp`EXyfW1Q diff --git a/examples/zips/identity.zip b/examples/zips/identity.zip index f20c97df31a1e55222e955bd94b4d6bc84fa7b83..4c7b6b8780e56c814732c81242afa4c3359e79af 100644 GIT binary patch delta 1990 zcmdm6zqg(@z?+$civa{A7EGSVtD%x#oswP%#HAJ742&!?)LbG+4nZ`~>~6s+hb{@Eq9xz<`1SRiOVhG($t6z9$s6lOGDXVK>}b_#@bMeG%-o zZ=NI~3JHW&qRv>2*vu%V0r8`bgcEiZO%m^!!M2phxMNpwUM2=&i=G?~cTALvhp6~0 z?}^=v0EHtE72--bA~Z(HnGqb6yPjOE@&P8JH5?2K(%_`D--a7!QhKf&3Gtw_nmu-_ zr>R9itp2EOiCu-AhBm~E94#a4DmH0dgs5oK#i8Pit^vfB|9WQF&G6L!4^iQ5h+W0x zsfO#oG2v!}BRzH+nM0g$*u+c;Jud>&Uw}6wlN>WV*G`r;^&>`Ex2YpB%HEm!5Th){ z%$^u!d(C2qQD$v!M~t%B=C;Hr`(+-BTN%7moLp()iCY;Wc%N8=5Th*05|5<_({5S@ z5@VW=RRA%{_F07zqs-KrD7S5~4kyMmT^pjJzK=L%?`?dEu{6%sofu`uZ5@bFrfEl% kvTi#UVodu;oU(9xTTQIlnUxJxt4IOiXJG2wVglj;0FkBb&;S4c delta 1990 zcmdm6zqg(@z?+$civa{2jk_oEYN%8iM5b2*acKoN10%~zW(Ee9dY~*wod}TT0IQ31 z5CN$JVPth1*CsIu0?mm$IBWBYBt`~?YfKCbvXdDVL?`bt?;HkL6>PTVT*L%c@qk+& zy9#9<4OXxUKS6)2Dkg6fJO}naC_G_673hBr&Cn32?+JzNVm9;e=g9lf-*wuq`Dr?$}kFmx+Pcq9=#L9TVl^Au2x0 zdtx^uK;Z~Pg}4%q2#ry4W&{W2t|u3(e1OSl4F>~*G&m{kx8cT_l%6X`LOkfKW{=(K zX=)J=t3Rq+Vpn0Op$#!3N6QGiicMMYXGt3zn&R(Gd%VGLsWPhVplPF zs^L0tOt=~0NRORH<`8EbHZfB|&x^q17vRmvB*zTTwUeby{fJT4ZR$vjvUjFF#3+j~ zvnNK`Ub7ftlv$hG5uCs$f{;#P(T-X|6z#3+lh#A7MKw40WJ z#F*w|6+n!#eO95wC^NMt%57V$!-+9X*M_L5?;}pxdmCS3ERC~uCq~(ETL)s4Y1$E` jtlQ3o7}Guyr!3swRugM>W@Q6aDpElB8JIe^n1FZy9Jmj%671M5u;3n-Cq-{rL1f~yBS!3a62Od!+BN^4*+eaN#y_l delta 320 zcmbQkKZl<;z?+$civa{2jk_oE8mm+qM5b2*acKoN10%~zW(Ee9dY~*wod}TT0IN%J z7XhgQVPth1_h&OP1I?MN%WQ*H!RA`#07kHi3oMRURZLc8-3C^0kJV8L-F&b+7@6dl p;Vzl%$QDYBvK?$*#3)l?_t(T~DJvV$ZUz=0+|J0raGn*!0{|6eL+t)nf)rX1khUT;3}G0u#l{RLSp^|( zF&Tq6pZH8W1rg?kn!o@_=LQQK8_7(jOg95Dv4BHJrcoyH8{2otvY305)1>JieBSq- z`#s-tcoR*+M3bP+H1L8y=l#6WD1M=R<29STc;5lf_h7l2Bf4YUZR4EgO;t*UKgT zqc_nd%&FmE#K(rW>BMgaClI9>X>{V(3_FyOoK4R~M^m;2h<1~nuAw#8gPARs?Q~+n z5(661c?`Qx*_%QqLW;_X-1g|{ zzt`#s$4!aVap7WbaS)v!EjEGTmXc&Tak69xdT^kW5$GGGmwe<-SJ~3(8g5%Fj9y(C zqX&~^zToiGAx0g>@|6KUX=kM6p8aR2^im~bz-KB8p^p5cj96bdI{Jcqm)cW|KHfW3 z29@SJ7+w0tkp`YlI}LO{OkZvX4QB%**Ru^D5uJB@2c0>6wF-`_P;p$OSe+Cqo;epx zSM5LNP{_|D*4C_7dY;iKIc}r;Ol@;G{h7Yzm%y{3uNaAnyYMd%>szNbb=#|d9OeDbTYVXvQ+yRfH zSw=C_8YW)1sKjGe86$G>>MfQ0P=!xU-g%F$g4+9#^e}*^MOS|S{ixyoHYlcUfW99) z#s;Dw1iEXC)wTcHUS2*qQnzi@*PfGe{l$jjFmdU3MyV0kyWr5FLB=MF{bMDYl{Xpr z{_|!xly&?zW6s>S)8UlZVMZs850Ah`IOt}~`wjQXt}~7@645f+1$9`*chW8Xal8-e z_;iwSmphZEL8JTuBM}1+szJl}D1my4c=l13yb#Qf8UL-DAKwLuV^0zyo_{ToUtfq~ zHUHlWj5z+pg2CRM&ctAY(>pNO=BG&*tnq0M277sC4+c9iqsL$iGpQJC-)sQ}yFY8d zV5Yfb4EFsTstYmmMHsb?c~os-3%fCDjs;YZUR*R|)M^&9Fxb)}stZS!vN38?OQ^h+ zE~jAB2A53;tUi@s@>btTb|KWHNJ22fAhi&ZhtZ2r5KO-$hXPk$AWtx%lMeF)vq_{e zo?s?NG6)0{0jXCYnC42a`;c6Wf9HJ&W_qMhUy_c|``j1TU!@%o z2k_qQTwQ zti{dcPg-0*5(030<4OQ7FY5w{71Q6=K-_&-2jTMaSr9Q|&YcM&`k?1ux1>xR33&#B CrRnDY delta 4703 zcma);e@s(X6vyA~dq7KDXg9WmEf^q12MS6S#Oa2LtrS`ikhWH67{V}Qi)2}y-6|k) zi^)2O^NDY1rzpZy)C5+LbZ)S)v60MV%5*aj6AL(mWEy2+`MvgCvMlD_T)*<8^_G2(!1sV%&LD1rWf-nD@Yf(075J5k zTxnKRkPCkQ&vo=@SvH`Wx^VI?+HT?j|NkL=9QeCNg18ijj)M!PL!U;^$N=5{Xr5`DDVG_K8dx@WZn6`*JrE zuyTw)?TF*g%y97~wyJmE*`I8yFc!)fmSm=*C>|w zx6VkGFlEJIBR=bPH;$7-bQu=uR zqzzYE?4oq(qAMGFI_=hz{V;yD9c#FoD7l_#`Vgsu<2&ds?5meBOtp+*68Jhz41elu z6j`y*{C|N355JUKzV_05RyQu|*d5B8`R?T4Q&NU0oj5i;f;YkeA7$Qe`j&T{VU&`H*3m9phjn}>+2S9@ z`*0nfPEzi2ck)ZDVSh+T#K6NktYLVZPCSJ_{kTh92&N~L|JE%}?qP|ePt)U{e=QMT zUyx)4``-%;KmODV!QP(EgJ6TxJ0RGmXBr50=2;;Gd)dDSf*tqkAlSS=3xe&NDS==Q zX7muuIID$V-_3%$kUUogQS;1!YKxuU4N-H=gM#$pf(fGLT*!xDiwmGG)Gii4)TS0e zd8=H?gs2TJ839;h7J}rhu@mhAs0j%OL54wSMW_g(7cW7OehDrKtiDJVK|&`SVi9DM z2xBaQOpc)E5F`RZFNYw_6_&Az?+$civa{A7EGSVtF4k>oswP%#HAJ742&!423^Zr*Ge#q<3O4I7?Pmq6c*kyuRmEg$jx}HfuQ)7~(9H+CgON#& p8SawFuAEN9C|k+tK#VeOE_Y3=ma?(|?Pg#B!Y)PzhT9w<9st4qO5p$i delta 320 zcmew@@>_&Az?+$civa{2jk_oEYO7QlM5b2*acKoN10%~zW(Ee9dY~*wod}TT0IQ2J z5do#q_b8F-vR%M1`+}A9fY%CA=Xj{z_sGjm^PQb0I1|OIuMywUV;Sp|8 zPl$?eF@5Z2%o5uGQQ<4$hh4>b32%sszmnKPV{@?7T!@O#(w11wnCu_}Ng4lTa73Dm z>}oz>fJaKiUsZkrOo=&+lNnirCkx1lU^mc0?jtyCbmVaaUWxoyu!0-~ZLB72Uajy9 z;^-+#hDzvZ9h@f^ndF$^xnlBjC1+xk`6zo3qimb96EVu9R2+y=R-@ugjIx(1_QWXj zQnevQ*$UMNVw5SV1rVcbiW*VD`%}%17}Fxvi3;Am>Q=;RnyqeWDDO_F* zIl$%}_ZI<~2g1naZPsG+XJiIiIJt%?$Ow;(aFZgt#ClBbFfuTlWo2N9omi+nS)17k zyV;e@FCk{f3fNAz6XQ_lWMC%7ipdvQpY65y2A(asC?K0OBlD;LFEu)MCEvu#oT|&Zv_DID)`N&=6u&fsg}M%O)QY+6E4z zT44tz^!Ns+A4VoQW_U`Qd|%iPw=#INPxcpy#jOls+BuN~+{zH91&B7{R)#R`vuGG@ zWeC%<#d2{gLzwnUEEKmgglUE1*~BROC+>+`8N$*`i8$QK5SG4_sKu=eVOobIF#$43 V3Qu?-?Ch8F6F^TOlix~70svA16l4GZ delta 1167 zcmZoOYct~w@MdP=VgLb0{dF4+N}IuW3H z4zPL0{Y60LfiSXpo3$AI8JU3=POf1JGQwjc+@#1Zu^y8T_ zR@gxaJ-)%|hmlE+8J^N6-xv17tqdORll?_vaVtZZc1|P#w=#rj0iun#l_5;~EEl1ke-6W3_biJAqneuo-zG+E`UgUMo@sR-h%Si&eqqY|-nCV22wdrriApbogAL!$l|8 zD|6v;_~uq|Ziu@kOBi4^bn?v&XJ?ZHX zS5(LvDxoJ~a8hSvl4FJ^_Q|JZ9f(n;D`!EBvUWKeVw63VGsmqAo?$23$(!OAGD>2IUDi9TJ@`_HxnAWUFl-uqTr_5T(mKaNCDOnPu?5mPBG0K9J tiSoiaWjkU_<5RIGMp?cJQI?)ovC+hu7g*VVS%N_n2sg4bFl5StcmTxag~R{= delta 1594 zcmdnswZV%wz?+$civa{2jk_oEDyvi)M5b2*acKoN10%~zW(Ee9dY~*wod}TT0ILfz z5&@|LVPth1XPskW2AVTDn^_C1g3T+Lg&4sq_Oa+;RWXV63RwO+t0q?Y%_4045EInc z)roTK_+Wk4}=)S$Ekx=#biIu2VmD2a+zaQu(^ioB*X|09_&FfxsPW(*a!z+ z6Rbu|?%zvQimQ5L4)N{q6-3PgpQyrL5^rZp=P<+l68DYI6xCC1WON|wYZ`>JG3jItnQ tqP(z9*^U^~_*CqPQI@Yll%=OtY&5av1y(j-mS7MC!j0?<44JYZ9spiNW^Mog diff --git a/examples/zips/license_manager.zip b/examples/zips/license_manager.zip index 986910723f1c876bc665f12edec147885d9ed5b1..02648dc68a896ca45626bfeb8df248547bc5d27e 100644 GIT binary patch delta 898 zcmcbsaaV&kz?+$civa{A7EGSVtFMw@oswP%#HAJ742&!=sxRY~H}`3~|Ia4hQTiyg2hAD)w+;cjjh6?&}a0 zuX((%nlagvcP7{wPkC*zD=_0*4_5Gk&sGUNq`@)5$Rx)MkCVyn{Jz8}+r}S5j4~4e z4`P(f6YwWS8NXmQG0Nr$W)P!HO~{QHWqm?^#3=hGM3fiug(HYD?WM4{Cf3MeWdp_; P0}l}9u`)2+Z?>5M5b2*acKoN10%~zW(Ee9dY~*wod}TT0IN%| z7XhgQVPtg^H*aGG8Z$YE(GRQq| zSnLXFS$BXHSg=K5SFnt2H&{Umy9HJSn>VmKLmcsq!vVVrFV1|3ialJ|ow-?%`#MC$ zYaTDGW=!_voe6fvQ(jx_3e5P{gB85svsFS5X>g1%GRZN+<7Bcszb`S$w(-Xhqs&CW zgBWG=1pJ9n#xIynjIud`8N?`46LKR)S)Y&}G0Of45#@z^;Rs?(dnxR#i8ZoV*?@7z PzypMNtPBh{`9M4X>cVyLsS^RJ z=K!0x!c+ug9tb0wxACJ3Gc(Y>$rdaoSQTt;V6kQdtJue?k6i^Ln-fHZ8@nk{j+s24 z-3_}@KiN~6z?LO)VRz2tm0at<3Zl48l+Zl`4je`%Ic9h;PTs(6jawN!bSCriI1{6+ zh{uT-W!HFYaVtZ(&6JlYOK0(h;5H561pz)MO{@XJ$_5MO_F* zIl$(vFckrr2g1naZT#rM%nY<|vIUC?Rt1|ISgaYrD)zDJV^_h*<^)mU#%@ZKVmF A)Bpeg diff --git a/examples/zips/load_balancer.zip b/examples/zips/load_balancer.zip index 4715ef103a900526c96fe8cd02038479f5250d4b..5ddfde33d6c265007559267cdbbb6f4b51352887 100644 GIT binary patch delta 532 zcmdmPy4{pFz?+$civa{A7EGSVtE-Y>f%iCsS^RJ z=K!0x-ChJ_9tb0wx0#Dkm!BDE;bbcT3!+S#JWaqAyHW22+*rUyS%{ipSJ5Qu&Ind< zM$8(kipkRAo52b$id!q8yA|wrMkYCCcqmQQlW@kZ4DR{KlO=p{D?^yZBZ(*4M5b2*acKoN10%~zW(Ee9dY~+-x;RsO>O_F* zIl$&^w-*7K2g1naZRTRsb;?_#&ZUy_Dkx7mj9!it-B%E<8gL{7RWC>r~$`Gb8NxI=yhA=Hl YGME@;_a$A3QRXV;DS+k|ZM&1B#W)?065Rh0fc_Oc_N`7@pdLa;(R&X;gvb8SMVwW*U?C*zu|p>->IR7wjfJ=bZ|%vtGcKIOjhQ zz+sey;3J6RWJN8BGpb6|9lNWpihf~)#*+m^B(?>w`OEuuwr6hPyl<`!IfJanr6`R#%3Q)4@jU-*Rsdw0(dT){7Wkcy9*Mu zO#g%TU#rkM+PvZ26!_v$uT1W`-`;)Ze@s65ohCt zTN%Q%Q#Qf4l_5;Cw{^m;3}M=0+Yn-uN!oeiR)(8PITN=sgxk1X!iiDV;*x?}8NyO7R~OvM5SA9W`r=lGFzvo;0&Zmp z(-PhMaVtZZcF8T37-f;}cybuR(!K6@@+-npBad9%mLg0$=;4N28NxJ8PogZH=jo}5 WwE$yf1J$?+Kv=}bz|dh0;sF51wpOeF delta 2519 zcmbO*g>k|ZM&1B#W)?065O6f^p2(}KQfUyGUJb;h72FJrEH9ZE7+C6ovLJOLK$-)r zF3w5>qz;6U)oonE!Nd$SXYv_wjY+ornxP?_49vtBI9Z(86|0Gx3z*+PjErY9A_(k3(St<7Z!-%b zjWWkkE^IKr3o&Yfl{Hq&Cf~Q(3J#;`*49eskpWDo0p5&Ea?FUp{$lNcTNxr%#MyY^ zR)#R`lua;hWeC&kZJlr{LzuSMHiQ^ul6Ky>l_4xW=pj9Mp`A8vr3j1P*#+TNhA=V7 z9*@Nc)6UxyWty{tJ8nx6rmb-Z#jOnCwm2K<$##zVxRoMI?01aDtqfrzj}snmAWUm; z$|lA%UgtpE%8*QR&cv+@;WloUaAK6TxTN4#hOm^&)djaQgrxjgo*ag-bgw&}{ED#D$RiiGr3ljwdbr_MhA>UjlPF8)d3tJM VEx=gWKozb65Ek( zNCcz~gpt*4oL9%h3^Zr5JhKH+22HMJ_Qq<`=3C4Q7{Nx>vKkO))J0Zn>_#cD$wFM^ zz@bf?QT-f-*p0fv@eg8DEvwRGA0=*eP6lRT0&KD-4|c~*uHd-?_GUP*0d^~A^GZOh z+{SNDoa-e8BC#9QCh&_LY+18}9(EN+B_2USeU+3cb`_tc`XMS>WekaP&Mg^R>_%zJ zo`x9pQ_fTgJt={c93zt)Gd$5v4v=@itqh)qCvTE>!>tTqnv_B$ZeQZ%|Oi ztrTJ6R|QYp$`B?dC|crHhA?fnqCIY92-9Sg>~JeXm{y~N$888@&+(atu+&}Iml#X8 oDW?;o%wENY7-e%+oN+5dxQ$5_Pq-m`nyl(AfS%?i?^Bfo0C^`h82|tP delta 1301 zcmccaechWkz?+$civa{2jk_oEs;g8QM5b2*acKoN10%~zW(Ee9dY~*wod}TT0IQ2I z5&@|LVPth1=hZPW1I?K%&ul@IL6fVQy|J3K`4;m6MzB$}tOmpxb&=H?yHN^kvJh7} zaA*@}R6mCycB8Iv{DT-(%c?ZlM~PdVlYyC-0Gq7IgWYkHD|qgJy&2AHfZfX3yb=&A zxAEH(=XyzjNbE+n3H)LQTh=V0hh4={iARu7UnOOVUBzdqeu#=z8AIZnb4$h+yHVP* zry)lDlrvRAPfFk<$H*kd3{P~E1LPfWD}$%u$(!Wea4SQYCZ!OGTN%PM871k-8x)jr zD@B<2RlyUtGK7ffZ#;HN=w1MOm61t~8SdH1VZ3p~D7(fRON_EmzCdD> Zo#1mPMwuZ$QEuDF?<0Wj)5*L7k^teTfBpaf delta 515 zcmZ3cuuOqBz?+$civa{2jk_oE8mLqnM5b2*acKoN10%~zW(Ee9dY~*wod}TT0IN$3 z5CN$JVPtg^k6vX48Z&t=qd!*pO-!kbU&R7*}-p?G%3RWS{X^CA$4yPN$jICVQ z9Whyw`!d*w_uO_^jhO7nvk9!=8;_k5x);D+Wn_|LhI@8$7;hXg%C7Oo5~D1XFOV2z ZC-~fnQD(?bl-oA)`v{=>bTY4iBmf<;b&LQ2 diff --git a/examples/zips/management_dashboard.zip b/examples/zips/management_dashboard.zip index 647bece64a87f9ec792433e634191ac797f9c71c..34c3898f92497e7590581720598950adfcb38e31 100644 GIT binary patch delta 484 zcmcbpeNme?z?+$civa{A7EGSVYod~0oswP%#HAJ742&!dm>3w0g+V+3Ra$U0 delta 484 zcmcbpeNme?z?+$civa{2jk_oEny6G7M5b2*acKoN10%~zW(Ee9dY~*wod}TT0IN&2 z6#=OOVPth1w|O!00nLfj^=7@z&CbAJtv;DwKxJ}(2&XtF12Z-)n}e7n*qMQPCg*b6 zV>NX10ZvCYunHCdYwRk51@19|RhS4lVO24?OK2-tfs?S461uCwzGGyPV}|>0@-ks> rVw4GscoL(mPQ;fOWp9ZyEkZOv6RQ_k*?>M_U<1MqCI$v$VGs`h$FpZa diff --git a/examples/zips/marketplace.zip b/examples/zips/marketplace.zip index 02452ddde48e5ab866be7d6d9d1f1b33aa9f869a..4f0b3f30da7ba11da5a40af64e41ab179ce3dc52 100644 GIT binary patch delta 452 zcmew+{!N@Wz?+$civa{A7EGSVtF4k>oswP%#HAJ742&!>SE0CsS^RJ z=K!0x-Bko+9tb0ww^@KukC_>0;bcb^6YMHFS)3TbD$cPQVOJr-R>%Za(ZOMfRmJ41 z92>z3Iyo(s(47GG5+jowGu-o&pK!Y3RtEReWN)ruVw4@=aw0~V3bz9>%G$Wy1<<`P I`7XC4031hbfB*mh delta 452 zcmew+{!N@Wz?+$civa{2jk_oEYO7QlM5b2*acKoN10%~zW(Ee9dY~+-x)^hO>O_F* zIl$&^cNGDd2g1naZ5CkEV`c_gIN6cK1iOk(7AHoqigT<+*j0$I6*7TUbZ}T=RWbQ0 z$40P%PEJcDbSHql#KZ#;cr=%AGacKoN10%~zW(Ee92B0iRod}TT0IQ34 z69K6MVPtg^cfMl=8Z&tnqdivn&3_s9F@aU=V+p{nLWxy@5v;l<0-_JJKWCLRT%T6Kvc})GsmvtDW5CE7F~fDtSTnY75D>o=o~>OtO_=N5|m{I zs}K_P!LFi6bS=aZC2<_i$Q4(IICQ$C2X-?)OIkrx7|37`j>!!&Yr)PikhM`lk1=q} zGBU|A!{c^xpKJ&*%2?!liBVQ87e|b;&vMbkC@YZnB1YLA`9NZn`75{*qimZ(7BR}4 u6a$D+wnZ_D7-a@ZM7eFcQW!C&@hf|2VvTxMHed>1-~&Q$AWKme!~+1RJ_2X} delta 1048 zcmZp2Z*u1i@MdP=VgLb0dml4xKLPf!&PHl2#BE1~S-#V{(JcTCg(=WNnntV+sVw4rj#Sx?Ivs^SW$_nJYh*5S&K9Cq?{tB+dDBGrxMT{~h t#QA6h@3`{K{UMSfiem4VVHL_<+zG$WoLA@c_Nu?R5YE diff --git a/examples/zips/metering_computation.zip b/examples/zips/metering_computation.zip index 91e62d69599cb29f7705d428781d0e71413d4c73..e2db26957c5ea69d8cf2a632beb6b5a594ba932d 100644 GIT binary patch delta 1162 zcmaE6@yvoZz?+$civa{A7EGSVYod~0oswP%#HAJ742&!>Qb%nsS^RJ z=Kz~`*ii&z9tb0ww^@SGikTT`;p9-3XrfG-e1#NO`g0LHPKxhKQ%fTW}SXE43DY6Y5YDuC_O6V~S z^jUy6Ba<96JdI60ChCD(8NzP{V*a?5Axv8+mWf*#!ZaQ60^G_FrtK4t$E^%un!Q9C zG0Kihc;i-vu+&77r~sKKNmPLFOX0B;;e{HhAY$D1K`IirGK6W_(h0;Udn+9vfSy7o I`^rcH0DNQ*OaK4? delta 1162 zcmaE6@yvoZz?+$civa{2jk_oEny6G7M5b2*acKoN10%~zW(Ee9dY~+-x>PHC>O_F* zIl$%}b`$}b2g1naZI)oPVrB+fI60IhnkbVdUtvkYZj=|RA|u$SJhnjMjC#x#f!!#7 z_9;wYqn>fvVpn0#EN9{a20>*(CM^2T=K2qH3oD9r( zq5&Sflb!ipu)A|Mzc0imuLZq{3zR6KAnZmR5Sjq-a~2$Rx)MPh*phiF)8xhVYw#m_Kf12-6mdW#U$bFil6i0Jk!PY5T>Y|PCsS^RJ z=K!0x(MAMh9tb0wx0#VKlZhE<;pALqLnAyk!cB@?cQQnH87l)rfdm7C%H)IGvXkF3 z^J6z$fMqi)*zjYV#@JQxayc;y0~z^x1(M3XNGdf`@vFwIWL9=9@t zY4e3Vh*8EV?1)<#!qOaJZ`{fdmfjSOBt}_?h?^$XaARcyMJFc^E(0c9c0mvi0Q}{p AWdHyG delta 743 zcmX@Cd03M-z?+$civa{2jk_oEYN=EjM5b2*acKoN10%~zW(Ee9dY~+-x@aSO>O_F* zIl$&^v=ITB2g1naZDwT5WMT$dI60Tu&aFZg}oeU9P#>&7@Ai=<(GWj64?Buu1 z{MZc_VA;$HHvAZ;F?JQaTuzLFK+lM4hLa4Ulc(d0{lUbvMZOtTZR$E^%u z+I%4oVw758@Doqr8k8miBT3J;--l;+*sK_vB?R9%YX@&T@b_r09-Yf A_W%F@ diff --git a/examples/zips/mysql.zip b/examples/zips/mysql.zip index c388dfc213ba6139689e405798be776d460d2733..9f656550cd32fe1626e71cac5c9e9ee67d367ee2 100644 GIT binary patch delta 941 zcmX?SbIyi0z?+$civa{A7EGSVtE!S;oswP%#HAJ742&!>cTAXsS^RJ z=K!0x*+B$k9tb0wx0#(Wk%<{-;pAFjg~@T!9GamaoD9r(tcDvoc@MJ*b~9O6L|DLP zN^_VK<+{mb9Cp}^I>B*>8EjN9j~;dv=XqQi!79Z0bg-)k=Tl~ddQq1+=bRJ9;WIIj zNf4i{mN3R@+2l_W8^Crgl{8jD4{UJcF*3<9!=rifFG+XY$`C=FEait=8N#&7Qr5VY zAxtxncEYU;VcHaFSKP`Fru~-oAx2rIj14i$j>}l#R)%n!vMfO_F* zIl$&^b`SxX2g1naZDwaoWMT$dIJs6>VRD=_hh}I9Cj&DctKmjY-otEy-Aoo15f-qS z(j4YQxo&b9haGmKPH-Gz1{>AOqlaC^c^+3runKWL9qcN?`IK3qUeqPdIp>6N_)JV> z62xb#C5*9JHu;mp2C!XAC5@HP0~;K9j7)OO@Mxa=OVS;;GDJ`(OZnkehA{22lr?T; z2-6Itop38dm^MY)6}K{kX}_g?h*6d)V?&Ix<1$vbl_A`wEK8J68)WhL6yb#@vW}Wq WBa4*{7-tMTK)8s7fnk~?hz9_w>JlCCsS^RJ z=Kz~`%tHiZ9tb0ww^@nNpP3nG;p7q)OYABRvUo9qRq(OdVO23Xfo(fjffTz3QI471 z#$JNeq|JOB1rWO$IZLst;NrT=1h(uIPZ4$%1-z^fA5{qCVOQ}>U<<^SjY5^!RoDsd zgxK;+Gz+_m3NdSlifs}}*j4CALRDl*7hqTMPP!W6(j570>?&T%--5XGgkm9f6~0Ph z5O<`hb6p$Rx)MPn(l@H2rZagD1JkwVGkX zDEq4EPK>fREg#&<5NDLjX%*mjV7-e@2>WNWSXIM*&GFhWqO{~e1l?|9W8H9jP0GI;iYJhkE DMqEzY delta 1356 zcmX?{dN`Fgz?+$civa{2jk_oE8mLqnM5b2*acKoN10%~zW(Ee9dY~+-xO_F* zIl$%}^AG`<2g1naZB}CRXJ!UkIJtzy61$3nEMAOY6?|-VSXE3;VA~E>AjR%Mlw&5h zv6o;qX)_;30mQCG&Qk0uxVY{zfh~K*Q-obb0WT}WM->8j*j4-z*aER-qfjMw6?Vcq zA-4Py&BCstLd+VXVw*$~b`?63P!(Cy1=v-*ldguiG)F!gyNcKHw;(P(p;(Arg|Ctr z#2slW`PfywRJjB(W1kuh6^`l|5EW}Q?3B<`2sp(tGRZN+)8=FzO@G|V;7M+Bt!5Z8 z%D!s46Qe9n%LlhIgxk(&5oM{1b`x&X5MFqp-As(KUY!PFl>e2%6sS^RJ z=Kz~`D_R6(9tb0wx7m~NC=WBx!pVYso kQn|z^GnMusM%iNNKuxSZWn}|;n1LM#BY{!BP6EUO02_UNr~m)} delta 553 zcmbPhG1r1Oz?+$civa{2jk_oEnyOS9M5b2*acKoN10%~zW(Ee9dY~+-y0id%>O_F* zIl$)KiWUKx2g1naZT4h5%EJt_aIzquCs8I%uH%cxZq!FUL3XfFtYUW9RfLNLGJ;jC z7I(&~VltD&4zPl~63$BKZUy_Dkx7mj9!isyB;#-^gL{7RBFRkL$`GdMN`>QAhA?fJ jR4y^fOr?E@QMOn*P!p?9S=oRdW?%=xNMO{jlK}AmO!0I! diff --git a/examples/zips/networking.zip b/examples/zips/networking.zip index ce1978cbdc3e2399f99546afdadbb2c056046d10..ac246b3e200823de7132d56948d620a4495bd6b9 100644 GIT binary patch delta 4883 zcmb7{ZA_b06vv#a<#q34UDpP^rw6$5t zChwLzO6l03V++1U7BaVFi4Lb97I6DE{Xk|-HZ%RC@q@Y;^?7=+cba>j9NP3l)BpXQ z|2^m2bDv(hF28bJp6smU6&g-_t(!)Hs_^ORN#taTA9;>b_=R8pqeBt1 zA>dCblF+6LYZ64J`}y9r+&40gTjEi9uP)%%AaB1WL(TExYVq@6qagO=$4g+{yRo_ZT8eN8W;N*Q0Ueqf&1JUNu`QXnCn9DuETeyz%jnst z+ZMtVzqfM>3}v;H&`|>x7v6GoS2+x2D{ZEu=1Y^6u|8aO8_?!pavr=5vuxFLW{+(r zw)bgGAy&(tVl-zZMRk2|sjI;P_1G?Z_hsr{0jnGs0 z-P4RhZ*^JaT5*`g;T-zJt3&@J4ozqpxE z%0Tny81+oc4j5{##X)zaZC%2s=q>~L`*cPzxYOMCZiX+*6&%<05XTh<7Ba-;$hSY0 z9%yEN3LZ=s4=}EqhYu>SBD0NQHa@!EZ)Yghyts1l_&tm$QI8ED15*csalGTuzvtM1 zqEi`WcuJzzem#6axPkRb6zSCoi%rZKcImaxaN>J98AITQ&ICLJetDw^HbT#bS~sYK z5n8E6PMr?5A7#{H_-Gn#)^pzN)M}xhy>qeoGvnI^Yp_3k6;#r^>+SDxRTH#ggQc$K zN)7fp>CpSVMqHxY6E!e@BPR~iQR;WPaUG8JZO{4tLy|BnoV7A}79W3bL(6>?Y#DhP zDC>7XWFPf6Lu94_CtF6m-5%1TivxLVY24rFpoBdF^hn9#F!b$UDp&bcY*fK)95tNuZgeDGvx^c(=K%sHa@kt8RK>T%uK()Oas)o?&CZ2`JzM3d! z%Scj8VNk(F!k~gBh4kpLQw8k6q-d|4YGTWXKe0vmNl=TrCqa|o)}+MQCH`EeCHxWD z5=>To1{Cy*GZH}`OiDdFcf{MrQ~MyY&C{TxeQDYXp*<1-T~KdDB$}P<^iHG_67;FF y689LPc?R|9*4ZKm(KsWKJ3^eDX@tvSYDd|D!_@ zlRnU!S}dZ?h^$z_w9Jj=y%06wNSB<;_>P!{K3#*0CgOTQW$sGwFTZVp? zK9fOJ*!lB(ngA|SNV+CafN|}9P}8Ugbw@VOtx)Zw=~XPP(3BK&xCiRQ=91~ zUR8(rI7+E8!%*#-MmlOyvm}e7!s&bH3VDV_vEo~g%wtIf#m!AC`D0Xy>|jb;Lx=vZ z{TnCxkE|-#4)$)?O-Ehb@FCv8YqgXTcpK`ueOxIy7vip_qEj6A(&O8tNXQRZZwbCUdOj);hu6NB^A8ECqL(>)y@qWvPtg+8^S$(!fHdupIgJ zrO^Y;>`TRi>EeFIb@T8`GOWmIXP8Zlt`9mGigmB7Ts*xVMwF<>ijRTu5QFi~p#!Vu zSdXGpnI?EjqSt;qcp-KJ>*OfXr;RN(GH2MOH$KOS@9AU=fgd}ScnJJ@q!>0r&xhJJ zDq8*Br_M0WrT>vtZW(a zcYmyjEhDtUK{H!MXg7i)Q-{!m0njiG82~6W4mv)`p*o1at`MlUcSE%hTEoQi5ZTug zm24SFiZKi-*hm;uu;h>qJ$|Z?9hemD^;0cu8Sy8yC_f2mQP(7B65N^;IlIK4^R$RR zB3pvVYR`azetAYD=z~dVWao}}`($b_M7DVvbhIx`TOhPYBA^TE?TARTlbzm)R6~M3 zeOBZiBQ(#T4&6Fi3?Uk3L~=)nvop;QTK2ileCp$qTp|49vc%p`>NxJre&O4{H|1WQ diff --git a/examples/zips/nosql.zip b/examples/zips/nosql.zip index 584987a68a49da663db51578554293ae103ce5b3..3ad57d5d40e2b660cdf1f31697d978b24f1693d5 100644 GIT binary patch delta 858 zcmbQBF+qbjz?+$civa{A7EGSVtE!S;oswP%#HAJ742&!>cR~1sS^RJ z=K!0x+Cl_m9tb0wxAD6)Gc(Y>$)YSKL>V+Wm&F>ZNt^euI5B~ZVq`Zb&Zro6JM2cS zV^4w@CCsIVT}3FD3nSRFIo#UBS@xRS2)j{+JaZtHUEnjus$#M@|9Y@pC;5$)&;t-0 zA&g9N%lU)Xtqfu5OCd|#$`F>i2s;p?Y?-j5Ce~PBWdlYA12+&lurM&};s@~nR2{<< delta 858 zcmbQBF+qbjz?+$civa{2jk_oEs;X2PM5b2*acKoN10%~zW(Ee9dY~+-x-dh0>O_F* zIl$(vwh#fC2g1naZTv3H%nY<|vM7rQQ3g%UWwFL;(&jxZPE25<7}?Ez?+$civa{A7EGSVtE-Y>f)^MsS^RJ z=K!0x$5jMm9tb0ww^@|&0~0gQ!pR&gI8-FEus~E~uz6xP<0#u2Mz9$r9FEvk1PI7N zRJ`Q$$F9PMs|ljwBDWcK71BJ;5EY5M#zgsf@(x}*>_&0%eT5jsBw&SI1>C^}f*#ma zz#SYYY>idLZe@r7F_-WmM%hvcqJo!SGK?70+9f>&(BpLS H14&5$wQT91 delta 970 zcmexq{L`2>z?+$civa{2jk_oE>Z(*4M5b2*acKoN10%~zW(Ee9dY~+-x;QI*>O_F* zIl$)aaTNiX2g1naZ5Czxz{Cu+a54uA4i$+kED#kLY@XQ7ILfw$5o|^Yha+|s0RplR z6)!pcv8(XmYJ#Y^$ZdvQg*1;dL`5R6F;RY=yo1*cyHQ+xUm->@30PrQ0e5hLpa*sp za0dqpTVqu*d4cdoaHxccSSz82J2)O0ndF$^F+O>thzD+E@Q9o&EgDRWvI)c~V-*W0 z#cb2x@Kz?+$civa{A7EGSVtEZA*oswP%#HAJ742&!_#QB zTQGs0Glw%3y9!aR{SXz`dCak^P~v^S0ycwH$O5a1$$>&PUxWl>O51AVyh=CLT)>;c;3sgc#Etwc?0Tc2FxCw=#sKcG^z3mBAxn@*-_d zVwCaf;PENKv=SXJ+@>Mi_CNcb2x@Kz?+$civa{2jk_oE>Zw#3M5b2*acKoN10%~zW(Ee9dY~*wod}TT0IQ3) z69K6MVPth1H%?<@2AVV3i^&qJg3Z&JmP1rHve;u+F@@zGL`5l^A5o5({G2TfyHSbk z7EEC0%;8MMu0oV+KSafK9&_v}lz1PofX!ePvcRfha-fh6SiuA#E367O-xI2V_$XEc zhb1dSJRvH+h`JHy=Qyzdtd_xD!zk{HRl(*Y@eF3Ld(TRl5NDUFv^934N~HZEp?6Fc zhsOlv&Oto(NZtmk8Iz3^W`SLEUcsI?*BB`VVl`>=bVXZeTq@(ROI>9P*sgmjHcIG8 z7o5ZyndF$^iF~q+st+;BR;juZqfA)M7q>Ea4xHSi7K2+E+-;N8ONdZ4d764LG0L&D|Y4WaCUu9qg(tiZ|!%n=NtKp4l#z;Ip# G!~+1{K3`S< diff --git a/examples/zips/ocvp.zip b/examples/zips/ocvp.zip index b84396bc0ebaad52b19dcac5dc3e2617c0ab704f..cbd0ba8343e2de251c03b8975148b7db8212b27c 100644 GIT binary patch delta 320 zcmZorZBXS6@MdP=VgLb&1(PT8s;J~wr=%AGacKoN10%~zW(Ee92B0iRod}TT0ILht z6#=OOVPth1r#Ue)1I?Lyn^7C9g3VG)-+93*LtOG0H7Bo^qHy`W{MkYCC oxJxF-3tAJSY>%KNG0Mb+95k_7%E|_`n}G!g^B5Tz{s@40098*y&Hw-a diff --git a/examples/zips/onesubscription.zip b/examples/zips/onesubscription.zip index f013b7e4d0216f38944c861d019c725c48600923..824d2a4d292d5657a1610d83256419d011c74172 100644 GIT binary patch delta 1522 zcmexw^WTOyz?+$civa{A7EGSVtFMw@oswP%#HAJ742&!>JmKhsS^RJ z=Kz~`Hb4Yq9tb0wx7m;}iIEv-;pAyd?nIe1nUUEKyHUx^84#n+u|yJQls9VvcBA&Q z8Zz<$T@?v*KNL((;5D24UV>kplYtpe$iRI(Ig33CyWuz3{UGktzbkP@P2=~$Zqzq^CMIwq z_$_FQRmEfD6hg%uKv`J#2xRoJH;}nm8N?`CE9r(?8NyOgsYu+)5SC7mO2DlQVVaP16mDe*)B2?G_!ME9piD3^ vrnSisWhs-aH*V7qmgdXG<5q_7!Ux$jO{}Sxl?_yc2?L=WCj*1FD2N9D$y!z( delta 1522 zcmexw^WTOyz?+$civa{2jk_oE>Z?>5M5b2*acKoN10%~zW(Ee9dY~+-x&%*r>O_F* zIl$(f4G;mD2g1naZ8l^~Vq^wdIC&bAJ5eT0W@PrmZd5XJ2E?dyERn<+<;|La-KhPn zhKzhbS4Dz?0|F)|@S072FTte57aR*^HY6`a>hEEpq>ra;F6(Y{$P~KqdChy_RgE&%`-<3F{rt$k=H|iTd6B9TQ z{1&vus$#N_&}Ko@_+VhLp3KOuGucL1oH*Odg(I+tTq+9a`1+{zH9af-*_R)#RGT|6DPGK6UY5_!0lAxv8! zk%(Iv!Zc;c3}Te6m2|_c3}LCLR3vU?2umkOCE!+uFil803b!(ZX?@aoe2OqlP$rld v)7oT+vXn{I8@Fi)OY>#paVtZ3;e%|NCf3x;$_6UIgn`hGlYv276vP7nSdBTv diff --git a/examples/zips/opa.zip b/examples/zips/opa.zip index 1eec8a83bd893611d4614d2cddf5c7094200decb..1c174dbf04c90cf865ba602c772ab93b596dbf21 100644 GIT binary patch delta 299 zcmZ3^yPTIdz?+$civa{A7EGSVtE`e=oswP%#HAJ742&!Eu2(NdT38N2ve+ delta 299 zcmZ3^yPTIdz?+$civa{2jk_oEDyvi)M5b2*acKoN10%~zW(Ee9dY~*wod}TT0ILhp z5domPz?+$civa{A7EGSVtEG}(oswP%#HAJ742&!_u2tqdMelYKe8aVtYux{EVN0NrhqWw;~(ljd4e delta 379 zcmdlgvQ>mPz?+$civa{2jk_oEYN=EjM5b2*acKoN10%~zW(Ee9dY~*wod}TT0IQ2O z76GXPVPth17r8Jp1I?NIlF#o4^WQG1(Gj(`0XE7px|2Ud-IY0yav6!$Jw& vAz%kHGRZN+ojkdT!;u(ePdVIhD}x8rWM58i+{zG^?&1s*KzG|@87@fxb6!&2 diff --git a/examples/zips/operator_access_control.zip b/examples/zips/operator_access_control.zip index a59013f178420095360f056da220465ba87765b7..9b222017de8507a56f38a491b78ece4512f1fd89 100644 GIT binary patch delta 1012 zcmbPWHo=THz?+$civa{A7EGSVYp#-CoswP%#HAJ742&!>N4E%sS^RJ z=Kz~`IZ^~<9tb0wx7mSl0V6Ze!pV=Bf{8L|aujnRcBAey-(~?DwU@(>IHUAA)3F=1 ziqi<v0ZxBR<<6{ delta 1012 zcmbPWHo=THz?+$civa{2jk_oEnyXYAM5b2*acKoN10%~zW(Ee9dY~+-x(s)G>O_F* zIl$&!juZiz2g1naZFXQ>z{m`=aPniOV4_T#9K~FS-KhJ_w^_hO?d9+z&M1A(bnHg0 z;xvM|>OPknaYlJ^hhsNt3-?oqQFC}5u&emM8w63|%I`s(WgGdUu^Xiz;KK|Kf_!0D ztSTm-5Z(z^&?4fhgdQ2-$Yo@bV}>V#$*)C1aVvwz?&KuVbll32OcPDStqfsWo>)C@ zWeC&w#bapa`jpYTK!viu1gjjrU^g$M63?&pGcq_Ixzq z`DlW|QZ1Dw39*;*A{kNS<+%b5rzd)K`jQ2SY)&c&vT*d zvFmT&xK^@ICXEJ?O>(W6=}$9qM!r=H{1ZvO$ak?b8y8rl@ywfxjC`t$Br97LOv<6E zi;DGPDyaWeQ7;BUeQ!#DoheOir6UU|HRNq)wtA5u71=8=zFX>I8y#uOej9i4mHVtj zR9%@{sOrv&1|3f;+X1`jbh1nkcBKk}lSndEWR)+MJoTwnzt;8tnTejMv3j#>YUAPw zl2e#JKA-)b?!jwS6?=UpxlT%4UTxu9pHkh%R-IG#QdL%gl}|NN;9;vW3Uhu>T|?ez zmXl`+IiK>T#=%yqwH>tGnBKsr`k~*$R<*4^PgTjqdNCE8?B-(5;l3ok(k7Hm<_8NIGx3>kyAave4jAIZw8OS0NofS9= z#@wzR9Q)Te)5T>p9_KR79&g2iq2FQODIRQD_ih}6Wt4@o$klF<9f9Cfe}Kn$-7j(s zz_upP%VV1i?87mzS%U322CFpB!o>g|i*7}%EgJ8%qam->fr3~Z(W6OMuH-T>F0R-CZ$ z*dCnd$1&*Ee6k+LpxgAx5RQQ@7%9Oqu)T^@^I+QsxgKEG1~=h0=$1HSz%l4{a7bjc n!1iLOj>l#m<~rna!)5u*Uu*e-=pP(mUGzPhDF}Pqu}?n%d^^mw delta 4003 zcma)_R=%RwMFS@atpopjoZSGW0#d%)N#(OdL$Y!O2APYsm{g<sk zol~qAQ$hXjiUu(d>U)y?>`ZA&8y#6NT}$5fWN8))Qjxs^r2;kuvMouA*xd4TliEH`JHT)vLO5S)V1V| zHj_M2$oZ7lv<|jXqwA*ariu-Gs`=vGY*oklGgOsSQY@x|ligCnIo#(ZN7$J*eHxue zr=eCX6OQx;!(q0{vBgAHH!8NXiR4N*UEpAql`rf^m6xp=skYOwkH%emDu=0$t@>n5xNqB0ZHj z3dWq?ejNMPIMd5ztT@VLe1EhJ4~Bm2-fXhHwnJwH$B2G3fT{co4_H78udv7}#En)bL>2M!6nfmq$x+8+1z;GvF9>J1{1) nSzvoMX63P&!d!=ZHe8m+{I!-ZivGb7ilXoL8G^9ez3}NLyY_&a diff --git a/examples/zips/optimizer.zip b/examples/zips/optimizer.zip index a27fdd8699236dc7b74a9f4815bc062053ce8357..98a6d9ae36451ccec5c4c9f58a79f0571b0fcdcd 100644 GIT binary patch delta 320 zcmZ21v{;BYz?+$civa{A7EGSVtErM-oswP%#HAJ742&!t`@Vw7?5M`&WTl$8x=Hv>SD diff --git a/examples/zips/oracle_content_experience.zip b/examples/zips/oracle_content_experience.zip index db6b519c2b131b38c22a1b3a9e713eb7c9081753..885cf33377fcca743a55128091505ccb4245e0f8 100644 GIT binary patch delta 299 zcmZ1_uu6b8z?+$civa{A7EGSVYpIf7oswP%#HAJ742&!@D1)Ecuo-lz`_^`TTRWW%v>vph$L^gLNbo0UPU}TbG dhP!0)DYgJ&l-aQR5u106;NdU)&LiGRu diff --git a/examples/zips/oracle_digital_assistant.zip b/examples/zips/oracle_digital_assistant.zip index 1966f95dea298621f6ec82bc554695fc9433e87e..907157605d136c5259f60b86a8ae4ff51a30d9c4 100644 GIT binary patch delta 414 zcmca7eove?z?+$civa{A7EGSVYoU@~oswP%#HAJ742&!#03^ZplKa)LH1)GzY_A(0sRYcyrS!>SC#K54>!N8z1c_D}DWCLy< zaZUziZ02sRV3S}18$6lA4XeSE-*RjRD_G9yriAV+u=5$2>XKaWsS^RJ z=Kz~`%3B0v9tb0ww^@^MCNne8!pW-zbte0}Hm+US$NE z>BsI)l!+DZ)f;b3DF9D4T8Wf!j2M z#jF;-xRoJHE3pW{tqft>D~mAP$`Ga{S;i8h?4czdw;?PIuyQ5FwCz?txRoJHQ?>TS gtqkFXN!EB0I>IzI8-HRO_F* zIl$(f@)iM^2g1naZPsL*$;=G2aPn$FoymTz9GamaoD9r(tcDvoS&7vFyP0LIR~f-( z`mwtc<+{l`+5NB^CCy>Y0yZj=$B8(j_VajRH%f-L2V&G}K}+I{;t;~&!5E>{5Tm%n zt*~1bA?^(cf@Ko+#978E>4x2?WXW(=a1iX3^B~SBO?iLpM)k;Vgt*&5#U87Q$&*#K zfbH^9H7CxlrK)yVP1^ijbv+Z4M#;B+URwU~biNB+e))Z4c~5m1#S$ zgI%@L$X*FOGk`M}Ba<96JR44yG7iG643QQ3j3aR?Lzu>C;*MJx!n7h2KitX?radwV z#jOlsTBKjf!TS2Qlgo zn-6hD<*)~1H|jF`Ifzk9IE}HZc+Gj39UKH31%rsQOkF4vyHQhw_Q8TceR98?ym4p< zCj&Dv@e}#G{8H=+Mg|7$$^ThofqFH>p*qoHY_pc=R){5!#7yzI7oJ8YTZ`Lab?@X} zadoiIw~Je0SHLQ<5v*XRgq0GyL%>Olkx7mjp2#MPN;>0KhHy`nWCU(y2-Chu#^Y9o zFzvpq^yCRrcDR)yO#C2~fLj^D#3Jb^+{zH9y^~HPMp>bZBW`5~ORvb_aT~(YFxhls zOuH`|iCY=Mv?w_|mLlACM~Znv2M5b2*acKoN10%~zW(Ee9dY~*wod}TT0IQ2N z6#=OOVPth1m$@)91I?NImeGqSgC<8a1!6U6^8u#A5Tn{yyoodFD@zb|qoP^oL5%vt z=0luOIqbpMjk?T!4r0_2PGjsUUUMF12M57M!64!+Qx}TFZqyW^eXt-WRhcsC$h<+lFqo5A>30X8G&0F!n7}v@wk;C zOuH{DJ$ZtZ9d4xv6F*2L;8un(u}C@!w=#rj@1zrnQC2A9h+7%L(kn7}+=j3;Og5bu z)9%Yg;#P(*ElLiLr3km(ks~Tz9p!z9v2?w>hbGp<#L5OtQw#z?n841!uu1~N0|2WR B725y+ diff --git a/examples/zips/osp_gateway.zip b/examples/zips/osp_gateway.zip index 3e16eb2201930941ffb65ff4561770714c764e83..fbebd14c6a548220f63578a842a45bfca6cf061d 100644 GIT binary patch delta 693 zcmca2eMOo#z?+$civa{A7EGSVtF4k>oswP%#HAJ742&!>S8SLsS^RJ z=K!0x!(Ier9tb0wx0#zUk&zi_;pBWK6YMIsGr2=lFtQjEW!K~g7Ax#VEn}&N8KpMa zkByf&_^ z{GH2}7-ebPPPmmJEIq~Th+7%LQe7So+{%zmlb*bZM-8`9go(fKnTSx9!s{-89(I#= H^GX5$I835m delta 693 zcmca2eMOo#z?+$civa{2jk_oEYO7QlM5b2*acKoN10%~zW(Ee9dY~+-x)=+5>O_F* zIl$)auonTD2g1naZRTc7WMl?fI60rm1iOmuOzsdBj4Z}P*)=(W#R|Jo%UJ4RMyXBq zW8)>xxOz4m#+_wLU;?|{fYTDIg_CPJw}2Ixa9Jv$dmS8k=7ZhA$Rx)M ccgf@sRv%)N9b)w&MwuR4pa8n1ll$2u0eZ+t_W%F@ delta 299 zcmZ3%yMmWDz?+$civa{2jk_oEnyOS9M5b2*acKoN10%~zW(Ee9dY~*wod}TT0IN&0 z69K6MVPth1cLXsq1I?Mt%VdL9!RA<|8iRHAV)8k1QY_0M4yS#Q*>R delta 319 zcmcc1dzY6tz?+$civa{2jk_oE+No3;M5b2*acKoN10%~zW(Ee9dY~*wod}TT0ISP) z7XhgQVPth1PlYft1I?MN$mEJu!R9KaG>D4F%syCEOm=431u|k1tB(@8@nB~#GRZN+ o9WptOHIx`-Pg#SBQ5MA(rHR#2RyLsB3@ku+jgf)jBMXQJ0D4PA%>V!Z diff --git a/examples/zips/osub_subscription.zip b/examples/zips/osub_subscription.zip index cb70a879bb82c921f10e845f935666311ade2556..9b4d68aafcd30784453762a5ddbc2000f40c497a 100644 GIT binary patch delta 338 zcmZqXYv$t(@MdP=VgLb&1(PT88XDzSr=%AGacKoN10%~zW(Ee92B0iRod}TT0I7?t zdU+_#hLM56iHU(hWpW~m+{8XU5s*$0M%KA;gC`?1P{-syj22iGZ1!N{U;?WMX0gYr zV)8PUjbH^)toBOi=7U|v$Rx)MciZIMtRBQDQ)P1_Mp-YLuO?PYS=oSgGq3>RB49vx Hvx0a4#)eIQ delta 338 zcmZqXYv$t(@MdP=VgLb0>O!pWsS^RJ z=K!0xDO3bx9tb0ww^^F;Aqz9m!pZ+x4Tv&naxj}WcB3}2=`sldjfy-tYx9aEMh1p! zObiUFlM~rwC-ZU&VAo^Fna>EeeleE`an}Flvd3jqCgbFM0XDF42Y8~ftJ3GShFF-( zr%jxNd-%+-8)e9eWMPGXBUV+D&kFnnyXdT-4ps%5d4=pDF7g-FCC)_)ge|Zeh2o+( z(Kzg?E{OU;EL0RX#HwO)n)n*9n?)rImC#cRI0Z5?$uYyz>f{Uw58TS&NpSKdiDcZ$ z5T=Do+Tm7)Fm1bJBr(d2q&#seLs&Xj$_ckJgr$tqzQiaikj})d3}NYSX-nM75SE6? yxDcakkBmPt%5-I|a4SQ&ty9(-w=#s=p2@lqqs&h(hZtpdO_F* zIl$&^3KapF2g1naZI)(y$ifV?aPogv1ENft9L(m8-Kb4$x=eyVqaqK^+Por(k%8eF z69a?l~R^D$v8P*fDLTi0iI~=s`PoSAr|KH zX%lDR9zHYdMj3JE=4CG->nPJxU}a?J3wIypna1Gh4G5}bTVA{nA_)VJV}uFEPprq%(0VLsy)*|tqkF|XR>a@DD#ucAx7C9IeP*0^fp;rUJ?MlfFEK2 diff --git a/examples/zips/psql.zip b/examples/zips/psql.zip index deb9ce3914b00fee97a607be230a3c81b7eab988..fcf1eb02378b247c3b4633d96ebbda1376871a6f 100644 GIT binary patch delta 452 zcmX>heL|Wyz?+$civa{A7EGSVtD=%$oswP%#HAJ742&!9T-T*8GFu)?VwBC`alow%9^#XK@mSzihHzU5 OueSiY7bdUgl>`98jcn)u delta 452 zcmX>heL|Wyz?+$civa{2jk_oEs;E>NM5b2*acKoN10%~zW(Ee9dY~*wod}TT0ILht z6#=OOVPth1r=>751I?NImr)z5g3UHex-4K7Ic!E)RZQN*b{4FliCv2*w@kjkZj05V z&59fu%wVH>xQ&$1oeK66Ba<96+*6Yua9b0j%$CQJ7-chf9B?axhxp`QJQlc>A>0n(upg~{uAB?0zqWAp$3 diff --git a/examples/zips/queue.zip b/examples/zips/queue.zip index 915b73d50b29693811940a4c02d0e12e995b91e2..cb318a8a199f2ce6cc630219f2ed0868e28c0280 100644 GIT binary patch delta 465 zcmX>vdR~+_z?+$civa{A7EGSVtE!S;oswP%#HAJ742&!vdR~+_z?+$civa{2jk_oEs;X2PM5b2*acKoN10%~zW(Ee9dY~*wod}TT0ILf# z5CN$JVPtg^XB9C6jhW2PsE1X4b0DJ&BUr@@CPVBh?lL7nR5-BcU{}$=BF+ppV-~wH zRuz*UvTp<{n95Q&+m@MdP=VgLb&1(PT8YN+H_r=%AGacKoN10%~zW(Ee92B0jex=1U0>O_F* zIl$&^cN77c2g1naZRTP0V`2tcI60QtnkbVd?_qYrZj=yQ&+m@MdP=VgLb0{dF4790IuW3H z4zPLK9YsLqfiSXpn|T=hn3#bUPL5@^Cd#DAdzhWD8zscz%nUXvg57~gquAZC8zs)M z5aO!cT!vUxY~prh1l#4oV}@11>cWiisS^RJ z=K!0x)=C6q9tb0wxAFH^W@ey$lRvZQVO6l%l+}e1tfGd^7^{lOhuJoQ6_m3ZE1{bY zb}u8795dW!lh3d_;#LNC@ML`s4`P(f?^{O{{KXWdk~qffWcJGcqt_u!DF2 DWg=Yc delta 399 zcmaDT^iYU5z?+$civa{2jk_oEs;X2PM5b2*acKoN10%~zW(Ee9dY~+-x-esW>O_F* zIl$(vwGsiD2g1naZT$U}nHgx`jJXxQ^gBWEqIc$hg_MO8~6RX=;*?>-DU>wTh DxhPe3 diff --git a/examples/zips/resourcemanager.zip b/examples/zips/resourcemanager.zip index 9d9f08653c9976f0beb5e1785eef33ec51f2a979..4ef08c4bf9d321882046ad6cca582acf7dbf4303 100644 GIT binary patch delta 591 zcmZ2#ywsRCz?+$civa{A7EGSVtFMw@oswP%#HAJ742&!7zU2P2alGdx5lH;aW3 sqwJ?xI5EnK#NCKdc1t{f7-c>ZvBW4lE#X3pGDAsk0rUWw+#@Lo0K|TirT_o{ delta 591 zcmZ2#ywsRCz?+$civa{2jk_oE>Z?>5M5b2*acKoN10%~zW(Ee9dY~*wod}TT0IN%I z69K6MVPth1cWq^12AVUuh}9FTg3aeyKeK{W9Obsau0oKf5aW`U=-4YKVMwyR9EHTPXOSllD%uv!>06jn^_ee?t09j3kwg3PC diff --git a/examples/zips/resourcescheduler.zip b/examples/zips/resourcescheduler.zip index 9f719a24c61de140c7983bdf7f8da839f6395b24..fdafa567b7a0bf949ff6b603f571938f49bf5340 100644 GIT binary patch delta 338 zcmZn^Y!u`T@MdP=VgLb&1(PT88XDzSr=%AGacKoN10%~zW(Ee92B0iRod}TT0I7?d zYPay7F(U(m0}}&-%49|+xru#zA|Rb0jI49x1_wrFppMC(87;6X*lf=QdTyg-3%;1xQvm3!3E3%0GoM9r~m)} delta 320 zcmZn=Xb|8H@MdP=VgLb0JMwv33za~~oS=oSgGq3>RDnyzUR@MdP=VgLb&1(PT8>Z{~er=%AGacKoN10%~zW(Ee92B0iRod}TT0IN%I z6alFNVPth1x4JVj1I?NIpV1eqg3Sp`9uO6)nQ^G#VUdEU&}6m1Zbm7qD@4U!HZ$xh z*x7XyzUR@MdP=VgLb0KyxPlXY|FYU~>YK2SmkcW*jPbSfn5-G+8aMn^DT@3Q@6_%?!H= zc6MEe3Udxu>?$U3e21v$;tc3O-#z?+$civa{A7EGSVYpRl8oswP%#HAJ742&!V=Gv}Bu-}~bo0UPU}TbG phP!0)cTOK-l%;Zc5u@xPSD+?VOIg`~b~CU5;U-1~hGtF>4*=hmN~Zt- delta 320 zcmX>tc3O-#z?+$civa{2jk_oEnyOS9M5b2*acKoN10%~zW(Ee9dY~*wod}TT0IN&0 z69K6MVPth1cla_g1I?Mt!DNF~!R81i4K}cfW)5epDkk6J*a}uKiPKpL-F&b+7@6dl p;Vzl{ozsUHWvN_V#3;MS6{v~TQdTyg-3%;1xQUU0p_voJ0|19qM6Un< diff --git a/examples/zips/service_mesh.zip b/examples/zips/service_mesh.zip index 972399616ce9f27687f9462867ff1c3702fbe961..49a825da580e4160e4c706bde5ee179eb5db1600 100644 GIT binary patch delta 1046 zcmccPe#f0Rz?+$civa{A7EGSVtD}-%oswP%#HAJ742&!QjM_{f1(UOx?XauZ%Y2m)tYRvwBX$+9Sal(0NO4$T zRWUh@qXcZkT@DZnv2M5b2*acKoN10%~zW(Ee9dY~*wod}TT0IQ3& z76GXPVPtg^*Vr+GjCpH=ReG~6qc#&r!Q^aaJM1d9aZ}VEVu`l66;>6KE5+A?jnJ0x!m40%r-UOUFwRQhP@yfo52E6Ytd$aae1YSY zkx7mj9NmG>t`**|$VVw9yR5M}8V1!rPRvs5I?(uInF u#F!?c;KN+#mP2_jA17pZEJ-@7L?SQA?EENJM3#PYgK>`u<|f1`?!Nhn$ph;2$ zh}UN3CkGM#MffKnfP|bmn6U{WL-d1jjl@if5Gs`Eh1`e*5)kMF6a=yWT7=mEHeE&R zzLEcTjE|_@8s&@Ap$^%oNWE}6(J->#$l&}I5rl!5fz-!CxPVzVj4>FEAk%W%d0VGV z#utBoB+tE=R!jNPrAr2NPn~%#hR{j`v*v6}l3A2kJj8@9;s*Iwsi^^Tgl)+j$#o(<>ew<9=)6vp2QtnBA(RJ=2v@tId2VhSre*^_ch&sQ@z2I1ixZXBX(AS$Zpi^{Lk_ZN4hB!@-7`f`RWc5F#J431-N2^Lt zAJH%G`=Ly(_QbSr;`Be`*CZRx#LxK9Y7MCOAF^@M<{}dF1AN^hWpx^v$cX$5nGe@1 z)<`$Zs~8M^nOF>zn7Lgwxijy|36O%#TcZA zW!a?DtGP{Px+{qm8QnH%uZO2BVk!BA^4NiGqMh(NN!`wDH@zgOvfmRQvCyWBTnjD_ zw(ENL7FSg{K3qVCJPXAIlVzXn&#P>CQ>otS=TDnXw8A}_OXJYgv&FnQIF@I|$yr_B zQzB@PiI&m7_GF`G3|IQEghoe`j)pQ}Csd+I6anLf&P^ zi<#0&*YZV^Yf&GvIAtuWWP(Fe2apn+d{{IK?@f-Pbp;Uy5qMcv`?r9}m56Cx7qpQY3bu16KSG1xh#*Qy+zd?H%IhD3w_L%Qp$ze~6q5R<8r-Y5a z(iGFww&8lacqB1J#-BOPX-KEKJ=-0v9W&J@wZcmlH6P__n%UJa_x~gg* z&hwx5>q&WZGS1JBN*>QFR=$xgdkN)t*MchBUv+F4#P0EU2m@c&uB$`Ao1A11O+0g; z5h3rP#7>IRx0F(>xh5OUq2Fl?KT*Oqh}vw8hKVyLdrQ{24TWwMa5!5dH%s3C6aK0l zT*t9&<=7x44o%?Zqh4-56so_N8IiS@fzSRi|!~ zkJ`dUOxkl-wIwOD!64}{!7V}l=4}g;$6zKk9ETK1SMJ?8jRbYx#aFG>Z_N9K2cA59 zSRY;_Jga)j*_fwqAZr3SBLWmubMmjF?1wyTU(UViOJk)-exM<-3;r$l0X>vPge4el zm%>vHU=WBMhEFp11j7oPr_ww)dp)M|+{=f@sWk{ApMq0w>*2GP9zJ`i?q@G*V3?W- z`#p6XkiG^P&U=l^Z2GPUix>^o^p`*&`Fx>3~kvNksO2Za=1T^g0%cY28A5q?$cGsItqja9O*Jicmv^+UE0kE0MW zP|6|G0ojk`9{9*Ife}nRR&c>6j62T;c}mMIvk&C#qsD7y9vL*A;1kRAok(V`hAEz&l^g-D18lo|M z#YG(D?-=Zf6pdt%FZ@Az+$SiRJT_!T?=45?T5FLaX@lajOe5p?& z8WAbqKXd!C9mlZRZI<)-S>}*rmZTQ78mN-cE#5(9N}d9i8@hV-95_R5^=b;zZfBRC zNfg#htfd2RD9ugzGG5m9^akiu&e4gnV2?%NhP!5Klu&*a-ppCIxn|$#;b>iE#^4Dq zP+bZxK)7wBKLX-ZFub1p*|P%DXrZS>BjtYdaCCE0*DV_!`J-#*aqafO2FFzF&$fPU zJxQ(%V}h6)!~^a3UeuiGDWpHoF?B;=J~SW810=d%bx{n!4Hqdls-jNME=g(enXun&emU-=!zHugb|H6=g zsQ^Ef#-_8VHdLP1$(nk0pMKQ^o)9_%@TbhJAqkeW{+0LV7~OBZb6j=9%Cs4sM~|Ya zZ5HMfScc(|C#Iqv-SJWN=W8Ls-hX&j20Qn1Jfn7A_nJVsO1vCS<^q)=qI*DUs7CZL z%ZkVbLn2J0oo@NvhG)DR^jXd`H$5Kx!$c;|7eVF-tBG2nE;^&>ouygj(8lg%4^GA; z8%`ulkgNKvO8zPb@u(tjZgBp!$>_6iu_W0!r>in$(LK`LO*vSdSG@t2tSyHEzhF&2 z8Yby|Tf2zPNotY+5DylbO}wXjOpKjb5GM9po+;u6g2F|Jt^tWX2C6cdJ%!J1!IgSQh&TYa>90Ep-LmBhq0A$@(Rk&)%mtb=1qboge6$dy~mEVvgZon4h`0Y zF=O0wv*JTo*+S8yt*L{ zR_IJD_q@N-PSo?Yb7?Ry%~IDa{cFdYag&3V!zvyP>)DHbo}`xyDYMU0>~Rbqwx`n(F=Umgr~1ffLc4OjVhq0IwsrYpC|V5(^Oti1rm6banmd5XRVQwb^A?@`4l+Y@%&v*aGAG9?9p z?2dpyUi-&A8o)?J=TFDIcIz3haV@&t7j}}lcDRK|Z=S}eI~dTlM^{rJnsT<5LnCZ+ zU9oX%(Ygj1yUku0>g2id+cw2k_s5#Pq;5QY#nhK8r=L2dzgo3I;VyfU{cT(Dm#@kV z`q$e8xpIOTc(3bT>2zt6)SD$vrY*?0$#AJnBaY9fRpTNW zTrDc+eyK2x9yY_y%0F<%G!TK#<=~5;bQ5^!Y@joasSOpV2Gi2UO=2-i zNtjY)SBE3e+^fht1GOad>wk$F_qO3MuW$hPFC20ZO`y>COS+qxi0Z4 zhl5lA;tt4HTfQiEo1|CnY+_GOjz-rhc-YLu^g_%1Q@i2(D_8DKkDd-Ok#g3^Hgsa! zRA)40?*5`6{WOlFg zcUc(K#Py_jS0$d*jm$m&JenVG;7~rGZjfVH5@G_2Zyo5HVr;mN&cmNdx)83@pK`y2 zh9Jvas!qF1>FdE5w|T&WiRx9~P_ttJQkzrSp1og_{fjF&y8B@!sAC^u3_^E?`F<_=?K7$F}m&uH}*gD2D2sh z4#1DBG1|T7-=U#Uns)g#fk>@-;6>J7Hrm35Vp3FUfPX-SSt3N>2gg6E88BPfXK@`WDs@xRv zkgy}q%V5=*9>ostaBbOaFU~h5$<>Nc1FXu6okEitG}z7h%-9-xA5Sqqr3kG6B#zf3Z=WRY|E63o~x>P+870YX1dUKTD<;Iz0n8q zBPUM=TqJsc&TzWlS^a3ly>!ZVwkET**KQ{*^ zOyGo_)BT@dJDnF?l?y#aP8#MZv$HWJ)GM(sVy!DmRY`Vp_`3PS8j0Q}ILo%TWl$(Z z*26GC+#kyM-ZZ(Zux^`<2sk!nZ9tu}J^QDZHejn3v(RBSXhWP+@AGGa`Oa~LqZxxA z&9^R`3s-&?9k*Wjy0T44jQ)&i7Ro32i=?|0#*b|poAf+~sU#EE5*ARgrV?{a>vD}1 zxcSRME!F3Hp0i?E?SVlTQPC~>K4B&=zg$GP+zLG zRn&NbO60w}SFa=FslK{!`Qgva6aOqkMUi-_)14m(aW)k)$(Esx96a1D-pqa5BIjB~ zagBM8`e$rX1KG)kkIB4@O2KDZj$4b&W2ufrn|)^E#;~)pgoXyq%RSM~7-ye;uC66m z)U-omYbiV@x_pUyQxi?85E!xB(t8EWu|ax^s8O@FyXs>a_mRl3JEw2BJrC$+X{l9POqvpRfY6QWkuYWdK* zkywGq(dDki+mw9kETPEOO!6C0Df0x-Ociwy6*KlF-||eSF7~6!H{ZL#;BI;{5=B-x zmKUu==Jj|*Oup-VN5ndOi(|goVZnpOD08LbtT{B?Vp)Hje5O=_o$iy@_jB)lPaceK z;;$f74$N}^5?TGDC;t_x!gWAP!bG14%trk4_5rZfGX3+gUv~g6wVeMv>=&Drw)LNf z{fAB4=g-4_u{rA4i~KQ!pKQM_6@UdDPeOP@bm3qeB|xOhg6|Ho@mpGu?A?U?_qqgM zRqRdGPaWVZ9%ewb4^!j)8|YUI>3VRmDm5M?io}-zf5ZF~LjBff0x|w5aq!1tQ2v#I zA58d`69a+r3Horb8v|aR6?mx#1E^(40daaL!67plz`-B?A1+Uz_O2-$tjoNwO)EfX z_<)Kb9DMI54u~{_tNw8n{G90hO7O>Afu#2*4FsYF&8uTse|XrdrAP^mUCjs%p8GG9 zOXF{k?_ei_zd32+z&l|9D2?g<9MP|3;N_q8&jh{}Y$gMN@gYYXo&!GK3*%!EwYS2H-cO!PYl-v^NT>!$np%zzkkI9N(-A0z=p8PWnv_%8TO z!$X8fnpnWWCnSHM|p><{GreIy42qcJqqv=5)N}ccD{s%cegBJh* delta 7999 zcmb7J2RPO57r$J)E0<(ld+)txvNxF*Wv^sslyMV^kny!gh=vuV60)<`HKOc@$S7oF z{;%|_U;l@m`{ViE=ka(ypYu8AJ>U17_uQl^jLnxAgt{7FECSHskGxQ193emRHGa5* zKkD)JI|ahPng@eGSP0aA|6FIK@V9lOsP%Y1_*#ug5BUzCfAf_IVcf?AqYMI3G~57G z@C>ilRX2A&Lj!ye_%HT<@d8R%Hpdgc#uCN&LA;KAK@c4(xHTVd~9xAE;8mlHoH>wLXfwH3Oo zVC``y+#z`n`c#$vnYkdMTUAjBUqnJBKjR$3Sz&Yis;fr4xl;CeI=Zl?ds+&l#q1aM zc&0P5Z@>H4$tjMkG%Co*ELLj`$M@-G`b^xT4wE%cf+8KFT z`^HNgm1wp!3XBLN+!hA!lrJ<;o(V!#ii&~AAbU;4H`fKtCxpzW5X84127D#2Np(2~ z-4%cCxSo80%R-UXV;*DSJsi62%o^f-+9=rP7BYxCcGsLq7e34e9^&O@Kd?2I5-eR* za?G-efoR^YZ%;klR+rjDSREwT9Tk9MNpOXO%m(+KlI%NANU}0R8Ke?}nXwC$cTrL0 zDpT(AREE+_rgCi)HzJSZUC=XnP%7PRN-SAQ4{;geky~k0PUND^me!h$vD|w|7q@Vj z`}KR)o%9rXBzgA*J#ZW@y^d=UJ%hm(p~qfBmt%&LO3T7{pEper$!JER=ANIPp|4RR zKU^#h$#>9Wm~nlv@wL)lu6LQNcDnvmu~xe8P}T!YT1dBILIYwP{GsL2x5*Aqoq0_P zQ7<8JciJ!kt$ERi*6zJtlg5y4ZOf)B>FUcYAI?9keeHC?x+6RKUDE!*m7KY{Wy||7 zhlihzjdtjFX-^7%x9B`SZ)bX1NH+W;aBH(e?S{-__f+ITL%s3FsNAWvo|Q&L0B6S@=9BpP+C(>pCO7uYf??{>Md}+5wPM;?*VlvHPfAYfq~)0HDn=&X2$cOQ^_s9FUH#oBmy&@yLMh*=<`HWs8lLEn$QCWgk-%{ z;dZZz&>t^l3F8nd&YstTK;%@1m4dDBwClpzp+DYro@T?9J_4`Sw$F znk=lDK>tDX)3J&`W;JKaL0)iGKWJQoh|9S9asRtvv6`~SBBAe7Wrx)}Sjq^?KLGPLF{KjhNg9?MPr?%~WJw#Wl-F zMUUN@i)PsN4vZefS07Nqi`Mgc$nP3XXEBHx7K#SmOc@{(;zhU@==(QkejdJe@g`q1 z!Mx^~rniFx&XOih*pkkvWqEDa$MC+*5q73Uvp7Flae3Q)El)FJubWoTOuRy~smM9M zv+;480k+gyPVIE##jYU-^1U(t73N}wEh33HS*KB-?@66h0?XfcJ;WxH{JoiNdT`Ba z^QFJ+#Jz9jmyJqC_zT9C=hPnTLqyJwWQK)|H8Z7(k_5^=P8+kz6{9nsiLn!0w0syS z;1FFf|KJsKGq+ssBKLZ(nbp>8gW;)k8ktxDk+F!iY~hk^nyw~wkboGr>BNqh0?G!cfdRUUXM7iVO z&F>GgZH>dW-hMq#^u7tRoPIUgvrL3BaX5PIgZ@2m=@BHT`>1ANXSic7qiW@3}8-Ia7XPyN{gb z;}p}Hf!FMrw$Bm={cw-Kpy{#+$W3l{K4VS)n7P)fvMMLMP`6&q-|jfg{K%xbMCX@{{1 z5HBJbO+H$Ry(}E?p=wzbt;Qo&Y76DKz`)@)7Ixr&JLx04w*I0OwnCEqc))8h1@Ee_ zdNclA{n24!--sx_ZPSfU1%BP<8Ff654Q8Bv(pOiE5zlPyZjDHtuhYd7Z>B_c@>kn< zv@G~oHFE&Bnsi%JoJwIhUh5&J+V@wJ_?7I8A~eOd~iWp0pk>0pk#O2^qgExPOP z_=UrG+je&M1yVsqGY6H4rTlI9l_pJ9bbuqZ`vIrhP)YZXRP%gw#Ymr{nnjs=9vl~{{;{lZM2 znWYVkBP3Ia`%>i3^zk#z1yG-z8;xr96#VL!*xI*9BVA&I_|nQE-PTduVCs}Y^Zqv5 zhD*6gvuxS)nKsY*460&djSXG*F6)xF=9qaGjpQaEB{Mh?-5UYaN!Mc*-f%q>QA_A< zHpD0~ET@QV&f>kFl5QRwXu`Jln1EEDrIb7GYS{)?ky8~;nB{;ZL0a#5 z=UHmrE6=DWE+M-2luD_3mJe3R3s*d4GA?fTQyBKP>^-~tHUB^$5Nz8=!ILo0#j%~0^Wpc-FBM1?l!F=6l+H z!i0U^ZbJAko&2&9po1#Um;ty&QT}LJT^`t4d;6J)(+a z7DJC}migTARFW)jj#_*SHbwNPoY+i{ry62&I-*kGkT`xtEQjhp#<&1?tpBt{3S1{_ zQ7IShQ7|fbtkCm7ju$vy-z;yy5tW^Q8G2M71#TZtg%FfKay5!Z4sa93=0N{C#xHzA z20aqaJCdg@rh%TkYB9&-) z$w^nozz+p1@opP)IbR{#$gBBG38c90Zw5|>K>HL8s`^YnTwhzZ8RuhTQ^n5}w!h1T zR9O%kC=#m)y0tkw?{M|ZnU36WtPM2^CRTCA1rfv=1#!ZVZp)f3Ym1(yM6}qz6GLrn zq)3@#U4C?Y-9rHqUZu;g?Cz-`U97Kna!Mc{!V8T#VI)GQTF<6zQDB#8x;P zy3rr=(JQ#_#jq^pE1$%3O@P-@Yuz*Bguo<(j37VF;3G>(X0XF0&TqRPGbAcj4e}G_ zJFNwLzS}cmnce-M-}=Z7sS+OQpj6V%Tzwz*^;0P!q0f5T+Nyl+#2GSu%Hg2f=LkG? zPLJSh*`|JYUa$cX5$fkE{`O3;%aI!Jrr4=gnNp!Gw)dDdB8*c`EnOsUw2@zBk8x>c zLd4`L=WpBJc|t)Nkme~Lc$Ljkuw1bfB%~q}W4cPNXv5;636AvS@O`k(N*cy{Eq&td9o z&@s(THAH`INp4eQo3qnHDAeXES6||JwkDG!012eNdAU9tjv%e{&4lb%zn@B%G=T%3DjTOXnJDm}}c%RY|(3Mby0dS*|A#TV&`^}PNwPBj{uCmtU^59MG zy7mg8rSkF(ySbt?7uStXn=kv;+opQUOveY8d$4Jv778Db!FhO0Ul^zm-GX@y8_L(n zC%QVmZ1!GYc#SL7T_jRs7IKYdb3J-S%p57z;C>5N0V(!r!%iWk_?k5lZMiL~wO_#4 zsz`|%MyO^X9}FZUif^?ufr&RDwL^eUfKRYyLslbx{68Bj+Vs}>caWJ z;8EeC*ZtxT@i<7tGL+= zI+eg3LQ1H7>Y41~cm4MnBNO#o5d&RGNo}LrQksUPWf`GTveL-&fgX~>d%PA-zL@(8 zT6sEY4m;yX+{5_GL_J^WSGf;%6QioB{kQG*tR`Ycm1(D!ipto)-szz`wRG8!NUCZ* zODAgB)_e;1S_r-PorsdB*QV@JAyO$$7F|kJRyc5T!RFVp{kz<2Ho6X5h}8jOjr2g7 zcnOg`sZU1p88O>wF^S5M>Ye#Y{FSFZ)_k@If76>HB9;*Oh=YE=Y8W@WC?hP3CcC0vA-g|8HTjdsU_** z3`%Hx!L&5=Ea%;|#>G!jbP{DRrdi1#Z6C?sF!jNw#MlSr4qMn?Q&hOTM{~&o)Hw4D z1_;Csq6XRd0m=-NfUFA1vBeIsReAnnwhB{~WjyBosjGp3NelipOa}Z_^-f;)O9im3 zYIpLo-)v8fVL+^!^vO&A#i-_S^0MEI!RnUWC%W;A?e~BfAk=V0hc{CL25y9a0Ae;? zU|s`yGUS&H0Hz58ixB<;IR$uXvYZV2?Lmbm43ixS&};B0p{@?tN5k`f588hW?hkk6 zmnrxkV+9ZeY6S>{+J8`9@ZBFws0jlZ%ipMen=jRZfvreE00y~&61wKi33YGPVS+$) zr$8X*Kg^H)U~)y%Hmv~+e4gUaHZME6z5^F^VBmry5U@){fu<=`=7IfSho*P{9a?M- zFSPAh=)%A=zmY(RF2lJKGwxSh;Xn4|=Lg5n7=b`g(31RXT2Pz^`+rbir3VAk(H(*S zX9iL<9iBvid>K(77;xhPE6RX!mzp@;aNmN)M5a%B|+xHLGS#*;6aA%j8 z58nlWzv}&E8Q{`~fel#>5qyB3J`5ePcPkB|q)=kdp;D3Q53zh~KOA4yKaH-~7WTv3 zphkUxX3$U3p$(?vW{;~!C;|~2tw6SD= s@RXaYqNADNA`CpMh>99Ds_7x(J}GM0sCN_u;z0dgJqrRYDINaxKjMik{Qv*} diff --git a/examples/zips/storage.zip b/examples/zips/storage.zip index 3a8e7121f5d0157d77e2034933fe1aa56025fe6f..6e1fd0ba5444d5311a73f4832a2339765dc77a05 100644 GIT binary patch delta 3222 zcmezWhVlO!M&1B#W)?065Rh0fc_Od6N`7@pdLa;(R&X;gvbJIIn?(SBv>_^X^Wtz7 zCtnf7XLW)O*v+^k_yuCdNnsQ0Dg;H;SitVEk}$`vqE(`m9jt;^!3?{KaE190TYf59 zVprj&bP1wDS_OwYl2v?|1VJIJJzsuu2NMH>FgpW->f}Nrk;w}LStj356UA;aqxw`x z+|AT9#jfI!CJRKxOKp4XDr|JhA+Fn|i`|Et^x7asbQ&07H{z^;6C>F9z_bAe;y~w1 zX@-VyGB6X9&?hGwITDr9C!a71$LD)OC~42zkc9u! z*AthDbmq-_1B)SP!#LQ4I2*fzvAccqt6+JEjXV)<*lkRUNPt*&GSY@P%QT|`u^ZJF zl@B&*Qj9Zp1>rGv5W8l?S`cT~mslLm_KUNFB$fU|N9>k8Njw6vY;`jBTsrwn@_KN@ zE=w_0LNCFA87jb=kx7mjkwE^YSmIWOi2aCE4`P%ZN)01MnN=E5rY%WxA;vVWbT?v@ z6{R~8qwH!rQEs!(@FT{w^%+jYC=$|?a@*Q0Phw1y$aW@1 zS#7p2G0NU#6XnyO96Q{mArkqf9BX2f@#p&ER))w64Y{efl_4x;&m$__it-|fG3{+0 zQE?iUA4-gAXY&JyQD$F2l-qU{5S3+A3h`Kq2;OOh;l#L&zlf;RTU><43kXZ!6@?IE zX-csdZeTTqb#r_5VtZ!LON1HRQaY;ipL8Gw=F6qDv=A9Ics9AK3Lg6%`z<@ Nyd=oLFg*pt0{{!^8Xy1w delta 3222 zcmezWhVlO!M&1B#W)?065O6f^p2(}NQfUyGUJb;h72FJrEH9ZE7+C6ovZ(4JwDGAE z0jlQ!o44Fb1Y{lvBb&GJ>jq|Kpna29uy|lqu$hI`p9!oYj2*iXo0qWjGVuY;h%~J| z+I1Xgqd(*1gSyg_Z*dA>HFEMl&MROOuX0&nRj^r+TZs{@!i~omyNX^OZHS89yf|FN z$yWsNS)HH*b~7#seu0>AQrHB$3PBMy7O*?4B+Rj^Xq9MX2dm&!FvG4QTwy-MmY<52 z*j2bGU4p2PR>9$pWECGKK~M;5&zGOv!NkBI%+A1|I=RqDWby(*mdQ8NM6sL9s6G`E zcQZ9jv8#Bb$pTUFQrjN83LBkri0iiLV)x-Dy*7vuodyQjjW}!I#0YjiFm1qrIMDf0 znxP?_49vtN^vTIajzp#O$tR4$u{*=qI0=#>W|&zMXViByZ|p{end?D}YPYf^&Zs9= z?%0j8w>IMer=SXVCwxZ1i-yVf+_AfAvaN?Y*raq1D|{xw3x&x?J)E#RO4{=_B;o(` z^~9wjoq6-#z+y<+Fb*~$&c^Ow>~7!uDp($3BTs}Ib{o?o5+IhHjI<%nGR>$!>_+uP z<%5ly6yuCtL3oTE#I6~!7R1^0B^HOX{o?E(Nu@v05xZqi5|2PETb+zOmrnkYydE5} z%Ti30&`WS&h6?azWRhb>B#^%;mbjH6Vm~6)gBWFpQp1Q*W|c;iX-m>vh%t>T-HjM! zMd^;jD7%_Yl-ukx{D?7aeTEY;%7imriBVRSNmPJ5$aE*hG|w!e+_pB$lNi$^vYm-h zR-5fhjIuY`MENu*#}2n?h(x|A$C?;r{JH+Pl_By%LvAW=We7{z^N0$!qP$3AOnaM0 zRGfz8hZ1Aj+57-vl-U;$<+fb~L}eM3LOhltf_GYBI5BSHFCr@S78l|10>aXFMIppk zno{hATN%Q%3&ruoC<`nJ#H|dGkdBlPRlezz;_(8)ZHr2YO60<2&YD=O4^}o%vrG#J MF9|X*Oiuyv01(C7WdHyG diff --git a/examples/zips/streaming.zip b/examples/zips/streaming.zip index 0ed47c26d8e42ad51eb26054def2a0728fe03fd9..f866f5cdfb2077e2d4bcf5d1bf81921c56a69a41 100644 GIT binary patch delta 299 zcmX>ia72JNz?+$civa{A7EGSVtErM-oswP%#HAJ742&!ia72JNz?+$civa{2jk_oEYN}KkM5b2*acKoN10%~zW(Ee9dY~*wod}TT0IQ2K z5&@|LVPth17dSIA1I?NIjL`tAg3Ve?6PUp&_OhB|RWX@^Z39@rZZ>lzbo0UPU}TbG dhP!042)hF@%F5X7h*5Tp-BkeH(#hH!k^r>cLZbix diff --git a/examples/zips/usage_proxy.zip b/examples/zips/usage_proxy.zip index 32e3adc52ac9134212f18127993c49ab72e661ab..99b38252f48013fb2859ef7fbeab5410d8129f6a 100644 GIT binary patch delta 605 zcmZ1`xlEEbz?+$civa{A7EGSVtF4k>oswP%#HAJ742&!>SCPnsS^RJ z=Kz~`*h>Ut9tb0ww^@-fn~@o4;pBcM6YMIkGr2=lD6%*bW!L0377y%3Jz^<=7!}E8 zgk8mawpkDrHXN2%RZQ;W*bH{BJ*TA-x^KXt!^kAZ3=hZ2vp55BD}x8mWL~ZaVwAOW nIpJ1@u=F*TKW=3ROJlghh*5Th+kqHmW<2f!=m9dhmq!u+wF!?u delta 605 zcmZ1`xlEEbz?+$civa{2jk_oEYO7QlM5b2*acKoN10%~zW(Ee9dY~+-x)^7C>O_F* zIl$%}_7VY^2g1naZB}H=W@H9hIJuw61iOmsOzsdBiY$&q*)_S1#RI!hk620|Mn$q2 zVOKGqZ5Bj@4TmLG6_YzTHiO-3&uOWI?i+CEFfz$8!^3g%EY3jO%HY8>nU^bq7-j8T nPPmmJEPc)8k6RhS(irYAVw7Fsb|6NX8IQXFdVoys<&gvc9#4Z$ diff --git a/examples/zips/vault_secret.zip b/examples/zips/vault_secret.zip index 5a10c8005498cd4d92e4217e3fd1e93d06e55483..cd5870a449c82be913aa326793a07ec3a3b687c7 100644 GIT binary patch delta 320 zcmX@lf1aN=z?+$civa{A7EGSVtD}-%oswP%#HAJ742&!n5-QD>f@7bo0UPU}TbG ohP!0)G&W~ql>KINBt}^ryN4!LOIg`~b~CU5VILy{gEp8402bv+0{{R3 delta 320 zcmX@lf1aN=z?+$civa{2jk_oE>Znv2M5b2*acKoN10%~zW(Ee9dY~*wod}TT0IQ2N z6#=OOVPth1m$@@C1I?NIfzcSNg3abkf0@84%vr6ls+io$x(Tenip@$1-F&b+7@6dl o;Vzjxjm?=DWxv@RiBT5E?xBg*QdTyg-3%;1*vH7gpbh2$0KSw&3jhEB diff --git a/examples/zips/vbs_inst.zip b/examples/zips/vbs_inst.zip index ff121ce8856e7bbdefe00dcaae7c5576b7ce0ad8..6f9b414f20157855f3dc2df15339fd8da652f700 100644 GIT binary patch delta 320 zcmeyv`-hh|z?+$civa{A7EGSVtD%x#oswP%#HAJ742&!%VvlIRx>4Z^TF<5WRhcs oyJYftR(oQU8L-(BqpY9JMH8!~tZYEL8CZa@j*)>OgB8RB02~WR-v9sr delta 320 zcmeyv`-hh|z?+$civa{2jk_oEYN%8iM5b2*acKoN10%~zW(Ee9dY~*wod}TT0IQ2M z6alFNVPth1=eaO41I?NIlu;k6g3TICK1^U0Z#;cr=%AGacKoN10%~zW(Ee92B0iRod}TT0IQ2P z7XhgQVPth1S9vlr1I?NIjnSScgC<8ZxnVVF^Jb=55TgQEOtGt&$r8^5w(K{X4OSJC zz1cT|6)?KAfIcB)0CdYHQ;#LL^qshlOd~qv7m}bfuLX5K2oX*536X5dF X#OeiBHlR-!*nqH_iGkr0JBSAW7w&A( delta 473 zcmZn`Z5HJX@MdP=VgLb0z diff --git a/examples/zips/vn_monitoring.zip b/examples/zips/vn_monitoring.zip index bc4ca0a793f46d600857e777d1657afe76da61d9..40042e14d82679d981bc1c281debd862756539d6 100644 GIT binary patch delta 532 zcmew^^Ie8Fz?+$civa{A7EGSVtE-Y>f)^NsS^RJ z=K!0x*GU9q9tb0ww^^8R7c(=^!pRp{%&@DFV)bAIt4L*YAj+=EC)wPw8>PY?1hK4= z%NnbS$tSorgYBy0wpK!SE7Z(*4M5b2*acKoN10%~zW(Ee9dY~+-x;Sfm>O_F* zIl$)abrJ!Y2g1naZ5C$S#mo$}aPkEfGwdp)SUniQDpJ`Th_Y+)Nj7)vMyap|K`g7} zvc{@n@(HfZV7uzLt(DN-3idlAlN>WVlqTQi_Qb6W?)k}XJORWg+ri_4TN%PqIbJ{9 X$`F?J@rDwkjFrz*0NtmP2psaH0 diff --git a/examples/zips/vulnerability_scanning_service.zip b/examples/zips/vulnerability_scanning_service.zip index f4c376e831922c17ff14dbbafad33fd2ace9b362..0c810f74b1318e9eb249a7b66ec3e4bfc89a05e0 100644 GIT binary patch delta 320 zcmZ21v{;BYz?+$civa{A7EGSVYp0T5oswP%#HAJ742&!2h2LN(fNudA$ delta 320 zcmZ21v{;BYz?+$civa{2jk_oE+No3;M5b2*acKoN10%~zW(Ee9dY~*wod}TT0ISP) z7XhgQVPth1PlYft1I?MN$mEJu!R9Kawaj1@T5LX8RZQ+;+X+_S#_pqpZa&x@j7)OO paFmbWDghz?+$civa{A7EGSVYod~0oswP%#HAJ742&!|~9NlO3# delta 299 zcmX>mbWDghz?+$civa{2jk_oEny6G7M5b2*acKoN10%~zW(Ee9dY~*wod}TT0IN&2 z6#=OOVPth1xA`$L1I?Mt&SZ^M!R9a~O%||K#3(z<5g>qW>116_NdV4ILsI|% diff --git a/examples/zips/web_app_firewall.zip b/examples/zips/web_app_firewall.zip index d11686b3e7cb56f0216ecbb11e360e0501e5ac61..fe7cc0a15aa537ffa655d383c6b15923d594be65 100644 GIT binary patch delta 320 zcmcaBc2|ryz?+$civa{A7EGSVYoL-}oswP%#HAJ742&!#34ooswP%#HAJ742&!${Zw;iBWb`B2^QsrL1f~yBS!3ke!Kv!Au;)0|4r`O1%I8 delta 320 zcmca?blHeEz?+$civa{2jk_oEda6_!M5b2*acKoN10%~zW(Ee9dY~*wod}TT0IRDC z5&@|LVPth1AH*^;1I?N2z!ZvA!RD1rxx!!-l49XlRZMOX+Xq(QDju$cZa&x@j7)OO oaFR diff --git a/examples/zips/zpr.zip b/examples/zips/zpr.zip index 97cbbd0315581bf1ba64b121ce0eb3649ba47b93..aed6d8c90a5b15cb48771ed33f39daa8740526ff 100644 GIT binary patch delta 299 zcmZ3+yNs7Nz?+$civa{A7EGSVtE`e=oswP%#HAJ742&!EvEENdS!-N1Ffu delta 299 zcmZ3+yNs7Nz?+$civa{2jk_oEDyvi)M5b2*acKoN10%~zW(Ee9dY~*wod}TT0ILhp z5doDZa&x@j7)OO daFL8AZw