schangxiang@126.com
2025-09-09 3d8966ba2c81e7e0365c8b123e861d18ee4f94f5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
'use strict';
 
const assert = require('assert');
const is = require('is-type-of');
const cluster = require('./lib');
const symbols = require('./lib/symbol');
const APIClientBase = require('./lib/api_client');
 
/**
 * Create an Wrapper
 *
 * @param {Function} clientClass - client class
 * @param {Object} options - wrapper options
 * @return {ClientWrapper} wrapper
 */
module.exports = cluster;
 
/**
 * Close a ClusterClient
 *
 * @param {Object} client - ClusterClient instance to be closed
 * @return {Promise} returns a promise which will be resolved after fully closed
 */
module.exports.close = client => {
  assert(is.function(client[symbols.close]), '[cluster#close] client should be instanceof ClusterClient');
  return client[symbols.close]();
};
 
/**
 * API Client SuperClass
 *
 * @example
 * ---------------------------------------------
 * class ClusterClient extends APIClientBase {
 *   get DataClient() {
 *     return require('./supports/client');
 *   }
 *   get delegates() {
 *     return {
 *       unPublish: 'invokeOneway',
 *     };
 *   }
 *   get clusterOptions() {
 *     return {
 *       responseTimeout: 1000,
 *       port,
 *     };
 *   }
 *   subscribe(...args) {
 *     return this._client.subscribe(...args);
 *   }
 *   unSubscribe(...args) {
 *     return this._client.unSubscribe(...args);
 *   }
 *   publish(...args) {
 *     return this._client.publish(...args);
 *   }
 *   unPublish(...args) {
 *     return this._client.unPublish(...args);
 *   }
 *   close() {
 *     return this._client.close();
 *   }
 * }
 */
module.exports.APIClientBase = APIClientBase;