View Javadoc
1   /*
2    * Licensed to the Apache Software Foundation (ASF) under one
3    * or more contributor license agreements.  See the NOTICE file
4    * distributed with this work for additional information
5    * regarding copyright ownership.  The ASF licenses this file
6    * to you under the Apache License, Version 2.0 (the
7    * "License"); you may not use this file except in compliance
8    * with the License.  You may obtain a copy of the License at
9    *
10   *   http://www.apache.org/licenses/LICENSE-2.0
11   *
12   * Unless required by applicable law or agreed to in writing,
13   * software distributed under the License is distributed on an
14   * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15   * KIND, either express or implied.  See the License for the
16   * specific language governing permissions and limitations
17   * under the License.
18   */
19  package org.apache.syncope.core.logic.audit;
20  
21  import com.fasterxml.jackson.databind.JsonNode;
22  import java.io.Serializable;
23  import org.apache.logging.log4j.core.Filter;
24  import org.apache.logging.log4j.core.Layout;
25  import org.apache.logging.log4j.core.LogEvent;
26  import org.apache.logging.log4j.core.appender.AbstractAppender;
27  import org.apache.logging.log4j.core.config.Property;
28  import org.apache.logging.log4j.core.config.plugins.PluginBuilderFactory;
29  import org.apache.syncope.core.provisioning.api.serialization.POJOHelper;
30  import org.apache.syncope.ext.opensearch.client.OpenSearchIndexManager;
31  
32  public class OpenSearchAppender extends AbstractAppender {
33  
34      public static class Builder extends AbstractAppender.Builder<Builder>
35              implements org.apache.logging.log4j.core.util.Builder<OpenSearchAppender> {
36  
37          private OpenSearchIndexManager openSearchIndexManager;
38  
39          private String domain;
40  
41          public OpenSearchAppender.Builder setDomain(final String domain) {
42              this.domain = domain;
43              return this;
44          }
45  
46          public OpenSearchAppender.Builder setIndexManager(
47                  final OpenSearchIndexManager openSearchIndexManager) {
48  
49              this.openSearchIndexManager = openSearchIndexManager;
50              return this;
51          }
52  
53          @Override
54          public OpenSearchAppender build() {
55              if (domain == null || openSearchIndexManager == null) {
56                  LOGGER.error("Cannot create OpenSearchAppender without Domain or IndexManager.");
57                  return null;
58              }
59              return new OpenSearchAppender(
60                      getName(), getFilter(), getLayout(), isIgnoreExceptions(), domain, openSearchIndexManager);
61          }
62      }
63  
64      @PluginBuilderFactory
65      public static Builder newBuilder() {
66          return new Builder();
67      }
68  
69      private final String domain;
70  
71      protected final OpenSearchIndexManager openSearchIndexManager;
72  
73      protected OpenSearchAppender(
74              final String name,
75              final Filter filter,
76              final Layout<? extends Serializable> layout,
77              final boolean ignoreExceptions,
78              final String domain,
79              final OpenSearchIndexManager openSearchIndexManager) {
80  
81          super(name, filter, layout, ignoreExceptions, Property.EMPTY_ARRAY);
82          this.domain = domain;
83          this.openSearchIndexManager = openSearchIndexManager;
84      }
85  
86      @Override
87      public void append(final LogEvent event) {
88          try {
89              openSearchIndexManager.audit(
90                      domain,
91                      event.getTimeMillis(),
92                      POJOHelper.deserialize(event.getMessage().getFormattedMessage(), JsonNode.class));
93          } catch (Exception e) {
94              LOGGER.error("While requesting to index event for appender [{}]", getName(), e);
95          }
96      }
97  }