TrueNAS uses DDP: https://github.com/meteor/meteor/blob/devel/packages/ddp/DDP.md .
DDP (Distributed Data Protocol) is the stateful websocket protocol to communicate between the client and the server.
Websocket endpoint: /websocket
e.g. ws://truenas.domain/websocket
connect
message.{
"msg": "connect",
"version": "1",
"support": ["1"]
}
connected
or failed
.{
"msg": "connected",
"session": "b4a4d164-6bc7-11e6-8a93-00e04d680384"
}
Authentication happens by calling the auth.login
method.
Request:
{
"id": "d8e715be-6bc7-11e6-8c28-00e04d680384",
"msg": "method",
"method": "auth.login",
"params": ["username", "password"]
}
Response:
{
"id": "d8e715be-6bc7-11e6-8c28-00e04d680384",
"msg": "result",
"result": true,
}
acme.dns.authenticator.authenticator_schemas |
---|
Get the schemas for all DNS providers we support for ACME DNS Challenge and the respective attributes required for connecting to them while validating a DNS Challenge |
acme.dns.authenticator.create |
---|
Arguments:
{
"type": "object",
"properties": {
"authenticator": {
"type": "string"
},
"name": {
"type": "string"
},
"attributes": {
"type": "object",
"properties": {},
"additionalProperties": true
}
},
"additionalProperties": false,
"title": "dns_authenticator_create",
"default": {}
}
|
Create a DNS Authenticator Create a specific DNS Authenticator containing required authentication details for the said provider to successfully connect with it |
Create a DNS Authenticator for Route53
|
acme.dns.authenticator.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete DNS Authenticator of |
Delete a DNS Authenticator of
|
acme.dns.authenticator.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
acme.dns.authenticator.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"attributes": {
"type": "object",
"properties": {},
"additionalProperties": true
}
},
"additionalProperties": false,
"title": "dns_authenticator_update",
"default": {}
}
|
Update DNS Authenticator of |
Update a DNS Authenticator of
|
activedirectory.change_trust_account_pw |
---|
Force an update of the AD machine account password. This can be used to refresh the Kerberos principals in the server's system keytab. |
activedirectory.config |
---|
- |
activedirectory.domain_info |
---|
Arguments:
{
"title": "domain",
"default": "",
"type": "string"
}
|
Returns the following information about the currently joined domain:
|
activedirectory.get_spn_list |
---|
Return list of kerberos SPN entries registered for the server's Active Directory computer account. This may not reflect the state of the server's current kerberos keytab. |
activedirectory.get_state |
---|
Wrapper function for 'directoryservices.get_state'. Returns only the state of the Active Directory service. |
activedirectory.leave |
---|
Arguments:
{
"type": "object",
"properties": {
"username": {
"type": "string"
},
"password": {
"type": "string"
}
},
"additionalProperties": false,
"title": "leave_ad",
"default": {}
}
|
Leave Active Directory domain. This will remove computer object from AD and clear relevant configuration data from the NAS. This requires credentials for appropriately-privileged user. Credentials are used to obtain a kerberos ticket, which is used to perform the actual removal from the domain. |
activedirectory.nss_info_choices |
---|
Returns list of available LDAP schema choices. |
activedirectory.started |
---|
Issue a no-effect command to our DC. This checks if our secure channel connection to our domain controller is still alive. It has much less impact than wbinfo -t. Default winbind request timeout is 60 seconds, and can be adjusted by the smb4.conf parameter 'winbind request timeout =' |
activedirectory.update |
---|
Arguments:
{
"type": "object",
"properties": {
"domainname": {
"type": "string"
},
"bindname": {
"type": "string"
},
"bindpw": {
"type": "string"
},
"verbose_logging": {
"type": "boolean"
},
"use_default_domain": {
"type": "boolean"
},
"allow_trusted_doms": {
"type": "boolean"
},
"allow_dns_updates": {
"type": "boolean"
},
"disable_freenas_cache": {
"type": "boolean"
},
"restrict_pam": {
"type": "boolean"
},
"site": {
"type": [
"string",
"null"
]
},
"kerberos_realm": {
"type": [
"integer",
"null"
]
},
"kerberos_principal": {
"type": [
"string",
"null"
]
},
"timeout": {
"type": "integer"
},
"dns_timeout": {
"type": "integer"
},
"nss_info": {
"type": [
"string",
"null"
],
"enum": [
"SFU",
"SFU20",
"RFC2307"
]
},
"createcomputer": {
"type": "string"
},
"netbiosname": {
"type": "string"
},
"netbiosname_b": {
"type": "string"
},
"netbiosalias": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"enable": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "activedirectory_update",
"default": {}
}
|
Update active directory configuration.
The OU string is read from top to bottom without RDNs. Slashes ("/")
are used as delimiters, like When this field is blank, new computer accounts are created in the Active Directory default OU. The Active Directory service is started after a configuration
update if the service was initially disabled, and the updated
configuration sets During the domain join, a kerberos keytab for the newly-created AD machine account is generated. It is used for all future LDAP / AD interaction and the user-provided credentials are removed. |
afp.bindip_choices |
---|
List of valid choices for IP addresses to which to bind the AFP service. |
afp.config |
---|
- |
afp.update |
---|
Arguments:
{
"type": "object",
"properties": {
"guest": {
"type": "boolean"
},
"guest_user": {
"type": "string"
},
"bindip": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"connections_limit": {
"type": "integer"
},
"dbpath": {
"type": "string"
},
"global_aux": {
"type": "string"
},
"map_acls": {
"type": "string",
"enum": [
"RIGHTS",
"MODE",
"NONE"
]
},
"chmod_request": {
"type": "string",
"enum": [
"PRESERVE",
"SIMPLE",
"IGNORE"
]
},
"loglevel": {
"type": "string",
"enum": [
"NONE",
"MINIMUM",
"NORMAL",
"FULL",
"DEBUG"
]
}
},
"additionalProperties": false,
"title": "afp_update",
"default": {}
}
|
Update AFP service settings.
|
alert.dismiss |
---|
Arguments:
{
"title": "uuid",
"type": "string"
}
|
Dismiss |
alert.list |
---|
List all types of alerts including active/dismissed currently in the system. |
alert.list_categories |
---|
List all types of alerts which the system can issue. |
alert.list_policies |
---|
List all alert policies which indicate the frequency of the alerts. |
alert.restore |
---|
Arguments:
{
"title": "uuid",
"type": "string"
}
|
Restore |
alertclasses.config |
---|
- |
alertclasses.update |
---|
Arguments:
{
"type": "object",
"properties": {
"classes": {
"type": "object",
"properties": {},
"additionalProperties": true
}
},
"additionalProperties": false,
"title": "alert_classes_update",
"default": {}
}
|
Update default Alert settings. |
alertservice.create |
---|
Arguments:
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"type": {
"type": "string"
},
"attributes": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"level": {
"type": "string",
"enum": [
"INFO",
"NOTICE",
"WARNING",
"ERROR",
"CRITICAL",
"ALERT",
"EMERGENCY"
]
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "alert_service_create",
"default": {}
}
|
Create an Alert Service of specified If |
Create an Alert Service of Mail
|
alertservice.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete Alert Service of |
alertservice.list_types |
---|
List all types of supported Alert services which can be configured with the system. |
alertservice.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
alertservice.test |
---|
Arguments:
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"type": {
"type": "string"
},
"attributes": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"level": {
"type": "string",
"enum": [
"INFO",
"NOTICE",
"WARNING",
"ERROR",
"CRITICAL",
"ALERT",
"EMERGENCY"
]
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "alert_service_create",
"default": {}
}
|
Send a test alert using |
Send a test alert using Alert Service of Mail
|
alertservice.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"type": {
"type": "string"
},
"attributes": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"level": {
"type": "string",
"enum": [
"INFO",
"NOTICE",
"WARNING",
"ERROR",
"CRITICAL",
"ALERT",
"EMERGENCY"
]
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "alert_service_create",
"default": {}
}
|
Update Alert Service of |
api_key.create |
---|
Arguments:
{
"type": "object",
"properties": {
"name": {
"type": "string"
}
},
"additionalProperties": false,
"title": "api_key_create",
"default": {}
}
|
Creates API Key.
|
api_key.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete API Key |
api_key.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
api_key.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"reset": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "api_key_create",
"default": {}
}
|
Update API Key Specify |
auth.check_password |
---|
Arguments:
{
"title": "username",
"type": "string"
}
{
"title": "password",
"type": "string"
}
|
Verify username and password |
auth.check_user |
---|
Arguments:
{
"title": "username",
"type": "string"
}
{
"title": "password",
"type": "string"
}
|
Verify username and password (this will only validate root user's password and
would return |
auth.generate_token |
---|
Arguments:
{
"type": [
"integer",
"null"
],
"title": "ttl",
"default": 600
}
{
"type": "object",
"properties": {},
"additionalProperties": true,
"title": "attrs",
"default": {}
}
|
Generate a token to be used for authentication.
|
auth.login |
---|
Arguments:
{
"title": "username",
"type": "string"
}
{
"title": "password",
"type": "string"
}
{
"title": "otp_token",
"default": null,
"type": [
"string",
"null"
]
}
|
Authenticate session using username and password.
Currently only root user is allowed.
|
auth.login_with_api_key |
---|
Arguments:
{
"title": "api_key",
"type": "string"
}
|
Authenticate session using API Key. |
auth.logout |
---|
Deauthenticates an app and if a token exists, removes that from the session. |
auth.sessions |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Returns list of active auth sessions. Example of return value: [ { "id": "NyhB1J5vjPjIV82yZ6caU12HLA1boDJcZNWuVQM4hQWuiyUWMGZTz2ElDp7Yk87d", "origin": "192.168.0.3:40392", "credentials": "TOKEN", "internal": False, "created_at": {"$date": 1545842426070} } ]
If you want to exclude all internal connections from the list, call this method with following arguments: [ [ ["internal", "=", True] ] ] |
auth.token |
---|
Arguments:
{
"title": "token",
"type": "string"
}
|
Authenticate using a given |
auth.two_factor_auth |
---|
Returns true if two factor authorization is required for authorizing user's login. |
auth.twofactor.config |
---|
- |
auth.twofactor.provisioning_uri |
---|
Returns the provisioning URI for the OTP. This can then be encoded in a QR Code and used to provision an OTP app like Google Authenticator. |
auth.twofactor.renew_secret |
---|
Generates a new secret for Two Factor Authentication. Returns boolean true on success. |
auth.twofactor.update |
---|
Arguments:
{
"type": "object",
"properties": {
"enabled": {
"type": "boolean"
},
"otp_digits": {
"type": "integer"
},
"window": {
"type": "integer"
},
"interval": {
"type": "integer"
},
"services": {
"type": "object",
"properties": {
"ssh": {
"type": "boolean"
}
},
"additionalProperties": false
}
},
"additionalProperties": false,
"title": "auth_twofactor_update",
"default": {}
}
|
|
auth.twofactor.verify |
---|
Arguments:
{
"title": "token",
"type": [
"string",
"null"
]
}
|
Returns boolean true if provided |
boot.attach
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"title": "dev",
"type": "string"
}
{
"type": "object",
"properties": {
"expand": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Attach a disk to the boot pool, turning a stripe into a mirror.
|
boot.detach |
---|
Arguments:
{
"title": "dev",
"type": "string"
}
|
Detach given |
boot.get_disks |
---|
Returns disks of the boot pool. |
boot.get_scrub_interval |
---|
Get Automatic Scrub Interval value in days. |
boot.get_state |
---|
Returns the current state of the boot pool, including all vdevs, properties and datasets. |
boot.replace |
---|
Arguments:
{
"title": "label",
"type": "string"
}
{
"title": "dev",
"type": "string"
}
|
Replace device |
boot.scrub
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Scrub on boot pool. |
boot.set_scrub_interval |
---|
Arguments:
{
"type": "integer",
"title": "interval"
}
|
Set Automatic Scrub Interval value in days. |
bootenv.activate |
---|
Arguments:
{
"title": "id",
"type": "string"
}
|
Activates boot environment |
bootenv.create |
---|
Arguments:
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"source": {
"type": "string"
}
},
"additionalProperties": false,
"title": "bootenv_create",
"default": {}
}
|
Create a new boot environment using If a new boot environment is desired which is a clone of another boot environment, Ensure that |
bootenv.delete
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"title": "id",
"type": "string"
}
|
Delete |
bootenv.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Query all Boot Environments with |
bootenv.set_attribute |
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "object",
"properties": {
"keep": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "attributes",
"default": {}
}
|
Sets attributes boot environment Currently only |
bootenv.update |
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "object",
"properties": {
"name": {
"type": "string"
}
},
"additionalProperties": false,
"title": "bootenv_update",
"default": {}
}
|
Update |
certificate.acme_server_choices |
---|
Dictionary of popular ACME Servers with their directory URI endpoints which we display automatically in UI |
certificate.country_choices |
---|
Returns country choices for creating a certificate/csr. |
certificate.create
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"tos": {
"type": "boolean"
},
"dns_mapping": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"csr_id": {
"type": "integer"
},
"signedby": {
"type": "integer"
},
"key_length": {
"type": "integer"
},
"renew_days": {
"type": "integer"
},
"type": {
"type": "integer"
},
"lifetime": {
"type": "integer"
},
"serial": {
"type": "integer"
},
"acme_directory_uri": {
"type": "string"
},
"certificate": {
"type": "string"
},
"city": {
"type": "string"
},
"common": {
"type": [
"string",
"null"
]
},
"country": {
"type": "string"
},
"CSR": {
"type": "string"
},
"ec_curve": {
"type": "string",
"enum": [
"BrainpoolP512R1",
"BrainpoolP384R1",
"BrainpoolP256R1",
"SECP256K1",
"SECP384R1",
"SECP521R1",
"ed25519"
]
},
"email": {
"type": "string"
},
"key_type": {
"type": "string",
"enum": [
"RSA",
"EC"
]
},
"name": {
"type": "string"
},
"organization": {
"type": "string"
},
"organizational_unit": {
"type": "string"
},
"passphrase": {
"type": "string"
},
"privatekey": {
"type": "string"
},
"state": {
"type": "string"
},
"create_type": {
"type": "string",
"enum": [
"CERTIFICATE_CREATE_INTERNAL",
"CERTIFICATE_CREATE_IMPORTED",
"CERTIFICATE_CREATE_CSR",
"CERTIFICATE_CREATE_IMPORTED_CSR",
"CERTIFICATE_CREATE_ACME"
]
},
"digest_algorithm": {
"type": "string",
"enum": [
"SHA1",
"SHA224",
"SHA256",
"SHA384",
"SHA512"
]
},
"san": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"cert_extensions": {
"type": "object",
"properties": {
"BasicConstraints": {
"type": "object",
"properties": {
"ca": {
"type": "boolean"
},
"enabled": {
"type": "boolean"
},
"path_length": {
"type": [
"integer",
"null"
]
},
"extension_critical": {
"type": "boolean"
}
},
"additionalProperties": false
},
"AuthorityKeyIdentifier": {
"type": "object",
"properties": {
"authority_cert_issuer": {
"type": "boolean"
},
"enabled": {
"type": "boolean"
},
"extension_critical": {
"type": "boolean"
}
},
"additionalProperties": false
},
"ExtendedKeyUsage": {
"type": "object",
"properties": {
"usages": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"enabled": {
"type": "boolean"
},
"extension_critical": {
"type": "boolean"
}
},
"additionalProperties": false
},
"KeyUsage": {
"type": "object",
"properties": {
"enabled": {
"type": "boolean"
},
"digital_signature": {
"type": "boolean"
},
"content_commitment": {
"type": "boolean"
},
"key_encipherment": {
"type": "boolean"
},
"data_encipherment": {
"type": "boolean"
},
"key_agreement": {
"type": "boolean"
},
"key_cert_sign": {
"type": "boolean"
},
"crl_sign": {
"type": "boolean"
},
"encipher_only": {
"type": "boolean"
},
"decipher_only": {
"type": "boolean"
},
"extension_critical": {
"type": "boolean"
}
},
"additionalProperties": false
}
},
"additionalProperties": false
}
},
"additionalProperties": false,
"title": "certificate_create",
"default": {}
}
|
Create a new Certificate Certificates are classified under following types and the necessary keywords to be passed
for 1) Internal Certificate - CERTIFICATE_CREATE_INTERNAL 2) Imported Certificate - CERTIFICATE_CREATE_IMPORTED 3) Certificate Signing Request - CERTIFICATE_CREATE_CSR 4) Imported Certificate Signing Request - CERTIFICATE_CREATE_IMPORTED_CSR 5) ACME Certificate - CERTIFICATE_CREATE_ACME By default, created certs use RSA keys. If an Elliptic Curve Key is desired, it can be specified with the
A type is selected by the Certificate Service based on
|
Create an ACME based certificate
Create an Imported Certificate Signing Request
Create an Internal Certificate
|
certificate.delete
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "boolean",
"title": "force",
"default": false
}
|
Delete certificate of If the certificate is an ACME based certificate, certificate service will try to
revoke the certificate by updating it's status with the ACME server, if it fails an exception is raised
and the certificate is not deleted from the system. However, if |
Delete certificate of
|
certificate.ec_curve_choices |
---|
Dictionary of supported EC curves. |
certificate.extended_key_usage_choices |
---|
Dictionary of choices for |
certificate.key_type_choices |
---|
Dictionary of supported key types for certificates. |
certificate.profiles |
---|
Returns a dictionary of predefined options for specific use cases i.e openvpn client/server configurations which can be used for creating certificates. |
certificate.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
certificate.update
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"revoked": {
"type": "boolean"
},
"name": {
"type": "string"
}
},
"additionalProperties": false,
"title": "certificate_update",
"default": {}
}
|
Update certificate of Only name and revoked attribute can be updated. When |
Update a certificate of
|
certificateauthority.ca_sign_csr |
---|
Arguments:
{
"type": "object",
"properties": {
"ca_id": {
"type": "integer"
},
"csr_cert_id": {
"type": "integer"
},
"name": {
"type": "string"
},
"cert_extensions": {
"type": "object",
"properties": {
"BasicConstraints": {
"type": "object",
"properties": {
"ca": {
"type": "boolean"
},
"enabled": {
"type": "boolean"
},
"path_length": {
"type": [
"integer",
"null"
]
},
"extension_critical": {
"type": "boolean"
}
},
"additionalProperties": false
},
"AuthorityKeyIdentifier": {
"type": "object",
"properties": {
"authority_cert_issuer": {
"type": "boolean"
},
"enabled": {
"type": "boolean"
},
"extension_critical": {
"type": "boolean"
}
},
"additionalProperties": false
},
"ExtendedKeyUsage": {
"type": "object",
"properties": {
"usages": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"enabled": {
"type": "boolean"
},
"extension_critical": {
"type": "boolean"
}
},
"additionalProperties": false
},
"KeyUsage": {
"type": "object",
"properties": {
"enabled": {
"type": "boolean"
},
"digital_signature": {
"type": "boolean"
},
"content_commitment": {
"type": "boolean"
},
"key_encipherment": {
"type": "boolean"
},
"data_encipherment": {
"type": "boolean"
},
"key_agreement": {
"type": "boolean"
},
"key_cert_sign": {
"type": "boolean"
},
"crl_sign": {
"type": "boolean"
},
"encipher_only": {
"type": "boolean"
},
"decipher_only": {
"type": "boolean"
},
"extension_critical": {
"type": "boolean"
}
},
"additionalProperties": false
}
},
"additionalProperties": false
}
},
"additionalProperties": false,
"title": "ca_sign_csr",
"default": {}
}
|
Sign CSR by Certificate Authority of Sign CSR's and generate a certificate from it.
|
Sign CSR of
|
certificateauthority.create |
---|
Arguments:
{
"type": "object",
"properties": {
"tos": {
"type": "boolean"
},
"csr_id": {
"type": "integer"
},
"signedby": {
"type": "integer"
},
"key_length": {
"type": "integer"
},
"renew_days": {
"type": "integer"
},
"type": {
"type": "integer"
},
"lifetime": {
"type": "integer"
},
"serial": {
"type": "integer"
},
"acme_directory_uri": {
"type": "string"
},
"certificate": {
"type": "string"
},
"city": {
"type": "string"
},
"common": {
"type": [
"string",
"null"
]
},
"country": {
"type": "string"
},
"CSR": {
"type": "string"
},
"ec_curve": {
"type": "string",
"enum": [
"BrainpoolP512R1",
"BrainpoolP384R1",
"BrainpoolP256R1",
"SECP256K1",
"SECP384R1",
"SECP521R1",
"ed25519"
]
},
"email": {
"type": "string"
},
"key_type": {
"type": "string",
"enum": [
"RSA",
"EC"
]
},
"name": {
"type": "string"
},
"organization": {
"type": "string"
},
"organizational_unit": {
"type": "string"
},
"passphrase": {
"type": "string"
},
"privatekey": {
"type": "string"
},
"state": {
"type": "string"
},
"create_type": {
"type": "string",
"enum": [
"CA_CREATE_INTERNAL",
"CA_CREATE_IMPORTED",
"CA_CREATE_INTERMEDIATE"
]
},
"digest_algorithm": {
"type": "string",
"enum": [
"SHA1",
"SHA224",
"SHA256",
"SHA384",
"SHA512"
]
},
"san": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"cert_extensions": {
"type": "object",
"properties": {
"BasicConstraints": {
"type": "object",
"properties": {
"ca": {
"type": "boolean"
},
"enabled": {
"type": "boolean"
},
"path_length": {
"type": [
"integer",
"null"
]
},
"extension_critical": {
"type": "boolean"
}
},
"additionalProperties": false
},
"AuthorityKeyIdentifier": {
"type": "object",
"properties": {
"authority_cert_issuer": {
"type": "boolean"
},
"enabled": {
"type": "boolean"
},
"extension_critical": {
"type": "boolean"
}
},
"additionalProperties": false
},
"ExtendedKeyUsage": {
"type": "object",
"properties": {
"usages": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"enabled": {
"type": "boolean"
},
"extension_critical": {
"type": "boolean"
}
},
"additionalProperties": false
},
"KeyUsage": {
"type": "object",
"properties": {
"enabled": {
"type": "boolean"
},
"digital_signature": {
"type": "boolean"
},
"content_commitment": {
"type": "boolean"
},
"key_encipherment": {
"type": "boolean"
},
"data_encipherment": {
"type": "boolean"
},
"key_agreement": {
"type": "boolean"
},
"key_cert_sign": {
"type": "boolean"
},
"crl_sign": {
"type": "boolean"
},
"encipher_only": {
"type": "boolean"
},
"decipher_only": {
"type": "boolean"
},
"extension_critical": {
"type": "boolean"
}
},
"additionalProperties": false
}
},
"additionalProperties": false
}
},
"additionalProperties": false,
"title": "certificate_create",
"default": {}
}
|
Create a new Certificate Authority Certificate Authorities are classified under following types with the necessary keywords to be passed
for 1) Internal Certificate Authority - CA_CREATE_INTERNAL 2) Imported Certificate Authority - CA_CREATE_IMPORTED 3) Intermediate Certificate Authority - CA_CREATE_INTERMEDIATE Created certificate authorities use RSA keys by default. If an Elliptic Curve Key is desired, then it can be
specified with the A type is selected by the Certificate Authority Service based on
|
Create an Internal Certificate Authority
Create an Imported Certificate Authority
|
certificateauthority.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete a Certificate Authority of |
Delete a Certificate Authority of
|
certificateauthority.profiles |
---|
Returns a dictionary of predefined options for specific use cases i.e OpenVPN certificate authority configurations which can be used for creating certificate authorities. |
certificateauthority.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
certificateauthority.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"revoked": {
"type": "boolean"
},
"ca_id": {
"type": "integer"
},
"csr_cert_id": {
"type": "integer"
},
"create_type": {
"type": "string",
"enum": [
"CA_SIGN_CSR"
]
},
"name": {
"type": "string"
}
},
"additionalProperties": false,
"title": "ca_update",
"default": {}
}
|
Update Certificate Authority of Only If |
Update a Certificate Authority of
|
cloudsync.abort |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Aborts cloud sync task. |
cloudsync.common_task_schema |
---|
- |
cloudsync.create |
---|
Arguments:
{
"type": "object",
"properties": {
"description": {
"type": "string"
},
"direction": {
"type": "string",
"enum": [
"PUSH",
"PULL"
]
},
"transfer_mode": {
"type": "string",
"enum": [
"SYNC",
"COPY",
"MOVE"
]
},
"path": {
"type": "string"
},
"credentials": {
"type": "integer"
},
"encryption": {
"type": "boolean"
},
"filename_encryption": {
"type": "boolean"
},
"encryption_password": {
"type": "string"
},
"encryption_salt": {
"type": "string"
},
"schedule": {
"type": "object",
"properties": {
"minute": {
"type": "string"
},
"hour": {
"type": "string"
},
"dom": {
"type": "string"
},
"month": {
"type": "string"
},
"dow": {
"type": "string"
}
},
"additionalProperties": false
},
"follow_symlinks": {
"type": "boolean"
},
"transfers": {
"type": [
"integer",
"null"
]
},
"bwlimit": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"exclude": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"attributes": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"snapshot": {
"type": "boolean"
},
"pre_script": {
"type": "string"
},
"post_script": {
"type": "string"
},
"args": {
"type": "string"
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "cloud_sync_create",
"default": {}
}
|
Creates a new cloud_sync entry. |
Create a new cloud_sync using amazon s3 attributes, which is supposed to run every hour.
|
cloudsync.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Deletes cloud_sync entry |
cloudsync.list_buckets |
---|
Arguments:
{
"type": "integer",
"title": "credentials_id"
}
|
- |
cloudsync.list_directory |
---|
Arguments:
{
"type": "object",
"properties": {
"credentials": {
"type": "integer"
},
"encryption": {
"type": "boolean"
},
"filename_encryption": {
"type": "boolean"
},
"encryption_password": {
"type": "string"
},
"encryption_salt": {
"type": "string"
},
"attributes": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"args": {
"type": "string"
}
},
"additionalProperties": false,
"title": "cloud_sync_ls",
"default": {}
}
|
List contents of a remote bucket / directory. If remote supports buckets, path is constructed by two keys "bucket"/"folder" in Path examples: S3 Service
Dropbox Service
|
cloudsync.onedrive_list_drives |
---|
Arguments:
{
"type": "object",
"properties": {
"client_id": {
"type": "string"
},
"client_secret": {
"type": "string"
},
"token": {
"type": "string"
}
},
"additionalProperties": false,
"title": "onedrive_list_drives",
"default": {}
}
|
Lists all available drives and their types for given Microsoft OneDrive credentials. |
Returns
|
cloudsync.providers |
---|
Returns a list of dictionaries of supported providers for Cloud Sync Tasks.
Example of a single provider: [ { "name": "AMAZON_CLOUD_DRIVE", "title": "Amazon Cloud Drive", "credentials_schema": [ { "property": "client_id", "schema": { "title": "Amazon Application Client ID", "required": true, "type": "string" } }, { "property": "client_secret", "schema": { "title": "Application Key", "required": true, "type": "string" } } ], "credentials_oauth": null, "buckets": false, "bucket_title": "Bucket", "task_schema": [] } ] |
cloudsync.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Query all Cloud Sync Tasks with |
cloudsync.restore |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"description": {
"type": "string"
},
"transfer_mode": {
"type": "string",
"enum": [
"SYNC",
"COPY"
]
},
"path": {
"type": "string"
}
},
"additionalProperties": false,
"title": "cloud_sync_restore",
"default": {}
}
|
Create the opposite of cloud sync task |
cloudsync.sync
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"dry_run": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "cloud_sync_sync_options",
"default": {}
}
|
Run the cloud_sync job |
cloudsync.sync_onetime
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"description": {
"type": "string"
},
"direction": {
"type": "string",
"enum": [
"PUSH",
"PULL"
]
},
"transfer_mode": {
"type": "string",
"enum": [
"SYNC",
"COPY",
"MOVE"
]
},
"path": {
"type": "string"
},
"credentials": {
"type": "integer"
},
"encryption": {
"type": "boolean"
},
"filename_encryption": {
"type": "boolean"
},
"encryption_password": {
"type": "string"
},
"encryption_salt": {
"type": "string"
},
"schedule": {
"type": "object",
"properties": {
"minute": {
"type": "string"
},
"hour": {
"type": "string"
},
"dom": {
"type": "string"
},
"month": {
"type": "string"
},
"dow": {
"type": "string"
}
},
"additionalProperties": false
},
"follow_symlinks": {
"type": "boolean"
},
"transfers": {
"type": [
"integer",
"null"
]
},
"bwlimit": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"exclude": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"attributes": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"snapshot": {
"type": "boolean"
},
"pre_script": {
"type": "string"
},
"post_script": {
"type": "string"
},
"args": {
"type": "string"
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "cloud_sync_create",
"default": {}
}
{
"type": "object",
"properties": {
"dry_run": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "cloud_sync_sync_options",
"default": {}
}
|
Run cloud sync task without creating it. |
cloudsync.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"description": {
"type": "string"
},
"direction": {
"type": "string",
"enum": [
"PUSH",
"PULL"
]
},
"transfer_mode": {
"type": "string",
"enum": [
"SYNC",
"COPY",
"MOVE"
]
},
"path": {
"type": "string"
},
"credentials": {
"type": "integer"
},
"encryption": {
"type": "boolean"
},
"filename_encryption": {
"type": "boolean"
},
"encryption_password": {
"type": "string"
},
"encryption_salt": {
"type": "string"
},
"schedule": {
"type": "object",
"properties": {
"minute": {
"type": "string"
},
"hour": {
"type": "string"
},
"dom": {
"type": "string"
},
"month": {
"type": "string"
},
"dow": {
"type": "string"
}
},
"additionalProperties": false
},
"follow_symlinks": {
"type": "boolean"
},
"transfers": {
"type": [
"integer",
"null"
]
},
"bwlimit": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"exclude": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"attributes": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"snapshot": {
"type": "boolean"
},
"pre_script": {
"type": "string"
},
"post_script": {
"type": "string"
},
"args": {
"type": "string"
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "cloud_sync_create",
"default": {}
}
|
Updates the cloud_sync entry |
cloudsync.credentials.create |
---|
Arguments:
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"provider": {
"type": "string"
},
"attributes": {
"type": "object",
"properties": {},
"additionalProperties": true
}
},
"additionalProperties": false,
"title": "cloud_sync_credentials_create",
"default": {}
}
|
Create Cloud Sync Credentials.
|
cloudsync.credentials.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete Cloud Sync Credentials of |
cloudsync.credentials.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
cloudsync.credentials.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"provider": {
"type": "string"
},
"attributes": {
"type": "object",
"properties": {},
"additionalProperties": true
}
},
"additionalProperties": false,
"title": "cloud_sync_credentials_create",
"default": {}
}
|
Update Cloud Sync Credentials of |
cloudsync.credentials.verify |
---|
Arguments:
{
"type": "object",
"properties": {
"provider": {
"type": "string"
},
"attributes": {
"type": "object",
"properties": {},
"additionalProperties": true
}
},
"additionalProperties": false,
"title": "cloud_sync_credentials_verify",
"default": {}
}
|
Verify if |
config.reset
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"reboot": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Reset database to configuration defaults. If |
config.save |
---|
Arguments:
{
"type": "object",
"properties": {
"secretseed": {
"type": "boolean"
},
"pool_keys": {
"type": "boolean"
},
"root_authorized_keys": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "configsave",
"default": {}
}
|
Create a bundle of security-sensitive information. These options select which information is included in the bundle:
If none of these options are set, the bundle is not generated and the database file is provided. |
config.upload |
---|
Accepts a configuration file via job pipe. |
core.bulk
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"title": "method",
"type": "string"
}
{
"type": "array",
"title": "params",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"title": "description",
"default": null,
"type": [
"string",
"null"
]
}
|
Will loop on a list of items for the given method, returning a list of dicts containing a result and error key.
Result will be the message returned by the method being called, or a string of an error, in which case the error key will be the exception |
core.debug |
---|
Arguments:
{
"title": "engine",
"type": "string",
"enum": [
"PTVS",
"PYDEV",
"REMOTE_PDB"
]
}
{
"type": "object",
"properties": {
"secret": {
"type": "string"
},
"bind_address": {
"type": "string"
},
"bind_port": {
"type": "integer"
},
"host": {
"type": "string"
},
"wait_attach": {
"type": "boolean"
},
"local_path": {
"type": "string"
},
"threaded": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Setup middlewared for remote debugging. engines: - PTVS: Python Visual Studio - PYDEV: Python Dev (Eclipse/PyCharm) - REMOTE_PDB: Remote vanilla PDB (over TCP sockets) options: - secret: password for PTVS - host: required for PYDEV, hostname of local computer (developer workstation) - local_path: required for PYDEV, path for middlewared source in local computer (e.g. /home/user/freenas/src/middlewared/middlewared - threaded: run debugger in a new thread instead of event loop |
core.download |
---|
Arguments:
{
"title": "method",
"type": "string"
}
{
"type": "array",
"title": "args",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"title": "filename",
"type": "string"
}
{
"type": "boolean",
"title": "buffered",
"default": false
}
|
Core helper to call a job marked for download. Non- Returns the job id and the URL for download. |
core.get_events |
---|
Returns metadata for every possible event emitted from websocket server. |
core.get_jobs |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Get the long running jobs. |
core.get_methods |
---|
Arguments:
{
"title": "service",
"default": null,
"type": [
"string",
"null"
]
}
|
Return methods metadata of every available service.
|
core.get_services |
---|
Returns a list of all registered services. |
core.job_abort |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
- |
core.job_update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"progress": {
"type": "object",
"properties": {},
"additionalProperties": true
}
},
"additionalProperties": false,
"title": "job-update",
"default": {}
}
|
- |
core.job_wait
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
- |
core.ping |
---|
Utility method which just returns "pong". Can be used to keep connection/authtoken alive instead of using "ping" protocol message. |
core.ping_remote |
---|
Arguments:
{
"type": "object",
"properties": {
"type": {
"type": "string",
"enum": [
"ICMP",
"ICMPV4",
"ICMPV6"
]
},
"hostname": {
"type": "string"
},
"timeout": {
"type": "integer"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Method that will send an ICMP echo request to "hostname" and will wait up to "timeout" for a reply. |
core.resize_shell |
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "integer",
"title": "cols"
}
{
"type": "integer",
"title": "rows"
}
|
Resize terminal session (/websocket/shell) to cols x rows |
core.sessions |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Get currently open websocket sessions. |
cronjob.create |
---|
Arguments:
{
"type": "object",
"properties": {
"enabled": {
"type": "boolean"
},
"stderr": {
"type": "boolean"
},
"stdout": {
"type": "boolean"
},
"schedule": {
"type": "object",
"properties": {
"minute": {
"type": "string"
},
"hour": {
"type": "string"
},
"dom": {
"type": "string"
},
"month": {
"type": "string"
},
"dow": {
"type": "string"
}
},
"additionalProperties": false
},
"command": {
"type": "string"
},
"description": {
"type": "string"
},
"user": {
"type": "string"
}
},
"additionalProperties": false,
"title": "cron_job_create",
"default": {}
}
|
Create a new cron job.
|
Create a cron job which executes
|
cronjob.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete cronjob of |
cronjob.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
cronjob.run
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "boolean",
"title": "skip_disabled",
"default": false
}
|
Job to run cronjob task of |
cronjob.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"enabled": {
"type": "boolean"
},
"stderr": {
"type": "boolean"
},
"stdout": {
"type": "boolean"
},
"schedule": {
"type": "object",
"properties": {
"minute": {
"type": "string"
},
"hour": {
"type": "string"
},
"dom": {
"type": "string"
},
"month": {
"type": "string"
},
"dow": {
"type": "string"
}
},
"additionalProperties": false
},
"command": {
"type": "string"
},
"description": {
"type": "string"
},
"user": {
"type": "string"
}
},
"additionalProperties": false,
"title": "cron_job_create",
"default": {}
}
|
Update cronjob of |
device.get_info |
---|
Arguments:
{
"title": "type",
"type": "string",
"enum": [
"SERIAL",
"DISK"
]
}
|
Get info for SERIAL/DISK device types. |
directoryservices.cache_refresh
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
This method refreshes the directory services cache for users and groups that is
used as a backing for A cache refresh is not required in order to use newly-added users and groups for in permissions and ACL related methods. Likewise, a cache refresh will not resolve issues with users being unable to authenticate to shares. |
directoryservices.get_state |
---|
|
disk.decrypt |
---|
Arguments:
{
"type": "array",
"title": "devices",
"items": [
{
"type": "string"
}
]
}
{
"title": "passphrase",
"default": null,
"type": [
"string",
"null"
]
}
|
Decrypt |
disk.get_encrypted |
---|
Arguments:
{
"type": "object",
"properties": {
"unused": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Get all geli providers It might be an entire disk or a partition of type freebsd-zfs. Before a geli encrypted pool can be imported, disks used in the pool should be decrypted
and then pool import can proceed as desired. In that case |
disk.get_unused |
---|
Arguments:
{
"type": "boolean",
"title": "join_partitions",
"default": false
}
|
Helper method to get all disks that are not in use, either by the boot pool or the user pools. |
disk.label_to_dev |
---|
- |
disk.label_to_dev_disk_cache |
---|
- |
disk.overprovision |
---|
Arguments:
{
"title": "devname",
"type": "string"
}
{
"type": "integer",
"title": "size"
}
|
Sets overprovision of disk |
disk.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Query disks. The following extra options are supported:
|
disk.sed_dev_name |
---|
- |
disk.smart_attributes |
---|
Arguments:
{
"title": "name",
"type": "string"
}
|
Returns S.M.A.R.T. attributes values for specified disk name. |
disk.spindown |
---|
Arguments:
{
"title": "disk",
"type": "string"
}
|
Spin down disk by device name |
Spin down
|
disk.temperature |
---|
Arguments:
{
"title": "name",
"type": "string"
}
{
"title": "powermode",
"default": "NEVER",
"type": "string",
"enum": [
"NEVER",
"SLEEP",
"STANDBY",
"IDLE"
]
}
|
Returns temperature for device |
disk.temperatures |
---|
Arguments:
{
"type": "array",
"title": "names",
"items": [
{
"type": "string"
}
]
}
{
"title": "powermode",
"default": "NEVER",
"type": "string",
"enum": [
"NEVER",
"SLEEP",
"STANDBY",
"IDLE"
]
}
|
Returns temperatures for a list of devices (runs in parallel).
See |
disk.unoverprovision |
---|
Arguments:
{
"title": "devname",
"type": "string"
}
|
Removes overprovisioning of disk |
disk.update |
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "object",
"properties": {
"togglesmart": {
"type": "boolean"
},
"acousticlevel": {
"type": "string",
"enum": [
"DISABLED",
"MINIMUM",
"MEDIUM",
"MAXIMUM"
]
},
"advpowermgmt": {
"type": "string",
"enum": [
"DISABLED",
"1",
"64",
"127",
"128",
"192",
"254"
]
},
"description": {
"type": "string"
},
"hddstandby": {
"type": "string",
"enum": [
"ALWAYS ON",
"5",
"10",
"20",
"30",
"60",
"120",
"180",
"240",
"300",
"330"
]
},
"hddstandby_force": {
"type": "boolean"
},
"passwd": {
"type": "string"
},
"smartoptions": {
"type": "string"
},
"critical": {
"type": [
"integer",
"null"
]
},
"difference": {
"type": [
"integer",
"null"
]
},
"informational": {
"type": [
"integer",
"null"
]
},
"enclosure": {
"type": "object",
"properties": {
"number": {
"type": "integer"
},
"slot": {
"type": "integer"
}
},
"additionalProperties": false
}
},
"additionalProperties": false,
"title": "disk_update",
"default": {}
}
|
Update disk of If extra options need to be passed to SMART which we don't already support, they can be passed by
Email of log level LOG_CRIT is issued when disk temperature crosses Email of log level LOG_INFO is issued when disk temperature crosses If temperature of a disk changes by |
disk.wipe
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"title": "dev",
"type": "string"
}
{
"title": "mode",
"type": "string",
"enum": [
"QUICK",
"FULL",
"FULL_RANDOM"
]
}
{
"type": "boolean",
"title": "synccache",
"default": true
}
{
"type": "object",
"properties": {
"configure_swap": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "swap_removal_options",
"default": {}
}
|
Performs a wipe of a disk |
dns.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Query Name Servers with |
dyndns.config |
---|
- |
dyndns.provider_choices |
---|
List supported Dynamic DNS Service Providers. |
dyndns.update |
---|
Arguments:
{
"type": "object",
"properties": {
"provider": {
"type": "string"
},
"checkip_ssl": {
"type": "boolean"
},
"checkip_server": {
"type": "string"
},
"checkip_path": {
"type": "string"
},
"ssl": {
"type": "boolean"
},
"custom_ddns_server": {
"type": "string"
},
"custom_ddns_path": {
"type": "string"
},
"domain": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"username": {
"type": "string"
},
"password": {
"type": "string"
},
"period": {
"type": "integer"
}
},
"additionalProperties": false,
"title": "dyndns_update",
"default": {}
}
|
Update dynamic dns service configuration.
|
ec2.Meta |
---|
- |
ec2.instance_id |
---|
- |
ec2.set_ntp_servers |
---|
- |
ec2.set_root_ssh_public_key |
---|
- |
ec2.setup |
---|
- |
enclosure.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
enclosure.set_slot_status |
---|
Arguments:
{
"title": "enclosure_id",
"type": "string"
}
{
"type": "integer",
"title": "slot"
}
{
"title": "status",
"type": "string",
"enum": [
"CLEAR",
"FAULT",
"IDENTIFY"
]
}
|
Set an enclosure's, with id of |
enclosure.update |
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "object",
"properties": {
"label": {
"type": "string"
}
},
"additionalProperties": false,
"title": "enclosure_update",
"default": {}
}
|
- |
failover.call_remote |
---|
Arguments:
{
"title": "method",
"type": "string"
}
{
"type": "array",
"title": "args",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"timeout": {
"type": "integer"
},
"job": {
"type": "boolean"
},
"job_return": {
"type": [
"boolean",
"null"
]
},
"callback": {
"anyOf": [
{
"type": "string"
},
{
"type": "integer"
},
{
"type": "boolean"
},
{
"type": "object"
},
{
"type": "array"
}
],
"title": "callback",
"nullable": false
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Call a method in the other node. |
failover.config |
---|
- |
failover.control |
---|
Arguments:
{
"title": "action",
"type": "string",
"enum": [
"ENABLE",
"DISABLE"
]
}
{
"type": "object",
"properties": {
"active": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
- |
failover.disabled_reasons |
---|
Returns a list of reasons why failover is not enabled/functional. NO_VOLUME - There are no pools configured. NO_VIP - There are no interfaces configured with Virtual IP. NO_SYSTEM_READY - Other storage controller has not finished booting. NO_PONG - Other storage controller is not communicable. NO_FAILOVER - Failover is administratively disabled. NO_LICENSE - Other storage controller has no license. DISAGREE_CARP - Nodes CARP states do not agree. MISMATCH_DISKS - The storage controllers do not have the same quantity of disks. NO_CRITICAL_INTERFACES - No network interfaces are marked critical for failover. |
failover.force_master |
---|
Force this controller to become MASTER. |
failover.get_ips |
---|
Get a list of IPs which can be accessed for management via UI. |
failover.hardware |
---|
Returns the hardware type for an HA system. ECHOSTREAM ECHOWARP PUMA SBB ULTIMATE BHYVE IXKVM (HA VMs (on KVM) for CI) MANUAL |
failover.in_progress |
---|
Returns True if there is an ongoing failover event. |
failover.licensed |
---|
Checks whether this instance is licensed as a HA unit. |
failover.node |
---|
Returns the slot position in the chassis that the controller is located. A - First node B - Seconde Node MANUAL - slot position in chassis could not be determined |
failover.status |
---|
Get the current HA status. Returns: MASTER BACKUP ELECTING IMPORTING ERROR SINGLE |
failover.sync_from_peer |
---|
Sync database and files from the other controller. |
failover.sync_to_peer |
---|
Arguments:
{
"type": "object",
"properties": {
"reboot": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Sync database and files to the other controller.
|
failover.unlock |
---|
Arguments:
{
"type": "object",
"properties": {
"pools": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"datasets": {
"type": "array",
"items": [
{
"type": "object"
}
]
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Unlock pools in HA, syncing passphrase between controllers and forcing this controller to be MASTER importing the pools. |
failover.update |
---|
Arguments:
{
"type": "object",
"properties": {
"disabled": {
"type": "boolean"
},
"timeout": {
"type": "integer"
},
"master": {
"type": [
"boolean",
"null"
]
}
},
"additionalProperties": false,
"title": "failover_update",
"default": {}
}
|
Update failover state.
|
failover.upgrade |
---|
Arguments:
{
"type": "object",
"properties": {
"train": {
"type": "string"
}
},
"additionalProperties": false,
"title": "failover_upgrade",
"default": {}
}
|
Upgrades both controllers. Files will be downloaded to the Active Controller and then transferred to the Standby Controller. Upgrade process will start concurrently on both nodes. Once both upgrades are applied, the Standby Controller will reboot. This job will wait for that job to complete before finalizing. |
failover.upgrade_finish
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Perform the last stage of an HA upgrade. This will activate the new boot environment on the Standby Controller and reboot it. |
failover.upgrade_pending |
---|
Verify if HA upgrade is pending.
|
fcport.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
fcport.update |
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "object",
"properties": {
"mode": {
"type": "string",
"enum": [
"INITIATOR",
"TARGET",
"DISABLED"
]
},
"target": {
"type": [
"integer",
"null"
]
}
},
"additionalProperties": false,
"title": "fcport_update",
"default": {}
}
|
- |
filesystem.acl_is_trivial |
---|
Arguments:
{
"title": "path",
"type": "string"
}
|
Returns True if the ACL can be fully expressed as a file mode without losing any access rules, or if the path does not support NFSv4 ACLs (for example a path on a tmpfs filesystem). |
filesystem.chown
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"path": {
"type": "string"
},
"uid": {
"type": [
"integer",
"null"
]
},
"gid": {
"type": [
"integer",
"null"
]
},
"options": {
"type": "object",
"properties": {
"recursive": {
"type": "boolean"
},
"traverse": {
"type": "boolean"
}
},
"additionalProperties": false
}
},
"additionalProperties": false,
"title": "filesystem_ownership",
"default": {}
}
|
Change owner or group of file at
If |
filesystem.default_acl_choices |
---|
Get list of default ACL types. |
filesystem.get |
---|
Arguments:
{
"title": "path",
"type": "string"
}
|
Job to get contents of |
filesystem.get_default_acl |
---|
Arguments:
{
"title": "acl_type",
"default": "OPEN",
"type": "string",
"enum": [
"OPEN",
"RESTRICTED",
"HOME",
"DOMAIN_HOME"
]
}
{
"title": "share_type",
"default": "NONE",
"type": "string",
"enum": [
"NONE",
"AFP",
"SMB",
"NFS"
]
}
|
Returns a default ACL depending on the usage specified by |
filesystem.getacl |
---|
Arguments:
{
"title": "path",
"type": "string"
}
{
"type": "boolean",
"title": "simplified",
"default": true
}
|
Return ACL of a given path. This may return a POSIX1e ACL or a NFSv4 ACL. The acl type is indicated
by the Errata about ACLType NFSv4:
If the permisssions do not fit within one of the pre-defined simplified permissions types, then the full ACL entry will be returned. In all cases we replace USER_OBJ, GROUP_OBJ, and EVERYONE with owner@, group@, everyone@ for consistency with getfacl and setfacl. If one of aforementioned special tags is used, 'id' must be set to None. An inheriting empty everyone@ ACE is appended to non-trivial ACLs in order to enforce Windows expectations regarding permissions inheritance. This entry is removed from NT ACL returned to SMB clients when 'ixnas' samba VFS module is enabled. We also remove it here to avoid confusion. |
filesystem.listdir |
---|
Arguments:
{
"title": "path",
"type": "string"
}
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Get the contents of a directory. Each entry of the list consists of: name(str): name of the file path(str): absolute path of the entry realpath(str): absolute real path of the entry (if SYMLINK) type(str): DIRECTORY | FILESYSTEM | SYMLINK | OTHER size(int): size of the entry mode(int): file mode/permission uid(int): user id of entry owner gid(int): group id of entry onwer acl(bool): extended ACL is present on file |
filesystem.put |
---|
Arguments:
{
"title": "path",
"type": "string"
}
{
"type": "object",
"properties": {
"append": {
"type": "boolean"
},
"mode": {
"type": "integer"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Job to put contents to |
filesystem.setacl
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"path": {
"type": "string"
},
"uid": {
"type": [
"integer",
"null"
]
},
"gid": {
"type": [
"integer",
"null"
]
},
"dacl": {
"type": "array",
"items": [
{
"type": "object"
},
{
"type": "object"
}
]
},
"nfs41_flags": {
"type": "object",
"properties": {
"autoinherit": {
"type": "boolean"
},
"protected": {
"type": "boolean"
}
},
"additionalProperties": false
},
"acltype": {
"type": "string",
"enum": [
"NFS4",
"POSIX1E",
"RICH"
]
},
"options": {
"type": "object",
"properties": {
"stripacl": {
"type": "boolean"
},
"recursive": {
"type": "boolean"
},
"traverse": {
"type": "boolean"
},
"canonicalize": {
"type": "boolean"
}
},
"additionalProperties": false
}
},
"additionalProperties": false,
"title": "filesystem_acl",
"default": {}
}
|
Set ACL of a given path. Takes the following parameters:
In all cases we replace USER_OBJ, GROUP_OBJ, and EVERYONE with owner@, group@, everyone@ for consistency with getfacl and setfacl. If one of aforementioned special tags is used, 'id' must be set to None. An inheriting empty everyone@ ACE is appended to non-trivial ACLs in order to enforce Windows expectations regarding permissions inheritance. This entry is removed from NT ACL returned to SMB clients when 'ixnas' samba VFS module is enabled. |
filesystem.setperm
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"path": {
"type": "string"
},
"mode": {
"type": [
"string",
"null"
]
},
"uid": {
"type": [
"integer",
"null"
]
},
"gid": {
"type": [
"integer",
"null"
]
},
"options": {
"type": "object",
"properties": {
"stripacl": {
"type": "boolean"
},
"recursive": {
"type": "boolean"
},
"traverse": {
"type": "boolean"
}
},
"additionalProperties": false
}
},
"additionalProperties": false,
"title": "filesystem_permission",
"default": {}
}
|
Remove extended ACL from specified path. If
If no |
filesystem.stat |
---|
Arguments:
{
"title": "path",
"type": "string"
}
|
Return the filesystem stat(2) for a given |
filesystem.statfs |
---|
Arguments:
{
"title": "path",
"type": "string"
}
|
Return stats from the filesystem of a given path. Raises: CallError(ENOENT) - Path not found |
ftp.config |
---|
- |
ftp.update |
---|
Arguments:
{
"type": "object",
"properties": {
"port": {
"type": "integer"
},
"clients": {
"type": "integer"
},
"ipconnections": {
"type": "integer"
},
"loginattempt": {
"type": "integer"
},
"timeout": {
"type": "integer"
},
"rootlogin": {
"type": "boolean"
},
"onlyanonymous": {
"type": "boolean"
},
"anonpath": {
"type": [
"string",
"null"
]
},
"onlylocal": {
"type": "boolean"
},
"banner": {
"type": "string"
},
"filemask": {
"type": "string"
},
"dirmask": {
"type": "string"
},
"fxp": {
"type": "boolean"
},
"resume": {
"type": "boolean"
},
"defaultroot": {
"type": "boolean"
},
"ident": {
"type": "boolean"
},
"reversedns": {
"type": "boolean"
},
"masqaddress": {
"type": "string"
},
"passiveportsmin": {
"type": "integer"
},
"passiveportsmax": {
"type": "integer"
},
"localuserbw": {
"type": "integer"
},
"localuserdlbw": {
"type": "integer"
},
"anonuserbw": {
"type": "integer"
},
"anonuserdlbw": {
"type": "integer"
},
"tls": {
"type": "boolean"
},
"tls_policy": {
"type": "string",
"enum": [
"on",
"off",
"data",
"!data",
"auth",
"ctrl",
"ctrl+data",
"ctrl+!data",
"auth+data",
"auth+!data"
]
},
"tls_opt_allow_client_renegotiations": {
"type": "boolean"
},
"tls_opt_allow_dot_login": {
"type": "boolean"
},
"tls_opt_allow_per_user": {
"type": "boolean"
},
"tls_opt_common_name_required": {
"type": "boolean"
},
"tls_opt_enable_diags": {
"type": "boolean"
},
"tls_opt_export_cert_data": {
"type": "boolean"
},
"tls_opt_no_cert_request": {
"type": "boolean"
},
"tls_opt_no_empty_fragments": {
"type": "boolean"
},
"tls_opt_no_session_reuse_required": {
"type": "boolean"
},
"tls_opt_stdenvvars": {
"type": "boolean"
},
"tls_opt_dns_name_required": {
"type": "boolean"
},
"tls_opt_ip_address_required": {
"type": "boolean"
},
"ssltls_certificate": {
"type": [
"integer",
"null"
]
},
"options": {
"type": "string"
}
},
"additionalProperties": false,
"title": "ftp_update",
"default": {}
}
|
Update ftp service configuration.
|
group.create |
---|
Arguments:
{
"type": "object",
"properties": {
"gid": {
"type": "integer"
},
"name": {
"type": "string"
},
"smb": {
"type": "boolean"
},
"sudo": {
"type": "boolean"
},
"sudo_nopasswd": {
"type": "boolean"
},
"sudo_commands": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"allow_duplicate_gid": {
"type": "boolean"
},
"users": {
"type": "array",
"items": [
{
"type": "integer"
}
]
}
},
"additionalProperties": false,
"title": "group_create",
"default": {}
}
|
Create a new group. If
|
group.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"delete_users": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Delete group The |
group.get_group_obj |
---|
Arguments:
{
"type": "object",
"properties": {
"groupname": {
"type": "string"
},
"gid": {
"type": "integer"
}
},
"additionalProperties": false,
"title": "get_group_obj",
"default": {}
}
|
Returns dictionary containing information from struct grp for the group specified by either the groupname or gid. Bypasses group cache. |
group.get_next_gid |
---|
Get the next available/free gid. |
group.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Query groups with Groups from directory services such as NIS, LDAP, or Active Directory will be included in query results
if the option |
group.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"gid": {
"type": "integer"
},
"name": {
"type": "string"
},
"smb": {
"type": "boolean"
},
"sudo": {
"type": "boolean"
},
"sudo_nopasswd": {
"type": "boolean"
},
"sudo_commands": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"allow_duplicate_gid": {
"type": "boolean"
},
"users": {
"type": "array",
"items": [
{
"type": "integer"
}
]
}
},
"additionalProperties": false,
"title": "group_create",
"default": {}
}
|
Update attributes of an existing group. |
hardware.events.apei |
---|
- |
hardware.events.mca |
---|
- |
hardware.events.report |
---|
- |
idmap.backend_choices |
---|
Returns array of valid idmap backend choices per directory service. |
idmap.backend_options |
---|
This returns full information about idmap backend options. Not all
|
idmap.clear_idmap_cache
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Stop samba, remove the winbindd_cache.tdb file, start samba, flush samba's cache. This should be performed after finalizing idmap changes. |
idmap.create |
---|
Arguments:
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"dns_domain_name": {
"type": "string"
},
"range_low": {
"type": "integer"
},
"range_high": {
"type": "integer"
},
"idmap_backend": {
"type": "string",
"enum": [
"AD",
"AUTORID",
"LDAP",
"NSS",
"RFC2307",
"RID",
"TDB"
]
},
"certificate": {
"type": [
"integer",
"null"
]
},
"options": {
"type": "object",
"properties": {
"schema_mode": {
"type": "string",
"enum": [
"RFC2307",
"SFU",
"SFU20"
]
},
"unix_primary_group": {
"type": "boolean"
},
"unix_nss_info": {
"type": "boolean"
},
"rangesize": {
"type": "integer"
},
"readonly": {
"type": "boolean"
},
"ignore_builtin": {
"type": "boolean"
},
"ldap_base_dn": {
"type": "string"
},
"ldap_user_dn": {
"type": "string"
},
"ldap_user_dn_password": {
"type": "string"
},
"ldap_url": {
"type": "string"
},
"ssl": {
"type": "string",
"enum": [
"OFF",
"ON",
"START_TLS"
]
},
"linked_service": {
"type": "string",
"enum": [
"LOCAL_ACCOUNT",
"LDAP",
"NIS"
]
},
"ldap_server": {
"type": "string"
},
"ldap_realm": {
"type": "boolean"
},
"bind_path_user": {
"type": "string"
},
"bind_path_group": {
"type": "string"
},
"user_cn": {
"type": "boolean"
},
"cn_realm": {
"type": "string"
},
"ldap_domain": {
"type": "string"
},
"sssd_compat": {
"type": "boolean"
}
},
"additionalProperties": false
}
},
"additionalProperties": false,
"title": "idmap_domain_create",
"default": {}
}
|
Create a new IDMAP domain. These domains must be unique. This table will be automatically populated after joining an Active Directory domain if "allow trusted domains" is set to True in the AD service configuration. There are three default system domains: DS_TYPE_ACTIVEDIRECTORY, DS_TYPE_LDAP, DS_TYPE_DEFAULT_DOMAIN. The system domains correspond with the idmap settings under Active Directory, LDAP, and SMB respectively.
|
idmap.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete a domain by id. Deletion of default system domains is not permitted. |
idmap.options_choices |
---|
Arguments:
{
"title": "idmap_backend",
"type": "string",
"enum": [
"AD",
"AUTORID",
"LDAP",
"NSS",
"RFC2307",
"RID",
"TDB"
]
}
|
Returns a list of supported keys for the specified idmap backend. |
idmap.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
idmap.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"dns_domain_name": {
"type": "string"
},
"range_low": {
"type": "integer"
},
"range_high": {
"type": "integer"
},
"idmap_backend": {
"type": "string",
"enum": [
"AD",
"AUTORID",
"LDAP",
"NSS",
"RFC2307",
"RID",
"TDB"
]
},
"certificate": {
"type": [
"integer",
"null"
]
},
"options": {
"type": "object",
"properties": {
"schema_mode": {
"type": "string",
"enum": [
"RFC2307",
"SFU",
"SFU20"
]
},
"unix_primary_group": {
"type": "boolean"
},
"unix_nss_info": {
"type": "boolean"
},
"rangesize": {
"type": "integer"
},
"readonly": {
"type": "boolean"
},
"ignore_builtin": {
"type": "boolean"
},
"ldap_base_dn": {
"type": "string"
},
"ldap_user_dn": {
"type": "string"
},
"ldap_user_dn_password": {
"type": "string"
},
"ldap_url": {
"type": "string"
},
"ssl": {
"type": "string",
"enum": [
"OFF",
"ON",
"START_TLS"
]
},
"linked_service": {
"type": "string",
"enum": [
"LOCAL_ACCOUNT",
"LDAP",
"NIS"
]
},
"ldap_server": {
"type": "string"
},
"ldap_realm": {
"type": "boolean"
},
"bind_path_user": {
"type": "string"
},
"bind_path_group": {
"type": "string"
},
"user_cn": {
"type": "boolean"
},
"cn_realm": {
"type": "string"
},
"ldap_domain": {
"type": "string"
},
"sssd_compat": {
"type": "boolean"
}
},
"additionalProperties": false
}
},
"additionalProperties": false,
"title": "idmap_domain_create",
"default": {}
}
|
Update a domain by id. |
initshutdownscript.create |
---|
Arguments:
{
"type": "object",
"properties": {
"type": {
"type": "string",
"enum": [
"COMMAND",
"SCRIPT"
]
},
"command": {
"type": [
"string",
"null"
]
},
"script_text": {
"type": [
"string",
"null"
]
},
"script": {
"type": [
"string",
"null"
]
},
"when": {
"type": "string",
"enum": [
"PREINIT",
"POSTINIT",
"SHUTDOWN"
]
},
"enabled": {
"type": "boolean"
},
"timeout": {
"type": "integer"
},
"comment": {
"type": "string"
}
},
"additionalProperties": false,
"title": "init_shutdown_script_create",
"default": {}
}
|
Create an initshutdown script task.
There are three choices for 1) PREINIT - This is early in the boot process before all the services / rc scripts have started 2) POSTINIT - This is late in the boot process when most of the services / rc scripts have started 3) SHUTDOWN - This is on shutdown
|
initshutdownscript.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete init/shutdown task of |
initshutdownscript.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
initshutdownscript.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"type": {
"type": "string",
"enum": [
"COMMAND",
"SCRIPT"
]
},
"command": {
"type": [
"string",
"null"
]
},
"script_text": {
"type": [
"string",
"null"
]
},
"script": {
"type": [
"string",
"null"
]
},
"when": {
"type": "string",
"enum": [
"PREINIT",
"POSTINIT",
"SHUTDOWN"
]
},
"enabled": {
"type": "boolean"
},
"timeout": {
"type": "integer"
},
"comment": {
"type": "string"
}
},
"additionalProperties": false,
"title": "init_shutdown_script_create",
"default": {}
}
|
Update initshutdown script task of |
interface.bridge_members_choices |
---|
Arguments:
{
"title": "id",
"default": null,
"type": [
"string",
"null"
]
}
|
Return available interface choices for
|
interface.checkin |
---|
After interfaces changes are committed with checkin timeout this method needs to be called within that timeout limit to prevent reverting the changes. This is to ensure user verifies the changes went as planned and its working. |
interface.checkin_waiting |
---|
Returns wether or not we are waiting user to checkin the applied network changes before they are rolled back. Value is in number of seconds or null. |
interface.choices |
---|
Arguments:
{
"type": "object",
"properties": {
"bridge_members": {
"type": "boolean"
},
"lag_ports": {
"type": "boolean"
},
"vlan_parent": {
"type": "boolean"
},
"exclude": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"exclude_types": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"include": {
"type": "array",
"items": [
{
"type": "null"
}
]
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Choices of available network interfaces.
|
interface.commit |
---|
Arguments:
{
"type": "object",
"properties": {
"rollback": {
"type": "boolean"
},
"checkin_timeout": {
"type": "integer"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Commit/apply pending interfaces changes.
|
interface.create |
---|
Arguments:
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"description": {
"type": [
"string",
"null"
]
},
"type": {
"type": "string",
"enum": [
"BRIDGE",
"LINK_AGGREGATION",
"VLAN"
]
},
"disable_offload_capabilities": {
"type": "boolean"
},
"ipv4_dhcp": {
"type": "boolean"
},
"ipv6_auto": {
"type": "boolean"
},
"aliases": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"failover_critical": {
"type": "boolean"
},
"failover_group": {
"type": [
"integer",
"null"
]
},
"failover_vhid": {
"type": [
"integer",
"null"
]
},
"failover_aliases": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"failover_virtual_aliases": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"bridge_members": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"lag_protocol": {
"type": "string",
"enum": [
"LACP",
"FAILOVER",
"LOADBALANCE",
"ROUNDROBIN",
"NONE"
]
},
"lag_ports": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"vlan_parent_interface": {
"type": "string"
},
"vlan_tag": {
"type": "integer"
},
"vlan_pcp": {
"type": [
"integer",
"null"
]
},
"mtu": {
"type": [
"integer",
"null"
]
},
"options": {
"type": "string"
}
},
"additionalProperties": false,
"title": "interface_create",
"default": {}
}
|
Create virtual interfaces (Link Aggregation, VLAN) For BRIDGE For LINK_AGGREGATION For VLAN |
interface.delete |
---|
Arguments:
{
"title": "id",
"type": "string"
}
|
Delete Interface of |
interface.enable_capabilities_individually |
---|
- |
interface.has_pending_changes |
---|
Returns whether there are pending interfaces changes to be applied or not. |
interface.ip_in_use |
---|
Arguments:
{
"type": "object",
"properties": {
"ipv4": {
"type": "boolean"
},
"ipv6": {
"type": "boolean"
},
"ipv6_link_local": {
"type": "boolean"
},
"loopback": {
"type": "boolean"
},
"any": {
"type": "boolean"
},
"static": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "ips",
"default": {}
}
|
Get all IPv4 / Ipv6 from all valid interfaces, excluding tap and epair.
Returns a list of dicts - eg - [ { "type": "INET6", "address": "fe80::5054:ff:fe16:4aac", "netmask": 64 }, { "type": "INET", "address": "192.168.122.148", "netmask": 24, "broadcast": "192.168.122.255" }, ] |
interface.lag_ports_choices |
---|
Arguments:
{
"title": "id",
"default": null,
"type": [
"string",
"null"
]
}
|
Return available interface choices for
|
interface.lag_setup |
---|
- |
interface.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Query Interfaces with |
interface.rollback |
---|
Rollback pending interfaces changes. |
interface.update |
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"description": {
"type": [
"string",
"null"
]
},
"disable_offload_capabilities": {
"type": "boolean"
},
"ipv4_dhcp": {
"type": "boolean"
},
"ipv6_auto": {
"type": "boolean"
},
"aliases": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"failover_critical": {
"type": "boolean"
},
"failover_group": {
"type": [
"integer",
"null"
]
},
"failover_vhid": {
"type": [
"integer",
"null"
]
},
"failover_aliases": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"failover_virtual_aliases": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"bridge_members": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"lag_protocol": {
"type": "string",
"enum": [
"LACP",
"FAILOVER",
"LOADBALANCE",
"ROUNDROBIN",
"NONE"
]
},
"lag_ports": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"vlan_parent_interface": {
"type": "string"
},
"vlan_tag": {
"type": "integer"
},
"vlan_pcp": {
"type": [
"integer",
"null"
]
},
"mtu": {
"type": [
"integer",
"null"
]
},
"options": {
"type": "string"
}
},
"additionalProperties": false,
"title": "interface_create",
"default": {}
}
|
Update Interface of |
interface.vlan_parent_interface_choices |
---|
Return available interface choices for |
interface.vlan_setup |
---|
- |
interface.websocket_interface |
---|
Returns the interface this websocket is connected to. |
interface.websocket_local_ip |
---|
Returns the ip this websocket is connected to. |
ipmi.channels |
---|
Return a list with the IPMI channels available. |
ipmi.identify |
---|
Arguments:
{
"type": "object",
"properties": {
"seconds": {
"type": "integer"
},
"force": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Turn on IPMI chassis identify light. To turn off specify 0 as |
ipmi.is_loaded |
---|
Returns a boolean true value indicating if ipmi device is loaded. |
ipmi.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Query all IPMI Channels with |
ipmi.update |
---|
Arguments:
{
"type": "integer",
"title": "channel"
}
{
"type": "object",
"properties": {
"ipaddress": {
"type": "string"
},
"netmask": {
"type": "string"
},
"gateway": {
"type": "string"
},
"password": {
"type": "string"
},
"dhcp": {
"type": "boolean"
},
"vlan": {
"type": [
"integer",
"null"
]
}
},
"additionalProperties": false,
"title": "ipmi",
"default": {}
}
|
Update
|
iscsi.auth.create |
---|
Arguments:
{
"type": "object",
"properties": {
"tag": {
"type": "integer"
},
"user": {
"type": "string"
},
"secret": {
"type": "string"
},
"peeruser": {
"type": "string"
},
"peersecret": {
"type": "string"
}
},
"additionalProperties": false,
"title": "iscsi_auth_create",
"default": {}
}
|
Create an iSCSI Authorized Access.
|
iscsi.auth.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete iSCSI Authorized Access of |
iscsi.auth.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
iscsi.auth.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"tag": {
"type": "integer"
},
"user": {
"type": "string"
},
"secret": {
"type": "string"
},
"peeruser": {
"type": "string"
},
"peersecret": {
"type": "string"
}
},
"additionalProperties": false,
"title": "iscsi_auth_create",
"default": {}
}
|
Update iSCSI Authorized Access of |
iscsi.extent.create |
---|
Arguments:
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"type": {
"type": "string",
"enum": [
"DISK",
"FILE"
]
},
"disk": {
"type": [
"string",
"null"
]
},
"serial": {
"type": [
"string",
"null"
]
},
"path": {
"type": [
"string",
"null"
]
},
"filesize": {
"type": "integer"
},
"blocksize": {
"type": "integer"
},
"pblocksize": {
"type": "boolean"
},
"avail_threshold": {
"type": [
"integer",
"null"
]
},
"comment": {
"type": "string"
},
"insecure_tpc": {
"type": "boolean"
},
"xen": {
"type": "boolean"
},
"rpm": {
"type": "string",
"enum": [
"UNKNOWN",
"SSD",
"5400",
"7200",
"10000",
"15000"
]
},
"ro": {
"type": "boolean"
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "iscsi_extent_create",
"default": {}
}
|
Create an iSCSI Extent. When With
|
iscsi.extent.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "boolean",
"title": "remove",
"default": false
}
{
"type": "boolean",
"title": "force",
"default": false
}
|
Delete iSCSI Extent of If |
iscsi.extent.disk_choices |
---|
Arguments:
{
"type": "array",
"title": "exclude",
"default": [],
"items": [
{
"type": "null"
}
]
}
|
Exclude will exclude the path from being in the used_zvols list, allowing the user to keep the same item on update |
iscsi.extent.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
iscsi.extent.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"type": {
"type": "string",
"enum": [
"DISK",
"FILE"
]
},
"disk": {
"type": [
"string",
"null"
]
},
"serial": {
"type": [
"string",
"null"
]
},
"path": {
"type": [
"string",
"null"
]
},
"filesize": {
"type": "integer"
},
"blocksize": {
"type": "integer"
},
"pblocksize": {
"type": "boolean"
},
"avail_threshold": {
"type": [
"integer",
"null"
]
},
"comment": {
"type": "string"
},
"insecure_tpc": {
"type": "boolean"
},
"xen": {
"type": "boolean"
},
"rpm": {
"type": "string",
"enum": [
"UNKNOWN",
"SSD",
"5400",
"7200",
"10000",
"15000"
]
},
"ro": {
"type": "boolean"
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "iscsi_extent_create",
"default": {}
}
|
Update iSCSI Extent of |
iscsi.global.alua_enabled |
---|
Returns whether iSCSI ALUA is enabled or not. |
iscsi.global.config |
---|
- |
iscsi.global.sessions |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Get a list of currently running iSCSI sessions. This includes initiator and target names and the unique connection IDs. |
iscsi.global.update |
---|
Arguments:
{
"type": "object",
"properties": {
"basename": {
"type": "string"
},
"isns_servers": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"pool_avail_threshold": {
"type": [
"integer",
"null"
]
},
"alua": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "iscsiglobal_update",
"default": {}
}
|
|
iscsi.initiator.create |
---|
Arguments:
{
"type": "object",
"properties": {
"initiators": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"auth_network": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"comment": {
"type": "string"
}
},
"additionalProperties": false,
"title": "iscsi_initiator_create",
"default": {}
}
|
Create an iSCSI Initiator.
|
iscsi.initiator.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete iSCSI initiator of |
iscsi.initiator.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
iscsi.initiator.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"initiators": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"auth_network": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"comment": {
"type": "string"
}
},
"additionalProperties": false,
"title": "iscsi_initiator_create",
"default": {}
}
|
Update iSCSI initiator of |
iscsi.portal.create |
---|
Arguments:
{
"type": "object",
"properties": {
"comment": {
"type": "string"
},
"discovery_authmethod": {
"type": "string",
"enum": [
"NONE",
"CHAP",
"CHAP_MUTUAL"
]
},
"discovery_authgroup": {
"type": [
"integer",
"null"
]
},
"listen": {
"type": "array",
"items": [
{
"type": "object"
}
]
}
},
"additionalProperties": false,
"title": "iscsiportal_create",
"default": {}
}
|
Create a new iSCSI Portal.
|
iscsi.portal.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete iSCSI Portal |
iscsi.portal.listen_ip_choices |
---|
Returns possible choices for |
iscsi.portal.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
iscsi.portal.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"comment": {
"type": "string"
},
"discovery_authmethod": {
"type": "string",
"enum": [
"NONE",
"CHAP",
"CHAP_MUTUAL"
]
},
"discovery_authgroup": {
"type": [
"integer",
"null"
]
},
"listen": {
"type": "array",
"items": [
{
"type": "object"
}
]
}
},
"additionalProperties": false,
"title": "iscsiportal_create",
"default": {}
}
|
Update iSCSI Portal |
iscsi.target.create |
---|
Arguments:
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"alias": {
"type": [
"string",
"null"
]
},
"mode": {
"type": "string",
"enum": [
"ISCSI",
"FC",
"BOTH"
]
},
"groups": {
"type": "array",
"items": [
{
"type": "object"
}
]
}
},
"additionalProperties": false,
"title": "iscsi_target_create",
"default": {}
}
|
Create an iSCSI Target.
|
iscsi.target.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "boolean",
"title": "force",
"default": false
}
|
Delete iSCSI Target of Deleting an iSCSI Target makes sure we delete all Associated Targets which use |
iscsi.target.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
iscsi.target.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"alias": {
"type": [
"string",
"null"
]
},
"mode": {
"type": "string",
"enum": [
"ISCSI",
"FC",
"BOTH"
]
},
"groups": {
"type": "array",
"items": [
{
"type": "object"
}
]
}
},
"additionalProperties": false,
"title": "iscsi_target_create",
"default": {}
}
|
Update iSCSI Target of |
iscsi.targetextent.create |
---|
Arguments:
{
"type": "object",
"properties": {
"target": {
"type": "integer"
},
"lunid": {
"type": [
"integer",
"null"
]
},
"extent": {
"type": "integer"
}
},
"additionalProperties": false,
"title": "iscsi_targetextent_create",
"default": {}
}
|
Create an Associated Target.
|
iscsi.targetextent.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "boolean",
"title": "force",
"default": false
}
|
Delete Associated Target of |
iscsi.targetextent.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
iscsi.targetextent.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"target": {
"type": "integer"
},
"lunid": {
"type": "integer"
},
"extent": {
"type": "integer"
}
},
"additionalProperties": false,
"title": "iscsi_targetextent_create",
"default": {}
}
|
Update Associated Target of |
jail.activate |
---|
Arguments:
{
"title": "pool",
"type": "string"
}
|
Activates a pool for iocage usage, and deactivates the rest. |
jail.clean |
---|
Arguments:
{
"title": "ds_type",
"type": "string",
"enum": [
"ALL",
"JAIL",
"TEMPLATE",
"RELEASE"
]
}
|
Cleans all iocage datasets of ds_type |
jail.clone
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"title": "source_jail",
"type": "string"
}
{
"type": "object",
"properties": {
"uuid": {
"type": "string"
},
"pkglist": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"thickjail": {
"type": "boolean"
},
"props": {
"type": "array",
"items": [
{
"type": "null"
}
]
}
},
"additionalProperties": false,
"title": "clone_jail",
"default": {}
}
|
- |
jail.create
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"release": {
"type": "string"
},
"template": {
"type": "string"
},
"pkglist": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"uuid": {
"type": "string"
},
"basejail": {
"type": "boolean"
},
"empty": {
"type": "boolean"
},
"short": {
"type": "boolean"
},
"props": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"https": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Creates a jail. |
jail.default_configuration |
---|
Retrieve default configuration for iocage jails. |
jail.delete |
---|
Arguments:
{
"title": "jail",
"type": "string"
}
{
"type": "object",
"properties": {
"force": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Takes a jail and destroys it. |
jail.exec
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"title": "jail",
"type": "string"
}
{
"type": "array",
"title": "command",
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"host_user": {
"type": "string"
},
"jail_user": {
"type": "string"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Issues a command inside a jail. |
jail.export
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"jail": {
"type": "string"
},
"compression_algorithm": {
"type": "string",
"enum": [
"ZIP",
"LZMA"
]
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Export jail to compressed file. |
jail.fetch
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"release": {
"type": "string"
},
"server": {
"type": "string"
},
"user": {
"type": "string"
},
"password": {
"type": "string"
},
"name": {
"type": [
"string",
"null"
]
},
"jail_name": {
"type": "string"
},
"accept": {
"type": "boolean"
},
"https": {
"type": "boolean"
},
"props": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"files": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"branch": {
"type": [
"string",
"null"
]
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Fetches a release or plugin. |
jail.fstab |
---|
Arguments:
{
"title": "jail",
"type": "string"
}
{
"type": "object",
"properties": {
"action": {
"type": "string",
"enum": [
"ADD",
"REMOVE",
"REPLACE",
"LIST"
]
},
"source": {
"type": "string"
},
"destination": {
"type": "string"
},
"fstype": {
"type": "string"
},
"fsoptions": {
"type": "string"
},
"dump": {
"type": "string"
},
"pass": {
"type": "string"
},
"index": {
"type": "integer"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Manipulate a jails fstab |
jail.get_activated_pool |
---|
Returns the activated pool if there is one, or None |
jail.import_image
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"jail": {
"type": "string"
},
"path": {
"type": [
"string",
"null"
]
},
"compression_algorithm": {
"type": [
"string",
"null"
],
"enum": [
"ZIP",
"LZMA",
null
]
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Import jail from compressed file.
|
jail.interface_choices |
---|
Returns a dictionary of interface choices which can be used with creating/updating jails. |
jail.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Query all jails with |
jail.rc_action |
---|
Arguments:
{
"title": "action",
"type": "string",
"enum": [
"START",
"STOP",
"RESTART"
]
}
|
Does specified action on rc enabled (boot=on) jails |
jail.releases_choices |
---|
Arguments:
{
"type": "boolean",
"title": "remote",
"default": false
}
|
List installed or available releases which can be downloaded. |
jail.restart
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"title": "jail",
"type": "string"
}
|
Takes a jail and restarts it. |
jail.start
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"title": "jail",
"type": "string"
}
|
Takes a jail and starts it. |
jail.stop
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"title": "jail",
"type": "string"
}
{
"type": "boolean",
"title": "force",
"default": false
}
|
Takes a jail and stops it. |
jail.update |
---|
Arguments:
{
"title": "jail",
"type": "string"
}
{
"type": "object",
"properties": {
"plugin": {
"type": "boolean"
}
},
"additionalProperties": true,
"title": "jail_update",
"default": {}
}
|
Sets a jail property. |
jail.update_defaults |
---|
Arguments:
{
"type": "object",
"properties": {},
"additionalProperties": true,
"title": "props",
"default": {}
}
|
Update default properties for iocage which will remain true for all jails moving on i.e nat_backend |
jail.update_to_latest_patch
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"title": "jail",
"type": "string"
}
{
"type": "boolean",
"title": "update_pkgs",
"default": false
}
|
Updates specified jail to latest patch level. |
jail.vnet_default_interface_choices |
---|
Returns a dictionary of interface choices which can be used with |
kerberos.config |
---|
- |
kerberos.update |
---|
Arguments:
{
"type": "object",
"properties": {
"appdefaults_aux": {
"type": "string"
},
"libdefaults_aux": {
"type": "string"
}
},
"additionalProperties": false,
"title": "kerberos_settings_update",
"default": {}
}
|
|
kerberos.keytab.create |
---|
Arguments:
{
"type": "object",
"properties": {
"file": {
"type": "string"
},
"name": {
"type": "string"
}
},
"additionalProperties": false,
"title": "kerberos_keytab_create",
"default": {}
}
|
Create a kerberos keytab. Uploaded keytab files will be merged with the system keytab under /etc/krb5.keytab.
|
kerberos.keytab.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete kerberos keytab by id, and force regeneration of system keytab. |
kerberos.keytab.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
kerberos.keytab.system_keytab_list |
---|
Returns content of system keytab (/etc/krb5.keytab). |
kerberos.keytab.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"file": {
"type": "string"
},
"name": {
"type": "string"
}
},
"additionalProperties": false,
"title": "kerberos_keytab_update",
"default": {}
}
|
Update kerberos keytab by id. |
kerberos.keytab.upload_keytab |
---|
Arguments:
{
"type": "object",
"properties": {
"name": {
"type": "string"
}
},
"additionalProperties": false,
"title": "keytab_data",
"default": {}
}
|
Upload a keytab file. This method expects the keytab file to be uploaded using the /_upload/ endpoint. |
kerberos.realm.create |
---|
Arguments:
{
"type": "object",
"properties": {
"realm": {
"type": "string"
},
"kdc": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"admin_server": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"kpasswd_server": {
"type": "array",
"items": [
{
"type": "null"
}
]
}
},
"additionalProperties": false,
"title": "kerberos_realm_create",
"default": {}
}
|
Create a new kerberos realm. This will be automatically populated during the domain join process in an Active Directory environment. Kerberos realm names are case-sensitive, but convention is to only use upper-case. Entries for kdc, admin_server, and kpasswd_server are not required. If they are unpopulated, then kerberos will use DNS srv records to discover the correct servers. The option to hard-code them is provided due to AD site discovery. Kerberos has no concept of Active Directory sites. This means that middleware performs the site discovery and sets the kerberos configuration based on the AD site. |
kerberos.realm.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete a kerberos realm by ID. |
kerberos.realm.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
kerberos.realm.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"realm": {
"type": "string"
},
"kdc": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"admin_server": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"kpasswd_server": {
"type": "array",
"items": [
{
"type": "null"
}
]
}
},
"additionalProperties": false,
"title": "kerberos_realm_create",
"default": {}
}
|
Update a kerberos realm by id. This will be automatically populated during the domain join process in an Active Directory environment. Kerberos realm names are case-sensitive, but convention is to only use upper-case. |
keychaincredential.create |
---|
Arguments:
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"type": {
"type": "string"
},
"attributes": {
"type": "object",
"properties": {},
"additionalProperties": true
}
},
"additionalProperties": false,
"title": "keychain_credential_create",
"default": {}
}
|
Create a Keychain Credential Create a Keychain Credential of any type.
Every Keychain Credential has a
|
|
keychaincredential.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"cascade": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Delete Keychain Credential with specific |
|
keychaincredential.generate_ssh_key_pair |
---|
Generate a public/private key pair Generate a public/private key pair (useful for |
|
keychaincredential.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
keychaincredential.remote_ssh_host_key_scan |
---|
Arguments:
{
"type": "object",
"properties": {
"host": {
"type": "string"
},
"port": {
"type": "string"
},
"connect_timeout": {
"type": "integer"
}
},
"additionalProperties": false,
"title": "keychain_remote_ssh_host_key_scan",
"default": {}
}
|
Discover a remote host key Discover a remote host key (useful for |
|
keychaincredential.remote_ssh_semiautomatic_setup |
---|
Arguments:
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"url": {
"type": "string"
},
"token": {
"type": "string"
},
"password": {
"type": "string"
},
"username": {
"type": "string"
},
"private_key": {
"type": "integer"
},
"cipher": {
"type": "string",
"enum": [
"STANDARD",
"FAST",
"DISABLED"
]
},
"connect_timeout": {
"type": "integer"
}
},
"additionalProperties": false,
"title": "keychain_remote_ssh_semiautomatic_setup",
"default": {}
}
|
Perform semi-automatic SSH connection setup with other FreeNAS machine Perform semi-automatic SSH connection setup with other FreeNAS machine. It creates a |
|
keychaincredential.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"attributes": {
"type": "object",
"properties": {},
"additionalProperties": true
}
},
"additionalProperties": false,
"title": "keychain_credential_create",
"default": {}
}
|
Update a Keychain Credential with specific Please note that you can't change Also you must specify full See the documentation for |
|
keychaincredential.used_by |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Returns list of objects that use this credential. |
kmip.clear_sync_pending_keys |
---|
Clear all keys which are pending to be synced between KMIP server and TN database. For ZFS/SED keys, we remove the UID from local database with which we are able to retrieve ZFS/SED keys. It should be used with caution. |
kmip.config |
---|
- |
kmip.kmip_sync_pending |
---|
Returns true or false based on if there are keys which are to be synced from local database to remote KMIP server or vice versa. |
kmip.sync_keys |
---|
Sync ZFS/SED keys between KMIP Server and TN database. |
kmip.update
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"enabled": {
"type": "boolean"
},
"force_clear": {
"type": "boolean"
},
"manage_sed_disks": {
"type": "boolean"
},
"manage_zfs_keys": {
"type": "boolean"
},
"change_server": {
"type": "boolean"
},
"validate": {
"type": "boolean"
},
"certificate": {
"type": [
"integer",
"null"
]
},
"certificate_authority": {
"type": [
"integer",
"null"
]
},
"port": {
"type": "integer"
},
"server": {
"type": "string"
}
},
"additionalProperties": false,
"title": "kmip_update",
"default": {}
}
|
Update KMIP Server Configuration. System currently authenticates connection with remote KMIP Server with a TLS handshake.
|
ldap.config |
---|
- |
ldap.get_state |
---|
Wrapper function for 'directoryservices.get_state'. Returns only the state of the LDAP service. |
ldap.schema_choices |
---|
Returns list of available LDAP schema choices. |
ldap.ssl_choices |
---|
Returns list of SSL choices. |
ldap.update |
---|
Arguments:
{
"type": "object",
"properties": {
"hostname": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"basedn": {
"type": "string"
},
"binddn": {
"type": "string"
},
"bindpw": {
"type": "string"
},
"anonbind": {
"type": "boolean"
},
"ssl": {
"type": "string",
"enum": [
"OFF",
"ON",
"START_TLS"
]
},
"certificate": {
"type": [
"integer",
"null"
]
},
"validate_certificates": {
"type": "boolean"
},
"disable_freenas_cache": {
"type": "boolean"
},
"timeout": {
"type": "integer"
},
"dns_timeout": {
"type": "integer"
},
"kerberos_realm": {
"type": [
"integer",
"null"
]
},
"kerberos_principal": {
"type": "string"
},
"has_samba_schema": {
"type": "boolean"
},
"auxiliary_parameters": {
"type": "string"
},
"schema": {
"type": "string",
"enum": [
"RFC2307",
"RFC2307BIS"
]
},
"enable": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "ldap_update",
"default": {}
}
|
|
lldp.config |
---|
- |
lldp.country_choices |
---|
Returns country choices for LLDP. |
lldp.update |
---|
Arguments:
{
"type": "object",
"properties": {
"intdesc": {
"type": "boolean"
},
"country": {
"type": "string"
},
"location": {
"type": "string"
}
},
"additionalProperties": false,
"title": "lldp_update",
"default": {}
}
|
Update LLDP Service Configuration.
|
mail.config |
---|
- |
mail.send |
---|
Arguments:
{
"type": "object",
"properties": {
"subject": {
"type": "string"
},
"text": {
"type": "string"
},
"html": {
"type": [
"string",
"null"
]
},
"to": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"cc": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"interval": {
"type": [
"integer",
"null"
]
},
"channel": {
"type": [
"string",
"null"
]
},
"timeout": {
"type": "integer"
},
"attachments": {
"type": "boolean"
},
"queue": {
"type": "boolean"
},
"extra_headers": {
"type": "object",
"properties": {},
"additionalProperties": true
}
},
"additionalProperties": false,
"title": "mail_message",
"default": {}
}
{
"type": "object",
"properties": {
"fromemail": {
"type": "string"
},
"fromname": {
"type": "string"
},
"outgoingserver": {
"type": "string"
},
"port": {
"type": "integer"
},
"security": {
"type": "string",
"enum": [
"PLAIN",
"SSL",
"TLS"
]
},
"smtp": {
"type": "boolean"
},
"user": {
"type": "string"
},
"pass": {
"type": "string"
},
"oauth": {
"type": "object",
"properties": {
"client_id": {
"type": "string"
},
"client_secret": {
"type": "string"
},
"refresh_token": {
"type": "string"
}
},
"additionalProperties": false
}
},
"additionalProperties": false,
"title": "mail_update",
"default": {}
}
|
Sends mail using configured mail settings.
If [ { "headers": [ { "name": "Content-Transfer-Encoding", "value": "base64" }, { "name": "Content-Type", "value": "application/octet-stream", "params": { "name": "test.txt" } } ], "content": "dGVzdAo=" } ] |
mail.update |
---|
Arguments:
{
"type": "object",
"properties": {
"fromemail": {
"type": "string"
},
"fromname": {
"type": "string"
},
"outgoingserver": {
"type": "string"
},
"port": {
"type": "integer"
},
"security": {
"type": "string",
"enum": [
"PLAIN",
"SSL",
"TLS"
]
},
"smtp": {
"type": "boolean"
},
"user": {
"type": "string"
},
"pass": {
"type": "string"
},
"oauth": {
"type": "object",
"properties": {
"client_id": {
"type": "string"
},
"client_secret": {
"type": "string"
},
"refresh_token": {
"type": "string"
}
},
"additionalProperties": false
}
},
"additionalProperties": false,
"title": "mail_update",
"default": {}
}
|
Update Mail Service Configuration.
|
multipath.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Get multipaths and their consumers. |
Get all multipaths
|
network.configuration.config |
---|
- |
network.configuration.update |
---|
Arguments:
{
"type": "object",
"properties": {
"hostname": {
"type": "string"
},
"hostname_b": {
"type": "string"
},
"hostname_virtual": {
"type": "string"
},
"domain": {
"type": "string"
},
"domains": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"service_announcement": {
"type": "object",
"properties": {
"netbios": {
"type": "boolean"
},
"mdns": {
"type": "boolean"
},
"wsd": {
"type": "boolean"
}
},
"additionalProperties": false
},
"ipv4gateway": {
"type": "string"
},
"ipv6gateway": {
"type": "string"
},
"nameserver1": {
"type": "string"
},
"nameserver2": {
"type": "string"
},
"nameserver3": {
"type": "string"
},
"httpproxy": {
"type": "string"
},
"netwait_enabled": {
"type": "boolean"
},
"netwait_ip": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"hosts": {
"type": "string"
}
},
"additionalProperties": false,
"title": "global_configuration_update",
"default": {}
}
|
Update Network Configuration Service configuration.
|
network.general.summary |
---|
Retrieve general information for current Network. Returns a dictionary. For example: |
|
nfs.add_principal |
---|
Arguments:
{
"type": "object",
"properties": {
"username": {
"type": "string"
},
"password": {
"type": "string"
}
},
"additionalProperties": false,
"title": "add_nfs_principal_creds",
"default": {}
}
|
Use user-provided admin credentials to kinit, add NFS SPN entries to the remote kerberos server, and then append the new entries to our system keytab. Currently this is only supported in AD environments. |
nfs.bindip_choices |
---|
Returns ip choices for NFS service to use |
nfs.config |
---|
- |
nfs.update |
---|
Arguments:
{
"type": "object",
"properties": {
"servers": {
"type": "integer"
},
"udp": {
"type": "boolean"
},
"allow_nonroot": {
"type": "boolean"
},
"v4": {
"type": "boolean"
},
"v4_v3owner": {
"type": "boolean"
},
"v4_krb": {
"type": "boolean"
},
"v4_domain": {
"type": "string"
},
"bindip": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"mountd_port": {
"type": [
"integer",
"null"
]
},
"rpcstatd_port": {
"type": [
"integer",
"null"
]
},
"rpclockd_port": {
"type": [
"integer",
"null"
]
},
"userd_manage_gids": {
"type": "boolean"
},
"mountd_log": {
"type": "boolean"
},
"statd_lockd_log": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "nfs_update",
"default": {}
}
|
Update NFS Service Configuration.
When
|
Update NFS Service Configuration to listen on 192.168.0.10 and use NFSv4
|
nis.config |
---|
- |
nis.get_state |
---|
Wrapper function for 'directoryservices.get_state'. Returns only the state of the NIS service. |
nis.update |
---|
Arguments:
{
"type": "object",
"properties": {
"domain": {
"type": "string"
},
"servers": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"secure_mode": {
"type": "boolean"
},
"manycast": {
"type": "boolean"
},
"enable": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "nis_update",
"default": {}
}
|
Update NIS Service Configuration.
|
openvpn.client.authentication_algorithm_choices |
---|
Returns a dictionary of valid authentication algorithms which can be used with OpenVPN server. |
openvpn.client.cipher_choices |
---|
Returns a dictionary of valid ciphers which can be used with OpenVPN server. |
openvpn.client.config |
---|
- |
openvpn.client.update |
---|
Arguments:
{
"type": "object",
"properties": {
"nobind": {
"type": "boolean"
},
"tls_crypt_auth_enabled": {
"type": "boolean"
},
"client_certificate": {
"type": [
"integer",
"null"
]
},
"root_ca": {
"type": [
"integer",
"null"
]
},
"port": {
"type": "integer"
},
"additional_parameters": {
"type": "string"
},
"authentication_algorithm": {
"type": [
"string",
"null"
]
},
"cipher": {
"type": [
"string",
"null"
]
},
"compression": {
"type": [
"string",
"null"
],
"enum": [
"LZO",
"LZ4"
]
},
"device_type": {
"type": "string",
"enum": [
"TUN",
"TAP"
]
},
"protocol": {
"type": "string",
"enum": [
"UDP",
"UDP4",
"UDP6",
"TCP",
"TCP4",
"TCP6"
]
},
"remote": {
"type": "string"
},
"tls_crypt_auth": {
"type": [
"string",
"null"
]
}
},
"additionalProperties": false,
"title": "openvpn_client_update",
"default": {}
}
|
Update OpenVPN Client configuration.
|
openvpn.server.authentication_algorithm_choices |
---|
Returns a dictionary of valid authentication algorithms which can be used with OpenVPN server. |
openvpn.server.cipher_choices |
---|
Returns a dictionary of valid ciphers which can be used with OpenVPN server. |
openvpn.server.client_configuration_generation |
---|
Arguments:
{
"type": "integer",
"title": "client_certificate_id"
}
{
"title": "server_address",
"type": [
"string",
"null"
]
}
|
Returns a configuration for OpenVPN client which can be used with any client to connect to FN/TN OpenVPN server.
|
openvpn.server.config |
---|
- |
openvpn.server.renew_static_key |
---|
Reset OpenVPN server's TLS static key which will be used to encrypt/authenticate control channel packets. |
openvpn.server.update |
---|
Arguments:
{
"type": "object",
"properties": {
"tls_crypt_auth_enabled": {
"type": "boolean"
},
"netmask": {
"type": "integer"
},
"server_certificate": {
"type": [
"integer",
"null"
]
},
"port": {
"type": "integer"
},
"root_ca": {
"type": [
"integer",
"null"
]
},
"server": {
"type": "string"
},
"additional_parameters": {
"type": "string"
},
"authentication_algorithm": {
"type": [
"string",
"null"
]
},
"cipher": {
"type": [
"string",
"null"
]
},
"compression": {
"type": [
"string",
"null"
],
"enum": [
"LZO",
"LZ4"
]
},
"device_type": {
"type": "string",
"enum": [
"TUN",
"TAP"
]
},
"protocol": {
"type": "string",
"enum": [
"UDP",
"UDP4",
"UDP6",
"TCP",
"TCP4",
"TCP6"
]
},
"tls_crypt_auth": {
"type": [
"string",
"null"
]
},
"topology": {
"type": [
"string",
"null"
],
"enum": [
"NET30",
"P2P",
"SUBNET"
]
}
},
"additionalProperties": false,
"title": "openvpn_server_update",
"default": {}
}
|
Update OpenVPN Server configuration. When |
plugin.available
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"cache": {
"type": "boolean"
},
"plugin_repository": {
"type": "string"
},
"branch": {
"type": "string"
}
},
"additionalProperties": false,
"title": "available_plugin_options",
"default": {}
}
|
List available plugins which can be fetched for |
plugin.branches_choices |
---|
Arguments:
{
"title": "repository",
"default": null,
"type": [
"string",
"null"
]
}
|
- |
plugin.create
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"plugin_name": {
"type": "string"
},
"jail_name": {
"type": "string"
},
"props": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"branch": {
"type": [
"string",
"null"
]
},
"plugin_repository": {
"type": "string"
}
},
"additionalProperties": false,
"title": "plugin_create",
"default": {}
}
|
Create a Plugin.
|
plugin.defaults |
---|
Arguments:
{
"type": "object",
"properties": {
"refresh": {
"type": "boolean"
},
"plugin": {
"type": "string"
},
"branch": {
"type": [
"string",
"null"
]
},
"plugin_repository": {
"type": "string"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Retrieve default properties specified for When |
plugin.delete |
---|
Arguments:
{
"title": "id",
"type": "string"
}
|
Delete plugin |
plugin.official_repositories |
---|
List officially supported plugin repositories. |
plugin.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Query installed plugins with |
plugin.retrieve_versions_for_repos |
---|
- |
plugin.update |
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "object",
"properties": {
"plugin": {
"type": "boolean"
}
},
"additionalProperties": true,
"title": "jail_update",
"default": {}
}
|
Update plugin |
plugin.update_plugin
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"title": "jail",
"type": "string"
}
{
"type": "boolean",
"title": "update_jail",
"default": true
}
|
Updates specified plugin to latest available plugin version and optionally update plugin to latest patch level. |
pool.attach
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "integer",
"title": "oid"
}
{
"type": "object",
"properties": {
"target_vdev": {
"type": "string"
},
"new_disk": {
"type": "string"
},
"passphrase": {
"type": "string"
},
"allow_duplicate_serials": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "pool_attach",
"default": {}
}
|
For TrueNAS Core/Enterprise platform, if the
|
pool.attachments |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Return a list of services dependent of this pool. Responsible for telling the user whether there is a related share, asking for confirmation. |
pool.create
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"encryption": {
"type": "boolean"
},
"deduplication": {
"type": [
"string",
"null"
],
"enum": [
null,
"ON",
"VERIFY",
"OFF"
]
},
"checksum": {
"type": [
"string",
"null"
],
"enum": [
null,
"ON",
"OFF",
"FLETCHER2",
"FLETCHER4",
"SHA256",
"SHA512",
"SKEIN"
]
},
"encryption_options": {
"type": "object",
"properties": {
"generate_key": {
"type": "boolean"
},
"pbkdf2iters": {
"type": "integer"
},
"algorithm": {
"type": "string",
"enum": [
"AES-128-CCM",
"AES-192-CCM",
"AES-256-CCM",
"AES-128-GCM",
"AES-192-GCM",
"AES-256-GCM"
]
},
"passphrase": {
"type": [
"string",
"null"
]
},
"key": {
"type": [
"string",
"null"
]
}
},
"additionalProperties": false
},
"topology": {
"type": "object",
"properties": {
"data": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"special": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"dedup": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"cache": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"log": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"spares": {
"type": "array",
"items": [
{
"type": "string"
}
]
}
},
"additionalProperties": false
},
"allow_duplicate_serials": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "pool_create",
"default": {}
}
|
Create a new ZFS Pool.
It should be noted that keys are stored by the system for automatic locking/unlocking on import/export of encrypted datasets. If that is not desired, dataset should be created with a passphrase as a key. Example of
|
Create a pool named "tank", raidz1 with 3 disks, 1 cache disk, 1 ZIL/log disk and 1 hot spare disk.
|
pool.detach |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"label": {
"type": "string"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Detach a disk from pool of id
|
Detach ZFS device.
|
pool.download_encryption_key |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"title": "filename",
"default": "geli.key",
"type": "string"
}
|
Download encryption key for a given pool |
pool.expand
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"geli": {
"type": "object",
"properties": {
"passphrase": {
"type": "string"
}
},
"additionalProperties": false
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Expand pool to fit all available disk space. |
pool.export
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"cascade": {
"type": "boolean"
},
"restart_services": {
"type": "boolean"
},
"destroy": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Export pool of
|
Export pool of id 1.
|
pool.filesystem_choices |
---|
Arguments:
{
"type": "array",
"title": "types",
"default": [
"FILESYSTEM",
"VOLUME"
],
"items": [
{
"type": "string"
}
]
}
|
Returns all available datasets, except system datasets. |
Get all datasets.
Get only filesystems (exclude volumes).
|
pool.get_disks |
---|
Arguments:
{
"type": [
"integer",
"null"
],
"title": "id",
"default": null
}
|
Get all disks in use by pools.
If |
pool.import_disk
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"title": "device",
"type": "string"
}
{
"title": "fs_type",
"type": "string"
}
{
"type": "object",
"properties": {},
"additionalProperties": true,
"title": "fs_options",
"default": {}
}
{
"title": "dst_path",
"type": "string"
}
|
Import a disk, by copying its content to a pool. |
Import a FAT32 (msdosfs) disk.
|
pool.import_disk_autodetect_fs_type |
---|
Arguments:
{
"title": "device",
"type": "string"
}
|
Autodetect filesystem type for |
|
pool.import_disk_msdosfs_locales |
---|
Get a list of locales for msdosfs type to be used in |
pool.import_find
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Returns a job id which can be used to retrieve a list of pools available for import with the following details as a result of the job: name, guid, status, hostname. |
pool.import_pool |
---|
Arguments:
{
"type": "object",
"properties": {
"guid": {
"type": "string"
},
"name": {
"type": "string"
},
"passphrase": {
"type": "string"
},
"enable_attachments": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "pool_import",
"default": {}
}
|
Import a pool found with If a
If Errors: ENOENT - Pool not found |
Import pool of guid 5571830764813710860.
|
pool.is_upgraded |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Returns whether or not the pool of |
Check if pool of id 1 is upgraded.
|
pool.lock
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"title": "passphrase",
"type": "string"
}
|
Lock encrypted pool |
pool.offline |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"label": {
"type": "string"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Offline a disk from pool of id
|
Offline ZFS device.
|
pool.online |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"label": {
"type": "string"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Online a disk from pool of id
|
Online ZFS device.
|
pool.passphrase |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"passphrase": {
"type": [
"string",
"null"
]
},
"admin_password": {
"type": "string"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Create/Change/Remove passphrase for an encrypted pool. Setting passphrase to null will remove the passphrase.
|
Change passphrase for pool 1.
|
pool.processes |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Returns a list of running processes using this pool. |
pool.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
pool.recoverykey_add |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"admin_password": {
"type": "string"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Add Recovery key for encrypted pool This is to be used with |
pool.recoverykey_rm |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"admin_password": {
"type": "string"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Remove recovery key for encrypted pool |
Remove recovery key for pool 1.
|
pool.rekey |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"admin_password": {
"type": "string"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Rekey encrypted pool |
Rekey pool 1.
|
pool.remove |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"label": {
"type": "string"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Remove a disk from pool of id
Error codes:
|
Remove ZFS device.
|
pool.replace
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"label": {
"type": "string"
},
"disk": {
"type": "string"
},
"force": {
"type": "boolean"
},
"passphrase": {
"type": "string"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Replace a disk on a pool.
|
Replace missing ZFS device with disk {serial}FOO.
|
pool.scrub
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"title": "action",
"type": "string",
"enum": [
"START",
"STOP",
"PAUSE"
]
}
|
Performs a scrub action to pool of
|
Start scrub on pool of id 1.
|
pool.unlock |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"passphrase": {
"type": "string"
},
"recoverykey": {
"type": "boolean"
},
"services_restart": {
"type": "array",
"items": [
{
"type": "null"
}
]
}
},
"additionalProperties": false,
"title": "pool_unlock_options",
"default": {}
}
|
Unlock encrypted pool
If
|
Unlock pool of id 1, restarting "cifs" service.
|
pool.unlock_services_restart_choices |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Get a mapping of services identifiers and labels that can be restart on volume unlock. |
pool.update
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"encryption_options": {
"type": "object",
"properties": {
"generate_key": {
"type": "boolean"
},
"pbkdf2iters": {
"type": "integer"
},
"algorithm": {
"type": "string",
"enum": [
"AES-128-CCM",
"AES-192-CCM",
"AES-256-CCM",
"AES-128-GCM",
"AES-192-GCM",
"AES-256-GCM"
]
},
"passphrase": {
"type": [
"string",
"null"
]
},
"key": {
"type": [
"string",
"null"
]
}
},
"additionalProperties": false
},
"topology": {
"type": "object",
"properties": {
"data": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"special": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"dedup": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"cache": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"log": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"spares": {
"type": "array",
"items": [
{
"type": "string"
}
]
}
},
"additionalProperties": false
},
"allow_duplicate_serials": {
"type": "boolean"
},
"autotrim": {
"type": "string",
"enum": [
"ON",
"OFF"
]
}
},
"additionalProperties": false,
"title": "pool_create",
"default": {}
}
|
Update pool of The |
Add a new set of raidz1 to pool of id 1.
|
pool.upgrade |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Upgrade pool of |
Upgrade pool of id 1.
|
pool.dataset.attachments |
---|
Arguments:
{
"title": "id",
"type": "string"
}
|
Return a list of services dependent of this dataset. Responsible for telling the user whether there is a related share, asking for confirmation. Example return value: [ { "type": "NFS Share", "service": "nfs", "attachments": ["/mnt/tank/work"] } ] |
pool.dataset.change_key |
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "object",
"properties": {
"generate_key": {
"type": "boolean"
},
"key_file": {
"type": "boolean"
},
"pbkdf2iters": {
"type": "integer"
},
"passphrase": {
"type": [
"string",
"null"
]
},
"key": {
"type": [
"string",
"null"
]
}
},
"additionalProperties": false,
"title": "change_key_options",
"default": {}
}
|
Change encryption properties for Changing dataset encryption to use passphrase instead of a key is not allowed if: 1) It has encrypted roots as children which are encrypted with a key 2) If it is a root dataset where the system dataset is located |
pool.dataset.checksum_choices |
---|
Retrieve checksums supported for ZFS dataset. |
pool.dataset.compression_choices |
---|
Retrieve compression algorithm supported by ZFS. |
pool.dataset.create |
---|
Arguments:
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"type": {
"type": "string",
"enum": [
"FILESYSTEM",
"VOLUME"
]
},
"volsize": {
"type": "integer"
},
"volblocksize": {
"type": "string",
"enum": [
"512",
"1K",
"2K",
"4K",
"8K",
"16K",
"32K",
"64K",
"128K"
]
},
"sparse": {
"type": "boolean"
},
"force_size": {
"type": "boolean"
},
"comments": {
"type": "string"
},
"sync": {
"type": "string",
"enum": [
"STANDARD",
"ALWAYS",
"DISABLED"
]
},
"compression": {
"type": "string",
"enum": [
"OFF",
"LZ4",
"GZIP",
"GZIP-1",
"GZIP-9",
"ZSTD",
"ZSTD-FAST",
"ZLE",
"LZJB",
"ZSTD-1",
"ZSTD-2",
"ZSTD-3",
"ZSTD-4",
"ZSTD-5",
"ZSTD-6",
"ZSTD-7",
"ZSTD-8",
"ZSTD-9",
"ZSTD-10",
"ZSTD-11",
"ZSTD-12",
"ZSTD-13",
"ZSTD-14",
"ZSTD-15",
"ZSTD-16",
"ZSTD-17",
"ZSTD-18",
"ZSTD-19",
"ZSTD-FAST-1",
"ZSTD-FAST-2",
"ZSTD-FAST-3",
"ZSTD-FAST-4",
"ZSTD-FAST-5",
"ZSTD-FAST-6",
"ZSTD-FAST-7",
"ZSTD-FAST-8",
"ZSTD-FAST-9",
"ZSTD-FAST-10",
"ZSTD-FAST-20",
"ZSTD-FAST-30",
"ZSTD-FAST-40",
"ZSTD-FAST-50",
"ZSTD-FAST-60",
"ZSTD-FAST-70",
"ZSTD-FAST-80",
"ZSTD-FAST-90",
"ZSTD-FAST-100",
"ZSTD-FAST-500",
"ZSTD-FAST-1000"
]
},
"atime": {
"type": "string",
"enum": [
"ON",
"OFF"
]
},
"exec": {
"type": "string",
"enum": [
"ON",
"OFF"
]
},
"managedby": {
"type": "string"
},
"quota": {
"type": [
"integer",
"null"
]
},
"quota_warning": {
"type": "integer"
},
"quota_critical": {
"type": "integer"
},
"refquota": {
"type": [
"integer",
"null"
]
},
"refquota_warning": {
"type": "integer"
},
"refquota_critical": {
"type": "integer"
},
"reservation": {
"type": "integer"
},
"refreservation": {
"type": "integer"
},
"special_small_block_size": {
"type": "integer"
},
"copies": {
"type": "integer"
},
"snapdir": {
"type": "string",
"enum": [
"VISIBLE",
"HIDDEN"
]
},
"deduplication": {
"type": "string",
"enum": [
"ON",
"VERIFY",
"OFF"
]
},
"checksum": {
"type": "string",
"enum": [
"ON",
"OFF",
"FLETCHER2",
"FLETCHER4",
"SHA256",
"SHA512",
"SKEIN"
]
},
"readonly": {
"type": "string",
"enum": [
"ON",
"OFF"
]
},
"recordsize": {
"type": "string"
},
"casesensitivity": {
"type": "string",
"enum": [
"SENSITIVE",
"INSENSITIVE",
"MIXED"
]
},
"aclmode": {
"type": "string",
"enum": [
"PASSTHROUGH",
"RESTRICTED"
]
},
"acltype": {
"type": "string",
"enum": [
"NOACL",
"NFS4ACL",
"POSIXACL"
]
},
"share_type": {
"type": "string",
"enum": [
"GENERIC",
"SMB"
]
},
"xattr": {
"type": "string",
"enum": [
"ON",
"SA"
]
},
"encryption_options": {
"type": "object",
"properties": {
"generate_key": {
"type": "boolean"
},
"pbkdf2iters": {
"type": "integer"
},
"algorithm": {
"type": "string",
"enum": [
"AES-128-CCM",
"AES-192-CCM",
"AES-256-CCM",
"AES-128-GCM",
"AES-192-GCM",
"AES-256-GCM"
]
},
"passphrase": {
"type": [
"string",
"null"
]
},
"key": {
"type": [
"string",
"null"
]
}
},
"additionalProperties": false
},
"encryption": {
"type": "boolean"
},
"inherit_encryption": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "pool_dataset_create",
"default": {}
}
|
Creates a dataset/zvol.
It should be noted that keys are stored by the system for automatic locking/unlocking on import/export of encrypted datasets. If that is not desired, dataset should be created with a passphrase as a key. |
Create a dataset within tank pool.
|
pool.dataset.delete |
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "object",
"properties": {
"recursive": {
"type": "boolean"
},
"force": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "dataset_delete",
"default": {}
}
|
Delete dataset/zvol
|
Delete "tank/myuser" dataset.
|
pool.dataset.encryption_algorithm_choices |
---|
Retrieve encryption algorithms supported for ZFS dataset encryption. |
pool.dataset.encryption_summary |
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "object",
"properties": {
"key_file": {
"type": "boolean"
},
"datasets": {
"type": "array",
"items": [
{
"type": "object"
}
]
}
},
"additionalProperties": false,
"title": "encryption_root_summary_options",
"default": {}
}
|
Retrieve summary of all encrypted roots under Keys/passphrase can be supplied to check if the keys are valid. It should be noted that there are 2 keys which show if a recursive unlock operation is
done for If a dataset is already unlocked, it will show up as true for "unlock_successful" regardless of what key user provided as the unlock keys in the output are to reflect what a real unlock operation would behave. If user is interested in seeing if a provided key is valid or not, then the key to look out for in the output is "valid_key" which based on what system has in database or if a user provided one, validates the key and sets a boolean value for the dataset. Example output: [ { "name": "vol", "key_format": "PASSPHRASE", "key_present_in_database": false, "valid_key": true, "locked": true, "unlock_error": null, "unlock_successful": true }, { "name": "vol/c1/d1", "key_format": "PASSPHRASE", "key_present_in_database": false, "valid_key": false, "locked": true, "unlock_error": "Provided key is invalid", "unlock_successful": false }, { "name": "vol/c", "key_format": "PASSPHRASE", "key_present_in_database": false, "valid_key": false, "locked": true, "unlock_error": "Key not provided", "unlock_successful": false }, { "name": "vol/c/d2", "key_format": "PASSPHRASE", "key_present_in_database": false, "valid_key": false, "locked": true, "unlock_error": "Child cannot be unlocked when parent "vol/c" is locked and provided key is invalid", "unlock_successful": false } ] |
pool.dataset.export_key |
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "boolean",
"title": "download",
"default": false
}
|
Export own encryption key for dataset Please refer to websocket documentation for downloading the file. |
pool.dataset.export_keys |
---|
Arguments:
{
"title": "id",
"type": "string"
}
|
Export keys for Please refer to websocket documentation for downloading the file. |
pool.dataset.get_quota |
---|
Arguments:
{
"title": "ds",
"type": "string"
}
{
"title": "quota_type",
"type": "string",
"enum": [
"USER",
"GROUP",
"DATASET"
]
}
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Return a list of the specified When quota_type is not DATASET, each quota entry has these fields:
'obj_used
|
pool.dataset.inherit_parent_encryption_properties |
---|
Arguments:
{
"title": "id",
"type": "string"
}
|
Allows inheriting parent's encryption root discarding its current encryption settings. This
can only be done where |
pool.dataset.lock
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "object",
"properties": {
"force_umount": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "lock_options",
"default": {}
}
|
Locks |
pool.dataset.permission
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "object",
"properties": {
"user": {
"type": "string"
},
"group": {
"type": "string"
},
"mode": {
"type": [
"string",
"null"
]
},
"acl": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"options": {
"type": "object",
"properties": {
"stripacl": {
"type": "boolean"
},
"recursive": {
"type": "boolean"
},
"traverse": {
"type": "boolean"
}
},
"additionalProperties": false
}
},
"additionalProperties": false,
"title": "pool_dataset_permission",
"default": {}
}
|
Set permissions for a dataset |
Change permissions of dataset "tank/myuser" to myuser:wheel and 755.
|
pool.dataset.processes |
---|
Arguments:
{
"title": "id",
"type": "string"
}
|
Return a list of processes using this dataset. Example return value: [ { "pid": 2520, "name": "smbd", "service": "cifs" }, { "pid": 97778, "name": "minio", "cmdline": "/usr/local/bin/minio -C /usr/local/etc/minio server --address=0.0.0.0:9000 --quiet /mnt/tank/wk" } ] |
pool.dataset.promote |
---|
Arguments:
{
"title": "id",
"type": "string"
}
|
Promote the cloned dataset |
pool.dataset.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Query Pool Datasets with We provide two ways to retrieve datasets. The first is a flat structure (default), where
all datasets in the system are returned as separate objects which contain all data
there is for their children. This retrieval type is slightly slower because of duplicates in each object.
The second type is hierarchical, where only top level datasets are returned in the list. They contain all the
children in the |
pool.dataset.recommended_zvol_blocksize |
---|
Arguments:
{
"title": "pool",
"type": "string"
}
|
Helper method to get recommended size for a new zvol (dataset of type VOLUME). |
Get blocksize for pool "tank".
|
pool.dataset.recordsize_choices |
---|
- |
pool.dataset.set_quota |
---|
Arguments:
{
"title": "ds",
"type": "string"
}
{
"type": "array",
"title": "quotas",
"default": [
{
"quota_type": "USER",
"id": "0",
"quota_value": 0
}
],
"items": [
{
"type": "object"
}
]
}
|
There are three over-arching types of quotas for ZFS datasets.
1) dataset quotas and refquotas. If a DATASET quota type is specified in
this API call, then the API acts as a wrapper for 2) User and group quotas. These limit the amount of disk space consumed by files that are owned by the specified users or groups. If the respective "object quota" type is specfied, then the quota limits the number of objects that may be owned by the specified user or group. 3) Project quotas. These limit the amount of disk space consumed by files that are owned by the specified project. Project quotas are not yet implemended. This API allows users to set multiple quotas simultaneously by submitting a list of quotas. The list may contain all supported quota types.
|
pool.dataset.unlock |
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "object",
"properties": {
"key_file": {
"type": "boolean"
},
"recursive": {
"type": "boolean"
},
"toggle_attachments": {
"type": "boolean"
},
"datasets": {
"type": "array",
"items": [
{
"type": "object"
}
]
}
},
"additionalProperties": false,
"title": "unlock_options",
"default": {}
}
|
Unlock If For datasets which are encrypted with a passphrase, include the passphrase with
Uploading a json file which contains encrypted dataset keys can be specified with
|
pool.dataset.update |
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "object",
"properties": {
"volsize": {
"type": "integer"
},
"force_size": {
"type": "boolean"
},
"comments": {
"type": "string"
},
"sync": {
"type": "string",
"enum": [
"STANDARD",
"ALWAYS",
"DISABLED",
"INHERIT"
]
},
"compression": {
"type": "string",
"enum": [
"OFF",
"LZ4",
"GZIP",
"GZIP-1",
"GZIP-9",
"ZSTD",
"ZSTD-FAST",
"ZLE",
"LZJB",
"ZSTD-1",
"ZSTD-2",
"ZSTD-3",
"ZSTD-4",
"ZSTD-5",
"ZSTD-6",
"ZSTD-7",
"ZSTD-8",
"ZSTD-9",
"ZSTD-10",
"ZSTD-11",
"ZSTD-12",
"ZSTD-13",
"ZSTD-14",
"ZSTD-15",
"ZSTD-16",
"ZSTD-17",
"ZSTD-18",
"ZSTD-19",
"ZSTD-FAST-1",
"ZSTD-FAST-2",
"ZSTD-FAST-3",
"ZSTD-FAST-4",
"ZSTD-FAST-5",
"ZSTD-FAST-6",
"ZSTD-FAST-7",
"ZSTD-FAST-8",
"ZSTD-FAST-9",
"ZSTD-FAST-10",
"ZSTD-FAST-20",
"ZSTD-FAST-30",
"ZSTD-FAST-40",
"ZSTD-FAST-50",
"ZSTD-FAST-60",
"ZSTD-FAST-70",
"ZSTD-FAST-80",
"ZSTD-FAST-90",
"ZSTD-FAST-100",
"ZSTD-FAST-500",
"ZSTD-FAST-1000",
"INHERIT"
]
},
"atime": {
"type": "string",
"enum": [
"ON",
"OFF",
"INHERIT"
]
},
"exec": {
"type": "string",
"enum": [
"ON",
"OFF",
"INHERIT"
]
},
"managedby": {
"type": "string"
},
"quota": {
"type": [
"integer",
"null"
]
},
"quota_warning": {
"nullable": false,
"anyOf": [
{
"type": "integer"
},
{
"type": "string",
"enum": [
"INHERIT"
]
}
]
},
"quota_critical": {
"nullable": false,
"anyOf": [
{
"type": "integer"
},
{
"type": "string",
"enum": [
"INHERIT"
]
}
]
},
"refquota": {
"type": [
"integer",
"null"
]
},
"refquota_warning": {
"nullable": false,
"anyOf": [
{
"type": "integer"
},
{
"type": "string",
"enum": [
"INHERIT"
]
}
]
},
"refquota_critical": {
"nullable": false,
"anyOf": [
{
"type": "integer"
},
{
"type": "string",
"enum": [
"INHERIT"
]
}
]
},
"reservation": {
"type": "integer"
},
"refreservation": {
"type": "integer"
},
"special_small_block_size": {
"nullable": false,
"anyOf": [
{
"type": "integer"
},
{
"type": "string",
"enum": [
"INHERIT"
]
}
]
},
"copies": {
"type": "integer"
},
"snapdir": {
"type": "string",
"enum": [
"VISIBLE",
"HIDDEN",
"INHERIT"
]
},
"deduplication": {
"type": "string",
"enum": [
"ON",
"VERIFY",
"OFF",
"INHERIT"
]
},
"checksum": {
"type": "string",
"enum": [
"ON",
"OFF",
"FLETCHER2",
"FLETCHER4",
"SHA256",
"SHA512",
"SKEIN",
"INHERIT"
]
},
"readonly": {
"type": "string",
"enum": [
"ON",
"OFF",
"INHERIT"
]
},
"recordsize": {
"type": "string"
},
"aclmode": {
"type": "string",
"enum": [
"PASSTHROUGH",
"RESTRICTED"
]
},
"acltype": {
"type": "string",
"enum": [
"NOACL",
"NFS4ACL",
"POSIXACL"
]
},
"xattr": {
"type": "string",
"enum": [
"ON",
"SA"
]
}
},
"additionalProperties": false,
"title": "pool_dataset_create",
"default": {}
}
|
Updates a dataset/zvol |
Update the
|
pool.dataset.userprop.create |
---|
Arguments:
{
"type": "object",
"properties": {
"id": {
"type": "string"
},
"property": {
"type": "object",
"properties": {
"name": {
"type": "string"
},
"value": {
"type": "string"
}
},
"additionalProperties": false
}
},
"additionalProperties": false,
"title": "dataset_user_prop_create",
"default": {}
}
|
Create a user property for a given |
pool.dataset.userprop.delete |
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "object",
"properties": {
"name": {
"type": "string"
}
},
"additionalProperties": false,
"title": "dataset_user_prop_delete",
"default": {}
}
|
Delete user property |
pool.dataset.userprop.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Query all user properties for ZFS datasets. |
pool.dataset.userprop.update |
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"value": {
"type": "string"
}
},
"additionalProperties": false,
"title": "dataset_user_prop_update",
"default": {}
}
|
Update |
pool.resilver.config |
---|
- |
pool.resilver.update |
---|
Arguments:
{
"type": "object",
"properties": {
"begin": {
"type": "string"
},
"end": {
"type": "string"
},
"enabled": {
"type": "boolean"
},
"weekday": {
"type": "array",
"items": [
{
"type": "integer"
}
]
}
},
"additionalProperties": false,
"title": "pool_resilver",
"default": {}
}
|
Configure Pool Resilver Priority. If
|
Enable pool resilver priority all business days from 7PM to 5AM.
|
pool.scrub.create |
---|
Arguments:
{
"type": "object",
"properties": {
"pool": {
"type": "integer"
},
"threshold": {
"type": "integer"
},
"description": {
"type": "string"
},
"schedule": {
"type": "object",
"properties": {
"minute": {
"type": "string"
},
"hour": {
"type": "string"
},
"dom": {
"type": "string"
},
"month": {
"type": "string"
},
"dow": {
"type": "string"
}
},
"additionalProperties": false
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "pool_scrub_create",
"default": {}
}
|
Create a scrub task for a pool.
|
Create a scrub task for pool of id 1, to run every sunday but with a threshold of 35 days. The check will run at 3AM every sunday.
|
pool.scrub.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete scrub task of |
pool.scrub.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
pool.scrub.run |
---|
Arguments:
{
"title": "name",
"type": "string"
}
{
"type": "integer",
"title": "threshold",
"default": 35
}
|
Initiate a scrub of a pool |
pool.scrub.scrub
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"title": "name",
"type": "string"
}
{
"title": "action",
"default": "START",
"type": "string",
"enum": [
"START",
"STOP",
"PAUSE"
]
}
|
Start/Stop/Pause a scrub on pool |
pool.scrub.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"pool": {
"type": "integer"
},
"threshold": {
"type": "integer"
},
"description": {
"type": "string"
},
"schedule": {
"type": "object",
"properties": {
"minute": {
"type": "string"
},
"hour": {
"type": "string"
},
"dom": {
"type": "string"
},
"month": {
"type": "string"
},
"dow": {
"type": "string"
}
},
"additionalProperties": false
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "pool_scrub_create",
"default": {}
}
|
Update scrub task of |
pool.snapshottask.create |
---|
Arguments:
{
"type": "object",
"properties": {
"dataset": {
"type": "string"
},
"recursive": {
"type": "boolean"
},
"exclude": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"lifetime_value": {
"type": "integer"
},
"lifetime_unit": {
"type": "string",
"enum": [
"HOUR",
"DAY",
"WEEK",
"MONTH",
"YEAR"
]
},
"naming_schema": {
"type": "string"
},
"schedule": {
"type": "object",
"properties": {
"minute": {
"type": "string"
},
"hour": {
"type": "string"
},
"dom": {
"type": "string"
},
"month": {
"type": "string"
},
"dow": {
"type": "string"
},
"begin": {
"type": "string"
},
"end": {
"type": "string"
}
},
"additionalProperties": false
},
"allow_empty": {
"type": "boolean"
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "periodic_snapshot_create",
"default": {}
}
|
Create a Periodic Snapshot Task Create a Periodic Snapshot Task that will take snapshots of specified |
Create a recursive Periodic Snapshot Task for dataset
|
pool.snapshottask.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete a Periodic Snapshot Task with specific |
|
pool.snapshottask.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
pool.snapshottask.run |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Execute a Periodic Snapshot Task of |
pool.snapshottask.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"dataset": {
"type": "string"
},
"recursive": {
"type": "boolean"
},
"exclude": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"lifetime_value": {
"type": "integer"
},
"lifetime_unit": {
"type": "string",
"enum": [
"HOUR",
"DAY",
"WEEK",
"MONTH",
"YEAR"
]
},
"naming_schema": {
"type": "string"
},
"schedule": {
"type": "object",
"properties": {
"minute": {
"type": "string"
},
"hour": {
"type": "string"
},
"dom": {
"type": "string"
},
"month": {
"type": "string"
},
"dow": {
"type": "string"
},
"begin": {
"type": "string"
},
"end": {
"type": "string"
}
},
"additionalProperties": false
},
"allow_empty": {
"type": "boolean"
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "periodic_snapshot_create",
"default": {}
}
|
Update a Periodic Snapshot Task with specific See the documentation for |
|
replication.count_eligible_manual_snapshots |
---|
Arguments:
{
"type": "array",
"title": "datasets",
"items": [
{
"type": "string"
}
]
}
{
"type": "array",
"title": "naming_schema",
"items": [
{
"type": "string"
}
]
}
{
"title": "transport",
"type": "string",
"enum": [
"SSH",
"SSH+NETCAT",
"LOCAL"
]
}
{
"type": [
"integer",
"null"
],
"title": "ssh_credentials",
"default": null
}
|
Count how many existing snapshots of |
|
replication.create |
---|
Arguments:
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"direction": {
"type": "string",
"enum": [
"PUSH",
"PULL"
]
},
"transport": {
"type": "string",
"enum": [
"SSH",
"SSH+NETCAT",
"LOCAL"
]
},
"ssh_credentials": {
"type": [
"integer",
"null"
]
},
"netcat_active_side": {
"type": [
"string",
"null"
],
"enum": [
"LOCAL",
"REMOTE"
]
},
"netcat_active_side_listen_address": {
"type": [
"string",
"null"
]
},
"netcat_active_side_port_min": {
"type": [
"integer",
"null"
]
},
"netcat_active_side_port_max": {
"type": [
"integer",
"null"
]
},
"netcat_passive_side_connect_address": {
"type": [
"string",
"null"
]
},
"source_datasets": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"target_dataset": {
"type": "string"
},
"recursive": {
"type": "boolean"
},
"exclude": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"properties": {
"type": "boolean"
},
"properties_exclude": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"replicate": {
"type": "boolean"
},
"encryption": {
"type": "boolean"
},
"encryption_key": {
"type": [
"string",
"null"
]
},
"encryption_key_format": {
"type": [
"string",
"null"
],
"enum": [
"HEX",
"PASSPHRASE"
]
},
"encryption_key_location": {
"type": [
"string",
"null"
]
},
"periodic_snapshot_tasks": {
"type": "array",
"items": [
{
"type": "integer"
}
]
},
"naming_schema": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"also_include_naming_schema": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"auto": {
"type": "boolean"
},
"schedule": {
"type": "object",
"properties": {
"minute": {
"type": "string"
},
"hour": {
"type": "string"
},
"dom": {
"type": "string"
},
"month": {
"type": "string"
},
"dow": {
"type": "string"
},
"begin": {
"type": "string"
},
"end": {
"type": "string"
}
},
"additionalProperties": false
},
"restrict_schedule": {
"type": "object",
"properties": {
"minute": {
"type": "string"
},
"hour": {
"type": "string"
},
"dom": {
"type": "string"
},
"month": {
"type": "string"
},
"dow": {
"type": "string"
},
"begin": {
"type": "string"
},
"end": {
"type": "string"
}
},
"additionalProperties": false
},
"only_matching_schedule": {
"type": "boolean"
},
"allow_from_scratch": {
"type": "boolean"
},
"readonly": {
"type": "string",
"enum": [
"SET",
"REQUIRE",
"IGNORE"
]
},
"hold_pending_snapshots": {
"type": "boolean"
},
"retention_policy": {
"type": "string",
"enum": [
"SOURCE",
"CUSTOM",
"NONE"
]
},
"lifetime_value": {
"type": [
"integer",
"null"
]
},
"lifetime_unit": {
"type": [
"string",
"null"
],
"enum": [
"HOUR",
"DAY",
"WEEK",
"MONTH",
"YEAR"
]
},
"compression": {
"type": [
"string",
"null"
],
"enum": [
"LZ4",
"PIGZ",
"PLZIP"
]
},
"speed_limit": {
"type": [
"integer",
"null"
]
},
"large_block": {
"type": "boolean"
},
"embed": {
"type": "boolean"
},
"compressed": {
"type": "boolean"
},
"retries": {
"type": "integer"
},
"logging_level": {
"type": [
"string",
"null"
],
"enum": [
"DEBUG",
"INFO",
"WARNING",
"ERROR"
]
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "replication_create",
"default": {}
}
|
Create a Replication Task Create a Replication Task that will push or pull ZFS snapshots to or from remote host..
|
|
replication.create_dataset |
---|
Arguments:
{
"title": "dataset",
"type": "string"
}
{
"title": "transport",
"type": "string",
"enum": [
"SSH",
"SSH+NETCAT",
"LOCAL"
]
}
{
"type": [
"integer",
"null"
],
"title": "ssh_credentials",
"default": null
}
|
Creates dataset on remote side Accepts |
|
replication.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete a Replication Task with specific |
|
replication.list_datasets |
---|
Arguments:
{
"title": "transport",
"type": "string",
"enum": [
"SSH",
"SSH+NETCAT",
"LOCAL"
]
}
{
"type": [
"integer",
"null"
],
"title": "ssh_credentials",
"default": null
}
|
List datasets on remote side Accepts |
|
replication.list_naming_schemas |
---|
List all naming schemas used in periodic snapshot and replication tasks. |
replication.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
replication.restore |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"target_dataset": {
"type": "string"
}
},
"additionalProperties": false,
"title": "replication_restore",
"default": {}
}
|
Create the opposite of replication task |
replication.run
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Run Replication Task of |
replication.target_unmatched_snapshots |
---|
Arguments:
{
"title": "direction",
"type": "string",
"enum": [
"PUSH",
"PULL"
]
}
{
"type": "array",
"title": "source_datasets",
"items": [
{
"type": "string"
}
]
}
{
"title": "target_dataset",
"type": "string"
}
{
"title": "transport",
"type": "string",
"enum": [
"SSH",
"SSH+NETCAT",
"LOCAL",
"LEGACY"
]
}
{
"type": [
"integer",
"null"
],
"title": "ssh_credentials",
"default": null
}
|
Check if target has any snapshots that do not exist on source. |
Returns
|
replication.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"direction": {
"type": "string",
"enum": [
"PUSH",
"PULL"
]
},
"transport": {
"type": "string",
"enum": [
"SSH",
"SSH+NETCAT",
"LOCAL"
]
},
"ssh_credentials": {
"type": [
"integer",
"null"
]
},
"netcat_active_side": {
"type": [
"string",
"null"
],
"enum": [
"LOCAL",
"REMOTE"
]
},
"netcat_active_side_listen_address": {
"type": [
"string",
"null"
]
},
"netcat_active_side_port_min": {
"type": [
"integer",
"null"
]
},
"netcat_active_side_port_max": {
"type": [
"integer",
"null"
]
},
"netcat_passive_side_connect_address": {
"type": [
"string",
"null"
]
},
"source_datasets": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"target_dataset": {
"type": "string"
},
"recursive": {
"type": "boolean"
},
"exclude": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"properties": {
"type": "boolean"
},
"properties_exclude": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"replicate": {
"type": "boolean"
},
"encryption": {
"type": "boolean"
},
"encryption_key": {
"type": [
"string",
"null"
]
},
"encryption_key_format": {
"type": [
"string",
"null"
],
"enum": [
"HEX",
"PASSPHRASE"
]
},
"encryption_key_location": {
"type": [
"string",
"null"
]
},
"periodic_snapshot_tasks": {
"type": "array",
"items": [
{
"type": "integer"
}
]
},
"naming_schema": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"also_include_naming_schema": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"auto": {
"type": "boolean"
},
"schedule": {
"type": "object",
"properties": {
"minute": {
"type": "string"
},
"hour": {
"type": "string"
},
"dom": {
"type": "string"
},
"month": {
"type": "string"
},
"dow": {
"type": "string"
},
"begin": {
"type": "string"
},
"end": {
"type": "string"
}
},
"additionalProperties": false
},
"restrict_schedule": {
"type": "object",
"properties": {
"minute": {
"type": "string"
},
"hour": {
"type": "string"
},
"dom": {
"type": "string"
},
"month": {
"type": "string"
},
"dow": {
"type": "string"
},
"begin": {
"type": "string"
},
"end": {
"type": "string"
}
},
"additionalProperties": false
},
"only_matching_schedule": {
"type": "boolean"
},
"allow_from_scratch": {
"type": "boolean"
},
"readonly": {
"type": "string",
"enum": [
"SET",
"REQUIRE",
"IGNORE"
]
},
"hold_pending_snapshots": {
"type": "boolean"
},
"retention_policy": {
"type": "string",
"enum": [
"SOURCE",
"CUSTOM",
"NONE"
]
},
"lifetime_value": {
"type": [
"integer",
"null"
]
},
"lifetime_unit": {
"type": [
"string",
"null"
],
"enum": [
"HOUR",
"DAY",
"WEEK",
"MONTH",
"YEAR"
]
},
"compression": {
"type": [
"string",
"null"
],
"enum": [
"LZ4",
"PIGZ",
"PLZIP"
]
},
"speed_limit": {
"type": [
"integer",
"null"
]
},
"large_block": {
"type": "boolean"
},
"embed": {
"type": "boolean"
},
"compressed": {
"type": "boolean"
},
"retries": {
"type": "integer"
},
"logging_level": {
"type": [
"string",
"null"
],
"enum": [
"DEBUG",
"INFO",
"WARNING",
"ERROR"
]
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "replication_create",
"default": {}
}
|
Update a Replication Task with specific See the documentation for |
|
replication.config.config |
---|
- |
replication.config.update |
---|
Arguments:
{
"type": "object",
"properties": {
"max_parallel_replication_tasks": {
"type": [
"integer",
"null"
]
}
},
"additionalProperties": false,
"title": "replication_config_update",
"default": {}
}
|
|
reporting.clear |
---|
Clear reporting database. |
reporting.config |
---|
- |
reporting.get_data |
---|
Arguments:
{
"type": "array",
"title": "graphs",
"items": [
{
"type": "object"
}
]
}
{
"type": "object",
"properties": {
"unit": {
"type": "string",
"enum": [
"HOUR",
"DAY",
"WEEK",
"MONTH",
"YEAR"
]
},
"page": {
"type": "integer"
},
"start": {
"type": "string"
},
"end": {
"type": "string"
},
"aggregate": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "reporting_query",
"default": {}
}
|
Get reporting data for given graphs. List of possible graphs can be retrieved using For the time period of the graph either
|
Get graph data of "nfsstat" from the last hour.
|
reporting.graphs |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
reporting.update |
---|
Arguments:
{
"type": "object",
"properties": {
"cpu_in_percentage": {
"type": "boolean"
},
"graphite": {
"type": "string"
},
"graphite_separateinstances": {
"type": "boolean"
},
"graph_age": {
"type": "integer"
},
"graph_points": {
"type": "integer"
},
"confirm_rrd_destroy": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "reporting_update",
"default": {}
}
|
Configure Reporting Database settings. If
|
Update reporting settings
Recreate reporting database with new settings
|
route.ipv4gw_reachable |
---|
Arguments:
{
"title": "ipv4_gateway",
"type": "string"
}
|
Get the IPv4 gateway and verify if it is reachable by any interface. Returns: bool: True if the gateway is reachable or otherwise False. |
route.system_routes |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Get current/applied network routes. |
rsyncd.config |
---|
- |
rsyncd.update |
---|
Arguments:
{
"type": "object",
"properties": {
"port": {
"type": "integer"
},
"auxiliary": {
"type": "string"
}
},
"additionalProperties": false,
"title": "rsyncd_update",
"default": {}
}
|
Update Rsyncd Service Configuration.
|
rsyncmod.create |
---|
Arguments:
{
"type": "object",
"properties": {
"enabled": {
"type": "boolean"
},
"name": {
"type": "string"
},
"comment": {
"type": "string"
},
"path": {
"type": "string"
},
"mode": {
"type": "string",
"enum": [
"RO",
"RW",
"WO"
]
},
"maxconn": {
"type": "integer"
},
"user": {
"type": "string"
},
"group": {
"type": "string"
},
"hostsallow": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"hostsdeny": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"auxiliary": {
"type": "string"
}
},
"additionalProperties": false,
"title": "rsyncmod_create",
"default": {}
}
|
Create a Rsyncmod module.
|
rsyncmod.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete Rsyncmod module of |
rsyncmod.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
rsyncmod.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"enabled": {
"type": "boolean"
},
"name": {
"type": "string"
},
"comment": {
"type": "string"
},
"path": {
"type": "string"
},
"mode": {
"type": "string",
"enum": [
"RO",
"RW",
"WO"
]
},
"maxconn": {
"type": "integer"
},
"user": {
"type": "string"
},
"group": {
"type": "string"
},
"hostsallow": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"hostsdeny": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"auxiliary": {
"type": "string"
}
},
"additionalProperties": false,
"title": "rsyncmod_create",
"default": {}
}
|
Update Rsyncmod module of |
rsynctask.create |
---|
Arguments:
{
"type": "object",
"properties": {
"path": {
"type": "string"
},
"user": {
"type": "string"
},
"remotehost": {
"type": "string"
},
"remoteport": {
"type": "integer"
},
"mode": {
"type": "string",
"enum": [
"MODULE",
"SSH"
]
},
"remotemodule": {
"type": "string"
},
"remotepath": {
"type": "string"
},
"validate_rpath": {
"type": "boolean"
},
"direction": {
"type": "string",
"enum": [
"PULL",
"PUSH"
]
},
"desc": {
"type": "string"
},
"schedule": {
"type": "object",
"properties": {
"minute": {
"type": "string"
},
"hour": {
"type": "string"
},
"dom": {
"type": "string"
},
"month": {
"type": "string"
},
"dow": {
"type": "string"
}
},
"additionalProperties": false
},
"recursive": {
"type": "boolean"
},
"times": {
"type": "boolean"
},
"compress": {
"type": "boolean"
},
"archive": {
"type": "boolean"
},
"delete": {
"type": "boolean"
},
"quiet": {
"type": "boolean"
},
"preserveperm": {
"type": "boolean"
},
"preserveattr": {
"type": "boolean"
},
"delayupdates": {
"type": "boolean"
},
"extra": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "rsync_task_create",
"default": {}
}
|
Create a Rsync Task. See the comment in Rsyncmod about
|
Create a Rsync Task which pulls data from a remote system every 5 minutes.
|
rsynctask.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete Rsync Task of |
rsynctask.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
rsynctask.run
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Job to run rsync task of Output is saved to job log excerpt (not syslog). |
rsynctask.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"path": {
"type": "string"
},
"user": {
"type": "string"
},
"remotehost": {
"type": "string"
},
"remoteport": {
"type": "integer"
},
"mode": {
"type": "string",
"enum": [
"MODULE",
"SSH"
]
},
"remotemodule": {
"type": "string"
},
"remotepath": {
"type": "string"
},
"validate_rpath": {
"type": "boolean"
},
"direction": {
"type": "string",
"enum": [
"PULL",
"PUSH"
]
},
"desc": {
"type": "string"
},
"schedule": {
"type": "object",
"properties": {
"minute": {
"type": "string"
},
"hour": {
"type": "string"
},
"dom": {
"type": "string"
},
"month": {
"type": "string"
},
"dow": {
"type": "string"
}
},
"additionalProperties": false
},
"recursive": {
"type": "boolean"
},
"times": {
"type": "boolean"
},
"compress": {
"type": "boolean"
},
"archive": {
"type": "boolean"
},
"delete": {
"type": "boolean"
},
"quiet": {
"type": "boolean"
},
"preserveperm": {
"type": "boolean"
},
"preserveattr": {
"type": "boolean"
},
"delayupdates": {
"type": "boolean"
},
"extra": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "rsync_task_create",
"default": {}
}
|
Update Rsync Task of |
sensor.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
service.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Query all system services with |
service.reload |
---|
Arguments:
{
"title": "service",
"type": "string"
}
{
"type": "object",
"properties": {
"ha_propagate": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "service-control",
"default": {}
}
|
Reload the service specified by |
service.restart |
---|
Arguments:
{
"title": "service",
"type": "string"
}
{
"type": "object",
"properties": {
"ha_propagate": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "service-control",
"default": {}
}
|
Restart the service specified by |
service.start |
---|
Arguments:
{
"title": "service",
"type": "string"
}
{
"type": "object",
"properties": {
"ha_propagate": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "service-control",
"default": {}
}
|
Start the service specified by |
service.started |
---|
Test if service specified by |
service.stop |
---|
Arguments:
{
"title": "service",
"type": "string"
}
{
"type": "object",
"properties": {
"ha_propagate": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "service-control",
"default": {}
}
|
Stop the service specified by |
service.terminate_process |
---|
Arguments:
{
"type": "integer",
"title": "pid"
}
{
"type": "integer",
"title": "timeout",
"default": 10
}
|
Terminate process by First send Returns |
service.update |
---|
Arguments:
{
"title": "id_or_name",
"type": "string"
}
{
"type": "object",
"properties": {
"enable": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "service-update",
"default": {}
}
|
Update service entry of Currently it only accepts |
sharing.afp.create |
---|
Arguments:
{
"type": "object",
"properties": {
"path": {
"type": "string"
},
"home": {
"type": "boolean"
},
"name": {
"type": "string"
},
"comment": {
"type": "string"
},
"allow": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"deny": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"ro": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"rw": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"timemachine": {
"type": "boolean"
},
"timemachine_quota": {
"type": "integer"
},
"nodev": {
"type": "boolean"
},
"nostat": {
"type": "boolean"
},
"upriv": {
"type": "boolean"
},
"fperm": {
"type": "string"
},
"dperm": {
"type": "string"
},
"umask": {
"type": "string"
},
"hostsallow": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"hostsdeny": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"vuid": {
"type": [
"string",
"null"
]
},
"auxparams": {
"type": "string"
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "sharingafp_create",
"default": {}
}
|
Create AFP share.
|
sharing.afp.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete AFP share |
sharing.afp.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
sharing.afp.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"path": {
"type": "string"
},
"home": {
"type": "boolean"
},
"name": {
"type": "string"
},
"comment": {
"type": "string"
},
"allow": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"deny": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"ro": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"rw": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"timemachine": {
"type": "boolean"
},
"timemachine_quota": {
"type": "integer"
},
"nodev": {
"type": "boolean"
},
"nostat": {
"type": "boolean"
},
"upriv": {
"type": "boolean"
},
"fperm": {
"type": "string"
},
"dperm": {
"type": "string"
},
"umask": {
"type": "string"
},
"hostsallow": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"hostsdeny": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"vuid": {
"type": [
"string",
"null"
]
},
"auxparams": {
"type": "string"
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "sharingafp_create",
"default": {}
}
|
Update AFP share |
sharing.nfs.create |
---|
Arguments:
{
"type": "object",
"properties": {
"paths": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"comment": {
"type": "string"
},
"networks": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"hosts": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"alldirs": {
"type": "boolean"
},
"ro": {
"type": "boolean"
},
"quiet": {
"type": "boolean"
},
"maproot_user": {
"type": [
"string",
"null"
]
},
"maproot_group": {
"type": [
"string",
"null"
]
},
"mapall_user": {
"type": [
"string",
"null"
]
},
"mapall_group": {
"type": [
"string",
"null"
]
},
"security": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "sharingnfs_create",
"default": {}
}
|
Create a NFS Share.
|
sharing.nfs.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete NFS Share of |
sharing.nfs.human_identifier |
---|
- |
sharing.nfs.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
sharing.nfs.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"paths": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"comment": {
"type": "string"
},
"networks": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"hosts": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"alldirs": {
"type": "boolean"
},
"ro": {
"type": "boolean"
},
"quiet": {
"type": "boolean"
},
"maproot_user": {
"type": [
"string",
"null"
]
},
"maproot_group": {
"type": [
"string",
"null"
]
},
"mapall_user": {
"type": [
"string",
"null"
]
},
"mapall_group": {
"type": [
"string",
"null"
]
},
"security": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "sharingnfs_create",
"default": {}
}
|
Update NFS Share of |
sharing.smb.create |
---|
Arguments:
{
"type": "object",
"properties": {
"purpose": {
"type": "string",
"enum": [
"NO_PRESET",
"DEFAULT_SHARE",
"ENHANCED_TIMEMACHINE",
"MULTI_PROTOCOL_AFP",
"MULTI_PROTOCOL_NFS",
"PRIVATE_DATASETS",
"WORM_DROPBOX"
]
},
"path": {
"type": "string"
},
"path_suffix": {
"type": "string"
},
"home": {
"type": "boolean"
},
"name": {
"type": "string"
},
"comment": {
"type": "string"
},
"ro": {
"type": "boolean"
},
"browsable": {
"type": "boolean"
},
"timemachine": {
"type": "boolean"
},
"recyclebin": {
"type": "boolean"
},
"guestok": {
"type": "boolean"
},
"abe": {
"type": "boolean"
},
"hostsallow": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"hostsdeny": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"aapl_name_mangling": {
"type": "boolean"
},
"acl": {
"type": "boolean"
},
"durablehandle": {
"type": "boolean"
},
"shadowcopy": {
"type": "boolean"
},
"streams": {
"type": "boolean"
},
"fsrvp": {
"type": "boolean"
},
"auxsmbconf": {
"type": "string"
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "sharingsmb_create",
"default": {}
}
|
Create a SMB Share.
|
sharing.smb.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete SMB Share of |
sharing.smb.presets |
---|
Retrieve pre-defined configuration sets for specific use-cases. These parameter combinations are often non-obvious, but beneficial in these scenarios. |
sharing.smb.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
sharing.smb.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"purpose": {
"type": "string",
"enum": [
"NO_PRESET",
"DEFAULT_SHARE",
"ENHANCED_TIMEMACHINE",
"MULTI_PROTOCOL_AFP",
"MULTI_PROTOCOL_NFS",
"PRIVATE_DATASETS",
"WORM_DROPBOX"
]
},
"path": {
"type": "string"
},
"path_suffix": {
"type": "string"
},
"home": {
"type": "boolean"
},
"name": {
"type": "string"
},
"comment": {
"type": "string"
},
"ro": {
"type": "boolean"
},
"browsable": {
"type": "boolean"
},
"timemachine": {
"type": "boolean"
},
"recyclebin": {
"type": "boolean"
},
"guestok": {
"type": "boolean"
},
"abe": {
"type": "boolean"
},
"hostsallow": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"hostsdeny": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"aapl_name_mangling": {
"type": "boolean"
},
"acl": {
"type": "boolean"
},
"durablehandle": {
"type": "boolean"
},
"shadowcopy": {
"type": "boolean"
},
"streams": {
"type": "boolean"
},
"fsrvp": {
"type": "boolean"
},
"auxsmbconf": {
"type": "string"
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "sharingsmb_create",
"default": {}
}
|
Update SMB Share of |
sharing.webdav.create |
---|
Arguments:
{
"type": "object",
"properties": {
"perm": {
"type": "boolean"
},
"ro": {
"type": "boolean"
},
"comment": {
"type": "string"
},
"name": {
"type": "string"
},
"path": {
"type": "string"
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "webdav_share_create",
"default": {}
}
|
Create a Webdav Share.
|
sharing.webdav.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Update Webdav Share of |
sharing.webdav.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
sharing.webdav.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"perm": {
"type": "boolean"
},
"ro": {
"type": "boolean"
},
"comment": {
"type": "string"
},
"name": {
"type": "string"
},
"path": {
"type": "string"
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "webdav_share_create",
"default": {}
}
|
Update Webdav Share of |
smart.config |
---|
- |
smart.update |
---|
Arguments:
{
"type": "object",
"properties": {
"interval": {
"type": "integer"
},
"powermode": {
"type": "string",
"enum": [
"NEVER",
"SLEEP",
"STANDBY",
"IDLE"
]
},
"difference": {
"type": "integer"
},
"informational": {
"type": "integer"
},
"critical": {
"type": "integer"
}
},
"additionalProperties": false,
"title": "smart_update",
"default": {}
}
|
Update SMART Service Configuration.
|
smart.test.create |
---|
Arguments:
{
"type": "object",
"properties": {
"schedule": {
"type": "object",
"properties": {
"hour": {
"type": "string"
},
"dom": {
"type": "string"
},
"month": {
"type": "string"
},
"dow": {
"type": "string"
}
},
"additionalProperties": false
},
"desc": {
"type": "string"
},
"all_disks": {
"type": "boolean"
},
"disks": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"type": {
"type": "string",
"enum": [
"LONG",
"SHORT",
"CONVEYANCE",
"OFFLINE"
]
}
},
"additionalProperties": false,
"title": "smart_task_create",
"default": {}
}
|
Create a SMART Test Task.
|
Create a SMART Test Task which executes after every 30 minutes.
|
smart.test.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete SMART Test Task of |
smart.test.disk_choices |
---|
Arguments:
{
"type": "boolean",
"title": "full_disk",
"default": false
}
|
Returns disk choices for S.M.A.R.T. test.
|
smart.test.manual_test |
---|
Arguments:
{
"type": "array",
"title": "disks",
"items": [
{
"type": "object"
}
]
}
|
Run manual SMART tests for
|
smart.test.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
smart.test.results |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Get disk(s) S.M.A.R.T. test(s) results. |
Get all disks tests results
Get specific disk test results
|
smart.test.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"schedule": {
"type": "object",
"properties": {
"hour": {
"type": "string"
},
"dom": {
"type": "string"
},
"month": {
"type": "string"
},
"dow": {
"type": "string"
}
},
"additionalProperties": false
},
"desc": {
"type": "string"
},
"all_disks": {
"type": "boolean"
},
"disks": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"type": {
"type": "string",
"enum": [
"LONG",
"SHORT",
"CONVEYANCE",
"OFFLINE"
]
}
},
"additionalProperties": false,
"title": "smart_task_create",
"default": {}
}
|
Update SMART Test Task of |
smb.bindip_choices |
---|
List of valid choices for IP addresses to which to bind the SMB service. Addresses assigned by DHCP are excluded from the results. |
smb.config |
---|
- |
smb.domain_choices |
---|
List of domains visible to winbindd. Returns empty list if winbindd is stopped. |
smb.get_remote_acl |
---|
Arguments:
{
"type": "object",
"properties": {
"server": {
"type": "string"
},
"share": {
"type": "string"
},
"path": {
"type": "string"
},
"username": {
"type": "string"
},
"password": {
"type": "string"
},
"options": {
"type": "object",
"properties": {
"use_kerberos": {
"type": "boolean"
},
"output_format": {
"type": "string",
"enum": [
"SMB",
"LOCAL"
]
}
},
"additionalProperties": false
}
},
"additionalProperties": false,
"title": "get_remote_acl",
"default": {}
}
|
Retrieves an ACL from a remote SMB server.
|
smb.groupmap_addmem |
---|
- |
smb.groupmap_listmem |
---|
- |
smb.json_check_version |
---|
- |
smb.status |
---|
Arguments:
{
"title": "info_level",
"default": "ALL",
"type": "string",
"enum": [
"AUTH_LOG",
"ALL",
"SESSIONS",
"SHARES",
"LOCKS",
"BYTERANGE",
"NOTIFICATIONS"
]
}
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
{
"type": "object",
"properties": {
"verbose": {
"type": "boolean"
},
"fast": {
"type": "boolean"
},
"restrict_user": {
"type": "string"
}
},
"additionalProperties": false,
"title": "status_options",
"default": {}
}
|
Returns SMB server status (sessions, open files, locks, notifications).
|
smb.unixcharset_choices |
---|
- |
smb.update |
---|
Arguments:
{
"type": "object",
"properties": {
"netbiosname": {
"type": "string"
},
"netbiosname_b": {
"type": "string"
},
"netbiosalias": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"workgroup": {
"type": "string"
},
"description": {
"type": "string"
},
"enable_smb1": {
"type": "boolean"
},
"unixcharset": {
"type": "string"
},
"loglevel": {
"type": "string",
"enum": [
"NONE",
"MINIMUM",
"NORMAL",
"FULL",
"DEBUG"
]
},
"syslog": {
"type": "boolean"
},
"aapl_extensions": {
"type": "boolean"
},
"localmaster": {
"type": "boolean"
},
"guest": {
"type": "string"
},
"admin_group": {
"type": [
"string",
"null"
]
},
"filemask": {
"type": "string"
},
"dirmask": {
"type": "string"
},
"ntlmv1_auth": {
"type": "boolean"
},
"bindip": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"smb_options": {
"type": "string"
}
},
"additionalProperties": false,
"title": "smb_update",
"default": {}
}
|
Update SMB Service Configuration.
|
smb.update_payload_with_diff |
---|
- |
smb.sharesec.create |
---|
Arguments:
{
"type": "object",
"properties": {
"share_name": {
"type": "string"
},
"share_acl": {
"type": "array",
"items": [
{
"type": "object"
}
]
}
},
"additionalProperties": false,
"title": "smbsharesec_create",
"default": {}
}
|
Update the ACL on a given SMB share. Will write changes to both
/var/db/system/samba4/share_info.tdb and the configuration file.
Since an SMB share will always have an ACL present, there is little
distinction between the
|
smb.sharesec.delete |
---|
Arguments:
{
"title": "id_or_name",
"type": "string"
}
|
Replace share ACL for the specified SMB share with the samba default ACL of S-1-1-0/FULL (Everyone - Full Control). In this case, access will be fully determined by the underlying filesystem ACLs and smb4.conf parameters governing access control and permissions. Share can be deleted by name or numerical by numerical index. |
smb.sharesec.getacl |
---|
Arguments:
{
"title": "share_name",
"type": "string"
}
{
"type": "object",
"properties": {
"resolve_sids": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
View the ACL information for If the |
smb.sharesec.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Use query-filters to search the SMB share ACLs present on server. |
smb.sharesec.synchronize_acls |
---|
Synchronize the share ACL stored in the config database with Samba's running configuration as reflected in the share_info.tdb file. The only situation in which the configuration stored in the database will overwrite samba's running configuration is if share_info.tdb is empty. Samba fakes a single S-1-1-0:ALLOW/0x0/FULL entry in the absence of an entry for a share in share_info.tdb. |
smb.sharesec.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"share_acl": {
"type": "array",
"items": [
{
"type": "object"
}
]
}
},
"additionalProperties": false,
"title": "smbsharesec_update",
"default": {}
}
|
Update the ACL on the share specified by the numerical index |
snmp.config |
---|
- |
snmp.update |
---|
Arguments:
{
"type": "object",
"properties": {
"location": {
"type": "string"
},
"contact": {
"type": "string"
},
"traps": {
"type": "boolean"
},
"v3": {
"type": "boolean"
},
"community": {
"type": "string"
},
"v3_username": {
"type": "string"
},
"v3_authtype": {
"type": "string",
"enum": [
"",
"MD5",
"SHA"
]
},
"v3_password": {
"type": "string"
},
"v3_privproto": {
"type": [
"string",
"null"
],
"enum": [
null,
"AES",
"DES"
]
},
"v3_privpassphrase": {
"type": "string"
},
"loglevel": {
"type": "integer"
},
"options": {
"type": "string"
},
"zilstat": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "snmp_update",
"default": {}
}
|
Update SNMP Service Configuration.
|
ssh.bindiface_choices |
---|
Available choices for the bindiface attribute of SSH service. |
ssh.config |
---|
- |
ssh.update |
---|
Arguments:
{
"type": "object",
"properties": {
"bindiface": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"tcpport": {
"type": "integer"
},
"rootlogin": {
"type": "boolean"
},
"passwordauth": {
"type": "boolean"
},
"kerberosauth": {
"type": "boolean"
},
"tcpfwd": {
"type": "boolean"
},
"compression": {
"type": "boolean"
},
"sftp_log_level": {
"type": "string",
"enum": [
"",
"QUIET",
"FATAL",
"ERROR",
"INFO",
"VERBOSE",
"DEBUG",
"DEBUG2",
"DEBUG3"
]
},
"sftp_log_facility": {
"type": "string",
"enum": [
"",
"DAEMON",
"USER",
"AUTH",
"LOCAL0",
"LOCAL1",
"LOCAL2",
"LOCAL3",
"LOCAL4",
"LOCAL5",
"LOCAL6",
"LOCAL7"
]
},
"weak_ciphers": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"options": {
"type": "string"
}
},
"additionalProperties": false,
"title": "ssh_update",
"default": {}
}
|
Update settings of SSH daemon service. If |
Make sshd listen only to igb0 interface.
|
staticroute.create |
---|
Arguments:
{
"type": "object",
"properties": {
"destination": {
"type": "string"
},
"gateway": {
"type": "string"
},
"description": {
"type": "string"
}
},
"additionalProperties": false,
"title": "staticroute_create",
"default": {}
}
|
Create a Static Route. Address families of
|
staticroute.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete Static Route of |
staticroute.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
staticroute.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"destination": {
"type": "string"
},
"gateway": {
"type": "string"
},
"description": {
"type": "string"
}
},
"additionalProperties": false,
"title": "staticroute_create",
"default": {}
}
|
Update Static Route of |
stats.get_data |
---|
Arguments:
{
"type": "array",
"title": "stats_list",
"items": [
{
"type": "object"
}
]
}
{
"type": "object",
"properties": {
"step": {
"type": "integer"
},
"start": {
"type": "string"
},
"end": {
"type": "string"
}
},
"additionalProperties": false,
"title": "stats-filter",
"default": {}
}
|
Get data points from rrd files. |
stats.get_dataset_info |
---|
Arguments:
{
"title": "source",
"type": "string"
}
{
"title": "type",
"type": "string"
}
|
Returns info about a given dataset from some source. |
stats.get_sources |
---|
Returns an object with all available sources tried with metric datasets. |
support.attach_ticket |
---|
Arguments:
{
"type": "object",
"properties": {
"ticket": {
"type": "integer"
},
"filename": {
"type": "string"
},
"token": {
"type": "string"
}
},
"additionalProperties": false,
"title": "attach_ticket",
"default": {}
}
|
Method to attach a file to a existing ticket. |
support.attach_ticket_max_size |
---|
Returns maximum uploaded file size for |
support.config |
---|
- |
support.fetch_categories |
---|
Arguments:
{
"title": "token",
"type": "string"
}
|
Fetch issue categories using access token |
support.fields |
---|
Returns list of pairs of field names and field titles for Proactive Support. |
support.is_available |
---|
Returns whether Proactive Support is available for this product type and current license. |
support.is_available_and_enabled |
---|
Returns whether Proactive Support is available and enabled. |
support.new_ticket
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"title": {
"type": "string"
},
"body": {
"type": "string"
},
"category": {
"type": "string"
},
"attach_debug": {
"type": "boolean"
},
"token": {
"type": "string"
},
"type": {
"type": "string",
"enum": [
"BUG",
"FEATURE"
]
},
"criticality": {
"type": "string"
},
"environment": {
"type": "string"
},
"phone": {
"type": "string"
},
"name": {
"type": "string"
},
"email": {
"type": "string"
},
"cc": {
"type": "array",
"items": [
{
"type": "string"
}
]
}
},
"additionalProperties": false,
"title": "new_ticket",
"default": {}
}
|
Creates a new ticket for support. This is done using the support proxy API. For FreeNAS it will be created on Redmine and for TrueNAS on SupportSuite. For FreeNAS |
support.update |
---|
Arguments:
{
"type": "object",
"properties": {
"enabled": {
"type": [
"boolean",
"null"
]
},
"name": {
"type": "string"
},
"title": {
"type": "string"
},
"email": {
"type": "string"
},
"phone": {
"type": "string"
},
"secondary_name": {
"type": "string"
},
"secondary_title": {
"type": "string"
},
"secondary_email": {
"type": "string"
},
"secondary_phone": {
"type": "string"
}
},
"additionalProperties": false,
"title": "support_update",
"default": {}
}
|
Update Proactive Support settings. |
system.boot_id |
---|
Returns an unique boot identifier. It is supposed to be unique every system boot. |
system.build_time |
---|
Retrieve build time of the system. |
system.debug |
---|
Job to stream debug file. This method is meant to be used in conjuntion with |
system.environment |
---|
Return environment in which product is running. Possible values: - DEFAULT - EC2 |
system.feature_enabled |
---|
Arguments:
{
"title": "feature",
"type": "string",
"enum": [
"DEDUP",
"FIBRECHANNEL",
"JAILS",
"VM"
]
}
|
Returns whether the |
system.host_id |
---|
Retrieve a hex string that is generated based
on the contents of |
system.info |
---|
Returns basic system information. |
system.is_freenas |
---|
FreeNAS is now TrueNAS CORE. DEPRECATED: Use |
system.license_update |
---|
Arguments:
{
"title": "license",
"type": "string"
}
|
Update license file. |
system.product_name |
---|
Returns name of the product we are using. |
system.product_type |
---|
Returns the type of the product. CORE - TrueNAS Core, community version ENTERPRISE - TrueNAS Enterprise, appliance version SCALE - TrueNAS SCALE |
system.ready |
---|
Returns whether the system completed boot and is ready to use |
system.reboot
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"delay": {
"type": "integer"
}
},
"additionalProperties": false,
"title": "system-reboot",
"default": {}
}
|
Reboots the operating system. Emits an "added" event of name "system" and id "reboot". |
system.shutdown
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"delay": {
"type": "integer"
}
},
"additionalProperties": false,
"title": "system-shutdown",
"default": {}
}
|
Shuts down the operating system. An "added" event of name "system" and id "shutdown" is emitted when shutdown is initiated. |
system.state |
---|
Returns system state: "BOOTING" - System is booting "READY" - System completed boot and is ready to use "SHUTTING_DOWN" - System is shutting down |
system.version |
---|
Returns software version of the system. |
system.advanced.config |
---|
- |
system.advanced.sed_global_password |
---|
Returns configured global SED password. |
system.advanced.serial_port_choices |
---|
Get available choices for |
system.advanced.update |
---|
Arguments:
{
"type": "object",
"properties": {
"advancedmode": {
"type": "boolean"
},
"autotune": {
"type": "boolean"
},
"boot_scrub": {
"type": "integer"
},
"consolemenu": {
"type": "boolean"
},
"consolemsg": {
"type": "boolean"
},
"debugkernel": {
"type": "boolean"
},
"fqdn_syslog": {
"type": "boolean"
},
"motd": {
"type": "string"
},
"powerdaemon": {
"type": "boolean"
},
"serialconsole": {
"type": "boolean"
},
"serialport": {
"type": "string"
},
"serialspeed": {
"type": "string",
"enum": [
"9600",
"19200",
"38400",
"57600",
"115200"
]
},
"swapondrive": {
"type": "integer"
},
"overprovision": {
"type": [
"integer",
"null"
]
},
"traceback": {
"type": "boolean"
},
"uploadcrash": {
"type": "boolean"
},
"anonstats": {
"type": "boolean"
},
"sed_user": {
"type": "string",
"enum": [
"USER",
"MASTER"
]
},
"sed_passwd": {
"type": "string"
},
"sysloglevel": {
"type": "string",
"enum": [
"F_EMERG",
"F_ALERT",
"F_CRIT",
"F_ERR",
"F_WARNING",
"F_NOTICE",
"F_INFO",
"F_DEBUG",
"F_IS_DEBUG"
]
},
"syslogserver": {
"type": "string"
},
"syslog_transport": {
"type": "string",
"enum": [
"UDP",
"TCP",
"TLS"
]
},
"syslog_tls_certificate": {
"type": [
"integer",
"null"
]
},
"syslog_tls_certificate_authority": {
"type": [
"integer",
"null"
]
}
},
"additionalProperties": false,
"title": "system_advanced_update",
"default": {}
}
|
Update System Advanced Service Configuration.
When |
system.general.config |
---|
- |
system.general.country_choices |
---|
Returns country choices. |
system.general.kbdmap_choices |
---|
Returns kbdmap choices. |
system.general.language_choices |
---|
Returns language choices. |
system.general.local_url |
---|
Returns configured local url in the format of protocol://host:port |
system.general.timezone_choices |
---|
Returns time zone choices. |
system.general.ui_address_choices |
---|
Returns UI ipv4 address choices. |
system.general.ui_certificate_choices |
---|
Return choices of certificates which can be used for |
system.general.ui_httpsprotocols_choices |
---|
Returns available HTTPS protocols. |
system.general.ui_restart |
---|
Arguments:
{
"type": "integer",
"title": "delay",
"default": 3
}
|
Restart HTTP server to use latest UI settings. HTTP server will be restarted after |
system.general.ui_v6address_choices |
---|
Returns UI ipv6 address choices. |
system.general.update |
---|
Arguments:
{
"type": "object",
"properties": {
"ui_certificate": {
"type": [
"integer",
"null"
]
},
"ui_httpsport": {
"type": "integer"
},
"ui_httpsredirect": {
"type": "boolean"
},
"ui_httpsprotocols": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"ui_port": {
"type": "integer"
},
"ui_address": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"ui_v6address": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"kbdmap": {
"type": "string"
},
"language": {
"type": "string"
},
"sysloglevel": {
"type": "string",
"enum": [
"F_EMERG",
"F_ALERT",
"F_CRIT",
"F_ERR",
"F_WARNING",
"F_NOTICE",
"F_INFO",
"F_DEBUG",
"F_IS_DEBUG"
]
},
"syslogserver": {
"type": "string"
},
"timezone": {
"type": "string"
},
"crash_reporting": {
"type": [
"boolean",
"null"
]
},
"usage_collection": {
"type": [
"boolean",
"null"
]
}
},
"additionalProperties": false,
"title": "general_settings",
"default": {}
}
|
Update System General Service Configuration.
|
system.ntpserver.create |
---|
Arguments:
{
"type": "object",
"properties": {
"address": {
"type": "string"
},
"burst": {
"type": "boolean"
},
"iburst": {
"type": "boolean"
},
"prefer": {
"type": "boolean"
},
"minpoll": {
"type": "integer"
},
"maxpoll": {
"type": "integer"
},
"force": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "ntp_create",
"default": {}
}
|
Add an NTP Server.
|
system.ntpserver.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete NTP server of |
system.ntpserver.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
system.ntpserver.test_ntp_server |
---|
- |
system.ntpserver.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"address": {
"type": "string"
},
"burst": {
"type": "boolean"
},
"iburst": {
"type": "boolean"
},
"prefer": {
"type": "boolean"
},
"minpoll": {
"type": "integer"
},
"maxpoll": {
"type": "integer"
},
"force": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "ntp_create",
"default": {}
}
|
Update NTP server of |
systemdataset.config |
---|
- |
systemdataset.update
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"pool": {
"type": [
"string",
"null"
]
},
"pool_exclude": {
"type": [
"string",
"null"
]
},
"syslog": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "sysdataset_update",
"default": {}
}
|
Update System Dataset Service Configuration.
|
tftp.config |
---|
- |
tftp.update |
---|
Arguments:
{
"type": "object",
"properties": {
"newfiles": {
"type": "boolean"
},
"directory": {
"type": "string"
},
"host": {
"type": "string"
},
"port": {
"type": "integer"
},
"options": {
"type": "string"
},
"umask": {
"type": "string"
},
"username": {
"type": "string"
}
},
"additionalProperties": false,
"title": "tftp_update",
"default": {}
}
|
Update TFTP Service Configuration.
|
truecommand.config |
---|
- |
truecommand.connected |
---|
Returns information which shows if system has an authenticated api key and has initiated a VPN connection with TrueCommand. |
truecommand.update |
---|
Arguments:
{
"type": "object",
"properties": {
"enabled": {
"type": "boolean"
},
"api_key": {
"type": [
"string",
"null"
]
}
},
"additionalProperties": false,
"title": "truecommand_update",
"default": {}
}
|
Update Truecommand service settings.
|
truenas.accept_eula |
---|
Accept TrueNAS EULA. |
truenas.get_chassis_hardware |
---|
Returns what type of hardware this is, detected from dmidecode |
truenas.get_customer_information |
---|
Returns stored customer information. |
truenas.get_eula |
---|
Returns the TrueNAS End-User License Agreement (EULA). |
truenas.is_eula_accepted |
---|
Returns whether the EULA is accepted or not. |
truenas.is_production |
---|
Returns if system is marked as production. |
truenas.set_production
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "boolean",
"title": "production"
}
{
"type": "boolean",
"title": "attach_debug",
"default": false
}
|
Sets system production state and optionally sends initial debug. |
truenas.update_customer_information |
---|
Arguments:
{
"type": "object",
"properties": {
"company": {
"type": "string"
},
"administrative_user": {
"type": "object",
"properties": {
"first_name": {
"type": "string"
},
"last_name": {
"type": "string"
},
"title": {
"type": "string"
},
"office_phone": {
"type": "string"
},
"mobile_phone": {
"type": "string"
},
"primary_email": {
"type": "string"
},
"secondary_email": {
"type": "string"
},
"address": {
"type": "string"
},
"city": {
"type": "string"
},
"state": {
"type": "string"
},
"zip": {
"type": "string"
},
"country": {
"type": "string"
}
},
"additionalProperties": false
},
"technical_user": {
"type": "object",
"properties": {
"first_name": {
"type": "string"
},
"last_name": {
"type": "string"
},
"title": {
"type": "string"
},
"office_phone": {
"type": "string"
},
"mobile_phone": {
"type": "string"
},
"primary_email": {
"type": "string"
},
"secondary_email": {
"type": "string"
},
"address": {
"type": "string"
},
"city": {
"type": "string"
},
"state": {
"type": "string"
},
"zip": {
"type": "string"
},
"country": {
"type": "string"
}
},
"additionalProperties": false
},
"reseller": {
"type": "object",
"properties": {
"company": {
"type": "string"
},
"first_name": {
"type": "string"
},
"last_name": {
"type": "string"
},
"title": {
"type": "string"
},
"office_phone": {
"type": "string"
},
"mobile_phone": {
"type": "string"
}
},
"additionalProperties": false
},
"physical_location": {
"type": "object",
"properties": {
"address": {
"type": "string"
},
"city": {
"type": "string"
},
"state": {
"type": "string"
},
"zip": {
"type": "string"
},
"country": {
"type": "string"
},
"contact_name": {
"type": "string"
},
"contact_phone_number": {
"type": "string"
},
"contact_email": {
"type": "string"
}
},
"additionalProperties": false
},
"primary_use_case": {
"type": "string"
},
"other_primary_use_case": {
"type": "string"
}
},
"additionalProperties": false,
"title": "customer_information_update",
"default": {}
}
|
Updates customer information. |
tunable.create |
---|
Arguments:
{
"type": "object",
"properties": {
"var": {
"type": "string"
},
"value": {
"type": "string"
},
"type": {
"type": "string",
"enum": [
"SYSCTL",
"LOADER",
"RC"
]
},
"comment": {
"type": "string"
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "tunable_create",
"default": {}
}
|
Create a Tunable.
|
tunable.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete Tunable of |
tunable.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
tunable.tunable_type_choices |
---|
Retrieve tunable type choices supported in the system |
tunable.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"var": {
"type": "string"
},
"value": {
"type": "string"
},
"type": {
"type": "string",
"enum": [
"SYSCTL",
"LOADER",
"RC"
]
},
"comment": {
"type": "string"
},
"enabled": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "tunable_create",
"default": {}
}
|
Update Tunable of |
update.check_available |
---|
Arguments:
{
"type": "object",
"properties": {
"train": {
"type": "string"
}
},
"additionalProperties": false,
"title": "update-check-available",
"default": {}
}
|
Checks if there is an update available from update server. status: - REBOOT_REQUIRED: an update has already been applied - AVAILABLE: an update is available - UNAVAILABLE: no update available - HA_UNAVAILABLE: HA is non-functional |
Check available update using default train:
|
update.download
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Download updates using selected train. |
update.file |
---|
Arguments:
{
"type": "object",
"properties": {
"destination": {
"type": [
"string",
"null"
]
}
},
"additionalProperties": false,
"title": "updatefile",
"default": {}
}
|
Updates the system using the uploaded .tar file. Use null |
update.get_auto_download |
---|
Returns if update auto-download is enabled. |
update.get_pending |
---|
Arguments:
{
"title": "path",
"default": null,
"type": [
"string",
"null"
]
}
|
Gets a list of packages already downloaded and ready to be applied. Each entry of the lists consists of type of operation and name of it, e.g. { "operation": "upgrade", "name": "baseos-11.0 -> baseos-11.1" } |
update.get_trains |
---|
Returns available trains dict and the currently configured train as well as the train of currently booted environment. |
update.manual
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"title": "path",
"type": "string"
}
|
Apply manual update of file |
update.set_auto_download |
---|
Arguments:
{
"type": "boolean",
"title": "autocheck"
}
|
Sets if update auto-download is enabled. |
update.set_train |
---|
Arguments:
{
"title": "train",
"type": "string"
}
|
Set an update train to be used by default in updates. |
update.update
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "object",
"properties": {
"train": {
"type": "string"
},
"reboot": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "update",
"default": {}
}
|
Downloads (if not already in cache) and apply an update. |
ups.config |
---|
- |
ups.driver_choices |
---|
Returns choices of UPS drivers supported by the system. |
ups.port_choices |
---|
- |
ups.update |
---|
Arguments:
{
"type": "object",
"properties": {
"emailnotify": {
"type": "boolean"
},
"powerdown": {
"type": "boolean"
},
"rmonitor": {
"type": "boolean"
},
"nocommwarntime": {
"type": [
"integer",
"null"
]
},
"remoteport": {
"type": "integer"
},
"shutdowntimer": {
"type": "integer"
},
"hostsync": {
"type": "integer"
},
"description": {
"type": "string"
},
"driver": {
"type": "string"
},
"extrausers": {
"type": "string"
},
"identifier": {
"type": "string"
},
"mode": {
"type": "string",
"enum": [
"MASTER",
"SLAVE"
]
},
"monpwd": {
"type": "string"
},
"monuser": {
"type": "string"
},
"options": {
"type": "string"
},
"optionsupsd": {
"type": "string"
},
"port": {
"type": "string"
},
"remotehost": {
"type": "string"
},
"shutdown": {
"type": "string",
"enum": [
"LOWBATT",
"BATT"
]
},
"shutdowncmd": {
"type": [
"string",
"null"
]
},
"subject": {
"type": "string"
},
"toemail": {
"type": "array",
"items": [
{
"type": "string"
}
]
}
},
"additionalProperties": false,
"title": "ups_update",
"default": {}
}
|
Update UPS Service Configuration.
|
user.create |
---|
Arguments:
{
"type": "object",
"properties": {
"uid": {
"type": "integer"
},
"username": {
"type": "string"
},
"group": {
"type": "integer"
},
"group_create": {
"type": "boolean"
},
"home": {
"type": "string"
},
"home_mode": {
"type": "string"
},
"shell": {
"type": "string"
},
"full_name": {
"type": "string"
},
"email": {
"type": [
"string",
"null"
]
},
"password": {
"type": "string"
},
"password_disabled": {
"type": "boolean"
},
"locked": {
"type": "boolean"
},
"microsoft_account": {
"type": "boolean"
},
"smb": {
"type": "boolean"
},
"sudo": {
"type": "boolean"
},
"sudo_nopasswd": {
"type": "boolean"
},
"sudo_commands": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"sshpubkey": {
"type": [
"string",
"null"
]
},
"groups": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"attributes": {
"type": "object",
"properties": {},
"additionalProperties": true
}
},
"additionalProperties": false,
"title": "user_create",
"default": {}
}
|
Create a new user. If
Available choices for
|
user.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"delete_group": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Delete user The |
user.get_next_uid |
---|
Get the next available/free uid. |
user.get_user_obj |
---|
Arguments:
{
"type": "object",
"properties": {
"username": {
"type": "string"
},
"uid": {
"type": "integer"
}
},
"additionalProperties": false,
"title": "get_user_obj",
"default": {}
}
|
Returns dictionary containing information from struct passwd for the user specified by either the username or uid. Bypasses user cache. |
user.has_root_password |
---|
Return whether the root user has a valid password set. This is used when the system is installed without a password and must be set on first use/login. |
user.pop_attribute |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"title": "key",
"type": "string"
}
|
Remove user general purpose |
user.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Query users with Users from directory services such as NIS, LDAP, or Active Directory will be included in query results
if the option |
user.set_attribute |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"title": "key",
"type": "string"
}
{
"anyOf": [
{
"type": "string"
},
{
"type": "integer"
},
{
"type": "boolean"
},
{
"type": "object"
},
{
"type": "array"
}
],
"title": "value",
"nullable": false
}
|
Set user general purpose e.g. Setting key="foo" value="var" will result in {"attributes": {"foo": "bar"}} |
user.set_root_password |
---|
Arguments:
{
"title": "password",
"type": "string"
}
{
"type": "object",
"properties": {
"ec2": {
"type": "object",
"properties": {
"instance_id": {
"type": "string"
}
},
"additionalProperties": false
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Set password for root user if it is not already set. |
user.shell_choices |
---|
Arguments:
{
"type": [
"integer",
"null"
],
"title": "user_id",
"default": null
}
|
Return the available shell choices to be used in If |
user.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"uid": {
"type": "integer"
},
"username": {
"type": "string"
},
"group": {
"type": "integer"
},
"home": {
"type": "string"
},
"home_mode": {
"type": "string"
},
"shell": {
"type": "string"
},
"full_name": {
"type": "string"
},
"email": {
"type": [
"string",
"null"
]
},
"password": {
"type": "string"
},
"password_disabled": {
"type": "boolean"
},
"locked": {
"type": "boolean"
},
"microsoft_account": {
"type": "boolean"
},
"smb": {
"type": "boolean"
},
"sudo": {
"type": "boolean"
},
"sudo_nopasswd": {
"type": "boolean"
},
"sudo_commands": {
"type": "array",
"items": [
{
"type": "string"
}
]
},
"sshpubkey": {
"type": [
"string",
"null"
]
},
"groups": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"attributes": {
"type": "object",
"properties": {},
"additionalProperties": true
}
},
"additionalProperties": false,
"title": "user_create",
"default": {}
}
|
Update attributes of an existing user. |
vm.clone |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"title": "name",
"default": null,
"type": "string"
}
|
Clone the VM
|
vm.create |
---|
Arguments:
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"description": {
"type": "string"
},
"vcpus": {
"type": "integer"
},
"cores": {
"type": "integer"
},
"threads": {
"type": "integer"
},
"memory": {
"type": "integer"
},
"bootloader": {
"type": "string",
"enum": [
"UEFI",
"UEFI_CSM",
"GRUB"
]
},
"grubconfig": {
"type": [
"string",
"null"
]
},
"devices": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"autostart": {
"type": "boolean"
},
"time": {
"type": "string",
"enum": [
"LOCAL",
"UTC"
]
},
"shutdown_timeout": {
"type": "integer"
}
},
"additionalProperties": false,
"title": "vm_create",
"default": {}
}
|
Create a Virtual Machine (VM).
Maximum of 16 guest virtual CPUs are allowed. By default, every virtual CPU is configured as a
separate package. Multiple cores can be configured per CPU by specifying
|
vm.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"zvols": {
"type": "boolean"
},
"force": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "vm_delete",
"default": {}
}
|
Delete a VM. |
vm.flags |
---|
Returns a dictionary with CPU flags for bhyve. |
vm.get_attached_iface |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Get the attached physical interfaces from a given guest. Returns: list: will return a list with all attached phisycal interfaces or otherwise False. |
vm.get_available_memory |
---|
Arguments:
{
"type": "boolean",
"title": "overcommit",
"default": false
}
|
Get the current maximum amount of available memory to be allocated for VMs. If This will include memory shrinking ZFS ARC to the minimum. Memory is of course a very "volatile" resource, values may change abruptly between a second but I deem it good enough to give the user a clue about how much memory is available at the current moment and if a VM should be allowed to be launched. |
vm.get_console |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Get the console device from a given guest. Returns: str: with the device path or False. |
vm.get_vmemory_in_use |
---|
The total amount of virtual memory in MB used by guests
|
vm.get_vnc |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Get the vnc devices from a given guest. Returns: list(dict): with all attributes of the vnc device or an empty list. |
vm.get_vnc_ipv4 |
---|
Get all available IPv4 address in the system. Returns: list: will return a list of available IPv4 address. |
vm.get_vnc_web |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"title": "host",
"default": "",
"type": "string"
}
|
Get the VNC URL from a given VM. Returns: list: With all URL available. |
vm.identify_hypervisor |
---|
Identify Hypervisors that might work nested with bhyve. Returns: bool: True if compatible otherwise False. |
vm.poweroff |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
- |
vm.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
vm.random_mac |
---|
Create a random mac address. Returns: str: with six groups of two hexadecimal digits |
vm.restart
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Restart a VM. |
vm.start |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"overcommit": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Start a VM. options.overcommit defaults to false, meaning VMs are not allowed to start if there is not enough available memory to hold all configured VMs. If true, VM starts even if there is not enough memory for all configured VMs. Error codes:
|
vm.status |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Get the status of a VM. Returns a dict: - state, RUNNING or STOPPED - pid, process id if RUNNING |
vm.stop
Job
This endpoint is a Job. Please refer to the Jobs section for details.
|
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"force": {
"type": "boolean"
},
"force_after_timeout": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Stops a VM. For unresponsive guests who have exceeded the
|
vm.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"description": {
"type": "string"
},
"vcpus": {
"type": "integer"
},
"cores": {
"type": "integer"
},
"threads": {
"type": "integer"
},
"memory": {
"type": "integer"
},
"bootloader": {
"type": "string",
"enum": [
"UEFI",
"UEFI_CSM",
"GRUB"
]
},
"grubconfig": {
"type": [
"string",
"null"
]
},
"devices": {
"type": "array",
"items": [
{
"type": "object"
}
]
},
"autostart": {
"type": "boolean"
},
"time": {
"type": "string",
"enum": [
"LOCAL",
"UTC"
]
},
"shutdown_timeout": {
"type": "integer"
}
},
"additionalProperties": false,
"title": "vm_create",
"default": {}
}
|
Update all information of a specific VM.
1) If there is no device in the |
vm.vnc_port_wizard |
---|
It returns the next available VNC PORT and WEB VNC PORT. Returns a dict with two keys vnc_port and vnc_web. |
vm.device.create |
---|
Arguments:
{
"type": "object",
"properties": {
"dtype": {
"type": "string",
"enum": [
"NIC",
"DISK",
"CDROM",
"PCI",
"VNC",
"RAW"
]
},
"vm": {
"type": "integer"
},
"attributes": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order": {
"type": [
"integer",
"null"
]
}
},
"additionalProperties": false,
"title": "vmdevice_create",
"default": {}
}
|
Create a new device for the VM of id If If |
vm.device.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"zvol": {
"type": "boolean"
},
"raw_file": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "vm_device_delete",
"default": {}
}
|
Delete a VM device of |
vm.device.nic_attach_choices |
---|
Available choices for NIC Attach attribute. |
vm.device.pptdev_choices |
---|
Available choices for PCI passthru device. |
vm.device.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
vm.device.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"dtype": {
"type": "string",
"enum": [
"NIC",
"DISK",
"CDROM",
"PCI",
"VNC",
"RAW"
]
},
"vm": {
"type": "integer"
},
"attributes": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order": {
"type": [
"integer",
"null"
]
}
},
"additionalProperties": false,
"title": "vmdevice_create",
"default": {}
}
|
Update a VM device of Pass |
vm.device.vnc_bind_choices |
---|
Available choices for VNC Bind attribute. |
vmware.create |
---|
Arguments:
{
"type": "object",
"properties": {
"datastore": {
"type": "string"
},
"filesystem": {
"type": "string"
},
"hostname": {
"type": "string"
},
"password": {
"type": "string"
},
"username": {
"type": "string"
}
},
"additionalProperties": false,
"title": "vmware_create",
"default": {}
}
|
Create VMWare snapshot.
|
vmware.dataset_has_vms |
---|
Arguments:
{
"title": "dataset",
"type": "string"
}
{
"type": "boolean",
"title": "recursive"
}
|
Returns "true" if |
vmware.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Delete VMWare snapshot of |
vmware.get_datastores |
---|
Arguments:
{
"type": "object",
"properties": {
"hostname": {
"type": "string"
},
"username": {
"type": "string"
},
"password": {
"type": "string"
}
},
"additionalProperties": false,
"title": "vmware-creds",
"default": {}
}
|
Get datastores from VMWare. |
vmware.get_virtual_machines |
---|
Arguments:
{
"type": "integer",
"title": "pk"
}
|
Returns Virtual Machines on the VMWare host identified by |
vmware.match_datastores_with_datasets |
---|
Arguments:
{
"type": "object",
"properties": {
"hostname": {
"type": "string"
},
"username": {
"type": "string"
},
"password": {
"type": "string"
}
},
"additionalProperties": false,
"title": "vmware-creds",
"default": {}
}
|
Requests datastores from vCenter server and tries to match them with local filesystems. Returns a list of datastores, a list of local filesystems and guessed relationship between them. |
|
vmware.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
vmware.update |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
{
"type": "object",
"properties": {
"datastore": {
"type": "string"
},
"filesystem": {
"type": "string"
},
"hostname": {
"type": "string"
},
"password": {
"type": "string"
},
"username": {
"type": "string"
}
},
"additionalProperties": false,
"title": "vmware_create",
"default": {}
}
|
Update VMWare snapshot of |
webdav.cert_choices |
---|
Permitted certificate choices for webdav service. |
webdav.config |
---|
- |
webdav.update |
---|
Arguments:
{
"type": "object",
"properties": {
"protocol": {
"type": "string",
"enum": [
"HTTP",
"HTTPS",
"HTTPHTTPS"
]
},
"tcpport": {
"type": "integer"
},
"tcpportssl": {
"type": "integer"
},
"password": {
"type": "string"
},
"htauth": {
"type": "string",
"enum": [
"NONE",
"BASIC",
"DIGEST"
]
},
"certssl": {
"type": [
"integer",
"null"
]
}
},
"additionalProperties": false,
"title": "webdav_update",
"default": {}
}
|
Update Webdav Service Configuration.
There are 3 types of Authentication supported with Webdav: 1) NONE - No authentication is required 2) BASIC - Password is sent over the network as plaintext 3) DIGEST - Hash of the password is sent over the network
|
webui.image.create |
---|
Arguments:
{
"type": "object",
"properties": {
"identifier": {
"type": "string"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Create a new database entry with identifier as the tag, all entries are lowercased Then puts the file in the /var/db/system/webui/images directory |
webui.image.delete |
---|
Arguments:
{
"type": "integer",
"title": "id"
}
|
Remove the database entry, and then the item if it exists |
webui.image.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
- |
zfs.snapshot.clone |
---|
Arguments:
{
"type": "object",
"properties": {
"snapshot": {
"type": "string"
},
"dataset_dst": {
"type": "string"
}
},
"additionalProperties": false,
"title": "snapshot_clone",
"default": {}
}
|
Clone a given snapshot to a new dataset. Returns: bool: True if succeed otherwise False. |
zfs.snapshot.create |
---|
Arguments:
{
"type": "object",
"properties": {
"dataset": {
"type": "string"
},
"name": {
"type": "string"
},
"naming_schema": {
"type": "string"
},
"recursive": {
"type": "boolean"
},
"vmware_sync": {
"type": "boolean"
},
"properties": {
"type": "object",
"properties": {},
"additionalProperties": true
}
},
"additionalProperties": false,
"title": "snapshot_create",
"default": {}
}
|
Take a snapshot from a given dataset. |
zfs.snapshot.delete |
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "object",
"properties": {
"defer": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Delete snapshot of name
|
zfs.snapshot.query |
---|
Arguments:
{
"type": "array",
"title": "query-filters",
"default": [],
"items": [
{
"type": "null"
}
]
}
{
"type": "object",
"properties": {
"relationships": {
"type": "boolean"
},
"extend": {
"type": [
"string",
"null"
]
},
"extend_context": {
"type": [
"string",
"null"
]
},
"prefix": {
"type": [
"string",
"null"
]
},
"extra": {
"type": "object",
"properties": {},
"additionalProperties": true
},
"order_by": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"select": {
"type": "array",
"items": [
{
"type": "null"
}
]
},
"count": {
"type": "boolean"
},
"get": {
"type": "boolean"
},
"offset": {
"type": "integer"
},
"limit": {
"type": "integer"
},
"force_sql_filters": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "query-options",
"default": {}
}
|
Query all ZFS Snapshots with |
zfs.snapshot.remove |
---|
Arguments:
{
"type": "object",
"properties": {
"dataset": {
"type": "string"
},
"name": {
"type": "string"
},
"defer_delete": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "snapshot_remove",
"default": {}
}
|
Remove a snapshot from a given dataset. Returns: bool: True if succeed otherwise False. |
zfs.snapshot.rollback |
---|
Arguments:
{
"title": "id",
"type": "string"
}
{
"type": "object",
"properties": {
"recursive": {
"type": "boolean"
},
"recursive_clones": {
"type": "boolean"
},
"force": {
"type": "boolean"
}
},
"additionalProperties": false,
"title": "options",
"default": {}
}
|
Rollback to a given snapshot
|
Events are triggers that are generated under certain scenarios or at a certain period of time.
Some events can accept arguments and return results that are influenced by those arguments. Follow this format to pass arguments to events:
event_name:arg
If arg
is accepted by the event, it is parsed automatically. Events that do not accept
arguments only use the event name when subscribing to the event.
Updates on job changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on acme.dns.authenticator changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on acme.registration changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on alertservice changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on api_key changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on bootenv changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on certificate changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on certificateauthority changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on cloudsync changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on cloudsync.credentials changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on cronjob changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on enclosure changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on fcport changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on group changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on idmap changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on initshutdownscript changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on interface changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on ipmi changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on iscsi.auth changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on iscsi.extent changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on iscsi.initiator changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on iscsi.portal changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on iscsi.target changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on iscsi.targetextent changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on jail changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on kerberos.keytab changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on kerberos.realm changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on keychaincredential changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on plugin changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on pool changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on pool.dataset changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on pool.dataset.userprop changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on pool.scrub changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on pool.snapshottask changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on replication changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on rsyncmod changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on rsynctask changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on service changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on sharing.afp changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on sharing.nfs changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on sharing.smb changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on sharing.webdav changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on smart.test changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on smb.sharesec changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on staticroute changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on system.ntpserver changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on tunable changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on user changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on vm changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on vm.device changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on vmware changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on webui.image changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on zfs.dataset changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on zfs.pool changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on zfs.snapshot changes.
This event can be subscribed to with the wildcard *
as the event name.
Notification of new and removed sessions.
This event can be subscribed to with the wildcard *
as the event name.
Sent on system state changes.
id=ready -- Finished boot process
id=reboot -- Started reboot process
id=shutdown -- Started shutdown process
This event can be subscribed to with the wildcard *
as the event name.
Sent on alert changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on network configuration changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on directory service state changes.
This event can be subscribed to with the wildcard *
as the event name.
Progress of pool resilver/scrub.
This event can be subscribed to with the wildcard *
as the event name.
Sent on TrueCommand configuration changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent on disk changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent when failover is being setup.
This event can be subscribed to with the wildcard *
as the event name.
Sent when failover status changes.
This event can be subscribed to with the wildcard *
as the event name.
Sent when the reasons for failover being disabled have changed.
This event can be subscribed to with the wildcard *
as the event name.
Sent when system is ready and HA upgrade is pending.
It is expected the client will react by issuing upgrade_finish
call
at user will.
This event can be subscribed to with the wildcard *
as the event name.
Sent when a CARP state is changed.
This event can be subscribed to with the wildcard *
as the event name.
Notifies of current system health which include statistics about consumption of memory and CPU, pools and
if updates are available. An integer delay
argument can be specified to determine the delay
on when the periodic event should be generated.
This event cannot be subscribed to with the wildcard *
as the event name.
Retrieve last no_of_lines
specified as an integer argument for a specific path
and then
any new lines as they are added. Specified argument has the format path:no_of_lines
( /var/log/messages:3
).
no_of_lines
is optional and if it is not specified it defaults to 3
.
However path
is required for this.
This event cannot be subscribed to with the wildcard *
as the event name.
Retrieve True View Statistics. An integer delay
argument can be specified to determine the delay
on when the periodic event should be generated.
This event cannot be subscribed to with the wildcard *
as the event name.
Retrieve real time statistics for CPU, network,
virtual memory and zfs arc.
This event cannot be subscribed to with the wildcard *
as the event name.
Retrieve currently running processes stats.
Usage: reporting.processes:{"interval": 10, "cpu_percent": 0.1, "memory_percent": 0.1}
This event cannot be subscribed to with the wildcard *
as the event name.
Events are generated by the system based on when certain conditions are met. It is not useful
if the system is generating an event and there is no event listener. Listening to events
is called subscribing
.
A client can subscribe to all system events by specifying *
. This only applies to events
that accept *
as a wildcard (refer to the list above for events that accept *
).
Request:
{
"id": "ad4dea8f-53a8-9a5c-1825-523e218c13ca",
"name": "*",
"msg": "sub"
}
Response:
{
"msg": "ready",
"subs": ["ad4dea8f-53a8-9a5c-1825-523e218c13ca"]
}
The example above subscribes the websocket client to system events that accept *
as a wildcard.
Each time an event is generated by the system the websocket client would get the event.
Event Response Example:
{
"msg": "changed",
"collection": "core.get_jobs",
"id": 79,
"fields": {
"id": 79, "method": "pool.scrub.scrub",
"arguments": ["vol1", "START"], "logs_path": null,
"logs_excerpt": null,
"progress": {"percent": 0.001258680822502356, "description": "Scrubbing", "extra": null},
"result": null, "error": null, "exception": null, "exc_info": null,
"state": "RUNNING", "time_started": {"$date": 1571297741181},
"time_finished": null
}
}
The event above was generated by the system when a pool is scrubbed.
The example below is how to subscribe to the reporting.realtime
event.
Request:
{
"id": "8592f7c2-ce2b-4466-443a-80bbae5937d9",
"name": "reporting.realtime",
"msg": "sub"
}
Response:
{
"msg": "ready",
"subs": ["8592f7c2-ce2b-4466-443a-80bbae5937d9"]
}
Event Response Example:
{
"msg": "added", "collection": "reporting.realtime",
"fields": {
"virtual_memory": {
"total": 4784615424, "available": 854155264, "percent": 82.1,
"used": 3779424256, "free": 136634368, "active": 894599168,
"inactive": 717520896, "buffers": 0, "cached": 0,
"shared": 188002304, "wired": 2884825088
},
"cpu": {"temperature": {}},
"interfaces": {
"em0": {
"received_bytes": 1068597254, "received_bytes_last": 1068597254,
"sent_bytes": 78087857, "sent_bytes_last": 78087857
},
"lo0": {
"received_bytes": 358364554, "received_bytes_last": 358364554,
"sent_bytes": 358360787, "sent_bytes_last": 358360787
}
}
}
}
The example below is how to subscribe to jobs.
Request:
{
"id": "19922f7c2-ce2b-4455-443a-80bbae5937a2",
"name": "core.get_jobs",
"msg": "sub"
}
Response:
{
"msg": "ready",
"subs": ["19922f7c2-ce2b-4455-443a-80bbae5937a2"]
}
Event Response Example:
{
"msg": "added", "collection": "core.get_jobs", "id": 26,
"fields": {
"id": 26, "method": "jail.stop", "arguments": ["abc"],
"logs_path": null, "logs_excerpt": null,
"progress": {"percent": null, "description": null, "extra": null},
"result": null, "error": null, "exception": null, "exc_info": null,
"state": "WAITING", "time_started": {"$date": 1571305262662},
"time_finished": null
}
}
The event above was generated when a jail was stopped and a job for stopping the jail started. The event response shows that system has registered the job and the job is waiting to be executed.
After the client has consumed the information required and no more updates are required, an event can be unsubscribed as shown here:
Request:
{
"id": "8592f7c2-ce2b-4466-443a-80bbae5937d9",
"msg": "unsub"
}
The server does not send a response for this call. This example unsubscribes
from the reporting.realtime
event that was subscribed to above. The id
is the same value
sent when subscribing to the event.
Tasks which require significant time to execute or process a significant amount of input or output are tagged as jobs. When a client connects to an endpoint marked as a job, they receive a job id from the endpoint. With this job id, the client can query the status of the job to see the progress and status. Errors are shown in the output, or the output contains the result returned by the endpoint on completion.
e.g. ws://truenas.domain/websocket
connect
message.{
"id": "6841f242-840a-11e6-a437-00e04d680384",
"msg": "method",
"method": "jail.start",
"params": ["jail_name"]
}
job_id
.{
"msg": "result",
"id": "c0bb5952-fc60-232a-3d6c-a47961b771a5",
"result": 53
}
Job status can be queried with the core.get_jobs
method.
Request:
{
"id": "d8e715be-6bc7-11e6-8c28-00e04d680384",
"msg": "method",
"method": "core.get_jobs",
"params": [[["id", "=", 53]]]
}
Response:
{
"id": "d8e715be-6bc7-11e6-8c28-00e04d680384",
"msg": "result",
"result": [{'id': 53, 'method': 'jail.start', 'arguments': ['abc'], 'logs_path': None, 'logs_excerpt': None, 'progress': {'percent': None, 'description': None, 'extra': None}, 'result': True, 'error': None, 'exception': None, 'exc_info': None, 'state': 'SUCCESS', 'time_started': {"$date": 1571300596053}, 'time_finished': null}]
}
There are some jobs which require input or output as files which can be uploaded or downloaded.
If a job gives a file as an output, this endpoint is to be used to download the output file.
Request:
{
"id": "d8e715be-6bc7-11e6-8c28-00e04d680384",
"msg": "method",
"method": "core.download",
"params": ["config.save", [{}], "freenas-FreeNAS-11.3-MASTER-201910090828-20191017122016.db"]
}
Response:
{
"id": "cdc8740a-336b-b0cd-b850-47568fe94223",
"msg": "result",
"result": [86, "/_download/86?auth_token=9WIqYg4jAYEOGQ4g319Bkr64Oj8CZk1VACfyN68M7hgjGTdeSSgZjSf5lJEshS8M"]
}
In the response, the first value 86
is the job id for config.save
. This can be used to query
the status of the job. The second value is a REST endpoint used to download the file.
The download endpoint has a special format:
http://system_ip/_download/{job_id}?auth_token={token}
job_id
and token
are parameters being passed.
core.download
takes responsibility for providing the download URI with the job_id
and token
values.
Note: 1) Job output is not buffered, so execution would be blocked if a file download is not started. 2) File download must begin within 60 seconds or the job is canceled. 3) The file can only be downloaded once.
Files can be uploaded via HTTP POST request only. The upload endpoint is:
http://system_ip/_upload
It expects two values as form data, data
and file
.
data
is JSON-encoded data. It must be the first parameter provided and in this format:
::: json
{
"method": "config.upload",
"params": []
}
file
is the URI of the file to download.
This example uses curl
,
Request:
curl -X POST -u root:freenas -H "Content-Type: multipart/form-data" -F 'data={"method": "config.upload", "params": []}' -F "file=@/home/user/Desktop/config" http://system_ip/_upload/
Response:
{"job_id": 20}