/* * 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); } } }