diff --git a/public/css/base.css b/public/css/base.css
index 7bc7e08..1c4f524 100644
--- a/public/css/base.css
+++ b/public/css/base.css
@@ -119,8 +119,9 @@
color:#ffffff;
font-family:arial;
font-size:12px;
- padding: 3px 20px;
+ padding: 5px 20px;
text-decoration:none;
+ width: 120px
}
.btn_find:hover {
background: rgba(50,54,162,1);
@@ -131,6 +132,19 @@
background: -ms-linear-gradient(top, rgba(50,54,162,1) 0%, rgba(141,146,251,1) 100%);
background: linear-gradient(to bottom, rgba(50,54,162,1) 0%, rgba(141,146,251,1) 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#3236a2', endColorstr='#8d92fb', GradientType=0 );
+ cursor: pointer;
+}
+.btn_find[disabled] {
+ background: rgba(50,54,162,1);
+ background: -moz-linear-gradient(top, rgba(50,54,162,1) 0%, rgba(141,146,251,1) 100%);
+ background: -webkit-gradient(left top, left bottom, color-stop(0%, rgba(50,54,162,1)), color-stop(100%, rgba(141,146,251,1)));
+ background: -webkit-linear-gradient(top, rgba(50,54,162,1) 0%, rgba(141,146,251,1) 100%);
+ background: -o-linear-gradient(top, rgba(50,54,162,1) 0%, rgba(141,146,251,1) 100%);
+ background: -ms-linear-gradient(top, rgba(50,54,162,1) 0%, rgba(141,146,251,1) 100%);
+ background: linear-gradient(to bottom, rgba(50,54,162,1) 0%, rgba(141,146,251,1) 100%);
+ filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#3236a2', endColorstr='#8d92fb', GradientType=0 );
+ opacity: 0.5;
+ cursor: default;
}
.btn_find_inactive {
diff --git a/public/css/style.css b/public/css/style.css
index db585d1..9fcd150 100644
--- a/public/css/style.css
+++ b/public/css/style.css
@@ -8,7 +8,7 @@ body {
#header {
height: 60px;
- min-width: 1150px;
+ min-width: 1200px;
background-color: rgb(248, 248, 248);
background-image: url("../img/hw_000469.jpg");
border-bottom: 1px solid rgb(255, 255, 255);
@@ -30,7 +30,7 @@ body {
#menu {
height: 46px;
- min-width: 1150px;
+ min-width: 1200px;
overflow: hidden;
width: auto !important;
margin: 0px auto;
@@ -106,7 +106,7 @@ h2 {
}
#content {
- min-width: 1150px;
+ min-width: 1200px;
min-height: 200px;
overflow-x: hidden;
position: relative;
diff --git a/public/img/blue_refresh_16px.png b/public/img/blue_refresh_16px.png
new file mode 100644
index 0000000..fe97c4a
Binary files /dev/null and b/public/img/blue_refresh_16px.png differ
diff --git a/public/img/green_check_16px.png b/public/img/green_check_16px.png
index e09bb4e..6bd8724 100644
Binary files a/public/img/green_check_16px.png and b/public/img/green_check_16px.png differ
diff --git a/public/img/red_cross_16px.png b/public/img/red_cross_16px.png
new file mode 100644
index 0000000..03e3170
Binary files /dev/null and b/public/img/red_cross_16px.png differ
diff --git a/public/img/refresh.png b/public/img/refresh.png
new file mode 100644
index 0000000..99fba11
Binary files /dev/null and b/public/img/refresh.png differ
diff --git a/public/img/waiting_16px.gif b/public/img/waiting_16px.gif
new file mode 100644
index 0000000..85b99d4
Binary files /dev/null and b/public/img/waiting_16px.gif differ
diff --git a/public/ods/config.js b/public/ods/config.js
index 890c9d6..3a25ad9 100644
--- a/public/ods/config.js
+++ b/public/ods/config.js
@@ -1,149 +1,153 @@
config = {
- "switches": [
- {
- "switch": {
- "ip": "172.29.8.40",
- "credential": {
- "version": "v2c",
- "community": "public"
- }
- }
- },
- {
- "switch": {
- "ip": "172.29.8.41",
- "credential": {
- "version": "v2c",
- "community": "public"
- }
- }
- }
- ],
- "security": {
- "server_credentials": {
- "username": "root",
- "password": "root"
- },
- "service_credentials": {
- "username": "service",
- "password": "admin"
- },
- "console_credentials": {
- "username": "console",
- "password": "admin"
- }
- },
- "networking": {
- "interfaces": {
- "management": {
- "ip_start": "10.10.10.100",
- "ip_end": "10.10.10.255",
- "netmask": "255.255.255.0",
- "gateway": "10.10.10.1",
- "nic": "eth0",
- "promisc": 0
- },
- "tenant": {
- "ip_start": "192.168.100.100",
- "ip_end": "192.168.100.200",
- "netmask": "255.255.255.0",
- "gateway": "192.168.100.1",
- "nic": "eth0",
- "promisc": 0
- },
- "public": {
- "ip_start": "172.29.3.100",
- "ip_end": "172.29.3.200",
- "netmask": "255.255.255.0",
- "gateway": "172.29.3.1",
- "nic": "eth1",
- "promisc": 1
- },
- "storage": {
- "ip_start": "172.16.128.10",
- "ip_end": "172.16.128.200",
- "netmask": "255.255.255.0",
- "gateway": "172.16.128.1",
- "nic": "eth0",
- "promisc": 0
- }
- },
- "global": {
- "nameservers": "4.4.4.4,8.8.8.8",
- "search_path": "ods.com",
- "gateway": "172.19.100.1",
- "proxy": "",
- "ntp_server": ""
- }
- }
+ "switches": [{
+ "switch": {
+ "ip": "172.29.8.40",
+ "credential": {
+ "version": "v2c",
+ "community": "public"
+ }
+ }
+ }, {
+ "switch": {
+ "ip": "172.29.8.41",
+ "credential": {
+ "version": "v2c",
+ "community": "public"
+ }
+ }
+ }, {
+ "switch": {
+ "ip": "172.29.8.42",
+ "credential": {
+ "version": "v2c",
+ "community": "public"
+ }
+ }
+ }],
+ "security": {
+ "server_credentials": {
+ "username": "root",
+ "password": "root"
+ },
+ "service_credentials": {
+ "username": "service",
+ "password": "admin"
+ },
+ "console_credentials": {
+ "username": "console",
+ "password": "admin"
+ }
+ },
+ "networking": {
+ "interfaces": {
+ "management": {
+ "ip_start": "10.10.10.100",
+ "ip_end": "10.10.10.255",
+ "netmask": "255.255.255.0",
+ "gateway": "10.10.10.1",
+ "nic": "eth0",
+ "promisc": 0
+ },
+ "tenant": {
+ "ip_start": "192.168.100.100",
+ "ip_end": "192.168.100.200",
+ "netmask": "255.255.255.0",
+ "gateway": "192.168.100.1",
+ "nic": "eth0",
+ "promisc": 0
+ },
+ "public": {
+ "ip_start": "172.29.3.100",
+ "ip_end": "172.29.3.200",
+ "netmask": "255.255.255.0",
+ "gateway": "172.29.3.1",
+ "nic": "eth1",
+ "promisc": 1
+ },
+ "storage": {
+ "ip_start": "172.16.128.10",
+ "ip_end": "172.16.128.200",
+ "netmask": "255.255.255.0",
+ "gateway": "172.16.128.1",
+ "nic": "eth0",
+ "promisc": 0
+ }
+ },
+ "global": {
+ "nameservers": "4.4.4.4,8.8.8.8",
+ "search_path": "ods.com",
+ "gateway": "172.19.100.1",
+ "proxy": "",
+ "ntp_server": ""
+ }
+ }
};
config_demo = {
- "switches": [
- {
- "switch": {
- "ip": "127.0.0.1",
- "credential": {
- "version": "v2c",
- "community": "public"
- }
- }
- } ],
+ "switches": [{
+ "switch": {
+ "ip": "127.0.0.1",
+ "credential": {
+ "version": "v2c",
+ "community": "public"
+ }
+ }
+ }],
"security": {
- "server_credentials": {
- "username": "root",
- "password": "huawei123"
- },
- "service_credentials": {
- "username": "service",
- "password": "huawei123"
- },
- "console_credentials": {
- "username": "console",
- "password": "huawei123"
- }
+ "server_credentials": {
+ "username": "root",
+ "password": "huawei123"
+ },
+ "service_credentials": {
+ "username": "service",
+ "password": "huawei123"
+ },
+ "console_credentials": {
+ "username": "console",
+ "password": "huawei123"
+ }
},
"networking": {
- "interfaces": {
- "management": {
- "ip_start": "33.33.33.100",
- "ip_end": "33.33.33.255",
- "netmask": "255.255.255.0",
- "gateway": "33.33.33.10",
- "nic": "eth0",
- "promisc": 0
- },
- "tenant": {
- "ip_start": "192.168.100.100",
- "ip_end": "192.168.100.200",
- "netmask": "255.255.255.0",
- "gateway": "192.168.100.1",
- "nic": "eth0",
- "promisc": 0
- },
- "public": {
- "ip_start": "172.29.3.100",
- "ip_end": "172.29.3.200",
- "netmask": "255.255.255.0",
- "gateway": "172.29.3.1",
- "nic": "eth1",
- "promisc": 1
- },
- "storage": {
- "ip_start": "172.16.128.10",
- "ip_end": "172.16.128.200",
- "netmask": "255.255.255.0",
- "gateway": "172.16.128.1",
- "nic": "eth0",
- "promisc": 0
- }
- },
- "global": {
- "nameservers": "33.33.33.10",
- "search_path": "ods.com",
- "gateway": "33.33.33.10",
- "proxy": "http://33.33.33.10:3128",
- "ntp_server": "33.33.33.10"
- }
+ "interfaces": {
+ "management": {
+ "ip_start": "33.33.33.100",
+ "ip_end": "33.33.33.255",
+ "netmask": "255.255.255.0",
+ "gateway": "33.33.33.10",
+ "nic": "eth0",
+ "promisc": 0
+ },
+ "tenant": {
+ "ip_start": "192.168.100.100",
+ "ip_end": "192.168.100.200",
+ "netmask": "255.255.255.0",
+ "gateway": "192.168.100.1",
+ "nic": "eth0",
+ "promisc": 0
+ },
+ "public": {
+ "ip_start": "172.29.3.100",
+ "ip_end": "172.29.3.200",
+ "netmask": "255.255.255.0",
+ "gateway": "172.29.3.1",
+ "nic": "eth1",
+ "promisc": 1
+ },
+ "storage": {
+ "ip_start": "172.16.128.10",
+ "ip_end": "172.16.128.200",
+ "netmask": "255.255.255.0",
+ "gateway": "172.16.128.1",
+ "nic": "eth0",
+ "promisc": 0
+ }
+ },
+ "global": {
+ "nameservers": "33.33.33.10",
+ "search_path": "ods.com",
+ "gateway": "33.33.33.10",
+ "proxy": "http://33.33.33.10:3128",
+ "ntp_server": "33.33.33.10"
+ }
}
};
\ No newline at end of file
diff --git a/public/ods/fixtures/fixtures.js b/public/ods/fixtures/fixtures.js
index 5194d70..ca8021a 100644
--- a/public/ods/fixtures/fixtures.js
+++ b/public/ods/fixtures/fixtures.js
@@ -15,17 +15,18 @@ steal("jquery/dom/fixture", "jquery/lang/json", function(){
var manage_ip = JSON.parse(original.data).switch.ip;
var switchId = 1;
- if(manage_ip == "172.29.8.40") {
+ if (manage_ip == "172.29.8.40") {
switchId = 1;
- }
- else if(manage_ip == "172.29.8.41"){
+ } else if (manage_ip == "172.29.8.41") {
switchId = 2;
+ } else if (manage_ip == "172.29.8.42") {
+ switchId = 3;
}
var returnData = {
"status": "accepted",
"switch": {
- "state": "not_reached",
+ "state": "initialized",
"link": {
"href": "/switches/"+switchId+"/",
"rel": "self"
@@ -41,12 +42,15 @@ steal("jquery/dom/fixture", "jquery/lang/json", function(){
};
//var xhr = {responseText: JSON.stringify(duplicateErr), status: 409};
- if(switchId == 1) {
- return [202, "accepted", returnData, {} ];
+ if (switchId == 1) {
+ return [202, "accepted", returnData, {}];
//return [202, returnData ];
- }
- else if(switchId == 2) {
+ } else if (switchId == 2) {
return [409, duplicateErr];
+ //return [202, "accepted", returnData, {} ];
+ } else if (switchId == 3) {
+ //return [409, duplicateErr];
+ return [202, "accepted", returnData, {} ];
}
});
@@ -57,7 +61,7 @@ steal("jquery/dom/fixture", "jquery/lang/json", function(){
var returnData = {
"status": "accepted",
"switch": {
- "state": "not_reached",
+ "state": "repulling",
"link": {
"href": "/switches/"+switchId+"/",
"rel": "self"
@@ -76,7 +80,8 @@ steal("jquery/dom/fixture", "jquery/lang/json", function(){
var returnData = {
"status": "OK",
"switch": {
- "state": switchId == 10 ? "not_reached" : "under_monitoring",
+ "state": switchId == 10 ? "initialized" : "under_monitoring",
+ "err-msg": "error message",
"link": {
"href": settings.url,
"rel": "self"
@@ -183,6 +188,36 @@ steal("jquery/dom/fixture", "jquery/lang/json", function(){
};
return returnData;
}
+ else if(switchId == 3) {
+ var returnData = {
+ "status": "OK",
+ "machines": [
+ {
+ "mac": "28:e5:ee:23:14:92",
+ "vlan": 3,
+ "link": {
+ "href": "/api/machines/80",
+ "rel": "self"
+ },
+ "id": 80,
+ "port": 1,
+ "switch_ip": "172.29.8.42"
+ },
+ {
+ "mac": "28:22:77:c2:46:4a",
+ "vlan": 3,
+ "link": {
+ "href": "/api/machines/90",
+ "rel": "self"
+ },
+ "id": 90,
+ "port": 2,
+ "switch_ip": "172.29.8.42"
+ }
+ ]
+ };
+ return returnData;
+ }
});
diff --git a/public/ods/ods.js b/public/ods/ods.js
index 5eaf17b..7ba6f7c 100644
--- a/public/ods/ods.js
+++ b/public/ods/ods.js
@@ -18,7 +18,7 @@ steal(
feature: null,
machines: [],
switches: [],
- snmp: 1,
+ snmp: true,
adapter_id: null
};
diff --git a/public/ods/ui/host_config/host_config.js b/public/ods/ui/host_config/host_config.js
index 1b8b903..45e9d5d 100644
--- a/public/ods/ui/host_config/host_config.js
+++ b/public/ods/ui/host_config/host_config.js
@@ -48,7 +48,7 @@ steal(
}
});
- $(document).tooltip({
+ $(".pattern-tip").tooltip({
items: "[data-geo], [title]",
content: function() {
var element = $(this);
diff --git a/public/ods/ui/host_config/views/init.ejs b/public/ods/ui/host_config/views/init.ejs
index d108977..f478532 100644
--- a/public/ods/ui/host_config/views/init.ejs
+++ b/public/ods/ui/host_config/views/init.ejs
@@ -17,7 +17,7 @@
-
+
diff --git a/public/ods/ui/install_review/install_review.js b/public/ods/ui/install_review/install_review.js
index d98beb9..24542fb 100644
--- a/public/ods/ui/install_review/install_review.js
+++ b/public/ods/ui/install_review/install_review.js
@@ -129,18 +129,14 @@ steal(
$("#continuing").css("opacity", 1);
var cluster_id = this.options.odsState.cluster_id;
- Ods.Cluster.action(
- cluster_id, {
- "deploy": ""
- },
- this.proxy('onTriggerDeploy'),
- this.proxy('onTriggerDeployErr'));
+ Ods.Cluster.action(cluster_id, {"deploy": []},
+ this.proxy('onTriggerDeploy'),
+ this.proxy('onTriggerDeployErr'));
},
onTriggerDeploy: function(data, textStatus, xhr) {
steal.dev.log(" *** onTriggerDeploy data *** ", data);
- steal.dev.log(" *** onTriggerDeploy textStatus *** ",
- textStatus);
+ steal.dev.log(" *** onTriggerDeploy textStatus *** ", textStatus);
steal.dev.log(" *** onTriggerDeploy xhr *** ", xhr);
if (xhr.status == 202) { // accepted
@@ -155,8 +151,7 @@ steal(
onTriggerDeployErr: function(xhr, status, statusText) {
steal.dev.log(" *** onTriggerDeployErr xhr *** ", xhr);
steal.dev.log(" *** onTriggerDeployErr status *** ", status);
- steal.dev.log(" *** onTriggerDeployErr statusText *** ",
- statusText);
+ steal.dev.log(" *** onTriggerDeployErr statusText *** ", statusText);
},
initProgressbars: function() {
@@ -186,8 +181,7 @@ steal(
switchjson.children.push(serverjson);
// initiate list based progress bars
- this.initListProgressbar(servers[i].clusterhost_id,
- servers[i].hostname);
+ this.initListProgressbar(servers[i].clusterhost_id, servers[i].hostname);
}
this.serverTreeJson.children.push(switchjson);
}
@@ -202,10 +196,8 @@ steal(
this.totalProgressbar.progressbar({
value: false
});
- this.totalProgressLabel = this.totalProgressbar.children(
- ".progress-label");
- this.totalProgressbarValue = this.totalProgressbar.find(
- ".ui-progressbar-value");
+ this.totalProgressLabel = this.totalProgressbar.children(".progress-label");
+ this.totalProgressbarValue = this.totalProgressbar.find(".ui-progressbar-value");
},
initListProgressbar: function(hostid, hostname) {
@@ -214,8 +206,7 @@ steal(
"hostid": hostid,
"message": "Waiting..."
}
- $("#tabs-2 table tbody").append(this.view('progress_row',
- initPData));
+ $("#tabs-2 table tbody").append(this.view('progress_row', initPData));
var pbar = $('div[data-hostid="' + hostid + '"]');
pbar.progressbar({
@@ -247,10 +238,7 @@ steal(
this.pendingHostList = [];
for (var i = 0; i < count; i++) {
- Ods.ClusterHost.progress(
- hosts[i],
- this.proxy('updateProgressBar'),
- this.proxy('updateProgressBarErr'));
+ Ods.ClusterHost.progress(hosts[i], this.proxy('updateProgressBar'), this.proxy('updateProgressBarErr'));
}
},
@@ -263,12 +251,12 @@ steal(
steal.dev.log(" *** onUpdateProgressBar textStatus *** ", textStatus);
steal.dev.log(" *** onUpdateProgressBar xhr *** ", xhr);
- this.pendingHostCount --;
+ this.pendingHostCount--;
var progressData = data.progress;
- if(progressData.percentage < 1) {
+ if (progressData.percentage < 1) {
this.pendingHostList.push(progressData.id);
}
@@ -289,8 +277,7 @@ steal(
updateProgressBarErr: function(xhr, status, statusText) {
steal.dev.log(" *** updateProgressBarErr xhr *** ", xhr);
steal.dev.log(" *** updateProgressBarErr status *** ", status);
- steal.dev.log(" *** updateProgressBarErr statusText *** ",
- xhr);
+ steal.dev.log(" *** updateProgressBarErr statusText *** ", xhr);
//TODO
},
@@ -311,16 +298,13 @@ steal(
}
// update graph-based progress bar
- if ($('rect[data-hostid="' + progressData.id + '"]')) {
- // check if the node is expanded
+ if ($('rect[data-hostid="' + progressData.id + '"]')) { // check if the node is expanded
if (progressData.percentage > 1.0) {
progressData.percentage = 1.0;
}
- $('rect[data-hostid="' + progressData.id + '"]')
- .attr("width", imgWidth * progressData.percentage);
+ $('rect[data-hostid="' + progressData.id + '"]').attr("width", imgWidth * progressData.percentage);
- $('text[data-hostid="' + progressData.id + '"]')
- .text(progressData.message);
+ $('text[data-hostid="' + progressData.id + '"]').text(progressData.message);
}
},
@@ -360,17 +344,14 @@ steal(
"background": "#5BB75B"
});
} else {
- pbar.progressbar(
- "value", progressData.percentage * 100)
+ pbar.progressbar("value", progressData.percentage * 100)
}
}
},
updateTotalBar: function(data) {
- if(this.pendingHostCount == 0) {
- Ods.Cluster.progress(this.options.odsState.cluster_id,
- this.proxy('onTotalProgressData'),
- this.proxy('onTotalProgressDataErr'));
+ if (this.pendingHostCount == 0) {
+ Ods.Cluster.progress(this.options.odsState.cluster_id, this.proxy('onTotalProgressData'), this.proxy('onTotalProgressDataErr'));
}
},
@@ -379,8 +360,7 @@ steal(
/********************************************/
onTotalProgressData: function(data, textStatus, xhr) {
steal.dev.log(" *** onTotalProgressData data *** ", data);
- steal.dev.log(" *** onTotalProgressData textStatus *** ",
- textStatus);
+ steal.dev.log(" *** onTotalProgressData textStatus *** ", textStatus);
steal.dev.log(" *** onTotalProgressData xhr *** ", xhr);
var total = data.progress.percentage;
@@ -397,9 +377,7 @@ steal(
setTimeout(this.proxy('getProgressData'), 3000);
} else {
this.totalProgressbar.progressbar("value", 100);
- Ods.DashboardLink.findOne(
- this.options.odsState.cluster_id,
- this.proxy('onFindDashboardLink'));
+ Ods.DashboardLink.findOne(this.options.odsState.cluster_id, this.proxy('onFindDashboardLink'));
}
},
@@ -408,23 +386,18 @@ steal(
/********************************************/
onTotalProgressDataErr: function(xhr, status, statusText) {
steal.dev.log(" *** onTotalProgressDataErr xhr *** ", xhr);
- steal.dev.log(" *** onTotalProgressDataErr status *** ",
- status);
- steal.dev.log(" *** onTotalProgressDataErr statusText *** ",
- xhr);
+ steal.dev.log(" *** onTotalProgressDataErr status *** ", status);
+ steal.dev.log(" *** onTotalProgressDataErr statusText *** ", xhr);
//TODO
},
onFindDashboardLink: function(data, textStatus, xhr) {
steal.dev.log(" *** onFindDashboardLink data *** ", data);
- steal.dev.log(" *** onFindDashboardLink textStatus *** ",
- textStatus);
+ steal.dev.log(" *** onFindDashboardLink textStatus *** ", textStatus);
steal.dev.log(" *** onFindDashboardLink xhr *** ", xhr);
if (data.status == "OK") {
- $(".dashboard-link").attr(
- "href",
- data.dashboardlinks["os-single-controller"]);
+ $(".dashboard-link").attr("href", data.dashboardlinks["os-single-controller"]);
$(".dashboard-link").attr("target", "_blank");
$(".dashboard-link").removeClass("disabled");
}
@@ -432,7 +405,7 @@ steal(
'.ui-tabs-nav click': function(el, ev) {
if ($("#tabs-2").is(":visible")) {
- var children = this.serverTreeJson.children;
+ var children = this.serverTreeJson.children;
for (var sw in children) {
var servers = children[sw]._children;
if (servers == null) {
@@ -486,8 +459,7 @@ steal(
.attr("width", width + margin.right + margin.left)
.attr("height", height + margin.top + margin.bottom)
.append("g")
- .attr("transform",
- "translate(" + margin.left + "," + margin.top + ")");
+ .attr("transform", "translate(" + margin.left + "," + margin.top + ")");
root = this.serverTreeJson;
root.x0 = height / 2;
diff --git a/public/ods/ui/networking/networking.js b/public/ods/ui/networking/networking.js
index c92c36a..a57dac9 100644
--- a/public/ods/ui/networking/networking.js
+++ b/public/ods/ui/networking/networking.js
@@ -165,7 +165,7 @@ steal(
server['roles'] = [];
}
- server['server_ip'] = this.startPrefix + (parseInt(this.startLastDigit) + i);
+ //server['server_ip'] = this.startPrefix + (parseInt(this.startLastDigit) + i);
var switchIp = server.switch_ip;
if (this.serverData[switchIp] == undefined) {
@@ -176,6 +176,16 @@ steal(
}
this.options.odsState.servers_config = this.serverData;
+ var j = 0;
+ var serverData = this.options.odsState.servers_config;
+ for (var key in serverData) {
+ var servers = serverData[key];
+ for (var i = 0; i < servers.length; i++) {
+ serverData[key][i]['server_ip'] = this.startPrefix + (parseInt(this.startLastDigit) + j);
+ j++;
+ }
+ }
+
var networkingData = {
"networking": {
"interfaces": {
diff --git a/public/ods/ui/networking/views/init.ejs b/public/ods/ui/networking/views/init.ejs
index 7166b93..18b31cd 100644
--- a/public/ods/ui/networking/views/init.ejs
+++ b/public/ods/ui/networking/views/init.ejs
@@ -26,12 +26,12 @@
-
+
(This selection should be consistent with your networking plan.)
Promisc Mode |
- The interface running in promisc mode will receive all packages in network. |
+ (The interface running in promisc mode will receive and pass all the trafic.) |
@@ -65,7 +65,7 @@
Promisc Mode |
- The interface running in promisc mode will receive all packages in network. |
+ (The interface running in promisc mode will receive and pass all the trafic.) |
@@ -105,7 +105,7 @@
Promisc Mode |
- The interface running in promisc mode will receive all packages in network. |
+ (The interface running in promisc mode will receive and pass all the trafic.) |
@@ -141,7 +141,7 @@
Promisc Mode |
- The interface running in promisc mode will receive all packages in network. |
+ (The interface running in promisc mode will receive and pass all the trafic.) |
@@ -150,23 +150,23 @@
diff --git a/public/ods/ui/servers/servers.css b/public/ods/ui/servers/servers.css
index 84ec77c..a2e3bf0 100644
--- a/public/ods/ui/servers/servers.css
+++ b/public/ods/ui/servers/servers.css
@@ -85,15 +85,15 @@ table.display thead th {
}
.sorting {
- background: url('../../../img/bg.gif') no-repeat center right;
+ background: url('../../../img/bg.gif') no-repeat 60% 50%;
}
.sorting_desc {
- background: url('../../../img/desc.gif') no-repeat center right;
+ background: url('../../../img/desc.gif') no-repeat 60% 50%;
}
.sorting_asc {
- background: url('../../../img/asc.gif') no-repeat center right;
+ background: url('../../../img/asc.gif') no-repeat 60% 50%;
}
.highlight {
diff --git a/public/ods/ui/servers/servers.js b/public/ods/ui/servers/servers.js
index dbdca72..938e765 100644
--- a/public/ods/ui/servers/servers.js
+++ b/public/ods/ui/servers/servers.js
@@ -7,20 +7,20 @@ steal(
'./servers.css',
'./views/init.ejs',
'lib/jquery.dataTables.js',
- './views/switch_row.ejs',
+ //'lib/jquery.dataTables.dataSourcePlugins.js',
'ods/models/servers.js',
- 'ods/models/cluster.js'
+ 'ods/models/cluster.js',
+ 'ods/ui/switch_entry'
).then(function($) {
$.Controller('Ods.Ui.servers', {}, {
init: function() {
this.element.html(this.view('init'));
- this.pendingSwitchList = [];
-
// we query up to 10 times. Report an error if any of the switches
// remains in not_reached status.
this.queryCount = 0;
+ this.displayNodes = [];
this.initServerTable();
this.checked_num = 0;
@@ -50,10 +50,8 @@ steal(
var oldSwitchesData = this.options.odsState.switches;
-
+ var tbody = $(".switchtable tbody");
if (oldSwitchesData.length > 0) {
- var tbody = $(".switchtable tbody");
-
if (this.options.odsState.snmp) {
$('#useSNMP').prop('checked', true);
} else {
@@ -61,39 +59,31 @@ steal(
}
for (var i = 0; i < oldSwitchesData.length; i++) {
- if (i > 0) {
- tbody.append(this.view('switch_row'));
- }
- if (this.options.odsState.snmp) {
- $("#snmpTitle").html("SNMP Version");
- $("#communityTitle").html("Community");
- $(".switch_row").find(".snmp").show();
- $(".switch_row").find(".community").show();
- $(".switch_row").find(".username").hide();
- $(".switch_row").find(".password").hide();
- } else {
- $("#snmpTitle").html("Username");
- $("#communityTitle").html("Password");
- $(".switch_row").find(".snmp").hide();
- $(".switch_row").find(".community").hide();
- $(".switch_row").find(".username").show();
- $(".switch_row").find(".password").show();
- }
-
- if (this.options.odsState.snmp) {
- $(".switch_row").eq(i).find(".switchIp").val(oldSwitchesData[i].switch.ip);
- $(".switch_row").eq(i).find(".snmp").val(oldSwitchesData[i].switch.credential.version);
- $(".switch_row").eq(i).find(".community").val(oldSwitchesData[i].switch.credential.community);
- } else {
- $(".switch_row").eq(i).find(".switchIp").val(oldSwitchesData[i].switch.ip);
- $(".switch_row").eq(i).find(".username").val(oldSwitchesData[i].switch.credential.username);
- $(".switch_row").eq(i).find(".password").val(oldSwitchesData[i].switch.credential.password);
- }
+ tbody.append("
");
+ var tr = tbody.find("tr:last");
+ tr.ods_ui_switch_entry({
+ "odsState": this.options.odsState,
+ "switchData": oldSwitchesData[i].switch,
+ "first": i == 0,
+ "serverControl": this
+ });
}
+ } else {
+ tbody.append("
");
+ var tr = tbody.find("tr:last");
+ tr.ods_ui_switch_entry({
+ "odsState": this.options.odsState,
+ "switchData": null,
+ "first": true,
+ "serverControl": this
+ });
}
+
},
initServerTable: function() {
+ var currNode = [];
+ var self = this;
this.dataTable = $('#tb_server_select').dataTable({
"sScrollY": "200px",
"bPaginate": false,
@@ -117,12 +107,24 @@ steal(
aTargets: [0, 1, 3]
}, {
bSearchable: false,
- aTargets: [ 0 ]
+ aTargets: [0]
}],
"aaSorting": [
[2, "asc"],
[4, "asc"]
- ]
+ ],
+ "fnPreDrawCallback": function(oSettings) {
+ /* reset currNode before each draw*/
+ currNode = [];
+ },
+ "fnRowCallback": function(nRow, aData, iDisplayIndex, iDisplayIndexFull) {
+ /* push this row of data to currNode array*/
+ currNode.push(nRow);
+ },
+ "fnDrawCallback": function(oSettings) {
+ /* can now access sorted node array*/
+ self.displayNodes = currNode;
+ }
});
$('.dataTables_info').remove();
@@ -130,21 +132,30 @@ steal(
$('.dataTables_filter input').addClass('rounded');
},
+ removeServersBySwitch: function(switchIp) {
+ var servers = this.dataTable.fnGetData();
+ var serversCount = servers.length;
+ var i = 0;
+ while (i < serversCount) {
+ if (servers[i].switch_ip == switchIp) {
+ this.dataTable.fnDeleteRow(i);
+ servers = this.dataTable.fnGetData();
+ serversCount = servers.length;
+ } else {
+ i++;
+ }
+ }
+ },
+
'input[name="snmp"] click': function(el, ev) {
+ this.options.odsState.attr("snmp", el.val() == "snmp");
+
if (el.val() == "snmp") {
$("#snmpTitle").html("SNMP Version");
$("#communityTitle").html("Community");
- $(".snmp").show();
- $(".community").show();
- $(".username").hide();
- $(".password").hide();
} else {
$("#snmpTitle").html("Username");
$("#communityTitle").html("Password");
- $(".snmp").hide();
- $(".community").hide();
- $(".username").show();
- $(".password").show();
}
},
@@ -203,22 +214,23 @@ steal(
},
'getSelectedServers': function() {
- selectedServers = [];
+ console.log("displayNodes ", this.displayNodes);
+ var selectedServers = [];
this.options.odsState.servers = [];
this.options.odsState.servers_config = [];
// loop through dataTable nodes to find selected servers
- for (var i = 0; i < this.dataTable.fnGetNodes().length; i++) {
- var ckboxTd = $('td', this.dataTable.fnGetNodes()[i])[0];
+ for (var i = 0; i < this.displayNodes.length; i++) {
+ var ckboxTd = $('td', this.displayNodes[i])[0];
var server_ckbox = $('input', ckboxTd)[0];
if (server_ckbox.checked == true) {
- var checkTd = $('td', this.dataTable.fnGetNodes()[i])[1];
- var macTd = $('td', this.dataTable.fnGetNodes()[i])[1];
- var switchIpTd = $('td', this.dataTable.fnGetNodes()[i])[2];
- var vlanTd = $('td', this.dataTable.fnGetNodes()[i])[3];
- var portTd = $('td', this.dataTable.fnGetNodes()[i])[4];
+ var checkTd = $('td', this.displayNodes[i])[1];
+ var macTd = $('td', this.displayNodes[i])[1];
+ var switchIpTd = $('td', this.displayNodes[i])[2];
+ var vlanTd = $('td', this.displayNodes[i])[3];
+ var portTd = $('td', this.displayNodes[i])[4];
var mac = macTd.textContent || macTd.innerText;
var switch_ip = switchIpTd.textContent || switchIpTd.innerText;
@@ -242,29 +254,25 @@ steal(
'div.add click': function(el, ev) {
var tbody = el.closest('tbody');
- tbody.append(this.view('switch_row'));
- if (!$("#useSNMP:checked").val()) {
- $(".switch_row").last().find(".snmp").hide();
- $(".switch_row").last().find(".community").hide();
- $(".switch_row").last().find(".username").show();
- $(".switch_row").last().find(".password").show();
- }
+ tbody.append("
");
+ var tr = tbody.find("tr:last");
+ tr.ods_ui_switch_entry({
+ "odsState": this.options.odsState,
+ "switchData": null
+ });
},
- 'div.remove click': function(el, ev) {
- var row = el.closest('tr');
- row.remove();
- },
-
- 'a.find_server click': function(el, ev) {
+ '.find_server click': function(el, ev) {
// remove the error class within the el
$('.switchtable').find('.error').removeClass('error');
$(".switchesErr").hide();
+ this.dataTable.fnClearTable();
+
var self = this;
var hasError = false;
- this.pendingSwitchList.length = 0;
+
this.queryCount = 0;
// return if the switch_ip/community or username/password input is empty
@@ -273,6 +281,7 @@ steal(
hasError = true;
}
});
+ // return if the ip format is not correct
$('.switchtable').find('.switchIp').each(function(index, value) {
var isValid = self.validateIpFormat($(value).val());
if (!isValid) {
@@ -287,269 +296,44 @@ steal(
}
$("#finding-servers").css("opacity", 1);
+ $('.find_server').attr("disabled", true);
+ $('.find_server').html("Finding...");
- var switch_count = $(".switch_row").length;
- this.pendingCount = switch_count;
- this.switches = [];
+ $('.switchtable').find('tr.switch_row').each(function(index, value) {
+ $(value).controller().findServers();
+ });
- // loop through switch rows to create new switches
- for (i = 0; i < switch_count; i++) {
- var switch_ip = $(".switch_row").eq(i).find(".switchIp");
- var snmp_version = null,
- community = null;
- var username = null,
- password = null;
- var switchData = {};
- if ($("#useSNMP:checked").val()) {
- this.options.odsState.snmp = 1;
- snmp_version = $(".switch_row").eq(i).find(".snmp");
- community = $(".switch_row").eq(i).find(".community");
- switchData = {
- "switch": {
- "ip": switch_ip.val(),
- "credential": {
- 'version': snmp_version.val(),
- 'community': community.val()
- }
- }
- };
- } else {
- this.options.odsState.snmp = 0;
- username = $(".switch_row").eq(i).find(".username");
- password = $(".switch_row").eq(i).find(".password");
- switchData = {
- "switch": {
- "ip": switch_ip.val(),
- "credential": {
- "username": username.val(),
- "password": password.val()
- }
- }
- };
+ setTimeout(this.proxy('checkSwitchesStatus'), 2000);
+ },
+
+ checkSwitchesStatus: function() {
+ var switchesFinished = true;
+ $('.switchtable').find('tr.switch_row').each(function(index, value) {
+ var status = $(value).controller().getSwitchStatus();
+ if(status.status == 1) {
+ switchesFinished = false;
}
-
- this.switches.push(switchData);
-
- Ods.Switch.create(switchData, this.proxy('onSwitchCreated', i), this.proxy('onSwitchCreateErr', i));
- }
- this.options.odsState.switches = this.switches;
-
- },
-
- 'input.switchIp keyup': function(el, ev) {
- var isValid = this.validateIpFormat(el.val());
- if (!isValid) {
- el.addClass("error");
- } else {
- el.removeClass("error");
- }
- },
-
- validateIpFormat: function(value) {
- var ipformat = /^(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/;
- if (value.match(ipformat)) {
- return true;
- } else {
- return false;
- }
- },
-
- /************************************/
- // switch create success callback
- /************************************/
- onSwitchCreated: function(switchIndex, data, textStatus, xhr) {
- steal.dev.log(" *** onSwitchCreated data *** ", data);
- steal.dev.log(" *** onSwitchCreated textStatus *** ", textStatus);
- steal.dev.log(" *** onSwitchCreated xhr *** ", xhr);
-
- this.pendingCount--;
- if (xhr.status == 202) { // accepted
- var switchId = data.
- switch.id;
- this.pendingSwitchList.push(switchId);
- }
-
- if (this.pendingCount == 0) {
- this.checkSwitchState();
- }
- },
-
- /************************************/
- // switch create error callback
- /************************************/
- onSwitchCreateErr: function(switchIndex, xhr, status, statusText) {
- steal.dev.log(" *** onSwitchCreatErr xhr *** ", xhr);
- steal.dev.log(" *** onSwitchCreatErr status *** ", status);
- steal.dev.log(" *** onSwitchCreatErr statusText *** ", xhr);
-
- $("#finding-servers").css("opacity", 0);
-
- if (xhr.status == 409) { // duplicate
- var failedSwitchId = 0;
- if ($.fixture.on == true) {
- failedSwitchId = statusText.failedSwitch;
- } else {
- failedSwitchId = JSON.parse(xhr.responseText).failedSwitch;
- }
- steal.dev.log(" *** failed Switch Id *** ", failedSwitchId);
- // PUT switches
- Ods.Switch.update(failedSwitchId, this.switches[switchIndex],
- this.proxy('onSwitchUpdated', switchIndex), this.proxy('onSwitchUpdateErr'));
-
- } else if (xhr.status == 400) { //bad request
- $(".switchesErr").html("Switch post error code: 400");
- $(".switchesErr").show();
- } else if (xhr.status == 500) { // internal server error
- $(".switchesErr").html("Switch post error code: 500");
- $(".switchesErr").show();
- }
-
- },
-
- /************************************/
- // switch update success callback
- /************************************/
- onSwitchUpdated: function(switchIndex, data, textStatus, xhr) {
- steal.dev.log(" *** onSwitchUpdated data *** ", data);
- steal.dev.log(" *** onSwitchUpdated textStatus *** ", textStatus);
- steal.dev.log(" *** onSwitchUpdated xhr *** ", xhr);
-
- this.pendingCount--;
-
- if (xhr.status == 202 || xhr.status == 200) { // accepted or OK
- var switchId = data.
- switch.id;
- this.pendingSwitchList.push(switchId);
- }
-
- if (this.pendingCount == 0) {
- this.checkSwitchState();
- }
-
- },
-
- /************************************/
- // switch create error callback
- /************************************/
- onSwitchUpdateErr: function(xhr, status, statusText) {
- steal.dev.log(" *** onSwitchUpdateErr xhr *** ", xhr);
- steal.dev.log(" *** onSwitchUpdateErr status *** ", status);
- steal.dev.log(" *** onSwitchUpdateErr statusText *** ", statusText);
-
- $("#finding-servers").css("opacity", 0);
-
- if (xhr.status == 404) { // not found
- $(".switchesErr").html("Switch update error code: 404");
- $(".switchesErr").show();
- } else if (xhr.status == 400) { // bad request
- $(".switchesErr").html("Switch update error code: 400");
- $(".switchesErr").show();
- } else if (xhr.status == 500) { // internal server error
- $(".switchesErr").html("Switch update error code: 500");
- $(".switchesErr").show();
- }
-
- },
-
- checkSwitchState: function() {
- this.queryCount++;
- this.pendingCount = this.pendingSwitchList.length;
-
- if (this.queryCount > 10) {
- $(".switchesErr").html("There is(are) " + this.pendingCount + " switch(es) not responding now. Please try again later.")
- $(".switchesErr").show();
+ })
+ if (switchesFinished) {
$("#finding-servers").css("opacity", 0);
- return;
- }
-
- var switches = this.pendingSwitchList;
- this.pendingSwitchList = [];
- var count = this.pendingCount;
- for (var i = 0; i < count; i++) {
- Ods.Switch.findOne(switches[i], this.proxy('onFindOneSwitch'), this.proxy('onFindOneSwitchErr'));
+ $('.find_server').attr("disabled", false);
+ $('.find_server').html("Find Servers");
+ } else {
+ setTimeout(this.proxy('checkSwitchesStatus'), 2000);
}
},
- /************************************/
- // find one switch success callback
- /************************************/
- onFindOneSwitch: function(data, textStatus, xhr) {
- steal.dev.log(" *** onFindOneSwitch data *** ", data);
- steal.dev.log(" *** onFindOneSwitch textStatus *** ", textStatus);
- steal.dev.log(" *** onFindOneSwitch xhr *** ", xhr);
- this.pendingCount--;
-
- if (xhr.status == 200) { //OK
- if (data.switch.state === "under_monitoring") {
- this.element.find('div.right-side').show();
- this.dataTable.fnClearTable();
-
- this.getServersBySwitch(data.switch.id);
- } else {
- this.pendingSwitchList.push(data.switch.id);
- }
- }
-
- if (this.pendingCount == 0) {
- setTimeout(this.proxy('checkSwitchState'), 2000);
- }
- },
-
- /************************************/
- // find one switch error callback
- /************************************/
- onFindOneSwitchErr: function(xhr, status, statusText) {
- steal.dev.log(" *** onFindOneSwitchErr xhr *** ", xhr);
- steal.dev.log(" *** onFindOneSwitchErr status *** ", status);
- steal.dev.log(" *** onFindOneSwitchErr statusText *** ", statusText);
-
- $("#finding-servers").css("opacity", 0);
- if (xhr.status == 404) { // not found
- $(".switchesErr").html("Find switch error code: 404");
- $(".switchesErr").show();
- } else if (xhr.status == 500) {
- $(".switchesErr").html("Find switch error code: 500");
- $(".switchesErr").show();
- }
-
- },
-
- getServersBySwitch: function(id) {
- Ods.Server.findAll({
- switchId: id
- }, this.proxy('onFindAllServers'));
- },
-
- /************************************/
- // find all servers success callback
- /************************************/
- onFindAllServers: function(data, textStatus, xhr) {
- steal.dev.log(" *** onFindAllServers data *** ", data);
- steal.dev.log(" *** onFindAllServers textStatus *** ", textStatus);
- steal.dev.log(" *** onFindAllServers xhr *** ", xhr);
-
- this.dataTable.fnAddData(data.machines);
-
- this.machines = this.machines.concat(data.machines);
-
- if (this.pendingCount == 0 && this.pendingSwitchList.length == 0) {
- steal.dev.log("loading finished");
- $("#finding-servers").css("opacity", 0);
+ onNewMachines: function(machines) {
+ this.element.find('div.right-side').show();
+ if (machines.length > 0) {
+ this.dataTable.fnAddData(machines);
+ this.machines = this.machines.concat(machines);
this.options.odsState.machines = this.machines;
}
},
- checkNonEmpty: function(el) {
- var value = el.val();
- if (!value) {
- el.addClass('error');
- return false;
- }
- return true;
- },
-
/************************************/
// add server to cluster success callback
/************************************/
@@ -621,6 +405,33 @@ steal(
this.countCheckedServers();
},
+ 'input.switchIp keyup': function(el, ev) {
+ var isValid = this.validateIpFormat(el.val());
+ if (!isValid) {
+ el.addClass("error");
+ } else {
+ el.removeClass("error");
+ }
+ },
+
+ validateIpFormat: function(value) {
+ var ipformat = /^(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/;
+ if (value.match(ipformat)) {
+ return true;
+ } else {
+ return false;
+ }
+ },
+
+ checkNonEmpty: function(el) {
+ var value = el.val();
+ if (!value) {
+ el.addClass('error');
+ return false;
+ }
+ return true;
+ },
+
show: function() {
this.element.show();
diff --git a/public/ods/ui/servers/views/init.ejs b/public/ods/ui/servers/views/init.ejs
index 9868c87..0872378 100644
--- a/public/ods/ui/servers/views/init.ejs
+++ b/public/ods/ui/servers/views/init.ejs
@@ -19,26 +19,12 @@
-
- |
-
-
-
- |
-
-
-
- |
- |
-
+
- Find Servers
+
diff --git a/public/ods/ui/switch_entry/servers_test.html b/public/ods/ui/switch_entry/servers_test.html
new file mode 100644
index 0000000..22f6e11
--- /dev/null
+++ b/public/ods/ui/switch_entry/servers_test.html
@@ -0,0 +1,55 @@
+
+
+
+
+ servers Widget Unit Test
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/public/ods/ui/switch_entry/switch_entry.css b/public/ods/ui/switch_entry/switch_entry.css
new file mode 100644
index 0000000..76fed09
--- /dev/null
+++ b/public/ods/ui/switch_entry/switch_entry.css
@@ -0,0 +1,51 @@
+.switch-status {
+ width: 16px;
+ height: 16px;
+}
+
+.switch-refresh {
+ width: 16px;
+ height: 16px;
+ margin-left: 5px;
+}
+
+.switch-refresh img {
+ cursor: hand;
+ cursor: pointer;
+}
+
+img.err:hover {
+ cursor: pointer;
+}
+
+.add {
+ width: 16px;
+ height: 16px;
+ background-image: url("../../../img/add_button_16px.png");
+ cursor: hand;
+ cursor: pointer;
+ float: left;
+}
+
+.remove {
+ width: 16px;
+ height: 16px;
+ background-image: url("../../../img/remove_button_16px.png");
+ cursor: hand;
+ cursor: pointer;
+ float: left;
+}
+
+.switch_row input {
+ width: 100px;
+}
+
+.server-result {
+ min-height: 200px;
+}
+
+.server-g-num {
+ padding: 1px 10px;
+ margin-top: 2px;
+}
+
diff --git a/public/ods/ui/switch_entry/switch_entry.js b/public/ods/ui/switch_entry/switch_entry.js
new file mode 100644
index 0000000..16d823b
--- /dev/null
+++ b/public/ods/ui/switch_entry/switch_entry.js
@@ -0,0 +1,327 @@
+steal(
+ 'jquery/controller',
+ 'jquery/view/ejs',
+ 'jquery/controller/view',
+ 'jquery/lang/json'
+).then(
+ './switch_entry.css',
+ './views/init.ejs',
+ './views/switch_row.ejs',
+ 'ods/models/servers.js',
+ 'ods/models/cluster.js',
+ 'lib/jquery-ui-1.10.3.custom.js'
+).then(function($) {
+ $.Controller('Ods.Ui.SwitchEntry', {}, {
+ init: function() {
+ this.element.html(this.view('init', {
+ "first": this.options.first
+ }));
+ this.switchId = 0;
+ this.switchStatus = {
+ "status": 0,
+ "message": ""
+ };
+ this.queryCount = 0;
+ this.displaySnmp(this.options.odsState.snmp);
+ var switchData = this.options.switchData;
+
+ if (switchData) {
+ if (this.options.odsState.snmp) {
+ this.find(".switchIp").val(switchData.ip);
+ this.find(".snmp").val(switchData.credential.version);
+ this.find(".community").val(switchData.credential.community);
+ } else {
+ this.find(".switchIp").val(switchData.ip);
+ this.find(".username").val(switchData.credential.username);
+ this.find(".password").val(switchData.credential.password);
+ }
+ }
+ },
+
+ findServers: function() {
+ this.setSwitchStatus(1, "waiting");
+ var switchData = this.getSwitchData();
+ Ods.Switch.create(switchData, this.proxy('onSwitchCreated'), this.proxy('onSwitchCreateErr'));
+ },
+
+ getSwitchData: function() {
+ var snmp_version = null,
+ community = null;
+ var username = null,
+ password = null;
+ var switchData = {};
+
+ var ip = this.find('.switchIp').val();
+
+ if ($("#useSNMP:checked").val()) {
+ snmp_version = $(".switch_row").eq(i).find(".snmp");
+ community = $(".switch_row").eq(i).find(".community");
+ switchData = {
+ "switch": {
+ "ip": ip,
+ "credential": {
+ 'version': snmp_version.val(),
+ 'community': community.val()
+ }
+ }
+ };
+ } else {
+ username = this.find(".username");
+ password = this.find(".password");
+ switchData = {
+ "switch": {
+ "ip": ip,
+ "credential": {
+ "username": username.val(),
+ "password": password.val()
+ }
+ }
+ };
+ }
+ return switchData;
+ },
+
+ 'div.switch-refresh img click': function(el, ev) {
+ //remove previously found servers in the data table
+ var oldSwitchStatus = this.getSwitchStatus().status;
+ if(oldSwitchStatus == 2) {
+ var switchIp = this.getSwitchData().switch.ip;
+ this.options.serverControl.removeServersBySwitch(switchIp);
+ }
+
+ this.setSwitchStatus(1, "waiting");
+ this.queryCount = 0;
+ this.checkSwitchState();
+ },
+
+ /************************************/
+ // switch create success callback
+ /************************************/
+ onSwitchCreated: function(data, textStatus, xhr) {
+ steal.dev.log(" *** onSwitchCreated data *** ", data);
+ steal.dev.log(" *** onSwitchCreated textStatus *** ", textStatus);
+ steal.dev.log(" *** onSwitchCreated xhr *** ", xhr);
+
+
+ if (xhr.status == 202) { // accepted
+ this.switchId = data.switch.id;
+ this.checkSwitchState();
+ }
+ },
+
+ /************************************/
+ // switch create error callback
+ /************************************/
+ onSwitchCreateErr: function(xhr, status, statusText) {
+ steal.dev.log(" *** onSwitchCreatErr xhr *** ", xhr);
+ steal.dev.log(" *** onSwitchCreatErr status *** ", status);
+ steal.dev.log(" *** onSwitchCreatErr statusText *** ", xhr);
+
+ if (xhr.status == 409) { // duplicate
+ var failedSwitchId = 0;
+ if ($.fixture.on == true) {
+ failedSwitchId = statusText.failedSwitch;
+ } else {
+ failedSwitchId = JSON.parse(xhr.responseText).failedSwitch;
+ }
+ steal.dev.log(" *** failed Switch Id *** ", failedSwitchId);
+ // PUT switches
+ var switchData = this.getSwitchData();
+ Ods.Switch.update(failedSwitchId, switchData,
+ this.proxy('onSwitchUpdated'),
+ this.proxy('onSwitchUpdateErr'));
+ } else {
+ this.setSwitchStatus(3, "POST switch API error");
+ //TODO
+ /*
+ if (xhr.status == 400) { //bad request
+ $(".switchesErr").html("Switch post error code: 400");
+ $(".switchesErr").show();
+ } else if (xhr.status == 500) { // internal server error
+ $(".switchesErr").html("Switch post error code: 500");
+ $(".switchesErr").show();
+ }
+ */
+ }
+ },
+
+ /************************************/
+ // switch update success callback
+ /************************************/
+ onSwitchUpdated: function(data, textStatus, xhr) {
+ steal.dev.log(" *** onSwitchUpdated data *** ", data);
+ steal.dev.log(" *** onSwitchUpdated textStatus *** ", textStatus);
+ steal.dev.log(" *** onSwitchUpdated xhr *** ", xhr);
+
+ if (xhr.status == 202 || xhr.status == 200) { // accepted or OK
+ this.switchId = data.switch.id;
+ this.checkSwitchState();
+ }
+ },
+
+ /************************************/
+ // switch create error callback
+ /************************************/
+ onSwitchUpdateErr: function(xhr, status, statusText) {
+ steal.dev.log(" *** onSwitchUpdateErr xhr *** ", xhr);
+ steal.dev.log(" *** onSwitchUpdateErr status *** ", status);
+ steal.dev.log(" *** onSwitchUpdateErr statusText *** ", statusText);
+
+ this.setSwitchStatus(3, "PUT switch API error");
+
+ if (xhr.status == 404) { // not found
+ $(".switchesErr").html("Switch update error code: 404");
+ $(".switchesErr").show();
+ } else if (xhr.status == 400) { // bad request
+ $(".switchesErr").html("Switch update error code: 400");
+ $(".switchesErr").show();
+ } else if (xhr.status == 500) { // internal server error
+ $(".switchesErr").html("Switch update error code: 500");
+ $(".switchesErr").show();
+ }
+ },
+
+ checkSwitchState: function() {
+ this.queryCount++;
+ if (this.queryCount > 5) {
+ this.setSwitchStatus(3, "Timed out in connecting to switch");
+ return;
+ }
+ Ods.Switch.findOne(this.switchId, this.proxy('onFindOneSwitch'), this.proxy('onFindOneSwitchErr'));
+ },
+
+ /************************************/
+ // find one switch success callback
+ /************************************/
+ onFindOneSwitch: function(data, textStatus, xhr) {
+ steal.dev.log(" *** onFindOneSwitch data *** ", data);
+ steal.dev.log(" *** onFindOneSwitch textStatus *** ", textStatus);
+ steal.dev.log(" *** onFindOneSwitch xhr *** ", xhr);
+
+ if (xhr.status == 200) { //OK
+ if (data.switch.state === "under_monitoring") {
+ this.element.find('div.right-side').show();
+ this.getServersBySwitch(data.switch.id);
+ this.setSwitchStatus(2, "The switch is under monitoring");
+ } else if (data.switch.state === "unreachable"){
+ this.element.find('div.right-side').show();
+ this.getServersBySwitch(data.switch.id);
+ this.setSwitchStatus(3, data.switch.err_msg);
+ } else if (data.switch.state === "initialized" || data.switch.state === "repulling") {
+ setTimeout(this.proxy('checkSwitchState'), 2000);
+ } else if (data.switch.state === "notsupported") {
+ this.setSwitchStatus(3, data.switch.err_msg);
+ }
+ }
+ },
+
+ /************************************/
+ // find one switch error callback
+ /************************************/
+ onFindOneSwitchErr: function(xhr, status, statusText) {
+ steal.dev.log(" *** onFindOneSwitchErr xhr *** ", xhr);
+ steal.dev.log(" *** onFindOneSwitchErr status *** ", status);
+ steal.dev.log(" *** onFindOneSwitchErr statusText *** ", statusText);
+
+ this.setSwitchStatus(3, "GET switch API error");
+
+ /*
+ if (xhr.status == 404) { // not found
+ $(".switchesErr").html("Find switch error code: 404");
+ $(".switchesErr").show();
+ } else if (xhr.status == 500) {
+ $(".switchesErr").html("Find switch error code: 500");
+ $(".switchesErr").show();
+ }*/
+ },
+
+ getServersBySwitch: function(id) {
+ Ods.Server.findAll({
+ switchId: id
+ }, this.proxy('onFindAllServers'));
+ },
+
+ /************************************/
+ // find machines success callback
+ /************************************/
+ onFindAllServers: function(data, textStatus, xhr) {
+ steal.dev.log(" *** onFindAllServers data *** ", data);
+ steal.dev.log(" *** onFindAllServers textStatus *** ", textStatus);
+ steal.dev.log(" *** onFindAllServers xhr *** ", xhr);
+
+ this.setSwitchStatus(2, "The switch is under monitoring");
+ this.options.serverControl.onNewMachines(data.machines);
+ },
+
+ "{odsState} snmp change": function(Observe, ev, attr, action, newVal, oldVal) {
+ console.log(Observe, ev, attr, action, newVal, oldVal);
+
+ if (attr == "snmp" && action == "set") {
+ this.displaySnmp(newVal);
+ }
+ },
+
+ displaySnmp: function(snmp) {
+ if (snmp) {
+ $(".username").hide();
+ $(".password").hide();
+ $(".snmp").show();
+ $(".community").show();
+ } else {
+ $(".snmp").hide();
+ $(".community").hide();
+ $(".username").show();
+ $(".password").show();
+ }
+ },
+
+ getSwitchStatus: function() {
+ return this.switchStatus;
+ },
+
+ setSwitchStatus: function(status, message) {
+ this.switchStatus.status = status;
+ this.switchStatus.message = message;
+ this.displaySwitchStatus(this.switchStatus);
+
+ },
+
+ displaySwitchStatus: function(swStatus) {
+ switch(swStatus.status) {
+ case 0: //none
+ this.find(".waiting").hide();
+ this.find(".ok").hide();
+ this.find(".err").hide();
+ this.find(".refresh").hide();
+ break;
+ case 1: //waiting
+ this.find(".waiting").show();
+ this.find(".ok").hide();
+ this.find(".err").hide();
+ this.find(".refresh").hide();
+ break;
+ case 2: //ok
+ this.find(".ok").show();
+ this.find(".waiting").hide();
+ this.find(".err").hide();
+ this.find(".refresh").show();
+ break;
+ case 3: //error
+ this.find(".err").show();
+ this.find(".ok").hide();
+ this.find(".waiting").hide();
+ this.find(".refresh").show();
+ this.find(".err").attr("title", swStatus.message);
+ this.find(".err").tooltip();
+ break;
+ }
+ },
+
+ // remove switch row in switch table
+ 'div.remove click': function(el, ev) {
+ var row = el.closest('tr');
+ row.remove();
+ },
+
+ });
+});
\ No newline at end of file
diff --git a/public/ods/ui/switch_entry/views/init.ejs b/public/ods/ui/switch_entry/views/init.ejs
new file mode 100644
index 0000000..b1a5e68
--- /dev/null
+++ b/public/ods/ui/switch_entry/views/init.ejs
@@ -0,0 +1,27 @@
+ |
+
+
+
+ |
+
+
+
+ |
+
+
+ <% if (!first) { %> <% } %>
+
+
+
+ 
+
+
+ |
+
diff --git a/public/ods/ui/servers/views/switch_row.ejs b/public/ods/ui/switch_entry/views/switch_row.ejs
similarity index 94%
rename from public/ods/ui/servers/views/switch_row.ejs
rename to public/ods/ui/switch_entry/views/switch_row.ejs
index 8fa6a1b..f8aa922 100644
--- a/public/ods/ui/servers/views/switch_row.ejs
+++ b/public/ods/ui/switch_entry/views/switch_row.ejs
@@ -1,4 +1,4 @@
-
+
>
|
|