Infoblox Deployment Infoblox Rest API
Infoblox Deployment Infoblox Rest API
Infoblox Deployment Infoblox Rest API
Introduction 5
Object Reference 6
Documentation 6
Common scenarios 7
Points to remember 7
Access 9
Authentication 9
Schema 11
Extensible Attributes 12
DNS-related scenarios 14
Zones 14
TTL 42
1
Zone Transfers 44
DNSSEC 45
Delete an IP address 72
Network Views 72
VLAN Management 75
DHCP ranges 77
DHCP Leases 79
2
Grid Settings 80
Members 83
Services 90
Discovery 90
vDiscovery 92
Permissions 94
3
Add multiple host record 116
Python 117
Powershell 119
Java 120
C# (CSharp) 121
References 122
4
Introduction
The Infoblox WAPI is an interface based on REST (REpresentational State Transfer), also called a
RESTful web API. These are not dependent on any programming language.
It uses HTTP methods for operations and supports input and output in JSON and XML. It supports the
primary or most-commonly-used HTTP verbs: POST, GET, PUT, and DELETE. These correspond to
create, read, update, and delete (or CRUD) operations, respectively.
All API calls are encrypted using SSL/TLS and authenticated using HTTP basic authentication.
URL
The first part of the URL consists of the host IP address (or FQDN) to which all the calls will be directed. The
second part of the URL identifies the requests as a WAPI request and specifies the expected version of WAPI.
The Infoblox WAPI has a versioning scheme that is independent of the NIOS versioning scheme. A current
WAPI version is backward compatible with WAPI releases that have the same major WAPI version or with
designated earlier major versions.
The last part of the URL identifies the resource, such as a network, on which the request operates.
Arguments
Query arguments (after ‘?’) can be used to specify general options and method specific options and data for
the request. All options start with the character _ (underscore).
With version 2.11, _inheritance is introduced. If this option is set to True, fields which support inheritance, will
display data properly.
Data (Body)
Contains data that is dependent on the method. Only, PUT, and POST methods can have a Body on input. All
methods have Body on output.
Example
GET https://172.26.1.2/wapi/v2.9/networkview?_return_type=xml-pretty&name=default
5
Object Reference
Every WAPI Object is referenced by a unique Object Reference. WAPI returns this reference when an object is
created, modified, deleted or read. This reference is used to identify the object for the same operations.
Example
networkview/ZG5zLm5ldHdvcmtfdmlldyQw:default
Documentation
For more information, you can navigate to the WAPI documentation available at https://<grid_IP>/wapidoc
6
You can also find more information in the Support Site under NIOS in the Tech Docs section.
Common scenarios
This section will cover the most common scenarios that you may encounter in your day-to-day activities while
working with the Infoblox grid.
Please note that this document will cover the most common use cases. It will not cover all the APIs
available. For any additional information, please refer to the official WAPI documentation.
Points to remember
● For each of the use cases, this document will cover the API call and corresponding cURL commands,
alongwith a sample output.
● The cURL commands used here can be used on Linux-based systems. For Windows-based systems,
the syntax may vary.
● The Sample Codes section contains sample Python, Powershell, Java and C# code.
● In the following WAPI Samples, the guide uses a base url referenced as <wapi_url>.
Replace it with https://<grid_master_ip>/wapi/<wapi_version> or
https://<grid_master_fqdn>/wapi/<wapi_version>. Example: https://x.x.x.x/wapi/v2.12 or
https://this.is.a.test.com/wapi/2.12
To get the latest version of WAPI supported by the Grid in your environment, refer to the Schema
section. This is also available as part of the documentation.
7
● In the sample cURL commands, replace the text in red with values specific to your environment.
● By default, all the fields are not returned during a GET request. You can use the _return_fields
argument to get the desired data. You would have to explicitly mention the additional fields you require
with a _return_fields+=<requiredfield>
● You can set _return_as_object argument to 1. This will change the format of the JSON output to make
it easy to parse by 3rd party libraries. It is recommended to set this as it standardizes the JSON format
and is less error prone.
● Set the _max_results option to 1 when you need to stop a search on the first match. This results in a
huge performance and speed improvement in large environments.
● When a search result yields a large number of results, you can use paging.
o To start a paging request, the initial search request must have _paging and _return_as_object
set to 1, and _max_results set to the desired page size.
o The returned results object will contain the next_page_id field and the result field set to the
first page of results. Note that the next_page_id field only contains URL-safe characters so it
can be used as is and no quotation characters are required for subsequent requests.
o To get the subsequent results, you can re-send GET requests to the original object and set
_page_id to the ID string returned in the previous page of results.
o For a sample request, refer to Sample paging request
● When making POST, or PUT requests, it is easier to send the data as 'application/json' in the body of
the message, since it lets you send complex data structures in the payload.
● Field and argument values must be quoted according to where they are used.
Examples:
o URL args, x-www-form-urlencoded:
Use %xx encoding for “%”, ”;”, “/”, ”?”, ”:”, “@”, “&”, “=”, “+”, “$”, ”,” and ” ” (a space)
o JSON Data:
Use JSON quoting, as specified at http://json.org
o XML Data:
Use XML quoting (& etc.) as needed for XML.
● In the following examples, ‘+’ is encoded as %2B, ‘:’ as %3A, ‘<’ as 3C, ‘>’ as 3E
● The following examples include a sample output for each API call. This data is only representative of
the test environment. “….” indicates that there are more records returned than mentioned.
● By default, the output of POST, PUT, and DELETE contains the _ref of the concerned object.
● PUT and DELETE operations require _ref of the object you are working with.
o In the following WAPI Samples, the text highlighted in green indicates an object reference
specific to the test environment. Please replace it with the object reference specific to your
environment. Example: In
{wapi_url}/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLmhvc3Qx:host.info.c
om/default
replace with {wapi_url}/<_ref>
o You can get the _ref by performing a GET operation.
● If a field is of type BOOLEAN, do not quote the word. Example: "is_default":true
● Some fields are associated with a corresponding boolean flag value that has the prefix use_. For
example, ttl is associated with the flag use_ttl. In an object, the value of this field will only take effect
when its use flag is true. Otherwise, the value will be inherited from a higher-level setting. With WAPI
2.12, you can get the inherited data by setting the _inheritance argument to true.
● While searching for network objects, you can filter the data using regular expressions. You would need
to specify the ~ modifier to indicate you are querying with a regular expression.
8
o A search argument can use the following modifiers
Modifier Explanation
! Negates the condition
: Makes string matching case insensitive
Regular expression search. Expressions are
~
unanchored
< Less than or equal
> Greater than or equal
o Only one of the following can be specified at a time: greater than, less than, and regular
expressions.
o Depending on the attribute type, following are modifiers supported by extensible attributes:
▪ integer and date support !, < and >.
1. Applications that allow you to make REST calls, like Insomnia and POSTMAN
2. Any programming language or utility, like curl and python (by importing the requests module)
3. Any third-party application that you want to integrate with, that supports REST methods, like
ServiceNow and HP Operations Orchestrator.
Authentication
The server certificate used for WAPI is the same certificate used by NIOS for the GUI.
WAPI supports only HTTP Basic Authentication. You can use the connection for issuing multiple requests. In
the case of multiple requests, authentication is handled by supplying the cookie (ibapauth) that was returned
after the initial authentication. The IBAPAUTH cookie is sent back by the server to avoid repeat authentication
requests. It is sent as an HTTPONLY, SECURE cookie.
Example: set-cookie:
ibapauth="ip=127.0.0.1,client=API,group=admin-group,ctime=1446631868,timeout=600,mtime=1446631868,su
=1,auth=LOCAL,user=admin,NlxMltsoxDNvBWKrfOMy+uxUMWS3guCB4yU"
This cookie can be invalidated by sending a POST request to /wapi/v2.12/logout
WAPI supports the same underlying authentication methods that NIOS supports for username and password.
This also applies to the cookie timeout which is the same value as the Grid UI timeout. All WAPI users must
have permissions that grant them access to the API.
9
You can login with any API call. This will set the cookie.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
curl -k -u admin:infoblox -c cookies.txt -X GET
"https://grid-master/wapi/v2.12/record:host?_return_as_object=1"
{"result":
[{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS50ZXN0Lmhvc3Qx:host1.test.com/default",
"ipv4addrs":
[{ "_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLnRlc3QuaG9zdDE
uMTcyLjI2LjEuMjAwLg:172.26.1.200/host1.test.com/default",
"configure_for_dhcp": false,
"host": "host1.test.com",
"ipv4addr": "172.26.1.200"
}],
A sample API call (Get "name": "host1.test.com",
host records) to save "view": "default"
the cookie generated to },
a file called cookies.txt ….
{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLnByaW50ZXI:printer.info.com/def
ault",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8ucHJpbnR
lci4xNjAuMjAuMS4xMDAu:160.20.1.100/printer.info.com/default",
"configure_for_dhcp": false,
"host": "printer.info.com",
"ipv4addr": "160.20.1.100"
}],
"name": "printer.info.com",
"view": "default"
}]}
curl -k -b cookies.txt -X GET "https://grid-master/wapi/v2.12/zone_auth?_return_as_object=1"
A sample API call (Get {"result":
zones) to show how to [{"_ref": "zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS50ZXN0:test.com/default",
use the generated "fqdn": "test.com",
cookie from cookies.txt "view": "default"
}]}
<wapi_url>/grid/b25lLmNsdXN0ZXIkMA:Inf {"security_setting":
PUT
oblox {"session_timeout": 60000}}
curl -k -b cookies.txt -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/grid/b25lLmNsdXN0ZXIkMA:Infoblox?_return_as_object=1&_retu
rn_fields%2B=security_setting" -d '{"security_setting":{"session_timeout": 60000}}'
Modify the session
timeout {"result":
{"_ref": "grid/b25lLmNsdXN0ZXIkMA:Infoblox",
"security_setting":
{ "admin_access_items": [],
"audit_log_rolling_enable": true,
"http_redirect_enable": false,
10
"lcd_input_enable": true,
"login_banner_enable": true,
"login_banner_text": "Disconnect NOW if you have not been expressly authorized to use
this system.",
"remote_console_access_enable": false,
"security_access_enable": false,
"security_access_remote_console_enable": true,
"session_timeout": 600000,
"ssh_perm_enable": true,
"support_access_enable": false,
"support_access_info": "Not enabled"
}}}
POST <wapi_url>/logout
Invalidate a cookie curl -k -b cookies.txt -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/logout"
Schema
The _schema argument returns the WAPI schema.
If a WAPI schema is requested without specifying the type of network object, an object with information about
requested version of the WAPI schema, list of supported objects in the requested version, and list of all
supported versions will be returned.
If you specify a network object while requesting WAPI schema, along with the above-mentioned information,
you will get a list of cloud restrictions, list of fields of the object, list of object restrictions, requested object type,
and actual requested version of the WAPI object schema.
REST
API Call
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/?_schema
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/?_schema&_return_as_object=1"
{"result":
{"requested_version": "2.12",
"supported_objects":
["ad_auth_service",
"admingroup",
"adminrole",
Get the overall WAPI Schema (supported versions …..
and supported objects) "zone_delegated",
"zone_forward",
"zone_rp",
"zone_stub"
],
"supported_versions":
["1.0","1.1","1.2","1.2.1", "1.3","1.4","1.4.1",
…….
"2.6","2.6.1","2.7", "2.7.1","2.7.2","2.7.3","2.8","2.9","2.9.1","2.9.5"
]}}
GET <wapi_url>/record:host?_schema
Get schema of an object (record:host can be curl -k -u admin:infoblox -X GET
replaced with any other object) "https://grid-master/wapi/v2.12/record:host?_schema&_return_as_obj
ect=1"
11
{"result":
{"cloud_additional_restrictions":
["function call"],
"fields":
[{"is_array": true,
"name": "aliases",
"standard_field": false,
"supports": "rwu",
"type": ["string"]
},
{"is_array": false,
"name": "allow_telnet",
"standard_field": false,
"supports": "rwu",
"type": ["bool"]
},
……
{"is_array": false,
"name": "zone",
"searchable_by": "=",
"standard_field": false,
"supports": "rs",
"type": ["string"]
}],
"restrictions": [],
"type": "record:host",
"version": "2.12"
}}
Extensible Attributes
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/extensibleattributedef
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/extensibleattributedef?_return_as_object=1"
{"result":
[{ "_ref":
"extensibleattributedef/b25lLmV4dGVuc2libGVfYXR0cmlidXRlc19kZWYkLkJ1aW
xkaW5n:Building",
"default_value": null,
Get the definition of the Extensible "name": "Building",
Attributes "type": "STRING"
},
……
{"_ref":
"extensibleattributedef/b25lLmV4dGVuc2libGVfYXR0cmlidXRlc19kZWYkLlJlcG9
ydGluZ1NpdGU:ReportingSite",
"default_value": "site1",
"name": "ReportingSite",
"type": "ENUM"
}]}
Create “Owner” Extensible Attribute of {"name": "Owner",
POST <wapi_url>/extensibleattributedef
type String "type": "STRING"}
12
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/extensibleattributedef?
_return_fields%2B=name,type&_return_as_object=1" -d '{"name":
"Owner","type": "STRING"}'
{"result":
{"_ref":
"extensibleattributedef/b25lLmV4dGVuc2libGVfYXR0cmlidXRlc19kZWYkLk93bm
Vy:Owner",
"default_value": null,
"name": "Owner",
"type": "STRING"
}}
{"name": "Location",
"type": "ENUM",
"list_values": [{"value": "Santa
POST <wapi_url>/extensibleattributedef Clara"},
{"value": "Tacoma"},
{"value": "Bangalore"},
{"value": "Mumbai"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/extensibleattributedef?
Create a “Location” Extensible Attribute
_return_fields%2B=name,type&_return_as_object=1" -d '{"name":
of type list with possible values Santa
"Location","type": "ENUM","list_values": [{"value": "Santa Clara"},{"value":
Clara, Tacoma, Bangalore, Mumbai
"Tacoma"},{"value": "Bangalore"},{"value": "Mumbai"}]}'
{"result":
{"_ref":
"extensibleattributedef/b25lLmV4dGVuc2libGVfYXR0cmlidXRlc19kZWYkLkxvY2
F0aW9u:Location",
"default_value": null,
"name": "Location",
"type": "ENUM"
}}
Extensible Attributes Inheritance
If inheritance is enabled for an extensible attribute, the following fields are supported in the extensible attribute
value object:
13
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
{"extattrs":
{"Location":
{"descendants_action":
<wapi_url>/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNv {"option_with_ea":
PUT
bS50ZXN0Lmhvc3Qx:host1.test.com/default "RETAIN",
"option_without_ea":
"NOT_INHERIT"},
"value": "Santa Clara"}}}
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS50ZXN0Lmhvc3Q
x:host1.test.com/default?_return_fields%2B=extattrs&_return_as_object=1" -d '{"extattrs":{"Location":
{"descendants_action": {"option_with_ea": "RETAIN","option_without_ea":"NOT_INHERIT"},"value":
"Santa Clara"}}}'
Add an extensible {"result":
attribute with {"_ref":
inheritance "record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS50ZXN0Lmhvc3Qx:host1.test.com/default",
"extattrs":
{"Location": {"value": "Santa Clara"}
},
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLnRlc3QuaG9zdDEuMTc
yLjI2LjEuMjAwLg:172.26.1.200/host1.test.com/default",
"configure_for_dhcp": false,
"host": "host1.test.com",
"ipv4addr": "172.26.1.200"
}],
"name": "host1.test.com",
"view": "default"
}}
DNS-related scenarios
Zones
REST
API Call Sample Body (for POST and PUT)
Method
Zone type Operation
Sample cURL Command
Sample Output
GET <wapi_url>/zone_auth
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/zone_auth?_return_as_object=1"
Fetch {"result":
information [{"_ref": "zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS50ZXN0:test.com/default",
Authoritative
"fqdn": "test.com",
Zone
"view": "default"
}]}
POST <wapi_url>/zone_auth {"fqdn": "info.com"}
Create
14
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/zone_auth?_return_fields%2B=fqdn&_return_as_object=1" -d
'{"fqdn": "info.com"}'
{"result":
{"_ref": "zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmZv:info.com/default",
"fqdn": "info.com",
"view": "default"
}}
{"fqdn": "10.10.10.in-addr.arpa ",
POST <wapi_url>/zone_auth
"zone_format":"IPV4"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/zone_auth?_return_fields%2B=fqdn&_return_as_object=1" -d
Create IPV4 '{"fqdn": "10.10.10.in-addr.arpa","zone_format":"IPV4"}'
reverse {"result":
mapping {"_ref":
zone "zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmFycGEuaW4tYWRkci4xMC4xMC4xMA:10.10
.10.0%2F24/default",
"fqdn": "10.10.10.0/24",
"view": "default"
}}
<wapi_url>/zone_auth/ZG5zLnpvbm
{"grid_primary":[{"name":"infoblox.localdom
PUT UkLl9kZWZhdWx0LmNvbS5pbmZv:i
ain"}]}
nfo.com/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmZv:i
nfo.com/default?_return_fields%2B=fqdn,grid_primary&_return_as_object=1" -d
'{"grid_primary":[{"name":"infoblox.localdomain"}]}'
Modify {"result":
{"_ref": "zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmZv:info.com/default",
"fqdn": "info.com",
"grid_primary":
[{"name": "infoblox.localdomain",
"stealth": false
}],
"view": "default"
}}
<wapi_url>/zone_auth/ZG5zLnpvbm
DELETE UkLl9kZWZhdWx0LmNvbS5pbmZv:i
nfo.com/default
Delete curl -k -u admin:infoblox -H 'content-type: application/json' -X DELETE
"https://grid-master/wapi/v2.12/zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmZv:i
nfo.com/default&?_return_as_object=1"
{"result": "zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmZv:info.com/default"}
GET <wapi_url>/zone_forward
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/zone_forward?_return_as_object=1"
{"result":
Fetch [{"_ref":
Forward Zone
information "zone_forward/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5mb3J3YXJkdGVzdA:forwardtest.co
m/default",
"forward_to":
[{"address": "172.26.1.10",
"name": "host.forwardtest.com"
}],
15
"fqdn": "forwardtest.com",
"view": "default"
}]}
{"fqdn":"infoblox.com",
POST <wapi_url>/zone_forward "forward_to":[{"address":"10.10.10.11",
"name":"host.infoblox.com"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/zone_forward?_return_as_object=1" -d
'{"fqdn":"infoblox.com","forward_to":[{"address":"10.10.10.11","name":"host.infoblox.com"}]}'
{"result":
{"_ref":
Create "zone_forward/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmZvYmxveA:infoblox.com/defaul
t",
"forward_to":
[{"address": "10.10.10.11",
"name": "host.infoblox.com"
}],
"fqdn": "infoblox.com",
"view": "default"
}}
<wapi_url>/zone_forward/ZG5zLnpv
{"forwarding_servers":
PUT bmUkLl9kZWZhdWx0LmNvbS5pbmZ
[{"name":"infoblox.localdomain"}]}
vYmxveA:infoblox.com/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/zone_forward/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbm
ZvYmxveA:infoblox.com/default?_return_fields%2B=forwarding_servers&_return_as_object=
1" -d '{"forwarding_servers": [{"name":"infoblox.localdomain"}]}'
{"result":
{"_ref":
"zone_forward/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmZvYmxveA:infoblox.com/defaul
t",
Modify "forward_to":
[{"address": "10.10.10.11",
"name": "host.infoblox.com"
}],
"forwarding_servers":
[{"forward_to": [],
"forwarders_only": false,
"name": "infoblox.localdomain",
"use_override_forwarders": false
}],
"fqdn": "infoblox.com",
"view": "default"
}}
<wapi_url>/zone_forward/ZG5zLnpv
DELETE bmUkLl9kZWZhdWx0LmNvbS5pbmZ
vYmxveA:infoblox.com/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X DELETE
Delete "https://grid-master/wapi/v2.12/zone_forward/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbm
ZvYmxveA:infoblox.com/default?_return_as_object=1"
{"result":
"zone_forward/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmZvYmxveA:infoblox.com/defaul
t"}
16
GET <wapi_url>/zone_delegated
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/zone_delegated?_return_as_object=1"
{"result":
[{"_ref":
"zone_delegated/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmZvLnRlc3Q:test.info.com/def
Fetch ault",
information "delegate_to":
[{"address": "172.26.1.100",
"name": "host.test.info.com"
}],
"fqdn": "test.info.com",
"view": "default"
}]}
{"fqdn":"demo.info.com",
POST <wapi_url>/zone_delegated "delegate_to":[{"address":"10.10.10.20",
"name":"host.demo.info.com"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/zone_delegated?_return_fields%2B=fqdn,delegate_to&_retur
n_as_object=1" -d
'{"fqdn":"demo.info.com","delegate_to":[{"address":"10.10.10.20","name":"host.demo.info.com
"}]}'
{"result":
Create {"_ref":
"zone_delegated/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmZvLmRlbW8:demo.info.com/
Zone default",
Delegation "delegate_to":
[{"address": "10.10.10.20",
"name": "host.demo.info.com"
}],
"fqdn": "demo.info.com",
"view": "default"
}}
<wapi_url>/zone_delegated/ZG5zLn
PUT pvbmUkLl9kZWZhdWx0LmNvbS5pb {"locked":true}
mZvLmRlbW8:demo.info.com/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/zone_delegated/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pb
mZvLmRlbW8:demo.info.com/default?_return_fields=locked&_return_as_object=1" -d
Modify '{"locked":true}'
{"result":
{"_ref":
"zone_delegated/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmZvLmRlbW8:demo.info.com/
default",
"locked": true
}}
<wapi_url>/zone_delegated/ZG5zLn
DELETE pvbmUkLl9kZWZhdWx0LmNvbS5pb
mZvLmRlbW8:demo.info.com/default
Delete
curl -k -u admin:infoblox -H 'content-type: application/json' -X DELETE
"https://grid-master/wapi/v2.12/zone_delegated/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pb
mZvLmRlbW8:demo.info.com/default?_return_as_object=1"
17
{"result":
"zone_delegated/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmZvLmRlbW8:demo.info.com/
default"}
The most common record types
REST
API Call Sample Body (for POST and PUT)
Record Method
Operation
type Sample cURL Command
Sample Output
GET <wapi_url>/record:host
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:host?_return_as_object=1"
{"result":
[{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS50ZXN0Lmhvc3Qx:host1.test.com/defa
ult",
"ipv4addrs":
[{ "_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLnRlc3QuaG9zd
DEuMTcyLjI2LjEuMjAwLg:172.26.1.200/host1.test.com/default",
"configure_for_dhcp": false,
"host": "host1.test.com",
"ipv4addr": "172.26.1.200"
}],
Fetch "name": "host1.test.com",
information "view": "default"
},
….
{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLnByaW50ZXI:printer.info.com/
default",
"ipv4addrs":
HOST [{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8ucHJpb
nRlci4xNjAuMjAuMS4xMDAu:160.20.1.100/printer.info.com/default",
"configure_for_dhcp": false,
"host": "printer.info.com",
"ipv4addr": "160.20.1.100"
}],
"name": "printer.info.com",
"view": "default"
}]}
{"name":"host.info.com",
POST <wapi_url>/record:host "ipv4addrs":
[{"ipv4addr":"10.10.10.20"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:host?_return_fields%2B=name,ipv4addrs&_return_as_
object=1" -d '{"name":"host.info.com","ipv4addrs": [{"ipv4addr":"10.10.10.20"}]}'
Create {"result":
{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLmhvc3Q:host.info.com/default"
,
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8uaG9z
18
dC4xMC4xMC4xMC4yMC4:10.10.10.20/host.info.com/default",
"configure_for_dhcp": false,
"host": "host.info.com",
"ipv4addr": "10.10.10.20"
}],
"name": "host.info.com",
"view": "default"
}}
<wapi_url>/record:host/ZG5zLmhvc3QkLl9
PUT kZWZhdWx0LmNvbS5pbmZvLmhvc3Q:ho {"name":"host1.info.com"}
st.info.com/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvL
mhvc3Q:host.info.com/default?_return_fields%2B=name&_return_as_object=1" -d
'{"name":"host1.info.com"}'
{"result":
{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLmhvc3Qx:host1.info.com/defa
Modify ult",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8uaG9z
dDEuMTAuMTAuMTAuMjAu:10.10.10.20/host1.info.com/default",
"configure_for_dhcp": false,
"host": "host1.info.com",
"ipv4addr": "10.10.10.20"
}],
"name": "host1.info.com",
"view": "default"
}}
<wapi_url>/record:host/ZG5zLmhvc3QkLl9
DELETE kZWZhdWx0LmNvbS5pbmZvLmhvc3Qx:h
ost1.info.com/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X DELETE
Delete "https://grid-master/wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvL
mhvc3Qx:host1.info.com/default?_return_as_object=1"
{"result":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLmhvc3Qx:host1.info.com/defa
ult"}
GET <wapi_url>/record:a
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:a?_return_as_object=1"
{"result":
Fetch [{"_ref":
information "record:a/ZG5zLmJpbmRfYSQuX2RlZmF1bHQuY29tLmluZm8sdGVzdC5ob3N0LDE3Mi4yNi
4xLjEwMA:host.test.info.com/default",
A "ipv4addr": "172.26.1.100",
"name": "host.test.info.com",
"view": "default"
}]}
{"name":"server.info.com",
POST <wapi_url>/record:a
Create "ipv4addr":"10.10.10.2"}
19
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:a?_return_fields%2B=name,ipv4addr&_return_as_obje
ct=1" -d '{"name":"server.info.com","ipv4addr":"10.10.10.2"}'
{"result":
{"_ref":
"record:a/ZG5zLmJpbmRfYSQuX2RlZmF1bHQuY29tLmluZm8sc2VydmVyLDEwLjEwLjEwLjI:
server.info.com/default",
"ipv4addr": "10.10.10.2",
"name": "server.info.com",
"view": "default"
}}
<wapi_url>/record:a/ZG5zLmJpbmRfYSQu
PUT X2RlZmF1bHQuY29tLmluZm8sc2VydmVy {"name":"server1.info.com"}
LDEwLjEwLjEwLjI:server.info.com/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/record:a/ZG5zLmJpbmRfYSQuX2RlZmF1bHQuY29tLmluZm8
sc2VydmVyLDEwLjEwLjEwLjI:server.info.com/default?_return_fields%2B=name&_return_as_
object=1" -d '{"name":"server1.info.com"}'
Modify {"result":
{"_ref":
"record:a/ZG5zLmJpbmRfYSQuX2RlZmF1bHQuY29tLmluZm8sc2VydmVyMSwxMC4xMC4x
MC4y:server1.info.com/default",
"ipv4addr": "10.10.10.2",
"name": "server1.info.com",
"view": "default"
}}
<wapi_url>/record:a/ZG5zLmJpbmRfYSQu
X2RlZmF1bHQuY29tLmluZm8sc2VydmVy
DELETE
MSwxMC4xMC4xMC4y:server1.info.com/d
efault
curl -k -u admin:infoblox -H 'content-type: application/json' -X DELETE
Delete
"https://grid-master/wapi/v2.12/record:a/ZG5zLmJpbmRfYSQuX2RlZmF1bHQuY29tLmluZm8
sc2VydmVyMSwxMC4xMC4xMC4y:server1.info.com/default?_return_as_object=1"
{"result":
"record:a/ZG5zLmJpbmRfYSQuX2RlZmF1bHQuY29tLmluZm8sc2VydmVyMSwxMC4xMC4x
MC4y:server1.info.com/default"}
GET <wapi_url>/record:aaaa
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:aaaa?_return_as_object=1"
{"result":
Fetch [{"_ref":
information "record:aaaa/ZG5zLmJpbmRfYWFhYSQuX2RlZmF1bHQuY29tLnRlc3QsaG9zdCxmZDYwO
mU0NTplMzFiOjo:host.test.com/default",
"ipv6addr": "fd60:e45:e31b::",
"name": "host.test.com",
AAAA "view": "default
}]}
{"name":"server.info.com",
POST <wapi_url>/record:aaaa
"ipv6addr":"fd60:e32:f1b9::2"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
Create "https://grid-master/wapi/v2.12/record:aaaa?_return_fields%2b=name,ipv6addr&_return_as_o
bject=1" -d '{"name":"server.info.com","ipv6addr":"fd60:e32:f1b9::2"}'
{"result":
{"_ref":
20
"record:aaaa/ZG5zLmJpbmRfYWFhYSQuX2RlZmF1bHQuY29tLmluZm8sc2VydmVyLGZkNjA
6ZTMyOmYxYjk6OjI:server.info.com/default",
"ipv6addr": "fd60:e32:f1b9::2",
"name": "server.info.com",
"view": "default"
}}
<wapi_url>/record:aaaa/ZG5zLmJpbmRfY
WFhYSQuX2RlZmF1bHQuY29tLmluZm8s
PUT {"name":"server1.info.com"}
c2VydmVyLGZkNjA6ZTMyOmYxYjk6OjI:s
erver.info.com/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/record:aaaa/ZG5zLmJpbmRfYWFhYSQuX2RlZmF1bHQuY29t
LmluZm8sc2VydmVyLGZkNjA6ZTMyOmYxYjk6OjI:server.info.com/default?_return_fields%2B
=name&_return_as_object=1" -d '{"name":"server1.info.com"}'
Modify
{"result":
{"_ref":
"record:aaaa/ZG5zLmJpbmRfYWFhYSQuX2RlZmF1bHQuY29tLmluZm8sc2VydmVyMSxmZD
YwOmUzMjpmMWI5Ojoy:server1.info.com/default",
"ipv6addr": "fd60:e32:f1b9::2",
"name": "server1.info.com",
"view": "default"
}}
<wapi_url>/record:aaaa/record:aaaa/ZG5z
LmJpbmRfYWFhYSQuX2RlZmF1bHQuY2
DELETE
9tLmluZm8sc2VydmVyMSxmZDYwOmUz
MjpmMWI5Ojoy:server1.info.com/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X DELETE
Delete "https://grid-master/wapi/v2.12/record:aaaa/ZG5zLmJpbmRfYWFhYSQuX2RlZmF1bHQuY29t
LmluZm8sc2VydmVyMSxmZDYwOmUzMjpmMWI5Ojoy:server1.info.com/default?_return_as_
object=1"
{"result":
"record:aaaa/ZG5zLmJpbmRfYWFhYSQuX2RlZmF1bHQuY29tLmluZm8sc2VydmVyMSxmZD
YwOmUzMjpmMWI5Ojoy:server1.info.com/default"}
GET <wapi_url>/record:cname
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:cname?_return_as_object=1"
{"result":
Fetch [{"_ref":
information "record:cname/ZG5zLmJpbmRfY25hbWUkLl9kZWZhdWx0LmNvbS50ZXN0LnRlc3Q:test.test.
com/default",
"canonical": "cnametest.com",
"name": "test.test.com",
"view": "default"
CNAME }]}
{"name":"cnametest.demo.info.com",
POST <wapi_url>/record:cname
"canonical":"demo.info.com"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:cname?_return_fields%2B=name,canonical&_return_as
_object=1" -d '{"name":"cnametest.demo.info.com","canonical":"demo.info.com"}'
Create
{"result":
{"_ref":
"record:cname/ZG5zLmJpbmRfY25hbWUkLl9kZWZhdWx0LmNvbS5pbmZvLmRlbW8uY25hb
WV0ZXN0:cnametest.demo.info.com/default",
"canonical": "demo.info.com",
21
"name": "cnametest.demo.info.com",
"view": "default"
}}
<wapi_url>/record:cname/ZG5zLmJpbmRf
Y25hbWUkLl9kZWZhdWx0LmNvbS5pbmZ
PUT {"name":"cname.demo.info.com "}
vLmRlbW8uY25hbWV0ZXN0:cnametest.d
emo.info.com/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/record:cname/ZG5zLmJpbmRfY25hbWUkLl9kZWZhdWx0LmN
vbS5pbmZvLmRlbW8uY25hbWV0ZXN0:cnametest.demo.info.com/default?_return_fields%2B
=name&_return_as_object=1" -d '{"name":"cname.demo.info.com"}'
Modify
{"result":
{"_ref":
"record:cname/ZG5zLmJpbmRfY25hbWUkLl9kZWZhdWx0LmNvbS5pbmZvLmRlbW8uY25hb
WU:cname.demo.info.com/default",
"canonical": "demo.info.com",
"name": "cname.demo.info.com",
"view": "default"
}}
<wapi_url>/record:cname/ZG5zLmJpbmRf
Y25hbWUkLl9kZWZhdWx0LmNvbS5pbmZ
DELETE
vLmRlbW8uY25hbWU:cname.demo.info.c
om/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X DELETE
Delete
"https://grid-master/wapi/v2.12/record:cname/ZG5zLmJpbmRfY25hbWUkLl9kZWZhdWx0LmN
vbS5pbmZvLmRlbW8uY25hbWU:cname.demo.info.com/default?_return_as_object=1"
{"result":
"record:cname/ZG5zLmJpbmRfY25hbWUkLl9kZWZhdWx0LmNvbS5pbmZvLmRlbW8uY25hb
WU:cname.demo.info.com/default"}
GET <wapi_url>/record:mx
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:mx?_return_as_object=1"
{"result":
[{"_ref":
Fetch "record:mx/ZG5zLmJpbmRfbXgkLl9kZWZhdWx0LmNvbS50ZXN0Lm1haWwuaG9zdDEudGV
information zdC5jb20uMQ:mail.test.com/default",
"mail_exchanger": "host1.test.com",
"name": "mail.test.com",
"preference": 1,
"view": "default"
}]}
MX {"mail_exchanger":"exchange.info.co
POST <wapi_url>/record:mx m",
"name":"mx.info.com","preference":1}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:mx?_return_fields%2B=mail_exchanger,name&_return_
as_object=1" -d
Create '{"mail_exchanger":"exchange.info.com","name":"mx.info.com","preference":1}'
{"result":
{"_ref":
"record:mx/ZG5zLmJpbmRfbXgkLl9kZWZhdWx0LmNvbS5pbmZvLm14LmV4Y2hhbmdlLmluZ
m8uY29tLjE:mx.info.com/default",
"mail_exchanger": "exchange.info.com",
"name": "mx.info.com",
22
"preference": 1,
"view": "default"
}}
<wapi_url>/record:mx/ZG5zLmJpbmRfbXg
kLl9kZWZhdWx0LmNvbS5pbmZvLm14Lm
PUT {"name":"mail.info.com "}
V4Y2hhbmdlLmluZm8uY29tLjE:mx.info.co
m/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/record:mx/ZG5zLmJpbmRfbXgkLl9kZWZhdWx0LmNvbS5pbm
ZvLm14LmV4Y2hhbmdlLmluZm8uY29tLjE:mx.info.com/default?_return_fields%2B=name&_r
eturn_as_object=1" -d '{"name":"mail.info.com"}'
Modify {"result":
{"_ref":
"record:mx/ZG5zLmJpbmRfbXgkLl9kZWZhdWx0LmNvbS5pbmZvLm1haWwuZXhjaGFuZ2Uu
aW5mby5jb20uMQ:mail.info.com/default",
"mail_exchanger": "exchange.info.com",
"name": "mail.info.com",
"preference": 1,
"view": "default"
}}
<wapi_url>/record:mx/ZG5zLmJpbmRfbXg
kLl9kZWZhdWx0LmNvbS5pbmZvLm1haW
DELETE
wuZXhjaGFuZ2UuaW5mby5jb20uMQ:mail
.info.com/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X DELETE
Delete
"https://grid-master/wapi/v2.12/record:mx/ZG5zLmJpbmRfbXgkLl9kZWZhdWx0LmNvbS5pbm
ZvLm1haWwuZXhjaGFuZ2UuaW5mby5jb20uMQ:mail.info.com/default?_return_as_object=1"
{"result":
"record:mx/ZG5zLmJpbmRfbXgkLl9kZWZhdWx0LmNvbS5pbmZvLm1haWwuZXhjaGFuZ2Uu
aW5mby5jb20uMQ:mail.info.com/default"}
GET <wapi_url>/record:ns
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:ns?_return_as_object=1"
{"result":
[{"_ref":
"record:ns/ZG5zLmJpbmRfbnMkLl9kZWZhdWx0LmFycGEuaW4tYWRkci4xMjcuMC4wLi5jbH
VzdGVy:cluster/0.0.127.in-addr.arpa/default",
"name": "0.0.127.in-addr.arpa",
"nameserver": "cluster",
"view": "default"
},
Fetch {"_ref":
NS
information "record:ns/ZG5zLmJpbmRfbnMkLl9kZWZhdWx0LmFycGEuaXA2LjAuMC4wLjAuMC4wLjAuM
C4wLjAuMC4wLjAuMC4wLjAuMC4wLjAuMC4wLjAuMC4wLjAuMC4wLjAuMC4wLjAuMS4uY2
x1c3Rlcg:cluster/1.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.ip6.arpa/default"
,
"name": "1.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.ip6.arpa",
"nameserver": "cluster",
"view": "default"
},
……
{"_ref":
"record:ns/ZG5zLmJpbmRfbnMkLl9kZWZhdWx0LmNvbS5pbmZvLnRlc3QuaG9zdC50ZXN0L
mluZm8uY29t:host.test.info.com/test.info.com/default",
23
"name": "test.info.com",
"nameserver": "host.test.info.com",
"view": "default"
}]}
{"name":"info.com",
"nameserver":"infoblox.localdomain",
POST <wapi_url>/record:ns
"addresses":[{"address":"192.168.11.0
"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:ns?_return_fields%2B=name,nameserver,addresses&_r
eturn_as_object=1" -d
'{"name":"info.com","nameserver":"infoblox.localdomain","addresses":[{"address":"192.168.11.
0"}]}'
{"result":
Create {"_ref":
"record:ns/ZG5zLmJpbmRfbnMkLl9kZWZhdWx0LmNvbS5pbmZvLi5pbmZvYmxveC5sb2Nhb
GRvbWFpbg:infoblox.localdomain/info.com/default",
"addresses":
[{"address": "192.168.11.0",
"auto_create_ptr": true
}],
"name": "info.com",
"nameserver": "infoblox.localdomain",
"view": "default"
}}
<wapi_url>/record:ns/ZG5zLmJpbmRfbnM
kLl9kZWZhdWx0LmNvbS5pbmZvLi5pbmZ
PUT {"nameserver":"nios.info.com"}
vYmxveC5sb2NhbGRvbWFpbg:infoblox.lo
caldomain/info.com/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/record:ns/ZG5zLmJpbmRfbnMkLl9kZWZhdWx0LmNvbS5pbm
ZvLi5pbmZvYmxveC5sb2NhbGRvbWFpbg:infoblox.localdomain/info.com/default?_return_fiel
ds%2B=name,nameserver&_return_as_object=1" -d '{"nameserver":"nios.info.com"}'
Modify
{"result":
{"_ref":
"record:ns/ZG5zLmJpbmRfbnMkLl9kZWZhdWx0LmNvbS5pbmZvLi5uaW9zLmluZm8uY29t:ni
os.info.com/info.com/default",
"name": "info.com",
"nameserver": "nios.info.com",
"view": "default"
}}
<wapi_url>/record:ns/ZG5zLmJpbmRfbnM
kLl9kZWZhdWx0LmNvbS5pbmZvLi5uaW9
DELETE
zLmluZm8uY29t:nios.info.com/info.com/def
ault
curl -k -u admin:infoblox -H 'content-type: application/json' -X DELETE
Delete
"https://grid-master/wapi/v2.12/record:ns/ZG5zLmJpbmRfbnMkLl9kZWZhdWx0LmNvbS5pbm
ZvLi5uaW9zLmluZm8uY29t:nios.info.com/info.com/default?_return_as_object=1"
{"result":
"record:ns/ZG5zLmJpbmRfbnMkLl9kZWZhdWx0LmNvbS5pbmZvLi5uaW9zLmluZm8uY29t:ni
os.info.com/info.com/default"}
GET <wapi_url>/record:ptr
Fetch
PTR curl -k -u admin:infoblox -X GET
information
"https://grid-master/wapi/v2.12/record:ptr?_return_as_object=1"
24
{"result":
[{"_ref":
"record:ptr/ZG5zLmJpbmRfcHRyJC5fZGVmYXVsdC5hcnBhLmluLWFkZHIuMTI3LjAuMC4xL
mxvY2FsaG9zdA:1.0.0.127.in-addr.arpa/default",
"ptrdname": "localhost",
"view": "default"
},
{"_ref":
"record:ptr/ZG5zLmJpbmRfcHRyJC5fZGVmYXVsdC5hcnBhLmlwNi4wLjAuMC4wLjAuMC4wL
jAuMC4wLjAuMC4wLjAuMC4wLjAuMC4wLjAuMC4wLjAuMC4wLjAuMC4wLjAuMC4wLjEuLm
xvY2FsaG9zdA:1.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.ip6.arpa/default",
"ptrdname": "localhost",
"view": "default"
},
……
{"_ref":
"record:ptr/ZG5zLmJpbmRfcHRyJC5fZGVmYXVsdC5hcnBhLmluLWFkZHIuMTcyLjI2LjEuMTA
wLmhvc3QudGVzdC5pbmZvLmNvbQ:100.1.26.172.in-addr.arpa/default",
"ptrdname": "host.test.info.com",
"view": "default"
}]}
{"name":"2.10.10.10.in-addr.arpa",
POST <wapi_url>/record:ptr "ptrdname":"server1.info.com",
"ipv4addr":"10.10.10.2"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:ptr?_return_fields%2B=name,ptrdname,ipv4addr&_retu
rn_as_object=1" -d '{"name":"2.10.10.10.in-addr.arpa",
"ptrdname":"server1.info.com","ipv4addr":"10.10.10.2"}'
Create {"result":
{"_ref":
"record:ptr/ZG5zLmJpbmRfcHRyJC5fZGVmYXVsdC5hcnBhLmluLWFkZHIuMTAuMTAuMTAu
Mi5zZXJ2ZXIuaW5mby5jb20:2.10.10.10.in-addr.arpa/default",
"ipv4addr": "10.10.10.2",
"name": "2.10.10.10.in-addr.arpa",
"ptrdname": "server1.info.com",
"view": "default"
}}
<wapi_url>/record:ptr/ZG5zLmJpbmRfcHR
yJC5fZGVmYXVsdC5hcnBhLmluLWFkZHI
PUT {"ptrdname":"server.info.com"}
uMTAuMTAuMTAuMi5zZXJ2ZXIuaW5mby
5jb20:2.10.10.10.in-addr.arpa/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/record:ptr/ZG5zLmJpbmRfcHRyJC5fZGVmYXVsdC5hcnBhLm
luLWFkZHIuMTAuMTAuMTAuMi5zZXJ2ZXIuaW5mby5jb20:2.10.10.10.in-addr.arpa/default?_r
Modify eturn_fields%2B=ptrdname&_return_as_object=1" -d '{"ptrdname":"server.info.com"}'
{"result":
{"_ref":
"record:ptr/ZG5zLmJpbmRfcHRyJC5fZGVmYXVsdC5hcnBhLmluLWFkZHIuMTAuMTAuMTAu
Mi5zZXJ2ZXIuaW5mby5jb20:2.10.10.10.in-addr.arpa/default",
"ptrdname": "server.info.com",
"view": "default"
}}
<wapi_url>/record:ptr/ZG5zLmJpbmRfcHR
Delete DELETE
yJC5fZGVmYXVsdC5hcnBhLmluLWFkZHI
25
uMTAuMTAuMTAuMi5zZXJ2ZXIuaW5mby
5jb20:2.10.10.10.in-addr.arpa/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X DELETE
"https://grid-master/wapi/v2.12/record:ptr/ZG5zLmJpbmRfcHRyJC5fZGVmYXVsdC5hcnBhLm
luLWFkZHIuMTAuMTAuMTAuMi5zZXJ2ZXIuaW5mby5jb20:2.10.10.10.in-addr.arpa/default?_r
eturn_as_object=1"
{"result":
"record:ptr/ZG5zLmJpbmRfcHRyJC5fZGVmYXVsdC5hcnBhLmluLWFkZHIuMTAuMTAuMTAu
Mi5zZXJ2ZXIuaW5mby5jb20:2.10.10.10.in-addr.arpa/default"}
GET <wapi_url>/record:txt
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:txt?_return_as_object=1"
{"result":
Fetch [{"_ref":
information "record:txt/ZG5zLmJpbmRfdHh0JC5fZGVmYXVsdC5jb20udGVzdC5tYWlsLiJUaGlzIiAiYSIgI
m1haWwiICJzZXJ2ZXIi:mail.test.com/default",
"name": "mail.test.com",
"text": "This a mail server",
"view": "default"
}]}
{"name":"server.info.com",
POST <wapi_url>/record:txt
"text":"This a host server"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:txt?_return_fields%2B=name,text&_return_as_object=1
" -d '{"name":"server.info.com","text":"This a host server"}'
{"result":
Create {"_ref":
"record:txt/ZG5zLmJpbmRfdHh0JC5fZGVmYXVsdC5jb20uaW5mby5zZXJ2ZXIuIlRoaXMiICJ
hIiAiaG9zdCIgInNlcnZlciI:server.info.com/default",
"name": "server.info.com",
TXT "text": "This a host server",
"view": "default"
}}
<wapi_url>/record:txt/ZG5zLmJpbmRfdHh
0JC5fZGVmYXVsdC5jb20uaW5mby5zZXJ
PUT {"text":"This is a test server"}
2ZXIuIlRoaXMiICJhIiAiaG9zdCIgInNlcnZlci
I:server.info.com/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/record:txt/ZG5zLmJpbmRfdHh0JC5fZGVmYXVsdC5jb20uaW5
mby5zZXJ2ZXIuIlRoaXMiICJhIiAiaG9zdCIgInNlcnZlciI:server.info.com/default?_return_fields
%2B=text&_return_as_object=1" -d '{"text":"This a test server"}'
Modify
{"result":
{"_ref":
"record:txt/ZG5zLmJpbmRfdHh0JC5fZGVmYXVsdC5jb20uaW5mby5zZXJ2ZXIuIlRoaXMiICJ
hIiAidGVzdCIgInNlcnZlciI:server.info.com/default",
"name": "server.info.com",
"text": "This a test server",
"view": "default"
}}
<wapi_url>/record:txt/ZG5zLmJpbmRfdHh
0JC5fZGVmYXVsdC5jb20uaW5mby5zZXJ
Delete DELETE
2ZXIuIlRoaXMiICJhIiAiaG9zdCIgInNlcnZlci
I:server.info.com/default
26
curl -k -u admin:infoblox -H 'content-type: application/json' -X DELETE
"https://grid-master/wapi/v2.12/record:txt/ZG5zLmJpbmRfdHh0JC5fZGVmYXVsdC5jb20uaW5
mby5zZXJ2ZXIuIlRoaXMiICJhIiAidGVzdCIgInNlcnZlciI:server.info.com/default?_return_as_ob
ject=1"
{"result":
"record:txt/ZG5zLmJpbmRfdHh0JC5fZGVmYXVsdC5jb20uaW5mby5zZXJ2ZXIuIlRoaXMiICJ
hIiAidGVzdCIgInNlcnZlciI:server.info.com/default"}
GET <wapi_url>/record:srv
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:srv?_return_as_object=1"
{"result":
[{"_ref":
"record:srv/ZG5zLmJpbmRfc3J2JC5fZGVmYXVsdC5jb20udGVzdC9fdGNwLl9zc2gvMS8xMC
Fetch 8yMi90ZXN0LmNvbQ:_ssh._tcp.test.com/default",
information "name": "_ssh._tcp.test.com",
"port": 22,
"priority": 1,
"target": "test.com",
"view": "default",
"weight": 10
}]}
{"name": "_ssh._tcp.info.com",
"port": 22,
POST <wapi_url>/record:srv "priority": 10,
"target": "info.com",
"weight": 10}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:srv?_return_fields%2B=name,target&_return_as_object
=1" -d '{"name": "_ssh._tcp.info.com","port": 22,"priority": 10,"target": "info.com","weight": 10}'
{"result":
SRV Create {"_ref":
"record:srv/ZG5zLmJpbmRfc3J2JC5fZGVmYXVsdC5jb20uaW5mby9fdGNwLl9zc2gvMTAvMT
AvMjIvaW5mby5jb20:_ssh._tcp.info.com/default",
"name": "_ssh._tcp.info.com",
"port": 22,
"priority": 10,
"target": "info.com",
"view": "default",
"weight": 10
}}
<wapi_url>/record:srv/ZG5zLmJpbmRfc3J
2JC5fZGVmYXVsdC5jb20uaW5mby9fdGN
PUT {"priority": 20}
wLl9zc2gvMTAvMTAvMjIvaW5mby5jb20:_
ssh._tcp.info.com/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/record:srv/ZG5zLmJpbmRfc3J2JC5fZGVmYXVsdC5jb20uaW5
mby9fdGNwLl9zc2gvMTAvMTAvMjIvaW5mby5jb20:_ssh._tcp.info.com/default?_return_fields
Modify
%2B=priority&_return_as_object=1" -d '{"priority": 20}'
{"result":
{"_ref":
"record:srv/ZG5zLmJpbmRfc3J2JC5fZGVmYXVsdC5jb20uaW5mby9fdGNwLl9zc2gvMjAvMT
AvMjIvaW5mby5jb20:_ssh._tcp.info.com/default",
"name": "_ssh._tcp.info.com",
"port": 22,
27
"priority": 20,
"target": "info.com",
"view": "default",
"weight": 10
}}
<wapi_url>/record:srv/ZG5zLmJpbmRfc3J
2JC5fZGVmYXVsdC5jb20uaW5mby9fdGN
DELETE
wLl9zc2gvMjAvMTAvMjIvaW5mby5jb20:_s
sh._tcp.info.com/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X DELETE
Delete "https://grid-master/wapi/v2.12/record:srv/ZG5zLmJpbmRfc3J2JC5fZGVmYXVsdC5jb20uaW5
mby9fdGNwLl9zc2gvMjAvMTAvMjIvaW5mby5jb20:_ssh._tcp.info.com/default?_return_as_obj
ect=1"
{"result":
"record:srv/ZG5zLmJpbmRfc3J2JC5fZGVmYXVsdC5jb20uaW5mby9fdGNwLl9zc2gvMjAvMT
AvMjIvaW5mby5jb20:_ssh._tcp.info.com/default"}
Retrieve all the records in a zone
The API function allrecords returns the following types of records within a particular zone:
● record:a
● record:aaaa
● record:cname
● record:dname
● record:host
● record:host_ipv4addr
● record:host_ipv6addr
● record:mx
● record:naptr
● record:ptr
● record:srv
● record:txt
● record:unknown
● sharedrecord:a
● sharedrecord:aaaa
● sharedrecord:mx
● sharedrecord:srv
● sharedrecord:txt
For the other types of records, it returns “UNSUPPORTED”.
REST
API Call
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/allrecords?zone=info.com
curl -k -u admin:infoblox -X GET
Retrieve all "https://grid-master/wapi/v2.12/allrecords?zone=info.com&_return_as_object=1"
records in a {"result":
zone [{"_ref":
"allrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX3NvYSQuX2RlZmF1bHQuY29tLmluZ
m8:",
28
"comment": "Auto-created by Add Zone",
"name": "",
"type": "UNSUPPORTED",
"view": "default",
"zone": "info.com"
},
{"_ref":
"allrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX25zJC5fZGVmYXVsdC5jb20uaW5mby
4uaW5mb2Jsb3gubG9jYWxkb21haW4:",
"comment": "Auto-created by Add Zone",
"name": "",
"type": "UNSUPPORTED",
"view": "default",
"zone": "info.com"
},
{"_ref":
"allrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5ob3N0JC5fZGVmYXVsdC5jb20uaW5mby5ob3
N0:host",
"comment": "",
"name": "host",
"type": "record:host_ipv4addr",
"view": "default",
"zone": "info.com"
},
{"_ref":
"allrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX2EkLl9kZWZhdWx0LmNvbS5pbmZvL
HNlcnZlciwxMC4xMC4xMC4y:server",
"comment": "",
"name": "server",
"type": "record:a",
"view": "default",
"zone": "info.com"
},
{"_ref":
"allrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX2FhYWEkLl9kZWZhdWx0LmNvbS5pb
mZvLHNlcnZlcixmZDYwOmUzMjpmMWI5Ojoy:server",
"comment": "",
"name": "server",
"type": "record:aaaa",
"view": "default",
"zone": "info.com"
},
{"_ref":
"allrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5ob3N0JC5fZGVmYXVsdC5jb20uaW5mby50Z
XN0:test",
"comment": "",
"name": "test",
"type": "record:host_ipv4addr",
"view": "default",
"zone": "info.com"
}]}
Retrieve non-system generated records
Records have a creator field. The possible values for this field are SYSTEM, STATIC and DYNAMIC. You
can either fetch STATIC and DYNAMIC records separately, or combine them in a Multiple Object Body
request as shown in the section Multiple Object Body Feature using /request
29
Run a GET request on the records by passing creator as the parameter.
REST
API Call
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/record:a?creator=STATIC
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:a?creator=STATIC&_return_fields%2B=creator&_return_as_object
=1"
{"result":
[{"_ref":
"record:a/ZG5zLmJpbmRfYSQuX2RlZmF1bHQuY29tLmluZm8sc2VydmVyLDEwLjEwLjEwLjI:server.info.
com/default",
Retrieve "creator": "STATIC",
non-system "ipv4addr": "10.10.10.2",
generated A "name": "server.info.com",
records "view": "default"
},
{"_ref":
"record:a/ZG5zLmJpbmRfYSQuX2RlZmF1bHQuY29tLmRlbW8scHJpbnQsMTAuMTAuTAuMjE:print.dem
o.com/default",
"creator": "STATIC",
"ipv4addr": "10.10.10.21",
"name": "print.demo.com",
"view": "default"
}]}
GET <wapi_url>/allrecords?zone=demo001.com&creator=STATIC
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/allrecords?zone=demo001.com&creator=STATIC&_return_fields%2B=cre
ator&_return_as_object=1"
{"result":
[{"_ref":
Retrieve "allrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5ob3N0JC5fZGVmYXVsdC5jb20uZGVtbzAwM
non-system S5ob3N0MDAx:host001",
"comment": "",
generated "name": "host001",
records of all "type": "record:host_ipv4addr",
types within "view": "default",
zone "zone": "demo001.com"},
demo001.com {"_ref":
"allrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX2EkLl9kZWZhdWx0LmNvbS5kZW1vM
DAxLGhvc3QwMDIsMTAuMC4wLjI:host002",
"comment": "",
"name": "host002",
"type": "record:a",
"view": "default",
"zone": "demo001.com"}]}
30
Search for a record based on some criteria
Run a GET request on host/A records by passing required criteria as the parameter
REST
API Call
Method
Operation
Sample cURL Command
Sample Output
<wapi_url>/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS50ZXN0Lmhvc3Qx:host1.test
GET
.com/default
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS50ZXN0Lmhvc3Qx:
host1.test.com/default?_return_as_object=1"
{"result":
{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS50ZXN0Lmhvc3Qx:host1.test.com/default",
Retrieve host by "ipv4addrs":
object reference [{ "_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLnRlc3QuaG9zdDEuMTcyL
jI2LjEuMjAwLg:172.26.1.200/host1.test.com/default",
"configure_for_dhcp": false,
"host": "host1.test.com",
"ipv4addr": "172.26.1.200"
}],
"name": "host1.test.com",
"view": "default"
}}
GET <wapi_url>/record:host?name=host1.info.com
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:host?name=host1.info.com&_return_as_object=1"
{"result":
[{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLmhvc3Qx:host1.info.com/default",
"ipv4addrs":
Search host by [{"_ref":
name "record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8uaG9zdDEuMTAu
MTAuMTAuMjAu:10.10.10.20/host1.info.com/default",
"configure_for_dhcp": false,
"host": "host1.info.com",
"ipv4addr": "10.10.10.20"
}],
"name": "host1.info.com",
"view": "default"
}]}
GET <wapi_url>/record:host?_return_fields%2B=extattrs&*Location:=Santa%20Clara
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:host?_return_fields%2B=extattrs&*Location%3A=Santa%20Clara
Search host by &_return_as_object=1"
EA (Location is {"result":
set to Santa [{"_ref":
Clara) "record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS50ZXN0Lmhvc3Qx:host1.test.com/default",
"extattrs":
{"Location":
{"value": "Santa Clara"}
31
},
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLnRlc3QuaG9zdDEuMTcyL
jI2LjEuMjAwLg:172.26.1.200/host1.test.com/default",
"configure_for_dhcp": false,
"host": "host1.test.com",
"ipv4addr": "172.26.1.200"
}],
"name": "host1.test.com",
"view": "default"
}]}
GET <wapi_url>/record:host?ipv4addr>=10.10.10.100&ipv4addr<=10.10.10.102
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:host?ipv4addr>=10.10.10.100&ipv4addr<=10.10.10.102&_return_
as_object=1"
{"result":
[{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5hYmMuaG9zdC0x:host-1.abc.com/default",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmFiYy5ob3N0LTEuMTAu
MTAuMTAuMTAxLg:10.10.10.101/host-1.abc.com/default",
"configure_for_dhcp": false,
"host": "host-1.abc.com",
"ipv4addr": "10.10.10.101"}],
"name": "host-1.abc.com",
"view": "default" },
{"_ref":
Search host by "record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5hYmMuaG9zdC0y:host-2.abc.com/default",
IP address "ipv4addrs":
range [{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmFiYy5ob3N0LTIuMTAuM
TAuMTAuMTAyLg:10.10.10.102/host-2.abc.com/default",
"configure_for_dhcp": false,
"host": "host-2.abc.com",
"ipv4addr": "10.10.10.102" }],
"name": "host-2.abc.com",
"view": "default"},
{"_ref": "record:host/ZG5zLmhvc3QkLl9kZWZhdWx0Lm5ldC54eXoudGVzdA:test.xyz.net/default",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQubmV0Lnh5ei50ZXN0LjEwLjEwLj
EwLjEwMC4:10.10.10.100/test.xyz.net/default",
"configure_for_dhcp": false,
"host": "test.xyz.net",
"ipv4addr": "10.10.10.100"}],
"name": "test.xyz.net",
"view": "default" }]}
GET <wapi_url>/record:host?network=10.10.10.0/24
curl -k -u admin:infoblox -X GET
Search host by "https://grid-master/wapi/v2.12/record:host?network=10.10.10.0/24&_return_as_object=1"
subnet {"result":
[{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5hYmMuaG9zdC0x:host-1.abc.com/default",
32
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmFiYy5ob3N0LTEuMTAu
MTAuMTAuMTAxLg:10.10.10.101/host-1.abc.com/default",
"configure_for_dhcp": false,
"host": "host-1.abc.com",
"ipv4addr": "10.10.10.101"}],
"name": "host-1.abc.com",
"view": "default" },
…….
{"_ref": "record:host/ZG5zLmhvc3QkLl9kZWZhdWx0Lm5ldC54eXoudGVzdA:test.xyz.net/default",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQubmV0Lnh5ei50ZXN0LjEwLjEwLj
EwLjEwMC4:10.10.10.100/test.xyz.net/default",
"configure_for_dhcp": false,
"host": "test.xyz.net",
"ipv4addr": "10.10.10.100"}],
"name": "test.xyz.net",
"view": "default" }]}
<wapi_url>/record:a/ZG5zLmJpbmRfYSQuX2RlZmF1bHQuY29tLmluZm8sc2VydmVyLDEwLj
GET
EwLjEwLjI:server.info.com/default
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:a/ZG5zLmJpbmRfYSQuX2RlZmF1bHQuY29tLmluZm8sc2VydmV
yLDEwLjEwLjEwLjI:server.info.com/default?_return_as_object=1"
Get A record {"result":
using object {"_ref":
reference "record:a/ZG5zLmJpbmRfYSQuX2RlZmF1bHQuY29tLmluZm8sc2VydmVyLDEwLjEwLjEwLjI:server.info.
com/default",
"ipv4addr": "10.10.10.2",
"name": "server.info.com",
"view": "default"
}}
The third example uses the _return_fields+ to specify the Extensible Attribute (EA) as an extra attribute. Also,
prepend ‘*’ to the front of the EA name.
The first example lists all A records that contain info.com in their name. The second example lists all zones that
start with an “i” and contain “lo”. The regular expression for this will be ^i.*lo.*$
Remember to specify the ~ modifier to indicate you are querying with a regular expression.
REST
API Call
Method
Operation
Sample cURL Command
Sample Output
Search for A GET <wapi_url>/record:a?name~=info.com&_return_fields=name
records that contain
33
info.com in the curl -k -u admin:infoblox -X GET
name "https://grid-master/wapi/v2.12/record:a?name~=info.com&_return_fields=name&_return_as_object=
1"
{"result":
[{"_ref":
"record:a/ZG5zLmJpbmRfYSQuX2RlZmF1bHQuY29tLmluZm8sc2VydmVyLDEwLjEwLjEwLjI:server.i
nfo.com/default",
"name": "server.info.com"
},
{"_ref":
"record:a/ZG5zLmJpbmRfYSQuX2RlZmF1bHQuY29tLmluZm8sdGVzdC5ob3N0LDE3Mi4yNi4xLjEw
MA:host.test.info.com/default",
"name": "host.test.info.com"
}]}
GET <wapi_url>/zone_auth?fqdn~=^i.*lo.*$&_return_fields=fqdn
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/zone_auth?fqdn~=^i.*lo.*$&_return_fields=fqdn&_return_as_object=1"
{"result":
[{"_ref": "zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmZvYmxveA:infoblox.com/default",
Search for zones "fqdn": "infoblox.com"
that start with an “i” },
and contain “lo” {"_ref":
"zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmZvcm1ibG94:informblox.com/default",
"fqdn": "informblox.com"
},
{"_ref": "zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmdsbw:inglo.com/default",
"fqdn": "inglo.com"
}]}
Aliases for a host
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
<wapi_url>/record:host?_return_fields%2B=aliases&name=print
GET
er.info.com
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:host?_return_fields%2B=aliases&name=printer.info.com&_return_
as_object=1"
{"result":
[{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLnByaW50ZXI:printer.info.com/default",
"aliases":
Get all the ["scanner.info.com"],
aliases on a host "ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8ucHJpbnRlci4xNj
AuMjAuMS4xMDAu:160.20.1.100/printer.info.com/default",
"configure_for_dhcp": false,
"host": "printer.info.com",
"ipv4addr": "160.20.1.100"
}],
"name": "printer.info.com",
"view": "default"
}]}
34
{"name":"wapialias.info.com"
,
"ipv4addrs":
POST <wapi_url>/record:host
[{"ipv4addr":"172.26.1.2"}],
"aliases": [
"remote","pointer"]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:host?_return_fields%2B=aliases&_return_as_object=1" -d
'{"name":"wapialias.info.com","ipv4addrs": [{"ipv4addr":"172.26.1.2"}],"aliases": [ "remote","pointer"]}'
{"result":
{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLndhcGlhbGlhcw:wapialias.info.com/defau
lt",
Add a host with "aliases":
aliases ["remote.info.com",
"pointer.info.com"
],
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8ud2FwaWFsaWF
zLjE3Mi4yNi4xLjIu:172.26.1.2/wapialias.info.com/default",
"configure_for_dhcp": false,
"host": "wapialias.info.com",
"ipv4addr": "172.26.1.2"
}],
"name": "wapialias.info.com",
"view": "default"
}}
<wapi_url>/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS
PUT {"aliases": ["local"]}
5pbmZvLndhcGlhbGlhcw:wapialias.info.com/default
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLndhcGlhb
Glhcw:wapialias.info.com/default?_return_fields%2B=aliases&_return_as_object=1" -d '{"aliases":
["local"]}'
{"result":
{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLndhcGlhbGlhcw:wapialias.info.com/defau
lt",
Modify aliases "aliases":
on a host ["local.info.com"],
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8ud2FwaWFsaWF
zLjE3Mi4yNi4xLjIu:172.26.1.2/wapialias.info.com/default",
"configure_for_dhcp": false,
"host": "wapialias.info.com",
"ipv4addr": "172.26.1.2"
}],
"name": "wapialias.info.com",
"view": "default"
}}
Remove aliases <wapi_url>/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS
PUT {"aliases": [ ]}
from a host 5pbmZvLndhcGlhbGlhcw:wapialias.info.com/default
35
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLndhcGlhb
Glhcw:wapialias.info.com/default?_return_fields%2B=aliases&_return_as_object=1" -d '{"aliases": [ ]}'
{"result":
{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLndhcGlhbGlhcw:wapialias.info.com/defau
lt",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8ud2FwaWFsaWF
zLjE3Mi4yNi4xLjIu:172.26.1.2/wapialias.info.com/default",
"configure_for_dhcp": false,
"host": "wapialias.info.com",
"ipv4addr": "172.26.1.2"
}],
"name": "wapialias.info.com",
"view": "default"
}}
Change the IP address of a host
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
<wapi_url>/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvb {"ipv4addrs":
PUT
S50ZXN0Lmhvc3Qx:host1.test.com/default [{"ipv4addr": "172.26.1.21"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS50ZXN0Lmhvc3Qx:
host1.test.com/default?_return_fields%2B=ipv4addrs&_return_as_object=1" -d '{"ipv4addrs":[{"ipv4addr":
"172.26.1.21"}]}'
{"result":
{"_ref":
Change IP "record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS50ZXN0Lmhvc3Qx:host1.test.com/default",
address of a "ipv4addrs":
host [{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLnRlc3QuaG9zdDEuMTcyL
jI2LjEuMjEu:172.26.1.21/host1.test.com/default",
"configure_for_dhcp": false,
"host": "host1.test.com",
"ipv4addr": "172.26.1.21"
}],
"name": "host1.test.com",
"view": "default"
}}
36
Add or remove IP addresses from a host
To add or remove IP address from a host record without altering the original list, use ipv4addrs+ or ipv4addrs-
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
{"ipv4addrs+":
<wapi_url>/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvb
PUT [{"ipv4addr": "192.168.1.21"},
S50ZXN0Lmhvc3Qx:host1.test.com/default
{"ipv4addr": "10.10.10.21"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS50ZXN0Lmhvc3Qx:h
ost1.test.com/default?_return_fields%2B=ipv4addrs&_return_as_object=1" -d
'{"ipv4addrs+":[{"ipv4addr":"192.168.1.21"},{"ipv4addr":"10.10.10.21"}]}'
{"result":
{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS50ZXN0Lmhvc3Qx:host1.test.com/default",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLnRlc3QuaG9zdDEuMTcyLj
I2LjEuMjEu:172.26.1.21/host1.test.com/default",
"configure_for_dhcp": false,
"host": "host1.test.com",
Add IP address "ipv4addr": "172.26.1.21"
to a host record },
{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLnRlc3QuaG9zdDEuMTkyL
jE2OC4xLjIxLg:192.168.1.21/host1.test.com/default",
"configure_for_dhcp": false,
"host": "host1.test.com",
"ipv4addr": "192.168.1.21"
},
{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLnRlc3QuaG9zdDEuMTAu
MTAuMTAuMjEu:10.10.10.21/host1.test.com/default",
"configure_for_dhcp": false,
"host": "host1.test.com",
"ipv4addr": "10.10.10.21"
}],
"name": "host1.test.com",
"view": "default"
}}
{"ipv4addrs-”:
<wapi_url>/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvb
PUT [{"ipv4addr":
S50ZXN0Lmhvc3Qx:host1.test.com/default
"192.168.1.21"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS50ZXN0Lmhvc3Qx:h
Remove IP
ost1.test.com/default?_return_fields%2B=ipv4addrs&_return_as_object=1" -d
address from a
'{"ipv4addrs-":[{"ipv4addr":"192.168.1.21"}]}'
host record
{"result":
{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS50ZXN0Lmhvc3Qx:host1.test.com/default",
"ipv4addrs":
[{"_ref":
37
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLnRlc3QuaG9zdDEuMTcyLj
I2LjEuMjEu:172.26.1.21/host1.test.com/default",
"configure_for_dhcp": false,
"host": "host1.test.com",
"ipv4addr": "172.26.1.21"
},
{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLnRlc3QuaG9zdDEuMTAu
MTAuMTAuMjEu:10.10.10.21/host1.test.com/default",
"configure_for_dhcp": false,
"host": "host1.test.com",
"ipv4addr": "10.10.10.21"
}],
"name": "host1.test.com",
"view": "default"
}}
Add a host with the next available IP address from a network
Use the function next_available_ip by specifying it in the option _function. You can use it in the longhand form
or the shorthand form(func). The following example also covers the different forms func supports in shorthand.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
{"name":"wapi.info.com",
"ipv4addrs":
[{"ipv4addr":{"_object_function":"next_available_ip",
POST <wapi_url>/record:host "_parameters":{"exclude":["10.10.10.1","10.10.10.2"]},
"_result_field":"ips",
"_object" : "network",
"_object_parameters":{"network":"10.10.10.0/24"}}}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:host?_return_fields%2B=name,ipv4addrs&_return_as_object=1 "
-d
'{"name":"wapi.info.com","ipv4addrs":[{"ipv4addr":{"_object_function":"next_available_ip","_parameters"
:{"exclude":["10.10.10.1","10.10.10.2"]},"_result_field":"ips","_object" :
"network","_object_parameters":{"network":"10.10.10.0/24"}}}]}'
Add host with next {"result":
available IP {"_ref": "record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLndhcGk:wapi.info.com/default",
address from a "ipv4addrs":
network [{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8ud2FwaS4xMC4
xMC4xMC4zLg:10.10.10.3/wapi.info.com/default",
"configure_for_dhcp": false,
"host": "wapi.info.com",
"ipv4addr": "10.10.10.3"
}],
"name": "wapi.info.com",
"view": "default"
}}
{"name": "wapi.info.com",
POST <wapi_url>/record:host "ipv4addrs":[{"ipv4addr":
"func:nextavailableip:10.10.10.0/24"}]}
38
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:host?_return_fields%2B=name,ipv4addrs&_return_as_object=1 "
-d '{"name": "wapi.info.com","ipv4addrs":[{"ipv4addr":"func:nextavailableip:10.10.10.0/24"}]}'
{"result":
{"_ref": "record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLndhcGk:wapi.info.com/default",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8ud2FwaS4xMC4
xMC4xMC4xLg:10.10.10.10/wapi.info.com/default",
"configure_for_dhcp": false,
"host": "wapi.info.com",
"ipv4addr": "10.10.10.10"
}],
"name": "wapi.info.com",
"view": "default"
}}
{"name":"wapi.info.com",
"ipv4addrs": [{"ipv4addr":
POST <wapi_url>/record:host
"func:nextavailableip:network/ZG5zLm5ldHdvcmskMTkyLjE2OC
4xLjAvMjQvMA:192.168.1.0/24/default"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:host?_return_fields%2B=name,ipv4addrs&_return_as_object=1 "
-d
'{"name":"wapi.info.com","ipv4addrs":[{"ipv4addr":"func:nextavailableip:network/ZG5zLm5ldHdvcmskM
TkyLjE2OC4xLjAvMjQvMA:192.168.1.0/24/default "}]}'
{"result":
{"_ref": "record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLndhcGk:wapi.info.com/default",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8ud2FwaS4xOTI
uMTY4LjEuMS4:192.168.1.5/wapi.info.com/default",
"configure_for_dhcp": false,
"host": "wapi.info.com",
"ipv4addr": "192.168.1.5"
}],
"name": "wapi.info.com",
"view": "default"
}}
{"name": "wapi.info.com",
POST <wapi_url>/record:host "ipv4addrs": [{"ipv4addr":
"func:nextavailableip:172.21.10.0/24,default"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:host?_return_fields%2B=name,ipv4addrs&_return_as_object=1 "
-d '{"name": "wapi.info.com","ipv4addrs": [{"ipv4addr":"func:nextavailableip:172.21.10.0/24,default"}]}'
{"result":
{"_ref": "record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLndhcGk:wapi.info.com/default",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8ud2FwaS4xNzIu
MjEuMTAuMS4:172.21.10.1/wapi.info.com/default",
"configure_for_dhcp": false,
"host": "wapi.info.com",
"ipv4addr": "172.21.10.1"
}],
"name": "wapi.info.com",
39
"view": "default"
}}
{"name": "wapi.info.com",
POST <wapi_url>/record:host "ipv4addrs": [{"ipv4addr":
"func:nextavailableip: 192.168.1.10-192.168.1.15"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:host?_return_fields%2B=name,ipv4addrs&_return_as_object=1 "
-d '{"name": "wapi.info.com","ipv4addrs": [{"ipv4addr":"func:nextavailableip:
192.168.1.10-192.168.1.15"}]}'
{"result":
{"_ref": "record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLndhcGk:wapi.info.com/default",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8ud2FwaS4xOTI
uMTY4LjEuMTAu:192.168.1.10/wapi.info.com/default",
"configure_for_dhcp": false,
"host": "wapi.info.com",
"ipv4addr": "192.168.1.10"
}],
"name": "wapi.info.com",
"view": "default"
}}
{"name":"wapi.info.com",
"ipv4addrs":[{"ipv4addr" : {"_object_function":"next_available_ip",
"_result_field":"ips",
POST <wapi_url>/record:host "_object":"network",
"_object_parameters":{"*Region" : "EMEA"},
"_parameters":{"exclude":["10.0.0.1","10.0.0.2"]}},
"use_for_ea_inheritance":true}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:host?_return_fields%2B=name,ipv4addrs&_return_as_object=1 "
-d
'{"name":"wapi.info.com","ipv4addrs":[{"ipv4addr":{"_object_function":"next_available_ip","_result_field":
Add host with next
"ips","_object":"network","_object_parameters":{"*Region" :
available IP from
"EMEA"},"_parameters":{"exclude":["10.0.0.1","10.0.0.2"]}},"use_for_ea_inheritance":true}]}'
a network using a
complex search {"result":
(using Extensible {"_ref": "record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLndhcGk:wapi.info.com/default",
Attributes) and "ipv4addrs":
inherit the EAs [{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8ud2FwaS4xMC4
wLjAuMy4:10.0.0.3/wapi.info.com/default",
"configure_for_dhcp": false,
"host": "wapi.info.com",
"ipv4addr": "10.0.0.3"
}],
"name": "wapi.info.com",
"view": "default"
}}
Similarly, you can create an A record or AAAA record with the next available IP address from a network.
40
Add a host with a fixed address
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
{"name":"host.info.com",
"ipv4addrs":
POST <wapi_url>/record:host
[{"ipv4addr":"172.26.1.20",
"mac":"aa:bb:cc:11:22:21"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:host?_return_fields%2B=name,ipv4addrs&_return_as_object=1"
-d '{"name":"host.info.com","ipv4addrs":[{"ipv4addr":"172.26.1.20","mac":"aa:bb:cc:11:22:21"}]}'
{"result":
{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLmhvc3Q:host.info.com/default",
Add a host with a "ipv4addrs":
fixed address [{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8uaG9zdC4xNzI
uMjYuMS4yMC4:172.26.1.20/host.info.com/default",
"configure_for_dhcp": true,
"host": "host.info.com",
"ipv4addr": "172.26.1.20",
"mac": "aa:bb:cc:11:22:21"
}],
"name": "host.info.com",
"view": "default"
}}
Add Extensible Attributes to an object
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
<wapi_url>/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNv {"extattrs":
PUT
bS5pbmZvLndhcGk:wapi.info.com/default {"Site": {"value": "East"}}}
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLndhcGk:
wapi.info.com/default?_return_fields%2B=extattrs&_return_as_object=1" -d '{"extattrs":{"Site": {"value":
"East"}}}'
{"result":
{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLndhcGk:wapi.info.com/default",
Add an extensible "extattrs":
attribute {"Site": {"value": "East"}
},
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8ud2FwaS4xMC
4wLjAuMy4:10.0.0.3/wapi.info.com/default",
"configure_for_dhcp": false,
"host": "wapi.info.com",
"ipv4addr": "10.0.0.3"
}],
"name": "wapi.info.com",
41
"view": "default"
}}
TTL
By default, the TTL is inherited from the Grid.
To override the default settings, while modifying TTL at the zone level, specify the TTL value in the
soa_default_ttl field and also set the use_grid_zone_timer field to true. When this is set to false, the
soa_default_ttl value indicates the default ttl.While modifying at the record level, remember to set the use_ttl
flag to true. Otherwise, the value will be inherited from a higher-level setting.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/grid:dns?_return_fields%2B=default_ttl
curl -k -u admin:infoblox -X GET
Fetch the default "https://grid-master/wapi/v2.12/grid:dns?_return_fields%2B=default_ttl&_return_as_object=1"
grid-wide TTL {"result":
value [{"_ref": "grid:dns/ZG5zLmNsdXN0ZXJfZG5zX3Byb3BlcnRpZXMkMA:Infoblox",
"default_ttl": 28800
}]}
<wapi_url>/zone_auth?fqdn=info.com&_return_fields%2B=use
GET
_grid_zone_timer,soa_default_ttl
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/zone_auth?fqdn=info.com&_return_fields%2B=use_grid_zone_timer,so
a_default_ttl&_return_as_object=1"
Fetch TTL for a {"result":
zone [{"_ref": "zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmZv:info.com/default",
"fqdn": "info.com",
"soa_default_ttl": 28800,
"use_grid_zone_timer": false,
"view": "default"
}]}
<wapi_url>/zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvb {"use_grid_zone_timer":true,
PUT
S5pbmZv:info.com/default "soa_default_ttl":5000}
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmZv:info.com/d
efault?_return_fields%2B=use_grid_zone_timer,soa_default_ttl&_return_as_object=1" -d
'{"use_grid_zone_timer":true,"soa_default_ttl":5000}'
Modify TTL for a
zone {"result":
{"_ref": "zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmZv:info.com/default",
"fqdn": "info.com",
"soa_default_ttl": 5000,
"use_grid_zone_timer": true,
"view": "default"
}}
<wapi_url>/record:txt/ZG5zLmJpbmRfdHh0JC5fZGVmYXVsd
{"use_ttl": true,
PUT C5jb20udGVzdC5tYWlsLiJUaGlzIiAiYSIgIm1haWwiICJzZXJ2
Modify TTL for a "ttl":3600}
ZXIi:mail.test.com/default
record
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/record:txt/ZG5zLmJpbmRfdHh0JC5fZGVmYXVsdC5jb20udGVzdC5tY
42
WlsLiJUaGlzIiAiYSIgIm1haWwiICJzZXJ2ZXIi:mail.test.com/default?_return_fields%2B=ttl&_return_as
_object=1" -d '{"use_ttl": true,"ttl":3600}'
{"result":
{"_ref":
"record:txt/ZG5zLmJpbmRfdHh0JC5fZGVmYXVsdC5jb20udGVzdC5tYWlsLiJUaGlzIiAiYSIgIm1haWwi
ICJzZXJ2ZXIi:mail.test.com/default",
"name": "mail.test.com",
"text": "This a mail server",
"ttl": 3600,
"view": "default"
}}
Name Server Groups
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/nsgroup
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/nsgroup?_return_fields%2B=grid_primary,grid_secondaries&_return_a
s_object=1"
Fetch name server {"result":
groups and its {"_ref": "nsgroup/ZG5zLm5zX2dyb3VwJFRlc3Qy:demo",
members "grid_primary":
[{"name": "infoblox.localdomain",
"stealth": false}],
"name": "demo"
}}
{"name":"test",
POST <wapi_url>/nsgroup "grid_primary":[{"name":"info
blox.localdomain"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/nsgroup?_return_fields%2B=grid_primary&_return_as_object=1" -d
'{"name":"test","grid_primary":[{"name":"infoblox.localdomain"}]}'
Create a name {"result":
server group {"_ref": "nsgroup/ZG5zLm5zX2dyb3VwJHRlc3Q:test",
"grid_primary":
[{"name": "infoblox.localdomain",
"stealth": false}],
"grid_secondaries": [],
"name": "test"
}}
{"grid_secondaries":[{"name
PUT <wapi_url>/nsgroup/ZG5zLm5zX2dyb3VwJHRlc3Q:test
":"member1.localdomain"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/nsgroup/ZG5zLm5zX2dyb3VwJHRlc3Q:test?_return_fields%2B=grid_p
rimary,grid_secondaries&_return_as_object=1" -d
Add grid
'{"grid_secondaries":[{"name":"member1.localdomain"}]}'
secondaries to the
name server group {"result":
{"_ref": "nsgroup/ZG5zLm5zX2dyb3VwJHRlc3Q:test",
"grid_primary":
[{"name": "infoblox.localdomain",
"stealth": false
}],
43
"grid_secondaries":
[{"enable_preferred_primaries": false,
"grid_replicate": true,
"lead": false,
"name": "member1.localdomain",
"preferred_primaries": [],
"stealth": false
}],
"name": "test"
}}
Zone Transfers
Zone transfers can be enabled and configured at the grid, member or zone level. While configuring at the zone
level, in addition to the allow_tranfer flag, set the use_allow_transfer flag.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
{"allow_transfer":
<wapi_url>/grid:dns/ZG5zLmNsdXN0ZXJfZG5zX3Byb3BlcnRp [{ "_struct": "addressac",
PUT
ZXMkMA:Infoblox?_return_fields%2B=allow_transfer "address":"Any",
"permission":"ALLOW"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/grid:dns/ZG5zLmNsdXN0ZXJfZG5zX3Byb3BlcnRpZXMkMA:Infoblox?_
Enable and specify
return_fields%2B=allow_transfer&_return_as_object=1" -d '{"allow_transfer": [{ "_struct":
the zone transfer
"addressac","address":"Any","permission":"ALLOW"}]}'
settings at the grid
level {"result":
{"_ref": "grid:dns/ZG5zLmNsdXN0ZXJfZG5zX3Byb3BlcnRpZXMkMA:Infoblox",
"allow_transfer":
[{"_struct": "addressac",
"address": "Any",
"permission": "ALLOW"
}]}}
{"allow_transfer":
<wapi_url>/member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydG
[{ "_struct": "addressac",
PUT llcyQx:member1.localdomain?_return_fields%2B=allow_transf
"address":"10.10.0.0/16",
er
"permission":"ALLOW"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQx:member1.loc
aldomain?_return_fields%2B=allow_transfer&_return_as_object=1" -d '{"allow_transfer": [{ "_struct":
Enable and specify "addressac","address":"10.10.0.0/16","permission":"ALLOW"}]}'
the zone transfer {"result":
settings at the {"_ref": "member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQx:member1.localdomain",
member level "allow_transfer":
[{"_struct": "addressac",
"address": "10.10.0.0/16",
"permission": "ALLOW"
}],
"host_name": "member1.localdomain",
"ipv4addr": "172.26.1.3"
}}
44
{"use_allow_transfer":true,
<wapi_url>/zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvb "allow_transfer":
PUT S5kZW1v:demo.com/default?_return_fields%2B=allow_transfe [{ "_struct": "addressac",
r "address":"192.168.0.1/24",
"permission":"ALLOW"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5kZW1v:demo.co
m/default?_return_fields%2B=allow_transfer&_return_as_object=1" -d
Enable and specify '{"use_allow_transfer":true,"allow_transfer": [{ "_struct":
the zone transfer "addressac","address":"192.168.0.0/24","permission":"ALLOW"}]}'
settings at the {"result":
zone level {"_ref": "zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5kZW1v:demo.com/default",
"allow_transfer":
[{"_struct": "addressac",
"address": "192.168.0.0/24",
"permission": "ALLOW"
}],
"fqdn": "demo.com",
"view": "default"
}}
DNSSEC
DNSSEC can be enabled at the grid, member, view or zone level.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
<wapi_url>/zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0L
{"use_dnssec_key_params":tr
PUT mNvbS5kZW1v:demo.com/default?_return_fields%2B=u
ue}
se_dnssec_key_params
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT "https://grid-master/wapi/v2.12/
zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5kZW1v:demo.com/default?_return_fields%2B
Enable DNSSEC at =use_dnssec_key_params&_return_as_object=1" -d '{"use_dnssec_key_params":true}'
the zone level {"result":
{ "_ref": "zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5kZW1v:demo.com/default",
"fqdn": "demo.com",
"use_dnssec_key_params": true,
"view": "default"
}}
<wapi_url>/zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0L
{"use_dnssec_key_params":fal
PUT mNvbS5kZW1v:demo.com/default?_return_fields%2B=u
se}
se_dnssec_key_params
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT "https://grid-master/wapi/v2.12/
zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5kZW1v:demo.com/default?_return_fields%2B
Disable DNSSEC at =use_dnssec_key_params&_return_as_object=1" -d '{"use_dnssec_key_params":false}'
the zone level {"result":
{ "_ref": "zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5kZW1v:demo.com/default",
"fqdn": "demo.com",
"use_dnssec_key_params": false,
"view": "default"
}}
45
<wapi_url>/zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0L
POST mNvbS5kZW1v:demo.com/default?_function=dnssec_op {"operation":"SIGN"}
eration
Sign the zone
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT "https://grid-master/wapi/v2.12/
zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5kZW1v:demo.com/default?_function=dnssec_
operation" -d '{"operation":"SIGN"}'
<wapi_url>/zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0L
POST mNvbS5kZW1v:demo.com/default?_function=dnssec_ge {"key_pair_type":"ZSK"}
t_zone_keys
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT "https://grid-master/wapi/v2.12/
zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5kZW1v:demo.com/default?_function=dnssec_
get_zone_keys" -d '{"key_pair_type":"ZSK"}'
Initiate the {"token":
DNSSEC "eJytUMFOwzAMvedHtsvauqVdx22oTEJCm7QhcbTaJB3R2iYkHlr5ehyQuHLhEMfx8/NznpTWzej1\
key nWXCQdgrkr5KsFw7EUpqpt91gb4mddDw0Ox1E01KLR90LlwuJ2F3NQGZCFMpIEq4QS+XuxGmh
download b874\nGcmMeiFcKXZQlnmZVesSkhqKGgBEOC2ufmC4YsIbkQv3aQpZApsqybM8ySGNVVSG1yP
szaDR2NTr\ndzRq1Rxe98+HbbPKCiigLnMOkPGdfoYLXvSMrjU+oRuxwjqKGcVZzVp/TeC2TSQo/iz
nkDEnDexM\ne9Ypje7f1voxIcqgnqRVZjrHas56D0/7mBa/DaNV0UqI7jbbly0eH3fxXYpARwdVdB7W
DPZGDyog\nWZR2dK3/ZtViHx3oWodmclfCD+2DsVPENox1yRdF36Jv\n",
"url":
"https://grid-master/http_direct_file_io/req_id-DOWNLOAD-0313185231810852/zsk_key_pair.txt"
}
<url_from_the_previous_output>
Example:
GET
https://x.x.x.x/http_direct_file_io/req_id-DOWNLOAD-031
3185231810852/zsk_key_pair.txt
curl -k -u admin:infoblox -H 'content-type: application/force-download'
Get the "https://grid-master/http_direct_file_io/ req_id-DOWNLOAD-0313185231810852/zsk_key_pair.txt"
zone key -o "zsk_key_pair.txt"
(key pair The content of the file looks similar to this:
type can Keytag: 61578
be ZSK Size: 1024
or KSK) demo.com. IN DNSKEY 256 3 8
AwEAAanEjBwnl/ftcaRD1R8NyXVhQwFFVzAxiFYUwanYKDJI3207eObhjb2FlNOgO9y98Ln0kmIzS
peLtqYzye10Dxfm+Eg4YSA9NNDunMM26yvSR/UqXakxH2Yain+rvXYIQB98QnuzWxNkJnmkPmst
gugfcCTLdvBHlECJS/C3XqcT
Private-key-format: v1.2
Download Algorithm: 8 (RSASHA256)
the zone Modulus:
key {0}_{aes}_sAAAAO3ti1bn6M/m4oXt8f3LUuyxdAjKjucwWVCL/0w3oqirdHsimtiVLc1mLwR7eZ1TTCn
PfQDOW6USdmUY384tk6hush/WjFrSpxwA2yPr1b2s0Lk5QkvK/bn/JHkO4nj2BJk4QWegKJJHTkU
hQzRlewr9Kj11OXfzExgu+FzkLTxvp6wSrmkY5hs4FV6yIZPWGA3DStRWv0f/cZDqvDZNpZyfS/0W
4HarfTb1IUfLariT
PublicExponent: {0}_{aes}_EAAAADPzg/q9WRyzpo50uikbF6g=
PrivateExponent:
{0}_{aes}_sAAAAG7ErDwDyxx4Xg171crlSdxCMOOKbZmO8JGsXO6qo5eDNvdEfxp4E4DUIaiCM6
4aHmshvS6J1ILwHipTwkfdLyXTi7IasLDFHNWi8csJCMGQSD7slPxp96Jy/d4OGaVWgeVdEtBaD4
BK+2g8/Z85eqvkvv/JCG+EHbiUYYWUwHMUqpgw/2QmiCT1NQAkUb6uiI9r3IE7gu9nGWJlx4s2u7
63UScbPtCfjOaRocAFcEaV
Prime1:
{0}_{aes}_YAAAAI9bl0lSOndVzocDRXWRBknU3qPBRY4wO2jIIzybdxgmXuPaBAW9CFK+JviUd+8
6JSEH5iMWay0NguohYK2d6Itg7y/Rnx3pTMJcjN0NrxzM9fRZFfJ7arb3ZEHn5pn7kA==
Prime2:
{0}_{aes}_YAAAACjERzXr9L/dNo9ZQld42jJmUKSMeBy3gC6Fr45W0iTJ6+PDawnknH1AlBDdbhkK
dFDMMuM1ItHo44gYt5aLQPZlAq6GVMjPLX6vQnu/MOPXkkqrNL85BtNlyaZLkcR5Gg==
46
Exponent1:
{0}_{aes}_YAAAANmPwbRhwdBAkLQZHRD2seAC3YpYcHTgS7t7kSq48AF1wtfOmXKpcGeYg0Q4
gAeTtJl4ELbB0B1ZLRFSDq7UklY+LfrCnl3mZsrM1fKwTkqHwglxuPwSjNJoIAlJ5SxXDw==
Exponent2:
{0}_{aes}_YAAAAFVZPm9Y3k0nAnSI/NIGC7kqPmjgAFHV6FvklTgjEdD3Oq8S3vDZ1GOvl51i8htJt
4D/wvc6RCqP0kRYFISzSAPlFObN/HZtN69l8QtQU2x+k9zDiE0S4IPqAFZy8ndqzg==
Coefficient:
{0}_{aes}_YAAAAO3i/B+eJC8sD0esfl/7l8lp4x2t7UDwNQh0vWQEp/6a8una6PUHuzTPuin/n+Lrtak6
OFkx/xGLNAE7G8KHtHA34XBpDRMQ7L7Yw/3fWbVhvS5DcBXPYNefxiUolb9EeQ==
POST <wapi_url>/fileop?_function=downloadcomplete {"token": "eJytUM..v\n"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
Remove the "https://grid-master/wapi/v2.12/fileop?_function=downloadcomplete" -d '{"token" :
stored file "eJytUMFOwzAMvedHtsvauqVdx22oTEJCm7QhcbTaJB3R2iYkHlr5ehyQuHLhEMfx8/NznpTWzej1\
using the nWXCQdgrkr5KsFw7EUpqpt91gb4mddDw0Ox1E01KLR90LlwuJ2F3NQGZCFMpIEq4QS+XuxGmh
token b874\nGcmMeiFcKXZQlnmZVesSkhqKGgBEOC2ufmC4YsIbkQv3aQpZApsqybM8ySGNVVSG1yP
szaDR2NTr\ndzRq1Rxe98+HbbPKCiigLnMOkPGdfoYLXvSMrjU+oRuxwjqKGcVZzVp/TeC2TSQo/iz
nkDEnDexM\ne9Ypje7f1voxIcqgnqRVZjrHas56D0/7mBa/DaNV0UqI7jbbly0eH3fxXYpARwdVdB7W
DPZGDyog\nWZR2dK3/ZtViHx3oWodmclfCD+2DsVPENox1yRdF36Jv\n"}'
<wapi_url>/zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0L
POST mNvbS5kZW1v:demo.com/default?_function=dnssec_ex
port&operation=EXPORT_DS
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT "https://grid-master/wapi/v2.12/
zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5kZW1v:demo.com/default?_function=dnssec_
export&operation=EXPORT_DS"
{"token":
Initiate the "eJytUMFOwzAMvedHtsvauqVdx22oTEJCm7QhcbTaJB3R2iYkHlr5ehyQuHLhEMfx8/NznpTWzej1\
export nWXCQdgrkr5KsFw7EUpqpt91gb4mddDw0Ox1E01KLR90LlwuJ2F3NQGZCFMpIEq4QS+XuxGmh
b874\nGcmMeiFcKXZQlnmZVesSkhqKGgBEOC2ufmC4YsIbkQv3aQpZApsqybM8ySGNVVSG1yP
szaDR2NTr\ndzRq1Rxe98+HbbPKCiigLnMOkPGdfoYLXvSMrjU+oRuxwjqKGcVZzVp/TeC2TSQo/iz
nkDEnDexM\ne9Ypje7f1voxIcqgnqRVZjrHas56D0/7mBa/DaNV0UqI7jbbly0eH3fxXYpARwdVdB7W
DPZGDyog\nWZR2dK3/ZtViHx3oWodmclfCD+2DsVPENox1yRdF36Jv\n",
"url":
"https://grid-master/http_direct_file_io/req_id-DOWNLOAD-0502010716646241/ds_records.txt"
}
Export <url_from_the_previous_output>
trust Example:
anchor GET
https://x.x.x.x/http_direct_file_io/req_id-DOWNLOAD-050
in DS 2010716646241/ds_records.txt
format
curl -k -u admin:infoblox -H 'content-type: application/force-download'
"https://grid-master/http_direct_file_io/ req_id- DOWNLOAD-0502010716646241/ds_records.txt" -o
Download
"ds_records.txt"
the DS
records The content of the file looks similar to this:
demo.com. IN DS 31006 8 1 EBFDB0B60D074F196E78ABAEF837451FD2027EE6
demo.com. IN DS 31006 8 2
7650608506F1037C278C3DB123F3799F089AC8FFFE58835970A8FD570A4C7C52
department.demo.com. IN DS 43081 8 1 008A09A1F7890B5256FA552316FBF806C72940E6
department.demo.com. IN DS 43081 8 2
CC7116368234A1C139C23A98545C35F280AE04AB672FA496A25C9BEEBA83C7CE
POST <wapi_url>/fileop?_function=downloadcomplete {"token": "eJytUM..v\n"}
Remove the curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
stored file "https://grid-master/wapi/v2.12/fileop?_function=downloadcomplete" -d '{"token" :
using the "eJytUMFOwzAMvedHtsvauqVdx22oTEJCm7QhcbTaJB3R2iYkHlr5ehyQuHLhEMfx8/NznpTWzej1\
token nWXCQdgrkr5KsFw7EUpqpt91gb4mddDw0Ox1E01KLR90LlwuJ2F3NQGZCFMpIEq4QS+XuxGmh
b874\nGcmMeiFcKXZQlnmZVesSkhqKGgBEOC2ufmC4YsIbkQv3aQpZApsqybM8ySGNVVSG1yP
47
szaDR2NTr\ndzRq1Rxe98+HbbPKCiigLnMOkPGdfoYLXvSMrjU+oRuxwjqKGcVZzVp/TeC2TSQo/iz
nkDEnDexM\ne9Ypje7f1voxIcqgnqRVZjrHas56D0/7mBa/DaNV0UqI7jbbly0eH3fxXYpARwdVdB7W
DPZGDyog\nWZR2dK3/ZtViHx3oWodmclfCD+2DsVPENox1yRdF36Jv\n"}'
<wapi_url>/zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0L
mNvbS5kZW1v:demo.com/default?_return_fields%2B=u
GET
se_dnssec_key_params,is_dnssec_enabled,dnssec_key
s
curl -k -u admin:infoblox -X GET "https://grid-master/wapi/v2.12/
zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5kZW1v:demo.com/default?_return_fields%2B
=use_dnssec_key_params,is_dnssec_enabled,dnssec_keys&_return_as_object=1"
{"result":
{ "_ref": "zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5kZW1v:demo.com/default",
"dnssec_keys":
[{"algorithm": "8",
"next_event_date": 1584039064,
"public_key":
"AwEAAboElNe0pPpO+SXWII8JY05tPL1WKqJV2GcoJqbUbiGa6dgD4NDpZ8taFax7cpSp3TKEUL
JiwXCoQ+tpPD8f0IJO0LRtGYnn99VYIX8eNuQ+jH2oJl66hnarmzx99YWowZNlQ4UsJiLe1bo1+5Qt
0vsgN8m0bLJHLgDnUBWga7BmNXsjVgXJD/QRHyfZdsSX5qbrvnogzZTjFYe+wsA2mZXvv5MhOE
3qdCpOv3W4GkX//x3HaRU1R1ozKlmpQM6Rk4+EUjjNT9gGXt2EMGGZDNBgvhMbjzuBhuyu0GX
5zqVi5ZkN++MOYQQUQ5EFKgJPW7oFJMtTYi4XmV7bwlZA/rM=",
"status": "ACTIVE",
"tag": 4654,
"type": "KSK"
},
Get a list of the zone {"algorithm": "8",
keys "next_event_date": 1555095064,
"public_key":
"AwEAAd2v3QOi88A/SDjY62yX33euAHSqdp+ORs98xRv93GmYli3zVMGfbglgJdhQ8UvRiCNBu+r
ECpZBzV//xgRh+WVoHAAPILGpuKuoqy7g82a9fenQPhAC1fP61pVJpl06bVEGVNS8GsARgMnf6Lf
084Dri32tq4WLfJdoj+rd4wir",
` "status": "PUBLISHED",
"tag": 49428,
"type": "ZSK"
},
{"algorithm": "8",
"next_event_date": 1555095064,
"public_key":
"AwEAAanEjBwnl/ftcaRD1R8NyXVhQwFFVzAxiFYUwanYKDJI3207eObhjb2FlNOgO9y98Ln0kmIz
SpeLtqYzye10Dxm+Eg4YSA9NNDunMM26yvSR/UqXakxH2Yain+rvXYIQB98QnuzWxNkJnmkPms
tgugfcCTLdvBHlECJS/C3XqcT",
"status": "ACTIVE",
"tag": 61578,
"type": "ZSK"
}],
"fqdn": "demo.com",
"is_dnssec_enabled": true,
"use_dnssec_key_params": true,
"view": "default"
}}
Response Policy Zones
DNS RPZs (Response Policy Zones), a technology developed by ISC (Internet System Consortium) for
allowing reputable sources to dynamically communicate domain name reputation so you can implement policy
controls for DNS lookups. You can configure RPZs and define RPZ rules to block DNS resolution for malicious
48
or unauthorized domain names, or redirect clients to a walled garden by substituting responses. You can assign
actions to RPZ rules.
For example, abc.com can have an action of pass thru or substitute (domain) with the domain xyz.com. You
can also configure a Grid member to act as a lead secondary that receives RPZ updates from external
reputation sources and redistributes the updates to other Grid members.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/zone_rp
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/zone_rp?_return_fields%2B=rpz_policy&_return_as_object=1"
{"result":
Fetch RPZs [{"_ref": "zone_rp/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5nb29nbC53d3c:www.googl.com/default",
"fqdn": "www.googl.com",
"rpz_policy": "NXDOMAIN",
"view": "default"
}]}
{"fqdn": "inblox.com",
"rpz_policy": "SUBSTITUTE",
POST <wapi_url>/zone_rp
"rpz_severity": "WARNING",
"substitute_name": "infoblox.com"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/zone_rp?_return_fields%2B=fqdn,rpz_policy,rpz_severity,substitute_na
me&_return_as_object=1" -d '{"fqdn": "inblox.com","rpz_policy": "SUBSTITUTE","rpz_severity":
Create a RPZ "WARNING","substitute_name": "infoblox.com"}'
{"result":
{"_ref": "zone_rp/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5pbmZvYmxvdw:inblox.com/default",
"fqdn": "inblox.com",
"rpz_policy": "SUBSTITUTE",
"rpz_severity": "WARNING",
"substitute_name": "infoblox.com"
}}
{"name": "server.inblox.com",
POST <wapi_url>/record:rpz:a "ipv4addr":"1.1.1.156",
"rp_zone":"inblox.com"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:rpz:a?_return_fields%2B=name,rp_zone&_return_as_object=1"
-d '{"name":"server.inblox.com","ipv4addr":"1.1.1.156","rp_zone":"inblox.com"}'
Add a substitution {"result":
rule for DNS A {"_ref":
records "record:rpz:a/ZG5zLmJpbmRfYSQuX2RlZmF1bHQuY29tLmluZm9ibG93LHNlcnZlciwxLjEuMS4xNTY:
server.inblox.com/default",
"ipv4addr": "1.1.1.156",
"name": "server.inblox.com",
"rp_zone": "inblox.com",
"view": "default"
}}
Add a substitution {"name":
rule for DNS PTR POST <wapi_url>/record:rpz:ptr "135.10.10.10.in-addr.arpa.inblox.c
records om ",
49
"ipv4addr":"10.10.10.135",
"ptrdname": "inblox.com",
"rp_zone":"inblox.com"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:rpz:ptr?_return_fields%2B=name,rp_zone&_return_as_object=1
" -d '{"name": "135.10.10.10.in-addr.arpa.inblox.com ","ipv4addr":"10.10.10.135","ptrdname":
"inblox.com","rp_zone":"inblox.com"}'
{"result":
{"_ref":
"record:rpz:ptr/ZG5zLmJpbmRfcHRyJC5fZGVmYXVsdC5jb20uaW5mb2Jsb3cuYXJwYS5pbi1hZGRyL
jEwLjEwLjEwLjEzNS5pbmZvYmxvdy5jb20:135.10.10.10.in-addr.arpa.inblox.com/default",
"name": "135.10.10.10.in-addr.arpa.inblox.com",
"ptrdname": "inblox.com",
"rp_zone": "inblox.com",
"view": "default"
}}
{"name":"1.1.1.6.inblox.com",
POST <wapi_url>/record:rpz:a:ipaddress "ipv4addr":"2.2.2.6",
"rp_zone":"inblox.com"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:rpz:a:ipaddress?_return_fields%2B=name,rp_zone&_return_as
_object=1" -d '{"name":"1.1.1.6.inblox.com","ipv4addr":"2.2.2.6","rp_zone":"inblox.com"}'
Add a substitution {"result":
rule for IP trigger {"_ref":
policy "record:rpz:a:ipaddress/ZG5zLmJpbmRfYSQuX2RlZmF1bHQuY29tLmluZm9ibG93LHJwei1pcC4xLjE
uMS42LjMyLDIuMi4yLjY:1.1.1.6.inblox.com/default",
"ipv4addr": "2.2.2.6",
"name": "1.1.1.6.inblox.com",
"rp_zone": "inblox.com",
"view": "default"
}}
{"name":"test.inblox.com",
POST <wapi_url>/record:rpz:cname "canonical":"",
"rp_zone":"inblox.com"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:rpz:cname?_return_fields%2B=name,rp_zone&_return_as_obje
ct=1" -d '{"name":"test.inblox.com","canonical":"","rp_zone":"inblox.com"}'
Add a Block
Domain Name {"result":
(No Such {"_ref":
Domain) Rule "record:rpz:cname/ZG5zLmJpbmRfY25hbWUkLl9kZWZhdWx0LmNvbS5pbmZvYmxvdy50ZXN0:test.i
nblox.com/default",
"canonical": "",
"name": "test.inblox.com",
"rp_zone": "inblox.com",
"view": "default"
}}
{"name":"demo.inblox.com",
POST <wapi_url>/record:rpz:cname "canonical":"*",
Add a Block "rp_zone":"inblox.com"}
Domain Name
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
(No Data) Rule
"https://grid-master/wapi/v2.12/record:rpz:cname?_return_fields%2B=name,rp_zone&_return_as_obje
ct=1" -d '{"name":"demo.inblox.com","canonical":"*","rp_zone":"inblox.com"}'
50
{"result":
{"_ref":
"record:rpz:cname/ZG5zLmJpbmRfY25hbWUkLl9kZWZhdWx0LmNvbS5pbmZvYmxvdy5kZW1v:demo
.inblox.com/default",
"canonical": "*",
"name": "demo.inblox.com",
"rp_zone": "inblox.com",
"view": "default"
}}
{"name":"pass.inblox.com",
POST <wapi_url>/record:rpz:cname "canonical":"pass.inblox.com",
"rp_zone":"inblox.com"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:rpz:cname?_return_fields%2B=name,rp_zone&_return_as_obje
ct=1" -d '{"name":"pass.inblox.com","canonical":"pass.inblox.com","rp_zone":"inblox.com"}'
Add a Passthru {"result":
Domain Name { "_ref":
Rule "record:rpz:cname/ZG5zLmJpbmRfY25hbWUkLl9kZWZhdWx0LmNvbS5pbmZvYmxvdy5wYXNz:pass
.inblox.com/default",
"canonical": "pass.inblox.com",
"name": "pass.inblox.com",
"rp_zone": "inblox.com",
"view": "default"
}}
{"name":"sub.inblox.com",
POST <wapi_url>/record:rpz:cname "canonical":"test",
"rp_zone":"inblox.com"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:rpz:cname?_return_fields%2B=name,rp_zone&_return_as_obje
ct=1" -d '{"name":"sub.inblox.com","canonical":"test","rp_zone":"inblox.com"}'
Add a Substitute {"result":
Domain Name {"_ref":
Rule "record:rpz:cname/ZG5zLmJpbmRfY25hbWUkLl9kZWZhdWx0LmNvbS5pbmZvYmxvdy5zdWI:sub.inb
lox.com/default",
"canonical": "test",
"name": "sub.inblox.com",
"rp_zone": "inblox.com",
"view": "default"
}}
{"name":"10.10.10.200.inblox.com"
,
POST <wapi_url>/record:rpz:cname:clientipaddress
"canonical":"",
"rp_zone":"inblox.com"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
Add a Block Client "https://grid-master/wapi/v2.12/record:rpz:cname:clientipaddress?_return_fields%2B=name,rp_zone&
IP Address (No _return_as_object=1" -d '{"name":"10.10.10.200.inblox.com","canonical":"","rp_zone":"inblox.com"}'
Such Domain) {"result":
Rule {"_ref":
"record:rpz:cname:clientipaddress/ZG5zLmJpbmRfY25hbWUkLl9kZWZhdWx0LmNvbS5pbmZvYmxvd
y5ycHotY2xpZW50LWlwLjEwLjEwLjEwLjIwMC4zMg:10.10.10.200.inblox.com/default",
"canonical": "",
"name": "10.10.10.200.inblox.com",
"rp_zone": "inblox.com",
51
"view": "default"
}}
{"name":"10.10.10.210.inblox.com"
,
POST <wapi_url>/record:rpz:cname:clientipaddress
"canonical":"*",
"rp_zone":"inblox.com"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:rpz:cname:clientipaddress?_return_fields%2B=name,rp_zone&
_return_as_object=1" -d '{"name":"10.10.10.210.inblox.com","canonical":"*","rp_zone":"inblox.com"}'
Add a Block Client
IP Address (No {"result":
Data) Rule {"_ref":
"record:rpz:cname:clientipaddress/ZG5zLmJpbmRfY25hbWUkLl9kZWZhdWx0LmNvbS5pbmZvYmxvd
y5ycHotY2xpZW50LWlwLjEwLjEwLjEwLjIxMC4zMg:10.10.10.210.inblox.com/default",
"canonical": "*",
"name": "10.10.10.210.inblox.com",
"rp_zone": "inblox.com",
"view": "default"
}}
{"name":"10.10.10.220.inblox.com"
,
POST <wapi_url>/record:rpz:cname:clientipaddress
"canonical":"rpz-passthru",
"rp_zone":"inblox.com"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:rpz:cname:clientipaddress?_return_fields%2B=name,rp_zone&
_return_as_object=1" -d
Add a Passthru '{"name":"10.10.10.220.inblox.com","canonical":"rpz-passthru","rp_zone":"inblox.com"}'
Client IP Address {"result":
Rule {"_ref":
"record:rpz:cname:clientipaddress/ZG5zLmJpbmRfY25hbWUkLl9kZWZhdWx0LmNvbS5pbmZvYmxvd
y5ycHotY2xpZW50LWlwLjEwLjEwLjEwLjIyMC4zMg:10.10.10.220.inblox.com/default",
"canonical": "rpz-passthru",
"name": "10.10.10.220.inblox.com",
"rp_zone": "inblox.com",
"view": "default"
}}
{"name":"10.10.10.230.inblox.com"
,
POST <wapi_url>/record:rpz:cname:clientipaddressdn
"canonical":"test",
"rp_zone":"inblox.com"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:rpz:cname:clientipaddressdn?_return_fields%2B=name,rp_zone
&_return_as_object=1" -d
'{"name":"10.10.10.230.inblox.com","canonical":"test","rp_zone":"inblox.com"}'
Add a Substitute {"result":
Domain Name {"_ref":
(Client IP "record:rpz:cname:clientipaddressdn/ZG5zLmJpbmRfY25hbWUkLl9kZWZhdWx0LmNvbS5pbmZvYm
Address) Rule xvdy5ycHotY2xpZW50LWlwLjEwLjEwLjEwLjIzMC4zMg:10.10.10.230.inblox.com/default",
"canonical": "test",
"name": "10.10.10.230.inblox.com",
"rp_zone": "inblox.com",
"view": "default"
}}
52
{"name":"5.5.5.10.inblox.com",
POST <wapi_url>/record:rpz:cname:ipaddress "canonical":"",
"rp_zone":"inblox.com"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:rpz:cname:ipaddress?_return_fields%2B=name,rp_zone&_retur
n_as_object=1" -d '{"name":"5.5.5.10.inblox.com","canonical":"","rp_zone":"inblox.com"}'
Add a Block IP {"result":
Address (No Such {"_ref":
Domain) Rule "record:rpz:cname:ipaddress/ZG5zLmJpbmRfY25hbWUkLl9kZWZhdWx0LmNvbS5pbmZvYmxvdy5yc
HotaXAuNS41LjUuMTAuMzI:5.5.5.10.inblox.com/default",
"canonical": "",
"name": "5.5.5.10.inblox.com",
"rp_zone": "inblox.com",
"view": "default"
}}
{"name":"5.5.5.25.inblox.com",
POST <wapi_url>/record:rpz:cname:ipaddress "canonical":"*",
"rp_zone":"inblox.com"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:rpz:cname:ipaddress?_return_fields%2B=name,rp_zone&_retur
n_as_object=1" -d '{"name":"5.5.5.25.inblox.com","canonical":"*","rp_zone":"inblox.com"}'
Add a Block IP {"result":
Address (No {"_ref":
Data) Rule "record:rpz:cname:ipaddress/ZG5zLmJpbmRfY25hbWUkLl9kZWZhdWx0LmNvbS5pbmZvYmxvdy5yc
HotaXAuNS41LjUuMjUuMzI:5.5.5.25.inblox.com/default",
"canonical": "*",
"name": "5.5.5.25.inblox.com",
"rp_zone": "inblox.com",
"view": "default"
}}
{"name":"5.5.5.100.inblox.com",
POST <wapi_url>/record:rpz:cname:ipaddress "canonical":"5.5.5.100",
"rp_zone":"inblox.com"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:rpz:cname:ipaddress?_return_fields%2B=name,rp_zone&_retur
n_as_object=1" -d '{"name":"5.5.5.100.inblox.com","canonical":"5.5.5.100","rp_zone":"inblox.com"}'
Add a Passthru IP {"result":
Address Rule {"_ref":
"record:rpz:cname:ipaddress/ZG5zLmJpbmRfY25hbWUkLl9kZWZhdWx0LmNvbS5pbmZvYmxvdy5yc
HotaXAuNS41LjUuMTAwLjMy:5.5.5.100.inblox.com/default",
"canonical": "5.5.5.100",
"name": "5.5.5.100.inblox.com",
"rp_zone": "inblox.com",
"view": "default"
}}
{"name":"5.5.5.200.inblox.com",
POST <wapi_url>/record:rpz:cname:ipaddressdn "canonical":"test",
"rp_zone":"inblox.com"}
Add a Substitute curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
Domain Name (IP "https://grid-master/wapi/v2.12/record:rpz:cname:ipaddressdn?_return_fields%2B=name,rp_zone&_ret
Address) Rule urn_as_object=1" -d '{"name":"5.5.5.200.inblox.com","canonical":"test","rp_zone":"inblox.com"}'
{"result":
{"_ref":
"record:rpz:cname:ipaddressdn/ZG5zLmJpbmRfY25hbWUkLl9kZWZhdWx0LmNvbS5pbmZvYmxvdy5
53
ycHotaXAuNS41LjUuMjAwLjMy:5.5.5.200.inblox.com/default",
"canonical": "test",
"name": "5.5.5.200.inblox.com",
"rp_zone": "inblox.com",
"view": "default"
}}
GET <wapi_url>/allrpzrecords?zone=inblox.com
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/allrpzrecords?zone=inblox.com&_return_fields%2B=rpz_rule&_return_
as_object=1"
{"result":
[{"_ref":
"allrpzrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX2EkLl9kZWZhdWx0LmNvbS5pb
mZvYmxvdyxycHotaXAuMS4xLjEuNi4zMiwyLjIuMi42:1.1.1.6",
"comment": "",
"name": "1.1.1.6",
"rpz_rule": "SubstituteIPv4AddressRecord",
"type": "record:rpz:a:ipaddress",
"view": "default",
"zone": "inblox.com"
},
{"_ref":
"allrpzrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX2NuYW1lJC5fZGVmYXVsdC5jb2
0uaW5mb2Jsb3cucnB6LWlwLjUuNS41LjEwLjMy:5.5.5.10",
"comment": "",
"name": "5.5.5.10",
"rpz_rule": "BlockNxdomainIpaddr",
"type": "record:rpz:cname:ipaddress",
"view": "default",
Fetch all objects "zone": "inblox.com"
belonging to a },
RPZ {"_ref":
"allrpzrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX2NuYW1lJC5fZGVmYXVsdC5jb2
0uaW5mb2Jsb3cucnB6LWlwLjUuNS41LjI1LjMy:5.5.5.25",
"comment": "",
"name": "5.5.5.25",
"rpz_rule": "BlockNoDataIpaddr",
"type": "record:rpz:cname:ipaddress",
"view": "default",
"zone": "inblox.com"
},
{"_ref":
"allrpzrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX2NuYW1lJC5fZGVmYXVsdC5jb2
0uaW5mb2Jsb3cucnB6LWlwLjUuNS41LjEwMC4zMg:5.5.5.100",
"comment": "",
"name": "5.5.5.100",
"rpz_rule": "PassthruIpaddr",
"type": "record:rpz:cname:ipaddress",
"view": "default",
"zone": "inblox.com"
},
{"_ref":
"allrpzrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX2NuYW1lJC5fZGVmYXVsdC5jb2
0uaW5mb2Jsb3cucnB6LWlwLjUuNS41LjIwMC4zMg:5.5.5.200",
"comment": "",
"name": "5.5.5.200",
54
"rpz_rule": "SubstituteIPAddressCname",
"type": "record:rpz:cname:ipaddressdn",
"view": "default",
"zone": "inblox.com"
},
{"_ref":
"allrpzrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX2NuYW1lJC5fZGVmYXVsdC5jb2
0uaW5mb2Jsb3cucnB6LWNsaWVudC1pcC4xMC4xMC4xMC4yMDAuMzI:10.10.10.200",
"comment": "",
"name": "10.10.10.200",
"rpz_rule": "BlockNxdomainClientIpaddr",
"type": "record:rpz:cname:clientipaddress",
"view": "default",
"zone": "inblox.com"
},
{"_ref":
"allrpzrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX2NuYW1lJC5fZGVmYXVsdC5jb2
0uaW5mb2Jsb3cucnB6LWNsaWVudC1pcC4xMC4xMC4xMC4yMTAuMzI:10.10.10.210",
"comment": "",
"name": "10.10.10.210",
"rpz_rule": "BlockNoDataClientIpaddr",
"type": "record:rpz:cname:clientipaddress",
"view": "default",
"zone": "inblox.com"
},
{"_ref":
"allrpzrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX2NuYW1lJC5fZGVmYXVsdC5jb2
0uaW5mb2Jsb3cucnB6LWNsaWVudC1pcC4xMC4xMC4xMC4yMjAuMzI:10.10.10.220",
"comment": "",
"name": "10.10.10.220",
"rpz_rule": "PassthruClientIpaddr",
"type": "record:rpz:cname:clientipaddress",
"view": "default",
"zone": "inblox.com"
},
{"_ref":
"allrpzrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX2NuYW1lJC5fZGVmYXVsdC5jb2
0uaW5mb2Jsb3cucnB6LWNsaWVudC1pcC4xMC4xMC4xMC4yMzAuMzI:10.10.10.230",
"comment": "",
"name": "10.10.10.230",
"rpz_rule": "SubstituteClientIPAddressCname",
"type": "UNSUPPORTED",
"view": "default",
"zone": "inblox.com"
},
{"_ref":
"allrpzrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX3B0ciQuX2RlZmF1bHQuY29tLml
uZm9ibG93LmFycGEuaW4tYWRkci4xMC4xMC4xMC4xMzUuaW5mb2Jsb3cuY29t:135.10.10.10.in-a
ddr.arpa",
"comment": "",
"name": "135.10.10.10.in-addr.arpa",
"rpz_rule": "SubstitutePTRRecord",
"type": "record:rpz:ptr",
"view": "default",
"zone": "inblox.com"
},
55
{"_ref":
"allrpzrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX2NuYW1lJC5fZGVmYXVsdC5jb2
0uaW5mb2Jsb3cuZGVtbw:demo",
"comment": "",
"name": "demo",
"rpz_rule": "BlockNoDataDomain",
"type": "record:rpz:cname",
"view": "default",
"zone": "inblox.com"
},
{"_ref":
"allrpzrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX2NuYW1lJC5fZGVmYXVsdC5jb2
0uaW5mb2Jsb3cucGFzcw:pass",
"comment": "",
"name": "pass",
"rpz_rule": "SubstituteCName",
"type": "record:rpz:cname",
"view": "default",
"zone": "inblox.com"
},
{"_ref":
"allrpzrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX2EkLl9kZWZhdWx0LmNvbS5pb
mZvYmxvdyxzZXJ2ZXIsMS4xLjEuMTU2:server",
"comment": "",
"name": "server",
"rpz_rule": "SubstituteARecord",
"type": "record:rpz:a",
"view": "default",
"zone": "inblox.com"
},
{"_ref":
"allrpzrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX2NuYW1lJC5fZGVmYXVsdC5jb2
0uaW5mb2Jsb3cuc3Vi:sub",
"comment": "",
"name": "sub",
"rpz_rule": "SubstituteCName",
"type": "record:rpz:cname",
"view": "default",
"zone": "inblox.com"
},
{"_ref":
"allrpzrecords/ZG5zLnpvbmVfc2VhcmNoX2luZGV4JGRucy5iaW5kX2NuYW1lJC5fZGVmYXVsdC5jb2
0uaW5mb2Jsb3cudGVzdA:test",
"comment": "",
"name": "test",
"rpz_rule": "BlockNxdomainDomain",
"type": "record:rpz:cname",
"view": "default",
"zone": "inblox.com"
}]
}
56
DNS Traffic Control
REST
API Call Sample Body (for POST and PUT)
Resource Method
Operation
type Sample cURL Command
Sample Output
GET <wapi_url>/dtc:server
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/dtc:server?_return_as_object=1"
{"result":
[{"_ref": "dtc:server/ZG5zLmlkbnNfc2VydmVyJHNlcnZlcjE:server1",
"host": "1.1.1.25",
"name": "server1"
},
Fetch {"_ref": "dtc:server/ZG5zLmlkbnNfc2VydmVyJGhvc3Q:host",
information "host": "10.10.10.20",
"name": "host"
},
{"_ref":
"dtc:server/ZG5zLmlkbnNfc2VydmVyJFNFUlZFUl9URU1QTkFNRV8yMjEyNw:SERVER_TE
DTC Servers MPNAME_22127",
"host": "example.com",
"name": "SERVER_TEMPNAME_22127"
}]}
{"name": "test-server",
POST <wapi_url>/dtc:server
"host": "2.2.2.56"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/dtc:server?_return_fields%2B=name,host&_return_as_object=
1" -d '{"name": "test-server","host": "2.2.2.56"}'
Create
{"result":
{"_ref": "dtc:server/ZG5zLmlkbnNfc2VydmVyJHRlc3Qtc2VydmVy:test-server",
"host": "2.2.2.56",
"name": "test-server"
}}
GET <wapi_url>/dtc:pool
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/dtc:pool?_return_as_object=1"
{"result":
[{"_ref": "dtc:pool/ZG5zLmlkbnNfcG9vbCRwb29sMQ:pool1",
Fetch "name": "pool1"
information },
{"_ref":
"dtc:pool/ZG5zLmlkbnNfcG9vbCRQT09MX1RFTVBOQU1FXzIyMTI3:POOL_TEMPNAME_2
DTC Pools 2127",
"name": "POOL_TEMPNAME_22127"
}]}
{"name": "test-pool",
"availability": "ALL",
"lb_preferred_method":"GLOBAL_AVAILAB
ILITY",
Create POST <wapi_url>/dtc:pool
"monitors":
["dtc:monitor:icmp/ZG5zLmlkbnNfbW9uaX
Rvcl9pY21wJGljbXA:icmp"],
"servers":
57
[{"ratio": 4,
"server":
"dtc:server/ZG5zLmlkbnNfc2VydmVyJHRlc
3Qtc2VydmVy:test-server"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/dtc:pool?_return_fields%2B=name,servers&_return_as_object
=1" -d '{"name": "test-pool","availability":
"ALL","lb_preferred_method":"GLOBAL_AVAILABILITY","monitors":
["dtc:monitor:icmp/ZG5zLmlkbnNfbW9uaXRvcl9pY21wJGljbXA:icmp"],"servers": [{"ratio":
4,"server": "dtc:server/ZG5zLmlkbnNfc2VydmVyJHRlc3Qtc2VydmVy:test-server"}]}'
{"result":
{"_ref": "dtc:pool/ZG5zLmlkbnNfcG9vbCR0ZXN0LXBvb2w:test-pool",
"name": "test-pool"
"servers":
[{"ratio": 4,
"server": "dtc:server/ZG5zLmlkbnNfc2VydmVyJHRlc3Qtc2VydmVy:test-server"
}]}}
{"servers":
[{"ratio": 4,
"server":
"dtc:server/ZG5zLmlkbnNfc2VydmVyJHRlc3
<wapi_url>/dtc:pool/ZG5zLmlkbnNfc Qtc2VydmVy:test-server"
PUT
G9vbCR0ZXN0LXBvb2w:test-pool },
{"ratio": 4,
"server":
"dtc:server/ZG5zLmlkbnNfc2VydmVyJHRlc3
Qtc2VydmVyMg:test-server2"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/dtc:pool/ZG5zLmlkbnNfcG9vbCR0ZXN0LXBvb2w:test-pool?_r
Modify to add
eturn_fields%2B=name,servers&_return_as_object=1" -d '{"servers": [{"ratio": 4,"server":
another server
"dtc:server/ZG5zLmlkbnNfc2VydmVyJHRlc3Qtc2VydmVy:test-server" },{"ratio": 4,"server":
"dtc:server/ZG5zLmlkbnNfc2VydmVyJHRlc3Qtc2VydmVyMg:test-server2"}]}'
{"result":
{"_ref": "dtc:pool/ZG5zLmlkbnNfcG9vbCR0ZXN0LXBvb2w:test-pool",
"name": "test-pool",
"servers":
[{"ratio": 4,
"server": "dtc:server/ZG5zLmlkbnNfc2VydmVyJHRlc3Qtc2VydmVy:test-server"
},
{"ratio": 4,
"server": "dtc:server/ZG5zLmlkbnNfc2VydmVyJHRlc3Qtc2VydmVyMg:test-server2"
}]}}
{"servers":
[{"ratio": 20,
"server":
"dtc:server/ZG5zLmlkbnNfc2VydmVyJHRlc
<wapi_url>/dtc:pool/ZG5zLmlkbnNfc 3Qtc2VydmVy:test-server"
PUT
G9vbCR0ZXN0LXBvb2w:test-pool },
Modify the {"ratio": 80,
ratio "server":
"dtc:server/ZG5zLmlkbnNfc2VydmVyJHRlc
3Qtc2VydmVyMg:test-server2"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/dtc:pool/ZG5zLmlkbnNfcG9vbCR0ZXN0LXBvb2w:test-pool?_r
eturn_fields%2B=name,servers&_return_as_object=1" -d '{"servers": [{"ratio": 20,"server":
58
"dtc:server/ZG5zLmlkbnNfc2VydmVyJHRlc3Qtc2VydmVy:test-server" },{"ratio": 80,"server":
"dtc:server/ZG5zLmlkbnNfc2VydmVyJHRlc3Qtc2VydmVyMg:test-server2"}]}'
{"result":
{"_ref": "dtc:pool/ZG5zLmlkbnNfcG9vbCR0ZXN0LXBvb2w:test-pool",
"name": "test-pool",
"servers":
[{"ratio": 20,
"server": "dtc:server/ZG5zLmlkbnNfc2VydmVyJHRlc3Qtc2VydmVy:test-server"
},
{"ratio": 80,
"server": "dtc:server/ZG5zLmlkbnNfc2VydmVyJHRlc3Qtc2VydmVyMg:test-server2"
}]}}
GET <wapi_url>/dtc:lbdn
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/dtc:lbdn?_return_as_object=1"
Fetch {"result":
information [{"_ref":
"dtc:lbdn/ZG5zLmlkbnNfbGJkbiRMQkROX1RFTVBOQU1FXzIyMTI3:LBDN_TEMPNAME_22
127",
"name": "LBDN_TEMPNAME_22127"
}]}
{"auth_zones":
["zone_auth/ZG5zLnpvbmUkLl9kZWZhdW
x0LmNvbS5kdGM:dtc.com/default"],
"lb_method": "ROUND_ROBIN",
"name": "test-lbdn",
POST <wapi_url>/dtc:lbdn
"patterns": ["server.dtc.com"],
"pools":
DTC Load [{"ratio": 4,
Balanced "pool":"dtc:pool/ZG5zLmlkbnNfcG9vbCR0Z
Domain XN0LXBvb2w:test-pool"}]}
Name curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/dtc:lbdn?_return_fields%2B=name,pools,auth_zones,patterns
&_return_as_object=1" -d
Create '{"auth_zones":["zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5kdGM:dtc.com/default"]
,"lb_method": "ROUND_ROBIN","name": "test-lbdn","patterns": ["server.dtc.com"],"pools":
[{"ratio": 4,"pool":"dtc:pool/ZG5zLmlkbnNfcG9vbCR0ZXN0LXBvb2w:test-pool"}]}'
{"result":
{"_ref": "dtc:lbdn/ZG5zLmlkbnNfbGJkbiR0ZXN0LWxiZG4:test-lbdn",
"auth_zones":
["zone_auth/ZG5zLnpvbmUkLl9kZWZhdWx0LmNvbS5kdGM:dtc.com/default"],
"name": "test-lbdn",
"patterns":
["server.dtc.com"],
"pools":
[{"pool": "dtc:pool/ZG5zLmlkbnNfcG9vbCR0ZXN0LXBvb2w:test-pool",
"ratio": 4
}]}}
59
IP address management related scenarios
Add a network or container
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
POST <wapi_url>/network {"network": "1.1.1.0/24"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/network?_return_fields%2B=network&_return_as_object=1 " -d
'{"network": "1.1.1.0/24"}'
Add a network {"result":
{"_ref": "network/ZG5zLm5ldHdvcmskMS4xLjEuMC8yNC8w:1.1.1.0/24/default",
"network": "1.1.1.0/24",
"network_view": "default"
}}
{"network": "2.2.2.0/24",
"members":
POST <wapi_url>/network
[{"_struct": "dhcpmember",
"ipv4addr":"172.26.1.3"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/network?_return_fields%2B=network,members&_return_as_object=
1" -d '{"network": "2.2.2.0/24","members":[{"_struct": "dhcpmember","ipv4addr":"172.26.1.3"}]}'
{"result":
Add a network and {"_ref": "network/ZG5zLm5ldHdvcmskMi4yLjIuMC8yNC8w:2.2.2.0/24/default",
assign to a member "members":
[{"_struct": "dhcpmember",
"ipv4addr": "172.26.1.3",
"ipv6addr": null,
"name": "member1.localdomain"
}],
"network": "2.2.2.0/24",
"network_view": "default"
}}
{"network": "10.10.10.0/24",
"members":
POST <wapi_url>/network [{"_struct": "dhcpmember",
"ipv4addr":"172.26.1.2"}],
"auto_create_reversezone":true}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/network?_return_fields%2B=network,members&_return_as_object=
Add a network and 1" -d '{"network": "10.10.10.0/24","members":[{"_struct":
automatically create "dhcpmember","ipv4addr":"172.26.1.2"}],"auto_create_reversezone":true}'
the corresponding {"result":
reverse lookup zone {"_ref": "network/ZG5zLm5ldHdvcmskMS4xLjEuMC8yNC8w:10.10.10.0/24/default",
"members":
[{"_struct": "dhcpmember",
"ipv4addr": "172.26.1.2",
"ipv6addr": null,
"name": "infoblox.localdomain"
}],
"network": "10.10.10.0/24",
60
"network_view": "default"
}}
{"network":"192.168.0.0/24",
"options":
[{"name": "domain-name-servers",
"num": 6,
"use_option": true,
"value": "192.168.0.2",
POST <wapi_url>/network "vendor_class": "DHCP"},
{"name": "routers",
"num": 3,
"use_option": true,
"value": "192.168.0.1",
"vendor_class": "DHCP"}],
"use_options":true}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/network?_return_fields%2B=options&_return_as_object=1" -d
'{"network":"192.168.0.0/24","options":[{"name": "domain-name-servers","num": 6,"use_option":
true,"value": "192.168.0.2","vendor_class": "DHCP"},"name": "routers","num": 3,"use_option":
true,"value": "192.168.0.1","vendor_class": "DHCP"}],"use_options":true}'
Add a network with {"_ref": "network/ZG5zLm5ldHdvcmskMTkyLjE2OS4wLjAvMjQvMA:192.168.0.0/24/default",
DHCP options "network": "192.168.0.0/24",
"network_view": "default",
"options":
[{"name": "dhcp-lease-time",
"num": 51,
"use_option": false,
"value": "43200",
"vendor_class": "DHCP"},
{"name": "domain-name-servers",
"num": 6,
"use_option": true,
"value": "192.168.0.2",
"vendor_class": "DHCP"},
{"name": "routers",
"num": 3,
"use_option": true,
"value": "192.168.0.1",
"vendor_class": "DHCP"}
]}
{"network":
"func:nextavailablenetwork:10.0.0.0/8,default,2
4",
POST <wapi_url>/network "network_view":"default",
"extattrs":
{"Country":{"value":"UK"},
Add a network from "Region":{"value":"EMEA"}}}
next available curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
network "https://grid-master/wapi/v2.12/network?_return_fields%2B=network,members,extattrs&_return_as_
object=1" -d '{"network": "func:nextavailablenetwork:10.0.0.0/8,default,24","network_view":
"default","extattrs": {"Country":{"value":"UK"},"Region":{"value":"EMEA"}}}'
{"result":
{"_ref": "network/ZG5zLm5ldHdvcmskMTAuMC4wLjAvMjQvMA:10.0.0.0/24/default",
"extattrs":
{"Country": {"value": "UK"},
61
"Region": {"value": "EMEA"}
},
"members": [],
"network": "10.0.0.0/24",
"network_view": "default"
}}
The last example uses the function next_available_network by specifying it in the option _function, in the
shorthand form.
62
{"result":
[{"_ref": "network/ZG5zLm5ldHdvcmskMTkyLjE2OC4xLjAvMjQvMA:192.168.1.0/24/default",
"extattrs":
{"Building": {"value": "Remote"},
"Site": {"value": "HQ"}},
"network": "192.168.1.0/24",
"network_view": "default"
},
{"_ref":
"network/ZG5zLm5ldHdvcmskMTkyLjE2OC4xMDAuMC8yNC8w:192.168.100.0/24/default",
"extattrs":
{"Building": {"value": "Main"},
"Site": {"value": "HQ"}},
"network": "192.168.100.0/24",
"network_view": "default"
}]}
GET <wapi_url>/network?_return_fields%2B=extattrs&*Site:=HQ
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/network?_return_fields%2B=extattrs&*Site%3A=HQ&*Building!=Mai
n&_return_as_object=1"
Search by EA {"result":
(Networks in the HQ [{"_ref": "network/ZG5zLm5ldHdvcmskMTkyLjE2OC4xLjAvMjQvMA:192.168.1.0/24/default",
but not in the Main "extattrs":
Building) {"Building": {"value": "Remote"},
"Site": {"value": "HQ"}},
"network": "192.168.1.0/24",
"network_view": "default"
}]}
Get next available subnet
Use the function next_available_network by specifying it in the option _function.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
{"network":
{"_object_function":
"next_available_network",
"_result_field":"networks",
"_object":"network",
POST <wapi_url>/network
"_object_parameters":
{"*Region" : "EMEA"},
Create a network from the "_parameters":
next available subnet from {"cidr":24}},
a network in the "network_view":"default"}
Region(EA) EMEA curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/network?_return_fields%2B=network&_return_as_object=1 "
-d
'{"network":{"_object_function":"next_available_network","_result_field":"networks","_object":"n
etwork","_object_parameters":{"*Region" :
"EMEA"},"_parameters":{"cidr":24}},"network_view":"default"}'
{
"result": {
63
"_ref":
"network/ZG5zLm5ldHdvcmskMTkyLjE2OC4wLjAvMjQvMA:192.168.0.0/24/default",
"network": "192.168.0.0/24",
"network_view": "default"
}
}
Get next available address from a subnet
Use the function next_available_ip by specifying it in the option _function. For this operation you would need
the _ref of the subnet you want to query.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
<wapi_url>/network/ZG5zLm5ldHdvcmskMTcyLjIxLjEw
POST LjAvMjQvMA:172.21.10.0/24/default?_function=next_a {"num":1}
vailable_ip
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
Get the next available IP "https://grid-master/wapi/v2.12/network/ZG5zLm5ldHdvcmskMTcyLjIxLjEwLjAvMjQvMA:172.2
address in a subnet 1.10.0/24/default?_function=next_available_ip&_return_as_object=1" -d '{"num":1}'
{"result":
{"ips":
[ "172.21.10.1"]
}}
<wapi_url>/network/ZG5zLm5ldHdvcmskMTcyLjIxLjEw
POST LjAvMjQvMA:172.21.10.0/24/default?_function=next_a {"num":5}
vailable_ip
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/network/ZG5zLm5ldHdvcmskMTcyLjIxLjEwLjAvMjQvMA:172.2
1.10.0/24/default?_function=next_available_ip&_return_as_object=1" -d '{"num":5}'
Get the next 5 available IP {"result":
addresses in a subnet {"ips":
["172.21.10.1",
"172.21.10.2",
"172.21.10.3",
"172.21.10.4",
"172.21.10.5"
]}}
Reparent subnets while deleting network container
This example uses the remove_subnets argument available with the network container DELETE operation.
This will retain the networks within the container.
REST
API Call
Method
Operation
Sample cURL Command
Sample Output
<wapi_url>/networkcontainer/ZG5zLm5ldHdvcmtfY29udGFpbmVyJDEwLjAuMC4w
DELETE
Reparent subnets while LzgvMA:10.0.0.0/8/default?remove_subnets=false
deleting network curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
container "https://grid-master/wapi/v2.12/networkcontainer/ZG5zLm5ldHdvcmtfY29udGFpbmVyJDEwLjAu
MC4wLzgvMA:10.0.0.0/8/default?remove_subnets=false&_return_as_object=1"
64
{"result":
{"_ref":
"networkcontainer/ZG5zLm5ldHdvcmtfY29udGFpbmVyJDEwLjAuMC4wLzgvMA:10.0.0.0/8/defa
ult"}}
Get all the addresses based on a search criteria
REST
API Call
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/ipv4address?network=10.10.10.0/24
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/ipv4address?network=10.10.10.0/24&_return_as_object=1"
{"result":
[{"_ref": "ipv4address/Li5pcHY0X2FkZHJlc3MkMTAuMTAuMTAuMjUzLzA:10.10.10.1",
"ip_address": "10.10.10.1",
"is_conflict": false,
"mac_address": "",
"names": [],
"network": "10.10.10.0/24",
"network_view": "default",
"objects": [],
"status": "UNUSED",
"types": [],
"usage": []
},
{"_ref": "ipv4address/Li5pcHY0X2FkZHJlc3MkMTAuMTAuMTAuMjU0LzA:10.10.10.2",
"ip_address": "10.10.10.2",
"is_conflict": false,
Get addresses in a "mac_address": "",
subnet "names": [],
"network": "10.10.10.0/24",
"network_view": "default",
"objects": [],
"status": "UNUSED",
"types": [],
"usage": []
},
….
{"_ref": "ipv4address/Li5pcHY0X2FkZHJlc3MkMTAuMTAuMTAuMjU1LzA:10.10.10.255",
"ip_address": "10.10.10.255",
"is_conflict": false,
"mac_address": "",
"names": [],
"network": "10.10.10.0/24",
"network_view": "default",
"objects": [],
"status": "USED",
"types": ["BROADCAST"],
"usage": []
}]}
GET <wapi_url>/ipv4address?ip_address>=10.10.10.252&&ip_address<=10.10.10.254
Get addresses in a given
range (10.10.10.252 - curl -k -u admin:infoblox -X GET
10.10.10.254) "https://grid-master/wapi/v2.12/ipv4address?ip_address%3E=10.10.10.252&ip_address%3C=10
.10.10.254&_return_as_object=1"
65
{"result":
[{"_ref": "ipv4address/Li5pcHY0X2FkZHJlc3MkMTAuMTAuMTAuMjUyLzA:10.10.10.252",
"ip_address": "10.10.10.252",
"is_conflict": false,
"mac_address": "",
"names": [],
"network": "10.10.10.0/24",
"network_view": "default",
"objects": [],
"status": "UNUSED",
"types": [],
"usage": []
},
{"_ref": "ipv4address/Li5pcHY0X2FkZHJlc3MkMTAuMTAuMTAuMjUzLzA:10.10.10.253",
"ip_address": "10.10.10.253",
"is_conflict": false,
"mac_address": "",
"names": [],
"network": "10.10.10.0/24",
"network_view": "default",
"objects": [],
"status": "UNUSED",
"types": [],
"usage": []
},
{"_ref": "ipv4address/Li5pcHY0X2FkZHJlc3MkMTAuMTAuMTAuMjU0LzA:10.10.10.254",
"ip_address": "10.10.10.254",
"is_conflict": false,
"mac_address": "",
"names": [],
"network": "10.10.10.0/24",
"network_view": "default",
"objects": [],
"status": "UNUSED",
"types": [],
"usage": []
}]}
Zone associations on a network
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
<wapi_url>/network/ZG5zLm5ldHdvcmskMTAu
GET
MS4wLjAvMTYvMA:10.1.0.0/16/default
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/network/ZG5zLm5ldHdvcmskMTAuMS4wLjAvMTYvMA:10.1.0.
0/16/default?_return_fields%2B=zone_associations&_return_as_object=1"
List zone associations on a {"result":
network {"_ref": "network/ZG5zLm5ldHdvcmskMTAuMS4wLjAvMTYvMA:10.1.0.0/16/default",
"network": "10.1.0.0/16",
"network_view": "default",
"zone_associations":
[{"fqdn": "info.com",
"is_default": true,
66
"view": "default"
}]}}
{"zone_associations":
<wapi_url>/network/ZG5zLm5ldHdvcmskMTcyLjI
PUT [{"fqdn":
xLjEwLjAvMjQvMA:172.21.10.0/24/default
"test.org","is_default":true}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/network/ZG5zLm5ldHdvcmskMTcyLjIxLjEwLjAvMjQvMA:172.2
1.10.0/24/default?_return_fields%2B=zone_associations&_return_as_object=1" -d
'{"zone_associations": [{"fqdn": "test.com","is_default":true}]}'
Add a zone association to {"result":
a network {"_ref": "network/ZG5zLm5ldHdvcmskMTcyLjIxLjEwLjAvMjQvMA:172.21.10.0/24/default",
"network": "172.21.10.0/24",
"network_view": "default",
"zone_associations":
[{"fqdn": "test.com",
"is_default": true,
"view": "default"
}]}}
Add a fixed address
A fixed address is a specific IP address that a DHCP server always assigns when a lease request comes from
a particular MAC address of the client.
For example, if you have a printer in your network, you can reserve a particular IP address to be assigned to it
every time it is turned on.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
{"ipv4addr":"192.168.1.100",
POST <wapi_url>/fixedaddress
"mac":"aa:bb:cc:11:22:21"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/fixedaddress?_return_fields%2B=ipv4addr,mac&_return_as_o
bject=1" -d '{"ipv4addr":"192.168.1.100","mac":"aa:bb:cc:11:22:21"}'
{"result":
Add a fixed address {"_ref":
"fixedaddress/ZG5zLmZpeGVkX2FkZHJlc3MkMTkyLjE2OC4xLjEwMC4wLi4:192.168.1.100/d
efault",
"ipv4addr": "192.168.1.100",
"mac": "aa:bb:cc:11:22:21",
"network_view": "default"
}}
{"ipv4addr":"172.26.1.200",
POST <wapi_url>/fixedaddress
"mac":"00:00:00:00:00:00"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/fixedaddress?_return_fields%2B=ipv4addr,mac&_return_as_o
bject=1" -d '{"ipv4addr":"172.26.1.200","mac":"00:00:00:00:00:00"}'
Add a fixed address
reservation {"result":
{"_ref":
"fixedaddress/ZG5zLmZpeGVkX2FkZHJlc3MkMTcyLjI2LjEuMjAwLjAuLg:172.26.1.200/default
",
"ipv4addr": "172.26.1.200",
"mac": "00:00:00:00:00:00",
67
"network_view": "default"
}}
{"ipv4addr":
"func:nextavailableip:10.1.0.0/16
POST <wapi_url>/fixedaddress?_return_fields=ipv4addr
",
"mac":"ff:ff:ff:ff:ff:ff"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/fixedaddress?_return_fields%2B=ipv4addr,mac&_return_as_o
Add a fixed address with bject=1" -d '{"ipv4addr":"func:nextavailableip:10.1.0.0/16","mac":"ff:ff:ff:ff:ff:ff"}'
next available IP {"result":
{"_ref":
"fixedaddress/ZG5zLmZpeGVkX2FkZHJlc3MkMTAuMS4wLjEuMC4u:10.1.0.1/default",
"ipv4addr": "10.1.0.1",
"mac": "ff:ff:ff:ff:ff:ff",
"network_view": "default"
}}
{"ipv6addr":"2001:0db8:85a3:00
00:0000:8a2e:0370:7334",
POST <wapi_url>/ipv6fixedaddress
"duid":"00:02:00:01:02:03:04:05:
07:a0"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/ipv6fixedaddress?_return_fields%2B=ipv6addr,duid&_return_a
s_object=1" -d
'{"ipv6addr":"2001:0db8:85a3:0000:0000:8a2e:0370:7334","duid":"00:02:00:01:02:03:04:05:07
Add an IPv6 fixed address :a0"}'
{"result":
{"_ref":
"ipv6fixedaddress/ZG5zLmZpeGVkX2FkZHJlc3MkMTkyLjE2OC4xLjEwMC4wLi4:2001:0db8:8
5a3:0000:0000:8a2e:0370:7334/default",
"ipv4addr": "2001:0db8:85a3:0000:0000:8a2e:0370:7334",
"duid": "00:02:00:01:02:03:04:05:07:a0",
"network_view": "default"
}}
Search for a fixed address by MAC
The following example uses the _return_fields+ to add the mac address to the list of fields that are returned.
REST
API Call
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/fixedaddress?_return_fields%2B=mac&mac=aa:bb:cc:11:22:21
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/fixedaddress?_return_fields%2B=mac&mac=aa:bb:cc:11:22:2
1&_return_as_object=1"
{"result":
Search fixed address by [{"_ref":
MAC "fixedaddress/ZG5zLmZpeGVkX2FkZHJlc3MkMTkyLjE2OC4xLjEwMC4wLi4:192.168.1.100/d
efault",
"ipv4addr": "192.168.1.100",
"mac": "aa:bb:cc:11:22:21",
"network_view": "default"
}]}
68
Complex search for a fixed address by Microsoft Server
The following example uses the _return_fields+ to add the Microsoft Server to the list of fields that are returned.
Since the search field is a structure, we pass it in the body of a PUT call.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
{"ms_server":
<wapi_url>/fixedaddress?_method=GET&_retur
PUT {"_struct": "msdhcpserver",
n_fields%2B=ipv4addr,mac,ms_server,name
"ipv4addr": "192.168.4.21"}}
curl -k -u admin:infoblox -X PUT
"https://grid-master/wapi/v2.12/fixedaddress?_method=GET&_return_fields%2B=ipv4addr,ma
c,ms_server,name&_return_as_object=1" -d '{"ms_server":{"_struct":
"msdhcpserver","ipv4addr": "192.168.4.21"}}'
{"result":
[{"_ref":
"fixedaddress/ZG5zLmZpeGVkX2FkZHJlc3MkMTkyLjE2OC40LjMuMC4xNy4:192.168.4.3/Co
mpany%201",
"ipv4addr": "192.168.4.3",
"mac": "12:34:56:78:91:23",
"ms_server":
{"_struct": "msdhcpserver",
"ipv4addr": "192.168.4.21"},
"name": "test",
"network_view": "Company 1"
},
Search for a fixed address {"_ref":
by Microsoft Server "fixedaddress/ZG5zLmZpeGVkX2FkZHJlc3MkMTkyLjE2OC40LjguMC4xNy4:192.168.4.8/Co
mpany%201",
"ipv4addr": "192.168.4.8",
"mac": "ca:fe:ca:fe:be:ef",
"ms_server":
{"_struct": "msdhcpserver",
"ipv4addr": "192.168.4.21"},
"name": "awo666",
"network_view": "Company 1"
},
{"_ref":
"fixedaddress/ZG5zLmZpeGVkX2FkZHJlc3MkMTkyLjE2OC40Ljg1LjAuMTcu:192.168.4.85/Co
mpany%201",
"ipv4addr": "192.168.4.85",
"mac": "00:50:56:ba:01:ec",
"ms_server":
{"_struct": "msdhcpserver",
"ipv4addr": "192.168.4.21"},
"name": "192.168.4.85",
"network_view": "Company 1"
}]}
69
Get information about an IP address
REST
API Call
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/ipv4address?ip_address=10.10.10.10
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/ipv4address?ip_address=10.10.10.10&_return_as_object=1"
{"result":
[{"_ref": "ipv4address/Li5pcHY0X2FkZHJlc3MkMTAuMTAuMTAuMTAvMA:10.10.10.10",
"ip_address": "10.10.10.10",
"is_conflict": false,
Query an IP address "mac_address": "",
"names": [],
"network": "10.10.10.0/24",
"network_view": "default",
"objects": [],
"status": "UNUSED",
"types": [],
"usage": []
}]}
Get unused IP addresses in a subnet
REST
API Call
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/ipv4address?network=10.10.10.0/24&status=UNUSED
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/ipv4address?network=10.10.10.0/24&status=UNUSED&_retur
n_as_object=1"
{"result":
[{"_ref": "ipv4address/Li5pcHY0X2FkZHJlc3MkMTAuMTAuMTAuMTcvMA:10.10.10.17",
"ip_address": "10.10.10.17",
"is_conflict": false,
"mac_address": "",
"names": [],
"network": "10.10.10.0/24",
"network_view": "default",
Query for unused IP "objects": [],
addresses in a subnet "status": "UNUSED",
"types": [],
"usage": []
},
{"_ref": "ipv4address/Li5pcHY0X2FkZHJlc3MkMTAuMTAuMTAuMTgvMA:10.10.10.108",
"ip_address": "10.10.10.108",
"is_conflict": false,
"mac_address": "",
"names": [],
"network": "10.10.10.0/24",
"network_view": "default",
"objects": [],
"status": "UNUSED",
"types": [],
70
"usage": []
},
….
]}
Search for any object with an IP address
REST
API Call
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/ipv4address?status=USED&ip_address=10.10.10.20
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/ipv4address?status=USED&ip_address=10.10.10.20&_return_
as_object=1"
{"result":
[{"_ref": "ipv4address/Li5pcHY0X2FkZHJlc3MkMTAuMTAuMTAuMjAvMA:10.10.10.20",
"ip_address": "10.10.10.20",
"is_conflict": false,
"mac_address": "",
Search for objects by IP "names": ["host1.info.com"],
address "network": "10.10.10.0/24",
"network_view": "default",
"objects":
["record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLmhvc3Qx:host1.info.com/defa
ult"],
"status": "USED",
"types": [ "HOST" ],
"usage": [ "DNS" ]
}]}
Search for an IP address
REST
API Call
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/search?address=172.26.1.100
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/search?address=172.26.1.100&_return_as_object=1"
{"result":
[{"_ref":
"record:a/ZG5zLmJpbmRfYSQuX2RlZmF1bHQuY29tLmluZm8sdGVzdC5ob3N0LDE3Mi4yNi
4xLjEwMA:host.test.info.com/default",
Search an IP address "ipv4addr": "172.26.1.100",
"name": "host.test.info.com",
"view": "default"
},
{"_ref": "network/ZG5zLm5ldHdvcmskMTcyLjI2LjEuMC8yNC8w:172.26.1.0/24/default",
"network": "172.26.1.0/24",
"network_view": "default"
}]}
71
Delete an IP address
REST
API Call
Method
Operation
Sample cURL Command
Sample Output
<wapi_url>/ipv4address/Li5pcHY0X2FkZHJlc3MkMTAuMTAuMTAuMjAvMA:10.10.
DELETE
10.20
curl -k -u admin:infoblox -H 'content-type: application/json' -X DELETE
Delete an IP
"https://grid-master/wapi/v2.12/ipv4address/Li5pcHY0X2FkZHJlc3MkMTAuMTAuMTAuMjAvM
A:10.10.10.20&_return_as_object=1"
{"result":"ipv4address/Li5pcHY0X2FkZHJlc3MkMTAuMTAuMTAuMjAvMA:10.10.10.20"}
Network Views
DNS views provide the ability to serve one version of DNS data to one set of clients and another version to
another set of clients. With DNS views, the appliance can provide a different answer to the same query,
depending on the source of the query.
A network view is a single routing domain with its own networks and shared networks. A network view can
contain both IPv4 and IPv6 networks. All networks must belong to a network view.
For example, network views can be used in cloud environments to isolate each of the tenant to their own
respective view. This enables support of overlapping networks across different tenants, each in its own network
view, thus enabling multi-tenancy in cloud environments.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/view
curl -k -u admin:infoblox -X GET "https://grid-master/wapi/v2.12/view?_return_as_object=1"
{"result":
[{"_ref": "view/ZG5zLnZpZXckLl9kZWZhdWx0:default/true",
"is_default": true,
"name": "default"
},
Get all DNS views {"_ref": "view/ZG5zLnZpZXckLjE:default.test/false",
"is_default": false,
"name": "default.test"
},
{"_ref": "view/ZG5zLnZpZXckLjI:default.cloud/false",
"is_default": false,
"name": "default.cloud"
}]}
GET <wapi_url>/zone_auth?view=default.test
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/zone_auth?view=default.test&_return_as_object=1"
Get authoritative zones {"result":
for a DNS view [{"_ref": "zone_auth/ZG5zLnpvbmUkLjEuY29tLmluZm8:info.com/default.test",
"fqdn": "info.com",
"view": "default.test"
},
72
{"_ref": "zone_auth/ZG5zLnpvbmUkLjEub3JnLnRlc3Q:test.org/default.test",
"fqdn": "test.org",
"view": "default.test"
}]}
GET <wapi_url>/record:host?zone=info.com&view=default.test
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:host?zone=info.com&view=default.test&_return_as_object=
1"
{"result":
[{"_ref": "record:host/ZG5zLmhvc3QkLjEuY29tLmluZm8uc2VydmVy:server.info.com/default.test",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuMS5jb20uaW5mby5zZXJ2ZXIuMTAuMTA
uMC4xMDAu:10.10.0.100/server.info.com/default.test",
"configure_for_dhcp": false,
"host": "server.info.com",
"ipv4addr": "10.10.0.100"
}],
Get all records for a "name": "server.info.com",
zone in a DNS view "view": "default.test"
},
{"_ref": "record:host/ZG5zLmhvc3QkLjEuY29tLmluZm8ubWFpbGVy:mailer.info.com/default.test",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuMS5jb20uaW5mby5tYWlsZXIuMTAuMS4x
LjEwMC4:10.1.1.100/mailer.info.com/default.test",
"configure_for_dhcp": false,
"host": "mailer.info.com",
"ipv4addr": "10.1.1.100",
"mac": "aa:bb:cc:11:22:33"
}],
"name": "mailer.info.com",
"view": "default.test"
}]}
GET <wapi_url>/networkview
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/networkview?_return_as_object=1"
{"result":
[{"_ref": "networkview/ZG5zLm5ldHdvcmtfdmlldyQw:default/true",
"is_default": true,
"name": "default"
Get all network views },
{"_ref": "networkview/ZG5zLm5ldHdvcmtfdmlldyQx:test/false",
"is_default": false,
"name": "test"
},
{"_ref": "networkview/ZG5zLm5ldHdvcmtfdmlldyQy:cloud/false",
"is_default": false,
"name": "cloud"
}]}
POST <wapi_url>/networkview {"name": "demo"}
Create a network view curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/networkview?_return_fields%2B=name&_return_as_object=1" -d
'{"name": "demo"}'
73
{"result":
{"_ref": "networkview/ZG5zLm5ldHdvcmtfdmlldyQx:demo/false",
"is_default": false,
"name": "demo"
}}
{"fqdn": "infoblox.com",
POST <wapi_url>/zone_auth
"view": "default.test"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/zone_auth?_return_fields%2B=fqdn,network_view&_return_as_obj
Create an authoritative ect=1" -d '{"fqdn": "infoblox.com","view": "default.test"}'
zone within a network {"result":
view {"_ref": "zone_auth/ZG5zLnpvbmUkLjEuY29tLmluZm9ibG94:infoblox.com/default.test",
"fqdn": "infoblox.com",
"network_view": "test"
"view": "default.test"
}}
{"name":"host.infoblox.co
m",
"ipv4addrs":
POST <wapi_url>/record:host
[{"ipv4addr":"10.10.10.20
"}],
"view": "default.test"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/record:host?_return_fields%2B=name,network_view&_return_as_o
bject=1" -d '{"name":"host.infoblox.com","ipv4addrs": [{"ipv4addr":"10.10.10.20"}],"view":
"default.test"}'
{"result":
Create a host record {"_ref":
within a network view "record:host/ZG5zLmhvc3QkLjEuY29tLmluZm9ibG94Lmhvc3Q:host.infoblox.com/default.test",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuMS5jb20uaW5mb2Jsb3guaG9zdC4xMC4x
MC4xMC4yMC4:10.10.10.20/host.infoblox.com/default.test",
"configure_for_dhcp": false,
"host": "host.infoblox.com",
"ipv4addr": "10.10.10.20"
}],
"name": "host.infoblox.com",
"network_view": "test",
"view": "default.test"
}}
{"network":
POST <wapi_url>/network "192.168.1.0/24",
"network_view": "test"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/network?_return_fields%2B=network&_return_as_object=1 " -d
Add a network within a
'{"network": "192.168.1.0/24","network_view": "test"}'
network view
{"result":
{"_ref": "network/ZG5zLm5ldHdvcmskMTkyLjE2OC4xLjAvMjQvMQ:192.168.1.0/24/test",
"network": "192.168.1.0/24",
"network_view": "test"
}}
74
VLAN Management
This is only supported with WAPI version 2.10 onwards
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/vlanview
curl -k -u admin:infoblox -X GET "https://grid-master/wapi/v2.12/vlanview?_return_as_object=1"
{"result":
Get VLAN View [{"_ref": "vlanview/ZG5zLnZsYW5fdmlldyRkZWZhdWx0LjEuNDA5NA:default/1/4094",
"end_vlan_id": 4094,
"name": "default",
"start_vlan_id": 1
}]}
{"start_vlan_id": 10,
POST <wapi_url>/vlanview "end_vlan_id": 20,
"name": "test"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/vlanview?_return_fields%2B=start_vlan_id,end_vlan_id,name&_return_
as_object=1" -d '{"start_vlan_id": 10,"end_vlan_id": 20,"name": "test"}'
Add a VLAN view
{"result":
{"_ref": "vlanview/ZG5zLnZsYW5fdmlldyR0ZXN0LjEwLjIw:test/10/20",
"end_vlan_id": 20,
"name": "test",
"start_vlan_id": 10
}}
{"start_vlan_id": 15,
"end_vlan_id": 20,
"name": "testrange",
POST <wapi_url>/vlanrange
"vlan_view":
"vlanview/ZG5zLnZsYW5fdmlldyR0
ZXN0LjEwLjIw:test/10/20"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/vlanrange?_return_fields%2B=start_vlan_id,end_vlan_id,name&_return
_as_object=1" -d '{"start_vlan_id": 15,"end_vlan_id": 20, "name": "testrange","vlan_view":
Add a VLAN range "vlanview/ZG5zLnZsYW5fdmlldyR0ZXN0LjEwLjIw:test/10/20"}'
{"result":
{"_ref":
"vlanrange/ZG5zLnZsYW5fcmFuZ2UkdGVzdC4xMC4yMC50ZXN0cmFuZ2UuMTUuMjA:test/testrange
/15/20",
"end_vlan_id": 20,
"name": "testrange",
"start_vlan_id": 15,
"vlan_view": {"_ref": "vlanview/ZG5zLnZsYW5fdmlldyR0ZXN0LjEwLjIw:test/10/20"}
}}
{"id": 11,
"name": "testvlan",
"parent":
Add a VLAN POST <wapi_url>/vlan
"vlanview/ZG5zLnZsYW5fdmlldyR0
ZXN0LjEwLjIw:test/10/20",
"reserved":true,
75
"contact":"879220",
"department":"ng"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/vlan?_return_fields%2B=id,name&_return_as_object=1" -d '{"id":
11,"name": "testvlan","parent":
"vlanview/ZG5zLnZsYW5fdmlldyR0ZXN0LjEwLjIw:test/10/20","reserved":true,"contact":"879220","depa
rtment":"ng"}'
{"result":
{ "_ref":
"vlan/ZG5zLnZsYW4kLmNvbS5pbmZvYmxveC5kbnMudmxhbl92aWV3JHRlc3QuMTAuMjAuMTE:test/
testvlan/11",
"id": 11,
"name": "testvlan",
"vlan_view": {"_ref": "vlanview/ZG5zLnZsYW5fdmlldyR0ZXN0LjEwLjIw:test/10/20"}
}}
{"id":"func:nextavailablevlanid:vlanvi
ew/ZG5zLnZsYW5fdmlldyR0ZXN0L
jEwLjIw:test/10/20",
"name": "next-vlan",
"parent":
POST <wapi_url>/vlan
"vlanview/ZG5zLnZsYW5fdmlldyR0
ZXN0LjEwLjIw:test/10/20",
"reserved":true,
"contact":"879220",
"department":"ng"}
Next available curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
VLAN "https://grid-master/wapi/v2.12/vlan?_return_fields%2B=id,name&_return_as_object=1" -d
'{"id":"func:nextavailablevlanid:vlanview/ZG5zLnZsYW5fdmlldyR0ZXN0LjEwLjIw:test/10/20","name":
"next-vlan","parent":
"vlanview/ZG5zLnZsYW5fdmlldyR0ZXN0LjEwLjIw:test/10/20","reserved":true,"contact":"879220","depa
rtment":"ng"}'
{"_ref":
"vlan/ZG5zLnZsYW4kLmNvbS5pbmZvYmxveC5kbnMudmxhbl92aWV3JHRlc3QuMTAuMjAuMTA:test/
next-vlan/10",
"id": 10,
"name": "next-vlan",
"parent": {"_ref": "vlanview/ZG5zLnZsYW5fdmlldyR0ZXN0LjEwLjIw:test/10/20"}}
{"network_view":"default",
"network":"61.0.0.0/24",
"vlans":
[{"vlan":
POST <wapi_url>/network
"vlan/ZG5zLnZsYW4kLmNvbS5pb
mZvYmxveC5kbnMudmxhbl92aWV
3JHRlc3QuMTAuMjAuMTA:test/nex
t-vlan/10" }]}
Create a network curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
with a VLAN "https://grid-master/wapi/v2.12/network?_return_fields%2B=vlans&_return_as_object=1" -d
'{"network_view":"default","network":"61.0.0.0/24","vlans":
[{"vlan":"vlan/ZG5zLnZsYW4kLmNvbS5pbmZvYmxveC5kbnMudmxhbl92aWV3JHRlc3QuMTAuMjAuM
TA:test/next-vlan/10" }]}'
{"result":
{"_ref": "network/ZG5zLm5ldHdvcmskNjEuMC4wLjAvMjQvMA:61.0.0.0/24/default",
"network": "61.0.0.0/24",
"network_view": "default",
"vlans":
76
[{"id": 10,
"name": "next-vlan",
"vlan":
"vlan/ZG5zLnZsYW4kLmNvbS5pbmZvYmxveC5kbnMudmxhbl92aWV3JHRlc3QuMTAuMjAuMTA:test/
next-vlan/10"
}]}}
{"network_view":"default",
"network":"62.0.0.0/24",
"vlans":
POST <wapi_url>/network [{"vlan":
"func:nextavailablevlan:vlanview/ZG
5zLnZsYW5fdmlldyR0ZXN0LjEwLjI
w:test/10/20" }]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/network?_return_fields%2B=vlans&_return_as_object=1" -d
'{"network_view":"default","network":"62.0.0.0/24","vlans":
Create network [{"vlan":"func:nextavailablevlan:vlanview/ZG5zLnZsYW5fdmlldyR0ZXN0LjEwLjIw:test/10/20" }]}'
with next available {"result":
VLAN {"_ref": "network/ZG5zLm5ldHdvcmskNjEuMC4wLjAvMjQvMA:62.0.0.0/24/default",
"network": "62.0.0.0/24",
"network_view": "default",
"vlans":
[{"id": 11,
"name": "testvlan",
"vlan":
"vlan/ZG5zLnZsYW4kLmNvbS5pbmZvYmxveC5kbnMudmxhbl92aWV3JHRlc3QuMTAuMjAuMTE:test/
testvlan/11"
}]}}
77
"dhcpmember",
"ipv4addr" : "172.26.1.3"}}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/range?_return_fields%2B=start_addr,end_addr,member&_return_as_ob
ject=1" -d '{"start_addr": "10.10.10.20","end_addr": "10.10.10.100","server_association_type":
"MEMBER","member":{"_struct": "dhcpmember","ipv4addr" : "172.26.1.3"}}'
{"result":
{"_ref":
"range/ZG5zLmRoY3BfcmFuZ2UkMTAuMTAuMTAuMjAvMTAuMTAuMTAuMTAwLy8vMC8:10.10.10.2
0/10.10.10.100/default",
"end_addr": "10.10.10.100",
"member":
{"_struct": "dhcpmember",
"ipv4addr": "172.26.1.3",
"ipv6addr": null,
"name": "member1.localdomain"
},
"network": "10.10.10.0/24",
"network_view": "default",
"start_addr": "10.10.10.20"
}}
{"start_addr": "172.26.1.20",
POST <wapi_url>/range
"end_addr": "172.26.1.100"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/range?_return_fields%2B=start_addr,end_addr,member&_return_as_ob
ject=1" -d '{"start_addr": "172.26.1.20","end_addr": "172.26.1.100"}'
Add a DHCP {"result":
range reserved {"_ref":
range "range/ZG5zLmRoY3BfcmFuZ2UkMTcyLjI2LjEuMjAvMTcyLjI2LjEuMTAwLy8vMC8:172.26.1.20/172.26.
1.100/default",
"end_addr": "172.26.1.100",
"network": "172.26.1.0/24",
"network_view": "default",
"start_addr": "172.26.1.20"
}}
In the third scenario in the above example, if you do not assign a member, the range is created as “reserved”.
78
"network_view": "test",
"start_addr": "10.10.10.150"
}]}
DHCP Leases
REST
API Call
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/lease
curl -k -u admin:infoblox -X GET "https://grid-master/wapi/v2.12/lease?_return_as_object=1"
{"result":
[{"_ref": "lease/ZG5zLmxlYXNlJDAvMTAuMTAuMC4yMDAvMC8:10.10.10.200/test",
"address": "10.10.10.200",
"network_view": "test"
},
Get DHCP leases {"_ref": "lease/ZG5zLmxlYXNlJDAvMTAuMTAuMC4xOTUvMC8:192.168.1.100/default",
"address": "192.168.1.100",
"network_view": "default"
},
……
{"_ref": "lease/ZG5zLmxlYXNlJDAvMTAuMTAuMC4xOTEvMC8:10.10.10.191/default",
"address": "10.10.10.191",
"network_view": "default"
}]}
<wapi_url>/lease?address=172.26.1.250&_return_fields=binding_state,hardware,client_ho
GET
stname,fingerprint&_max_results=1
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/lease?address=172.26.1.250&_return_fields=binding_state,hardware,
client_hostname,fingerprint&_max_results=1&_return_as_object=1"
Get DHCP lease by
IP Address {"result":
[{"_ref": "lease/ZG5zLmxlYXNlJDQvMTcyLjE2LjIwMC4xMDEvMC8:172.26.1.250/default1",
"binding_state": "ACTIVE",
"fingerprint": "Cisco/Linksys SPA series IP Phone",
"hardware": "16:55:a4:1b:98:c9"
}]}
<wapi_url>/lease?client_hostname~=demo&_max_results=1&_return_fields=binding_state
GET
,hardware,client_hostname,fingerprint
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/lease?client_hostname~=demo&_max_results=1&_return_fields=bindi
ng_state,hardware,client_hostname,fingerprint&_return_as_object=1"
Get a DHCP lease
by hostname {"result":
[{"_ref": "lease/ZG5zLmxlYXNlJC8xOTIuMTY4LjQuMy8wLzE3:192.168.4.3/Company%201",
"binding_state": "STATIC",
"client_hostname": "test",
"hardware": "12:34:56:78:91:23"
}]}
<wapi_url>/lease?network=172.26.1.0/24&_return_fields=binding_state,hardware,client_h
GET
ostname,fingerprint,network
Get DHCP leases
by network curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/lease?network=172.26.1.0/24&_return_fields=binding_state,hardware
,client_hostname,fingerprint,network&_return_as_object=1"
79
{"result":
[{"_ref": "lease/ZG5zLmxlYXNlJDQvMTcyLjE2LjIwMC4xMDEvMC8:172.26.1.250/default1",
"binding_state": "ACTIVE",
"fingerprint": "Cisco/Linksys SPA series IP Phone",
"hardware": "16:55:a4:1b:98:c9",
"network": "172.26.1.0/24"
},
{"_ref": "lease/ZG5zLmxlYXNlJC8xOTIuMTY4LjQuMy8wLzE3:172.26.1.3/Company%201",
"binding_state": "STATIC",
"client_hostname": "test",
"hardware": "12:34:56:78:91:23",
"network": "172.26.1.0/24"
}]}
Grid management related scenarios
For these operations, you would need the _ref of the grid.
REST
API Call
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/grid
curl -k -u admin:infoblox -X GET "https://grid-master/wapi/v2.12/grid"
Grid reference
{"result":
[{"_ref": "grid/b25lLmNsdXN0ZXIkMA:Infoblox"}]}
Grid Settings
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
{"snmp_setting":
{"queries_community_string":
"public",
"queries_enable": true,
<wapi_url>/grid/b25lLmNsdXN0ZXIkMA:Info "trap_receivers":
PUT
blox?_return_fields%2B=snmp_setting [{"address": "1.1.1.1"}],
"traps_community_string":
"public",
"traps_enable": true
}}
curl -k -u admin:infoblox -X GET
Configure SNMP "https://grid-master/wapi/v2.12/grid/b25lLmNsdXN0ZXIkMA:Infoblox?_return_fields%2B=sn
mp_setting&_return_as_object=1" -d '{"snmp_setting": {"queries_community_string":
"public","queries_enable": true, "trap_receivers": [{"address":
"1.1.1.1"}],"traps_community_string": "public","traps_enable": true}}'
{"result":
{"_ref": "grid/b25lLmNsdXN0ZXIkMA:Infoblox",
"snmp_setting":
{"engine_id": ["80:00:1E:63:05:00:50:56:81:4d:38:0a:c4:cd:0c"],
"queries_community_string": "public",
"queries_enable": true,
"snmpv3_queries_enable": false,
"snmpv3_traps_enable": false,
80
"syscontact": [],
"sysdescr": [],
"syslocation": [],
"sysname": [],
"trap_receivers": [{"address": "1.1.1.1"}],
"traps_community_string": "public",
"traps_enable": true
}}}
{"ntp_setting":
{"enable_ntp": true,
<wapi_url>/grid/b25lLmNsdXN0ZXIkMA:Info
PUT "ntp_servers":
blox?_return_fields%2B=ntp_setting
[{"address":"10.224.0.10"}]
}}
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/grid/b25lLmNsdXN0ZXIkMA:Infoblox?_return_fields%2B=ntp
_setting&_return_as_object=1" -d '{"ntp_setting": {"enable_ntp": true,"ntp_servers":
[{"address":"10.224.0.10"}]}}'
{"result":
{"_ref": "grid/b25lLmNsdXN0ZXIkMA:Infoblox",
"ntp_setting":
Configure NTP {"enable_ntp": true,
"ntp_acl":
{"ac_list": [],
"acl_type": "NONE",
"service": "TIME"},
"ntp_keys": [],
"ntp_kod": false,
"ntp_servers":
[{"address": "10.224.0.10",
"burst": true,
"enable_authentication": false,
"iburst": true,
"preferred": false}]}
}}
<wapi_url>/grid/b25lLmNsdXN0ZXIkMA:Info {"dns_resolver_setting" :
PUT blox?_return_fields%2B=dns_resolver_settin {"resolvers":["192.168.8.52"]}
g }
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/grid/b25lLmNsdXN0ZXIkMA:Infoblox?_return_fields%2B=dn
s_resolver_setting&_return_as_object=1" -d '{"dns_resolver_setting" :
Configure DNS Resolver {"resolvers":["192.168.8.52"]}}'
Setting {"result":
{"_ref": "grid/b25lLmNsdXN0ZXIkMA:Infoblox",
"dns_resolver_setting":
{"resolvers": ["192.168.8.52"],
"search_domains": []
}
}}
Grid DNS properties
The grid:dns object supports DNS service management and configuration such as time-to-live (TTL) settings,
zone transfers, queries, root name servers, dynamic updates, sort lists, Transaction Signatures (TSIG) for DNS
and others, all at the grid level.
81
The service configurations of a grid are inherited by all members, zones, and networks unless you specifically
override them for selected members, zones, and networks. For this reason, it is recommended that you
configure services at the grid level before configuring member, zone and network services.
The Grid Member DNS (member:dns) object can be used to configure DNS properties for a Grid member,
including enabling or disabling DNS services and other DNS service related parameters. Remember to set the
corresponding use flag to true. The value of the field will only take effect when its use flag is true. Otherwise,
Grid service configurations are inherited by all members.
In the following examples, max_cached_lifetime indicates the maximum time (in seconds) a DNS response can
be stored in the hardware acceleration cache.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
<wapi_url>/grid:dns?_return_fields%2B=ma
GET
x_cached_lifetime
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/grid:dns?_return_fields%2B=max_cached_lifetime&_return_
Get grid DNS properties as_object=1"
{"result":
[{"_ref": "grid:dns/ZG5zLmNsdXN0ZXJfZG5zX3Byb3BlcnRpZXMkMA:Infoblox",
"max_cached_lifetime": 86400
}]}
<wapi_url>/grid:dns/ZG5zLmNsdXN0ZXJfZ
PUT G5zX3Byb3BlcnRpZXMkMA:Infoblox?_retur {"max_cached_lifetime":60000}
n_fields%2B=max_cached_lifetime
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
Modify grid DNS properties "https://grid-master/wapi/v2.12/grid:dns/ZG5zLmNsdXN0ZXJfZG5zX3Byb3BlcnRpZXMkMA:
(max_cached_lifetime) at the Infoblox?_return_fields%2B=max_cached_lifetime&_return_as_object=1" -d
Grid level '{"max_cached_lifetime":60000}'
{"result":
{"_ref": "grid:dns/ZG5zLmNsdXN0ZXJfZG5zX3Byb3BlcnRpZXMkMA:Infoblox",
"max_cached_lifetime": 60000
}}
<wapi_url>/member:dns?_return_fields%2B
GET
=max_cached_lifetime
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/member:dns?_return_fields%2B=max_cached_lifetime&_ret
urn_as_object=1"
{"result":
[{"_ref": "member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQw:infoblox.localdomain",
Get member DNS properties "host_name": "infoblox.localdomain",
"ipv4addr": "172.26.1.2",
"max_cached_lifetime": 86400
},
{"_ref": "member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQx:member1.localdomain",
"host_name": "member1.localdomain",
"ipv4addr": "172.26.1.3",
"max_cached_lifetime": 86400
}]}
82
<wapi_url>/member:dns/ZG5zLm1lbWJlcl9k
{"use_max_cached_lifetime":
bnNfcHJvcGVydGllcyQx:member1.localdom
PUT true,
ain?_return_fields%2B=max_cached_lifetim
"max_cached_lifetime":80000}
e
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQx:me
Modify DNS properties
mber1.localdomain?_return_fields%2B=max_cached_lifetime&_return_as_object=1" -d
(max_cached_lifetime) at the
'{"use_max_cached_lifetime": true,"max_cached_lifetime":80000}'
member level
{"result":
[{"_ref": "member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQx:member1.localdomain",
"host_name": "member1.localdomain",
"ipv4addr": "172.26.1.3",
"max_cached_lifetime": 80000
}]}
<wapi_url>/member:dns/ZG5zLm1lbWJlcl9k
{"additional_ip_list":
PUT bnNfcHJvcGVydGllcyQw:infoblox.localdomai
["32.32.32.32"]}
n?_return_fields%2B=additional_ip_list
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQw:inf
oblox.localdomain?_return_fields%2B=additional_ip_list&_return_as_object=1" -d
Update DNS properties with
'{"additional_ip_list": ["32.32.32.32"]}'
additional IP list
{"result":
[{"_ref": "member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQw:infoblox.localdomain",
"host_name": "infoblox.localdomain",
"ipv4addr": "172.26.1.3",
"additional_ip_list": ["32.32.32.32"]
}]}
Members
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/member
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/member?_return_as_object=1"
{"result":
[{"_ref": "member/b25lLnZpcnR1YWxfbm9kZSQw:infoblox.localdomain",
"config_addr_type": "IPV4",
"host_name": "infoblox.localdomain",
Get members "platform": "VNIOS",
"service_type_configuration": "ALL_V4"
},
{"_ref": "member/b25lLnZpcnR1YWxfbm9kZSQx:member1.localdomain",
"config_addr_type": "IPV4",
"host_name": "member1.localdomain",
"platform": "VNIOS",
"service_type_configuration": "ALL_V4"
}]}
<wapi_url>/member?host_name=infoblox.loc
GET
aldomain
Get details of a member
based on its name curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/member?host_name=infoblox.localdomain&_return_as_obje
ct=1"
83
{"result":
[{"_ref": "member/b25lLnZpcnR1YWxfbm9kZSQw:infoblox.localdomain",
"config_addr_type": "IPV4",
"host_name": "infoblox.localdomain",
"platform": "VNIOS",
"service_type_configuration": "ALL_V4"
}]}
<wapi_url>/member?ipv4_address=172.26.1.
GET
2
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/member?ipv4_address=172.26.1.2&_return_fields%2B=vip_
setting&_return_as_object=1"
{"result":
[{"_ref": "member/b25lLnZpcnR1YWxfbm9kZSQw:infoblox.localdomain",
"config_addr_type": "IPV4",
Get details of a member "host_name": "infoblox.localdomain",
based on its IPv4 address "platform": "VNIOS",
"service_type_configuration": "ALL_V4",
"vip_setting":
{"address": "172.26.1.2",
"dscp": 0,
"gateway": "172.26.1.1",
"primary": true,
"subnet_mask": "255.255.255.0",
"use_dscp": false
}}]}
<wapi_url>/member?_return_fields%2B=node
GET
_info
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/member?_return_fields%2B=node_info&_return_as_object=
1"
{"result":
[{"_ref": "member/b25lLnZpcnR1YWxfbm9kZSQw:infoblox.localdomain",
"config_addr_type": "IPV4",
"host_name": "infoblox.localdomain",
"node_info":
[{"ha_status": "NOT_CONFIGURED",
"hwid": "42017879A14D4EE9E59F6ABEC0E8F729",
"hwmodel": "",
Get node information for all "hwplatform": "VMWARE",
members "hwtype": "IB-V815",
"lan2_physical_setting": {"auto_port_setting_enabled": true},
"lan_ha_port_setting":
{"ha_port_setting":
{"auto_port_setting_enabled": true,
"speed": "10"},
"lan_port_setting": {"auto_port_setting_enabled": true}
},
"mgmt_physical_setting": {"auto_port_setting_enabled": true},
"paid_nios": false,
"physical_oid": "0",
"service_status":
[{"description": "Running",
"service": "NODE_STATUS",
"status": "WORKING"
84
},
{"description": "2% - Primary drive usage is OK.",
"service": "DISK_USAGE",
"status": "WORKING"
},
{"description": "172.26.1.2",
"service": "ENET_LAN",
"status": "WORKING"
},
{"description": "7% - Database capacity usage is OK.",
"service": "DB_OBJECT",
"status": "WORKING"
},
{"service": "NTP_SYNC",
"status": "INACTIVE"
},
…..
{"service": "VPN_CERT",
"status": "WORKING"
}],
"v6_mgmt_network_setting":
{"auto_router_config_enabled": false,
"enabled": false
}}],
......}
<wapi_url>/member?_return_fields%2B=servi
GET
ce_status
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/member?_return_fields%2B=service_status&_return_as_obj
ect=1"
{"result":
[{"_ref": "member/b25lLnZpcnR1YWxfbm9kZSQw:infoblox.localdomain",
"config_addr_type": "IPV4",
"host_name": "infoblox.localdomain",
"platform": "VNIOS",
"service_status":
[{"description": "DHCP Service is working",
"service": "DHCP",
"status": "WORKING"
Get Service Status for all },
members {"description": "DNS Service is working",
"service": "DNS",
"status": "WORKING"
},
{"description": "NTP Service is working",
"service": "NTP",
"status": "WORKING"
},
{"description": "Hard Disk: 0% - TFTP Service is inactive",
"service": "TFTP",
"status": "INACTIVE"
},
{"description": "Hard Disk: 0% - HTTP File Dist Service is inactive",
"service": "HTTP_FILE_DIST",
"status": "INACTIVE"
},
85
{"description": "Hard Disk: 0% - FTP Service is inactive",
"service": "FTP",
"status": "INACTIVE"
},
{"description": "CPU: 100%, Memory: 0%, Hard Disk: 0%",
"service": "BLOXTOOLS",
"status": "INACTIVE"
},
{"description": "Captive Portal Service is inactive",
"service": "CAPTIVE_PORTAL",
"status": "INACTIVE"
},
{"service": "HSM",
"status": "UNKNOWN"
}],
"service_type_configuration": "ALL_V4"
},
…
]}
<wapi_url>/member/b25lLnZpcnR1YWxfbm9
PUT {"host_name":"nios.test.com"}
kZSQw:infoblox.localdomain
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/member/b25lLnZpcnR1YWxfbm9kZSQw:infoblox.localdomai
n?_return_fields%2B=host_name&_return_as_object=1" -d '{"host_name":"nios.test.com"}'
Modify the name of a {"result":
member {"_ref": "member/b25lLnZpcnR1YWxfbm9kZSQw:nios.test.com",
"config_addr_type": "IPV4",
"host_name": "nios.test.com",
"platform": "VNIOS",
"service_type_configuration": "ALL_V4"
}}
{"static_routes":
[{"address":"10.10.10.0",
<wapi_url>/member/b25lLnZpcnR1YWxfbm9
PUT "gateway":"172.26.1.1",
kZSQw:infoblox.localdomain
"subnet_mask":
"255.255.255.0"}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/member/b25lLnZpcnR1YWxfbm9kZSQw:infoblox.localdomai
n?_return_fields%2B=static_routes&_return_as_object=1" -d '{ "static_routes":[{"address":
"10.10.10.0","gateway": "172.26.1.1","subnet_mask": "255.255.255.0"}]}'
Add static routes to a {"result":
member {"_ref": "member/b25lLnZpcnR1YWxfbm9kZSQw:infoblox.localdomain",
"config_addr_type": "IPV4",
"host_name": "infoblox.localdomain",
"platform": "VNIOS",
"service_type_configuration": "ALL_V4",
"static_routes":
[{"address": "10.10.10.0",
"gateway": "172.26.1.1",
"subnet_mask": "255.255.255.0"
}]}}
Delete static routes from a <wapi_url>/member/b25lLnZpcnR1YWxfbm9
PUT {"static_routes": []}
member kZSQw:infoblox.localdomain
86
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/member/b25lLnZpcnR1YWxfbm9kZSQw:infoblox.localdomai
n?_return_fields%2B=static_routes&_return_as_object=1" -d '{ "static_routes":[]}'
{"result":
{"_ref": "member/b25lLnZpcnR1YWxfbm9kZSQw:infoblox.localdomain",
"config_addr_type": "IPV4",
"host_name": "infoblox.localdomain",
"platform": "VNIOS",
"service_type_configuration": "ALL_V4",
"static_routes": []
}}
<wapi_url>/member:dns/ZG5zLm1lbWJlcl9kb
PUT nNfcHJvcGVydGllcyQw:member1.localdomai {"enable_dns":true}
n
Enable DNS Service on a
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
member
"https://grid-master/wapi/v2.12/member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQw:m
ember1.localdomain?_return_as_object=1" -d '{"enable_dns":true}'
{"result": "member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQw:member1.localdomain"}
<wapi_url>/member:dhcpproperties/ZG5zLm
PUT 1lbWJlcl9kaGNwX3Byb3BlcnRpZXMkMQ:me {"enable_dhcp":true}
mber1.localdomain
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
Enable DHCP Service on a
"https://grid-master/wapi/v2.12/member:dhcpproperties/ZG5zLm1lbWJlcl9kaGNwX3Byb3Bl
member
cnRpZXMkMQ:member1.localdomain?_return_as_object=1" -d '{"enable_dhcp":true}'
{"result":
"member:dhcpproperties/ZG5zLm1lbWJlcl9kaGNwX3Byb3BlcnRpZXMkMQ:member1.local
domain"}
{"config_addr_type": "IPV4",
"platform": "VNIOS",
"host_name":"autojoin01.localdo
main",
POST <wapi_url>/member "vip_setting":
{"subnet_mask": "255.255.255.0"
,
Add a member to the grid "address": "192.128.2.7",
"gateway":"192.128.2.1"}}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/member?_return_as_object=1" -d '{"config_addr_type":
"IPV4","platform":
"VNIOS","host_name":"autojoin01.localdomain","vip_setting": {"subnet_mask": "255.255.25
5.0","address": "192.128.2.7","gateway":"192.128.2.1"}}'
{"result": "member/b25lLnZpcnR1YWxfbm9kZSQx:autojoin01.localdomain"}
{"config_addr_type": "IPV4",
"platform": "VNIOS",
"host_name":"member-ha.localdo
main",
"enable_ha":true,
"router_id":150,
Add a HA member to the grid POST <wapi_url>/member
"vip_setting":
{"subnet_mask":
"255.255.255.0",
"address": "192.128.2.100",
"gateway":"192.128.2.1"},
"node_info":
87
[{"lan_ha_port_setting":
{"ha_ip_address":"192.128.2.70",
"mgmt_lan":"192.128.2.80"}},
{"lan_ha_port_setting":
{"ha_ip_address":"192.128.2.71",
"mgmt_lan":"192.128.2.81"}}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/member?_return_as_object=1" -d '{"config_addr_type":
"IPV4","platform":
"VNIOS","host_name":"member-ha.localdomain","enable_ha":true,"router_id":150,"vip_setti
ng": {"subnet_mask": "255.255.255.0","address":
"192.128.2.100","gateway":"192.128.2.1"},"node_info":[{"lan_ha_port_setting":{"ha_ip_addr
ess":"192.128.2.70","mgmt_lan":"192.128.2.80"}},{"lan_ha_port_setting":{"ha_ip_address":"
192.128.2.71","mgmt_lan":"192.128.2.81"}}]}'
{"result": "member/b25LnW9vjR1ZUxfbm9aUIsx:member-ha.localdomain"}
{"config_addr_type": "IPV4",
"platform": "VNIOS",
"host_name":"member-anycast.lo
caldomain",
"vip_setting":
{"subnet_mask":
"255.255.255.0",
"address": "192.128.2.100",
"gateway":"192.128.2.1"},
"additional_ip_list":
[{"anycast":true,
"enable_bgp":true,
"enable_ospf":true,
"interface":"LOOPBACK",
"ipv4_network_setting":
{"subnet_mask":
"255.255.255.255",
POST <wapi_url>/member
"address": "192.128.2.10",
"gateway":"192.128.2.1"}}],
Add a member with anycast "bgp_as":
configuration [{"as":100,
"link_detect":true,
"neighbors":
[{"authentication_mode":"NONE",
"interface":"LAN_HA",
"neighbor_ip":"192.168.2.102",
"remote_as":102,
"enable_bfd":true}]}],
"ospf_list":
[{"area_id":"100",
"authentication_type":"NONE",
"auto_calc_cost_enabled":true,
"interface":"LAN_HA",
"is_ipv4":true}]}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/member?_return_as_object=1" -d '{"config_addr_type":
"IPV4","platform": "VNIOS","host_name":"member-anycast.localdomain","vip_setting":
{"subnet_mask": "255.255.255.0","address":
"192.128.2.100","gateway":"192.128.2.1"},"additional_ip_list":[{"anycast":true,"enable_bgp":t
rue,"enable_ospf":true,"interface":"LOOPBACK","ipv4_network_setting":{"subnet_mask":
88
"255.255.255.255","address":
"192.128.2.10","gateway":"192.128.2.1"}}],"bgp_as":[{"as":100,"link_detect":true,"neighbors"
:[{"authentication_mode":"NONE","interface":"LAN_HA","neighbor_ip":"192.168.2.102","rem
ote_as":102,"enable_bfd":true}]}],"ospf_list":[{"area_id":"100","authentication_type":"NONE",
"auto_calc_cost_enabled":true,"interface":"LAN_HA","is_ipv4":true}]}'
{"result": "member/b25lLnZpcnR1YWxfbm9kZSQz:member-anycast.localdomain"}
{"grid_name":"Infoblox",
"master":"<grid master ip
POST <member_wapi_url>/grid?_function=join
address>",
Initiate member join "shared_secret":"test"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://member-master/wapi/v2.12/grid?_function=join&_return_as_object=1" -d
'{"grid_name":"Infoblox", "master":"grid-master", "shared_secret":"test"}'
Clear DNS Cache
REST
API Call
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/member:dns
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/member:dns?_return_as_object=1"
{"result":
[{"_ref": "member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQw:infoblox.localdomain",
"host_name": "infoblox.localdomain",
"ipv4addr": "10.196.205.12"},
{"_ref":
"member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQx:infoblox_member1.localdomain",
"host_name": "infoblox_member1.localdomain",
"ipv4addr": "10.196.205.13"},
Get member DNS reference {"_ref":
"member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQ2:infoblox-cpmember.localdomain"
,
"host_name": "infoblox-cpmember.localdomain",
"ipv4addr": "10.196.205.14"},
{"_ref":
"member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQ4:testingwapi.localdomain",
"host_name": "testingwapi.localdomain",
"ipv4addr": "192.128.2.7"},
{"_ref": "member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQxMA:nios.test.com",
"host_name": "nios.test.com",
"ipv4addr": "10.196.205.100"
}]}
<wapi_url>/member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQx:infoblox_
POST
member1.localdomain?_function=clear_dns_cache
Clear DNS cache of a curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
member "https://grid-master/wapi/v2.12/member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQx:inf
oblox_member1.localdomain?_function=clear_dns_cache"
{}
<wapi_url>/member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQx:infoblox_
POST
Clear DNS cache of a member1.localdomain?_function=clear_dns_cache&view=Internal%20DNS
member for a specific DNS curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
view "https://grid-master/wapi/v2.12/member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQx:inf
oblox_member1.localdomain?_function=clear_dns_cache&view=Internal%20DNS"
89
{}
<wapi_url>/member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQx:infoblox_
POST member1.localdomain?_function=clear_dns_cache&domain=test.com&clear_f
ull_tree=true
Clear DNS cache of a
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
member for a specific FQDN
"https://grid-master/wapi/v2.12/member:dns/ZG5zLm1lbWJlcl9kbnNfcHJvcGVydGllcyQx:inf
and all the records within it
oblox_member1.localdomain?_function=clear_dns_cache&domain=test.com&clear_full_tre
e=true"
{}
Services
REST
API Call Sample Body
Operation Method
Sample cURL Command
<wapi_url>/grid/b25lLmNsdXN0ZXIkMA:Infoblox?_f
POST {"service_option": "ALL"}
unction=requestrestartservicestatus
Get grid service status curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/grid/b25lLmNsdXN0ZXIkMA:Infoblox?_function=requestr
estartservicestatus" -d '{"service_option": "ALL"}'
{"member_order" :
<wapi_url>/grid/b25lLmNsdXN0ZXIkMA:Infoblox?_f
POST "SIMULTANEOUSLY",
unction=restartservices
"service_option": "ALL"}
Restart the services
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/grid/b25lLmNsdXN0ZXIkMA:Infoblox?_function=
restartservices" -d '{"member_order" : "SIMULTANEOUSLY","service_option": "ALL"}'
{"member_order" :
"SIMULTANEOUSLY",
<wapi_url>/grid/b25lLmNsdXN0ZXIkMA:Infoblox?_f
POST "restart_option":"FORCE
unction=restartservices
_RESTART",
Restart the services when no "service_option": "ALL"}
restart action is required
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/grid/b25lLmNsdXN0ZXIkMA:Infoblox?_function=
restartservices" -d '{"member_order" :
"SIMULTANEOUSLY","restart_option":"FORCE_RESTART","service_option": "ALL"}'
<wapi_url>/grid:servicerestart:request:changedobje
GET
ct
Get the pending changes
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/grid:servicerestart:request:changedobject"
In the above examples, in the service_option you can replace ALL with DNS or DHCP
Discovery
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/discoverytask
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/discoverytask?_return_as_object=1"
Get the pre-built discovery tasks
on the grid {"result":
[{"_ref": "discoverytask/ZG5zLmRpc2NvdmVyeV90YXNrJGN1cnJlbnQ:current",
"discovery_task_oid": "current",
"member_name": "infoblox.localdomain"},
90
{"_ref": "discoverytask/ZG5zLmRpc2NvdmVyeV90YXNrJHNjaGVkdWxlZA:scheduled",
"discovery_task_oid": "scheduled",
"member_name": "infoblox.localdomain"
}]}
'{"mode":"ICMP",
"network_view":"default",
"networks":
["network/ZG5zLm5ldHdvcmskMTky
LjE2OC4xMS4wLzI0LzA:192.168.11
.0/24/default",
"network/ZG5zLm5ldHdvcmskMTcy
LjAuMC4wLzI0LzA:172.0.0.0/24/def
ault",
<wapi_url>/discoverytask/ZG5zLmRpc2N
"network/ZG5zLm5ldHdvcmskMTAu
PUT vdmVyeV90YXNrJHNjaGVkdWxlZA:sche
MTAuMTAwLjAvMjQvMA:10.10.100.
duled
0/24/default"],
"ping_retries": 5,
"ping_timeout": 1500,
Modify the scheduled discovery "scheduled_run":
task {"frequency": "DAILY",
"hour_of_day": 6,
"minutes_past_hour": 0,
"repeat": "RECUR"
}}'
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/discoverytask/ZG5zLmRpc2NvdmVyeV90YXNrJHNjaGVk
dWxlZA:scheduled" -d '{"mode":"ICMP","network_view":"default","networks":
["network/ZG5zLm5ldHdvcmskMTkyLjE2OC4xMS4wLzI0LzA:192.168.11.0/24/default",
"network/ZG5zLm5ldHdvcmskMTcyLjAuMC4wLzI0LzA:172.0.0.0/24/default","network/ZG
5zLm5ldHdvcmskMTAuMTAuMTAwLjAvMjQvMA:10.10.100.0/24/default"],"ping_retries":
5,"ping_timeout": 1500,"scheduled_run": {"frequency": "DAILY","hour_of_day":
6,"minutes_past_hour": 0,"repeat": "RECUR"}}'
discoverytask/ZG5zLmRpc2NvdmVyeV90YXNrJHNjaGVkdWxlZA:scheduled
'{"mode":"ICMP",
"network_view":"default",
"networks":
["network/ZG5zLm5ldHdvcmskMTky
LjE2OC4xMS4wLzI0LzA:192.168.11
.0/24/default",
<wapi_url>/discoverytask/ZG5zLmRpc2N "network/ZG5zLm5ldHdvcmskMTcy
PUT
vdmVyeV90YXNrJGN1cnJlbnQ:current LjAuMC4wLzI0LzA:172.0.0.0/24/def
ault",
"network/ZG5zLm5ldHdvcmskMTAu
MTAuMTAwLjAvMjQvMA:10.10.100.
Modify the current discovery task 0/24/default"],
"ping_retries": 5,
"ping_timeout": 1500}'
curl -k -u admin:infoblox -H 'content-type: application/json' -X PUT
"https://grid-master/wapi/v2.12/discoverytask/ZG5zLmRpc2NvdmVyeV90YXNrJGN1cnJlb
nQ:current" -d '{"mode":"ICMP","network_view":"default","networks":
["network/ZG5zLm5ldHdvcmskMTkyLjE2OC4xMS4wLzI0LzA:192.168.11.0/24/default",
"network/ZG5zLm5ldHdvcmskMTcyLjAuMC4wLzI0LzA:172.0.0.0/24/default","network/ZG
5zLm5ldHdvcmskMTAuMTAuMTAwLjAvMjQvMA:10.10.100.0/24/default"],"ping_retries":
5,"ping_timeout": 1500}'
discoverytask/ZG5zLmRpc2NvdmVyeV90YXNrJGN1cnJlbnQ:current
91
<wapi_url>/discoverytask/ZG5zLmRpc2
POST NvdmVyeV90YXNrJGN1cnJlbnQ:current {"action":"START"}
?_function=network_discover_control
Start the current discovery task
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/discoverytask/ZG5zLmRpc2NvdmVyeV90YXNrJGN1cnJlb
nQ:current?_function=network_discovery_control" -d '{"action":"START"}'
<wapi_url>/discoverytask?_return_fields
GET
%2B=status,state
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/discoverytask?_return_as_object=1&_return_fields%2B=s
tatus,state"
{"result":
[{"_ref": "discoverytask/ZG5zLmRpc2NvdmVyeV90YXNrJGN1cnJlbnQ:current",
"discovery_task_oid": "current",
"member_name": "infoblox.localdomain",
Fetch the discovery task to get "state": "COMPLETE",
the state "status": "Current status: Ended\nDiscovery was started by administrator 'admin'\n\n
Discovered: 8\n Pending processing: 0\n Managed: 0\n Unmanaged: 8\n Conflicts: 0\n\n
Existing objects updated with discovery data: 0"},
{"_ref": "discoverytask/ZG5zLmRpc2NvdmVyeV90YXNrJHNjaGVkdWxlZA:scheduled",
"discovery_task_oid": "scheduled",
"member_name": "infoblox.localdomain",
"state": "COMPLETE",
"status": "Current status: Ended\n\n Discovered: 0\n Pending processing: 0\n
Managed: 0\n Unmanaged: 0\n Conflicts: 0\n\n Existing objects updated with discovery
data: 0"
}]}
vDiscovery
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/vdiscoverytask
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/vdiscoverytask?_return_as_object=1"
{"result":
[{"_ref":
"vdiscoverytask/ZG5zLmNkaXNjb3ZlcnlfdGFzayRBenVyZSB2RGlzY292ZXJ5:Azure%20
vDiscovery",
"name": "Azure vDiscovery",
"state": "WARNING"
},
Get vDiscovery tasks {"_ref":
"vdiscoverytask/ZG5zLmNkaXNjb3ZlcnlfdGFzayRBV1MgdkRpc2NvdmVyeQ:AWS%20vD
iscovery",
"name": "AWS vDiscovery",
"state": "WARNING"
},
{"_ref":
"vdiscoverytask/ZG5zLmNkaXNjb3ZlcnlfdGFzayRWTXdhcmUgdkRpc2NvdmVyeQ:VMwa
re%20vDiscovery",
"name": "VMware vDiscovery",
"state": "WARNING"
92
},
{"_ref":
"vdiscoverytask/ZG5zLmNkaXNjb3ZlcnlfdGFzayRPcGVuc3RhY2sgdkRpc2NvdmVyeQ:O
penstack%20vDiscovery",
"name": "Openstack vDiscovery",
"state": "WARNING"
}]}
'{"name": "ec2.eu-west-1",
"driver_type": "AWS",
"fqdn_or_ip":
"ec2.eu-west-1.amazonaws.com",
"username": "test",
"password": "test",
"member": "infoblox.localdomain",
"port": 443,
"protocol": "HTTPS",
"auto_consolidate_cloud_ea": true,
"auto_consolidate_managed_tenant
": true,
"auto_consolidate_managed_vm":
true,
POST <wapi_url>/vdiscoverytask
"merge_data": true,
"private_network_view": "default",
"private_network_view_mapping_po
licy": "DIRECT",
"public_network_view": "default",
"public_network_view_mapping_poli
cy": "DIRECT",
"update_metadata": true,
Create a vDiscovery Task to "scheduled_run":
discover the AWS environment {"_struct":"setting:schedule",
"frequency": "HOURLY",
"repeat": "RECUR",
"minutes_past_hour": 1,
"disable": true}}'
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/vdiscoverytask?_return_fields=name,driver_type&_return_
as_object=1" -d '{"name": "ec2.eu-west-1", "driver_type": "AWS", "fqdn_or_ip":
"ec2.eu-west-1.amazonaws.com", "username": "test", "password": "test", "member":
"infoblox.localdomain", "port": 443, "protocol": "HTTPS", "auto_consolidate_cloud_ea":
true, "auto_consolidate_managed_tenant": true, "auto_consolidate_managed_vm": true,
"merge_data": true, "private_network_view": "default",
"private_network_view_mapping_policy": "DIRECT", "public_network_view": "default",
"public_network_view_mapping_policy": "DIRECT", "update_metadata": true,
"scheduled_run": {"_struct":"setting:schedule","frequency": "HOURLY", "repeat":
"RECUR", "minutes_past_hour": 1, "disable": true}}'
{"result":
{"_ref":
"vdiscoverytask/ZG5zLmNkaXNjb3ZlcnlfdGFzayRlYzIuZXUtd2VzdC0x:ec2.eu-west-1",
"driver_type": "AWS",
"name": "ec2.eu-west-1"
}}
<wapi_url>/vdiscoverytask/ZG5zLmNka
Start a vDiscovery task POST {"action":"START"}
XNjb3ZlcnlfdGFzayRlYzIuZXUtd2VzdC0
93
x:ec2.eu-west-1?_function=vdiscover_co
ntrol
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/vdiscoverytask/ZG5zLmNkaXNjb3ZlcnlfdGFzayRlYzIuZX
Utd2VzdC0x:ec2.eu-west-1?_function=vdiscovery_control" -d '{"action":"START"}'
Permissions
REST
API Call
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/permission
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/permission?_return_as_object=1"
{"result":
[{"_ref":
"permission/b25lLmhpZXJfcnVsZSQuY29tLmluZm9ibG94LmRucy56b25lJC4uLi4uY29tL
mluZm9ibG94Lm9uZS5yb2xlJEROUyBBZG1pbi4:DNS%20Admin/WRITE",
"permission": "WRITE",
"resource_type": "VIEW",
"role": "DNS Admin"
},
{"_ref":
"permission/b25lLmhpZXJfcnVsZSQuY29tLmluZm9ibG94LmRucy56b25lJC5zcmdfcm9v
Get permissions dC4uLmNvbS5pbmZvYmxveC5vbmUucm9sZSRETlMgQWRtaW4u:DNS%20Admin/WR
ITE",
"permission": "WRITE",
"resource_type": "SHARED_RECORD_GROUP",
"role": "DNS Admin"
},
….
{"_ref":
"permission/b25lLmhpZXJfcnVsZSQuY29tLmluZm9ibG94LmRucy5uZXR3b3JrX3ZpZXd
fcGFyZW50JC8uLi5jb20uaW5mb2Jsb3gub25lLnJvbGUkR3JpZCBBZG1pbi5kbnMubXN
fYWRfc2l0ZXNfZG9tYWlu:Grid%20Admin/WRITE",
"permission": "WRITE",
"resource_type": "MS_ADSITES_DOMAIN",
"role": "Grid Admin"
}]}
GET <wapi_url>/permission?role=DHCP%20Admin
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/permission?role=DHCP%20Admin&_return_as_object=1
"
{"result":
[{"_ref":
Get permissions for a role "permission/b25lLmhpZXJfcnVsZSQuY29tLmluZm9ibG94LmRucy5uZXR3b3JrX3ZpZXd
(DHCP Admin) fcGFyZW50JC8uLi5jb20uaW5mb2Jsb3gub25lLnJvbGUkREhDUCBBZG1pbi4:DHCP%2
0Admin/WRITE",
"permission": "WRITE",
"resource_type": "NETWORK_VIEW",
"role": "DHCP Admin"
},
{"_ref":
"permission/b25lLmhpZXJfcnVsZSQuY29tLmluZm9ibG94LmRucy5kaGNwX21hY19ma
94
Wx0ZXJfcGFyZW50JDAuLi5jb20uaW5mb2Jsb3gub25lLnJvbGUkREhDUCBBZG1pbi4:
DHCP%20Admin/WRITE",
"permission": "WRITE",
"resource_type": "DHCP_MAC_FILTER",
"role": "DHCP Admin"
},
…..
{"_ref":
"permission/b25lLmhpZXJfcnVsZSQuY29tLmluZm9ibG94LmRucy5jbHVzdGVyX2RoY3
BfcHJvcGVydGllcyQwLi4uY29tLmluZm9ibG94Lm9uZS5yb2xlJERIQ1AgQWRtaW4u:DH
CP%20Admin/WRITE",
"permission": "WRITE",
"resource_type": "GRID_DHCP_PROPERTIES",
"role": "DHCP Admin"
}]}
GET <wapi_url>/permission?group=cloud-api-only
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/permission?group=cloud-api-only"
{"result":
[{"_ref":
"permission/b25lLmhpZXJfcnVsZSQuY29tLmluZm9ibG94LmRucy5jbHVzdGVyX2RoY3
BfcHJvcGVydGllcyQwLi4uY29tLmluZm9ibG94Lm9uZS5hZG1pbl9ncm91cCQuY2xvdW
QtYXBpLW9ubHku:cloud-api-only/WRITE",
"group": "cloud-api-only",
"permission": "WRITE",
"resource_type": "GRID_DHCP_PROPERTIES"
},
{"_ref":
"permission/b25lLmhpZXJfcnVsZSQuY29tLmluZm9ibG94LmRucy50ZW5hbnRfcGFyZW
50JGFsbC4uLmNvbS5pbmZvYmxveC5vbmUuYWRtaW5fZ3JvdXAkLmNsb3VkLWFwa
S1vbmx5Lg:cloud-api-only/WRITE",
"group": "cloud-api-only",
Get permissions for a group "permission": "WRITE",
"resource_type": "TENANT"
},
{"_ref":
"permission/b25lLmhpZXJfcnVsZSQuY29tLmluZm9ibG94LmRucy5uZXR3b3JrX3ZpZXd
fcGFyZW50JC8uLi5jb20uaW5mb2Jsb3gub25lLmFkbWluX2dyb3VwJC5jbG91ZC1hcGkt
b25seS4:cloud-api-only/WRITE",
"group": "cloud-api-only",
"permission": "WRITE",
"resource_type": "NETWORK_VIEW"
},
{"_ref":
"permission/b25lLmhpZXJfcnVsZSQuY29tLmluZm9ibG94LmRucy5jbHVzdGVyX2Ruc19
wcm9wZXJ0aWVzJDAuLi5jb20uaW5mb2Jsb3gub25lLmFkbWluX2dyb3VwJC5jbG91ZC
1hcGktb25seS4:cloud-api-only/WRITE",
"group": "cloud-api-only",
"permission": "WRITE",
"resource_type": "GRID_DNS_PROPERTIES"
}]}
Export a CSV file
When you initiate a CSV Export, you will get a URL that can be used to download the file directly, and a token
for the download session. After downloading the CSV file, remember to remove the stored file using the token.
95
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
POST <wapi_url>/fileop?_function=csv_export {"_object": "record:host"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/fileop?_function=csv_export" -d '{"_object": "record:host"}'
{"token":
"eJylUMFuwjAMvftH4ELbFNrCbkwd2qQJJJi0o9UmKbPUJlkSEPz9nEnbabcdYjl+z89+ltK6O3p9\nB
Initiate a CSV export g7SmhD9RUbrwQmYSzKD7Ud7y6zR6cW70wHaLnZ41AO4EiRif6ExkkEERTKCW8JcuRWcZvrmy
N8x\n0qRn4CrYiaqomqouVpus4VCtIZxmFz8yWjP/I0YXHvJcNGVW1pnIyjyVUBGvFnGgUSPZ3OtP
JLVo\nD+/718O2XYiiEPmz5c3ZgFchk+HKik0SJ8XZmrX/amJok0iK/XAuCublgc13Z53Hyf1nuhA/yqiN
\ntIrMOVVLHvH4sk/p8pcwWZUOJNLN2u3bFo9Pu/SvIMSjE3W6p2gYHEiPKmC0KO3kOv/dtYZ9Mt
p3\nDsm4S8Sr9oGsSdiGsT77AjVimUo=\n",
"url": "https://grid-master.2/http_direct_file_io/req_id-DOWNLOAD-1001/Hostrecords.csv"
}
<url_from_the_previous_output>
Example:
GET
https://x.x.x.x/http_direct_file_io/req_id-DOWNLOAD-10
Download the CSV 01/Hostrecords.csv
file curl -k -u admin:infoblox -H 'content-type: application/force-download'
"https://grid-master/http_direct_file_io/req_id-DOWNLOAD-1001/Hostrecords.csv" -o
"Hostrecords.csv"
#Hostrecords.csv file is saved in the present working directory#
POST <wapi_url>/fileop?_function=downloadcomplete {"token": "eJyIUM..o="}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/fileop?_function=downloadcomplete" -d '{"token" :
Remove the stored "eJylUMFuwjAMvftH4ELbFNrCbkwd2qQJJJi0o9UmKbPUJlkSEPz9nEnbabcdYjl+z89+ltK6O3p9\nB
file using the token g7SmhD9RUbrwQmYSzKD7Ud7y6zR6cW70wHaLnZ41AO4EiRif6ExkkEERTKCW8JcuRWcZvrmy
N8x\n0qRn4CrYiaqomqouVpus4VCtIZxmFz8yWjP/I0YXHvJcNGVW1pnIyjyVUBGvFnGgUSPZ3OtP
JLVo\nD+/718O2XYiiEPmz5c3ZgFchk+HKik0SJ8XZmrX/amJok0iK/XAuCublgc13Z53Hyf1nuhA/yqiN
\ntIrMOVVLHvH4sk/p8pcwWZUOJNLN2u3bFo9Pu/SvIMSjE3W6p2gYHEiPKmC0KO3kOv/dtYZ9Mt
p3\nDsm4S8Sr9oGsSdiGsT77AjVimUo=\n"}'
Please note that while downloading the CSV file (in the second step above), the Content-Type in the header will
be application/force-download.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
{"_encoding":"JSON",
"_filename":"allhosts.info.com.js
POST <wapi_url>/fileop?_function=read on","_object":"record:host",
"_return_fields":"name,extattrs",
Export results of a "zone":"info.com"}
WAPI call
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/fileop?_function=read" -d
'{"_encoding":"JSON","_filename":"allhosts.info.com.json","_object":"record:host","_return_fields":"na
me,extattrs","zone":"info.com"}'
96
The file will be in a folder called 'wapi_output' in the HTTP file distribution.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
{"member": "m1.infoblox.com",
POST <wapi_url>/fileop?_function=getleasehistoryfiles "start_time": "1514764800",
"end_time" :"1533686400"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/fileop?_function=getleasehistoryfiles" -d '{"member":
"m1.infoblox.com", "start_time": "1514764800", "end_time" :"1533686400"}'
{"token":
"eJylUMFuwjAMvftH4ELbFNrCbkwd2qQJJJi0o9UmKbPUJlkSEPz9nEnbabcdYjl+z89+ltK6O3p9\nB
Initiate a CSV export g7SmhD9RUbrwQmYSzKD7Ud7y6zR6cW70wHaLnZ41AO4EiRif6ExkkEERTKCW8JcuRWcZvrmy
N8x\n0qRn4CrYiaqomqouVpus4VCtIZxmFz8yWjP/I0YXHvJcNGVW1pnIyjyVUBGvFnGgUSPZ3OtP
JLVo\nD+/718O2XYiiEPmz5c3ZgFchk+HKik0SJ8XZmrX/amJok0iK/XAuCublgc13Z53Hyf1nuhA/yqiN
\ntIrMOVVLHvH4sk/p8pcwWZUOJNLN2u3bFo9Pu/SvIMSjE3W6p2gYHEiPKmC0KO3kOv/dtYZ9Mt
p3\nDsm4S8Sr9oGsSdiGsT77AjVimUo=\n",
"url":
"https://192.168.1.2/http_direct_file_io/req_id-DOWNLOAD-0202150809630902/dhcpLeaseHistory.c
sv.gz"
}
<url_from_the_previous_output>
Example:
GET
https://x.x.x.x/http_direct_file_io/req_id-DOWNLOAD-02
Download the CSV 02150809630902/dhcpLeaseHistory.csv.gz
file curl -k -u admin:infoblox -H 'content-type: application/force-download'
"https://grid-master/http_direct_file_io/req_id-DOWNLOAD-0202150809630902/dhcpLeaseHistory.c
sv.gz" -o "dhcpLeaseHistory.csv.gz"
#dhcpLeaseHistory.csv.gz file is saved in the present working directory#
POST <wapi_url>/fileop?_function=downloadcomplete {"token": "eJyIUM..o="}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/fileop?_function=downloadcomplete" -d '{"token" :
Remove the stored "eJylUMFuwjAMvftH4ELbFNrCbkwd2qQJJJi0o9UmKbPUJlkSEPz9nEnbabcdYjl+z89+ltK6O3p9\nB
file using the token g7SmhD9RUbrwQmYSzKD7Ud7y6zR6cW70wHaLnZ41AO4EiRif6ExkkEERTKCW8JcuRWcZvrmy
N8x\n0qRn4CrYiaqomqouVpus4VCtIZxmFz8yWjP/I0YXHvJcNGVW1pnIyjyVUBGvFnGgUSPZ3OtP
JLVo\nD+/718O2XYiiEPmz5c3ZgFchk+HKik0SJ8XZmrX/amJok0iK/XAuCublgc13Z53Hyf1nuhA/yqiN
\ntIrMOVVLHvH4sk/p8pcwWZUOJNLN2u3bFo9Pu/SvIMSjE3W6p2gYHEiPKmC0KO3kOv/dtYZ9Mt
p3\nDsm4S8Sr9oGsSdiGsT77AjVimUo=\n"}'
Please note that while downloading the lease history file (in the second step above), the Content-Type in the
header will be application/force-download.
97
When you initiate a file import, you will get a URL to which you can upload the file to. Once you have uploaded
the file, signal to the appliance to perform an action on the uploaded file. In this example, we will upload a
certificate.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
POST <wapi_url>/fileop?_function=uploadinit
curl -k -u admin:infoblox -H 'content-type:application/json' -X POST
"https://grid-master/wapi/v2.12/fileop?_function=uploadinit"
{"token":
"eJydUMFOwzAMvftHymVt09Fu5TY0JiGhgTY4W22SDkttYpIUbX9PMgQXbhwS2X7PL3lPSssXdPo
Initiate file upload E\n8ZLW+OBmGawDFnAjyQy2H+05t0anEy6sPWy70OFBD8AVSMR+pjGQQQRFMgAv4UbxLRwzf
WZyFww0\n6Qy4hp2oy3pVN1XT5GXZtmIF/pjNboxoE/nvIbC/KwqxqvKqyUVeFWmEiuLXAg40aiRb
OP2BpBZv\nL0/Pm+1ClKUoaGLrvhlR6ypLKlbrqPqXHoE2UVT0EWtRRlbho+nupIsw8f9eFeJHE7W
RVpE5pWkV\nxe8f96lc/hImq64rKaXt5nWDh4dd6mvw4cCiSQnGdI7ZQHpUHoNFaSfu3HVrDftksO8
YyfAc8FM7\nT9YkrI1Yn38Bt1KUqw==\n",
"url": "https://172.26.1.2/http_direct_file_io/req_id-UPLOAD-1001/import_file"
}
<url_from_the_previous_output>
Example:
POST [email protected]
Upload contents of a https://x.x.x.x/http_direct_file_io/req_id-UPLOAD-1001/i
CA certificate mport_file
curl -k -u admin:infoblox -H 'content-type:multipart-formdata'
"https://grid-master/http_direct_file_io/req_id-UPLOAD-1001/import_file" -F [email protected]
{"certificate_usage":"EAP_CA",
"member":
POST <wapi_url>/fileop?_function=uploadcertificate
"infoblox.localdomain",
"token":"eJydk..=="}
curl -k -u admin:infoblox -H 'content-type:application/json' -X POST
Upload the CA "https://grid-master/wapi/v2.12/fileop?_function=uploadcertificate" -d
Certificate '{"certificate_usage":"EAP_CA","member":
"infoblox.localdomain","token":"eJydUMFOwzAMvftHymVt09Fu5TY0JiGhgTY4W22SDkttYpIUbX9P
MgQXbhwS2X7PL3lPSssXdPoE\n8ZLW+OBmGawDFnAjyQy2H+05t0anEy6sPWy70OFBD8AVSM
R+pjGQQQRFMgAv4UbxLRwzfWZyFww0\n6Qy4hp2oy3pVN1XT5GXZtmIF/pjNboxoE/nvIbC/Kwqx
qvKqyUVeFWmEiuLXAg40aiRbOP2BpBZv\nL0/Pm+1ClKUoaGLrvhlR6ypLKlbrqPqXHoE2UVT0EWt
RRlbho+nupIsw8f9eFeJHE7WRVpE5pWkV\nxe8f96lc/hImq64rKaXt5nWDh4dd6mvw4cCiSQnGdI7Z
QHpUHoNFaSfu3HVrDftksO8YyfAc8FM7\nT9YkrI1Yn38Bt1KUqw==\n"}'
Please note that while uploading the file (in the second step above), the Content-Type in the header will be
multipart/form-data
98
Import a CSV file
When you need to update or create multiple records, you can store the data as fields in a CSV file and import it
at once. This will be faster in comparison with updating or creating each object with a separate API call. This
example assumes that the values and fields in your CSV file are comma-separated. For more information on
the CSV file, you can refer to the CSV Import Reference section under Tech Docs in the Support Site.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
POST <wapi_url>/fileop?_function=uploadinit
curl -k -u admin:infoblox -H 'content-type:application/json' -X POST
"https://grid-master/wapi/v2.12/fileop?_function=uploadinit"
{"token":
"eJydUE1PwzAMvfuPbJe1Tbe2G7ehMQkJDbTB2WqTdFhqk5CkaPv3OENw4cYhkeP34TxLad0Vv
Initiate file upload T4D\nX9KaEP0ko/XgBMwlmd52g71k1uh04tXpALs2tnjUPbgSJGI30RDJIIIiGcEtYa7cCk4zfXHkrxhp\
n1DNwFexFVVRNVddVk4l6tdyUGwin2eQHhmsWvMfowl2ei6bMyjoTWZmnFiriv0XsadBINvf6A0kt\n
3l6enre7hSiKMqfRWf/NYK8m2ZLias2uf+kM3CYrDsK1KJiVB07dnnUeR/e/qUL8eKI20ioy59Qt\n2fz+
8ZDK5S9htOomSWvabV+3eHzYp3cFIR6dqNMKRcNgT3pQAaNFaUfX+ptqDYcUsGsdknFTxE/t\nA
1mTsA1jXfYFNGOU6g==\n",
"url": "https://172.26.1.2/http_direct_file_io/req_id-UPLOAD-1002/import_file"
}
<url_from_the_previous_output>
Example:
POST [email protected]
Upload contents of https://x.x.x.x/http_direct_file_io/req_id-UPLOAD-1002/i
the CSV file mport_file
curl -k -u admin:infoblox -H 'content-type:multipart/form-data' "https://grid-master/
http_direct_file_io/req_id-UPLOAD-1002/import_file" -F [email protected]
{"action":"START",
"on_error":"CONTINUE",
POST <wapi_url>/fileop?_function=csv_import
"update_method":"MERGE",
"token":"eJydU..=="}
curl -k -u admin:infoblox -H 'content-type:application/json' -X POST
"https://grid-master/wapi/v2.12/fileop?_function=csv_import" -d
'{"action":"START","on_error":"CONTINUE","update_method":"MERGE","token":"eJydUE1PwzAMvf
uPbJe1Tbe2G7ehMQkJDbTB2WqTdFhqk5CkaPv3OENw4cYhkeP34TxLad0VvT4D\nX9KaEP0ko/X
gBMwlmd52g71k1uh04tXpALs2tnjUPbgSJGI30RDJIIIiGcEtYa7cCk4zfXHkrxhp\n1DNwFexFVVRNV
ddVk4l6tdyUGwin2eQHhmsWvMfowl2ei6bMyjoTWZmnFiriv0XsadBINvf6A0kt\n3l6enre7hSiKMqfR
Wf/NYK8m2ZLias2uf+kM3CYrDsK1KJiVB07dnnUeR/e/qUL8eKI20ioy59Qt\n2fz+8ZDK5S9htOomS
WvabV+3eHzYp3cFIR6dqNMKRcNgT3pQAaNFaUfX+ptqDYcUsGsdknFTxE/t\nA1mTsA1jXfYFNGO
Upload the CSV file U6g==\n"}'
{"csv_import_task":
{"_ref": "csvimporttask/b25lLmNzdl9pbXBvcnRfdGFzayQ1:5",
"admin_name": "admin",
"file_name": "import_file",
"file_size": 215,
"import_id": 5,
"lines_failed": 0,
"lines_processed": 0,
"lines_warning": 0,
"on_error": "CONTINUE",
"operation": "UPDATE",
"separator": "COMMA",
99
"start_time": 1537512228,
"status": "PENDING",
"update_method": "MERGE"
}}
GET <wapi_url>/csvimporttask/b25lLmNzdl9pbXBvcnRfdGFzayQ1:5
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/csvimporttask/b25lLmNzdl9pbXBvcnRfdGFzayQ1:5"
{"_ref": "csvimporttask/b25lLmNzdl9pbXBvcnRfdGFzayQ1:5",
"admin_name": "admin",
"end_time": 1537512233,
"file_name": "import_file",
"file_size": 215,
Verify the status of "import_id": 5,
the CSV import task "lines_failed": 0,
"lines_processed": 3,
"lines_warning": 0,
"on_error": "CONTINUE",
"operation": "UPDATE",
"separator": "COMMA",
"start_time": 1537512233,
"status": "COMPLETED",
"update_method": "MERGE"
}
Please note that while uploading the file (in the second step above), the Content-Type in the header will be
multipart/form-data.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
{"certificate_usage" : "ADMIN",
"algorithm":"SHA-512",
"email" :
"[email protected]",
"cn" : "API-Testing",
"country" : "US",
POST <wapi_url>/fileop?_function=generatecsr
"state" : "California",
"locality" : "Santa Clara",
"org" : "Infoblox",
Initiate a CSV export "org_unit" : "TME",
"member":
"infoblox.localdomain"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/fileop?_function=generatecsr" -d '{"_object": "record:host"}'
{"token":
"eJyljrEKwjAURX+lZLZJXzSN7VapgiAtiOAYSvOsAWNrjKCI/24z6Orgei733PskeB+MeyhvLJI8\ngnQ
2nfNUCEElZGIGMInIzZ3GiBy9H645Y5BQyFLKE0GBs0CVNg5brw7mhMr0zOFFGR2X9b7a1EUZ\n
JzzhIHkGQkIqhWQtOk8HtGS068Y3Cs9tr825CzuLdfXlttfhFimLXaG2y9UnCIxdfe+aDpm3w/83\njA7
OXxXyegM9j1mw\n",
100
"url": "https://10.196.205.12/http_direct_file_io/req_id-DOWNLOAD-0202172915716757/cert.pem"}
<url_from_the_previous_output>
Example:
GET
https://x.x.x.x/http_direct_file_io/rreq_id-DOWNLOAD-0
Download the CSV 202172915716757/cert.pem
file curl -k -u admin:infoblox -H 'content-type: application/force-download'
"https://grid-master/http_direct_file_io/req_id-DOWNLOAD-0202172915716757/cert.pem" -o
"cert.pem"
#cert.pem file is saved in the present working directory#
POST <wapi_url>/fileop?_function=downloadcomplete {"token": "eJyl..w\n"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
Remove the stored "https://grid-master/wapi/v2.12/fileop?_function=downloadcomplete" -d '{"token" :
file using the token "eJyljrEKwjAURX+lZLZJXzSN7VapgiAtiOAYSvOsAWNrjKCI/24z6Orgei733PskeB+MeyhvLJI8\ngnQ
2nfNUCEElZGIGMInIzZ3GiBy9H645Y5BQyFLKE0GBs0CVNg5brw7mhMr0zOFFGR2X9b7a1EUZ\n
JzzhIHkGQkIqhWQtOk8HtGS068Y3Cs9tr825CzuLdfXlttfhFimLXaG2y9UnCIxdfe+aDpm3w/83\njA7
OXxXyegM9j1mw\n"}'
Please note that while downloading the CSV file (in the second step above), the Content-Type in the header will
be application/force-download.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
POST <wapi_url>/fileop?_function=getgriddata {"type": "BACKUP"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/fileop?_function=getgriddata" -d '{"type": "BACKUP"}'
{"token":
"eJydUE1PwzAMvfuPjMvaplvWjdtQmYSENmlD4mi1STos2iQkGdr+PQ4SnDhxSOT4fcR+Sjl/w2DO\
Initiate a backup nwJdyNqZwUckF8ALuFNnB9aO7Fs6afNLNmwhtlzo8mgF8DQqxv9CYyCKCJpXAL+BO+yWcZubqK
dww\n0WRm4CXshKxkI+W6XhWyqZayhniaXcLI6Ir5byn5eF+WoqkLpoiiLnMLNfFoCQcaDZIrg/lA0v
P2\n8Lp/PmzbuagqUWqeqe+iKfrune2a7EyaqzUb/6VgaJNJWci1qJhXRt68O5syTf7fXwvxY4vGKqfJ\
nnnO3Zv+Hp30uF7+EyekcjchptduXLR4fd/ktIaajF6ucpGgYHMiMOmJyqNzku/CtWsM+b9l3Hsn6\nS
8JPEyI5m7ENY33xBbQAllA=\n",
"url": "https://grid-master/http_direct_file_io/req_id-DOWNLOAD-1001/database.bak"
}
<url_from_the_previous_output>
Example:
GET
https://x.x.x.x/http_direct_file_io/req_id-DOWNLOAD-10
Download the 01/database.bak
backup
curl -k -u admin:infoblox -H 'content-type: application/force-download'
"https://grid-master/http_direct_file_io/req_id-DOWNLOAD-1001/database.bak" -o "database.bak"
#database.bak file is saved in the present working directory#
POST <wapi_url>/fileop?_function=downloadcomplete {"token": "eJydU..A="}
Remove the stored curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
file using the token "https://grid-master/wapi/v2.12/fileop?_function=downloadcomplete" -d '{"token" :
"eJydUE1PwzAMvfuPjMvaplvWjdtQmYSENmlD4mi1STos2iQkGdr+PQ4SnDhxSOT4fcR+Sjl/w2DO\
nwJdyNqZwUckF8ALuFNnB9aO7Fs6afNLNmwhtlzo8mgF8DQqxv9CYyCKCJpXAL+BO+yWcZubqK
101
dww\n0WRm4CXshKxkI+W6XhWyqZayhniaXcLI6Ir5byn5eF+WoqkLpoiiLnMLNfFoCQcaDZIrg/lA0v
P2\n8Lp/PmzbuagqUWqeqe+iKfrune2a7EyaqzUb/6VgaJNJWci1qJhXRt68O5syTf7fXwvxY4vGKqfJ\
nnnO3Zv+Hp30uF7+EyekcjchptduXLR4fd/ktIaajF6ucpGgYHMiMOmJyqNzku/CtWsM+b9l3Hsn6\nS
8JPEyI5m7ENY33xBbQAllA=\n"}'
Please note that while downloading the backup (in the second step above), the Content-Type in the header will
be application/force-download.
When you initiate a backup, you will get a URL to which you can upload the backup file directly, and a token for
restoring the database.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
POST <wapi_url>/fileop?_function=uploadinit
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/fileop?_function=uploadinit"
{"token":
"eJydUMFOwzAMvftHymVt09Fu5TY0JiGhgTY4W22SDkttYpIUbX9PMgQXbhwS2X7PL3lPSssXdPo
Initiate a file upload E\n8ZLW+OBmGawDFnAjyQy2H+05t0anEy6sPWy70OFBD8AVSMR+pjGQQQRFMgAv4UbxLRwzf
WZyFww0\n6Qy4hp2oy3pVN1XT5GXZtmIF/pjNboxoE/nvIbC/KwqxqvKqyUVeFWmEiuLXAg40aiRb
OP2BpBZv\nL0/Pm+1ClKUoaGLrvhlR6ypLKlbrqPqXHoE2UVT0EWtRRlbho+nupIsw8f9eFeJHE7W
RVpE5pWkV\nxe8f96lc/hImq64rKaXt5nWDh4dd6mvw4cCiSQnGdI7ZQHpUHoNFaSfu3HVrDftksO8
YyfAc8FM7\nT9YkrI1Yn38Bt1KUqw==\n",
"url": "https://grid-master/http_direct_file_io/req_id-UPLOAD-1001/import_file"
}
<url_from_the_previous_output>
Example:
POST [email protected]
Upload the backup https://x.x.x.x/http_direct_file_io/req_id-UPLOAD-1001/i
file mport_file
curl -k -u admin:infoblox "https://grid-master/http_direct_file_io/req_id-UPLOAD-1001/import_file" -F
name=database.bak -F [email protected]
{"mode":"NORMAL",
POST <wapi_url>/fileop?_function=restoredatabase
"token": "eJydU..w="}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/fileop?_function=restoredatabase" -d
Restore the '{"mode":"NORMAL","token":"eJydUMFOwzAMvftHymVt09Fu5TY0JiGhgTY4W22SDkttYpIUbX9PM
database gQXbhwS2X7PL3lPSssXdPoE\n8ZLW+OBmGawDFnAjyQy2H+05t0anEy6sPWy70OFBD8AVSMR+
pjGQQQRFMgAv4UbxLRwzfWZyFww0\n6Qy4hp2oy3pVN1XT5GXZtmIF/pjNboxoE/nvIbC/KwqxqvK
qyUVeFWmEiuLXAg40aiRbOP2BpBZv\nL0/Pm+1ClKUoaGLrvhlR6ypLKlbrqPqXHoE2UVT0EWtRRl
bho+nupIsw8f9eFeJHE7WRVpE5pWkV\nxe8f96lc/hImq64rKaXt5nWDh4dd6mvw4cCiSQnGdI7ZQH
pUHoNFaSfu3HVrDftksO8YyfAc8FM7\nT9YkrI1Yn38Bt1KUqw==\n"}'
Grid upgrade
For a grid-wide upgrade, you can use the upgrade function. This function provides control over the Grid
upgrade. The upgrade process normally is as follows:
1. Upload the upgrade file using the set_upgrade_file function call in object fileop.
2. Call this function with ‘action’ set to ‘UPLOAD’, this will prepare the uploaded file for deployment.
3. Call this function with ‘action’ set to ‘DISTRIBUTION_START’, which will start the Grid distribution
process.
4. Call this function with ‘action’ set to ‘UPGRADE’, which will restart the appliances with the new NIOS
version.
102
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
POST <wapi_url>/fileop?_function=uploadinit
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/fileop?_function=uploadinit"
{"token":
"eJydUMFOwzAMvftHymVt09Fu5TY0JiGhgTY4W22SDkttYpIUbX9PMgQXbhwS2X7PL3lPSssXdPo
Initiate a E\n8ZLW+OBmGawDFnAjyQy2H+05t0anEy6sPWy70OFBD8AVSMR+pjGQQQRFMgAv4UbxLRwzf
file upload WZyFww0\n6Qy4hp2oy3pVN1XT5GXZtmIF/pjNboxoE/nvIbC/KwqxqvKqyUVeFWmEiuLXAg40aiRb
OP2BpBZv\nL0/Pm+1ClKUoaGLrvhlR6ypLKlbrqPqXHoE2UVT0EWtRRlbho+nupIsw8f9eFeJHE7W
RVpE5pWkV\nxe8f96lc/hImq64rKaXt5nWDh4dd6mvw4cCiSQnGdI7ZQHpUHoNFaSfu3HVrDftksO8
YyfAc8FM7\nT9YkrI1Yn38Bt1KUqw==\n",
"url": "https://grid-master/http_direct_file_io/req_id-UPLOAD-1001/import_file"
}
Upload
<url_from_the_previous_output>
the
Upload Example:
upgrade POST [email protected]
the https://x.x.x.x/http_direct_file_io/req_id-UPLOAD-1001/i
file
upgrade mport_file
file curl -k -u admin:infoblox "https://grid-master/http_direct_file_io/req_id-UPLOAD-1001/import_file" -F
name=upgrade-file.bin -F [email protected]
POST <wapi_url>/fileop?_function=set_upgrade_file {"token": "eJydU..w="}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
Set it as "https://grid-master/wapi/v2.12/fileop?_function=set_upgrade_file" -d
the '{"token":"eJydUMFOwzAMvftHymVt09Fu5TY0JiGhgTY4W22SDkttYpIUbX9PMgQXbhwS2X7PL3lP
upgrade SssXdPoE\n8ZLW+OBmGawDFnAjyQy2H+05t0anEy6sPWy70OFBD8AVSMR+pjGQQQRFMgAv4U
file bxLRwzfWZyFww0\n6Qy4hp2oy3pVN1XT5GXZtmIF/pjNboxoE/nvIbC/KwqxqvKqyUVeFWmEiuLXA
g40aiRbOP2BpBZv\nL0/Pm+1ClKUoaGLrvhlR6ypLKlbrqPqXHoE2UVT0EWtRRlbho+nupIsw8f9eFe
JHE7WRVpE5pWkV\nxe8f96lc/hImq64rKaXt5nWDh4dd6mvw4cCiSQnGdI7ZQHpUHoNFaSfu3HVr
DftksO8YyfAc8FM7\nT9YkrI1Yn38Bt1KUqw==\n"}'
<wapi_url>/grid/b25lLmNsdXN0ZXIkMA:Infoblox?_functi
POST {"action": "UPLOAD"}
Call the upgrade on=upgrade
function to curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"UPLOAD" the file "https://grid-master/wapi/v2.12/grid/b25lLmNsdXN0ZXIkMA:Infoblox?_function=upgrade" -d
'{"action": "UPLOAD"}'
<wapi_url>/grid/b25lLmNsdXN0ZXIkMA:Infoblox?_functi {"action":
POST
Call the upgrade on=upgrade "DISTRIBUTION_START"}
function to start the curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
distribution process "https://grid-master/wapi/v2.12/grid/b25lLmNsdXN0ZXIkMA:Infoblox?_function=upgrade" -d
'{"action": "DISTRIBUTION_START"}'
<wapi_url>/grid/b25lLmNsdXN0ZXIkMA:Infoblox?_functi
POST {"action": "UPGRADE"}
Call the upgrade on=upgrade
function to start the curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
upgrade "https://grid-master/wapi/v2.12/grid/b25lLmNsdXN0ZXIkMA:Infoblox?_function=upgrade" -d
'{"action": "UPGRADE"}'
GET <wapi_url>/upgradestatus?type=GRID
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
Check the upgrade
"https://grid-master/wapi/v2.12/upgradestatus?type=GRID"
status
[{"_ref": "upgradestatus/Li51cGdyYWRlc3RhdHVzJHVwZ3JhZGVfc3RhdHVz:Infoblox",
"element_status": "WORKING",
103
"grid_state": "DEFAULT",
"group_state": "GROUP_NONE",
"ha_status": "NOT_CONFIGURED",
"message": "",
"steps_completed": 0,
"steps_total": 0,
"type": "GRID",
"upgrade_state": "NONE",
"upgrade_test_status": "NONE"
}]
Traffic Capture
You must first initiate the traffic capture. To download the traffic capture file, the capture must be stopped.
Either stop it manually or wait for the timer to expire. After downloading the capture file, remember to remove
the stored file using the token.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
<wapi_url>/member/b25lLnZpcnR1YWxfbm9kZSQw:inf
POST
oblox.localdomain?_function=capture_traffic_status
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
Check the current "https://grid-master/wapi/v2.12/member/b25lLnZpcnR1YWxfbm9kZSQw:infoblox.localdomain?_funct
capture status ion=capture_traffic_status"
{"file_exists": false,
"file_size": 0,
"status": "STOPPED"}
<wapi_url>/member/b25lLnZpcnR1YWxfbm9kZSQw:inf
POST oblox.localdomain?_function=capture_traffic_control&ac
tion=START&interface=ALL
Initiate the capture curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/member/b25lLnZpcnR1YWxfbm9kZSQw:infoblox.localdomain?_funct
ion=capture_traffic_control&action=START&interface=ALL"
{}
<wapi_url>/member/b25lLnZpcnR1YWxfbm9kZSQw:inf
POST
oblox.localdomain?_function=capture_traffic_status
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
Check the capture "https://grid-master/wapi/v2.12/member/b25lLnZpcnR1YWxfbm9kZSQw:infoblox.localdomain?_funct
status ion=capture_traffic_status"
{"file_exists": true,
"file_size": 12288,
"status": "RUNNING"}
<wapi_url>/member/b25lLnZpcnR1YWxfbm9kZSQw:inf
POST oblox.localdomain?_function=capture_traffic_control&ac
tion=STOP&interface=ALL
Stop the capture curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/member/b25lLnZpcnR1YWxfbm9kZSQw:infoblox.localdomain?_funct
ion=capture_traffic_control&action=STOP&interface=ALL"
{}
Generate the <wapi_url>/fileop?_function=getmemberdata&member=i
POST
capture file nfoblox.localdomain&type=TRAFFIC_CAPTURE_FILE
104
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/fileop?_function=getmemberdata&member=infoblox.localdomain&typ
e=TRAFFIC_CAPTURE_FILE"
{"token":
"eJy9kcFuwyAMhu+8SHsJCTRJw26dskqTqlZqJ+1oJUAypCQwQqZ2Tz9Tab3utgOW8f9bfNhSWnc
D\nr3uCQdppDn6RwXriGFlLM3W2HeyV2knHE25Oz6RuQgNn3RHHiQRoFzMEMwEQZWQgbkPW
yuXkstJX\nZ/wNghn1iriC7FmxzZkQvKoo5xUrBZkvq8UPqJbo/wjBzU9pyjLKREl5VtCcp7EKyiBdgM4
MGoxN\nvf4Eo5L69H48nHZ1whgTPNvkecV5IcoifYAPVjaDspABz5hAY4KRZ8kmT/IKgnRqGd3B9jQ
0nvbf\nSLKNUEZhViHTXy+h7f4LhTPBnGXYk844wKbXaRjdv+Mz9osDepJWmamPVY5cz6/HmG4e
htGquBkW\nl1Xv3nZwftnHe0HmcHasjItkWxQ7owc1Q7Ag7egaf++qyDFOqm0cmMktAb60n42doiZQ
a+kPIMm5\nYA==\n",
"url":
"https://10.196.205.42/http_direct_file_io/req_id-DOWNLOAD-1119203448225965/infoblox.localdo_
0_2019-11-19-20-34-48_tcpdumpLog.tar.gz"}
<url_from_the_previous_output>
Example:
GET https://x.x.x.x/http_direct_file_io/req_id-DOWNLOAD-11
19203448225965/infoblox.localdo_0_2019-11-19-20-34-
Download the traffic 48_tcpdumpLog.tar.gz
capture file
curl -k -u admin:infoblox -H 'content-type: application/force-download'
"https://grid-master/http_direct_file_io/req_id-DOWNLOAD-1119203448225965/infoblox.localdo_0_2
019-11-19-20-34-48_tcpdumpLog.tar.gz" -o "trafficCapture.tar.gz"
# trafficCapture.tar.gz file is saved in the present working directory#
POST <wapi_url>/fileop?_function=downloadcomplete {"token": "eJy9kc..A=="}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/fileop?_function=downloadcomplete" -d '{"token" :
"eJy9kcFuwyAMhu+8SHsJCTRJw26dskqTqlZqJ+1oJUAypCQwQqZ2Tz9Tab3utgOW8f9bfNhSWnc
Remove the stored D\nr3uCQdppDn6RwXriGFlLM3W2HeyV2knHE25Oz6RuQgNn3RHHiQRoFzMEMwEQZWQgbkPW
file using the token yuXkstJX\nZ/wNghn1iriC7FmxzZkQvKoo5xUrBZkvq8UPqJbo/wjBzU9pyjLKREl5VtCcp7EKyiBdgM4
MGoxN\nvf4Eo5L69H48nHZ1whgTPNvkecV5IcoifYAPVjaDspABz5hAY4KRZ8kmT/IKgnRqGd3B9jQ
0nvbf\nSLKNUEZhViHTXy+h7f4LhTPBnGXYk844wKbXaRjdv+Mz9osDepJWmamPVY5cz6/HmG4e
htGquBkW\nl1Xv3nZwftnHe0HmcHasjItkWxQ7owc1Q7Ag7egaf++qyDFOqm0cmMktAb60n42doiZQ
a+kPIMm5\nYA==\n"}'
Please note that while downloading the capture file, the Content-Type in the header will be
application/force-download.
Support Bundle
When you initiate a support bundle download, you will get a URL that can be used to download the tar.gz file
directly, and a token for the download session. After downloading the support bundle, remember to remove the
stored file using the token.
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
POST <wapi_url>/fileop?_function=get_support_bundle {"member": "infoblox.local"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/fileop?_function=get_support_bundle" -d '{"member": "infoblox.local"}'
Initiate the support
bundle download {"token":
"eJytUUFuwyAQvPOR5BJsnBjbvSVyI1WqEimp1OPKBuwi2bAFXCV9faFSe+2lB9Cws8MsgxAW7+
DU\nSOImrPHBLSJYR5CRtdBmsP1kb9QalVa4o/Kk7UIHFzUQLIgA6Bc9BW0AiNQiENyStcQdua7U
DbW7\nQ9CzWhEsyZGVVV00ZVE2lFf5rm4Y8dfV4qZI8yh4CwH9Q5axpqCM15TRKs9SEaSO0wU
105
Y9KRA28yp\nd9By055fT8/nfbvJWc5zXuRlw3lV57vML4jWhcNi5KRo6BwdP6NJlfy0jKiOdn/dEtuaJJ
DxvRGz\nPGoyH8PpRpWFGf91NMZ+rEAZYaU2Y6oW0fPwdEpw+9swW5kSZSnkdv+yh8vjMZ1L4s
MFGU8fwKpI\nDlpN0kOwIOyMnftW1eSUUug7BG1wCfChnNfWJK6JXE+/AJH0pUU=\n",
"url":
"https://10.196.205.42/http_direct_file_io/req_id-DOWNLOAD-0106062059667804/supportBundle.ta
r.gz"}
<url_from_the_previous_output>
Example:
GET
https://x.x.x.x/http_direct_file_io/req_id-DOWNLOAD-01
Download the 06062059667804/supportBundle.tar.gz
support bundle curl -k -u admin:infoblox -H 'content-type: application/force-download'
"https://grid-master/http_direct_file_io/req_id-DOWNLOAD-0106062059667804/supportBundle.tar.g
z" -o "infoblox.local_supportBundle.tar.gz"
# infoblox.local_supportBundle.tar.gz file is saved in the present working directory#
POST <wapi_url>/fileop?_function=downloadcomplete {"token": "eJytUUF..U=\n"}
curl -k -u admin:infoblox -H 'content-type: application/json' -X POST
"https://grid-master/wapi/v2.12/fileop?_function=downloadcomplete" -d '{"token" :
Remove the stored "eJytUUFuwyAQvPOR5BJsnBjbvSVyI1WqEimp1OPKBuwi2bAFXCV9faFSe+2lB9Cws8MsgxAW7+
file using the token DU\nSOImrPHBLSJYR5CRtdBmsP1kb9QalVa4o/Kk7UIHFzUQLIgA6Bc9BW0AiNQiENyStcQdua7U
DbW7\nQ9CzWhEsyZGVVV00ZVE2lFf5rm4Y8dfV4qZI8yh4CwH9Q5axpqCM15TRKs9SEaSO0wU
Y9KRA28yp\nd9By055fT8/nfbvJWc5zXuRlw3lV57vML4jWhcNi5KRo6BwdP6NJlfy0jKiOdn/dEtuaJJ
DxvRGz\nPGoyH8PpRpWFGf91NMZ+rEAZYaU2Y6oW0fPwdEpw+9swW5kSZSnkdv+yh8vjMZ1L4s
MFGU8fwKpI\nDlpN0kOwIOyMnftW1eSUUug7BG1wCfChnNfWJK6JXE+/AJH0pUU=\n"}'
Please note that while downloading the capture file, the Content-Type in the header will be
application/force-download.
The following example shows how to retrieve all host records in the environment, 4 at a time. You can change
the queried network object or the number of records according to your requirement.
REST
API Call
Method
Operation
Sample cURL Command
Sample Output
GET <wapi_url>/record:host?_paging=1&_return_as_object=1&max_results=4
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:host?_paging=1&_return_as_object=1&_max_results=4"
{"next_page_id":
Fetch the first 4 "789c55904d4ec3301085f77391744354a7296db9413615a207b0fc1b8c128f653ba2bd3d330681d858f23
host records 7efcd7bf6ce2601b70eb3ab5b8ed207b7d82257b4a58334d0a48372eb569acba466c7f400d35e305579e6
fb083b9b8e4da6ee3237cd334c2313f6c8103d123b8131981ea498810e83b1d4bc998a19d2197686657ac
17b8fd1f55a1507afe49e8842ba8091526f61a9214a09a83f9ca990c41eaef52d09c11504d7f5983f55b614
277e7b96aa7265321261b084353470fca939634599b0841a304af4beb836a7673cb5155655c5e0d482ce
5034416a511fc931bf50343f29db97772cec1d5ad2ff7f652ce0ca9536fd87065e3a1c58ef43fe767355dad0
106
7f014b0f819a-e4718db1318cfc3099a781c541542ccd82f4738853cf5c1a2b0b371",
"result":
[{"_ref": "record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLmhvc3Q:host.info.com/default",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8uaG9zdC4xMC4x
MC4xMC4yMC4:10.10.10.20/host.info.com/default",
"configure_for_dhcp": false,
"host": "host.info.com",
"ipv4addr": "10.10.10.20"
}],
"name": "host.info.com",
"view": "default"
},
{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5kZW1vLnNlcnZlcjE:server1.demo.com/default",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmRlbW8uc2VydmVyMS4x
LjEuMS4yNS4:1.1.1.25/server1.demo.com/default",
"configure_for_dhcp": false,
"host": "server1.demo.com",
"ipv4addr": "1.1.1.25"
}],
"name": "server1.demo.com",
"view": "default"
},
{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5kZW1vLm1vbml0b3I:monitor.demo.com/default",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmRlbW8ubW9uaXRvci4xL
jEuMS41MC4:1.1.1.50/monitor.demo.com/default",
"configure_for_dhcp": false,
"host": "monitor.demo.com",
"ipv4addr": "1.1.1.50"
}],
"name": "monitor.demo.com",
"view": "default"
},
{"_ref": "record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLnRlc3Q:test.info.com/default",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8udGVzdC4yLjIuMi
4xMTAu:2.2.2.120/test.info.com/default",
"configure_for_dhcp": false,
"host": "test.info.com",
"ipv4addr": "2.2.2.120"
}],
"name": "test.info.com",
"view": "default"
}]}
<wapi_url>/record:host?_paging=1&_return_as_object=1&_page_id=789c55904d4ec3301085
Query the next f77391744354a7296db9413615a207b0fc1b8c128f653ba2bd3d330681d858f237efcd7bf6ce26
GET
set of records 01b70eb3ab5b8ed207b7d82257b4a58334d0a48372eb569acba466c7f400d35e305579e6fb08
3b9b8e4da6ee3237cd334c2313f6c8103d123b8131981ea498810e83b1d4bc998a19d219768
107
6657ac17b8fd1f55a1507afe49e8842ba8091526f61a9214a09a83f9ca990c41eaef52d09c1150
4d7f5983f55b614277e7b96aa7265321261b084353470fca939634599b0841a304af4beb836a7
673cb5155655c5e0d482ce5034416a511fc931bf50343f29db97772cec1d5ad2ff7f652ce0ca95
36fd87065e3a1c58ef43fe767355dad07f014b0f819a-e4718db1318cfc3099a781c541542ccd82
f4738853cf5c1a2b0b371
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:host?_paging=1&_return_as_object=1&_page_id=789c55904d4ec
3301085f77391744354a7296db9413615a207b0fc1b8c128f653ba2bd3d330681d858f237efcd7bf6ce260
1b70eb3ab5b8ed207b7d82257b4a58334d0a48372eb569acba466c7f400d35e305579e6fb083b9b8e4da
6ee3237cd334c2313f6c8103d123b8131981ea498810e83b1d4bc998a19d2197686657ac17b8fd1f55a15
07afe49e8842ba8091526f61a9214a09a83f9ca990c41eaef52d09c11504d7f5983f55b614277e7b96aa72
65321261b084353470fca939634599b0841a304af4beb836a7673cb5155655c5e0d482ce5034416a511fc
931bf50343f29db97772cec1d5ad2ff7f652ce0ca9536fd87065e3a1c58ef43fe767355dad07f014b0f819a-e
4718db1318cfc3099a781c541542ccd82f4738853cf5c1a2b0b371"
{"next_page_id":
"789c55904b6ec3300c44f7bc88b3322cd9f9f506de0445730041d6c755619b8224a3c9ed4b0a69812ef96
6c82179b051c0bdc1e4ca9e36e5835b6c562bdadc4094a43490efcd4aba8a7a764c7b183bc154a799eb0
10e361eab4d3f54aa9e138c0393ff734938c38df1f4559ed1517da188e40c26fbf689b910b9721f67a9b079
24203a3006e39346cfa0d8bce5927653309128e060d8382df8687173eda4b38377ea1f89924182516adac
352c2a61450b43385780fb7f21145dd5e1c690d8fe95b27cb89a7df1373d1899712e7d7414b5843059717
98b1a08a984309b829f43ebbaa5f61ec59b7ba687e65c73992864e3c769ffe3e226555aad987547f20075a
a083dcfe0072798173-a0384f2ecdda419caa42aba69cb40f4827127cd8d59201fdd873f5e",
"result":
[{"_ref": "record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLnMx:s1.info.com/default",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8uczEuMTAuMTAu
MTAuMjAu:10.10.10.20/s1.info.com/default",
"configure_for_dhcp": false,
"host": "s1.info.com",
"ipv4addr": "10.10.10.20"
}],
"name": "s1.info.com",
"view": "default"
},
{"_ref": "record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLmgy:h2.info.com/default",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8uaDIuNS41LjUuO
TAu:5.5.5.90/h2.info.com/default",
"configure_for_dhcp": false,
"host": "h2.info.com",
"ipv4addr": "5.5.5.90"
}],
"name": "h2.info.com",
"view": "default"
},
{"_ref": "record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLmUy:e2.info.com/default",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8uZTIuOS45LjkuM
TAwLg:9.9.9.100/e2.info.com/default",
"configure_for_dhcp": false,
"host": "e2.info.com",
"ipv4addr": "9.9.9.100"
}],
108
"name": "e2.info.com",
"view": "default"
},
{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLmRldnN0YWNr:devstack.info.com/default
",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8uZGV2c3RhY2su
MTcyLjI2LjEuMjAu:172.26.1.20/devstack.info.com/default",
"configure_for_dhcp": false,
"host": "devstack.info.com",
"ipv4addr": "172.26.1.20"
}],
"name": "devstack.info.com",
"view": "default"
}]}
<wapi_url>/record:host?_paging=1&_return_as_object=1&_page_id=789c55904b6ec3300c44
f7bc88b3322cd9f9f506de0445730041d6c755619b8224a3c9ed4b0a69812ef966c82179b051c
0bdc1e4ca9e36e5835b6c562bdadc4094a43490efcd4aba8a7a764c7b183bc154a799eb010e3
61eab4d3f54aa9e138c0393ff734938c38df1f4559ed1517da188e40c26fbf689b910b9721f67a9
GET b07924203a3006e39346cfa0d8bce5927653309128e060d8382df8687173eda4b38377ea1f89
924182516adac352c2a61450b43385780fb7f21145dd5e1c690d8fe95b27cb89a7df1373d1899
712e7d7414b584305971798b1a08a984309b829f43ebbaa5f61ec59b7ba687e65c73992864e3
c769ffe3e226555aad987547f20075aa083dcfe0072798173-a0384f2ecdda419caa42aba69cb4
0f4827127cd8d59201fdd873f5e
curl -k -u admin:infoblox -X GET
"https://grid-master/wapi/v2.12/record:host?_paging=1&_return_as_object=1&_page_id=789c55904b6ec
3300c44f7bc88b3322cd9f9f506de0445730041d6c755619b8224a3c9ed4b0a69812ef966c82179b051c0b
dc1e4ca9e36e5835b6c562bdadc4094a43490efcd4aba8a7a764c7b183bc154a799eb010e361eab4d3f54
aa9e138c0393ff734938c38df1f4559ed1517da188e40c26fbf689b910b9721f67a9b07924203a3006e3934
6cfa0d8bce5927653309128e060d8382df8687173eda4b38377ea1f89924182516adac352c2a61450b433
Query the next 85780fb7f21145dd5e1c690d8fe95b27cb89a7df1373d1899712e7d7414b584305971798b1a08a984309b
set of records 829f43ebbaa5f61ec59b7ba687e65c73992864e3c769ffe3e226555aad987547f20075aa083dcfe0072798
173-a0384f2ecdda419caa42aba69cb40f4827127cd8d59201fdd873f5e"
{"result":
[{"_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLnJvdXRlcg:router.info.com/default",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuX2RlZmF1bHQuY29tLmluZm8ucm91dGVyLjEw
MC4xMC4xMC4xLg:100.10.10.1/router.info.com/default",
"configure_for_dhcp": false,
"host": "router.info.com",
"ipv4addr": "100.10.10.1"
}],
"name": "router.info.com",
"view": "default"
}]}
109
Multiple Object Body Feature using /request
The request object allows the control of WAPI through a single-entry point. You can either have Single Object
Body Requests or Multiple Object Body Requests.
Single object body requests can be used for any supported WAPI operations, including scheduling and
approval. Only HTTP methods (GET, PUT, DELETE and POST) are valid methods for the single object body
Multiple object body requests are composed of a list of single requests. While programming this enables to
make multiple requests with one API call, thus simplifying an operation, and reducing the number of API calls to
be made. In addition to the standard HTTP methods (GET, PUT, POST, and DELETE), single request inside a
multiple object body request can be set to these values:
Method Description
Copy fields in the data object to the
STATE:ASSIGN
state object.
Added the state object to the
STATE:DISPLAY
returned result list.
Note: The Multiple Object Body Feature is only available NIOS 7.1 onwards (WAPI v2.1 onwards)
110
"ipv4addr": "172.26.1.21"
},
….
{"_ref": "record:host/ZG5zLmhvc3QkLjEuY29tLmluZm8ubWFpbGVy:mailer.info.com/default.test",
"configure_for_dns": true,
"dns_name": "mailer.info.com",
"ipv4addrs":
[{"_ref":
"record:host_ipv4addr/ZG5zLmhvc3RfYWRkcmVzcyQuMS5jb20uaW5mby5tYWlsZXIuMTAuMS4xLjE
wMC4:10.1.1.100/mailer.info.com/default.test",
"configure_for_dhcp": false,
"host": "mailer.info.com",
"ipv4addr": "10.1.1.100",
"mac": "aa:bb:cc:11:22:33"
}],
"name": "mailer.info.com"
}],
[{"_ref":
"record:a/ZG5zLmJpbmRfYSQuX2RlZmF1bHQuY29tLmluZm8sdGVzdC5ob3N0LDE3Mi4yNi4xLjEwM
A:host.test.info.com/default",
"ipv4addr": "172.26.1.100",
"name": "host.test.info.com",
"view": "default"
},
{"_ref":
"record:a/ZG5zLmJpbmRfYSQuX2RlZmF1bHQuY29tLmluZm8sc2VydmVyLDEwLjEwLjEwLjI:server.inf
o.com/default",
"ipv4addr": "10.10.10.2",
"name": "server.info.com",
"view": "default"
}],
[{"_ref":
"record:ptr/ZG5zLmJpbmRfcHRyJC5fZGVmYXVsdC5hcnBhLmluLWFkZHIuMTI3LjAuMC4xLmxvY2Fs
aG9zdA:1.0.0.127.in-addr.arpa/default",
"ptrdname": "localhost",
"view": "default"
},
….
{"_ref":
"record:ptr/ZG5zLmJpbmRfcHRyJC4yLmFycGEuaXA2LjAuMC4wLjAuMC4wLjAuMC4wLjAuMC4wLjA
uMC4wLjAuMC4wLjAuMC4wLjAuMC4wLjAuMC4wLjAuMC4wLjAuMS4ubG9jYWxob3N0:1.0.0.0.0.0.0.
0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.ip6.arpa/default.cloud",
"ptrdname": "localhost",
"view": "default.cloud"
}]]
Delete a host record
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
[{"method": "STATE:ASSIGN",
"data":{"host_name":"host1.test.com"}},
Delete a Host
POST <wapi_url>/request {"method":"GET",
record
"object": "record:host",
"data": {"name":"##STATE:host_name:##"},
111
"assign_state": {"host_ref": "_ref"},
"enable_substitution": true,"discard": true},
{ "method": "DELETE",
"object": "##STATE:host_ref:##",
"enable_substitution": true,"discard": true},
{"method": "STATE:DISPLAY"}]
curl -k -u admin:infoblox -H 'content-type:application/json' -X POST
"https://grid-master/wapi/v2.12/request" -d '[{"method":
"STATE:ASSIGN","data":{"host_name":"host1.test.com"}},{"method":"GET","object":
"record:host","data": {"name":"##STATE:host_name:##"},"assign_state": {"host_ref":
"_ref"},"enable_substitution": true,"discard": true},{ "method": "DELETE", "object":
"##STATE:host_ref:##","enable_substitution": true,"discard": true},{"method": "STATE:DISPLAY"}]'
[{"host_name": "host1.test.com",
"host_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS50ZXN0Lmhvc3Qx:host1.test.com/default"
}]
Get next available IP address
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
[{"method": "GET",
"object": "network",
"data": {"network": "192.168.1.0/24"},
"assign_state": {"netw_ref": "_ref"},
POST <wapi_url>/request "discard": true},
{"method": "POST",
Get next available "object": "##STATE:netw_ref:##",
IP address from an "args": {"_function": "next_available_ip"},
IPv4 subnet "enable_substitution": true}]
curl -k -u admin:infoblox -H 'content-type:application/json' -X POST
"https://grid-master/wapi/v2.12/request" -d '[{"method": "GET","object": "network","data": {"network":
"192.168.1.0/24"},"assign_state": {"netw_ref": "_ref"},"discard": true},{"method": "POST","object":
"##STATE:netw_ref:##","args": {"_function": "next_available_ip"},"enable_substitution": true}]'
[{"ips": ["192.168.1.1"]}]
[{"method": "POST",
"object": "record:host",
"data": {"configure_for_dns": false,
"ipv6addrs":
[{"configure_for_dhcp": false,
"ipv6addr":
{"_object_function":"next_available_ip",
Get next available "_result_field":"ips",
IP address from an POST <wapi_url>/request "_object" : "ipv6network",
IPv6 subnet "_object_parameters":
{"network":"2600:6801:1106:f00::f00/120",
"network_view":"sandbox"}}}],
"name": "CPE_1",
"network_view": "sandbox"},
"args": {"_return_fields": "name" }
}]
112
curl -k -u admin:infoblox -H 'content-type:application/json' -X POST
"https://grid-master/wapi/v2.12/request" -d '[{"method": "POST","object": "record:host","data":
{"configure_for_dns": false,"ipv6addrs":[{"configure_for_dhcp": false,
"ipv6addr":{"_object_function":"next_available_ip","_result_field":"ips","_object" :
"ipv6network","_object_parameters":{"network":"2600:6801:1106:f00::f00/120",
"network_view":"sandbox"}}}],"name": "host.demo.com","network_view": "sandbox"},"args":
{"_return_fields": "name" }}]'
[{"_ref":
"record:host/ZG5zLmhvc3QkLm5vbl9ETlNfaG9zdF9yb290MS4wLjE1NzQxOTEwMTc2NzUuY29tLm
RlbW8uaG9zdA:host.demo.com/%20%20",
"name": "host.demo.com"
}]
Pre-provision a Grid member
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
[{"method": "POST",
"object": "member",
"data": {"host_name": "autojoin01.localdomain",
"vip_setting": {"address": "172.16.0.160",
"gateway": "172.16.0.1",
"subnet_mask": "255.255.255.0"},
"config_addr_type": "IPV4",
"platform": "VNIOS"},
"assign_state": {"member_ref": "_ref"},
"enable_substitution": true,
"discard": true},
POST <wapi_url>/request
{"method": "PUT",
"object": "##STATE:member_ref:##",
"enable_substitution": true,
"data": {"pre_provisioning":{"hardware_info": [{"hwmodel":
Pre-provision a grid "IB-VM-820",
member "hwtype":
"IB-VNIOS"}],
"licenses":
["dhcp","dns","enterprise",
"vnios","rpz"]}}},
{"method": "STATE:DISPLAY"}]
curl -k -u admin:infoblox -H 'content-type:application/json' -X POST
"https://grid-master/wapi/v2.12/request" -d '[{"method": "POST","object": "member","data":
{"host_name": "autojoin01.localdomain","vip_setting": {"address": "172.16.0.160","gateway":
"172.16.0.1","subnet_mask": "255.255.255.0"},"config_addr_type": "IPV4","platform":
"VNIOS"},"assign_state": {"member_ref": "_ref"},"enable_substitution": true, "discard": true},
{"method": "PUT","object": "##STATE:member_ref:##","enable_substitution": true,"data":
{"pre_provisioning":{"hardware_info": [{"hwmodel": "IB-VM-820","hwtype": "IB-VNIOS"}],"licenses":
["dhcp","dns","enterprise","vnios","rpz"]}}},{"method": "STATE:DISPLAY"}]'
["member/b25lLnZpcnR1YWxfbm9kZSQy:autojoin01.infoblox",
{"member_ref": "member/b25lLnZpcnR1YWxfbm9kZSQy:autojoin01.infoblox"}]
[{"method": "POST",
"object": "member",
Pre-provision an
POST <wapi_url>/request "data": {"host_name": "flex-member1.localdomain",
IB-FLEX member
"vip_setting": {"address": "172.16.0.200",
"gateway": "172.16.0.1",
113
"subnet_mask": "255.255.255.0"},
"config_addr_type": "IPV4",
"platform": "VNIOS"},
"assign_state": {"member_ref": "_ref"},
"enable_substitution": true,
"discard": true},
{"method": "PUT",
"object": "##STATE:member_ref:##",
"enable_substitution": true,
"data": {"pre_provisioning":{"hardware_info": [{"hwtype":
"IB-FLEX"}],
"licenses": []}}},
{"method": "STATE:DISPLAY"}]
curl -k -u admin:infoblox -H 'content-type:application/json' -X POST
"https://grid-master/wapi/v2.12/request" -d '[{"method": "POST","object": member","data":
{"host_name": "flex-member1.localdomain","vip_setting": {"address": "172.16.0.200","gateway":
"172.16.0.1","subnet_mask": "255.255.255.0"},"config_addr_type": "IPV4","platform":
"VNIOS"},"assign_state": {"member_ref": "_ref"},"enable_substitution": true, "discard": true},
{"method": "PUT","object": "##STATE:member_ref:##","enable_substitution": true,"data":
{"pre_provisioning":{"hardware_info": [{"hwtype": "IB-FLEX"}],"licenses": []}}},{"method":
"STATE:DISPLAY"}]'
["member/b25lLnZpcnR1YWxfbm9kZSQ5:flex-member1.localdomain",
{"member_ref": "member/b25lLnZpcnR1YWxfbm9kZSQ5:flex-member1.localdomain"}]
Enable DHCP service on a member
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
[{"method": "STATE:ASSIGN",
"data":{"member_name":"member1.localdomain"}},
{"method":"GET",
"object": "member:dhcpproperties",
"data": {"host_name":"##STATE:member_name:##"},
"assign_state": {"host_ref": "_ref"},
POST <wapi_url>/request "enable_substitution": true,
"discard": true},
{"method": "PUT",
"object": "##STATE:host_ref:##",
"enable_substitution": true,
Enable the DHCP "data": {"enable_dhcp":true}},
service on a {"method": "STATE:DISPLAY"}]
member
curl -k -u admin:infoblox -H 'content-type:application/json' -X POST
"https://grid-master/wapi/v2.12/request" - d '[{"method":
"STATE:ASSIGN","data":{"member_name":"member1.localdomain"}},{"method":"GET","object":
"member:dhcpproperties","data": {"host_name":"##STATE:member_name:##"},"assign_state":
{"host_ref": "_ref"},"enable_substitution": true,"discard": true},{ "method": "PUT", "object":
"##STATE:host_ref:##","enable_substitution": true,"data": {"enable_dhcp":true}},{"method":
"STATE:DISPLAY"}]'
["member:dhcpproperties/ZG5zLm1lbWJlcl9kaGNwX3Byb3BlcnRpZXMkMQ:member1.localdomain",
{"host_ref":
"member:dhcpproperties/ZG5zLm1lbWJlcl9kaGNwX3Byb3BlcnRpZXMkMQ:member1.localdomain",
"member_name": "member1.localdomain"}]
114
Get permissions for an object
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
[{"method": "STATE:ASSIGN",
"data": {"zone_name": "test.org"}},
{"method": "GET",
"object": "zone_auth",
"data": {"fqdn": "##STATE:zone_name:##"},
POST <wapi_url>/request "assign_state": {"zone_ref": "_ref"},
"enable_substitution": true,"discard": true},
{"method": "GET",
"object": "permission",
"enable_substitution": true },
{"method": "STATE:DISPLAY"}]
curl -k -u admin:infoblox -H 'content-type:application/json' -X POST
"https://grid-master/wapi/v2.12/request" -d '[{"method": "STATE:ASSIGN","data": {"zone_name":
"test.org"}},{"method": "GET","object": "zone_auth","data": {"fqdn":
"##STATE:zone_name:##"},"assign_state": {"zone_ref": "_ref"},"enable_substitution": true,"discard":
true},{"method": "GET", "object": "permission","enable_substitution": true },{"method":
"STATE:DISPLAY"}]'
[[{"_ref":
"permission/b25lLmhpZXJfcnVsZSQuY29tLmluZm9ibG94LmRucy56b25lJC4uLi4uY29tLmluZm9ibG9
Get permissions for 4Lm9uZS5yb2xlJEROUyBBZG1pbi4:DNS%20Admin/WRITE",
an object "permission": "WRITE",
"resource_type": "VIEW",
"role": "DNS Admin"
},
…
{"_ref":
"permission/b25lLmhpZXJfcnVsZSQuY29tLmluZm9ibG94LmRucy5jbHVzdGVyX2Ruc19wcm9wZXJ0
aWVzJDAuLi5jb20uaW5mb2Jsb3gub25lLmFkbWluX2dyb3VwJC5jbG91ZC1hcGktb25seS4:cloud-api
-only/WRITE",
"group": "cloud-api-only",
"permission": "WRITE",
"resource_type": "GRID_DNS_PROPERTIES"
}],
{"zone_name": "test.org",
"zone_ref": "zone_auth/ZG5zLnpvbmUkLjEub3JnLnRlc3Q:test.org/default.test"
}]
[{"host_name": "host1.test.com",
"host_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS50ZXN0Lmhvc3Qx:host1.test.com/default"
}]
Add multiple subnets
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
[{"method": "POST",
Create multiple
POST <wapi_url>/request "object": "network",
subnets
"data": {"network": "10.10.10.0/24"}},
115
{"method": "POST",
"object": "network",
"data": {"network": "10.10.20.0/24"}},
{"method": "POST",
"object": "network",
"data": {"network": "10.10.30.0/24"}}]
curl -k -u admin:infoblox -H 'content-type:application/json' -X POST
"https://grid-master/wapi/v2.12/request" -d '[{"method": "POST","object": "network","data": {"network":
"10.10.10.0/24"}},{"method": "POST", "object": "network","data": {"network":
"10.10.20.0/24"}},{"method": "POST","object": "network","data": {"network": "10.10.30.0/24"}}]'
["network/ZG5zLm5ldHdvcmskMTAuMTAuMTAuMC8yNC8w:10.10.10.0/24/default",
"network/ZG5zLm5ldHdvcmskMTAuMTAuMjAuMC8yNC8w:10.10.20.0/24/default",
"network/ZG5zLm5ldHdvcmskMTAuMTAuMzAuMC8yNC8w:10.10.30.0/24/default"]
Add multiple host record
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
[{"method": "POST",
"object": "record:host",
"data": {"name":"host-1.info.com",
"ipv4addrs": [{"ipv4addr":"10.10.10.21"}]},
"assign_state": {"host1_ref": "_ref"},
"enable_substitution": true,
"discard": true},
POST <wapi_url>/request
{"method": "POST",
"object": "record:host",
"data": {"name":"host-2.info.com",
"ipv4addrs": [{"ipv4addr":"10.10.10.22"}]},
Create multiple host "assign_state": {"host2_ref": "_ref"},
records "enable_substitution": true,
"discard": true},
{"method": "STATE: DISPLAY"}]
curl -k -u admin:infoblox -H 'content-type:application/json' -X POST
"https://grid-master/wapi/v2.12/request" -d '[{"method": "POST","object": "record:host","data":
{"name":"host-1.info.com","ipv4addrs": [{"ipv4addr":"10.10.10.21"}]},"assign_state": {"host1_ref":
"_ref"},"enable_substitution": true,"discard": true},{"method": "POST","object": "record:host","data":
{"name":"host-2.info.com", "ipv4addrs": [{"ipv4addr":"10.10.10.22"}]},"assign_state": {"host2_ref":
"_ref"},"enable_substitution": true,"discard": true},{"method": "STATE:DISPLAY"}]'
[{"host1_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLmhvc3QtMQ:host-1.info.com/default",
"host2_ref":
"record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLmhvc3QtMg:host-2.info.com/default"}]
Add network using next available network
REST
API Call Sample Body
Method
Operation
Sample cURL Command
Sample Output
Create network [{ "method": "GET",
using the next POST <wapi_url>/request "object": "networkcontainer",
available network "data": {"*Site:": "test"},
116
function within a "assign_state": {"netw_ref": "_ref"},
network container "discard": true},
with the EA Site set { "method": "POST",
to "test" "object": "network",
"data":{
"network":
{"_object_function": "next_available_network",
"_result_field":"networks",
"_parameters":{ "cidr":24 },
"_object_ref": "##STATE:netw_ref:##"
}
},
"enable_substitution": true},
{"method": "STATE: DISPLAY"}]
curl -k -u admin:infoblox -H 'content-type:application/json' -X POST
"https://grid-master/wapi/v2.12/request" -d '[{ "method": "GET","object": "networkcontainer", "data":
{"*Site:": "test"}, "assign_state": {"netw_ref": "_ref"},"discard": true},{ "method": "POST","object":
"network","data":{"network":{"_object_function":
"next_available_network","_result_field":"networks","_parameters":{ "cidr":24 },"_object_ref":
"##STATE:netw_ref:##"} },"enable_substitution": true},{"method": "STATE: DISPLAY"}]'
[
"network/ZG5zLm5ldHdvcmskMTkyLjE2OC4xLjAvMjQvMA:192.168.1.0/24/default"
]
Sample Codes
This section covers sample API calls in different programming/scripting languages
Python
These examples use the requests module. For more details on the requests module, please refer
http://docs.python-requests.org
Network REST
Sample Python Programme
Object Operation
import requests
requests.packages.urllib3.disable_warnings() # Disable SSL warnings in requests #
GET url = "https://grid-master/wapi/v2.12/record:host?_return_as_object=1"
response = requests.request("GET", url, auth=('admin', 'Infoblox'), verify=False)
print(response.text)
#This example demonstrates the use of cookies(ibapauth)#
import requests
import copy
requests.packages.urllib3.disable_warnings() # Disable SSL warnings in requests #
url = "https://grid-master/wapi/v2.12/record:host?_return_as_object=1"
HOST record
GET response = requests.request("GET", url, auth=('admin', 'Infoblox'), verify=False)
authcookie = copy.copy(response.cookies[‘ibapauth’] print(authcookie)
print(response.text)
#You can re-use the authcookie in subsequent API calls#
response_using_cookie = requests.request("GET", url, cookies=authcookie, verify=False)
print(response_using_cookie.text)
#This example demonstrates how you can work with large results using paging#
import requests
GET
requests.packages.urllib3.disable_warnings() # Disable SSL warnings in requests #
url = "https://grid-master/wapi/v2.12/record:host?_return_as_object=1"
117
querystring = {"_max_results":"20","_paging":"1","_return_as_object":"1"}
response = requests.request("GET", url, auth=('admin', 'Infoblox'),
params=querystring,verify=False)
print(response.text)
next_page_id = response.json()['next_page_id']
while next_page_id:
query = {"_page_id":next_page_id}
newresponse = requests.request("GET", url, auth=('admin', 'infoblox'),
params=query,verify=False)
print(newresponse.text)
try:
next_page_id = newresponse.json()['next_page_id']
except Exception:
next_page_id = 0
import requests
requests.packages.urllib3.disable_warnings() # Disable SSL warnings in requests #
url = "https://grid-master/wapi/v2.12/record:host?_return_as_object=1"
payload = "{\"name\":\"host.info.com\",\"ipv4addrs\": [{\"ipv4addr\":\"172.26.1.20\"}]}"
POST
headers = {'content-type': "application/json"}
response = requests.request("POST", url, auth=('admin', 'Infoblox'), data=payload,
headers=headers, verify=False)
print(response.text)
import requests
import getpass
requests.packages.urllib3.disable_warnings() # Disable SSL warnings in requests #
url = "https://grid-master/wapi/v2.12"
POST # Get username and password for auth #
(using the user = input('Username: ')
‘session’ passwd = getpass.getpass('Password: ')
method that wapi_session = requests.session()
automatically wapi_session.auth = ('user', 'passwd')
handles the payload = '{"name":"host.info.com","ipv4addrs": [{"ipv4addr":"172.26.1.20"}]}'
session headers = { 'content-type': "application/json" }
cookies, etc # WAPI call POST /record:host #
when you response = wapi_session.post(wapi_url+"/record:host?_return_as_object=1",
perform data=payload, headers=headers, auth=(user, passwd), verify=False)
multiple # Error handling #
POST/GET) if response.status_code == 201:
print("Success.")
else:
print("Failed.")
print(response.text)
import requests
requests.packages.urllib3.disable_warnings() # Disable SSL warnings in requests #
url =
"https://grid-master/wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZ
vLmhvc3Qx:host.info.com/default?_return_as_object=1"
PUT
payload = "{\"name\":\"host1.info.com\"}"
headers = {'content-type': "application/json"}
response = requests.request("PUT", url, auth=('admin', 'Infoblox'), data=payload,
headers=headers, verify=False)
print(response.text)
import requests
DELETE requests.packages.urllib3.disable_warnings() # Disable SSL warnings in requests #
url =
118
"https://grid-master/wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZ
vLmhvc3Qx:host.info.com/default?_return_as_object=1"
headers = {'content-type': "application/json"}
response = requests.request("DELETE", url, auth=('admin', 'Infoblox'), headers=headers,
verify=False)
print(response.text)
Powershell
The following examples use the following function to avoid SSL Certificate issue while using HTTPS.
Network REST
Sample Powershell Code
Object Operation
Ignore-SelfSignedCerts
$url = "https://grid-master/wapi/v2.12/record:host?_return_as_object=1"
GET $pwd = ConvertTo-SecureString "Infoblox" -AsPlainText -Force
$creds = New-Object Management.Automation.PSCredential ('admin', $pwd)
Invoke-RestMethod -Uri $url -Method GET -Credential $creds
#This example demonstrates the use of cookies(ibapauth)#
Ignore-SelfSignedCerts
HOST record $url = "https://grid-master/wapi/v2.12/record:host?_return_as_object=1"
$pwd = ConvertTo-SecureString "Infoblox" -AsPlainText -Force
GET
$creds = New-Object Management.Automation.PSCredential ('admin', $pwd)
Invoke-RestMethod -Uri $url -Method GET -Credential $creds -SessionVariable authcookie
#You can re-use the authcookie in subsequent API calls#
Invoke-RestMethod -Uri $url -Method GET -WebSession $authcookie
119
Ignore-SelfSignedCerts
$url = "https://grid-master/wapi/v2.12/record:host?_return_as_object=1"
$pwd = ConvertTo-SecureString "Infoblox" -AsPlainText -Force
$creds = New-Object Management.Automation.PSCredential ('admin', $pwd)
$host_details = @{
POST
name="host.info.com"
ipv4addrs=@(@{ipv4addr="172.26.1.20"})}
$body = $host_details | ConvertTo-Json
Invoke-RestMethod -Uri $url -Method POST -Credential $creds -ContentType 'application/json'
-Body $body
Ignore-SelfSignedCerts
$url =
"https://grid-master/wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvL
mhvc3Qx:host.info.com/default?_return_as_object=1"
$pwd = ConvertTo-SecureString "Infoblox" -AsPlainText -Force
PUT $creds = New-Object Management.Automation.PSCredential ('admin', $pwd)
$host_details = @{
name="host1.info.com"}
$body = $host_details | ConvertTo-Json
Invoke-RestMethod -Uri $url -Method PUT -Credential $creds -ContentType 'application/json'
-Body $body
Ignore-SelfSignedCerts
$url =
"https://grid-master/wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvL
DELETE mhvc3Qx:host.info.com/default?_return_as_object=1"
$pwd = ConvertTo-SecureString "Infoblox" -AsPlainText -Force
$creds = New-Object Management.Automation.PSCredential ('admin', $pwd)
Invoke-RestMethod -Uri $url -Method DELETE -Credential $creds
Java
Using Java Unirest
Network REST
Sample Java Unirest Code
Object Operation
HttpResponse<JsonNode> response =
Unirest.get("https://grid-master/wapi/v2.12/record:host?_return_as_object=1")
GET .header("authorization", "Basic YWRtaW46aW5mb2Jsb3g=")
.header("accept", "application/json")
.asJson();
HttpResponse<JsonNode> response =
Unirest.post("https://grid-master/wapi/v2.12/record:host?_return_as_object=1")
.header("authorization", "Basic YWRtaW46aW5mb2Jsb3g=")
POST .header("accept", "application/json")
.header("content-type", "application/json")
HOST record
.body("{\"name\":\"host.info.com\",\"ipv4addrs\": [{\"ipv4addr\":\"172.26.1.20\"}]}")
.asJson();
HttpResponse<JsonNode> response =
Unirest.put("https://grid-master/wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvb
S5pbmZvLmhvc3Qx:host.info.com/default?_return_as_object=1")
.header("authorization", "Basic YWRtaW46aW5mb2Jsb3g=")
PUT
.header("accept", "application/json")
.header("content-type", "application/json")
.body("{\"name\":\"host1.info.com\"}")
.asJson();
120
HttpResponse<JsonNode> response =
Unirest.delete("https://grid-master/wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmN
vbS5pbmZvLmhvc3Qx:host.info.com/default?_return_as_object=1")
.header("authorization", "Basic YWRtaW46aW5mb2Jsb3g=")
DELETE
.header("accept", "application/json")
.header("content-type", "application/json")
.body("{\"name\":\"host1.info.com\"}")
.asJson();
Using Java OkHttpClient
Network REST
Sample Java OkHttpClient Code
Object Operation
OkHttpClient client = new OkHttpClient();
Request request = new Request.Builder()
.url("https://grid-master/wapi/v2.12/record:host?_return_as_object=1")
GET .get()
.addHeader("authorization", "Basic YWRtaW46aW5mb2Jsb3g=")
.build();
Response response = client.newCall(request).execute();
OkHttpClient client = new OkHttpClient();
MediaType mediaType = MediaType.parse("application/json");
RequestBody body = RequestBody.create(mediaType,
"{\"name\":\"host.info.com\",\"ipv4addrs\":[{\"ipv4addr\":\"172.26.1.20\"}]}");
Request request = new Request.Builder()
POST .url("https://grid-master/wapi/v2.12/record:host?_return_as_object=1")
.post(body)
.addHeader("authorization", "Basic YWRtaW46aW5mb2Jsb3g=")
.addHeader("content-type", "application/json")
.build();
Response response = client.newCall(request).execute();
HOST record OkHttpClient client = new OkHttpClient();
MediaType mediaType = MediaType.parse("application/json");
RequestBody body = RequestBody.create(mediaType, "{\"name\":\"host1.info.com\"}");
Request request = new Request.Builder()
.url("https://grid-master/wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbm
PUT ZvLmhvc3Qx:host.info.com/default?_return_as_object=1")
.put(body)
.addHeader("authorization", "Basic YWRtaW46aW5mb2Jsb3g=")
.addHeader("content-type", "application/json")
.build();
Response response = client.newCall(request).execute();
OkHttpClient client = new OkHttpClient();
Request request = new Request.Builder()
.url("https://grid-master/wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbm
ZvLmhvc3Qx:host.info.com/default?_return_as_object=1")
DELETE .delete(null)
.addHeader("authorization", "Basic YWRtaW46aW5mb2Jsb3g=")
.addHeader("content-type", "application/json")
.build();
Response response = client.newCall(request).execute();
C# (CSharp)
These examples use the RestSharp library.
121
Network REST
Sample C# Scripts
Object Operation
ServicePointManager.ServerCertificateValidationCallback +=(sender, certificate, chain,
sslPolicyErrors) =>true; //Disable SSL Warnings//
var client = new RestClient("grid-master");
GET var request = new RestRequest("wapi/v2.12/record:host?_return_as_object=1",Method.GET);
request.AddHeader("authorization", "Basic YWRtaW46aW5mb2Jsb3g=");
IRestResponse response = client.Execute(request);
var results = response.Data;
ServicePointManager.ServerCertificateValidationCallback +=(sender, certificate, chain,
sslPolicyErrors) =>true; //Disable SSL Warnings//
var client = new RestClient("grid-master");
var request = new
RestRequest("wapi/v2.12/record:host?_return_as_object=1",Method.POST);
POST request.AddHeader("authorization", "Basic YWRtaW46aW5mb2Jsb3g=");
request.AddHeader("content-type", "application/json");
request.AddParameter("application/json", "{\"name\":\"host.info.com\",\"ipv4addrs\":
[{\"ipv4addr\":\"172.26.1.20\"}]}", ParameterType.RequestBody);
IRestResponse response = client.Execute(request);
var results = response.Data;
ServicePointManager.ServerCertificateValidationCallback +=(sender, certificate, chain,
HOST record sslPolicyErrors) =>true; //Disable SSL Warnings//
var client = new RestClient("grid-master");
var request = new
RestRequest("wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLmhvc
3Qx:host.info.com/default?_return_as_object=1",Method.PUT);
PUT
request.AddHeader("authorization", "Basic YWRtaW46aW5mb2Jsb3g=");
request.AddHeader("content-type", "application/json");
request.AddParameter("application/json", "{\"name\":\"host1.info.com\"}",
ParameterType.RequestBody);
IRestResponse response = client.Execute(request);
var results = response.Data;
ServicePointManager.ServerCertificateValidationCallback +=(sender, certificate, chain,
sslPolicyErrors) =>true; //Disable SSL Warnings//
var client = new RestClient("grid-master");
var request = new
RestRequest("wapi/v2.12/record:host/ZG5zLmhvc3QkLl9kZWZhdWx0LmNvbS5pbmZvLmhvc
DELETE
3Qx:host.info.com/default?_return_as_object=1",Method.DELETE);
request.AddHeader("authorization", "Basic YWRtaW46aW5mb2Jsb3g=");
request.AddHeader("content-type", "application/json");
IRestResponse response = client.Execute(request);
var results = response.Data;
References
Infoblox Community: Definitive List of REST Examples
122
Infoblox Community: Get more value out of Infoblox APIs
123
124