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

io.helidon.microprofile.accesslog.AccessLogCdiExtension Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 2019, 2023 Oracle and/or its affiliates.
 *
 * 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.microprofile.accesslog;

import io.helidon.config.Config;
import io.helidon.microprofile.cdi.RuntimeStart;
import io.helidon.microprofile.server.ServerCdiExtension;
import io.helidon.webserver.accesslog.AccessLogFeature;

import jakarta.annotation.Priority;
import jakarta.enterprise.event.Observes;
import jakarta.enterprise.inject.spi.BeanManager;
import jakarta.enterprise.inject.spi.Extension;

import static jakarta.interceptor.Interceptor.Priority.PLATFORM_BEFORE;

/**
 * Extension of MicroProfile to add support for access log.
 */
public class AccessLogCdiExtension implements Extension {
    private static final System.Logger LOGGER = System.getLogger(AccessLogCdiExtension.class.getName());

    private void setUpAccessLog(@Observes @Priority(PLATFORM_BEFORE + 10) @RuntimeStart Config config,
                                BeanManager beanManager) {
        Config alConfig = config.get("server.access-log");
        Config newAlConfig = config.get("server.features.access-log");

        if (!alConfig.exists() && newAlConfig.exists()) {
            // do nothing, server will pick it up automatically
            return;
        }
        // default to old behavior
        if (alConfig.exists()) {
            LOGGER.log(System.Logger.Level.WARNING, "Configuration key server.access-log is deprecated,"
                    + " please use server.features.access-log instead");
        }
        beanManager.getExtension(ServerCdiExtension.class)
                .addFeature(AccessLogFeature.create(alConfig));
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy