Tackle (2nd generation) UI component.
To install a Tackle2 cluster environment, refer to Tackle documentation.
- NodeJS >= 16.x
- minikube (optional): setup your local minikube instance with your container manager of choice. (Docker, Hyperkit, Hyper-V, KVM, Parallels, Podman, VirtualBox, or VMware Fusion/Workstation.)
To get started, clone the repo to your development workstation and install the required dependencies locally with NPM.
git clone https://github.com/konveyor/tackle2-ui
cd tackle2-ui
npm install
With an existing Tackle2 environment available, one can start a locally served tackle2-ui instance with:
npm run start:dev
With the UI project setup out of the way, you can now begin setting up you local Tackle2 dev environment. The preferred local development option is to setup a minikube instance. Alternatively, for information on general Kubernetes installation refer to Tackle2 operator readme file.
Minikube implements a local Kubernetes cluster on macOS, Linux, and Windows. See the minikube getting started guide here.
All you need to run minikube is Docker (or similarly compatible) container or a Virtual Machine environment.
By default, Minikube uses a driver with 6,000 MB of memory and 2 CPUs. This is not enough to run all the services, so we need to increase the allocated memory. In our experience, 10 GB of memory and 4 CPUs is fine:
$ minikube config set memory 10240
$ minikube config set cpus 4
From a terminal with administrator access (but not logged in as root), run:
$ minikube start --addons=dashboard --addons=ingress --addons=olm
Note: We need to enable the dashboard, ingress and olm addons. The dashboard addon installs the dashboard service that exposes the Kubernetes objects in a user interface. The ingress addon allows us to create Ingress CRs to expose the Tackle UI and Tackle Hub API. The olm addon allows us to use an operator to deploy Tackle.
You will need kubectl
on your PATH and configured to control minikube in order to proceed. There are two ways to set this up:
-
Install kubectl yourself
If you already have the
kubectl
CLI tool installed and available on your PATH, theminikube start
command should configure it to control the minikube cluster. You should see the following message when minikube starts if this worked correctly:🏄 Done! kubectl is now configured to use "minikube" cluster and "default" namespace by default
-
Use a shell alias for minikube's built-in kubectl
Minikube provides its own internal
kubectl
which you can use by runningminikube kubectl --
followed by your CLI arguments. If you want to use the built-inminikube kubectl
as thekubectl
on your PATH, you can set a shell alias. The following example shows how to do it for Bash on Fedora 35.$ mkdir -p ~/.bashrc.d $ cat << EOF > ~/.bashrc.d/minikube alias kubectl="minikube kubectl --" EOF $ source ~/.bashrc
The konveyor/operator git repository provides a script to install Tackle locally using kubectl
. You can inspect its source here. This script creates the konveyor-tackle
namespace, CatalogSource, OperatorGroup, Subscription and Tackle CR, then waits for deployments to be ready.
The install script provides optional environment variables you can use to customize the images and features used. See the source of the script for all available variables.
For example, if you wish to run tackle with keycloak authentication enabled, export the following variable before running the install script:
$ export TACKLE_FEATURE_AUTH_REQUIRED=true
Before proceeding, if you are on macOS you will need to use Homebrew to install the coreutils
package:
$ brew install coreutils
To run the install script (requires kubectl
on your PATH configured for minikube):
$ curl https://raw.githubusercontent.com/konveyor/operator/main/hack/install-tackle.sh | bash
Alternatively, you can clone the konveyor/operator git repository and run ./hack/install-tackle.sh
from your clone, or you can execute its commands manually.
NotFound
errors. You can safely ignore these. The script will wait 30 seconds to check for the CRD again before proceeding.
The installation is complete when the script outputs "condition met" messages and terminates.
Now that your environment is ready, navigate to your installed tackle-ui directory and run your development server:
$ cd tackle2-ui
$ npm run start:dev
Tackle2 runs in a Kubernetes compatible environment (Openshift, Kubernetes or minikube) and is usually deployed with Tackle2 Operator (OLM). Although the UI pod has access to tackle2 APIs from within the cluster, the UI can also be executed outside the cluster and access Tackle APIs endpoints by proxy.
The React and Patternfly based UI is composed of web pages served by an http server with proxy capabilities.
-
In production mode, Express (Node.js) plays the role of both UI server and proxy server (using http-proxy-middleware). Everything is served on port 8080. The
/auth
and/hub
routes are proxied to their services. All other routes serve the UI bundle where they are handled by react-router. -
In development mode, webpack-dev-server plays the role of UI server and Express plays the role of proxy server only. This allows webpack-dev-server to provide development features such as hot reload. The webpack-dev-server serves the UI on port 9000. The
/auth
and/hub
routes are forwarded to port 8080 for Express to handle.
The Express server/src/setupProxy.js proxies use the environment
variables TACKLE_HUB_URL
and SSO_SERVER_URL
to define the backend endpoints:
-
If the Tackle Hub variable
TACKLE_HUB_URL
is not defined, the URLhttp://localhost:9002
is used by default. -
If the Tackle Keycloak (SSO) variable
SSO_SERVER_URL
is not defined, the URLhttp://localhost:9001
is used by default.
To enable running the UI outside the cluster, port forwardings must be activated to route
the Tackle Keycloak (SSO) and Tackle Hub requests to the services on the cluster. Use
the script npm run port-forward
to easily start the forwards. The script npm run start:dev
will also setup port forwarding to all tackle2 services concurrently with starting the dev server.
To manually setup the kubectl port forwards, open a terminal and run each following command separately:
$ kubectl port-forward svc/tackle-keycloak-sso -n konveyor-tackle 9001:8080
$ kubectl port-forward svc/tackle-hub -n konveyor-tackle 9002:8080
Note: The npm run port-forward
or kubectl port-forward
commands need to remain running
for the ports to be available.
We may need to access the dashboard, either simply to see what's happening under the hood, or to
troubleshoot an issue. The dashboard addon is enabled in the default in recommended minikube start
command in the Minikube setup section.
There are two ways to setup access to the dashboard.
First, we can use the minikube dashboard
command. Use to following to open on an explicit
port and only show the URL instead of opening the default browser directly:
$ minikube dashboard --port=18080 --url=true
Second, we can use the kubectl proxy
command to enable access to the dashboard. The following
command sets up the proxy to listen on any network interface (useful for remote access), to the
18080/tcp port (easy to remember), and with requests filtering disabled (less secure, but necessary):
$ kubectl proxy --address=0.0.0.0 --port 18080 --disable-filter=true
We can now access the minikube dashboard through the proxy. Use the following URL as a template,
replacing the IP address with your workstation IP address:
http://192.168.0.1:18080/api/v1/namespaces/kubernetes-dashboard/services/http:kubernetes-dashboard:/proxy/#/
Note - The steps described are executed on a Fedora 35 workstation, but will likely work on any recent Linux distribution. The only prerequisites are to enable virtualization extensions in the BIOS/EFI of the machine, to install libvirt and to add our user to the libvirt group.
-
Ensure that your minikube installation directory is available in your
$PATH
environment variable. This is usually/usr/local/bin/
or something similar depending on your OS of choice. -
The following command gives us the IP address assigned to the virtual machine created by Minikube. It's used when interacting with tackle UI image installed on the minikube cluster.
$ minikube ip
192.168.39.23
Please read the Pull Request (PR) Process section of the Konveyor versioning and branching doc for more information.
- Use kebab-case for file names.
- The root page/parent level components are placed directly in their respective directories.
- Presentation layer components are placed within the
components/
subdirectory of the parent component.
We welcome contributions to this project! If you're interested in contributing, please read the konveyor/community CONTRIBUTING doc for more information on how to get started.
Refer to Konveyor's Code of Conduct page