com.googlesource.gerrit.plugins.auditsl4j.AuditRendererToCsv.java Source code

Java tutorial

Introduction

Here is the source code for com.googlesource.gerrit.plugins.auditsl4j.AuditRendererToCsv.java

Source

// Copyright (C) 2018 The Android Open Source Project
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

package com.googlesource.gerrit.plugins.auditsl4j;

import com.google.common.collect.Multimap;
import com.google.gerrit.server.AuditEvent;
import com.google.gerrit.server.audit.ExtendedHttpAuditEvent;
import com.google.gerrit.server.audit.HttpAuditEvent;
import com.google.gerrit.server.audit.SshAuditEvent;
import java.text.SimpleDateFormat;
import java.util.Collection;
import java.util.Collections;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import java.util.Optional;
import java.util.Set;
import java.util.TreeSet;

public class AuditRendererToCsv implements AuditFormatRenderer {

    private static final SimpleDateFormat dateFmt = new SimpleDateFormat("yyyy/MM/dd hh:mm:ss.SSSS");

    @SuppressWarnings("serial")
    private static final Map<Class<?>, CsvFieldFormatter<?>> FIELD_CSV_FORMATTERS = Collections
            .unmodifiableMap(new HashMap<Class<?>, CsvFieldFormatter<? extends Object>>() {
                {
                    put(HttpAuditEvent.class, new HttpAuditEventFormat());
                    put(ExtendedHttpAuditEvent.class, new HttpAuditEventFormat());
                    put(SshAuditEvent.class, new SshAuditEventFormat());
                    put(AuditEvent.class, new AuditEventFormat());
                }
            });

    interface CsvFieldFormatter<T> {
        String formatToCsv(T result);
    }

    static class HttpAuditEventFormat implements CsvFieldFormatter<HttpAuditEvent> {

        @Override
        public String formatToCsv(HttpAuditEvent result) {
            return "HTTP-" + result.httpMethod + ", Status:" + result.httpStatus;
        }
    }

    static class SshAuditEventFormat implements CsvFieldFormatter<SshAuditEvent> {
        @Override
        public String formatToCsv(SshAuditEvent result) {
            return "SSH";
        }
    }

    static class AuditEventFormat implements CsvFieldFormatter<SshAuditEvent> {

        @Override
        public String formatToCsv(SshAuditEvent result) {
            return "";
        }
    }

    @Override
    public String render(AuditEvent auditEvent) {
        return String.format("%1$s | %2$s | %3$s | %4$s | %5$s | %6$s | %7$s | %8$s | %9$s | %10$s",
                auditEvent.uuid.uuid(), getFormattedTS(auditEvent.when), auditEvent.sessionId,
                getFieldAsCsv(auditEvent.who), getFieldAsCsv(auditEvent), auditEvent.what,
                getFormattedAuditList(auditEvent.params), getFieldAsCsv(auditEvent.result),
                getFormattedTS(auditEvent.timeAtStart), auditEvent.elapsed);
    }

    @Override
    public String render(AuditEvent auditEvent, TransformableAuditLogType type) {
        return render(auditEvent);
    }

    @Override
    public Optional<String> headers() {
        return Optional.of(
                "EventId | EventTS | SessionId | User | Protocol data | Action | Parameters | Result | StartTS | Elapsed");
    }

    private Object getFormattedAuditList(Multimap<String, ?> params) {
        if (params == null || params.size() == 0) {
            return "[]";
        }

        StringBuilder formattedOut = new StringBuilder("[");

        Set<String> paramNames = new TreeSet<>(params.keySet());

        int numParams = 0;
        for (String paramName : paramNames) {
            if (numParams++ > 0) {
                formattedOut.append(",");
            }
            formattedOut.append(paramName);
            formattedOut.append("=");
            formattedOut.append(getFormattedAudit(params.get(paramName)));
        }

        formattedOut.append(']');

        return formattedOut.toString();
    }

    private Object getFormattedAudit(Collection<? extends Object> values) {
        StringBuilder out = new StringBuilder();
        int numValues = 0;
        for (Object object : values) {
            if (numValues > 0) {
                out.append(",");
            }
            out.append(getFieldAsCsv(object));
            numValues++;
        }

        if (numValues > 1) {
            return "[" + out.toString() + "]";
        }
        return out.toString();
    }

    public static <T> String getFieldAsCsv(T result) {
        if (result == null)
            return "";

        @SuppressWarnings("unchecked")
        CsvFieldFormatter<T> fmt = (CsvFieldFormatter<T>) FIELD_CSV_FORMATTERS.get(result.getClass());
        if (fmt == null)
            return result.toString();

        return fmt.formatToCsv(result);
    }

    public static synchronized String getFormattedTS(long when) {
        return dateFmt.format(new Date(when));
    }
}