first commit
This commit is contained in:
commit
24ed43ec46
89 changed files with 14683 additions and 0 deletions
22
kind/edfbuilder.yaml
Normal file
22
kind/edfbuilder.yaml
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: edfbuilder
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
spec:
|
||||||
|
destination:
|
||||||
|
name: in-cluster
|
||||||
|
namespace: argocd
|
||||||
|
source:
|
||||||
|
path: registry
|
||||||
|
repoURL: 'https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot'
|
||||||
|
targetRevision: HEAD
|
||||||
|
project: default
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
prune: true
|
||||||
|
selfHeal: true
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
22
kind/registry/core.yaml
Normal file
22
kind/registry/core.yaml
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: core
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
spec:
|
||||||
|
destination:
|
||||||
|
name: in-cluster
|
||||||
|
namespace: argocd
|
||||||
|
source:
|
||||||
|
path: stacks/core
|
||||||
|
repoURL: 'https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot'
|
||||||
|
targetRevision: HEAD
|
||||||
|
project: default
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
prune: true
|
||||||
|
selfHeal: true
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
22
kind/registry/crossplane-integrations.yaml
Normal file
22
kind/registry/crossplane-integrations.yaml
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: crossplane-integrations
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
spec:
|
||||||
|
destination:
|
||||||
|
name: in-cluster
|
||||||
|
namespace: argocd
|
||||||
|
source:
|
||||||
|
path: stacks/crossplane-integrations
|
||||||
|
repoURL: 'https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot'
|
||||||
|
targetRevision: HEAD
|
||||||
|
project: default
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
prune: true
|
||||||
|
selfHeal: true
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
22
kind/registry/localstack-integration.yaml
Normal file
22
kind/registry/localstack-integration.yaml
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: localstack-integration
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
spec:
|
||||||
|
destination:
|
||||||
|
name: in-cluster
|
||||||
|
namespace: argocd
|
||||||
|
source:
|
||||||
|
path: stacks/localstack-integration
|
||||||
|
repoURL: 'https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot'
|
||||||
|
targetRevision: HEAD
|
||||||
|
project: default
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
prune: true
|
||||||
|
selfHeal: true
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
22
kind/registry/ref-implementation.yaml
Normal file
22
kind/registry/ref-implementation.yaml
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: ref-implementation
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
spec:
|
||||||
|
destination:
|
||||||
|
name: in-cluster
|
||||||
|
namespace: argocd
|
||||||
|
source:
|
||||||
|
path: stacks/ref-implementation
|
||||||
|
repoURL: 'https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot'
|
||||||
|
targetRevision: HEAD
|
||||||
|
project: default
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
prune: true
|
||||||
|
selfHeal: true
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
27
kind/stacks/core/argocd.yaml
Normal file
27
kind/stacks/core/argocd.yaml
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: argocd
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
spec:
|
||||||
|
project: default
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
selfHeal: true
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
||||||
|
destination:
|
||||||
|
name: in-cluster
|
||||||
|
namespace: argocd
|
||||||
|
sources:
|
||||||
|
- repoURL: https://github.com/argoproj/argo-helm
|
||||||
|
path: charts/argo-cd
|
||||||
|
targetRevision: HEAD
|
||||||
|
helm:
|
||||||
|
valueFiles:
|
||||||
|
- $values/stacks/core/argocd/values.yaml
|
||||||
|
- repoURL: https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot
|
||||||
|
targetRevision: HEAD
|
||||||
|
ref: values
|
40
kind/stacks/core/argocd/values.yaml
Normal file
40
kind/stacks/core/argocd/values.yaml
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
global:
|
||||||
|
domain: cnoe.localtest.me
|
||||||
|
|
||||||
|
configs:
|
||||||
|
params:
|
||||||
|
server.insecure: true
|
||||||
|
server.basehref: /argocd
|
||||||
|
cm:
|
||||||
|
application.resourceTrackingMethod: "annotation"
|
||||||
|
timeout.reconciliation: 60s
|
||||||
|
resource.exclusions: |
|
||||||
|
- kinds:
|
||||||
|
- ProviderConfigUsage
|
||||||
|
apiGroups:
|
||||||
|
- "*"
|
||||||
|
tls:
|
||||||
|
certificates:
|
||||||
|
|
||||||
|
notifications:
|
||||||
|
enabled: false
|
||||||
|
|
||||||
|
dex:
|
||||||
|
enabled: false
|
||||||
|
|
||||||
|
server:
|
||||||
|
ingress:
|
||||||
|
enabled: true
|
||||||
|
ingressClassName: nginx
|
||||||
|
annotations:
|
||||||
|
nginx.ingress.kubernetes.io/backend-protocol: HTTP
|
||||||
|
nginx.ingress.kubernetes.io/rewrite-target: /$2
|
||||||
|
nginx.ingress.kubernetes.io/use-regex: "true"
|
||||||
|
nginx.ingress.kubernetes.io/force-ssl-redirect: "true"
|
||||||
|
path: /argocd(/|$)(.*)
|
||||||
|
pathType: ImplementationSpecific
|
||||||
|
extraTls:
|
||||||
|
- hosts:
|
||||||
|
- cnoe.localtest.me
|
||||||
|
secretName: argocd-net-tls
|
||||||
|
|
27
kind/stacks/core/forgejo.yaml
Normal file
27
kind/stacks/core/forgejo.yaml
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: forgejo
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
spec:
|
||||||
|
project: default
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
selfHeal: true
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
||||||
|
destination:
|
||||||
|
name: in-cluster
|
||||||
|
namespace: gitea
|
||||||
|
sources:
|
||||||
|
- repoURL: https://code.forgejo.org/forgejo-helm/forgejo-helm.git
|
||||||
|
path: .
|
||||||
|
targetRevision: HEAD
|
||||||
|
helm:
|
||||||
|
valueFiles:
|
||||||
|
- $values/stacks/core/forgejo/values.yaml
|
||||||
|
- repoURL: https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot
|
||||||
|
targetRevision: HEAD
|
||||||
|
ref: values
|
59
kind/stacks/core/forgejo/values.yaml
Normal file
59
kind/stacks/core/forgejo/values.yaml
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
redis-cluster:
|
||||||
|
enabled: false
|
||||||
|
postgresql:
|
||||||
|
enabled: false
|
||||||
|
postgresql-ha:
|
||||||
|
enabled: false
|
||||||
|
|
||||||
|
persistence:
|
||||||
|
enabled: true
|
||||||
|
size: 5Gi
|
||||||
|
|
||||||
|
test:
|
||||||
|
enabled: false
|
||||||
|
|
||||||
|
gitea:
|
||||||
|
admin:
|
||||||
|
existingSecret: gitea-credential
|
||||||
|
config:
|
||||||
|
database:
|
||||||
|
DB_TYPE: sqlite3
|
||||||
|
session:
|
||||||
|
PROVIDER: memory
|
||||||
|
cache:
|
||||||
|
ADAPTER: memory
|
||||||
|
queue:
|
||||||
|
TYPE: level
|
||||||
|
server:
|
||||||
|
DOMAIN: 'gitea.cnoe.localtest.me'
|
||||||
|
ROOT_URL: 'https://gitea.cnoe.localtest.me:443'
|
||||||
|
|
||||||
|
service:
|
||||||
|
ssh:
|
||||||
|
type: NodePort
|
||||||
|
nodePort: 32222
|
||||||
|
externalTrafficPolicy: Local
|
||||||
|
|
||||||
|
ingress:
|
||||||
|
# NOTE: The ingress is generated in a later step for path based routing feature See: hack/argo-cd/generate-manifests.sh
|
||||||
|
enabled: true
|
||||||
|
className: nginx
|
||||||
|
annotations:
|
||||||
|
nginx.ingress.kubernetes.io/proxy-body-size: 512m
|
||||||
|
nginx.ingress.kubernetes.io/force-ssl-redirect: "true"
|
||||||
|
hosts:
|
||||||
|
- host: gitea.cnoe.localtest.me
|
||||||
|
paths:
|
||||||
|
- path: /
|
||||||
|
pathType: Prefix
|
||||||
|
tls:
|
||||||
|
- hosts:
|
||||||
|
- gitea.cnoe.localtest.me
|
||||||
|
secretName: forgejo-net-tls
|
||||||
|
|
||||||
|
image:
|
||||||
|
pullPolicy: "IfNotPresent"
|
||||||
|
# Overrides the image tag whose default is the chart appVersion.
|
||||||
|
#tag: "8.0.3"
|
||||||
|
# Adds -rootless suffix to image name
|
||||||
|
rootless: true
|
29
kind/stacks/core/grafana.yaml
Normal file
29
kind/stacks/core/grafana.yaml
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: grafana
|
||||||
|
namespace: argocd
|
||||||
|
# namespace: monitoring
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
spec:
|
||||||
|
project: default
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
selfHeal: true
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
||||||
|
destination:
|
||||||
|
name: in-cluster
|
||||||
|
# namespace: grafana
|
||||||
|
namespace: monitoring
|
||||||
|
sources:
|
||||||
|
- repoURL: https://github.com/grafana/helm-charts
|
||||||
|
path: charts/grafana
|
||||||
|
targetRevision: HEAD
|
||||||
|
helm:
|
||||||
|
valueFiles:
|
||||||
|
- $values/stacks/core/grafana/values.yaml
|
||||||
|
- repoURL: https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot
|
||||||
|
targetRevision: HEAD
|
||||||
|
ref: values
|
167
kind/stacks/core/grafana/values.yaml
Normal file
167
kind/stacks/core/grafana/values.yaml
Normal file
|
@ -0,0 +1,167 @@
|
||||||
|
rbac:
|
||||||
|
create: true
|
||||||
|
## Use an existing ClusterRole/Role (depending on rbac.namespaced false/true)
|
||||||
|
# useExistingRole: name-of-some-role
|
||||||
|
# useExistingClusterRole: name-of-some-clusterRole
|
||||||
|
pspEnabled: false
|
||||||
|
pspUseAppArmor: false
|
||||||
|
namespaced: false
|
||||||
|
extraRoleRules: []
|
||||||
|
# - apiGroups: []
|
||||||
|
# resources: []
|
||||||
|
# verbs: []
|
||||||
|
extraClusterRoleRules: []
|
||||||
|
# - apiGroups: []
|
||||||
|
# resources: []
|
||||||
|
# verbs: []
|
||||||
|
serviceAccount:
|
||||||
|
create: true
|
||||||
|
name:
|
||||||
|
nameTest:
|
||||||
|
## ServiceAccount labels.
|
||||||
|
labels: {}
|
||||||
|
## Service account annotations. Can be templated.
|
||||||
|
# annotations:
|
||||||
|
# eks.amazonaws.com/role-arn: arn:aws:iam::123456789000:role/iam-role-name-here
|
||||||
|
|
||||||
|
## autoMount is deprecated in favor of automountServiceAccountToken
|
||||||
|
# autoMount: false
|
||||||
|
automountServiceAccountToken: false
|
||||||
|
|
||||||
|
replicas: 1
|
||||||
|
|
||||||
|
## Create a headless service for the deployment
|
||||||
|
headlessService: false
|
||||||
|
|
||||||
|
## Should the service account be auto mounted on the pod
|
||||||
|
automountServiceAccountToken: true
|
||||||
|
|
||||||
|
## Create HorizontalPodAutoscaler object for deployment type
|
||||||
|
#
|
||||||
|
autoscaling:
|
||||||
|
enabled: false
|
||||||
|
minReplicas: 1
|
||||||
|
maxReplicas: 5
|
||||||
|
targetCPU: "60"
|
||||||
|
targetMemory: ""
|
||||||
|
behavior: {}
|
||||||
|
|
||||||
|
## See `kubectl explain poddisruptionbudget.spec` for more
|
||||||
|
## ref: https://kubernetes.io/docs/tasks/run-application/configure-pdb/
|
||||||
|
podDisruptionBudget: {}
|
||||||
|
# apiVersion: ""
|
||||||
|
# minAvailable: 1
|
||||||
|
# maxUnavailable: 1
|
||||||
|
|
||||||
|
## See `kubectl explain deployment.spec.strategy` for more
|
||||||
|
## ref: https://kubernetes.io/docs/concepts/workloads/controllers/deployment/#strategy
|
||||||
|
deploymentStrategy:
|
||||||
|
type: RollingUpdate
|
||||||
|
|
||||||
|
readinessProbe:
|
||||||
|
httpGet:
|
||||||
|
path: /api/health
|
||||||
|
port: 3000
|
||||||
|
|
||||||
|
livenessProbe:
|
||||||
|
httpGet:
|
||||||
|
path: /api/health
|
||||||
|
port: 3000
|
||||||
|
initialDelaySeconds: 60
|
||||||
|
timeoutSeconds: 30
|
||||||
|
failureThreshold: 10
|
||||||
|
|
||||||
|
# dns configuration for pod
|
||||||
|
dnsPolicy: ~
|
||||||
|
dnsConfig: {}
|
||||||
|
# nameservers:
|
||||||
|
# - 8.8.8.8
|
||||||
|
# options:
|
||||||
|
# - name: ndots
|
||||||
|
# value: "2"
|
||||||
|
# - name: edns0
|
||||||
|
|
||||||
|
securityContext:
|
||||||
|
runAsNonRoot: true
|
||||||
|
runAsUser: 472
|
||||||
|
runAsGroup: 472
|
||||||
|
fsGroup: 472
|
||||||
|
|
||||||
|
containerSecurityContext:
|
||||||
|
allowPrivilegeEscalation: false
|
||||||
|
capabilities:
|
||||||
|
drop:
|
||||||
|
- ALL
|
||||||
|
seccompProfile:
|
||||||
|
type: RuntimeDefault
|
||||||
|
|
||||||
|
# Enable creating the grafana configmap
|
||||||
|
createConfigmap: true
|
||||||
|
|
||||||
|
## Pod Labels
|
||||||
|
# podLabels: {}
|
||||||
|
|
||||||
|
podPortName: grafana
|
||||||
|
gossipPortName: gossip
|
||||||
|
## Deployment annotations
|
||||||
|
# annotations: {}
|
||||||
|
|
||||||
|
## Expose the grafana service to be accessed from outside the cluster (LoadBalancer service).
|
||||||
|
## or access it from within the cluster (ClusterIP service). Set the service type and the port to serve it.
|
||||||
|
## ref: http://kubernetes.io/docs/user-guide/services/
|
||||||
|
##
|
||||||
|
service:
|
||||||
|
enabled: true
|
||||||
|
|
||||||
|
|
||||||
|
gettype: ClusterIP
|
||||||
|
#type: NodePort
|
||||||
|
|
||||||
|
# Set the ip family policy to configure dual-stack see [Configure dual-stack](https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services)
|
||||||
|
ipFamilyPolicy: ""
|
||||||
|
# Sets the families that should be supported and the order in which they should be applied to ClusterIP as well. Can be IPv4 and/or IPv6.
|
||||||
|
ipFamilies: []
|
||||||
|
loadBalancerIP: ""
|
||||||
|
loadBalancerClass: ""
|
||||||
|
loadBalancerSourceRanges: []
|
||||||
|
#port: 90
|
||||||
|
port: 3000
|
||||||
|
targetPort: 3000
|
||||||
|
#targetPort: 90
|
||||||
|
# targetPort: 4181 To be used with a proxy extraContainer
|
||||||
|
## Service annotations. Can be templated.
|
||||||
|
annotations: {}
|
||||||
|
labels: {}
|
||||||
|
portName: service
|
||||||
|
# Adds the appProtocol field to the service. This allows to work with istio protocol selection. Ex: "http" or "tcp"
|
||||||
|
appProtocol: ""
|
||||||
|
|
||||||
|
dashboardProviders: {}
|
||||||
|
|
||||||
|
dashboards: {}
|
||||||
|
|
||||||
|
|
||||||
|
grafana.ini:
|
||||||
|
server:
|
||||||
|
domain: cnoe.localtest.me
|
||||||
|
root_url: "%(protocol)s://%(domain)s/grafana"
|
||||||
|
serve_from_sub_path: true
|
||||||
|
|
||||||
|
ingress:
|
||||||
|
enabled: true
|
||||||
|
ingressClassName: nginx
|
||||||
|
hosts:
|
||||||
|
- cnoe.localtest.me
|
||||||
|
path: /grafana
|
||||||
|
|
||||||
|
|
||||||
|
#TODO: not yet!
|
||||||
|
#datasources:
|
||||||
|
# datasources.yaml:
|
||||||
|
# apiVersion: 1
|
||||||
|
# datasources:
|
||||||
|
# - name: Prometheus
|
||||||
|
# type: prometheus
|
||||||
|
# url: http://prometheus-server.prometheus.svc.cluster.local
|
||||||
|
# access: proxy
|
||||||
|
# isDefault: true
|
27
kind/stacks/core/ingress-nginx.yaml
Normal file
27
kind/stacks/core/ingress-nginx.yaml
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: ingress-nginx
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
spec:
|
||||||
|
project: default
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
selfHeal: true
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
||||||
|
destination:
|
||||||
|
name: in-cluster
|
||||||
|
namespace: ingress-nginx
|
||||||
|
sources:
|
||||||
|
- repoURL: https://github.com/kubernetes/ingress-nginx
|
||||||
|
path: charts/ingress-nginx
|
||||||
|
targetRevision: HEAD
|
||||||
|
helm:
|
||||||
|
valueFiles:
|
||||||
|
- $values/stacks/core/ingress-nginx/values.yaml
|
||||||
|
- repoURL: https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot
|
||||||
|
targetRevision: HEAD
|
||||||
|
ref: values
|
36
kind/stacks/core/ingress-nginx/values.yaml
Normal file
36
kind/stacks/core/ingress-nginx/values.yaml
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
controller:
|
||||||
|
updateStrategy:
|
||||||
|
type: RollingUpdate
|
||||||
|
rollingUpdate:
|
||||||
|
maxUnavailable: 1
|
||||||
|
hostPort:
|
||||||
|
enabled: true
|
||||||
|
terminationGracePeriodSeconds: 0
|
||||||
|
service:
|
||||||
|
type: NodePort
|
||||||
|
watchIngressWithoutClass: true
|
||||||
|
|
||||||
|
nodeSelector:
|
||||||
|
ingress-ready: "true"
|
||||||
|
tolerations:
|
||||||
|
- key: "node-role.kubernetes.io/master"
|
||||||
|
operator: "Equal"
|
||||||
|
effect: "NoSchedule"
|
||||||
|
- key: "node-role.kubernetes.io/control-plane"
|
||||||
|
operator: "Equal"
|
||||||
|
effect: "NoSchedule"
|
||||||
|
|
||||||
|
publishService:
|
||||||
|
enabled: false
|
||||||
|
extraArgs:
|
||||||
|
publish-status-address: localhost
|
||||||
|
# added for idpbuilder
|
||||||
|
enable-ssl-passthrough: ""
|
||||||
|
|
||||||
|
# added for idpbuilder
|
||||||
|
allowSnippetAnnotations: true
|
||||||
|
|
||||||
|
# added for idpbuilder
|
||||||
|
config:
|
||||||
|
proxy-buffer-size: 32k
|
||||||
|
use-forwarded-headers: "true"
|
28
kind/stacks/core/kube-prometheus.yaml
Normal file
28
kind/stacks/core/kube-prometheus.yaml
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: kube-prometheus-stack
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
spec:
|
||||||
|
project: default
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
selfHeal: true
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
||||||
|
- ServerSideApply=true
|
||||||
|
destination:
|
||||||
|
name: in-cluster
|
||||||
|
namespace: monitoring
|
||||||
|
sources:
|
||||||
|
- repoURL: https://github.com/prometheus-community/helm-charts
|
||||||
|
path: charts/kube-prometheus-stack
|
||||||
|
targetRevision: HEAD
|
||||||
|
helm:
|
||||||
|
valueFiles:
|
||||||
|
- $values/stacks/core/kube-prometheus/values.yaml
|
||||||
|
- repoURL: https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot
|
||||||
|
targetRevision: HEAD
|
||||||
|
ref: values
|
15
kind/stacks/core/kube-prometheus/values.yaml
Normal file
15
kind/stacks/core/kube-prometheus/values.yaml
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
grafana:
|
||||||
|
namespaceOverride: "monitoring"
|
||||||
|
|
||||||
|
grafana.ini:
|
||||||
|
server:
|
||||||
|
domain: cnoe.localtest.me
|
||||||
|
root_url: "%(protocol)s://%(domain)s/grafana"
|
||||||
|
serve_from_sub_path: true
|
||||||
|
|
||||||
|
ingress:
|
||||||
|
enabled: true
|
||||||
|
ingressClassName: nginx
|
||||||
|
hosts:
|
||||||
|
- cnoe.localtest.me
|
||||||
|
path: /grafana
|
27
kind/stacks/core/prometheus.yaml
Normal file
27
kind/stacks/core/prometheus.yaml
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: prometheus
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
spec:
|
||||||
|
project: default
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
selfHeal: true
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
||||||
|
destination:
|
||||||
|
name: in-cluster
|
||||||
|
namespace: monitoring
|
||||||
|
sources:
|
||||||
|
- repoURL: https://github.com/prometheus-community/helm-charts
|
||||||
|
path: charts/prometheus
|
||||||
|
targetRevision: HEAD
|
||||||
|
helm:
|
||||||
|
valueFiles:
|
||||||
|
- $values/stacks/core/prometheus/values.yaml
|
||||||
|
- repoURL: https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot
|
||||||
|
targetRevision: HEAD
|
||||||
|
ref: values
|
107
kind/stacks/core/prometheus/values.yaml
Normal file
107
kind/stacks/core/prometheus/values.yaml
Normal file
|
@ -0,0 +1,107 @@
|
||||||
|
|
||||||
|
logLevel: 4
|
||||||
|
|
||||||
|
metricsRelistInterval: 1m
|
||||||
|
|
||||||
|
listenPort: 6443
|
||||||
|
|
||||||
|
nodeSelector: {}
|
||||||
|
|
||||||
|
priorityClassName: ""
|
||||||
|
|
||||||
|
# Url to access prometheus
|
||||||
|
prometheus:
|
||||||
|
# Value is templated
|
||||||
|
url: http://prometheus.default.svc
|
||||||
|
port: 9090
|
||||||
|
path: ""
|
||||||
|
|
||||||
|
replicas: 1
|
||||||
|
|
||||||
|
# SecurityContext of the container
|
||||||
|
# ref. https://kubernetes.io/docs/tasks/configure-pod-container/security-context
|
||||||
|
securityContext:
|
||||||
|
allowPrivilegeEscalation: false
|
||||||
|
capabilities:
|
||||||
|
drop: ["ALL"]
|
||||||
|
readOnlyRootFilesystem: true
|
||||||
|
runAsNonRoot: true
|
||||||
|
runAsUser: 10001
|
||||||
|
seccompProfile:
|
||||||
|
type: RuntimeDefault
|
||||||
|
|
||||||
|
rbac:
|
||||||
|
# Specifies whether RBAC resources should be created
|
||||||
|
create: true
|
||||||
|
# Specifies if a Cluster Role should be used for the Auth Reader
|
||||||
|
useAuthReaderClusterRole: false
|
||||||
|
externalMetrics:
|
||||||
|
resources: ["*"]
|
||||||
|
customMetrics:
|
||||||
|
resources: ["*"]
|
||||||
|
|
||||||
|
serviceAccount:
|
||||||
|
# Specifies whether a service account should be created
|
||||||
|
create: true
|
||||||
|
# The name of the service account to use.
|
||||||
|
# If not set and create is true, a name is generated using the fullname template
|
||||||
|
name:
|
||||||
|
# ServiceAccount annotations.
|
||||||
|
# Use case: AWS EKS IAM roles for service accounts
|
||||||
|
# ref: https://docs.aws.amazon.com/eks/latest/userguide/specify-service-account-role.html
|
||||||
|
annotations: {}
|
||||||
|
|
||||||
|
# Configure liveness probe
|
||||||
|
# https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#Probe
|
||||||
|
livenessProbe:
|
||||||
|
httpGet:
|
||||||
|
path: /healthz
|
||||||
|
port: https
|
||||||
|
scheme: HTTPS
|
||||||
|
initialDelaySeconds: 30
|
||||||
|
timeoutSeconds: 5
|
||||||
|
|
||||||
|
# Configure readiness probe
|
||||||
|
readinessProbe:
|
||||||
|
httpGet:
|
||||||
|
path: /healthz
|
||||||
|
port: https
|
||||||
|
scheme: HTTPS
|
||||||
|
initialDelaySeconds: 30
|
||||||
|
timeoutSeconds: 5
|
||||||
|
|
||||||
|
rules:
|
||||||
|
default: true
|
||||||
|
|
||||||
|
custom: []
|
||||||
|
|
||||||
|
# Mounts a configMap with pre-generated rules for use. Overrides the
|
||||||
|
# default, custom, external and resource entries
|
||||||
|
existing:
|
||||||
|
|
||||||
|
external: []
|
||||||
|
|
||||||
|
service:
|
||||||
|
annotations: {}
|
||||||
|
port: 443
|
||||||
|
type: ClusterIP
|
||||||
|
# clusterIP: 1.2.3.4
|
||||||
|
ipDualStack:
|
||||||
|
enabled: false
|
||||||
|
ipFamilies: ["IPv6", "IPv4"]
|
||||||
|
ipFamilyPolicy: "PreferDualStack"
|
||||||
|
|
||||||
|
# Set environment variables from secrets, configmaps or by setting them as name/value
|
||||||
|
env: []
|
||||||
|
|
||||||
|
# Deployment strategy type
|
||||||
|
strategy:
|
||||||
|
type: RollingUpdate
|
||||||
|
rollingUpdate:
|
||||||
|
maxUnavailable: 25%
|
||||||
|
maxSurge: 25%
|
||||||
|
|
||||||
|
certManager:
|
||||||
|
enabled: false
|
||||||
|
caCertDuration: 43800h0m0s
|
||||||
|
certDuration: 8760h0m0s
|
37
kind/stacks/crossplane-integrations/README.md
Executable file
37
kind/stacks/crossplane-integrations/README.md
Executable file
|
@ -0,0 +1,37 @@
|
||||||
|
# Crossplane Integrations for Backstage
|
||||||
|
|
||||||
|
`idpBuilder` is extensible to launch custom Crossplane patterns using package extensions.
|
||||||
|
|
||||||
|
Please use the below command to deploy an IDP reference implementation with an Argo application for preparing up the setup for terraform integrations:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
idpbuilder create \
|
||||||
|
--use-path-routing \
|
||||||
|
--package https://github.com/cnoe-io/stacks//ref-implementation \
|
||||||
|
--package https://github.com/cnoe-io/stacks//crossplane-integrations
|
||||||
|
```
|
||||||
|
## What is installed?
|
||||||
|
|
||||||
|
1. Crossplane Runtime
|
||||||
|
1. AWS providers
|
||||||
|
1. Basic Compositions
|
||||||
|
|
||||||
|
This needs your credentials for this to work. Follow the Crossplane installation documentation on how to add your credentials.
|
||||||
|
|
||||||
|
## Application with cloud resources.
|
||||||
|
|
||||||
|
With this integration, we can deploy an application with cloud resources using Backstage templates from the reference implementation, together with Crossplane integrations.
|
||||||
|
|
||||||
|
In this example, we will create an application with a S3 Bucket.
|
||||||
|
|
||||||
|
Choose a template named `App with S3 bucket`, type `demo3` as the name, then choose a region to create this bucket in.
|
||||||
|
|
||||||
|
Once you click the create button, you will have a very similar setup as the basic example.
|
||||||
|
The only difference is we now have a resource for a S3 Bucket which is managed by Crossplane.
|
||||||
|
|
||||||
|
Note that Bucket is **not** created because Crossplane doesn't have necessary credentials to do so.
|
||||||
|
If you'd like it to actually create a bucket, update [the credentials secret file](crossplane-providers/provider-secret.yaml), then run `idpbuilder create --package https://github.com/cnoe-io/stacks//ref-implementation`.
|
||||||
|
|
||||||
|
In this example, we used Crossplane to provision resources, but you can use other cloud resource management tools such as Terraform instead.
|
||||||
|
|
||||||
|
Regardless of your tool choice, concepts are the same. We use Backstage as the templating mechanism and UI for users, then use Kubernetes API with GitOps to deploy resources.
|
22
kind/stacks/crossplane-integrations/crossplane-compositions.yaml
Executable file
22
kind/stacks/crossplane-integrations/crossplane-compositions.yaml
Executable file
|
@ -0,0 +1,22 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: crossplane-compositions
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
finalizers:
|
||||||
|
- resources-finalizer.argocd.argoproj.io
|
||||||
|
spec:
|
||||||
|
project: default
|
||||||
|
source:
|
||||||
|
repoURL: https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot
|
||||||
|
targetRevision: HEAD
|
||||||
|
path: "stacks/crossplane-integrations/crossplane-compositions"
|
||||||
|
directory:
|
||||||
|
recurse: true
|
||||||
|
destination:
|
||||||
|
server: "https://kubernetes.default.svc"
|
||||||
|
namespace: crossplane-system
|
||||||
|
syncPolicy:
|
||||||
|
automated: {}
|
|
@ -0,0 +1,76 @@
|
||||||
|
# Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
||||||
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
apiVersion: apiextensions.crossplane.io/v1
|
||||||
|
kind: CompositeResourceDefinition
|
||||||
|
metadata:
|
||||||
|
name: xobjectstorages.awsblueprints.io
|
||||||
|
spec:
|
||||||
|
claimNames:
|
||||||
|
kind: ObjectStorage
|
||||||
|
plural: objectstorages
|
||||||
|
group: awsblueprints.io
|
||||||
|
names:
|
||||||
|
kind: XObjectStorage
|
||||||
|
plural: xobjectstorages
|
||||||
|
connectionSecretKeys:
|
||||||
|
- region
|
||||||
|
- bucket-name
|
||||||
|
- s3-put-policy
|
||||||
|
versions:
|
||||||
|
- name: v1alpha1
|
||||||
|
served: true
|
||||||
|
referenceable: true
|
||||||
|
schema:
|
||||||
|
openAPIV3Schema:
|
||||||
|
properties:
|
||||||
|
spec:
|
||||||
|
description: ObjectStorageSpec defines the desired state of ObjectStorage
|
||||||
|
properties:
|
||||||
|
resourceConfig:
|
||||||
|
description: ResourceConfig defines general properties of this AWS
|
||||||
|
resource.
|
||||||
|
properties:
|
||||||
|
deletionPolicy:
|
||||||
|
description: Defaults to Delete
|
||||||
|
enum:
|
||||||
|
- Delete
|
||||||
|
- Orphan
|
||||||
|
type: string
|
||||||
|
name:
|
||||||
|
description: Set the name of this resource in AWS to the value
|
||||||
|
provided by this field.
|
||||||
|
type: string
|
||||||
|
providerConfigName:
|
||||||
|
type: string
|
||||||
|
region:
|
||||||
|
type: string
|
||||||
|
tags:
|
||||||
|
items:
|
||||||
|
properties:
|
||||||
|
key:
|
||||||
|
type: string
|
||||||
|
value:
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- key
|
||||||
|
- value
|
||||||
|
type: object
|
||||||
|
type: array
|
||||||
|
required:
|
||||||
|
- providerConfigName
|
||||||
|
- region
|
||||||
|
- tags
|
||||||
|
type: object
|
||||||
|
required:
|
||||||
|
- resourceConfig
|
||||||
|
type: object
|
||||||
|
status:
|
||||||
|
description: ObjectStorageStatus defines the observed state of ObjectStorage
|
||||||
|
properties:
|
||||||
|
bucketName:
|
||||||
|
type: string
|
||||||
|
bucketArn:
|
||||||
|
type: string
|
||||||
|
type: object
|
||||||
|
type: object
|
|
@ -0,0 +1,80 @@
|
||||||
|
apiVersion: apiextensions.crossplane.io/v1
|
||||||
|
kind: Composition
|
||||||
|
metadata:
|
||||||
|
name: s3bucket.awsblueprints.io
|
||||||
|
labels:
|
||||||
|
awsblueprints.io/provider: aws
|
||||||
|
awsblueprints.io/environment: dev
|
||||||
|
s3.awsblueprints.io/configuration: standard
|
||||||
|
spec:
|
||||||
|
writeConnectionSecretsToNamespace: crossplane-system
|
||||||
|
compositeTypeRef:
|
||||||
|
apiVersion: awsblueprints.io/v1alpha1
|
||||||
|
kind: XObjectStorage
|
||||||
|
patchSets:
|
||||||
|
- name: common-fields
|
||||||
|
patches:
|
||||||
|
- type: FromCompositeFieldPath
|
||||||
|
fromFieldPath: spec.resourceConfig.providerConfigName
|
||||||
|
toFieldPath: spec.providerConfigRef.name
|
||||||
|
- type: FromCompositeFieldPath
|
||||||
|
fromFieldPath: spec.resourceConfig.deletionPolicy
|
||||||
|
toFieldPath: spec.deletionPolicy
|
||||||
|
- type: FromCompositeFieldPath
|
||||||
|
fromFieldPath: spec.resourceConfig.region
|
||||||
|
toFieldPath: spec.forProvider.region
|
||||||
|
- type: FromCompositeFieldPath
|
||||||
|
fromFieldPath: spec.resourceConfig.name
|
||||||
|
toFieldPath: metadata.annotations[crossplane.io/external-name]
|
||||||
|
resources:
|
||||||
|
- name: s3-bucket
|
||||||
|
connectionDetails:
|
||||||
|
- name: bucket-name
|
||||||
|
fromConnectionSecretKey: endpoint
|
||||||
|
- name: region
|
||||||
|
fromConnectionSecretKey: region
|
||||||
|
base:
|
||||||
|
apiVersion: s3.aws.crossplane.io/v1beta1
|
||||||
|
kind: Bucket
|
||||||
|
spec:
|
||||||
|
deletionPolicy: Delete
|
||||||
|
forProvider:
|
||||||
|
objectOwnership: BucketOwnerEnforced
|
||||||
|
publicAccessBlockConfiguration:
|
||||||
|
blockPublicPolicy: true
|
||||||
|
restrictPublicBuckets: true
|
||||||
|
serverSideEncryptionConfiguration:
|
||||||
|
rules:
|
||||||
|
- applyServerSideEncryptionByDefault:
|
||||||
|
sseAlgorithm: AES256
|
||||||
|
tagging:
|
||||||
|
tagSet:
|
||||||
|
- key: cnoe
|
||||||
|
value: "1"
|
||||||
|
patches:
|
||||||
|
- type: PatchSet
|
||||||
|
patchSetName: common-fields
|
||||||
|
- type: FromCompositeFieldPath
|
||||||
|
fromFieldPath: spec.resourceConfig.tags
|
||||||
|
toFieldPath: spec.forProvider.tagging.tagSet
|
||||||
|
policy:
|
||||||
|
mergeOptions:
|
||||||
|
appendSlice: true
|
||||||
|
keepMapValues: true
|
||||||
|
- type: FromCompositeFieldPath
|
||||||
|
fromFieldPath: spec.resourceConfig.region
|
||||||
|
toFieldPath: spec.forProvider.locationConstraint
|
||||||
|
- fromFieldPath: spec.writeConnectionSecretToRef.namespace
|
||||||
|
toFieldPath: spec.writeConnectionSecretToRef.namespace
|
||||||
|
- type: ToCompositeFieldPath
|
||||||
|
fromFieldPath: metadata.annotations[crossplane.io/external-name]
|
||||||
|
toFieldPath: status.bucketName
|
||||||
|
- type: ToCompositeFieldPath
|
||||||
|
fromFieldPath: status.atProvider.arn
|
||||||
|
toFieldPath: status.bucketArn
|
||||||
|
- fromFieldPath: metadata.uid
|
||||||
|
toFieldPath: spec.writeConnectionSecretToRef.name
|
||||||
|
transforms:
|
||||||
|
- type: string
|
||||||
|
string:
|
||||||
|
fmt: "%s-bucket"
|
22
kind/stacks/crossplane-integrations/crossplane-providers.yaml
Executable file
22
kind/stacks/crossplane-integrations/crossplane-providers.yaml
Executable file
|
@ -0,0 +1,22 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: crossplane-providers
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
finalizers:
|
||||||
|
- resources-finalizer.argocd.argoproj.io
|
||||||
|
spec:
|
||||||
|
project: default
|
||||||
|
source:
|
||||||
|
repoURL: https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot
|
||||||
|
targetRevision: HEAD
|
||||||
|
path: "stacks/crossplane-integrations/crossplane-providers"
|
||||||
|
destination:
|
||||||
|
server: "https://kubernetes.default.svc"
|
||||||
|
namespace: crossplane-system
|
||||||
|
syncPolicy:
|
||||||
|
automated: {}
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
|
@ -0,0 +1,6 @@
|
||||||
|
apiVersion: pkg.crossplane.io/v1
|
||||||
|
kind: Provider
|
||||||
|
metadata:
|
||||||
|
name: provider-aws
|
||||||
|
spec:
|
||||||
|
package: xpkg.upbound.io/crossplane-contrib/provider-aws:v0.48.0
|
|
@ -0,0 +1,14 @@
|
||||||
|
apiVersion: aws.crossplane.io/v1beta1
|
||||||
|
kind: ProviderConfig
|
||||||
|
metadata:
|
||||||
|
name: default
|
||||||
|
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
|
|
@ -0,0 +1,11 @@
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: local-secret
|
||||||
|
namespace: crossplane-system
|
||||||
|
stringData:
|
||||||
|
creds: |
|
||||||
|
[default]
|
||||||
|
aws_access_key_id = replaceme
|
||||||
|
aws_secret_access_key = replaceme
|
||||||
|
aws_session_token = replacemeifneeded
|
26
kind/stacks/crossplane-integrations/crossplane.yaml
Executable file
26
kind/stacks/crossplane-integrations/crossplane.yaml
Executable file
|
@ -0,0 +1,26 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: crossplane
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
finalizers:
|
||||||
|
- resources-finalizer.argocd.argoproj.io
|
||||||
|
spec:
|
||||||
|
project: default
|
||||||
|
source:
|
||||||
|
repoURL: 'https://charts.crossplane.io/stable'
|
||||||
|
targetRevision: 1.15.0
|
||||||
|
helm:
|
||||||
|
releaseName: crossplane
|
||||||
|
chart: crossplane
|
||||||
|
destination:
|
||||||
|
server: 'https://kubernetes.default.svc'
|
||||||
|
namespace: crossplane-system
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
prune: true
|
||||||
|
selfHeal: true
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
17
kind/stacks/localstack-integration/README.md
Normal file
17
kind/stacks/localstack-integration/README.md
Normal file
|
@ -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 https://github.com/cnoe-io/stacks//ref-implementation \
|
||||||
|
--package https://github.com/cnoe-io/stacks//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`.
|
|
@ -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: https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot
|
||||||
|
targetRevision: HEAD
|
||||||
|
path: "stacks/localstack-integration/crossplane-provider-localstack"
|
||||||
|
destination:
|
||||||
|
server: "https://kubernetes.default.svc"
|
||||||
|
namespace: crossplane-system
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
prune: true
|
||||||
|
selfHeal: true
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
|
@ -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
|
24
kind/stacks/localstack-integration/localstack.yaml
Normal file
24
kind/stacks/localstack-integration/localstack.yaml
Normal file
|
@ -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
|
146
kind/stacks/ref-implementation/README.md
Normal file
146
kind/stacks/ref-implementation/README.md
Normal file
|
@ -0,0 +1,146 @@
|
||||||
|
# Reference implementation
|
||||||
|
|
||||||
|
This example creates a local version of the CNOE reference implementation.
|
||||||
|
|
||||||
|
## Prerequisites
|
||||||
|
|
||||||
|
Ensure you have the following tools installed on your computer.
|
||||||
|
|
||||||
|
**Required**
|
||||||
|
|
||||||
|
- [idpbuilder](https://github.com/cnoe-io/idpbuilder/releases/latest): version `0.3.0` or later
|
||||||
|
- [kubectl](https://kubernetes.io/docs/tasks/tools/#kubectl): version `1.27` or later
|
||||||
|
- Your computer should have at least 6 GB RAM allocated to Docker. If you are on Docker Desktop, see [this guide](https://docs.docker.com/desktop/settings/mac/).
|
||||||
|
|
||||||
|
**Optional**
|
||||||
|
|
||||||
|
- AWS credentials: Access Key and secret Key. If you want to create AWS resources in one of examples below.
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
**_NOTE:_**
|
||||||
|
- If you'd like to run this in your web browser through Codespaces, please follow [the instructions here](./codespaces.md) to install instead.
|
||||||
|
|
||||||
|
- _This example assumes that you run the reference implementation with the default port configguration of 8443 for the idpBuilder.
|
||||||
|
If you happen to configure a different host or port for the idpBuilder, the manifests in the reference example need to be updated
|
||||||
|
and be configured with the new host and port. you can use the [replace.sh](replace.sh) to change the port as desired prior to applying the manifest as instructed in the command above._
|
||||||
|
|
||||||
|
```bash
|
||||||
|
idpbuilder create --use-path-routing \
|
||||||
|
--package https://github.com/cnoe-io/stacks//ref-implementation
|
||||||
|
```
|
||||||
|
|
||||||
|
This will take ~6 minutes for everything to come up. To track the progress, you can go to the [ArgoCD UI](https://cnoe.localtest.me:8443/argocd/applications).
|
||||||
|
|
||||||
|
### What was installed?
|
||||||
|
|
||||||
|
1. **Argo Workflows** to enable workflow orchestrations.
|
||||||
|
1. **Backstage** as the UI for software catalog and templating. Source is available [here](https://github.com/cnoe-io/backstage-app).
|
||||||
|
1. **External Secrets** to generate secrets and coordinate secrets between applications.
|
||||||
|
1. **Keycloak** as the identity provider for applications.
|
||||||
|
1. **Spark Operator** to demonstrate an example Spark workload through Backstage.
|
||||||
|
|
||||||
|
If you don't want to install a package above, you can remove the ArgoCD Application file corresponding to the package you want to remove.
|
||||||
|
For example, if you want to remove Spark Operator, you can delete [this file](./spark-operator.yaml).
|
||||||
|
|
||||||
|
The only package that cannot be removed this way is Keycloak because other packages rely on it.
|
||||||
|
|
||||||
|
|
||||||
|
#### Accessing UIs
|
||||||
|
- Argo CD: https://cnoe.localtest.me:8443/argocd
|
||||||
|
- Argo Workflows: https://cnoe.localtest.me:8443/argo-workflows
|
||||||
|
- Backstage: https://cnoe.localtest.me:8443/
|
||||||
|
- Gitea: https://cnoe.localtest.me:8443/gitea
|
||||||
|
- Keycloak: https://cnoe.localtest.me:8443/keycloak/admin/master/console/
|
||||||
|
|
||||||
|
# Using it
|
||||||
|
|
||||||
|
For this example, we will walk through a few demonstrations. Once applications are ready, go to the [backstage URL](https://cnoe.localtest.me:8443).
|
||||||
|
|
||||||
|
Click on the Sign-In button, you will be asked to log into the Keycloak instance. There are two users set up in this
|
||||||
|
configuration, and their password can be retrieved with the following command:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
idpbuilder get secrets
|
||||||
|
```
|
||||||
|
|
||||||
|
Use the username **`user1`** and the password value given by `USER_PASSWORD` field to login to the backstage instance.
|
||||||
|
`user1` is an admin user who has access to everything in the cluster, while `user2` is a regular user with limited access.
|
||||||
|
Both users use the same password retrieved above.
|
||||||
|
|
||||||
|
If you want to create a new user or change existing users:
|
||||||
|
|
||||||
|
1. Go to the [Keycloak UI](https://cnoe.localtest.me:8443/keycloak/admin/master/console/).
|
||||||
|
Login with the username `cnoe-admin`. Password is the `KEYCLOAK_ADMIN_PASSWORD` field from the command above.
|
||||||
|
2. Select `cnoe` from the realms drop down menu.
|
||||||
|
3. Select users tab.
|
||||||
|
|
||||||
|
|
||||||
|
## Basic Deployment
|
||||||
|
|
||||||
|
Let's start by deploying a simple application to the cluster through Backstage.
|
||||||
|
|
||||||
|
Click on the `Create...` button on the left, then select the `Create a Basic Deployment` template.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
|
||||||
|
In the next screen, type `demo` for the name field, then click Review, then Create.
|
||||||
|
Once steps run, click the Open In Catalog button to go to the entity page.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
In the demo entity page, you will notice a ArgoCD overview card associated with this entity.
|
||||||
|
You can click on the ArgoCD Application name to see more details.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
### What just happened?
|
||||||
|
|
||||||
|
1. Backstage created [a git repository](https://cnoe.localtest.me:8443/gitea/giteaAdmin/demo), then pushed templated contents to it.
|
||||||
|
2. Backstage created [an ArgoCD Application](https://cnoe.localtest.me:8443/argocd/applications/argocd/demo?) and pointed it to the git repository.
|
||||||
|
3. Backstage registered the application as [a component](https://cnoe.localtest.me:8443/gitea/giteaAdmin/demo/src/branch/main/catalog-info.yaml) in Backstage.
|
||||||
|
4. ArgoCD deployed the manifests stored in the repo to the cluster.
|
||||||
|
5. Backstage retrieved application health from ArgoCD API, then displayed it.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
|
||||||
|
## Argo Workflows and Spark Operator
|
||||||
|
|
||||||
|
In this example, we will deploy a simple Apache Spark job through Argo Workflows.
|
||||||
|
|
||||||
|
Click on the `Create...` button on the left, then select the `Basic Argo Workflow with a Spark Job` template.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
Type `demo2` for the name field, then click create. You will notice that the Backstage templating steps are very similar to the basic example above.
|
||||||
|
Click on the Open In Catalog button to go to the entity page.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
Deployment processes are the same as the first example. Instead of deploying a pod, we deployed a workflow to create a Spark job.
|
||||||
|
|
||||||
|
In the entity page, there is a card for Argo Workflows, and it should say running or succeeded.
|
||||||
|
You can click the name in the card to go to the Argo Workflows UI to view more details about this workflow run.
|
||||||
|
When prompted to log in, click the login button under single sign on. Argo Workflows is configured to use SSO with Keycloak allowing you to login with the same credentials as Backstage login.
|
||||||
|
|
||||||
|
Note that Argo Workflows are not usually deployed this way. This is just an example to show you how you can integrate workflows, backstage, and spark.
|
||||||
|
|
||||||
|
Back in the entity page, you can view more details about Spark jobs by navigating to the Spark tab.
|
||||||
|
|
||||||
|
## Application with cloud resources.
|
||||||
|
|
||||||
|
To deploy cloud resources, you can follow any of the instructions below:
|
||||||
|
|
||||||
|
- [Cloud resource deployments via Crossplane](../crossplane-integrations/)
|
||||||
|
- [Cloud resource deployments via Terraform](../terraform-integrations/)
|
||||||
|
|
||||||
|
## Notes
|
||||||
|
|
||||||
|
- In these examples, we have used the pattern of creating a new repository for every app, then having ArgoCD deploy it.
|
||||||
|
This is done for convenience and demonstration purposes only. There are alternative actions that you can use.
|
||||||
|
For example, you can create a PR to an existing repository, create a repository but not deploy them yet, etc.
|
||||||
|
|
||||||
|
- If Backstage's pipelining and templating mechanisms is too simple, you can use more advanced workflow engines like Tekton or Argo Workflows.
|
||||||
|
You can invoke them in Backstage templates, then track progress similar to how it was described above.
|
25
kind/stacks/ref-implementation/argo-workflows.yaml
Normal file
25
kind/stacks/ref-implementation/argo-workflows.yaml
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: argo-workflows
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
finalizers:
|
||||||
|
- resources-finalizer.argocd.argoproj.io
|
||||||
|
spec:
|
||||||
|
project: default
|
||||||
|
source:
|
||||||
|
repoURL: https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot
|
||||||
|
targetRevision: HEAD
|
||||||
|
path: "stacks/ref-implementation/argo-workflows/manifests/dev"
|
||||||
|
destination:
|
||||||
|
server: "https://kubernetes.default.svc"
|
||||||
|
namespace: argo
|
||||||
|
syncPolicy:
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
||||||
|
automated:
|
||||||
|
selfHeal: true
|
||||||
|
retry:
|
||||||
|
limit: -1
|
File diff suppressed because it is too large
Load diff
|
@ -0,0 +1,2 @@
|
||||||
|
resources:
|
||||||
|
- install.yaml
|
|
@ -0,0 +1,20 @@
|
||||||
|
apiVersion: external-secrets.io/v1beta1
|
||||||
|
kind: ExternalSecret
|
||||||
|
metadata:
|
||||||
|
name: keycloak-oidc
|
||||||
|
namespace: argo
|
||||||
|
spec:
|
||||||
|
secretStoreRef:
|
||||||
|
name: keycloak
|
||||||
|
kind: ClusterSecretStore
|
||||||
|
target:
|
||||||
|
name: keycloak-oidc
|
||||||
|
data:
|
||||||
|
- secretKey: client-id
|
||||||
|
remoteRef:
|
||||||
|
key: keycloak-clients
|
||||||
|
property: ARGO_WORKFLOWS_CLIENT_ID
|
||||||
|
- secretKey: secret-key
|
||||||
|
remoteRef:
|
||||||
|
key: keycloak-clients
|
||||||
|
property: ARGO_WORKFLOWS_CLIENT_SECRET
|
|
@ -0,0 +1,31 @@
|
||||||
|
apiVersion: networking.k8s.io/v1
|
||||||
|
kind: Ingress
|
||||||
|
metadata:
|
||||||
|
name: argo-workflows-ingress
|
||||||
|
namespace: argo
|
||||||
|
annotations:
|
||||||
|
nginx.ingress.kubernetes.io/use-regex: "true"
|
||||||
|
nginx.ingress.kubernetes.io/rewrite-target: /$2
|
||||||
|
spec:
|
||||||
|
ingressClassName: "nginx"
|
||||||
|
rules:
|
||||||
|
- host: localhost
|
||||||
|
http:
|
||||||
|
paths:
|
||||||
|
- path: /argo-workflows(/|$)(.*)
|
||||||
|
pathType: ImplementationSpecific
|
||||||
|
backend:
|
||||||
|
service:
|
||||||
|
name: argo-server
|
||||||
|
port:
|
||||||
|
name: web
|
||||||
|
- host: cnoe.localtest.me
|
||||||
|
http:
|
||||||
|
paths:
|
||||||
|
- path: /argo-workflows(/|$)(.*)
|
||||||
|
pathType: ImplementationSpecific
|
||||||
|
backend:
|
||||||
|
service:
|
||||||
|
name: argo-server
|
||||||
|
port:
|
||||||
|
name: web
|
|
@ -0,0 +1,8 @@
|
||||||
|
resources:
|
||||||
|
- ../base
|
||||||
|
- external-secret.yaml
|
||||||
|
- ingress.yaml
|
||||||
|
- sa-admin.yaml
|
||||||
|
patches:
|
||||||
|
- path: patches/cm-argo-workflows.yaml
|
||||||
|
- path: patches/deployment-argo-server.yaml
|
|
@ -0,0 +1,26 @@
|
||||||
|
apiVersion: v1
|
||||||
|
kind: ConfigMap
|
||||||
|
metadata:
|
||||||
|
name: workflow-controller-configmap
|
||||||
|
namespace: argo
|
||||||
|
data:
|
||||||
|
config: |
|
||||||
|
sso:
|
||||||
|
insecureSkipVerify: true
|
||||||
|
issuer: https://cnoe.localtest.me/keycloak/realms/cnoe
|
||||||
|
clientId:
|
||||||
|
name: keycloak-oidc
|
||||||
|
key: client-id
|
||||||
|
clientSecret:
|
||||||
|
name: keycloak-oidc
|
||||||
|
key: secret-key
|
||||||
|
redirectUrl: https://cnoe.localtest.me:443/argo-workflows/oauth2/callback
|
||||||
|
rbac:
|
||||||
|
enabled: true
|
||||||
|
scopes:
|
||||||
|
- openid
|
||||||
|
- profile
|
||||||
|
- email
|
||||||
|
- groups
|
||||||
|
nodeEvents:
|
||||||
|
enabled: false
|
|
@ -0,0 +1,30 @@
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: argo-server
|
||||||
|
namespace: argo
|
||||||
|
annotations:
|
||||||
|
argocd.argoproj.io/sync-wave: "20"
|
||||||
|
spec:
|
||||||
|
template:
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: argo-server
|
||||||
|
readinessProbe:
|
||||||
|
httpGet:
|
||||||
|
path: /
|
||||||
|
port: 2746
|
||||||
|
scheme: HTTP
|
||||||
|
env:
|
||||||
|
- name: BASE_HREF
|
||||||
|
value: "/argo-workflows/"
|
||||||
|
args:
|
||||||
|
- server
|
||||||
|
- --configmap=workflow-controller-configmap
|
||||||
|
- --auth-mode=client
|
||||||
|
- --auth-mode=sso
|
||||||
|
- "--secure=false"
|
||||||
|
- "--loglevel"
|
||||||
|
- "info"
|
||||||
|
- "--log-format"
|
||||||
|
- "text"
|
|
@ -0,0 +1,32 @@
|
||||||
|
# Used by users in the admin group
|
||||||
|
# TODO Need to tighten up permissions.
|
||||||
|
apiVersion: v1
|
||||||
|
kind: ServiceAccount
|
||||||
|
metadata:
|
||||||
|
name: admin
|
||||||
|
namespace: argo
|
||||||
|
annotations:
|
||||||
|
workflows.argoproj.io/rbac-rule: "'admin' in groups"
|
||||||
|
workflows.argoproj.io/rbac-rule-precedence: "10"
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: ClusterRoleBinding
|
||||||
|
metadata:
|
||||||
|
name: argo-admin
|
||||||
|
roleRef:
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
kind: ClusterRole
|
||||||
|
name: cluster-admin
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: admin
|
||||||
|
namespace: argo
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: admin.service-account-token
|
||||||
|
annotations:
|
||||||
|
kubernetes.io/service-account.name: admin
|
||||||
|
namespace: argo
|
||||||
|
type: kubernetes.io/service-account-token
|
25
kind/stacks/ref-implementation/backstage-templates.yaml
Normal file
25
kind/stacks/ref-implementation/backstage-templates.yaml
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: backstage-templates
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
spec:
|
||||||
|
project: default
|
||||||
|
source:
|
||||||
|
repoURL: https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot
|
||||||
|
targetRevision: HEAD
|
||||||
|
path: "stacks/ref-implementation/backstage-templates/entities"
|
||||||
|
directory:
|
||||||
|
exclude: 'catalog-info.yaml'
|
||||||
|
destination:
|
||||||
|
server: "https://kubernetes.default.svc"
|
||||||
|
namespace: backstage
|
||||||
|
syncPolicy:
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
||||||
|
automated:
|
||||||
|
selfHeal: true
|
||||||
|
retry:
|
||||||
|
limit: -1
|
|
@ -0,0 +1,48 @@
|
||||||
|
apiVersion: backstage.io/v1alpha1
|
||||||
|
kind: Resource
|
||||||
|
metadata:
|
||||||
|
name: ${{values.name}}-bucket
|
||||||
|
description: Stores things
|
||||||
|
annotations:
|
||||||
|
argocd/app-name: ${{values.name | dump}}
|
||||||
|
spec:
|
||||||
|
type: s3-bucket
|
||||||
|
owner: guests
|
||||||
|
---
|
||||||
|
apiVersion: backstage.io/v1alpha1
|
||||||
|
kind: Component
|
||||||
|
metadata:
|
||||||
|
name: ${{values.name | dump}}
|
||||||
|
description: This is for testing purposes
|
||||||
|
annotations:
|
||||||
|
backstage.io/techdocs-ref: dir:.
|
||||||
|
backstage.io/kubernetes-label-selector: 'entity-id=${{values.name}}'
|
||||||
|
backstage.io/kubernetes-namespace: default
|
||||||
|
argocd/app-name: ${{values.name | dump}}
|
||||||
|
links:
|
||||||
|
- url: https://gitea.cnoe.localtest.me:443
|
||||||
|
title: Repo URL
|
||||||
|
icon: github
|
||||||
|
spec:
|
||||||
|
owner: guests
|
||||||
|
lifecycle: experimental
|
||||||
|
type: service
|
||||||
|
system: ${{values.name | dump}}
|
||||||
|
dependsOn:
|
||||||
|
- resource:default/${{values.name}}-bucket
|
||||||
|
---
|
||||||
|
apiVersion: backstage.io/v1alpha1
|
||||||
|
kind: System
|
||||||
|
metadata:
|
||||||
|
name: ${{values.name | dump}}
|
||||||
|
description: An example system for demonstration purposes
|
||||||
|
annotations:
|
||||||
|
backstage.io/techdocs-ref: dir:.
|
||||||
|
links:
|
||||||
|
- url: https://github.com/cnoe-io/stacks/tree/main/ref-implementation
|
||||||
|
title: CNOE Repo
|
||||||
|
icon: github
|
||||||
|
spec:
|
||||||
|
owner: guests
|
||||||
|
lifecycle: experimental
|
||||||
|
type: service
|
|
@ -0,0 +1,46 @@
|
||||||
|
[![Codespell][codespell-badge]][codespell-link]
|
||||||
|
[![E2E][e2e-badge]][e2e-link]
|
||||||
|
[![Go Report Card][report-badge]][report-link]
|
||||||
|
[![Commit Activity][commit-activity-badge]][commit-activity-link]
|
||||||
|
|
||||||
|
# IDP Builder
|
||||||
|
|
||||||
|
Internal development platform binary launcher.
|
||||||
|
|
||||||
|
> **WORK IN PROGRESS**: This tool is in a pre-release stage and is under active development.
|
||||||
|
|
||||||
|
## About
|
||||||
|
|
||||||
|
Spin up a complete internal developer platform using industry standard technologies like Kubernetes, Argo, and backstage with only Docker required as a dependency.
|
||||||
|
|
||||||
|
This can be useful in several ways:
|
||||||
|
* Create a single binary which can demonstrate an IDP reference implementation.
|
||||||
|
* Use within CI to perform integration testing.
|
||||||
|
* Use as a local development environment for platform engineers.
|
||||||
|
|
||||||
|
## Getting Started
|
||||||
|
|
||||||
|
Checkout our [documentation website](https://cnoe.io/docs/reference-implementation/installations/idpbuilder) for getting started with idpbuilder.
|
||||||
|
|
||||||
|
## Community
|
||||||
|
|
||||||
|
- If you have questions or concerns about this tool, please feel free to reach out to us on the [CNCF Slack Channel](https://cloud-native.slack.com/archives/C05TN9WFN5S).
|
||||||
|
- You can also join our community meetings to meet the team and ask any questions. Checkout [this calendar](https://calendar.google.com/calendar/embed?src=064a2adfce866ccb02e61663a09f99147f22f06374e7a8994066bdc81e066986%40group.calendar.google.com&ctz=America%2FLos_Angeles) for more information.
|
||||||
|
|
||||||
|
## Contribution
|
||||||
|
|
||||||
|
Checkout the [contribution doc](./CONTRIBUTING.md) for contribution guidelines and more information on how to set up your local environment.
|
||||||
|
|
||||||
|
|
||||||
|
<!-- JUST BADGES & LINKS -->
|
||||||
|
[codespell-badge]: https://github.com/cnoe-io/idpbuilder/actions/workflows/codespell.yaml/badge.svg
|
||||||
|
[codespell-link]: https://github.com/cnoe-io/idpbuilder/actions/workflows/codespell.yaml
|
||||||
|
|
||||||
|
[e2e-badge]: https://github.com/cnoe-io/idpbuilder/actions/workflows/e2e.yaml/badge.svg
|
||||||
|
[e2e-link]: https://github.com/cnoe-io/idpbuilder/actions/workflows/e2e.yaml
|
||||||
|
|
||||||
|
[report-badge]: https://goreportcard.com/badge/github.com/cnoe-io/idpbuilder
|
||||||
|
[report-link]: https://goreportcard.com/report/github.com/cnoe-io/idpbuilder
|
||||||
|
|
||||||
|
[commit-activity-badge]: https://img.shields.io/github/commit-activity/m/cnoe-io/idpbuilder
|
||||||
|
[commit-activity-link]: https://github.com/cnoe-io/idpbuilder/pulse
|
Binary file not shown.
After Width: | Height: | Size: 57 KiB |
|
@ -0,0 +1,16 @@
|
||||||
|

|
||||||
|
|
||||||
|
# Example Basic Application
|
||||||
|
|
||||||
|
Thanks for trying out this demo! In this example, we deployed a simple application with a S3 bucket using Crossplane.
|
||||||
|
|
||||||
|
|
||||||
|
### idpbuilder
|
||||||
|
|
||||||
|
Checkout the idpbuilder website: https://cnoe.io/docs/reference-implementation/installations/idpbuilder
|
||||||
|
|
||||||
|
Checkout the idpbuilder repository: https://github.com/cnoe-io/idpbuilder
|
||||||
|
|
||||||
|
## Crossplane
|
||||||
|
|
||||||
|
Checkout the Crossplane website: https://www.crossplane.io/
|
|
@ -0,0 +1,3 @@
|
||||||
|
module ${{ values.name }}
|
||||||
|
|
||||||
|
go 1.19
|
|
@ -0,0 +1,3 @@
|
||||||
|
resources:
|
||||||
|
- nginx.yaml
|
||||||
|
- ${{ values.name }}.yaml
|
|
@ -0,0 +1,34 @@
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: nginx
|
||||||
|
labels:
|
||||||
|
app: nginx
|
||||||
|
spec:
|
||||||
|
replicas: 3
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: nginx
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: nginx
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: nginx
|
||||||
|
image: nginx:1.14.2
|
||||||
|
ports:
|
||||||
|
- containerPort: 80
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: nginx
|
||||||
|
labels:
|
||||||
|
app: nginx
|
||||||
|
spec:
|
||||||
|
ports:
|
||||||
|
- port: 80
|
||||||
|
targetPort: 80
|
||||||
|
selector:
|
||||||
|
app: nginx
|
|
@ -0,0 +1,2 @@
|
||||||
|
resources:
|
||||||
|
- ../base
|
|
@ -0,0 +1,35 @@
|
||||||
|
{%- if values.awsResources %}
|
||||||
|
resources:
|
||||||
|
{%- if 'Bucket' in values.awsResources %}
|
||||||
|
- ../base/
|
||||||
|
{%- endif %}
|
||||||
|
{%- if 'Table' in values.awsResources %}
|
||||||
|
- ../base/table.yaml
|
||||||
|
{%- endif %}
|
||||||
|
{%- endif %}
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
patches:
|
||||||
|
- target:
|
||||||
|
kind: Deployment
|
||||||
|
patch: |
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: not-used
|
||||||
|
labels:
|
||||||
|
backstage.io/kubernetes-id: ${{values.name}}
|
||||||
|
spec:
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
backstage.io/kubernetes-id: ${{values.name}}
|
||||||
|
- target:
|
||||||
|
kind: Service
|
||||||
|
patch: |
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: not-used
|
||||||
|
labels:
|
||||||
|
backstage.io/kubernetes-id: ${{values.name}}
|
|
@ -0,0 +1,5 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,6 @@
|
||||||
|
site_name: 'Argo Spark Example'
|
||||||
|
nav:
|
||||||
|
- Home: index.md
|
||||||
|
- idpBuilder: idpbuilder.md
|
||||||
|
plugins:
|
||||||
|
- techdocs-core
|
|
@ -0,0 +1,126 @@
|
||||||
|
apiVersion: scaffolder.backstage.io/v1beta3
|
||||||
|
kind: Template
|
||||||
|
metadata:
|
||||||
|
description: Adds a Go application with AWS resources
|
||||||
|
name: app-with-aws-resources
|
||||||
|
title: Add a Go App with AWS resources
|
||||||
|
spec:
|
||||||
|
owner: guests
|
||||||
|
type: service
|
||||||
|
parameters:
|
||||||
|
- properties:
|
||||||
|
name:
|
||||||
|
title: Application Name
|
||||||
|
type: string
|
||||||
|
description: Unique name of the component
|
||||||
|
ui:autofocus: true
|
||||||
|
labels:
|
||||||
|
title: Labels
|
||||||
|
type: object
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
description: Labels to apply to the application
|
||||||
|
ui:autofocus: true
|
||||||
|
required:
|
||||||
|
- name
|
||||||
|
title: Choose your repository location
|
||||||
|
- description: Configure your bucket
|
||||||
|
properties:
|
||||||
|
apiVersion:
|
||||||
|
default: awsblueprints.io/v1alpha1
|
||||||
|
description: APIVersion for the resource
|
||||||
|
type: string
|
||||||
|
kind:
|
||||||
|
default: ObjectStorage
|
||||||
|
description: Kind for the resource
|
||||||
|
type: string
|
||||||
|
config:
|
||||||
|
description: ObjectStorageSpec defines the desired state of ObjectStorage
|
||||||
|
properties:
|
||||||
|
resourceConfig:
|
||||||
|
description: ResourceConfig defines general properties of this AWS resource.
|
||||||
|
properties:
|
||||||
|
deletionPolicy:
|
||||||
|
description: Defaults to Delete
|
||||||
|
enum:
|
||||||
|
- Delete
|
||||||
|
- Orphan
|
||||||
|
type: string
|
||||||
|
region:
|
||||||
|
type: string
|
||||||
|
providerConfigName:
|
||||||
|
type: string
|
||||||
|
default: default
|
||||||
|
tags:
|
||||||
|
items:
|
||||||
|
properties:
|
||||||
|
key:
|
||||||
|
type: string
|
||||||
|
value:
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- key
|
||||||
|
- value
|
||||||
|
type: object
|
||||||
|
type: array
|
||||||
|
required:
|
||||||
|
- region
|
||||||
|
type: object
|
||||||
|
required:
|
||||||
|
- resourceConfig
|
||||||
|
title: Bucket configuration options
|
||||||
|
type: object
|
||||||
|
steps:
|
||||||
|
- id: template
|
||||||
|
name: Generating component
|
||||||
|
action: fetch:template
|
||||||
|
input:
|
||||||
|
url: ./skeleton
|
||||||
|
values:
|
||||||
|
name: ${{parameters.name}}
|
||||||
|
- action: roadiehq:utils:serialize:yaml
|
||||||
|
id: serialize
|
||||||
|
input:
|
||||||
|
data:
|
||||||
|
apiVersion: awsblueprints.io/v1alpha1
|
||||||
|
kind: ${{ parameters.kind }}
|
||||||
|
metadata:
|
||||||
|
name: ${{ parameters.name }}
|
||||||
|
spec: ${{ parameters.config }}
|
||||||
|
name: serialize
|
||||||
|
- action: roadiehq:utils:fs:write
|
||||||
|
id: write
|
||||||
|
input:
|
||||||
|
content: ${{ steps['serialize'].output.serialized }}
|
||||||
|
path: kustomize/base/${{ parameters.name }}.yaml
|
||||||
|
name: write-to-file
|
||||||
|
- id: publish
|
||||||
|
name: Publishing to a gitea git repository
|
||||||
|
action: publish:gitea
|
||||||
|
input:
|
||||||
|
description: This is an example app
|
||||||
|
# Hard coded value for this demo purposes only.
|
||||||
|
repoUrl: gitea.cnoe.localtest.me:443/?repo=${{parameters.name}}
|
||||||
|
defaultBranch: main
|
||||||
|
- id: create-argocd-app
|
||||||
|
name: Create ArgoCD App
|
||||||
|
action: cnoe:create-argocd-app
|
||||||
|
input:
|
||||||
|
appName: ${{parameters.name}}
|
||||||
|
appNamespace: default
|
||||||
|
argoInstance: in-cluster
|
||||||
|
projectName: default
|
||||||
|
# necessary until we generate our own cert
|
||||||
|
repoUrl: https://gitea.cnoe.localtest.me:443/giteaAdmin/${{parameters.name}}
|
||||||
|
path: "kustomize/base"
|
||||||
|
- id: register
|
||||||
|
name: Register
|
||||||
|
action: catalog:register
|
||||||
|
input:
|
||||||
|
repoContentsUrl: ${{ steps['publish'].output.repoContentsUrl }}
|
||||||
|
catalogInfoPath: 'catalog-info.yaml'
|
||||||
|
output:
|
||||||
|
links:
|
||||||
|
- title: Open in catalog
|
||||||
|
icon: catalog
|
||||||
|
entityRef: ${{ steps['register'].output.entityRef }}
|
|
@ -0,0 +1,40 @@
|
||||||
|
---
|
||||||
|
apiVersion: backstage.io/v1alpha1
|
||||||
|
kind: Component
|
||||||
|
metadata:
|
||||||
|
name: ${{values.name | dump}}
|
||||||
|
description: This is an example Backstage component representing the use of Argo Workflows and Spark Operator.
|
||||||
|
annotations:
|
||||||
|
backstage.io/techdocs-ref: dir:.
|
||||||
|
backstage.io/kubernetes-label-selector: 'entity-id=${{values.name}}'
|
||||||
|
backstage.io/kubernetes-namespace: argo
|
||||||
|
argocd/app-name: ${{values.name | dump}}
|
||||||
|
argo-workflows.cnoe.io/label-selector: env=dev,entity-id=${{values.name}}
|
||||||
|
argo-workflows.cnoe.io/cluster-name: local
|
||||||
|
apache-spark.cnoe.io/label-selector: env=dev,entity-id=${{values.name}}
|
||||||
|
apache-spark.cnoe.io/cluster-name: local
|
||||||
|
links:
|
||||||
|
- url: https://gitea.cnoe.localtest.me:443
|
||||||
|
title: Repo URL
|
||||||
|
icon: github
|
||||||
|
spec:
|
||||||
|
owner: guests
|
||||||
|
lifecycle: experimental
|
||||||
|
type: service
|
||||||
|
system: ${{values.name | dump}}
|
||||||
|
---
|
||||||
|
apiVersion: backstage.io/v1alpha1
|
||||||
|
kind: System
|
||||||
|
metadata:
|
||||||
|
name: ${{values.name | dump}}
|
||||||
|
description: An example system for demonstration purposes
|
||||||
|
annotations:
|
||||||
|
backstage.io/techdocs-ref: dir:.
|
||||||
|
links:
|
||||||
|
- url: https://github.com/cnoe-io/stacks/tree/main/ref-implementation
|
||||||
|
title: CNOE Repo
|
||||||
|
icon: github
|
||||||
|
spec:
|
||||||
|
owner: guests
|
||||||
|
lifecycle: experimental
|
||||||
|
type: service
|
|
@ -0,0 +1,160 @@
|
||||||
|
<!-- markdownlint-disable-next-line MD041 -->
|
||||||
|
[](https://github.com/argoproj/argo-workflows/actions/workflows/snyk.yml?query=branch%3Amain)
|
||||||
|
[](https://bestpractices.coreinfrastructure.org/projects/3830)
|
||||||
|
[](https://api.securityscorecards.dev/projects/github.com/argoproj/argo-workflows)
|
||||||
|
[](https://app.fossa.com/projects/git%2Bgithub.com%2Fargoproj%2Fargo-workflows?ref=badge_shield)
|
||||||
|
[](https://argoproj.github.io/community/join-slack)
|
||||||
|
[](https://twitter.com/argoproj)
|
||||||
|
[](https://www.linkedin.com/company/argoproj/)
|
||||||
|
[](https://github.com/argoproj/argo-workflows/releases/latest)
|
||||||
|
[](https://artifacthub.io/packages/helm/argo/argo-workflows)
|
||||||
|
|
||||||
|
## What is Argo Workflows?
|
||||||
|
|
||||||
|
Argo Workflows is an open source container-native workflow engine for orchestrating parallel jobs on Kubernetes.
|
||||||
|
Argo Workflows is implemented as a Kubernetes CRD (Custom Resource Definition).
|
||||||
|
|
||||||
|
* Define workflows where each step is a container.
|
||||||
|
* Model multi-step workflows as a sequence of tasks or capture the dependencies between tasks using a directed acyclic graph (DAG).
|
||||||
|
* Easily run compute intensive jobs for machine learning or data processing in a fraction of the time using Argo Workflows on Kubernetes.
|
||||||
|
|
||||||
|
Argo is a [Cloud Native Computing Foundation (CNCF)](https://cncf.io/) graduated project.
|
||||||
|
|
||||||
|
## Use Cases
|
||||||
|
|
||||||
|
* [Machine Learning pipelines](use-cases/machine-learning.md)
|
||||||
|
* [Data and batch processing](use-cases/data-processing.md)
|
||||||
|
* [Infrastructure automation](use-cases/infrastructure-automation.md)
|
||||||
|
* [CI/CD](use-cases/ci-cd.md)
|
||||||
|
* [Other use cases](use-cases/other.md)
|
||||||
|
|
||||||
|
## Why Argo Workflows?
|
||||||
|
|
||||||
|
* Argo Workflows is the most popular workflow execution engine for Kubernetes.
|
||||||
|
* Light-weight, scalable, and easier to use.
|
||||||
|
* Designed from the ground up for containers without the overhead and limitations of legacy VM and server-based environments.
|
||||||
|
* Cloud agnostic and can run on any Kubernetes cluster.
|
||||||
|
|
||||||
|
[Read what people said in our latest survey](https://blog.argoproj.io/argo-workflows-events-2023-user-survey-results-82c53bc30543)
|
||||||
|
|
||||||
|
## Try Argo Workflows
|
||||||
|
|
||||||
|
You can try Argo Workflows via one of the following:
|
||||||
|
|
||||||
|
1. [Interactive Training Material](https://killercoda.com/argoproj/course/argo-workflows/)
|
||||||
|
1. [Access the demo environment](https://workflows.apps.argoproj.io/workflows/argo)
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
## Who uses Argo Workflows?
|
||||||
|
|
||||||
|
[About 200+ organizations are officially using Argo Workflows](https://github.com/argoproj/argo-workflows/blob/main/USERS.md)
|
||||||
|
|
||||||
|
## Ecosystem
|
||||||
|
|
||||||
|
Just some of the projects that use or rely on Argo Workflows (complete list [here](https://github.com/akuity/awesome-argo#ecosystem-projects)):
|
||||||
|
|
||||||
|
* [Argo Events](https://github.com/argoproj/argo-events)
|
||||||
|
* [Couler](https://github.com/couler-proj/couler)
|
||||||
|
* [Hera](https://github.com/argoproj-labs/hera-workflows)
|
||||||
|
* [Katib](https://github.com/kubeflow/katib)
|
||||||
|
* [Kedro](https://kedro.readthedocs.io/en/stable/)
|
||||||
|
* [Kubeflow Pipelines](https://github.com/kubeflow/pipelines)
|
||||||
|
* [Netflix Metaflow](https://metaflow.org)
|
||||||
|
* [Onepanel](https://github.com/onepanelio/onepanel)
|
||||||
|
* [Orchest](https://github.com/orchest/orchest/)
|
||||||
|
* [Piper](https://github.com/quickube/piper)
|
||||||
|
* [Ploomber](https://github.com/ploomber/ploomber)
|
||||||
|
* [Seldon](https://github.com/SeldonIO/seldon-core)
|
||||||
|
* [SQLFlow](https://github.com/sql-machine-learning/sqlflow)
|
||||||
|
|
||||||
|
## Client Libraries
|
||||||
|
|
||||||
|
Check out our [Java, Golang and Python clients](client-libraries.md).
|
||||||
|
|
||||||
|
## Quickstart
|
||||||
|
|
||||||
|
* [Get started here](quick-start.md)
|
||||||
|
* [Walk-through examples](walk-through/index.md)
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
You're here!
|
||||||
|
|
||||||
|
## Features
|
||||||
|
|
||||||
|
An incomplete list of features Argo Workflows provide:
|
||||||
|
|
||||||
|
* UI to visualize and manage Workflows
|
||||||
|
* Artifact support (S3, Artifactory, Alibaba Cloud OSS, Azure Blob Storage, HTTP, Git, GCS, raw)
|
||||||
|
* Workflow templating to store commonly used Workflows in the cluster
|
||||||
|
* Archiving Workflows after executing for later access
|
||||||
|
* Scheduled workflows using cron
|
||||||
|
* Server interface with REST API (HTTP and GRPC)
|
||||||
|
* DAG or Steps based declaration of workflows
|
||||||
|
* Step level input & outputs (artifacts/parameters)
|
||||||
|
* Loops
|
||||||
|
* Parameterization
|
||||||
|
* Conditionals
|
||||||
|
* Timeouts (step & workflow level)
|
||||||
|
* Retry (step & workflow level)
|
||||||
|
* Resubmit (memoized)
|
||||||
|
* Suspend & Resume
|
||||||
|
* Cancellation
|
||||||
|
* K8s resource orchestration
|
||||||
|
* Exit Hooks (notifications, cleanup)
|
||||||
|
* Garbage collection of completed workflow
|
||||||
|
* Scheduling (affinity/tolerations/node selectors)
|
||||||
|
* Volumes (ephemeral/existing)
|
||||||
|
* Parallelism limits
|
||||||
|
* Daemoned steps
|
||||||
|
* DinD (docker-in-docker)
|
||||||
|
* Script steps
|
||||||
|
* Event emission
|
||||||
|
* Prometheus metrics
|
||||||
|
* Multiple executors
|
||||||
|
* Multiple pod and workflow garbage collection strategies
|
||||||
|
* Automatically calculated resource usage per step
|
||||||
|
* Java/Golang/Python SDKs
|
||||||
|
* Pod Disruption Budget support
|
||||||
|
* Single-sign on (OAuth2/OIDC)
|
||||||
|
* Webhook triggering
|
||||||
|
* CLI
|
||||||
|
* Out-of-the box and custom Prometheus metrics
|
||||||
|
* Windows container support
|
||||||
|
* Embedded widgets
|
||||||
|
* Multiplex log viewer
|
||||||
|
|
||||||
|
## Community Meetings
|
||||||
|
|
||||||
|
We host monthly community meetings where we and the community showcase demos and discuss the current and future state of the project. Feel free to join us!
|
||||||
|
For Community Meeting information, minutes and recordings, please [see here](https://bit.ly/argo-wf-cmty-mtng).
|
||||||
|
|
||||||
|
Participation in Argo Workflows is governed by the [CNCF Code of Conduct](https://github.com/cncf/foundation/blob/master/code-of-conduct.md)
|
||||||
|
|
||||||
|
## Community Blogs and Presentations
|
||||||
|
|
||||||
|
* [Awesome-Argo: A Curated List of Awesome Projects and Resources Related to Argo](https://github.com/terrytangyuan/awesome-argo)
|
||||||
|
* [Automation of Everything - How To Combine Argo Events, Workflows & Pipelines, CD, and Rollouts](https://youtu.be/XNXJtxkUKeY)
|
||||||
|
* [Argo Workflows and Pipelines - CI/CD, Machine Learning, and Other Kubernetes Workflows](https://youtu.be/UMaivwrAyTA)
|
||||||
|
* [Argo Ansible role: Provisioning Argo Workflows on OpenShift](https://medium.com/@marekermk/provisioning-argo-on-openshift-with-ansible-and-kustomize-340a1fda8b50)
|
||||||
|
* [Argo Workflows vs Apache Airflow](http://bit.ly/30YNIvT)
|
||||||
|
* [CI/CD with Argo on Kubernetes](https://medium.com/@bouwe.ceunen/ci-cd-with-argo-on-kubernetes-28c1a99616a9)
|
||||||
|
* [Define Your CI/CD Pipeline with Argo Workflows](https://haque-zubair.medium.com/define-your-ci-cd-pipeline-with-argo-workflows-25aefb02fa63)
|
||||||
|
* [Distributed Machine Learning Patterns from Manning Publication](https://github.com/terrytangyuan/distributed-ml-patterns)
|
||||||
|
* [Running Argo Workflows Across Multiple Kubernetes Clusters](https://admiralty.io/blog/running-argo-workflows-across-multiple-kubernetes-clusters/)
|
||||||
|
* [Open Source Model Management Roundup: Polyaxon, Argo, and Seldon](https://www.anaconda.com/blog/developer-blog/open-source-model-management-roundup-polyaxon-argo-and-seldon/)
|
||||||
|
* [Producing 200 OpenStreetMap extracts in 35 minutes using a scalable data workflow](https://www.interline.io/blog/scaling-openstreetmap-data-workflows/)
|
||||||
|
* [Argo integration review](http://dev.matt.hillsdon.net/2018/03/24/argo-integration-review.html)
|
||||||
|
* TGI Kubernetes with Joe Beda: [Argo workflow system](https://www.youtube.com/watch?v=M_rxPPLG8pU&start=859)
|
||||||
|
|
||||||
|
## Project Resources
|
||||||
|
|
||||||
|
* [Argo Project GitHub organization](https://github.com/argoproj)
|
||||||
|
* [Argo Website](https://argoproj.github.io/)
|
||||||
|
* [Argo Slack](https://argoproj.github.io/community/join-slack)
|
||||||
|
|
||||||
|
## Security
|
||||||
|
|
||||||
|
See [Security](security.md).
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 57 KiB |
|
@ -0,0 +1,9 @@
|
||||||
|

|
||||||
|
|
||||||
|
# Example Spark Application
|
||||||
|
|
||||||
|
Thanks for trying out this demo! In this example, we deployed a simple Apache Spark job through Argo Workflows.
|
||||||
|
|
||||||
|
To learn more about Spark Operators, check out [this link](https://github.com/kubeflow/spark-operator)
|
||||||
|
|
||||||
|
To learn more about Argo Workflows, see [this link](https://argoproj.github.io/workflows/)
|
|
@ -0,0 +1,86 @@
|
||||||
|
# Kubeflow Spark Operator
|
||||||
|
|
||||||
|
[](https://goreportcard.com/report/github.com/kubeflow/spark-operator)
|
||||||
|
|
||||||
|
## What is Spark Operator?
|
||||||
|
|
||||||
|
The Kubernetes Operator for Apache Spark aims to make specifying and running [Spark](https://github.com/apache/spark) applications as easy and idiomatic as running other workloads on Kubernetes. It uses
|
||||||
|
[Kubernetes custom resources](https://kubernetes.io/docs/concepts/extend-kubernetes/api-extension/custom-resources/) for specifying, running, and surfacing status of Spark applications.
|
||||||
|
|
||||||
|
## Overview
|
||||||
|
|
||||||
|
For a complete reference of the custom resource definitions, please refer to the [API Definition](docs/api-docs.md). For details on its design, please refer to the [Architecture](https://www.kubeflow.org/docs/components/spark-operator/overview/#architecture). It requires Spark 2.3 and above that supports Kubernetes as a native scheduler backend.
|
||||||
|
|
||||||
|
The Kubernetes Operator for Apache Spark currently supports the following list of features:
|
||||||
|
|
||||||
|
* Supports Spark 2.3 and up.
|
||||||
|
* Enables declarative application specification and management of applications through custom resources.
|
||||||
|
* Automatically runs `spark-submit` on behalf of users for each `SparkApplication` eligible for submission.
|
||||||
|
* Provides native [cron](https://en.wikipedia.org/wiki/Cron) support for running scheduled applications.
|
||||||
|
* Supports customization of Spark pods beyond what Spark natively is able to do through the mutating admission webhook, e.g., mounting ConfigMaps and volumes, and setting pod affinity/anti-affinity.
|
||||||
|
* Supports automatic application re-submission for updated `SparkApplication` objects with updated specification.
|
||||||
|
* Supports automatic application restart with a configurable restart policy.
|
||||||
|
* Supports automatic retries of failed submissions with optional linear back-off.
|
||||||
|
* Supports mounting local Hadoop configuration as a Kubernetes ConfigMap automatically via `sparkctl`.
|
||||||
|
* Supports automatically staging local application dependencies to Google Cloud Storage (GCS) via `sparkctl`.
|
||||||
|
* Supports collecting and exporting application-level metrics and driver/executor metrics to Prometheus.
|
||||||
|
|
||||||
|
## Project Status
|
||||||
|
|
||||||
|
**Project status:** *beta*
|
||||||
|
|
||||||
|
**Current API version:** *`v1beta2`*
|
||||||
|
|
||||||
|
**If you are currently using the `v1beta1` version of the APIs in your manifests, please update them to use the `v1beta2` version by changing `apiVersion: "sparkoperator.k8s.io/<version>"` to `apiVersion: "sparkoperator.k8s.io/v1beta2"`. You will also need to delete the `previous` version of the CustomResourceDefinitions named `sparkapplications.sparkoperator.k8s.io` and `scheduledsparkapplications.sparkoperator.k8s.io`, and replace them with the `v1beta2` version either by installing the latest version of the operator or by running `kubectl create -f config/crd/bases`.**
|
||||||
|
|
||||||
|
## Prerequisites
|
||||||
|
|
||||||
|
* Version >= 1.13 of Kubernetes to use the [`subresource` support for CustomResourceDefinitions](https://kubernetes.io/docs/tasks/access-kubernetes-api/custom-resources/custom-resource-definitions/#subresources), which became beta in 1.13 and is enabled by default in 1.13 and higher.
|
||||||
|
|
||||||
|
* Version >= 1.16 of Kubernetes to use the `MutatingWebhook` and `ValidatingWebhook` of `apiVersion: admissionregistration.k8s.io/v1`.
|
||||||
|
|
||||||
|
## Getting Started
|
||||||
|
|
||||||
|
For getting started with Spark operator, please refer to [Getting Started](https://www.kubeflow.org/docs/components/spark-operator/getting-started/).
|
||||||
|
|
||||||
|
## User Guide
|
||||||
|
|
||||||
|
For detailed user guide and API documentation, please refer to [User Guide](https://www.kubeflow.org/docs/components/spark-operator/user-guide/) and [API Specification](docs/api-docs.md).
|
||||||
|
|
||||||
|
If you are running Spark operator on Google Kubernetes Engine (GKE) and want to use Google Cloud Storage (GCS) and/or BigQuery for reading/writing data, also refer to the [GCP guide](https://www.kubeflow.org/docs/components/spark-operator/user-guide/gcp/).
|
||||||
|
|
||||||
|
## Version Matrix
|
||||||
|
|
||||||
|
The following table lists the most recent few versions of the operator.
|
||||||
|
|
||||||
|
| Operator Version | API Version | Kubernetes Version | Base Spark Version |
|
||||||
|
| ------------- | ------------- | ------------- | ------------- |
|
||||||
|
| `v1beta2-1.6.x-3.5.0` | `v1beta2` | 1.16+ | `3.5.0` |
|
||||||
|
| `v1beta2-1.5.x-3.5.0` | `v1beta2` | 1.16+ | `3.5.0` |
|
||||||
|
| `v1beta2-1.4.x-3.5.0` | `v1beta2` | 1.16+ | `3.5.0` |
|
||||||
|
| `v1beta2-1.3.x-3.1.1` | `v1beta2` | 1.16+ | `3.1.1` |
|
||||||
|
| `v1beta2-1.2.3-3.1.1` | `v1beta2` | 1.13+ | `3.1.1` |
|
||||||
|
| `v1beta2-1.2.2-3.0.0` | `v1beta2` | 1.13+ | `3.0.0` |
|
||||||
|
| `v1beta2-1.2.1-3.0.0` | `v1beta2` | 1.13+ | `3.0.0` |
|
||||||
|
| `v1beta2-1.2.0-3.0.0` | `v1beta2` | 1.13+ | `3.0.0` |
|
||||||
|
| `v1beta2-1.1.x-2.4.5` | `v1beta2` | 1.13+ | `2.4.5` |
|
||||||
|
| `v1beta2-1.0.x-2.4.4` | `v1beta2` | 1.13+ | `2.4.4` |
|
||||||
|
|
||||||
|
## Developer Guide
|
||||||
|
|
||||||
|
For developing with Spark Operator, please refer to [Developer Guide](https://www.kubeflow.org/docs/components/spark-operator/developer-guide/).
|
||||||
|
|
||||||
|
## Contributor Guide
|
||||||
|
|
||||||
|
For contributing to Spark Operator, please refer to [Contributor Guide](CONTRIBUTING.md).
|
||||||
|
|
||||||
|
## Community
|
||||||
|
|
||||||
|
* Join the [CNCF Slack Channel](https://www.kubeflow.org/docs/about/community/#kubeflow-slack-channels) and then join `#kubeflow-spark-operator` Channel.
|
||||||
|
* Check out our blog post [Announcing the Kubeflow Spark Operator: Building a Stronger Spark on Kubernetes Community](https://blog.kubeflow.org/operators/2024/04/15/kubeflow-spark-operator.html).
|
||||||
|
* Join our monthly community meeting [Kubeflow Spark Operator Meeting Notes](https://bit.ly/3VGzP4n).
|
||||||
|
|
||||||
|
## Adopters
|
||||||
|
|
||||||
|
Check out [adopters of Spark Operator](ADOPTERS.md).
|
||||||
|
|
|
@ -0,0 +1,109 @@
|
||||||
|
# apiVersion: argoproj.io/v1alpha1
|
||||||
|
# kind: Workflow
|
||||||
|
# metadata:
|
||||||
|
# name: ${{values.name}}
|
||||||
|
# namespace: argo
|
||||||
|
# labels:
|
||||||
|
# env: dev
|
||||||
|
# entity-id: ${{values.name}}
|
||||||
|
# spec:
|
||||||
|
# serviceAccountName: admin
|
||||||
|
# entrypoint: whalesay
|
||||||
|
# templates:
|
||||||
|
# - name: whalesay
|
||||||
|
# container:
|
||||||
|
# image: docker/whalesay:latest
|
||||||
|
# command: [cowsay]
|
||||||
|
# args: ["hello world"]
|
||||||
|
---
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Workflow
|
||||||
|
metadata:
|
||||||
|
name: ${{values.name}}
|
||||||
|
namespace: argo
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
entity-id: ${{values.name}}
|
||||||
|
spec:
|
||||||
|
serviceAccountName: admin
|
||||||
|
entrypoint: main
|
||||||
|
action: create
|
||||||
|
templates:
|
||||||
|
- name: main
|
||||||
|
steps:
|
||||||
|
- - name: spark-job
|
||||||
|
template: spark-job
|
||||||
|
- - name: wait
|
||||||
|
template: wait
|
||||||
|
arguments:
|
||||||
|
parameters:
|
||||||
|
- name: spark-job-name
|
||||||
|
value: '{{steps.spark-job.outputs.parameters.spark-job-name}}'
|
||||||
|
|
||||||
|
- name: wait
|
||||||
|
inputs:
|
||||||
|
parameters:
|
||||||
|
- name: spark-job-name
|
||||||
|
resource:
|
||||||
|
action: get
|
||||||
|
successCondition: status.applicationState.state == COMPLETED
|
||||||
|
failureCondition: status.applicationState.state == FAILED
|
||||||
|
manifest: |
|
||||||
|
apiVersion: "sparkoperator.k8s.io/v1beta2"
|
||||||
|
kind: SparkApplication
|
||||||
|
metadata:
|
||||||
|
name: {{inputs.parameters.spark-job-name}}
|
||||||
|
namespace: argo
|
||||||
|
|
||||||
|
- name: spark-job
|
||||||
|
outputs:
|
||||||
|
parameters:
|
||||||
|
- name: spark-job-name
|
||||||
|
valueFrom:
|
||||||
|
jsonPath: '{.metadata.name}'
|
||||||
|
resource:
|
||||||
|
action: create
|
||||||
|
setOwnerReference: true
|
||||||
|
manifest: |
|
||||||
|
apiVersion: "sparkoperator.k8s.io/v1beta2"
|
||||||
|
kind: SparkApplication
|
||||||
|
metadata:
|
||||||
|
name: spark-pi-${{values.name}}
|
||||||
|
namespace: argo
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
entity-id: ${{values.name}}
|
||||||
|
spec:
|
||||||
|
type: Scala
|
||||||
|
mode: cluster
|
||||||
|
image: "docker.io/apache/spark:v3.1.3"
|
||||||
|
imagePullPolicy: IfNotPresent
|
||||||
|
mainClass: org.apache.spark.examples.SparkPi
|
||||||
|
mainApplicationFile: "local:///opt/spark/examples/jars/spark-examples_2.12-3.1.3.jar"
|
||||||
|
sparkVersion: "3.1.1"
|
||||||
|
restartPolicy:
|
||||||
|
type: Never
|
||||||
|
volumes:
|
||||||
|
- name: "test-volume"
|
||||||
|
hostPath:
|
||||||
|
path: "/tmp"
|
||||||
|
type: Directory
|
||||||
|
driver:
|
||||||
|
cores: 1
|
||||||
|
coreLimit: "1200m"
|
||||||
|
memory: "512m"
|
||||||
|
labels:
|
||||||
|
version: 3.1.1
|
||||||
|
serviceAccount: admin
|
||||||
|
volumeMounts:
|
||||||
|
- name: "test-volume"
|
||||||
|
mountPath: "/tmp"
|
||||||
|
executor:
|
||||||
|
cores: 1
|
||||||
|
instances: 1
|
||||||
|
memory: "512m"
|
||||||
|
labels:
|
||||||
|
version: 3.1.1
|
||||||
|
volumeMounts:
|
||||||
|
- name: "test-volume"
|
||||||
|
mountPath: "/tmp"
|
|
@ -0,0 +1,8 @@
|
||||||
|
site_name: 'Argo Spark Example'
|
||||||
|
nav:
|
||||||
|
- Home: index.md
|
||||||
|
- Argo-Workflows: argo-workflows.md
|
||||||
|
- Apache Spark Operator: spark-operator.md
|
||||||
|
plugins:
|
||||||
|
- techdocs-core
|
||||||
|
|
|
@ -0,0 +1,62 @@
|
||||||
|
apiVersion: scaffolder.backstage.io/v1beta3
|
||||||
|
kind: Template
|
||||||
|
metadata:
|
||||||
|
description: Creates a Basic Kubernetes Deployment
|
||||||
|
name: argo-workflows-basic
|
||||||
|
title: Basic Argo Workflow with a Spark Job
|
||||||
|
spec:
|
||||||
|
owner: guests
|
||||||
|
type: service
|
||||||
|
parameters:
|
||||||
|
- title: Configuration Options
|
||||||
|
required:
|
||||||
|
- name
|
||||||
|
properties:
|
||||||
|
name:
|
||||||
|
type: string
|
||||||
|
description: name of this application
|
||||||
|
mainApplicationFile:
|
||||||
|
type: string
|
||||||
|
default: 'local:///opt/spark/examples/jars/spark-examples_2.12-3.1.3.jar'
|
||||||
|
description: Path to the main application file
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- id: template
|
||||||
|
name: Generating component
|
||||||
|
action: fetch:template
|
||||||
|
input:
|
||||||
|
url: ./skeleton
|
||||||
|
values:
|
||||||
|
name: ${{parameters.name}}
|
||||||
|
|
||||||
|
- id: publish
|
||||||
|
name: Publishing to a gitea git repository
|
||||||
|
action: publish:gitea
|
||||||
|
input:
|
||||||
|
description: This is an example app
|
||||||
|
# Hard coded value for this demo purposes only.
|
||||||
|
repoUrl: gitea.cnoe.localtest.me:443/?repo=${{parameters.name}}
|
||||||
|
defaultBranch: main
|
||||||
|
- id: create-argocd-app
|
||||||
|
name: Create ArgoCD App
|
||||||
|
action: cnoe:create-argocd-app
|
||||||
|
input:
|
||||||
|
appName: ${{parameters.name}}
|
||||||
|
appNamespace: ${{parameters.name}}
|
||||||
|
argoInstance: in-cluster
|
||||||
|
projectName: default
|
||||||
|
# necessary until we generate our own cert
|
||||||
|
repoUrl: https://gitea.cnoe.localtest.me:443/giteaAdmin/${{parameters.name}}
|
||||||
|
path: "manifests"
|
||||||
|
- id: register
|
||||||
|
name: Register
|
||||||
|
action: catalog:register
|
||||||
|
input:
|
||||||
|
repoContentsUrl: ${{ steps['publish'].output.repoContentsUrl }}
|
||||||
|
catalogInfoPath: 'catalog-info.yaml'
|
||||||
|
|
||||||
|
output:
|
||||||
|
links:
|
||||||
|
- title: Open in catalog
|
||||||
|
icon: catalog
|
||||||
|
entityRef: ${{ steps['register'].output.entityRef }}
|
|
@ -0,0 +1,6 @@
|
||||||
|
site_name: 'Argo Spark Example'
|
||||||
|
nav:
|
||||||
|
- Home: index.md
|
||||||
|
- idpBuilder: idpbuilder.md
|
||||||
|
plugins:
|
||||||
|
- techdocs-core
|
|
@ -0,0 +1,36 @@
|
||||||
|
---
|
||||||
|
apiVersion: backstage.io/v1alpha1
|
||||||
|
kind: Component
|
||||||
|
metadata:
|
||||||
|
name: ${{values.name | dump}}
|
||||||
|
description: This is a basic example application
|
||||||
|
annotations:
|
||||||
|
backstage.io/techdocs-ref: dir:.
|
||||||
|
backstage.io/kubernetes-label-selector: 'entity-id=${{values.name}}'
|
||||||
|
backstage.io/kubernetes-namespace: default
|
||||||
|
argocd/app-name: ${{values.name | dump}}
|
||||||
|
links:
|
||||||
|
- url: https://gitea.cnoe.localtest.me:443
|
||||||
|
title: Repo URL
|
||||||
|
icon: github
|
||||||
|
spec:
|
||||||
|
owner: guests
|
||||||
|
lifecycle: experimental
|
||||||
|
type: service
|
||||||
|
system: ${{values.name | dump}}
|
||||||
|
---
|
||||||
|
apiVersion: backstage.io/v1alpha1
|
||||||
|
kind: System
|
||||||
|
metadata:
|
||||||
|
name: ${{values.name | dump}}
|
||||||
|
description: An example system for demonstration purposes
|
||||||
|
annotations:
|
||||||
|
backstage.io/techdocs-ref: dir:.
|
||||||
|
links:
|
||||||
|
- url: https://github.com/cnoe-io/stacks/tree/main/ref-implementation
|
||||||
|
title: CNOE Repo
|
||||||
|
icon: github
|
||||||
|
spec:
|
||||||
|
owner: guests
|
||||||
|
lifecycle: experimental
|
||||||
|
type: service
|
|
@ -0,0 +1,46 @@
|
||||||
|
[![Codespell][codespell-badge]][codespell-link]
|
||||||
|
[![E2E][e2e-badge]][e2e-link]
|
||||||
|
[![Go Report Card][report-badge]][report-link]
|
||||||
|
[![Commit Activity][commit-activity-badge]][commit-activity-link]
|
||||||
|
|
||||||
|
# IDP Builder
|
||||||
|
|
||||||
|
Internal development platform binary launcher.
|
||||||
|
|
||||||
|
> **WORK IN PROGRESS**: This tool is in a pre-release stage and is under active development.
|
||||||
|
|
||||||
|
## About
|
||||||
|
|
||||||
|
Spin up a complete internal developer platform using industry standard technologies like Kubernetes, Argo, and backstage with only Docker required as a dependency.
|
||||||
|
|
||||||
|
This can be useful in several ways:
|
||||||
|
* Create a single binary which can demonstrate an IDP reference implementation.
|
||||||
|
* Use within CI to perform integration testing.
|
||||||
|
* Use as a local development environment for platform engineers.
|
||||||
|
|
||||||
|
## Getting Started
|
||||||
|
|
||||||
|
Checkout our [documentation website](https://cnoe.io/docs/reference-implementation/installations/idpbuilder) for getting started with idpbuilder.
|
||||||
|
|
||||||
|
## Community
|
||||||
|
|
||||||
|
- If you have questions or concerns about this tool, please feel free to reach out to us on the [CNCF Slack Channel](https://cloud-native.slack.com/archives/C05TN9WFN5S).
|
||||||
|
- You can also join our community meetings to meet the team and ask any questions. Checkout [this calendar](https://calendar.google.com/calendar/embed?src=064a2adfce866ccb02e61663a09f99147f22f06374e7a8994066bdc81e066986%40group.calendar.google.com&ctz=America%2FLos_Angeles) for more information.
|
||||||
|
|
||||||
|
## Contribution
|
||||||
|
|
||||||
|
Checkout the [contribution doc](./CONTRIBUTING.md) for contribution guidelines and more information on how to set up your local environment.
|
||||||
|
|
||||||
|
|
||||||
|
<!-- JUST BADGES & LINKS -->
|
||||||
|
[codespell-badge]: https://github.com/cnoe-io/idpbuilder/actions/workflows/codespell.yaml/badge.svg
|
||||||
|
[codespell-link]: https://github.com/cnoe-io/idpbuilder/actions/workflows/codespell.yaml
|
||||||
|
|
||||||
|
[e2e-badge]: https://github.com/cnoe-io/idpbuilder/actions/workflows/e2e.yaml/badge.svg
|
||||||
|
[e2e-link]: https://github.com/cnoe-io/idpbuilder/actions/workflows/e2e.yaml
|
||||||
|
|
||||||
|
[report-badge]: https://goreportcard.com/badge/github.com/cnoe-io/idpbuilder
|
||||||
|
[report-link]: https://goreportcard.com/report/github.com/cnoe-io/idpbuilder
|
||||||
|
|
||||||
|
[commit-activity-badge]: https://img.shields.io/github/commit-activity/m/cnoe-io/idpbuilder
|
||||||
|
[commit-activity-link]: https://github.com/cnoe-io/idpbuilder/pulse
|
Binary file not shown.
After Width: | Height: | Size: 57 KiB |
|
@ -0,0 +1,11 @@
|
||||||
|

|
||||||
|
|
||||||
|
# Example Basic Application
|
||||||
|
|
||||||
|
Thanks for trying out this demo! In this example, we deployed a simple application.
|
||||||
|
|
||||||
|
### idpbuilder
|
||||||
|
|
||||||
|
Checkout idpbuilder website: https://cnoe.io/docs/reference-implementation/installations/idpbuilder
|
||||||
|
|
||||||
|
Checkout idpbuilder repository: https://github.com/cnoe-io/idpbuilder
|
|
@ -0,0 +1,24 @@
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: ${{values.name | dump}}
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
entity-id: ${{values.name}}
|
||||||
|
app: nginx
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: nginx
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: nginx
|
||||||
|
entity-id: ${{values.name}}
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: nginx
|
||||||
|
image: nginx:1.14.2
|
||||||
|
ports:
|
||||||
|
- containerPort: 80
|
|
@ -0,0 +1,58 @@
|
||||||
|
apiVersion: scaffolder.backstage.io/v1beta3
|
||||||
|
kind: Template
|
||||||
|
metadata:
|
||||||
|
description: Creates a Basic Kubernetes Deployment
|
||||||
|
name: basic
|
||||||
|
title: Create a Basic Deployment
|
||||||
|
spec:
|
||||||
|
owner: guests
|
||||||
|
type: service
|
||||||
|
parameters:
|
||||||
|
- title: Configuration Options
|
||||||
|
required:
|
||||||
|
- name
|
||||||
|
properties:
|
||||||
|
name:
|
||||||
|
type: string
|
||||||
|
description: name of this application
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- id: template
|
||||||
|
name: Generating component
|
||||||
|
action: fetch:template
|
||||||
|
input:
|
||||||
|
url: ./skeleton
|
||||||
|
values:
|
||||||
|
name: ${{parameters.name}}
|
||||||
|
|
||||||
|
- id: publish
|
||||||
|
name: Publishing to a gitea git repository
|
||||||
|
action: publish:gitea
|
||||||
|
input:
|
||||||
|
description: This is an example app
|
||||||
|
# Hard coded value for this demo purposes only.
|
||||||
|
repoUrl: gitea.cnoe.localtest.me:443/?repo=${{parameters.name}}
|
||||||
|
defaultBranch: main
|
||||||
|
- id: create-argocd-app
|
||||||
|
name: Create ArgoCD App
|
||||||
|
action: cnoe:create-argocd-app
|
||||||
|
input:
|
||||||
|
appName: ${{parameters.name}}
|
||||||
|
appNamespace: ${{parameters.name}}
|
||||||
|
argoInstance: in-cluster
|
||||||
|
projectName: default
|
||||||
|
# necessary until we generate our own cert
|
||||||
|
repoUrl: https://gitea.cnoe.localtest.me:443/giteaAdmin/${{parameters.name}}
|
||||||
|
path: "manifests"
|
||||||
|
- id: register
|
||||||
|
name: Register
|
||||||
|
action: catalog:register
|
||||||
|
input:
|
||||||
|
repoContentsUrl: ${{ steps['publish'].output.repoContentsUrl }}
|
||||||
|
catalogInfoPath: 'catalog-info.yaml'
|
||||||
|
|
||||||
|
output:
|
||||||
|
links:
|
||||||
|
- title: Open in catalog
|
||||||
|
icon: catalog
|
||||||
|
entityRef: ${{ steps['register'].output.entityRef }}
|
|
@ -0,0 +1,20 @@
|
||||||
|
apiVersion: backstage.io/v1alpha1
|
||||||
|
kind: Location
|
||||||
|
metadata:
|
||||||
|
name: basic-example-templates
|
||||||
|
description: A collection of example templates
|
||||||
|
spec:
|
||||||
|
targets:
|
||||||
|
- ./basic/template.yaml
|
||||||
|
- ./argo-workflows/template.yaml
|
||||||
|
- ./app-with-bucket/template.yaml
|
||||||
|
- ./demo-go-hello-world/template.yaml
|
||||||
|
---
|
||||||
|
apiVersion: backstage.io/v1alpha1
|
||||||
|
kind: Location
|
||||||
|
metadata:
|
||||||
|
name: basic-organization
|
||||||
|
description: Basic organization data
|
||||||
|
spec:
|
||||||
|
targets:
|
||||||
|
- ./organization/guests.yaml
|
|
@ -0,0 +1,35 @@
|
||||||
|
---
|
||||||
|
apiVersion: backstage.io/v1alpha1
|
||||||
|
kind: Component
|
||||||
|
metadata:
|
||||||
|
name: ${{ values.name }}
|
||||||
|
description: This is a Backstage component created from the custom template that creates Hello-World example
|
||||||
|
annotations:
|
||||||
|
backstage.io/techdocs-ref: dir:.
|
||||||
|
backstage.io/kubernetes-label-selector: 'entity-id=${{ values.name }}'
|
||||||
|
backstage.io/kubernetes-namespace: gitea
|
||||||
|
links:
|
||||||
|
- url: https://gitea.cnoe.localtest.me:443
|
||||||
|
title: Repo URL
|
||||||
|
icon: git
|
||||||
|
spec:
|
||||||
|
owner: guests
|
||||||
|
lifecycle: experimental
|
||||||
|
type: service
|
||||||
|
system: ${{ values.name | dump }}
|
||||||
|
---
|
||||||
|
apiVersion: backstage.io/v1alpha1
|
||||||
|
kind: System
|
||||||
|
metadata:
|
||||||
|
name: ${{ values.name | dump }}
|
||||||
|
description: A system for managing services created from the Gitea template.
|
||||||
|
annotations:
|
||||||
|
backstage.io/techdocs-ref: dir:.
|
||||||
|
links:
|
||||||
|
- url: https://gitea.cnoe.localtest.me:443
|
||||||
|
title: Gitea Repo
|
||||||
|
icon: git
|
||||||
|
spec:
|
||||||
|
owner: guests
|
||||||
|
lifecycle: experimental
|
||||||
|
type: service
|
|
@ -0,0 +1,20 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"net/http"
|
||||||
|
)
|
||||||
|
|
||||||
|
func helloHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
|
fmt.Fprintln(w, "Hello World")
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
http.HandleFunc("/", helloHandler)
|
||||||
|
|
||||||
|
fmt.Println("Server is running on port 8081...")
|
||||||
|
err := http.ListenAndServe(":8081", nil)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println("Error starting the server:", err)
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,54 @@
|
||||||
|
apiVersion: scaffolder.backstage.io/v1beta3
|
||||||
|
kind: Template
|
||||||
|
metadata:
|
||||||
|
name: example-go-template
|
||||||
|
title: Example Go template
|
||||||
|
description: An example template for the scaffolder that creates a simple go service
|
||||||
|
spec:
|
||||||
|
owner: user:guest
|
||||||
|
type: service
|
||||||
|
|
||||||
|
parameters:
|
||||||
|
- title: Fill in some steps
|
||||||
|
required:
|
||||||
|
- name
|
||||||
|
properties:
|
||||||
|
name:
|
||||||
|
title: Name
|
||||||
|
type: string
|
||||||
|
description: Unique name of the component
|
||||||
|
ui:autofocus: true
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- id: fetch-template
|
||||||
|
name: Fetch Template
|
||||||
|
action: fetch:template
|
||||||
|
input:
|
||||||
|
url: ./skeleton
|
||||||
|
targetPath: ./skeleton
|
||||||
|
values:
|
||||||
|
name: ${{ parameters.name }}
|
||||||
|
|
||||||
|
- id: publish
|
||||||
|
name: Publish to Gitea
|
||||||
|
action: publish:gitea
|
||||||
|
input:
|
||||||
|
repoUrl: gitea.cnoe.localtest.me:443/?repo=${{parameters.name}}
|
||||||
|
description: This is the repository for ${{ parameters.name }}
|
||||||
|
sourcePath: ./skeleton
|
||||||
|
defaultBranch: main
|
||||||
|
|
||||||
|
- id: register
|
||||||
|
name: Register in Catalog
|
||||||
|
action: catalog:register
|
||||||
|
input:
|
||||||
|
repoContentsUrl: ${{ steps['publish'].output.repoContentsUrl }}
|
||||||
|
catalogInfoPath: 'catalog-info.yaml'
|
||||||
|
|
||||||
|
output:
|
||||||
|
links:
|
||||||
|
- title: Repository
|
||||||
|
url: ${{ steps['publish'].output.remoteUrl }}
|
||||||
|
- title: Open in Catalog
|
||||||
|
icon: catalog
|
||||||
|
entityRef: ${{ steps['register'].output.entityRef }}
|
|
@ -0,0 +1,15 @@
|
||||||
|
---
|
||||||
|
apiVersion: backstage.io/v1alpha1
|
||||||
|
kind: User
|
||||||
|
metadata:
|
||||||
|
name: guest
|
||||||
|
spec:
|
||||||
|
memberOf: [guests]
|
||||||
|
---
|
||||||
|
apiVersion: backstage.io/v1alpha1
|
||||||
|
kind: Group
|
||||||
|
metadata:
|
||||||
|
name: guests
|
||||||
|
spec:
|
||||||
|
type: team
|
||||||
|
children: []
|
23
kind/stacks/ref-implementation/backstage.yaml
Normal file
23
kind/stacks/ref-implementation/backstage.yaml
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: backstage
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
spec:
|
||||||
|
project: default
|
||||||
|
source:
|
||||||
|
repoURL: https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot
|
||||||
|
targetRevision: HEAD
|
||||||
|
path: "stacks/ref-implementation/backstage/manifests"
|
||||||
|
destination:
|
||||||
|
server: "https://kubernetes.default.svc"
|
||||||
|
namespace: backstage
|
||||||
|
syncPolicy:
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
||||||
|
automated:
|
||||||
|
selfHeal: true
|
||||||
|
retry:
|
||||||
|
limit: -1
|
|
@ -0,0 +1,77 @@
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: ServiceAccount
|
||||||
|
metadata:
|
||||||
|
name: eso-store
|
||||||
|
namespace: argocd
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: Role
|
||||||
|
metadata:
|
||||||
|
name: eso-store
|
||||||
|
namespace: argocd
|
||||||
|
rules:
|
||||||
|
- apiGroups: [""]
|
||||||
|
resources:
|
||||||
|
- secrets
|
||||||
|
verbs:
|
||||||
|
- get
|
||||||
|
- list
|
||||||
|
- watch
|
||||||
|
- apiGroups:
|
||||||
|
- authorization.k8s.io
|
||||||
|
resources:
|
||||||
|
- selfsubjectrulesreviews
|
||||||
|
verbs:
|
||||||
|
- create
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: RoleBinding
|
||||||
|
metadata:
|
||||||
|
name: eso-store
|
||||||
|
namespace: argocd
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: eso-store
|
||||||
|
namespace: argocd
|
||||||
|
roleRef:
|
||||||
|
kind: Role
|
||||||
|
name: eso-store
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
---
|
||||||
|
apiVersion: external-secrets.io/v1beta1
|
||||||
|
kind: ClusterSecretStore
|
||||||
|
metadata:
|
||||||
|
name: argocd
|
||||||
|
spec:
|
||||||
|
provider:
|
||||||
|
kubernetes:
|
||||||
|
remoteNamespace: argocd
|
||||||
|
server:
|
||||||
|
caProvider:
|
||||||
|
type: ConfigMap
|
||||||
|
name: kube-root-ca.crt
|
||||||
|
namespace: argocd
|
||||||
|
key: ca.crt
|
||||||
|
auth:
|
||||||
|
serviceAccount:
|
||||||
|
name: eso-store
|
||||||
|
namespace: argocd
|
||||||
|
---
|
||||||
|
apiVersion: external-secrets.io/v1beta1
|
||||||
|
kind: ExternalSecret
|
||||||
|
metadata:
|
||||||
|
name: argocd-credentials
|
||||||
|
namespace: backstage
|
||||||
|
spec:
|
||||||
|
secretStoreRef:
|
||||||
|
name: argocd
|
||||||
|
kind: ClusterSecretStore
|
||||||
|
refreshInterval: "0"
|
||||||
|
target:
|
||||||
|
name: argocd-credentials
|
||||||
|
data:
|
||||||
|
- secretKey: ARGOCD_ADMIN_PASSWORD
|
||||||
|
remoteRef:
|
||||||
|
key: argocd-initial-admin-secret
|
||||||
|
property: password
|
455
kind/stacks/ref-implementation/backstage/manifests/install.yaml
Normal file
455
kind/stacks/ref-implementation/backstage/manifests/install.yaml
Normal file
|
@ -0,0 +1,455 @@
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Namespace
|
||||||
|
metadata:
|
||||||
|
name: backstage
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: ServiceAccount
|
||||||
|
metadata:
|
||||||
|
name: backstage
|
||||||
|
namespace: backstage
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: ClusterRole
|
||||||
|
metadata:
|
||||||
|
name: backstage-argo-worfklows
|
||||||
|
rules:
|
||||||
|
- apiGroups:
|
||||||
|
- argoproj.io
|
||||||
|
resources:
|
||||||
|
- workflows
|
||||||
|
verbs:
|
||||||
|
- create
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: ClusterRole
|
||||||
|
metadata:
|
||||||
|
name: read-all
|
||||||
|
rules:
|
||||||
|
- apiGroups:
|
||||||
|
- '*'
|
||||||
|
resources:
|
||||||
|
- '*'
|
||||||
|
verbs:
|
||||||
|
- get
|
||||||
|
- list
|
||||||
|
- watch
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: ClusterRoleBinding
|
||||||
|
metadata:
|
||||||
|
name: backstage-argo-worfklows
|
||||||
|
roleRef:
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
kind: ClusterRole
|
||||||
|
name: backstage-argo-worfklows
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: backstage
|
||||||
|
namespace: backstage
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: ClusterRoleBinding
|
||||||
|
metadata:
|
||||||
|
name: backstage-read-all
|
||||||
|
roleRef:
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
kind: ClusterRole
|
||||||
|
name: read-all
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: backstage
|
||||||
|
namespace: backstage
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: ConfigMap
|
||||||
|
metadata:
|
||||||
|
name: backstage-config
|
||||||
|
namespace: backstage
|
||||||
|
data:
|
||||||
|
app-config.yaml: |
|
||||||
|
app:
|
||||||
|
title: CNOE Backstage
|
||||||
|
baseUrl: https://cnoe.localtest.me:443
|
||||||
|
organization:
|
||||||
|
name: CNOE
|
||||||
|
backend:
|
||||||
|
# Used for enabling authentication, secret is shared by all backend plugins
|
||||||
|
# See https://backstage.io/docs/tutorials/backend-to-backend-auth for
|
||||||
|
# information on the format
|
||||||
|
# auth:
|
||||||
|
# keys:
|
||||||
|
# - secret: ${BACKEND_SECRET}
|
||||||
|
baseUrl: https://cnoe.localtest.me:443
|
||||||
|
listen:
|
||||||
|
port: 7007
|
||||||
|
# Uncomment the following host directive to bind to specific interfaces
|
||||||
|
# host: 127.0.0.1
|
||||||
|
csp:
|
||||||
|
connect-src: ["'self'", 'http:', 'https:']
|
||||||
|
# Content-Security-Policy directives follow the Helmet format: https://helmetjs.github.io/#reference
|
||||||
|
# Default Helmet Content-Security-Policy values can be removed by setting the key to false
|
||||||
|
cors:
|
||||||
|
origin: https://cnoe.localtest.me:443
|
||||||
|
methods: [GET, HEAD, PATCH, POST, PUT, DELETE]
|
||||||
|
credentials: true
|
||||||
|
database:
|
||||||
|
client: pg
|
||||||
|
connection:
|
||||||
|
host: ${POSTGRES_HOST}
|
||||||
|
port: ${POSTGRES_PORT}
|
||||||
|
user: ${POSTGRES_USER}
|
||||||
|
password: ${POSTGRES_PASSWORD}
|
||||||
|
cache:
|
||||||
|
store: memory
|
||||||
|
# workingDirectory: /tmp # Use this to configure a working directory for the scaffolder, defaults to the OS temp-dir
|
||||||
|
|
||||||
|
integrations:
|
||||||
|
gitea:
|
||||||
|
- baseUrl: https://gitea.cnoe.localtest.me:443
|
||||||
|
host: gitea.cnoe.localtest.me:443
|
||||||
|
username: ${GITEA_USERNAME}
|
||||||
|
password: ${GITEA_PASSWORD}
|
||||||
|
- baseUrl: https://gitea.cnoe.localtest.me
|
||||||
|
host: gitea.cnoe.localtest.me
|
||||||
|
username: ${GITEA_USERNAME}
|
||||||
|
password: ${GITEA_PASSWORD}
|
||||||
|
# github:
|
||||||
|
# - host: github.com
|
||||||
|
# apps:
|
||||||
|
# - $include: github-integration.yaml
|
||||||
|
# - host: github.com
|
||||||
|
# # This is a Personal Access Token or PAT from GitHub. You can find out how to generate this token, and more information
|
||||||
|
# # about setting up the GitHub integration here: https://backstage.io/docs/getting-started/configuration#setting-up-a-github-integration
|
||||||
|
# token: ${GITHUB_TOKEN}
|
||||||
|
### Example for how to add your GitHub Enterprise instance using the API:
|
||||||
|
# - host: ghe.example.net
|
||||||
|
# apiBaseUrl: https://ghe.example.net/api/v3
|
||||||
|
# token: ${GHE_TOKEN}
|
||||||
|
|
||||||
|
# Reference documentation http://backstage.io/docs/features/techdocs/configuration
|
||||||
|
# Note: After experimenting with basic setup, use CI/CD to generate docs
|
||||||
|
# and an external cloud storage when deploying TechDocs for production use-case.
|
||||||
|
# https://backstage.io/docs/features/techdocs/how-to-guides#how-to-migrate-from-techdocs-basic-to-recommended-deployment-approach
|
||||||
|
techdocs:
|
||||||
|
builder: 'local' # Alternatives - 'external'
|
||||||
|
generator:
|
||||||
|
runIn: 'local'
|
||||||
|
publisher:
|
||||||
|
type: 'local' # Alternatives - 'googleGcs' or 'awsS3'. Read documentation for using alternatives.
|
||||||
|
|
||||||
|
auth:
|
||||||
|
environment: development
|
||||||
|
session:
|
||||||
|
secret: MW2sV-sIPngEl26vAzatV-6VqfsgAx4bPIz7PuE_2Lk=
|
||||||
|
providers:
|
||||||
|
keycloak-oidc:
|
||||||
|
development:
|
||||||
|
metadataUrl: ${KEYCLOAK_NAME_METADATA}
|
||||||
|
clientId: backstage
|
||||||
|
clientSecret: ${KEYCLOAK_CLIENT_SECRET}
|
||||||
|
prompt: auto
|
||||||
|
|
||||||
|
scaffolder:
|
||||||
|
# see https://backstage.io/docs/features/software-templates/configuration for software template options
|
||||||
|
defaultAuthor:
|
||||||
|
name: backstage-scaffolder
|
||||||
|
email: noreply
|
||||||
|
defaultCommitMessage: "backstage scaffolder"
|
||||||
|
catalog:
|
||||||
|
import:
|
||||||
|
entityFilename: catalog-info.yaml
|
||||||
|
pullRequestBranchName: backstage-integration
|
||||||
|
rules:
|
||||||
|
- allow: [Component, System, API, Resource, Location, Template]
|
||||||
|
locations:
|
||||||
|
# Examples from a public GitHub repository.
|
||||||
|
- type: url
|
||||||
|
target: https://gitea.cnoe.localtest.me:443/giteaAdmin/edfbuilder-shoot/raw/branch/main/stacks/ref-implementation/backstage-templates/entities/catalog-info.yaml
|
||||||
|
rules:
|
||||||
|
- allow: [Component, System, API, Resource, Location, Template, User, Group]
|
||||||
|
kubernetes:
|
||||||
|
serviceLocatorMethod:
|
||||||
|
type: 'multiTenant'
|
||||||
|
clusterLocatorMethods:
|
||||||
|
- $include: k8s-config.yaml
|
||||||
|
argocd:
|
||||||
|
username: admin
|
||||||
|
password: ${ARGOCD_ADMIN_PASSWORD}
|
||||||
|
appLocatorMethods:
|
||||||
|
- type: 'config'
|
||||||
|
instances:
|
||||||
|
- name: in-cluster
|
||||||
|
url: https://cnoe.localtest.me:443/argocd
|
||||||
|
username: admin
|
||||||
|
password: ${ARGOCD_ADMIN_PASSWORD}
|
||||||
|
argoWorkflows:
|
||||||
|
baseUrl: ${ARGO_WORKFLOWS_URL}
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: k8s-config
|
||||||
|
namespace: backstage
|
||||||
|
stringData:
|
||||||
|
k8s-config.yaml: "type: 'config'\nclusters:\n - url: https://kubernetes.default.svc.cluster.local\n
|
||||||
|
\ name: local\n authProvider: 'serviceAccount'\n skipTLSVerify: true\n
|
||||||
|
\ skipMetricsLookup: true\n serviceAccountToken: \n $file: /var/run/secrets/kubernetes.io/serviceaccount/token\n
|
||||||
|
\ caData: \n $file: /var/run/secrets/kubernetes.io/serviceaccount/ca.crt\n"
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: backstage
|
||||||
|
namespace: backstage
|
||||||
|
spec:
|
||||||
|
ports:
|
||||||
|
- name: http
|
||||||
|
port: 7007
|
||||||
|
targetPort: http
|
||||||
|
selector:
|
||||||
|
app: backstage
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: postgresql
|
||||||
|
name: postgresql
|
||||||
|
namespace: backstage
|
||||||
|
spec:
|
||||||
|
clusterIP: None
|
||||||
|
ports:
|
||||||
|
- name: postgres
|
||||||
|
port: 5432
|
||||||
|
selector:
|
||||||
|
app: postgresql
|
||||||
|
---
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: backstage
|
||||||
|
namespace: backstage
|
||||||
|
annotations:
|
||||||
|
argocd.argoproj.io/sync-wave: "20"
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: backstage
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: backstage
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- command:
|
||||||
|
- node
|
||||||
|
- packages/backend
|
||||||
|
- --config
|
||||||
|
- config/app-config.yaml
|
||||||
|
env:
|
||||||
|
- name: LOG_LEVEL
|
||||||
|
value: debug
|
||||||
|
- name: NODE_TLS_REJECT_UNAUTHORIZED
|
||||||
|
value: "0"
|
||||||
|
envFrom:
|
||||||
|
- secretRef:
|
||||||
|
name: backstage-env-vars
|
||||||
|
- secretRef:
|
||||||
|
name: gitea-credentials
|
||||||
|
- secretRef:
|
||||||
|
name: argocd-credentials
|
||||||
|
image: ghcr.io/cnoe-io/backstage-app:9232d633b2698fffa6d0a73b715e06640d170162
|
||||||
|
name: backstage
|
||||||
|
ports:
|
||||||
|
- containerPort: 7007
|
||||||
|
name: http
|
||||||
|
volumeMounts:
|
||||||
|
- mountPath: /app/config
|
||||||
|
name: backstage-config
|
||||||
|
readOnly: true
|
||||||
|
serviceAccountName: backstage
|
||||||
|
volumes:
|
||||||
|
- name: backstage-config
|
||||||
|
projected:
|
||||||
|
sources:
|
||||||
|
- configMap:
|
||||||
|
items:
|
||||||
|
- key: app-config.yaml
|
||||||
|
path: app-config.yaml
|
||||||
|
name: backstage-config
|
||||||
|
- secret:
|
||||||
|
items:
|
||||||
|
- key: k8s-config.yaml
|
||||||
|
path: k8s-config.yaml
|
||||||
|
name: k8s-config
|
||||||
|
---
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: StatefulSet
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: postgresql
|
||||||
|
name: postgresql
|
||||||
|
namespace: backstage
|
||||||
|
annotations:
|
||||||
|
argocd.argoproj.io/sync-wave: "10"
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: postgresql
|
||||||
|
serviceName: service-postgresql
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: postgresql
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- env:
|
||||||
|
- name: POSTGRES_DB
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: backstage-env-vars
|
||||||
|
key: POSTGRES_DB
|
||||||
|
- name: POSTGRES_USER
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: backstage-env-vars
|
||||||
|
key: POSTGRES_USER
|
||||||
|
- name: POSTGRES_PASSWORD
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: backstage-env-vars
|
||||||
|
key: POSTGRES_PASSWORD
|
||||||
|
image: docker.io/library/postgres:15.3-alpine3.18
|
||||||
|
name: postgres
|
||||||
|
ports:
|
||||||
|
- containerPort: 5432
|
||||||
|
name: postgresdb
|
||||||
|
resources:
|
||||||
|
limits:
|
||||||
|
memory: 500Mi
|
||||||
|
requests:
|
||||||
|
cpu: 100m
|
||||||
|
memory: 300Mi
|
||||||
|
volumeMounts:
|
||||||
|
- name: data
|
||||||
|
mountPath: /var/lib/postgresql/data
|
||||||
|
volumeClaimTemplates:
|
||||||
|
- metadata:
|
||||||
|
name: data
|
||||||
|
spec:
|
||||||
|
accessModes: ["ReadWriteOnce"]
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
storage: "500Mi"
|
||||||
|
---
|
||||||
|
apiVersion: generators.external-secrets.io/v1alpha1
|
||||||
|
kind: Password
|
||||||
|
metadata:
|
||||||
|
name: backstage
|
||||||
|
namespace: backstage
|
||||||
|
spec:
|
||||||
|
length: 36
|
||||||
|
digits: 5
|
||||||
|
symbols: 5
|
||||||
|
symbolCharacters: "/-+"
|
||||||
|
noUpper: false
|
||||||
|
allowRepeat: true
|
||||||
|
---
|
||||||
|
apiVersion: external-secrets.io/v1beta1
|
||||||
|
kind: ExternalSecret
|
||||||
|
metadata:
|
||||||
|
name: backstage-oidc
|
||||||
|
namespace: backstage
|
||||||
|
spec:
|
||||||
|
secretStoreRef:
|
||||||
|
name: keycloak
|
||||||
|
kind: ClusterSecretStore
|
||||||
|
refreshInterval: "0"
|
||||||
|
target:
|
||||||
|
name: backstage-env-vars
|
||||||
|
template:
|
||||||
|
engineVersion: v2
|
||||||
|
data:
|
||||||
|
BACKSTAGE_FRONTEND_URL: https://cnoe.localtest.me:443/backstage
|
||||||
|
POSTGRES_HOST: postgresql.backstage.svc.cluster.local
|
||||||
|
POSTGRES_PORT: '5432'
|
||||||
|
POSTGRES_DB: backstage
|
||||||
|
POSTGRES_USER: backstage
|
||||||
|
POSTGRES_PASSWORD: "{{.POSTGRES_PASSWORD}}"
|
||||||
|
ARGO_WORKFLOWS_URL: https://cnoe.localtest.me:443/argo-workflows
|
||||||
|
KEYCLOAK_NAME_METADATA: https://cnoe.localtest.me:443/keycloak/realms/cnoe/.well-known/openid-configuration
|
||||||
|
KEYCLOAK_CLIENT_SECRET: "{{.BACKSTAGE_CLIENT_SECRET}}"
|
||||||
|
ARGOCD_AUTH_TOKEN: "argocd.token={{.ARGOCD_SESSION_TOKEN}}"
|
||||||
|
ARGO_CD_URL: 'https://argocd-server.argocd.svc.cluster.local/api/v1/'
|
||||||
|
data:
|
||||||
|
- secretKey: ARGOCD_SESSION_TOKEN
|
||||||
|
remoteRef:
|
||||||
|
key: keycloak-clients
|
||||||
|
property: ARGOCD_SESSION_TOKEN
|
||||||
|
- secretKey: BACKSTAGE_CLIENT_SECRET
|
||||||
|
remoteRef:
|
||||||
|
key: keycloak-clients
|
||||||
|
property: BACKSTAGE_CLIENT_SECRET
|
||||||
|
dataFrom:
|
||||||
|
- sourceRef:
|
||||||
|
generatorRef:
|
||||||
|
apiVersion: generators.external-secrets.io/v1alpha1
|
||||||
|
kind: Password
|
||||||
|
name: backstage
|
||||||
|
rewrite:
|
||||||
|
- transform:
|
||||||
|
template: "POSTGRES_PASSWORD"
|
||||||
|
---
|
||||||
|
apiVersion: external-secrets.io/v1beta1
|
||||||
|
kind: ExternalSecret
|
||||||
|
metadata:
|
||||||
|
name: gitea-credentials
|
||||||
|
namespace: backstage
|
||||||
|
spec:
|
||||||
|
secretStoreRef:
|
||||||
|
name: gitea
|
||||||
|
kind: ClusterSecretStore
|
||||||
|
refreshInterval: "0"
|
||||||
|
target:
|
||||||
|
name: gitea-credentials
|
||||||
|
data:
|
||||||
|
- secretKey: GITEA_USERNAME
|
||||||
|
remoteRef:
|
||||||
|
key: gitea-credential
|
||||||
|
property: username
|
||||||
|
- secretKey: GITEA_PASSWORD
|
||||||
|
remoteRef:
|
||||||
|
key: gitea-credential
|
||||||
|
property: password
|
||||||
|
---
|
||||||
|
apiVersion: networking.k8s.io/v1
|
||||||
|
kind: Ingress
|
||||||
|
metadata:
|
||||||
|
name: backstage
|
||||||
|
namespace: backstage
|
||||||
|
spec:
|
||||||
|
ingressClassName: "nginx"
|
||||||
|
rules:
|
||||||
|
- host: localhost
|
||||||
|
http:
|
||||||
|
paths:
|
||||||
|
- path: /
|
||||||
|
pathType: Prefix
|
||||||
|
backend:
|
||||||
|
service:
|
||||||
|
name: backstage
|
||||||
|
port:
|
||||||
|
name: http
|
||||||
|
- host: cnoe.localtest.me
|
||||||
|
http:
|
||||||
|
paths:
|
||||||
|
- path: /
|
||||||
|
pathType: Prefix
|
||||||
|
backend:
|
||||||
|
service:
|
||||||
|
name: backstage
|
||||||
|
port:
|
||||||
|
name: http
|
73
kind/stacks/ref-implementation/codespaces.md
Normal file
73
kind/stacks/ref-implementation/codespaces.md
Normal file
|
@ -0,0 +1,73 @@
|
||||||
|
## Running idpbuilder in Codespaces in Browser
|
||||||
|
|
||||||
|
**_NOTE:_**: __Steps described below applies to running this implementation in Codespaces in **web browsers** (e.g. Firefox and Chrome).
|
||||||
|
If you are using Codespaces with GitHub CLI, steps described here do not apply to you.__
|
||||||
|
|
||||||
|
|
||||||
|
Let's create an instance of Codespaces.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
It may take a few minutes for it to be ready. Once it's ready, you can either get the latest release of idpbuilder or build from the main branch.
|
||||||
|
Build the idpbuilder binary.
|
||||||
|
|
||||||
|
|
||||||
|
- Get the latest release:
|
||||||
|
```bash
|
||||||
|
version=$(curl -Ls -o /dev/null -w %{url_effective} https://github.com/cnoe-io/idpbuilder/releases/latest)
|
||||||
|
version=${version##*/}
|
||||||
|
wget https://github.com/cnoe-io/idpbuilder/releases/download/${version}/idpbuilder-linux-amd64.tar.gz
|
||||||
|
tar xzf idpbuilder-linux-amd64.tar.gz
|
||||||
|
sudo mv ./idpbuilder /usr/local/bin/
|
||||||
|
```
|
||||||
|
- Alternatively, build from the main branch
|
||||||
|
```bash
|
||||||
|
make build
|
||||||
|
sudo mv ./idpbuilder /usr/local/bin/
|
||||||
|
```
|
||||||
|
|
||||||
|
Codespaces assigns random hostname to your specific instance. You need to make sure they are reflected correctly.
|
||||||
|
Instance host name is available as an environment variable (`CODESPACE_NAME`). Let's use it to setup our host names.
|
||||||
|
Run the following commands to update host name and ports. Port is set to 443 because this is the port used by the browser to access your instance.
|
||||||
|
|
||||||
|
Clone the [stacks](https://github.com/cnoe-io/stacks) repo.
|
||||||
|
|
||||||
|
|
||||||
|
```bash
|
||||||
|
cd ref-implementation
|
||||||
|
|
||||||
|
./replace.sh ${CODESPACE_NAME}-8080.${GITHUB_CODESPACES_PORT_FORWARDING_DOMAIN} 443
|
||||||
|
|
||||||
|
cd -
|
||||||
|
```
|
||||||
|
|
||||||
|
Now you are ready to run idpbuilder with reference implementation.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
idpbuilder create --protocol http \
|
||||||
|
--host ${CODESPACE_NAME}-8080.${GITHUB_CODESPACES_PORT_FORWARDING_DOMAIN} \
|
||||||
|
--port 8080 --use-path-routing --package ref-implementation
|
||||||
|
```
|
||||||
|
Once idpbuilder finishes bootstrapping, you should have port 8080 forward in the port tab within Codespaces.
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
You may get a 404 page after clicking the port 8080 forwarded address. This is completely normal because Backstage may not be ready yet.
|
||||||
|
Give it a few more minutes and it should redirect you to a Backstage page.
|
||||||
|
|
||||||
|
### Accessing UIs
|
||||||
|
|
||||||
|
If you'd like to track progress of deployment, go to `/argocd` path and login with your ArgoCD credentials.
|
||||||
|
For example run this command to get the URL for Argo CD:
|
||||||
|
```bash
|
||||||
|
echo https://${CODESPACE_NAME}-8080.${GITHUB_CODESPACES_PORT_FORWARDING_DOMAIN}/argocd
|
||||||
|
```
|
||||||
|
|
||||||
|
From here on, you can follow the instructions in the [README](./README.md) file. The only difference is that the URL to access UIs is given by:
|
||||||
|
|
||||||
|
```echo
|
||||||
|
echo https://${CODESPACE_NAME}-8080.${GITHUB_CODESPACES_PORT_FORWARDING_DOMAIN}
|
||||||
|
```
|
||||||
|
|
||||||
|
For example, if you need to access Argo Workflows UI, instead of going to `https://cnoe.localtest.me:8443/argo`,
|
||||||
|
you go to `https://${CODESPACE_NAME}-8080.${GITHUB_CODESPACES_PORT_FORWARDING_DOMAIN}/argo`
|
23
kind/stacks/ref-implementation/external-secrets.yaml
Normal file
23
kind/stacks/ref-implementation/external-secrets.yaml
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: external-secrets
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
finalizers:
|
||||||
|
- resources-finalizer.argocd.argoproj.io
|
||||||
|
spec:
|
||||||
|
destination:
|
||||||
|
namespace: external-secrets
|
||||||
|
server: "https://kubernetes.default.svc"
|
||||||
|
source:
|
||||||
|
repoURL: https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot
|
||||||
|
targetRevision: HEAD
|
||||||
|
path: "stacks/ref-implementation/external-secrets/manifests"
|
||||||
|
project: default
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
selfHeal: true
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
12
kind/stacks/ref-implementation/external-secrets/generate-manifests.sh
Executable file
12
kind/stacks/ref-implementation/external-secrets/generate-manifests.sh
Executable file
|
@ -0,0 +1,12 @@
|
||||||
|
#!/bin/bash
|
||||||
|
set -e
|
||||||
|
|
||||||
|
INSTALL_YAML="manifests/install.yaml"
|
||||||
|
CHART_VERSION="0.9.11"
|
||||||
|
|
||||||
|
echo "# EXTERNAL SECRETS INSTALL RESOURCES" >${INSTALL_YAML}
|
||||||
|
echo "# This file is auto-generated with 'ref-impelmentation/external-secrets/generate-manifests.sh'" >>${INSTALL_YAML}
|
||||||
|
|
||||||
|
helm repo add external-secrets --force-update https://charts.external-secrets.io
|
||||||
|
helm repo update
|
||||||
|
helm template --namespace external-secrets external-secrets external-secrets/external-secrets -f values.yaml --version ${CHART_VERSION} >>${INSTALL_YAML}
|
File diff suppressed because it is too large
Load diff
21
kind/stacks/ref-implementation/keycloak.yaml
Normal file
21
kind/stacks/ref-implementation/keycloak.yaml
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: keycloak
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
example: ref-implementation
|
||||||
|
spec:
|
||||||
|
destination:
|
||||||
|
namespace: keycloak
|
||||||
|
server: "https://kubernetes.default.svc"
|
||||||
|
source:
|
||||||
|
repoURL: https://gitea.cnoe.localtest.me/giteaAdmin/edfbuilder-shoot
|
||||||
|
targetRevision: HEAD
|
||||||
|
path: "stacks/ref-implementation/keycloak/manifests"
|
||||||
|
project: default
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
selfHeal: true
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
|
@ -0,0 +1,30 @@
|
||||||
|
apiVersion: networking.k8s.io/v1
|
||||||
|
kind: Ingress
|
||||||
|
metadata:
|
||||||
|
name: keycloak-ingress-localhost
|
||||||
|
namespace: keycloak
|
||||||
|
annotations:
|
||||||
|
argocd.argoproj.io/sync-wave: "100"
|
||||||
|
spec:
|
||||||
|
ingressClassName: "nginx"
|
||||||
|
rules:
|
||||||
|
- host: localhost
|
||||||
|
http:
|
||||||
|
paths:
|
||||||
|
- path: /keycloak
|
||||||
|
pathType: ImplementationSpecific
|
||||||
|
backend:
|
||||||
|
service:
|
||||||
|
name: keycloak
|
||||||
|
port:
|
||||||
|
name: http
|
||||||
|
- host: cnoe.localtest.me
|
||||||
|
http:
|
||||||
|
paths:
|
||||||
|
- path: /keycloak
|
||||||
|
pathType: ImplementationSpecific
|
||||||
|
backend:
|
||||||
|
service:
|
||||||
|
name: keycloak
|
||||||
|
port:
|
||||||
|
name: http
|
162
kind/stacks/ref-implementation/keycloak/manifests/install.yaml
Normal file
162
kind/stacks/ref-implementation/keycloak/manifests/install.yaml
Normal file
|
@ -0,0 +1,162 @@
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Namespace
|
||||||
|
metadata:
|
||||||
|
name: keycloak
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: keycloak
|
||||||
|
labels:
|
||||||
|
app: keycloak
|
||||||
|
spec:
|
||||||
|
ports:
|
||||||
|
- name: http
|
||||||
|
port: 8080
|
||||||
|
targetPort: 8080
|
||||||
|
selector:
|
||||||
|
app: keycloak
|
||||||
|
type: ClusterIP
|
||||||
|
---
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: keycloak
|
||||||
|
name: keycloak
|
||||||
|
namespace: keycloak
|
||||||
|
annotations:
|
||||||
|
argocd.argoproj.io/sync-wave: "10"
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: keycloak
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: keycloak
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- args:
|
||||||
|
- start-dev
|
||||||
|
env:
|
||||||
|
- name: KEYCLOAK_ADMIN
|
||||||
|
value: cnoe-admin
|
||||||
|
- name: KEYCLOAK_LOGLEVEL
|
||||||
|
value: ALL
|
||||||
|
- name: QUARKUS_TRANSACTION_MANAGER_ENABLE_RECOVERY
|
||||||
|
value: 'true'
|
||||||
|
envFrom:
|
||||||
|
- secretRef:
|
||||||
|
name: keycloak-config
|
||||||
|
image: quay.io/keycloak/keycloak:22.0.3
|
||||||
|
name: keycloak
|
||||||
|
ports:
|
||||||
|
- containerPort: 8080
|
||||||
|
name: http
|
||||||
|
readinessProbe:
|
||||||
|
httpGet:
|
||||||
|
path: /keycloak/realms/master
|
||||||
|
port: 8080
|
||||||
|
volumeMounts:
|
||||||
|
- mountPath: /opt/keycloak/conf
|
||||||
|
name: keycloak-config
|
||||||
|
readOnly: true
|
||||||
|
volumes:
|
||||||
|
- configMap:
|
||||||
|
name: keycloak-config
|
||||||
|
name: keycloak-config
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
data:
|
||||||
|
keycloak.conf: |
|
||||||
|
# Database
|
||||||
|
# The database vendor.
|
||||||
|
db=postgres
|
||||||
|
|
||||||
|
# The username of the database user.
|
||||||
|
db-url=jdbc:postgresql://postgresql.keycloak.svc.cluster.local:5432/postgres
|
||||||
|
|
||||||
|
# The proxy address forwarding mode if the server is behind a reverse proxy.
|
||||||
|
proxy=edge
|
||||||
|
|
||||||
|
# hostname configuration
|
||||||
|
hostname=cnoe.localtest.me
|
||||||
|
http-relative-path=keycloak
|
||||||
|
|
||||||
|
# the admin url requires its own configuration to reflect correct url
|
||||||
|
|
||||||
|
hostname-debug=true
|
||||||
|
|
||||||
|
# this should only be allowed in development. NEVER in production.
|
||||||
|
hostname-strict=false
|
||||||
|
hostname-strict-backchannel=false
|
||||||
|
|
||||||
|
|
||||||
|
kind: ConfigMap
|
||||||
|
metadata:
|
||||||
|
name: keycloak-config
|
||||||
|
namespace: keycloak
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: postgresql
|
||||||
|
name: postgresql
|
||||||
|
namespace: keycloak
|
||||||
|
spec:
|
||||||
|
clusterIP: None
|
||||||
|
ports:
|
||||||
|
- name: postgres
|
||||||
|
port: 5432
|
||||||
|
selector:
|
||||||
|
app: postgresql
|
||||||
|
---
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: StatefulSet
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: postgresql
|
||||||
|
name: postgresql
|
||||||
|
namespace: keycloak
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: postgresql
|
||||||
|
serviceName: service-postgresql
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: postgresql
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- envFrom:
|
||||||
|
- secretRef:
|
||||||
|
name: keycloak-config
|
||||||
|
image: docker.io/library/postgres:15.3-alpine3.18
|
||||||
|
name: postgres
|
||||||
|
ports:
|
||||||
|
- containerPort: 5432
|
||||||
|
name: postgresdb
|
||||||
|
resources:
|
||||||
|
limits:
|
||||||
|
memory: 500Mi
|
||||||
|
requests:
|
||||||
|
cpu: 100m
|
||||||
|
memory: 300Mi
|
||||||
|
volumeMounts:
|
||||||
|
- name: data
|
||||||
|
mountPath: /var/lib/postgresql/data
|
||||||
|
volumeClaimTemplates:
|
||||||
|
- metadata:
|
||||||
|
name: data
|
||||||
|
spec:
|
||||||
|
accessModes: ["ReadWriteOnce"]
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
storage: "500Mi"
|
||||||
|
|
|
@ -0,0 +1,366 @@
|
||||||
|
# resources here are used to configure keycloak instance for SSO
|
||||||
|
apiVersion: v1
|
||||||
|
kind: ServiceAccount
|
||||||
|
metadata:
|
||||||
|
name: keycloak-config
|
||||||
|
namespace: keycloak
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: Role
|
||||||
|
metadata:
|
||||||
|
name: keycloak-config
|
||||||
|
namespace: keycloak
|
||||||
|
rules:
|
||||||
|
- apiGroups: [""]
|
||||||
|
resources: ["secrets"]
|
||||||
|
verbs: ["get", "create", "update", "patch"]
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: RoleBinding
|
||||||
|
metadata:
|
||||||
|
name: keycloak-config
|
||||||
|
namespace: keycloak
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: keycloak-config
|
||||||
|
namespace: keycloak
|
||||||
|
roleRef:
|
||||||
|
kind: Role
|
||||||
|
name: keycloak-config
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: Role
|
||||||
|
metadata:
|
||||||
|
name: keycloak-config
|
||||||
|
namespace: argocd
|
||||||
|
rules:
|
||||||
|
- apiGroups: [""]
|
||||||
|
resources: ["secrets"]
|
||||||
|
verbs: ["get"]
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: RoleBinding
|
||||||
|
metadata:
|
||||||
|
name: keycloak-config
|
||||||
|
namespace: argocd
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: keycloak-config
|
||||||
|
namespace: keycloak
|
||||||
|
roleRef:
|
||||||
|
kind: Role
|
||||||
|
name: keycloak-config
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: ConfigMap
|
||||||
|
metadata:
|
||||||
|
name: config-job
|
||||||
|
namespace: keycloak
|
||||||
|
data:
|
||||||
|
client-scope-groups-payload.json: |
|
||||||
|
{
|
||||||
|
"name": "groups",
|
||||||
|
"description": "groups a user belongs to",
|
||||||
|
"attributes": {
|
||||||
|
"consent.screen.text": "Access to groups a user belongs to.",
|
||||||
|
"display.on.consent.screen": "true",
|
||||||
|
"include.in.token.scope": "true",
|
||||||
|
"gui.order": ""
|
||||||
|
},
|
||||||
|
"type": "default",
|
||||||
|
"protocol": "openid-connect"
|
||||||
|
}
|
||||||
|
group-admin-payload.json: |
|
||||||
|
{"name":"admin"}
|
||||||
|
group-base-user-payload.json: |
|
||||||
|
{"name":"base-user"}
|
||||||
|
group-mapper-payload.json: |
|
||||||
|
{
|
||||||
|
"protocol": "openid-connect",
|
||||||
|
"protocolMapper": "oidc-group-membership-mapper",
|
||||||
|
"name": "groups",
|
||||||
|
"config": {
|
||||||
|
"claim.name": "groups",
|
||||||
|
"full.path": "false",
|
||||||
|
"id.token.claim": "true",
|
||||||
|
"access.token.claim": "true",
|
||||||
|
"userinfo.token.claim": "true"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
realm-payload.json: |
|
||||||
|
{"realm":"cnoe","enabled":true}
|
||||||
|
user-password.json: |
|
||||||
|
{
|
||||||
|
"temporary": false,
|
||||||
|
"type": "password",
|
||||||
|
"value": "${USER1_PASSWORD}"
|
||||||
|
}
|
||||||
|
user-user1.json: |
|
||||||
|
{
|
||||||
|
"username": "user1",
|
||||||
|
"email": "",
|
||||||
|
"firstName": "user",
|
||||||
|
"lastName": "one",
|
||||||
|
"requiredActions": [],
|
||||||
|
"emailVerified": false,
|
||||||
|
"groups": [
|
||||||
|
"/admin"
|
||||||
|
],
|
||||||
|
"enabled": true
|
||||||
|
}
|
||||||
|
user-user2.json: |
|
||||||
|
{
|
||||||
|
"username": "user2",
|
||||||
|
"email": "",
|
||||||
|
"firstName": "user",
|
||||||
|
"lastName": "two",
|
||||||
|
"requiredActions": [],
|
||||||
|
"emailVerified": false,
|
||||||
|
"groups": [
|
||||||
|
"/base-user"
|
||||||
|
],
|
||||||
|
"enabled": true
|
||||||
|
}
|
||||||
|
argo-client-payload.json: |
|
||||||
|
{
|
||||||
|
"protocol": "openid-connect",
|
||||||
|
"clientId": "argo-workflows",
|
||||||
|
"name": "Argo Workflows Client",
|
||||||
|
"description": "Used for Argo Workflows SSO",
|
||||||
|
"publicClient": false,
|
||||||
|
"authorizationServicesEnabled": false,
|
||||||
|
"serviceAccountsEnabled": false,
|
||||||
|
"implicitFlowEnabled": false,
|
||||||
|
"directAccessGrantsEnabled": true,
|
||||||
|
"standardFlowEnabled": true,
|
||||||
|
"frontchannelLogout": true,
|
||||||
|
"attributes": {
|
||||||
|
"saml_idp_initiated_sso_url_name": "",
|
||||||
|
"oauth2.device.authorization.grant.enabled": false,
|
||||||
|
"oidc.ciba.grant.enabled": false
|
||||||
|
},
|
||||||
|
"alwaysDisplayInConsole": false,
|
||||||
|
"rootUrl": "",
|
||||||
|
"baseUrl": "",
|
||||||
|
"redirectUris": [
|
||||||
|
"https://cnoe.localtest.me:443/argo-workflows/oauth2/callback"
|
||||||
|
],
|
||||||
|
"webOrigins": [
|
||||||
|
"/*"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
backstage-client-payload.json: |
|
||||||
|
{
|
||||||
|
"protocol": "openid-connect",
|
||||||
|
"clientId": "backstage",
|
||||||
|
"name": "Backstage Client",
|
||||||
|
"description": "Used for Backstage SSO",
|
||||||
|
"publicClient": false,
|
||||||
|
"authorizationServicesEnabled": false,
|
||||||
|
"serviceAccountsEnabled": false,
|
||||||
|
"implicitFlowEnabled": false,
|
||||||
|
"directAccessGrantsEnabled": true,
|
||||||
|
"standardFlowEnabled": true,
|
||||||
|
"frontchannelLogout": true,
|
||||||
|
"attributes": {
|
||||||
|
"saml_idp_initiated_sso_url_name": "",
|
||||||
|
"oauth2.device.authorization.grant.enabled": false,
|
||||||
|
"oidc.ciba.grant.enabled": false
|
||||||
|
},
|
||||||
|
"alwaysDisplayInConsole": false,
|
||||||
|
"rootUrl": "",
|
||||||
|
"baseUrl": "",
|
||||||
|
"redirectUris": [
|
||||||
|
"https://cnoe.localtest.me:443/api/auth/keycloak-oidc/handler/frame"
|
||||||
|
],
|
||||||
|
"webOrigins": [
|
||||||
|
"/*"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
---
|
||||||
|
apiVersion: batch/v1
|
||||||
|
kind: Job
|
||||||
|
metadata:
|
||||||
|
name: config
|
||||||
|
namespace: keycloak
|
||||||
|
annotations:
|
||||||
|
argocd.argoproj.io/hook: PostSync
|
||||||
|
spec:
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
generateName: config
|
||||||
|
spec:
|
||||||
|
serviceAccountName: keycloak-config
|
||||||
|
restartPolicy: Never
|
||||||
|
volumes:
|
||||||
|
- name: keycloak-config
|
||||||
|
secret:
|
||||||
|
secretName: keycloak-config
|
||||||
|
- name: config-payloads
|
||||||
|
configMap:
|
||||||
|
name: config-job
|
||||||
|
containers:
|
||||||
|
- name: kubectl
|
||||||
|
image: docker.io/library/ubuntu:22.04
|
||||||
|
volumeMounts:
|
||||||
|
- name: keycloak-config
|
||||||
|
readOnly: true
|
||||||
|
mountPath: "/var/secrets/"
|
||||||
|
- name: config-payloads
|
||||||
|
readOnly: true
|
||||||
|
mountPath: "/var/config/"
|
||||||
|
command: ["/bin/bash", "-c"]
|
||||||
|
args:
|
||||||
|
- |
|
||||||
|
#! /bin/bash
|
||||||
|
|
||||||
|
set -ex -o pipefail
|
||||||
|
|
||||||
|
apt -qq update && apt -qq install curl jq -y
|
||||||
|
|
||||||
|
ADMIN_PASSWORD=$(cat /var/secrets/KEYCLOAK_ADMIN_PASSWORD)
|
||||||
|
USER1_PASSWORD=$(cat /var/secrets/USER_PASSWORD)
|
||||||
|
|
||||||
|
KEYCLOAK_URL=http://keycloak.keycloak.svc.cluster.local:8080/keycloak
|
||||||
|
|
||||||
|
KEYCLOAK_TOKEN=$(curl -sS --fail-with-body -X POST -H "Content-Type: application/x-www-form-urlencoded" \
|
||||||
|
--data-urlencode "username=cnoe-admin" \
|
||||||
|
--data-urlencode "password=${ADMIN_PASSWORD}" \
|
||||||
|
--data-urlencode "grant_type=password" \
|
||||||
|
--data-urlencode "client_id=admin-cli" \
|
||||||
|
${KEYCLOAK_URL}/realms/master/protocol/openid-connect/token | jq -e -r '.access_token')
|
||||||
|
|
||||||
|
set +e
|
||||||
|
|
||||||
|
curl --fail-with-body -H "Authorization: bearer ${KEYCLOAK_TOKEN}" "${KEYCLOAK_URL}/admin/realms/cnoe" &> /dev/null
|
||||||
|
if [ $? -eq 0 ]; then
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
set -e
|
||||||
|
|
||||||
|
curl -sS -LO "https://dl.k8s.io/release/v1.28.3//bin/linux/amd64/kubectl"
|
||||||
|
chmod +x kubectl
|
||||||
|
|
||||||
|
echo "creating cnoe realm and groups"
|
||||||
|
|
||||||
|
curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" \
|
||||||
|
-X POST --data @/var/config/realm-payload.json \
|
||||||
|
${KEYCLOAK_URL}/admin/realms
|
||||||
|
|
||||||
|
curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" \
|
||||||
|
-X POST --data @/var/config/client-scope-groups-payload.json \
|
||||||
|
${KEYCLOAK_URL}/admin/realms/cnoe/client-scopes
|
||||||
|
|
||||||
|
curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" \
|
||||||
|
-X POST --data @/var/config/group-admin-payload.json \
|
||||||
|
${KEYCLOAK_URL}/admin/realms/cnoe/groups
|
||||||
|
|
||||||
|
curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" \
|
||||||
|
-X POST --data @/var/config/group-base-user-payload.json \
|
||||||
|
${KEYCLOAK_URL}/admin/realms/cnoe/groups
|
||||||
|
|
||||||
|
# Create scope mapper
|
||||||
|
echo 'adding group claim to tokens'
|
||||||
|
CLIENT_SCOPE_GROUPS_ID=$(curl -sS -H "Content-Type: application/json" -H "Authorization: bearer ${KEYCLOAK_TOKEN}" -X GET ${KEYCLOAK_URL}/admin/realms/cnoe/client-scopes | jq -e -r '.[] | select(.name == "groups") | .id')
|
||||||
|
|
||||||
|
curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" \
|
||||||
|
-X POST --data @/var/config/group-mapper-payload.json \
|
||||||
|
${KEYCLOAK_URL}/admin/realms/cnoe/client-scopes/${CLIENT_SCOPE_GROUPS_ID}/protocol-mappers/models
|
||||||
|
|
||||||
|
echo "creating test users"
|
||||||
|
curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" \
|
||||||
|
-X POST --data @/var/config/user-user1.json \
|
||||||
|
${KEYCLOAK_URL}/admin/realms/cnoe/users
|
||||||
|
|
||||||
|
curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" \
|
||||||
|
-X POST --data @/var/config/user-user2.json \
|
||||||
|
${KEYCLOAK_URL}/admin/realms/cnoe/users
|
||||||
|
|
||||||
|
USER1ID=$(curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" "${KEYCLOAK_URL}/admin/realms/cnoe/users?lastName=one" | jq -r '.[0].id')
|
||||||
|
USER2ID=$(curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" "${KEYCLOAK_URL}/admin/realms/cnoe/users?lastName=two" | jq -r '.[0].id')
|
||||||
|
|
||||||
|
echo "setting user passwords"
|
||||||
|
jq -r --arg pass ${USER1_PASSWORD} '.value = $pass' /var/config/user-password.json > /tmp/user-password-to-be-applied.json
|
||||||
|
|
||||||
|
curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" \
|
||||||
|
-X PUT --data @/tmp/user-password-to-be-applied.json \
|
||||||
|
${KEYCLOAK_URL}/admin/realms/cnoe/users/${USER1ID}/reset-password
|
||||||
|
|
||||||
|
curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" \
|
||||||
|
-X PUT --data @/tmp/user-password-to-be-applied.json \
|
||||||
|
${KEYCLOAK_URL}/admin/realms/cnoe/users/${USER2ID}/reset-password
|
||||||
|
|
||||||
|
echo "creating Argo Workflows client"
|
||||||
|
curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" \
|
||||||
|
-X POST --data @/var/config/argo-client-payload.json \
|
||||||
|
${KEYCLOAK_URL}/admin/realms/cnoe/clients
|
||||||
|
|
||||||
|
CLIENT_ID=$(curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" \
|
||||||
|
-X GET ${KEYCLOAK_URL}/admin/realms/cnoe/clients | jq -e -r '.[] | select(.clientId == "argo-workflows") | .id')
|
||||||
|
CLIENT_SCOPE_GROUPS_ID=$(curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" \
|
||||||
|
-X GET ${KEYCLOAK_URL}/admin/realms/cnoe/client-scopes | jq -e -r '.[] | select(.name == "groups") | .id')
|
||||||
|
|
||||||
|
curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" \
|
||||||
|
-X PUT ${KEYCLOAK_URL}/admin/realms/cnoe/clients/${CLIENT_ID}/default-client-scopes/${CLIENT_SCOPE_GROUPS_ID}
|
||||||
|
|
||||||
|
ARGO_WORKFLOWS_CLIENT_SECRET=$(curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" \
|
||||||
|
-X GET ${KEYCLOAK_URL}/admin/realms/cnoe/clients/${CLIENT_ID} | jq -e -r '.secret')
|
||||||
|
|
||||||
|
echo "creating Backstage client"
|
||||||
|
curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" \
|
||||||
|
-X POST --data @/var/config/backstage-client-payload.json \
|
||||||
|
${KEYCLOAK_URL}/admin/realms/cnoe/clients
|
||||||
|
|
||||||
|
CLIENT_ID=$(curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" \
|
||||||
|
-X GET ${KEYCLOAK_URL}/admin/realms/cnoe/clients | jq -e -r '.[] | select(.clientId == "backstage") | .id')
|
||||||
|
|
||||||
|
CLIENT_SCOPE_GROUPS_ID=$(curl -sS -H "Content-Type: application/json" -H "Authorization: bearer ${KEYCLOAK_TOKEN}" -X GET ${KEYCLOAK_URL}/admin/realms/cnoe/client-scopes | jq -e -r '.[] | select(.name == "groups") | .id')
|
||||||
|
curl -sS -H "Content-Type: application/json" -H "Authorization: bearer ${KEYCLOAK_TOKEN}" -X PUT ${KEYCLOAK_URL}/admin/realms/cnoe/clients/${CLIENT_ID}/default-client-scopes/${CLIENT_SCOPE_GROUPS_ID}
|
||||||
|
|
||||||
|
BACKSTAGE_CLIENT_SECRET=$(curl -sS -H "Content-Type: application/json" \
|
||||||
|
-H "Authorization: bearer ${KEYCLOAK_TOKEN}" \
|
||||||
|
-X GET ${KEYCLOAK_URL}/admin/realms/cnoe/clients/${CLIENT_ID} | jq -e -r '.secret')
|
||||||
|
|
||||||
|
ARGOCD_PASSWORD=$(./kubectl -n argocd get secret argocd-initial-admin-secret -o go-template='{{.data.password | base64decode }}')
|
||||||
|
|
||||||
|
ARGOCD_SESSION_TOKEN=$(curl -k -sS http://argocd-server.argocd.svc.cluster.local:443/api/v1/session -H 'Content-Type: application/json' -d "{\"username\":\"admin\",\"password\":\"${ARGOCD_PASSWORD}\"}" | jq -r .token)
|
||||||
|
|
||||||
|
echo \
|
||||||
|
"apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: keycloak-clients
|
||||||
|
namespace: keycloak
|
||||||
|
type: Opaque
|
||||||
|
stringData:
|
||||||
|
ARGO_WORKFLOWS_CLIENT_SECRET: ${ARGO_WORKFLOWS_CLIENT_SECRET}
|
||||||
|
ARGO_WORKFLOWS_CLIENT_ID: argo-workflows
|
||||||
|
ARGOCD_SESSION_TOKEN: ${ARGOCD_SESSION_TOKEN}
|
||||||
|
BACKSTAGE_CLIENT_SECRET: ${BACKSTAGE_CLIENT_SECRET}
|
||||||
|
BACKSTAGE_CLIENT_ID: backstage
|
||||||
|
" > /tmp/secret.yaml
|
||||||
|
|
||||||
|
./kubectl apply -f /tmp/secret.yaml
|
||||||
|
|
|
@ -0,0 +1,179 @@
|
||||||
|
apiVersion: generators.external-secrets.io/v1alpha1
|
||||||
|
kind: Password
|
||||||
|
metadata:
|
||||||
|
name: keycloak
|
||||||
|
namespace: keycloak
|
||||||
|
spec:
|
||||||
|
length: 36
|
||||||
|
digits: 5
|
||||||
|
symbols: 5
|
||||||
|
symbolCharacters: "/-+"
|
||||||
|
noUpper: false
|
||||||
|
allowRepeat: true
|
||||||
|
---
|
||||||
|
apiVersion: external-secrets.io/v1beta1
|
||||||
|
kind: ExternalSecret
|
||||||
|
metadata:
|
||||||
|
name: keycloak-config
|
||||||
|
namespace: keycloak
|
||||||
|
spec:
|
||||||
|
refreshInterval: "0"
|
||||||
|
target:
|
||||||
|
name: keycloak-config
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
cnoe.io/cli-secret: "true"
|
||||||
|
cnoe.io/package-name: keycloak
|
||||||
|
engineVersion: v2
|
||||||
|
data:
|
||||||
|
KEYCLOAK_ADMIN_PASSWORD: "{{.KEYCLOAK_ADMIN_PASSWORD}}"
|
||||||
|
KC_DB_USERNAME: keycloak
|
||||||
|
KC_DB_PASSWORD: "{{.KC_DB_PASSWORD}}"
|
||||||
|
POSTGRES_DB: keycloak
|
||||||
|
POSTGRES_USER: keycloak
|
||||||
|
POSTGRES_PASSWORD: "{{.KC_DB_PASSWORD}}"
|
||||||
|
USER_PASSWORD: "{{.USER_PASSWORD}}"
|
||||||
|
dataFrom:
|
||||||
|
- sourceRef:
|
||||||
|
generatorRef:
|
||||||
|
apiVersion: generators.external-secrets.io/v1alpha1
|
||||||
|
kind: Password
|
||||||
|
name: keycloak
|
||||||
|
rewrite:
|
||||||
|
- transform:
|
||||||
|
template: "KEYCLOAK_ADMIN_PASSWORD"
|
||||||
|
- sourceRef:
|
||||||
|
generatorRef:
|
||||||
|
apiVersion: generators.external-secrets.io/v1alpha1
|
||||||
|
kind: Password
|
||||||
|
name: keycloak
|
||||||
|
rewrite:
|
||||||
|
- transform:
|
||||||
|
template: "KC_DB_PASSWORD"
|
||||||
|
- sourceRef:
|
||||||
|
generatorRef:
|
||||||
|
apiVersion: generators.external-secrets.io/v1alpha1
|
||||||
|
kind: Password
|
||||||
|
name: keycloak
|
||||||
|
rewrite:
|
||||||
|
- transform:
|
||||||
|
template: "USER_PASSWORD"
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: ServiceAccount
|
||||||
|
metadata:
|
||||||
|
name: eso-store
|
||||||
|
namespace: keycloak
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: Role
|
||||||
|
metadata:
|
||||||
|
namespace: keycloak
|
||||||
|
name: eso-store
|
||||||
|
rules:
|
||||||
|
- apiGroups: [""]
|
||||||
|
resources:
|
||||||
|
- secrets
|
||||||
|
verbs:
|
||||||
|
- get
|
||||||
|
- list
|
||||||
|
- watch
|
||||||
|
- apiGroups:
|
||||||
|
- authorization.k8s.io
|
||||||
|
resources:
|
||||||
|
- selfsubjectrulesreviews
|
||||||
|
verbs:
|
||||||
|
- create
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: RoleBinding
|
||||||
|
metadata:
|
||||||
|
name: eso-store
|
||||||
|
namespace: keycloak
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: eso-store
|
||||||
|
namespace: keycloak
|
||||||
|
roleRef:
|
||||||
|
kind: Role
|
||||||
|
name: eso-store
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
---
|
||||||
|
apiVersion: external-secrets.io/v1beta1
|
||||||
|
kind: ClusterSecretStore
|
||||||
|
metadata:
|
||||||
|
name: keycloak
|
||||||
|
spec:
|
||||||
|
provider:
|
||||||
|
kubernetes:
|
||||||
|
remoteNamespace: keycloak
|
||||||
|
server:
|
||||||
|
caProvider:
|
||||||
|
type: ConfigMap
|
||||||
|
name: kube-root-ca.crt
|
||||||
|
namespace: keycloak
|
||||||
|
key: ca.crt
|
||||||
|
auth:
|
||||||
|
serviceAccount:
|
||||||
|
name: eso-store
|
||||||
|
namespace: keycloak
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: ServiceAccount
|
||||||
|
metadata:
|
||||||
|
name: eso-store
|
||||||
|
namespace: gitea
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: Role
|
||||||
|
metadata:
|
||||||
|
name: eso-store
|
||||||
|
namespace: gitea
|
||||||
|
rules:
|
||||||
|
- apiGroups: [""]
|
||||||
|
resources:
|
||||||
|
- secrets
|
||||||
|
verbs:
|
||||||
|
- get
|
||||||
|
- list
|
||||||
|
- watch
|
||||||
|
- apiGroups:
|
||||||
|
- authorization.k8s.io
|
||||||
|
resources:
|
||||||
|
- selfsubjectrulesreviews
|
||||||
|
verbs:
|
||||||
|
- create
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: RoleBinding
|
||||||
|
metadata:
|
||||||
|
name: eso-store
|
||||||
|
namespace: gitea
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: eso-store
|
||||||
|
namespace: gitea
|
||||||
|
roleRef:
|
||||||
|
kind: Role
|
||||||
|
name: eso-store
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
---
|
||||||
|
apiVersion: external-secrets.io/v1beta1
|
||||||
|
kind: ClusterSecretStore
|
||||||
|
metadata:
|
||||||
|
name: gitea
|
||||||
|
spec:
|
||||||
|
provider:
|
||||||
|
kubernetes:
|
||||||
|
remoteNamespace: gitea
|
||||||
|
server:
|
||||||
|
caProvider:
|
||||||
|
type: ConfigMap
|
||||||
|
name: kube-root-ca.crt
|
||||||
|
namespace: gitea
|
||||||
|
key: ca.crt
|
||||||
|
auth:
|
||||||
|
serviceAccount:
|
||||||
|
name: eso-store
|
||||||
|
namespace: gitea
|
29
kind/stacks/ref-implementation/metric-server.yaml
Normal file
29
kind/stacks/ref-implementation/metric-server.yaml
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: metric-server
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
finalizers:
|
||||||
|
- resources-finalizer.argocd.argoproj.io
|
||||||
|
spec:
|
||||||
|
project: default
|
||||||
|
source:
|
||||||
|
repoURL: https://kubernetes-sigs.github.io/metrics-server
|
||||||
|
targetRevision: 3.12.1
|
||||||
|
helm:
|
||||||
|
releaseName: metrics-server
|
||||||
|
values: |
|
||||||
|
args:
|
||||||
|
- --kubelet-insecure-tls #required for kind/minikube
|
||||||
|
chart: metrics-server
|
||||||
|
destination:
|
||||||
|
server: 'https://kubernetes.default.svc'
|
||||||
|
namespace: kube-system
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
prune: true
|
||||||
|
selfHeal: true
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
36
kind/stacks/ref-implementation/replace.sh
Executable file
36
kind/stacks/ref-implementation/replace.sh
Executable file
|
@ -0,0 +1,36 @@
|
||||||
|
# this script replaces hostname and port used by this implementation.
|
||||||
|
# intended for use in environments such as Codespaces where external host and port need to be updated to access in-cluster resources.
|
||||||
|
|
||||||
|
#!/bin/bash
|
||||||
|
set -e
|
||||||
|
# Check if the new port number is provided as an argument
|
||||||
|
if [ "$#" -ne 2 ]; then
|
||||||
|
echo "Usage: NEW_HOST NEW_PORT"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Assign the first script argument to NEW_PORT
|
||||||
|
NEW_HOST="$1"
|
||||||
|
NEW_PORT="$2"
|
||||||
|
|
||||||
|
# Base directory to start from, "." means the current directory
|
||||||
|
CURRENT_DIR=$(echo "${PWD##*/}")
|
||||||
|
if [[ ${CURRENT_DIR} != "ref-implementation" ]]; then
|
||||||
|
echo "please run this script from the ref-implementation directory"
|
||||||
|
exit 10
|
||||||
|
fi
|
||||||
|
BASE_DIRECTORY="."
|
||||||
|
|
||||||
|
# Find all .yaml files recursively starting from the base directory
|
||||||
|
# and perform an in-place search and replace from 8443 to the new port
|
||||||
|
find "$BASE_DIRECTORY" -type f -name "*.yaml" -exec sed -i "s/8443/${NEW_PORT}/g" {} +
|
||||||
|
find "$BASE_DIRECTORY" -type f -name "*.yaml" -exec sed -i "s/cnoe\.localtest\.me/${NEW_HOST}/g" {} +
|
||||||
|
|
||||||
|
# Remove hostname-port configuration if the new port is 443. Browsers strip 443 but keycloak still expects 443 in url.
|
||||||
|
if [[ ${NEW_PORT} == "443" ]]; then
|
||||||
|
sed -i "/hostname-port/d" keycloak/manifests/install.yaml
|
||||||
|
sed -i "/hostname-admin/d" keycloak/manifests/install.yaml
|
||||||
|
sed -i '0,/:443/{s/:443//}' argo-workflows/manifests/dev/patches/cm-argo-workflows.yaml
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Replacement complete."
|
25
kind/stacks/ref-implementation/spark-operator.yaml
Normal file
25
kind/stacks/ref-implementation/spark-operator.yaml
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: spark-operator
|
||||||
|
namespace: argocd
|
||||||
|
labels:
|
||||||
|
env: dev
|
||||||
|
finalizers:
|
||||||
|
- resources-finalizer.argocd.argoproj.io
|
||||||
|
spec:
|
||||||
|
project: default
|
||||||
|
sources:
|
||||||
|
- repoURL: https://kubeflow.github.io/spark-operator
|
||||||
|
targetRevision: 1.1.27
|
||||||
|
helm:
|
||||||
|
releaseName: spark-operator
|
||||||
|
chart: spark-operator
|
||||||
|
destination:
|
||||||
|
server: "https://kubernetes.default.svc"
|
||||||
|
namespace: spark-operator
|
||||||
|
syncPolicy:
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
||||||
|
automated:
|
||||||
|
selfHeal: true
|
Reference in a new issue