📄 getreturnqos.java
字号:
/*------------------------------------------------------------------------------Name: GetReturnQos.javaProject: xmlBlaster.orgCopyright: xmlBlaster.org, see xmlBlaster-LICENSE file------------------------------------------------------------------------------*/package org.xmlBlaster.client.qos;import java.util.logging.Logger;import java.util.logging.Level;import org.xmlBlaster.util.Global;import org.xmlBlaster.util.Timestamp;import org.xmlBlaster.util.XmlBlasterException;import org.xmlBlaster.util.SessionName;import org.xmlBlaster.util.cluster.RouteInfo;import org.xmlBlaster.util.def.PriorityEnum;import org.xmlBlaster.util.qos.MsgQosData;import org.xmlBlaster.util.qos.ClientProperty;import org.xmlBlaster.util.def.MethodName;import java.util.Map;/** * QoS (quality of service) informations sent from server to client<br /> * via the return value of the get() method. * <p /> * If you are a Java client you may use this class to parse the QoS argument. * <p /> * Example: * <pre> * <qos> <!-- GetReturnQos --> * <state id='OK'/> * <sender>Tim</sender> * <priority>5</priority> * <rcvTimestamp nanos='1007764305862000002'> <!-- UTC time when message was created in xmlBlaster server with a publish() call, in nanoseconds since 1970 --> * 2001-12-07 23:31:45.862000002 <!-- The nanos from above but human readable --> * </rcvTimestamp> * <expiration lifeTime='1200'/> <!-- The overall life time of the message [milliseconds] --> * <route> * <node id='heron'/> * </route> * </qos> * </pre> * @author xmlBlaster@marcelruff.info */public final class GetReturnQos{ private String ME = "GetReturnQos"; private final Global glob; private static Logger log = Logger.getLogger(GetReturnQos.class.getName()); private final MsgQosData msgQosData; /** * Default constructor for transient messages. */ public GetReturnQos(Global glob, MsgQosData msgQosData) { this.glob = (glob==null) ? Global.instance() : glob; this.msgQosData = msgQosData; this.msgQosData.setMethod(MethodName.GET); } /** * Constructs the specialized quality of service object for a get() call. */ public GetReturnQos(Global glob, String xmlQos) throws XmlBlasterException { this(glob, glob.getMsgQosFactory().readObject(xmlQos)); } /** * Get the QoS data object which i'm hiding */ public MsgQosData getData() { return this.msgQosData; } /** * Access sender name. * @return loginName of sender */ public SessionName getSender() { return this.msgQosData.getSender(); } /** * Message priority. * @return priority 0-9 */ public PriorityEnum getPriority() { return this.msgQosData.getPriority(); } /** * Access state of message. * @return OK (Other values are not yet supported) */ public String getState() { return this.msgQosData.getState(); } /** * True if the message is OK */ public boolean isOk() { return this.msgQosData.isOk(); } /** * True if the message was erased by timer or by a * client invoking erase(). */ public boolean isErased() { return this.msgQosData.isErased(); } /** * Is this a volatile message? */ public boolean isVolatile() { return this.msgQosData.isVolatile(); } /** * Is this a persistent message? */ public boolean isPersistent() { return this.msgQosData.isPersistent(); } /** * Is this a readonly message? */ public boolean isReadonly() { return this.msgQosData.isReadonly(); } /** * True if a timeout on this message occurred. * <p /> * Timeouts are spanned by the publisher and thrown by xmlBlaster * on timeout to indicate for example * STALE messages or any other user problem domain specific event. */ public boolean isTimeout() { return this.msgQosData.isTimeout(); } /** * The approximate receive timestamp (UTC time), * when message was created - arrived at xmlBlaster server.<br /> * In nanoseconds elapsed since midnight, January 1, 1970 UTC */ public Timestamp getRcvTimestamp() { return this.msgQosData.getRcvTimestamp(); } /** * Human readable form of message receive time in xmlBlaster server, * in SQL representation e.g.:<br /> * 2001-12-07 23:31:45.862000004 */ public String getRcvTime() { return this.msgQosData.getRcvTimestamp().toString(); } /** * Approxiamte millis counted from now when message will be discarded * by xmlBlaster. * Calculated by xmlBlaster just before sending the get, so there * will be an offset (the time sending the message to us). * @return The time to live for this message or -1 (unlimited) if not known */ public long getRemainingLifeStatic() { return this.msgQosData.getRemainingLifeStatic(); } /** * @return never null, but may have length==0 */ public RouteInfo[] getRouteNodes() { return this.msgQosData.getRouteNodes(); } /** * Access all client properties. * @return a map The return is unordered and the map values are of type ClientProperty. * @see org.xmlBlaster.util.qos.ClientProperty */ public final Map getClientProperties() { return this.msgQosData.getClientProperties(); } /** * Read back a property. * @return The client property or null if not found */ public ClientProperty getClientProperty(String key) { return this.msgQosData.getClientProperty(key); } /** * Access the String client property. * @param name The property key * @param defaultValue The value to return if the property is not known */ public final String getClientProperty(String name, String defaultValue) { return this.msgQosData.getClientProperty(name, defaultValue); } /** * Access the integer client property. * @param name The property key * @param defaultValue The value to return if the property is not known */ public final int getClientProperty(String name, int defaultValue) { return this.msgQosData.getClientProperty(name, defaultValue); } /** * Access the boolean client property. * @param name The property key * @param defaultValue The value to return if the property is not known */ public final boolean getClientProperty(String name, boolean defaultValue) { return this.msgQosData.getClientProperty(name, defaultValue); } /** * Access the double client property. * @param name The property key * @param defaultValue The value to return if the property is not known */ public final double getClientProperty(String name, double defaultValue) { return this.msgQosData.getClientProperty(name, defaultValue); } /** * Access the float client property. * @param name The property key * @param defaultValue The value to return if the property is not known */ public final float getClientProperty(String name, float defaultValue) { return this.msgQosData.getClientProperty(name, defaultValue); } /** * Access the byte client property. * @param name The property key * @param defaultValue The value to return if the property is not known */ public final byte getClientProperty(String name, byte defaultValue) { return this.msgQosData.getClientProperty(name, defaultValue); } /** * Access the byte[] client property. * @param name The property key * @param defaultValue The value to return if the property is not known */ public final byte[] getClientProperty(String name, byte[] defaultValue) { return this.msgQosData.getClientProperty(name, defaultValue); } /** * Access the long client property. * @param name The property key * @param defaultValue The value to return if the property is not known */ public final long getClientProperty(String name, long defaultValue) { return this.msgQosData.getClientProperty(name, defaultValue); } /** * Access the short client property. * @param name The property key * @param defaultValue The value to return if the property is not known */ public final short getClientProperty(String name, short defaultValue) { return this.msgQosData.getClientProperty(name, defaultValue); } /** * Dump state of this object into a XML ASCII string. * <br> * @return internal state of the RequestBroker as a XML ASCII string */ public String toXml() { return toXml((String)null); } /** * Dump state of this object into a XML ASCII string. * <br> * @param extraOffset indenting of tags for nice output * @return internal state of the RequestBroker as a XML ASCII string */ public String toXml(String extraOffset) { return this.msgQosData.toXml(extraOffset); } public String toString() { return toXml(null); }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -