/*
* JBoss, Home of Professional Open Source.
* Copyright 2011, Red Hat, Inc., and individual contributors
* as indicated by the @author tags. See the copyright.txt file in the
* distribution for a full listing of individual contributors.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.wildfly.extension.messaging.activemq;
import static org.jboss.as.controller.SimpleAttributeDefinitionBuilder.create;
import static org.jboss.as.controller.client.helpers.MeasurementUnit.BYTES;
import static org.jboss.as.controller.client.helpers.MeasurementUnit.DAYS;
import static org.jboss.as.controller.client.helpers.MeasurementUnit.MILLISECONDS;
import static org.jboss.as.controller.client.helpers.MeasurementUnit.PERCENTAGE;
import static org.jboss.as.controller.client.helpers.MeasurementUnit.SECONDS;
import static org.jboss.dmr.ModelType.BOOLEAN;
import static org.jboss.dmr.ModelType.INT;
import static org.jboss.dmr.ModelType.LONG;
import static org.jboss.dmr.ModelType.STRING;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.List;
import org.apache.activemq.artemis.api.config.ActiveMQDefaultConfiguration;
import org.apache.activemq.artemis.core.config.impl.ConfigurationImpl;
import org.apache.activemq.artemis.core.server.JournalType;
import org.jboss.as.controller.AttributeDefinition;
import org.jboss.as.controller.ObjectTypeAttributeDefinition;
import org.jboss.as.controller.PersistentResourceDefinition;
import org.jboss.as.controller.SimpleAttributeDefinition;
import org.jboss.as.controller.access.management.SensitiveTargetAccessConstraintDefinition;
import org.jboss.as.controller.descriptions.ModelDescriptionConstants;
import org.jboss.as.controller.operations.validation.EnumValidator;
import org.jboss.as.controller.operations.validation.IntRangeValidator;
import org.jboss.as.controller.operations.validation.LongRangeValidator;
import org.jboss.as.controller.registry.ManagementResourceRegistration;
import org.jboss.as.controller.security.CredentialReference;
import org.jboss.dmr.ModelNode;
import org.jboss.dmr.ModelType;
import org.wildfly.extension.messaging.activemq.ha.LiveOnlyDefinition;
import org.wildfly.extension.messaging.activemq.ha.ReplicationColocatedDefinition;
import org.wildfly.extension.messaging.activemq.ha.ReplicationMasterDefinition;
import org.wildfly.extension.messaging.activemq.ha.ReplicationSlaveDefinition;
import org.wildfly.extension.messaging.activemq.ha.SharedStoreColocatedDefinition;
import org.wildfly.extension.messaging.activemq.ha.SharedStoreMasterDefinition;
import org.wildfly.extension.messaging.activemq.ha.SharedStoreSlaveDefinition;
import org.wildfly.extension.messaging.activemq.jms.ConnectionFactoryDefinition;
import org.wildfly.extension.messaging.activemq.jms.JMSQueueDefinition;
import org.wildfly.extension.messaging.activemq.jms.JMSServerControlHandler;
import org.wildfly.extension.messaging.activemq.jms.JMSTopicDefinition;
import org.wildfly.extension.messaging.activemq.jms.PooledConnectionFactoryDefinition;
import org.wildfly.extension.messaging.activemq.jms.legacy.LegacyConnectionFactoryDefinition;
/**
* {@link org.jboss.as.controller.ResourceDefinition} for the messaging-activemq subsystem server resource.
*
* @author Brian Stansberry (c) 2011 Red Hat Inc.
*/
public class ServerDefinition extends PersistentResourceDefinition {
public static final SimpleAttributeDefinition CLUSTER_PASSWORD = create("cluster-password", ModelType.STRING, true)
.setAttributeGroup("cluster")
.setXmlName("password")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultClusterPassword()))
.setAllowExpression(true)
.setRestartAllServices()
.addAccessConstraint(SensitiveTargetAccessConstraintDefinition.CREDENTIAL)
.addAccessConstraint(MessagingExtension.MESSAGING_SECURITY_SENSITIVE_TARGET)
.setAlternatives("cluster-" + CredentialReference.CREDENTIAL_REFERENCE)
.build();
public static final ObjectTypeAttributeDefinition CREDENTIAL_REFERENCE =
CredentialReference.getAttributeBuilder("cluster-" + CredentialReference.CREDENTIAL_REFERENCE, CredentialReference.CREDENTIAL_REFERENCE, true, true)
.setAttributeGroup("cluster")
.setRestartAllServices()
.addAccessConstraint(SensitiveTargetAccessConstraintDefinition.CREDENTIAL)
.addAccessConstraint(MessagingExtension.MESSAGING_SECURITY_SENSITIVE_TARGET)
.setAlternatives(CLUSTER_PASSWORD.getName())
.build();
public static final SimpleAttributeDefinition CLUSTER_USER = create("cluster-user", ModelType.STRING)
.setAttributeGroup("cluster")
.setXmlName("user")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultClusterUser()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.addAccessConstraint(SensitiveTargetAccessConstraintDefinition.CREDENTIAL)
.addAccessConstraint(MessagingExtension.MESSAGING_SECURITY_SENSITIVE_TARGET)
.build();
public static final AttributeDefinition SCHEDULED_THREAD_POOL_MAX_SIZE = create("scheduled-thread-pool-max-size", INT)
.setDefaultValue(new ModelNode().set(ActiveMQDefaultConfiguration.getDefaultScheduledThreadPoolMaxSize()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition SECURITY_DOMAIN = create("security-domain", ModelType.STRING)
.setAttributeGroup("security")
.setXmlName("domain")
.setDefaultValue(new ModelNode("other"))
.setAlternatives("elytron-domain")
.setRequired(false)
.setAllowExpression(false) // references the security domain service name
.setRestartAllServices()
.addAccessConstraint(SensitiveTargetAccessConstraintDefinition.SECURITY_DOMAIN_REF)
.addAccessConstraint(MessagingExtension.MESSAGING_SECURITY_SENSITIVE_TARGET)
.setDeprecated(MessagingExtension.VERSION_1_1_0)
.build();
public static final SimpleAttributeDefinition ELYTRON_DOMAIN = create("elytron-domain", ModelType.STRING)
.setAttributeGroup("security")
.setRequired(false)
.setAlternatives(SECURITY_DOMAIN.getName())
.setAllowExpression(false)
.setRestartAllServices()
.addAccessConstraint(SensitiveTargetAccessConstraintDefinition.ELYTRON_SECURITY_DOMAIN_REF)
.addAccessConstraint(MessagingExtension.MESSAGING_SECURITY_SENSITIVE_TARGET)
.setCapabilityReference(Capabilities.ELYTRON_DOMAIN_CAPABILITY, Capabilities.ACTIVEMQ_SERVER_CAPABILITY)
.build();
public static final AttributeDefinition THREAD_POOL_MAX_SIZE = create("thread-pool-max-size", INT)
.setDefaultValue(new ModelNode().set(ActiveMQDefaultConfiguration.getDefaultThreadPoolMaxSize()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition OVERRIDE_IN_VM_SECURITY = create("override-in-vm-security", BOOLEAN)
.setAttributeGroup("security")
.setDefaultValue(new ModelNode(true))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition WILD_CARD_ROUTING_ENABLED = create("wild-card-routing-enabled", BOOLEAN)
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.isDefaultWildcardRoutingEnabled()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition STATISTICS_ENABLED = create(ModelDescriptionConstants.STATISTICS_ENABLED, BOOLEAN)
.setAttributeGroup("statistics")
.setXmlName("enabled")
.setDefaultValue(new ModelNode(false))
.setRequired(false)
.setAllowExpression(true)
.build();
// no default values, depends on whether NIO or AIO is used.
public static final SimpleAttributeDefinition JOURNAL_BUFFER_SIZE = create("journal-buffer-size", LONG)
.setAttributeGroup("journal")
.setXmlName("buffer-size")
.setMeasurementUnit(BYTES)
.setRequired(false)
.setAllowExpression(true)
.setValidator(new LongRangeValidator(0,Long.MAX_VALUE,true,true))
.setRestartAllServices()
.build();
// no default values, depends on whether NIO or AIO is used.
public static final SimpleAttributeDefinition JOURNAL_BUFFER_TIMEOUT = create("journal-buffer-timeout", LONG)
.setAttributeGroup("journal")
.setXmlName("buffer-timeout")
.setMeasurementUnit(MILLISECONDS)
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition JOURNAL_COMPACT_MIN_FILES = create("journal-compact-min-files", INT)
.setAttributeGroup("journal")
.setXmlName("compact-min-files")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultJournalCompactMinFiles()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition JOURNAL_COMPACT_PERCENTAGE = create("journal-compact-percentage", INT)
.setAttributeGroup("journal")
.setXmlName("compact-percentage")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultJournalCompactPercentage()))
.setMeasurementUnit(PERCENTAGE)
.setValidator(new IntRangeValidator(0, 100, true, true))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
// TODO: if this attribute is set, warn/error if any fs-related journal attribute is set.
// TODO: add capability for data-source https://github.com/wildfly/wildfly-capabilities/blob/master/org/wildfly/data-source/capability.adoc
public static final SimpleAttributeDefinition JOURNAL_DATASOURCE = create("journal-datasource", STRING)
.setAttributeGroup("journal")
.setXmlName("datasource")
.setRequired(false)
// references another resource
.setAllowExpression(false)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition JOURNAL_BINDINGS_TABLE = create("journal-bindings-table", STRING)
.setAttributeGroup("journal")
.setXmlName("bindings-table")
.setRequired(false)
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultBindingsTableName()))
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition JOURNAL_JMS_BINDINGS_TABLE = create("journal-jms-bindings-table", STRING)
.setAttributeGroup("journal")
.setXmlName("jms-bindings-table")
.setRequired(false)
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultJMSBindingsTableName()))
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition JOURNAL_LARGE_MESSAGES_TABLE = create("journal-large-messages-table", STRING)
.setAttributeGroup("journal")
.setXmlName("large-messages-table")
.setRequired(false)
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultLargeMessagesTableName()))
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition JOURNAL_MESSAGES_TABLE = create("journal-messages-table", STRING)
.setAttributeGroup("journal")
.setXmlName("messages-table")
.setRequired(false)
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultMessageTableName()))
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition JOURNAL_PAGE_STORE_TABLE = create("journal-page-store-table", STRING)
.setAttributeGroup("journal")
.setXmlName("page-store-table")
.setRequired(false)
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultPageStoreTableName()))
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final AttributeDefinition JOURNAL_DATABASE = create("journal-database", STRING)
.setAttributeGroup("journal")
.setXmlName("database")
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final AttributeDefinition JOURNAL_JDBC_NETWORK_TIMEOUT = create("journal-jdbc-network-timeout", INT)
.setAttributeGroup("journal")
.setXmlName("jdbc-network-timeout")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultJdbcNetworkTimeout()))
.setMeasurementUnit(SECONDS)
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition JOURNAL_FILE_SIZE = create("journal-file-size", LONG)
.setAttributeGroup("journal")
.setXmlName("file-size")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultJournalFileSize()))
.setMeasurementUnit(BYTES)
.setValidator(new ModularLongRangeParameterValidator(512, 1024, Long.MAX_VALUE, true, true))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
// no default values, depends on whether NIO or AIO is used.
public static final SimpleAttributeDefinition JOURNAL_MAX_IO = create("journal-max-io", INT)
.setAttributeGroup("journal")
.setXmlName("max-io")
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition JOURNAL_MIN_FILES = create("journal-min-files", INT)
.setAttributeGroup("journal")
.setXmlName("min-files")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultJournalMinFiles()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.setValidator(new IntRangeValidator(2, true, true))
.build();
public static final SimpleAttributeDefinition JOURNAL_POOL_FILES = create("journal-pool-files", INT)
.setAttributeGroup("journal")
.setXmlName("pool-files")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultJournalPoolFiles()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition JOURNAL_SYNC_NON_TRANSACTIONAL = create("journal-sync-non-transactional", BOOLEAN)
.setAttributeGroup("journal")
.setXmlName("sync-non-transactional")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.isDefaultJournalSyncNonTransactional()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition JOURNAL_SYNC_TRANSACTIONAL = create("journal-sync-transactional", BOOLEAN)
.setAttributeGroup("journal")
.setXmlName("sync-transactional")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.isDefaultJournalSyncTransactional()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition JOURNAL_TYPE = create("journal-type", ModelType.STRING)
.setAttributeGroup("journal")
.setXmlName("type")
.setDefaultValue(new ModelNode(ConfigurationImpl.DEFAULT_JOURNAL_TYPE.toString()))
.setRequired(false)
.setAllowExpression(true)
// list allowed values explicitly to exclude MAPPED
.setValidator(new EnumValidator<>(JournalType.class, true, true, JournalType.ASYNCIO, JournalType.NIO))
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition LOG_JOURNAL_WRITE_RATE = create("log-journal-write-rate", BOOLEAN)
.setAttributeGroup("journal")
.setXmlName("log-write-rate")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.isDefaultJournalLogWriteRate()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition CONNECTION_TTL_OVERRIDE = create("connection-ttl-override", LONG)
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultConnectionTtlOverride()))
.setMeasurementUnit(MILLISECONDS)
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition ASYNC_CONNECTION_EXECUTION_ENABLED = create("async-connection-execution-enabled", BOOLEAN)
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.isDefaultAsyncConnectionExecutionEnabled()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition MESSAGE_COUNTER_MAX_DAY_HISTORY = create("message-counter-max-day-history", INT)
.setAttributeGroup("statistics")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultMessageCounterMaxDayHistory()))
.setMeasurementUnit(DAYS)
.setRequired(false)
.setAllowExpression(true)
.build();
public static final SimpleAttributeDefinition MESSAGE_COUNTER_SAMPLE_PERIOD = create("message-counter-sample-period", LONG)
.setAttributeGroup("statistics")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultMessageCounterSamplePeriod()))
.setMeasurementUnit(MILLISECONDS)
.setRequired(false)
.setAllowExpression(true)
.build();
public static final SimpleAttributeDefinition TRANSACTION_TIMEOUT = create("transaction-timeout", LONG)
.setAttributeGroup("transaction")
.setXmlName("timeout")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultTransactionTimeout()))
.setMeasurementUnit(MILLISECONDS)
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition TRANSACTION_TIMEOUT_SCAN_PERIOD = create("transaction-timeout-scan-period", LONG)
.setAttributeGroup("transaction")
.setXmlName("scan-period")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultTransactionTimeoutScanPeriod()))
.setMeasurementUnit(MILLISECONDS)
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition MESSAGE_EXPIRY_SCAN_PERIOD = create("message-expiry-scan-period", LONG)
.setAttributeGroup("message-expiry")
.setXmlName("scan-period")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultMessageExpiryScanPeriod()))
.setMeasurementUnit(MILLISECONDS)
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition MESSAGE_EXPIRY_THREAD_PRIORITY = create("message-expiry-thread-priority", INT)
.setAttributeGroup("message-expiry")
.setXmlName("thread-priority")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultMessageExpiryThreadPriority()))
.setRequired(false)
.setAllowExpression(true)
.setValidator(new IntRangeValidator(Thread.MIN_PRIORITY, Thread.MAX_PRIORITY, true, true))
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition PERF_BLAST_PAGES = create("perf-blast-pages", INT)
.setAttributeGroup("debug")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultJournalPerfBlastPages()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition RUN_SYNC_SPEED_TEST = create("run-sync-speed-test", BOOLEAN)
.setAttributeGroup("debug")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.isDefaultRunSyncSpeedTest()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition SERVER_DUMP_INTERVAL = create("server-dump-interval", LONG)
.setAttributeGroup("debug")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultServerDumpInterval()))
.setMeasurementUnit(MILLISECONDS)
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition MEMORY_MEASURE_INTERVAL = create("memory-measure-interval", LONG)
.setAttributeGroup("debug")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultMemoryMeasureInterval()))
.setMeasurementUnit(MILLISECONDS)
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition MEMORY_WARNING_THRESHOLD = create("memory-warning-threshold", INT)
.setAttributeGroup("debug")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultMemoryWarningThreshold()))
.setMeasurementUnit(PERCENTAGE)
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition SECURITY_INVALIDATION_INTERVAL = create("security-invalidation-interval", LONG)
.setAttributeGroup("security")
.setXmlName("invalidation-interval")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultSecurityInvalidationInterval()))
.setMeasurementUnit(MILLISECONDS)
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.addAccessConstraint(MessagingExtension.MESSAGING_SECURITY_SENSITIVE_TARGET)
.build();
public static final SimpleAttributeDefinition SECURITY_ENABLED = create("security-enabled", BOOLEAN)
.setAttributeGroup("security")
.setXmlName("enabled")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.isDefaultSecurityEnabled()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.addAccessConstraint(MessagingExtension.MESSAGING_SECURITY_SENSITIVE_TARGET)
.build();
public static final SimpleAttributeDefinition PERSISTENCE_ENABLED = create("persistence-enabled", BOOLEAN)
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.isDefaultPersistenceEnabled()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition MANAGEMENT_NOTIFICATION_ADDRESS = create("management-notification-address", ModelType.STRING)
.setAttributeGroup("management")
.setXmlName("notification-address")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultManagementNotificationAddress().toString()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.addAccessConstraint(MessagingExtension.MESSAGING_MANAGEMENT_SENSITIVE_TARGET)
.build();
public static final SimpleAttributeDefinition MANAGEMENT_ADDRESS = create("management-address", ModelType.STRING)
.setAttributeGroup("management")
.setXmlName("address")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultManagementAddress().toString()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.addAccessConstraint(MessagingExtension.MESSAGING_MANAGEMENT_SENSITIVE_TARGET)
.build();
public static final SimpleAttributeDefinition JMX_MANAGEMENT_ENABLED = create("jmx-management-enabled", BOOLEAN)
.setAttributeGroup("management")
.setXmlName("jmx-enabled")
.setDefaultValue(new ModelNode(false))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.addAccessConstraint(MessagingExtension.MESSAGING_MANAGEMENT_SENSITIVE_TARGET)
.build();
public static final SimpleAttributeDefinition JMX_DOMAIN = create("jmx-domain", ModelType.STRING)
.setAttributeGroup("management")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultJmxDomain()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.addAccessConstraint(MessagingExtension.MESSAGING_MANAGEMENT_SENSITIVE_TARGET)
.build();
public static final SimpleAttributeDefinition PERSIST_ID_CACHE = create("persist-id-cache", BOOLEAN)
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.isDefaultPersistIdCache()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition PERSIST_DELIVERY_COUNT_BEFORE_DELIVERY = create("persist-delivery-count-before-delivery", BOOLEAN)
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.isDefaultPersistDeliveryCountBeforeDelivery()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition ID_CACHE_SIZE = create("id-cache-size", INT)
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultIdCacheSize()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition PAGE_MAX_CONCURRENT_IO = create("page-max-concurrent-io", INT)
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.getDefaultMaxConcurrentPageIo()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition CREATE_BINDINGS_DIR = create("create-bindings-dir", BOOLEAN)
.setAttributeGroup("journal")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.isDefaultCreateBindingsDir()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final SimpleAttributeDefinition CREATE_JOURNAL_DIR = create("create-journal-dir", BOOLEAN)
.setAttributeGroup("journal")
.setDefaultValue(new ModelNode(ActiveMQDefaultConfiguration.isDefaultCreateJournalDir()))
.setRequired(false)
.setAllowExpression(true)
.setRestartAllServices()
.build();
public static final AttributeDefinition[] ATTRIBUTES = {PERSISTENCE_ENABLED, SCHEDULED_THREAD_POOL_MAX_SIZE,
THREAD_POOL_MAX_SIZE, SECURITY_DOMAIN, ELYTRON_DOMAIN, SECURITY_ENABLED, SECURITY_INVALIDATION_INTERVAL,
OVERRIDE_IN_VM_SECURITY, WILD_CARD_ROUTING_ENABLED, MANAGEMENT_ADDRESS, MANAGEMENT_NOTIFICATION_ADDRESS,
CLUSTER_USER, CLUSTER_PASSWORD, CREDENTIAL_REFERENCE, JMX_MANAGEMENT_ENABLED, JMX_DOMAIN, STATISTICS_ENABLED, MESSAGE_COUNTER_SAMPLE_PERIOD,
MESSAGE_COUNTER_MAX_DAY_HISTORY, CONNECTION_TTL_OVERRIDE, ASYNC_CONNECTION_EXECUTION_ENABLED, TRANSACTION_TIMEOUT,
TRANSACTION_TIMEOUT_SCAN_PERIOD, MESSAGE_EXPIRY_SCAN_PERIOD, MESSAGE_EXPIRY_THREAD_PRIORITY, ID_CACHE_SIZE, PERSIST_ID_CACHE,
CommonAttributes.INCOMING_INTERCEPTORS, CommonAttributes.OUTGOING_INTERCEPTORS,
PERSIST_DELIVERY_COUNT_BEFORE_DELIVERY,
PAGE_MAX_CONCURRENT_IO, CREATE_BINDINGS_DIR, CREATE_JOURNAL_DIR, JOURNAL_TYPE, JOURNAL_BUFFER_TIMEOUT,
JOURNAL_BUFFER_SIZE,
JOURNAL_DATASOURCE, JOURNAL_DATABASE, JOURNAL_JDBC_NETWORK_TIMEOUT,
JOURNAL_MESSAGES_TABLE, JOURNAL_BINDINGS_TABLE, JOURNAL_JMS_BINDINGS_TABLE, JOURNAL_LARGE_MESSAGES_TABLE, JOURNAL_PAGE_STORE_TABLE,
JOURNAL_SYNC_TRANSACTIONAL, JOURNAL_SYNC_NON_TRANSACTIONAL, LOG_JOURNAL_WRITE_RATE,
JOURNAL_FILE_SIZE, JOURNAL_MIN_FILES, JOURNAL_POOL_FILES, JOURNAL_COMPACT_PERCENTAGE, JOURNAL_COMPACT_MIN_FILES, JOURNAL_MAX_IO,
PERF_BLAST_PAGES, RUN_SYNC_SPEED_TEST, SERVER_DUMP_INTERVAL, MEMORY_WARNING_THRESHOLD, MEMORY_MEASURE_INTERVAL,
};
private final boolean registerRuntimeOnly;
ServerDefinition(boolean registerRuntimeOnly) {
super(MessagingExtension.SERVER_PATH,
MessagingExtension.getResourceDescriptionResolver(CommonAttributes.SERVER),
ServerAdd.INSTANCE,
ServerRemove.INSTANCE);
this.registerRuntimeOnly = registerRuntimeOnly;
}
@Override
public void registerOperations(ManagementResourceRegistration resourceRegistration) {
super.registerOperations(resourceRegistration);
if (registerRuntimeOnly) {
ExportJournalOperation.registerOperation(resourceRegistration, getResourceDescriptionResolver());
ImportJournalOperation.registerOperation(resourceRegistration, getResourceDescriptionResolver());
ActiveMQServerControlHandler.INSTANCE.registerOperations(resourceRegistration, getResourceDescriptionResolver());
JMSServerControlHandler.INSTANCE.registerOperations(resourceRegistration, getResourceDescriptionResolver());
AddressSettingsResolveHandler.registerOperationHandler(resourceRegistration, getResourceDescriptionResolver());
}
}
@Override
public void registerAttributes(ManagementResourceRegistration resourceRegistration) {
ActiveMQServerControlWriteHandler.INSTANCE.registerAttributes(resourceRegistration, registerRuntimeOnly);
if (registerRuntimeOnly) {
ActiveMQServerControlHandler.INSTANCE.registerAttributes(resourceRegistration);
}
}
@Override
public void registerCapabilities(ManagementResourceRegistration resourceRegistration) {
resourceRegistration.registerCapability(Capabilities.ACTIVEMQ_SERVER_CAPABILITY);
}
@Override
public Collection<AttributeDefinition> getAttributes() {
return Arrays.asList(ATTRIBUTES);
}
@Override
protected List<? extends PersistentResourceDefinition> getChildren() {
List<PersistentResourceDefinition> children = new ArrayList();
// Static resources
children.addAll(Arrays.asList(
// HA policy
LiveOnlyDefinition.INSTANCE,
ReplicationMasterDefinition.INSTANCE,
ReplicationSlaveDefinition.INSTANCE,
ReplicationColocatedDefinition.INSTANCE,
SharedStoreMasterDefinition.INSTANCE,
SharedStoreSlaveDefinition.INSTANCE,
SharedStoreColocatedDefinition.INSTANCE,
AddressSettingDefinition.INSTANCE,
SecuritySettingDefinition.INSTANCE,
// Connectors
HTTPConnectorDefinition.INSTANCE,
RemoteTransportDefinition.CONNECTOR_INSTANCE,
InVMTransportDefinition.CONNECTOR_INSTANCE,
GenericTransportDefinition.CONNECTOR_INSTANCE,
// Acceptors
HTTPAcceptorDefinition.INSTANCE,
RemoteTransportDefinition.ACCEPTOR_INSTANCE,
InVMTransportDefinition.ACCEPTOR_INSTANCE,
GenericTransportDefinition.ACCEPTOR_INSTANCE,
BroadcastGroupDefinition.INSTANCE,
DiscoveryGroupDefinition.INSTANCE,
BridgeDefinition.INSTANCE,
ClusterConnectionDefinition.INSTANCE,
DivertDefinition.INSTANCE,
ConnectorServiceDefinition.INSTANCE,
GroupingHandlerDefinition.INSTANCE,
// JMS resources
LegacyConnectionFactoryDefinition.INSTANCE,
PooledConnectionFactoryDefinition.INSTANCE));
// Dynamic resources (depending on registerRuntimeOnly)
children.add(new QueueDefinition(registerRuntimeOnly, MessagingExtension.QUEUE_PATH));
children.add(new JMSQueueDefinition(false, registerRuntimeOnly));
children.add(new JMSTopicDefinition(false, registerRuntimeOnly));
children.add(new ConnectionFactoryDefinition(registerRuntimeOnly));
return children;
}
@Override
public void registerChildren(ManagementResourceRegistration resourceRegistration) {
super.registerChildren(resourceRegistration);
// runtime queues and core-address are only registered when it is ok to register runtime resource (ie they are not registered on HC).
if (registerRuntimeOnly) {
resourceRegistration.registerSubModel(new QueueDefinition(registerRuntimeOnly, MessagingExtension.RUNTIME_QUEUE_PATH));
resourceRegistration.registerSubModel(CoreAddressDefinition.INSTANCE);
}
}
}