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" + } + ] +}