device control policies - CrowdStrike/falconpy GitHub Wiki
| Operation ID | Description | ||||
|---|---|---|---|---|---|
| 
 | Search for members of a Device Control Policy in your environment by providing a FQL filter and paging details. Returns a set of host details which match the filter criteria. | ||||
| 
 | Search for Device Control Policies in your environment by providing a FQL filter and paging details. Returns a set of Device Control Policies which match the filter criteria. | ||||
| 
 | Retrieve the configuration for the Default Device Control Policy. | ||||
| 
 | Update the configuration for the Default Device Control Policy. | ||||
| 
 | Perform the specified action on the Device Control Policies specified in the request. | ||||
| 
 | Get default device control settings (USB and Bluetooth). | ||||
| 
 | Update the configuration for Default Device Control Settings. | ||||
| 
 | Sets the precedence of Device Control Policies based on the order of IDs specified in the request. The first ID specified will have the highest precedence and the last ID specified will have the lowest. You must specify all non-Default Policies for a platform when updating precedence. | ||||
| 
 | Retrieve a set of Device Control Policies by specifying their IDs. | ||||
| 
 | Get device control policies for the given filter criteria. Supports USB and Bluetooth. | ||||
| 
 | Create Device Control Policies by specifying details about the policy to create. | ||||
| 
 | Create Device Control Policies by specifying details about the policy to create. | ||||
| 
 | Delete a set of Device Control Policies by specifying their IDs. | ||||
| 
 | Update device control policy's classes (USB and Bluetooth). | ||||
| 
 | Update Device Control Policies by specifying the ID of the policy and details to update | ||||
| 
 | Update Device Control Policies by specifying the ID of the policy and details to update | ||||
| 
 | Search for members of a Device Control Policy in your environment by providing a FQL filter and paging details. Returns a set of Agent IDs which match the filter criteria. | ||||
| 
 | Search for Device Control Policies in your environment by providing a FQL filter and paging details. Returns a set of Device Control Policy IDs which match the filter criteria. | ||||
WARNING
client_idandclient_secretare keyword arguments that contain your CrowdStrike API credentials. Please note that all examples below do not hard code these values. (These values are ingested as strings.)CrowdStrike does not recommend hard coding API credentials or customer identifiers within source code.
Search for members of a Device Control Policy in your environment by providing a FQL filter and paging details. Returns a set of host details which match the filter criteria
query_combined_policy_members
| Method | Route | 
|---|---|
| /policy/combined/device-control-members/v1 | 
- Produces: application/json
| Name | Service | Uber | Type | Data type | Description | 
|---|---|---|---|---|---|
| filter |  |  | query | string | FQL Syntax formatted string used to limit the results. | 
| id |  |  | query | integer | The ID of the Device Control Policy to search for members of. | 
| limit |  |  | query | integer | Maximum number of records to return. (Max: 5000) | 
| offset |  |  | query | integer | Starting index of overall result set from which to return ids. | 
| sort |  |  | query | string | The property to sort by. (Ex: modified_timestamp.desc) | 
| parameters |  |  | query | dictionary | Full query string parameters payload in JSON format. | 
from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
response = falcon.query_combined_policy_members(id="string",
                                                filter="string",
                                                offset=integer,
                                                limit=integer,
                                                sort="string"
                                                )
print(response)from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
response = falcon.queryCombinedDeviceControlPolicyMembers(id="string",
                                                          filter="string",
                                                          offset=integer,
                                                          limit=integer,
                                                          sort="string"
                                                          )
print(response)from falconpy import APIHarnessV2
# Do not hardcode API credentials!
falcon = APIHarnessV2(client_id=CLIENT_ID,
                      client_secret=CLIENT_SECRET
                      )
response = falcon.command("queryCombinedDeviceControlPolicyMembers",
                          id="string",
                          filter="string",
                          offset=integer,
                          limit=integer,
                          sort="string"
                          )
print(response)Search for Device Control Policies in your environment by providing a FQL filter and paging details. Returns a set of Device Control Policies which match the filter criteria
query_combined_policies
| Method | Route | 
|---|---|
| /policy/combined/device-control/v1 | 
- Produces: application/json
| Name | Service | Uber | Type | Data type | Description | 
|---|---|---|---|---|---|
| filter |  |  | query | string | FQL Syntax formatted string used to limit the results. | 
| limit |  |  | query | integer | Maximum number of records to return. (Max: 5000) | 
| offset |  |  | query | integer | Starting index of overall result set from which to return ids. | 
| sort |  |  | query | string | The property to sort by. (Ex: modified_timestamp.desc) | 
| parameters |  |  | query | dictionary | Full query string parameters payload in JSON format. | 
from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
response = falcon.query_combined_policies(filter="string",
                                          offset=integer,
                                          limit=integer,
                                          sort="string"
                                          )
print(response)from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
response = falcon.queryCombinedDeviceControlPolicies(filter="string",
                                                     offset=integer,
                                                     limit=integer,
                                                     sort="string"
                                                     )
