All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.helidon.security.internal.SecurityAuditEvent Maven / Gradle / Ivy

There is a newer version: 4.1.4
Show newest version
/*
 * Copyright (c) 2018 Oracle and/or its affiliates. All rights reserved.
 *
 * 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 io.helidon.security.internal;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Optional;

import io.helidon.security.AuditEvent;

/**
 * A default implementation of AuditEvent, used by security itself.
 */
public final class SecurityAuditEvent implements AuditEvent {
    private final AuditSeverity severity;
    private final String eventType;
    private final String messageFormat;
    private final Optional throwable;
    private final List auditParameters = new ArrayList<>();

    private SecurityAuditEvent(AuditSeverity severity,
                               String eventType,
                               String messageFormat,
                               Throwable throwable) {
        this.severity = severity;
        this.eventType = eventType;
        this.messageFormat = messageFormat;
        this.throwable = Optional.ofNullable(throwable);
    }

    /**
     * Factory method to create a security audit event.
     *
     * @param eventType     Type of event
     * @param messageFormat Format of event message
     * @return event instance
     */
    public static SecurityAuditEvent info(String eventType, String messageFormat) {
        return new SecurityAuditEvent(AuditSeverity.INFO, eventType, messageFormat, null);
    }

    /**
     * Factory method to create a security audit event.
     *
     * @param eventType     Type of event
     * @param messageFormat Format of event message
     * @return event instance
     */
    public static SecurityAuditEvent success(String eventType, String messageFormat) {
        return new SecurityAuditEvent(AuditSeverity.SUCCESS, eventType, messageFormat, null);
    }

    /**
     * Factory method to create a security audit event.
     *
     * @param eventType     Type of event
     * @param messageFormat Format of event message
     * @return event instance
     */
    public static SecurityAuditEvent warn(String eventType, String messageFormat) {
        return new SecurityAuditEvent(AuditSeverity.WARN, eventType, messageFormat, null);
    }

    /**
     * Factory method to create a security audit event.
     *
     * @param eventType     Type of event
     * @param messageFormat Format of event message
     * @param e             Throwable to be audited
     * @return event instance
     */
    public static SecurityAuditEvent warn(String eventType, String messageFormat, Throwable e) {
        return new SecurityAuditEvent(AuditSeverity.WARN, eventType, messageFormat, e);
    }

    /**
     * Factory method to create a security audit event.
     *
     * @param eventType     Type of event
     * @param messageFormat Format of event message
     * @return event instance
     */
    public static SecurityAuditEvent error(String eventType, String messageFormat) {
        return new SecurityAuditEvent(AuditSeverity.ERROR, eventType, messageFormat, null);
    }

    /**
     * Factory method to create a security audit event.
     *
     * @param eventType     Type of event
     * @param messageFormat Format of event message
     * @param e             Throwable to be audited
     * @return event instance
     */
    public static SecurityAuditEvent error(String eventType, String messageFormat, Throwable e) {
        return new SecurityAuditEvent(AuditSeverity.ERROR, eventType, messageFormat, e);
    }

    /**
     * Factory method to create a security audit event.
     *
     * @param eventType     Type of event
     * @param messageFormat Format of event message
     * @return event instance
     */
    public static SecurityAuditEvent failure(String eventType, String messageFormat) {
        return new SecurityAuditEvent(AuditSeverity.FAILURE, eventType, messageFormat, null);
    }

    /**
     * Factory method to create a security audit event.
     *
     * @param eventType     Type of event
     * @param messageFormat Format of event message
     * @param e             Throwable to be audited
     * @return event instance
     */
    public static SecurityAuditEvent failure(String eventType, String messageFormat, Throwable e) {
        return new SecurityAuditEvent(AuditSeverity.FAILURE, eventType, messageFormat, e);
    }

    /**
     * Factory method to create a security audit event.
     *
     * @param eventType     Type of event
     * @param messageFormat Format of event message
     * @return event instance
     */
    public static SecurityAuditEvent auditFailure(String eventType, String messageFormat) {
        return new SecurityAuditEvent(AuditSeverity.AUDIT_FAILURE, eventType, messageFormat, null);
    }

    /**
     * Factory method to create a security audit event.
     *
     * @param eventType     Type of event
     * @param messageFormat Format of event message
     * @param e             Throwable to be audited
     * @return event instance
     */
    public static SecurityAuditEvent auditFailure(String eventType, String messageFormat, Throwable e) {
        return new SecurityAuditEvent(AuditSeverity.AUDIT_FAILURE, eventType, messageFormat, e);
    }

    /**
     * Create a new audit event.
     *
     * @param severity      Severity of this event
     * @param eventType     Event type
     * @param messageFormat Message format to print this event out (default - may be overridden by {@link
     *                      io.helidon.security.spi.AuditProvider})
     * @return event instance
     */
    public static SecurityAuditEvent audit(AuditSeverity severity, String eventType, String messageFormat) {
        return new SecurityAuditEvent(severity, eventType, messageFormat, null);
    }

    /**
     * Add a parameter to this event.
     *
     * @param param parameter to add, e.g. using {@link AuditParam#plain(String, Object)}
     * @return updated instance
     */
    public SecurityAuditEvent addParam(AuditParam param) {
        this.auditParameters.add(param);
        return this;
    }

    @Override
    public String eventType() {
        return eventType;
    }

    @Override
    public Optional throwable() {
        return throwable;
    }

    @Override
    public List params() {
        return Collections.unmodifiableList(auditParameters);
    }

    @Override
    public String messageFormat() {
        return messageFormat;
    }

    @Override
    public AuditSeverity severity() {
        return severity;
    }

    @Override
    public String toString() {
        return "AuditEvent{"
                + "severity=" + severity
                + ", eventType='" + eventType + '\''
                + ", messageFormat='" + messageFormat + '\''
                + ", throwable=" + throwable
                + ", auditParameters=" + toString(auditParameters)
                + '}';
    }

    private String toString(List auditParameters) {
        StringBuilder response = new StringBuilder();

        for (AuditParam param : auditParameters) {
            if (param.isSensitive()) {
                response.append(param.name()).append("=").append("********");
            } else {
                response.append(param.name()).append("=").append(param.value().orElse("null"));
            }
            response.append(",");
        }

        if (response.length() != 0) {
            return response.substring(0, response.length() - 1);
        }

        return response.toString();
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy