2019-03-21 05:46:49 +00:00
|
|
|
import moment from 'moment';
|
|
|
|
|
2020-04-10 21:54:53 +00:00
|
|
|
angular.module('portainer.docker').factory('ServiceHelper', [
|
|
|
|
function ServiceHelperFactory() {
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
var helper = {};
|
|
|
|
|
|
|
|
helper.associateTasksToService = function (service, tasks) {
|
|
|
|
service.Tasks = [];
|
|
|
|
var otherServicesTasks = [];
|
|
|
|
for (var i = 0; i < tasks.length; i++) {
|
|
|
|
var task = tasks[i];
|
|
|
|
if (task.ServiceId === service.Id) {
|
|
|
|
service.Tasks.push(task);
|
|
|
|
task.ServiceName = service.Name;
|
|
|
|
} else {
|
|
|
|
otherServicesTasks.push(task);
|
|
|
|
}
|
2017-07-10 07:33:09 +00:00
|
|
|
}
|
2020-04-10 21:54:53 +00:00
|
|
|
tasks = otherServicesTasks;
|
|
|
|
};
|
|
|
|
|
|
|
|
helper.translateKeyValueToPlacementPreferences = function (keyValuePreferences) {
|
|
|
|
if (keyValuePreferences) {
|
|
|
|
var preferences = [];
|
|
|
|
keyValuePreferences.forEach(function (preference) {
|
|
|
|
if (preference.strategy && preference.strategy !== '' && preference.value && preference.value !== '') {
|
|
|
|
switch (preference.strategy.toLowerCase()) {
|
|
|
|
case 'spread':
|
|
|
|
preferences.push({
|
|
|
|
Spread: {
|
|
|
|
SpreadDescriptor: preference.value,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
break;
|
|
|
|
}
|
2017-05-04 06:57:08 +00:00
|
|
|
}
|
|
|
|
});
|
2020-04-10 21:54:53 +00:00
|
|
|
return preferences;
|
2017-07-10 07:33:09 +00:00
|
|
|
}
|
2020-04-10 21:54:53 +00:00
|
|
|
return [];
|
|
|
|
};
|
|
|
|
|
|
|
|
helper.translateKeyValueToPlacementConstraints = function (keyValueConstraints) {
|
|
|
|
if (keyValueConstraints) {
|
|
|
|
var constraints = [];
|
|
|
|
keyValueConstraints.forEach(function (constraint) {
|
|
|
|
if (constraint.key && constraint.key !== '' && constraint.value && constraint.value !== '') {
|
|
|
|
constraints.push(constraint.key + constraint.operator + constraint.value);
|
|
|
|
}
|
2017-07-10 07:33:09 +00:00
|
|
|
});
|
2020-04-10 21:54:53 +00:00
|
|
|
return constraints;
|
|
|
|
}
|
|
|
|
return [];
|
|
|
|
};
|
|
|
|
|
|
|
|
helper.translatePreferencesToKeyValue = function (preferences) {
|
|
|
|
if (preferences) {
|
|
|
|
var keyValuePreferences = [];
|
|
|
|
preferences.forEach(function (preference) {
|
|
|
|
if (preference.Spread) {
|
|
|
|
keyValuePreferences.push({
|
|
|
|
strategy: 'Spread',
|
|
|
|
value: preference.Spread.SpreadDescriptor,
|
|
|
|
});
|
|
|
|
}
|
2017-12-22 09:05:31 +00:00
|
|
|
});
|
2020-04-10 21:54:53 +00:00
|
|
|
return keyValuePreferences;
|
|
|
|
}
|
|
|
|
return [];
|
|
|
|
};
|
|
|
|
|
|
|
|
helper.translateConstraintsToKeyValue = function (constraints) {
|
|
|
|
function getOperator(constraint) {
|
|
|
|
var indexEquals = constraint.indexOf('==');
|
|
|
|
if (indexEquals >= 0) {
|
|
|
|
return [indexEquals, '=='];
|
2017-12-22 09:05:31 +00:00
|
|
|
}
|
2020-04-10 21:54:53 +00:00
|
|
|
return [constraint.indexOf('!='), '!='];
|
|
|
|
}
|
|
|
|
if (constraints) {
|
|
|
|
var keyValueConstraints = [];
|
|
|
|
constraints.forEach(function (constraint) {
|
|
|
|
var operatorIndices = getOperator(constraint);
|
|
|
|
|
|
|
|
var key = constraint.slice(0, operatorIndices[0]);
|
|
|
|
var operator = operatorIndices[1];
|
|
|
|
var value = constraint.slice(operatorIndices[0] + 2);
|
|
|
|
|
|
|
|
keyValueConstraints.push({
|
|
|
|
key: key,
|
|
|
|
value: value,
|
|
|
|
operator: operator,
|
|
|
|
originalKey: key,
|
|
|
|
originalValue: value,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
return keyValueConstraints;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
helper.translateHumanDurationToNanos = function (humanDuration) {
|
|
|
|
var nanos;
|
|
|
|
var regex = /^([0-9]+)(h|m|s|ms|us|ns)$/i;
|
|
|
|
var matches = humanDuration.match(regex);
|
|
|
|
|
|
|
|
if (matches !== null && matches.length === 3) {
|
|
|
|
var duration = parseInt(matches[1], 10);
|
|
|
|
var unit = matches[2];
|
|
|
|
// Moment.js cannot use micro or nanoseconds
|
|
|
|
switch (unit) {
|
|
|
|
case 'ns':
|
|
|
|
nanos = duration;
|
|
|
|
break;
|
|
|
|
case 'us':
|
|
|
|
nanos = duration * 1000;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
nanos = moment.duration(duration, unit).asMilliseconds() * 1000000;
|
2017-12-21 08:53:34 +00:00
|
|
|
}
|
2020-04-10 21:54:53 +00:00
|
|
|
}
|
|
|
|
return nanos;
|
|
|
|
};
|
|
|
|
|
|
|
|
// Convert nanoseconds to the higher unit possible
|
|
|
|
// e.g 1840 nanoseconds = 1804ns
|
|
|
|
// e.g 300000000000 nanoseconds = 5m
|
|
|
|
// e.g 3510000000000 nanoseconds = 3510s
|
|
|
|
// e.g 3540000000000 nanoseconds = 59m
|
|
|
|
// e.g 3600000000000 nanoseconds = 1h
|
|
|
|
|
|
|
|
helper.translateNanosToHumanDuration = function (nanos) {
|
|
|
|
var humanDuration = '0s';
|
|
|
|
var conversionFromNano = {};
|
|
|
|
conversionFromNano['ns'] = 1;
|
|
|
|
conversionFromNano['us'] = conversionFromNano['ns'] * 1000;
|
|
|
|
conversionFromNano['ms'] = conversionFromNano['us'] * 1000;
|
|
|
|
conversionFromNano['s'] = conversionFromNano['ms'] * 1000;
|
|
|
|
conversionFromNano['m'] = conversionFromNano['s'] * 60;
|
|
|
|
conversionFromNano['h'] = conversionFromNano['m'] * 60;
|
|
|
|
|
|
|
|
Object.keys(conversionFromNano).forEach(function (unit) {
|
|
|
|
if (nanos % conversionFromNano[unit] === 0 && nanos / conversionFromNano[unit] > 0) {
|
|
|
|
humanDuration = nanos / conversionFromNano[unit] + unit;
|
2017-12-21 08:53:34 +00:00
|
|
|
}
|
2018-02-01 12:27:52 +00:00
|
|
|
});
|
2020-04-10 21:54:53 +00:00
|
|
|
return humanDuration;
|
|
|
|
};
|
|
|
|
|
|
|
|
helper.translateLogDriverOptsToKeyValue = function (logOptions) {
|
|
|
|
var options = [];
|
|
|
|
if (logOptions) {
|
|
|
|
Object.keys(logOptions).forEach(function (key) {
|
|
|
|
options.push({
|
|
|
|
key: key,
|
|
|
|
value: logOptions[key],
|
|
|
|
originalKey: key,
|
|
|
|
originalValue: logOptions[key],
|
|
|
|
added: true,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
return options;
|
|
|
|
};
|
|
|
|
|
|
|
|
helper.translateKeyValueToLogDriverOpts = function (keyValueLogDriverOpts) {
|
|
|
|
var options = {};
|
|
|
|
if (keyValueLogDriverOpts) {
|
|
|
|
keyValueLogDriverOpts.forEach(function (option) {
|
|
|
|
if (option.key && option.key !== '' && option.value && option.value !== '') {
|
|
|
|
options[option.key] = option.value;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
return options;
|
|
|
|
};
|
|
|
|
|
|
|
|
helper.translateHostsEntriesToHostnameIP = function (entries) {
|
|
|
|
var ipHostEntries = [];
|
|
|
|
if (entries) {
|
|
|
|
entries.forEach(function (entry) {
|
|
|
|
if (entry.indexOf(' ') && entry.split(' ').length === 2) {
|
|
|
|
var keyValue = entry.split(' ');
|
|
|
|
ipHostEntries.push({ hostname: keyValue[1], ip: keyValue[0] });
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
return ipHostEntries;
|
|
|
|
};
|
|
|
|
|
|
|
|
helper.translateHostnameIPToHostsEntries = function (entries) {
|
|
|
|
var ipHostEntries = [];
|
|
|
|
if (entries) {
|
|
|
|
entries.forEach(function (entry) {
|
|
|
|
if (entry.ip && entry.hostname) {
|
|
|
|
ipHostEntries.push(entry.ip + ' ' + entry.hostname);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
return ipHostEntries;
|
|
|
|
};
|
2017-12-21 08:53:34 +00:00
|
|
|
|
2020-04-10 21:54:53 +00:00
|
|
|
return helper;
|
|
|
|
},
|
|
|
|
]);
|