001 /**
002 * Licensed to the Apache Software Foundation (ASF) under one or more
003 * contributor license agreements. See the NOTICE file distributed with
004 * this work for additional information regarding copyright ownership.
005 * The ASF licenses this file to You under the Apache License, Version 2.0
006 * (the "License"); you may not use this file except in compliance with
007 * the License. You may obtain a copy of the License at
008 *
009 * http://www.apache.org/licenses/LICENSE-2.0
010 *
011 * Unless required by applicable law or agreed to in writing, software
012 * distributed under the License is distributed on an "AS IS" BASIS,
013 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
014 * See the License for the specific language governing permissions and
015 * limitations under the License.
016 */
017 package org.apache.activemq.broker.region.virtual;
018
019 import java.util.Collection;
020
021 import org.apache.activemq.broker.Broker;
022 import org.apache.activemq.broker.ConnectionContext;
023 import org.apache.activemq.broker.region.Destination;
024 import org.apache.activemq.command.ActiveMQDestination;
025
026 /**
027 *
028 *
029 */
030 public abstract class CompositeDestination implements VirtualDestination {
031
032 private String name;
033 private Collection forwardTo;
034 private boolean forwardOnly = true;
035 private boolean copyMessage = true;
036
037 public Destination intercept(Destination destination) {
038 return new CompositeDestinationFilter(destination, getForwardTo(), isForwardOnly(), isCopyMessage());
039 }
040
041 public void create(Broker broker, ConnectionContext context, ActiveMQDestination destination) {
042 }
043
044 public void remove(Destination destination) {
045 }
046
047 public String getName() {
048 return name;
049 }
050
051 /**
052 * Sets the name of this composite destination
053 */
054 public void setName(String name) {
055 this.name = name;
056 }
057
058 public Collection getForwardTo() {
059 return forwardTo;
060 }
061
062 /**
063 * Sets the list of destinations to forward to
064 */
065 public void setForwardTo(Collection forwardDestinations) {
066 this.forwardTo = forwardDestinations;
067 }
068
069 public boolean isForwardOnly() {
070 return forwardOnly;
071 }
072
073 /**
074 * Sets if the virtual destination is forward only (and so there is no
075 * physical queue to match the virtual queue) or if there is also a physical
076 * queue with the same name).
077 */
078 public void setForwardOnly(boolean forwardOnly) {
079 this.forwardOnly = forwardOnly;
080 }
081
082 public boolean isCopyMessage() {
083 return copyMessage;
084 }
085
086 /**
087 * Sets whether a copy of the message will be sent to each destination.
088 * Defaults to true so that the forward destination is set as the
089 * destination of the message
090 */
091 public void setCopyMessage(boolean copyMessage) {
092 this.copyMessage = copyMessage;
093 }
094
095 }