{"id":20060661,"url":"https://github.com/mossabtn/quarkus-dynamic-multi-tenant","last_synced_at":"2025-07-31T16:19:06.927Z","repository":{"id":38486461,"uuid":"283557335","full_name":"MossabTN/quarkus-dynamic-multi-tenant","owner":"MossabTN","description":null,"archived":false,"fork":false,"pushed_at":"2023-01-07T20:37:02.000Z","size":3534,"stargazers_count":10,"open_issues_count":25,"forks_count":4,"subscribers_count":0,"default_branch":"master","last_synced_at":"2025-05-05T15:51:09.063Z","etag":null,"topics":["angular","keycloak","multitenant","quarkus"],"latest_commit_sha":null,"homepage":"","language":"Java","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/MossabTN.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2020-07-29T17:08:53.000Z","updated_at":"2024-05-17T10:20:50.000Z","dependencies_parsed_at":"2023-02-08T01:15:39.763Z","dependency_job_id":null,"html_url":"https://github.com/MossabTN/quarkus-dynamic-multi-tenant","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/MossabTN/quarkus-dynamic-multi-tenant","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/MossabTN%2Fquarkus-dynamic-multi-tenant","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/MossabTN%2Fquarkus-dynamic-multi-tenant/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/MossabTN%2Fquarkus-dynamic-multi-tenant/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/MossabTN%2Fquarkus-dynamic-multi-tenant/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/MossabTN","download_url":"https://codeload.github.com/MossabTN/quarkus-dynamic-multi-tenant/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/MossabTN%2Fquarkus-dynamic-multi-tenant/sbom","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":268069829,"owners_count":24190808,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-07-31T02:00:08.723Z","response_time":66,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["angular","keycloak","multitenant","quarkus"],"created_at":"2024-11-13T13:16:12.902Z","updated_at":"2025-07-31T16:19:06.863Z","avatar_url":"https://github.com/MossabTN.png","language":"Java","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Quarkus multi tenant\n\nIn this example, we build a very simple quarkus application:\n\n\n## Requirements\n\nTo compile and run this demo you will need:\n- JDK 1.8+\n- GraalVM\n- NodeJS\n\nMake sure you have this ports available\n- 80\n- 8080\n- 8180\n- 5432\n\n## Setup environment\n* Adding a host name in the /etc/hosts file\n```bash\nsudo gedit /etc/hosts\n\n#paste this hostnames#\n127.0.0.1       tenant1.maxilog.io\n127.0.0.1       tenant2.maxilog.io\n127.0.0.1       tenant3.maxilog.io\n```\n\n* To start a Keycloak Server,Nginx, Postgres  you can use Docker and just run the following command:\n```bash\ndocker-compose -f src/main/docker/docker-compose.yaml up -d\n```\n\nYou should be able to access your Keycloak Server at http://localhost:8180/auth .\n\nLog in as admin to access the Keycloak Administration Console.\nUsername should be `admin` and password `admin`.\n\nFor more details, see the Keycloak documentation about how to https://www.keycloak.org/docs/latest/server_admin/index.html#_create-realm[create a new realm].\n\n\n### Initialized Tenant\n\n###### keycloak realms:\n  - default:\n    - Clients : \n      - front\n      - back | back (backend)\n    - Users : \n      - admin | admin\n      - user | user \n  - tenant1:\n    - Clients : \n      - front\n      - back | back (backend)\n    - Users : \n      - admin | admin\n      - user | user  \n  - tenant2:\n    - Clients : \n      - front\n      - back | back (backend)\n    - Users : \n      - admin | admin\n      - user | user  \n\n###### Databases:\n  - default:\n    - maxilog-default: \n      - maxilog-default-user | maxilog-default-password\n  - tenant1:\n    - maxilog-tenant1: \n      - maxilog-tenant1-user | maxilog-tenant1-password\n  - tenant2:\n    - maxilog-tenant2: \n      - maxilog-tenant2-user | maxilog-tenant2-password\n\n### Get an access token\nChange `REALM`, `USERNAME` and `PASSWORD` by the information of the realm you want to connect :\n```bash\nexport access_token=$(\\\n    curl -X POST http://localhost:8180/auth/realms/REALM/protocol/openid-connect/token \\\n    --header 'Content-Type: application/x-www-form-urlencoded' \\\n    --data-urlencode 'username=USERNAME' \\\n    --data-urlencode 'password=PASSWORD' \\\n    --data-urlencode 'client_id=front' \\\n    --data-urlencode 'grant_type=password' | jq --raw-output '.access_token' \\\n )\n````\n\nExample :\n\n```bash\nexport access_token=$(\\\n    curl -X POST http://localhost:8180/auth/realms/tenant1/protocol/openid-connect/token \\\n    --header 'Content-Type: application/x-www-form-urlencoded' \\\n    --data-urlencode 'username=admin' \\\n    --data-urlencode 'password=admin' \\\n    --data-urlencode 'client_id=front' \\\n    --data-urlencode 'grant_type=password' | jq --raw-output '.access_token' \\\n )\n```\n\n### Get your task list\nIf you get the token from `tenant1` realm :\n\n```bash\ncurl -X GET -v http://localhost:8080/api/tasks/me \\\n--header  \"x-tenant: tenant1\" \\\n--header  \"Authorization: Bearer $access_token\"\n```\n\n### Create new Tenant\nTo create new tenant you have to use `default` tenant.\n\nLet's create tenant named `tenant3`\n```bash\nexport access_token=$(\\\n    curl -X POST http://localhost:8180/auth/realms/default/protocol/openid-connect/token \\\n    --header 'Content-Type: application/x-www-form-urlencoded' \\\n    --data-urlencode 'username=admin' \\\n    --data-urlencode 'password=admin' \\\n    --data-urlencode 'client_id=front' \\\n    --data-urlencode 'grant_type=password' | jq --raw-output '.access_token' \\\n )\n \ncurl -X POST -v http://localhost:8080/api/tenants/tenant3 \\\n--header  \"x-tenant: default\" \\\n--header  \"Authorization: Bearer $access_token\"\n```\n\nThis command will create realm `tenant3` and database `maxilog-tenant3`.\n\nPS: In this case, you have to add hostname to `/etc/hosts` :\n\n`127.0.0.1       tenant3.maxilog.io`\n\n\n#### Backend(quarkus)\n\u003e ./mvnw compile quarkus:dev\n\nThis command will leave Quarkus running in the foreground listening on port 8080.\n\n#### Frontend(angular)\n```bash\ncd src/main/webapp/\nnpm install\nnpm start\n```\nYou should be able to access your angular app at `http://tenant1.maxilog.io` or `http://tenant2.maxilog.io`.\n\n![test](tenant1-ss.gif)\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmossabtn%2Fquarkus-dynamic-multi-tenant","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fmossabtn%2Fquarkus-dynamic-multi-tenant","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmossabtn%2Fquarkus-dynamic-multi-tenant/lists"}