Nucleus .Net Core CMS

Configuration Reference

Nucleus configuration settings may be split across multiple .json files and can be stored in environment variables or submitted as command-line arguments. Refer to the Configuration page for information on how Nucleus loads configuration settings.

The default configuration settings, along with the settings which are set up automatically by the Setup Wizard are suitable for most users, so you don't need modify configuration files unless you require special settings.

The default appSettings.json file contains a full set of available configuration settings (some are commented out), which you should use as a reference for the file format.

When Nucleus-specific configuration settings are read from .json files, they are part of a hierachy that begins with a "Nucleus" element. In this document, configuration sections and items are specified using the : character to represent the hierachy of configuration elements. The configuration section in the example below would be represented as Nucleus:ResourceFileOptions and the UseMinifiedJs property would be represented as Nucleus:ResourceFileOptions:UseMinifiedJs.

"Nucleus": { 
    "ResourceFileOptions": {
      "UseMinifiedJs": true    // We refer to this as Nucleus:ResourceFileOptions:UseMinifiedJs
    }
  }

Configuration Settings

This page contains information on Nucleus-specific settings only, which reside within the "Nucleus" section of your configuration files. ASP.NET Core and third party components have their own configuration settings, and they may also be present in your configuration files, but are not documented here.

Nucleus

MachineName (string) Specifies the name used to identify the server in logging filenames, for scheduled task history and in observability/instrumentation. If not set, the value is set to the result of Environment.MachineName, which is the NETBIOS name of the computer in Windows, or the value of the HOSTNAME environment variable in Linux. Using this value to override the machine name is useful in some hosted environments, where the name of the underlying virtual machine may change.
EnableResponseCompression:Enabled (Boolean) Default is true.
MaxRequestSize (long) Specifies the maximum MultipartBodyLengthLimit and MaxRequestBodySize in bytes. This value must be set high enough for the largest file upload that you want to allow. If not specified, the .net core defaults are used.
"Nucleus": 
{
  "MachineName": "WEB-MEL-001",
  "EnableResponseCompression": { 
    "Enabled" : true 
  },
  "EnableForwardedHeaders": { 
    "Enabled" : true 
  },
  "MaxRequestSize": 67108864
  ...
}

Nucleus:ForwardedHeaders

Specifies options for the ForwardedHeadersMiddleware. The ForwardedHeadersMiddleware is used to process X-Forwarded-For, X-Forwarded-Proto and other headers, which are commonly added by reverse proxies and load balancers.

Enabled (Boolean) Default is true.
KnownProxies (list of string) Specifies A list of reverse proxy servers which are trusted to send forwarded headers.
KnownNetworks (list of KnownNetwork) Specifies A list of reverse proxy networks which are trusted to send forwarded headers. Each KnownNetwork entry contains a prefix and a prefix length. The prefix is in IP address format, and the prefix length is a subnet, in CIDR notation.
"Nucleus": 
{
  "ForwardedHeaders": {
      "Enabled": true,
      "KnownNetworks": [
        {
          "prefix": "192.168.1.0",
          "prefixlength": 24
        }
      ],
      "KnownProxies": [ "192.168.1.1" ]
    }
  ...
}

Nucleus:FolderOptions

DataFolder (String) Specifies the name of the root folder that Nucleus uses to store files on the file system.
"Nucleus": 
{
  "FolderOptions": 
  {
    "DataFolder": "%ProgramData%/Nucleus"
  }
  ...
}

The DataFolder setting can contain environment variables like %ProgramData%, which are resolved at run time.

Whenever you set a configuration file setting to a file system path, it is a good idea to use / instead of \ as a path delimiter, because:

  1. \ is a reserved character in JSON.
  2. Windows and Linux both understand / as a path delimiter, but Linux does not understand \.

File-based database providers (Sqlite) store database files in a Data sub-folder of the folder specified by Nucleus:FolderOptions:DataFolder.

Nucleus:TextFileLoggerOptions

Path (String) Specifies the name of the folder that the Nucleus text file logger uses to store log files on the file system. By default, this value is the Logs subfolder of the folder specified by Nucleus:FolderOptions:DataFolder.
LogFileExpiry (TimeSpan) Specifies how long log files are retained before being automatically deleted. This value is a TimeSpan, which is represented in days, hours, minutes and seconds in the form "days:hours:minutes:seconds". For example, 7 days, 11 hours, 20 minutes and 15 seconds would be represented as "07:11:20:15". The default value is 7 days ("07:00:00:00").
"Nucleus": 
{
  "TextFileLoggerOptions": 
  {
  "Path": "{DataFolder}/Logs"
  }
  ...
}

Nucleus:ResourceFileOptions

Specifies use of minified javascript and css stylesheets, when they are available. Developers may want to set these values to false in order to more easily debug client-side javascript and css.

