flex.messaging.services.AbstractBootstrapService 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 flex.messaging.services;
import java.util.List;
import java.util.Map;
import flex.management.BaseControl;
import flex.messaging.Destination;
import flex.messaging.MessageBroker;
import flex.messaging.config.ConfigMap;
import flex.messaging.config.ConfigurationException;
import flex.messaging.endpoints.Endpoint;
import flex.messaging.messages.CommandMessage;
import flex.messaging.messages.Message;
/**
* The purpose of AbstractBootstrapService
is to enable creation
* of dynamic services, destinations, and adapters. MessageBroker
* creates an instance of this class and calls initialize
after all
* of the server components are created but right before they are started.
* MessageBroker
also calls start
as server starts and
* stop
as server stops. Subclasses should have their dynamic
* component creation code in one of initialize
, start
,
* and stop
methods depending on when they want their components
* to be created.
*
* @author matamel
*
*/
public abstract class AbstractBootstrapService implements Service
{
// Errors
private static final int NULL_COMPONENT_PROPERTY = 11116;
protected String id;
protected MessageBroker broker;
/**
* Default constructor which is no-op.
*/
public AbstractBootstrapService()
{
// No-op
}
/**
* Returns the id of the AbstractBootstrapService
.
*
* @return The id of the AbstractBootstrapService
.
*/
public String getId()
{
return id;
}
/**
* Sets the id of the AbstractBootstrapService
. If the
* AbstractBootstrapService
has a MessageBroker
* already assigned, it also updates the id in the MessageBroker
.
*/
public void setId(String id)
{
String oldId = getId();
if (id == null)
{
// Id of a component cannot be null.
ConfigurationException ce = new ConfigurationException();
ce.setMessage(NULL_COMPONENT_PROPERTY, new Object[]{"id"});
throw ce;
}
this.id = id;
// Update the service id in the broker
MessageBroker broker = getMessageBroker();
if (broker != null)
{
// broker must have the service then
broker.removeService(oldId);
broker.addService(this);
}
}
/**
* Returns the MessageBroker
managing this AbstractBootstrapService
.
*
* @return MessageBroker of the AbstractBootstrapService
.
*/
public MessageBroker getMessageBroker()
{
return broker;
}
/**
* Sets the MessageBroker
managing this AbstractBootstrapService
.
* Removes the AbstractService
from the old broker (if there was one)
* and adds to the list of services in the new broker.
*
* @param broker MessageBroker
of the AbstractBootstrapService
.
*/
public void setMessageBroker(MessageBroker broker)
{
MessageBroker oldBroker = getMessageBroker();
this.broker = broker;
if (oldBroker != null)
{
oldBroker.removeService(getId());
}
// Add service to the new broker if needed
if (broker.getService(getId()) != this)
broker.addService(this);
}
/**
* Always unmanaged.
*
* @return false
.
*/
public boolean isManaged()
{
return false;
}
/**
* Management is always disabled.
*/
public void setManaged(boolean enableManagement)
{
// No-op
}
/**
* Called by the MessageBroker
after all of the server
* components are created but right before they are started. This is
* usually the place to create dynamic components.
*
* @param id Id of the AbstractBootstrapService
.
* @param properties Properties for the AbstractBootstrapService
.
*/
public abstract void initialize(String id, ConfigMap properties);
/**
* Called by the MessageBroker
as server starts. Useful for
* custom code that needs to run after all the components are initialized
* and the server is starting up.
*/
public abstract void start();
/**
* Called by the MessageBroker
as server stops. Useful for
* custom code that needs to run as the server is shutting down.
*/
public abstract void stop();
/** @exclude **/
public ConfigMap describeService(Endpoint endpoint)
{
return null;
}
/** @exclude **/
public BaseControl getControl()
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public void setControl(BaseControl control)
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public void addDefaultChannel(String id)
{
// No-op
}
/** @exclude **/
public void setDefaultChannels(List ids)
{
// No-op
}
/** @exclude **/
public boolean removeDefaultChannel(String id)
{
return false;
}
/** @exclude **/
public void addDestination(Destination destination)
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public Destination createDestination(String destId)
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public Destination removeDestination(String id)
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public String getDefaultAdapter()
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public void setDefaultAdapter(String id)
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public List getDefaultChannels()
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public Destination getDestination(Message message)
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public Destination getDestination(String id)
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public Map getDestinations()
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public Map getRegisteredAdapters()
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public boolean isStarted()
{
return false;
}
/** @exclude **/
public boolean isSupportedMessage(Message message)
{
return false;
}
/** @exclude **/
public boolean isSupportedMessageType(String messageClassName)
{
return false;
}
/** @exclude **/
public String registerAdapter(String id, String className)
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public String unregisterAdapter(String id)
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public Object serviceCommand(CommandMessage message)
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public Object serviceMessage(Message message)
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public List getMessageTypes()
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public void addMessageType(String messageType)
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public void setMessageTypes(List messageTypes)
{
throw new UnsupportedOperationException();
}
/** @exclude **/
public boolean removeMessageType(String messageType)
{
throw new UnsupportedOperationException();
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy