groovy.jmx.builder.JmxTimerFactory.groovy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of groovy-jmx Show documentation
Show all versions of groovy-jmx Show documentation
Groovy: A powerful, dynamic language for the JVM
The newest version!
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package groovy.jmx.builder
import groovy.jmx.GroovyMBean
import javax.management.MBeanServer
import javax.management.NotificationFilter
import javax.management.NotificationFilterSupport
import javax.management.ObjectName
/**
* The JmxTimerFactory class generates a timer() node for JmxBuilder. This node crates a standard JMX Timer object
* that can be used to provide timing signals to registered JMX listeners.
*
* Syntax:
*
* timer(
* name:"object name"|ObjectName(),
* event:"...",
* message:"...",
* data:dataValue
* startDate:"now"|dateValue
* period:"99d"|"99h"|"99m"|"99s"|99
* occurences:long
* )
*
*/
class JmxTimerFactory extends AbstractFactory {
public Object newInstance(FactoryBuilderSupport builder, Object nodeName, Object nodeParam, Map nodeAttribs) {
if (nodeParam) {
throw new JmxBuilderException("Node '${nodeName}' only supports named attributes.")
}
JmxBuilder fsb = (JmxBuilder) builder
javax.management.timer.Timer timer = new javax.management.timer.Timer()
def metaMap = [:]
metaMap.server = fsb.getMBeanServer()
metaMap.timer = timer
metaMap.name = nodeAttribs.remove("name")
metaMap.event = nodeAttribs.remove("event") ?: nodeAttribs.remove("type") ?: "jmx.builder.event"
metaMap.message = nodeAttribs.remove("message") ?: nodeAttribs.remove("msg")
metaMap.data = nodeAttribs.remove("data") ?: nodeAttribs.remove("userData")
metaMap.date = nodeAttribs.remove("date") ?: nodeAttribs.remove("startDate")
metaMap.period = nodeAttribs.remove("period") ?: nodeAttribs.remove("frequency")
metaMap.occurences = nodeAttribs.remove("occurs") ?: nodeAttribs.remove("occurences") ?: 0
// normalize data
metaMap.name = getNormalizedName(fsb, timer, metaMap.name)
metaMap.date = getNormalizedDate(metaMap.date)
metaMap.period = getNormalizedPeriod(metaMap.period)
metaMap.listeners = getNormalizedRecipientList(metaMap.listeners)
def result = registerTimer(metaMap)
result
}
private static getNormalizedName(fsb, timer, name) {
def result
if (!name) {
result = getDefaultName(fsb, timer)
} else {
if (name instanceof String) {
result = new ObjectName(name)
} else if (name instanceof ObjectName) {
result = name
} else {
result = getDefaultName(fsb, timer)
}
}
result
}
private static getDefaultName(fsb, timer) {
def name = "${fsb.getDefaultJmxNameDomain()}:type=TimerService,name=Timer@${timer.hashCode()}"
new ObjectName(name)
}
private static getNormalizedDate(date) {
if (!date) return new Date()
if (date instanceof Date) {
return date
}
def startDate
switch (date) {
case null:
case "now":
default:
startDate = new Date()
}
startDate
}
private static getNormalizedPeriod(period) {
if (!period) return 1000L
if (period instanceof Number) {
return period
}
def result = 1000L
if (period instanceof String) {
def multiplier = period[-1]
def value
try {
value = period[0..-2].toLong()
} catch (ignore) {
multiplier = "x"
value = 0
}
switch (multiplier) {
case "s":
result = value * 1000
break
case "m":
result = value * 60 * 1000
break
case "h":
result = value * 60 * 60 * 1000
break
case "d":
result = value * 24 * 60 * 60 * 1000
break
default:
result = 1000L
}
}
result
}
private static getNormalizedRecipientList(list) {
if (!list) return null
def result = []
list.each { name ->
def on
if (name instanceof String) {
on = new ObjectName(name)
} else if (name instanceof ObjectName) {
on = name
} else {
on = new ObjectName(name.toString())
}
result.add(on)
}
result
}
private static registerTimer(metaMap) {
def server = (MBeanServer) metaMap.server
def timer = metaMap.timer
timer.addNotification(
metaMap.event,
metaMap.message,
metaMap.data,
metaMap.date,
metaMap.period,
metaMap.occurences)
if (server.isRegistered(metaMap.name)) {
server.unregisterMBean metaMap.name
}
server.registerMBean(timer, metaMap.name)
new GroovyMBean(metaMap.server, metaMap.name)
}
private static NotificationFilter getEventFilter(type) {
def noteFilter = new NotificationFilterSupport()
noteFilter.enableType type
noteFilter
}
boolean onHandleNodeAttributes(FactoryBuilderSupport builder, Object node, Map nodeAttribs) {
false
}
boolean isLeaf() {
true
}
void onNodeCompleted(FactoryBuilderSupport builder, Object parentNode, Object thisNode) {
if (parentNode != null) {
parentNode.add(thisNode)
}
}
}