
org.jpos.q2.QBeanSupport Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jpos Show documentation
Show all versions of jpos Show documentation
jPOS is an ISO-8583 based financial transaction
library/framework that can be customized and
extended in order to implement financial interchanges.
/*
* jPOS Project [http://jpos.org]
* Copyright (C) 2000-2020 jPOS Software SRL
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program 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 Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see .
*/
package org.jpos.q2;
import org.jdom2.Element;
import org.jpos.core.Configurable;
import org.jpos.core.Configuration;
import org.jpos.core.ConfigurationException;
import org.jpos.util.*;
import java.beans.BeanInfo;
import java.beans.Introspector;
import java.beans.PropertyDescriptor;
import java.io.ByteArrayOutputStream;
import java.io.Closeable;
import java.io.PrintStream;
import java.lang.reflect.Method;
import java.net.URL;
import java.util.Iterator;
import java.util.concurrent.ScheduledThreadPoolExecutor;
/**
* @author Alireza Taherkordi
* @author Alejandro P. Revilla
*/
public class QBeanSupport
implements QBean, QPersist, QBeanSupportMBean, Configurable
{
Element persist;
int state;
Q2 server;
final Object modifyLock = new Object();
boolean modified;
String name;
protected Log log;
protected Configuration cfg;
protected ScheduledThreadPoolExecutor scheduledThreadPoolExecutor;
public QBeanSupport () {
super();
setLogger (Q2.LOGGER_NAME);
state = -1;
}
@Override
public void setServer (Q2 server) {
this.server = server;
}
@Override
public Q2 getServer () {
return server;
}
public QFactory getFactory () {
return getServer().getFactory ();
}
@Override
public void setName (String name) {
if (this.name == null)
this.name = name;
if (log != null)
log.setRealm (name);
setModified (true);
}
@Override
public void setLogger (String loggerName) {
log = Log.getLog (loggerName, getClass().getName());
setModified (true);
}
@Override
public void setRealm (String realm) {
if (log != null)
log.setRealm (realm);
}
@Override
public String getRealm() {
return log != null ? log.getRealm() : null;
}
@Override
public String getLogger () {
return log != null ? log.getLogger().getName() : null;
}
public Log getLog () {
return log;
}
@Override
public String getName () {
return name;
}
@Override
public void init () {
if (state == -1) {
setModified (false);
try {
initService();
state = QBean.STOPPED;
} catch (Throwable t) {
log.warn ("init", t);
}
}
}
@Override
public synchronized void start() {
if (state != QBean.DESTROYED &&
state != QBean.STOPPED &&
state != QBean.FAILED)
return;
this.state = QBean.STARTING;
try {
startService();
} catch (Throwable t) {
state = QBean.FAILED;
log.warn ("start", t);
return;
}
state = QBean.STARTED;
}
@Override
public synchronized void stop () {
if (state != QBean.STARTED)
return;
state = QBean.STOPPING;
try {
stopService();
} catch (Throwable t) {
state = QBean.FAILED;
log.warn ("stop", t);
return;
}
state = QBean.STOPPED;
}
@Override
public void destroy () {
if (state == QBean.DESTROYED)
return;
if (state != QBean.STOPPED)
stop();
if (scheduledThreadPoolExecutor != null) {
scheduledThreadPoolExecutor.shutdown();
scheduledThreadPoolExecutor = null;
}
try {
destroyService();
}
catch (Throwable t) {
log.warn ("destroy", t);
}
state = QBean.DESTROYED;
}
@Override
public int getState () {
return state;
}
@Override
public URL[] getLoaderURLS() {
return server.getLoader().getURLs();
}
@Override
public QClassLoader getLoader() {
return server.getLoader();
}
@Override
public String getStateAsString () {
return state >= 0 ? stateString[state] : "Unknown";
}
public void setState (int state) {
this.state = state;
}
@Override
public void setPersist (Element persist) {
this.persist = persist ;
}
@Override
public Element getPersist () {
setModified (false);
return persist;
}
public void setModified (boolean modified) {
synchronized (this.modifyLock) {
this.modified = modified;
}
}
@Override
public boolean isModified () {
synchronized (this.modifyLock) {
return modified;
}
}
public boolean running () {
return state == QBean.STARTING || state == QBean.STARTED;
}
@Override
public void setConfiguration (Configuration cfg)
throws ConfigurationException
{
this.cfg = cfg;
}
public Configuration getConfiguration () {
return cfg;
}
public String getDump () {
if (this instanceof Loggeable) {
ByteArrayOutputStream baos = new ByteArrayOutputStream();
PrintStream p = new PrintStream(baos);
((Loggeable)this).dump(p, "");
return baos.toString();
}
return toString();
}
protected void initService() throws Exception {}
protected void startService() throws Exception {}
protected void stopService() throws Exception {}
protected void destroyService() throws Exception {}
protected synchronized ScheduledThreadPoolExecutor getScheduledThreadPoolExecutor() {
if (scheduledThreadPoolExecutor == null)
scheduledThreadPoolExecutor = ConcurrentUtil.newScheduledThreadPoolExecutor();
return scheduledThreadPoolExecutor;
}
protected Element createElement (String name, Class mbeanClass) {
Element e = new Element (name);
Element classPath = persist != null ?
persist.getChild ("classpath") : null;
if (classPath != null)
e.addContent (classPath);
e.setAttribute ("class", getClass().getName());
if (!e.getName().equals (getName ()))
e.setAttribute ("name", getName());
String loggerName = getLogger();
if (loggerName != null)
e.setAttribute ("logger", loggerName);
try {
BeanInfo info = Introspector.getBeanInfo (mbeanClass);
PropertyDescriptor[] desc = info.getPropertyDescriptors();
for (PropertyDescriptor aDesc : desc) {
if (aDesc.getWriteMethod() != null) {
Method read = aDesc.getReadMethod();
Object obj = read.invoke(this);
String type = read.getReturnType().getName();
if ("java.lang.String".equals(type))
type = null;
addAttr(e, aDesc.getName(), obj, type);
}
}
} catch (Exception ex) {
log.warn ("get-persist", ex);
}
return e;
}
protected void addAttr (Element e, String name, Object obj, String type) {
String value = obj == null ? "null" : obj.toString();
Element attr = new Element ("attr");
attr.setAttribute ("name", name);
if (type != null)
attr.setAttribute ("type", type);
attr.setText (value);
e.addContent (attr);
}
protected Iterator getAttrs () {
return getPersist().getChildren ("attr").iterator();
}
protected Iterator getAttrs (String parent) {
return getPersist().getChild(parent).
getChildren("attr").iterator();
}
protected void setAttr (Iterator attrs, String name, Object obj) {
String value = obj == null ? "null" : obj.toString ();
while (attrs.hasNext ()) {
Element e = (Element) attrs.next ();
if (name.equals (e.getAttributeValue ("name"))) {
e.setText(value);
break;
}
}
}
protected Iterator getProperties (String parent) {
return getPersist().getChild (parent).
getChildren ("property").iterator();
}
protected void setProperty (Iterator props, String name, String value) {
while (props.hasNext()) {
Element e = (Element) props.next();
if (name.equals (e.getAttributeValue ("name"))) {
e.setAttribute ("value", value);
break;
}
}
}
protected String getProperty (Iterator props, String name) {
while (props.hasNext()) {
Element e = (Element) props.next();
if (name.equals (e.getAttributeValue ("name"))) {
return e.getAttributeValue ("value");
}
}
return null;
}
protected void close (Closeable... closeables) {
LogEvent evt = null;
for (Closeable c : closeables) {
try {
c.close();
} catch (Exception e) {
if (evt == null)
evt = getLog().createWarn();
evt.addMessage(e);
}
}
if (evt != null)
Logger.log(evt);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy