diff --git a/content/en/docs/creating-addons/top-level-operator/addon-package.md b/content/en/docs/creating-addons/top-level-operator/addon-package.md index 6c0d0784..d2dc5a23 100644 --- a/content/en/docs/creating-addons/top-level-operator/addon-package.md +++ b/content/en/docs/creating-addons/top-level-operator/addon-package.md @@ -3,16 +3,21 @@ title: Plug and Play Addon linkTitle: Plug and Play Addon --- -## Package +## Package Operator -Each addon that includes a `packageOperator` defined in its `spec`, will have a corresponding +Package Operator is a Kubernetes Operator for packaging and managing a collection of arbitrary Kubernetes objects. + +Each addon with a `packageOperator` defined in its `spec` will have a corresponding [ClusterObjectTemplate](https://package-operator.run/docs/getting_started/api-reference/#clusterobjecttemplate). -However, regular users typically do not need to directly interact with the `ClusterObjectTemplate`. -Instead, they can interact with the resulting +The ClusterObjectTemplate is an API defined in Package +Operator, enabling users to create an object by templating a + manifest and injecting values retrieved from other arbitrary source objects. +However, regular users typically do not need to interact with the `ClusterObjectTemplate`. +Instead, they can interact with the generated [ClusterPackage](https://package-operator.run/docs/getting_started/api-reference/#clusterpackage) -manifest that is generated from it. +manifest. -Example `ClusterPackage` manifest: +**Example of a `ClusterPackage` manifest:** ```shell apiVersion: package-operator.run/v1alpha1 @@ -34,17 +39,15 @@ spec: targetNamespace: pko-test-ns-00-req-apy-dsy-pdy ``` -The `deadMansSnitchUrl` and the `pagerDutyKey` are obtained -from the ConfigMaps with their default names and locations, -as documented in the -[addons deadMansSnitch](https://mt-sre.github.io/docs/creating-addons/monitoring/deadmanssnitch_integration/) -and -the [addons pagerDuty](https://mt-sre.github.io/docs/creating-addons/monitoring/pagerduty_integration/) documentation. - -**IMPORTANT:** To successfully inject the `deadMansSnitchUrl` and `pagerDutyKey` values, +* The `deadMansSnitchUrl` and `pagerDutyKey` are obtained +from the ConfigMaps using their default names and locations. +**IMPORTANT:** To successfully inject the `deadMansSnitchUrl` and `pagerDutyKey` values into the `ClusterPackage` manifest, you must keep the default naming scheme and location of the corresponding ConfigMaps. +See the [addons deadMansSnitch](https://mt-sre.github.io/docs/creating-addons/monitoring/deadmanssnitch_integration/) +and [addons pagerDuty](https://mt-sre.github.io/docs/creating-addons/monitoring/pagerduty_integration/) +documentation for more information. -Additionally, all the values present in `.spec.config.addonsv1` +* Additionally, all the values present in `.spec.config.addonsv1` can be injected into the objects within your packageImage. See the [package operator](https://package-operator.run/docs/guides/packaging-an-application/#go-templates) @@ -52,9 +55,9 @@ documentation for more information. ## Tenants Onboarding Steps -You can generate the packageImage yourself using the -[package operator](https://package-operator.run/docs/guides/packaging-an-application/#build--validate) documentation. -However, we recommend you use the Managed Tenants Bundles (MTB) facilities. +Although you can generate the packageImage yourself using the +[package operator](https://package-operator.run/docs/guides/packaging-an-application/#build--validate) documentation, +we recommend you use the Managed Tenants Bundles (MTB) facilities. The following steps are an example of generating the packageImage for the reference-addon package using the MTB flow: