jsforce
Version:
Salesforce API Library for JavaScript
878 lines (874 loc) • 84.9 kB
JavaScript
import _Object$getOwnPropertySymbols from "@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols";
import _filterInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/filter";
import _Object$getOwnPropertyDescriptor from "@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor";
import _forEachInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/for-each";
import _Object$getOwnPropertyDescriptors from "@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors";
import _Object$defineProperties from "@babel/runtime-corejs3/core-js-stable/object/define-properties";
import _Object$defineProperty from "@babel/runtime-corejs3/core-js-stable/object/define-property";
import _sliceInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/slice";
import _Array$from from "@babel/runtime-corejs3/core-js-stable/array/from";
import _Symbol from "@babel/runtime-corejs3/core-js-stable/symbol";
import _getIteratorMethod from "@babel/runtime-corejs3/core-js/get-iterator-method";
import _Array$isArray from "@babel/runtime-corejs3/core-js-stable/array/is-array";
import _asyncToGenerator from "@babel/runtime-corejs3/helpers/asyncToGenerator";
import _classCallCheck from "@babel/runtime-corejs3/helpers/classCallCheck";
import _createClass from "@babel/runtime-corejs3/helpers/createClass";
import _defineProperty from "@babel/runtime-corejs3/helpers/defineProperty";
function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof _Symbol && _getIteratorMethod(r) || r["@@iterator"]; if (!t) { if (_Array$isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t.return || t.return(); } finally { if (u) throw o; } } }; }
function _unsupportedIterableToArray(r, a) { if (r) { var _context22; if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = _sliceInstanceProperty(_context22 = {}.toString.call(r)).call(_context22, 8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? _Array$from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
function ownKeys(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context20, _context21; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context20 = ownKeys(Object(t), !0)).call(_context20, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context21 = ownKeys(Object(t))).call(_context21, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
import "core-js/modules/es.error.cause.js";
import "core-js/modules/es.array.push.js";
import "core-js/modules/es.function.name.js";
import "core-js/modules/es.number.constructor.js";
import "core-js/modules/es.object.keys.js";
import "core-js/modules/es.object.to-string.js";
import "core-js/modules/es.regexp.exec.js";
import "core-js/modules/es.regexp.test.js";
import "core-js/modules/es.regexp.to-string.js";
import _startsWithInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/starts-with";
import _Promise from "@babel/runtime-corejs3/core-js-stable/promise";
import _reduceInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/reduce";
import _Object$keys from "@babel/runtime-corejs3/core-js-stable/object/keys";
import _concatInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/concat";
import _regeneratorRuntime from "@babel/runtime-corejs3/regenerator";
/**
* @file Command line interface for JSforce
* @author Shinichi Tomita <shinichi.tomita@gmail.com>
*/
import http from 'http';
import url from 'url';
import crypto from 'crypto';
import _openUrl from 'open';
import { Command } from 'commander';
import inquirer from 'inquirer';
import request from '../request';
import base64url from 'base64url';
import Repl from './repl';
import jsforce, { Connection, OAuth2 } from '..';
import version from '../VERSION';
var registry = jsforce.registry;
/**
*
*/
export var Cli = /*#__PURE__*/function () {
function Cli() {
_classCallCheck(this, Cli);
_defineProperty(this, "_repl", new Repl(this));
_defineProperty(this, "_conn", new Connection());
_defineProperty(this, "_connName", undefined);
_defineProperty(this, "_outputEnabled", true);
_defineProperty(this, "_defaultLoginUrl", undefined);
}
return _createClass(Cli, [{
key: "readCommand",
value:
/**
*
*/
function readCommand() {
return new Command().option('-u, --username [username]', 'Salesforce username').option('-p, --password [password]', 'Salesforce password (and security token, if available)').option('-c, --connection [connection]', 'Connection name stored in connection registry').option('-l, --loginUrl [loginUrl]', 'Salesforce login url').option('--sandbox', 'Login to Salesforce sandbox').option('-e, --evalScript [evalScript]', 'Script to evaluate').version(version).parse(process.argv);
}
}, {
key: "start",
value: function () {
var _start = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee() {
var program;
return _regeneratorRuntime.wrap(function _callee$(_context) {
while (1) switch (_context.prev = _context.next) {
case 0:
program = this.readCommand();
this._outputEnabled = !program.evalScript;
_context.prev = 2;
_context.next = 5;
return this.connect(program);
case 5:
if (program.evalScript) {
this._repl.start({
interactive: false,
evalScript: program.evalScript
});
} else {
this._repl.start();
}
_context.next = 12;
break;
case 8:
_context.prev = 8;
_context.t0 = _context["catch"](2);
console.error(_context.t0);
process.exit();
case 12:
case "end":
return _context.stop();
}
}, _callee, this, [[2, 8]]);
}));
function start() {
return _start.apply(this, arguments);
}
return start;
}()
}, {
key: "getCurrentConnection",
value: function getCurrentConnection() {
return this._conn;
}
}, {
key: "print",
value: function print() {
if (this._outputEnabled) {
var _console;
(_console = console).log.apply(_console, arguments);
}
}
}, {
key: "saveCurrentConnection",
value: function saveCurrentConnection() {
if (this._connName) {
var conn = this._conn;
var connName = this._connName;
var connConfig = {
oauth2: conn.oauth2 ? {
clientId: conn.oauth2.clientId || undefined,
clientSecret: conn.oauth2.clientSecret || undefined,
redirectUri: conn.oauth2.redirectUri || undefined,
loginUrl: conn.oauth2.loginUrl || undefined
} : undefined,
accessToken: conn.accessToken || undefined,
instanceUrl: conn.instanceUrl || undefined,
refreshToken: conn.refreshToken || undefined
};
registry.saveConnectionConfig(connName, connConfig);
}
}
}, {
key: "setLoginServer",
value: function setLoginServer(loginServer) {
if (!loginServer) {
return;
}
if (loginServer === 'production') {
this._defaultLoginUrl = 'https://login.salesforce.com';
} else if (loginServer === 'sandbox') {
this._defaultLoginUrl = 'https://test.salesforce.com';
} else if (!_startsWithInstanceProperty(loginServer).call(loginServer, 'https://')) {
this._defaultLoginUrl = 'https://' + loginServer;
} else {
this._defaultLoginUrl = loginServer;
}
this.print("Using \"".concat(this._defaultLoginUrl, "\" as default login URL."));
}
/**
*
*/
}, {
key: "connect",
value: (function () {
var _connect = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee2(options) {
var _this = this;
var loginServer, connConfig, username, password, identity;
return _regeneratorRuntime.wrap(function _callee2$(_context2) {
while (1) switch (_context2.prev = _context2.next) {
case 0:
loginServer = options.loginUrl ? options.loginUrl : options.sandbox ? 'sandbox' : null;
this.setLoginServer(loginServer);
this._connName = options.connection;
_context2.next = 5;
return registry.getConnectionConfig(options.connection);
case 5:
connConfig = _context2.sent;
username = options.username;
if (!connConfig) {
connConfig = {};
if (this._defaultLoginUrl) {
connConfig.loginUrl = this._defaultLoginUrl;
}
username = username || options.connection;
}
this._conn = new Connection(connConfig);
password = options.password;
if (!username) {
_context2.next = 16;
break;
}
_context2.next = 13;
return this.startPasswordAuth(username, password);
case 13:
this.saveCurrentConnection();
_context2.next = 34;
break;
case 16:
if (!(this._connName && this._conn.accessToken)) {
_context2.next = 34;
break;
}
this._conn.on('refresh', function () {
_this.print('Refreshing access token ... ');
_this.saveCurrentConnection();
});
_context2.prev = 18;
_context2.next = 21;
return this._conn.identity();
case 21:
identity = _context2.sent;
this.print("Logged in as : ".concat(identity.username));
_context2.next = 34;
break;
case 25:
_context2.prev = 25;
_context2.t0 = _context2["catch"](18);
if (_context2.t0 instanceof Error) {
this.print(_context2.t0.message);
}
if (!this._conn.oauth2) {
_context2.next = 32;
break;
}
throw new Error('Please re-authorize connection.');
case 32:
_context2.next = 34;
return this.startPasswordAuth(this._connName);
case 34:
case "end":
return _context2.stop();
}
}, _callee2, this, [[18, 25]]);
}));
function connect(_x) {
return _connect.apply(this, arguments);
}
return connect;
}()
/**
*
*/
)
}, {
key: "startPasswordAuth",
value: (function () {
var _startPasswordAuth = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee3(username, password) {
return _regeneratorRuntime.wrap(function _callee3$(_context3) {
while (1) switch (_context3.prev = _context3.next) {
case 0:
_context3.prev = 0;
_context3.next = 3;
return this.loginByPassword(username, password, 2);
case 3:
_context3.next = 12;
break;
case 5:
_context3.prev = 5;
_context3.t0 = _context3["catch"](0);
if (!(_context3.t0 instanceof Error && _context3.t0.message === 'canceled')) {
_context3.next = 11;
break;
}
console.error('Password authentication canceled: Not logged in');
_context3.next = 12;
break;
case 11:
throw _context3.t0;
case 12:
case "end":
return _context3.stop();
}
}, _callee3, this, [[0, 5]]);
}));
function startPasswordAuth(_x2, _x3) {
return _startPasswordAuth.apply(this, arguments);
}
return startPasswordAuth;
}()
/**
*
*/
)
}, {
key: "loginByPassword",
value: (function () {
var _loginByPassword = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee4(username, password, retryCount) {
var pass, result;
return _regeneratorRuntime.wrap(function _callee4$(_context4) {
while (1) switch (_context4.prev = _context4.next) {
case 0:
if (!(password === '')) {
_context4.next = 2;
break;
}
throw new Error('canceled');
case 2:
if (!(password == null)) {
_context4.next = 7;
break;
}
_context4.next = 5;
return this.promptPassword('Password: ');
case 5:
pass = _context4.sent;
return _context4.abrupt("return", this.loginByPassword(username, pass, retryCount));
case 7:
_context4.prev = 7;
_context4.next = 10;
return this._conn.login(username, password);
case 10:
result = _context4.sent;
this.print("Logged in as : ".concat(username));
return _context4.abrupt("return", result);
case 15:
_context4.prev = 15;
_context4.t0 = _context4["catch"](7);
if (_context4.t0 instanceof Error) {
console.error(_context4.t0.message);
}
if (!(retryCount > 0)) {
_context4.next = 22;
break;
}
return _context4.abrupt("return", this.loginByPassword(username, undefined, retryCount - 1));
case 22:
throw new Error('canceled');
case 23:
case "end":
return _context4.stop();
}
}, _callee4, this, [[7, 15]]);
}));
function loginByPassword(_x4, _x5, _x6) {
return _loginByPassword.apply(this, arguments);
}
return loginByPassword;
}()
/**
*
*/
)
}, {
key: "disconnect",
value: (function () {
var _disconnect = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee5(connName) {
var name;
return _regeneratorRuntime.wrap(function _callee5$(_context5) {
while (1) switch (_context5.prev = _context5.next) {
case 0:
name = connName || this._connName;
_context5.t0 = name;
if (!_context5.t0) {
_context5.next = 6;
break;
}
_context5.next = 5;
return registry.getConnectionConfig(name);
case 5:
_context5.t0 = _context5.sent;
case 6:
if (!_context5.t0) {
_context5.next = 10;
break;
}
_context5.next = 9;
return registry.removeConnectionConfig(name);
case 9:
this.print("Disconnect connection '".concat(name, "'"));
case 10:
this._connName = undefined;
this._conn = new Connection();
case 12:
case "end":
return _context5.stop();
}
}, _callee5, this);
}));
function disconnect(_x7) {
return _disconnect.apply(this, arguments);
}
return disconnect;
}()
/**
*
*/
)
}, {
key: "authorize",
value: (function () {
var _authorize = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee6(clientName) {
var name, oauth2Config, oauth2, verifier, challenge, state, authzUrl, params, identity;
return _regeneratorRuntime.wrap(function _callee6$(_context6) {
while (1) switch (_context6.prev = _context6.next) {
case 0:
name = clientName || 'default';
_context6.next = 3;
return registry.getClientConfig(name);
case 3:
oauth2Config = _context6.sent;
if (oauth2Config !== null && oauth2Config !== void 0 && oauth2Config.clientId) {
_context6.next = 9;
break;
}
if (!(name === 'default' || name === 'sandbox')) {
_context6.next = 8;
break;
}
this.print('No client information registered. Downloading JSforce default client information...');
return _context6.abrupt("return", this.downloadDefaultClientInfo(name));
case 8:
throw new Error("No OAuth2 client information registered : '".concat(name, "'. Please register client info first."));
case 9:
oauth2 = new OAuth2(oauth2Config);
verifier = base64url.encode(crypto.randomBytes(32));
challenge = base64url.encode(crypto.createHash('sha256').update(verifier).digest());
state = base64url.encode(crypto.randomBytes(32));
authzUrl = oauth2.getAuthorizationUrl({
code_challenge: challenge,
state: state
});
this.print('Opening authorization page in browser...');
this.print("URL: ".concat(authzUrl));
this.openUrl(authzUrl);
_context6.next = 19;
return this.waitCallback(oauth2Config.redirectUri, state);
case 19:
params = _context6.sent;
if (params.code) {
_context6.next = 22;
break;
}
throw new Error('No authorization code returned.');
case 22:
if (!(params.state !== state)) {
_context6.next = 24;
break;
}
throw new Error('Invalid state parameter returned.');
case 24:
this._conn = new Connection({
oauth2: oauth2
});
this.print('Received authorization code. Please close the opened browser window.');
_context6.next = 28;
return this._conn.authorize(params.code, {
code_verifier: verifier
});
case 28:
this.print('Authorized. Fetching user info...');
_context6.next = 31;
return this._conn.identity();
case 31:
identity = _context6.sent;
this.print("Logged in as : ".concat(identity.username));
this._connName = identity.username;
this.saveCurrentConnection();
case 35:
case "end":
return _context6.stop();
}
}, _callee6, this);
}));
function authorize(_x8) {
return _authorize.apply(this, arguments);
}
return authorize;
}()
/**
*
*/
)
}, {
key: "downloadDefaultClientInfo",
value: (function () {
var _downloadDefaultClientInfo = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee7(clientName) {
var configUrl, res, clientConfig;
return _regeneratorRuntime.wrap(function _callee7$(_context7) {
while (1) switch (_context7.prev = _context7.next) {
case 0:
configUrl = 'https://jsforce.github.io/client-config/default.json';
_context7.next = 3;
return new _Promise(function (resolve, reject) {
request({
method: 'GET',
url: configUrl
}).on('complete', resolve).on('error', reject);
});
case 3:
res = _context7.sent;
clientConfig = JSON.parse(res.body);
if (clientName === 'sandbox') {
clientConfig.loginUrl = 'https://test.salesforce.com';
}
_context7.next = 8;
return registry.registerClientConfig(clientName, clientConfig);
case 8:
this.print('Client information downloaded successfully.');
return _context7.abrupt("return", this.authorize(clientName));
case 10:
case "end":
return _context7.stop();
}
}, _callee7, this);
}));
function downloadDefaultClientInfo(_x9) {
return _downloadDefaultClientInfo.apply(this, arguments);
}
return downloadDefaultClientInfo;
}())
}, {
key: "waitCallback",
value: function () {
var _waitCallback = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee8(serverUrl, state) {
var code;
return _regeneratorRuntime.wrap(function _callee8$(_context8) {
while (1) switch (_context8.prev = _context8.next) {
case 0:
if (!(serverUrl && _startsWithInstanceProperty(serverUrl).call(serverUrl, 'http://localhost:'))) {
_context8.next = 4;
break;
}
return _context8.abrupt("return", new _Promise(function (resolve, reject) {
var server = http.createServer(function (req, res) {
if (!req.url) {
return;
}
var qparams = url.parse(req.url, true).query;
res.writeHead(200, {
'Content-Type': 'text/html'
});
res.write('<html><script>location.href="about:blank";</script></html>');
res.end();
if (qparams.error) {
reject(new Error(qparams.error));
} else {
resolve(qparams);
}
server.close();
req.connection.end();
req.connection.destroy();
});
var port = Number(url.parse(serverUrl).port);
server.listen(port, 'localhost');
}));
case 4:
_context8.next = 6;
return this.promptMessage('Copy & paste authz code passed in redirected URL: ');
case 6:
code = _context8.sent;
return _context8.abrupt("return", {
code: decodeURIComponent(code),
state: state
});
case 8:
case "end":
return _context8.stop();
}
}, _callee8, this);
}));
function waitCallback(_x10, _x11) {
return _waitCallback.apply(this, arguments);
}
return waitCallback;
}()
/**
*
*/
}, {
key: "register",
value: (function () {
var _register = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee10(clientName, clientConfig) {
var _context9,
_this2 = this;
var name, prompts, registered, msg, ok;
return _regeneratorRuntime.wrap(function _callee10$(_context11) {
while (1) switch (_context11.prev = _context11.next) {
case 0:
name = clientName || 'default';
prompts = {
clientId: 'Input client ID : ',
clientSecret: 'Input client secret (optional) : ',
redirectUri: 'Input redirect URI : ',
loginUrl: 'Input login URL (default is https://login.salesforce.com) : '
};
_context11.next = 4;
return registry.getClientConfig(name);
case 4:
registered = _context11.sent;
if (!registered) {
_context11.next = 12;
break;
}
msg = "Client '".concat(name, "' is already registered. Are you sure you want to override ? [yN] : ");
_context11.next = 9;
return this.promptConfirm(msg);
case 9:
ok = _context11.sent;
if (ok) {
_context11.next = 12;
break;
}
throw new Error('Registration canceled.');
case 12:
_context11.next = 14;
return _reduceInstanceProperty(_context9 = _Object$keys(prompts)).call(_context9, /*#__PURE__*/function () {
var _ref = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee9(promise, name) {
var cconfig, promptName, message, value;
return _regeneratorRuntime.wrap(function _callee9$(_context10) {
while (1) switch (_context10.prev = _context10.next) {
case 0:
_context10.next = 2;
return promise;
case 2:
cconfig = _context10.sent;
promptName = name;
message = prompts[promptName];
if (cconfig[promptName]) {
_context10.next = 11;
break;
}
_context10.next = 8;
return _this2.promptMessage(message);
case 8:
value = _context10.sent;
if (!value) {
_context10.next = 11;
break;
}
return _context10.abrupt("return", _objectSpread(_objectSpread({}, cconfig), {}, _defineProperty({}, promptName, value)));
case 11:
return _context10.abrupt("return", cconfig);
case 12:
case "end":
return _context10.stop();
}
}, _callee9);
}));
return function (_x14, _x15) {
return _ref.apply(this, arguments);
};
}(), _Promise.resolve(clientConfig));
case 14:
clientConfig = _context11.sent;
_context11.next = 17;
return registry.registerClientConfig(name, clientConfig);
case 17:
this.print('Client registered successfully.');
case 18:
case "end":
return _context11.stop();
}
}, _callee10, this);
}));
function register(_x12, _x13) {
return _register.apply(this, arguments);
}
return register;
}()
/**
*
*/
)
}, {
key: "listConnections",
value: (function () {
var _listConnections = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee11() {
var names, _iterator, _step, name;
return _regeneratorRuntime.wrap(function _callee11$(_context12) {
while (1) switch (_context12.prev = _context12.next) {
case 0:
_context12.next = 2;
return registry.getConnectionNames();
case 2:
names = _context12.sent;
_iterator = _createForOfIteratorHelper(names);
try {
for (_iterator.s(); !(_step = _iterator.n()).done;) {
name = _step.value;
this.print((name === this._connName ? '* ' : ' ') + name);
}
} catch (err) {
_iterator.e(err);
} finally {
_iterator.f();
}
case 5:
case "end":
return _context12.stop();
}
}, _callee11, this);
}));
function listConnections() {
return _listConnections.apply(this, arguments);
}
return listConnections;
}()
/**
*
*/
)
}, {
key: "getConnectionNames",
value: (function () {
var _getConnectionNames = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee12() {
return _regeneratorRuntime.wrap(function _callee12$(_context13) {
while (1) switch (_context13.prev = _context13.next) {
case 0:
return _context13.abrupt("return", registry.getConnectionNames());
case 1:
case "end":
return _context13.stop();
}
}, _callee12);
}));
function getConnectionNames() {
return _getConnectionNames.apply(this, arguments);
}
return getConnectionNames;
}()
/**
*
*/
)
}, {
key: "getClientNames",
value: (function () {
var _getClientNames = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee13() {
return _regeneratorRuntime.wrap(function _callee13$(_context14) {
while (1) switch (_context14.prev = _context14.next) {
case 0:
return _context14.abrupt("return", registry.getClientNames());
case 1:
case "end":
return _context14.stop();
}
}, _callee13);
}));
function getClientNames() {
return _getClientNames.apply(this, arguments);
}
return getClientNames;
}()
/**
*
*/
)
}, {
key: "prompt",
value: (function () {
var _prompt = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee14(type, message) {
var answer;
return _regeneratorRuntime.wrap(function _callee14$(_context15) {
while (1) switch (_context15.prev = _context15.next) {
case 0:
this._repl.pause();
_context15.next = 3;
return inquirer.prompt([{
type: type,
name: 'value',
message: message
}]);
case 3:
answer = _context15.sent;
this._repl.resume();
return _context15.abrupt("return", answer.value);
case 6:
case "end":
return _context15.stop();
}
}, _callee14, this);
}));
function prompt(_x16, _x17) {
return _prompt.apply(this, arguments);
}
return prompt;
}()
/**
*
*/
)
}, {
key: "promptMessage",
value: (function () {
var _promptMessage = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee15(message) {
return _regeneratorRuntime.wrap(function _callee15$(_context16) {
while (1) switch (_context16.prev = _context16.next) {
case 0:
return _context16.abrupt("return", this.prompt('input', message));
case 1:
case "end":
return _context16.stop();
}
}, _callee15, this);
}));
function promptMessage(_x18) {
return _promptMessage.apply(this, arguments);
}
return promptMessage;
}())
}, {
key: "promptPassword",
value: function () {
var _promptPassword = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee16(message) {
return _regeneratorRuntime.wrap(function _callee16$(_context17) {
while (1) switch (_context17.prev = _context17.next) {
case 0:
return _context17.abrupt("return", this.prompt('password', message));
case 1:
case "end":
return _context17.stop();
}
}, _callee16, this);
}));
function promptPassword(_x19) {
return _promptPassword.apply(this, arguments);
}
return promptPassword;
}()
/**
*
*/
}, {
key: "promptConfirm",
value: (function () {
var _promptConfirm = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee17(message) {
return _regeneratorRuntime.wrap(function _callee17$(_context18) {
while (1) switch (_context18.prev = _context18.next) {
case 0:
return _context18.abrupt("return", this.prompt('confirm', message));
case 1:
case "end":
return _context18.stop();
}
}, _callee17, this);
}));
function promptConfirm(_x20) {
return _promptConfirm.apply(this, arguments);
}
return promptConfirm;
}()
/**
*
*/
)
}, {
key: "openUrl",
value: function openUrl(url) {
_openUrl(url);
}
/**
*
*/
}, {
key: "openUrlUsingSession",
value: function openUrlUsingSession(url) {
var _context19;
var frontdoorUrl = _concatInstanceProperty(_context19 = "".concat(this._conn.instanceUrl, "/secur/frontdoor.jsp?sid=")).call(_context19, this._conn.accessToken);
if (url) {
frontdoorUrl += '&retURL=' + encodeURIComponent(url);
}
this.openUrl(frontdoorUrl);
}
}]);
}();
/* ------------------------------------------------------------------------- */
var cli = new Cli();
export default cli;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["http","url","crypto","openUrl","Command","inquirer","request","base64url","Repl","jsforce","Connection","OAuth2","version","registry","Cli","_classCallCheck","_defineProperty","undefined","_createClass","key","value","readCommand","option","parse","process","argv","_start","_asyncToGenerator","_regeneratorRuntime","mark","_callee","program","wrap","_callee$","_context","prev","next","_outputEnabled","evalScript","connect","_repl","start","interactive","t0","console","error","exit","stop","apply","arguments","getCurrentConnection","_conn","print","_console","log","saveCurrentConnection","_connName","conn","connName","connConfig","oauth2","clientId","clientSecret","redirectUri","loginUrl","accessToken","instanceUrl","refreshToken","saveConnectionConfig","setLoginServer","loginServer","_defaultLoginUrl","_startsWithInstanceProperty","call","concat","_connect","_callee2","options","_this","username","password","identity","_callee2$","_context2","sandbox","connection","getConnectionConfig","sent","startPasswordAuth","on","Error","message","_x","_startPasswordAuth","_callee3","_callee3$","_context3","loginByPassword","_x2","_x3","_loginByPassword","_callee4","retryCount","pass","result","_callee4$","_context4","promptPassword","abrupt","login","_x4","_x5","_x6","_disconnect","_callee5","name","_callee5$","_context5","removeConnectionConfig","disconnect","_x7","_authorize","_callee6","clientName","oauth2Config","verifier","challenge","state","authzUrl","params","_callee6$","_context6","getClientConfig","downloadDefaultClientInfo","encode","randomBytes","createHash","update","digest","getAuthorizationUrl","code_challenge","waitCallback","code","authorize","code_verifier","_x8","_downloadDefaultClientInfo","_callee7","configUrl","res","clientConfig","_callee7$","_context7","_Promise","resolve","reject","method","JSON","body","registerClientConfig","_x9","_waitCallback","_callee8","serverUrl","_callee8$","_context8","server","createServer","req","qparams","query","writeHead","write","end","close","destroy","port","Number","listen","promptMessage","decodeURIComponent","_x10","_x11","_register","_callee10","_context9","_this2","prompts","registered","msg","ok","_callee10$","_context11","promptConfirm","_reduceInstanceProperty","_Object$keys","_ref","_callee9","promise","cconfig","promptName","_callee9$","_context10","_objectSpread","_x14","_x15","register","_x12","_x13","_listConnections","_callee11","names","_iterator","_step","_callee11$","_context12","getConnectionNames","_createForOfIteratorHelper","s","n","done","err","e","f","listConnections","_getConnectionNames","_callee12","_callee12$","_context13","_getClientNames","_callee13","_callee13$","_context14","getClientNames","_prompt","_callee14","type","answer","_callee14$","_context15","pause","prompt","resume","_x16","_x17","_promptMessage","_callee15","_callee15$","_context16","_x18","_promptPassword","_callee16","_callee16$","_context17","_x19","_promptConfirm","_callee17","_callee17$","_context18","_x20","openUrlUsingSession","_context19","frontdoorUrl","_concatInstanceProperty","encodeURIComponent","cli"],"sources":["../../src/cli/cli.ts"],"sourcesContent":["/**\n * @file Command line interface for JSforce\n * @author Shinichi Tomita <shinichi.tomita@gmail.com>\n */\nimport http from 'http';\nimport url from 'url';\nimport crypto from 'crypto';\nimport openUrl from 'open';\nimport { Command } from 'commander';\nimport inquirer from 'inquirer';\nimport request from '../request';\nimport base64url from 'base64url';\nimport Repl from './repl';\nimport jsforce, { Connection, OAuth2 } from '..';\nimport version from '../VERSION';\nimport { Optional } from '../types';\nimport { ClientConfig } from '../registry/types';\n\nconst registry = jsforce.registry;\n\ntype CliCommand = {\n  connection?: string;\n  username?: string;\n  password?: string;\n  loginUrl?: string;\n  sandbox?: boolean;\n  evalScript?: string;\n} & Command\n\n/**\n *\n */\nexport class Cli {\n  _repl: Repl = new Repl(this);\n  _conn: Connection = new Connection();\n  _connName: string | undefined = undefined;\n  _outputEnabled: boolean = true;\n  _defaultLoginUrl: string | undefined = undefined;\n\n  /**\n   *\n   */\n  readCommand(): CliCommand {\n    return new Command()\n      .option('-u, --username [username]', 'Salesforce username')\n      .option(\n        '-p, --password [password]',\n        'Salesforce password (and security token, if available)',\n      )\n      .option(\n        '-c, --connection [connection]',\n        'Connection name stored in connection registry',\n      )\n      .option('-l, --loginUrl [loginUrl]', 'Salesforce login url')\n      .option('--sandbox', 'Login to Salesforce sandbox')\n      .option('-e, --evalScript [evalScript]', 'Script to evaluate')\n      .version(version)\n      .parse(process.argv);\n  }\n\n  async start() {\n    const program = this.readCommand();\n    this._outputEnabled = !program.evalScript;\n    try {\n      await this.connect(program);\n      if (program.evalScript) {\n        this._repl.start({\n          interactive: false,\n          evalScript: program.evalScript,\n        });\n      } else {\n        this._repl.start();\n      }\n    } catch (err) {\n      console.error(err);\n      process.exit();\n    }\n  }\n\n  getCurrentConnection() {\n    return this._conn;\n  }\n\n  print(...args: any[]) {\n    if (this._outputEnabled) {\n      console.log(...args);\n    }\n  }\n\n  saveCurrentConnection() {\n    if (this._connName) {\n      const conn = this._conn;\n      const connName = this._connName;\n      const connConfig = {\n        oauth2: conn.oauth2\n          ? {\n              clientId: conn.oauth2.clientId || undefined,\n              clientSecret: conn.oauth2.clientSecret || undefined,\n              redirectUri: conn.oauth2.redirectUri || undefined,\n              loginUrl: conn.oauth2.loginUrl || undefined,\n            }\n          : undefined,\n        accessToken: conn.accessToken || undefined,\n        instanceUrl: conn.instanceUrl || undefined,\n        refreshToken: conn.refreshToken || undefined,\n      };\n      registry.saveConnectionConfig(connName, connConfig);\n    }\n  }\n\n  setLoginServer(loginServer: Optional<string>) {\n    if (!loginServer) {\n      return;\n    }\n    if (loginServer === 'production') {\n      this._defaultLoginUrl = 'https://login.salesforce.com';\n    } else if (loginServer === 'sandbox') {\n      this._defaultLoginUrl = 'https://test.salesforce.com';\n    } else if (!loginServer.startsWith('https://')) {\n      this._defaultLoginUrl = 'https://' + loginServer;\n    } else {\n      this._defaultLoginUrl = loginServer;\n    }\n    this.print(`Using \"${this._defaultLoginUrl}\" as default login URL.`);\n  }\n\n  /**\n   *\n   */\n  async connect(options: {\n    username?: string;\n    password?: string;\n    connection?: string;\n    loginUrl?: string;\n    sandbox?: boolean;\n  }) {\n    const loginServer = options.loginUrl\n      ? options.loginUrl\n      : options.sandbox\n      ? 'sandbox'\n      : null;\n    this.setLoginServer(loginServer);\n    this._connName = options.connection;\n    let connConfig = await registry.getConnectionConfig(options.connection);\n    let username = options.username;\n    if (!connConfig) {\n      connConfig = {};\n      if (this._defaultLoginUrl) {\n        connConfig.loginUrl = this._defaultLoginUrl;\n      }\n      username = username || options.connection;\n    }\n    this._conn = new Connection(connConfig);\n    const password = options.password;\n    if (username) {\n      await this.startPasswordAuth(username, password);\n      this.saveCurrentConnection();\n    } else {\n      if (this._connName && this._conn.accessToken) {\n        this._conn.on('refresh', () => {\n          this.print('Refreshing access token ... ');\n          this.saveCurrentConnection();\n        });\n        try {\n          const identity = await this._conn.identity();\n          this.print(`Logged in as : ${identity.username}`);\n        } catch (err) {\n          if (err instanceof Error) {\n            this.print(err.message);\n          }\n          if (this._conn.oauth2) {\n            throw new Error('Please re-authorize connection.');\n          } else {\n            await this.startPasswordAuth(this._connName);\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   *\n   */\n  async startPasswordAuth(username: string, password?: string) {\n    try {\n      await this.loginByPassword(username, password, 2);\n    } catch (err) {\n      if (err instanceof Error && err.message === 'canceled') {\n        console.error('Password authentication canceled: Not logged in');\n      } else {\n        throw err;\n      }\n    }\n  }\n\n  /**\n   *\n   */\n  async loginByPassword(\n    username: string,\n    password: string | undefined,\n    retryCount: number,\n  ): Promise<{ id: string }> {\n    if (password === '') {\n      throw new Error('canceled');\n    }\n    if (password == null) {\n      const pass = await this.promptPassword('Password: ');\n      return this.loginByPassword(username, pass, retryCount);\n    }\n    try {\n      const result = await this._conn.login(username, password);\n      this.print(`Logged in as : ${username}`);\n      return result;\n    } catch (err) {\n      if (err instanceof Error) {\n        console.error(err.message);\n      }\n      if (retryCount > 0) {\n        return this.loginByPassword(username, undefined, retryCount - 1);\n      } else {\n        throw new Error('canceled');\n      }\n    }\n  }\n\n  /**\n   *\n   */\n  async disconnect(connName?: string) {\n    const name = connName || this._connName;\n    if (name && (await registry.getConnectionConfig(name))) {\n      await registry.removeConnectionConfig(name);\n      this.print(`Disconnect connection '${name}'`);\n    }\n    this._connName = undefined;\n    this._conn = new Connection();\n  }\n\n  /**\n   *\n   */\n  async authorize(clientName: string) {\n    const name = clientName || 'default';\n    const oauth2Config = await registry.getClientConfig(name);\n    if (!oauth2Config?.clientId) {\n      if (name === 'default' || name === 'sandbox') {\n        this.print(\n          'No client information registered. Downloading JSforce default client information...',\n        );\n        return this.downloadDefaultClientInfo(name);\n      }\n      throw new Error(\n        `No OAuth2 client information registered : '${name}'. Please register client info first.`,\n      );\n    }\n    const oauth2 = new OAuth2(oauth2Config);\n    const verifier = base64url.encode(crypto.randomBytes(32));\n    const challenge = base64url.encode(\n      crypto.createHash('sha256').update(verifier).digest(),\n    );\n    const state = base64url.encode(crypto.randomBytes(32));\n    const authzUrl = oauth2.getAuthorizationUrl({\n      code_challenge: challenge,\n      state,\n    });\n    this.print('Opening authorization page in browser...');\n    this.print(`URL: ${authzUrl}`);\n    this.openUrl(authzUrl);\n    const params = await this.waitCallback(oauth2Config.redirectUri, state);\n    if (!params.code) {\n      throw new Error('No authorization code returned.');\n    }\n    if (params.state !== state) {\n      throw new Error('Invalid state parameter returned.');\n    }\n    this._conn = new Connection({ oauth2 });\n    this.print(\n      'Received authorization code. Please close the opened browser window.',\n    );\n    await this._conn.authorize(params.code, { code_verifier: verif