Reference
This reference explains the global configuration options for R2Devops, including frontend configuration and backend environment variables. The frontend configuration is stored in a JSON file, while the backend settings are managed through environment variables.
Frontend
The frontend configuration file is a JSON file that should be mounted to
/app/.next/server/app/config.body
in our official container. It contains the
following options:
{
"appTitle": "R2Devops",
"apiUrl": "https://r2devops.REPLACEME/api",
"gitLabApiUrl": "https://gitlab.com/",
"selfHosted": true,
"docUrl": "https://docs.r2devops.io",
"debug": false,
"allowExternalQueries": true
}
Options
appTitle
: The title of the application displayed in the user interfaceapiUrl
: The R2Devops API URL for API calls made by the frontendgitLabApiUrl
: URL of the gitlab instance for API calls made by the frontendselfHosted
: A boolean indicating if the application is self-hosted (true
) or SaaS (false
)docUrl
: The URL to the R2Devops documentation sitedebug
: Enables debug mode when set totrue
allowExternalQueries
: A boolean that, whentrue
, allows the frontend to perform external queries
Backend
The backend configuration is managed through environment variables. Below is a detailed explanation of the variables
General Configuration
JOBS_LISTEN_ADDR
: The address on which the backend listens (e.g.,localhost
)JOBS_LISTEN_PORT
: The port on which the backend listens (e.g.,3000
)JOBS_CORS_ORIGIN
: Specifies allowed CORS origins. Use*
to allow all originsJOBS_API_DOMAIN
: The base URL for the backend APIJOBS_FRONTEND_URL
: The URL of the frontend applicationGITLEAKS_PATH
: The path to the Gitleaks binary for detecting secretsJOBS_ANALYSIS_TIMEOUT
: The duration after which we consider an analysis as failed (the more projects you have, the higher this value should be). Default:10m
Session and Security
JOBS_SESSION_TTL
: The validity duration of a user session (e.g.,24h
)SECRET_KEY
: The encryption key for sensitive data. Ensure this is securely generated and kept private
Organization and License
ORGANIZATION
: For self-managed GitLab, leave empty to consider all groups. For SaaS GitLab, specify the path of the top-level group of your organizationLICENSE
: The license key for the application
Logging
LOG_LEVEL
: The logging level (error
,warn
,info
,debug
)LOG_FORMATTER
: The log output format (json
ortext
)
GitLab Integration
JOBS_GITLAB_URL
: The URL of the GitLab instance (e.g.,https://gitlab.com
)GITLAB_OAUTH2_CLIENT_ID
: The client ID for GitLab OAuth2GITLAB_OAUTH2_CLIENT_SECRET
: The client secret for GitLab OAuth2
PostgreSQL Database
JOBS_DB_HOST
: The host address of the PostgreSQL databaseJOBS_DB_PORT
: The port of the PostgreSQL databaseJOBS_DB_USER
: The username for database authenticationJOBS_DB_NAME
: The name of the PostgreSQL databaseJOBS_DB_SSLMODE
: The SSL mode for database connections (e.g.,disable
)JOBS_DB_TIMEZONE
: The timezone for database operationsJOBS_DB_PASSWORD
: The password for database authentication
Redis Database
JOBS_REDIS_HOST
: The host address of the Redis databaseJOBS_REDIS_PORT
: The port of the Redis databaseJOBS_REDIS_DB
: The database index for Redis (e.g.,0
)JOBS_REDIS_USER
: The username for Redis authenticationJOBS_REDIS_PASSWORD
: The password for Redis authenticationJOBS_REDIS_CERT
: The certificate path for Redis (optional)JOBS_REDIS_SET_NAMESPACES_TTL
: The TTL for Redis namespaces (e.g.,24h
)