/**
* Copyright (C) FuseSource, Inc.
* http://fusesource.com
*
* 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 org.jboss.test.osgi.ds.support;
import java.util.Map;
import org.jboss.logging.Logger;
/**
* An abstract base class for validatable components.
* {@link}
* @author Thomas.Diesler@jboss.com
* @since 13-Sep-2013
*/
public abstract class AbstractComponent implements Validatable {
public final static Logger LOGGER = Logger.getLogger(AbstractComponent.class);
/* This uses volatile to make sure that every thread sees the last written value
*
* - The use of AtomicBoolean would be wrong because it does not guarantee that
* prior written state is also seen by other threads
*
* - Synchronizing all methods in here would also work, but would effectively cause
* a lock acquisition on every public method in every component
*/
private ValidationSupport active = new ValidationSupport();
public void activateComponent() {
LOGGER.infof("activate: %s", this);
active.setValid();
}
public void activateComponent(Map<String, String> config) {
LOGGER.infof("activate %s with config: %s", this, config);
active.setValid();
}
public void deactivateComponent() {
LOGGER.infof("deactivate: %s", this);
active.setInvalid();
}
@Override
public boolean isValid() {
return active.isValid();
}
@Override
public void assertValid() {
active.assertValid();
}
}