Processo de fluxo de trabalho personalizado para converter JSON em XML

O código fornecido converte JSON em XML, armazenando o XML resultante em uma variável de processo de fluxo de trabalho chamada dataXml.

import org.slf4j.LoggerFactory;
import com.adobe.granite.workflow.WorkflowException;
import java.io.InputStream;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import javax.jcr.Node;
import javax.jcr.Session;
import org.json.JSONObject;
import org.json.XML;
import org.slf4j.Logger;
import org.osgi.service.component.annotations.Component;
import com.adobe.granite.workflow.WorkflowSession;
import com.adobe.granite.workflow.exec.WorkItem;
import com.adobe.granite.workflow.exec.WorkflowProcess;
import com.adobe.granite.workflow.metadata.MetaDataMap;

@Component(property = {
    "service.description=Convert JSON to XML",
    "process.label=Convert JSON to XML"
})
public class ConvertJSONToXML implements WorkflowProcess {

    private static final Logger log = LoggerFactory.getLogger(ConvertJSONToXML.class);

    @Override
    public void execute(final WorkItem workItem, final WorkflowSession workflowSession, final MetaDataMap arg2) throws WorkflowException {
        String processArgs = arg2.get("PROCESS_ARGS", "string");
        log.debug("The process argument I got was " + processArgs);

        String submittedDataFile = processArgs;
        String payloadPath = workItem.getWorkflowData().getPayload().toString();
        log.debug("The payload in convert json to xml " + payloadPath);

        String dataFilePath = payloadPath + "/" + submittedDataFile + "/jcr:content";
        try {
            Session session = workflowSession.adaptTo(Session.class);
            Node submittedJsonDataNode = session.getNode(dataFilePath);
            InputStream jsonDataStream = submittedJsonDataNode.getProperty("jcr:data").getBinary().getStream();
            BufferedReader streamReader = new BufferedReader(new InputStreamReader(jsonDataStream, "UTF-8"));
            StringBuilder stringBuilder = new StringBuilder();
            String inputStr;
            while ((inputStr = streamReader.readLine()) != null) {
                stringBuilder.append(inputStr);
            }
            JSONObject submittedJson = new JSONObject(stringBuilder.toString());
            log.debug(submittedJson.toString());

            String xmlString = XML.toString(submittedJson);
            log.debug("The json converted to XML " + xmlString);

            MetaDataMap metaDataMap = workItem.getWorkflow().getWorkflowData().getMetaDataMap();
            metaDataMap.put("xmlData", xmlString);
        } catch (Exception e) {
            log.error("Error converting JSON to XML: " + e.getMessage(), e);
        }
    }
}

Criar fluxo de trabalho

Para lidar com envios de formulários, crie um fluxo de trabalho que inclua duas etapas:

  1. A etapa inicial emprega um processo personalizado para transformar os dados JSON enviados em XML.
  2. A etapa subsequente gera uma PDF combinando os dados XML com o modelo XDP.

json-para-xml

Implante o código de exemplo

Para testar isso no servidor local, siga estas etapas simplificadas:

  1. Baixe e instale o pacote personalizado por meio do console OSGi da Web do AEM.
  2. Importar o pacote de fluxo de trabalho.
  3. Importe o formulário adaptável de exemplo e o modelo XDP.
  4. Visualizar o Formulário Adaptável.
  5. Preencha alguns campos de formulário.
  6. Envie o formulário para iniciar o workflow do AEM.
  7. Encontre o PDF renderizado na pasta de carga do fluxo de trabalho.
recommendation-more-help