ARTEMIS-3043 - improvements on new console
https://issues.apache.org/jira/browse/ARTEMIS-3043
This commit is contained in:
parent
168883df20
commit
ea7f001776
|
@ -2793,4 +2793,28 @@ public interface AuditLogger extends BasicLogger {
|
||||||
@LogMessage(level = Logger.Level.INFO)
|
@LogMessage(level = Logger.Level.INFO)
|
||||||
@Message(id = 601742, value = "User {0} is getting the queue count on target resource: {1} {2}", format = Message.Format.MESSAGE_FORMAT)
|
@Message(id = 601742, value = "User {0} is getting the queue count on target resource: {1} {2}", format = Message.Format.MESSAGE_FORMAT)
|
||||||
void getQueueCount(String user, Object source, Object... args);
|
void getQueueCount(String user, Object source, Object... args);
|
||||||
|
|
||||||
|
static void lastValueKey(Object source) {
|
||||||
|
LOGGER.lastValueKey(getCaller(), source);
|
||||||
|
}
|
||||||
|
|
||||||
|
@LogMessage(level = Logger.Level.INFO)
|
||||||
|
@Message(id = 601743, value = "User {0} is getting last-value-key property on target resource: {1} {2}", format = Message.Format.MESSAGE_FORMAT)
|
||||||
|
void lastValueKey(String user, Object source, Object... args);
|
||||||
|
|
||||||
|
static void consumersBeforeDispatch(Object source) {
|
||||||
|
LOGGER.consumersBeforeDispatch(getCaller(), source);
|
||||||
|
}
|
||||||
|
|
||||||
|
@LogMessage(level = Logger.Level.INFO)
|
||||||
|
@Message(id = 601744, value = "User {0} is getting consumers-before-dispatch property on target resource: {1} {2}", format = Message.Format.MESSAGE_FORMAT)
|
||||||
|
void consumersBeforeDispatch(String user, Object source, Object... args);
|
||||||
|
|
||||||
|
static void delayBeforeDispatch(Object source) {
|
||||||
|
LOGGER.delayBeforeDispatch(getCaller(), source);
|
||||||
|
}
|
||||||
|
|
||||||
|
@LogMessage(level = Logger.Level.INFO)
|
||||||
|
@Message(id = 601745, value = "User {0} is getting delay-before-dispatch property on target resource: {1} {2}", format = Message.Format.MESSAGE_FORMAT)
|
||||||
|
void delayBeforeDispatch(String user, Object source, Object... args);
|
||||||
}
|
}
|
||||||
|
|
|
@ -290,6 +290,26 @@ public interface QueueControl {
|
||||||
@Attribute(desc = "is this queue a last value queue")
|
@Attribute(desc = "is this queue a last value queue")
|
||||||
boolean isLastValue();
|
boolean isLastValue();
|
||||||
|
|
||||||
|
/**
|
||||||
|
*The key used for the last value queues
|
||||||
|
*/
|
||||||
|
@Attribute(desc = "last value key")
|
||||||
|
String getLastValueKey();
|
||||||
|
|
||||||
|
/**
|
||||||
|
*Return the Consumers Before Dispatch
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Attribute(desc = "Return the Consumers Before Dispatch")
|
||||||
|
int getConsumersBeforeDispatch();
|
||||||
|
|
||||||
|
/**
|
||||||
|
*Return the Consumers Before Dispatch
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@Attribute(desc = "Return the Consumers Before Dispatch")
|
||||||
|
long getDelayBeforeDispatch();
|
||||||
|
|
||||||
// Operations ----------------------------------------------------
|
// Operations ----------------------------------------------------
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -46,6 +46,7 @@ var Artemis = (function (Artemis) {
|
||||||
<artemis-tree></artemis-tree>
|
<artemis-tree></artemis-tree>
|
||||||
</div>
|
</div>
|
||||||
<div class="tree-nav-main">
|
<div class="tree-nav-main">
|
||||||
|
<jmx-header></jmx-header>
|
||||||
<artemis-navigation></artemis-navigation>
|
<artemis-navigation></artemis-navigation>
|
||||||
<div class="contents" ng-view></div>
|
<div class="contents" ng-view></div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -28,6 +28,7 @@ var Artemis;
|
||||||
</h1>
|
</h1>
|
||||||
<div ng-include="'plugin/artemistoolbar.html'"></div>
|
<div ng-include="'plugin/artemistoolbar.html'"></div>
|
||||||
<pf-table-view config="$ctrl.tableConfig"
|
<pf-table-view config="$ctrl.tableConfig"
|
||||||
|
dt-options="$ctrl.dtOptions"
|
||||||
columns="$ctrl.tableColumns"
|
columns="$ctrl.tableColumns"
|
||||||
action-buttons="$ctrl.tableActionButtons"
|
action-buttons="$ctrl.tableActionButtons"
|
||||||
items="$ctrl.addresses">
|
items="$ctrl.addresses">
|
||||||
|
@ -59,17 +60,48 @@ var Artemis;
|
||||||
function AddressesController($scope, workspace, jolokia, localStorage, artemisMessage, $location, $timeout, $filter, $sanitize, pagination, artemisAddress) {
|
function AddressesController($scope, workspace, jolokia, localStorage, artemisMessage, $location, $timeout, $filter, $sanitize, pagination, artemisAddress) {
|
||||||
var ctrl = this;
|
var ctrl = this;
|
||||||
ctrl.pagination = pagination;
|
ctrl.pagination = pagination;
|
||||||
|
ctrl.pagination.reset();
|
||||||
var mbean = Artemis.getBrokerMBean(workspace, jolokia);
|
var mbean = Artemis.getBrokerMBean(workspace, jolokia);
|
||||||
ctrl.allAddresses = [];
|
ctrl.allAddresses = [];
|
||||||
ctrl.addresses = [];
|
ctrl.addresses = [];
|
||||||
ctrl.workspace = workspace;
|
ctrl.workspace = workspace;
|
||||||
ctrl.refreshed = false;
|
ctrl.refreshed = false;
|
||||||
|
ctrl.dtOptions = {
|
||||||
|
// turn of ordering as we do it ourselves
|
||||||
|
ordering: false,
|
||||||
|
columns: [
|
||||||
|
{name: "ID", visible: true},
|
||||||
|
{name: "Name", visible: true},
|
||||||
|
{name: "Routing Types", visible: true},
|
||||||
|
{name: "Queue Count", visible: true}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
|
||||||
|
Artemis.log.debug('sessionStorage: addressColumnDefs =', localStorage.getItem('addressColumnDefs'));
|
||||||
|
if (localStorage.getItem('addressColumnDefs')) {
|
||||||
|
loadedDefs = JSON.parse(localStorage.getItem('addressColumnDefs'));
|
||||||
|
//sanity check to make sure columns havent been added
|
||||||
|
if(loadedDefs.length === ctrl.dtOptions.columns.length) {
|
||||||
|
ctrl.dtOptions.columns = loadedDefs;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
ctrl.updateColumns = function () {
|
||||||
|
var attributes = [];
|
||||||
|
ctrl.dtOptions.columns.forEach(function (column) {
|
||||||
|
attributes.push({name: column.name, visible: column.visible});
|
||||||
|
});
|
||||||
|
Artemis.log.debug("saving columns " + JSON.stringify(attributes));
|
||||||
|
localStorage.setItem('addressColumnDefs', JSON.stringify(attributes));
|
||||||
|
}
|
||||||
|
|
||||||
ctrl.filter = {
|
ctrl.filter = {
|
||||||
fieldOptions: [
|
fieldOptions: [
|
||||||
{id: 'ID', name: 'ID'},
|
{id: 'id', name: 'ID'},
|
||||||
{id: 'NAME', name: 'Name'},
|
{id: 'name', name: 'Name'},
|
||||||
{id: 'ROUTING_TYPES', name: 'Queue Count'},
|
{id: 'routingTypes', name: 'Routing Types'},
|
||||||
{id: 'QUEUE_COUNT', name: 'User'}
|
{id: 'queueCount', name: 'Queue Count'}
|
||||||
],
|
],
|
||||||
operationOptions: [
|
operationOptions: [
|
||||||
{id: 'EQUALS', name: 'Equals'},
|
{id: 'EQUALS', name: 'Equals'},
|
||||||
|
@ -139,6 +171,7 @@ var Artemis;
|
||||||
ctrl.filter.values.field = ctrl.filter.fieldOptions[1].id;
|
ctrl.filter.values.field = ctrl.filter.fieldOptions[1].id;
|
||||||
ctrl.filter.values.operation = ctrl.filter.operationOptions[0].id;
|
ctrl.filter.values.operation = ctrl.filter.operationOptions[0].id;
|
||||||
ctrl.filter.values.value = artemisAddress.address.address;
|
ctrl.filter.values.value = artemisAddress.address.address;
|
||||||
|
artemisAddress.address = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
selectQueues = function (idx) {
|
selectQueues = function (idx) {
|
||||||
|
|
|
@ -65,6 +65,11 @@ var Artemis;
|
||||||
ng-disabled="$ctrl.retryDisabled"
|
ng-disabled="$ctrl.retryDisabled"
|
||||||
ng-click="$ctrl.openRetryDialog()">Retry Messages
|
ng-click="$ctrl.openRetryDialog()">Retry Messages
|
||||||
</button>
|
</button>
|
||||||
|
<button class="btn btn-default primary-action ng-binding ng-scope"
|
||||||
|
type="button"
|
||||||
|
title=""
|
||||||
|
ng-click="$ctrl.showColumns = true">Columns
|
||||||
|
</button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
|
@ -72,7 +77,7 @@ var Artemis;
|
||||||
<pf-table-view config="$ctrl.tableConfig"
|
<pf-table-view config="$ctrl.tableConfig"
|
||||||
columns="$ctrl.tableColumns"
|
columns="$ctrl.tableColumns"
|
||||||
items="$ctrl.messages"
|
items="$ctrl.messages"
|
||||||
dt-options="$ctrl.tableDtOptions"
|
dt-options="$ctrl.dtOptions"
|
||||||
action-buttons="$ctrl.tableMenuActions">
|
action-buttons="$ctrl.tableMenuActions">
|
||||||
</pf-table-view>
|
</pf-table-view>
|
||||||
<div ng-include="'plugin/artemispagination.html'"></div>
|
<div ng-include="'plugin/artemispagination.html'"></div>
|
||||||
|
@ -147,6 +152,33 @@ var Artemis;
|
||||||
<p>{{$ctrl.actionText}}</p>
|
<p>{{$ctrl.actionText}}</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="form-group" ng-show="$ctrl.showColumns">
|
||||||
|
<button class="btn btn-default" data-toggle="modal" data-target="#myModal">Columns</button>
|
||||||
|
<div class="modal ng-scope">
|
||||||
|
<div class="modal-dialog ">
|
||||||
|
<div class="modal-content">
|
||||||
|
<div class="modal-header">
|
||||||
|
<h4 class="modal-title ng-binding">Column Selector</h4>
|
||||||
|
</div>
|
||||||
|
<div class="modal-body">
|
||||||
|
<table class="table-view-container table table-striped table-bordered table-hover dataTable ng-scope ng-isolate-scope no-footer">
|
||||||
|
<tbody>
|
||||||
|
<tr ng-repeat="col in $ctrl.dtOptions.columns">
|
||||||
|
<td>{{ col.name }}</td>
|
||||||
|
<td><input type="checkbox" ng-model="col.visible" placeholder="Name" autocomplete="off" id="name"></td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
<div class="modal-footer">
|
||||||
|
<button type="button" class="btn btn-default ng-binding" ng-click="$ctrl.showColumns = false;$ctrl.updateColumns()">
|
||||||
|
Close
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
<script type="text/ng-template" id="browse-instructions.html">
|
<script type="text/ng-template" id="browse-instructions.html">
|
||||||
<div>
|
<div>
|
||||||
<p>
|
<p>
|
||||||
|
@ -174,6 +206,7 @@ var Artemis;
|
||||||
ctrl.moveDisabled = true;
|
ctrl.moveDisabled = true;
|
||||||
ctrl.retryDisabled = true;
|
ctrl.retryDisabled = true;
|
||||||
ctrl.pagination = pagination;
|
ctrl.pagination = pagination;
|
||||||
|
ctrl.pagination.reset();
|
||||||
ctrl.filter = '';
|
ctrl.filter = '';
|
||||||
ctrl.actionText = '';
|
ctrl.actionText = '';
|
||||||
|
|
||||||
|
@ -200,6 +233,44 @@ var Artemis;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ctrl.dtOptions = {
|
||||||
|
// turn of ordering as we do it ourselves
|
||||||
|
ordering: false,
|
||||||
|
columns: [
|
||||||
|
{name: "Select", visible: true},
|
||||||
|
{name: "Message ID", visible: true},
|
||||||
|
{name: "Type", visible: true},
|
||||||
|
{name: "Durable", visible: true},
|
||||||
|
{name: "Priority", visible: true},
|
||||||
|
{name: "Timestamp", visible: true},
|
||||||
|
{name: "Expires", visible: true},
|
||||||
|
{name: "Redelivered", visible: true},
|
||||||
|
{name: "Large", visible: true},
|
||||||
|
{name: "Persistent Size", visible: true},
|
||||||
|
{name: "User ID", visible: true},
|
||||||
|
{name: "Validated User", visible: true},
|
||||||
|
{name: "Original Queue (Expiry/DLQ's only)", visible: true}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
|
||||||
|
Artemis.log.debug('sessionStorage: browseColumnDefs =', localStorage.getItem('browseColumnDefs'));
|
||||||
|
if (localStorage.getItem('browseColumnDefs')) {
|
||||||
|
loadedDefs = JSON.parse(localStorage.getItem('browseColumnDefs'));
|
||||||
|
//sanity check to make sure columns havent been added
|
||||||
|
if(loadedDefs.length === ctrl.dtOptions.columns.length) {
|
||||||
|
ctrl.dtOptions.columns = loadedDefs;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ctrl.updateColumns = function () {
|
||||||
|
var attributes = [];
|
||||||
|
ctrl.dtOptions.columns.forEach(function (column) {
|
||||||
|
attributes.push({name: column.name, visible: column.visible});
|
||||||
|
});
|
||||||
|
Artemis.log.debug("saving columns " + JSON.stringify(attributes));
|
||||||
|
localStorage.setItem('browseColumnDefs', JSON.stringify(attributes));
|
||||||
|
}
|
||||||
|
|
||||||
ctrl.tableConfig = {
|
ctrl.tableConfig = {
|
||||||
onCheckBoxChange: handleCheckBoxChange,
|
onCheckBoxChange: handleCheckBoxChange,
|
||||||
selectionMatchProp: 'messageID',
|
selectionMatchProp: 'messageID',
|
||||||
|
@ -208,7 +279,7 @@ var Artemis;
|
||||||
ctrl.tableColumns = [
|
ctrl.tableColumns = [
|
||||||
{
|
{
|
||||||
itemField: 'messageID',
|
itemField: 'messageID',
|
||||||
header: 'messageID'
|
header: 'Message ID'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
itemField: 'type',
|
itemField: 'type',
|
||||||
|
@ -312,9 +383,6 @@ var Artemis;
|
||||||
|
|
||||||
ctrl.tableMenuActions = [ showConfig, resendConfig ];
|
ctrl.tableMenuActions = [ showConfig, resendConfig ];
|
||||||
|
|
||||||
ctrl.tableDtOptions = {
|
|
||||||
order: [[0, "asc"]]
|
|
||||||
};
|
|
||||||
ctrl.sysprops = [];
|
ctrl.sysprops = [];
|
||||||
|
|
||||||
Artemis.log.debug("loaded browse 5" + Artemis.browseQueueModule);
|
Artemis.log.debug("loaded browse 5" + Artemis.browseQueueModule);
|
||||||
|
@ -354,33 +422,34 @@ var Artemis;
|
||||||
}
|
}
|
||||||
|
|
||||||
function formatExpires(timestamp) {
|
function formatExpires(timestamp) {
|
||||||
if (isNaN(timestamp)) {
|
if (isNaN(timestamp)) {
|
||||||
return timestamp;
|
return timestamp;
|
||||||
}
|
}
|
||||||
var expiresIn = timestamp - Date.now();
|
var expiresIn = timestamp - Date.now();
|
||||||
if (Math.abs(expiresIn) < MS_PER_DAY) {
|
if (Math.abs(expiresIn) < MS_PER_DAY) {
|
||||||
var duration = expiresIn < 0 ? -expiresIn : expiresIn;
|
var duration = expiresIn < 0 ? -expiresIn : expiresIn;
|
||||||
var hours = pad2(Math.floor((duration / MS_PER_HOUR) % 24));
|
var hours = pad2(Math.floor((duration / MS_PER_HOUR) % 24));
|
||||||
var mins = pad2(Math.floor((duration / MS_PER_MIN) % 60));
|
var mins = pad2(Math.floor((duration / MS_PER_MIN) % 60));
|
||||||
var secs = pad2(Math.floor((duration / MS_PER_SEC) % 60));
|
var secs = pad2(Math.floor((duration / MS_PER_SEC) % 60));
|
||||||
if (expiresIn < 0) {
|
if (expiresIn < 0) {
|
||||||
// "HH:mm:ss ago"
|
// "HH:mm:ss ago"
|
||||||
return hours + ":" + mins + ":" + secs + " ago";
|
return hours + ":" + mins + ":" + secs + " ago";
|
||||||
}
|
}
|
||||||
// "in HH:mm:ss ago"
|
// "in HH:mm:ss ago"
|
||||||
return "in " + hours + ":" + mins + ":" + secs;
|
return "in " + hours + ":" + mins + ":" + secs;
|
||||||
}
|
}
|
||||||
return formatTimestamp(timestamp);
|
return formatTimestamp(timestamp);
|
||||||
}
|
}
|
||||||
|
|
||||||
function formatTimestamp(timestamp) {
|
function formatTimestamp(timestamp) {
|
||||||
if (isNaN(timestamp)) {
|
if (isNaN(timestamp)) {
|
||||||
return timestamp;
|
return timestamp;
|
||||||
}
|
}
|
||||||
var d = new Date(timestamp);
|
var d = new Date(timestamp);
|
||||||
// "yyyy-MM-dd HH:mm:ss"
|
// "yyyy-MM-dd HH:mm:ss"
|
||||||
return d.getFullYear() + "-" + pad2(d.getMonth()) + "-" + pad2(d.getDay()) + " " + pad2(d.getHours()) + ":" + pad2(d.getMinutes()) + ":" + pad2(d.getSeconds());
|
//add 1 to month as getmonth returns the position not the actual month
|
||||||
}
|
return d.getFullYear() + "-" + pad2(d.getMonth() + 1) + "-" + pad2(d.getDate()) + " " + pad2(d.getHours()) + ":" + pad2(d.getMinutes()) + ":" + pad2(d.getSeconds());
|
||||||
|
}
|
||||||
|
|
||||||
var typeLabels = ["default", "1", "object", "text", "bytes", "map", "stream", "embedded"];
|
var typeLabels = ["default", "1", "object", "text", "bytes", "map", "stream", "embedded"];
|
||||||
function formatType(type) {
|
function formatType(type) {
|
||||||
|
|
|
@ -29,6 +29,7 @@ var Artemis;
|
||||||
</h1>
|
</h1>
|
||||||
<div ng-include="'plugin/artemistoolbar.html'"></div>
|
<div ng-include="'plugin/artemistoolbar.html'"></div>
|
||||||
<pf-table-view config="$ctrl.tableConfig"
|
<pf-table-view config="$ctrl.tableConfig"
|
||||||
|
dt-options="$ctrl.dtOptions"
|
||||||
columns="$ctrl.tableColumns"
|
columns="$ctrl.tableColumns"
|
||||||
action-buttons="$ctrl.tableActionButtons"
|
action-buttons="$ctrl.tableActionButtons"
|
||||||
items="$ctrl.connections">
|
items="$ctrl.connections">
|
||||||
|
@ -71,6 +72,7 @@ var Artemis;
|
||||||
function ConnectionsController($scope, workspace, jolokia, localStorage, artemisMessage, $location, $timeout, $filter, $sanitize, pagination, artemisConnection, artemisSession) {
|
function ConnectionsController($scope, workspace, jolokia, localStorage, artemisMessage, $location, $timeout, $filter, $sanitize, pagination, artemisConnection, artemisSession) {
|
||||||
var ctrl = this;
|
var ctrl = this;
|
||||||
ctrl.pagination = pagination;
|
ctrl.pagination = pagination;
|
||||||
|
ctrl.pagination.reset();
|
||||||
var mbean = Artemis.getBrokerMBean(workspace, jolokia);
|
var mbean = Artemis.getBrokerMBean(workspace, jolokia);
|
||||||
ctrl.allConnections = [];
|
ctrl.allConnections = [];
|
||||||
ctrl.connections = [];
|
ctrl.connections = [];
|
||||||
|
@ -79,16 +81,51 @@ var Artemis;
|
||||||
ctrl.refreshed = false;
|
ctrl.refreshed = false;
|
||||||
ctrl.connectionToDelete = '';
|
ctrl.connectionToDelete = '';
|
||||||
ctrl.closeDialog = false;
|
ctrl.closeDialog = false;
|
||||||
|
ctrl.dtOptions = {
|
||||||
|
// turn of ordering as we do it ourselves
|
||||||
|
ordering: false,
|
||||||
|
columns: [
|
||||||
|
{name: "ID", visible: true},
|
||||||
|
{name: "Client ID", visible: true},
|
||||||
|
{name: "Users", visible: true},
|
||||||
|
{name: "Protocol", visible: true},
|
||||||
|
{name: "Session Count", visible: true},
|
||||||
|
{name: "Remote Address", visible: true},
|
||||||
|
{name: "Local Address", visible: true},
|
||||||
|
{name: "Session ID", visible: true},
|
||||||
|
{name: "Creation Time", visible: true}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
|
||||||
|
Artemis.log.debug('localStorage: connectionsColumnDefs =', localStorage.getItem('connectionsColumnDefs'));
|
||||||
|
if (localStorage.getItem('connectionsColumnDefs')) {
|
||||||
|
loadedDefs = JSON.parse(localStorage.getItem('connectionsColumnDefs'));
|
||||||
|
//sanity check to make sure columns havent been added
|
||||||
|
if(loadedDefs.length === ctrl.dtOptions.columns.length) {
|
||||||
|
ctrl.dtOptions.columns = loadedDefs;
|
||||||
|
}
|
||||||
|
Artemis.log.debug('loaded' + ctrl.dtOptions.columns);
|
||||||
|
}
|
||||||
|
|
||||||
|
ctrl.updateColumns = function () {
|
||||||
|
var attributes = [];
|
||||||
|
ctrl.dtOptions.columns.forEach(function (column) {
|
||||||
|
attributes.push({name: column.name, visible: column.visible});
|
||||||
|
});
|
||||||
|
Artemis.log.debug("saving columns " + JSON.stringify(attributes));
|
||||||
|
localStorage.setItem('connectionsColumnDefs', JSON.stringify(attributes));
|
||||||
|
}
|
||||||
|
|
||||||
ctrl.filter = {
|
ctrl.filter = {
|
||||||
fieldOptions: [
|
fieldOptions: [
|
||||||
{id: 'CONNECTION_ID', name: 'ID'},
|
{id: 'connection_id', name: 'ID'},
|
||||||
{id: 'CLIENT_ID', name: 'Client ID'},
|
{id: 'client_id', name: 'Client ID'},
|
||||||
{id: 'USERS', name: 'Users'},
|
{id: 'users', name: 'Users'},
|
||||||
{id: 'PROTOCOL', name: 'Protocol'},
|
{id: 'protocol', name: 'Protocol'},
|
||||||
{id: 'SESSION_COUNT', name: 'Session Count'},
|
{id: 'session_count', name: 'Session Count'},
|
||||||
{id: 'REMOTE_ADDRESS', name: 'Remote Address'},
|
{id: 'remote_address', name: 'Remote Address'},
|
||||||
{id: 'LOCAL_ADDRESS', name: 'Local Address'},
|
{id: 'local_address', name: 'Local Address'},
|
||||||
{id: 'SESSION_ID', name: 'Session ID'}
|
{id: 'session_id', name: 'Session ID'}
|
||||||
],
|
],
|
||||||
operationOptions: [
|
operationOptions: [
|
||||||
{id: 'EQUALS', name: 'Equals'},
|
{id: 'EQUALS', name: 'Equals'},
|
||||||
|
@ -106,6 +143,12 @@ var Artemis;
|
||||||
value: "",
|
value: "",
|
||||||
sortOrder: "asc",
|
sortOrder: "asc",
|
||||||
sortColumn: "connectionID"
|
sortColumn: "connectionID"
|
||||||
|
},
|
||||||
|
text: {
|
||||||
|
fieldText: "Filter Field..",
|
||||||
|
operationText: "Operation..",
|
||||||
|
sortOrderText: "ascending",
|
||||||
|
sortByText: "ID"
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -144,6 +187,7 @@ var Artemis;
|
||||||
ctrl.filter.values.field = ctrl.filter.fieldOptions[0].id;
|
ctrl.filter.values.field = ctrl.filter.fieldOptions[0].id;
|
||||||
ctrl.filter.values.operation = ctrl.filter.operationOptions[0].id;
|
ctrl.filter.values.operation = ctrl.filter.operationOptions[0].id;
|
||||||
ctrl.filter.values.value = artemisSession.session.connectionID;
|
ctrl.filter.values.value = artemisSession.session.connectionID;
|
||||||
|
artemisSession.session = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
ctrl.refresh = function () {
|
ctrl.refresh = function () {
|
||||||
|
@ -180,7 +224,7 @@ var Artemis;
|
||||||
ctrl.pagination.reset();
|
ctrl.pagination.reset();
|
||||||
ctrl.refreshed = false;
|
ctrl.refreshed = false;
|
||||||
}
|
}
|
||||||
Artemis.log.debug(JSON.stringify(connectionsFilter));
|
Artemis.log.info(JSON.stringify(connectionsFilter));
|
||||||
jolokia.request({ type: 'exec', mbean: mbean, operation: method, arguments: [JSON.stringify(connectionsFilter), ctrl.pagination.pageNumber, ctrl.pagination.pageSize] }, Core.onSuccess(populateTable, { error: onError }));
|
jolokia.request({ type: 'exec', mbean: mbean, operation: method, arguments: [JSON.stringify(connectionsFilter), ctrl.pagination.pageNumber, ctrl.pagination.pageSize] }, Core.onSuccess(populateTable, { error: onError }));
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -27,6 +27,7 @@ var Artemis;
|
||||||
</h1>
|
</h1>
|
||||||
<div ng-include="'plugin/artemistoolbar.html'"></div>
|
<div ng-include="'plugin/artemistoolbar.html'"></div>
|
||||||
<pf-table-view config="$ctrl.tableConfig"
|
<pf-table-view config="$ctrl.tableConfig"
|
||||||
|
dt-options="$ctrl.dtOptions"
|
||||||
columns="$ctrl.tableColumns"
|
columns="$ctrl.tableColumns"
|
||||||
action-buttons="$ctrl.tableActionButtons"
|
action-buttons="$ctrl.tableActionButtons"
|
||||||
items="$ctrl.consumers">
|
items="$ctrl.consumers">
|
||||||
|
@ -69,6 +70,7 @@ var Artemis;
|
||||||
function ConsumersController($scope, workspace, jolokia, localStorage, artemisMessage, $location, $timeout, $filter, $sanitize, pagination, artemisConsumer, artemisQueue, artemisAddress, artemisSession) {
|
function ConsumersController($scope, workspace, jolokia, localStorage, artemisMessage, $location, $timeout, $filter, $sanitize, pagination, artemisConsumer, artemisQueue, artemisAddress, artemisSession) {
|
||||||
var ctrl = this;
|
var ctrl = this;
|
||||||
ctrl.pagination = pagination;
|
ctrl.pagination = pagination;
|
||||||
|
ctrl.pagination.reset();
|
||||||
var mbean = Artemis.getBrokerMBean(workspace, jolokia);
|
var mbean = Artemis.getBrokerMBean(workspace, jolokia);
|
||||||
ctrl.allConsumers = [];
|
ctrl.allConsumers = [];
|
||||||
ctrl.consumers = [];
|
ctrl.consumers = [];
|
||||||
|
@ -78,6 +80,41 @@ var Artemis;
|
||||||
ctrl.consumerToDeletesSession = '';
|
ctrl.consumerToDeletesSession = '';
|
||||||
ctrl.consumerToDelete = '';
|
ctrl.consumerToDelete = '';
|
||||||
ctrl.closeDialog = false;
|
ctrl.closeDialog = false;
|
||||||
|
ctrl.dtOptions = {
|
||||||
|
// turn of ordering as we do it ourselves
|
||||||
|
ordering: false,
|
||||||
|
columns: [
|
||||||
|
{name: "ID", visible: true},
|
||||||
|
{name: "Session", visible: true},
|
||||||
|
{name: "Client ID", visible: true},
|
||||||
|
{name: "Protocol", visible: true},
|
||||||
|
{name: "Queue", visible: true},
|
||||||
|
{name: "Queue Type", visible: true},
|
||||||
|
{name: "Filter", visible: true},
|
||||||
|
{name: "Address", visible: true},
|
||||||
|
{name: "Remote Address", visible: true},
|
||||||
|
{name: "Local Address", visible: true},
|
||||||
|
{name: "Creation Time", visible: true}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
|
||||||
|
Artemis.log.debug('localStorage: consumersColumnDefs =', localStorage.getItem('consumersColumnDefs'));
|
||||||
|
if (localStorage.getItem('consumersColumnDefs')) {
|
||||||
|
loadedDefs = JSON.parse(localStorage.getItem('consumersColumnDefs'));
|
||||||
|
//sanity check to make sure columns havent been added
|
||||||
|
if(loadedDefs.length === ctrl.dtOptions.columns.length) {
|
||||||
|
ctrl.dtOptions.columns = loadedDefs;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ctrl.updateColumns = function () {
|
||||||
|
var attributes = [];
|
||||||
|
ctrl.dtOptions.columns.forEach(function (column) {
|
||||||
|
attributes.push({name: column.name, visible: column.visible});
|
||||||
|
});
|
||||||
|
Artemis.log.debug("saving columns " + JSON.stringify(attributes));
|
||||||
|
localStorage.setItem('consumersColumnDefs', JSON.stringify(attributes));
|
||||||
|
}
|
||||||
ctrl.filter = {
|
ctrl.filter = {
|
||||||
fieldOptions: [
|
fieldOptions: [
|
||||||
{id: 'ID', name: 'ID'},
|
{id: 'ID', name: 'ID'},
|
||||||
|
@ -132,7 +169,7 @@ var Artemis;
|
||||||
{ header: 'Client ID', itemField: 'clientID' },
|
{ header: 'Client ID', itemField: 'clientID' },
|
||||||
{ header: 'Protocol', itemField: 'protocol' },
|
{ header: 'Protocol', itemField: 'protocol' },
|
||||||
{ header: 'Queue', itemField: 'queue', templateFn: function(value, item) { return '<a href="#" onclick="selectQueue(' + item.idx + ')">' + $sanitize(value) + '</a>' }},
|
{ header: 'Queue', itemField: 'queue', templateFn: function(value, item) { return '<a href="#" onclick="selectQueue(' + item.idx + ')">' + $sanitize(value) + '</a>' }},
|
||||||
{ header: 'queueType', itemField: 'queueType' },
|
{ header: 'Queue Type', itemField: 'queueType' },
|
||||||
{ header: 'Filter', itemField: 'filter' },
|
{ header: 'Filter', itemField: 'filter' },
|
||||||
{ header: 'Address', itemField: 'address' , templateFn: function(value, item) { return '<a href="#" onclick="selectAddress(' + item.idx + ')">' + $sanitize(value) + '</a>' }},
|
{ header: 'Address', itemField: 'address' , templateFn: function(value, item) { return '<a href="#" onclick="selectAddress(' + item.idx + ')">' + $sanitize(value) + '</a>' }},
|
||||||
{ header: 'Remote Address', itemField: 'remoteAddress' },
|
{ header: 'Remote Address', itemField: 'remoteAddress' },
|
||||||
|
@ -164,6 +201,15 @@ var Artemis;
|
||||||
ctrl.filter.values.field = ctrl.filter.fieldOptions[1].id;
|
ctrl.filter.values.field = ctrl.filter.fieldOptions[1].id;
|
||||||
ctrl.filter.values.operation = ctrl.filter.operationOptions[0].id;
|
ctrl.filter.values.operation = ctrl.filter.operationOptions[0].id;
|
||||||
ctrl.filter.values.value = artemisConsumer.consumer.sessionID;
|
ctrl.filter.values.value = artemisConsumer.consumer.sessionID;
|
||||||
|
artemisConsumer.consumer = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (artemisQueue.queue) {
|
||||||
|
Artemis.log.info("navigating to consumer = " + artemisQueue.queue.queue);
|
||||||
|
ctrl.filter.values.field = ctrl.filter.fieldOptions[5].id;
|
||||||
|
ctrl.filter.values.operation = ctrl.filter.operationOptions[0].id;
|
||||||
|
ctrl.filter.values.value = artemisQueue.queue.queue;
|
||||||
|
artemisQueue.queue = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
selectQueue = function (idx) {
|
selectQueue = function (idx) {
|
||||||
|
@ -220,6 +266,8 @@ var Artemis;
|
||||||
ctrl.pagination.reset();
|
ctrl.pagination.reset();
|
||||||
ctrl.refreshed = false;
|
ctrl.refreshed = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Artemis.log.info(JSON.stringify(sessionsFilter));
|
||||||
jolokia.request({ type: 'exec', mbean: mbean, operation: method, arguments: [JSON.stringify(sessionsFilter), ctrl.pagination.pageNumber, ctrl.pagination.pageSize] }, Core.onSuccess(populateTable, { error: onError }));
|
jolokia.request({ type: 'exec', mbean: mbean, operation: method, arguments: [JSON.stringify(sessionsFilter), ctrl.pagination.pageNumber, ctrl.pagination.pageSize] }, Core.onSuccess(populateTable, { error: onError }));
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -44,6 +44,16 @@ var Artemis;
|
||||||
<label>Show internal queues:
|
<label>Show internal queues:
|
||||||
<input type="checkbox" ng-model="$ctrl.showInternalQueues">
|
<input type="checkbox" ng-model="$ctrl.showInternalQueues">
|
||||||
</label>
|
</label>
|
||||||
|
|
||||||
|
<label>Show Live Brokers:
|
||||||
|
<input type="checkbox" ng-model="$ctrl.showLiveBrokers">
|
||||||
|
</label>
|
||||||
|
<label>Show Backup Brokers:
|
||||||
|
<input type="checkbox" ng-model="$ctrl.showBackupBrokers">
|
||||||
|
</label>
|
||||||
|
<label>Show Connectors:
|
||||||
|
<input type="checkbox" ng-model="$ctrl.showConnectors">
|
||||||
|
</label>
|
||||||
<button type="submit" class="btn btn-primary"
|
<button type="submit" class="btn btn-primary"
|
||||||
ng-click="$ctrl.refresh()">Refresh
|
ng-click="$ctrl.refresh()">Refresh
|
||||||
</button>
|
</button>
|
||||||
|
@ -81,6 +91,10 @@ var Artemis;
|
||||||
ctrl.showQueues = true;
|
ctrl.showQueues = true;
|
||||||
ctrl.showInternalAddresses = false;
|
ctrl.showInternalAddresses = false;
|
||||||
ctrl.showInternalQueues = false;
|
ctrl.showInternalQueues = false;
|
||||||
|
ctrl.showLiveBrokers = true;
|
||||||
|
ctrl.showBackupBrokers = true;
|
||||||
|
ctrl.showConnectors = true;
|
||||||
|
ctrl.hiddenRelations = [];
|
||||||
$scope.$watch('$ctrl.showAddresses', function () {
|
$scope.$watch('$ctrl.showAddresses', function () {
|
||||||
if(ctrl.kinds.Address && !ctrl.showAddresses) {
|
if(ctrl.kinds.Address && !ctrl.showAddresses) {
|
||||||
delete ctrl.kinds.Address;
|
delete ctrl.kinds.Address;
|
||||||
|
@ -109,6 +123,34 @@ var Artemis;
|
||||||
ctrl.kinds.InternalQueue = true;
|
ctrl.kinds.InternalQueue = true;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
$scope.$watch('$ctrl.showLiveBrokers', function () {
|
||||||
|
if(ctrl.kinds.ThisBroker && !ctrl.showLiveBrokers) {
|
||||||
|
delete ctrl.kinds.ThisBroker;
|
||||||
|
} else if (!ctrl.kinds.ThisBroker && ctrl.showLiveBrokers) {
|
||||||
|
ctrl.kinds.ThisBroker = true;
|
||||||
|
}
|
||||||
|
if(ctrl.kinds.MasterBroker && !ctrl.showLiveBrokers) {
|
||||||
|
delete ctrl.kinds.MasterBroker;
|
||||||
|
} else if (!ctrl.kinds.MasterBroker && ctrl.showLiveBrokers) {
|
||||||
|
ctrl.kinds.MasterBroker = true;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$scope.$watch('$ctrl.showBackupBrokers', function () {
|
||||||
|
if(ctrl.kinds.SlaveBroker && !ctrl.showBackupBrokers) {
|
||||||
|
delete ctrl.kinds.SlaveBroker;
|
||||||
|
} else if (!ctrl.kinds.SlaveBroker && ctrl.showBackupBrokers) {
|
||||||
|
ctrl.kinds.SlaveBroker = true;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$scope.$watch('$ctrl.showConnectors', function () {
|
||||||
|
if(!ctrl.showConnectors) {
|
||||||
|
ctrl.data.relations = [];
|
||||||
|
} else {
|
||||||
|
ctrl.data.relations = ctrl.hiddenRelations;
|
||||||
|
}
|
||||||
|
});
|
||||||
ctrl.datasets = [];
|
ctrl.datasets = [];
|
||||||
//icons can be found at https://www.patternfly.org/v3/styles/icons/index.html
|
//icons can be found at https://www.patternfly.org/v3/styles/icons/index.html
|
||||||
ctrl.serverIcon = "\ue90d";
|
ctrl.serverIcon = "\ue90d";
|
||||||
|
@ -157,7 +199,7 @@ var Artemis;
|
||||||
};
|
};
|
||||||
|
|
||||||
load();
|
load();
|
||||||
|
ctrl.hiddenRelations = ctrl.relations;
|
||||||
function load() {
|
function load() {
|
||||||
ctrl.items = {};
|
ctrl.items = {};
|
||||||
|
|
||||||
|
|
|
@ -28,6 +28,7 @@ var Artemis;
|
||||||
</h1>
|
</h1>
|
||||||
<div ng-include="'plugin/artemistoolbar.html'"></div>
|
<div ng-include="'plugin/artemistoolbar.html'"></div>
|
||||||
<pf-table-view config="$ctrl.tableConfig"
|
<pf-table-view config="$ctrl.tableConfig"
|
||||||
|
dt-options="$ctrl.dtOptions"
|
||||||
columns="$ctrl.tableColumns"
|
columns="$ctrl.tableColumns"
|
||||||
items="$ctrl.producers">
|
items="$ctrl.producers">
|
||||||
</pf-table-view>
|
</pf-table-view>
|
||||||
|
@ -56,12 +57,45 @@ var Artemis;
|
||||||
function ProducersController($scope, workspace, jolokia, localStorage, artemisMessage, $location, $timeout, $filter, $sanitize, pagination, artemisProducer, artemisAddress, artemisSession) {
|
function ProducersController($scope, workspace, jolokia, localStorage, artemisMessage, $location, $timeout, $filter, $sanitize, pagination, artemisProducer, artemisAddress, artemisSession) {
|
||||||
var ctrl = this;
|
var ctrl = this;
|
||||||
ctrl.pagination = pagination;
|
ctrl.pagination = pagination;
|
||||||
|
ctrl.pagination.reset();
|
||||||
var mbean = Artemis.getBrokerMBean(workspace, jolokia);
|
var mbean = Artemis.getBrokerMBean(workspace, jolokia);
|
||||||
ctrl.allProducers = [];
|
ctrl.allProducers = [];
|
||||||
ctrl.producers = [];
|
ctrl.producers = [];
|
||||||
ctrl.pageNumber = 1;
|
ctrl.pageNumber = 1;
|
||||||
ctrl.workspace = workspace;
|
ctrl.workspace = workspace;
|
||||||
ctrl.refreshed = false;
|
ctrl.refreshed = false;
|
||||||
|
ctrl.dtOptions = {
|
||||||
|
// turn of ordering as we do it ourselves
|
||||||
|
ordering: false,
|
||||||
|
columns: [
|
||||||
|
{name: "ID", visible: true},
|
||||||
|
{name: "Session", visible: true},
|
||||||
|
{name: "Client ID", visible: true},
|
||||||
|
{name: "Protocol", visible: true},
|
||||||
|
{name: "User", visible: true},
|
||||||
|
{name: "Address", visible: true},
|
||||||
|
{name: "Remote Address", visible: true},
|
||||||
|
{name: "Local Address", visible: true}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
|
||||||
|
Artemis.log.debug('localStorage: producersColumnDefs =', localStorage.getItem('producersColumnDefs'));
|
||||||
|
if (localStorage.getItem('producersColumnDefs')) {
|
||||||
|
loadedDefs = JSON.parse(localStorage.getItem('producersColumnDefs'));
|
||||||
|
//sanity check to make sure columns havent been added
|
||||||
|
if(loadedDefs.length === ctrl.dtOptions.columns.length) {
|
||||||
|
ctrl.dtOptions.columns = loadedDefs;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ctrl.updateColumns = function () {
|
||||||
|
var attributes = [];
|
||||||
|
ctrl.dtOptions.columns.forEach(function (column) {
|
||||||
|
attributes.push({name: column.name, visible: column.visible});
|
||||||
|
});
|
||||||
|
Artemis.log.debug("saving columns " + JSON.stringify(attributes));
|
||||||
|
localStorage.setItem('producersColumnDefs', JSON.stringify(attributes));
|
||||||
|
}
|
||||||
ctrl.filter = {
|
ctrl.filter = {
|
||||||
fieldOptions: [
|
fieldOptions: [
|
||||||
{id: 'ID', name: 'ID'},
|
{id: 'ID', name: 'ID'},
|
||||||
|
@ -148,6 +182,7 @@ var Artemis;
|
||||||
ctrl.filter.values.field = ctrl.filter.fieldOptions[1].id;
|
ctrl.filter.values.field = ctrl.filter.fieldOptions[1].id;
|
||||||
ctrl.filter.values.operation = ctrl.filter.operationOptions[0].id;
|
ctrl.filter.values.operation = ctrl.filter.operationOptions[0].id;
|
||||||
ctrl.filter.values.value = artemisProducer.producer.sessionID;
|
ctrl.filter.values.value = artemisProducer.producer.sessionID;
|
||||||
|
artemisProducer.producer = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
ctrl.loadOperation = function () {
|
ctrl.loadOperation = function () {
|
||||||
|
|
|
@ -28,6 +28,7 @@ var Artemis;
|
||||||
</h1>
|
</h1>
|
||||||
<div ng-include="'plugin/artemistoolbar.html'"></div>
|
<div ng-include="'plugin/artemistoolbar.html'"></div>
|
||||||
<pf-table-view config="$ctrl.tableConfig"
|
<pf-table-view config="$ctrl.tableConfig"
|
||||||
|
dt-options="$ctrl.dtOptions"
|
||||||
columns="$ctrl.tableColumns"
|
columns="$ctrl.tableColumns"
|
||||||
action-buttons="$ctrl.tableActionButtons"
|
action-buttons="$ctrl.tableActionButtons"
|
||||||
items="$ctrl.queues">
|
items="$ctrl.queues">
|
||||||
|
@ -59,28 +60,86 @@ var Artemis;
|
||||||
function QueuesController($scope, workspace, jolokia, localStorage, artemisMessage, $location, $timeout, $filter, $sanitize, pagination, artemisQueue, artemisAddress) {
|
function QueuesController($scope, workspace, jolokia, localStorage, artemisMessage, $location, $timeout, $filter, $sanitize, pagination, artemisQueue, artemisAddress) {
|
||||||
var ctrl = this;
|
var ctrl = this;
|
||||||
ctrl.pagination = pagination;
|
ctrl.pagination = pagination;
|
||||||
|
ctrl.pagination.reset();
|
||||||
var mbean = Artemis.getBrokerMBean(workspace, jolokia);
|
var mbean = Artemis.getBrokerMBean(workspace, jolokia);
|
||||||
ctrl.allAddresses = [];
|
ctrl.allAddresses = [];
|
||||||
ctrl.queues = [];
|
ctrl.queues = [];
|
||||||
ctrl.workspace = workspace;
|
ctrl.workspace = workspace;
|
||||||
ctrl.refreshed = false;
|
ctrl.refreshed = false;
|
||||||
|
ctrl.dtOptions = {
|
||||||
|
// turn of ordering as we do it ourselves
|
||||||
|
ordering: false,
|
||||||
|
columns: [
|
||||||
|
{name: "ID", visible: true},
|
||||||
|
{name: "name", visible: true},
|
||||||
|
{name: "Address", visible: true},
|
||||||
|
{name: "Routing Type", visible: true},
|
||||||
|
{name: "Filter", visible: true},
|
||||||
|
{name: "Durable", visible: true},
|
||||||
|
{name: "Max Consumers", visible: true},
|
||||||
|
{name: "Purge On No Consumers", visible: true},
|
||||||
|
{name: "Consumer Count", visible: true},
|
||||||
|
{name: "Rate", visible: true},
|
||||||
|
{name: "Message Count", visible: true},
|
||||||
|
{name: "Paused", visible: false},
|
||||||
|
{name: "Temporary", visible: false},
|
||||||
|
{name: "Auto Created", visible: false},
|
||||||
|
{name: "User", visible: false},
|
||||||
|
{name: "Total Messages Added", visible: false},
|
||||||
|
{name: "Total Messages Acked", visible: false},
|
||||||
|
{name: "Delivering Count", visible: false},
|
||||||
|
{name: "Messages Killed", visible: false},
|
||||||
|
{name: "Direct Deliver", visible: false},
|
||||||
|
{name: "Exclusive", visible: false},
|
||||||
|
{name: "Last Value", visible: false},
|
||||||
|
{name: "Last Value Key", visible: false},
|
||||||
|
{name: "Scheduled Count", visible: false},
|
||||||
|
{name: "Group Rebalance", visible: false},
|
||||||
|
{name: "Group Rebalance Pause Dispatch", visible: false},
|
||||||
|
{name: "Group Buckets", visible: false},
|
||||||
|
{name: "Group First Key", visible: false},
|
||||||
|
{name: "Queue Enabled", visible: false},
|
||||||
|
{name: "Ring Size", visible: false},
|
||||||
|
{name: "Consumers Before Dispatch", visible: false},
|
||||||
|
{name: "Delay Before Dispatch", visible: false}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
|
||||||
|
Artemis.log.debug('localStorage: queuesColumnDefs =', localStorage.getItem('queuesColumnDefs'));
|
||||||
|
if (localStorage.getItem('queuesColumnDefs')) {
|
||||||
|
Artemis.log.info("loading columns " + localStorage.getItem('queuesColumnDefs'))
|
||||||
|
loadedDefs = JSON.parse(localStorage.getItem('queuesColumnDefs'));
|
||||||
|
//sanity check to make sure columns havent been added
|
||||||
|
if(loadedDefs.length === ctrl.dtOptions.columns.length) {
|
||||||
|
ctrl.dtOptions.columns = loadedDefs;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ctrl.updateColumns = function () {
|
||||||
|
var attributes = [];
|
||||||
|
ctrl.dtOptions.columns.forEach(function (column) {
|
||||||
|
attributes.push({name: column.name, visible: column.visible});
|
||||||
|
});
|
||||||
|
Artemis.log.debug("saving columns " + JSON.stringify(attributes));
|
||||||
|
localStorage.setItem('queuesColumnDefs', JSON.stringify(attributes));
|
||||||
|
}
|
||||||
ctrl.filter = {
|
ctrl.filter = {
|
||||||
fieldOptions: [
|
fieldOptions: [
|
||||||
{id: 'ID', name: 'ID'},
|
{id: 'id', name: 'ID'},
|
||||||
{id: 'NAME', name: 'Name'},
|
{id: 'name', name: 'Name'},
|
||||||
{id: 'CONSUMER_ID', name: 'Consumer ID'},
|
{id: 'consumerId', name: 'Consumer ID'},
|
||||||
{id: 'ADDRESS', name: 'Address'},
|
{id: 'address', name: 'Address'},
|
||||||
{id: 'FILTER', name: 'Filter'},
|
{id: 'filter', name: 'Filter'},
|
||||||
{id: 'MAX_CONSUMERS', name: 'maxConsumers'},
|
{id: 'maxConsumers', name: 'Max Consumers'},
|
||||||
{id: 'ROUTING_TYPE', name: 'Routing Type'},
|
{id: 'routingType', name: 'Routing Type'},
|
||||||
{id: 'PURGE_ON_NO_CONSUMERS', name: 'Purge On No Consumers'},
|
{id: 'purgeOnNoConsumers', name: 'Purge On No Consumers'},
|
||||||
{id: 'USER', name: 'User'},
|
{id: 'user', name: 'User'},
|
||||||
{id: 'MESSAGE_COUNT', name: 'Message Count'},
|
{id: 'messageCount', name: 'Message Count'},
|
||||||
{id: 'DELIVERING_COUNT', name: 'Delivering Count'},
|
{id: 'deliveringCount', name: 'Delivering Count'},
|
||||||
{id: 'PAUSED', name: 'Paused'},
|
{id: 'paused', name: 'Paused'},
|
||||||
{id: 'TEMPORARY', name: 'Temporary'},
|
{id: 'temporary', name: 'Temporary'},
|
||||||
{id: 'AUTO_CREATED', name: 'Auto Created'},
|
{id: 'autoCreated', name: 'Auto Created'},
|
||||||
{id: 'RATE', name: 'Rate'}
|
{id: 'rate', name: 'Rate'}
|
||||||
],
|
],
|
||||||
operationOptions: [
|
operationOptions: [
|
||||||
{id: 'EQUALS', name: 'Equals'},
|
{id: 'EQUALS', name: 'Equals'},
|
||||||
|
@ -128,16 +187,17 @@ var Artemis;
|
||||||
{ header: 'Name', itemField: 'name',
|
{ header: 'Name', itemField: 'name',
|
||||||
templateFn: function(value, item) { return '<a href="#" onclick="selectQueue(' + item.idx + ')">' + $sanitize(value) + '</a>' }
|
templateFn: function(value, item) { return '<a href="#" onclick="selectQueue(' + item.idx + ')">' + $sanitize(value) + '</a>' }
|
||||||
},
|
},
|
||||||
{ header: 'Routing Types', itemField: 'routingTypes' },
|
|
||||||
{ header: 'Address', itemField: 'address',
|
{ header: 'Address', itemField: 'address',
|
||||||
templateFn: function(value, item) { return '<a href="#" onclick="selectAddress(' + item.idx + ')">' + $sanitize(value) + '</a>' }
|
templateFn: function(value, item) { return '<a href="#" onclick="selectAddress(' + item.idx + ')">' + $sanitize(value) + '</a>' }
|
||||||
},
|
},
|
||||||
{ header: 'Routing Type', itemField: 'routingType' },
|
{ header: 'Routing Type', itemField: 'routingType'},
|
||||||
{ header: 'Filter', itemField: 'filter' },
|
{ header: 'Filter', itemField: 'filter' },
|
||||||
{ header: 'Durable', itemField: 'durable' },
|
{ header: 'Durable', itemField: 'durable' },
|
||||||
{ header: 'Max Consumers', itemField: 'maxConsumers' },
|
{ header: 'Max Consumers', itemField: 'maxConsumers' },
|
||||||
{ header: 'Purge On No Consumers', itemField: 'purgeOnNoConsumers' },
|
{ header: 'Purge On No Consumers', itemField: 'purgeOnNoConsumers' },
|
||||||
{ header: 'Consumer Count', itemField: 'consumerCount' },
|
{ header: 'Consumer Count', itemField: 'consumerCount' ,
|
||||||
|
templateFn: function(value, item) { return '<a href="#" onclick="selectConsumers(' + item.idx + ')">' + $sanitize(value) + '</a>' }
|
||||||
|
},
|
||||||
{ header: 'Rate', itemField: 'rate' },
|
{ header: 'Rate', itemField: 'rate' },
|
||||||
{ header: 'Message Count', itemField: 'messageCount',
|
{ header: 'Message Count', itemField: 'messageCount',
|
||||||
templateFn: function(value, item) { return '<a href="#" onclick="browseQueue(' + item.idx + ')" title="Browse Messages">' + value + '</a>' }
|
templateFn: function(value, item) { return '<a href="#" onclick="browseQueue(' + item.idx + ')" title="Browse Messages">' + value + '</a>' }
|
||||||
|
@ -150,12 +210,24 @@ var Artemis;
|
||||||
{ header: 'Total Messages Acked', itemField: 'messagesAcked' },
|
{ header: 'Total Messages Acked', itemField: 'messagesAcked' },
|
||||||
{ header: 'Delivering Count', itemField: 'deliveringCount' },
|
{ header: 'Delivering Count', itemField: 'deliveringCount' },
|
||||||
{ header: 'Messages Killed', itemField: 'messagesKilled' },
|
{ header: 'Messages Killed', itemField: 'messagesKilled' },
|
||||||
{ header: 'Direct Deliver', itemField: 'directDeliver' }
|
{ header: 'Direct Deliver', itemField: 'directDeliver' },
|
||||||
|
{ header: 'exclusive', itemField: 'exclusive' },
|
||||||
|
{ header: 'Last Value', itemField: 'lastValue' },
|
||||||
|
{ header: 'Last Value Key', itemField: 'lastValueKey' },
|
||||||
|
{ header: 'Scheduled Count', itemField: 'scheduledCount' },
|
||||||
|
{ header: 'Group Rebalance', itemField: 'groupRebalance' },
|
||||||
|
{ header: 'Group Rebalance Pause Dispatch', itemField: 'groupRebalancePauseDispatch' },
|
||||||
|
{ header: 'Group Buckets', itemField: 'groupBuckets' },
|
||||||
|
{ header: 'Group First Key', itemField: 'groupFirstKey' },
|
||||||
|
{ header: 'Enabled', itemField: 'enabled'},
|
||||||
|
{ header: 'Ring Size', itemField: 'ringSize'},
|
||||||
|
{ header: 'Consumers Before Dispatch', itemField: 'consumersBeforeDispatch'},
|
||||||
|
{ header: 'Delay Before Dispatch', itemField: 'delayBeforeDispatch'}
|
||||||
];
|
];
|
||||||
|
|
||||||
ctrl.refresh = function () {
|
ctrl.refresh = function () {
|
||||||
ctrl.refreshed = true;
|
ctrl.refreshed = true;
|
||||||
loadTable();
|
ctrl.pagination.load();
|
||||||
};
|
};
|
||||||
ctrl.reset = function () {
|
ctrl.reset = function () {
|
||||||
ctrl.filter.values.field = "";
|
ctrl.filter.values.field = "";
|
||||||
|
@ -176,6 +248,7 @@ var Artemis;
|
||||||
ctrl.filter.values.field = ctrl.filter.fieldOptions[1].id;
|
ctrl.filter.values.field = ctrl.filter.fieldOptions[1].id;
|
||||||
ctrl.filter.values.operation = ctrl.filter.operationOptions[0].id;
|
ctrl.filter.values.operation = ctrl.filter.operationOptions[0].id;
|
||||||
ctrl.filter.values.value = artemisQueue.queue.queue;
|
ctrl.filter.values.value = artemisQueue.queue.queue;
|
||||||
|
artemisQueue.queue = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (artemisAddress.address) {
|
if (artemisAddress.address) {
|
||||||
|
@ -183,10 +256,13 @@ var Artemis;
|
||||||
ctrl.filter.values.field = ctrl.filter.fieldOptions[3].id;
|
ctrl.filter.values.field = ctrl.filter.fieldOptions[3].id;
|
||||||
ctrl.filter.values.operation = ctrl.filter.operationOptions[0].id;
|
ctrl.filter.values.operation = ctrl.filter.operationOptions[0].id;
|
||||||
ctrl.filter.values.value = artemisAddress.address.address;
|
ctrl.filter.values.value = artemisAddress.address.address;
|
||||||
|
artemisAddress.address = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
function navigateToQueuesAtts(action, item) {
|
function navigateToQueuesAtts(action, item) {
|
||||||
$location.path("artemis/attributes").search({"tab": "artemis", "nid": getQueuesNid(item, $location)});
|
qnid = getQueuesNid(item, $location);
|
||||||
|
Artemis.log.info(qnid);
|
||||||
|
$location.path("artemis/attributes").search({"tab": "artemis", "nid": qnid });
|
||||||
};
|
};
|
||||||
function navigateToQueuesOps(action, item) {
|
function navigateToQueuesOps(action, item) {
|
||||||
$location.path("artemis/operations").search({"tab": "artemis", "nid": getQueuesNid(item, $location)});
|
$location.path("artemis/operations").search({"tab": "artemis", "nid": getQueuesNid(item, $location)});
|
||||||
|
@ -201,10 +277,15 @@ var Artemis;
|
||||||
var item = ctrl.queues[idx];
|
var item = ctrl.queues[idx];
|
||||||
var nid = getQueuesNid(item, $location);
|
var nid = getQueuesNid(item, $location);
|
||||||
Artemis.log.debug("navigating to queue:" + nid);
|
Artemis.log.debug("navigating to queue:" + nid);
|
||||||
artemisAddress.address = { address: item.address };
|
artemisQueue.queue = { queue: item.name };
|
||||||
artemisQueue.queue = item;
|
|
||||||
$location.path("artemis/artemisQueues").search({"tab": "artemis", "nid": nid});
|
$location.path("artemis/artemisQueues").search({"tab": "artemis", "nid": nid});
|
||||||
};
|
};
|
||||||
|
selectConsumers = function (idx) {
|
||||||
|
var item = ctrl.queues[idx];
|
||||||
|
var nid = getQueuesNid(item, $location);
|
||||||
|
artemisQueue.queue = { queue: item.name };
|
||||||
|
$location.path("artemis/artemisConsumers").search({"tab": "artemis", "nid": nid});;
|
||||||
|
};
|
||||||
browseQueue = function (idx) {
|
browseQueue = function (idx) {
|
||||||
var item = ctrl.queues[idx];
|
var item = ctrl.queues[idx];
|
||||||
var nid = getQueuesNid(item, $location);
|
var nid = getQueuesNid(item, $location);
|
||||||
|
@ -224,16 +305,14 @@ var Artemis;
|
||||||
return targetNID;
|
return targetNID;
|
||||||
}
|
}
|
||||||
function getRootNid($location) {
|
function getRootNid($location) {
|
||||||
var currentNid = $location.search()['nid'];
|
var mBean = Artemis.getBrokerMBean(workspace, jolokia);
|
||||||
Artemis.log.debug("current nid=" + currentNid);
|
var details = Core.parseMBean(mBean);
|
||||||
var firstDash = currentNid.indexOf('-');
|
var properties = details['attributes'];
|
||||||
var secondDash = currentNid.indexOf('-', firstDash + 1);
|
var brokerAddress = properties["broker"] || "unknown";
|
||||||
var thirdDash = currentNid.indexOf('-', secondDash + 1);
|
var artemisJmxDomain = localStorage['artemisJmxDomain'] || "org.apache.activemq.artemis";
|
||||||
if (thirdDash < 0) {
|
//we have to remove the surrounding quotes
|
||||||
return currentNid + "-";
|
return "root-" + artemisJmxDomain + "-" + brokerAddress.replace(/^"|"$/g, '') + "-";
|
||||||
}
|
|
||||||
var rootNID = currentNid.substring(0, thirdDash + 1);
|
|
||||||
return rootNID;
|
|
||||||
}
|
}
|
||||||
ctrl.loadOperation = function () {
|
ctrl.loadOperation = function () {
|
||||||
if (mbean) {
|
if (mbean) {
|
||||||
|
@ -257,7 +336,7 @@ var Artemis;
|
||||||
ctrl.pagination.setOperation(ctrl.loadOperation);
|
ctrl.pagination.setOperation(ctrl.loadOperation);
|
||||||
|
|
||||||
function onError(response) {
|
function onError(response) {
|
||||||
Core.notification("error", "could not invoke list sessions" + response.error);
|
Core.notification("error", "could not invoke list queues" + response.error);
|
||||||
$scope.workspace.selectParentNode();
|
$scope.workspace.selectParentNode();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -28,6 +28,7 @@ var Artemis;
|
||||||
</h1>
|
</h1>
|
||||||
<div ng-include="'plugin/artemistoolbar.html'"></div>
|
<div ng-include="'plugin/artemistoolbar.html'"></div>
|
||||||
<pf-table-view config="$ctrl.tableConfig"
|
<pf-table-view config="$ctrl.tableConfig"
|
||||||
|
dt-options="$ctrl.dtOptions"
|
||||||
columns="$ctrl.tableColumns"
|
columns="$ctrl.tableColumns"
|
||||||
action-buttons="$ctrl.tableActionButtons"
|
action-buttons="$ctrl.tableActionButtons"
|
||||||
items="$ctrl.sessions">
|
items="$ctrl.sessions">
|
||||||
|
@ -70,6 +71,7 @@ var Artemis;
|
||||||
function SessionsController($scope, workspace, jolokia, localStorage, artemisMessage, $location, $timeout, $filter, $sanitize, pagination, artemisConnection, artemisSession, artemisConsumer, artemisProducer) {
|
function SessionsController($scope, workspace, jolokia, localStorage, artemisMessage, $location, $timeout, $filter, $sanitize, pagination, artemisConnection, artemisSession, artemisConsumer, artemisProducer) {
|
||||||
var ctrl = this;
|
var ctrl = this;
|
||||||
ctrl.pagination = pagination;
|
ctrl.pagination = pagination;
|
||||||
|
ctrl.pagination.reset();
|
||||||
var mbean = Artemis.getBrokerMBean(workspace, jolokia);
|
var mbean = Artemis.getBrokerMBean(workspace, jolokia);
|
||||||
ctrl.allSessions = [];
|
ctrl.allSessions = [];
|
||||||
ctrl.sessions = [];
|
ctrl.sessions = [];
|
||||||
|
@ -79,16 +81,46 @@ var Artemis;
|
||||||
ctrl.sessionToDeletesConnection = '';
|
ctrl.sessionToDeletesConnection = '';
|
||||||
ctrl.sessionToDelete = '';
|
ctrl.sessionToDelete = '';
|
||||||
ctrl.closeDialog = false;
|
ctrl.closeDialog = false;
|
||||||
|
ctrl.dtOptions = {
|
||||||
|
// turn of ordering as we do it ourselves
|
||||||
|
ordering: false,
|
||||||
|
columns: [
|
||||||
|
{name: "ID", visible: true},
|
||||||
|
{name: "Connection", visible: true},
|
||||||
|
{name: "User", visible: true},
|
||||||
|
{name: "Consumer Count", visible: true},
|
||||||
|
{name: "Producer Count", visible: true},
|
||||||
|
{name: "Creation Time", visible: true}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
|
||||||
|
Artemis.log.debug('localStorage: sessionsColumnDefs =', localStorage.getItem('sessionsColumnDefs'));
|
||||||
|
if (localStorage.getItem('sessionsColumnDefs')) {
|
||||||
|
loadedDefs = JSON.parse(localStorage.getItem('sessionsColumnDefs'));
|
||||||
|
//sanity check to make sure columns havent been added
|
||||||
|
if(loadedDefs.length === ctrl.dtOptions.columns.length) {
|
||||||
|
ctrl.dtOptions.columns = loadedDefs;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ctrl.updateColumns = function () {
|
||||||
|
var attributes = [];
|
||||||
|
ctrl.dtOptions.columns.forEach(function (column) {
|
||||||
|
attributes.push({name: column.name, visible: column.visible});
|
||||||
|
});
|
||||||
|
Artemis.log.debug("saving columns " + JSON.stringify(attributes));
|
||||||
|
localStorage.setItem('sessionsColumnDefs', JSON.stringify(attributes));
|
||||||
|
}
|
||||||
ctrl.filter = {
|
ctrl.filter = {
|
||||||
fieldOptions: [
|
fieldOptions: [
|
||||||
{id: 'ID', name: 'ID'},
|
{id: 'id', name: 'ID'},
|
||||||
{id: 'CONNECTION_ID', name: 'Connection ID'},
|
{id: 'connection_id', name: 'Connection ID'},
|
||||||
{id: 'CONSUMER_COUNT', name: 'Consumer Count'},
|
{id: 'consumer_count', name: 'Consumer Count'},
|
||||||
{id: 'USER', name: 'User'},
|
{id: 'user', name: 'User'},
|
||||||
{id: 'PROTOCOL', name: 'Protocol'},
|
{id: 'protocol', name: 'Protocol'},
|
||||||
{id: 'CLIENT_ID', name: 'Client ID'},
|
{id: 'client_id', name: 'Client ID'},
|
||||||
{id: 'LOCAL_ADDRESS', name: 'Local Address'},
|
{id: 'local_address', name: 'Local Address'},
|
||||||
{id: 'REMOTE_ADDRESS', name: 'Remote Address'}
|
{id: 'remote_address', name: 'Remote Address'}
|
||||||
],
|
],
|
||||||
operationOptions: [
|
operationOptions: [
|
||||||
{id: 'EQUALS', name: 'Equals'},
|
{id: 'EQUALS', name: 'Equals'},
|
||||||
|
@ -181,6 +213,7 @@ var Artemis;
|
||||||
ctrl.filter.values.field = ctrl.filter.fieldOptions[1].id;
|
ctrl.filter.values.field = ctrl.filter.fieldOptions[1].id;
|
||||||
ctrl.filter.values.operation = ctrl.filter.operationOptions[0].id;
|
ctrl.filter.values.operation = ctrl.filter.operationOptions[0].id;
|
||||||
ctrl.filter.values.value = artemisConnection.connection.connectionID;
|
ctrl.filter.values.value = artemisConnection.connection.connectionID;
|
||||||
|
artemisConnection.connection = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (artemisSession.session) {
|
if (artemisSession.session) {
|
||||||
|
@ -188,6 +221,7 @@ var Artemis;
|
||||||
ctrl.filter.values.field = ctrl.filter.fieldOptions[0].id;
|
ctrl.filter.values.field = ctrl.filter.fieldOptions[0].id;
|
||||||
ctrl.filter.values.operation = ctrl.filter.operationOptions[0].id;
|
ctrl.filter.values.operation = ctrl.filter.operationOptions[0].id;
|
||||||
ctrl.filter.values.value = artemisSession.session.session;
|
ctrl.filter.values.value = artemisSession.session.session;
|
||||||
|
artemisSession.session = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
function openCloseDialog(action, item) {
|
function openCloseDialog(action, item) {
|
||||||
|
|
|
@ -66,7 +66,42 @@ var Artemis;
|
||||||
ng-click="$ctrl.reset()">Reset
|
ng-click="$ctrl.reset()">Reset
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="input-group-btn">
|
||||||
|
<button class="btn btn-default primary-action ng-binding ng-scope"
|
||||||
|
type="button"
|
||||||
|
title=""
|
||||||
|
ng-click="$ctrl.showColumns = true">Columns
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group" ng-show="$ctrl.showColumns">
|
||||||
|
<button class="btn btn-default" data-toggle="modal" data-target="#myModal">Columns</button>
|
||||||
|
<div class="modal ng-scope">
|
||||||
|
<div class="modal-dialog ">
|
||||||
|
<div class="modal-content">
|
||||||
|
<div class="modal-header">
|
||||||
|
<h4 class="modal-title ng-binding">Column Selector</h4>
|
||||||
|
</div>
|
||||||
|
<div class="modal-body">
|
||||||
|
<table class="table-view-container table table-striped table-bordered table-hover dataTable ng-scope ng-isolate-scope no-footer">
|
||||||
|
<tbody>
|
||||||
|
<tr ng-repeat="col in $ctrl.dtOptions.columns">
|
||||||
|
<td>{{ col.name }}</td>
|
||||||
|
<td><input type="checkbox" ng-model="col.visible" placeholder="Name" autocomplete="off" id="name"></td>
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
<div class="modal-footer">
|
||||||
|
<button type="button" class="btn btn-default ng-binding" ng-click="$ctrl.showColumns = false;$ctrl.updateColumns()">
|
||||||
|
Close
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
`
|
`
|
||||||
|
|
|
@ -703,6 +703,55 @@ public class QueueControlImpl extends AbstractControl implements QueueControl {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getLastValueKey() {
|
||||||
|
if (AuditLogger.isEnabled()) {
|
||||||
|
AuditLogger.lastValueKey(queue);
|
||||||
|
}
|
||||||
|
checkStarted();
|
||||||
|
|
||||||
|
clearIO();
|
||||||
|
try {
|
||||||
|
if (queue.getLastValueKey() != null) {
|
||||||
|
return queue.getLastValueKey().toString();
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
blockOnIO();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getConsumersBeforeDispatch() {
|
||||||
|
if (AuditLogger.isEnabled()) {
|
||||||
|
AuditLogger.consumersBeforeDispatch(queue);
|
||||||
|
}
|
||||||
|
checkStarted();
|
||||||
|
|
||||||
|
clearIO();
|
||||||
|
try {
|
||||||
|
return queue.getConsumersBeforeDispatch();
|
||||||
|
} finally {
|
||||||
|
blockOnIO();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public long getDelayBeforeDispatch() {
|
||||||
|
if (AuditLogger.isEnabled()) {
|
||||||
|
AuditLogger.delayBeforeDispatch(queue);
|
||||||
|
}
|
||||||
|
checkStarted();
|
||||||
|
|
||||||
|
clearIO();
|
||||||
|
try {
|
||||||
|
return queue.getDelayBeforeDispatch();
|
||||||
|
} finally {
|
||||||
|
blockOnIO();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Map<String, Object>[] listScheduledMessages() throws Exception {
|
public Map<String, Object>[] listScheduledMessages() throws Exception {
|
||||||
if (AuditLogger.isEnabled()) {
|
if (AuditLogger.isEnabled()) {
|
||||||
|
|
|
@ -60,14 +60,19 @@ public class QueueView extends ActiveMQAbstractView<QueueControl> {
|
||||||
.add("messagesAcked", toString(queue.getMessagesAcknowledged()))
|
.add("messagesAcked", toString(queue.getMessagesAcknowledged()))
|
||||||
.add("deliveringCount", toString(queue.getDeliveringCount()))
|
.add("deliveringCount", toString(queue.getDeliveringCount()))
|
||||||
.add("messagesKilled", toString(queue.getMessagesKilled()))
|
.add("messagesKilled", toString(queue.getMessagesKilled()))
|
||||||
.add("deliverDeliver", toString(q.isDirectDeliver()))
|
.add("directDeliver", toString(q.isDirectDeliver()))
|
||||||
.add("exclusive", toString(queue.isExclusive()))
|
.add("exclusive", toString(queue.isExclusive()))
|
||||||
.add("lastValue", toString(queue.isLastValue()))
|
.add("lastValue", toString(queue.isLastValue()))
|
||||||
|
.add("lastValueKey", toString(queue.getLastValueKey()))
|
||||||
.add("scheduledCount", toString(queue.getScheduledCount()))
|
.add("scheduledCount", toString(queue.getScheduledCount()))
|
||||||
.add("groupRebalance", toString(queue.isGroupRebalance()))
|
.add("groupRebalance", toString(queue.isGroupRebalance()))
|
||||||
.add("groupRebalancePauseDispatch", toString(queue.isGroupRebalancePauseDispatch()))
|
.add("groupRebalancePauseDispatch", toString(queue.isGroupRebalancePauseDispatch()))
|
||||||
.add("groupBuckets", toString(queue.getGroupBuckets()))
|
.add("groupBuckets", toString(queue.getGroupBuckets()))
|
||||||
.add("groupFirstKey", toString(queue.getGroupFirstKey()));
|
.add("groupFirstKey", toString(queue.getGroupFirstKey()))
|
||||||
|
.add("enabled", toString(queue.isEnabled()))
|
||||||
|
.add("ringSize", toString(queue.getRingSize()))
|
||||||
|
.add("consumersBeforeDispatch", toString(queue.getConsumersBeforeDispatch()))
|
||||||
|
.add("delayBeforeDispatch", toString(queue.getDelayBeforeDispatch()));
|
||||||
return obj;
|
return obj;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -119,6 +124,8 @@ public class QueueView extends ActiveMQAbstractView<QueueControl> {
|
||||||
return q.isExclusive();
|
return q.isExclusive();
|
||||||
case "lastValue":
|
case "lastValue":
|
||||||
return q.isLastValue();
|
return q.isLastValue();
|
||||||
|
case "lastValueKey":
|
||||||
|
return q.getLastValueKey();
|
||||||
case "scheduledCount":
|
case "scheduledCount":
|
||||||
return q.getScheduledCount();
|
return q.getScheduledCount();
|
||||||
case "groupRebalance":
|
case "groupRebalance":
|
||||||
|
@ -129,6 +136,14 @@ public class QueueView extends ActiveMQAbstractView<QueueControl> {
|
||||||
return queue.getGroupBuckets();
|
return queue.getGroupBuckets();
|
||||||
case "groupFirstKey":
|
case "groupFirstKey":
|
||||||
return queue.getGroupFirstKey();
|
return queue.getGroupFirstKey();
|
||||||
|
case "enabled":
|
||||||
|
return q.isEnabled();
|
||||||
|
case "ringSize":
|
||||||
|
return q.getRingSize();
|
||||||
|
case "consumersBeforeDispatch":
|
||||||
|
return q.getConsumersBeforeDispatch();
|
||||||
|
case "delayBeforeDispatch":
|
||||||
|
return q.getDelayBeforeDispatch();
|
||||||
default:
|
default:
|
||||||
throw new IllegalArgumentException("Unsupported field, " + fieldName);
|
throw new IllegalArgumentException("Unsupported field, " + fieldName);
|
||||||
}
|
}
|
||||||
|
|
|
@ -224,6 +224,21 @@ public class QueueControlUsingCoreTest extends QueueControlTest {
|
||||||
return (Boolean) proxy.retrieveAttributeValue("lastValue");
|
return (Boolean) proxy.retrieveAttributeValue("lastValue");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getLastValueKey() {
|
||||||
|
return (String) proxy.retrieveAttributeValue("lastValueKey");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getConsumersBeforeDispatch() {
|
||||||
|
return (Integer) proxy.retrieveAttributeValue("consumersBeforeDispatch");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public long getDelayBeforeDispatch() {
|
||||||
|
return (Long) proxy.retrieveAttributeValue("delayBeforeDispatch");
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getDeliveringCount() {
|
public int getDeliveringCount() {
|
||||||
return (Integer) proxy.retrieveAttributeValue("deliveringCount", Integer.class);
|
return (Integer) proxy.retrieveAttributeValue("deliveringCount", Integer.class);
|
||||||
|
|
Loading…
Reference in New Issue