networktocode.nautobot.location module – Creates or removes locations from Nautobot

Note

This module is part of the networktocode.nautobot collection (version 5.2.0).

To install it, use: ansible-galaxy collection install networktocode.nautobot. You need further requirements to be able to use this module, see Requirements for details.

To use it in a playbook, specify: networktocode.nautobot.location.

New in networktocode.nautobot 4.3.0

Synopsis

  • Creates or removes locations from Nautobot

Requirements

The below requirements are needed on the host that executes this module.

  • pynautobot

Parameters

Parameter

Comments

api_version

string

added in networktocode.nautobot 4.1.0

API Version Nautobot REST API

asn

integer

added in networktocode.nautobot 5.1.0

The ASN associated with the location

comments

string

added in networktocode.nautobot 5.1.0

Comments for the location. This can be markdown syntax

contact_email

string

added in networktocode.nautobot 5.1.0

Contact email for location

contact_name

string

added in networktocode.nautobot 5.1.0

Name of contact for location

contact_phone

string

added in networktocode.nautobot 5.1.0

Contact phone number for location

custom_fields

dictionary

added in networktocode.nautobot 3.0.0

Must exist in Nautobot and in key/value format

description

string

Location description

facility

string

added in networktocode.nautobot 5.1.0

Data center provider or facility, ex. Equinix NY7

id

string

Primary Key of the location, used to delete the location.

Because of hierarchical nature of locations and name being not unique across locations,

it’s a user responsibility to query location and pass its id(PK) to the task to delete the location.

latitude

string

added in networktocode.nautobot 5.1.0

Latitude in decimal format

location_type

any

The type of location

Required if state=present and does not exist yet

longitude

string

added in networktocode.nautobot 5.1.0

Longitude in decimal format

name

string

Name of the location to be created

parent_location

aliases: parent

any

The parent location this location should be tied to

physical_address

string

added in networktocode.nautobot 5.1.0

Physical address of location

query_params

list / elements=string

added in networktocode.nautobot 3.0.0

This can be used to override the specified values in ALLOWED_QUERY_PARAMS that is defined

in plugins/module_utils/utils.py and provides control to users on what may make

an object unique in their environment.

shipping_address

string

added in networktocode.nautobot 5.1.0

Shipping address of location

state

string

Use present or absent for adding or removing.

Choices:

status

any

Status of the location

Required if state=present and does not exist yet

tags

list / elements=any

added in networktocode.nautobot 3.0.0

Any tags that this item may need to be associated with

tenant

any

added in networktocode.nautobot 5.1.0

The tenant the location will be assigned to

time_zone

string

added in networktocode.nautobot 5.1.0

Timezone associated with the location, ex. America/Denver

token

string / required

The token created within Nautobot to authorize API access

url

string / required

The URL of the Nautobot instance resolvable by the Ansible host (for example: http://nautobot.example.com:8000)

validate_certs

any

If no, SSL certificates will not be validated. This should only be used on personally controlled sites using self-signed certificates.

Default: :ansible-option-default:`true`

Notes

Note

  • Tags should be defined as a YAML list

  • This should be ran with connection local and hosts localhost

Examples

- name: "Test Nautobot location module"
  connection: local
  hosts: localhost
  gather_facts: False
  tasks:
    - name: Create location
      networktocode.nautobot.location:
        url: http://nautobot.local
        token: thisIsMyToken
        name: My Location
        status: Active
        location_type:
          name: My Location Type
        state: present

    - name: Delete location
      networktocode.nautobot.location:
        url: http://nautobot.local
        token: thisIsMyToken
        id: "{{ location_to_delete['key'] }}"
        state: absent
      vars:
        location_to_delete: "{{ lookup('networktocode.nautobot.lookup', 'locations', api_endpoint=nautobot_url, token=nautobot_token, api_filter='name=\"My Location\" parent_location=\"Location Parent\" location_type=\"Main Type\"') }}"

    - name: Create location with all parameters
      networktocode.nautobot.location:
        url: http://nautobot.local
        token: thisIsMyToken
        name: My Nested Location
        status: Active
        location_type:
          name: My Location Type
        description: My Nested Location Description
        tenant: Test Tenant
        facility: EquinoxCA7
        asn: "65001"
        time_zone: America/Los Angeles
        physical_address: Hollywood, CA, 90210
        shipping_address: Hollywood, CA, 90210
        latitude: "10.100000"
        longitude: "12.200000"
        contact_name: Jenny
        contact_phone: 867-5309
        contact_email: jenny@example.com
        comments: "**This** is a `markdown` comment"
        parent: My Location
        state: present

Return Values

Common return values are documented here, the following are the fields unique to this module:

Key

Description

location

dictionary

Serialized object as created or already existent within Nautobot

Returned: on creation

msg

string

Message indicating failure or info about what has been achieved

Returned: always

Authors

  • Joe Wesch (@joewesch)