UNPKG

jsforce

Version:

Salesforce API Library for JavaScript

878 lines (874 loc) 84.9 kB
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