All Downloads are FREE. Search and download functionalities are using the official Maven repository.

no.digipost.api.config.TransaksjonsLogg Maven / Gradle / Ivy

The newest version!
package no.digipost.api.config;

import no.digipost.org.oasis_open.docs.ebxml_msg.ebms.v3_0.ns.core._200704.Error;
import no.digipost.org.oasis_open.docs.ebxml_msg.ebms.v3_0.ns.core._200704.MessageInfo;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.ws.soap.SoapFault;

import static no.digipost.api.config.TransaksjonsLogg.Retning.INNKOMMENDE;
import static no.digipost.api.config.TransaksjonsLogg.Retning.UTGÅENDE;
import static no.digipost.api.config.TransaksjonsLogg.Type.EBMSFEIL;
import static no.digipost.api.config.TransaksjonsLogg.Type.SOAPFAULT;
import static org.apache.commons.lang3.StringUtils.defaultIfEmpty;

public class TransaksjonsLogg {

    public static final String EMPTY_MESSAGE_PARTITION_CHANNEL_EBMS_ERROR_CODE = "EBMS:0006";
    public static final String MF_LOGGER_TRANSLOG = "mf.logger.translog";
    private static final String N_A = "";
    private static final Logger LOG = LoggerFactory.getLogger(MF_LOGGER_TRANSLOG);

    public void innkommende(final String endpoint, final String orgnr, final Type type, final String mpc, final String conversationId, final String instanceIdentifier, final String messageId, final String refToMessageId) {
        log(endpoint, orgnr, INNKOMMENDE, type, mpc, conversationId, instanceIdentifier, messageId, refToMessageId, "");
    }

    public void utgående(final String endpoint, final String orgnr, final Type type, final String mpc, final String conversationId, final String instanceIdentifier, final String messageId, final String refToMessageId) {
        log(endpoint, orgnr, UTGÅENDE, type, mpc, conversationId, instanceIdentifier, messageId, refToMessageId, "");
    }

    public void log(final String endpoint, final String orgnr, final Retning retning, final Type type, final String mpc, final String conversationId, final String instanceIdentifier, final String messageId, final String refToMessageId, final String extra) {
        String ref = refToMessageId != null ? "ref:[" + refToMessageId + "]" : "";
        LOG.info("[{}] [{}] {} {} mpc:[{}] conversationId:[{}] instanceId:[{}] messageId:[{}] {} {}",
                endpoint, toLoggable(orgnr), retning, type, toLoggable(mpc), toLoggable(conversationId), toLoggable(instanceIdentifier), messageId, ref, extra);
    }

    public void soapfault(final String endpoint, final String orgnr, final SoapFault soapFault) {
        LOG.warn("[{}] [{}] {} fault:[{}]", endpoint, toLoggable(orgnr), SOAPFAULT, soapFault.getFaultStringOrReason());
    }

    private String toLoggable(final String s) {
        return defaultIfEmpty(s, N_A);
    }


    public void ebmserror(final String endpoint, final String orgnr, final Retning retning, final Error error, final MessageInfo messageInfo, final String mpc, final String conversationId, final String instanceIdentifier) {
        if (EMPTY_MESSAGE_PARTITION_CHANNEL_EBMS_ERROR_CODE.equals(error.getErrorCode())) {
            log(endpoint, orgnr, retning, EBMSFEIL, mpc, conversationId, instanceIdentifier, messageInfo.getMessageId(), messageInfo.getRefToMessageId(), "");
            return;
        }
        String errorMsg = String.format("error:[%s][%s]", error.getShortDescription(), error.getDescription() != null ? error.getDescription().getValue() : "");
        log(endpoint, orgnr, retning, EBMSFEIL, mpc, conversationId, instanceIdentifier, messageInfo.getMessageId(), messageInfo.getRefToMessageId(), errorMsg);
    }

    public enum Retning {
        INNKOMMENDE, UTGÅENDE
    }

    public enum Type {
        USERMESSAGE_SDP, USERMESSAGE_FLYTT, USERMESSAGE_FYSISK, PULLREQUEST, TRANSPORTKVITTERING, APPLIKASJONSKVITTERING, TOMKØ, EBMSFEIL, SOAPFAULT
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy