runtimes-inventory-operator
This project aims to provide a reusable component for Red Hat operators managing Java workloads.
This component allows these operators to more easily integrate their workloads into the Red Hat Insights
Runtimes Inventory.
Description
Containers running in OpenShift that support either the Insights Java Client
or its corresponding Java Agent, will attempt to send reports to Red Hat Insights.
Doing so requires authentication to associate the report with a particular Red Hat customer. On OpenShift, these containers will likely not have
the means to obtain this authentication information when sending their reports.
This component allows operators for Red Hat products to create and manage an APICast HTTP proxy,
configured with the necessary authentication information.
If the workload containers are configured to send their Insights reports to the proxy, they do not need to authenticate themselves.
The proxy is created using authentication information obtained from the OpenShift cluster that uniquely identifies it as belonging to a particular
customer.
Getting Started
Environment Variables
The following are required environment variables your operator must set:
RELATED_IMAGE_INSIGHTS_PROXY
: the container image to be used for the APICast proxy (e.g. registry.redhat.io/3scale-amp2/apicast-gateway-rhel8:3scale2.14
)
INSIGHTS_BACKEND_DOMAIN
: the Red Hat Insights server host where reports will be forwarded (e.g. console.redhat.com
)
INSIGHTS_ENABLED
: must be set to true
in order for this component to run, this provides an opt-out mechanism for customers at the operator level
When running this controller as a container image, these environment variables must also be set:
OPERATOR_NAME
: the name of the operator controller's deployment
OPERATOR_NAMESPACE
: the namespace where the operator controller lives, best obtained using the Kubernetes downward API
USER_AGENT_PREFIX
: the UHC Auth Proxy approved User-Agent prefix, of the form operator-name/x.y.z
, where x.y.z is your operator's version
Optionally set the following environment variable:
INSIGHTS_PROXY_DOMAIN
: only needed when testing against a staging Insights backend that requires a proxy to access
RBAC
Your operator will need to be run with the following permissions:
- Create, Get, List, Watch, Delete on Deployments, Services, Config Maps, Secrets in its own namespace
- Get, List, Watch on the OpenShift global pull secret:
pull-secret
in the openshift-config
namespace
- Get, List, Watch on the cluster-scoped ClusterVersion resource, named
version
UHC Auth Proxy
In order for Red Hat Insights to accept traffic from the proxy, the proxy must specify a User-Agent header
with an approved prefix. Ensure that your operator's name is added to the list of
approved prefixes.
Run as a Container Image (Option 1)
You’ll need an OpenShift cluster to run against. You can use CRC to get a local cluster for testing, or run against a remote cluster.
Note: Your controller will automatically use the current context in your kubeconfig file (i.e. whatever cluster oc cluster-info
shows).
Running on the cluster
- Build and push your image to the location specified by
IMG
:
make docker-build docker-push IMG=<some-registry>/runtimes-inventory-operator:tag
- Deploy the controller to the cluster with the image specified by
IMG
:
make deploy IMG=<some-registry>/runtimes-inventory-operator:tag
Undeploy controller
UnDeploy the controller from the cluster:
make undeploy
How it works
This project aims to follow the Kubernetes Operator pattern.
It uses Controllers,
which provide a reconcile function responsible for synchronizing resources until the desired state is reached on the cluster.
Test It Out
- Run your controller (this will run in the foreground, so switch to a new terminal if you want to leave it running):
make run
Modifying the API definitions
If you are editing the API definitions, generate the manifests such as CRs or CRDs using:
make manifests
NOTE: Run make --help
for more information on all potential make
targets
More information can be found via the Kubebuilder Documentation
Adding to your Manager (Option 2)
Inside your operator's main function, add this component by creating a new InsightsIntegration
and
call its Setup
method. You will need the following arguments:
- Your controller-runtime Manager
- The operator deployment's name and namespace, which can be obtained from the Kubernetes downward API
- The UHC Auth Proxy approved User-Agent prefix, of the form
operator-name/x.y.z
, where x.y.z is your operator's version
- Your Manager's logger
insightsURL, err := insights.NewInsightsIntegration(mgr,
operatorName, operatorNamespace, userAgentPrefix, &setupLog).Setup()
if err != nil {
setupLog.Error(err, "failed to set up Insights integration")
}
setupLog.Info("Insights proxy set up", "url", insightsURL.String())
This will add a new Insights Controller to your manager, which will be responsible for managing the proxy container.