|
|
@ -37,12 +37,12 @@ options:
|
|
|
|
description:
|
|
|
|
description:
|
|
|
|
- Password of login user
|
|
|
|
- Password of login user
|
|
|
|
required: true
|
|
|
|
required: true
|
|
|
|
default: True
|
|
|
|
default: 'yes'
|
|
|
|
login_tenant_name:
|
|
|
|
login_tenant_name:
|
|
|
|
description:
|
|
|
|
description:
|
|
|
|
- The tenant name of the login user
|
|
|
|
- The tenant name of the login user
|
|
|
|
required: true
|
|
|
|
required: true
|
|
|
|
default: True
|
|
|
|
default: 'yes'
|
|
|
|
auth_url:
|
|
|
|
auth_url:
|
|
|
|
description:
|
|
|
|
description:
|
|
|
|
- The keystone url for authentication
|
|
|
|
- The keystone url for authentication
|
|
|
@ -193,48 +193,49 @@ def _remove_interface_router(quantum, module, router_id, subnet_id):
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
quantum.remove_interface_router(router_id, kwargs)
|
|
|
|
quantum.remove_interface_router(router_id, kwargs)
|
|
|
|
except Exception as e:
|
|
|
|
except Exception as e:
|
|
|
|
module.fail_json(msg = "Error in removing interface from router: %s" % e.message)
|
|
|
|
module.fail_json(msg="Error in removing interface from router: %s" % e.message)
|
|
|
|
return True
|
|
|
|
return True
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
def main():
|
|
|
|
module = AnsibleModule(
|
|
|
|
module = AnsibleModule(
|
|
|
|
argument_spec = dict(
|
|
|
|
argument_spec = dict(
|
|
|
|
login_username = dict(default='admin'),
|
|
|
|
login_username = dict(default='admin'),
|
|
|
|
login_password = dict(required=True),
|
|
|
|
login_password = dict(required=True),
|
|
|
|
login_tenant_name = dict(required='True'),
|
|
|
|
login_tenant_name = dict(required='True'),
|
|
|
|
auth_url = dict(default='http://127.0.0.1:35357/v2.0/'),
|
|
|
|
auth_url = dict(default='http://127.0.0.1:35357/v2.0/'),
|
|
|
|
region_name = dict(default=None),
|
|
|
|
region_name = dict(default=None),
|
|
|
|
router_name = dict(required=True),
|
|
|
|
router_name = dict(required=True),
|
|
|
|
subnet_name = dict(required=True),
|
|
|
|
subnet_name = dict(required=True),
|
|
|
|
tenant_name = dict(default=None),
|
|
|
|
tenant_name = dict(default=None),
|
|
|
|
state = dict(default='present', choices=['absent', 'present']),
|
|
|
|
state = dict(default='present', choices=['absent', 'present']),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
quantum = _get_quantum_client(module, module.params)
|
|
|
|
quantum = _get_quantum_client(module, module.params)
|
|
|
|
_set_tenant_id(module)
|
|
|
|
_set_tenant_id(module)
|
|
|
|
|
|
|
|
|
|
|
|
router_id = _get_router_id(module, quantum)
|
|
|
|
router_id = _get_router_id(module, quantum)
|
|
|
|
if not router_id:
|
|
|
|
if not router_id:
|
|
|
|
module.fail_json(msg = "failed to get the router id, please check the router name")
|
|
|
|
module.fail_json(msg="failed to get the router id, please check the router name")
|
|
|
|
|
|
|
|
|
|
|
|
subnet_id = _get_subnet_id(module, quantum)
|
|
|
|
subnet_id = _get_subnet_id(module, quantum)
|
|
|
|
if not subnet_id:
|
|
|
|
if not subnet_id:
|
|
|
|
module.fail_json(msg = "failed to get the subnet id, please check the subnet name")
|
|
|
|
module.fail_json(msg="failed to get the subnet id, please check the subnet name")
|
|
|
|
|
|
|
|
|
|
|
|
if module.params['state'] == 'present':
|
|
|
|
if module.params['state'] == 'present':
|
|
|
|
port_id = _get_port_id(quantum, module, router_id, subnet_id)
|
|
|
|
port_id = _get_port_id(quantum, module, router_id, subnet_id)
|
|
|
|
if not port_id:
|
|
|
|
if not port_id:
|
|
|
|
_add_interface_router(quantum, module, router_id, subnet_id)
|
|
|
|
_add_interface_router(quantum, module, router_id, subnet_id)
|
|
|
|
module.exit_json(changed = True, result = "created", id = port_id)
|
|
|
|
module.exit_json(changed=True, result="created", id=port_id)
|
|
|
|
module.exit_json(changed = False, result = "success", id = port_id)
|
|
|
|
module.exit_json(changed=False, result="success", id=port_id)
|
|
|
|
|
|
|
|
|
|
|
|
if module.params['state'] == 'absent':
|
|
|
|
if module.params['state'] == 'absent':
|
|
|
|
port_id = _get_port_id(quantum, module, router_id, subnet_id)
|
|
|
|
port_id = _get_port_id(quantum, module, router_id, subnet_id)
|
|
|
|
if not port_id:
|
|
|
|
if not port_id:
|
|
|
|
module.exit_json(changed = False, result = "Sucess")
|
|
|
|
module.exit_json(changed = False, result = "Sucess")
|
|
|
|
_remove_interface_router(quantum, module, router_id, subnet_id)
|
|
|
|
_remove_interface_router(quantum, module, router_id, subnet_id)
|
|
|
|
module.exit_json(changed = True, result = "Deleted")
|
|
|
|
module.exit_json(changed=True, result="Deleted")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# this is magic, see lib/ansible/module.params['common.py
|
|
|
|
# this is magic, see lib/ansible/module.params['common.py
|
|
|
|
#<<INCLUDE_ANSIBLE_MODULE_COMMON>>
|
|
|
|
#<<INCLUDE_ANSIBLE_MODULE_COMMON>>
|
|
|
|
main()
|
|
|
|
main()
|
|
|
|