Server IP : 85.214.239.14 / Your IP : 18.225.156.91 Web Server : Apache/2.4.62 (Debian) System : Linux h2886529.stratoserver.net 4.9.0 #1 SMP Tue Jan 9 19:45:01 MSK 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.18 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : OFF | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : OFF Directory : /lib/python3/dist-packages/ansible_collections/netbox/netbox/plugins/modules/ |
Upload File : |
#!/usr/bin/python # -*- coding: utf-8 -*- # Copyright: (c) 2018, Mikhail Yohman (@FragmentedPacket) <mikhail.yohman@gmail.com> # GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt) from __future__ import absolute_import, division, print_function __metaclass__ = type DOCUMENTATION = r""" --- module: netbox_ip_address short_description: Creates or removes IP addresses from NetBox description: - Creates or removes IP addresses from NetBox notes: - Tags should be defined as a YAML list - This should be ran with connection C(local) and hosts C(localhost) author: - Mikhail Yohman (@FragmentedPacket) - Anthony Ruhier (@Anthony25) requirements: - pynetbox version_added: '0.1.0' extends_documentation_fragment: - netbox.netbox.common options: data: type: dict description: - Defines the IP address configuration suboptions: family: description: - (DEPRECATED) - NetBox now handles determining the IP family natively. - Specifies with address family the IP address belongs to choices: - 4 - 6 required: false type: int address: description: - Required if state is C(present) required: false type: str prefix: description: - | With state C(present), if an interface is given, it will ensure that an IP inside this prefix (and vrf, if given) is attached to this interface. Otherwise, it will get the next available IP of this prefix and attach it. With state C(new), it will force to get the next available IP in this prefix. If an interface is given, it will also force to attach it. Required if state is C(present) or C(new) when no address is given. Unused if an address is specified. required: false type: raw vrf: description: - VRF that IP address is associated with required: false type: raw tenant: description: - The tenant that the device will be assigned to required: false type: raw status: description: - The status of the IP address required: false type: raw role: description: - The role of the IP address choices: - Loopback - Secondary - Anycast - VIP - VRRP - HSRP - GLBP - CARP required: false type: str interface: description: - | The name and device of the interface that the IP address should be assigned to Required if state is C(present) and a prefix specified. required: false type: raw description: description: - The description of the interface required: false type: str nat_inside: description: - The inside IP address this IP is assigned to required: false type: raw dns_name: description: - Hostname or FQDN required: false type: str assigned_object: description: - Definition of the assigned object. required: false type: dict suboptions: name: description: - The name of the interface type: str required: False device: description: - The device the interface is attached to. type: str required: False virtual_machine: description: - The virtual machine the interface is attached to. type: str required: False comments: description: - Comments that may include additional information in regards to the IP Address required: false type: str version_added: "3.10.0" tags: description: - Any tags that the IP address may need to be associated with required: false type: list elements: raw custom_fields: description: - must exist in NetBox required: false type: dict required: true state: description: - | Use C(present), C(new) or C(absent) for adding, force adding or removing. C(present) will check if the IP is already created, and return it if true. C(new) will force to create it anyway (useful for anycasts, for example). choices: [ absent, new, present ] default: present type: str """ EXAMPLES = r""" - name: "Test NetBox IP address module" connection: local hosts: localhost gather_facts: False tasks: - name: Create IP address within NetBox with only required information netbox.netbox.netbox_ip_address: netbox_url: http://netbox.local netbox_token: thisIsMyToken data: address: 192.168.1.10 state: present - name: Force to create (even if it already exists) the IP netbox.netbox.netbox_ip_address: netbox_url: http://netbox.local netbox_token: thisIsMyToken data: address: 192.168.1.10 state: new - name: Get a new available IP inside 192.168.1.0/24 netbox.netbox.netbox_ip_address: netbox_url: http://netbox.local netbox_token: thisIsMyToken data: prefix: 192.168.1.0/24 state: new - name: Delete IP address within netbox netbox.netbox.netbox_ip_address: netbox_url: http://netbox.local netbox_token: thisIsMyToken data: address: 192.168.1.10 state: absent - name: Create IP address with several specified options netbox.netbox.netbox_ip_address: netbox_url: http://netbox.local netbox_token: thisIsMyToken data: address: 192.168.1.20 vrf: Test tenant: Test Tenant status: Reserved role: Loopback description: Test description tags: - Schnozzberry state: present - name: Create IP address and assign a nat_inside IP netbox.netbox.netbox_ip_address: netbox_url: http://netbox.local netbox_token: thisIsMyToken data: address: 192.168.1.30 vrf: Test nat_inside: address: 192.168.1.20 vrf: Test interface: name: GigabitEthernet1 device: test100 - name: Ensure that an IP inside 192.168.1.0/24 is attached to GigabitEthernet1 netbox.netbox.netbox_ip_address: netbox_url: http://netbox.local netbox_token: thisIsMyToken data: prefix: 192.168.1.0/24 vrf: Test interface: name: GigabitEthernet1 device: test100 state: present - name: Attach a new available IP of 192.168.1.0/24 to GigabitEthernet1 netbox.netbox.netbox_ip_address: netbox_url: http://netbox.local netbox_token: thisIsMyToken data: prefix: 192.168.1.0/24 vrf: Test interface: name: GigabitEthernet1 device: test100 state: new - name: Attach a new available IP of 192.168.1.0/24 to GigabitEthernet1 (NetBox 2.9+) netbox.netbox.netbox_ip_address: netbox_url: http://netbox.local netbox_token: thisIsMyToken data: prefix: 192.168.1.0/24 vrf: Test assigned_object: name: GigabitEthernet1 device: test100 state: new """ RETURN = r""" ip_address: description: Serialized object as created or already existent within NetBox returned: on creation type: dict msg: description: Message indicating failure or info about what has been achieved returned: always type: str """ from ansible_collections.netbox.netbox.plugins.module_utils.netbox_utils import ( NetboxAnsibleModule, NETBOX_ARG_SPEC, ) from ansible_collections.netbox.netbox.plugins.module_utils.netbox_ipam import ( NetboxIpamModule, NB_IP_ADDRESSES, ) from copy import deepcopy def main(): """ Main entry point for module execution """ argument_spec = deepcopy(NETBOX_ARG_SPEC) # state choices present, absent, new argument_spec["state"] = dict( required=False, default="present", choices=["present", "absent", "new"] ) argument_spec.update( dict( data=dict( type="dict", required=True, options=dict( address=dict(required=False, type="str"), family=dict( required=False, type="int", choices=[4, 6], removed_in_version="4.0.0", removed_from_collection="netbox.netbox", ), prefix=dict(required=False, type="raw"), vrf=dict(required=False, type="raw"), tenant=dict(required=False, type="raw"), status=dict(required=False, type="raw"), role=dict( required=False, type="str", choices=[ "Loopback", "Secondary", "Anycast", "VIP", "VRRP", "HSRP", "GLBP", "CARP", ], ), interface=dict(required=False, type="raw"), description=dict(required=False, type="str"), nat_inside=dict(required=False, type="raw"), dns_name=dict(required=False, type="str"), assigned_object=dict( required=False, type="dict", options=dict( name=dict(required=False, type="str"), device=dict(required=False, type="str"), virtual_machine=dict(required=False, type="str"), ), ), comments=dict(required=False, type="str"), tags=dict(required=False, type="list", elements="raw"), custom_fields=dict(required=False, type="dict"), ), ), ) ) required_if = [ ("state", "present", ["address", "prefix"], True), ("state", "absent", ["address"]), ("state", "new", ["address", "prefix"], True), ] mutually_exclusive = [["interface", "assigned_object"], ["address", "prefix"]] module = NetboxAnsibleModule( argument_spec=argument_spec, supports_check_mode=True, required_if=required_if, mutually_exclusive=mutually_exclusive, ) netbox_ip_address = NetboxIpamModule(module, NB_IP_ADDRESSES) netbox_ip_address.run() if __name__ == "__main__": # pragma: no cover main()