Szenario: Handlers für CRUD-Vorgänge

Bei Bedarf können Sie Handler für die Vor- und Nachbearbeitung mit CRUD-Vorgängen eines Elementtyps hinzufügen. Implementieren Sie Änderungen mithilfe der ActionHandler-Schnittstelle.

Übersicht über die Implementierung

In diesem Beispiel wird ein Beispielhandler für die Texterstellung erstellt, um den Namen des Textmoduls im Vorbearbeitungsschritt zu ändern:
  1. Erstellen Sie eine TextCreateHandler-Klasse, die die ActionHandler-Schnittstelle im CorrespondenceManagementSolutionTemplate/Services-Projekt implementiert. Diese Schnittstelle enthält die preProcess()- und postProcess()-Methoden, die vor bzw. nach der Create-Methode aufgerufen werden:
    package com.adobe.icc; 
     
    import java.util.Map; 
    import com.adobe.icc.dbforms.obj.TextModule; 
    import com.adobe.livecycle.content.repository.action.ActionHandler; 
    import com.adobe.livecycle.content.repository.action.ActionType; 
     
    /** 
     * TextCreateHandler is the handler associated with the Create operation of the Form. The preProcess() and postProcess() methods of 
     * this class are invoked just before and after the Create operation. 
     */ 
    public class TextCreateHandler implements ActionHandler { 
     
            private static final String PREFIX = "PREFIX"; 
        /** 
         * This method is invoked just prior to the Create operation of TextModule. The first parameter of this API is the form object that 
         * is being Created. 
         */ 
        public void preProcess(String nodeType, ActionType actionType, Object obj, Map<String, Object> arg1) 
        { 
            TextModule text = (TextModule) obj; 
                    text.setName(PREFIX + text.getName()); 
        } 
         
        /** 
         * This method is invoked just after to the Create operation of Text. The first parameter is the form object that has been 
         * Created. 
         */ 
        public void postProcess(String nodeType, ActionType actionType, Object arg0, Map<String, Object> arg1) { 
            // Do nothing 
        } 
    }
  2. Konfigurieren Sie den Handler, indem Sie den folgenden Eintrag dem Abschnitt „<bp:blueprint>“ der Datei „CorrespondenceManagementSolutionTemplate\Services\resources\META-INF\spring\osgi-context.xml“ hinzufügen:
    <bp:reference interface="com.adobe.livecycle.content.repository.RepositoryService" />
  3. Fügen Sie der Klasse „AssetDefinitionDeployer“ eine private Variable „repositoryService“ der Klasse „com.adobe.livecycle.content.repository.RepositoryService“ hinzu:
    @Autowired 
    private RepositoryService repositoryService;
  4. Fügen Sie außerdem der Methode „afterPropertiesSet()“ den folgenden Code hinzu:
    List<ActionHandler> handlers = new ArrayList<ActionHandler>(); 
    handlers = new ArrayList<ActionHandler>(); 
    handlers.add(new TextCreateHandler()); 
    repositoryService.addActionHandlers(ActionHandlerService.APP_ROOT_GLOBAL, TextModule.class.getName(), ActionType.CREATE, handlers);
  5. Erstellen Sie zum Anzeigen der Änderungen die Lösungsvorlage neu und stellen Sie sie erneut bereit. Informationen zum erneuten Erstellen und Bereitstellen finden Sie unter Lösungsvorlage erstellen und bereitstellen.