Skip to main content

Configuration Reference

The configuration file is appsettings.json, if not present it will be created with default values (appsettings-default.json).

Authentication

AuthCookieName

The name of the authorization cookie.

info

The default value is jwtToken.

AuthProvider

The authentication provider, supported values:

  • Sqlite: SQLite database
  • Mysql: MySQL or MariaDB, (compatibility)
  • Mssql: Microsoft SQL Server (no migrations)
info

The default value is Sqlite

The IdentityConnection connection string should be changed accordingly.

Secret

The secret used as key to generate the JWT tokens. Do not use the same secret for multiple applications.

TokenExpirationInDays

The number of days after which the JWT tokens will expire.

info

The default value is 7 days.

RevokedTokens

The list of revoked JWT tokens.

ExternalAuthUrl

The URL of the external authentication provider.

info

The default value is null.

Database

Use MySQL / MariaDB instead of SQLite

For production environments with high load, it's recommended to use MySQL or MariaDB. See the Getting Started guide for setup instructions.

RegistryProvider

The Registry database provider, supported values:

  • Sqlite: SQLite database
  • Mysql: MySQL or MariaDB, (compatibility)
  • Mssql: Microsoft SQL Server (no migrations)
info

The default value is Sqlite

The RegistryConnection connection string should be changed accordingly.

HangfireProvider

The Hangfire provider, supported values:

  • InMemory: In-memory provider
  • Mysql: MySQL or MariaDB
info

The default value is InMemory

The HangfireConnection connection string should be changed accordingly.

Storage

StoragePath

The path to the storage folder.

info

The default value is ./data

DatasetsPath

The path to the datasets folder.

info

The default value is ./datasets

TempPath

The path to the temporary files folder.

info

The default value is ./temp

CachePath

The path to the cache folder. This is used to store the generated tiles and thumbnails.

info

The default value is ./cache.

Cache

CacheProvider

The additional cache provider, supported values:

  • InMemory: In-memory cache provider. Example value:
{ "type": "InMemory" }
  • Redis: Redis cache provider. Example value:
{
"type": "Redis",
"settings": {
"InstanceAddress": "localhost:5002",
"InstanceName": "registry"
}
}
info

The default value is null (InMemory is used).

ClearCacheInterval

The interval to clear the file cache (TimeSpan).

info

The default value is 01:00:00 (1 hour).

ThumbnailsCacheExpiration

The expiration time of the thumbnails cache (TimeSpan).

info

The default value is 00:30:00 (30 minutes).

TilesCacheExpiration

The expiration time of the tiles cache (TimeSpan).

info

The default value is 00:30:00 (30 minutes).

VisibilityCacheExpiration

The expiration time for the dataset visibility cache (TimeSpan).

info

The default value is 1.00:00:00 (1 day).

Upload & Sharing

MaxRequestBodySize

The maximum request body size. It sets the MultipartBodyLengthLimit of the kestrel FormOptions.

info

The default value is null (default).

BatchTokenLength

The length of the token generated in the share endpoint.

info

The default value is 32.

RandomDatasetNameLength

The length of the random dataset name, generated when calling the share endpoint.

info

The default value is 16.

UploadBatchTimeout

The timeout for the share upload endpoint. It is the maximum time allowed between the uploads.

info

The default value is 01:00:00 (1 hour).

MaxZipMemoryThreshold

Memory threshold (in bytes) before using disk-based ZIP creation.

info

The default value is 1073741824 (1 GB)

MaxExportSizeBytes

Maximum allowed size (in bytes) for a dataset export operation. Export requests that would exceed this limit are rejected.

info

The default value is 1073741824 (1 GB)

User Management

DefaultAdmin

The default admin user.

info

The default value is:

{
"Email": "admin@example.com",
"UserName": "admin",
"Password": "password123"
}

EnableStorageLimiter

Enable the storage limiter. Registry will limit the storage usage of the user based on its metadata (maxStorageMB key).

info

The default value is false.

EnableDefaultUserOrganization

Enables the automatic creation of a default personal organization when a new user is created. By default, every new user gets a personal organization with a slug matching their username.

