blob: 6ebbf4f8173cbe126754321bdd9d2c403268d166 [file] [log] [blame]
/**
* Controller for network
*
* @module app/configuration
* @exports networkController
* @name networkController
*/
window.angular && (function(angular) {
'use strict';
angular.module('app.configuration').controller('networkController', [
'$scope', '$window', 'APIUtils', 'dataService', '$timeout', '$route', '$q',
function($scope, $window, APIUtils, dataService, $timeout, $route, $q) {
$scope.dataService = dataService;
$scope.network = {};
$scope.old_interface = {};
$scope.interface = {};
$scope.networkDevice = false;
$scope.hostname = '';
$scope.defaultgateway = '';
$scope.set_network_error = '';
$scope.set_network_success = false;
$scope.selectedInterface = '';
$scope.confirm_settings = false;
$scope.loading = false;
$scope.selectInterface = function(interfaceId) {
$scope.interface = $scope.network.interfaces[interfaceId];
// Copy the interface so we know later if changes were made to the page
$scope.old_interface = JSON.parse(JSON.stringify($scope.interface));
$scope.selectedInterface = interfaceId;
$scope.networkDevice = false;
};
$scope.setNetworkSettings = function() {
// Hides the confirm network settings modal
$scope.confirm_settings = false;
$scope.set_network_error = '';
$scope.set_network_success = false;
$scope.loading = true;
var promises = [];
// MAC Address are case-insensitive
if ($scope.interface.MACAddress.toLowerCase() !=
dataService.mac_address.toLowerCase()) {
promises.push(setMACAddress());
}
if ($scope.defaultgateway != dataService.defaultgateway) {
promises.push(setDefaultGateway());
}
if ($scope.hostname != dataService.hostname) {
promises.push(setHostname());
}
if ($scope.interface.DHCPEnabled != $scope.old_interface.DHCPEnabled) {
promises.push(setDHCPEnabled());
}
// Set IPV4 IP Addresses, Netmask Prefix Lengths, and Gateways
if (!$scope.interface.DHCPEnabled) {
for (var i in $scope.interface.ipv4.values) {
if ($scope.interface.ipv4.values[i].Address !=
$scope.old_interface.ipv4.values[i].Address ||
$scope.interface.ipv4.values[i].PrefixLength !=
$scope.old_interface.ipv4.values[i].PrefixLength ||
$scope.interface.ipv4.values[i].Gateway !=
$scope.old_interface.ipv4.values[i].Gateway) {
promises.push(setIPV4(i));
}
}
}
if (promises.length) {
$q.all(promises).finally(function() {
$scope.loading = false;
if (!$scope.set_network_error) {
$scope.set_network_success = true;
// Since an IPV4 interface (e.g. IP address, gateway, or netmask)
// edit is a delete then an add and the GUI can't calculate the
// interface id (e.g. 5c083707) beforehand and it is not returned
// by the REST call, openbmc#3227, reload the page after an edit,
// which makes a 2nd REST call.
// Do this for all network changes due to the possibility of a set
// network failing even though it returned success, openbmc#1641,
// and to update dataService and old_interface to know which
// data has changed if the user continues to edit network
// settings.
// TODO: The reload is not ideal. Revisit this.
$timeout(function() {
$route.reload();
}, 4000);
}
});
} else {
$scope.loading = false;
}
};
function setMACAddress() {
return APIUtils
.setMACAddress(
$scope.selectedInterface, $scope.interface.MACAddress)
.then(
function(data) {},
function(error) {
console.log(JSON.stringify(error));
$scope.set_network_error = 'MAC Address';
});
}
function setDefaultGateway() {
return APIUtils.setDefaultGateway($scope.defaultgateway)
.then(
function(data) {},
function(error) {
console.log(JSON.stringify(error));
$scope.set_network_error = 'Default Gateway';
});
}
function setHostname() {
return APIUtils.setHostname($scope.hostname)
.then(
function(data) {},
function(error) {
console.log(JSON.stringify(error));
$scope.set_network_error = 'Hostname';
});
}
function setDHCPEnabled() {
return APIUtils
.setDHCPEnabled(
$scope.selectedInterface, $scope.interface.DHCPEnabled)
.then(
function(data) {},
function(error) {
console.log(JSON.stringify(error));
$scope.set_network_error = 'DHCP';
});
}
function setIPV4(index) {
// The correct way to edit an IPV4 interface is to remove it and then
// add a new one
return APIUtils
.deleteIPV4(
$scope.selectedInterface, $scope.interface.ipv4.ids[index])
.then(
function(data) {
return APIUtils
.addIPV4(
$scope.selectedInterface,
$scope.interface.ipv4.values[index].Address,
$scope.interface.ipv4.values[index].PrefixLength,
$scope.interface.ipv4.values[index].Gateway)
.then(
function(data) {},
function(error) {
console.log(JSON.stringify(error));
$scope.set_network_error =
$scope.interface.ipv4.values[index].Address;
});
},
function(error) {
console.log(JSON.stringify(error));
$scope.set_network_error =
$scope.interface.ipv4.values[index].Address;
});
}
$scope.refresh = function() {
$route.reload();
};
APIUtils.getNetworkInfo().then(function(data) {
dataService.setNetworkInfo(data);
$scope.network = data.formatted_data;
$scope.hostname = data.hostname;
$scope.defaultgateway = data.defaultgateway;
if ($scope.network.interface_ids.length) {
$scope.selectedInterface = $scope.network.interface_ids[0];
$scope.interface =
$scope.network.interfaces[$scope.selectedInterface];
// Copy the interface so we know later if changes were made to the
// page
$scope.old_interface = JSON.parse(JSON.stringify($scope.interface));
}
});
}
]);
})(angular);