8.1.1.3. Data Received from the OpenNAC Server
The following data is received from OpenNAC Enterprise in response to device information sent via the POST method to /agent.
- Scripts: scripts are received by the OpenNAC Server to be executed after each device’s information is sent. This point is detailed in a later section of this document. 
- Configuration updates and interface: The Agent’s configuration is received; time interval between each scan, if the sending of logs to the server is enabled, the language of the agent’s taskbar, etc. There is also information regarding the Agent’s connection to OpenNAC Enterprise, such as the protocol. 
- USB policies: USB policies generated by the OpenNAC Portal to detect valid and invalid USB devices on the device running the Agent. These are by product class and by specific product. For each type, there is a list of allowed and a list for not allowed. 
- VPN configuration: We get an object for each VPN configuration. Each of the configurations is a string that represents the configuration file for the connection to the VPN. 
 
8.1.1.3.1. Example of payload
{
    "AGENT_CONFIG":{
        "INTERVAL": "3600",
        "FULL_INTERVAL": "86400",
        "START_MODE_INTERVAL": "120",
        "IGNORE_SC_STATUS_INTERVAL": "420",
        "INTERVAL_BETWEEN_USER_SESSION_EVENTS": "30",
        "DISCOVERY": "0",
        "DEBUG": "0",
        "SENDLOGSTOSERVER": "0",
        "MAXLOGSIZE": "1",
        "MAXCOMPRESSEDLOGS": "10",
        "UPDATE": "1.0.0"
    },
    "AGENT_CONNECTION": {
        "PROTOCOL": "https",
        "ACTION": "/opennac-agent",
        "PING_ACTION": "/admin/img/logo_opencloudFactory.png",
        "IP": "10.21.1.40",
        "TAG": "bb7416c44d524d098fc0bf00eb34a726"
    },
    "AGENT_TASKBAR_CONFIG": {
        "ENABLED": "1",
        "DEBUG": "0",
        "PLUGIN_VPN": "1",
        "LANGUAGE": "en",
        "MUI": "en-US"
    },
    "AGENT_QUERY": [
        {
            "TYPE": "PS",
            "KEY": "test1",
            "IMPERSONATE": "1",
            "SCRIPT": "22test"
        }
    ],
    "USB_POLICY_CLASS_WHITELIST": [],
    "USB_POLICY_CLASS_BLACKLIST": [
        {
            "CLASS_ID": "01"
        }
    ],
    "USB_POLICY_PRODUCT_WHITELIST": [],
    "USB_POLICY_PRODUCT_BLACKLIST": [
        {
            "VENDOR_ID": "0x090C",
            "PRODUCT_ID": "*"
        },
        {
        "VENDOR_ID": "0x047B",
        "PRODUCT_ID": "0x0001"
            }
        ],
    "AGENT_HASH_QUERY": "e32c243bc7991c6bc7420fa783f71a09",
    "AGENT_VPN_CONFIG": {
        "vpnPublicDemoCenter": ".ovpn file content",
        "EmmaVPNRoadWarrior": ".ovpn file content"
    }
    "vlan": "0",
    "AGENT_POLICY_NAME": "default",
    "AGENT_POLICY_USER_MESSAGE": "msg example",
    "AGENT_DEVICE_TAGS": "ONC_AUTOLEARNED,ONC_AGENT,ONC_WIN_AGENT, ISS_FW_STATUS,ISS_FW_UPDATE,ISS_FW_ENABLED,ISS_AV_STATUS, ISS_AV_UPDATE,ISS_AV_ENABLED,DOS_WINDOWS_10,ROS_WINDOWS"
}
AGENT_CONFIG: This JSON object offers new settings to overwrite in the Agent. This configuration is editable in the OpenNAC Portal.
- INTERVAL: Time interval between each normal scan (light payload). 
- FULL_INTERVAL: Time interval between each full scan (full payload). 
- START_MODE_INTERVAL: Wait time to start full scan at agent initialization (in seconds). 
- IGNORE_SC_STATUS_INTERVAL: Ignore security center events during x seconds after windows initialization. 
- INTERVAL_BETWEEN_USER_SESSION_EVENTS: Time interval between user session events. 
- DISCOVERY: If discovery will be executed or not. 
- DEBUG: If debug mode is enabled or not. 
- SENDLOGSTOSERVER: If daemon logs will be sent from the Agent to the server. 
- MAXLOGSIZE: Maximum log file size (in MB). 
- MAXCOMPRESSEDLOGS: Max number of old logs saved. 
- UPDATE: Minimum version required. 
AGENT_CONNECTION
- PROTOCOL: Connection protocol. 
- ACTION: Connection endpoint. 
- PING_ACTION: Endpoint to discover the IP that agent uses to make requests. 
- IP: Connection IP. 
- TAG: Agent connection tag. It works as unique identifier. 
AGENT_TASKBAR_CONFIG
- ENABLED: If the taskbar is enabled or not. 
- DEBUG: If debug mode is used or not. 
- PLUGIN_VPN: If VPN plugin is used or not. 
- LANGUAGE: Taskbar language. 
- MUI: MUI language. 
AGENT_QUERY
- TYPE: The type of the script. It can be cmd, powershell, cscript, etc. 
- KEY: Unique identifier for the agent script. 
- IMPERSONATE: If the script will be executed as impersonated or not. Impersonated means that it will be executed as a new process assigned to the user with the logged in user. Otherwise, it will be executed with the same process used for the Agent. 
- SCRIPT: The script code to execute. 
USB_POLICY_CLASS_WHITELIST:
- CLASS_ID: The family class identifier (hexa format XX). It can represent a type of device, for example, Audio, Printer, etc. 
USB_POLICY_CLASS_BLACKLIST:
- CLASS_ID: The family class identifier (hexa format XX). It can represent a type of device, for example, Audio, Printer, etc. 
USB_POLICY_PRODUCT_WHITELIST:
- VENDOR_ID: Vendor identifier (hexa format XXXX). 
- PRODUCT_ID: Product identifier (hexa format XXXX). If this value is * it means that all products of the vendor will be in the list. 
USB_POLICY_PRODUCT_BLACKLIST:
- VENDOR_ID: Vendor identifier (hexa format XXXX). 
- PRODUCT_ID: Product identifier (hexa format XXXX). If this value is * it means that all products of the vendor will be in the list. 
AGENT_HASH_QUERY: Agent hash query.
AGENT_VPN_CONFIG:
- vlan: VLAN assigned for the user specified in the UID parameter within OPENNAC. 
AGENT_POLICY_NAME: Agent policy name matched for the user specified in the UID parameter within OPENNAC.
AGENT_POLICY_USER_MESSAGE: User message when the policy matches.
AGENT_DEVICE_TAGS: Tags learned by matching the policy.