jsforce2
Version:
Salesforce API Library for JavaScript
404 lines (373 loc) • 36.1 kB
JavaScript
(function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g=(g.jsforce||(g.jsforce = {}));g=(g.modules||(g.modules = {}));g=(g.api||(g.api = {}));g.Soap = f()}})(function(){var define,module,exports;return (function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(require,module,exports){
/**
* @file Salesforce SOAP API
* @author Shinichi Tomita <shinichi.tomita@gmail.com>
*/
;
var _ = window.jsforce.require('lodash/core');
var jsforce = window.jsforce.require('./core');
var SOAP = window.jsforce.require('./soap');
/**
* API class for Partner SOAP call
*
* @class
* @param {Connection} conn - Connection
*/
var SoapApi = module.exports = function(conn) {
this._conn = conn;
};
/**
* Call SOAP Api (Partner) endpoint
* @private
*/
SoapApi.prototype._invoke = function(method, message, schema, callback) {
var soapEndpoint = new SOAP(this._conn, {
xmlns: "urn:partner.soap.sforce.com",
endpointUrl: this._conn.instanceUrl + "/services/Soap/u/" + this._conn.version
});
return soapEndpoint.invoke(method, message, { result: schema }).then(function(res) {
return res.result;
}).thenCall(callback);
};
/* */
var Schemas = {};
/**
* @typedef SoapApi~LeadConvert
* @prop {String} convertedStatus - Status of converted lead
* @prop {String} leadId - Lead record Id to convert
* @prop {String} [accountId] - Account record Id to assign the converted record
* @prop {String} [contactId] - Contact record Id to assign the converted record
* @prop {Boolean} [doNotCreateOpportunity] - True if you don't want to create a new opportunity
* @prop {String} [opportunityName] - Name of opportunity to create
* @prop {Boolean} [overwriteLeadSource] - True if overwriting lead source
* @prop {String} [ownerId] - Owner Id
* @prop {Boolean} [sendNotificationEmail] - True if send notification email
*/
/**
* @typedef SoapApi~LeadConvertResult
* @prop {String} leadId - Lead record Id to convert
* @prop {String} [accountId] - Account record Id of converted lead
* @prop {String} [contactId] - Contact record Id of converted lead
* @prop {String} [opportunityId] - Opportunity record Id created in conversion
* @prop {Boolean} success - True if successfully converted
* @prop {Array.<Object>} errors - Error
*/
/**
* Converts a Lead into an Account, Contact, or (optionally) an Opportunity.
*
* @param {SoapApi~LeadConvert|Array.<SoapApi~LeadConvert>} leadConverts
* @param {Callback.<SoapApi~LeadConvertResult|Array.<SoapApi~LeadConvertResult>>} [callback] - Callback function
* @returns {Promise.<SoapApi~LeadConvertResult|Array.<SoapApi~LeadConvertResult>>}
*/
SoapApi.prototype.convertLead = function(leadConverts, callback) {
var schema = _.isArray(leadConverts) ? [ Schemas.LeadConvertResult ] : Schemas.LeadConvertResult;
return this._invoke("convertLead", { leadConverts: leadConverts }, schema, callback);
};
Schemas.LeadConvertResult = {
success: 'boolean',
errors: [],
leadId: 'string',
accountId: 'string',
contactId: 'string',
opportunityId: 'string'
};
/**
* @typedef SoapApi~MergeRequest
* @prop {Object} masterRecord - The merge destination record
* @prop {Array.<String>} recordToMergeIds - Ids of records to merge
*/
/**
* @typedef SoapApi~MergeResult
* @prop {Boolean} success - True if successfully merged
* @prop {Array.<Object>} errors - Error
* @prop {String} id - ID of the master record
* @prop {Array.<String>} mergedRecordIds - ID of the records that were merged into the master record
* @prop {Array.<String>} updatedRelatedIds - ID of all related records that were moved (re-parented) as a result of the merge
*/
/**
* Merge up to three records into one
*
* @param {SoapApi~MergeRequest|Array.<SoapApi~MergeRequest>} mergeRequests
* @param {Callback.<SoapApi~MergeResult|Array.<SoapApi~MergeResult>>} [callback] - Callback function
* @returns {Promise.<SoapApi~MergeResult|Array.<SoapApi~MergeResult>>}
*/
SoapApi.prototype.merge = function(mergeRequests, callback) {
var schema = _.isArray(mergeRequests) ? [ Schemas.MergeResult ] : Schemas.MergeResult;
return this._invoke("merge", { mergeRequests: mergeRequests }, schema, callback);
};
Schemas.MergeResult = {
success: 'boolean',
errors: [],
id: 'string',
mergedRecordIds: ['string'],
updatedRelatedIds: ['string']
};
/**
* @typedef SoapApi~EmptyRecycleBinResult
* @prop {String} id - ID of an sObject that you attempted to delete from the Recycle Bin
* @prop {Boolean} success - Whether the call succeeded (true) or not (false) for this record
* @prop {Array.<Object>} errors - Errors
*/
/**
* Delete records from the recycle bin immediately
*
* @param {Array.<String>} ids - Record ids to empty from recycle bin
* @param {Callback.<Array.<SoapApi~EmptyRecycleBinResult>>} [callback] - Callback function
* @returns {Promise.<Array.<SoapApi~EmptyRecycleBinResult>>}
*/
SoapApi.prototype.emptyRecycleBin = function(ids, callback) {
return this._invoke("emptyRecycleBin", { ids: ids }, [ Schemas.EmptyRecycleBinResult ], callback);
};
Schemas.EmptyRecycleBinResult = {
id: 'string',
success: 'boolean',
errors: []
};
/**
* @typedef SoapApi~DescribeTabSetResult
* @prop {String} label - The display label for this standard or custom app
* @prop {String} logoUrl - A fully qualified URL to the logo image associated with the standard or custom app
* @prop {String} namespace - Namespace of application package
* @prop {Boolean} selected - If true, then this standard or custom app is the user’s currently selected app
* @prop {Array.<SoapApi~DescribeTab>} tabs - An array of tabs that are displayed for the specified standard app or custom app
*/
/**
* @typedef SoapApi~DescribeTab
* @prop {Array.<Object>} colors - Array of color information used for a tab
* @prop {Boolean} custom - true if this is a custom tab
* @prop {String} iconUrl - The URL for the main 32 x 32 pixel icon for a tab
* @prop {Array.<Object>} icons - Array of icon information used for a tab
* @prop {String} label - The display label for this tab
* @prop {String} miniIconUrl - The URL for the 16 x 16 pixel icon that represents a tab
* @prop {String} name - The API name of the tab
* @prop {String} sobjectName - The name of the sObject that is primarily displayed on this tab
* @prop {String} url - A fully qualified URL for viewing this tab
*/
/**
* Returns information about the standard and custom apps available to the logged-in user
*
* @param {Callback.<Array.<SoapApi~DescribeTabSetResult>>} [callback] - Callback function
* @returns {Promise.<Array.<SoapApi~DescribeTabSetResult>>}
*/
SoapApi.prototype.describeTabs = function(callback) {
return this._invoke("describeTabs", {}, [ Schemas.DescribeTabSetResult ], callback);
};
Schemas.DescribeTabSetResult = {
label: 'string',
logoUrl: 'string',
namespace: 'string',
selected: 'boolean',
tabs: [{
colors: [{
theme: 'string',
color: 'string',
context: 'string'
}],
iconUrl: 'string',
icons: [{
theme: 'string',
height: 'number',
width: 'number',
url: 'string',
contentType: 'string'
}],
label: 'string',
custom: 'boolean',
miniIconUrl: 'string',
name: 'string',
sobjectName: 'string',
url: 'string'
}]
};
/**
* Retrieves the current system timestamp (Coordinated Universal Time (UTC) time zone) from the API
*
* @typedef SoapApi~ServerTimestampResult
* @prop {String} timestamp - Timestamp
*/
/**
* @param {Callback.<SoapApi~ServerTimestampResult>} [callback] - Callback function
* @returns {Promise.<SoapApi~ServerTimestampResult>}
*/
SoapApi.prototype.getServerTimestamp = function(callback) {
return this._invoke("getServerTimestamp", {}, Schemas.GetServerTimestampResult, callback);
};
Schemas.GetServerTimestampResult = {
timestamp: 'string'
};
/**
* @typedef SoapApi~UserInfoResult
* @prop {Boolean} accessibilityMode
* @prop {String} currencySymbol
* @prop {Number} orgAttachmentFileSizeLimit
* @prop {String} orgDefaultCurrencyIsoCode
* @prop {String} orgDisallowHtmlAttachments
* @prop {Boolean} orgHasPersonAccounts
* @prop {String} organizationId
* @prop {Boolean} organizationMultiCurrency
* @prop {String} organizationName
* @prop {String} profileId
* @prop {String} roleId
* @prop {Number} sessionSecondsValid
* @prop {String} userDefaultCurrencyIsoCode
* @prop {String} userEmail
* @prop {String} userFullName
* @prop {String} userId
* @prop {String} userLanguage
* @prop {String} userLocale
* @prop {String} userName
* @prop {String} userTimeZone
* @prop {String} userType
* @prop {String} userUiSkin
*/
/**
* Retrieves personal information for the user associated with the current session
*
* @param {Callback.<SoapApi~UserInfoResult>} [callback] - Callback function
* @returns {Promise.<SoapApi~UserInfoResult>}
*/
SoapApi.prototype.getUserInfo = function(callback) {
return this._invoke("getUserInfo", {}, Schemas.GetUserInfoResult, callback);
};
Schemas.GetUserInfoResult = {
accessibilityMode: 'boolean',
currencySymbol: 'string',
orgAttachmentFileSizeLimit: 'number',
orgDefaultCurrencyIsoCode: 'string',
orgDisallowHtmlAttachments: 'boolean',
orgHasPersonAccounts: 'boolean',
organizationId: 'string',
organizationMultiCurrency: 'boolean',
organizationName: 'string',
profileId: 'string',
roleId: 'string',
sessionSecondsValid: 'number',
userDefaultCurrencyIsoCode: 'string',
userEmail: 'string',
userFullName: 'string',
userId: 'string',
userLanguage: 'string',
userLocale: 'string',
userName: 'string',
userTimeZone: 'string',
userType: 'string',
userUiSkin: 'string'
};
/**
* Sets the specified user’s password to the specified value
*
* @param {String} userId - User Id to set password
* @param {String} password - New password
* @param {Callback.<String>} [callback] - Callback function
* @returns {Promise.<String>}
*/
SoapApi.prototype.setPassword = function(userId, password, callback) {
return this._invoke("setPassword", { userId: userId, password: password }, callback);
};
/**
* @typedef SoapApi~ResetPasswordResult
* @prop {String} password
*/
/**
* Resets the specified user’s password
*
* @param {String} userId - User Id to set password
* @param {String} password - New password
* @param {Callback.<SoapApi~ResetPasswordResult>} [callback] - Callback function
* @returns {Promise.<SoapApi~ResetPasswordResult>}
*/
SoapApi.prototype.resetPassword = function(userId, callback) {
return this._invoke("resetPassword", { userId: userId }, callback);
};
/**
* Adds one or more new records to your organization’s data
*
* @param {Array.<Object>} sObjects - Records to insert
* @param {Callback.<SoapApi~SaveResult>} [callback] - Callback function
* @returns {Promise.<SoapApi~SaveResult>}
*/
SoapApi.prototype.create = function(sObjects, callback) {
var schema = _.isArray(sObjects) ? [ Schemas.SaveResult ] : Schemas.SaveResult;
var args = {
'@xmlns' : 'urn:partner.soap.sforce.com',
'@xmlns:ns1' : 'sobject.partner.soap.sforce.com',
'ns1:sObjects' : sObjects
};
return this._invoke("create", args, schema, callback);
};
/**
* Updates one or more existing records in your organization’s data.
*
* @param {Array.<Object>} sObjects - Records to update
* @param {Callback.<SoapApi~SaveResult>} [callback] - Callback function
* @returns {Promise.<SoapApi~SaveResult>}
*/
SoapApi.prototype.update = function(sObjects, callback) {
var schema = _.isArray(sObjects) ? [ Schemas.SaveResult ] : Schemas.SaveResult;
var args = {
'@xmlns' : 'urn:partner.soap.sforce.com',
'@xmlns:ns1' : 'sobject.partner.soap.sforce.com',
'ns1:sObjects' : sObjects
};
return this._invoke("update", args, schema, callback);
};
Schemas.SaveResult = {
success: 'boolean',
errors: [],
id: 'string'
};
/**
* Creates new records and updates existing records in your organization’s data.
*
* @param {Array.<Object>} sObjects - Records to upsert
* @param {Callback.<SoapApi~UpsertResult>} [callback] - Callback function
* @returns {Promise.<SoapApi~UpsertResult>}
*/
SoapApi.prototype.upsert = function(externalIdFieldName, sObjects, callback) {
var schema = _.isArray(sObjects) ? [ Schemas.UpsertResult ] : Schemas.UpsertResult;
var args = {
'@xmlns' : 'urn:partner.soap.sforce.com',
'@xmlns:ns1' : 'sobject.partner.soap.sforce.com',
'ns1:externalIDFieldName' : externalIdFieldName,
'ns1:sObjects' : sObjects
};
return this._invoke("upsert", args, schema, callback);
};
Schemas.UpsertResult = {
created: 'boolean',
success: 'boolean',
errors: [],
id: 'string'
};
/**
* Deletes one or more records from your organization’s data
*
* @param {Array.<Object>} ids - Id of records to delete
* @param {Callback.<SoapApi~DeleteResult>} [callback] - Callback function
* @returns {Promise.<SoapApi~DeleteResult>}
*/
SoapApi.prototype.delete = function(ids, callback) {
var schema = _.isArray(ids) ? [ Schemas.DeleteResult ] : Schemas.DeleteResult;
var args = {
'@xmlns' : 'urn:partner.soap.sforce.com',
'@xmlns:ns1' : 'sobject.partner.soap.sforce.com',
'ns1:ids' : ids
};
return this._invoke("delete", args, schema, callback);
};
Schemas.DeleteResult = {
success: 'boolean',
errors: [],
id: 'string'
};
/*--------------------------------------------*/
/*
* Register hook in connection instantiation for dynamically adding this API module features
*/
jsforce.on('connection:new', function(conn) {
conn.soap = new SoapApi(conn);
});
module.exports = SoapApi;
},{}]},{},[1])(1)
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","lib/api/soap.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c=\"function\"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error(\"Cannot find module '\"+i+\"'\");throw a.code=\"MODULE_NOT_FOUND\",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u=\"function\"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()","/**\n * @file Salesforce SOAP API\n * @author Shinichi Tomita <shinichi.tomita@gmail.com>\n */\n\n'use strict';\n\nvar _ = window.jsforce.require('lodash/core');\nvar jsforce = window.jsforce.require('./core');\nvar SOAP = window.jsforce.require('./soap');\n\n/**\n * API class for Partner SOAP call\n *\n * @class\n * @param {Connection} conn - Connection\n */\nvar SoapApi = module.exports = function(conn) {\n  this._conn = conn;\n};\n\n/**\n * Call SOAP Api (Partner) endpoint\n * @private\n */\nSoapApi.prototype._invoke = function(method, message, schema, callback) {\n  var soapEndpoint = new SOAP(this._conn, {\n    xmlns: \"urn:partner.soap.sforce.com\",\n    endpointUrl: this._conn.instanceUrl + \"/services/Soap/u/\" + this._conn.version\n  });\n  return soapEndpoint.invoke(method, message, { result: schema }).then(function(res) {\n    return res.result;\n  }).thenCall(callback);\n};\n\n\n/* */\nvar Schemas = {};\n\n/**\n * @typedef SoapApi~LeadConvert\n * @prop {String} convertedStatus - Status of converted lead\n * @prop {String} leadId - Lead record Id to convert\n * @prop {String} [accountId] - Account record Id to assign the converted record\n * @prop {String} [contactId] - Contact record Id to assign the converted record\n * @prop {Boolean} [doNotCreateOpportunity] - True if you don't want to create a new opportunity\n * @prop {String} [opportunityName] - Name of opportunity to create\n * @prop {Boolean} [overwriteLeadSource] - True if overwriting lead source\n * @prop {String} [ownerId] - Owner Id\n * @prop {Boolean} [sendNotificationEmail] - True if send notification email\n */\n/**\n * @typedef SoapApi~LeadConvertResult\n * @prop {String} leadId - Lead record Id to convert\n * @prop {String} [accountId] - Account record Id of converted lead\n * @prop {String} [contactId] - Contact record Id of converted lead\n * @prop {String} [opportunityId] - Opportunity record Id created in conversion\n * @prop {Boolean} success - True if successfully converted\n * @prop {Array.<Object>} errors - Error\n */\n/**\n * Converts a Lead into an Account, Contact, or (optionally) an Opportunity.\n *\n * @param {SoapApi~LeadConvert|Array.<SoapApi~LeadConvert>} leadConverts\n * @param {Callback.<SoapApi~LeadConvertResult|Array.<SoapApi~LeadConvertResult>>} [callback] - Callback function\n * @returns {Promise.<SoapApi~LeadConvertResult|Array.<SoapApi~LeadConvertResult>>}\n */\nSoapApi.prototype.convertLead = function(leadConverts, callback) {\n  var schema = _.isArray(leadConverts) ? [ Schemas.LeadConvertResult ] : Schemas.LeadConvertResult;\n  return this._invoke(\"convertLead\", { leadConverts: leadConverts }, schema, callback);\n};\nSchemas.LeadConvertResult = {\n  success: 'boolean',\n  errors: [],\n  leadId: 'string',\n  accountId: 'string',\n  contactId: 'string',\n  opportunityId: 'string'\n};\n\n/**\n * @typedef SoapApi~MergeRequest\n * @prop {Object} masterRecord - The merge destination record\n * @prop {Array.<String>} recordToMergeIds - Ids of records to merge\n */\n/**\n * @typedef SoapApi~MergeResult\n * @prop {Boolean} success - True if successfully merged\n * @prop {Array.<Object>} errors - Error\n * @prop {String} id - ID of the master record\n * @prop {Array.<String>} mergedRecordIds - ID of the records that were merged into the master record\n * @prop {Array.<String>} updatedRelatedIds - ID of all related records that were moved (re-parented) as a result of the merge\n */\n\n/**\n * Merge up to three records into one\n *\n * @param {SoapApi~MergeRequest|Array.<SoapApi~MergeRequest>} mergeRequests\n * @param {Callback.<SoapApi~MergeResult|Array.<SoapApi~MergeResult>>} [callback] - Callback function\n * @returns {Promise.<SoapApi~MergeResult|Array.<SoapApi~MergeResult>>}\n */\nSoapApi.prototype.merge = function(mergeRequests, callback) {\n  var schema = _.isArray(mergeRequests) ? [ Schemas.MergeResult ] : Schemas.MergeResult;\n  return this._invoke(\"merge\", { mergeRequests: mergeRequests }, schema, callback);\n};\nSchemas.MergeResult = {\n  success: 'boolean',\n  errors: [],\n  id: 'string',\n  mergedRecordIds: ['string'],\n  updatedRelatedIds: ['string']\n};\n\n\n/**\n * @typedef SoapApi~EmptyRecycleBinResult\n * @prop {String} id - ID of an sObject that you attempted to delete from the Recycle Bin\n * @prop {Boolean} success - Whether the call succeeded (true) or not (false) for this record\n * @prop {Array.<Object>} errors - Errors\n */\n/**\n * Delete records from the recycle bin immediately\n *\n * @param {Array.<String>} ids - Record ids to empty from recycle bin\n * @param {Callback.<Array.<SoapApi~EmptyRecycleBinResult>>} [callback] - Callback function\n * @returns {Promise.<Array.<SoapApi~EmptyRecycleBinResult>>}\n */\nSoapApi.prototype.emptyRecycleBin = function(ids, callback) {\n  return this._invoke(\"emptyRecycleBin\", { ids: ids }, [ Schemas.EmptyRecycleBinResult ], callback);\n};\nSchemas.EmptyRecycleBinResult = {\n  id: 'string',\n  success: 'boolean',\n  errors: []\n};\n\n\n/**\n * @typedef SoapApi~DescribeTabSetResult\n * @prop {String} label - The display label for this standard or custom app\n * @prop {String} logoUrl - A fully qualified URL to the logo image associated with the standard or custom app\n * @prop {String} namespace - Namespace of application package\n * @prop {Boolean} selected - If true, then this standard or custom app is the user’s currently selected app\n * @prop {Array.<SoapApi~DescribeTab>} tabs - An array of tabs that are displayed for the specified standard app or custom app\n */\n/**\n * @typedef SoapApi~DescribeTab\n * @prop {Array.<Object>} colors - Array of color information used for a tab\n * @prop {Boolean} custom - true if this is a custom tab\n * @prop {String} iconUrl - The URL for the main 32 x 32 pixel icon for a tab\n * @prop {Array.<Object>} icons - Array of icon information used for a tab\n * @prop {String} label - The display label for this tab\n * @prop {String} miniIconUrl - The URL for the 16 x 16 pixel icon that represents a tab\n * @prop {String} name - The API name of the tab\n * @prop {String} sobjectName - The name of the sObject that is primarily displayed on this tab\n * @prop {String} url - A fully qualified URL for viewing this tab\n */\n/**\n * Returns information about the standard and custom apps available to the logged-in user\n *\n * @param {Callback.<Array.<SoapApi~DescribeTabSetResult>>} [callback] - Callback function\n * @returns {Promise.<Array.<SoapApi~DescribeTabSetResult>>}\n */\nSoapApi.prototype.describeTabs = function(callback) {\n  return this._invoke(\"describeTabs\", {}, [ Schemas.DescribeTabSetResult ], callback);\n};\nSchemas.DescribeTabSetResult = {\n  label: 'string',\n  logoUrl: 'string',\n  namespace: 'string',\n  selected: 'boolean',\n  tabs: [{\n    colors: [{\n      theme: 'string',\n      color: 'string',\n      context: 'string'\n    }],\n    iconUrl: 'string',\n    icons: [{\n      theme: 'string',\n      height: 'number',\n      width: 'number',\n      url: 'string',\n      contentType: 'string'\n    }],\n    label: 'string',\n    custom: 'boolean',\n    miniIconUrl: 'string',\n    name: 'string',\n    sobjectName: 'string',\n    url: 'string'\n  }]\n};\n\n/**\n * Retrieves the current system timestamp (Coordinated Universal Time (UTC) time zone) from the API\n *\n * @typedef SoapApi~ServerTimestampResult\n * @prop {String} timestamp - Timestamp\n */\n/**\n * @param {Callback.<SoapApi~ServerTimestampResult>} [callback] - Callback function\n * @returns {Promise.<SoapApi~ServerTimestampResult>}\n */\nSoapApi.prototype.getServerTimestamp = function(callback) {\n  return this._invoke(\"getServerTimestamp\", {}, Schemas.GetServerTimestampResult, callback);\n};\nSchemas.GetServerTimestampResult = {\n  timestamp: 'string'\n};\n\n/**\n * @typedef SoapApi~UserInfoResult\n * @prop {Boolean} accessibilityMode\n * @prop {String} currencySymbol\n * @prop {Number} orgAttachmentFileSizeLimit\n * @prop {String} orgDefaultCurrencyIsoCode\n * @prop {String} orgDisallowHtmlAttachments\n * @prop {Boolean} orgHasPersonAccounts\n * @prop {String} organizationId\n * @prop {Boolean} organizationMultiCurrency\n * @prop {String} organizationName\n * @prop {String} profileId\n * @prop {String} roleId\n * @prop {Number} sessionSecondsValid\n * @prop {String} userDefaultCurrencyIsoCode\n * @prop {String} userEmail\n * @prop {String} userFullName\n * @prop {String} userId\n * @prop {String} userLanguage\n * @prop {String} userLocale\n * @prop {String} userName\n * @prop {String} userTimeZone\n * @prop {String} userType\n * @prop {String} userUiSkin\n */\n/**\n * Retrieves personal information for the user associated with the current session\n *\n * @param {Callback.<SoapApi~UserInfoResult>} [callback] - Callback function\n * @returns {Promise.<SoapApi~UserInfoResult>}\n */\nSoapApi.prototype.getUserInfo = function(callback) {\n  return this._invoke(\"getUserInfo\", {}, Schemas.GetUserInfoResult, callback);\n};\nSchemas.GetUserInfoResult = {\n  accessibilityMode: 'boolean',\n  currencySymbol: 'string',\n  orgAttachmentFileSizeLimit: 'number',\n  orgDefaultCurrencyIsoCode: 'string',\n  orgDisallowHtmlAttachments: 'boolean',\n  orgHasPersonAccounts: 'boolean',\n  organizationId: 'string',\n  organizationMultiCurrency: 'boolean',\n  organizationName: 'string',\n  profileId: 'string',\n  roleId: 'string',\n  sessionSecondsValid: 'number',\n  userDefaultCurrencyIsoCode: 'string',\n  userEmail: 'string',\n  userFullName: 'string',\n  userId: 'string',\n  userLanguage: 'string',\n  userLocale: 'string',\n  userName: 'string',\n  userTimeZone: 'string',\n  userType: 'string',\n  userUiSkin: 'string'\n};\n\n/**\n * Sets the specified user’s password to the specified value\n *\n * @param {String} userId - User Id to set password\n * @param {String} password - New password\n * @param {Callback.<String>} [callback] - Callback function\n * @returns {Promise.<String>}\n */\nSoapApi.prototype.setPassword = function(userId, password, callback) {\n  return this._invoke(\"setPassword\", { userId: userId, password: password }, callback);\n};\n\n/**\n * @typedef SoapApi~ResetPasswordResult\n * @prop {String} password\n */\n/**\n * Resets the specified user’s password\n *\n * @param {String} userId - User Id to set password\n * @param {String} password - New password\n * @param {Callback.<SoapApi~ResetPasswordResult>} [callback] - Callback function\n * @returns {Promise.<SoapApi~ResetPasswordResult>}\n */\nSoapApi.prototype.resetPassword = function(userId, callback) {\n  return this._invoke(\"resetPassword\", { userId: userId }, callback);\n};\n\n/**\n * Adds one or more new records to your organization’s data\n *\n * @param {Array.<Object>} sObjects - Records to insert\n * @param {Callback.<SoapApi~SaveResult>} [callback] - Callback function\n * @returns {Promise.<SoapApi~SaveResult>}\n */\nSoapApi.prototype.create = function(sObjects, callback) {\n  var schema = _.isArray(sObjects) ? [ Schemas.SaveResult ] : Schemas.SaveResult;\n  var args = {\n    '@xmlns' : 'urn:partner.soap.sforce.com',\n    '@xmlns:ns1' : 'sobject.partner.soap.sforce.com',\n    'ns1:sObjects' : sObjects\n  };\n  return this._invoke(\"create\", args, schema, callback);\n};\n\n/**\n * Updates one or more existing records in your organization’s data.\n *\n * @param {Array.<Object>} sObjects - Records to update\n * @param {Callback.<SoapApi~SaveResult>} [callback] - Callback function\n * @returns {Promise.<SoapApi~SaveResult>}\n */\nSoapApi.prototype.update = function(sObjects, callback) {\n  var schema = _.isArray(sObjects) ? [ Schemas.SaveResult ] : Schemas.SaveResult;\n  var args = {\n    '@xmlns' : 'urn:partner.soap.sforce.com',\n    '@xmlns:ns1' : 'sobject.partner.soap.sforce.com',\n    'ns1:sObjects' : sObjects\n  };\n  return this._invoke(\"update\", args, schema, callback);\n};\n\nSchemas.SaveResult = {\n  success: 'boolean',\n  errors: [],\n  id: 'string'\n};\n\n/**\n * Creates new records and updates existing records in your organization’s data.\n *\n * @param {Array.<Object>} sObjects - Records to upsert\n * @param {Callback.<SoapApi~UpsertResult>} [callback] - Callback function\n * @returns {Promise.<SoapApi~UpsertResult>}\n */\nSoapApi.prototype.upsert = function(externalIdFieldName, sObjects, callback) {\n  var schema = _.isArray(sObjects) ? [ Schemas.UpsertResult ] : Schemas.UpsertResult;\n  var args = {\n    '@xmlns' : 'urn:partner.soap.sforce.com',\n    '@xmlns:ns1' : 'sobject.partner.soap.sforce.com',\n    'ns1:externalIDFieldName' : externalIdFieldName,\n    'ns1:sObjects' : sObjects\n  };\n  return this._invoke(\"upsert\", args, schema, callback);\n};\n\nSchemas.UpsertResult = {\n  created: 'boolean',\n  success: 'boolean',\n  errors: [],\n  id: 'string'\n};\n\n/**\n * Deletes one or more records from your organization’s data\n *\n * @param {Array.<Object>} ids - Id of records to delete\n * @param {Callback.<SoapApi~DeleteResult>} [callback] - Callback function\n * @returns {Promise.<SoapApi~DeleteResult>}\n */\nSoapApi.prototype.delete = function(ids, callback) {\n  var schema = _.isArray(ids) ? [ Schemas.DeleteResult ] : Schemas.DeleteResult;\n  var args = {\n    '@xmlns' : 'urn:partner.soap.sforce.com',\n    '@xmlns:ns1' : 'sobject.partner.soap.sforce.com',\n    'ns1:ids' : ids\n  };\n  return this._invoke(\"delete\", args, schema, callback);\n};\n\nSchemas.DeleteResult = {\n  success: 'boolean',\n  errors: [],\n  id: 'string'\n};\n\n\n/*--------------------------------------------*/\n/*\n * Register hook in connection instantiation for dynamically adding this API module features\n */\njsforce.on('connection:new', function(conn) {\n  conn.soap = new SoapApi(conn);\n});\n\n\nmodule.exports = SoapApi;\n"]}