org.apache.brooklyn.api.entity.EntityLocal Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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 org.apache.brooklyn.api.entity;
import java.util.Map;
import org.apache.brooklyn.api.mgmt.SubscriptionContext;
import org.apache.brooklyn.api.mgmt.SubscriptionHandle;
import org.apache.brooklyn.api.mgmt.SubscriptionManager;
import org.apache.brooklyn.api.mgmt.Task;
import org.apache.brooklyn.api.sensor.AttributeSensor;
import org.apache.brooklyn.api.sensor.Sensor;
import org.apache.brooklyn.api.sensor.SensorEventListener;
import org.apache.brooklyn.config.ConfigKey;
import org.apache.brooklyn.config.ConfigKey.HasConfigKey;
import org.apache.brooklyn.util.guava.Maybe;
import com.google.common.annotations.Beta;
import com.google.common.base.Function;
/**
* Extended Entity interface for use in places where the caller should have certain privileges,
* such as setting attribute values, adding policies, etc.
*
* FIXME Moved from core project to api project because of bug in groovy's covariant return types.
* EntityDriver needs to return EntityLocal rather than Entity, to avoid changing a whole load
* of sub-types.
* FIXME Add {@link setAttribute(AttributeSensorAndConfigKey,T>)} back in if/when move it back,
* or if we extract an interface for AttributeSensorAndConfigKey.
*
* @deprecated since 0.9.0; use {@link Entity} or {@link org.apache.brooklyn.core.entity.EntityInternal}
*/
public interface EntityLocal extends Entity {
// FIXME Rename to something other than EntityLocal.
// Separate out what is specific to "local jvm", and what is here for an SPI rather than API.
/**
* @deprecated since 0.7.0; use {@link #config()}, such as {@code entity.config().set(key, val)}
*/
@Deprecated
T setConfig(ConfigKey key, T val);
/**
* @deprecated since 0.7.0; use {@link #config()}, such as {@code entity.config().set(key, val)}
*/
@Deprecated
T setConfig(ConfigKey key, Task val);
/**
* @deprecated since 0.7.0; use {@link #config()}, such as {@code entity.config().set(key, val)}
*/
@Deprecated
T setConfig(HasConfigKey key, T val);
/**
* @deprecated since 0.7.0; use {@link #config()}, such as {@code entity.config().set(key, val)}
*/
@Deprecated
T setConfig(HasConfigKey key, Task val);
/**
* @deprecated since 0.8.0; use {@link SensorSupport#set(AttributeSensor, Object)} via code like {@code sensors().set(attribute, val)}.
*/
T setAttribute(AttributeSensor attribute, T val);
/**
* @deprecated since 0.8.0; use {@link SensorSupport#modify(AttributeSensor, Function)} via code like {@code sensors().modify(attribute, modifier)}.
*/
@Beta
T modifyAttribute(AttributeSensor attribute, Function super T, Maybe> modifier);
/**
* @deprecated since 0.8.0; use {@link SensorSupport#emit(Sensor, Object)} via code like {@code sensors().emit(sensor, val)}.
*/
void emit(Sensor sensor, T value);
/**
* Allow us to subscribe to data from a {@link Sensor} on another entity.
*
* @return a subscription id which can be used to unsubscribe
*
* @see SubscriptionManager#subscribe(Map, Entity, Sensor, SensorEventListener)
*
* @deprecated since 0.9.0; see {@link SubscriptionSupportInternal#getSubscriptionContext()}, e.g. with {@code subscriptions().getSubscriptionContext()}
*/
@Deprecated
@Beta
SubscriptionHandle subscribe(Entity producer, Sensor sensor, SensorEventListener super T> listener);
/**
* @see SubscriptionManager#subscribeToChildren(Map, Entity, Sensor, SensorEventListener)
*
* @deprecated since 0.9.0; see {@link SubscriptionSupport#subscribeToChildren(Entity, Sensor, SensorEventListener)}, e.g. with {@code subscriptions().subscribeToChildren(...)}
*/
@Deprecated
@Beta
SubscriptionHandle subscribeToChildren(Entity parent, Sensor sensor, SensorEventListener super T> listener);
/**
* @see SubscriptionManager#subscribeToMembers(Group, Sensor, SensorEventListener)
*
* @deprecated since 0.9.0; see {@link SubscriptionSupport#subscribeToMembers(Entity, Sensor, SensorEventListener)}, e.g. with {@code subscriptions().subscribeToMembers(...)}
*/
@Deprecated
@Beta
SubscriptionHandle subscribeToMembers(Group group, Sensor sensor, SensorEventListener super T> listener);
/**
* Unsubscribes from the given producer.
*
* @see SubscriptionContext#unsubscribe(SubscriptionHandle)
*
* @deprecated since 0.9.0; see {@link SubscriptionSupport#unsubscribe(Entity)}, e.g. with {@code subscriptions().unsubscribe(...)}
*/
@Deprecated
@Beta
boolean unsubscribe(Entity producer);
/**
* Unsubscribes the given handle.
*
* @see SubscriptionContext#unsubscribe(SubscriptionHandle)
*
* @deprecated since 0.9.0; see {@link SubscriptionSupport#unsubscribe(Entity, SubscriptionHandle)}, e.g. with {@code subscriptions().unsubscribe(...)}
*/
@Deprecated
@Beta
boolean unsubscribe(Entity producer, SubscriptionHandle handle);
/**
* Removes all policy from this entity.
* @return True if any policies existed at this entity; false otherwise
*
* @deprecated since 0.9.0; see {@link PolicySupportInternal#removeAllPolicies()}, e.g. {@code ((EntityInternal)entity).policies().removeAllPolicies()}
*/
@Deprecated
boolean removeAllPolicies();
/**
* Removes all enricher from this entity.
* Use with caution as some entities automatically register enrichers; this will remove those enrichers as well.
* @return True if any enrichers existed at this entity; false otherwise
*
* @deprecated since 0.9.0; see {@link EnricherSupportInternal#removeAllEnrichers()}, e.g. {@code ((EntityInternal)entity).enrichers().removeAllEnrichers()}
*/
@Deprecated
boolean removeAllEnrichers();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy