本文翻译自 – http://www.tigase.org/content/basic-information
下面是当你需要创建一个新的Component所需要关注的接口列表:
- tigase.server.ServerComponent – 这是一个非常基本的component接口。所有的component都必须实现接口中定义的方法。
/** * Interface ServerComponent * 这种类型的对象可以被MessageRouter管理. * 所有被MessageRouter加载的类必须要实现这个接口。 */ public interface ServerComponent { void setName(String name); String getName(); JID getComponentId(); void release(); /** * processPacket是所有components都必须实现的阻塞性方法. * 这个方法处理packet并且不等待任何资源立即返回results * */ void processPacket(Packet packet, Queue results); void initializationCompleted(); }
- tigase.server.MessageReceiver – 这个接口extends ServerComponent,所有希望接收数据packets的Component都需要实现接口中定义的方法,比如session manager和c2s connection manager。
/** * Interface MessageReceiver * 这种类型的对象可以接收消息,它们事实上也可以根据最终地址进行消息路由。 * 消息在MessageRouter类中被路由到正确的目的地。 */ public interface MessageReceiver extends ServerComponent { /** * 这里缺少方法表述 * * @param packet a Packet value * @return 如果packet被成功添加了,返回true。否则否则返回false */ boolean addPacket(Packet packet); boolean addPacketNB(Packet packet); boolean addPackets(Queue packets); BareJID getDefHostName(); boolean isInRegexRoutings(String address); void setParent(MessageReceiver msg_rec); void start();}
- tigase.conf.Configurable – 如果希望components可以被配置,则需要实现这个接口。在运行时,配置信息会被推送到这种类型的对象。components必须能够在运行时对变更的配置项进行处理,这一点在实现时要留神。
/** * Interface Configurable * * 实现这个接口的对象实例对象是可配置的。 在Tigase系统中组件是不能够请求配置信息的。 * 配置信息是可以在任何时候被推送到组件。这种方式提供了运行时的动态配置机制。 */ public interface Configurable extends ServerComponent { /** * 常量 GEN_CONFIG 是所有配置类型的前缀. */ public static final String GEN_CONFIG = "--gen-config"; /** * 常量 GEN_CONFIG_ALL 是所有直接被服务加载的components配置类型的参数名. */ public static final String GEN_CONFIG_ALL = GEN_CONFIG + "-all"; /** * 常量 GEN_CONFIG_SM 是session manager的配置信息参数名, * 也是 会预先配置并连接到 “具有ClientConnectionMananger的服务实例” * XEP-0114 component的配置信息参数名。 */ public static final String GEN_CONFIG_SM = GEN_CONFIG + "-sm"; /** * 常量 GEN_CONFIG_CS 是 ClientConnectionManager 的配置信息参数名。 * 也是 会预先配置并连接到 “具有SessionManager的服务实例” * 的XEP-0114 component的配置信息参数名。 */ public static final String GEN_CONFIG_CS = GEN_CONFIG + "-cs"; /** * 常量 GEN_CONFIG_DEF 是 SessionManager,ClientConnectionManager * 和ServerConnectionManager的常用配置想参数名。 */ public static final String GEN_CONFIG_DEF = GEN_CONFIG + "-default"; public static final String GEN_CONFIG_COMP = GEN_CONFIG + "-comp"; /** * 常量 CLUSTER_MODE 设置集群工作状态,true 或 false * 默认状态下 CLUSTER_MODE 为 false */ public static final String CLUSTER_MODE = "--cluster-mode"; /** * 常量 CLUSTER_NODES 用来设置集群中的节点列表 */ public static final String CLUSTER_NODES = "--cluster-nodes"; /** Field description */ public static final String CLUSTER_LISTEN = "cluster-listen"; /** Field description */ public static final String CLUSTER_CONECT = "cluster-connect"; /** Field description */ public static final String GEN_CONF = "--gen-"; /** Field description */ public static final String GEN_TEST = "--test"; /** Field description */ public static final String GEN_COMP_NAME = "--comp-name"; /** Field description */ public static final String GEN_COMP_CLASS = "--comp-class"; /** Field description */ public static final String GEN_EXT_COMP = "--ext-comp"; /** Field description */ public static final String GEN_USER_DB = "--user-db"; /** Field description */ public static final String USER_REPO_POOL_CLASS = "--user-repo-pool"; /** Field description */ public static final String USER_DOMAIN_POOL_CLASS = "--user-domain-repo-pool"; /** Field description */ public static final String GEN_AUTH_DB = "--auth-db"; /** Field description */ public static final String AUTH_REPO_POOL_CLASS = "--auth-repo-pool"; /** Field description */ public static final String AUTH_DOMAIN_POOL_CLASS = "--auth-domain-repo-pool"; /** Field description */ public static final String GEN_USER_DB_URI_PROP_KEY = "user-db-uri"; /** Field description */ public static final String GEN_USER_DB_URI = "--" + GEN_USER_DB_URI_PROP_KEY; /** Field description */ public static final String GEN_AUTH_DB_URI = "--auth-db-uri"; /** Field description */ public static final String GEN_ADMINS = "--admins"; /** Field description */ public static final String GEN_TRUSTED = "--trusted"; /** Field description */ public static final String GEN_VIRT_HOSTS = "--virt-hosts"; /** Field description */ public static final String GEN_SM_PLUGINS = "--sm-plugins"; /** Field description */ public static final String GEN_DEBUG = "--debug"; /** Field description */ public static final String GEN_DEBUG_PACKAGES = "--debug-packages"; /** Field description */ public static final String GEN_MAX_QUEUE_SIZE = "--max-queue-size"; /** Field description */ public static final String GEN_SCRIPT_DIR = "--script-dir"; /** Field description */ public static final String GEN_SREC_DB = "--gen-srec-db"; /** Field description */ public static final String GEN_SREC_DB_URI = "--gen-srec-db-uri"; /** Field description */ public static final String GEN_SREC_ADMINS = "--gen-srec-admins"; /** Field description */ public static final String MONITORING = "--monitoring"; /** Field description */ public static final String USER_REPO_POOL_SIZE = "--user-repo-pool-size"; /** Field description */ public static final String STRINGPREP_PROCESSOR = "--stringprep-processor"; /** Field description */ public static final String XML_REPO_CLASS_PROP_VAL = "tigase.db.xml.XMLRepository"; /** Field description */ public static final String MYSQL_REPO_CLASS_PROP_VAL = "tigase.db.jdbc.JDBCRepository"; /** Field description */ public static final String DERBY_REPO_CLASS_PROP_VAL = "tigase.db.jdbc.JDBCRepository"; /** Field description */ public static final String PGSQL_REPO_CLASS_PROP_VAL = "tigase.db.jdbc.JDBCRepository"; /** Field description */ public static final String TIGASE_AUTH_REPO_CLASS_PROP_VAL = "tigase.db.jdbc.TigaseAuth"; /** Field description */ public static final String TIGASE_CUSTOM_AUTH_REPO_CLASS_PROP_VAL = "tigase.db.jdbc.TigaseCustomAuth"; /** Field description */ public static final String DRUPALWP_REPO_CLASS_PROP_VAL = "tigase.db.jdbc.DrupalWPAuth"; /** Field description */ public static final String LIBRESOURCE_REPO_CLASS_PROP_VAL = "tigase.db.jdbc.LibreSourceAuth"; /** Field description */ public static final String SHARED_USER_REPO_PROP_KEY = "shared-user-repo"; /** Field description */ public static final String SHARED_USER_REPO_PARAMS_PROP_KEY = "shared-user-repo-params"; /** Field description */ public static final String SHARED_AUTH_REPO_PROP_KEY = "shared-auth-repo"; /** Field description */ public static final String SHARED_AUTH_REPO_PARAMS_PROP_KEY = "shared-auth-repo-params"; /** Field description */ public static final String XML_REPO_URL_PROP_VAL = "user-repository.xml"; /** Field description */ public static final String MYSQL_REPO_URL_PROP_VAL ="jdbc:mysql://localhost/tigase?user=root&password=mypass"; /** Field description */ public static final String DERBY_REPO_URL_PROP_VAL = "jdbc:derby:tigase-derbydb;create=true"; /** Field description */ public static final String PGSQL_REPO_URL_PROP_VAL = "jdbc:postgresql://localhost/tigase?user=tigase"; /** Field description */ public static final String TIGASE_AUTH_REPO_URL_PROP_VAL = "jdbc:mysql://localhost/tigasedb?user=tigase_user&password=mypass"; /** Field description */ public static final String DRUPAL_REPO_URL_PROP_VAL = "jdbc:mysql://localhost/drupal?user=root&password=mypass"; /** Field description */ public static final String LIBRESOURCE_REPO_URL_PROP_VAL = "jdbc:postgresql://localhost/libresource?user=demo"; /** Field description */ public static final String DEF_SM_NAME = "sess-man"; /** Field description */ public static final String DEF_MONITOR_NAME = "monitor"; /** Field description */ public static final String DEF_C2S_NAME = "c2s"; /** Field description */ public static final String DEF_S2S_NAME = "s2s"; /** Field description */ public static final String DEF_EXT_COMP_NAME = "ext-comp"; /** Field description */ public static final String DEF_COMP_PROT_NAME = "ext"; /** Field description */ public static final String DEF_CL_COMP_NAME = "cl-comp"; /** Field description */ public static final String DEF_SSEND_NAME = "ssend"; /** Field description */ public static final String DEF_SRECV_NAME = "srecv"; /** Field description */ public static final String DEF_BOSH_NAME = "bosh"; /** Field description */ public static final String DEF_STATS_NAME = "stats"; /** Field description */ public static final String DEF_CLUST_CONTR_NAME = "cluster-contr"; /** Field description */ public static final String DEF_VHOST_MAN_NAME = "vhost-man"; /** Field description */ public static final String ROUTER_COMP_CLASS_NAME = "tigase.server.MessageRouter"; /** Field description */ public static final String C2S_COMP_CLASS_NAME = "tigase.server.xmppclient.ClientConnectionManager"; /** Field description */ public static final String C2S_CLUST_COMP_CLASS_NAME = "tigase.cluster.ClientConnectionClustered"; /** Field description */ public static final String S2S_COMP_CLASS_NAME = "tigase.server.xmppserver.S2SConnectionManager"; /** Field description */ public static final String S2S_CLUST_COMP_CLASS_NAME = "tigase.cluster.S2SConnectionClustered"; /** Field description */ public static final String SM_COMP_CLASS_NAME = "tigase.server.xmppsession.SessionManager"; /** Field description */ public static final String SM_CLUST_COMP_CLASS_NAME = "tigase.cluster.SessionManagerClustered"; /** Field description */ public static final String EXT_COMP_CLASS_NAME = "tigase.server.xmppcomponent.ComponentConnectionManager"; /** Field description */ public static final String MONITOR_CLASS_NAME = "tigase.server.monitor.MonitorComponent"; /** Field description */ public static final String MONITOR_CLUST_CLASS_NAME = "tigase.server.monitor.MonitorClustered"; /** Field description */ public static final String COMP_PROT_CLASS_NAME = "tigase.server.ext.ComponentProtocol"; /** Field description */ public static final String CL_COMP_CLASS_NAME = "tigase.cluster.ClusterConnectionManager"; /** Field description */ public static final String SSEND_COMP_CLASS_NAME = "tigase.server.ssender.StanzaSender"; /** Field description */ public static final String SRECV_COMP_CLASS_NAME = "tigase.server.sreceiver.StanzaReceiver"; /** Field description */ public static final String BOSH_COMP_CLASS_NAME = "tigase.server.bosh.BoshConnectionManager"; /** Field description */ public static final String STATS_CLASS_NAME = "tigase.stats.StatisticsCollector"; /** Field description */ public static final String CLUSTER_CONTR_CLASS_NAME = "tigase.cluster.ClusterController"; /** Field description */ public static final String VHOST_MAN_CLASS_NAME = "tigase.vhosts.VHostManager"; /** Field description */ public static final String USER_REPO_URL_PROP_KEY = "user-repo-url"; /** Field description */ public static final String USER_REPO_PARAMS_NODE = "user-repo-params"; /** Field description */ public static final String USER_REPO_POOL_SIZE_PROP_KEY = "user-repo-pool-size"; /** Field description */ public static final String USER_REPO_DOMAINS_PROP_KEY = "user-repo-domains"; /** Field description */ public static final String AUTH_REPO_DOMAINS_PROP_KEY = "auth-repo-domains"; /** Field description */ public static final String AUTH_REPO_URL_PROP_KEY = "auth-repo-url"; /** Field description */ public static final String AUTH_REPO_PARAMS_NODE = "auth-repo-params"; /** Field description */ public static final String HOSTNAMES_PROP_KEY = "hostnames"; /** Field description */ public static final String ADMINS_PROP_KEY = "admins"; /** Field description */ public static final String TRUSTED_PROP_KEY = "trusted"; /** Field description */ public static final String DEF_HOSTNAME_PROP_KEY = "def-hostname"; /** Field description */ public static final String COMPONENT_ID_PROP_KEY = "component-id"; /** Field description */ public static final String CLUSTER_NODES_PROP_KEY = "cluster-nodes"; //~--- get methods ---------------------------------------------------------- /** * 返回对象的默认配置信息 * @param params * @return */ Map getDefaults(Map params); //~--- set methods ---------------------------------------------------------- /** * 批量设置配置信息 * @param properties */ void setProperties(Map properties); }
- tigase.disco.XMPPService – 实现了这个对象的类可以对“ServiceDiscovery”请求做出响应。
/** * Interface XMPPService * <p/> * 实现了这个接口的对象可以对“ServiceDiscovery”请求做出应答。 * ManagerRouter管理所有的“ServiceDiscovery”请求 */ public interface XMPPService extends ServerComponent { /** * 一个方便的服务发现信息xmlns字符串常量 */ public static final String INFO_XMLNS = "http://jabber.org/protocol/disco#info"; /** * 一个方便的服务发现对象xmlns字符串常量 */ public static final String ITEMS_XMLNS = "http://jabber.org/protocol/disco#items"; /** * 一个方便的服务发现 二进制流特性 常量 */ public static final String[] DEF_FEATURES = {INFO_XMLNS, ITEMS_XMLNS}; /** * A convenience constant with component features related to ad-hoc commands. */ public static final String[] CMD_FEATURES = { "http://jabber.org/protocol/commands", "jabber:x:data"}; /** * 为component返回服务发现信息。如果jid是null,那么返回top level的服务发现信息。 * SessionMananger可以返回top level的服务发现信息,其他component不行。 * * @param node 服务发现的对象节点,如果是null,则返回top level的服务发现信息 * @param jid 服务发现请求的接收者,“被询问人” * @param from 服务发现请求的发出者. “询问人”。一些服务发现信息仅能提供给系统管理器 * @return returns 一个 XML 元素格式的服务发现数据 */ Element getDiscoInfo(String node, JID jid, JID from); /** * 为component返回服务发现对象。 如果jid是空,则返回top level的服务发现对象, * SessionMananger可以返回top level的服务发现对象,其他component则返回null。 * * @param node 服务发现的对象节点 * @param jid 服务发现请求的接收者,“被询问人” * @param from 服务发现请求的发出者. “询问人”。一些服务发现对象仅能提供给系统管理器 * @return 一个服务发现对象的列表,对于top level请求,返回component自己的服务发现对象 */ List<Element> getDiscoItems(String node, JID jid, JID from); /** * 获取top level的服务发现特性 * * @param from 请求发出者的地址。 一些服务发现特性仅能返回给系统管理器, * 所以component需要检查请求的发起者是不是系统管理器,并返回响应的内容。 * @return 服务发现特性列表 */ List<Element> getDiscoFeatures(JID from); }
- tigase.stats.StatisticsContainer – 实现了这个对象的类可以返回运行时的统计信息。任何一个对象都可以实现这个接口用来收集统计信息
public interface StatisticsContainer extends ServerComponent { public void getStatistics(StatisticsList list); }