UseMinifiedJs (Boolean) Specifies whether to use minified versions of .js files, when they are available. Default value is true.
UseMinifiedCss (Boolean) Specifies whether to use minified versions of .css files, when they are available. Default value is true.
"Nucleus": 
{
  "ResourceFileOptions": 
  {
    "UseMinifiedJs": true,
    "UseMinifiedCss": true
  }
  ...   
}

Nucleus:HtmlEditor

Specifies stylesheets and script files used by the Html editor. More than one Html editor can be included, but only one can be selected. This section is automatically present in the default appSettings.config file, and users generally do not need to edit this section.

Default (String) Specifies the Key of the Html Editor that is in use. This value does not have a default.
HtmlEditors (array) Array of one or more HtmlEditor sections.

Nucleus:HtmlEditor[n]

Each HtmlEditor has properties:

Key (String) Unique identifier for the Html Editor configuration section.
Scripts (array) Array of one or more script sections.

Nucleus:HtmlEditor[n]:Scripts[n]

Each scripts section has properties:

Type (String) javascript or stylesheet.
Path (String) Application-relative path to the script or javascript file. Start with a ~ to represent the application root.

Nucleus:FileSystems

The FileSystems section controls static file validation and file system provider's settings. File system providers are initially configured by the Setup Wizard.

Nucleus:FileSystems:AllowedFileTypes

AllowedFileTypes are used to specify one or more file extensions and a list of signatures for each file type. Files with extensions do not match an entry in this list cannot be uploaded and will generate an error. The integrity of uploaded files is validated by comparing the first few bytes of the file with the specified signatures. The file bytes must match at least one of the signatures. Signatures are specified as hexadecimal values, with no spaces or delimiters. The special value "??" in a signature skips validation of the byte in the ordinal position represented by the ?? characters.

The Nucleus:FileSystems:AllowedFileTypes element is an array of allowed file type elements. This section is automatically present in the default appSettings.config file, and users generally do not need to edit this section, unless there is a need to support upload of additional file types.

FileExtensions (array of string) Array of file extensions represented by this entry, including the leading . character. Not case-sensitive.
Signatures (array of string) Array of file signatures which match the file extensions specified for this entry.
Restricted (Boolean). Specifies whether uploads of the file type are restricted to site administrators.
"Nucleus": 
{
  "FileSystems": 
  {
    "AllowedFileTypes": 
    [
      {
        "FileExtensions": [ ".jpg", ".jpeg" ],
        "Signatures": [ "FFD8FFE0", "FFD8FFE1", "FFD8FFE2", "FFD8FFE3" ]
      },
      {
        ...
      }
    ]
  }
}

Nucleus:FileSystems:Providers

Specifies one or more file system providers. The configuration section for each file provider has a key, name and provider type (class name). You can specify multiple file providers, and the user can choose from a list in the user interface. The "Name" property is shown to the user. Each entry has a key which uniquely identifies the provider entry.

The Setup Wizard automatically creates File System provider entries and is the easiest way to set up your file systems.

The default file system provider is the Local File System provider, which stores files on the local file system. Other file system providers are available as extensions, including providers for Amazon S3 and Azure Blob Storage.

The Nucleus:FileSystems:Providers element is an array of file system provider type elements.

Key (String) Unique identifier for the file system provider configuration entry.
Name (String) Friendly name for the file system provider, which is shown to users when selecting a file system.
ProviderType (String). Assembly-qualified class name for the file system provider.
"Nucleus": 
{
  "FileSystems": 
  {
    "Providers": 
    [
      {
        "Key": "local",
        "Name": "Local File System",
        "ProviderType": "Nucleus.Core.FileSystemProviders.LocalFileSystemProvider,Nucleus.Core"
      }
    ]
  }
  ...
}

Nucleus:PasswordOptions

Specifies authentication and password settings.

FailedPasswordWindowTimeout (Timespan) Specifies the time span for which the system remembers that a user has had a failed password attempt. Repeated failures within the specified file will increment the failed password attempts count, and when the FailedPasswordMaxAttempts threshold is exceeded, the user account will be locked for a period of time. Default value is 0:15:00 (15 minutes).
FailedPasswordMaxAttempts (Integer) Specifies the number of failed password attempts before account lockout. Default value is 3.
FailedPasswordLockoutReset (Timespan). Specifies the time span after which an account lockout is automatically reset. Default value is 0:10:00 (10 minutes).
PasswordResetTokenExpiry (Timespan). Specifies the time span after which a password reset token expires. Password reset tokens are sent to the user when they request a password reset. Default value is 02:00:00 (2 hours).
PasswordComplexityRules (array). Array of password complexity rules. All rules must succeed for a password to be valid.
"Nucleus": 
{
  "PasswordOptions": 
  {
    "FailedPasswordWindowTimeout": "0:15:00",
    "FailedPasswordMaxAttempts": 3,
    "FailedPasswordLockoutReset": "0:10:00",
    "PasswordResetTokenExpiry": "02:00:00",   
    "PasswordComplexityRules": 
    [
      {
        "Pattern": "^(?=.*[A-z])(?=.*[A-Z])(?=.*[0-9])(?=.*[\\\\!\\@\\#\\$\\%\\^\\&\\*\\(\\)\\[\\]])\\S{8,}$",
        "Message": "Passwords must contain at least one upper case character, at least one lower case character, at least one number, at least one symbol and must be at least 8 characters long."
      }
    ]
  }
  ...
}

