Swap-Aggregator-Subgraph/node_modules/dockerode/lib/service.js
Richa-iitr d211083153 Revert "Revert "added handler""
This reverts commit c36ee8c5ca.
2022-07-03 07:30:05 +05:30

176 lines
3.5 KiB
JavaScript

var util = require('./util');
/**
* Represents an Service
* @param {Object} modem docker-modem
* @param {String} id Service's ID
*/
var Service = function(modem, id) {
this.modem = modem;
this.id = id;
};
Service.prototype[require('util').inspect.custom] = function() { return this; };
/**
* Query Docker for service details.
*
* @param {function} callback
*/
Service.prototype.inspect = function(callback) {
var self = this;
var optsf = {
path: '/services/' + this.id,
method: 'GET',
statusCodes: {
200: true,
404: 'no such service',
500: 'server error'
}
};
if(callback === undefined) {
return new this.modem.Promise(function(resolve, reject) {
self.modem.dial(optsf, function(err, data) {
if (err) {
return reject(err);
}
resolve(data);
});
});
} else {
this.modem.dial(optsf, function(err, data) {
callback(err, data);
});
}
};
/**
* Delete Service
*
* @param {function} callback
*/
Service.prototype.remove = function(callback) {
var self = this;
var optsf = {
path: '/services/' + this.id,
method: 'DELETE',
statusCodes: {
200: true,
204: true,
404: 'no such service',
500: 'server error'
}
};
if(callback === undefined) {
return new this.modem.Promise(function(resolve, reject) {
self.modem.dial(optsf, function(err, data) {
if (err) {
return reject(err);
}
resolve(data);
});
});
} else {
this.modem.dial(optsf, function(err, data) {
callback(err, data);
});
}
};
/**
* Update service
*
* @param {object} options
* @param {function} callback
*/
Service.prototype.update = function(auth, opts, callback) {
var self = this;
if (!callback) {
var t = typeof opts;
if(t === 'function'){
callback = opts;
opts = auth;
auth = opts.authconfig || undefined;
} else if (t === 'undefined'){
opts = auth;
auth = opts.authconfig || undefined;
}
}
var optsf = {
path: '/services/' + this.id + '/update?',
method: 'POST',
statusCodes: {
200: true,
404: 'no such service',
500: 'server error'
},
authconfig: auth,
options: opts
};
if(callback === undefined) {
return new this.modem.Promise(function(resolve, reject) {
self.modem.dial(optsf, function(err, data) {
if (err) {
return reject(err);
}
self.output = data;
resolve(self);
});
});
} else {
this.modem.dial(optsf, function(err, data) {
callback(err, data);
});
}
};
/**
* Service logs
* @param {Object} opts Logs options. (optional)
* @param {Function} callback Callback with data
*/
Service.prototype.logs = function(opts, callback) {
var self = this;
var args = util.processArgs(opts, callback, {});
var optsf = {
path: '/services/' + this.id + '/logs?',
method: 'GET',
isStream: args.opts.follow || false,
statusCodes: {
200: true,
404: 'no such service',
500: 'server error',
503: 'node is not part of a swarm'
},
options: args.opts
};
if(args.callback === undefined) {
return new this.modem.Promise(function(resolve, reject) {
self.modem.dial(optsf, function(err, data) {
if (err) {
return reject(err);
}
resolve(data);
});
});
} else {
this.modem.dial(optsf, function(err, data) {
args.callback(err, data);
});
}
};
module.exports = Service;