print(response)from falconpy import APIHarnessV2
# Do not hardcode API credentials!
falcon = APIHarnessV2(client_id=CLIENT_ID,
                      client_secret=CLIENT_SECRET
                      )
response = falcon.command("queryCombinedDeviceControlPolicies",
                          filter="string",
                          offset=integer,
                          limit=integer,
                          sort="string"
                          )
print(response)Retrieve the configuration for the Default Device Control Policy.
get_default_policies
| Method | Route | 
|---|---|
| /policy/entities/default-device-control/v1 | 
- Produces: application/json
No keywords or arguments accepted.
from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
response = falcon.get_default_policies()
print(response)from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
response = falcon.getDefaultDeviceControlPolicies()
print(response)from falconpy import APIHarnessV2
# Do not hardcode API credentials!
falcon = APIHarnessV2(client_id=CLIENT_ID,
                      client_secret=CLIENT_SECRET
                      )
response = falcon.command("getDefaultDeviceControlPolicies")
print(response)Back to Table of Contents
Retrieve the configuration for the Default Device Control Policy.
update_default_policies
| Method | Route | 
|---|---|
| /policy/entities/default-device-control/v1 | 
- Produces: application/json
| Name | Service | Uber | Type | Data type | Description | 
|---|---|---|---|---|---|
| blocked_custom_message |  |  | body | string | String containing the blocked notification custom message. When this keyword is provided, you do not need to provide the blocked_notificationorbodykeywords. | 
| blocked_notification |  |  | body | dictionary | Dictionary containing the blocked notification message. { "custom_message": "string", "use_custom": true } | 
| body |  |  | body | dictionary | Full body payload in JSON format. | 
| restricted_custom_message |  |  | body | string | String containing the restricted notification custom message. When this keyword is provided, you do not need to provide the restricted_notificationorbodykeywords. | 
| restricted_notification |  |  | body | dictionary | Dictionary containing the restricted notification message. { "custom_message": "string", "use_custom": true } | 
from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
blocked = {
    "custom_message": "string",
    "use_custom": True
}
restricted = {
    "custom_message": "string",
    "use_custom": True
}
response = falcon.update_default_policies(blocked_custom_message="string",
                                          blocked_notification=blocked,
                                          restricted_custom_message="string",
                                          restricted_notification=restricted
                                          )
print(response)from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
blocked = {
    "custom_message": "string",
    "use_custom": True
}
restricted = {
    "custom_message": "string",
    "use_custom": True
}
response = falcon.updateDefaultDeviceControlPolicies(blocked_custom_message="string",
                                                     blocked_notification=blocked,
                                                     restricted_custom_message="string",
                                                     restricted_notification=restricted
                                                     )
print(response)from falconpy import APIHarnessV2
# Do not hardcode API credentials!
falcon = APIHarnessV2(client_id=CLIENT_ID,
                      client_secret=CLIENT_SECRET
                      )
body_payload = {
    "custom_notifications": {
        "blocked_notification": {
            "custom_message": "string",
            "use_custom": boolean
        },
        "restricted_notification": {
            "custom_message": "string",
            "use_custom": boolean
        }
    }
}
response = falcon.command("updateDefaultDeviceControlPolicies", body=body_payload)
print(response)Back to Table of Contents
Perform the specified action on the Device Control Policies specified in the request
perform_action
| Method | Route | 
|---|---|
| /policy/entities/device-control-actions/v1 | 
- Produces: application/json
| Name | Service | Uber | Type | Data type | Description | 
|---|---|---|---|---|---|
| action_name |  |  | query | string | The action to perform. Allowed values: 
 | 
| action_parameters |  |  | body | list of dictionaries | List of name / value pairs in JSON format. | 
| body |  |  | body | dictionary | Full body payload in JSON format. | 
| group_id |  |  | body action_parameters | string | Host Group ID to apply the policy to. String. Overridden if action_parametersis specified. | 
| ids |  |  | body | string or list of strings | Device Control Policy ID(s) to perform actions against. | 
| parameters |  |  | query | dictionary | Full query string parameters payload in JSON format. | 
from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
response = falcon.perform_action(action_name="string",
                                 group_id="HOST_GROUP_ID",
                                 ids="ID_TO_UPDATE"
                                 )
print(response)from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
act_params = [{
    "name": "group_id",
    "value": "HOST_GROUP_ID"
}]
response = falcon.performDeviceControlPoliciesAction(action_name="string",
                                                     action_parameters=act_params,
                                                     ids="ID_TO_UPDATE"
                                                     )
print(response)from falconpy import APIHarnessV2
# Do not hardcode API credentials!
falcon = APIHarnessV2(client_id=CLIENT_ID,
                      client_secret=CLIENT_SECRET
                      )
