ℹ️ The proxy is a work in progress.
Please check out the proxy README for more detailed information on how to use the proxy in your development process. You'll also find explanation and workaround for the things that are currently not working.
ℹ️ Environment settings are located in the file .env.local-api
.
- node needs to be installed. See nvmrc or the
engines
definition in package.json for version. - Coral uses pnpm (version 8) as a package manager. Read their official documentation how to install pnpm.
Step by step
- Navigate to
/coral
- Run
pnpm install
- Run
pnpm add-precommit
the first time you install the repository to set the custom directory for our pre commit hooks. - Go to directory
coral/proxy
- Run
pnpm install
there, too - Install and run Docker: Get Docker
- Go to directory
coral/proxy
- Run
pnpm install
if you haven't already - Run
pnpm run setup
to build and deploy your docker container for:- Klaw core: the main API Coral interacts with
- Klaw cluster api: the API interacting with the Kafka clusters managed by Klaw
- Kafka, zoo-keeper, schema-registry: a basic Kafka setup
- Run
pnmv dev:[start|restart]
- check out the documentation for more scripts and information when to use them.
- the proxy runs on
http://localhost:1337
- Login (❗️The correct redirect for login and authentication is not working in the proxy yet):
- Go to your local Klaw
- Login as superadmin with:
superadmin
, passwordwelcometoklaw
(see application.properties) - Go back to the proxy
- As superadmin, create one or more users proxy "User" and "superadmin" are roles that have authorization to different views and functionality. We're migrating the user views in Coral first, so you'll need to log in to Coral with a "user" account to have access to all functionality.
- As superadmin, add a cluster and environment - you can follow our official documentation
- When configuring Kafka clusters: the bootstrap server for Kafka cluster is running on
http://klaw-kafka:9092
in docker - When configuring schema registry: the bootstrap server for schema registry is running on
http://klaw-schema-registry:8081
in docker. - Do not forget to set the following configuration options in the settings (Dashboard -> settings)
- Cluster API URL (klaw.clusterapi.url):
http://klaw-cluster-api:9343
(running in docker) - Base sync cluster, order of topic promotion environments, topic request envs (klaw.tenant.config): you may copy the example provided, replacing the environment names with the ones you created. For example, if you have only created a
DEV
environment:
- Cluster API URL (klaw.clusterapi.url):
- When configuring Kafka clusters: the bootstrap server for Kafka cluster is running on
{
"tenantModel" : {
"tenantName" : "default",
"baseSyncEnvironment" : "DEV",
"orderOfTopicPromotionEnvsList" : [ "DEV" ],
"requestTopicsEnvironmentsList" : [ "DEV" ],
"baseSyncKafkaConnectCluster" : null,
"orderOfConnectorsPromotionEnvsList" : null,
"requestConnectorsEnvironmentsList" : null
}
}
- You are good to go! 🎉
The correct redirect for login and authentication is not working yet.
- Go to your local Klaw
- Login with your credentials
- After you've been sucessfully logged in, go back to the proxy ->
http://localhost:1337
Related to that the proxy currently also does not redirect you to the login if your access expires. If you're getting related errors from your API, please log in again like described above 🙏
The proxy and Klaw are running with http
. Your browser may show you an error (SSL connection error), because it tries to automatically upgrade to https, without making a http request for security. You have to allow localhost
to be accessed via http explicitly.
ℹ️ When you're done, you can run either:
pnpm dev:stop
to stop all containers in docker (enables a fast restart)pnpm dev:destroy
to tear down all containers in docker (you'll have to runpnpm run setup
orpnpm:start
again next time you want to use them, so they get build again)
If all requirements are met, and you've done your first setup, these are the scripts you can use in the directory /proxy
:
-
pnpm dev:start
to build and start your docker container for klaw and cluster api. This runs tests and build for Klaw, which takes some time. -
pnpm dev:start:testEnv
to build and start your docker container for klaw and cluster api as well as a sandbox with zookeeper, kafka and a schema-registry (note: these files are large!). Same as above, this will run tests and do a new build. -
pnpm dev:restart
to restart you container. Used when you already have build Klaw in a container and there are now changes. It restarts the container without new build. -
pnpm dev:restart:testEnv
to restart you container including sandbox. Same as above, this will not do a new build. -
pnpm:stop
to stop your running containers. -
pnpm:destroy
to stop and teardown your running containers (will require you to run :start the next time again). -
Please check out the proxy README for more detailed information and a deeper breakdown of all available scripts.