Skip to content

Latest commit

 

History

History
116 lines (87 loc) · 7.17 KB

development-with-local-klaw.md

File metadata and controls

116 lines (87 loc) · 7.17 KB

Development with local Klaw API

ℹ️ 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.

Table of content

First setup

ℹ️ Environment settings are located in the file .env.local-api.

⚠️ Requirements

  • 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

  1. Navigate to /coral
  2. Run pnpm install
  3. Run pnpm add-precommit the first time you install the repository to set the custom directory for our pre commit hooks.
  4. Go to directory coral/proxy
  5. Run pnpm install there, too
  6. Install and run Docker: Get Docker
  7. Go to directory coral/proxy
  8. Run pnpm install if you haven't already
  9. 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
  10. Run pnmv dev:[start|restart]
  11. 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.
  12. 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:
    {
        "tenantModel" : {
            "tenantName" : "default",
            "baseSyncEnvironment" : "DEV",
            "orderOfTopicPromotionEnvsList" : [ "DEV" ],
            "requestTopicsEnvironmentsList" : [ "DEV" ],
            "baseSyncKafkaConnectCluster" : null,
            "orderOfConnectorsPromotionEnvsList" : null,
            "requestConnectorsEnvironmentsList" : null
        }
    }
  1. You are good to go! 🎉

Note on login and authentication

The correct redirect for login and authentication is not working yet.

Login

gif showing the three steps described above

Authentication expired

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 🙏

gif showing a redirect error. Pressing the reload button of the browser while the authentication has expired. We see a loading spinner that does not stop. The network tab shows a successful call to getAuth and a failed call to login. The console shows an error log "Access to fetch at localhost:9097/login from origin http:localhost:1337 has been blocked by CORS policy.

gif showing a redirect error. Pressing the link to the topic details shows the page with a loading spinner running for some time. Then an error is show on the page with the error message "Failed to fetch." The network tab shows a successful calls to getTopicOverview and getSchemaOfTopic and failed calls to login. The console shows an error log "Access to fetch at localhost:9097/login from origin http:localhost:1337 has been blocked by CORS policy.

🙋Potential browser problem

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 run pnpm run setup or pnpm:start again next time you want to use them, so they get build again)

How to run the project

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.