From b6f425a47af2344a0c5efb82f39e982e5b40ccb2 Mon Sep 17 00:00:00 2001 From: "Bradon Kanyid (rattboi)" Date: Thu, 16 May 2024 01:22:17 +0000 Subject: [PATCH] Add localstack as addon package Signed-off-by: Bradon Kanyid (rattboi) --- examples/localstack-integration/README.md | 17 +++++++++++++ .../crossplane-provider-localstack.yaml | 22 +++++++++++++++++ .../provider-config-localstack.yaml | 19 +++++++++++++++ .../localstack-integration/localstack.yaml | 24 +++++++++++++++++++ 4 files changed, 82 insertions(+) create mode 100644 examples/localstack-integration/README.md create mode 100644 examples/localstack-integration/crossplane-provider-localstack.yaml create mode 100644 examples/localstack-integration/crossplane-provider-localstack/provider-config-localstack.yaml create mode 100644 examples/localstack-integration/localstack.yaml diff --git a/examples/localstack-integration/README.md b/examples/localstack-integration/README.md new file mode 100644 index 00000000..eaf6015f --- /dev/null +++ b/examples/localstack-integration/README.md @@ -0,0 +1,17 @@ +# Localstack Integration + +Please use the below command to deploy an IDP reference implementation with an Argo application that adds Localstack, as well as integrating with Crossplane. + +```bash +idpbuilder create \ + --use-path-routing \ + --package-dir examples/ref-implementation \ + --package-dir examples/localstack-integration +``` + +As you see above, this add-on to `idpbuilder` has a dependency on the [reference implementation](../ref-implementation/). This command primarily does the following: + +1. Installs `localstack` helmchart as an `argo` application. +2. Adds localstack crossplane ProviderConfig, targetting localstack + +Once the custom package is installed, localstack can be used from the backstage template `app-with-aws-resources`, by changing the `providerConfigName` during the bucket configuration page from `default` to `localstack`. diff --git a/examples/localstack-integration/crossplane-provider-localstack.yaml b/examples/localstack-integration/crossplane-provider-localstack.yaml new file mode 100644 index 00000000..8403c179 --- /dev/null +++ b/examples/localstack-integration/crossplane-provider-localstack.yaml @@ -0,0 +1,22 @@ +apiVersion: argoproj.io/v1alpha1 +kind: Application +metadata: + name: crossplane-provider-localstack + namespace: argocd + labels: + example: localstack-integration +spec: + project: default + source: + repoURL: cnoe://crossplane-provider-localstack + targetRevision: HEAD + path: "." + destination: + server: "https://kubernetes.default.svc" + namespace: crossplane-system + syncPolicy: + automated: + prune: true + selfHeal: true + syncOptions: + - CreateNamespace=true diff --git a/examples/localstack-integration/crossplane-provider-localstack/provider-config-localstack.yaml b/examples/localstack-integration/crossplane-provider-localstack/provider-config-localstack.yaml new file mode 100644 index 00000000..78ce7759 --- /dev/null +++ b/examples/localstack-integration/crossplane-provider-localstack/provider-config-localstack.yaml @@ -0,0 +1,19 @@ +apiVersion: aws.crossplane.io/v1beta1 +kind: ProviderConfig +metadata: + name: localstack + annotations: + argocd.argoproj.io/sync-wave: "20" + argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true +spec: + credentials: + source: Secret + secretRef: + namespace: crossplane-system + name: local-secret + key: creds + endpoint: + hostnameImmutable: true + url: + type: Static + static: http://localstack.localstack.svc.cluster.local:4566 diff --git a/examples/localstack-integration/localstack.yaml b/examples/localstack-integration/localstack.yaml new file mode 100644 index 00000000..afeb2c2c --- /dev/null +++ b/examples/localstack-integration/localstack.yaml @@ -0,0 +1,24 @@ +apiVersion: argoproj.io/v1alpha1 +kind: Application +metadata: + name: localstack + namespace: argocd + labels: + example: localstack-integration +spec: + project: default + source: + repoURL: https://localstack.github.io/helm-charts + targetRevision: 0.6.12 + chart: localstack + helm: + releaseName: localstack + destination: + server: "https://kubernetes.default.svc" + namespace: localstack + syncPolicy: + automated: + prune: true + selfHeal: true + syncOptions: + - CreateNamespace=true