Set to false for enterprise deployments where organizations are assigned by administrators after user creation.

info

The default value is true.

Example — disable default organization creation:

{
"AppSettings": {
"EnableDefaultUserOrganization": false
}
}

Or via environment variable:

AppSettings__EnableDefaultUserOrganization=false

EnableOrganizationMemberManagement

Enables organization member management in the admin UI, allowing administrators to add and remove users from organizations directly.

info

The default value is false.

MaxConcurrentDownloadsPerUser

Maximum number of concurrent download requests allowed per authenticated user. Set to null to disable throttling.

info

The default value is null (no limit).

MonitorToken

Static bearer token required to access the monitoring endpoints (e.g., /quickhealth). When set, the endpoint requires the Authorization: Bearer <token> header instead of a regular JWT. Set to null to disable token-based monitoring access.

info

The default value is null.

PasswordPolicy

Password complexity policy applied when creating or changing user passwords. Set to null to disable all policy enforcement.

info

The default policy requires at least 8 characters and one digit.

Sub-fields:

FieldTypeDefaultDescription
MinLengthint8Minimum password length
RequireDigitbooltrueAt least one digit (0–9)
RequireUppercaseboolfalseAt least one uppercase letter
RequireLowercaseboolfalseAt least one lowercase letter
RequireNonAlphanumericboolfalseAt least one non-alphanumeric character

Example — enforce a stronger password policy:

{
"AppSettings": {
"PasswordPolicy": {
"MinLength": 12,
"RequireDigit": true,
"RequireUppercase": true,
"RequireLowercase": true,
"RequireNonAlphanumeric": true
}
}
}

Example — disable password policy entirely:

{
"AppSettings": {
"PasswordPolicy": null
}
}

Or via environment variables:

AppSettings__PasswordPolicy__MinLength=12
AppSettings__PasswordPolicy__RequireDigit=true

Networking

AllowedOrigins

List of allowed CORS origins. When null or empty, all origins are permitted (open CORS). For production or on-premise deployments, restrict this to the actual origins that need access.

info

The default value is null (all origins allowed).

Example — restrict to specific origins:

{
"AppSettings": {
"AllowedOrigins": [
"https://hub.example.com",
"https://admin.example.com"
]
}
}

ExternalUrlOverride

The external URL of Registry. This is used when the application is behind a reverse proxy.

info

The default value is null.

Security Headers

Registry automatically adds the following security headers to all HTTP responses:

HeaderValuePurpose
X-Content-Type-OptionsnosniffPrevents MIME type sniffing
X-Frame-OptionsSAMEORIGINPrevents clickjacking via cross-origin iframes while allowing same-origin embedding (e.g. PDF viewer)
Referrer-Policystrict-origin-when-cross-originControls referrer information sent with requests

These headers are always enabled and require no configuration.

note

For embed routes (URLs with ?embed=1), the X-Frame-Options header is omitted to allow cross-origin iframe embedding.

Processing

WorkerThreads

The number of worker threads used by the application. Use -1 for automatic detection.

info

The default value is -1

RemoteThumbnailGeneratorUrl

URL of a remote thumbnail generator service for offloading thumbnail generation.

info

The default value is null

Hub UI Customization

The Hub web app (the Vue SPA shipped with Registry) reads its branding and feature flags from AppSettings:HubOptions. The block is exposed to the browser through the anonymous /sys/features endpoint and applied at runtime — index.html is no longer the place to customize the app.

When you remove the section from appsettings.json, the Hub falls back to the default DroneDB banner (/images/logo-banner.svg) without any extra wordmark.

HubOptions

Top-level container for branding and feature flags. Set to null (or omit it entirely) to use defaults.

Sub-fields:

