You can find your API URL in Settings > Access. The API URL will follow the below formats.
US -
https://SubDomain.api.kandji.io
EU -
https://SubDomain.api.eu.kandji.io
For information on how to obtain an API token, please refer to the following support article.
https://support.kandji.io/api
The Kandji API currently has an API rate limit of 10,000 requests per hour per customer.
HTTP request methods supported by the Kandji API.
Method | Definition |
---|---|
GET | The GET method requests a representation of the specified resource. |
POST | The POST method submits an entity to the specified resource. |
PATCH | The PATCH method applies partial modifications to a resource. |
DELETE | The DELETE method deletes the specified resource. |
Not all response codes apply to every endpoint.
Code | Response |
---|---|
200 | OK |
201 | Created |
204 | No content |
Typical response when sending the DELETE method. | |
400 | Bad Request |
"Command already running" - The command may already be running in a Pending state waiting on the device. | |
"Command is not allowed for current device" - The command may not be compatible with the target device. | |
"JSON parse error - Expecting ',' delimiter: line 3 column 2 (char 65)" | |
401 | Unauthorized |
This error can occur if the token is incorrect, was revoked, or the token has expired. | |
403 | Forbidden |
The request was understood but cannot be authorized. | |
404 | Not found |
Unable to locate the resource in the Kandji tenant. | |
415 | Unsupported Media Type |
The request contains a media type which the server or resource does not support. | |
500 | Internal server error |
503 | Service unavailable |
This error can occur if a file upload is still being processed via the custom apps API. |
The API returns all structured responses in JSON schema format.
Code examples using the API can be found in the Kandji support GitHub.
This API client was generated by the OpenAPI Generator project. By using the OpenAPI-spec from a remote server, you can easily generate an API client.
- API version: 1.0.0
- Package version: 1.0.0
- Generator version: 7.10.0
- Build package: org.openapitools.codegen.languages.GoClientCodegen For more information, please visit https://github.com/MScottBlake/kandji-openapi
Install the following dependencies:
go get github.com/stretchr/testify/assert
go get golang.org/x/net/context
Put the package under your project folder and add the following in import:
import kandji_sdk "github.com/MScottBlake/kandji-go-sdk"
To use a proxy, set the environment variable HTTP_PROXY
:
os.Setenv("HTTP_PROXY", "http://proxy_name:proxy_port")
Default configuration comes with Servers
field that contains server objects as defined in the OpenAPI specification.
For using other server than the one defined on index 0 set context value kandji_sdk.ContextServerIndex
of type int
.
ctx := context.WithValue(context.Background(), kandji_sdk.ContextServerIndex, 1)
Templated server URL is formatted using default variables from configuration or from context value kandji_sdk.ContextServerVariables
of type map[string]string
.
ctx := context.WithValue(context.Background(), kandji_sdk.ContextServerVariables, map[string]string{
"basePath": "v2",
})
Note, enum values are always validated and all unused variables are silently ignored.
Each operation can use different server URL defined using OperationServers
map in the Configuration
.
An operation is uniquely identified by "{classname}Service.{nickname}"
string.
Similar rules for overriding default operation server index and variables applies by using kandji_sdk.ContextOperationServerIndices
and kandji_sdk.ContextOperationServerVariables
context maps.
ctx := context.WithValue(context.Background(), kandji_sdk.ContextOperationServerIndices, map[string]int{
"{classname}Service.{nickname}": 2,
})
ctx = context.WithValue(context.Background(), kandji_sdk.ContextOperationServerVariables, map[string]map[string]string{
"{classname}Service.{nickname}": {
"port": "8443",
},
})
All URIs are relative to https://<sub_domain>.api.kandji.io
Class | Method | HTTP request | Description |
---|---|---|---|
AutomatedDeviceEnrollmentIntegrationsAPI | CreateAdeIntegration | Post /api/v1/integrations/apple/ade/ | Create ADE integration |
AutomatedDeviceEnrollmentIntegrationsAPI | DeleteAdeIntegration | Delete /api/v1/integrations/apple/ade/{ade_token_id} | Delete ADE integration |
AutomatedDeviceEnrollmentIntegrationsAPI | DownloadAdePublicKey | Get /api/v1/integrations/apple/ade/public_key/ | Download ADE public key |
AutomatedDeviceEnrollmentIntegrationsAPI | GetAdeDevice | Get /api/v1/integrations/apple/ade/devices/{device_id} | Get ADE device |
AutomatedDeviceEnrollmentIntegrationsAPI | GetAdeIntegration | Get /api/v1/integrations/apple/ade/{ade_token_id} | Get ADE integration |
AutomatedDeviceEnrollmentIntegrationsAPI | ListAdeDevices | Get /api/v1/integrations/apple/ade/devices | List ADE devices |
AutomatedDeviceEnrollmentIntegrationsAPI | ListAdeIntegrations | Get /api/v1/integrations/apple/ade | List ADE integrations |
AutomatedDeviceEnrollmentIntegrationsAPI | ListDevicesAssociatedToAdeToken | Get /api/v1/integrations/apple/ade/{ade_token_id}/devices | List devices associated to ADE token |
AutomatedDeviceEnrollmentIntegrationsAPI | RenewAdeIntegration | Post /api/v1/integrations/apple/ade/{ade_token_id}/renew | Renew ADE integration |
AutomatedDeviceEnrollmentIntegrationsAPI | UpdateAdeDevice | Patch /api/v1/integrations/apple/ade/devices/{device_id} | Update ADE device |
AutomatedDeviceEnrollmentIntegrationsAPI | UpdateAdeIntegration | Patch /api/v1/integrations/apple/ade/{ade_token_id} | Update ADE integration |
BlueprintsAPI | AssignLibraryItem | Post /api/v1/blueprints/{blueprint_id}/assign-library-item | Assign Library Item |
BlueprintsAPI | CreateBlueprint | Post /api/v1/blueprints | Create Blueprint |
BlueprintsAPI | DeleteBlueprint | Delete /api/v1/blueprints/{blueprint_id} | Delete Blueprint |
BlueprintsAPI | GetBlueprint | Get /api/v1/blueprints/{blueprint_id} | Get Blueprint |
BlueprintsAPI | GetBlueprintTemplates | Get /api/v1/blueprints/templates/ | Get Blueprint Templates |
BlueprintsAPI | GetManualEnrollmentProfile | Get /api/v1/blueprints/{blueprint_id}/ota-enrollment-profile | Get Manual Enrollment Profile |
BlueprintsAPI | ListBlueprints | Get /api/v1/blueprints | List Blueprints |
BlueprintsAPI | ListLibraryItems | Get /api/v1/blueprints/{blueprint_id}/list-library-items | List Library Items |
BlueprintsAPI | RemoveLibraryItem | Post /api/v1/blueprints/{blueprint_id}/remove-library-item | Remove Library Item |
BlueprintsAPI | UpdateBlueprint | Patch /api/v1/blueprints/{blueprint_id} | Update Blueprint |
CustomAppsAPI | CreateCustomApp | Post /api/v1/library/custom-apps | Create Custom App |
CustomAppsAPI | DeleteCustomApp | Delete /api/v1/library/custom-apps/{library_item_id} | Delete Custom App |
CustomAppsAPI | GetCustomApp | Get /api/v1/library/custom-apps/{library_item_id} | Get Custom App |
CustomAppsAPI | ListCustomApps | Get /api/v1/library/custom-apps | List Custom Apps |
CustomAppsAPI | UpdateCustomApp | Patch /api/v1/library/custom-apps/{library_item_id} | Update Custom App |
CustomAppsAPI | UploadCustomApp | Post /api/v1/library/custom-apps/upload | Upload Custom App |
CustomProfilesAPI | CreateCustomProfile | Post /api/v1/library/custom-profiles | Create Custom Profile |
CustomProfilesAPI | DeleteCustomProfile | Delete /api/v1/library/custom-profiles/{library_item_id} | Delete Custom Profile |
CustomProfilesAPI | GetCustomProfile | Get /api/v1/library/custom-profiles/{library_item_id} | Get Custom Profile |
CustomProfilesAPI | ListCustomProfiles | Get /api/v1/library/custom-profiles | List Custom Profiles |
CustomProfilesAPI | UpdateCustomProfile | Patch /api/v1/library/custom-profiles/{library_item_id} | Update Custom Profile |
CustomScriptsAPI | CreateCustomScript | Post /api/v1/library/custom-scripts | Create Custom Script |
CustomScriptsAPI | DeleteCustomScript | Delete /api/v1/library/custom-scripts/{library_item_id} | Delete Custom Script |
CustomScriptsAPI | GetCustomScript | Get /api/v1/library/custom-scripts/{library_item_id} | Get Custom Script |
CustomScriptsAPI | ListCustomScripts | Get /api/v1/library/custom-scripts | List Custom Scripts |
CustomScriptsAPI | UpdateCustomScript | Patch /api/v1/library/custom-scripts/{library_item_id} | Update Custom Script |
DeviceActionsAPI | ClearPasscode | Post /api/v1/devices/{device_id}/action/clearpasscode | Clear Passcode |
DeviceActionsAPI | DeleteDevice | Delete /api/v1/devices/{device_id} | Delete Device |
DeviceActionsAPI | DeleteUser | Post /api/v1/devices/{device_id}/action/deleteuser | Delete User |
DeviceActionsAPI | EraseDevice | Post /api/v1/devices/{device_id}/action/erase | Erase Device |
DeviceActionsAPI | GetDeviceCommands | Get /api/v1/devices/{device_id}/commands | Get Device Commands |
DeviceActionsAPI | LockDevice | Post /api/v1/devices/{device_id}/action/lock | Lock Device |
DeviceActionsAPI | ReinstallAgent | Post /api/v1/devices/{device_id}/action/reinstallagent | Reinstall Agent |
DeviceActionsAPI | RemoteDesktop | Post /api/v1/devices/{device_id}/action/remotedesktop | Remote Desktop |
DeviceActionsAPI | RenewMdmProfile | Post /api/v1/devices/{device_id}/action/renewmdmprofile | Renew MDM Profile |
DeviceActionsAPI | RestartDevice | Post /api/v1/devices/{device_id}/action/restart | Restart Device |
DeviceActionsAPI | SendBlankpush | Post /api/v1/devices/{device_id}/action/blankpush | Send Blankpush |
DeviceActionsAPI | SetName | Post /api/v1/devices/{device_id}/action/setname | Set Name |
DeviceActionsAPI | Shutdown | Post /api/v1/devices/{device_id}/action/shutdown | Shutdown |
DeviceActionsAPI | UnlockAccount | Post /api/v1/devices/{device_id}/action/unlockaccount | Unlock Account |
DeviceActionsAPI | UpdateInventory | Post /api/v1/devices/{device_id}/action/updateinventory | Update Inventory |
DeviceInformationAPI | CancelLostMode | Delete /api/v1/devices/{device_id}/details/lostmode | Cancel Lost Mode |
DeviceInformationAPI | GetDeviceActivity | Get /api/v1/devices/{device_id}/activity | Get Device Activity |
DeviceInformationAPI | GetDeviceApps | Get /api/v1/devices/{device_id}/apps | Get Device Apps |
DeviceInformationAPI | GetDeviceDetails | Get /api/v1/devices/{device_id}/details | Get Device Details |
DeviceInformationAPI | GetDeviceLibraryItems | Get /api/v1/devices/{device_id}/library-items | Get Device Library Items |
DeviceInformationAPI | GetDeviceLostModeDetails | Get /api/v1/devices/{device_id}/details/lostmode | Get Device Lost Mode details |
DeviceInformationAPI | GetDeviceParameters | Get /api/v1/devices/{device_id}/parameters | Get Device Parameters |
DeviceInformationAPI | GetDeviceStatus | Get /api/v1/devices/{device_id}/status | Get Device Status |
DeviceInformationAPI | ListDevices | Get /api/v1/devices | List Devices |
DeviceSecretsAPI | GetActivationLockBypassCode | Get /api/v1/devices/{device_id}/secrets/bypasscode | Get Activation Lock Bypass Code |
DeviceSecretsAPI | GetFilevaultRecoveryKey | Get /api/v1/devices/{device_id}/secrets/filevaultkey | Get FileVault Recovery Key |
DeviceSecretsAPI | GetRecoveryLockPassword | Get /api/v1/devices/{device_id}/secrets/recoverypassword | Get Recovery Lock Password |
DeviceSecretsAPI | GetUnlockPin | Get /api/v1/devices/{device_id}/secrets/unlockpin | Get Unlock Pin |
InHouseAppsAPI | CreateInhouseApp | Post /api/v1/library/ipa-apps | Create In-House App |
InHouseAppsAPI | DeleteInhouseApp | Delete /api/v1/library/ipa-apps/{library_item_id} | Delete In-House App |
InHouseAppsAPI | GetInhouseApp | Get /api/v1/library/ipa-apps/{library_item_id} | Get In-House App |
InHouseAppsAPI | ListInhouseApps | Get /api/v1/library/ipa-apps | List In-House Apps |
InHouseAppsAPI | UpdateInhouseApp | Patch /api/v1/library/ipa-apps/{library_item_id} | Update In-House App |
InHouseAppsAPI | UploadInhouseApp | Post /api/v1/library/ipa-apps/upload | Upload In-House App |
InHouseAppsAPI | UploadInhouseAppStatus | Get /api/v1/library/ipa-apps/upload/{pending_upload_id}/status | Upload In-House App Status |
LibraryItemsAPI | GetLibraryItemActivity | Get /api/v1/library/library-items/{library_item_id}/activity | Get Library Item Activity |
LibraryItemsAPI | GetLibraryItemStatuses | Get /api/v1/library/library-items/{library_item_id}/status | Get Library Item Statuses |
LostModeAPI | DisableLostMode | Post /api/v1/devices/{device_id}/action/disablelostmode | Disable Lost Mode |
LostModeAPI | EnableLostMode | Post /api/v1/devices/{device_id}/action/enablelostmode | Enable Lost Mode |
LostModeAPI | PlayLostModeSound | Post /api/v1/devices/{device_id}/action/playlostmodesound | Play Lost Mode Sound |
LostModeAPI | UpdateLocation | Post /api/v1/devices/{device_id}/action/updatelocation | Update Location |
NotesAPI | CreateDeviceNote | Post /api/v1/devices/{device_id}/notes | Create Device Note |
NotesAPI | DeleteDeviceNote | Delete /api/v1/devices/{device_id}/notes/{note_id} | Delete Device Note |
NotesAPI | GetDeviceNotes | Get /api/v1/devices/{device_id}/notes | Get Device Notes |
NotesAPI | RetrieveDeviceNote | Get /api/v1/devices/{device_id}/notes/{note_id} | Retrieve Device Note |
NotesAPI | UpdateDeviceNote | Patch /api/v1/devices/{device_id}/notes/{note_id} | Update Device Note |
PrismAPI | ActivationLock | Get /api/v1/prism/activation_lock | Activation lock |
PrismAPI | ApplicationFirewall | Get /api/v1/prism/application_firewall | Application firewall |
PrismAPI | Applications | Get /api/v1/prism/apps | Applications |
PrismAPI | Certificates | Get /api/v1/prism/certificates | Certificates |
PrismAPI | Count | Get /api/v1/prism/count | Count |
PrismAPI | DesktopAndScreensaver | Get /api/v1/prism/desktop_and_screensaver | Desktop and Screensaver |
PrismAPI | DeviceInformation | Get /api/v1/prism/device_information | Device information |
PrismAPI | Filevault | Get /api/v1/prism/filevault | FileVault |
PrismAPI | GatekeeperAndXprotect | Get /api/v1/prism/gatekeeper_and_xprotect | Gatekeeper and XProtect |
PrismAPI | GetCategoryExport | Get /api/v1/prism/export/{export_id} | Get category export |
PrismAPI | InstalledProfiles | Get /api/v1/prism/installed_profiles | Installed profiles |
PrismAPI | KernelExtensions | Get /api/v1/prism/kernel_extensions | Kernel Extensions |
PrismAPI | LaunchAgentsAndDaemons | Get /api/v1/prism/launch_agents_and_daemons | Launch Agents and Daemons |
PrismAPI | LocalUsers | Get /api/v1/prism/local_users | Local users |
PrismAPI | RequestCategoryExport | Post /api/v1/prism/export | Request category export |
PrismAPI | StartupSettings | Get /api/v1/prism/startup_settings | Startup settings |
PrismAPI | SystemExtensions | Get /api/v1/prism/system_extensions | System Extensions |
PrismAPI | TransparencyDatabase | Get /api/v1/prism/transparency_database | Transparency database |
SelfServiceAPI | ListSelfServiceCategories | Get /api/v1/self-service/categories | List Self Service Categories |
SettingsAPI | Licensing | Get /api/v1/settings/licensing | Licensing |
TagsAPI | CreateTag | Post /api/v1/tags | Create Tag |
TagsAPI | DeleteTag | Delete /api/v1/tags/{tag_id} | Delete Tag |
TagsAPI | GetTags | Get /api/v1/tags | Get Tags |
TagsAPI | UpdateTag | Patch /api/v1/tags/{tag_id} | Update Tag |
ThreatsAPI | GetThreatDetails | Get /api/v1/threat-details | Get Threat Details |
UsersAPI | GetUser | Get /api/v1/users/{user_id} | Get User |
UsersAPI | ListUsers | Get /api/v1/users | List Users |
Authentication schemes defined for the API:
- Type: HTTP Bearer token authentication
Example
auth := context.WithValue(context.Background(), kandji_sdk.ContextAccessToken, "BEARER_TOKEN_STRING")
r, err := client.Service.Operation(auth, args)
Due to the fact that model structure members are all pointers, this package contains a number of utility functions to easily obtain pointers to values of basic types. Each of these functions takes a value of the given basic type and returns a pointer to it:
PtrBool
PtrInt
PtrInt32
PtrInt64
PtrFloat
PtrFloat32
PtrFloat64
PtrString
PtrTime