Create an Inventory Source for an Inventory
post
/api/v2/inventories/{id}/inventory_sources/
Make a POST request to this resource with the following inventory source fields to create a new inventory source associated with this inventory.
name
: Name of this inventory source. (string, required)description
: Optional description of this inventory source. (string, default=""
)source
: (choice)file
: File, Directory or Scriptscm
: Sourced from a Projectec2
: Amazon EC2gce
: Google Compute Engineazure_rm
: Microsoft Azure Resource Managervmware
: VMware vCentersatellite6
: Red Hat Satellite 6openstack
: OpenStackrhv
: Red Hat Virtualizationtower
: Ansible Towercustom
: Custom Script
source_path
: (string, default=""
)source_script
: (id, default=``)source_vars
: Inventory source variables in YAML or JSON format. (string, default=""
)credential
: Cloud credential to use for inventory updates. (integer, default=None
)enabled_var
: Retrieve the enabled state from the given dict of host variables. The enabled variable may be specified as "foo.bar", in which case the lookup will traverse into nested dicts, equivalent to: from_dict.get("foo", {}).get("bar", default) (string, default=""
)enabled_value
: Only used when enabled_var is set. Value when the host is considered enabled. For example if enabled_var="status.power_state"and enabled_value="powered_on" with host variables:{ "status": { "power_state": "powered_on", "created": "2018-02-01T08:00:00.000000Z:00", "healthy": true }, "name": "foobar", "ip_address": "192.168.2.1"}The host would be marked enabled. If power_state where any value other than powered_on then the host would be disabled when imported into Tower. If the key is not found then the host will be enabled (string, default=""
)host_filter
: Regex where only matching hosts will be imported into Tower. (string, default=""
)overwrite
: Overwrite local groups and hosts from remote inventory source. (boolean, default=False
)overwrite_vars
: Overwrite local variables from remote inventory source. (boolean, default=False
)custom_virtualenv
: Local absolute file path containing a custom Python virtualenv to use (string, default=""
)timeout
: The amount of time (in seconds) to run before the task is canceled. (integer, default=0
)-
verbosity
: (choice)0
: 0 (WARNING)1
: 1 (INFO) (default)2
: 2 (DEBUG)
-
update_on_launch
: (boolean, default=False
) update_cache_timeout
: (integer, default=0
)source_project
: Project containing inventory file used as source. (id, default=``)update_on_project_update
: (boolean, default=False
)
Request
Supported Media Types
- application/json
Path Parameters
Root Schema : schema
Example:
{
"name":"new inv src",
"overwrite_vars":true,
"source":"scm",
"source_project":1,
"source_vars":"plugin: a.b.c",
"update_on_project_update":false
}
Response
Supported Media Types
- application/json
201 Response
Example Response (application/json)
{
"created":"2018-02-01T08:00:00.000000Z",
"credential":null,
"custom_virtualenv":null,
"description":"",
"enabled_value":"",
"enabled_var":"",
"host_filter":"",
"id":3,
"inventory":1,
"last_job_failed":false,
"last_job_run":null,
"last_update_failed":false,
"last_updated":null,
"modified":"2018-02-01T08:00:00.000000Z",
"name":"new inv src",
"next_job_run":null,
"overwrite":false,
"overwrite_vars":true,
"related":{
"activity_stream":"/api/v2/inventory_sources/3/activity_stream/",
"credentials":"/api/v2/inventory_sources/3/credentials/",
"groups":"/api/v2/inventory_sources/3/groups/",
"hosts":"/api/v2/inventory_sources/3/hosts/",
"inventory":"/api/v2/inventories/1/",
"inventory_updates":"/api/v2/inventory_sources/3/inventory_updates/",
"notification_templates_error":"/api/v2/inventory_sources/3/notification_templates_error/",
"notification_templates_started":"/api/v2/inventory_sources/3/notification_templates_started/",
"notification_templates_success":"/api/v2/inventory_sources/3/notification_templates_success/",
"schedules":"/api/v2/inventory_sources/3/schedules/",
"source_project":"/api/v2/projects/1/",
"update":"/api/v2/inventory_sources/3/update/"
},
"source":"scm",
"source_path":"",
"source_project":1,
"source_script":null,
"source_vars":"plugin: a.b.c",
"status":"never updated",
"summary_fields":{
"credentials":[
],
"inventory":{
"description":"",
"has_active_failures":false,
"has_inventory_sources":true,
"hosts_with_active_failures":0,
"id":1,
"inventory_sources_with_failures":0,
"kind":"",
"name":"test-inv",
"organization_id":1,
"total_groups":0,
"total_hosts":0,
"total_inventory_sources":2
},
"organization":{
"description":"test-org-desc",
"id":1,
"name":"test-org"
},
"source_project":{
"description":"test-proj-desc",
"id":1,
"name":"test-proj",
"scm_type":"git",
"status":"never updated"
},
"user_capabilities":{
"delete":true,
"edit":true,
"schedule":true,
"start":true
}
},
"timeout":0,
"type":"inventory_source",
"update_cache_timeout":0,
"update_on_launch":false,
"update_on_project_update":false,
"url":"/api/v2/inventory_sources/3/",
"verbosity":1
}
400 Response
Example Response (application/json)
{
"inventory":{
"detail":"Cannot create Inventory Source for Smart Inventory"
},
"source":[
"\"\" is not a valid choice."
]
}
403 Response
Example Response (application/json)
{
"detail":"You do not have permission to perform this action."
}