# This is an automatically generated code sample.
# To make this code sample work in your Oracle Cloud tenancy,
# please replace the values for any parameters whose current values do not fit
# your use case (such as resource IDs, strings containing ‘EXAMPLE’ or ‘unique_id’, and
# boolean, number, and enum parameters with values not fitting your use case).

require 'oci'

# Create a default config using DEFAULT profile in default location
# Refer to https://docs.cloud.oracle.com/en-us/iaas/Content/API/Concepts/sdkconfig.htm#SDK_and_CLI_Configuration_File for more info
config = OCI::ConfigFileLoader.load_config

# Initialize service client with default config file
container_engine_client =
  OCI::ContainerEngine::ContainerEngineClient.new(config: config)

# Send the request to service, some parameters are not required, see API doc for more info
create_cluster_response =
  container_engine_client.create_cluster(
    OCI::ContainerEngine::Models::CreateClusterDetails.new(
      name: 'EXAMPLE-name-Value',
      compartment_id: 'ocid1.test.oc1..<unique_ID>EXAMPLE-compartmentId-Value',
      vcn_id: 'ocid1.test.oc1..<unique_ID>EXAMPLE-vcnId-Value',
      kubernetes_version: 'EXAMPLE-kubernetesVersion-Value',
      endpoint_config:
        OCI::ContainerEngine::Models::CreateClusterEndpointConfigDetails.new(
          subnet_id: 'ocid1.test.oc1..<unique_ID>EXAMPLE-subnetId-Value',
          nsg_ids: %w[EXAMPLE--Value],
          is_public_ip_enabled: true
        ),
      kms_key_id: 'ocid1.test.oc1..<unique_ID>EXAMPLE-kmsKeyId-Value',
      freeform_tags: {
        'EXAMPLE_KEY_sAyCw' => 'EXAMPLE_VALUE_Qi8ybJaJ20BBBFXNp2Sz'
      },
      defined_tags: {
        'EXAMPLE_KEY_zInXU' => { 'EXAMPLE_KEY_mYCC1' => 'EXAMPLE--Value' }
      },
      options:
        OCI::ContainerEngine::Models::ClusterCreateOptions.new(
          service_lb_subnet_ids: %w[EXAMPLE--Value],
          ip_families: %w[IPv4],
          kubernetes_network_config:
            OCI::ContainerEngine::Models::KubernetesNetworkConfig.new(
              pods_cidr: 'EXAMPLE-podsCidr-Value',
              services_cidr: 'EXAMPLE-servicesCidr-Value'
            ),
          add_ons:
            OCI::ContainerEngine::Models::AddOnOptions.new(
              is_kubernetes_dashboard_enabled: false, is_tiller_enabled: false
            ),
          admission_controller_options:
            OCI::ContainerEngine::Models::AdmissionControllerOptions.new(
              is_pod_security_policy_enabled: true
            ),
          persistent_volume_config:
            OCI::ContainerEngine::Models::PersistentVolumeConfigDetails.new(
              freeform_tags: {
                'EXAMPLE_KEY_WaOnj' => 'EXAMPLE_VALUE_g71lsVdBQOse4MgygtC8'
              },
              defined_tags: {
                'EXAMPLE_KEY_K9KSk' => {
                  'EXAMPLE_KEY_tFBTR' => 'EXAMPLE--Value'
                }
              }
            ),
          service_lb_config:
            OCI::ContainerEngine::Models::ServiceLbConfigDetails.new(
              freeform_tags: {
                'EXAMPLE_KEY_0Q3W0' => 'EXAMPLE_VALUE_Md3k7Oc6btE0yL0nMkiC'
              },
              defined_tags: {
                'EXAMPLE_KEY_TN0UO' => {
                  'EXAMPLE_KEY_8MpYZ' => 'EXAMPLE--Value'
                }
              }
            ),
          open_id_connect_token_authentication_config:
            OCI::ContainerEngine::Models::OpenIdConnectTokenAuthenticationConfig
              .new(
              is_open_id_connect_auth_enabled: true,
              issuer_url: 'EXAMPLE-issuerUrl-Value',
              client_id: 'ocid1.test.oc1..<unique_ID>EXAMPLE-clientId-Value',
              username_claim: 'EXAMPLE-usernameClaim-Value',
              username_prefix: 'EXAMPLE-usernamePrefix-Value',
              groups_claim: 'EXAMPLE-groupsClaim-Value',
              groups_prefix: 'EXAMPLE-groupsPrefix-Value',
              required_claims: [
                OCI::ContainerEngine::Models::KeyValue.new(
                  key: 'EXAMPLE-key-Value', value: 'EXAMPLE-value-Value'
                )
              ],
              ca_certificate: 'EXAMPLE-caCertificate-Value',
              signing_algorithms: %w[EXAMPLE--Value],
              configuration_file: 'EXAMPLE-configurationFile-Value'
            ),
          open_id_connect_discovery:
            OCI::ContainerEngine::Models::OpenIdConnectDiscovery.new(
              is_open_id_connect_discovery_enabled: false
            )
        ),
      image_policy_config:
        OCI::ContainerEngine::Models::CreateImagePolicyConfigDetails.new(
          is_policy_enabled: true,
          key_details: [
            OCI::ContainerEngine::Models::KeyDetails.new(
              kms_key_id: 'ocid1.test.oc1..<unique_ID>EXAMPLE-kmsKeyId-Value'
            )
          ]
        ),
      cluster_pod_network_options: [
        OCI::ContainerEngine::Models::FlannelOverlayClusterPodNetworkOptionDetails
          .new(cni_type: 'FLANNEL_OVERLAY')
      ],
      type: 'ENHANCED_CLUSTER'
    )
  )

# Get the data from response
puts "#{create_cluster_response.headers}"

Was this article helpful?