mirror of
https://github.com/portainer/portainer.git
synced 2025-07-23 15:29:42 +02:00
* chore(log-viewer): add the ability to use`since` parameter #1942 https://github.com/portainer/portainer/issues/1942#issuecomment-430246378 * chore(log-viewer): change lineCount to 100 #1942 https://github.com/portainer/portainer/issues/1942#issuecomment-430246378 * fix(log-viewer): js syntax typo for `;` and `'` forget to lint the code, reported by codeclimate * fix(log-viewer): use mementjs to format timestamp 1. use moment lib instead of define a function in filter.js(not the right place for this function, removed) 2. set sinceTimestamp init value to `24 hours ago`, as we just need to focus on the relative latest logs after the log-viewer loading, not all the logs(to speedup the process) 3. use moment().unix() to convert the `sinceTimestamp` to local unix timestamp(not utc) * chore(log-viewer): add the ability to select the datetime for `since` * chore(log-viewer): add the ability to fetch logs from specific time
87 lines
2.4 KiB
JavaScript
87 lines
2.4 KiB
JavaScript
angular.module('portainer.docker')
|
|
.factory('ServiceService', ['$q', 'Service', 'ServiceHelper', 'TaskService', 'ResourceControlService', 'LogHelper',
|
|
function ServiceServiceFactory($q, Service, ServiceHelper, TaskService, ResourceControlService, LogHelper) {
|
|
'use strict';
|
|
var service = {};
|
|
|
|
service.services = function(filters) {
|
|
var deferred = $q.defer();
|
|
|
|
Service.query({ filters: filters ? filters : {} }).$promise
|
|
.then(function success(data) {
|
|
var services = data.map(function (item) {
|
|
return new ServiceViewModel(item);
|
|
});
|
|
deferred.resolve(services);
|
|
})
|
|
.catch(function error(err) {
|
|
deferred.reject({ msg: 'Unable to retrieve services', err: err });
|
|
});
|
|
|
|
return deferred.promise;
|
|
};
|
|
|
|
service.service = function(id) {
|
|
var deferred = $q.defer();
|
|
|
|
Service.get({ id: id }).$promise
|
|
.then(function success(data) {
|
|
var service = new ServiceViewModel(data);
|
|
deferred.resolve(service);
|
|
})
|
|
.catch(function error(err) {
|
|
deferred.reject({ msg: 'Unable to retrieve service details', err: err });
|
|
});
|
|
|
|
return deferred.promise;
|
|
};
|
|
|
|
service.remove = function(service) {
|
|
var deferred = $q.defer();
|
|
|
|
Service.remove({id: service.Id}).$promise
|
|
.then(function success() {
|
|
if (service.ResourceControl && service.ResourceControl.Type === 2) {
|
|
return ResourceControlService.deleteResourceControl(service.ResourceControl.Id);
|
|
}
|
|
})
|
|
.then(function success() {
|
|
deferred.resolve();
|
|
})
|
|
.catch(function error(err) {
|
|
deferred.reject({ msg: 'Unable to remove service', err: err });
|
|
});
|
|
|
|
return deferred.promise;
|
|
};
|
|
|
|
service.update = function(service, config) {
|
|
return Service.update({ id: service.Id, version: service.Version }, config).$promise;
|
|
};
|
|
|
|
service.logs = function(id, stdout, stderr, timestamps, since, tail) {
|
|
var deferred = $q.defer();
|
|
|
|
var parameters = {
|
|
id: id,
|
|
stdout: stdout || 0,
|
|
stderr: stderr || 0,
|
|
timestamps: timestamps || 0,
|
|
since: since || 0,
|
|
tail: tail || 'all'
|
|
};
|
|
|
|
Service.logs(parameters).$promise
|
|
.then(function success(data) {
|
|
var logs = LogHelper.formatLogs(data.logs, true);
|
|
deferred.resolve(logs);
|
|
})
|
|
.catch(function error(err) {
|
|
deferred.reject(err);
|
|
});
|
|
|
|
return deferred.promise;
|
|
};
|
|
|
|
return service;
|
|
}]);
|