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.transactionlog; 011 012import ca.cdr.api.annotations.CdrPublicAPI; 013import ca.cdr.api.model.enm.TransactionLogEventSubTypeEnum; 014import ca.cdr.api.model.enm.TransactionLogEventTypeEnum; 015import ca.cdr.api.model.json.TransactionLogEventsJson; 016import ca.cdr.api.model.json.TransactionLogStepJson; 017 018import java.util.Collections; 019import java.util.List; 020 021/** 022 * This class is the ingestion point for all Transaction Logs generated in Smile CDR. This class is capable of routing all incoming 023 * Transaction Logs to every Module which implements a transaction log writer. If you are looking to create and store a Transaction Log, this is the class to use. 024 */ 025@CdrPublicAPI 026public interface ITransactionLogStoringSvc { 027 028 /** 029 * Creates a new Transaction Log. This method will persist the transaction log to all modules which implement a transaction log writer. 030 * 031 * @param theIncomingTransactionLog parameter object encapsulating the properties required to persist a {@link TransactionLogEventsJson.TransactionLogEventJson} 032 * @return Returns a {@link TransactionLogIdentifiers} indicating the underlying PID of the transaction log, for each module that was able to persist the log and its initial steps. 033 */ 034 TransactionLogIdentifiers persistNewLog(IncomingTransactionLog theIncomingTransactionLog); 035 036 @Deprecated 037 default TransactionLogIdentifiers persistNewLog( 038 TransactionLogEventTypeEnum theType, 039 TransactionLogEventSubTypeEnum theSubType, 040 List<TransactionLogStepJson> theInitialSteps, 041 String theTransactionId, 042 String theTransactionGuid, 043 String theModuleId) { 044 045 IncomingTransactionLog incomingTransactionLog = IncomingTransactionLog.builder() 046 .withType(theType) 047 .withSubType(theSubType) 048 .withInitialSteps(theInitialSteps) 049 .withTransactionId(theTransactionId) 050 .withTransactionGuid(theTransactionGuid) 051 .withModuleId(theModuleId) 052 .build(); 053 054 return persistNewLog(incomingTransactionLog); 055 } 056 057 @Deprecated 058 default TransactionLogIdentifiers persistNewLog( 059 TransactionLogEventTypeEnum theType, 060 TransactionLogEventSubTypeEnum theSubType, 061 TransactionLogStepJson theInitialStep, 062 String theTransactionId, 063 String theTransactionGuid, 064 String theModuleId) { 065 return persistNewLog( 066 theType, 067 theSubType, 068 Collections.singletonList(theInitialStep), 069 theTransactionId, 070 theTransactionGuid, 071 theModuleId); 072 } 073 074 @Deprecated 075 default TransactionLogIdentifiers persistNewLog( 076 TransactionLogEventTypeEnum theType, 077 TransactionLogEventSubTypeEnum theSubType, 078 List<TransactionLogStepJson> theInitialSteps, 079 String theTransactionId, 080 String theModuleId) { 081 return persistNewLog(theType, theSubType, theInitialSteps, theTransactionId, null, theModuleId); 082 } 083 084 @Deprecated 085 default TransactionLogIdentifiers persistNewLog( 086 TransactionLogEventTypeEnum theType, 087 TransactionLogEventSubTypeEnum theSubType, 088 TransactionLogStepJson theInitialStep, 089 String theTransactionId, 090 String theModuleId) { 091 return persistNewLog( 092 theType, theSubType, Collections.singletonList(theInitialStep), theTransactionId, null, theModuleId); 093 } 094 095 /** 096 * This method adds new steps to existing parent Transaction Logs. 097 * 098 * @param theTransactionPidMap the {@link TransactionLogIdentifiers} entity containing the mappings of writer to pid. 099 * @param theStep the {@link TransactionLogStepJson} to add to this parent transaction log. 100 */ 101 void persistNewStep(TransactionLogIdentifiers theTransactionPidMap, TransactionLogStepJson theStep); 102 103 /** 104 * This is an alternative to {@link #persistNewStep(TransactionLogIdentifiers, TransactionLogStepJson)}. 105 * 106 * Since the GUID is manually set on create, it is guaranteed to be identical across all the possible TX Log writers, and as such we need no map for lookup. 107 * This will add a new step to the existing parent transcation log, identified by GUID. 108 * 109 * @param theTransactionGuid the GUID of the parent transaction log. 110 * @param theStep the {@link TransactionLogStepJson} to add to this parent transaction log. 111 */ 112 void persistNewStep(String theTransactionGuid, TransactionLogStepJson theStep); 113 114 /** 115 * Given an event, delete it by ID. 116 * 117 * @param theId the ID of the event to delete. 118 */ 119 void deleteEvent(Long theId); 120 121 /** 122 * Indicates whether Transaction Logging is enabled anywhere on the system, either in the cluster manager, or any modules which implement a transaction log writer. 123 * 124 * @return true if transaction logging is enabled anywhere on the system. 125 */ 126 boolean isEnabled(); 127}