A Functions-as-a-Service PoC UI for the OpenShift Web Console. Developers create, edit, and deploy serverless functions without CLI knowledge.
Built as an OpenShift Console dynamic plugin using React, TypeScript, and PatternFly 6.
Check out the Github page for a quick start or read ahead.
- oc CLI
- An OpenShift 4.19 cluster
- Github Personal Access Token with administration, content, secret and workflow write permissions in all repositories
oc new-project console-functions-plugin
oc apply -f https://functions-dev.github.io/ocp-console-plugin/plugin.yamlManual install (requires Helm)
oc new-project console-functions-plugin
helm upgrade -i console-functions-plugin charts/openshift-console-plugin \
-n console-functions-plugin --create-namespace \
--set "plugin.image=ghcr.io/functions-dev/ocp-console-plugin-functions-plugin:latest@sha256:<digest>"To deploy a specific build, use its git commit SHA as the tag:
--set "plugin.image=ghcr.io/functions-dev/ocp-console-plugin-functions-plugin:sha-<commit>"Available image tags are listed in the container registry. Consult the chart values file for additional parameters.
- Node.js (v18+)
- Yarn (v4)
- oc CLI
- Docker or podman 3.2.0+
- An OpenShift cluster
- Github Personal Access Token with administration, content and workflow write permissions in all repositories
- inotify-tools (optional, enables Go backend auto-recompile on file changes)
In one terminal window, run:
yarn installyarn run start
In another terminal window, run:
oc login(requires oc and an OpenShift cluster)yarn run start-console(requires Docker or podman 3.2.0+)
This will run the OpenShift console in a container connected to the cluster you've logged into. The plugin HTTP server runs on port 9001 with CORS enabled. Navigate to http://localhost:9000/example to see the running plugin.
If you are using podman on a Mac with Apple silicon, yarn run start-console
might fail since it runs an amd64 image. You can workaround the problem with
qemu-user-static by running
these commands:
podman machine ssh
sudo -i
rpm-ostree install qemu-user-static
systemctl rebootMake sure the Remote Containers extension is installed. This method uses Docker Compose where one container is the OpenShift console and the second container is the plugin. It requires that you have access to an existing OpenShift cluster. After the initial build, the cached containers will help you start developing in seconds.
- Create a
dev.envfile inside the.devcontainerfolder with the correct values for your cluster:
OC_PLUGIN_NAME=console-functions-plugin
OC_URL=https://api.example.com:6443
OC_USER=kubeadmin
OC_PASS=<password>(Ctrl+Shift+P) => Remote Containers: Open Folder in Container...yarn run start- Navigate to http://localhost:9000/example
Before you can deploy your plugin on a cluster, you must build an image and push it to an image registry.
-
Build the image:
docker build -t quay.io/my-repository/my-plugin:latest . -
Run the image:
docker run -it --rm -d -p 9001:80 quay.io/my-repository/my-plugin:latest
-
Push the image:
docker push quay.io/my-repository/my-plugin:latest
NOTE: If you have a Mac with Apple silicon, you will need to add the flag
--platform=linux/amd64 when building the image to target the correct platform
to run in-cluster.
The plugin uses react-i18next for translations. The i18n namespace must match
the name of the ConsolePlugin resource with the plugin__ prefix to avoid
naming conflicts. This plugin uses the
plugin__console-functions-plugin namespace. You can use the useTranslation hook
with this namespace as follows:
const Header: React.FC = () => {
const { t } = useTranslation('plugin__console-functions-plugin');
return <h1>{t('Hello, World!')}</h1>;
};For labels in console-extensions.json, you can use the format
%plugin__console-functions-plugin~My Label%. Console will replace the value with
the message for the current language from the plugin__console-functions-plugin
namespace. For example:
{
"type": "console.navigation/section",
"properties": {
"id": "functions-section",
"perspective": "admin",
"name": "%plugin__console-functions-plugin~Serverless Functions%"
}
}Running yarn i18n updates the JSON files in the locales folder when adding or changing messages.
This project adds prettier, eslint, and stylelint. Linting can be run with
yarn run lint.
The stylelint config disallows defining colors since these cause problems with dark mode. Use PatternFly semantic tokens for colors instead.
The stylelint config also disallows naked element selectors like table and
.pf- or .co- prefixed classes. This prevents plugins from accidentally
overwriting default console styles, breaking the layout of existing pages. The
best practice is to prefix your CSS class names with your plugin name to avoid
conflicts. Please don't disable these rules without understanding how they can
break console styles!
Steps to generate reports
- In command prompt, navigate to root folder and execute the command
yarn run cypress-merge - Then execute command
yarn run cypress-generateThe cypress-report.html file is generated and should be in (/integration-tests/screenshots) directory.