act_params = [{
    "name": "group_id",
    "value": "HOST_GROUP_ID"
}]
# Only one ID may be updated at a time
body_payload = {
    "action_parameters": act_params,
    "ids": ["ID_TO_UPDATE"]
}
response = falcon.command("performDeviceControlPoliciesAction", action_name="string", body=body_payload)
print(response)Get default device control settings (USB and Bluetooth).
get_default_settings
| Method | Route | 
|---|---|
| /policy/entities/device-control-default-settings/v1 | 
- Produces: application/json
No keywords or arguments accepted.
from falconpy import DeviceControlPolicies
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
response = falcon.get_default_settings()
print(response)from falconpy import DeviceControlPolicies
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
response = falcon.getDefaultDeviceControlSettings()
print(response)from falconpy import APIHarnessV2
falcon = APIHarnessV2(client_id=CLIENT_ID,
                      client_secret=CLIENT_SECRET
                      )
response = falcon.command("getDefaultDeviceControlSettings")
print(response)Update the configuration for Default Device Control Settings.
update_default_settings
| Method | Route | 
|---|---|
| /policy/entities/device-control-default-settings/v1 | 
- Produces: application/json
| Name | Service | Uber | Type | Data type | Description | 
|---|---|---|---|---|---|
| body |  |  | body | dictionary | Full body payload in JSON format. | 
| bluetooth_custom_notifications |  |  | body | dictionary | Device Control policy bluetooth custom notifications. | 
| usb_custom_notifications |  |  | body | dictionary | Device Control policy USB custom notifications. | 
from falconpy import DeviceControlPolicies
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
bluetooth_custom = {
    "blocked_notification": {
        "custom_message": "string",
        "use_custom": boolean
    }
}
usb_custom = {
    "blocked_notification": {
        "custom_message": "string",
        "use_custom": boolean
    },
    "restricted_notification": {
        "custom_message": "string",
        "use_custom": boolean
    }
}
response = falcon.update_default_settings(bluetooth_custom_notifications=bluetooth_custom,
                                          usb_custom_notifications=usb_custom
                                          )
print(response)from falconpy import DeviceControlPolicies
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
bluetooth_custom = {
    "blocked_notification": {
        "custom_message": "string",
        "use_custom": boolean
    }
}
usb_custom = {
    "blocked_notification": {
        "custom_message": "string",
        "use_custom": boolean
    },
    "restricted_notification": {
        "custom_message": "string",
        "use_custom": boolean
    }
}
response = falcon.updateDefaultDeviceControlSettings(bluetooth_custom_notifications=bluetooth_custom,
                                                     usb_custom_notifications=usb_custom
                                                     )
print(response)from falconpy import APIHarnessV2
falcon = APIHarnessV2(client_id=CLIENT_ID,
                      client_secret=CLIENT_SECRET
                      )
body_payload = {
  "bluetooth_custom_notifications": {
    "blocked_notification": {
      "custom_message": "string",
      "use_custom": boolean
    }
  },
  "usb_custom_notifications": {
    "blocked_notification": {
      "custom_message": "string",
      "use_custom": boolean
    },
    "restricted_notification": {
      "custom_message": "string",
      "use_custom": boolean
    }
  }
}
response = falcon.command("updateDefaultDeviceControlSettings", body=body_payload)
print(response)Sets the precedence of Device Control Policies based on the order of IDs specified in the request. The first ID specified will have the highest precedence and the last ID specified will have the lowest. You must specify all non-Default Policies for a platform when updating precedence
set_precedence
| Method | Route | 
|---|---|
| /policy/entities/device-control-precedence/v1 | 
- Produces: application/json
| Name | Service | Uber | Type | Data type | Description | 
|---|---|---|---|---|---|
| body |  |  | body | dictionary | Full body payload in JSON format. | 
| ids |  |  | body | string or list of strings | Device Control Policy ID(s) to adjust precedence. | 
| platform_name |  |  | body | string | OS platform name. (Linux, Mac, Windows) | 
from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
id_list = 'ID1,ID2,ID3'  # Can also pass a list here: ['ID1', 'ID2', 'ID3']
response = falcon.set_precedence(ids=id_list, platform_name="string")
print(response)from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
id_list = 'ID1,ID2,ID3'  # Can also pass a list here: ['ID1', 'ID2', 'ID3']
response = falcon.setDeviceControlPoliciesPrecedence(ids=id_list, platform_name="string")
print(response)from falconpy import APIHarnessV2
# Do not hardcode API credentials!
falcon = APIHarnessV2(client_id=CLIENT_ID,
                      client_secret=CLIENT_SECRET
                      )
id_list = 'ID1,ID2,ID3'  # Can also pass a list here: ['ID1', 'ID2', 'ID3']
body_payload = {
    "ids": id_list,
    "platform_name": "string"
}
response = falcon.command("setDeviceControlPoliciesPrecedence", body=body_payload)
print(response)Retrieve a set of Device Control Policies by specifying their IDs
get_policies
| Method | Route | 
|---|---|
| /policy/entities/device-control/v1 | 
- Produces: application/json
| Name | Service | Uber | Type | Data type | Description | 
|---|---|---|---|---|---|
| ids |  |  | query | string or list of strings | The ID(s) of the Device Control Policies to return. | 
| parameters |  |  | query | dictionary | Full query string parameters payload in JSON format. | 
from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
id_list = 'ID1,ID2,ID3'  # Can also pass a list here: ['ID1', 'ID2', 'ID3']
response = falcon.get_policies(ids=id_list)
print(response)from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
id_list = 'ID1,ID2,ID3'  # Can also pass a list here: ['ID1', 'ID2', 'ID3']
response = falcon.getDeviceControlPolicies(ids=id_list)
print(response)from falconpy import APIHarnessV2
# Do not hardcode API credentials!
falcon = APIHarnessV2(client_id=CLIENT_ID,
                      client_secret=CLIENT_SECRET
                      )