Nucleus:PasswordOptions:PasswordComplexityRules

Password complexity rules are regular expressions. You can specify multiple password complexity rules and all of them must succeed (match) in order for a password to be valid.

Pattern (String) Regular expression which passwords must match in order to be valid.
Message (String) Error message when the pattern does not match the entered password.

Nucleus:CacheOptions

Specifies cache capacity and expiry for the named cache. Once the cache capacity threshold is reached, new cache entries will displace the oldest cache entry. Cache entries are automatically removed once they are older than ExpiryTime. ExpiryTime is expressed as a time span (hh:mm:ss).

Nucleus core cache keys are PageCache, PageRouteCache, PageMenuCache, MailTemplateCache, PageModuleCache, RoleCache, RoleGroupCache, ScheduledTaskCache, SiteCache, SiteDetectCache, UserCache, FolderCache, ListCache, ContentCache, SessionCache. If configuration values are omitted, the default capacity is 1000, and expiry time is 5 minutes.

Extensions may cache values: refer to each extension's documentation for the cache key name, or use the System control panel / Cache tab to view a list of caches and their configured values.

Capacity (Integer) Number of entities to cache in memory.
ExpiryTime (Timespan) Expiry time for cache entries.
"Nucleus":
  ...
  "CacheOptions": {
    "PageCache": {
      "Capacity": 500,
      "ExpiryTime": "00:15:00"
    },
    "PageModuleCache": {
      "Capacity": 2000,
      "ExpiryTime": "00:15:00"
    }
  }

Nucleus:SecurityHeaderOptions

Specifies options for SecurityHeadersMiddleware. The SecurityHeadersMiddleware adds security headers to HTTP responses, which help protect against common web vulnerabilities. These options can be used to override the automatic behavior of the middleware.

Nucleus automatically generates a Content Security Policy (CSP) header. You only need to use the SecurityHeaderOptions if you need to override the automatic behavior of the middleware, or if you want to add additional security headers or modify the automatic Content Security Policy directives. Refer to MDN Web Docs for more information on Content Security Policy and security headers.

Headers A list of security headers to be added to the response. These values override the values which would otherwise be generated by SecurityHeadersMiddleware.
Directives A list of Content Security Policy directives to be added to the response. These values modify the auto-generated directives which would otherwise be set by SecurityHeadersMiddleware.
ReportUri (string). If set, overrides the URI to which Content Security Policy violation reports should be sent. The default value is "/_csp-reports". If this setting is specified and set to an empty string, disables CSP reporting.
ReportOnly (boolean). If true, enables Content Security Policy report-only mode.
"Nucleus": 
{
  "SecurityHeaderOptions": 
  {
    "Headers": [
      {
        "Name": "X-Content-Type-Options",
        "Value": "nosniff"
      }
    ],
    "Directives": [
      {
        "Name": "default-src",
        "Value": "'self' https://example.com"
      },
      {
        "Name": "script-src",
        "Uris": "https://cdn.example.com",
        "UriOperation": "Append"
      }
    ],
    "ReportUri": "https://my-log-server/csp-reports"
  }
  ...
}

Nucleus:SecurityHeaderOptions:Headers[n]

Name Http header name. The headers written by the SecurityHeadersMiddleware are: Content-Security-Policy, Reporting-Endpoints, X-Content-Type-Options, X-XSS-Protection, Referrer-Policy and X-Permitted-Cross-Domain-Policies.
Value Http header value. If a header name and value is specified, SecurityHeadersMiddleware will use the value, and will not generate an automatic value.

Nucleus:SecurityHeaderOptions:Directives[n]

Name Content Security Policy directive name. SecurityHeadersMiddleware writes directives for default-src, script-src, style-src, img-src, frame-ancestors, report-uri and report-to.
Value Specifying a value will override the value which is generated by SecurityHeadersMiddleware. If you want to add extra Uris to the directive, use the Uris property instead.
Uris (string) A list of space-delimited Uris. Depending on the value of UriOperation, the specified Uris are either added to the list of automatically-derived values, or conpletely replace them. In most cases you should include a "/" character at the end of each Uri to ensure that the directive applies to all subfolders and files.
UriOperation Append or Replace. The default value is Append.