Apex - interfejsy

Interfejs jest jak klasa Apex, w której żadna z metod nie została zaimplementowana. Zawiera tylko sygnatury metod, ale treść każdej metody jest pusta. Aby użyć interfejsu, inna klasa musi go zaimplementować, dostarczając treść dla wszystkich metod zawartych w interfejsie.

Interfejsy są używane głównie do dostarczania warstwy abstrakcji dla twojego kodu. Oddzielają implementację od deklaracji metody.

Weźmy przykład naszej firmy chemicznej. Załóżmy, że musimy zapewnić zniżkę klientom Premium i Zwykłym, a rabaty dla obu będą różne.

Stworzymy interfejs o nazwie DiscountProcessor.

// Interface
public interface DiscountProcessor {
   Double percentageDiscountTobeApplied(); // method signature only
}

// Premium Customer Class
public class PremiumCustomer implements DiscountProcessor {
   
   //Method Call
   public Double percentageDiscountTobeApplied () {
      
      // For Premium customer, discount should be 30%
      return 0.30;
   }
}

// Normal Customer Class
public class NormalCustomer implements DiscountProcessor {
   
   // Method Call
   public Double percentageDiscountTobeApplied () {
      
      // For Premium customer, discount should be 10%
      return 0.10;
   }
}

Podczas implementowania interfejsu konieczne jest zaimplementowanie metody tego interfejsu. Jeśli nie zaimplementujesz metod Interface, zostanie zgłoszony błąd. Należy używać interfejsów, jeśli chcesz, aby implementacja metody była obowiązkowa dla programisty.

Standardowy interfejs Salesforce dla Batch Apex

SFDC ma standardowe interfejsy, takie jak Database.Batchable, Schedulable itp. Na przykład, jeśli zaimplementujesz Database.Batchable Interface, musisz zaimplementować trzy metody zdefiniowane w interfejsie - Start, Execute i Finish.

Poniżej znajduje się przykład standardowego interfejsu Database.Batchable dostarczanego przez Salesforce, który wysyła wiadomości e-mail do użytkowników ze statusem partii. Ten interfejs ma 3 metody: Start, Execute i Finish. Korzystając z tego interfejsu, możemy zaimplementować funkcjonalność Batchable, a także zapewnia zmienną BatchableContext, której możemy użyć, aby uzyskać więcej informacji o wykonywanym Batchie i wykonać inne funkcje.

global class CustomerProessingBatch implements Database.Batchable<sobject7>,
Schedulable {
   // Add here your email address
   global String [] email = new String[] {'[email protected]'};

   // Start Method
   global Database.Querylocator start (Database.BatchableContext BC) {
      
      // This is the Query which will determine the scope of Records and fetching the same
      return Database.getQueryLocator('Select id, Name, APEX_Customer_Status__c,
         APEX_Customer_Decscription__c From APEX_Customer__c WHERE createdDate = today
         && APEX_Active__c = true');
   }

   // Execute method
   global void execute (Database.BatchableContext BC, List<sobject> scope) {
      List<apex_customer__c> customerList = new List<apex_customer__c>();
      List<apex_customer__c> updtaedCustomerList = new List<apex_customer__c>();
      
      for (sObject objScope: scope) {
         // type casting from generic sOject to APEX_Customer__c
         APEX_Customer__c newObjScope = (APEX_Customer__c)objScope ;
         newObjScope.APEX_Customer_Decscription__c = 'Updated Via Batch Job';
         newObjScope.APEX_Customer_Status__c = 'Processed';
         
         // Add records to the List
         updtaedCustomerList.add(newObjScope);
      }

      // Check if List is empty or not
      if (updtaedCustomerList != null && updtaedCustomerList.size()>0) {
         
         // Update the Records
         Database.update(updtaedCustomerList); System.debug('List Size
            '+updtaedCustomerList.size());
      }
   }

   // Finish Method
   global void finish(Database.BatchableContext BC) {
      Messaging.SingleEmailMessage mail = new Messaging.SingleEmailMessage();
      
      // get the job Id
      AsyncApexJob a = [Select a.TotalJobItems, a.Status, a.NumberOfErrors,
      a.JobType, a.JobItemsProcessed, a.ExtendedStatus, a.CreatedById,
      a.CompletedDate From AsyncApexJob a WHERE id = :BC.getJobId()];
      System.debug('$$$ Jobid is'+BC.getJobId());
      
      // below code will send an email to User about the status
      mail.setToAddresses(email);
     
      // Add here your email address
      mail.setReplyTo('[email protected]');
      mail.setSenderDisplayName('Apex Batch Processing Module');
      mail.setSubject('Batch Processing '+a.Status);
      mail.setPlainTextBody('The Batch Apex job processed
         '+a.TotalJobItems+'batches with '+a.NumberOfErrors+'failures'+'Job Item
         processed are'+a.JobItemsProcessed);
      Messaging.sendEmail(new Messaging.Singleemailmessage [] {mail});
   }

   // Scheduler Method to scedule the class
   global void execute(SchedulableContext sc) {
      CustomerProessingBatch conInstance = new CustomerProessingBatch();
      database.executebatch(conInstance,100);
   }
}

Aby wykonać tę klasę, musisz uruchomić poniższy kod w Konsoli programisty.

CustomerProessingBatch objBatch = new CustomerProessingBatch ();
Database.executeBatch(objBatch);