SalesforceXyToolsCore/Python上ですべてのMetadataを情報を取得してみよう

Topic

  • SalesforceXyToolsCoreを使ってすべてのMetadataを情報を取得する。
  • メタデータのID, Typeを取得可能です。

すべてのMetadataを情報を取得する

  • Salesforce組織のユーザ名、パスワード、Apiバージョン、Product/Sandboxを設定してください。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
from SalesforceXytoolsCore import *
import pprint
config = {
"api_version": 42.0,
"username": "sfdc username",
"password": "sfdc password",
"security_token": "",
"is_sandbox": True
}
meta_api = MetadataApi(username=config["username"],
password=config["password"],
security_token=config["security_token"],
sandbox=config["is_sandbox"],
version=config["api_version"]
)
"""getAllMetadataMap"""
all_metadata_map = meta_api.getAllMetadataMap()
pprint.pprint(all_metadata_map)

結果確認

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
{'ApexClass': {'classes/A_Batch.cls': OrderedDict([('createdById',
'005xxxxxxxxxxxxx'),
('createdByName',
'SFDC Exia'),
('createdDate',
'2010-08-09T00:07:13.000Z'),
('fileName',
'classes/A_Batch.cls'),
('fullName', 'A_Batch'),
('id', '01pxxxxxxxxxxxxx'),
('lastModifiedById',
'005xxxxxxxxxxxxx'),
('lastModifiedByName',
'SFDC Exia'),
('lastModifiedDate',
'2010-08-09T00:24:29.000Z'),
('manageableState',
'unmanaged'),
('type', 'ApexClass')]),
................省略
'Report': {
'reports/Xy/MyID.report': OrderedDict([('createdById',
'005xxxxxxxxxxxxx'),
('createdByName',
'SFDC Exia'),
('createdDate',
'2010-09-15T00:29:36.000Z'),
('fileName',
'reports/Xy/MyID.report'),
('fullName', 'Xy/MyID'),
('id', '00OXXXXXXXXXXXXXX'),
('lastModifiedById',
'005XXXXXXXXXXXXXX'),
('lastModifiedByName',
'SFDC Exia'),
('lastModifiedDate',
'2010-09-25T00:03:33.000Z'),
('manageableState',
'unmanaged'),
('type', 'Report')]),
................省略
}

Metadataのリストを取得したい場合

1
2
3
"""listAllMetadata """
for meta in meta_api.listAllMetadata():
pprint.pprint(meta)

指定したメタデータを取得する

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
"""listmeta"""
query_option_list = [
{
"metadata_type" : "EmailFolder",
"folder" : ""
},
{
"metadata_type" : "ApexClass",
"folder" : ""
}
]
listmeta_result = meta_api.listMetadata(query_option_list)
print(len(listmeta_result))
for meta in listmeta_result:
pprint.pprint(meta)