Added oparent to sdc main
[sdc.git] / catalog-be / src / main / java / org / openecomp / sdc / be / auditing / impl / AuditConsumerEventFactory.java
1 /*-
2  * ============LICENSE_START=======================================================
3  * SDC
4  * ================================================================================
5  * Copyright (C) 2019 AT&T Intellectual Property. All rights reserved.
6  * ================================================================================
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  * 
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  * 
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  * ============LICENSE_END=========================================================
19  */
20
21 package org.openecomp.sdc.be.auditing.impl;
22
23 import org.openecomp.sdc.be.model.ConsumerDefinition;
24 import org.openecomp.sdc.be.model.User;
25 import org.openecomp.sdc.be.resources.data.auditing.AuditingActionEnum;
26 import org.openecomp.sdc.be.resources.data.auditing.AuditingGenericEvent;
27 import org.openecomp.sdc.be.resources.data.auditing.ConsumerEvent;
28 import org.openecomp.sdc.be.resources.data.auditing.model.CommonAuditData;
29
30 public class AuditConsumerEventFactory extends AuditBaseEventFactory {
31
32     private static final String LOG_STR = "ACTION = \"%s\" MODIFIER = \"%s\" ECOMP_USER = \"%s\" STATUS = \"%s\" DESC = \"%s\"";
33     private final ConsumerEvent event;
34
35     public AuditConsumerEventFactory(AuditingActionEnum action, CommonAuditData commonFields, User modifier, ConsumerDefinition ecompUser) {
36         this(action, commonFields, buildConsumerName(ecompUser), buildUserName(modifier));
37     }
38
39     public AuditConsumerEventFactory(AuditingActionEnum action, CommonAuditData commonFields,
40                                      String ecompUser, String modifier, String timestamp) {
41         this(action, commonFields, ecompUser, modifier);
42         this.event.setTimestamp1(timestamp);
43     }
44
45     private AuditConsumerEventFactory(AuditingActionEnum action, CommonAuditData commonFields,
46                                      String ecompUser, String modifier) {
47         super(action);
48         event = new ConsumerEvent(getAction().getName(), commonFields, ecompUser, modifier);
49     }
50
51     @Override
52     public String getLogPattern() {
53         return LOG_STR;
54     }
55
56     @Override
57     public String[] getLogMessageParams() {
58         return new String[] {event.getAction(), event.getModifier(), event.getEcompUser(), event.getStatus(), event.getDesc()};
59     }
60
61     @Override
62     public AuditingGenericEvent getDbEvent() {
63         return event;
64     }
65
66     static String buildConsumerName(ConsumerDefinition consumer) {
67         StringBuilder ecompUser = new StringBuilder();
68         if (consumer != null) {
69             appendIfNotEmpty(consumer.getConsumerName(), ecompUser, ",");
70             appendIfNotEmpty(consumer.getConsumerSalt(), ecompUser, ",");
71             appendIfNotEmpty(consumer.getConsumerPassword(), ecompUser, ",");
72         }
73         return ecompUser.toString();
74     }
75 }