Salesforce学习之路(八)一次拉取多个文件或全部文件至本地

时间:2023-03-10 00:02:47
Salesforce学习之路(八)一次拉取多个文件或全部文件至本地

在开发中,经常会遇到本地工程错乱或者误操作导致本地本地项目被删除,此时利用SFDX: Retrieve Source from Org只会拉取新建并且名称相同的组件,若通过创建一个个文件,然后再拉取的方式,不免显得过于笨拙。

本人便踩过这个坑,这里分享一下个人的解决方案。


在我看来,从Org中一次拉取多个组件文件或者全部组件文件,有三种解决方案,下面一一叙述:

1. 利用manifest新建工程

1)打开Vs Code,进入命令行模式(shift+cmmand+p/F1), SFDX: Create Project with Manifest

Salesforce学习之路(八)一次拉取多个文件或全部文件至本地

直接创建标准模式即可,当然可根据自身实际选择。这里直接创建工程:sample

在sample/manifest目录下,可发现名为package.xml的文件,标准内容如下:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<Package xmlns="http://soap.sforce.com/2006/04/metadata">
<types>
<members>*</members>
<name>ApexClass</name>
</types>
<types>
<members>*</members>
<name>ApexComponent</name>
</types>
<types>
<members>*</members>
<name>ApexPage</name>
</types>
<types>
<members>*</members>
<name>ApexTestSuite</name>
</types>
<types>
<members>*</members>
<name>ApexTrigger</name>
</types>
<types>
<members>*</members>
<name>AuraDefinitionBundle</name>
</types>
<types>
<members>*</members>
<name>LightningComponentBundle</name>
</types>
<types>
<members>*</members>
<name>StaticResource</name>
</types>
<version>47.0</version>
</Package>

从packge.xml文件中可以看出,主要分为一下标准类型:

  • ApexClass: Apex类文件
  • ApexComponent: Apex组件
  • ApexPage: Visualforce组件
  • ApexTestSuite: Apex测试类
  • ApexTrigger: Apex的触发问价
  • AuraDefinitionBundle: Apex的自定义Aura组件
  • LightningCompentBundle: Apex的自定义LWC组件
  • StaticResource: 项目中的静态文件

2)认证Org并设置为默认Org

# 认证Org
SFDX: Authorize an Org
# 设置默认Org
SFDX: Set a Default Org

查看Org列表

[kaiwu3@localhost:~/sample]$sfdx force:org:list
=== Orgs
ALIAS USERNAME ORG ID CONNECTED STATUS
─── ──────────── ──────────────────────── ────────────────── ────────────────
(U) k_Reset kaiwu3@*****.com 00D2v000001Xk5DEAS Connected No active scratch orgs found. Specify --all to see all scratch orgs

3) 利用pacakge.xml拉取文件

右击sample/manifest/pacakge.xml,选择SFDX: Retrieve Source in Manifest from Org

::16.740 sfdx force:source:retrieve --manifest /Users/kaiwu3/Works/Code/sfdcTmp/sample/manifest/package.xml
=== Retrieved Source
FULL NAME TYPE PROJECT PATH
──────────────────────────────────────────────────────────────────────── ──────────────────────── ────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
heatmapmock StaticResource force-app/main/default/staticresources/heatmapmock.resource-meta.xml
heatmapmock StaticResource force-app/main/default/staticresources/heatmapmock.js
heatmap StaticResource force-app/main/default/staticresources/heatmap.resource-meta.xml
heatmap StaticResource force-app/main/default/staticresources/heatmap.js
......

此时,你会发现package.xml中定义的标准组件,都已经成功拉到本地工程。

2. 利用Package Manage方式*拉取文件

1) Org中创建Package包

上述manifest方式拉取的文件,仅限于创建工程是自动生成的package.xml中定义的几种类型,有时并不能满足我们的需求(比如Org迁移或者备份,此时不仅需要上述的组件文件,还需要保留在Org中创建的Object等信息)。此时,你会发现Package Manager可以满足你的一切需求。

在Org中,【Setup】-->【Package Manager】-->【new】

Salesforce学习之路(八)一次拉取多个文件或全部文件至本地

点击Add按钮,添加所需组件。

Salesforce学习之路(八)一次拉取多个文件或全部文件至本地

返回Package Maneger界面可见Package列表存在sample的包。

2)本地工程下载smaple包

[kaiwu3@localhost:~/Works/Code/sfdcTmp/sample]$mkdir pacakge
# 下载包命令:sfdx force:mdapi:retrieve -s -r {{pathToCreatePackageFile}} -u {{sandboxUsername}} -p {{packageName}}
[kaiwu3@localhost:~/Works/Code/sfdcTmp/sample]$sfdx force:mdapi:retrieve -s -r package/ -u kaiwu3@*****.com -p sample
Retrieving source... === Status
Status: InProgress
jobid: 09S2v000006nL64EAE === Result
Status: Succeeded
jobid: 09S2v000006nL64EAE # 产生的zip包路径
Wrote retrieve zip to /Users/kaiwu3/Works/Code/sfdcTmp/sample/package/unpackaged.zip.

3)转换package为工程文件

