この文章は Salesforce 機械翻訳システムを使用して翻訳されました。詳細はこちらをご参照ください。
英語に切り替える

リードの変換用の Process.Plugin の実装のサンプル

この例では、Apex クラスで Process.Plugin インターフェースを実装し、リードを取引先、取引先責任者、および必要に応じて商談に変換します。プラグインのテストメソッドも含まれています。この実装は、従来の Apex アクションを使用してフローからコールできます。

Process.Plugin インターフェースではなく @InvocableMethod アノテーションを使用することをお勧めします。

  • インターフェースは、Blob、Collection、sObject、および Time データ型と一括操作をサポートしていません。インターフェースをクラスに実装すると、クラスはフローからしか参照できません。
  • アノテーションは、すべてのデータ型と一括操作をサポートしています。アノテーションをクラスに実装すると、クラスはフロー、プロセス、および Custom Invocable Actions REST API エンドポイントから参照できます。

ヒント

1// Converts a lead as an action in a flow.
2global class VWFConvertLead implements Process.Plugin {
3    // This method runs when called by a flow's legacy Apex action.
4    global Process.PluginResult invoke(
5        Process.PluginRequest request) {
6            
7        // Set up variables to store input parameters from 
8        // the flow.
9        String leadID = (String) request.inputParameters.get(
10            'LeadID');
11        String contactID = (String) 
12            request.inputParameters.get('ContactID');
13        String accountID = (String) 
14            request.inputParameters.get('AccountID');
15        String convertedStatus = (String) 
16            request.inputParameters.get('ConvertedStatus');
17        Boolean overWriteLeadSource = (Boolean) 
18            request.inputParameters.get('OverwriteLeadSource');
19        Boolean createOpportunity = (Boolean) 
20            request.inputParameters.get('CreateOpportunity');
21        String opportunityName = (String) 
22            request.inputParameters.get('ContactID');
23        Boolean sendEmailToOwner = (Boolean) 
24            request.inputParameters.get('SendEmailToOwner');   
25        
26        // Set the default handling for booleans. 
27        if (overWriteLeadSource == null) 
28            overWriteLeadSource = false;
29        if (createOpportunity == null) 
30            createOpportunity = true;
31        if (sendEmailToOwner == null) 
32            sendEmailToOwner = false;
33        
34        // Convert the lead by passing it to a helper method.
35        Map<String,Object> result = new Map<String,Object>();
36        result = convertLead(leadID, contactID, accountID, 
37            convertedStatus, overWriteLeadSource, 
38            createOpportunity, opportunityName, 
39            sendEmailToOwner);
40 
41        return new Process.PluginResult(result); 
42    }
43    
44    // This method describes the plug-in and its inputs from
45    // and outputs to the flow.
46    // Implementing this method makes the class available 
47    // in Flow Builder as a legacy Apex action.
48    global Process.PluginDescribeResult describe() {
49        // Set up plugin metadata
50        Process.PluginDescribeResult result = new 
51            Process.PluginDescribeResult();
52        result.description = 
53            'The LeadConvert Flow Plug-in converts a lead into ' + 
54            'an account, a contact, and ' + 
55            '(optionally)an opportunity.';
56        result.tag = 'Lead Management';
57        
58        // Create a list that stores both mandatory and optional 
59        // input parameters from the flow.
60        // NOTE: Only primitive types (STRING, NUMBER, etc.) are 
61        // supported. Collections aren't supported.
62        result.inputParameters = new 
63            List<Process.PluginDescribeResult.InputParameter>{
64            // Lead ID (mandatory)
65            new Process.PluginDescribeResult.InputParameter(
66                'LeadID', 
67                Process.PluginDescribeResult.ParameterType.STRING, 
68                true),
69            // Account Id (optional)
70            new Process.PluginDescribeResult.InputParameter(
71                'AccountID', 
72                Process.PluginDescribeResult.ParameterType.STRING, 
73                false),
74            // Contact ID (optional)
75            new Process.PluginDescribeResult.InputParameter(
76                'ContactID', 
77                Process.PluginDescribeResult.ParameterType.STRING, 
78                false),            
79            // Status to use once converted
80            new Process.PluginDescribeResult.InputParameter(
81                'ConvertedStatus', 
82                Process.PluginDescribeResult.ParameterType.STRING, 
83                true),
84            new Process.PluginDescribeResult.InputParameter(
85                'OpportunityName', 
86                Process.PluginDescribeResult.ParameterType.STRING, 
87                false),
88            new Process.PluginDescribeResult.InputParameter(
89                'OverwriteLeadSource', 
90                Process.PluginDescribeResult.ParameterType.BOOLEAN, 
91                false),
92            new Process.PluginDescribeResult.InputParameter(
93                'CreateOpportunity', 
94                Process.PluginDescribeResult.ParameterType.BOOLEAN, 
95                false),
96            new Process.PluginDescribeResult.InputParameter(
97                'SendEmailToOwner', 
98                Process.PluginDescribeResult.ParameterType.BOOLEAN, 
99                false)                                                   
100        };
101
102        // Create a list that stores output parameters sent 
103        // to the flow.
104        result.outputParameters = new List<
105            Process.PluginDescribeResult.OutputParameter>{
106            // Account ID of the converted lead
107            new Process.PluginDescribeResult.OutputParameter(
108                'AccountID', 
109                Process.PluginDescribeResult.ParameterType.STRING),
110            // Contact ID of the converted lead
111            new Process.PluginDescribeResult.OutputParameter(
112                'ContactID', 
113                Process.PluginDescribeResult.ParameterType.STRING),
114            // Opportunity ID of the converted lead
115            new Process.PluginDescribeResult.OutputParameter(
116                'OpportunityID', 
117                Process.PluginDescribeResult.ParameterType.STRING)                
118        };
119
120        return result;
121    }
122        
123    /**
124     * Implementation of the LeadConvert plug-in.
125     * Converts a given lead with several options:
126     * leadID - ID of the lead to convert
127     * contactID - 
128     * accountID - ID of the Account to attach the converted 
129     *  Lead/Contact/Opportunity to.
130     * convertedStatus - 
131     * overWriteLeadSource - 
132     * createOpportunity - true if you want to create a new 
133     *  Opportunity upon conversion
134     * opportunityName - Name of the new Opportunity.
135     * sendEmailtoOwner - true if you are changing owners upon 
136     *  conversion and want to notify the new Opportunity owner.
137     *
138     * returns: a Map with the following output:
139     * AccountID - ID of the Account created or attached 
140     *  to upon conversion.
141     * ContactID - ID of the Contact created or attached 
142     *  to upon conversion.
143     * OpportunityID - ID of the Opportunity created 
144     *  upon conversion.
145     */
146    public Map<String,String> convertLead (
147                               String leadID,
148                               String contactID,
149                               String accountID,
150                               String convertedStatus,
151                               Boolean overWriteLeadSource,
152                               Boolean createOpportunity,
153                               String opportunityName,
154                               Boolean sendEmailToOwner
155        ) {
156        Map<String,String> result = new Map<String,String>();
157                                
158        if (leadId == null) throw new ConvertLeadPluginException(
159            'Lead Id cannot be null');
160        
161        // check for multiple leads with the same ID
162        Lead[] leads = [Select Id, FirstName, LastName, Company 
163            From Lead where Id = :leadID];
164        if (leads.size() > 0) {
165            Lead l = leads[0];
166            // CheckAccount = true, checkContact = false
167            if (accountID == null && l.Company != null) {
168                Account[] accounts = [Select Id, Name FROM Account 
169                    where Name = :l.Company LIMIT 1];
170                if (accounts.size() > 0) {
171                    accountId = accounts[0].id;
172                }
173            }
174            
175            // Perform the lead conversion.
176            Database.LeadConvert lc = new Database.LeadConvert();
177            lc.setLeadId(leadID);
178            lc.setOverwriteLeadSource(overWriteLeadSource);
179            lc.setDoNotCreateOpportunity(!createOpportunity);
180            lc.setConvertedStatus(convertedStatus);
181            if (sendEmailToOwner != null) lc.setSendNotificationEmail(
182                sendEmailToOwner);
183            if (accountId != null && accountId.length() > 0) 
184                lc.setAccountId(accountId);
185            if (contactId != null && contactId.length() > 0) 
186                lc.setContactId(contactId);
187            if (createOpportunity) {
188                lc.setOpportunityName(opportunityName);
189            }
190            
191            Database.LeadConvertResult lcr = Database.convertLead(
192                lc, true);
193            if (lcr.isSuccess()) {
194                result.put('AccountID', lcr.getAccountId());
195                result.put('ContactID', lcr.getContactId());
196                if (createOpportunity) {
197                    result.put('OpportunityID', 
198                        lcr.getOpportunityId());
199                }
200            } else {
201                String error = lcr.getErrors()[0].getMessage();
202                throw new ConvertLeadPluginException(error);
203            }
204        } else { 
205            throw new ConvertLeadPluginException(
206                'No leads found with Id : "' + leadId + '"');
207        }
208        return result;
209    }
210        
211    // Utility exception class
212    class ConvertLeadPluginException extends Exception {}
213}
1// Test class for the lead convert Apex plug-in.
2@isTest
3private class VWFConvertLeadTest {
4    static testMethod void basicTest() {
5        // Create test lead
6        Lead testLead = new Lead(
7           Company='Test Lead',FirstName='John',LastName='Doe');
8        insert testLead;
9    
10        LeadStatus convertStatus = 
11           [Select Id, MasterLabel from LeadStatus 
12           where IsConverted=true limit 1]; 
13        
14        // Create test conversion
15        VWFConvertLead aLeadPlugin = new VWFConvertLead();
16        Map<String,Object> inputParams = new Map<String,Object>();
17        Map<String,Object> outputParams = new Map<String,Object>();
18
19        inputParams.put('LeadID',testLead.ID);
20        inputParams.put('ConvertedStatus', 
21           convertStatus.MasterLabel);
22
23        Process.PluginRequest request = new 
24           Process.PluginRequest(inputParams);
25        Process.PluginResult result;
26        result = aLeadPlugin.invoke(request);
27        
28        Lead aLead = [select name, id, isConverted 
29                       from Lead where id = :testLead.ID];
30        System.Assert(aLead.isConverted);
31        
32    }
33
34     /*
35      * This tests lead conversion with 
36      * the Account ID specified.
37      */
38    static testMethod void basicTestwithAccount() {
39
40        // Create test lead
41        Lead testLead = new Lead(
42            Company='Test Lead',FirstName='John',LastName='Doe');
43        insert testLead;
44        
45        Account testAccount = new Account(name='Test Account');
46        insert testAccount;
47    
48           // System.debug('ACCOUNT BEFORE' + testAccount.ID);
49
50        LeadStatus convertStatus = [Select Id, MasterLabel 
51                    from LeadStatus where IsConverted=true limit 1]; 
52        
53        // Create test conversion
54        VWFConvertLead aLeadPlugin = new VWFConvertLead();
55        Map<String,Object> inputParams = new Map<String,Object>();
56        Map<String,Object> outputParams = new Map<String,Object>();
57
58        inputParams.put('LeadID',testLead.ID);
59        inputParams.put('AccountID',testAccount.ID);
60        inputParams.put('ConvertedStatus',
61            convertStatus.MasterLabel);
62
63        Process.PluginRequest request = new 
64            Process.PluginRequest(inputParams);
65        Process.PluginResult result;
66        result = aLeadPlugin.invoke(request);
67        
68        Lead aLead = 
69            [select name, id, isConverted, convertedAccountID 
70             from Lead where id = :testLead.ID];
71        System.Assert(aLead.isConverted);
72        //System.debug('ACCOUNT AFTER' + aLead.convertedAccountID);
73        System.AssertEquals(testAccount.ID, aLead.convertedAccountID);
74    }
75
76    /*
77     * This tests lead conversion with the Account ID specified.
78    */
79    static testMethod void basicTestwithAccounts() {
80
81        // Create test lead
82        Lead testLead = new Lead(
83            Company='Test Lead',FirstName='John',LastName='Doe');
84        insert testLead;
85        
86        Account testAccount1 = new Account(name='Test Lead');
87        insert testAccount1;
88        Account testAccount2 = new Account(name='Test Lead');
89        insert testAccount2;
90
91           // System.debug('ACCOUNT BEFORE' + testAccount.ID);
92
93        LeadStatus convertStatus = [Select Id, MasterLabel 
94            from LeadStatus where IsConverted=true limit 1]; 
95        
96        // Create test conversion
97        VWFConvertLead aLeadPlugin = new VWFConvertLead();
98        Map<String,Object> inputParams = new Map<String,Object>();
99        Map<String,Object> outputParams = new Map<String,Object>();
100
101        inputParams.put('LeadID',testLead.ID);
102        inputParams.put('ConvertedStatus',
103            convertStatus.MasterLabel);
104
105        Process.PluginRequest request = new 
106            Process.PluginRequest(inputParams);
107        Process.PluginResult result;
108        result = aLeadPlugin.invoke(request);
109        
110        Lead aLead = 
111            [select name, id, isConverted, convertedAccountID 
112            from Lead where id = :testLead.ID];
113        System.Assert(aLead.isConverted);
114    }
115
116
117     /*
118      * -ve Test
119      */    
120    static testMethod void errorTest() {
121
122        // Create test lead
123        // Lead testLead = new Lead(Company='Test Lead',
124        //   FirstName='John',LastName='Doe');
125        LeadStatus convertStatus = [Select Id, MasterLabel 
126            from LeadStatus where IsConverted=true limit 1]; 
127        
128        // Create test conversion
129        VWFConvertLead aLeadPlugin = new VWFConvertLead();
130        Map<String,Object> inputParams = new Map<String,Object>();
131        Map<String,Object> outputParams = new Map<String,Object>();
132        inputParams.put('LeadID','00Q7XXXXxxxxxxx');
133        inputParams.put('ConvertedStatus',convertStatus.MasterLabel);
134
135        Process.PluginRequest request = new 
136            Process.PluginRequest(inputParams);
137        Process.PluginResult result;
138        try {
139            result = aLeadPlugin.invoke(request);    
140        }
141        catch (Exception e) {
142          System.debug('EXCEPTION' + e);
143          System.AssertEquals(1,1);
144        }
145        
146    }
147    
148    
149     /*
150      * This tests the describe() method
151      */ 
152    static testMethod void describeTest() {
153
154        VWFConvertLead aLeadPlugin = 
155            new VWFConvertLead();
156        Process.PluginDescribeResult result = 
157            aLeadPlugin.describe();
158        
159        System.AssertEquals(
160            result.inputParameters.size(), 8);
161        System.AssertEquals(
162            result.OutputParameters.size(), 3);
163        
164     }
165
166}