From dfd925bf191d3dd7ca2d11960876f4668ea935bc Mon Sep 17 00:00:00 2001 From: gazarenkov Date: Thu, 24 Jul 2025 14:26:18 +0300 Subject: [PATCH] add profile --- profile/README.md | 52 +++++++++++ profile/compose.yaml | 51 +++++++++++ profile/rhdho/app-config/app-config.yaml | 90 +++++++++++++++++++ .../rhdho/catalog-entities/components.yaml | 15 ++++ profile/rhdho/catalog-entities/mkdocs.yml | 4 + profile/rhdho/catalog-entities/users.yaml | 14 +++ profile/rhdho/default.env | 1 + .../dynamic-plugins/dynamic-plugins.yaml | 42 +++++++++ profile/rhdho/services.yaml | 16 ++++ 9 files changed, 285 insertions(+) create mode 100644 profile/README.md create mode 100644 profile/compose.yaml create mode 100644 profile/rhdho/app-config/app-config.yaml create mode 100644 profile/rhdho/catalog-entities/components.yaml create mode 100644 profile/rhdho/catalog-entities/mkdocs.yml create mode 100644 profile/rhdho/catalog-entities/users.yaml create mode 100644 profile/rhdho/default.env create mode 100644 profile/rhdho/dynamic-plugins/dynamic-plugins.yaml create mode 100644 profile/rhdho/services.yaml diff --git a/profile/README.md b/profile/README.md new file mode 100644 index 0000000..39dc84e --- /dev/null +++ b/profile/README.md @@ -0,0 +1,52 @@ +## Preconfigured Profiles + +The `profile/` directory provides an alternative way to set up RHDH using preconfigured profiles. This approach allows you to quickly deploy RHDH with a set of predefined configurations and plugins tailored for specific use cases or environments. + +### Benefits of Using Profiles + +- **Simplified Setup**: Profiles come with preconfigured settings, reducing the need for manual configuration. +- **Consistency**: Ensures a unified and structured approach to managing and maintaining configurations. +- **Customizability**: Each profile can be tailored to specific requirements while maintaining a consistent structure. + +### Trade-offs + +While profiles offer a structured approach, they may introduce some duplication of configuration files, as each profile contains its own set of configurations and plugins. + +### Example: RHDH Profile + +The `rhdh` profile contains configurations and plugins commonly used in Red Hat Developer Hub deployments, including the Orchestrator plugin. This profile is ideal for environments where the Orchestrator plugin is required for workflow management. + +### Directory Structure + +Each profile in the `profile/` directory follows a consistent structure like this (not exhaustive): + +``` +profile/ +├── / +│ ├── app-config/ +│ ├── dynamic-plugins/ +│ ├── catalog-entities/ +│ ├── services.yaml +``` + +### How to Use Profiles + +1. **Select a Profile**: Choose the profile that best matches your use case from the `profile/` directory. + +2. **Create a Profile** *(Optional)*: If you want to create a new profile, you can copy an existing profile as a template and modify it as needed. + +3. **Customize the Profile** *(Optional)*: + - Modify the `app-config.yaml` file to override default application configurations. + - Update the `dynamic-plugins.yaml` file to include or exclude specific plugins. + - Adjust the `users.yaml` and `components.yaml` files to customize catalog entities. + - etc. + +3. **Run the Profile**: Use the `PROFILE` environment variable to point to the selected profile. For example: + + ```sh + PROFILE=profile/rhdho podman compose -f profile/compose.yaml up -d + ``` + or + ```sh + PROFILE=profile/rhdho docker compose -f profile/compose.yaml up -d + ``` diff --git a/profile/compose.yaml b/profile/compose.yaml new file mode 100644 index 0000000..e546df6 --- /dev/null +++ b/profile/compose.yaml @@ -0,0 +1,51 @@ +include: + - ${PROFILE}/services.yaml +services: + rhdh: + container_name: rhdh + image: ${RHDH_IMAGE:-quay.io/rhdh-community/rhdh:1.6} + env_file: + - path: "../default.env" + required: true + - path: "../profile/${PROFILE}/default.env" + required: false + - path: "../profile/${PROFILE}/.env" + required: false + user: "1001" + entrypoint: + - "/opt/app-root/src/wait-for-plugins-and-start.sh" + ports: # dclint disable-line no-unbound-port-interfaces + - "7007:7007" + - "127.0.0.1:9229:9229" + environment: + NODE_OPTIONS: "--inspect=0.0.0.0:9229 --no-node-snapshot" + volumes: + - ../wait-for-plugins-and-start.sh:/opt/app-root/src/wait-for-plugins-and-start.sh:Z + - ../profile/${PROFILE}:/opt/app-root/src/configs:Z + - dynamic-plugins-root:/opt/app-root/src/dynamic-plugins-root + depends_on: + install-dynamic-plugins: + condition: service_completed_successfully + # db: + # condition: service_healthy + + install-dynamic-plugins: + container_name: rhdh-plugins-installer + image: ${RHDH_IMAGE:-quay.io/rhdh-community/rhdh:1.6} + # docker compose volumes are owned by root, so we need to run as root to write to them + # the main rhdh container will be able to read from this as files are world readable + user: "root" + entrypoint: + - "/opt/app-root/src/prepare-and-install-dynamic-plugins.sh" + env_file: + - path: "../default.env" + required: true + - path: "../profile/${PROFILE}/.env" + required: false + volumes: + - ../prepare-and-install-dynamic-plugins.sh:/opt/app-root/src/prepare-and-install-dynamic-plugins.sh:Z + - ../profile/${PROFILE}:/opt/app-root/src/configs:Z + - dynamic-plugins-root:/dynamic-plugins-root + +volumes: + dynamic-plugins-root: \ No newline at end of file diff --git a/profile/rhdho/app-config/app-config.yaml b/profile/rhdho/app-config/app-config.yaml new file mode 100644 index 0000000..1d071d6 --- /dev/null +++ b/profile/rhdho/app-config/app-config.yaml @@ -0,0 +1,90 @@ +# This is the default rhdh-local config, and any user configuration should be added app-config.local.yaml instead +auth: + environment: development + providers: + guest: + dangerouslyAllowOutsideDevelopment: true + # github: + # development: + # clientId: ${AUTH_GITHUB_CLIENT_ID} + # clientSecret: ${AUTH_GITHUB_CLIENT_SECRET} + +# integrations: +# github: +# - host: github.com +# apps: +# - $include: github-app-credentials.yaml + +app: + title: Red Hat Developer Hub + baseUrl: ${BASE_URL} + branding: + # These logo overrides are required for quay.io/rhdh-community/rhdh:1.6 + # if using a different logo, replace this line with your own image + # it is expected that as of 1.7 they will not be required + fullLogo:  + iconLogo:  + fullLogoWidth: ${FULL_LOGO_WIDTH} + theme: + light: + primaryColor: ${PRIMARY_LIGHT_COLOR} + headerColor1: ${HEADER_LIGHT_COLOR_1} + headerColor2: ${HEADER_LIGHT_COLOR_2} + navigationIndicatorColor: ${NAV_INDICATOR_LIGHT_COLOR} + dark: + primaryColor: ${PRIMARY_DARK_COLOR} + headerColor1: ${HEADER_DARK_COLOR_1} + headerColor2: ${HEADER_DARK_COLOR_2} + navigationIndicatorColor: ${NAV_INDICATOR_DARK_COLOR} +backend: + listen: + port: 7007 + baseUrl: ${BASE_URL} + # uncomment this if backend.baseUrl is exposed over HTTPS + # and you want RHDH to auto-generate and serve a self-signed certificate. + # https: true + cors: + origin: ${BASE_URL} + methods: [GET, HEAD, PATCH, POST, PUT, DELETE] + credentials: true + csp: + upgrade-insecure-requests: false + +# comment out the following 'database' section to use the PostgreSQL database + database: + client: better-sqlite3 + connection: ':memory:' + + auth: + keys: + - secret: "development" + +# You can use local files from catalog-entities directory to load entities into the catalog +catalog: + + rules: + - allow: [Component, API, Location, Template, Domain, User, Group, System, Resource] + + locations: + - type: file + target: /opt/app-root/src/configs/catalog-entities/users.yaml + rules: + - allow: [User, Group] + - type: file + target: /opt/app-root/src/configs/catalog-entities/components.yaml + rules: + - allow: [Component, System] + # - type: url + # target: https://github.com/backstage/backstage/blob/master/packages/catalog-model/examples/all.yaml + # rules: + # - allow: [Component, User, Group, Domain] + + +techdocs: + generator: + runIn: local + builder: local + publisher: + type: local + local: + publishDirectory: /tmp/techdocs diff --git a/profile/rhdho/catalog-entities/components.yaml b/profile/rhdho/catalog-entities/components.yaml new file mode 100644 index 0000000..7231eac --- /dev/null +++ b/profile/rhdho/catalog-entities/components.yaml @@ -0,0 +1,15 @@ +# This is an example override file for catalog components. +# If present, this file will be used instead of components.yaml. +# Uncomment and edit the entries below to override catalog components. + +apiVersion: backstage.io/v1alpha1 +kind: Component +metadata: + name: example-service + description: A simple demo component to appear in the Software Catalog. + annotations: + backstage.io/techdocs-ref: dir:. +spec: + type: service + lifecycle: experimental + owner: user:default/user \ No newline at end of file diff --git a/profile/rhdho/catalog-entities/mkdocs.yml b/profile/rhdho/catalog-entities/mkdocs.yml new file mode 100644 index 0000000..62fa0cc --- /dev/null +++ b/profile/rhdho/catalog-entities/mkdocs.yml @@ -0,0 +1,4 @@ +site_name: example-service +docs_dir: docs +plugins: + - techdocs-core diff --git a/profile/rhdho/catalog-entities/users.yaml b/profile/rhdho/catalog-entities/users.yaml new file mode 100644 index 0000000..c99df6b --- /dev/null +++ b/profile/rhdho/catalog-entities/users.yaml @@ -0,0 +1,14 @@ +# This is an example override file for catalog users. +# If present, this file will be used instead of users.yaml. +# Uncomment and edit the entries below to override catalog users. + +apiVersion: backstage.io/v1alpha1 +kind: User +metadata: + name: my-user +spec: + profile: + displayName: My User + memberOf: + - my-group1 + - my-group2 diff --git a/profile/rhdho/default.env b/profile/rhdho/default.env new file mode 100644 index 0000000..a6743ff --- /dev/null +++ b/profile/rhdho/default.env @@ -0,0 +1 @@ +MAX_ENTRY_SIZE: "30000000" \ No newline at end of file diff --git a/profile/rhdho/dynamic-plugins/dynamic-plugins.yaml b/profile/rhdho/dynamic-plugins/dynamic-plugins.yaml new file mode 100644 index 0000000..9d831cf --- /dev/null +++ b/profile/rhdho/dynamic-plugins/dynamic-plugins.yaml @@ -0,0 +1,42 @@ + +includes: + - dynamic-plugins.default.yaml + +plugins: + - package: https://github.com/rhdhorchestrator/orchestrator-plugins-internal-release/releases/download/v1.6.0/backstage-plugin-orchestrator-1.6.0.tgz + integrity: sha512-fOSJv2PgtD2urKwBM7p9W6gV/0UIHSf4pkZ9V/wQO0eg0Zi5Mys/CL1ba3nO9x9l84MX11UBZ2r7PPVJPrmOtw== + disabled: false + pluginConfig: + dynamicPlugins: + frontend: + red-hat-developer-hub.backstage-plugin-orchestrator: + appIcons: + - importName: OrchestratorIcon + name: orchestratorIcon + dynamicRoutes: + - importName: OrchestratorPage + menuItem: + icon: orchestratorIcon + text: Orchestrator + path: /orchestrator + - disabled: false + package: https://github.com/rhdhorchestrator/orchestrator-plugins-internal-release/releases/download/v1.6.0/backstage-plugin-orchestrator-backend-dynamic-1.6.0.tgz + integrity: sha512-Kr55YbuVwEADwGef9o9wyimcgHmiwehPeAtVHa9g2RQYoSPEa6BeOlaPzB6W5Ke3M2bN/0j0XXtpLuvrlXQogA== + pluginConfig: + orchestrator: + dataIndexService: + url: http://sonataflow:8899 + - disabled: false + package: https://github.com/rhdhorchestrator/orchestrator-plugins-internal-release/releases/download/v1.6.0/backstage-plugin-scaffolder-backend-module-orchestrator-dynamic-1.6.0.tgz + integrity: sha512-Bueeix4661fXEnfJ9y31Yw91LXJgw6hJUG7lPVdESCi9VwBCjDB9Rm8u2yPqP8sriwr0OMtKtqD+Odn3LOPyVw== + pluginConfig: + orchestrator: + dataIndexService: + url: http://sonataflow:8899 + - disabled: false + package: https://github.com/rhdhorchestrator/orchestrator-plugins-internal-release/releases/download/v1.6.0/backstage-plugin-orchestrator-form-widgets-1.6.0.tgz + integrity: sha512-Tqn6HO21Q1TQ7TFUoRhwBVCtSBzbQYz+OaanzzIB0R24O6YtVx3wR7Chtr5TzC05Vz5GkBO1+FZid8BKpqljgA== + pluginConfig: + dynamicPlugins: + frontend: + red-hat-developer-hub.backstage-plugin-orchestrator-form-widgets: {} \ No newline at end of file diff --git a/profile/rhdho/services.yaml b/profile/rhdho/services.yaml new file mode 100644 index 0000000..3e2dda0 --- /dev/null +++ b/profile/rhdho/services.yaml @@ -0,0 +1,16 @@ + +services: + sonataflow: + container_name: sonataflow + image: "${SONATAFLOW_IMAGE:-registry.redhat.io/openshift-serverless-1/logic-swf-devmode-rhel8:1.36.0}" + environment: + QUARKUS_HTTP_PORT: "8899" + KOGITO_SERVICE_URL: http://sonataflow:8899 + KOGITO.CODEGEN.PROCESS.FAILONERROR: "false" + QUARKUS_EMBEDDED_POSTGRESQL_DATA_DIR: /home/kogito/persistence + NOTIFICATIONS_BEARER_TOKEN: "***" + BACKSTAGE_NOTIFICATIONS_URL: http://host.docker.internal:7008 + ports: + - "127.0.0.1:8899:8899" + volumes: + - ${RHDH_ORCHESTRATOR_WORKFLOWS:-../../rhdho-workflow-examples}:/home/kogito/serverless-workflow-project/src/main/resources:Z \ No newline at end of file