2015-07-20 00:09:47 -07:00
|
|
|
/* jslint node: true */
|
|
|
|
|
|
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
|
|
exports = module.exports = {
|
|
|
|
|
DeveloperError: DeveloperError,
|
|
|
|
|
|
2016-06-01 18:21:02 -07:00
|
|
|
isEnabled: isEnabled,
|
2015-07-20 00:09:47 -07:00
|
|
|
setEnabled: setEnabled,
|
2015-07-27 13:08:07 +02:00
|
|
|
issueDeveloperToken: issueDeveloperToken,
|
|
|
|
|
getNonApprovedApps: getNonApprovedApps
|
2015-07-20 00:09:47 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
var assert = require('assert'),
|
2015-07-27 13:08:07 +02:00
|
|
|
config = require('./config.js'),
|
2015-12-31 10:42:02 +01:00
|
|
|
debug = require('debug')('box:developer'),
|
2016-05-01 13:46:33 -07:00
|
|
|
eventlog = require('./eventlog.js'),
|
2015-07-20 00:09:47 -07:00
|
|
|
tokendb = require('./tokendb.js'),
|
2015-07-23 12:52:04 +02:00
|
|
|
settings = require('./settings.js'),
|
2015-07-27 13:08:07 +02:00
|
|
|
superagent = require('superagent'),
|
2015-07-20 00:09:47 -07:00
|
|
|
util = require('util');
|
|
|
|
|
|
|
|
|
|
function DeveloperError(reason, errorOrMessage) {
|
|
|
|
|
assert.strictEqual(typeof reason, 'string');
|
|
|
|
|
assert(errorOrMessage instanceof Error || typeof errorOrMessage === 'string' || typeof errorOrMessage === 'undefined');
|
|
|
|
|
|
|
|
|
|
Error.call(this);
|
|
|
|
|
Error.captureStackTrace(this, this.constructor);
|
|
|
|
|
|
|
|
|
|
this.name = this.constructor.name;
|
|
|
|
|
this.reason = reason;
|
|
|
|
|
if (typeof errorOrMessage === 'undefined') {
|
|
|
|
|
this.message = reason;
|
|
|
|
|
} else if (typeof errorOrMessage === 'string') {
|
|
|
|
|
this.message = errorOrMessage;
|
|
|
|
|
} else {
|
|
|
|
|
this.message = 'Internal error';
|
|
|
|
|
this.nestedError = errorOrMessage;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
util.inherits(DeveloperError, Error);
|
|
|
|
|
DeveloperError.INTERNAL_ERROR = 'Internal Error';
|
2015-12-15 09:12:52 -08:00
|
|
|
DeveloperError.EXTERNAL_ERROR = 'External Error';
|
2015-07-20 00:09:47 -07:00
|
|
|
|
2016-06-01 18:21:02 -07:00
|
|
|
function isEnabled(callback) {
|
2015-07-20 00:09:47 -07:00
|
|
|
assert.strictEqual(typeof callback, 'function');
|
|
|
|
|
|
2015-07-23 12:52:04 +02:00
|
|
|
settings.getDeveloperMode(function (error, enabled) {
|
|
|
|
|
if (error) return callback(new DeveloperError(DeveloperError.INTERNAL_ERROR, error));
|
|
|
|
|
callback(null, enabled);
|
|
|
|
|
});
|
2015-07-20 00:09:47 -07:00
|
|
|
}
|
|
|
|
|
|
2016-05-01 13:46:33 -07:00
|
|
|
function setEnabled(enabled, auditSource, callback) {
|
2015-07-20 00:09:47 -07:00
|
|
|
assert.strictEqual(typeof enabled, 'boolean');
|
2016-05-01 13:46:33 -07:00
|
|
|
assert.strictEqual(typeof auditSource, 'object');
|
2015-07-20 00:09:47 -07:00
|
|
|
assert.strictEqual(typeof callback, 'function');
|
|
|
|
|
|
2015-07-23 12:52:04 +02:00
|
|
|
settings.setDeveloperMode(enabled, function (error) {
|
|
|
|
|
if (error) return callback(new DeveloperError(DeveloperError.INTERNAL_ERROR, error));
|
2016-05-01 13:46:33 -07:00
|
|
|
|
|
|
|
|
eventlog.add(eventlog.ACTION_CLI_MODE, auditSource, { enabled: enabled });
|
|
|
|
|
|
2015-07-23 12:52:04 +02:00
|
|
|
callback(null);
|
|
|
|
|
});
|
2015-07-20 00:09:47 -07:00
|
|
|
}
|
|
|
|
|
|
2016-05-01 13:46:33 -07:00
|
|
|
function issueDeveloperToken(user, auditSource, callback) {
|
2015-07-20 00:09:47 -07:00
|
|
|
assert.strictEqual(typeof user, 'object');
|
2016-05-01 13:46:33 -07:00
|
|
|
assert.strictEqual(typeof auditSource, 'object');
|
2015-07-20 00:09:47 -07:00
|
|
|
assert.strictEqual(typeof callback, 'function');
|
|
|
|
|
|
|
|
|
|
var token = tokendb.generateToken();
|
|
|
|
|
var expiresAt = Date.now() + 24 * 60 * 60 * 1000; // 1 day
|
|
|
|
|
|
2016-06-02 15:58:40 -07:00
|
|
|
tokendb.add(token, tokendb.PREFIX_DEV + user.id, '', expiresAt, '*', function (error) {
|
2015-07-20 00:09:47 -07:00
|
|
|
if (error) return callback(new DeveloperError(DeveloperError.INTERNAL_ERROR, error));
|
|
|
|
|
|
2016-05-01 13:46:33 -07:00
|
|
|
eventlog.add(eventlog.ACTION_USER_LOGIN, auditSource, { authType: 'cli', userId: user.id, username: user.username });
|
|
|
|
|
|
2015-07-20 00:09:47 -07:00
|
|
|
callback(null, { token: token, expiresAt: expiresAt });
|
|
|
|
|
});
|
|
|
|
|
}
|
2015-07-27 13:08:07 +02:00
|
|
|
|
|
|
|
|
function getNonApprovedApps(callback) {
|
|
|
|
|
assert.strictEqual(typeof callback, 'function');
|
|
|
|
|
|
|
|
|
|
var url = config.apiServerOrigin() + '/api/v1/boxes/' + config.fqdn() + '/apps';
|
|
|
|
|
superagent.get(url).query({ token: config.token(), boxVersion: config.version() }).end(function (error, result) {
|
2015-12-15 09:12:52 -08:00
|
|
|
if (error && !error.response) return callback(new DeveloperError(DeveloperError.EXTERNAL_ERROR, error));
|
2015-12-31 10:42:02 +01:00
|
|
|
if (result.statusCode === 401) {
|
|
|
|
|
debug('Failed to list apps in development. Appstore token invalid or missing. Returning empty list.', result.body);
|
|
|
|
|
return callback(null, []);
|
|
|
|
|
}
|
2015-12-15 09:12:52 -08:00
|
|
|
if (result.statusCode !== 200) return callback(new DeveloperError(DeveloperError.EXTERNAL_ERROR, util.format('App listing failed. %s %j', result.status, result.body)));
|
2015-07-27 13:08:07 +02:00
|
|
|
|
2015-07-27 16:27:50 +02:00
|
|
|
callback(null, result.body.apps || []);
|
2015-07-27 13:08:07 +02:00
|
|
|
});
|
|
|
|
|
}
|