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.model.enm.TransactionLogEventSubTypeEnum;
013import ca.cdr.api.model.enm.TransactionLogEventTypeEnum;
014import ca.cdr.api.model.json.TransactionLogEventsJson;
015import ca.cdr.api.model.json.TransactionLogStepJson;
016import com.fasterxml.jackson.core.JsonProcessingException;
017import com.fasterxml.jackson.databind.ObjectMapper;
018import org.apache.commons.lang3.StringUtils;
019import org.slf4j.Logger;
020import org.slf4j.LoggerFactory;
021
022import java.util.List;
023import java.util.Map;
024
025import static org.apache.commons.lang3.ObjectUtils.isEmpty;
026
027/**
028 * Parameter Object class encapsulating the properties required to persist a {@link TransactionLogEventsJson.TransactionLogEventJson}
029 *
030 * @apiNote  myType the type of event that is logged
031 * @apiNote  mySubType sub-categories precising the type
032 * @apiNote  myTransactionGuid the GUID of the transaction log
033 * @apiNote  myInitialSteps the {@link TransactionLogStepJson} to add to this transaction log
034 * @apiNote  myTransactionId unique ID identifying the request for which this transaction is created
035 * @apiNote  myModuleId the ID of the module creating the log
036 * @apiNote  myUserPid the PID of the user creating the log
037 * @apiNote  myAdditionalJson inline JSON of client provided key/value pairs
038 *
039 */
040public class IncomingTransactionLog {
041        private static final Logger ourLog = LoggerFactory.getLogger(IncomingTransactionLog.class);
042        private final TransactionLogEventTypeEnum myType;
043        private final TransactionLogEventSubTypeEnum mySubType;
044        private final List<TransactionLogStepJson> myInitialSteps;
045        private final String myTransactionId;
046        private final String myTransactionGuid;
047        private final String myModuleId;
048        private final String myAdditionalJson;
049
050        private final Long myUserPid;
051        private final String myUsername;
052
053        public static IncomingTransactionLogBuilder builder() {
054                return new IncomingTransactionLogBuilder();
055        }
056
057        public static IncomingTransactionLogBuilder from(IncomingTransactionLog theIncomingTransactionLog) {
058                return builder()
059                                .withType(theIncomingTransactionLog.myType)
060                                .withSubType(theIncomingTransactionLog.mySubType)
061                                .withInitialSteps(theIncomingTransactionLog.myInitialSteps)
062                                .withTransactionId(theIncomingTransactionLog.myTransactionId)
063                                .withTransactionGuid(theIncomingTransactionLog.myTransactionGuid)
064                                .withModuleId(theIncomingTransactionLog.myModuleId)
065                                .withAdditionalJsonSting(theIncomingTransactionLog.myAdditionalJson)
066                                .withUserPid(theIncomingTransactionLog.myUserPid)
067                                .withUsername(theIncomingTransactionLog.myUsername);
068        }
069
070        private IncomingTransactionLog(IncomingTransactionLogBuilder theIncomingTransactionLogBuilder) {
071                myType = theIncomingTransactionLogBuilder.myType;
072                mySubType = theIncomingTransactionLogBuilder.mySubType;
073                myInitialSteps = theIncomingTransactionLogBuilder.myInitialSteps;
074                myTransactionId = theIncomingTransactionLogBuilder.myTransactionId;
075                myTransactionGuid = theIncomingTransactionLogBuilder.myTransactionGuid;
076                myModuleId = theIncomingTransactionLogBuilder.myModuleId;
077                myAdditionalJson = theIncomingTransactionLogBuilder.myAdditionalJson;
078                myUsername = theIncomingTransactionLogBuilder.myUsername;
079                myUserPid = theIncomingTransactionLogBuilder.myUserPid;
080        }
081
082        public static IncomingTransactionLog from(TransactionLogEventsJson.TransactionLogEventJson theLog) {
083                return builder()
084                                .withType(theLog.getType())
085                                .withSubType(theLog.getSubType())
086                                .withInitialSteps(theLog.getEvents())
087                                .withTransactionId(theLog.getRequestId())
088                                .withTransactionGuid(theLog.getTransactionGuid())
089                                .withModuleId(theLog.getEndpointModuleId())
090                                .withAdditionalJsonSting(theLog.getAdditionalJson())
091                                .withUserPid(theLog.getUserId())
092                                .withUsername(theLog.getUsername())
093                                .build();
094        }
095
096        public TransactionLogEventTypeEnum getType() {
097                return myType;
098        }
099
100        public TransactionLogEventSubTypeEnum getSubType() {
101                return mySubType;
102        }
103
104        public Long getUserPid() {
105                return myUserPid;
106        }
107
108        public String getUsername() {
109                return myUsername;
110        }
111
112        public List<TransactionLogStepJson> getInitialSteps() {
113                return myInitialSteps;
114        }
115
116        public String getTransactionId() {
117                return myTransactionId;
118        }
119
120        public String getTransactionGuid() {
121                return myTransactionGuid;
122        }
123
124        public boolean hasTransactionGuid() {
125                return StringUtils.isNotEmpty(myTransactionGuid);
126        }
127
128        public String getModuleId() {
129                return myModuleId;
130        }
131
132        public String getAdditionalJson() {
133                return myAdditionalJson;
134        }
135
136        public static final class IncomingTransactionLogBuilder {
137                private final ObjectMapper ourObjectMapper = new ObjectMapper();
138                private TransactionLogEventTypeEnum myType;
139                private TransactionLogEventSubTypeEnum mySubType;
140                private List<TransactionLogStepJson> myInitialSteps;
141                private String myTransactionId;
142                private String myTransactionGuid;
143                private String myModuleId;
144                private String myAdditionalJson;
145                private String myUsername;
146                private Long myUserPid;
147
148                private IncomingTransactionLogBuilder() {}
149
150                public IncomingTransactionLogBuilder withType(TransactionLogEventTypeEnum theType) {
151                        myType = theType;
152                        return this;
153                }
154
155                public IncomingTransactionLogBuilder withSubType(TransactionLogEventSubTypeEnum theSubType) {
156                        mySubType = theSubType;
157                        return this;
158                }
159
160                public IncomingTransactionLogBuilder withInitialSteps(List<TransactionLogStepJson> theInitialSteps) {
161                        myInitialSteps = theInitialSteps;
162                        return this;
163                }
164
165                public IncomingTransactionLogBuilder withTransactionId(String theTransactionId) {
166                        myTransactionId = theTransactionId;
167                        return this;
168                }
169
170                public IncomingTransactionLogBuilder withTransactionGuid(String theTransactionGuid) {
171                        myTransactionGuid = theTransactionGuid;
172                        return this;
173                }
174
175                public IncomingTransactionLogBuilder withModuleId(String theModuleId) {
176                        myModuleId = theModuleId;
177                        return this;
178                }
179
180                public IncomingTransactionLogBuilder withUsername(String theUsername) {
181                        myUsername = theUsername;
182                        return this;
183                }
184
185                public IncomingTransactionLogBuilder withUserPid(Long theUserPid) {
186                        myUserPid = theUserPid;
187                        return this;
188                }
189
190                public IncomingTransactionLogBuilder withAdditionalProperties(Map<String, Object> theAdditionalProperties) {
191                        if (isEmpty(theAdditionalProperties)) {
192                                return this;
193                        }
194
195                        try {
196                                myAdditionalJson = ourObjectMapper.writeValueAsString(theAdditionalProperties);
197                        } catch (JsonProcessingException e) {
198                                ourLog.error("Could not serialize the additional properties to json string", e);
199                        }
200
201                        return this;
202                }
203
204                public IncomingTransactionLog build() {
205                        return new IncomingTransactionLog(this);
206                }
207
208                private IncomingTransactionLogBuilder withAdditionalJsonSting(String theAdditionalJsonSting) {
209                        myAdditionalJson = theAdditionalJsonSting;
210                        return this;
211                }
212        }
213}