# 解压下载包(下载包一般命名为:unpacakge.zip)
[kaiwu3@localhost:~/sfdcTmp/sample/package]$unzip unpackaged.zip
Archive: unpackaged.zip
inflating: staticresources/leaflet1.resource
inflating: staticresources/leaflet1.resource-meta.xml
inflating: aura/SmartLocks/SmartLocks.css
inflating: aura/SmartLocks/SmartLocksHelper.js
inflating: aura/SmartLocks/SmartLocksController.js
inflating: aura/SmartHome/SmartHome.css
inflating: aura/SmartHome/SmartHomeController.js
......
inflating: package.xml # 将解压文件转换匹配到对应工程中
# 转换命令:sfdx force:mdapi:convert -r {pacakge.xml所在目录}
[kaiwu3@localhost:~/Works/Code/sfdcTmp/sample]$sfdx force:mdapi:convert -r package/
=== Converted Source
STATE FULL NAME TYPE PROJECT PATH
───── ─────────────────────────────────────────────────────── ───────────────── ────────────────────────────────────────────────────────────────────────────────────────────────────────────
Add CCTG CustomApplication force-app/main/default/applications/CCTG.app-meta.xml
Add Company__c-Company Layout Layout force-app/main/default/layouts/Company__c-Company Layout.layout-meta.xml
Add Employee__c-Employee Layout Layout force-app/main/default/layouts/Employee__c-Employee Layout.layout-meta.xml
......

细心的同学应该发现了,package manager方式中也存在package.xml文件,区别在哪呢?

<?xml version="1.0" encoding="UTF-8"?>
<Package xmlns="http://soap.sforce.com/2006/04/metadata">
<fullName>sample</fullName>
<!--类型:ApexClass,成员:sample中自定义添加的-->
<types>
<members>BotController</members>
...
<name>ApexClass</name>
</types>
<!--类型:触发器,成员:sample包中自定义选择-->
<types>
<members>PairContactToAccount</members>
<members>PushNotificationTrigger</members>
...
<name>ApexTrigger</name>
</types>
<!--类型:Aura组件,成员:sample包中自定义选择-->
<types>
<members>Map</members>
<members>MapCard</members>
...
<name>AuraDefinitionBundle</name>
</types>
<!--类型:自定义应用,成员:sample包中自定义选择-->
<types>
<members>CCTG</members>
...
<name>CustomApplication</name>
</types>
<!--类型:自定义字段,成员:sample包中自定义选择-->
<types>
<members>Command__c.Active__c</members>
...
<name>CustomField</name>
</types>
<!--类型:自定义对象,成员:sample包中自定义选择-->
<types>
<members>Command__c</members>
...
<name>CustomObject</name>
</types>
<!--类型:自定义导航,成员:sample包中自定义选择-->
<types>
<members>Account__c</members>
...
<name>CustomTab</name>
</types>
<!--类型:Layout,成员:sample包中自定义选择-->
<types>
<members>Bot_Command__c-Bot Action Layout</members>
...
<name>Layout</name>
</types>
...
<!--类型:RecordType,成员:sample包中自定义选择-->
<types>
<members>Account__c.DemoChart</members>
...
<name>RecordType</name>
</types>
<!--类型:静态文件, 成员:sample包中自定义选择-->
<types>
<members>leaflet1</members>
<name>StaticResource</name>
</types>
<types>
<members>Account__c.Open_Report</members>
<name>WebLink</name>
</types>
<version>47.0</version>
</Package>

而在manifest中,类型仅有上述几种,并且成员为所有。

3. 利用Scratch Org全部拉取

1)创建Scratch Org

# 创建scratch Org
# 注意,如果没有权限,需进入Org,enable Dev Hub
# 这里使设置有效期为3天
[kaiwu3@localhost:~/smaple/config]$sfdx force:org:create -f project-scratch-def.json -d
Successfully created scratch org: 00D9D0000000St7UAE, username: test-l5cwqegykwud@example.comsfdx force:org:create -f project-scratch-def.json -d # 将scratch Org设置为默认Org
[kaiwu3@localhost:~/sample/config]$sfdx force:config:set defaultusername=test-l5cwqegykwud@example.com
=== Set Config
NAME VALUE
─────────────── ─────────────────────────────
defaultusername test-l5cwqegykwud@example.com # 查看Org列表
[kaiwu3@localhost:~/Works/Code/test/config]$sfdx force:org:list
=== Orgs
ALIAS USERNAME ORG ID CONNECTED STATUS
─── ───── ──────────────── ────────────────── ────────────────
(D) k_Reset kaiwu3@*****.com 00D2v000001Xk5DEAS Connected ALIAS SCRATCH ORG NAME USERNAME ORG ID EXPIRATION DATE
─── ───── ──────────────── ───────────────────────────── ────────────────── ───────────────
(U) kaiwu3 Company test-l5cwqegykwud@example.com 00D9D0000000St7UAE --

2)全量拉取数据

# 权量拉取命令:sfdx force:source:pull -u {username}
[kaiwu3@localhost:~/sample]$sfdx force:source:pull -u test-l5cwqegykwud@example.com
=== Pulled Source
...

在切换Org即可。

作者:吴家二少

博客地址:https://www.cnblogs.com/cloudman-open/

本文欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。