Kanaaldocumenten afdrukken met ingediende gegevens
- Van toepassing op:
- Experience Manager 6.4
- Experience Manager 6.5
Gemaakt voor:
- tussenpersoon
- Ontwikkelaar
Afdrukkanaaldocumenten worden doorgaans gegenereerd door gegevens op te halen van een gegevensbron op de achtergrond via de ophalen-service van het formuliergegevensmodel. In sommige gevallen moet u mogelijk afdrukkanaaldocumenten genereren met de verschafte gegevens. De klant vult bijvoorbeeld de wijziging van het formulier in en u wilt mogelijk een document voor het afdrukkanaal genereren met gegevens uit het verzonden formulier. Om dit te bereiken moet deze gebruikscase de volgende stappen volgen
Prefill-service maken
De de dienstnaam "ccm-druk-test"wordt gebruikt om tot deze dienst toegang te hebben. Zodra deze voorvulservice is gedefinieerd, kunt u deze service openen in uw servlet of in de implementatie van de stap voor workflowproces om het document voor het afdrukkanaal te genereren.
import java.io.InputStream;
import org.osgi.service.component.annotations.Component;
import com.adobe.forms.common.service.ContentType;
import com.adobe.forms.common.service.DataOptions;
import com.adobe.forms.common.service.DataProvider;
import com.adobe.forms.common.service.FormsException;
import com.adobe.forms.common.service.PrefillData;
@Component(immediate = true, service = {DataProvider.class})
public class ICPrefillService implements DataProvider {
@Override
public String getServiceDescription() {
// TODO Auto-generated method stub
return "Prefill Service for IC Print Channel";
}
@Override
public String getServiceName() {
// TODO Auto-generated method stub
return "ccm-print-test";
}
@Override
public PrefillData getPrefillData(DataOptions options) throws FormsException {
// TODO Auto-generated method stub
PrefillData data = null;
if (options != null && options.getExtras() != null && options.getExtras().get("data") != null) {
InputStream is = (InputStream) options.getExtras().get("data");
data = new PrefillData(is, options.getContentType() != null ? options.getContentType() : ContentType.JSON);
}
return data;
}
}
WorkflowProcess-implementatie maken
Het codefragment voor workflowimplementatie wordt hieronder weergegeven. Deze code wordt uitgevoerd wanneer processtap in de AEM-workflow aan deze implementatie is gekoppeld. Deze implementatie verwacht drie procesargumenten die hieronder worden beschreven:
- Naam van het pad DataFile dat is opgegeven bij het configureren van het adaptieve formulier
- Naam van de afdruksjabloon
- Naam van het gegenereerde afdrukkanaaldocument
Regel 98 - Aangezien het Aangepaste Vorm op het Model van de Gegevens van het Vorm wordt gebaseerd, worden de gegevens die in de gegevensknoop van afBoundData verblijven gehaald.
Regel 128 - De de dienstnaam van de Opties van Gegevens wordt geplaatst. Noteer de servicenaam. Deze moet overeenkomen met de naam die is geretourneerd in regel 45 van de vorige code.
Regel 135 - Het document wordt geproduceerd gebruikend de teruggevende methode van het voorwerp PrintChannel
String params = arg2.get("PROCESS_ARGS","string").toString();
String payloadPath = workItem.getWorkflowData().getPayload().toString();
String dataFile = params.split(",")[0];
final String icFileName = params.split(",")[1];
String dataFilePath = payloadPath + "/"+dataFile+"/jcr:content";
Session session = workflowSession.adaptTo(Session.class);
Node xmlDataNode = null;
try {
xmlDataNode = session.getNode(dataFilePath);
InputStream xmlDataStream = xmlDataNode.getProperty("jcr:data").getBinary().getStream();
JsonParser jsonParser = new JsonParser();
BufferedReader streamReader = null;
try {
streamReader = new BufferedReader(new InputStreamReader(xmlDataStream, "UTF-8"));
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
StringBuilder responseStrBuilder = new StringBuilder();
String inputStr;
try {
while ((inputStr = streamReader.readLine()) != null)
responseStrBuilder.append(inputStr);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
String submittedDataXml = responseStrBuilder.toString();
JsonObject jsonObject = jsonParser.parse(submittedDataXml).getAsJsonObject().get("afData").getAsJsonObject()
.get("afBoundData").getAsJsonObject().get("data").getAsJsonObject();
logger.info("Successfully Parsed gson" + jsonObject.toString());
InputStream targetStream = IOUtils.toInputStream(jsonObject.toString());
//InputStream targetStream = new ByteArrayInputStream(jsonObject.toString().getBytes());
// Node dataNode = session.getNode(formName);
logger.info("Got resource using resource resolver"
);
resHelper.callWith(getResolver.getFormsServiceResolver(), new Callable<Void>() {
@Override
public Void call() throws Exception {
System.out.println("The target stream is "+targetStream.available());
// TODO Auto-generated method stub
com.adobe.fd.ccm.channels.print.api.model.PrintChannel printChannel = null;
String formName = params.split(",")[2];
logger.info("The form name I got was "+formName);
printChannel = printChannelService.getPrintChannel(formName);
logger.info("Did i get print channel?");
com.adobe.fd.ccm.channels.print.api.model.PrintChannelRenderOptions options = new com.adobe.fd.ccm.channels.print.api.model.PrintChannelRenderOptions();
options.setMergeDataOnServer(true);
options.setRenderInteractive(false);
com.adobe.forms.common.service.DataOptions dataOptions = new com.adobe.forms.common.service.DataOptions();
dataOptions.setServiceName(printChannel.getPrefillService());
// dataOptions.setExtras(map);
dataOptions.setContentType(ContentType.JSON);
logger.info("####Set the content type####");
dataOptions.setFormResource(getResolver.getFormsServiceResolver().getResource(formName));
dataOptions.setServiceName("ccm-print-test");
dataOptions.setExtras(new HashMap<String, Object>());
dataOptions.getExtras().put("data", targetStream);
options.setDataOptions(dataOptions);
logger.info("####Set the data options");
com.adobe.fd.ccm.channels.print.api.model.PrintDocument printDocument = printChannel
.render(options);
logger.info("####Generated the document");
com.adobe.aemfd.docmanager.Document uploadedDocument = new com.adobe.aemfd.docmanager.Document(
printDocument.getInputStream());
logger.info("Generated the document");
Binary binary = session.getValueFactory().createBinary(printDocument.getInputStream());
Session jcrSession = workflowSession.adaptTo(Session.class);
String dataFilePath = workItem.getWorkflowData().getPayload().toString();
Node dataFileNode = jcrSession.getNode(dataFilePath);
Node icPdf = dataFileNode.addNode(icFileName, "nt:file");
Node contentNode = icPdf.addNode("jcr:content", "nt:resource");
contentNode.setProperty("jcr:data", binary);
jcrSession.save();
logger.info("Copied the generated document");
uploadedDocument.close();
return null;
}
Voer de volgende stappen uit om dit op uw server te testen:
-
vorm de Dienst van de Post van de Dag CQ. Dit is nodig om e-mail te verzenden met het document dat als bijlage is gegenereerd.
-
Controleer of u de volgende vermelding hebt toegevoegd in de configuratie van de service Gebruikerskaart van de Apache Sling Service
-
DevelopingWithServiceUser.core:getformsresourceresolver=fd-service
-
De aan dit artikel gerelateerde elementen downloaden en uitpakken naar uw bestandssysteem
-
voer de volgende pakketten in gebruikend de het pakketManager van AEM
- beneficiaryconfirmationic.zip
- changeofbeneficiaryform.zip
- generatebeneficiaryworkflow.zip
-
stel het volgende op gebruikend de Console van het Web van AEM Felix
- GenerateIC.GenerateIC.core-1.0-SNAPSHOT.jar. Deze bundel bevat de code die in dit artikel wordt vermeld.
-
Zorg ervoor dat het adaptieve formulier is geconfigureerd voor verzending naar de AEM Workflow, zoals hieronder wordt weergegeven
-
vorm het werkschemamodel. zorg ervoor de processtap en verzend e-mailcomponenten zoals per uw milieu worden gevormd
-
voorproef ChangeOfBeneficiaryForm. Vul enkele details in en verzend
-
De workflow moet worden aangeroepen en het document met het IC-afdrukkanaal moet worden verzonden naar de ontvanger die is opgegeven in het onderdeel E-mail verzenden als bijlage