id_list = 'ID1,ID2,ID3'  # Can also pass a list here: ['ID1', 'ID2', 'ID3']
response = falcon.command("getDeviceControlPolicies", ids=id_list)
print(response)Get device control policies for the given filter criteria. Supports USB and Bluetooth.
get_policies_v2
| Method | Route | 
|---|---|
| /policy/entities/device-control/v1 | 
- Produces: application/json
| Name | Service | Uber | Type | Data type | Description | 
|---|---|---|---|---|---|
| ids |  |  | query | string or list of strings | The ID(s) of the Device Control Policies to return. | 
| parameters |  |  | query | dictionary | Full query string parameters payload in JSON format. | 
from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
id_list = 'ID1,ID2,ID3'  # Can also pass a list here: ['ID1', 'ID2', 'ID3']
response = falcon.get_policies_v2(ids=id_list)
print(response)from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
id_list = 'ID1,ID2,ID3'  # Can also pass a list here: ['ID1', 'ID2', 'ID3']
response = falcon.getDeviceControlPoliciesV2(ids=id_list)
print(response)from falconpy import APIHarnessV2
# Do not hardcode API credentials!
falcon = APIHarnessV2(client_id=CLIENT_ID,
                      client_secret=CLIENT_SECRET
                      )
id_list = 'ID1,ID2,ID3'  # Can also pass a list here: ['ID1', 'ID2', 'ID3']
response = falcon.command("getDeviceControlPoliciesV2", ids=id_list)
print(response)Create Device Control Policies by specifying details about the policy to create
create_policies
| Method | Route | 
|---|---|
| /policy/entities/device-control/v1 | 
- Produces: application/json
| Name | Service | Uber | Type | Data type | Description | 
|---|---|---|---|---|---|
| body |  |  | body | dictionary | Full body payload in JSON format. | 
| description |  |  | body | string | Device Control Policy description. | 
| clone_id |  |  | body | string | Device Control Policy ID to clone. | 
| name |  |  | body | string | Device Control Policy name. | 
| platform_name |  |  | body | string | Device Control Policy platform. | 
| settings |  |  | body | dictionary | Device Control specific settings. | 
from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
dc_settings = {
    "classes": [
    {
        "action": "FULL_ACCESS",
        "exceptions": [
        {
            "action": "string",
            "class": "string",
            "combined_id": "string",
            "id": "string",
            "match_method": "string",
            "product_id": "string",
            "product_id_decimal": "string",
            "product_name": "string",
            "serial_number": "string",
            "vendor_id": "string",
            "vendor_id_decimal": "string",
            "vendor_name": "string"
        }
        ],
        "id": "string"
    }
    ],
    "end_user_notification": "TRUE",
    "enforcement_mode": "string",
    "id": "string"
}
response = falcon.create_policies(clone_id="string",
                                  description="string",
                                  name="string",
                                  platform_name="string",
                                  settings=dc_settings
                                  )
print(response)from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
dc_settings = {
    "classes": [
    {
        "action": "FULL_ACCESS",
        "exceptions": [
        {
            "action": "string",
            "class": "string",
            "combined_id": "string",
            "id": "string",
            "match_method": "string",
            "product_id": "string",
            "product_id_decimal": "string",
            "product_name": "string",
            "serial_number": "string",
            "vendor_id": "string",
            "vendor_id_decimal": "string",
            "vendor_name": "string"
        }
        ],
        "id": "string"
    }
    ],
    "end_user_notification": "TRUE",
    "enforcement_mode": "string",
    "id": "string"
}
response = falcon.createDeviceControlPolicies(clone_id="string",
                                              description="string",
                                              name="string",
                                              platform_name="string",
                                              settings=dc_settings
                                              )
print(response)from falconpy import APIHarnessV2
# Do not hardcode API credentials!
falcon = APIHarnessV2(client_id=CLIENT_ID,
                      client_secret=CLIENT_SECRET
                      )
