import moment from 'moment'; 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); } } 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; } } }); return preferences; } 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); } }); 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, }); } }); return keyValuePreferences; } return []; }; helper.translateConstraintsToKeyValue = function (constraints) { function getOperator(constraint) { var indexEquals = constraint.indexOf('=='); if (indexEquals >= 0) { return [indexEquals, '==']; } 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; } } 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; } }); 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; }; return helper; }, ]);