001/*- 002 * #%L 003 * Smile CDR - CDR 004 * %% 005 * Copyright (C) 2016 - 2025 Smile CDR, Inc. 006 * %% 007 * All rights reserved. 008 * #L% 009 */ 010package ca.cdr.api.camel; 011 012import ca.cdr.api.model.enm.TransactionLogBodyTypeEnum; 013import ca.cdr.api.model.enm.TransactionLogOutcomeEnum; 014import ca.cdr.api.model.enm.TransactionLogStepTypeEnum; 015import ca.cdr.api.model.json.TransactionLogStepJson; 016import org.apache.camel.Exchange; 017import org.apache.commons.lang3.tuple.Pair; 018 019import java.util.List; 020 021public interface ICamelProcessorTxLogHelper { 022 023 /** 024 * Requests to include message body in the transaction log step 025 * Default value is true 026 */ 027 String TX_LOG_PARAM_SHOW_BODY = "showMsgBody"; 028 029 /** 030 * If transaction logging was initiated (smile:txLogStart procedure, present before current procedure in 031 * route), adds a log step to the transaction log 032 * @param theExchange the camel exchange 033 * @param theProcedureName the log-producing procedure name 034 */ 035 void addStepIfTxLogActive(Exchange theExchange, String theProcedureName); 036 037 /** 038 * If transaction logging was initiated (smile:txLogStart procedure, present before current procedure in 039 * route), adds step from provider to the transaction log 040 * @param theExchange the camel exchange 041 * @param theStepsProvider the provider of the corresponding transaction log steps 042 */ 043 void addStepIfTxLogActive(Exchange theExchange, ITxLogStepsProvider theStepsProvider); 044 045 /** 046 * If transaction logging was initiated (smile:txLogStart procedure, present before current procedure in 047 * route), adds step from provider to the transaction log, adds the list of steps to the transaction log 048 * @param theExchange the camel exchange 049 * @param theLogSteps the log steps to be added to the transaction log 050 */ 051 void addStepIfTxLogActive(Exchange theExchange, List<TransactionLogStepJson> theLogSteps); 052 053 /** 054 * Builds a new transaction log step considering received exchange properties and parameters. 055 * @param theExchange the camel exchange 056 * @param theLogStepType the transaction log step type 057 * @param theBodyAndType A Pair containing the body and the body type or null 058 * @param theOutcome The desired step outcome 059 * @return the built transaction log step 060 */ 061 TransactionLogStepJson buildTxLogStep( 062 Exchange theExchange, 063 TransactionLogStepTypeEnum theLogStepType, 064 Pair<String, TransactionLogBodyTypeEnum> theBodyAndType, 065 TransactionLogOutcomeEnum theOutcome); 066 067 /** 068 * Builds a string containing the received procedure name, including the module id if present in the exchange 069 * @param theExchange the camel exchange 070 * @param theProcedureName the log-producing procedure name 071 * @return a string with the built executing procedure URI 072 */ 073 String getRequestUrl(Exchange theExchange, String theProcedureName); 074 075 /** 076 * Informs if 'showMsgBody' parameter is present 077 * @param theExchange the camel exchange 078 * @return boolean indicating if 'showMsgBody' parameter is present 079 */ 080 boolean isTxLogShowBody(Exchange theExchange); 081 082 /** 083 * informs if a transaction log is active for the route 084 * @param theExchange the camel exchange 085 * @return boolean indicating if transaction log is active for the route 086 */ 087 boolean isTxLogStarted(Exchange theExchange); 088 089 /** 090 * Requests transaction log initiation for the route 091 * @param theExchange the camel exchange 092 */ 093 void startTxLog(Exchange theExchange); 094 095 /** 096 * Commits the transaction log to configured writers 097 * @param theExchange the camel exchange 098 */ 099 void commitTxLog(Exchange theExchange); 100 101 /** 102 * Discards current transaction logging and marks logging not initiated for the route 103 * @param theExchange the camel exchange 104 */ 105 void clearTxLog(Exchange theExchange); 106}