body_payload = {
    "resources": [
        {
            "clone_id": "string",
            "description": "string",
            "name": "string",
            "platform_name": "Windows",
            "settings": {
                "classes": [
                {
                    "action": "FULL_ACCESS",
                    "exceptions": [
                    {
                        "action": "string",
                        "class": "string",
                        "combined_id": "string",
                        "id": "string",
                        "match_method": "string",
                        "product_id": "string",
                        "product_id_decimal": "string",
                        "product_name": "string",
                        "serial_number": "string",
                        "vendor_id": "string",
                        "vendor_id_decimal": "string",
                        "vendor_name": "string"
                    }
                    ],
                    "id": "string"
                }
                ],
                "end_user_notification": "TRUE",
                "enforcement_mode": "string",
                "id": "string"
            }
        }
    ]
}
response = falcon.command("createDeviceControlPolicies", body=body_payload)
print(response)Create Device Control Policies by specifying details about the policy to create
create_policies_v2
| Method | Route | 
|---|---|
| /policy/entities/device-control/v1 | 
- Produces: application/json
| Name | Service | Uber | Type | Data type | Description | 
|---|---|---|---|---|---|
| bluetooth_settings |  |  | body | dictionary | Device Control bluetooth specific settings. | 
| body |  |  | body | dictionary | Full body payload in JSON format. | 
| description |  |  | body | string | Device Control Policy description. | 
| clone_id |  |  | body | string | Device Control Policy ID to clone. | 
| name |  |  | body | string | Device Control Policy name. | 
| platform_name |  |  | body | string | Device Control Policy platform. | 
| usb_settings |  |  | body | dictionary | Device Control USB specific settings. | 
from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
bluetooth_settings = {
    "custom_end_user_notifications": {
        "blocked_notification": {
            "custom_message": "string",
            "use_custom": boolean
        }
    },
    "end_user_notification": "NOTIFY_USER,SILENT",
    "enforcement_mode": "MONITOR_ONLY,MONITOR_ENFORCE,OFF"
}
usb_settings = {
    "custom_notifications": {
        "blocked_notification": {
            "custom_message": "string",
            "use_custom": boolean
        },
        "restricted_notification": {
            "custom_message": "string",
            "use_custom": boolean
        }
    },
    "end_user_notification": "NOTIFY_USER,SILENT",
    "enforcement_mode": "MONITOR_ONLY,MONITOR_ENFORCE,OFF",
    "enhanced_file_metadata": boolean,
    "whitelist_mode": "ENABLE_ALWAYS,DISABLE_VIRTUAL"
}
response = falcon.create_policies_v2(bluetooth_settings=bluetooth_settings,
                                     clone_id="string",
                                     description="string",
                                     name="string",
                                     platform_name="string",
                                     usb_settings=usb_settings
                                     ) 
print(response)from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
bluetooth_settings = {
    "custom_end_user_notifications": {
        "blocked_notification": {
            "custom_message": "string",
            "use_custom": boolean
        }
    },
    "end_user_notification": "NOTIFY_USER,SILENT",
    "enforcement_mode": "MONITOR_ONLY,MONITOR_ENFORCE,OFF"
}
usb_settings = {
    "custom_notifications": {
        "blocked_notification": {
            "custom_message": "string",
            "use_custom": boolean
        },
        "restricted_notification": {
            "custom_message": "string",
            "use_custom": boolean
        }
    },
    "end_user_notification": "NOTIFY_USER,SILENT",
    "enforcement_mode": "MONITOR_ONLY,MONITOR_ENFORCE,OFF",
    "enhanced_file_metadata": boolean,
    "whitelist_mode": "ENABLE_ALWAYS,DISABLE_VIRTUAL"
}
response = falcon.postDeviceControlPoliciesV2(bluetooth_settings=bluetooth_settings,
                                              clone_id="string",
                                              description="string",
                                              name="string",
                                              platform_name="string",
                                              usb_settings=usb_settings
                                              )
print(response)from falconpy import APIHarnessV2
# Do not hardcode API credentials!
falcon = APIHarnessV2(client_id=CLIENT_ID,
                      client_secret=CLIENT_SECRET
                      )
body_payload = {
  "policies": [
    {
      "bluetooth_settings": {
        "custom_end_user_notifications": {
          "blocked_notification": {
            "custom_message": "string",
            "use_custom": boolean
          }
        },
        "end_user_notification": "NOTIFY_USER,SILENT",
        "enforcement_mode": "MONITOR_ONLY,MONITOR_ENFORCE,OFF"
      },
      "clone_id": "string",
      "description": "string",
      "name": "string",
      "platform_name": "Windows,Mac",
      "usb_settings": {
        "custom_notifications": {
          "blocked_notification": {
            "custom_message": "string",
            "use_custom": boolean
          },
          "restricted_notification": {
            "custom_message": "string",
            "use_custom": boolean
          }
        },
        "end_user_notification": "NOTIFY_USER,SILENT",
        "enforcement_mode": "MONITOR_ONLY,MONITOR_ENFORCE,OFF",
        "enhanced_file_metadata": boolean,
        "whitelist_mode": "ENABLE_ALWAYS,DISABLE_VIRTUAL"
      }
    }
  ]
}
response = falcon.command("postDeviceControlPoliciesV2", body=body_payload)
print(response)Delete a set of Device Control Policies by specifying their IDs
delete_policies
| Method | Route | 
|---|---|
| /policy/entities/device-control/v1 | 
- Produces: application/json
| Name | Service | Uber | Type | Data type | Description | 
|---|---|---|---|---|---|
| ids |  |  | query | string or list of strings | The ID(s) of the Device Control Policies to delete. | 
| parameters |  |  | query | dictionary | Full query string parameters payload in JSON format. | 
from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
id_list = 'ID1,ID2,ID3'  # Can also pass a list here: ['ID1', 'ID2', 'ID3']
response = falcon.delete_policies(ids=id_list)
print(response)from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
id_list = 'ID1,ID2,ID3'  # Can also pass a list here: ['ID1', 'ID2', 'ID3']
response = falcon.deleteDeviceControlPolicies(ids=id_list)
print(response)from falconpy import APIHarnessV2
# Do not hardcode API credentials!
falcon = APIHarnessV2(client_id=CLIENT_ID,
                      client_secret=CLIENT_SECRET
                      )
