Desktop owner settings
Desktop owner settings are global settings that control aspects of the OpenFin environment on an individual computer or device.
The global desktop settings that can be defined include the following:
- Allowed applications
- Custom URLs (e.g., OpenFin assets, license server)
- Global settings for applications, such as whether and where they can have shortcuts
While these settings can be defined directly in the Windows registry, doing so is inconvenient and not very scalable. A more common, convenient, and scalable approach is to define settings in a JSON file, typically residing on the customer's network, and to set only a single registry key containing the location of the desktop owner settings file. This file can therefore be easily updated; it's also possible to define multiple desktop owner settings files, depending on the category of user.
When the OpenFin RVM launches, it does the following:
- It reads the
DesktopOwnerSettings
registry key to find the location of the desktop owner settings file. - It parses the file and overrides any equivalent registry settings, such as
assetsUrl
orlrsUrl
, with the settings specified in the file. RVM versions 5.3 and up cache the settings in the RVM installation directory.
The following registry key is used to specify the desktop owner file:
Key: HKEY_LOCAL_MACHINE\Software\OpenFin\RVM\Settings\DesktopOwnerSettings
Data type: String
Example value: "https://example.com/company/files/end-user-desktop-owner-settings.json"
Starting in RVM version 7.0, the RVM also reads the registry key and the settings file whenever it launches an application. It updates the values of settings where:
- The setting can be refreshed.
- The value is different from the last time it was read.
This feature enables desktop owners to update settings for newly-launched applications without terminating the RVM and other running applications, possibly by pointing to a completely different settings file. For already-running applications, the settings values remain as they were at the time that the application was launched.
Note
In the following tables, properties that can be refreshed are marked with the ↺ character.
The following top-level properties contain settings for various aspects of the OpenFin environment.
Property | Description | Type |
---|---|---|
contactInfo | (RVM v11+) Info about who to contact about support issues for this system. | Object |
contactInfo.email | (RVM v11+) Email address of a support contact. Required when using runtimeControls settings; if omitted, the Runtime version controls are not enforced. | String |
customProtocols | (RVM v12+, Runtime v34+) Contains up to two members, which are arrays of strings. allowList is protocol schemes that are allowed; denyList is protocol schemes that are denied. Refer to Custom protocols in URLs. | Object |
desktopSettings | General settings. | Object |
extensionServerURLs (v38.126.83.73+) | List of URLs for allowed servers for installing Chrome extensions (See Microsoft Single Sign On extension) | Array |
applicationSettings ↺ | Settings to block or allow applications' use of secured APIs. Refer to API security for details of these settings. | Object |
trustedAppConfigs | OpenFin-provided definition that, if validated at runtime, allows access to protected features. Refer to Trusted application configurations. | Object |
whitelist ↺ | Rules defining which applications can be launched and which are blocked. Refer to the Allowed applications section. | Object |
[services ]↺ | Deprecated Definitions of custom services. | Array of objects |
The following settings can be defined as members of the desktopSettings
object. Some of theses settings can also be set in the Windows Registry; in the table, those settings are linked to their corresponding Registry key documentation.
Property | Description | Type | Default value |
---|---|---|---|
applicationLogging ↺ | Controls applications' use of log files, through the following settings. | Object | |
applicationLogging. maxAppLogFileSizeMB ↺ | Maximum size in megabytes for an application-specific log file. | integer | Infinity (i.e., unlimited) |
applicationLogging. maxAppLogFiles ↺ | Maximum number of log files per application. | integer | Infinity (i.e., unlimited) |
assetsUrl | URL for downloading OpenFin assets, including Runtime and RVM. | string | "https://cdn.openfin.co/ release" |
cleanUnusedRuntimes ↺ | Whether the RVM cleans up runtime and runtime cache folders that are no longer referenced by any installed application. | boolean | true |
crashReporterUrl ↺ | The URL endpoint to which the RVM sends crash reports | string | "https://dl.openfin.co/ services/crash-report-v2" |
deployment | An object containing settings that control aspects of deploying OpenFin. Refer to the Deployment section below. | Object | none |
disableErrorReporting | (RVM v10+) Whether to hide the Report Error button in the RVM error reporting dialogs. If set to true, the button is not shown. | boolean | false |
disableShortcutCreation | Whether to prevent applications installed via RVM from creating their own shortcuts. By default, applications can create shortcuts. | boolean | false |
enableDesktopShortcut | Globally determines whether applications have desktop shortcuts. | boolean | true |
enableInstallation Detection | Whether to allow the RVM to install a font on the system, so that web pages can detect if OpenFin is installed. | boolean | true in RVM 12+; false in earlier releases |
enableRuntimeDiagnostics ↺ | Whether the RVM sends API diagnostics to OpenFin. Refer to OpenFin API diagnostics for details. | boolean | true |
enableServices ↺ | Whether use of services is allowed. | boolean | true |
enableStartMenuShortcut | Globally determines whether applications have Start menu shortcuts. | boolean | true |
enableStartupShortcut | Globally determines whether OpenFin applications have startup shortcuts. | boolean | true |
lrsUrl ↺ | License relay server URL, to which the RVM sends licensing information, for all applications. | string | "https://dl.openfin.co/ services" |
network | Contains settings related network operations (for RVM only). | Object | |
network.connectTimeout | Time in ms to wait for a connection to be made before canceling the connection request. | integer | 0 |
network.receiveTimeout | Time in ms to wait to receive a response, before canceling the request. | integer | 0 |
network.readTimeout | Time in ms to wait while reading a response, before canceling the request. | integer | 0 |
network.sendTimeout | Time in ms to while while sending a request, before canceling the request. | integer | 0 |
reportErrorUrl | (RVM v10+) The URL of a server to send error reports to, for all OpenFin applications on the system. For information on hosting a custom error report service, contact [email protected] | string | "https://dl.openfin.co" |
securedAPIDefault Permission ↺ | Default permission for secured APIs whose permission is not otherwise defined. Refer to API security for details. | string: one of "allow", "deny", "prompt". | "prompt" |
startMenuRootFolder | Root folder for applications' Start menu shortcuts. | string | standard Start menu directory |
systemApps ↺ | Defines custom settings for system applications. Refer to Workspace settings for an example. Note: Prior to RVM version 6.4.1.1, this setting was named openfinSystemApplications . | Object | {} |
trackBetaAutoUpdates | Whether the RVM tracks the beta channel for automatic updates. | boolean | false |
unusedRuntimeExpiration InMinutes ↺ | Amount of time (in minutes) after which the RVM deletes a downloaded runtime and corresponding runtime cache folder(s). | integer | 43,200 (i.e., 30 days) |
useLocalAPILanguage | Whether to use strings hardcoded in the RVM binary to describe secured APIs in the Review Security Permissions dialog box. If false, the strings are retrieved from https://cdn.openfin.co/release/rvm/ApiLanguage; retrieving the strings requires internet access. | boolean | false |
Use these properties only under specialized circumstances.
Property | Description | Type | Default value |
---|---|---|---|
protocolHandlerLocation | Location where fin and fins links launch the RVM from. (RVM 6.6+) Note: Takes precedence over deployment.rvmInstallDirectory . Use only in situations where this location needs to be explicitly set, such as when the default location in a virtual environment is periodically emptied. | string | \"%local appdata%/OpenFin\" |
One important use of the desktop owner settings file is to allow applications listed in the whitelist
object.
The members of the whitelist
object are the following:
-
distributionEmail
↺: An email alias that end-users can contact to request permission for a denied application. It is displayed in a dialog box that is shown to the end-user when an application tries and fails to launch because it is not allowed. -
allowed
↺: An array of objects specifying applications that are allowed to run.
An application can be allowed by listing its client ID (same as the licenseKey
in its application manifest) as well an app UUID or app config domain. If it is listed, the application launches.
The deployment
member of the desktopSettings
object contains several properties that control aspects of OpenFin's operation that are relevant to deployment to end users.
Property | Description | Type | Default |
---|---|---|---|
runtimeCache | Location for runtimes to write cache data. Overrides application manifest settings. | string | "%rvmInstall Directory%/cache" |
runtimeControls. allowedVersionList | (RVM v11+) A list of Runtime versions that are allowed to run. | Array of strings | none |
runtimeControls. blockedVersionsList | (RVM v11+) A list of Runtime versions that are blocked from running. | Array of strings | none |
runtimeControls. enforce | (RVM v11+) If "strict" , the RVM blocks a disallowed version from running; if "warn" , the RVM only warns that the version is disallowed. | String: "strict" or "warn" | "warn" |
runtimeControls. maximumAllowedVersion | (RVM v11+) The lowest Runtime version number that can be run. | String | none |
runtimeControls. minimumAllowedVersion | (RVM v11+) The highest Runtime version number that can be run. | String | none |
runtimeDirectory | Location for runtime binary files. | string | "%rvmInstall Directory%/runtime" |
rvmControls. versionPattern | (RVM v11+) A pattern for RVM versions that are allowed to be run. A version pattern consists of up to 4 dot-separated levels, where a level is either a concrete number or * ; a concrete number must not follow * . | String | none |
rvmInstallDirectory | Location for RVM binary files. The RVM copies itself here. | string | "%local appdata%/OpenFin" |
shortcutPointsTo OriginalInstall | Whether the RVM installs itself every time it runs. A true value is typically used in environments such as Citrix that wipe %localappdata%. | boolean | false |
Warning
If you use any of the
runtimeControls
settings, you must also define the top-levelcontactInfo.email
option. If you do not specify an email address that users can contact for support in case of problems, then the Runtime version controls are not enforced.
{
"desktopSettings": {
"assetsUrl": "http://localhost:8000/",
"lrsUrl": "http://localhost:8000/services",
"contactInfo" : {
"email" : "[email protected]"
},
"cleanUnusedRuntimes": true,
"unusedRuntimeExpirationInMinutes": 43200,
"enableDesktopShortcut": true,
"enableStartMenuShortcut": true,
"enableStartupShortcut": true,
"disableShortcutCreation": false,
"startMenuRootFolder": "CompanyName",
"network": {
"readTimeout": 30000,
"sendTimeout": 30000,
"receiveTimeout": 30000,
"connectTimeout": 30000
},
"deployment": {
"runtimeCache": "CUSTOM_RUNTIME_CACHE_DIR",
"runtimeDirectory": "CUSTOM_RUNTIME_DIR",
"runtimeControls": {
"enforce" : "warn",
"allowedVersionsList" : ["N.0.*.*", "M.0.0.*"],
"blockedVersionsList" : ["K.106.83.*"],
"maximumAllowedVersion" : "W.*.*.*",
"minimumAllowedVersion" : "G.0.0.*"
},
"rvmControls" : {
"versionPattern" : "X.Y.Z.*"
},
"rvmInstallDirectory": "CUSTOM_RVM_DIR"
},
"applicationLogging": {
"maxAppLogFileSizeMB": 10000,
"maxAppLogFiles": 10
}
},
"whitelist": {
"distributionEmail": "[email protected]",
"allowed": [
{
"appNames": [
"COMPANY_NAME"
],
"clientId": "COMPANY_NAME_CLIENT_ID"
},
{
"appNames": [
"COMPANY_NAME"
],
"clientId": "OPENFIN_SPECIAL_ASSIGNED_ID",
"appUuids": [
"APP_1",
"APP_2",
"APP_3"
]
},
{
"appNames": [
"COMPANY_NAME"
],
"clientId": "COMPANY_NAME_SPECIAL_ASSIGNED_ID",
"appUuids": [
"APP_1"
],
"appRuntimes": [
"1.2.3.4",
"5.6.7.8"
],
"appConfigDomains": [
"www.COMPANY1.com",
"www.COMPANY2.com"
]
}
]
}
}
Updated about 6 hours ago