diff --git a/.github/workflows/stack.yml b/.github/workflows/stack.yml new file mode 100644 index 0000000..1a5a99b --- /dev/null +++ b/.github/workflows/stack.yml @@ -0,0 +1,50 @@ +# Copyright (c) 2022 Oracle and/or its affiliates. All rights reserved. +# Licensed under the Universal Permissive License v 1.0 as shown at http://oss.oracle.com/licenses/upl. +# + +# Creates and Publishes the Oracle Resource Manager stack + +name: Generate stacks and publish release + +on: + push: + branches: [ main ] + paths: ['terraform/VERSION'] + +jobs: + + publish_stack: + runs-on: ubuntu-latest + steps: + - name: Checkout + uses: actions/checkout@v3 + + - name: Create stacks + id: create_stacks + run: | + # + STACKNAME=${{ github.event.repository.name }} + FOLDER=terraform/ + RELEASE=$(cat terraform/VERSION) + ASSETS+="${STACKNAME}-stack.zip ${STACKNAME}-${RELEASE}.zip " + echo "::group::Processing $STACKNAME" + zip -r ${STACKNAME}-stack.zip $FOLDER || { printf '\n⛔ Unable to create %s stack.\n'; exit 1; } + cp ${STACKNAME}-stack.zip ${STACKNAME}-${RELEASE}.zip || { printf '\n⛔ Unable to create %s stack.\n'; exit 1; } + echo "::endgroup::" + echo "::set-output name=assets::$ASSETS" + echo "::set-output name=release::$RELEASE" + echo "::set-output name=prefix::$STACKNAME" + + - name: Prepare Release Notes + run: | + # + printf '%s\n' '${{ steps.create_stacks.outputs.prefix }} Stack - v${{ steps.create_stacks.outputs.release }}' >release.md + printf '%s\n' '' '## [![Deploy to Oracle Cloud][magic_button]][magic_stack]' >>release.md + printf '%s\n' '' '' >>release.md + printf '%s\n' '' '[magic_button]: https://oci-resourcemanager-plugin.plugins.oci.oraclecloud.com/latest/deploy-to-oracle-cloud.svg' >>release.md + printf '%s\n' '' '[magic_stack]: https://cloud.oracle.com/resourcemanager/stacks/create?zipUrl=https://github.com/${{ github.repository }}/releases/download/${{ steps.create_stacks.outputs.release }}/${{ steps.create_stacks.outputs.prefix }}-${{ steps.create_stacks.outputs.release }}.zip' >>release.md + + - name: Create Release + run: gh release create ${{ steps.create_stacks.outputs.release }} --generate-notes -F release.md ${{ steps.create_stacks.outputs.assets }} + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} diff --git a/.gitignore b/.gitignore index f4f7191..4747660 100644 --- a/.gitignore +++ b/.gitignore @@ -3,6 +3,7 @@ **/.DS_Store *.tgz *.zip +.vscode/ # Terraform ### ## Local .terraform directories diff --git a/README.md b/README.md index 9c32dd9..a7f4f92 100644 --- a/README.md +++ b/README.md @@ -1,4 +1,4 @@ -# ![Sysdig Logo](./images/sysdig-logo-white-text.svg#gh-light-mode-only)![Sysdig Logo - Dark Mode](./images/sysdig-logo.svg#gh-dark-mode-only) [![Deploy to Oracle Cloud][magic_button]][magic_sysdig_stack] +# ![Sysdig Logo](./images/sysdig-logo.svg#gh-light-mode-only)![Sysdig Logo - Dark Mode](./images/sysdig-logo-white-text.svg#gh-dark-mode-only) [![Deploy to Oracle Cloud][magic_button]][magic_sysdig_stack] Terraform module that deploys the Sysdig Secure Agents in Oracle Kubernetes Engine (OKE) Cluster. diff --git a/images/sysdig-icon.svg b/images/sysdig-icon.svg new file mode 100644 index 0000000..014bc87 --- /dev/null +++ b/images/sysdig-icon.svg @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/terraform/.terraform.lock.hcl b/terraform/.terraform.lock.hcl index aa6c015..700f694 100644 --- a/terraform/.terraform.lock.hcl +++ b/terraform/.terraform.lock.hcl @@ -70,33 +70,6 @@ provider "registry.terraform.io/hashicorp/local" { ] } -provider "registry.terraform.io/hashicorp/oci" { - version = "4.68.0" - constraints = ">= 4.68.0" - hashes = [ - "h1:+ibmD9qY8nGrxOtcxZf5JFSUWCHj9NnNdYb2+kYSgBI=", - "h1:aJ996CmyR4SBjvDI+hF8MVzD6yd241AKJ/pTtwqcvGY=", - "h1:bfj2Sj01ZRGFFCXJt2eBcjDYHVVa3fw0U4+jnUiQJHM=", - "h1:nagiVTWsneUlp4FMDgnMCDhC+x8uNlUH3MP2SvXL0Z0=", - "h1:pU9mgzYZ9fapGYfqWnn6F8q/VnqtG3xtJzXOom0KTmk=", - "zh:0eb113292d8c0dfb83af8b57603f3d87f539e3d6fd59101cdc90cb839a7a15d2", - "zh:38e135a2b40c4a72f21bfaa9761e5d541095726dbbd6c0e68b599f14626f4d15", - "zh:42034e5dccb0c8067390242f25c10c41da68afa6bfd5dfa8a29bacd7cf0acc72", - "zh:51e12d9aa6ae9fa2925d98e5b30249464ee11a0b79bbdf696bbb7d2a505b6e6c", - "zh:54b5bf9589b3ab0527f74c3054dd28dbb427fb3868d65388d2984cf2c7637a76", - "zh:55d017747528964b476c73068f4e0a419e58721eb2f654c10947d6756a66cf63", - "zh:6d5ef791501fd20e6a5cf8b1a674c5de2c30cb2219c54b619cc42d8da69739a5", - "zh:7bd75323793a6974d0e262a3e256d8ab6e323fdeca5c344a6ee4d2582a8e5ebe", - "zh:9b12af85486a96aedd8d7984b0ff811a4b42e3d88dad1a3fb4c0b580d04fa425", - "zh:a381b0ae5bc8ccecaf8e3270e41e220e7f900052e2f34928d81e66e335f5afc6", - "zh:bbdcc854328cad0402534866d75b11275ea7dbef4d43e0ff4955c2e9782a40d2", - "zh:c1cf442599f7d87dcba638f291babd786c1384603a57af7b9525bfca9ce86a79", - "zh:c5f3c18b0ad41536cf6004a5b5d367bc3d28be6edaccd1cea133391a9d3b9424", - "zh:d5cd4b7e621ee421a119cc477cea6b0ff4d0619c78e997104388801711670365", - "zh:d8870c7bbce64613f9318f7251b803b7d018d6bd0757623c02ca2ebe0807f12f", - ] -} - provider "registry.terraform.io/hashicorp/random" { version = "3.1.0" constraints = "3.1.0" @@ -142,3 +115,30 @@ provider "registry.terraform.io/hashicorp/tls" { "zh:fc1e12b713837b85daf6c3bb703d7795eaf1c5177aebae1afcf811dd7009f4b0", ] } + +provider "registry.terraform.io/oracle/oci" { + version = "4.75.0" + constraints = ">= 4.75.0" + hashes = [ + "h1:7mA4N3Snal+MjgATEm2NCjiVlLYYAaNMFRn7+IYF3KE=", + "h1:RlYetIy/lQQ4uL3dfOY1Kq5MsRL86xxWyhPqp520fqs=", + "h1:RsrBRtygE17vqHmrclCu6vwggQta5nydw/S7Tt0SKZ0=", + "h1:fhuVWZ0a26hMLIOh2pKc78yR7ML/dr0ZPTTDnq56uhM=", + "h1:lV4Z/CuFOVjyivvAyZEJBAmFVLIm153a3Zi49lRHjKU=", + "zh:0390dd200ab50344f1014306dc186c21a8fb8fd881585b3a8299b1261ad41ca4", + "zh:0f46b164faaad0325006f3fdab4b699f1b26203e46cf9df33891ab483455c2ce", + "zh:0fb4c9ae86b24c11369bb8097a4461cde5f4f69736871c0c9d3401a2791fd402", + "zh:17bc369131353acdbce7dd132bac1caf44ec9a7ad5eb66dc33a1cf7c48eaac0e", + "zh:2cb11c8658480240e6f60ab6cc84b748bf76e08a821fc73a493a052bf8e17183", + "zh:3ae19ec595635b7fd5046669e1b0112db3bc7f378d6f8132955963a623520d20", + "zh:9b12af85486a96aedd8d7984b0ff811a4b42e3d88dad1a3fb4c0b580d04fa425", + "zh:b342b03ef66c754d86e1296dbbed533b660bc477371b5ca0918eb06704503314", + "zh:b49b11491c9e4be5417f73766d05afbac0901659196aa03147db0a86eedae1f3", + "zh:c093376cb83d66d2c46f7f83534461728d2c8a9aff25df80bbd3826da09dd4bd", + "zh:cc7fa18d38f32bd7a49dc457d1b5131ded0ca402764594d88bbb288d52e25e7e", + "zh:d0da468726410393fe9546ee23eae7056ca9a517d5ccf90baf704f4ec49f621a", + "zh:d79f133c6add2bc9a901d6941bd6b87c6d0df07eb38eed4174625697e6283dd4", + "zh:d90c8340b74defee4c8d86df230e4135cfa08ac6339cc58d92c6a833a9a32070", + "zh:da871ab255a31ebfb7a97489cf84411df8c48968f97b8048930f5a52fb3914a0", + ] +} diff --git a/terraform/VERSION b/terraform/VERSION index afaf360..7f20734 100644 --- a/terraform/VERSION +++ b/terraform/VERSION @@ -1 +1 @@ -1.0.0 \ No newline at end of file +1.0.1 \ No newline at end of file diff --git a/terraform/oke-autoscaler.tf b/terraform/oke-autoscaler.tf index dff94f8..58d2ba3 100644 --- a/terraform/oke-autoscaler.tf +++ b/terraform/oke-autoscaler.tf @@ -3,7 +3,7 @@ # locals { - cluster_autoscaler_supported_k8s_versions = { "1.18" = "1.18.3-4", "1.19" = "1.19.1-8", "1.20" = "1.20.0-6", "1.21" = "1.21.1-3" } # There's no API to get that list. Need to be updated manually + cluster_autoscaler_supported_k8s_versions = { "1.18" = "1.18.3-4", "1.19" = "1.19.1-8", "1.20" = "1.20.0-6", "1.21" = "1.21.1-3", "1.22" = "1.22.2-4" } # There's no API to get that list. Need to be updated manually cluster_autoscaler_image_version = lookup(local.cluster_autoscaler_supported_k8s_versions, local.k8s_major_minor_version, reverse(values(local.cluster_autoscaler_supported_k8s_versions))[0]) cluster_autoscaler_image_region = "iad" # Available regions: iad, phx, fra, lhr cluster_autoscaler_image = "${local.cluster_autoscaler_image_region}.ocir.io/oracle/oci-cluster-autoscaler:${local.cluster_autoscaler_image_version}" diff --git a/terraform/oke-datasources.tf b/terraform/oke-datasources.tf index 5eea26a..fa36529 100644 --- a/terraform/oke-datasources.tf +++ b/terraform/oke-datasources.tf @@ -18,6 +18,9 @@ data "oci_containerengine_cluster_option" "oke" { data "oci_containerengine_node_pool_option" "oke" { node_pool_option_id = "all" } +data "oci_containerengine_clusters" "oke" { + compartment_id = local.oke_compartment_ocid +} # Gets a list of Availability Domains data "oci_identity_availability_domains" "ADs" { diff --git a/terraform/oke-outputs.tf b/terraform/oke-outputs.tf index 39c06c0..be55b45 100755 --- a/terraform/oke-outputs.tf +++ b/terraform/oke-outputs.tf @@ -7,7 +7,7 @@ output "comments" { } output "deployed_oke_kubernetes_version" { - value = (var.k8s_version == "Latest") ? local.cluster_k8s_latest_version : var.k8s_version + value = local.deployed_k8s_version } output "kubeconfig_for_kubectl" { value = "export KUBECONFIG=./generated/kubeconfig" diff --git a/terraform/oke-variables.tf b/terraform/oke-variables.tf index 6cc31a1..f7cc7b3 100644 --- a/terraform/oke-variables.tf +++ b/terraform/oke-variables.tf @@ -16,6 +16,10 @@ variable "existent_oke_cluster_id" { default = "" description = "Using existent OKE Cluster. Only the application and services will be provisioned. If select cluster autoscaler feature, you need to get the node pool id and enter when required" } +variable "existent_oke_cluster_compartment_ocid" { + default = "" + description = "Existent OKE Cluster Compartment" +} variable "create_new_compartment_for_oke" { default = false description = "Creates new compartment for OKE Nodes and OCI Services deployed. NOTE: The creation of the compartment increases the deployment time by at least 3 minutes, and can increase by 15 minutes when destroying" diff --git a/terraform/oke.tf b/terraform/oke.tf index 581278b..0e64a90 100644 --- a/terraform/oke.tf +++ b/terraform/oke.tf @@ -89,7 +89,8 @@ resource "oci_identity_compartment" "oke_compartment" { count = var.create_new_compartment_for_oke ? 1 : 0 } locals { - oke_compartment_ocid = var.create_new_compartment_for_oke ? oci_identity_compartment.oke_compartment.0.id : var.compartment_ocid + # oke_compartment_ocid = var.create_new_compartment_for_oke ? oci_identity_compartment.oke_compartment.0.id : var.compartment_ocid + oke_compartment_ocid = var.create_new_oke_cluster ? (var.create_new_compartment_for_oke ? oci_identity_compartment.oke_compartment.0.id : var.compartment_ocid) : var.existent_oke_cluster_compartment_ocid } # Local kubeconfig for when using Terraform locally. Not used by Oracle Resource Manager @@ -108,6 +109,8 @@ resource "tls_private_key" "oke_worker_node_ssh_key" { locals { cluster_k8s_latest_version = reverse(sort(data.oci_containerengine_cluster_option.oke.kubernetes_versions))[0] node_pool_k8s_latest_version = reverse(sort(data.oci_containerengine_node_pool_option.oke.kubernetes_versions))[0] + deployed_k8s_version = var.create_new_oke_cluster ? (var.k8s_version == "Latest") ? local.cluster_k8s_latest_version : var.k8s_version :[ + for x in data.oci_containerengine_clusters.oke.clusters : x.kubernetes_version if x.id == var.existent_oke_cluster_id][0] } # Checks if is using Flexible Compute Shapes diff --git a/terraform/providers.tf b/terraform/providers.tf index 0e7cff1..7328ff0 100644 --- a/terraform/providers.tf +++ b/terraform/providers.tf @@ -3,12 +3,12 @@ # terraform { - required_version = ">= 1.0" + required_version = ">= 1.1" required_providers { oci = { - source = "hashicorp/oci" - version = ">= 4.68.0" - # https://registry.terraform.io/providers/hashicorp/oci/4.68.0 + source = "oracle/oci" + version = ">= 4.75.0" + # https://registry.terraform.io/providers/oracle/oci/4.75.0 } kubernetes = { source = "hashicorp/kubernetes" diff --git a/terraform/schema.yaml b/terraform/schema.yaml new file mode 100644 index 0000000..9643925 --- /dev/null +++ b/terraform/schema.yaml @@ -0,0 +1,618 @@ +# Copyright (c) 2022 Oracle and/or its affiliates. All rights reserved. +# Licensed under the Universal Permissive License v 1.0 as shown at http://oss.oracle.com/licenses/upl. +# + +title: "Sysdig Secure for OKE" +description: "Sysdig Secure: Unified security and compliance for containers, Kubernetes and cloud" +informationalText: "This stack deploys Sysdig Secure and Sysdig Container on an existent OKE Cluster (optionally the stack allows create a new cluster before deploy)." +schemaVersion: 1.1.0 +version: "20190304" + +logoUrl:  + +source: + type: quickstart + +locale: "en" +variableGroups: + - title: "Basic Hidden" + variables: + - compartment_ocid + - tenancy_ocid + - region + visible: false + + - title: "Sysdig Configuration" + variables: + - sysdig_access_key + - sysdig_settings_collector + - sysdig_settings_collector_port + - sysdig_node_analyzer_api_endpoint + + - title: "Sysdig <> Snyk Integration" + variables: + - sysdig_snyk_integration + - snyk_integration_id + - snyk_deploy_goof_sample + - snyk_private_registry + - snyk_private_registry_url + - snyk_private_registry_username + - snyk_private_registry_password + + - title: "Snyk Hidden Variables" + variables: + - snyk_sysdig_integration + - sysdig_eve_secret_name + - sysdig_agent_namespace + visible: false + + - title: "OKE Cluster Configuration" + variables: + - create_new_oke_cluster + - existent_oke_cluster_compartment_ocid + - existent_oke_cluster_id + - show_advanced + - app_name + - k8s_version + - cluster_workers_visibility + - cluster_endpoint_visibility + - create_new_compartment_for_oke + + - title: "OKE Worker Nodes" + variables: + - cluster_autoscaler_enabled + - num_pool_workers + - cluster_autoscaler_min_nodes + - cluster_autoscaler_max_nodes + - node_pool_shape + - node_pool_node_shape_config_ocpus + - node_pool_node_shape_config_memory_in_gbs + - generate_public_ssh_key + - public_ssh_key + - image_operating_system + - image_operating_system_version + - node_pool_name + + - title: "Dynamic Group and Policies" + variables: + - create_dynamic_group_for_nodes_in_compartment + - existent_dynamic_group_for_nodes_in_compartment + - create_compartment_policies + - create_tenancy_policies + + - title: "Encryption using OCI Vault (KMS)" + variables: + - use_encryption_from_oci_vault + - create_new_encryption_key + - existent_encryption_key_id + - create_vault_policies_for_group + - user_admin_group_for_vault_policy + + - title: "Extras Hidden" + variables: + - user_ocid + - fingerprint + - private_key_path + - network_cidrs + - cluster_options_admission_controller_options_is_pod_security_policy_enabled + - cluster_options_add_ons_is_kubernetes_dashboard_enabled + - node_pool_boot_volume_size_in_gbs + - oke_compartment_description + - create_oci_service_user + - existent_oke_nodepool_id_for_autoscaler + visible: false + +variables: + compartment_ocid: + type: oci:identity:compartment:id + title: "Compartment" + description: "The compartment in which to create compute instance(s)" + required: true + + sysdig_access_key: + type: string + title: "Sysdig Agent Access Key" + required: true + + sysdig_settings_collector: + type: string + title: "Sysdig Agent Collector URL" + required: true + + sysdig_settings_collector_port: + type: string + title: "Sysdig Agent Collector Port" + required: true + + sysdig_node_analyzer_api_endpoint: + type: string + title: "Sysdig Node Analyzer API endpoint" + required: true + + sysdig_snyk_integration: + type: boolean + title: "Enable Snyk integration to Sysdig" + required: true + visible: yes + + snyk_integration_id: + type: string + title: "Snyk Integration id" + required: true + visible: + and: + - sysdig_snyk_integration + + snyk_deploy_goof_sample: + type: boolean + title: "Deploy Snyk's Goof Sample" + required: true + visible: + and: + - sysdig_snyk_integration + + snyk_private_registry: + type: boolean + title: "Configure Private Container Registry to be scanned by Snyk" + required: true + visible: + and: + - sysdig_snyk_integration + + snyk_private_registry_url: + type: string + title: "Container Private Registry URL" + required: true + visible: + and: + - sysdig_snyk_integration + - snyk_private_registry + + snyk_private_registry_username: + type: string + title: "Container Private Registry Username" + required: true + visible: + and: + - sysdig_snyk_integration + - snyk_private_registry + + snyk_private_registry_password: + type: string + title: "Container Private Registry Password or Auth Token" + required: true + visible: + and: + - sysdig_snyk_integration + - snyk_private_registry + + app_name: + type: string + title: "Cluster Name Prefix" + required: true + visible: + and: + - create_new_oke_cluster + + show_advanced: + type: boolean + title: "Show advanced options?" + description: "Shows advanced options, allowing enable customer-managed encryption keys, select your ssh key, select/unselect cluster utilities, do not create policies, and other advanced options" + visible: + and: + - create_new_oke_cluster + + create_oci_service_user: + type: boolean + title: "Creates OCI Service User" + required: true + visible: + and: + - create_new_oke_cluster + - show_advanced + + # OKE Cluster + create_new_oke_cluster: + type: boolean + title: "Create new OKE Cluster" + + existent_oke_cluster_compartment_ocid: + type: oci:identity:compartment:id + title: "Existent OKE Cluster Compartment" + description: "The compartment where you find the existent OKE Cluster" + default: compartment_ocid + required: true + visible: + not: + - create_new_oke_cluster + + existent_oke_cluster_id: + type: oci:container:cluster:id + title: "Existent OKE Cluster" + required: true + dependsOn: + compartmentId: existent_oke_cluster_compartment_ocid + visible: + not: + - create_new_oke_cluster + + k8s_version: + type: enum + enum: # Necessary hardcoded supported versions, as ORM does not retrieve the versions from OKE. + - "Latest" + - "v1.22.5" + - "v1.21.5" + - "v1.20.11" + - "v1.19.15" + title: "Kubernetes Version" + required: true + visible: + and: + - create_new_oke_cluster + - show_advanced + + cluster_workers_visibility: + type: enum + enum: + - "Private" + - "Public" + title: "Choose Worker Nodes visibility type" + required: true + visible: + and: + - create_new_oke_cluster + + cluster_endpoint_visibility: + type: enum + enum: + # - "Private" + - "Public" + title: "Choose Kubernetes API Endpoint visibility type" + required: true + visible: + and: + - create_new_oke_cluster + + create_new_compartment_for_oke: + type: boolean + title: "Create new Compartment" + visible: + and: + - create_new_oke_cluster + - show_advanced + + cluster_autoscaler_enabled: + type: boolean + title: "Enable Cluster Autoscaler" + visible: + and: + - create_new_oke_cluster + + num_pool_workers: + type: integer + title: "Number of Worker Nodes" + minimum: 1 + maximum: 1000 + required: true + visible: + and: + - and: + - create_new_oke_cluster + - not: + - cluster_autoscaler_enabled + + cluster_autoscaler_min_nodes: + type: integer + title: "Autoscaler: Minimum number of nodes" + minimum: 1 + maximum: 1000 + required: true + visible: + and: + - create_new_oke_cluster + - cluster_autoscaler_enabled + + cluster_autoscaler_max_nodes: + type: integer + title: "Autoscaler: Maximum number of nodes" + minimum: 1 + maximum: 1000 + required: true + visible: + and: + - create_new_oke_cluster + - cluster_autoscaler_enabled + + existent_oke_nodepool_id_for_autoscaler: + type: string + title: "OKE Nodepool id" + required: true + visible: + and: + - and: + - cluster_autoscaler_enabled + - not: + - create_new_oke_cluster + + node_pool_shape: + type: oci:core:instanceshape:name + title: "Select a shape for the Worker Nodes instances" + required: true + dependsOn: + compartmentId: compartment_ocid + visible: + and: + - create_new_oke_cluster + + node_pool_node_shape_config_ocpus: + type: integer + minimum: 1 + maximum: 64 + title: "Number of OCPUs" + visible: + and: + - and: + - create_new_oke_cluster + - or: + - eq: + - node_pool_shape + - "VM.Standard.E3.Flex" + - eq: + - node_pool_shape + - "VM.Standard.E4.Flex" + - eq: + - node_pool_shape + - "VM.Standard.A1.Flex" + + node_pool_node_shape_config_memory_in_gbs: + type: integer + minimum: 1 + maximum: 1024 + title: "Amount of memory (GB)" + visible: + and: + - and: + - create_new_oke_cluster + - or: + - eq: + - node_pool_shape + - "VM.Standard.E3.Flex" + - eq: + - node_pool_shape + - "VM.Standard.E4.Flex" + - eq: + - node_pool_shape + - "VM.Standard.A1.Flex" + + node_pool_name: + type: string + title: "Node Pool Name" + required: true + visible: + and: + - create_new_oke_cluster + - show_advanced + + cluster_options_add_ons_is_kubernetes_dashboard_enabled: + type: boolean + title: "Kubernetes Dashboard Enabled" + visible: false + + generate_public_ssh_key: + type: boolean + title: "Auto generate public ssh key?" + required: true + visible: + and: + - create_new_oke_cluster + - show_advanced + + public_ssh_key: + type: oci:core:ssh:publickey + title: "Import your own SSH public key" + additionalProps: + allowMultiple: true + required: false + pattern: "((^(ssh-rsa AAAAB3NzaC1yc2|ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNT|ecdsa-sha2-nistp384 AAAAE2VjZHNhLXNoYTItbmlzdHAzODQAAAAIbmlzdHAzOD|ecdsa-sha2-nistp521 AAAAE2VjZHNhLXNoYTItbmlzdHA1MjEAAAAIbmlzdHA1Mj|ssh-ed25519 AAAAC3NzaC1lZDI1NTE5|ssh-dss AAAAB3NzaC1kc3)[0-9A-Za-z+\/]+[=]{0,3})( [^,]*)?)(,((ssh-rsa AAAAB3NzaC1yc2|ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNT|ecdsa-sha2-nistp384 AAAAE2VjZHNhLXNoYTItbmlzdHAzODQAAAAIbmlzdHAzOD|ecdsa-sha2-nistp521 AAAAE2VjZHNhLXNoYTItbmlzdHA1MjEAAAAIbmlzdHA1Mj|ssh-ed25519 AAAAC3NzaC1lZDI1NTE5|ssh-dss AAAAB3NzaC1kc3)[0-9A-Za-z+\/]+[=]{0,3})( [^,]*)?)*$" + visible: + and: + - and: + - create_new_oke_cluster + - show_advanced + - not: + - generate_public_ssh_key + + image_operating_system: + type: enum + title: "Image OS" + enum: + - "Oracle Linux" + required: true + visible: + and: + - create_new_oke_cluster + - show_advanced + + image_operating_system_version: + type: string + title: "Image OS Version" + required: true + visible: + and: + - create_new_oke_cluster + - show_advanced + + # Dynamic Groups and Policies for Instance Principals and Autoscaler + create_dynamic_group_for_nodes_in_compartment: + type: boolean + title: "Create Dynamic Group for Worker Nodes in the Compartment" + required: true + visible: + and: + - show_advanced + + existent_dynamic_group_for_nodes_in_compartment: + type: string + title: "Existent Dynamic Group" + required: true + visible: + and: + - and: + - show_advanced + - or: + - create_compartment_policies + - create_tenancy_policies + - not: + - create_dynamic_group_for_nodes_in_compartment + + create_compartment_policies: + type: boolean + title: "Create Compartment Policies" + required: true + visible: + and: + - show_advanced + + create_tenancy_policies: + type: boolean + title: "Create Tenancy Policies" + required: true + visible: + and: + - show_advanced + + # Encryption options + use_encryption_from_oci_vault: + type: boolean + title: "Encrypt using Customer-Managed Keys instead of Oracle Managed Encryption" + visible: + and: + - create_new_oke_cluster + - show_advanced + + create_new_encryption_key: + type: boolean + title: "Create new Vault and Key" + visible: + and: + - create_new_oke_cluster + - show_advanced + - use_encryption_from_oci_vault + + existent_encryption_key_id: + type: string + title: "Existent Encryption Key OCID" + required: true + visible: + and: + - and: + - create_new_oke_cluster + - show_advanced + - use_encryption_from_oci_vault + - not: + - create_new_encryption_key + + create_vault_policies_for_group: + type: boolean + title: "Create policies for the user group to manage vault and keys" + visible: + and: + - create_new_oke_cluster + - show_advanced + - use_encryption_from_oci_vault + - create_new_encryption_key + + user_admin_group_for_vault_policy: + type: string + title: "Specify your group to include the policy" + visible: + and: + - create_new_oke_cluster + - show_advanced + - use_encryption_from_oci_vault + - create_new_encryption_key + - create_vault_policies_for_group + +outputGroups: + - title: Deployment Info + outputs: + - deploy_id + - deployed_to_region + - stack_version + + - title: Kubernetes Cluster Info + outputs: + - deployed_oke_kubernetes_version + - generated_private_key_pem + + - title: Snyk Goof App Notes + outputs: + - snyk_goof_sample_access + - snyk_goof_sample_mongodb_access + + - title: Dev Notes + outputs: + - dev + - comments + +outputs: + + deploy_id: + type: string + title: "Deployment Id" + visible: true + + deployed_to_region: + type: string + title: "Deployed using Region" + visible: true + + deployed_oke_kubernetes_version: + type: string + title: "OKE Kubernetes version deployed" + visible: true + + stack_version: + type: string + title: Stack Version + displayText: Stack Version deployed + visible: true + + generated_private_key_pem: + type: string + title: Generated Private Key + displayText: Generated Private Key + + comments: + type: string + title: Comments + displayText: Comments + visible: true + + dev: + type: string + title: dev + displayText: dev note from Oracle Developers + visible: true + + snyk_goof_sample_access: + type: string + title: Kubectl command to check goof sample + displayText: Kubectl command to check goof sample (http://localhost:8088) + visible: + and: + - snyk_deploy_goof_sample + + snyk_goof_sample_mongodb_access: + type: string + title: Kubectl command to check goof mongoDb + displayText: Kubectl command to check goof mongoDb + visible: + and: + - snyk_deploy_goof_sample + + kubeconfig_for_kubectl: + type: string + title: kubeconfig + displayText: kubeconfig for local kubectl run. Not used by ORM + visible: false diff --git a/terraform/snyk-goof-app.tf b/terraform/snyk-goof-app.tf new file mode 100644 index 0000000..358623d --- /dev/null +++ b/terraform/snyk-goof-app.tf @@ -0,0 +1,175 @@ +# Copyright (c) 2022 Oracle and/or its affiliates. All rights reserved. +# Licensed under the Universal Permissive License v 1.0 as shown at http://oss.oracle.com/licenses/upl. +# + +#======================================================================================= +# DO NOT deploy the following sample application in a production environment. +# This application is used for demo purposes and contains a number of vulnerabilities. +# It is highly recommended that you promptly uninstall the application after +# you've completed the test. +#======================================================================================= + +resource "kubernetes_namespace" "goof_app_namespace" { + metadata { + name = "goof" + } + + depends_on = [data.oci_containerengine_cluster_kube_config.oke] + + count = local.install_snyk ? (var.snyk_deploy_goof_sample ? 1 : 0) : 0 +} + +resource "kubernetes_deployment" "goof" { + metadata { + name = "goof" + namespace = kubernetes_namespace.goof_app_namespace.0.id + } + + spec { + replicas = 1 + + selector { + match_labels = { + app = "goof" + tier = "frontend" + } + } + + template { + metadata { + labels = { + app = "goof" + tier = "frontend" + } + } + + spec { + container { + image = "snyklabs/goof" + name = "goof" + + resources { + requests = { + cpu = "100m" + memory = "100Mi" + } + } + port { + container_port = 3001 + } + port { + container_port = 9229 + } + env { + name = "DOCKER" + value = "1" + } + + } + } + } + } + + count = local.install_snyk ? (var.snyk_deploy_goof_sample ? 1 : 0) : 0 +} + +resource "kubernetes_deployment" "goof_mongo" { + metadata { + name = "goof-mongo" + namespace = kubernetes_namespace.goof_app_namespace.0.id + } + + spec { + replicas = 1 + + selector { + match_labels = { + app = "goof" + tier = "backend" + } + } + + template { + metadata { + labels = { + app = "goof" + tier = "backend" + } + } + + spec { + container { + image = "mongo" + name = "goof-mongo" + port { + container_port = 27017 + } + } + } + } + } + + count = local.install_snyk ? (var.snyk_deploy_goof_sample ? 1 : 0) : 0 +} + +resource "kubernetes_service" "goof" { + metadata { + name = "goof" + namespace = kubernetes_namespace.goof_app_namespace.0.id + } + spec { + selector = { + app = "goof" + tier = "frontend" + } + port { + protocol = "TCP" + port = 80 + target_port = 3001 + name = "http" + } + port { + protocol = "TCP" + port = 9229 + target_port = 9229 + name = "debug" + } + + type = "ClusterIP" + } + + count = local.install_snyk ? (var.snyk_deploy_goof_sample ? 1 : 0) : 0 +} + +resource "kubernetes_service" "goof_mongo" { + metadata { + name = "goof-mongo" + namespace = kubernetes_namespace.goof_app_namespace.0.id + } + spec { + selector = { + app = "goof" + tier = "backend" + } + port { + protocol = "TCP" + port = 27017 + target_port = 27017 + name = "mongo" + } + + type = "ClusterIP" + } + + count = local.install_snyk ? (var.snyk_deploy_goof_sample ? 1 : 0) : 0 +} + +output "snyk_goof_sample_access" { + value = "kubectl -n goof port-forward svc/goof 8088:80" + description = "If using deployed the goof app, this command will allow you to access the app locally" +} + +output "snyk_goof_sample_mongodb_access" { + value = "kubectl -n goof port-forward svc/goof-mongo 27017:27017" + description = "If using deployed the goof app, this command will allow you to access the mongodb locally" +} diff --git a/terraform/snyk-monitor.tf b/terraform/snyk-monitor.tf new file mode 100644 index 0000000..a06ed35 --- /dev/null +++ b/terraform/snyk-monitor.tf @@ -0,0 +1,111 @@ +# Copyright (c) 2021 Oracle and/or its affiliates. All rights reserved. +# Licensed under the Universal Permissive License v 1.0 as shown at http://oss.oracle.com/licenses/upl. +# + +# Namespace +resource "kubernetes_namespace" "snyk_monitor_namespace" { + metadata { + name = "snyk-monitor" + } + + depends_on = [data.oci_containerengine_cluster_kube_config.oke] + + count = local.install_snyk ? 1 : 0 +} + +# Helm Charts +## https://github.com/snyk/kubernetes-monitor/tree/staging/snyk-monitor +resource "helm_release" "snyk_monitor" { + name = "snyk-monitor" + repository = local.snyk_helm_repository.snyk_charts + chart = "snyk-monitor" + namespace = kubernetes_namespace.snyk_monitor_namespace.0.id + wait = true + + set { + name = "clusterName" + value = yamldecode(data.oci_containerengine_cluster_kube_config.oke.content)["users"][0]["user"]["exec"]["args"][4] + } + set { + name = "sysdig.enabled" + value = var.sysdig_snyk_integration + } + + depends_on = [helm_release.sysdig_agent] + + count = local.install_snyk ? 1 : 0 +} + +locals { + # Helm repos + snyk_helm_repository = { + snyk_charts = "https://snyk.github.io/kubernetes-monitor" + } +} + +# Secrets +resource "kubernetes_secret" "snyk_monitor" { + metadata { + name = "snyk-monitor" + namespace = kubernetes_namespace.snyk_monitor_namespace.0.id + } + data = { + integrationId = var.snyk_integration_id + "dockercfg.json" = jsonencode(local.snyk_dockercfg) + } + type = "Opaque" + + count = local.install_snyk ? 1 : 0 +} + +locals { + snyk_dockercfg = var.snyk_private_registry ? { + auths = { + "${var.snyk_private_registry_url}" = { + auth = "${base64encode("${var.snyk_private_registry_username}:${var.snyk_private_registry_password}")}" + } + } + } : {} +} + +# resource "kubernetes_secret" "snyk_docker_cfg" { +# metadata { +# name = "docker-cfg" +# } + +# data = { +# ".dockerconfigjson" = jsonencode({ + # auths = { + # "${var.registry_server}" = { + # auth = "${base64encode("${var.registry_username}:${var.registry_password}")}" + # } + # } + # }) +# } + +# type = "kubernetes.io/dockerconfigjson" +# } + +data "kubernetes_secret" "sysdig_eve" { + metadata { + name = var.sysdig_eve_secret_name + namespace = var.sysdig_agent_namespace + } + + depends_on = [helm_release.sysdig_agent] + + count = var.sysdig_snyk_integration ? 1 : 0 +} + +resource "kubernetes_secret" "sysdig_eve_for_snyk" { + metadata { + name = var.sysdig_eve_secret_name + namespace = kubernetes_namespace.snyk_monitor_namespace.0.id + } + data = data.kubernetes_secret.sysdig_eve.0.data + type = data.kubernetes_secret.sysdig_eve.0.type + + depends_on = [helm_release.sysdig_agent] + + count = var.sysdig_snyk_integration ? 1 : 0 +} \ No newline at end of file diff --git a/terraform/snyk-variables.tf b/terraform/snyk-variables.tf new file mode 100644 index 0000000..dc70a70 --- /dev/null +++ b/terraform/snyk-variables.tf @@ -0,0 +1,48 @@ +# Copyright (c) 2022 Oracle and/or its affiliates. All rights reserved. +# Licensed under the Universal Permissive License v 1.0 as shown at http://oss.oracle.com/licenses/upl. +# + +variable "snyk_integration_id" { + default = "" + description = "Snyk Integration Id" +} + +variable "snyk_deploy_goof_sample" { + default = false + description = "NOTE: DO NOT deploy the sample application in a production environment. This application is used for demo purposes and contains a number of vulnerabilities. It is highly recommended that you promptly uninstall the application after you've completed the tutorial." +} +variable "snyk_private_registry" { + default = false + description = "Enter credentials to scan private registry. If need more than one, update the created secret with the new credentials." +} +variable "snyk_private_registry_url" { + default = "" + description = "Enter private registry url. i.e. iad.ocir.io" +} +variable "snyk_private_registry_username" { + default = "" + description = "Enter private registry username. i.e. /oracleidentitycloudservice/" +} +variable "snyk_private_registry_password" { + default = "" + description = "Enter private registry password or auth token. Note: For ocir.io, the password is the auth token generated for the user." +} + +variable "snyk_sysdig_integration" { + default = false + description = "Enrich the issues detected by Snyk for workloads with runtime data provided by Sysdig. NOTE: The Sysdig agent must be installed and running on the same cluster." +} + +variable "sysdig_eve_secret_name" { + default = "sysdig-eve-secret" + description = "Sysdig Eve Secret Name" +} + +variable "sysdig_agent_namespace" { + default = "sysdig-agent" + description = "Sysdig Agent Namespace" +} + +locals { + install_snyk = var.sysdig_snyk_integration +} \ No newline at end of file diff --git a/terraform/sysdig-agent.tf b/terraform/sysdig-agent.tf index 3e03452..e1f7229 100644 --- a/terraform/sysdig-agent.tf +++ b/terraform/sysdig-agent.tf @@ -9,15 +9,17 @@ resource "kubernetes_namespace" "sysdig_agent_namespace" { } depends_on = [data.oci_containerengine_cluster_kube_config.oke] + + count = local.install_sysdig ? 1 : 0 } # Helm Charts ## https://github.com/sysdiglabs/charts/tree/master/charts/agent resource "helm_release" "sysdig_agent" { name = "sysdig-agent" - repository = local.helm_repository.sysdig_charts + repository = local.sysdig_helm_repository.sysdig_charts chart = "sysdig" - namespace = kubernetes_namespace.sysdig_agent_namespace.id + namespace = kubernetes_namespace.sysdig_agent_namespace.0.id wait = false set { @@ -44,11 +46,16 @@ resource "helm_release" "sysdig_agent" { name = "ebpf.enabled" value = true } + + count = local.install_sysdig ? 1 : 0 } locals { # Helm repos - helm_repository = { + sysdig_helm_repository = { sysdig_charts = "https://charts.sysdig.com" } + + # Sysdig Agent + install_sysdig = true } diff --git a/terraform/sysdig-variables.tf b/terraform/sysdig-variables.tf index edc6165..5a4bf99 100644 --- a/terraform/sysdig-variables.tf +++ b/terraform/sysdig-variables.tf @@ -21,3 +21,8 @@ variable "sysdig_node_analyzer_api_endpoint" { default = "" description = "Sysdig secure API endpoint, without protocol (i.e. secure.sysdig.com)" } + +variable "sysdig_snyk_integration" { + default = false + description = "Enrich security insights and automated remediation with Snyk and seamlessly integrated to more easily find, prioritize, and fix vulnerabilities in containers and open source dependencies." +} \ No newline at end of file