| // Copyright (C) 2012 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.google.gerrit.server; |
| |
| import static java.util.Objects.requireNonNull; |
| |
| import com.google.auto.value.AutoValue; |
| import com.google.common.base.MoreObjects; |
| import com.google.common.collect.ImmutableListMultimap; |
| import com.google.common.collect.ListMultimap; |
| import com.google.gerrit.server.util.time.TimeUtil; |
| |
| public class AuditEvent { |
| |
| public static final String UNKNOWN_SESSION_ID = "000000000000000000000000000"; |
| protected static final ImmutableListMultimap<String, ?> EMPTY_PARAMS = ImmutableListMultimap.of(); |
| |
| public final String sessionId; |
| public final CurrentUser who; |
| public final long when; |
| public final String what; |
| public final ListMultimap<String, ?> params; |
| public final Object result; |
| public final long timeAtStart; |
| public final long elapsed; |
| public final UUID uuid; |
| |
| @AutoValue |
| public abstract static class UUID { |
| private static UUID create() { |
| return new AutoValue_AuditEvent_UUID( |
| String.format("audit:%s", java.util.UUID.randomUUID().toString())); |
| } |
| |
| public abstract String uuid(); |
| } |
| |
| /** |
| * Creates a new audit event with results |
| * |
| * @param sessionId session id the event belongs to |
| * @param who principal that has generated the event |
| * @param what object of the event |
| * @param when time-stamp of when the event started |
| * @param params parameters of the event |
| * @param result result of the event |
| */ |
| public AuditEvent( |
| String sessionId, |
| CurrentUser who, |
| String what, |
| long when, |
| ListMultimap<String, ?> params, |
| Object result) { |
| requireNonNull(what, "what is a mandatory not null param !"); |
| |
| this.sessionId = MoreObjects.firstNonNull(sessionId, UNKNOWN_SESSION_ID); |
| this.who = who; |
| this.what = what; |
| this.when = when; |
| this.timeAtStart = this.when; |
| this.params = MoreObjects.firstNonNull(params, EMPTY_PARAMS); |
| this.uuid = UUID.create(); |
| this.result = result; |
| this.elapsed = TimeUtil.nowMs() - timeAtStart; |
| } |
| |
| @Override |
| public int hashCode() { |
| return uuid.hashCode(); |
| } |
| |
| // This is a value class that allows adding attributes by subclassing. |
| // Doing this is discouraged and using composition rather than inheritance to add fields to value |
| // types is preferred. However this class is part of the plugin API (used in the AuditListener |
| // extension point), hence we cannot change it without breaking plugins. Hence suppress the |
| // EqualsGetClass warning here. |
| @SuppressWarnings("EqualsGetClass") |
| @Override |
| public boolean equals(Object obj) { |
| if (this == obj) { |
| return true; |
| } |
| if (obj == null) { |
| return false; |
| } |
| if (getClass() != obj.getClass()) { |
| return false; |
| } |
| |
| AuditEvent other = (AuditEvent) obj; |
| return this.uuid.equals(other.uuid); |
| } |
| |
| @Override |
| public String toString() { |
| return String.format( |
| "AuditEvent UUID:%s, SID:%s, TS:%d, who:%s, what:%s", |
| uuid.uuid(), sessionId, when, who, what); |
| } |
| } |