-
Notifications
You must be signed in to change notification settings - Fork 76
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1 changed file
with
46 additions
and
219 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,9 +1,5 @@ | ||
# ![SFDMU](src/images/logo-black.png) SFDX Data Move Utility (SFDMU) | ||
|
||
The Salesforce Data Move Utility (SFDMU) is a sophisticated SFDX Plugin designed to streamline the process of populating your Salesforce org (whether scratch, development, sandbox, or production) with data imported from another org or CSV files. It seamlessly supports Delete, Insert, Update, and Upsert operations across multiple related sObjects, enhancing the efficiency and accuracy of data migration tasks. | ||
|
||
**Use the [SFDMU GUI Application](https://github.com/forcedotcom/SFDX-Data-Move-Utility-Desktop-App) to easily configure and run migration jobs** | ||
|
||
[![Version](https://img.shields.io/npm/v/sfdmu.svg)](https://npmjs.org/package/sfdmu) | ||
[![Downloads/week](https://img.shields.io/npm/dw/sfdmu.svg)](https://npmjs.org/package/sfdmu) | ||
[![Downloads/total](https://img.shields.io/npm/dt/sfdmu.svg)](https://npmjs.org/package/sfdmu) | ||
|
@@ -12,234 +8,65 @@ The Salesforce Data Move Utility (SFDMU) is a sophisticated SFDX Plugin designed | |
[![License](https://img.shields.io/npm/l/sfdmu.svg)](https://github.com/forcedotcom/SFDX-Data-Move-Utility/blob/master/LICENSE.txt) | ||
[![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=flat-square)](http://makeapullrequest.com) | ||
|
||
**The documentation can be found here: [SFDMU Help Center](https://help.sfdmu.com/)** | ||
|
||
**Please, see the [User Support Policy](https://help.sfdmu.com/full-documentation/additional-information/support_policy) before opening cases** | ||
|
||
**Welcome to contribute to the SFDMU! Please, take some time to read our [Contribution Policy](https://help.sfdmu.com/full-documentation/additional-information/code_contribution_policy)** | ||
|
||
--- | ||
**Table of contents** | ||
|
||
- [Introduction to the SFDMU.](#introduction) | ||
- [Why should you use the SFDMU ?](#why-should-you-use-the-sfdmu) | ||
- [Use case.](#use-case) | ||
- [Watch the demo. The Plugin in action.](#watch-the-demo-the-plugin-in-action) | ||
- [Installation of the Plugin.](#installation-of-the-plugin) | ||
- [Configuring the migration job.](#configuring-the-migration-job) | ||
- [Running the migration job.](#running-the-migration-job) | ||
## Introduction. | ||
|
||
### The SFDX Data Move Utility (SFDMU) is the most modern and powerful plugin for **salesforce data migration**. | ||
### Makes data seeding extremely easy and fast. | ||
|
||
#### This Tool is the innovative and very handy alternative to the traditional salesforce data loader application as well as to the set of the force:data:tree commands. | ||
|
||
✔ The SFDMU will help you to populate your **Scratch / Dev / Sandbox / Prod** org with records imported from another org or CSV files.<br /> | ||
✔ It can perform all CRUD operations (**Insert** / **Update** / **Upsert** / **Delete**) also for **multiple related sObjects**.<br /> | ||
✔It's the comprehensive **All-In-One data migration solution** having a bulk of unique features have never provided before by any of the existing tools.<br /> | ||
✔ This Plugin is **approved and digitally signed** by Salesforce. | ||
|
||
### Why should you use the SFDMU ? | ||
|
||
#### The Plugin is equipped with an extended built-in functionality making migration of multiple related objects very handy: | ||
|
||
- It supports **direct Org-to-Org data migration** without having to deal with annoying intermediate CSV files. | ||
- Full support of CRUD operations: **Insert** / **Update** / **Upsert** / **Delete.** | ||
- Supports **import and export of CSV files**. | ||
- Supports **multiple object sets** allowing you to execute **multiple migration jobs in one run**. | ||
- Supports **simultaneous migration** **of multiple SObjects in one run.**. | ||
- Handles **complex circular references between multiple SObjects.** | ||
- **Simple and user-friendly configuration** just with a [single export.json file](https://help.sfdmu.com/full-documentation/configuration-and-running/full-exportjson-format) | ||
- **Can be run from a command line, can be easly integrated into any DevOps pipeline.** | ||
- Handles **self-referenced fields**, e.g. Account.ParentId. | ||
- Supports **External Id field of any type** even formula and auto-name fields, a field does not need to be defined as External Id. | ||
- Supports [**composite external Id keys.**](https://help.sfdmu.com/full-documentation/advanced-features/composite-external-id-keys) | ||
- Supports data [**migration preserving Record Type**](https://help.sfdmu.com/full-documentation/advanced-features/handling-record-type) for each record. | ||
- Supports [**fully** **customized Fields and Object Mapping**](https://help.sfdmu.com/full-documentation/advanced-features/fields-mapping). | ||
- Has the **built-in ETL features,** including [**customized Value Mapping**](https://help.sfdmu.com/full-documentation/advanced-features/values-mapping), [**expression-based records transformation**](https://help.sfdmu.com/full-documentation/add-on-api/records-transform-core-add-on-module). | ||
- Supports migration of **Person Accounts,** including **mixed account records of Busines and Person type**. | ||
- Supports **migration of** [**Salesforce Files**](https://help.sfdmu.com/full-documentation/add-on-api/export-file-core-add-on-module) as well as old-fashioned [**Notes** , **Attachments**](https://help.sfdmu.com/full-documentation/advanced-features/export-attachments-and-files), **including file binary data**. | ||
- Supports **record owner assignment,** including **option for a default owner assignment.** | ||
- Has the [**built-in** **data anonymization feature**](https://help.sfdmu.com/full-documentation/advanced-features/data-anonymization) to anonymize a sensitive source data (e.g. coming from Production org). | ||
- Supports binding of [**polymorphic lookup fields**](https://help.sfdmu.com/full-documentation/advanced-features/polymorphic-lookup-fields) (e.g. FeedItem.ParentId). | ||
- **Secured and safe**. All operations are performed on the client's machine, there is no cloud interaction, so all is completely safe. | ||
- **Fast performance.** Processes only a selected subset of records and fields that need to be inserted or updated and does not touch others. | ||
- **The core functionality can be extended by using the [Custom Add-On Api](https://help.sfdmu.com/full-documentation/add-on-api/custom-sfdmu-add-on-api)**. You can create your own Add-On for your special purposes. | ||
|
||
## Use case. | ||
|
||
Creating of a scratch org, dev org or even a sandbox today is a pretty fast and simple action. On the other hand the newly created organization has only metadata ready-to-use, has no real data that is always strongly required to develop and debug any Salesforce application. It makes no sense to manually create or load data traditional way (with the Salesforce Data Loader) for each new org because the data easily can be taken in whole or in part from production or from the sandbox and imported into the new organization. | ||
|
||
In some cases we already have the data, but it's only required to modify particular records or even fields without touching others. When a date model is complex and contains a large number of dependencies, it becomes a very hard and annoying task. | ||
|
||
Also there is a situation when as client you would like to keep the data model clean without creating external ID fields in the SObject, therefore your goal is to find some workaround to update records in your developer org from the existing source without adding new fields. | ||
|
||
Population of the RecordtypeId field is another quite difficult task, when ids are not consistent between environment. | ||
|
||
At current moment, there is no effective tool for both inserting and updating dependent objects based on any unique field used as External Id. In most cases people use Excel spreadsheets to build source tables and try to mix between them to get proper values for the lookup or master-detail fields. So filling out even a small number of objects turns into a huge pain... | ||
|
||
## Watch the demo. The Plugin in action. | ||
|
||
Running the Plugin from the command console / terminal: | ||
|
||
[![SFDMU DEMO](https://img.youtube.com/vi/KI_1vD93prA/hqdefault.jpg)](https://www.youtube.com/watch?v=KI_1vD93prA) | ||
|
||
|
||
## Installation of the Plugin. | ||
|
||
### Prerequisites. | ||
|
||
Before using the SFDMU you need to perform the usual procedure of installing SF CLI on your computer from here: | ||
|
||
```bash | ||
https://developer.salesforce.com/docs/atlas.en-us.sfdx_setup.meta/sfdx_setup/sfdx_setup_install_cli.htm | ||
``` | ||
|
||
### Installation of the SFDMU as a standard SFDX plugin: | ||
|
||
```bash | ||
# If you have an old version of the Plugin, uninstall it: | ||
$ sf plugins uninstall sfdmu | ||
|
||
# Install the latest version of the Plugin: | ||
$ sf plugins install sfdmu | ||
``` | ||
|
||
### Installation with the SFDMU source code: | ||
|
||
The Salesforce Data Move Utility (SFDMU) is an advanced SFDX plugin crafted to streamline data migration within various Salesforce environments, including scratch, development, sandbox, and production orgs. It facilitates the migration from other orgs or from CSV files, efficiently managing various data operations and supporting the migration of multiple related sObjects in a single run. | ||
|
||
**Useful Resources:** | ||
- [**SFDMU GUI Application:**](https://github.com/forcedotcom/SFDX-Data-Move-Utility-Desktop-App) Download and easily configure migration jobs. | ||
- [**SFDMU Help Center:**](https://help.sfdmu.com/) Access detailed documentation. | ||
- [**User Support Policy:**](https://help.sfdmu.com/full-documentation/additional-information/support_policy) Understand support guidelines before opening cases. | ||
- [**Contribution Policy:**](https://help.sfdmu.com/full-documentation/additional-information/code_contribution_policy) Guidelines for contributing to the SFDMU project. | ||
|
||
## Key Features: | ||
- **Comprehensive Migration Support:** Facilitates direct Org-to-Org data migration, avoiding the need for CSV intermediates, and fully supports CRUD operations: Insert, Upsert, Update, Delete. | ||
- **Multiple Objects and Relationships:** Manages migrations involving multiple object sets and handles complex relationships, including [circular references](https://help.sfdmu.com/examples/basic-examples#example-1-handling-circular-references). | ||
- **Ease of Use:** Simplifies the configuration process using a [single export.json file](https://help.sfdmu.com/full-configuration). | ||
- **Secure and Local:** Ensures data security as all operations are performed locally without cloud interactions. | ||
- **High Performance:** Optimizes processing by focusing on necessary data subsets. | ||
- **Extended Functionality:** Offers advanced features such as [custom field mapping](https://help.sfdmu.com/full-documentation/advanced-features/fields-mapping), [data anonymization](https://help.sfdmu.com/full-documentation/advanced-features/data-anonymization), and supports [composite external ID keys](https://help.sfdmu.com/full-documentation/advanced-features/composite-external-id-keys). | ||
|
||
## Installation Instructions: | ||
1. **Prepare Environment:** Install the Salesforce CLI as per the [official instructions](https://developer.salesforce.com/docs/atlas.en-us.sfdx_setup.meta/sfdx_setup/sfdx_setup_install_cli.htm). | ||
2. **Plugin Installation:** | ||
```bash | ||
# Uninstall old version, if any: | ||
$ sf plugins uninstall sfdmu | ||
|
||
# Install the latest version: | ||
$ sf plugins install sfdmu | ||
``` | ||
|
||
## Detailed Setup for Developers: | ||
For those needing customization or access to the source: | ||
```bash | ||
# If you have outdated source code already cloned and linked, go to the directory containing old Plugin source code and unlink it from the SFDX by typing: | ||
$ sf plugins unlink | ||
|
||
# Clone the source code: | ||
# Clone the repository: | ||
$ git clone https://github.com/forcedotcom/SFDX-Data-Move-Utility | ||
|
||
# Make the installation directory current: | ||
# Navigate to the directory and link it: | ||
$ cd SFDX-Data-Move-Utility | ||
|
||
# Install npm modules: | ||
$ npm install | ||
|
||
# Link the Plugin to the SFDX: | ||
$ sf plugins link | ||
``` | ||
|
||
**Watch the Demo:** | ||
- Experience the plugin in action [here](https://www.youtube.com/watch?v=KI_1vD93prA). | ||
|
||
## Configuring the migration job. | ||
|
||
### Example of basic configuration: upserting Accounts. | ||
|
||
Create a new **export.json** file with the following format: | ||
|
||
|
||
```json | ||
{ | ||
"objects": [ | ||
{ | ||
"query": "SELECT Id, Name FROM Account", | ||
"operation": "Upsert", | ||
"externalId": "Name" | ||
} | ||
] | ||
} | ||
``` | ||
|
||
<br /> | ||
|
||
|
||
### Example of advanced configuration: upserting multiple related SObjects. | ||
|
||
Assume you have the following data model **with complex circular relationships** between SObjects: | ||
|
||
![diagram](src/images/diagram.jpg) | ||
|
||
Let's say, each record has unique Name value, so you want to use Name field as an External Id field for all SObjects in that data model. | ||
|
||
You can Upsert all records preserving relationships between SObjects by creating an **export.json** file with the following format: | ||
|
||
```json | ||
{ | ||
"objects": [ | ||
{ | ||
"query": "SELECT Id, Phone, TestObject3__c FROM Account WHERE Name LIKE 'TEST_ACC_%'", | ||
"operation": "Upsert", | ||
"externalId": "Name" | ||
}, | ||
{ | ||
"query": "SELECT Id, Account__c, TestObject3__c, RecordTypeId FROM TestObject__c", | ||
"operation": "Upsert", | ||
"externalId": "Name" | ||
}, | ||
{ | ||
"query": "SELECT Id, Account__c, TestObject__c FROM TestObject2__c", | ||
"operation": "Upsert", | ||
"externalId": "Name" | ||
}, | ||
{ | ||
"query": "SELECT Id, TestObject2__c FROM TestObject3__c", | ||
"operation": "Upsert", | ||
"externalId": "Name" | ||
} | ||
] | ||
} | ||
``` | ||
|
||
**Note!** Object API names in **export.json** query expressions are **case-sensitive**, make sure they are spelled correctly if you want them to be imported. | ||
|
||
## Running the migration job. | ||
|
||
- Go to the directory where your **export.json** is located. | ||
|
||
- Use the following command to run a direct migration between source and target salesforce orgs: | ||
## Migration Configuration: | ||
For setting up a migration job, create an `export.json` file with specific data models and operations as detailed in the [full export.json format guide](https://help.sfdmu.com/full-documentation/configuration-and-running/full-exportjson-format). | ||
|
||
## Running the Migration Job: | ||
Execute migrations using commands tailored to your source and target, whether they are Salesforce orgs or CSV files: | ||
```bash | ||
$ sf sfdmu run --sourceusername [email protected] --targetusername [email protected] | ||
``` | ||
For CSV data interactions, modify the usernames as required for your specific scenario. | ||
|
||
- For import data from CSV files: | ||
|
||
```bash | ||
$ sf sfdmu run --sourceusername csvfile --targetusername [email protected] | ||
``` | ||
|
||
- For export data into CSV files: | ||
|
||
```bash | ||
$ sf sfdmu run --sourceusername [email protected] --targetusername csvfile | ||
``` | ||
|
||
<br /> | ||
|
||
##### Notes: | ||
|
||
- When installing and running the SFDMU on MacOS you can sometimes run into a permission issue. If so, just prepend all above command with "**sudo**", e.g.: | ||
|
||
*$ sudo sf plugins install sfdmu* | ||
|
||
- All examples are provided with the assumption that you are using the current **SF CLI** platform. However, if you are operating under the outdated **SFDX CLI** platform, you should replace ```sf``` by ```sfdx``` and ```:``` by a space, for example: | ||
```sfdx plugins:install sfdmu``` instead of ```sf plugins install sfdmu``` | ||
|
||
|
||
---- | ||
|
||
Documentation articles: | ||
|
||
- [Get Started with the SFDMU](https://help.sfdmu.com/get-started) | ||
|
||
- [Installation](https://help.sfdmu.com/installation) | ||
|
||
- [Configuration](https://help.sfdmu.com/configuration) | ||
|
||
- [Running](https://help.sfdmu.com/running) | ||
|
||
- [Debugging](https://help.sfdmu.com/debugging) | ||
|
||
- [Full export.json format](https://help.sfdmu.com/full-configuration) | ||
|
||
|
||
|
||
|
||
|
||
**Documentation Links:** | ||
- [**Getting Started**](https://help.sfdmu.com/get-started) | ||
- [**Installation Guide**](https://help.sfdmu.com/installation) | ||
- [**Configuration Tips**](https://help.sfdmu.com/configuration) | ||
- [**How to Run Migrations**](https://help.sfdmu.com/running) | ||
- [**Debugging Steps**](https://help.sfdmu.com/debugging) | ||
- [**Detailed export.json Format**](https://help.sfdmu.com/full-configuration) | ||
|
||
**Note:** If you encounter permission issues on MacOS, prepend your commands with `sudo`. Adjust CLI command syntax if using the older SFDX CLI platform. | ||
|