From 271695bedeba7da55781204df7b3219489d3ad83 Mon Sep 17 00:00:00 2001
From: Leonardo Milleri <lmilleri@redhat.com>
Date: Wed, 30 Oct 2024 08:48:13 +0000
Subject: [PATCH] Release trustee-operator in OCP 4.17

Signed-off-by: Leonardo Milleri <lmilleri@redhat.com>
---
 .tekton/trustee-fbc-4-17-pull-request.yaml  | 57 ++++++++++++++++
 .tekton/trustee-fbc-4-17-push.yaml          | 54 +++++++++++++++
 v4.17/Dockerfile                            | 15 ++++
 v4.17/catalog-template.json                 | 24 +++++++
 v4.17/catalog/trustee-operator/catalog.json | 76 +++++++++++++++++++++
 5 files changed, 226 insertions(+)
 create mode 100644 .tekton/trustee-fbc-4-17-pull-request.yaml
 create mode 100644 .tekton/trustee-fbc-4-17-push.yaml
 create mode 100644 v4.17/Dockerfile
 create mode 100644 v4.17/catalog-template.json
 create mode 100644 v4.17/catalog/trustee-operator/catalog.json

diff --git a/.tekton/trustee-fbc-4-17-pull-request.yaml b/.tekton/trustee-fbc-4-17-pull-request.yaml
new file mode 100644
index 0000000..0ec7f2d
--- /dev/null
+++ b/.tekton/trustee-fbc-4-17-pull-request.yaml
@@ -0,0 +1,57 @@
+apiVersion: tekton.dev/v1
+kind: PipelineRun
+metadata:
+  annotations:
+    build.appstudio.openshift.io/repo: https://github.com/openshift/trustee-fbc?rev={{revision}}
+    build.appstudio.redhat.com/commit_sha: '{{revision}}'
+    build.appstudio.redhat.com/pull_request_number: '{{pull_request_number}}'
+    build.appstudio.redhat.com/target_branch: '{{target_branch}}'
+    pipelinesascode.tekton.dev/max-keep-runs: "3"
+    pipelinesascode.tekton.dev/on-cel-expression:
+      event == "pull_request" &&
+      target_branch == "main" &&
+      files.all.exists(path, path.matches('.tekton/pipeline.yaml$|.tekton/trustee-fbc-4-17-.*.yaml$|v4.17/Dockerfile$|v4.17/.*/catalog.json$'))
+  creationTimestamp: null
+  labels:
+    appstudio.openshift.io/application: trustee-fbc-4-17
+    appstudio.openshift.io/component: trustee-fbc-4-17
+    pipelines.appstudio.openshift.io/type: build
+  name: trustee-fbc-4-17-on-pull-request
+  namespace: ose-osc-tenant
+spec:
+  params:
+  - name: git-url
+    value: '{{source_url}}'
+  - name: revision
+    value: '{{revision}}'
+  - name: output-image
+    value: quay.io/redhat-user-workloads/ose-osc-tenant/trustee-fbc-4-17:on-pr-{{revision}}
+  - name: image-expires-after
+    value: 5d
+  - name: path-context
+    value: v4.17
+  - name: dockerfile
+    value: v4.17/Dockerfile
+  - name: build-platforms
+    value:
+      - linux/x86_64
+      - linux/s390x
+  pipelineRef:
+    name: build-pipeline
+  taskRunTemplate: {}
+  workspaces:
+  - name: workspace
+    volumeClaimTemplate:
+      metadata:
+        creationTimestamp: null
+      spec:
+        accessModes:
+        - ReadWriteOnce
+        resources:
+          requests:
+            storage: 1Gi
+      status: {}
+  - name: git-auth
+    secret:
+      secretName: '{{ git_auth_secret }}'
+status: {}
diff --git a/.tekton/trustee-fbc-4-17-push.yaml b/.tekton/trustee-fbc-4-17-push.yaml
new file mode 100644
index 0000000..3eb612b
--- /dev/null
+++ b/.tekton/trustee-fbc-4-17-push.yaml
@@ -0,0 +1,54 @@
+apiVersion: tekton.dev/v1
+kind: PipelineRun
+metadata:
+  annotations:
+    build.appstudio.openshift.io/repo: https://github.com/openshift/trustee-fbc?rev={{revision}}
+    build.appstudio.redhat.com/commit_sha: '{{revision}}'
+    build.appstudio.redhat.com/target_branch: '{{target_branch}}'
+    pipelinesascode.tekton.dev/max-keep-runs: "3"
+    pipelinesascode.tekton.dev/on-cel-expression:
+      event == "push" &&
+      target_branch == "main" &&
+      files.all.exists(path, path.matches('.tekton/pipeline.yaml$|.tekton/trustee-fbc-4-17-.*.yaml$|v4.17/Dockerfile$|v4.17/.*/catalog.json$'))
+  creationTimestamp: null
+  labels:
+    appstudio.openshift.io/application: trustee-fbc-4-17
+    appstudio.openshift.io/component: trustee-fbc-4-17
+    pipelines.appstudio.openshift.io/type: build
+  name: trustee-fbc-4-17-on-push
+  namespace: ose-osc-tenant
+spec:
+  params:
+  - name: git-url
+    value: '{{source_url}}'
+  - name: revision
+    value: '{{revision}}'
+  - name: output-image
+    value: quay.io/redhat-user-workloads/ose-osc-tenant/trustee-fbc-4-17:{{revision}}
+  - name: path-context
+    value: v4.17
+  - name: dockerfile
+    value: v4.17/Dockerfile
+  - name: build-platforms
+    value:
+      - linux/x86_64
+      - linux/s390x
+  pipelineRef:
+    name: build-pipeline
+  taskRunTemplate: {}
+  workspaces:
+  - name: workspace
+    volumeClaimTemplate:
+      metadata:
+        creationTimestamp: null
+      spec:
+        accessModes:
+        - ReadWriteOnce
+        resources:
+          requests:
+            storage: 1Gi
+      status: {}
+  - name: git-auth
+    secret:
+      secretName: '{{ git_auth_secret }}'
+status: {}
diff --git a/v4.17/Dockerfile b/v4.17/Dockerfile
new file mode 100644
index 0000000..d1a806b
--- /dev/null
+++ b/v4.17/Dockerfile
@@ -0,0 +1,15 @@
+# The base image is expected to contain
+# /bin/opm (with a serve subcommand) and /bin/grpc_health_probe
+FROM registry.redhat.io/openshift4/ose-operator-registry-rhel9:v4.17
+
+# Configure the entrypoint and command
+ENTRYPOINT ["/bin/opm"]
+CMD ["serve", "/configs", "--cache-dir=/tmp/cache"]
+
+# Copy declarative config root into image at /configs and pre-populate serve cache
+COPY catalog/ /configs
+RUN ["/bin/opm", "serve", "/configs", "--cache-dir=/tmp/cache", "--cache-only"]
+
+# Set DC-specific label for the location of the DC root directory
+# in the image
+LABEL operators.operatorframework.io.index.configs.v1=/configs
diff --git a/v4.17/catalog-template.json b/v4.17/catalog-template.json
new file mode 100644
index 0000000..51ce7ce
--- /dev/null
+++ b/v4.17/catalog-template.json
@@ -0,0 +1,24 @@
+{
+    "entries": [
+        {
+            "defaultChannel": "stable",
+            "name": "trustee-operator",
+            "schema": "olm.package"
+        },
+        {
+            "entries": [
+                {
+                    "name": "trustee-operator.v0.1.0"
+                }
+            ],
+            "name": "stable",
+            "package": "trustee-operator",
+            "schema": "olm.channel"
+        },
+        {
+            "image": "registry.redhat.io/confidential-compute-attestation-tech-preview/trustee-operator-bundle@sha256:6ac8c6158f093acd2ff7edd39f1e28788b78f91ee83bb36763d21990276034a0",
+            "schema": "olm.bundle"
+        }
+    ],
+    "schema": "olm.template.basic"
+}
diff --git a/v4.17/catalog/trustee-operator/catalog.json b/v4.17/catalog/trustee-operator/catalog.json
new file mode 100644
index 0000000..a1ff976
--- /dev/null
+++ b/v4.17/catalog/trustee-operator/catalog.json
@@ -0,0 +1,76 @@
+{
+    "schema": "olm.package",
+    "name": "trustee-operator",
+    "defaultChannel": "stable"
+}
+{
+    "schema": "olm.channel",
+    "name": "stable",
+    "package": "trustee-operator",
+    "entries": [
+        {
+            "name": "trustee-operator.v0.1.0"
+        }
+    ]
+}
+{
+    "schema": "olm.bundle",
+    "name": "trustee-operator.v0.1.0",
+    "package": "trustee-operator",
+    "image": "registry.redhat.io/confidential-compute-attestation-tech-preview/trustee-operator-bundle@sha256:6ac8c6158f093acd2ff7edd39f1e28788b78f91ee83bb36763d21990276034a0",
+    "properties": [
+        {
+            "type": "olm.gvk",
+            "value": {
+                "group": "confidentialcontainers.org",
+                "kind": "KbsConfig",
+                "version": "v1alpha1"
+            }
+        },
+        {
+            "type": "olm.package",
+            "value": {
+                "packageName": "trustee-operator",
+                "version": "0.1.0"
+            }
+        },
+        {
+            "type": "olm.bundle.object",
+            "value": {
+                "data": "eyJhcGlWZXJzaW9uIjoiYXBpZXh0ZW5zaW9ucy5rOHMuaW8vdjEiLCJraW5kIjoiQ3VzdG9tUmVzb3VyY2VEZWZpbml0aW9uIiwibWV0YWRhdGEiOnsiYW5ub3RhdGlvbnMiOnsiY29udHJvbGxlci1nZW4ua3ViZWJ1aWxkZXIuaW8vdmVyc2lvbiI6InYwLjE0LjAifSwiY3JlYXRpb25UaW1lc3RhbXAiOm51bGwsIm5hbWUiOiJrYnNjb25maWdzLmNvbmZpZGVudGlhbGNvbnRhaW5lcnMub3JnIn0sInNwZWMiOnsiZ3JvdXAiOiJjb25maWRlbnRpYWxjb250YWluZXJzLm9yZyIsIm5hbWVzIjp7ImtpbmQiOiJLYnNDb25maWciLCJsaXN0S2luZCI6Iktic0NvbmZpZ0xpc3QiLCJwbHVyYWwiOiJrYnNjb25maWdzIiwic2luZ3VsYXIiOiJrYnNjb25maWcifSwic2NvcGUiOiJOYW1lc3BhY2VkIiwidmVyc2lvbnMiOlt7Im5hbWUiOiJ2MWFscGhhMSIsInNjaGVtYSI6eyJvcGVuQVBJVjNTY2hlbWEiOnsiZGVzY3JpcHRpb24iOiJLYnNDb25maWcgaXMgdGhlIFNjaGVtYSBmb3IgdGhlIGtic2NvbmZpZ3MgQVBJIiwicHJvcGVydGllcyI6eyJhcGlWZXJzaW9uIjp7ImRlc2NyaXB0aW9uIjoiQVBJVmVyc2lvbiBkZWZpbmVzIHRoZSB2ZXJzaW9uZWQgc2NoZW1hIG9mIHRoaXMgcmVwcmVzZW50YXRpb24gb2YgYW4gb2JqZWN0LlxuU2VydmVycyBzaG91bGQgY29udmVydCByZWNvZ25pemVkIHNjaGVtYXMgdG8gdGhlIGxhdGVzdCBpbnRlcm5hbCB2YWx1ZSwgYW5kXG5tYXkgcmVqZWN0IHVucmVjb2duaXplZCB2YWx1ZXMuXG5Nb3JlIGluZm86IGh0dHBzOi8vZ2l0Lms4cy5pby9jb21tdW5pdHkvY29udHJpYnV0b3JzL2RldmVsL3NpZy1hcmNoaXRlY3R1cmUvYXBpLWNvbnZlbnRpb25zLm1kI3Jlc291cmNlcyIsInR5cGUiOiJzdHJpbmcifSwia2luZCI6eyJkZXNjcmlwdGlvbiI6IktpbmQgaXMgYSBzdHJpbmcgdmFsdWUgcmVwcmVzZW50aW5nIHRoZSBSRVNUIHJlc291cmNlIHRoaXMgb2JqZWN0IHJlcHJlc2VudHMuXG5TZXJ2ZXJzIG1heSBpbmZlciB0aGlzIGZyb20gdGhlIGVuZHBvaW50IHRoZSBjbGllbnQgc3VibWl0cyByZXF1ZXN0cyB0by5cbkNhbm5vdCBiZSB1cGRhdGVkLlxuSW4gQ2FtZWxDYXNlLlxuTW9yZSBpbmZvOiBodHRwczovL2dpdC5rOHMuaW8vY29tbXVuaXR5L2NvbnRyaWJ1dG9ycy9kZXZlbC9zaWctYXJjaGl0ZWN0dXJlL2FwaS1jb252ZW50aW9ucy5tZCN0eXBlcy1raW5kcyIsInR5cGUiOiJzdHJpbmcifSwibWV0YWRhdGEiOnsidHlwZSI6Im9iamVjdCJ9LCJzcGVjIjp7ImRlc2NyaXB0aW9uIjoiS2JzQ29uZmlnU3BlYyBkZWZpbmVzIHRoZSBkZXNpcmVkIHN0YXRlIG9mIEtic0NvbmZpZyIsInByb3BlcnRpZXMiOnsiS2JzRW52VmFycyI6eyJhZGRpdGlvbmFsUHJvcGVydGllcyI6eyJ0eXBlIjoic3RyaW5nIn0sImRlc2NyaXB0aW9uIjoiS2JzRW52VmFycyBpbmplY3RzIGVudmlyb25tZW50IHZhcmlhYmxlcyBpbiB0aGUgdHJ1c3RlZSBwb2RzXG5Gb3IgZXhhbXBsZSwgUlVTVF9MT0c9ZGVidWcgZW5hYmxlcyBsb2dnaW5nIHdpdGggREVCVUcgc2V2ZXJpdHkiLCJ0eXBlIjoib2JqZWN0In0sImlibVNFQ29uZmlnU3BlYyI6eyJkZXNjcmlwdGlvbiI6IklibVNFQ29uZmlnU3BlYyBpcyB0aGUgc3RydWN0IHRoYXQgaG9zdHMgdGhlIElCTVNFIHNwZWNpZmljIGNvbmZpZ3VyYXRpb24iLCJwcm9wZXJ0aWVzIjp7ImNlcnRTdG9yZVB2YyI6eyJkZXNjcmlwdGlvbiI6ImNlcnRTdG9yZVB2YyBpcyB0aGUgbmFtZSBvZiB0aGUgUGVyaXN0ZW50Vm9sdW1lQ2xhaW0gd2hlcmUgY2VydGlmaWNhdGVzL2tleXMgYXJlIG1vdW50ZWQiLCJ0eXBlIjoic3RyaW5nIn19LCJ0eXBlIjoib2JqZWN0In0sImtic0FzQ29uZmlnTWFwTmFtZSI6eyJkZXNjcmlwdGlvbiI6Iktic0FzQ29uZmlnTWFwTmFtZSBpcyB0aGUgbmFtZSBvZiB0aGUgY29uZmlnbWFwIHRoYXQgY29udGFpbnMgdGhlIEtCUyBBUyBjb25maWd1cmF0aW9uXG5SZXF1aXJlZCBvbmx5IHdoZW4gTWljcm9zZXJ2aWNlc0RlcGxveW1lbnQgaXMgc2V0IiwidHlwZSI6InN0cmluZyJ9LCJrYnNBdHRlc3RhdGlvblBvbGljeUNvbmZpZ01hcE5hbWUiOnsiZGVzY3JpcHRpb24iOiJLYnNBdHRlc3RhdGlvblBvbGljeUNvbmZpZ01hcE5hbWUgaXMgdGhlIG5hbWUgb2YgdGhlIGNvbmZpZ21hcCB0aGF0IGNvbnRhaW5zIHRoZSBBdHRlc3RhdGlvbiBQb2xpY3kiLCJ0eXBlIjoic3RyaW5nIn0sImtic0F1dGhTZWNyZXROYW1lIjp7ImRlc2NyaXB0aW9uIjoiS2JzQXV0aFNlY3JldE5hbWUgaXMgdGhlIG5hbWUgb2YgdGhlIHNlY3JldCB0aGF0IGNvbnRhaW5zIHRoZSBLQlMgYXV0aCBzZWNyZXQiLCJ0eXBlIjoic3RyaW5nIn0sImtic0NvbmZpZ01hcE5hbWUiOnsiZGVzY3JpcHRpb24iOiJLYnNDb25maWdNYXBOYW1lIGlzIHRoZSBuYW1lIG9mIHRoZSBjb25maWdtYXAgdGhhdCBjb250YWlucyB0aGUgS0JTIGNvbmZpZ3VyYXRpb24iLCJ0eXBlIjoic3RyaW5nIn0sImtic0RlcGxveW1lbnRUeXBlIjp7ImRlc2NyaXB0aW9uIjoiS2JzRGVwbG95bWVudFR5cGUgaXMgdGhlIHR5cGUgb2YgS0JTIGRlcGxveW1lbnRcbkl0IGNhbiBhc3N1bWUgb25lIG9mIHRoZSBmb2xsb3dpbmcgdmFsdWVzOlxuICAgQWxsSW5PbmVEZXBsb3ltZW50OiBhbGwgdGhlIEtCUyBjb21wb25lbnRzIHdpbGwgYmUgZGVwbG95ZWQgaW4gdGhlIHNhbWUgY29udGFpbmVyXG4gICBNaWNyb3NlcnZpY2VzRGVwbG95bWVudDogYWxsIHRoZSBLQlMgY29tcG9uZW50cyB3aWxsIGJlIGRlcGxveWVkIGluIHNlcGFyYXRlIGNvbnRhaW5lcnNcbkRlZmF1bHQgdmFsdWUgaXMgQWxsSW5PbmVEZXBsb3ltZW50IiwiZW51bSI6WyJBbGxJbk9uZURlcGxveW1lbnQiLCJNaWNyb3NlcnZpY2VzRGVwbG95bWVudCJdLCJ0eXBlIjoic3RyaW5nIn0sImtic0h0dHBzQ2VydFNlY3JldE5hbWUiOnsiZGVzY3JpcHRpb24iOiJLYnNIdHRwc0NlcnRTZWNyZXROYW1lIGlzIHRoZSBuYW1lIG9mIHRoZSBzZWNyZXQgdGhhdCBjb250YWlucyB0aGUgS0JTIGh0dHBzIGNlcnRpZmljYXRlIiwidHlwZSI6InN0cmluZyJ9LCJrYnNIdHRwc0tleVNlY3JldE5hbWUiOnsiZGVzY3JpcHRpb24iOiJLYnNIdHRwc0tleVNlY3JldE5hbWUgaXMgdGhlIG5hbWUgb2YgdGhlIHNlY3JldCB0aGF0IGNvbnRhaW5zIHRoZSBLQlMgaHR0cHMgcHJpdmF0ZSBrZXkiLCJ0eXBlIjoic3RyaW5nIn0sImtic1Jlc291cmNlUG9saWN5Q29uZmlnTWFwTmFtZSI6eyJkZXNjcmlwdGlvbiI6Iktic1Jlc291cmNlUG9saWN5Q29uZmlnTWFwTmFtZSBpcyB0aGUgbmFtZSBvZiB0aGUgY29uZmlnbWFwIHRoYXQgY29udGFpbnMgdGhlIFJlc291cmNlIFBvbGljeSIsInR5cGUiOiJzdHJpbmcifSwia2JzUnZwc0NvbmZpZ01hcE5hbWUiOnsiZGVzY3JpcHRpb24iOiJLYnNSdnBzQ29uZmlnTWFwTmFtZSBpcyB0aGUgbmFtZSBvZiB0aGUgY29uZmlnbWFwIHRoYXQgY29udGFpbnMgdGhlIEtCUyBSVlBTIGNvbmZpZ3VyYXRpb25cblJlcXVpcmVkIG9ubHkgd2hlbiBNaWNyb3NlcnZpY2VzRGVwbG95bWVudCBpcyBzZXQiLCJ0eXBlIjoic3RyaW5nIn0sImtic1J2cHNSZWZWYWx1ZXNDb25maWdNYXBOYW1lIjp7ImRlc2NyaXB0aW9uIjoia2JzUnZwc1JlZlZhbHVlc0NvbmZpZ01hcE5hbWUgaXMgdGhlIG5hbWUgb2YgdGhlIGNvbmZpZ21hcCB0aGF0IGNvbnRhaW5zIHRoZSBSVlBTIHJlZmVyZW5jZSB2YWx1ZXMiLCJ0eXBlIjoic3RyaW5nIn0sImtic1NlY3JldFJlc291cmNlcyI6eyJkZXNjcmlwdGlvbiI6Iktic1NlY3JldFJlc291cmNlcyBpcyBhbiBhcnJheSBvZiBzZWNyZXQgbmFtZXMgdGhhdCBjb250YWluIHRoZSBrZXlzIHJlcXVpcmVkIGJ5IGNsaWVudHMiLCJpdGVtcyI6eyJ0eXBlIjoic3RyaW5nIn0sInR5cGUiOiJhcnJheSJ9LCJrYnNTZXJ2aWNlVHlwZSI6eyJkZXNjcmlwdGlvbiI6Iktic1NlcnZpY2VUeXBlIGlzIHRoZSB0eXBlIG9mIHNlcnZpY2UgdG8gY3JlYXRlIGZvciBLQlNcbkRlZmF1bHQgdmFsdWUgaXMgQ2x1c3RlcklQIiwidHlwZSI6InN0cmluZyJ9LCJ0ZHhDb25maWdTcGVjIjp7ImRlc2NyaXB0aW9uIjoiVGR4Q29uZmlnU3BlYyBpcyB0aGUgc3RydWN0IHRoYXQgaG9zdHMgdGhlIFREWCBzcGVjaWZpYyBjb25maWd1cmF0aW9uIiwicHJvcGVydGllcyI6eyJrYnNUZHhDb25maWdNYXBOYW1lIjp7ImRlc2NyaXB0aW9uIjoia2JzVGR4Q29uZmlnTWFwTmFtZSBpcyB0aGUgbmFtZSBvZiB0aGUgY29uZmlnbWFwIGNvbnRhaW5pbmcgc2d4X2RlZmF1bHRfcWNubC5jb25mIGZpbGUiLCJ0eXBlIjoic3RyaW5nIn19LCJ0eXBlIjoib2JqZWN0In19LCJ0eXBlIjoib2JqZWN0In0sInN0YXR1cyI6eyJkZXNjcmlwdGlvbiI6Iktic0NvbmZpZ1N0YXR1cyBkZWZpbmVzIHRoZSBvYnNlcnZlZCBzdGF0ZSBvZiBLYnNDb25maWciLCJwcm9wZXJ0aWVzIjp7ImlzUmVhZHkiOnsiZGVzY3JpcHRpb24iOiJJc1JlYWR5IGlzIHRydWUgd2hlbiB0aGUgS0JTIGNvbmZpZ3VyYXRpb24gaXMgcmVhZHkiLCJ0eXBlIjoiYm9vbGVhbiJ9fSwidHlwZSI6Im9iamVjdCJ9fSwidHlwZSI6Im9iamVjdCJ9fSwic2VydmVkIjp0cnVlLCJzdG9yYWdlIjp0cnVlLCJzdWJyZXNvdXJjZXMiOnsic3RhdHVzIjp7fX19XX0sInN0YXR1cyI6eyJhY2NlcHRlZE5hbWVzIjp7ImtpbmQiOiIiLCJwbHVyYWwiOiIifSwiY29uZGl0aW9ucyI6bnVsbCwic3RvcmVkVmVyc2lvbnMiOm51bGx9fQ=="
+            }
+        },
+        {
+            "type": "olm.bundle.object",
+            "value": {
+                "data": "{"apiVersion":"operators.coreos.com/v1alpha1","kind":"ClusterServiceVersion","metadata":{"annotations":{"alm-examples":"[]","capabilities":"Basic Install","categories":"Security","containerImage":"registry.redhat.io/confidential-compute-attestation-tech-preview/trustee-rhel9-operator@sha256:3dde530418ef436113e7d431067367a98faf7e171edca1f4c55eda2bb34f9618","createdAt":"2024-06-07T10:06:06Z","features.operators.openshift.io/cnf":"false","features.operators.openshift.io/cni":"false","features.operators.openshift.io/csi":"false","features.operators.openshift.io/disconnected":"true","features.operators.openshift.io/fips-compliant":"false","features.operators.openshift.io/proxy-aware":"false","features.operators.openshift.io/tls-profiles":"false","features.operators.openshift.io/token-auth-aws":"false","features.operators.openshift.io/token-auth-azure":"false","features.operators.openshift.io/token-auth-gcp":"false","operatorframework.io/suggested-namespace":"trustee-operator-system","operators.openshift.io/valid-subscription":"[\"OpenShift Container Platform\", \"OpenShift Platform Plus\"]","operators.operatorframework.io/builder":"operator-sdk-v1.33.0","operators.operatorframework.io/project_layout":"go.kubebuilder.io/v4","repository":"https://github.com/openshift/trustee-operator"},"labels":{"operatorframework.io/arch.amd64":"supported","operatorframework.io/arch.s390x":"supported","operatorframework.io/os.linux":"supported"},"name":"trustee-operator.v0.1.0","namespace":"placeholder"},"spec":{"apiservicedefinitions":{},"customresourcedefinitions":{"owned":[{"description":"KbsConfig is the Schema for the kbsconfigs API","displayName":"Kbs Config","kind":"KbsConfig","name":"kbsconfigs.confidentialcontainers.org","version":"v1alpha1"}]},"description":"Remote attestation operator for confidential containers","displayName":"confidential compute attestation","icon":[{"base64data":"PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyNTguNTEgMjU4LjUxIj48ZGVmcz48c3R5bGU+LmNscy0xe2ZpbGw6I2QxZDFkMTt9LmNscy0ye2ZpbGw6IzhkOGQ4Zjt9PC9zdHlsZT48L2RlZnM+PHRpdGxlPkFzc2V0IDQ8L3RpdGxlPjxnIGlkPSJMYXllcl8yIiBkYXRhLW5hbWU9IkxheWVyIDIiPjxnIGlkPSJMYXllcl8xLTIiIGRhdGEtbmFtZT0iTGF5ZXIgMSI+PHBhdGggY2xhc3M9ImNscy0xIiBkPSJNMTI5LjI1LDIwQTEwOS4xLDEwOS4xLDAsMCwxLDIwNi40LDIwNi40LDEwOS4xLDEwOS4xLDAsMSwxLDUyLjExLDUyLjExLDEwOC40NSwxMDguNDUsMCwwLDEsMTI5LjI1LDIwbTAtMjBoMEM1OC4xNiwwLDAsNTguMTYsMCwxMjkuMjVIMGMwLDcxLjA5LDU4LjE2LDEyOS4yNiwxMjkuMjUsMTI5LjI2aDBjNzEuMDksMCwxMjkuMjYtNTguMTcsMTI5LjI2LTEyOS4yNmgwQzI1OC41MSw1OC4xNiwyMDAuMzQsMCwxMjkuMjUsMFoiLz48cGF0aCBjbGFzcz0iY2xzLTIiIGQ9Ik0xNzcuNTQsMTAzLjQxSDE0MS42NkwxNTQuOSw2NS43NmMxLjI1LTQuNC0yLjMzLTguNzYtNy4yMS04Ljc2SDEwMi45M2E3LjMyLDcuMzIsMCwwLDAtNy40LDZsLTEwLDY5LjYxYy0uNTksNC4xNywyLjg5LDcuODksNy40LDcuODloMzYuOUwxMTUuNTUsMTk3Yy0xLjEyLDQuNDEsMi40OCw4LjU1LDcuMjQsOC41NWE3LjU4LDcuNTgsMCwwLDAsNi40Ny0zLjQ4TDE4NCwxMTMuODVDMTg2Ljg2LDEwOS4yNCwxODMuMjksMTAzLjQxLDE3Ny41NCwxMDMuNDFaIi8+PC9nPjwvZz48L3N2Zz4=","mediatype":"image/svg+xml"}],"install":{"spec":{"clusterPermissions":[{"rules":[{"apiGroups":[""],"resources":["configmaps"],"verbs":["get","list","watch"]},{"apiGroups":[""],"resources":["namespaces"],"verbs":["get","update"]},{"apiGroups":[""],"resources":["secrets"],"verbs":["get","list","watch"]},{"apiGroups":["apps"],"resources":["deployments"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["confidentialcontainers.org"],"resources":["kbsconfigs"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["confidentialcontainers.org"],"resources":["kbsconfigs/finalizers"],"verbs":["update"]},{"apiGroups":["confidentialcontainers.org"],"resources":["kbsconfigs/status"],"verbs":["get","patch","update"]},{"apiGroups":[""],"resources":["services"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["authentication.k8s.io"],"resources":["tokenreviews"],"verbs":["create"]},{"apiGroups":["authorization.k8s.io"],"resources":["subjectaccessreviews"],"verbs":["create"]}],"serviceAccountName":"trustee-operator-controller-manager"}],"deployments":[{"label":{"app.kubernetes.io/component":"manager","app.kubernetes.io/created-by":"trustee-operator","app.kubernetes.io/instance":"controller-manager","app.kubernetes.io/managed-by":"kustomize","app.kubernetes.io/name":"deployment","app.kubernetes.io/part-of":"trustee-operator","control-plane":"controller-manager"},"name":"trustee-operator-controller-manager","spec":{"replicas":1,"selector":{"matchLabels":{"control-plane":"controller-manager"}},"strategy":{},"template":{"metadata":{"annotations":{"kubectl.kubernetes.io/default-container":"manager"},"labels":{"control-plane":"controller-manager"}},"spec":{"affinity":{"nodeAffinity":{"requiredDuringSchedulingIgnoredDuringExecution":{"nodeSelectorTerms":[{"matchExpressions":[{"key":"kubernetes.io/arch","operator":"In","values":["amd64","arm64","ppc64le","s390x"]},{"key":"kubernetes.io/os","operator":"In","values":["linux"]}]}]}}},"containers":[{"args":["--secure-listen-address=0.0.0.0:8443","--upstream=http://127.0.0.1:8080/","--logtostderr=true","--v=0"],"image":"registry.redhat.io/openshift4/ose-kube-rbac-proxy-rhel9","name":"kube-rbac-proxy","ports":[{"containerPort":8443,"name":"https","protocol":"TCP"}],"resources":{"limits":{"cpu":"500m","memory":"128Mi"},"requests":{"cpu":"5m","memory":"64Mi"}},"securityContext":{"allowPrivilegeEscalation":false,"capabilities":{"drop":["ALL"]}}},{"args":["--health-probe-bind-address=:8081","--metrics-bind-address=127.0.0.1:8080","--leader-elect"],"command":["/manager"],"env":[{"name":"POD_NAMESPACE","valueFrom":{"fieldRef":{"fieldPath":"metadata.namespace"}}},{"name":"KBS_IMAGE_NAME","value":"registry.redhat.io/confidential-compute-attestation-tech-preview/trustee-rhel9@sha256:db1fa9dc95ed524a8b65f0c906d969f879232a4dc05dbda9cccbb39fc111cfc8"},{"name":"AS_IMAGE_NAME","value":"ghcr.io/confidential-containers/staged-images/coco-as-grpc:latest"},{"name":"RVPS_IMAGE_NAME","value":"ghcr.io/confidential-containers/staged-images/rvps:latest"}],"image":"registry.redhat.io/confidential-compute-attestation-tech-preview/trustee-rhel9-operator@sha256:3dde530418ef436113e7d431067367a98faf7e171edca1f4c55eda2bb34f9618","livenessProbe":{"httpGet":{"path":"/healthz","port":8081},"initialDelaySeconds":15,"periodSeconds":20},"name":"manager","readinessProbe":{"httpGet":{"path":"/readyz","port":8081},"initialDelaySeconds":5,"periodSeconds":10},"resources":{"limits":{"cpu":"500m","memory":"128Mi"},"requests":{"cpu":"10m","memory":"64Mi"}},"securityContext":{"allowPrivilegeEscalation":false,"capabilities":{"drop":["ALL"]}}}],"securityContext":{"runAsNonRoot":true},"serviceAccountName":"trustee-operator-controller-manager","terminationGracePeriodSeconds":10}}}}],"permissions":[{"rules":[{"apiGroups":[""],"resources":["configmaps"],"verbs":["get","list","watch","create","update","patch","delete"]},{"apiGroups":["coordination.k8s.io"],"resources":["leases"],"verbs":["get","list","watch","create","update","patch","delete"]},{"apiGroups":[""],"resources":["events"],"verbs":["create","patch"]}],"serviceAccountName":"trustee-operator-controller-manager"}]},"strategy":"deployment"},"installModes":[{"supported":true,"type":"OwnNamespace"},{"supported":true,"type":"SingleNamespace"},{"supported":false,"type":"MultiNamespace"},{"supported":false,"type":"AllNamespaces"}],"keywords":["trustee","Confidential Computing","Attestation"],"links":[{"name":"confidential compute attestation","url":"https://github.com/openshift/trustee-operator"}],"maintainers":[{"email":"support@redhat.com","name":"Red Hat"}],"maturity":"beta","provider":{"name":"Red Hat"},"version":"0.1.0"}}"
+            }
+        },
+        {
+            "type": "olm.bundle.object",
+            "value": {
+                "data": "eyJhcGlWZXJzaW9uIjoicmJhYy5hdXRob3JpemF0aW9uLms4cy5pby92MSIsImtpbmQiOiJDbHVzdGVyUm9sZSIsIm1ldGFkYXRhIjp7ImNyZWF0aW9uVGltZXN0YW1wIjpudWxsLCJsYWJlbHMiOnsiYXBwLmt1YmVybmV0ZXMuaW8vY29tcG9uZW50Ijoia3ViZS1yYmFjLXByb3h5IiwiYXBwLmt1YmVybmV0ZXMuaW8vY3JlYXRlZC1ieSI6InRydXN0ZWUtb3BlcmF0b3IiLCJhcHAua3ViZXJuZXRlcy5pby9pbnN0YW5jZSI6Im1ldHJpY3MtcmVhZGVyIiwiYXBwLmt1YmVybmV0ZXMuaW8vbWFuYWdlZC1ieSI6Imt1c3RvbWl6ZSIsImFwcC5rdWJlcm5ldGVzLmlvL25hbWUiOiJjbHVzdGVycm9sZSIsImFwcC5rdWJlcm5ldGVzLmlvL3BhcnQtb2YiOiJ0cnVzdGVlLW9wZXJhdG9yIn0sIm5hbWUiOiJ0cnVzdGVlLW9wZXJhdG9yLW1ldHJpY3MtcmVhZGVyIn0sInJ1bGVzIjpbeyJub25SZXNvdXJjZVVSTHMiOlsiL21ldHJpY3MiXSwidmVyYnMiOlsiZ2V0Il19XX0="
+            }
+        },
+        {
+            "type": "olm.bundle.object",
+            "value": {
+                "data": "eyJhcGlWZXJzaW9uIjoidjEiLCJraW5kIjoiU2VydmljZSIsIm1ldGFkYXRhIjp7ImNyZWF0aW9uVGltZXN0YW1wIjpudWxsLCJsYWJlbHMiOnsiYXBwLmt1YmVybmV0ZXMuaW8vY29tcG9uZW50Ijoia3ViZS1yYmFjLXByb3h5IiwiYXBwLmt1YmVybmV0ZXMuaW8vY3JlYXRlZC1ieSI6InRydXN0ZWUtb3BlcmF0b3IiLCJhcHAua3ViZXJuZXRlcy5pby9pbnN0YW5jZSI6ImNvbnRyb2xsZXItbWFuYWdlci1tZXRyaWNzLXNlcnZpY2UiLCJhcHAua3ViZXJuZXRlcy5pby9tYW5hZ2VkLWJ5Ijoia3VzdG9taXplIiwiYXBwLmt1YmVybmV0ZXMuaW8vbmFtZSI6InNlcnZpY2UiLCJhcHAua3ViZXJuZXRlcy5pby9wYXJ0LW9mIjoidHJ1c3RlZS1vcGVyYXRvciIsImNvbnRyb2wtcGxhbmUiOiJjb250cm9sbGVyLW1hbmFnZXIifSwibmFtZSI6InRydXN0ZWUtb3BlcmF0b3ItY29udHJvbGxlci1tYW5hZ2VyLW1ldHJpY3Mtc2VydmljZSJ9LCJzcGVjIjp7InBvcnRzIjpbeyJuYW1lIjoiaHR0cHMiLCJwb3J0Ijo4NDQzLCJwcm90b2NvbCI6IlRDUCIsInRhcmdldFBvcnQiOiJodHRwcyJ9XSwic2VsZWN0b3IiOnsiY29udHJvbC1wbGFuZSI6ImNvbnRyb2xsZXItbWFuYWdlciJ9fSwic3RhdHVzIjp7ImxvYWRCYWxhbmNlciI6e319fQ=="
+            }
+        }
+    ],
+    "relatedImages": [
+        {
+            "name": "",
+            "image": "registry.redhat.io/confidential-compute-attestation-tech-preview/trustee-operator-bundle@sha256:6ac8c6158f093acd2ff7edd39f1e28788b78f91ee83bb36763d21990276034a0"
+        },
+        {
+            "name": "",
+            "image": "registry.redhat.io/confidential-compute-attestation-tech-preview/trustee-rhel9-operator@sha256:3dde530418ef436113e7d431067367a98faf7e171edca1f4c55eda2bb34f9618"
+        },
+        {
+            "name": "",
+            "image": "registry.redhat.io/openshift4/ose-kube-rbac-proxy-rhel9"
+        }
+    ]
+}