tigase component (一)

本文翻译自 – http://www.tigase.org/content/basic-information
下面是当你需要创建一个新的Component所需要关注的接口列表:

  1. 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();
    }
  2. 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();}
  3. 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);
    }
  4. 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);
    
    }
  5. tigase.stats.StatisticsContainer – 实现了这个对象的类可以返回运行时的统计信息。任何一个对象都可以实现这个接口用来收集统计信息
    public interface StatisticsContainer extends ServerComponent {
        public void getStatistics(StatisticsList list);
    }

你可能感兴趣的:(tigase)