2015-07-20 00:09:47 -07:00
|
|
|
/* jslint node: true */
|
|
|
|
|
|
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
|
|
exports = module.exports = {
|
|
|
|
|
DeveloperError: DeveloperError,
|
|
|
|
|
|
2017-11-02 10:31:11 -07:00
|
|
|
issueDeveloperToken: issueDeveloperToken
|
2015-07-20 00:09:47 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
var assert = require('assert'),
|
2016-06-03 11:10:22 +02:00
|
|
|
clients = require('./clients.js'),
|
2016-08-01 10:14:45 +02:00
|
|
|
constants = require('./constants.js'),
|
2016-05-01 13:46:33 -07:00
|
|
|
eventlog = require('./eventlog.js'),
|
2015-07-20 00:09:47 -07:00
|
|
|
tokendb = require('./tokendb.js'),
|
|
|
|
|
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-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();
|
2016-08-01 10:14:45 +02:00
|
|
|
var expiresAt = Date.now() + constants.DEFAULT_TOKEN_EXPIRATION;
|
2016-06-03 11:10:22 +02:00
|
|
|
var scopes = '*,' + clients.SCOPE_ROLE_SDK;
|
2015-07-20 00:09:47 -07:00
|
|
|
|
2016-06-08 13:39:31 +02:00
|
|
|
tokendb.add(token, user.id, 'cid-cli', expiresAt, scopes, 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 });
|
|
|
|
|
|
2016-06-03 10:11:09 -07:00
|
|
|
callback(null, { token: token, expiresAt: new Date(expiresAt).toISOString() });
|
2015-07-20 00:09:47 -07:00
|
|
|
});
|
|
|
|
|
}
|