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

com.aspectran.core.context.env.Environment Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 2008-2025 The Aspectran 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.aspectran.core.context.env;

import com.aspectran.core.activity.Activity;

import java.util.Iterator;

/**
 * Interface representing the environment in which the current application is running.
 * Models two key aspects of the application environment: profiles and properties.
 */
public interface Environment {

    /**
     * Return the set of profiles explicitly made active for this environment. Profiles
     * are used for creating logical groupings of bean definitions to be registered
     * conditionally, for example based on deployment environment. Profiles can be
     * activated by setting {@linkplain EnvironmentProfiles#ACTIVE_PROFILES_PROPERTY_NAME
     * "aspectran.profiles.active"} as a system property or by calling
     * {@link EnvironmentProfiles#setActiveProfiles(String...)}.
     * 

If no profiles have explicitly been specified as active, then any * {@linkplain #getDefaultProfiles() default profiles} will automatically be activated. * @see #getDefaultProfiles * @see EnvironmentProfiles#setActiveProfiles * @see EnvironmentProfiles#ACTIVE_PROFILES_PROPERTY_NAME */ String[] getActiveProfiles(); /** * Return the set of profiles to be active by default when no active profiles have * been set explicitly. * @see #getActiveProfiles * @see EnvironmentProfiles#setDefaultProfiles * @see EnvironmentProfiles#DEFAULT_PROFILES_PROPERTY_NAME */ String[] getDefaultProfiles(); /** * Return the set of profiles explicitly made active for this environment. * If no active profile is explicitly set, returns the set of profiles to be * active by default. * @see #getActiveProfiles * @see EnvironmentProfiles#getActiveProfiles * @see #getDefaultProfiles * @see EnvironmentProfiles#getDefaultProfiles */ String[] getCurrentProfiles(); /** * Determine whether one of the given profile expressions matches the * {@linkplain #getActiveProfiles() active profiles} — or in the case * of no explicit active profiles, whether one of the given profile expressions * matches the {@linkplain #getDefaultProfiles() default profiles}. *

Profile expressions allow for complex, boolean profile logic to be * expressed — for example {@code "p1 & p2"}, {@code "(p1 & p2) | p3"}, * etc. See {@link Profiles#of(String)} for details on the supported * expression syntax. *

This method is a convenient shortcut for * {@code env.acceptsProfiles(Profiles.of(profileExpression))}. * @since 7.5.0 * @see Profiles#of(String) * @see #acceptsProfiles(Profiles) */ boolean matchesProfiles(String profileExpression); /** * Determine whether the given {@link Profiles} predicate matches the * {@linkplain #getActiveProfiles() active profiles} — or in the case * of no explicit active profiles, whether the given {@code Profiles} predicate * matches the {@linkplain #getDefaultProfiles() default profiles}. *

If you wish provide profile expressions directly as strings, use * {@link #matchesProfiles(String)} instead. * @since 7.5.0 * @see #matchesProfiles(String) * @see Profiles#of(String) */ boolean acceptsProfiles(Profiles profiles); /** * Return whether one or more of the given profiles is active or, in the case of no * explicit active profiles, whether one or more of the given profiles is included in * the set of default profiles. If a profile begins with '!' the logic is inverted, * i.e. the method will return true if the given profile is not active. * For example,

env.acceptsProfiles("p1", "!p2")
will * return {@code true} if profile 'p1' is active or 'p2' is not active. * @param profiles the given profiles * @return true if the given profile is active; false otherwise * @throws IllegalArgumentException if called with zero arguments * or if any profile is {@code null}, empty or whitespace-only * @see #getActiveProfiles * @see #getDefaultProfiles */ boolean acceptsProfiles(String... profiles); /** * Add a profile to the current set of active profiles. * @throws IllegalArgumentException if the profile is null, empty or whitespace-only */ void addActiveProfile(String profile); /** * Returns the value of the property on environment via the currently available activity. * @param the type of the value * @param name the given property name * @return the value of the property on environment */ T getProperty(String name); /** * Returns the value of the property on environment via the specified activity. * @param the type of the value * @param name the given property name * @param activity the activity * @return the value of the property on environment */ T getProperty(String name, Activity activity); Iterator getPropertyNames(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy