学习目标
- 使用Apex元数据API从组织中检索元数据。
- 使用Apex元数据API更新元数据并部署到组织中。
解决常见的多组织安装问题
检索元数据并将自定义字段添加到布局
以下是检索帐户页面布局的当前元数据的一些示例代码。然后它使用元数据来定位页面布局的帐户信息部分。最后,它为自定义字段创建一个元数据布局项目,并将其添加到本节中的元数据布局项目列表中。
- 点击设置装置,然后点击开发者控制台,打开 Developer Console.
- 在开发者控制台中,点击 .
- 命名类UpdatePageLayout并单击 OK.
- 摆脱任何现有的代码,并复制并粘贴下面的示例代码。
public class UpdatePageLayout {
// 将自定义字段添加到页面布局
public Metadata.Layout buildLayout() {
// 检索帐户布局和部分
List<Metadata.Metadata> layouts =
Metadata.Operations.retrieve(Metadata.MetadataType.Layout,
new List<String> {'Account-Account Layout'});
Metadata.Layout layoutMd = (Metadata.Layout) layouts.get(0);
Metadata.LayoutSection layoutSectionToEdit = null;
List<Metadata.LayoutSection> layoutSections = layoutMd.layoutSections;
for (Metadata.LayoutSection section : layoutSections) {
if (System.equals(section.label, 'Account Information')) {
layoutSectionToEdit = section;
break;
}
}
// 添加左栏中“帐户信息”部分下的字段
List<Metadata.LayoutColumn> layoutColumns = layoutSectionToEdit.layoutColumns;
List<Metadata.LayoutItem> layoutItems = layoutColumns.get(0).layoutItems;
// 为自定义字段创建一个新的布局项目
Metadata.LayoutItem item = new Metadata.LayoutItem();
item.behavior = Metadata.UiBehavior.Edit;
item.field = 'AMAPI__Apex_MD_API_sample_field__c';
layoutItems.add(item);
return layoutMd;
}
}
有关Metadata名称空间中的类的更多信息,请参阅Apex开发人员指南。
提供一个回调类
现在我们已经创建了布局字段元数据,我们准备将元数据部署到我们的组织。由于部署是异步的,因此我们提供回调,以便在排队的部署完成时通知我们。回调类必须实现Metadata.DeployCallback接口。
public class PostInstallCallback implements Metadata.DeployCallback {
public void handleResult(Metadata.DeployResult result,
Metadata.DeployCallbackContext context) {
if (result.status == Metadata.DeployStatus.Succeeded) {
// 部署成功,采取适当的行动。
System.debug('Deployment Succeeded!');
} else {
// 部署不成功,采取适当的行动。
System.debug('Deployment Failed!');
}
}
}
Apex元数据API提供了Metadata.Operations.enqueueDeployment方法来将元数据部署到当前组织。当调用此方法时,部署请求将排队进行异步处理。
使用以下代码创建名称为DeployMetadata的Apex类。这个类创建一个部署容器,并将新的布局元数据添加到它。它实例化我们的回调类,当部署完成时调用它。然后调用Metadata.Operations.enqueueDeployment方法将新的元数据部署到组织中。
public class DeployMetadata {
// 创建元数据容器
public Metadata.DeployContainer constructDeploymentRequest() {
Metadata.DeployContainer container = new Metadata.DeployContainer();
// 添加组件到容器
Metadata.Layout layoutMetadata = new UpdatePageLayout().buildLayout();
container.addMetadata(layoutMetadata);
return container;
}
// 部署元数据
public void deploy(Metadata.DeployContainer container) {
// 创建回调
PostInstallCallback callback = new PostInstallCallback();
// 使用新组件部署容器。
Id asyncResultId = Metadata.Operations.enqueueDeployment(container, callback);
}
}
异步部署元数据
现在我们已经编写了我们需要的Apex类,我们可以部署我们的自定义元数据。我们从后安装脚本启动部署,后者是一个实现InstallHandler接口的Apex类。如果软件包包含安装后脚本,则在安装或升级软件包后脚本将自动运行。在Developer Console中,创建PostInstallScript Apex类。
public class PostInstallScript implements InstallHandler {
// 部署安装后的元数据
public void onInstall(InstallContext context) {
DeployMetadata deployUtil = new DeployMetadata();
Metadata.DeployContainer container = deployUtil.constructDeploymentRequest();
deployUtil.deploy(container);
}
}