Foreman considers a domain and a DNS zone as the same thing. That is, if you are planning to manage a site where all the machines are of the form hostname.somewhere.com then the domain is somewhere.com. This allows Foreman to associate a puppet variable with a domain/site and automatically append this variable to all external node requests made by machines at that site.
GET /api/locations/447626446/organizations/447626443/domains 200 { "total": 1, "subtotal": 1, "page": 1, "per_page": 20, "search": null, "sort": { "by": null, "order": null }, "results": [ { "fullname": "example341.com", "created_at": "2021-05-18 15:52:58 UTC", "updated_at": "2021-05-18 15:52:58 UTC", "id": 759776769, "name": "example341.com", "dns_id": null, "dns": null } ] }
Param name | Description |
---|---|
subnet_id optional |
ID of subnet Validations:
|
location_id optional |
Scope by locations Validations:
|
organization_id optional |
Scope by organizations Validations:
|
search optional |
filter results Validations:
|
order optional |
Sort field and order, eg. ‘id DESC’ Validations:
|
page optional |
Page number, starting at 1 Validations:
|
per_page optional |
Number of results per page to return, ‘all’ to return all results Validations:
|
Field name | Type | Possible values |
---|---|---|
fullname | string | |
location | string | |
location_id | integer | |
name | string | |
organization | string | |
organization_id | integer | |
params | string |
GET /api/domains/759776769 200 { "fullname": "example480.com", "created_at": "2021-05-18 15:59:23 UTC", "updated_at": "2021-05-18 15:59:23 UTC", "id": 759776769, "name": "example480.com", "dns_id": null, "dns": null, "subnets": [], "interfaces": [], "parameters": [ { "priority": 30, "created_at": "2021-05-18 15:59:23 UTC", "updated_at": "2021-05-18 15:59:23 UTC", "id": 767575245, "name": "foo", "parameter_type": "string", "value": "*****" } ], "locations": [ { "id": 255093256, "name": "Location 1", "title": "Location 1", "description": null } ], "organizations": [ { "id": 447626438, "name": "Organization 1", "title": "Organization 1", "description": null } ] }
Param name | Description |
---|---|
location_id optional |
Set the current location context for the request Validations:
|
organization_id optional |
Set the current organization context for the request Validations:
|
id required |
Numerical ID or domain name Validations:
|
show_hidden_parameters optional |
Display hidden parameter values Validations:
|
The fullname field is used for human readability in reports and other pages that refer to domains, and also available as an external node parameter
POST /api/domains { "organization_id": 447626440, "domain": { "name": "example340.com", "organization_ids": [ 447626440 ], "location_ids": [ 447626442 ] } } 201 { "fullname": null, "created_at": "2021-05-18 15:52:57 UTC", "updated_at": "2021-05-18 15:52:57 UTC", "id": 759776768, "name": "example340.com", "dns_id": null, "dns": null, "subnets": [], "interfaces": [], "parameters": [], "locations": [ { "id": 447626442, "name": "loc161", "title": "loc161", "description": null } ], "organizations": [ { "id": 447626440, "name": "org154", "title": "org154", "description": null } ] }
Param name | Description |
---|---|
location_id optional |
Set the current location context for the request Validations:
|
organization_id optional |
Set the current organization context for the request Validations:
|
domain required |
Validations:
|
domain[name] required |
The full DNS domain name Validations:
|
domain[fullname] optional , nil allowed |
Description of the domain Validations:
|
domain[dns_id] optional , nil allowed |
DNS proxy ID to use within this domain Validations:
|
domain[domain_parameters_attributes] optional , nil allowed |
Array of parameters (name, value) Validations:
|
domain[location_ids] optional , nil allowed |
REPLACE locations with given ids Validations:
|
domain[organization_ids] optional , nil allowed |
REPLACE organizations with given ids. Validations:
|
POST /api/domains/22495316-mydomain-net { "domain": { "name": "domain.new", "dns_id": -1 } } 422 { "error": { "id": 22495316, "errors": { "dns_id": [ "Invalid smart-proxy id" ] }, "full_messages": [ "Dns Invalid smart-proxy id" ] } }
Param name | Description |
---|---|
location_id optional |
Set the current location context for the request Validations:
|
organization_id optional |
Set the current organization context for the request Validations:
|
id required |
Validations:
|
domain required |
Validations:
|
domain[name] optional |
The full DNS domain name Validations:
|
domain[fullname] optional , nil allowed |
Description of the domain Validations:
|
domain[dns_id] optional , nil allowed |
DNS proxy ID to use within this domain Validations:
|
domain[domain_parameters_attributes] optional , nil allowed |
Array of parameters (name, value) Validations:
|
domain[location_ids] optional , nil allowed |
REPLACE locations with given ids Validations:
|
domain[organization_ids] optional , nil allowed |
REPLACE organizations with given ids. Validations:
|
DELETE /api/domains/22495316-mydomain-net { "domain": {} } 200 { "id": 22495316, "name": "mydomain.net", "fullname": null, "created_at": "2021-05-18T16:20:36.021Z", "updated_at": "2021-05-18T16:20:36.021Z", "dns_id": 113629430 }
Param name | Description |
---|---|
location_id optional |
Set the current location context for the request Validations:
|
organization_id optional |
Set the current organization context for the request Validations:
|
id required |
Validations:
|