- 16 Jan 2025
- 11 Minutes to read
- Print
- DarkLight
- PDF
Agent Configuration
- Updated on 16 Jan 2025
- 11 Minutes to read
- Print
- DarkLight
- PDF
Agent.json
The agent.json file allows for configuration of the Liquit Universal Agent.
The path to the agent.json location is:
Platform | Path |
---|---|
Windows | %ProgramData%\Liquit\Agent\Agent.json |
macOS | /Library/Application Support/com.liquit.Agent/Agent.json |
Below you will find a sample an agent.json configuration.
{
"zone": "https://workspace.liquit.com",
"registration": {
"type": "Certificate"
},
"login": {
"sso": true
},
"log": {
"level": "Debug"
}
}
Backslashes '\' should be escaped within a JSON file. So that a single '\' will be a '\\'.
JSON keys are case sensitive. For example, "autostart" will not work, but "autoStart" will work.
Zone
This should be the URL with the FQDN where the targeted Liquit Workspace Zone is reachable.
{
"zone": "https://company.liquit.com/"
}
Prompt Zone
This key controls the display of the Zone Prompt dialog box where the user can configure the zone URL. The value entered in the dialog box is saved in the zone
key.
This feature works only if there is no URL configured in the zone
key.
Available options:
- Disabled: User is NOT prompted to enter the zone URL, even if it is not configured
- Show: User is prompted to enter the zone URL, if none is configured. This is the default value of the key.
{
"promptZone": "Show"
}
Registration
These settings allows a device to register itself with Liquit Workspace. Some of them without requiring a user login.
For the User Account and Agent Credentials registration methods, you need to assing the user an access policy that has the Register device privilege. By default, the predefined User access policy has this permission granted.
For a detailed description of Device Registration options within Liquit Workspace UI, see Device Registration.
For step by step instructions on methods of registering a device, see Device registration methods.
User Account based registration example:
{
"registration": {
"type": "User"
}
}
Agent Credentials based registration example:
{
"registration": {
"type": "Credentials",
"username": "local\\wksimport",
"password": "P@ssw0rd"
}
}
Agent Certificate based registration example:
Example 1:
{
"registration": {
"type": "Certificate",
"certificateThumbprint": "69f4db57b74e13415cd103323331d95022d840c1"
}
}
Example 2:
{
"registration": {
"type": "Certificate"
}
}
Agent Certificate Enrollment based registration example:
"registration": {
"type": "CertificateEnrollment",
"certificateIssuer": "Sectigo RSA Domain Validation Secure Server CA"
}
Keys
Key | Description | Default |
---|---|---|
type |
| User |
username | When type key is set to Credentials, this username is used to register the device. | |
password | When type key is set to Credentials, this password is used to register the device. | |
certificateThumbprint | The hexadecimal string that uniquely identifies the certificate, for example: ea7f07211fddc0df73bac1437a3ff932ce531005. | |
certificateIssuer | The authority that issued the certificate. |
When type key is set to Certificate or Certificate Enrollment, the certificateThumbprint
and certificateIssuer
are optional settings that can be used to verify the certificate.
If the value of certificateThumbprint
is not specified: the certificate must persist on the device in the following locations:
- Windows: %ProgramData%\Liquit\Agent\AgentRegistration.cer
- macOS: /Library/Application Support/com.liquit.Agent/AgentRegistration.cer
If the value of certificateThumbprint
is specified: then the Windows Certificate Store or macOS Keychain will be checked for a certificate with the specified value.
Deployments
{
"deployment": {
"enabled": false,
"start": true,
"context": "Device",
"cancel": true,
"triggers": false,
"autoStart": {
"enabled": false,
"deployment": null,
"timer": 0
}
}
}
Key | Description | Default |
---|---|---|
enabled | If set to true, Liquit Workspace will enable the deployment process on this machine. | false |
start | If set to true, the process of deployments is automatically started.
| true |
context | The context in which the deployment should run.
| Device |
cancel | If set to true, the deployment process can be cancelled. | true |
triggers | If set to true, Liquit Workspace events (refresh/ login) can still be executed. | false |
Autostart
Key | Description | Default |
---|---|---|
enabled | If set to true, Liquit Workspace will automatically start the deployment process when a corresponding deployment is found as configured in the deployment key or when only one deployment is available for this device. | false |
deployment | The targeted deployment which can be either the name or the ID of the deployment. | |
timer | This key accepts an integer and represents the number of seconds Liquit Workspace will wait before automatically starting the deployment. | 0 |
Log
The Liquit Universal Agent logs events it initiates.
{
"log": {
"level": "Debug",
"agentPath": "Agent.log",
"userHostPath":"UserHost.log",
"rotateCount": 5,
"rotateSize": 1048576
}
}
Key | Description | Default |
---|---|---|
level | This element is used to define the level of logging. Liquit Workspace distinguishes between two logging levels:
| Info |
agentPath | You can define an alternate path of the Agent log files here. The default location is:
| Agent.log |
userHostPath | You can define an alternate path of the userhost log files here. The default location is:
| UserHost.log |
rotateCount | The number of logfiles that will be archived. | 5 |
rotateSize | The limit of logfile size in bytes. When this limit is reached, a new logfile will be created and the old file will be archived. | 1048576 |
Login
This element controls the login behaviour for the Liquit Universal Agent.
{
"login": {
"enabled": true,
"sso": true,
"identitySource": "LIQUIT",
"timeout": 4
}
}
Key | Description | Default |
---|---|---|
enabled | If set to true, the user will be prompted for login. | true |
sso | If set to true, the Universal Agent will use the value of the identity source key you provide, to facilitate SSO. | false |
identitySource | The default identity source used to log in the user. Use the name of the identity source as you defined it within Liquit Workspace. | |
timeout | The interval in seconds after which the Liquit Workspace login prompt will be displayed if SSO could not be performed within the interval. | 4 |
Icon
Controls the behaviour of the system tray icon.
{
"icon": {
"enabled": true,
"exit": true,
"timeout": 30
}
}
Key | Description | Default |
---|---|---|
enabled | If set to false, the tray icon is hidden from the user. | true |
exit | If set to false, the quit option from the icon's context menu in the system tray is hidden. The quit option will always be disabled if the launcher is enabled and is not allowed to close. | true |
timeout | The number of seconds Liquit Workspace waits for the Windows shell to load in order to display the system tray icon. Note that there is no maximum time limit. | 30 |
Cache
This element controls the settings of the cache.
{
"cache": {
"enabled": true,
"offline": true,
"path": "Cache",
"tempPath": "Temp",
"packageTempPath": "${TEMP}",
"autoClean": true,
"expireContent": 90
}
}
Key | Description | Default |
---|---|---|
enabled | When an identity is entitled to a package, the package is automatically downloaded and cached on the end-user device. It will remain there even after the session ends, as long as the end-user is entitled to it. When the entitlement is removed, the cache is cleaned depending on how autoClean and expireContent are configured. | |
offline | If set to true, the offline mode will be available for the local device. If set to false, the packages marked offline will not be automatically downloaded and the Liquit Launcher won't switch to offline mode. | true |
path | The location on the local device where all the content used by the Agent is cached. Note that this path must be relative to the Liquit Workspace directory. By default, this path is configured to:
| Cache |
tempPath | The temp directory on the local device, used for uploading folders to the Liquit Workspace. By default, this path is configured to:
| Temp |
packageTempPath | When a Liquit Workspace app is entitled to a user, it is automatically deployed in the local cache directory: %ProgramData%\Liquit\Agent\Cache. The name of the app will actually be a GUID with the .dat extension. Once it gets installed on the local device, the app is copied in the directory configured for the ${PackageTempDir} variable and renamed to its true name. By default, the path of ${PackageTempDir} is configured to:
| ${TEMP} |
autoClean | If enabled, the stale content from the local cache of devices is automatically deleted if one of the following conditions are met:
| true |
expireContent | The period in days after which the local cache of devices is deleted automatically if it meets one of the conditions defined above for the autoClean . | 90 |
Native Icons
Modify the behaviour of the native icons configured for package entitlements that allow you to display Liquit icons on certain locations within the device's operating system.
{
"nativeIcons": {
"enabled": true,
"primary": true,
"startMenuPath": "${Programs}\\Liquit"
}
}
Key | Description | Default |
---|---|---|
enabled | Allow Liquit Workspace to push native icons configured for package entitlements to the operating system of devices. | true |
primary | If set to true, only icons from the zone defined in the zone key in the Agent.json file will be pushed. | true |
startMenuPath | The location where the Start Menu items will be displayed; it allows you to specify a different directory than Liquit. This option is available only for Windows. | ${Programs}\\Liquit |
Triggers
Modify the behaviour of the events configured for package entitlements.
{
"triggers": {
"enabled": true,
"primary": true
}
}
Key | Description | Default |
---|---|---|
enabled | Allow Liquit Workspace to execute events like refresh or login for example. | true |
primary | If set to true, the Agent will trigger events only for the primary zone defined in the zone key in the Agent.json file. | false |
Refresh
Modify the behaviour of the agent refresh process.
{
"refresh": {
"manual": true,
"interval": 3600
}
}
Key | Description | Default |
---|---|---|
manual | If set to false, the refresh option from the icon's context menu in the system tray is hidden. | true |
interval | This value represents the time interval between Liquit Workspace refreshes. | 3600 |
Launcher
{
"launcher": {
"enabled": true,
"state": "Default",
"start": "Auto",
"tiles": false,
"minimal": false,
"contextMenu": true,
"sideMenu": "Tags",
"close": true
}
}
Keys | Description | Default |
---|---|---|
enabled | Enable or disable the Liquit Launcher. | true |
state | Defines how the Liquit Launcher will be shown on start up:
| Default |
start | Defines when the launcher is started:
| Auto |
tiles | If set to true, Liquit Workspace will use the tile-themed skin. | false |
minimal | If set to true, the Side Menu and tabs (Workspace, Contacts, Catalog, Manage) are hidden. Only the toolbar without the side menu toggler is displayed. | false |
contextMenu | If set to true, the context menu is available across Liquit Launcher. | true |
sideMenu | Choose which tab(s) should be opened by default in the Side Menu.:
| |
close | If set to false, the X close button of the Liquit Launcher window is disabled and the quit option from the icon's context menu in the system tray is hidden. | true |
Restrict Zones
Define which Liquit Zones are always allowed to communicate with the local Agent.
{
"restrictZones": false
}
If set to true, only the zones you list will have access to the local Agent. If set to false, a warning will be displayed asking the user if the zone where he wants to navigate is allowed to access the agent. The default value is false.
Trusted Zones
Here you can add additionally trusted zones.
{
"trustedZones": [
"zone1.liquit.com",
"zone2.liquit.com",
"*.dev.liquit.com"
]
}
Events
Configure how event data is uploaded to server when the Agent triggers the event.
{
"events": {
"enabled": true,
"interval": 30
}
}
Keys | Description | Default |
---|---|---|
enabled | If set to true, event data is uploaded from the agent to the server. | true |
interval | The time interval in seconds when the event data is uploaded from the Agent to the server. | 30 |
Web Socket
This protocol allows a more efficient way of handling data. This option is mandatory for the push event feature described in the Events section.
{
"webSocket": {
"enabled": true
}
}