// 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).

import * as containerengine from "oci-containerengine";
import common = require("oci-common");

// Create a default authentication provider that uses the DEFAULT
// profile in the configuration file.
// Refer to <see href="https://docs.cloud.oracle.com/en-us/iaas/Content/API/Concepts/sdkconfig.htm#SDK_and_CLI_Configuration_File>the public documentation</see> on how to prepare a configuration file.

const provider: common.ConfigFileAuthenticationDetailsProvider = new common.ConfigFileAuthenticationDetailsProvider();

(async () => {
  try {
    // Create a service client
    const client = new containerengine.ContainerEngineClient({
      authenticationDetailsProvider: provider
    });

    // Create a request and dependent object(s).
    const createClusterDetails = ({
      name: "EXAMPLE-name-Value",
      compartmentId: "ocid1.test.oc1..<unique_ID>EXAMPLE-compartmentId-Value",
      endpointConfig: ({
        subnetId: "ocid1.test.oc1..<unique_ID>EXAMPLE-subnetId-Value",
        nsgIds: ["EXAMPLE--Value"],
        isPublicIpEnabled: false,
        securityAttributes: {
          EXAMPLE_KEY_2s1xD: {
            EXAMPLE_KEY_KCmRC: "EXAMPLE--Value"
          }
        }
      } as unknown) as containerengine.models.CreateClusterEndpointConfigDetails,
      vcnId: "ocid1.test.oc1..<unique_ID>EXAMPLE-vcnId-Value",
      kubernetesVersion: "EXAMPLE-kubernetesVersion-Value",
      kmsKeyId: "ocid1.test.oc1..<unique_ID>EXAMPLE-kmsKeyId-Value",
      freeformTags: {
        EXAMPLE_KEY_UaxgT: "EXAMPLE_VALUE_yJqjRCwV0cz2U9vvwxhW"
      },
      definedTags: {
        EXAMPLE_KEY_x8s13: {
          EXAMPLE_KEY_Cpd3B: "EXAMPLE--Value"
        }
      },
      options: ({
        serviceLbSubnetIds: ["EXAMPLE--Value"],
        ipFamilies: [containerengine.models.ClusterCreateOptions.IpFamilies.IPv4],
        kubernetesNetworkConfig: ({
          podsCidr: "EXAMPLE-podsCidr-Value",
          servicesCidr: "EXAMPLE-servicesCidr-Value"
        } as unknown) as containerengine.models.KubernetesNetworkConfig,
        addOns: ({
          isKubernetesDashboardEnabled: false,
          isTillerEnabled: false
        } as unknown) as containerengine.models.AddOnOptions,
        admissionControllerOptions: ({
          isPodSecurityPolicyEnabled: true
        } as unknown) as containerengine.models.AdmissionControllerOptions,
        persistentVolumeConfig: ({
          freeformTags: {
            EXAMPLE_KEY_D0Ahb: "EXAMPLE_VALUE_uTS8abpeGgV00fxYqpvO"
          },
          definedTags: {
            EXAMPLE_KEY_hdwyW: {
              EXAMPLE_KEY_Mb1cK: "EXAMPLE--Value"
            }
          }
        } as unknown) as containerengine.models.PersistentVolumeConfigDetails,
        serviceLbConfig: ({
          freeformTags: {
            EXAMPLE_KEY_6RjEN: "EXAMPLE_VALUE_8maFq8qCu8ZS9Jv6CFeX"
          },
          definedTags: {
            EXAMPLE_KEY_MeQLQ: {
              EXAMPLE_KEY_vxZDd: "EXAMPLE--Value"
            }
          },
          backendNsgIds: ["EXAMPLE--Value"]
        } as unknown) as containerengine.models.ServiceLbConfigDetails,
        openIdConnectTokenAuthenticationConfig: ({
          issuerUrl: "EXAMPLE-issuerUrl-Value",
          clientId: "ocid1.test.oc1..<unique_ID>EXAMPLE-clientId-Value",
          usernameClaim: "EXAMPLE-usernameClaim-Value",
          usernamePrefix: "EXAMPLE-usernamePrefix-Value",
          groupsClaim: "EXAMPLE-groupsClaim-Value",
          groupsPrefix: "EXAMPLE-groupsPrefix-Value",
          requiredClaims: [
            ({
              key: "EXAMPLE-key-Value",
              value: "EXAMPLE-value-Value"
            } as unknown) as containerengine.models.KeyValue
          ],
          caCertificate: "EXAMPLE-caCertificate-Value",
          signingAlgorithms: ["EXAMPLE--Value"],
          isOpenIdConnectAuthEnabled: false,
          configurationFile: "EXAMPLE-configurationFile-Value"
        } as unknown) as containerengine.models.OpenIdConnectTokenAuthenticationConfig,
        openIdConnectDiscovery: ({
          isOpenIdConnectDiscoveryEnabled: true
        } as unknown) as containerengine.models.OpenIdConnectDiscovery
      } as unknown) as containerengine.models.ClusterCreateOptions,
      imagePolicyConfig: ({
        isPolicyEnabled: false,
        keyDetails: [
          ({
            kmsKeyId: "ocid1.test.oc1..<unique_ID>EXAMPLE-kmsKeyId-Value"
          } as unknown) as containerengine.models.KeyDetails
        ]
      } as unknown) as containerengine.models.CreateImagePolicyConfigDetails,
      clusterPodNetworkOptions: [
        ({
          cniType: "FLANNEL_OVERLAY"
        } as unknown) as containerengine.models.FlannelOverlayClusterPodNetworkOptionDetails
      ],
      type: containerengine.models.ClusterType.BasicCluster
    } as unknown) as containerengine.models.CreateClusterDetails;

    const createClusterRequest: containerengine.requests.CreateClusterRequest = {
      createClusterDetails: createClusterDetails,
      opcRetryToken: "EXAMPLE-opcRetryToken-Value",
      opcRequestId: "J1ZXPVHYQ4IZZOJCCFGO<unique_ID>"
    };

    // Send request to the Client.
    const createClusterResponse = await client.createCluster(createClusterRequest);
  } catch (error) {
    console.log("createCluster Failed with error  " + error);
  }
})();