summaryrefslogtreecommitdiffstats
path: root/ansible_collections/cisco/ise/plugins/action/user_equipment_info.py
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-05 16:18:34 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-05 16:18:34 +0000
commit3667197efb7b18ec842efd504785965911f8ac4b (patch)
tree0b986a4bc6879d080b100666a97cdabbc9ca1f28 /ansible_collections/cisco/ise/plugins/action/user_equipment_info.py
parentAdding upstream version 9.5.1+dfsg. (diff)
downloadansible-1f02d92b7a8d732f4e9bbdeb50c68dd718d53d00.tar.xz
ansible-1f02d92b7a8d732f4e9bbdeb50c68dd718d53d00.zip
Adding upstream version 10.0.0+dfsg.upstream/10.0.0+dfsg
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'ansible_collections/cisco/ise/plugins/action/user_equipment_info.py')
-rw-r--r--ansible_collections/cisco/ise/plugins/action/user_equipment_info.py141
1 files changed, 141 insertions, 0 deletions
diff --git a/ansible_collections/cisco/ise/plugins/action/user_equipment_info.py b/ansible_collections/cisco/ise/plugins/action/user_equipment_info.py
new file mode 100644
index 000000000..94879efff
--- /dev/null
+++ b/ansible_collections/cisco/ise/plugins/action/user_equipment_info.py
@@ -0,0 +1,141 @@
+#!/usr/bin/env python
+# -*- coding: utf-8 -*-
+
+# Copyright (c) 2024, Cisco Systems
+# GNU General Public License v3.0+ (see LICENSE or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+from __future__ import absolute_import, division, print_function
+
+__metaclass__ = type
+from ansible.plugins.action import ActionBase
+
+try:
+ from ansible_collections.ansible.utils.plugins.module_utils.common.argspec_validate import (
+ AnsibleArgSpecValidator,
+ )
+except ImportError:
+ ANSIBLE_UTILS_IS_INSTALLED = False
+else:
+ ANSIBLE_UTILS_IS_INSTALLED = True
+from ansible.errors import AnsibleActionFail
+from ansible_collections.cisco.ise.plugins.plugin_utils.ise import (
+ ISESDK,
+ ise_argument_spec,
+)
+
+# Get common arguements specification
+argument_spec = ise_argument_spec()
+# Add arguments specific for this module
+argument_spec.update(dict(
+ page=dict(type="int"),
+ size=dict(type="int"),
+ filter=dict(type="str"),
+ filterType=dict(type="str"),
+ sort=dict(type="str"),
+ sortBy=dict(type="str"),
+ userEquipmentId=dict(type="str"),
+))
+
+required_if = []
+required_one_of = []
+mutually_exclusive = []
+required_together = []
+
+
+class ActionModule(ActionBase):
+ def __init__(self, *args, **kwargs):
+ if not ANSIBLE_UTILS_IS_INSTALLED:
+ raise AnsibleActionFail("ansible.utils is not installed. Execute 'ansible-galaxy collection install ansible.utils'")
+ super(ActionModule, self).__init__(*args, **kwargs)
+ self._supports_async = False
+ self._supports_check_mode = True
+ self._result = None
+
+ # Checks the supplied parameters against the argument spec for this module
+ def _check_argspec(self):
+ aav = AnsibleArgSpecValidator(
+ data=self._task.args,
+ schema=dict(argument_spec=argument_spec),
+ schema_format="argspec",
+ schema_conditionals=dict(
+ required_if=required_if,
+ required_one_of=required_one_of,
+ mutually_exclusive=mutually_exclusive,
+ required_together=required_together,
+ ),
+ name=self._task.action,
+ )
+ valid, errors, self._task.args = aav.validate()
+ if not valid:
+ raise AnsibleActionFail(errors)
+
+ def get_object(self, params):
+ new_object = dict(
+ page=params.get("page"),
+ size=params.get("size"),
+ filter=params.get("filter"),
+ filter_type=params.get("filterType"),
+ sort=params.get("sort"),
+ sort_by=params.get("sortBy"),
+ user_equipment_id=params.get("userEquipmentId"),
+ )
+ return new_object
+
+ def run(self, tmp=None, task_vars=None):
+ self._task.diff = False
+ self._result = super(ActionModule, self).run(tmp, task_vars)
+ self._result["changed"] = False
+ self._check_argspec()
+
+ self._result.update(dict(ise_response=[]))
+
+ ise = ISESDK(params=self._task.args)
+
+ id = self._task.args.get("userEquipmentId")
+ name = self._task.args.get("name")
+ if id:
+ response = ise.exec(
+ family="user_equipment",
+ function='get_user_equipment_by_id',
+ params=self.get_object(self._task.args)
+ ).response['response']
+ self._result.update(dict(ise_response=response))
+ self._result.update(ise.exit_json())
+ return self._result
+ if not name and not id:
+ responses = []
+ generator = ise.exec(
+ family="user_equipment",
+ function='get_user_equipments_generator',
+ params=self.get_object(self._task.args),
+ )
+ try:
+ for item in generator:
+ tmp_response = item.response['response']
+ if isinstance(tmp_response, list):
+ responses += tmp_response
+ else:
+ responses.append(tmp_response)
+ response = responses
+ except (TypeError, AttributeError) as e:
+ ise.fail_json(
+ msg=(
+ "An error occured when executing operation."
+ " Check the configuration of your API Settings and API Gateway settings on your ISE server."
+ " This collection assumes that the API Gateway, the ERS APIs and OpenAPIs are enabled."
+ " You may want to enable the (ise_debug: True) argument."
+ " The error was: {error}"
+ ).format(error=e)
+ )
+ except Exception as e:
+ ise.fail_json(
+ msg=(
+ "An error occured when executing operation."
+ " The error was: {error}"
+ " You may want to enable the (ise_debug: True) argument."
+ ).format(error=e)
+ )
+
+ self._result.update(dict(ise_response=response))
+ self._result.update(ise.exit_json())
+ return self._result