From 4a106d3cf7ef0ac4e98ae80a10affaee25a4c6ef Mon Sep 17 00:00:00 2001 From: Xiuchao Wu Date: Tue, 27 Sep 2016 15:42:46 +0100 Subject: add icons needed by topology rendering, add code for loading data from overlay micro-services, and show more details when a node is clicked. Change-Id: I15335650d77aba6ac7fd1b5ab19c6bef94026d9c Signed-off-by: Xiuchao Wu --- .../src/main/webapp/lifecyclemgr/js/topo/Node.js | 7 +- .../webapp/lifecyclemgr/js/topo/OverlayTopology.js | 147 +++++++++++++++------ 2 files changed, 116 insertions(+), 38 deletions(-) (limited to 'openo-portal/portal-lifecyclemgr/src/main/webapp/lifecyclemgr/js') diff --git a/openo-portal/portal-lifecyclemgr/src/main/webapp/lifecyclemgr/js/topo/Node.js b/openo-portal/portal-lifecyclemgr/src/main/webapp/lifecyclemgr/js/topo/Node.js index 8215c3c5..efb80b03 100644 --- a/openo-portal/portal-lifecyclemgr/src/main/webapp/lifecyclemgr/js/topo/Node.js +++ b/openo-portal/portal-lifecyclemgr/src/main/webapp/lifecyclemgr/js/topo/Node.js @@ -16,11 +16,16 @@ var icon = { device_icon : "images/topo/NEUP.png", sfc_device_icon : "images/topo/OTHER_3.png", + site_icon : "images/topo/site.png", network_icon : "images/topo/NETWORK.png" } -function Node(id, label, size, type, x, y) { + +/* when node is clicked, details will be displayed in the label. */ +function Node(id, label, details, size, type, x, y) { this.id = id; this.label = label; + this.brief = label; + this.details = details; this.type = "square"; this.x = x; this.y = y; diff --git a/openo-portal/portal-lifecyclemgr/src/main/webapp/lifecyclemgr/js/topo/OverlayTopology.js b/openo-portal/portal-lifecyclemgr/src/main/webapp/lifecyclemgr/js/topo/OverlayTopology.js index 7c35c38a..6b4fd1eb 100644 --- a/openo-portal/portal-lifecyclemgr/src/main/webapp/lifecyclemgr/js/topo/OverlayTopology.js +++ b/openo-portal/portal-lifecyclemgr/src/main/webapp/lifecyclemgr/js/topo/OverlayTopology.js @@ -13,6 +13,10 @@ * limitations under the License. */ +/* overlay micro-service API URL. We might use Maven filter feature to replace with the real address when generating the war package. */ +const REQUEST_URL_PER_OVERLAY_VPN = "http://localhost:8080/org.openo.sdno.overlayvpnservice/openoapi/sdnooverlayvpn/v1/site2dc-vpn/"; + +/* extract Overlay VPN ID from query string of request URL. */ function extractOverlayVPNId() { var parameters = location.search.substring(1).split("&"); @@ -22,8 +26,35 @@ function extractOverlayVPNId() return id; } -function Topology(containerId) { +/* load overlay vpn instance data from overlay micro-service and display its topology. */ +function loadOverlayData(vpn_id) { + var requestUrl = REQUEST_URL_PER_OVERLAY_VPN.concat(vpn_id); + $ + .ajax({ + type: "GET", + url: requestUrl, + contentType: "application/json", + success: function (jsonobj) { + init_topo(jsonobj); + }, + error: function (xhr, ajaxOptions, thrownError) { + alert("Error on getting Overlayvpn data : " + xhr.responseText); + + //the following lines are used to test w/o overlay micro-service. + //var vpn_info = createMockVpnInfo(); + //init_topo(vpn_info); + } + }); +} +/* a function that mock overlay micro-service response based on API for testing purpose only.*/ +function createMockVpnInfo(vpn_id) { + var vpnObj = '{"name":"Overlay VPN 1","description":"One VPN connect site to DC.","site":{"cidr":"10.10.0.0/16","thinCpeId":"thincpe-1234-5678","portAndVlan":"port12vlan13","vCPEId":"vcpe-2222-5555"},"vpc":{"name":"VPC 1","site":{"name":"subnet 1","cidr":"172.18.0.0/16","vni":"vni-1234-9999"}},"sfp":{"scfNeId":"scfneid-1234-5678","servicePathHop":[{"hopNumber":"hopNumber-111111","sfiId":"sfiId-333333","sfgId":"sfgId-444444"}]}}'; + return JSON.parse(vpnObj); +} + +/* definition of Topology */ +function Topology(containerId) { /** * IMPORTANT: This only works with the canvas renderer. TBD in the future * will also support the WebGL renderer. @@ -48,71 +79,113 @@ function Topology(containerId) { edgeLabelSize : 'proportional' } }); + this.addNode = addNode; this.addEdge = addEdge; } - function addNode(node) { - this.s.graph.addNode(node); - } - function addEdge(edge) { this.s.graph.addEdge(edge); } -function init() { - var node1 = new Node("1", "ThinCPE", 16, "device_icon", 0.1, 0.5); - var node2 = new Node("2", "vCPE", 16, "device_icon", 0.4, 0.5); - var node3 = new Node("3", "GW", 16, "device_icon", 0.8, 0.5); +/* get details to be displayed when site or vpc node is clicked. Note that more details may be added if it is appropriate. */ +function getSiteDetails(vpn_info) { + var siteCidr = vpn_info.site.cidr; + return "Site CIDR: ".concat(siteCidr); +} +function getVPCDetails(vpn_info) { + var vpcCidr = vpn_info.vpc.site.cidr; + return "VPC CIDR: ".concat(vpcCidr);; +} - var node6 = new Node("6", "FW", 8, "sfc_device_icon", 0.85, 0.4); - var node7 = new Node("7", "LB", 8, "sfc_device_icon", 0.9, 0.3); - var node8 = new Node("8", "VPC", 48, "network_icon", 1.05, 0.4); - - var node4 = new Node("4", "vFW", 8, "sfc_device_icon", 0.32, 0.35); - var node5 = new Node("5", "vLB", 8, "sfc_device_icon", 0.48, 0.35); +/** create topology of overlay vpn with instance data. + * Note that the layout/topology is hard-coded. In the future, this function may be moved to BRS/MSS + * that can understand NSD, calculate layout, fill with instance information, and return the final JSON string expected by sigma for rendering. + */ +function createNodesAndEdgesForOverlayVPN(topology, vpn_info) { + var siteNode = new Node("site", "Site", getSiteDetails(vpn_info), 48, "site_icon", 0.1, 0.65); + var thinCPENode = new Node("thinCPE", "ThinCPE", "ThinCPE ID: ".concat(vpn_info.site.thinCpeId), 16, "device_icon", 0.1, 0.5); + var vCPENode = new Node("vCPE", "vCPE", "vCPE ID: ".concat(vpn_info.site.vCPEId), 16, "device_icon", 0.4, 0.5); + var gwNode = new Node("gw", "GW", "GW", 16, "device_icon", 0.8, 0.5); - var edge1 = new Edge("e1", "VxLAN", "1", "2", 0.5, "blue"); - var edge2 = new Edge("e2", "IPSec", "2", "3", 0.5, "green"); + var fwNode = new Node("fw", "FW", "FW", 8, "sfc_device_icon", 0.8, 0.4); + var lbNode = new Node("lb", "LB", "LB", 8, "sfc_device_icon", 0.8, 0.3); + var vpcNode = new Node("vpc", "VPC", getVPCDetails(vpn_info), 48, "network_icon", 1.0, 0.3); + var vfwNode = new Node("vfw", "vFW", "vFW", 8, "sfc_device_icon", 0.32, 0.35); + var vlbNode = new Node("vlb", "vLB", "vLB", 8, "sfc_device_icon", 0.48, 0.35); - var edge3 = new Edge("e3", "", "2", "4", 0.5, "grey"); - var edge4 = new Edge("e4", "", "4", "5", 0.5, "grey"); - var edge5 = new Edge("e5", "", "5", "2", 0.5, "grey"); + var edge0 = new Edge("e0", "", "site", "thinCPE", 0.5, "black"); + var edge1 = new Edge("e1", "VxLAN", "thinCPE", "vCPE", 0.5, "blue"); + var edge2 = new Edge("e2", "IPSec", "vCPE", "gw", 0.5, "green"); - var edge6 = new Edge("e6", "", "3", "6", 0.5, "grey"); - var edge7 = new Edge("e7", "", "6", "7", 0.5, "grey"); - var edge8 = new Edge("e8", "", "7", "8", 0.5, "grey"); + var edge3 = new Edge("e3", "", "vCPE", "vfw", 0.5, "grey"); + var edge4 = new Edge("e4", "", "vfw", "vlb", 0.5, "grey"); + var edge5 = new Edge("e5", "", "vlb", "vCPE", 0.5, "grey"); - var topology = new Topology("container"); + var edge6 = new Edge("e6", "", "gw", "fw", 0.5, "grey"); + var edge7 = new Edge("e7", "", "fw", "lb", 0.5, "grey"); + var edge8 = new Edge("e8", "", "lb", "vpc", 0.5, "grey"); - topology.addNode(node1); - topology.addNode(node2); - topology.addNode(node3); - topology.addNode(node4); - topology.addNode(node5); - topology.addNode(node6); - topology.addNode(node7); - topology.addNode(node8); - + topology.addNode(siteNode); + topology.addNode(thinCPENode); + topology.addNode(vCPENode); + topology.addNode(gwNode); + topology.addNode(fwNode); + topology.addNode(lbNode); + topology.addNode(vpcNode); + topology.addNode(vfwNode); + topology.addNode(vlbNode); + + topology.addEdge(edge0); topology.addEdge(edge1); topology.addEdge(edge2); topology.addEdge(edge3); topology.addEdge(edge4); topology.addEdge(edge5); - topology.addEdge(edge6); topology.addEdge(edge7); topology.addEdge(edge8); - - +} + + +/* create and show the topology based on overlay vpn instance data. */ +function init_topo(vpn_info) { + var topology = new Topology("container"); + createNodesAndEdgesForOverlayVPN(topology, vpn_info); CustomShapes.init(topology.s); topology.s.refresh(); + + //show details when a node is clicked + topology.s.bind('clickNode', function(e) { + console.log(e.type, e.data.node.label, e.data.captor); + var nodeId = e.data.node.id; + topology.s.graph.nodes().forEach(function(n) { + if (n.id == nodeId) + n.label = n.details; + }); + topology.s.refresh(); + }); + topology.s.bind('clickStage', function(e) { + console.log(e.type, e.data.edge, e.data.captor); + topology.s.graph.nodes().forEach(function(n) { + n.label = n.brief; + }); + topology.s.refresh(); + }); } +/* code to be run when loading the page */ $(document).ready(function() { - init(); + var vpn_id = extractOverlayVPNId(); + + //load overlay vpn instance data and show its topology. + loadOverlayData(vpn_id); + + //insert overlay VPN id into the title. + var titleStr = "Topology of Overlay VPN : ".concat("", vpn_id, ""); + document.getElementById("title").innerHTML = titleStr; }); \ No newline at end of file -- cgit 1.2.3-korg