mirror of
https://github.com/opennetworkinglab/onos.git
synced 2025-10-27 14:21:48 +01:00
GUI -- Refactored Topo View to move websocket code into TopoEventService.
- now it is more properly encapsulated. Change-Id: Ib5cb88acf63e78be648ff45e737c76041b53e44b
This commit is contained in:
parent
bb596362db
commit
fd1231a0a6
@ -28,13 +28,13 @@
|
|||||||
];
|
];
|
||||||
|
|
||||||
// references to injected services etc.
|
// references to injected services etc.
|
||||||
var $log, ks, zs, gs, ms, ps, wss, tes;
|
var $log, ks, zs, gs, ms, ps, tes;
|
||||||
|
|
||||||
// DOM elements
|
// DOM elements
|
||||||
var ovtopo, svg, defs, zoomLayer, map;
|
var ovtopo, svg, defs, zoomLayer, map;
|
||||||
|
|
||||||
// Internal state
|
// Internal state
|
||||||
var zoomer, wsock, evDispatcher;
|
var zoomer, evDispatcher;
|
||||||
|
|
||||||
// Note: "exported" state should be properties on 'self' variable
|
// Note: "exported" state should be properties on 'self' variable
|
||||||
|
|
||||||
@ -129,44 +129,6 @@
|
|||||||
//showCallibrationPoints();
|
//showCallibrationPoints();
|
||||||
}
|
}
|
||||||
|
|
||||||
// --- Web Socket Connection -----------------------------------------
|
|
||||||
// TODO: migrate this code to be encapsulated by TopoEventService
|
|
||||||
|
|
||||||
function onWsOpen() {
|
|
||||||
$log.log('web socket opened...');
|
|
||||||
evDispatcher.sendEvent('requestSummary');
|
|
||||||
}
|
|
||||||
|
|
||||||
function onWsMessage(ev) {
|
|
||||||
evDispatcher.handleEvent(ev);
|
|
||||||
}
|
|
||||||
|
|
||||||
function onWsClose(reason) {
|
|
||||||
$log.log('web socket closed; reason=', reason);
|
|
||||||
wsock = null;
|
|
||||||
tes.bindSock(null);
|
|
||||||
}
|
|
||||||
|
|
||||||
// wsport indicates web-socket-server port other than the default.
|
|
||||||
// Used for testing with the mock-web-socket-server.
|
|
||||||
function setUpWebSocket(wsport) {
|
|
||||||
wsock = wss.createWebSocket('topology', {
|
|
||||||
onOpen: onWsOpen,
|
|
||||||
onMessage: onWsMessage,
|
|
||||||
onClose: onWsClose,
|
|
||||||
wsport: wsport
|
|
||||||
});
|
|
||||||
|
|
||||||
tes.bindSock(wsock);
|
|
||||||
|
|
||||||
// TODO: handle "guiSuccessor" functionality (replace host)
|
|
||||||
// TODO: implement retry on close functionality
|
|
||||||
|
|
||||||
|
|
||||||
$log.log('created web socket', wsock);
|
|
||||||
// TODO: complete implementation...
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// --- Controller Definition -----------------------------------------
|
// --- Controller Definition -----------------------------------------
|
||||||
|
|
||||||
@ -175,10 +137,10 @@
|
|||||||
.controller('OvTopoCtrl', [
|
.controller('OvTopoCtrl', [
|
||||||
'$scope', '$log', '$location', '$timeout',
|
'$scope', '$log', '$location', '$timeout',
|
||||||
'KeyService', 'ZoomService', 'GlyphService', 'MapService',
|
'KeyService', 'ZoomService', 'GlyphService', 'MapService',
|
||||||
'PanelService', 'WebSocketService', 'TopoEventService',
|
'PanelService', 'TopoEventService',
|
||||||
|
|
||||||
function ($scope, _$log_, $loc, $timeout,
|
function ($scope, _$log_, $loc, $timeout,
|
||||||
_ks_, _zs_, _gs_, _ms_, _ps_, _wss_, _tes_) {
|
_ks_, _zs_, _gs_, _ms_, _ps_, _tes_) {
|
||||||
var self = this;
|
var self = this;
|
||||||
$log = _$log_;
|
$log = _$log_;
|
||||||
ks = _ks_;
|
ks = _ks_;
|
||||||
@ -186,7 +148,6 @@
|
|||||||
gs = _gs_;
|
gs = _gs_;
|
||||||
ms = _ms_;
|
ms = _ms_;
|
||||||
ps = _ps_;
|
ps = _ps_;
|
||||||
wss = _wss_;
|
|
||||||
tes = _tes_;
|
tes = _tes_;
|
||||||
|
|
||||||
self.notifyResize = function () {
|
self.notifyResize = function () {
|
||||||
@ -196,9 +157,7 @@
|
|||||||
// Cleanup on destroyed scope..
|
// Cleanup on destroyed scope..
|
||||||
$scope.$on('$destroy', function () {
|
$scope.$on('$destroy', function () {
|
||||||
$log.log('OvTopoCtrl is saying Buh-Bye!');
|
$log.log('OvTopoCtrl is saying Buh-Bye!');
|
||||||
wsock && wsock.close();
|
tes.closeSock();
|
||||||
wsock = null;
|
|
||||||
tes.bindSock(null);
|
|
||||||
ps.destroyPanel('topo-p-summary');
|
ps.destroyPanel('topo-p-summary');
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -206,14 +165,16 @@
|
|||||||
ovtopo = d3.select('#ov-topo');
|
ovtopo = d3.select('#ov-topo');
|
||||||
svg = ovtopo.select('svg');
|
svg = ovtopo.select('svg');
|
||||||
|
|
||||||
// bind to topo event service..
|
// bind to topo event dispatcher..
|
||||||
evDispatcher = tes.dispatcher;
|
evDispatcher = tes.bindDispatcher('TODO: topo-DOM-elements-here');
|
||||||
|
|
||||||
setUpKeys();
|
setUpKeys();
|
||||||
setUpDefs();
|
setUpDefs();
|
||||||
setUpZoom();
|
setUpZoom();
|
||||||
setUpMap();
|
setUpMap();
|
||||||
setUpWebSocket($loc.search().wsport);
|
|
||||||
|
// open up a connection to the server...
|
||||||
|
tes.openSock();
|
||||||
|
|
||||||
// TODO: remove this temporary code....
|
// TODO: remove this temporary code....
|
||||||
var p = ps.createPanel('topo-p-summary');
|
var p = ps.createPanel('topo-p-summary');
|
||||||
|
|||||||
@ -22,11 +22,17 @@
|
|||||||
(function () {
|
(function () {
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
var $log, wes;
|
// injected refs
|
||||||
|
var $log, wss, wes;
|
||||||
|
|
||||||
|
// internal state
|
||||||
|
var wsock;
|
||||||
|
|
||||||
var evHandler = {
|
var evHandler = {
|
||||||
showSummary: showSummary,
|
showSummary: showSummary,
|
||||||
addInstance: addInstance
|
addInstance: addInstance
|
||||||
|
// TODO: implement remaining handlers..
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
function unknownEvent(ev) {
|
function unknownEvent(ev) {
|
||||||
@ -43,16 +49,9 @@
|
|||||||
$log.log(' *** We got an ADD INSTANCE event: ', ev);
|
$log.log(' *** We got an ADD INSTANCE event: ', ev);
|
||||||
}
|
}
|
||||||
|
|
||||||
angular.module('ovTopo')
|
// ==========================
|
||||||
.factory('TopoEventService', ['$log', 'WsEventService',
|
|
||||||
function (_$log_, _wes_) {
|
|
||||||
$log = _$log_;
|
|
||||||
wes = _wes_;
|
|
||||||
|
|
||||||
var wsock;
|
var dispatcher = {
|
||||||
|
|
||||||
return {
|
|
||||||
dispatcher: {
|
|
||||||
handleEvent: function (ev) {
|
handleEvent: function (ev) {
|
||||||
(evHandler[ev.event] || unknownEvent)(ev);
|
(evHandler[ev.event] || unknownEvent)(ev);
|
||||||
},
|
},
|
||||||
@ -60,14 +59,71 @@
|
|||||||
if (wsock) {
|
if (wsock) {
|
||||||
wes.sendEvent(wsock, evType, payload);
|
wes.sendEvent(wsock, evType, payload);
|
||||||
} else {
|
} else {
|
||||||
$log.warn('sendEvent: no websocket open:',
|
$log.warn('sendEvent: no websocket open:', evType, payload);
|
||||||
evType, payload);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
};
|
||||||
bindSock: function (ws) {
|
|
||||||
wsock = ws;
|
// === Web Socket functions ===
|
||||||
|
|
||||||
|
function onWsOpen() {
|
||||||
|
$log.debug('web socket opened...');
|
||||||
|
// kick off request for periodic summary data...
|
||||||
|
dispatcher.sendEvent('requestSummary');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function onWsMessage(ev) {
|
||||||
|
dispatcher.handleEvent(ev);
|
||||||
|
}
|
||||||
|
|
||||||
|
function onWsClose(reason) {
|
||||||
|
$log.log('web socket closed; reason=', reason);
|
||||||
|
wsock = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ==========================
|
||||||
|
|
||||||
|
angular.module('ovTopo')
|
||||||
|
.factory('TopoEventService',
|
||||||
|
['$log', '$location', 'WebSocketService', 'WsEventService',
|
||||||
|
|
||||||
|
function (_$log_, $loc, _wss_, _wes_) {
|
||||||
|
$log = _$log_;
|
||||||
|
wss = _wss_;
|
||||||
|
wes = _wes_;
|
||||||
|
|
||||||
|
function bindDispatcher(TopoDomElementsPassedHere) {
|
||||||
|
// TODO: store refs to topo DOM elements...
|
||||||
|
|
||||||
|
return dispatcher;
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: handle "guiSuccessor" functionality (replace host)
|
||||||
|
// TODO: implement retry on close functionality
|
||||||
|
function openSock() {
|
||||||
|
wsock = wss.createWebSocket('topology', {
|
||||||
|
onOpen: onWsOpen,
|
||||||
|
onMessage: onWsMessage,
|
||||||
|
onClose: onWsClose,
|
||||||
|
wsport: $loc.search().wsport
|
||||||
|
});
|
||||||
|
$log.debug('web socket opened:', wsock);
|
||||||
|
}
|
||||||
|
|
||||||
|
function closeSock() {
|
||||||
|
var path;
|
||||||
|
if (wsock) {
|
||||||
|
path = wsock.meta.path;
|
||||||
|
wsock.close();
|
||||||
|
wsock = null;
|
||||||
|
$log.debug('web socket closed. path:', path);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
bindDispatcher: bindDispatcher,
|
||||||
|
openSock: openSock,
|
||||||
|
closeSock: closeSock
|
||||||
}
|
}
|
||||||
}]);
|
}]);
|
||||||
}());
|
}());
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user