id_list = 'ID1,ID2,ID3'  # Can also pass a list here: ['ID1', 'ID2', 'ID3']
response = falcon.command("deleteDeviceControlPolicies", ids=id_list)
print(response)Update device control policy's classes (USB and Bluetooth).
update_policies_v2
| Method | Route | 
|---|---|
| /policy/entities/device-control-classes/v1 | 
- Produces: application/json
| Name | Service | Uber | Type | Data type | Description | 
|---|---|---|---|---|---|
| body |  |  | body | dictionary | Full body payload in JSON format. | 
| bluetooth_settings |  |  | body | dictionary | Device Control policy bluetooth specific settings. | 
| description |  |  | body | string | Device Control policy description. | 
| id |  |  | body | string | Device Control policy ID to be updated. | 
| name |  |  | body | string | Device Control policy name. | 
| platform_name |  |  | body | string | Device Control policy platform name. | 
| usb_settings |  |  | body | dictionary | Device Control policy USB specific settings. | 
from falconpy import DeviceControlPolicies
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
bluetooth_settings = {
    "custom_end_user_notifications": {
        "blocked_notification": {
            "custom_message": "string",
            "use_custom": boolean
        }
    },
    "end_user_notification": "string",
    "enforcement_mode": "string"
}
usb_settings = {
    "custom_notifications": {
        "blocked_notification": {
            "custom_message": "string",
            "use_custom": boolean
        },
        "restricted_notification": {
            "custom_message": "string",
            "use_custom": boolean
        }
    },
    "end_user_notification": "string",
    "enforcement_mode": "string",
    "enhanced_file_metadata": boolean,
    "whitelist_mode": "string"
}
response = falcon.patchDeviceControlPoliciesClassesV1(bluetooth_settings=bluetooth_settings,
                                                      description="string",
                                                      id="string",
                                                      name="string",
                                                      platform_name="string",
                                                      usb_settings=usb_settings
                                                      )
print(response)from falconpy import DeviceControlPolicies
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
bluetooth_settings = {
    "custom_end_user_notifications": {
        "blocked_notification": {
            "custom_message": "string",
            "use_custom": boolean
        }
    },
    "end_user_notification": "string",
    "enforcement_mode": "string"
}
usb_settings = {
    "custom_notifications": {
        "blocked_notification": {
            "custom_message": "string",
            "use_custom": boolean
        },
        "restricted_notification": {
            "custom_message": "string",
            "use_custom": boolean
        }
    },
    "end_user_notification": "string",
    "enforcement_mode": "string",
    "enhanced_file_metadata": boolean,
    "whitelist_mode": "string"
}
response = falcon.patchDeviceControlPoliciesClassesV1(bluetooth_settings=bluetooth_settings,
                                                      description="string",
                                                      id="string",
                                                      name="string",
                                                      platform_name="string",
                                                      usb_settings=usb_settings
                                                      )
print(response)from falconpy import APIHarnessV2
falcon = APIHarnessV2(client_id=CLIENT_ID,
                      client_secret=CLIENT_SECRET
                      )
body_payload = {
    "policies": [
        {
            "bluetooth_settings": {
                "custom_end_user_notifications": {
                    "blocked_notification": {
                        "custom_message": "string",
                        "use_custom": boolean
                    }
                },
                "end_user_notification": "string",
                "enforcement_mode": "string"
            },
            "description": "string",
            "id": "string",
            "name": "string",
            "platform_name": "string",
            "usb_settings": {
                "custom_notifications": {
                    "blocked_notification": {
                        "custom_message": "string",
                        "use_custom": boolean
                    },
                    "restricted_notification": {
                        "custom_message": "string",
                        "use_custom": boolean
                    }
                },
                "end_user_notification": "string",
                "enforcement_mode": "string",
                "enhanced_file_metadata": boolean,
                "whitelist_mode": "string"
            }
        }
    ]
}
response = falcon.command("patchDeviceControlPoliciesClassesV1", body=body_payload)
print(response)Update Device Control Policies by specifying the ID of the policy and details to update
update_policies
| Method | Route | 
|---|---|
| /policy/entities/device-control/v1 | 
- Produces: application/json
| Name | Service | Uber | Type | Data type | Description | 
|---|---|---|---|---|---|
| body |  |  | body | dictionary | Full body payload in JSON format. | 
| description |  |  | body | string | Device Control Policy description. | 
| id |  |  | body | string | Device Control Policy ID to update. | 
| name |  |  | body | string | Device Control Policy name. | 
| settings |  |  | body | dictionary | Device control specific policy settings. | 
from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
dc_settings = {
    "classes": [
        {
            "action": "FULL_ACCESS",
            "exceptions": [
                {
                    "action": "string",
                    "class": "string",
                    "combined_id": "string",
                    "id": "string",
                    "match_method": "string",
                    "product_id": "string",
                    "product_id_decimal": "string",
                    "product_name": "string",
                    "serial_number": "string",
                    "vendor_id": "string",
                    "vendor_id_decimal": "string",
                    "vendor_name": "string"
                }
            ],
            "id": "string"
        }
    ],
    "end_user_notification": "TRUE",
    "enforcement_mode": "string",
    "id": "string"
}
response = falcon.update_policies(description="string",
                                  id="string",
                                  name="string",
                                  platform_name="string",
                                  settings=dc_settings
                                  )
