A JavaScript toolkit for working with Salesforce metadata. Built to support the SFDX deploy and retrieve experience in the Salesforce VS Code Extensions, CLI plugins, and other tools working with metadata.
- Resolve Salesforce metadata files into JavaScript objects
- Parse and generate manifest files
- Convert source files between SFDX File Formats
- Generate metadata packages with the option to automatically create a zip file
- Deploy and retrieve metadata with an org
- An index to reference available metadata types.
- Utilize promises with
async/await
syntax
Install the package:
npm install @salesforce/source-deploy-retrieve
Examples:
const { ComponentSet } = require('@salesforce/source-deploy-retrieve');
// Deploy a local set of Apex classes to an org
const deployResult = await ComponentSet
.fromSource('/dev/MyProject/force-app/main/default/classes')
.deploy({ usernameOrConnection: 'user@example.com' })
.start();
// Retrieve metadata defined in a manifest file
const retrieveResult = await ComponentSet
.fromManifest('/dev/my-project/manifest/package.xml')
.retrieve({
usernameOrConnection: 'user@example.com'
output: '/dev/retrieve-result'
})
.start();
// Search for a particular CustomObject
const myObject = ComponentSet
.fromSource([
'/dev/my-project/force-app',
'/dev/my-project/force-app-2'
])
.find(component => {
return component.fullName === 'MyObject__c' && component.type.name === 'CustomObject')
});
See the examples folder for more code samples and guides. See the API documentation for details on how to effectively use and integrate SDR.
See CONTRIBUTING.md for details on how to contribute to the library.
See developing.md for details on building and testing the library locally.
SDR publishes when changes are merged into main
. The version is bumped per the rules of the release orb and standard-version.