FieldTypeDefaultDescription
AppLogostring/images/logo-banner.svgURL of the banner image shown in the header. Set to an empty string to fall back to AppIcon + AppName.
AppNamestringnullWordmark next to AppIcon. When null no text is rendered (banner alone).
AppIconstringnullIcon class shown when no logo is configured ("dronedb" for the default DroneDB mark, or any Semantic UI icon name).
ShowRegistrationLinkbooltrueWhether the Login page shows the "Sign up" link.
DisableDatasetCreationboolfalseHides the "New dataset" button.
DisableStorageInfoboolfalseHides the per-user storage indicator in the header.
DisableAccountManagementboolfalseHides the account-management menu (useful when authentication is delegated to an external provider).
SingleOrganizationstringnullWhen set, the Hub treats the app as single-tenant and routes the user directly to the named organization.
ReadOnlyOrgsboolnullWhen true, organization create/delete/edit actions are hidden.
FaviconobjectnullOptional favicon set (see below).

Example — minimal white-label deployment:

{
"AppSettings": {
"HubOptions": {
"AppLogo": "/branding/acme-banner.svg",
"AppName": "Acme Maps",
"ShowRegistrationLink": false,
"DisableAccountManagement": true,
"SingleOrganization": "acme"
}
}
}
tip

All paths starting with /branding/ are served from {StoragePath}/branding/, a folder that survives Hub upgrades. Drop your logos, favicons and manifest.webmanifest there and reference them from HubOptions. See Updating.

HubOptions.Favicon

When set, the Hub injects the matching <link> and <meta> tags into <head> at runtime. Any unset field is omitted. Drop the actual image/manifest files under {StoragePath}/branding/ so they survive upgrades.

FieldTypeDescription
FaviconIcostringURL of the .ico fallback (e.g. /branding/favicon.ico).
Favicon16stringURL of the 16×16 PNG.
Favicon32stringURL of the 32×32 PNG.
AppleTouchIconstringURL of the 180×180 PNG used by iOS.
ManifeststringURL of site.webmanifest. The 192/512 PWA icons live inside the manifest itself.
ThemeColorstringCSS color string used for the theme-color meta tag.

Example:

{
"AppSettings": {
"HubOptions": {
"AppLogo": "/branding/acme-banner.svg",
"Favicon": {
"FaviconIco": "/branding/favicon.ico",
"Favicon16": "/branding/favicon-16x16.png",
"Favicon32": "/branding/favicon-32x32.png",
"AppleTouchIcon": "/branding/apple-touch-icon.png",
"Manifest": "/branding/site.webmanifest",
"ThemeColor": "#0070e0"
}
}
}
}

Scheduled Jobs

CleanupExpiredJobsCron

Cron expression for the job that cleans up expired jobs.

info

The default value is 0 * * * * (every hour)

SyncJobIndexStatesCron

Cron expression for the job that synchronizes job index states.

info

The default value is */5 * * * * (every 5 minutes)

ProcessPendingBuildsCron

Cron expression for the job that processes pending builds.

info

The default value is * * * * * (every minute)

OrphanedDatasetCleanupCron

Cron expression for the job that cleans up orphaned dataset folders. This job runs daily to remove filesystem folders that no longer have a corresponding database entry (e.g., from failed deletions).

info

The default value is 0 3 * * * (daily at 3:00 AM)

DatasetCleanupCron

Cron expression for the recurring full-cleanup job that runs DroneDB cleanup (purge of stale entries and unused build artifacts) on every dataset of every organization. The same operation is also exposed via the admin API endpoint POST /sys/cleanup.

Set this value to an empty string ("") to disable the recurring job entirely.

info

The default value is 0 0 * * * (daily at midnight)

JobIndexCleanupCron

Cron expression for the job that purges old terminal records (Succeeded, Failed, Deleted) from the JobIndices table. This prevents the table from growing indefinitely.

info

The default value is 0 4 * * * (daily at 4:00 AM)

JobIndexRetentionDays

Number of days to retain terminal (Succeeded/Failed/Deleted) job index records. Records whose last state change is older than this value are automatically purged by the cleanup job.

info

The default value is 60

Example — keep records for 30 days and run the cleanup at 2:00 AM:

{
"AppSettings": {
"JobIndexRetentionDays": 30,
"JobIndexCleanupCron": "0 2 * * *"
}
}
tip

If the JobIndices table has already grown very large, you can trigger an immediate cleanup via the admin API endpoint POST /sys/cleanup-jobindices. An optional retentionDays query parameter lets you override the configured retention for that single run.