print(response)from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
dc_settings = {
    "classes": [
        {
            "action": "FULL_ACCESS",
            "exceptions": [
                {
                    "action": "string",
                    "class": "string",
                    "combined_id": "string",
                    "id": "string",
                    "match_method": "string",
                    "product_id": "string",
                    "product_id_decimal": "string",
                    "product_name": "string",
                    "serial_number": "string",
                    "vendor_id": "string",
                    "vendor_id_decimal": "string",
                    "vendor_name": "string"
                }
            ],
            "id": "string"
        }
    ],
    "end_user_notification": "TRUE",
    "enforcement_mode": "string",
    "id": "string"
}
response = falcon.updateDeviceControlPolicies(description="string",
                                              id="string",
                                              name="string",
                                              platform_name="string",
                                              settings=dc_settings
                                              )
print(response)from falconpy import APIHarnessV2
# Do not hardcode API credentials!
falcon = APIHarnessV2(client_id=CLIENT_ID,
                      client_secret=CLIENT_SECRET
                      )
body_payload = {
    "resources": [
        {
            "clone_id": "string",
            "description": "string",
            "name": "string",
            "platform_name": "Windows",
            "settings": {
                "classes": [
                {
                    "action": "FULL_ACCESS",
                    "exceptions": [
                    {
                        "action": "string",
                        "class": "string",
                        "combined_id": "string",
                        "id": "string",
                        "match_method": "string",
                        "product_id": "string",
                        "product_id_decimal": "string",
                        "product_name": "string",
                        "serial_number": "string",
                        "vendor_id": "string",
                        "vendor_id_decimal": "string",
                        "vendor_name": "string"
                    }
                    ],
                    "id": "string"
                }
                ],
                "end_user_notification": "TRUE",
                "enforcement_mode": "string",
                "id": "string"
            }
        }
    ]
}
response = falcon.command("updateDeviceControlPolicies", body=body_payload)
print(response)Update Device Control Policies by specifying the ID of the policy and details to update
update_policies_v2
| Method | Route | 
|---|---|
| /policy/entities/device-control/v1 | 
- Produces: application/json
| Name | Service | Uber | Type | Data type | Description | 
|---|---|---|---|---|---|
| bluetooth_settings |  |  | body | dictionary | Device control bluetooth specific policy settings. | 
| body |  |  | body | dictionary | Full body payload in JSON format. | 
| description |  |  | body | string | Device Control Policy description. | 
| id |  |  | body | string | Device Control Policy ID to update. | 
| name |  |  | body | string | Device Control Policy name. | 
| usb_settings |  |  | body | dictionary | Device control USB specific policy settings. | 
from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
bluetooth_settings = {
    "custom_end_user_notifications": {
        "blocked_notification": {
            "custom_message": "string",
            "use_custom": boolean
        }
    },
    "end_user_notification": "NOTIFY_USER,SILENT",
    "enforcement_mode": "MONITOR_ONLY,MONITOR_ENFORCE,OFF"
}
usb_settings = {
    "custom_notifications": {
        "blocked_notification": {
            "custom_message": "string",
            "use_custom": boolean
        },
        "restricted_notification": {
            "custom_message": "string",
            "use_custom": boolean
        }
    },
    "end_user_notification": "NOTIFY_USER,SILENT",
    "enforcement_mode": "MONITOR_ONLY,MONITOR_ENFORCE,OFF",
    "enhanced_file_metadata": boolean,
    "whitelist_mode": "ENABLE_ALWAYS,DISABLE_VIRTUAL"
}
response = falcon.update_policies_v2(bluetooth_settings=bluetooth_settings,
                                     description="string",
                                     id="string",
                                     name="string",
                                     platform_name="string",
                                     usb_settings=usb_settings
                                     )
