diff options
author | Ilia Abashin <abashinos@gmail.com> | 2017-08-13 15:25:58 +0300 |
---|---|---|
committer | Ilia Abashin <abashinos@gmail.com> | 2017-08-13 15:34:41 +0300 |
commit | e97b4b77236b225b14f6f1eb7ac7bb88663889f8 (patch) | |
tree | ba2c5e7fe21fd12eb725383c4b20c1920c9535b4 /app/discover/fetchers | |
parent | 1ae58d7b103bead4f09f735b837efa3d55b08736 (diff) |
TA3017 Added more data to switch pnics
Added fvCEp and fvRsCEpToPathEp data to fetched switch pnic data
Change-Id: I1a33955369567466dea0e626e1ca3992d1cbf53f
Signed-off-by: Ilia Abashin <abashinos@gmail.com>
Diffstat (limited to 'app/discover/fetchers')
-rw-r--r-- | app/discover/fetchers/aci/aci_fetch_switch_pnic.py | 33 |
1 files changed, 29 insertions, 4 deletions
diff --git a/app/discover/fetchers/aci/aci_fetch_switch_pnic.py b/app/discover/fetchers/aci/aci_fetch_switch_pnic.py index bb87b7b..b888af4 100644 --- a/app/discover/fetchers/aci/aci_fetch_switch_pnic.py +++ b/app/discover/fetchers/aci/aci_fetch_switch_pnic.py @@ -45,6 +45,26 @@ class AciFetchSwitchPnic(AciAccess): "attributes") return switch_data[0] if switch_data else None + def fetch_client_endpoints(self, mac_address): + mac_filter = "eq(fvCEp.mac,\"{}\")".format(mac_address) + query_params = { + "rsp-subtree": "children", + "query-target-filter": mac_filter + } + + endpoints = self.fetch_objects_by_class("fvCEp", query_params) + + results = [] + for endpoint in endpoints: + result = endpoint["attributes"] + result["fvRsCEpToPathEp"] = [] + for path in filter(lambda child: "fvRsCEpToPathEp" in child, + endpoint.get("children", [])): + result["fvRsCEpToPathEp"].append(path["fvRsCEpToPathEp"]["attributes"]) + results.append(result) + + return results + @aci_config_required(default=[]) def get(self, pnic_id): environment = self.get_env() @@ -91,17 +111,22 @@ class AciFetchSwitchPnic(AciAccess): environment=environment) # Prepare pnic json for results list - if_id = decode_aci_dn(leaf_pnic["ifId"]) - db_pnic_id = "-".join([db_leaf_id, if_id, mac_address]) + fvCEp = self.fetch_client_endpoints(mac_address) + + db_pnic_id = "-".join([db_leaf_id, + encode_aci_dn(leaf_pnic["ifId"]), + mac_address]) + pnic_json = { "id": db_pnic_id, - "object_name": if_id, + "object_name": leaf_pnic["ifId"], "type": "switch_pnic", "role": "hostlink", "parent_id": db_leaf_id, "parent_type": "switch", "mac_address": mac_address, "switch": db_leaf_id, - "aci_document": leaf_pnic + "aci_document": leaf_pnic, + "fvCEp": fvCEp } return [pnic_json] |