diff --git a/catalog-info.yaml b/catalog-info.yaml index 0189a58..da18b87 100644 --- a/catalog-info.yaml +++ b/catalog-info.yaml @@ -133,3 +133,2925 @@ spec: # ─── Per-service Components (from Watcher discovery) ───────────────── + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: adservice + description: "adservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=adservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=adservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=adservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=adservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "adservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=adservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: cartservice + description: "cartservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=cartservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=cartservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=cartservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=cartservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "cartservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=cartservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: redis-cart + description: "redis-cart service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + - python + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=redis-cart" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=redis-cart" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=redis-cart" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=redis-cart" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "redis-cart" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=redis-cart + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: checkoutservice + description: "checkoutservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=checkoutservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=checkoutservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=checkoutservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=checkoutservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "checkoutservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=checkoutservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: currencyservice + description: "currencyservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=currencyservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=currencyservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=currencyservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=currencyservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "currencyservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=currencyservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: emailservice + description: "emailservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=emailservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=emailservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=emailservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=emailservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "emailservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=emailservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: frontend + description: "frontend service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=frontend" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=frontend" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=frontend" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=frontend" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "frontend" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=frontend + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: loadgenerator + description: "loadgenerator service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=loadgenerator" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=loadgenerator" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=loadgenerator" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=loadgenerator" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "loadgenerator" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=loadgenerator + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: paymentservice + description: "paymentservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=paymentservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=paymentservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=paymentservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=paymentservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "paymentservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=paymentservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: productcatalogservice + description: "productcatalogservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=productcatalogservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=productcatalogservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=productcatalogservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=productcatalogservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "productcatalogservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=productcatalogservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: recommendationservice + description: "recommendationservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=recommendationservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=recommendationservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=recommendationservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=recommendationservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "recommendationservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=recommendationservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: shippingservice + description: "shippingservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=shippingservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=shippingservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=shippingservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=shippingservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "shippingservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=shippingservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: adservice + description: "adservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + - java + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=adservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=adservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=adservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=adservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "adservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=adservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: cartservice + description: "cartservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + - dotnet + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=cartservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=cartservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=cartservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=cartservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "cartservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=cartservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: redis-cart + description: "redis-cart service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + - python + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=redis-cart" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=redis-cart" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=redis-cart" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=redis-cart" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "redis-cart" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=redis-cart + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: checkoutservice + description: "checkoutservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=checkoutservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=checkoutservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=checkoutservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=checkoutservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "checkoutservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=checkoutservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: currencyservice + description: "currencyservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + - nodejs + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=currencyservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=currencyservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=currencyservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=currencyservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "currencyservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=currencyservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: emailservice + description: "emailservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + - python + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=emailservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=emailservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=emailservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=emailservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "emailservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=emailservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: frontend + description: "frontend service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=frontend" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=frontend" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=frontend" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=frontend" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "frontend" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=frontend + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: loadgenerator + description: "loadgenerator service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + - python + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=loadgenerator" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=loadgenerator" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=loadgenerator" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=loadgenerator" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "loadgenerator" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=loadgenerator + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: paymentservice + description: "paymentservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + - nodejs + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=paymentservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=paymentservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=paymentservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=paymentservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "paymentservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=paymentservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: productcatalogservice + description: "productcatalogservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=productcatalogservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=productcatalogservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=productcatalogservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=productcatalogservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "productcatalogservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=productcatalogservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: recommendationservice + description: "recommendationservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + - python + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=recommendationservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=recommendationservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=recommendationservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=recommendationservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "recommendationservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=recommendationservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: shippingservice + description: "shippingservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=shippingservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=shippingservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=shippingservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=shippingservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "shippingservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=shippingservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: opentelemetrycollector + description: "opentelemetrycollector service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=opentelemetrycollector" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=opentelemetrycollector" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=opentelemetrycollector" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=opentelemetrycollector" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "opentelemetrycollector" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=opentelemetrycollector + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: shoppingassistantservice + description: "shoppingassistantservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=shoppingassistantservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=shoppingassistantservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=shoppingassistantservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=shoppingassistantservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "shoppingassistantservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=shoppingassistantservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: loadgenerator + description: "loadgenerator service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=loadgenerator" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=loadgenerator" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=loadgenerator" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=loadgenerator" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "loadgenerator" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=loadgenerator + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: currencyservice + description: "currencyservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + - nodejs + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=currencyservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=currencyservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=currencyservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=currencyservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "currencyservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=currencyservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: loadgenerator + description: "loadgenerator service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + - python + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=loadgenerator" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=loadgenerator" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=loadgenerator" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=loadgenerator" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "loadgenerator" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=loadgenerator + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: productcatalogservice + description: "productcatalogservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=productcatalogservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=productcatalogservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=productcatalogservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=productcatalogservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "productcatalogservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=productcatalogservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: checkoutservice + description: "checkoutservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=checkoutservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=checkoutservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=checkoutservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=checkoutservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "checkoutservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=checkoutservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: shippingservice + description: "shippingservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=shippingservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=shippingservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=shippingservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=shippingservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "shippingservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=shippingservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: cartservice + description: "cartservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + - dotnet + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=cartservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=cartservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=cartservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=cartservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "cartservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=cartservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: redis-cart + description: "redis-cart service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + - python + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=redis-cart" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=redis-cart" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=redis-cart" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=redis-cart" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "redis-cart" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=redis-cart + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: emailservice + description: "emailservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + - python + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=emailservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=emailservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=emailservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=emailservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "emailservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=emailservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: paymentservice + description: "paymentservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + - nodejs + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=paymentservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=paymentservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=paymentservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=paymentservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "paymentservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=paymentservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: frontend + description: "frontend service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=frontend" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=frontend" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=frontend" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=frontend" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "frontend" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=frontend + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: recommendationservice + description: "recommendationservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + - python + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=recommendationservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=recommendationservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=recommendationservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=recommendationservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "recommendationservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=recommendationservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + +--- +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: adservice + description: "adservice service — part of security-scan-test" + labels: + backstage.io/environment: "dev" + app.kubernetes.io/managed-by: "backstage" + tags: + - deployment + - argocd + + - opentelemetry + + - load-testing + - k6 + + - chaos-engineering + - chaos-mesh + + + - java + + annotations: + argocd/app-name: "security-scan-test" + argocd/app-namespace: "argocd" + argocd/instance-name: "" + backstage.io/source-location: "url:https://gitea.kyndemo.live/validate/security-scan-test/src/branch/main" + backstage.io/kubernetes-namespace: "demo-apps" + backstage.io/kubernetes-label-selector: "app=adservice" + backstage.io/techdocs-ref: dir:. + gitea.kyndemo.live/repo-slug: "validate/security-scan-test" + + grafana/grafana-instance: "default" + grafana/alert-label-selector: "app=adservice" + grafana/dashboard-selector: "uid == 'otel-app-observability-v2'" + grafana.com/alert-label-selector: "app=adservice" + grafana.com/dashboard-url: "https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=adservice" + + k6/enabled: "true" + k6/test-configmap: "k6-test-security-scan-test" + k6/test-namespace: "demo-apps" + k6/target-service: "adservice" + + chaos-mesh/enabled: "true" + + links: + - url: https://security-scan-test.kyndemo.live + title: Live Application + icon: web + - url: https://gitea.kyndemo.live/validate/security-scan-test + title: Repository + icon: github + - url: https://argocd.kyndemo.live/applications/security-scan-test + title: ArgoCD App + icon: dashboard + + - url: https://grafana.kyndemo.live/d/otel-app-observability-v2/opentelemetry-application-observability?orgId=1&var-service=adservice + title: Grafana Dashboard + icon: dashboard + +spec: + type: service + owner: "platform-engineering" + lifecycle: experimental + + system: security-scan-test + dependsOn: + - component:default/argocd-service + + + - resource:default/otel-collector + + - resource:default/k6-operator + + diff --git a/k6/load-test.js b/k6/load-test.js new file mode 100644 index 0000000..b590d11 --- /dev/null +++ b/k6/load-test.js @@ -0,0 +1,36 @@ +// FALLBACK k6 load-test script. +// This static skeleton is only used when The Watcher agent fails to generate +// a bespoke k6 script tailored to the application's detected HTTP endpoints. +// When generation succeeds, the agent produces a custom script that replaces +// this file in the scaffolded output repository. +import http from 'k6/http'; +import { check, sleep } from 'k6'; + +export const options = { + scenarios: { + load_test: { + executor: 'ramping-vus', + startVUs: 0, + stages: [ + { duration: '${{ values.k6_ramp_up | default("10s") }}', target: ${{ values.k6_virtual_users | default(10) }} }, + { duration: '${{ values.k6_duration | default("30s") }}', target: ${{ values.k6_virtual_users | default(10) }} }, + { duration: '5s', target: 0 }, + ], + }, + }, + thresholds: { + http_req_duration: ['p(95)<500'], + http_req_failed: ['rate<0.01'], + }, +}; + +const BASE_URL = `http://${{ values.frontend_service_name | default("frontend") }}.${{ values.destination_namespace }}.svc.cluster.local:${{ values.frontend_service_port | default(80) }}`; + +export default function () { + const res = http.get(`${BASE_URL}${{ values.k6_target_path | default("/") }}`); + check(res, { + 'status is 200': (r) => r.status === 200, + 'response time < 500ms': (r) => r.timings.duration < 500, + }); + sleep(0.5); +} diff --git a/k6/testrun.yaml b/k6/testrun.yaml new file mode 100644 index 0000000..5550c67 --- /dev/null +++ b/k6/testrun.yaml @@ -0,0 +1,36 @@ +# FALLBACK k6 TestRun CRD — reference template for load testing ${{ values.component_id }}. +# This static skeleton is only used when The Watcher agent fails to generate +# a bespoke k6 script. When generation succeeds, the agent produces a custom +# TestRun CRD that replaces this file in the scaffolded output repository. +# +# TestRun CRDs are committed to the repo as a reference. They are created +# dynamically from Backstage (not auto-synced by ArgoCD) because they are +# ephemeral one-shot resources. +apiVersion: k6.io/v1alpha1 +kind: TestRun +metadata: + name: k6-${{ values.component_id }} + namespace: ${{ values.destination_namespace }} + labels: + app: ${{ values.component_id }} + backstage.io/component: ${{ values.component_id }} + app.kubernetes.io/managed-by: backstage + app.kubernetes.io/component: load-testing +spec: + parallelism: 1 + script: + configMap: + name: k6-test-${{ values.component_id }} + file: load-test.js + runner: + image: grafana/k6:latest + envFrom: + - configMapRef: + name: k6-test-${{ values.component_id }} + env: + - name: K6_OTEL_SERVICE_NAME + value: k6-${{ values.component_id }} + - name: TEST_VUS + value: "10" + - name: TEST_DURATION + value: "30s" diff --git a/overlays/deploy/k6-configmap.yaml b/overlays/deploy/k6-configmap.yaml new file mode 100644 index 0000000..bde0f88 --- /dev/null +++ b/overlays/deploy/k6-configmap.yaml @@ -0,0 +1,59 @@ +# FALLBACK ConfigMap. +# This static skeleton is only used when The Watcher agent fails to generate +# a bespoke k6 script. When generation succeeds, the agent produces a custom +# ConfigMap containing the tailored load-test.js that replaces this file in +# the scaffolded output repository. +apiVersion: v1 +kind: ConfigMap +metadata: + name: k6-test-${{ values.component_id }} + namespace: ${{ values.destination_namespace }} + labels: + app: ${{ values.component_id }} + app.kubernetes.io/managed-by: backstage + app.kubernetes.io/component: load-testing +data: + K6_OUT: "opentelemetry" + K6_OTEL_GRPC_EXPORTER_INSECURE: "true" + K6_OTEL_GRPC_EXPORTER_ENDPOINT: "otel-collector.monitoring.svc.cluster.local:4317" + K6_OTEL_METRIC_PREFIX: "k6_" + K6_OTEL_FLUSH_INTERVAL: "1000" + K6_OTEL_EXPORT_INTERVAL: "5000" + K6_OTEL_SERVICE_NAME: "k6-${{ values.component_id }}" + load-test.js: | + import http from 'k6/http'; + import { check, sleep } from 'k6'; + + const vus = parseInt(__ENV.TEST_VUS || '10'); + const duration = __ENV.TEST_DURATION || '30s'; + const targetUrl = __ENV.TARGET_URL || 'http://localhost'; + + export const options = { + scenarios: { + load_test: { + executor: 'ramping-vus', + startVUs: 0, + stages: [ + { duration: '10s', target: vus }, + { duration: duration, target: vus }, + { duration: '5s', target: 0 }, + ], + }, + }, + thresholds: { + http_req_duration: ['p(95)<500'], + http_req_failed: ['rate<0.075'], + }, + }; + + // Treat 2xx and 3xx responses as expected (redirects won't inflate http_req_failed) + http.setResponseCallback(http.expectedStatuses({ min: 200, max: 399 })); + + export default function () { + const res = http.get(targetUrl); + check(res, { + 'status is 200': (r) => r.status === 200, + 'response time < 500ms': (r) => r.timings.duration < 500, + }); + sleep(0.5); + } diff --git a/overlays/otel/kustomization.yaml b/overlays/otel/kustomization.yaml new file mode 100644 index 0000000..d0e279e --- /dev/null +++ b/overlays/otel/kustomization.yaml @@ -0,0 +1,68 @@ +apiVersion: kustomize.config.k8s.io/v1beta1 +kind: Kustomization +resources: +- ../deploy +patches: +- target: + kind: Deployment + name: redis-cart + patch: "apiVersion: apps/v1\nkind: Deployment\nmetadata:\n name: redis-cart\nspec:\n\ + \ template:\n metadata:\n annotations:\n instrumentation.opentelemetry.io/inject-python:\ + \ monitoring/otel-instrumentation\n spec:\n containers:\n - name:\ + \ redis\n env:\n - name: OTEL_SERVICE_NAME\n value: redis-cart\n\ + \ - name: OTEL_EXPORTER_OTLP_ENDPOINT\n value: http://otel-collector.monitoring.svc.cluster.local:4318\n\ + \ - name: OTEL_RESOURCE_ATTRIBUTES\n value: app=security-scan-test\n" +- target: + kind: Deployment + name: adservice + patch: "apiVersion: apps/v1\nkind: Deployment\nmetadata:\n name: adservice\nspec:\n\ + \ template:\n metadata:\n annotations:\n instrumentation.opentelemetry.io/inject-java:\ + \ monitoring/otel-instrumentation\n spec:\n containers:\n - name:\ + \ server\n env:\n - name: OTEL_SERVICE_NAME\n value: adservice\n\ + \ - name: OTEL_EXPORTER_OTLP_ENDPOINT\n value: http://otel-collector.monitoring.svc.cluster.local:4318\n\ + \ - name: OTEL_RESOURCE_ATTRIBUTES\n value: app=security-scan-test\n" +- target: + kind: Deployment + name: currencyservice + patch: "apiVersion: apps/v1\nkind: Deployment\nmetadata:\n name: currencyservice\n\ + spec:\n template:\n metadata:\n annotations:\n instrumentation.opentelemetry.io/inject-nodejs:\ + \ monitoring/otel-instrumentation\n spec:\n containers:\n - name:\ + \ server\n env:\n - name: OTEL_SERVICE_NAME\n value: currencyservice\n\ + \ - name: OTEL_EXPORTER_OTLP_ENDPOINT\n value: http://otel-collector.monitoring.svc.cluster.local:4318\n\ + \ - name: OTEL_RESOURCE_ATTRIBUTES\n value: app=security-scan-test\n" +- target: + kind: Deployment + name: emailservice + patch: "apiVersion: apps/v1\nkind: Deployment\nmetadata:\n name: emailservice\n\ + spec:\n template:\n metadata:\n annotations:\n instrumentation.opentelemetry.io/inject-python:\ + \ monitoring/otel-instrumentation\n spec:\n containers:\n - name:\ + \ server\n env:\n - name: OTEL_SERVICE_NAME\n value: emailservice\n\ + \ - name: OTEL_EXPORTER_OTLP_ENDPOINT\n value: http://otel-collector.monitoring.svc.cluster.local:4318\n\ + \ - name: OTEL_RESOURCE_ATTRIBUTES\n value: app=security-scan-test\n" +- target: + kind: Deployment + name: loadgenerator + patch: "apiVersion: apps/v1\nkind: Deployment\nmetadata:\n name: loadgenerator\n\ + spec:\n template:\n metadata:\n annotations:\n instrumentation.opentelemetry.io/inject-python:\ + \ monitoring/otel-instrumentation\n spec:\n containers:\n - name:\ + \ main\n env:\n - name: OTEL_SERVICE_NAME\n value: loadgenerator\n\ + \ - name: OTEL_EXPORTER_OTLP_ENDPOINT\n value: http://otel-collector.monitoring.svc.cluster.local:4318\n\ + \ - name: OTEL_RESOURCE_ATTRIBUTES\n value: app=security-scan-test\n" +- target: + kind: Deployment + name: paymentservice + patch: "apiVersion: apps/v1\nkind: Deployment\nmetadata:\n name: paymentservice\n\ + spec:\n template:\n metadata:\n annotations:\n instrumentation.opentelemetry.io/inject-nodejs:\ + \ monitoring/otel-instrumentation\n spec:\n containers:\n - name:\ + \ server\n env:\n - name: OTEL_SERVICE_NAME\n value: paymentservice\n\ + \ - name: OTEL_EXPORTER_OTLP_ENDPOINT\n value: http://otel-collector.monitoring.svc.cluster.local:4318\n\ + \ - name: OTEL_RESOURCE_ATTRIBUTES\n value: app=security-scan-test\n" +- target: + kind: Deployment + name: recommendationservice + patch: "apiVersion: apps/v1\nkind: Deployment\nmetadata:\n name: recommendationservice\n\ + spec:\n template:\n metadata:\n annotations:\n instrumentation.opentelemetry.io/inject-python:\ + \ monitoring/otel-instrumentation\n spec:\n containers:\n - name:\ + \ server\n env:\n - name: OTEL_SERVICE_NAME\n value: recommendationservice\n\ + \ - name: OTEL_EXPORTER_OTLP_ENDPOINT\n value: http://otel-collector.monitoring.svc.cluster.local:4318\n\ + \ - name: OTEL_RESOURCE_ATTRIBUTES\n value: app=security-scan-test\n" diff --git a/overlays/otel/patches/otel-patch.yaml b/overlays/otel/patches/otel-patch.yaml new file mode 100644 index 0000000..0cad39c --- /dev/null +++ b/overlays/otel/patches/otel-patch.yaml @@ -0,0 +1,139 @@ +apiVersion: apps/v1 +kind: Deployment +metadata: + name: redis-cart +spec: + template: + metadata: + annotations: + instrumentation.opentelemetry.io/inject-python: monitoring/otel-instrumentation + spec: + containers: + - name: redis + env: + - name: OTEL_SERVICE_NAME + value: redis-cart + - name: OTEL_EXPORTER_OTLP_ENDPOINT + value: http://otel-collector.monitoring.svc.cluster.local:4318 + - name: OTEL_RESOURCE_ATTRIBUTES + value: app=security-scan-test +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: adservice +spec: + template: + metadata: + annotations: + instrumentation.opentelemetry.io/inject-java: monitoring/otel-instrumentation + spec: + containers: + - name: server + env: + - name: OTEL_SERVICE_NAME + value: adservice + - name: OTEL_EXPORTER_OTLP_ENDPOINT + value: http://otel-collector.monitoring.svc.cluster.local:4318 + - name: OTEL_RESOURCE_ATTRIBUTES + value: app=security-scan-test +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: currencyservice +spec: + template: + metadata: + annotations: + instrumentation.opentelemetry.io/inject-nodejs: monitoring/otel-instrumentation + spec: + containers: + - name: server + env: + - name: OTEL_SERVICE_NAME + value: currencyservice + - name: OTEL_EXPORTER_OTLP_ENDPOINT + value: http://otel-collector.monitoring.svc.cluster.local:4318 + - name: OTEL_RESOURCE_ATTRIBUTES + value: app=security-scan-test +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: emailservice +spec: + template: + metadata: + annotations: + instrumentation.opentelemetry.io/inject-python: monitoring/otel-instrumentation + spec: + containers: + - name: server + env: + - name: OTEL_SERVICE_NAME + value: emailservice + - name: OTEL_EXPORTER_OTLP_ENDPOINT + value: http://otel-collector.monitoring.svc.cluster.local:4318 + - name: OTEL_RESOURCE_ATTRIBUTES + value: app=security-scan-test +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: loadgenerator +spec: + template: + metadata: + annotations: + instrumentation.opentelemetry.io/inject-python: monitoring/otel-instrumentation + spec: + containers: + - name: main + env: + - name: OTEL_SERVICE_NAME + value: loadgenerator + - name: OTEL_EXPORTER_OTLP_ENDPOINT + value: http://otel-collector.monitoring.svc.cluster.local:4318 + - name: OTEL_RESOURCE_ATTRIBUTES + value: app=security-scan-test +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: paymentservice +spec: + template: + metadata: + annotations: + instrumentation.opentelemetry.io/inject-nodejs: monitoring/otel-instrumentation + spec: + containers: + - name: server + env: + - name: OTEL_SERVICE_NAME + value: paymentservice + - name: OTEL_EXPORTER_OTLP_ENDPOINT + value: http://otel-collector.monitoring.svc.cluster.local:4318 + - name: OTEL_RESOURCE_ATTRIBUTES + value: app=security-scan-test +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: recommendationservice +spec: + template: + metadata: + annotations: + instrumentation.opentelemetry.io/inject-python: monitoring/otel-instrumentation + spec: + containers: + - name: server + env: + - name: OTEL_SERVICE_NAME + value: recommendationservice + - name: OTEL_EXPORTER_OTLP_ENDPOINT + value: http://otel-collector.monitoring.svc.cluster.local:4318 + - name: OTEL_RESOURCE_ATTRIBUTES + value: app=security-scan-test