Skip to content
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
52 changes: 52 additions & 0 deletions profile/README.md
Original file line number Diff line number Diff line change
@@ -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/
├── <profile-name>/
│ ├── 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
```
51 changes: 51 additions & 0 deletions profile/compose.yaml
Original file line number Diff line number Diff line change
@@ -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:
90 changes: 90 additions & 0 deletions profile/rhdho/app-config/app-config.yaml
Original file line number Diff line number Diff line change
@@ -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
15 changes: 15 additions & 0 deletions profile/rhdho/catalog-entities/components.yaml
Original file line number Diff line number Diff line change
@@ -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
4 changes: 4 additions & 0 deletions profile/rhdho/catalog-entities/mkdocs.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
site_name: example-service
docs_dir: docs
plugins:
- techdocs-core
14 changes: 14 additions & 0 deletions profile/rhdho/catalog-entities/users.yaml
Original file line number Diff line number Diff line change
@@ -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
1 change: 1 addition & 0 deletions profile/rhdho/default.env
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
MAX_ENTRY_SIZE: "30000000"
Loading