print(response)from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
bluetooth_settings = {
    "custom_end_user_notifications": {
        "blocked_notification": {
            "custom_message": "string",
            "use_custom": boolean
        }
    },
    "end_user_notification": "NOTIFY_USER,SILENT",
    "enforcement_mode": "MONITOR_ONLY,MONITOR_ENFORCE,OFF"
}
usb_settings = {
    "custom_notifications": {
        "blocked_notification": {
            "custom_message": "string",
            "use_custom": boolean
        },
        "restricted_notification": {
            "custom_message": "string",
            "use_custom": boolean
        }
    },
    "end_user_notification": "NOTIFY_USER,SILENT",
    "enforcement_mode": "MONITOR_ONLY,MONITOR_ENFORCE,OFF",
    "enhanced_file_metadata": boolean,
    "whitelist_mode": "ENABLE_ALWAYS,DISABLE_VIRTUAL"
}
response = falcon.patchDeviceControlPoliciesV2(bluetooth_settings=bluetooth_settings,
                                               description="string",
                                               id="string",
                                               name="string",
                                               platform_name="string",
                                               usb_settings=usb_settings
                                               )
print(response)from falconpy import APIHarnessV2
# Do not hardcode API credentials!
falcon = APIHarnessV2(client_id=CLIENT_ID,
                      client_secret=CLIENT_SECRET
                      )
body_payload = {
  "policies": [
    {
      "bluetooth_settings": {
        "custom_end_user_notifications": {
          "blocked_notification": {
            "custom_message": "string",
            "use_custom": boolean
          }
        },
        "end_user_notification": "NOTIFY_USER,SILENT",
        "enforcement_mode": "MONITOR_ONLY,MONITOR_ENFORCE,OFF"
      },
      "description": "string",
      "id": "string",
      "name": "string",
      "usb_settings": {
        "custom_notifications": {
          "blocked_notification": {
            "custom_message": "string",
            "use_custom": boolean
          },
          "restricted_notification": {
            "custom_message": "string",
            "use_custom": boolean
          }
        },
        "end_user_notification": "NOTIFY_USER,SILENT",
        "enforcement_mode": "MONITOR_ONLY,MONITOR_ENFORCE,OFF",
        "enhanced_file_metadata": boolean
      }
    }
  ]
}
response = falcon.command("patchDeviceControlPoliciesV2", body=body_payload)
print(response)Search for members of a Device Control Policy in your environment by providing a FQL filter and paging details. Returns a set of Agent IDs which match the filter criteria
query_policy_members
| Method | Route | 
|---|---|
| /policy/queries/device-control-members/v1 | 
- Produces: application/json
| Name | Service | Uber | Type | Data type | Description | 
|---|---|---|---|---|---|
| filter |  |  | query | string | FQL Syntax formatted string used to limit the results. | 
| id |  |  | query | integer | The ID of the Device Control Policy to search for members of. | 
| limit |  |  | query | integer | Maximum number of records to return. (Max: 5000) | 
| offset |  |  | query | integer | Starting index of overall result set from which to return ids. | 
| sort |  |  | query | string | The property to sort by. (Ex: modified_timestamp.desc) | 
| parameters |  |  | query | dictionary | Full query string parameters payload in JSON format. | 
from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
response = falcon.query_policy_members(id="string",
                                       filter="string",
                                       offset=integer,
                                       limit=integer,
                                       sort="string"
                                       )
print(response)from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
response = falcon.queryDeviceControlPolicyMembers(id="string",
                                                  filter="string",
                                                  offset=integer,
                                                  limit=integer,
                                                  sort="string"
                                                  )
print(response)from falconpy import APIHarnessV2
# Do not hardcode API credentials!
falcon = APIHarnessV2(client_id=CLIENT_ID,
                      client_secret=CLIENT_SECRET
                      )
response = falcon.command("queryDeviceControlPolicyMembers",
                          id="string",
                          filter="string",
                          offset=integer,
                          limit=integer,
                          sort="string"
                          )
print(response)Search for Device Control Policies in your environment by providing a FQL filter and paging details. Returns a set of Device Control Policy IDs which match the filter criteria
query_policies
| Method | Route | 
|---|---|
| /policy/queries/device-control/v1 | 
- Produces: application/json
| Name | Service | Uber | Type | Data type | Description | 
|---|---|---|---|---|---|
| filter |  |  | query | string | FQL Syntax formatted string used to limit the results. | 
| limit |  |  | query | integer | Maximum number of records to return. (Max: 5000) | 
| offset |  |  | query | integer | Starting index of overall result set from which to return ids. | 
| sort |  |  | query | string | The property to sort by. (Ex: modified_timestamp.desc) | 
| parameters |  |  | query | dictionary | Full query string parameters payload in JSON format. | 
from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
response = falcon.query_policies(filter="string",
                                 offset=integer,
                                 limit=integer,
                                 sort="string"
                                 )
print(response)from falconpy import DeviceControlPolicies
# Do not hardcode API credentials!
falcon = DeviceControlPolicies(client_id=CLIENT_ID,
                               client_secret=CLIENT_SECRET
                               )
response = falcon.queryDeviceControlPolicies(filter="string",
                                             offset=integer,
                                             limit=integer,
                                             sort="string"
                                             )
print(response)from falconpy import APIHarnessV2
# Do not hardcode API credentials!
falcon = APIHarnessV2(client_id=CLIENT_ID,
                      client_secret=CLIENT_SECRET
                      )
response = falcon.command("queryDeviceControlPolicies",
                          filter="string",
                          offset=integer,
                          limit=integer,
                          sort="string"
                          )
print(response) 
