@webex/internal-plugin-presence 3.0.0-beta.9 → 3.0.0-bnr.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/presence.js CHANGED
@@ -1,40 +1,30 @@
1
1
  "use strict";
2
2
 
3
3
  var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
4
-
5
4
  var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
6
-
7
5
  _Object$defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
-
11
8
  exports.default = void 0;
12
-
13
9
  var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/toConsumableArray"));
14
-
15
10
  var _promise = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/promise"));
16
-
17
11
  var _isArray = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/array/is-array"));
18
-
19
12
  require("@webex/internal-plugin-device");
20
-
21
13
  var _webexCore = require("@webex/webex-core");
22
-
23
14
  var _presenceBatcher = _interopRequireDefault(require("./presence-batcher"));
24
-
25
15
  var _presenceWorker = _interopRequireDefault(require("./presence-worker"));
26
-
27
16
  /*!
28
17
  * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.
29
18
  */
19
+
30
20
  var defaultSubscriptionTtl = 600;
31
21
  var USER = 'user';
32
22
  var USER_PRESENCE_ENABLED = 'user-presence-enabled';
23
+
33
24
  /**
34
25
  * @class
35
26
  * @extends WebexPlugin
36
27
  */
37
-
38
28
  var Presence = _webexCore.WebexPlugin.extend({
39
29
  namespace: 'Presence',
40
30
  children: {
@@ -48,21 +38,18 @@ var Presence = _webexCore.WebexPlugin.extend({
48
38
  type: 'any'
49
39
  }
50
40
  },
51
-
52
41
  /**
53
42
  * Initialize the presence worker for client
54
43
  * @returns {undefined}
55
44
  */
56
45
  initialize: function initialize() {
57
46
  var _this = this;
58
-
59
47
  this.webex.once('ready', function () {
60
48
  if (_this.config.initializeWorker) {
61
49
  _this.worker.initialize(_this.webex);
62
50
  }
63
51
  });
64
52
  },
65
-
66
53
  /**
67
54
  * Trigger an event.
68
55
  * @param {string} event
@@ -74,7 +61,6 @@ var Presence = _webexCore.WebexPlugin.extend({
74
61
  this.trigger(event, payload);
75
62
  }
76
63
  },
77
-
78
64
  /**
79
65
  * Enables presence feature
80
66
  * @returns {Promise<boolean>} resolves with true, if successful
@@ -84,7 +70,6 @@ var Presence = _webexCore.WebexPlugin.extend({
84
70
  return response.value;
85
71
  });
86
72
  },
87
-
88
73
  /**
89
74
  * Disables presence feature
90
75
  * @returns {Promise<boolean>} resolves with false, if successful
@@ -94,7 +79,6 @@ var Presence = _webexCore.WebexPlugin.extend({
94
79
  return response.value;
95
80
  });
96
81
  },
97
-
98
82
  /**
99
83
  * Returns true if presence is enabled, false otherwise
100
84
  * @returns {Promise<boolean>} resolves with true if presence is enabled
@@ -102,7 +86,6 @@ var Presence = _webexCore.WebexPlugin.extend({
102
86
  isEnabled: function isEnabled() {
103
87
  return this.webex.internal.feature.getFeature(USER, USER_PRESENCE_ENABLED);
104
88
  },
105
-
106
89
  /**
107
90
  * The status object
108
91
  * @typedef {Object} PresenceStatusObject
@@ -122,7 +105,6 @@ var Presence = _webexCore.WebexPlugin.extend({
122
105
  * @property {string} lastSeenDeviceUrl: Resource Identifier of the last device to post presence activity for
123
106
  * this user.
124
107
  */
125
-
126
108
  /**
127
109
  * Gets the current presence status of a given person id
128
110
  * @param {string} personId
@@ -132,7 +114,6 @@ var Presence = _webexCore.WebexPlugin.extend({
132
114
  if (!personId) {
133
115
  return _promise.default.reject(new Error('A person id is required'));
134
116
  }
135
-
136
117
  return this.webex.request({
137
118
  method: 'GET',
138
119
  service: 'apheleia',
@@ -141,12 +122,10 @@ var Presence = _webexCore.WebexPlugin.extend({
141
122
  return response.body;
142
123
  });
143
124
  },
144
-
145
125
  /**
146
- * @typedef {Object} PresenceStatusesObject
147
- * @property {Array.<PresenceStatusObject>} statusList
126
+ * @typedef {Object} PresenceStatusesObject
127
+ * @property {Array.<PresenceStatusObject>} statusList
148
128
  */
149
-
150
129
  /**
151
130
  * Gets the current presence statuses of an array of people ids
152
131
  * @param {Array} personIds
@@ -154,11 +133,9 @@ var Presence = _webexCore.WebexPlugin.extend({
154
133
  */
155
134
  list: function list(personIds) {
156
135
  var _this2 = this;
157
-
158
136
  if (!personIds || !(0, _isArray.default)(personIds)) {
159
137
  return _promise.default.reject(new Error('An array of person ids is required'));
160
138
  }
161
-
162
139
  return _promise.default.all(personIds.map(function (id) {
163
140
  return _this2.batcher.request(id);
164
141
  })).then(function (presences) {
@@ -167,7 +144,6 @@ var Presence = _webexCore.WebexPlugin.extend({
167
144
  };
168
145
  });
169
146
  },
170
-
171
147
  /**
172
148
  * Subscribes to a person's presence status updates
173
149
  * Updates are sent via mercury events `apheleia.subscription_update`
@@ -177,27 +153,22 @@ var Presence = _webexCore.WebexPlugin.extend({
177
153
  */
178
154
  subscribe: function subscribe(personIds) {
179
155
  var _this3 = this;
180
-
181
156
  var subscriptionTtl = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultSubscriptionTtl;
182
157
  var subjects;
183
158
  var batches = [];
184
159
  var batchLimit = 50;
185
-
186
160
  if (!personIds) {
187
161
  return _promise.default.reject(new Error('A person id is required'));
188
162
  }
189
-
190
163
  if ((0, _isArray.default)(personIds)) {
191
164
  subjects = personIds;
192
165
  } else {
193
166
  subjects = [personIds];
194
- } // Limit batches to 50 ids per request
195
-
196
-
167
+ }
168
+ // Limit batches to 50 ids per request
197
169
  for (var i = 0; i < subjects.length; i += batchLimit) {
198
170
  batches.push(subjects.slice(i, i + batchLimit));
199
171
  }
200
-
201
172
  return _promise.default.all(batches.map(function (ids) {
202
173
  return _this3.webex.request({
203
174
  method: 'POST',
@@ -213,13 +184,11 @@ var Presence = _webexCore.WebexPlugin.extend({
213
184
  });
214
185
  })).then(function (idBatches) {
215
186
  var _ref;
216
-
217
187
  return {
218
188
  responses: (_ref = []).concat.apply(_ref, (0, _toConsumableArray2.default)(idBatches))
219
189
  };
220
190
  });
221
191
  },
222
-
223
192
  /**
224
193
  * Unsubscribes from a person or group of people's presence subscription
225
194
  * @param {string | Array} personIds
@@ -227,17 +196,14 @@ var Presence = _webexCore.WebexPlugin.extend({
227
196
  */
228
197
  unsubscribe: function unsubscribe(personIds) {
229
198
  var subjects;
230
-
231
199
  if (!personIds) {
232
200
  return _promise.default.reject(new Error('A person id is required'));
233
201
  }
234
-
235
202
  if ((0, _isArray.default)(personIds)) {
236
203
  subjects = personIds;
237
204
  } else {
238
205
  subjects = [personIds];
239
206
  }
240
-
241
207
  return this.webex.request({
242
208
  method: 'POST',
243
209
  api: 'apheleia',
@@ -249,7 +215,6 @@ var Presence = _webexCore.WebexPlugin.extend({
249
215
  }
250
216
  });
251
217
  },
252
-
253
218
  /**
254
219
  * Sets the status of the current user
255
220
  * @param {string} status - active | inactive | ooo | dnd
@@ -260,7 +225,6 @@ var Presence = _webexCore.WebexPlugin.extend({
260
225
  if (!status) {
261
226
  return _promise.default.reject(new Error('A status is required'));
262
227
  }
263
-
264
228
  return this.webex.request({
265
229
  method: 'POST',
266
230
  api: 'apheleia',
@@ -274,7 +238,6 @@ var Presence = _webexCore.WebexPlugin.extend({
274
238
  return response.body;
275
239
  });
276
240
  },
277
-
278
241
  /**
279
242
  * Retrieves and subscribes to a user's presence.
280
243
  * @param {string} id
@@ -283,7 +246,6 @@ var Presence = _webexCore.WebexPlugin.extend({
283
246
  enqueue: function enqueue(id) {
284
247
  return this.worker.enqueue(id);
285
248
  },
286
-
287
249
  /**
288
250
  * Retract from subscribing to a user's presence.
289
251
  * @param {string} id
@@ -292,9 +254,8 @@ var Presence = _webexCore.WebexPlugin.extend({
292
254
  dequeue: function dequeue(id) {
293
255
  return this.worker.dequeue(id);
294
256
  },
295
- version: "3.0.0-beta.9"
257
+ version: "3.0.0-bnr.2"
296
258
  });
297
-
298
259
  var _default2 = Presence;
299
260
  exports.default = _default2;
300
261
  //# sourceMappingURL=presence.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["defaultSubscriptionTtl","USER","USER_PRESENCE_ENABLED","Presence","WebexPlugin","extend","namespace","children","batcher","PresenceBatcher","session","worker","default","PresenceWorker","type","initialize","webex","once","config","initializeWorker","emitEvent","event","payload","trigger","enable","internal","feature","setFeature","then","response","value","disable","isEnabled","getFeature","get","personId","reject","Error","request","method","service","resource","body","list","personIds","all","map","id","presences","statusList","subscribe","subscriptionTtl","subjects","batches","batchLimit","i","length","push","slice","ids","api","includeStatus","responses","idBatches","concat","unsubscribe","setStatus","status","ttl","subject","device","userId","eventType","enqueue","dequeue"],"sources":["presence.js"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\n\nimport '@webex/internal-plugin-device';\n\nimport {WebexPlugin} from '@webex/webex-core';\n\nimport PresenceBatcher from './presence-batcher';\nimport PresenceWorker from './presence-worker';\n\nconst defaultSubscriptionTtl = 600;\nconst USER = 'user';\nconst USER_PRESENCE_ENABLED = 'user-presence-enabled';\n\n/**\n * @class\n * @extends WebexPlugin\n */\nconst Presence = WebexPlugin.extend({\n namespace: 'Presence',\n\n children: {\n batcher: PresenceBatcher\n },\n\n session: {\n worker: {\n default() {\n return new PresenceWorker();\n },\n type: 'any'\n }\n },\n\n /**\n * Initialize the presence worker for client\n * @returns {undefined}\n */\n initialize() {\n this.webex.once('ready', () => {\n if (this.config.initializeWorker) {\n this.worker.initialize(this.webex);\n }\n });\n },\n\n /**\n * Trigger an event.\n * @param {string} event\n * @param {string} payload\n * @returns {undefined}\n */\n emitEvent(event, payload) {\n if (payload.type && payload.payload) {\n this.trigger(event, payload);\n }\n },\n\n /**\n * Enables presence feature\n * @returns {Promise<boolean>} resolves with true, if successful\n */\n enable() {\n return this.webex.internal.feature.setFeature(USER, USER_PRESENCE_ENABLED, true)\n .then((response) => response.value);\n },\n\n /**\n * Disables presence feature\n * @returns {Promise<boolean>} resolves with false, if successful\n */\n disable() {\n return this.webex.internal.feature.setFeature(USER, USER_PRESENCE_ENABLED, false)\n .then((response) => response.value);\n },\n\n /**\n * Returns true if presence is enabled, false otherwise\n * @returns {Promise<boolean>} resolves with true if presence is enabled\n */\n isEnabled() {\n return this.webex.internal.feature.getFeature(USER, USER_PRESENCE_ENABLED);\n },\n\n /**\n * The status object\n * @typedef {Object} PresenceStatusObject\n * @property {string} url: Public resource identifier for presence\n * @property {string} subject: User ID for the user the returned composed presence represents\n * @property {string} status: Current composed presence state\n * @property {string} statusTime: DateTime in RFC3339 format that the current status began\n * @property {string} lastActive: DateTime in RFC3339 format that the service last saw activity from the user.\n * @property {string} expires: DEPRECATED - DateTime in RFC3339 format that represents when the current\n * status will expire. Will not exist if expiresTTL is -1.\n * @property {Number} expiresTTL: TTL in seconds until the status will expire. If TTL is -1 the current\n * status has no known expiration.\n * @property {string} expiresTime: DateTime in RFC3339 format that the current status will expire. Missing\n * field means no known expiration.\n * @property {Object} vectorCounters: Used for packet ordering and tracking.\n * @property {Boolean} suppressNotifications: Indicates if notification suppression is recommended for this status.\n * @property {string} lastSeenDeviceUrl: Resource Identifier of the last device to post presence activity for\n * this user.\n */\n\n /**\n * Gets the current presence status of a given person id\n * @param {string} personId\n * @returns {Promise<PresenceStatusObject>} resolves with status object of person\n */\n get(personId) {\n if (!personId) {\n return Promise.reject(new Error('A person id is required'));\n }\n\n return this.webex.request({\n method: 'GET',\n service: 'apheleia',\n resource: `compositions?userId=${personId}`\n })\n .then((response) => response.body);\n },\n\n /**\n * @typedef {Object} PresenceStatusesObject\n * @property {Array.<PresenceStatusObject>} statusList\n */\n /**\n * Gets the current presence statuses of an array of people ids\n * @param {Array} personIds\n * @returns {Promise<PresenceStatusesObject>} resolves with an object with key of `statusList` array\n */\n list(personIds) {\n if (!personIds || !Array.isArray(personIds)) {\n return Promise.reject(new Error('An array of person ids is required'));\n }\n\n return Promise.all(personIds.map((id) =>\n this.batcher.request(id)))\n .then((presences) => ({statusList: presences}));\n },\n\n /**\n * Subscribes to a person's presence status updates\n * Updates are sent via mercury events `apheleia.subscription_update`\n * @param {string | Array} personIds\n * @param {number} subscriptionTtl - Requested length of subscriptions in seconds.\n * @returns {Promise}\n */\n subscribe(personIds, subscriptionTtl = defaultSubscriptionTtl) {\n let subjects;\n const batches = [];\n const batchLimit = 50;\n\n if (!personIds) {\n return Promise.reject(new Error('A person id is required'));\n }\n if (Array.isArray(personIds)) {\n subjects = personIds;\n }\n else {\n subjects = [personIds];\n }\n // Limit batches to 50 ids per request\n for (let i = 0; i < subjects.length; i += batchLimit) {\n batches.push(subjects.slice(i, i + batchLimit));\n }\n\n return Promise.all(batches.map((ids) =>\n this.webex.request({\n method: 'POST',\n api: 'apheleia',\n resource: 'subscriptions',\n body: {\n subjects: ids,\n subscriptionTtl,\n includeStatus: true\n }\n })\n .then((response) => response.body.responses)))\n .then((idBatches) => ({responses: [].concat(...idBatches)}));\n },\n\n /**\n * Unsubscribes from a person or group of people's presence subscription\n * @param {string | Array} personIds\n * @returns {Promise}\n */\n unsubscribe(personIds) {\n let subjects;\n\n if (!personIds) {\n return Promise.reject(new Error('A person id is required'));\n }\n if (Array.isArray(personIds)) {\n subjects = personIds;\n }\n else {\n subjects = [personIds];\n }\n\n return this.webex.request({\n method: 'POST',\n api: 'apheleia',\n resource: 'subscriptions',\n body: {\n subjects,\n subscriptionTtl: 0,\n includeStatus: true\n }\n });\n },\n\n /**\n * Sets the status of the current user\n * @param {string} status - active | inactive | ooo | dnd\n * @param {number} ttl - Time To Live for the event in seconds.\n * @returns {Promise}\n */\n setStatus(status, ttl) {\n if (!status) {\n return Promise.reject(new Error('A status is required'));\n }\n\n return this.webex.request({\n method: 'POST',\n api: 'apheleia',\n resource: 'events',\n body: {\n subject: this.webex.internal.device.userId,\n eventType: status,\n ttl\n }\n })\n .then((response) => response.body);\n },\n\n /**\n * Retrieves and subscribes to a user's presence.\n * @param {string} id\n * @returns {undefined}\n */\n enqueue(id) {\n return this.worker.enqueue(id);\n },\n\n /**\n * Retract from subscribing to a user's presence.\n * @param {string} id\n * @returns {undefined}\n */\n dequeue(id) {\n return this.worker.dequeue(id);\n }\n});\n\nexport default Presence;\n"],"mappings":"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"}
1
+ {"version":3,"names":["defaultSubscriptionTtl","USER","USER_PRESENCE_ENABLED","Presence","WebexPlugin","extend","namespace","children","batcher","PresenceBatcher","session","worker","default","PresenceWorker","type","initialize","webex","once","config","initializeWorker","emitEvent","event","payload","trigger","enable","internal","feature","setFeature","then","response","value","disable","isEnabled","getFeature","get","personId","reject","Error","request","method","service","resource","body","list","personIds","all","map","id","presences","statusList","subscribe","subscriptionTtl","subjects","batches","batchLimit","i","length","push","slice","ids","api","includeStatus","responses","idBatches","concat","unsubscribe","setStatus","status","ttl","subject","device","userId","eventType","enqueue","dequeue"],"sources":["presence.js"],"sourcesContent":["/*!\n * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.\n */\n\nimport '@webex/internal-plugin-device';\n\nimport {WebexPlugin} from '@webex/webex-core';\n\nimport PresenceBatcher from './presence-batcher';\nimport PresenceWorker from './presence-worker';\n\nconst defaultSubscriptionTtl = 600;\nconst USER = 'user';\nconst USER_PRESENCE_ENABLED = 'user-presence-enabled';\n\n/**\n * @class\n * @extends WebexPlugin\n */\nconst Presence = WebexPlugin.extend({\n namespace: 'Presence',\n\n children: {\n batcher: PresenceBatcher,\n },\n\n session: {\n worker: {\n default() {\n return new PresenceWorker();\n },\n type: 'any',\n },\n },\n\n /**\n * Initialize the presence worker for client\n * @returns {undefined}\n */\n initialize() {\n this.webex.once('ready', () => {\n if (this.config.initializeWorker) {\n this.worker.initialize(this.webex);\n }\n });\n },\n\n /**\n * Trigger an event.\n * @param {string} event\n * @param {string} payload\n * @returns {undefined}\n */\n emitEvent(event, payload) {\n if (payload.type && payload.payload) {\n this.trigger(event, payload);\n }\n },\n\n /**\n * Enables presence feature\n * @returns {Promise<boolean>} resolves with true, if successful\n */\n enable() {\n return this.webex.internal.feature\n .setFeature(USER, USER_PRESENCE_ENABLED, true)\n .then((response) => response.value);\n },\n\n /**\n * Disables presence feature\n * @returns {Promise<boolean>} resolves with false, if successful\n */\n disable() {\n return this.webex.internal.feature\n .setFeature(USER, USER_PRESENCE_ENABLED, false)\n .then((response) => response.value);\n },\n\n /**\n * Returns true if presence is enabled, false otherwise\n * @returns {Promise<boolean>} resolves with true if presence is enabled\n */\n isEnabled() {\n return this.webex.internal.feature.getFeature(USER, USER_PRESENCE_ENABLED);\n },\n\n /**\n * The status object\n * @typedef {Object} PresenceStatusObject\n * @property {string} url: Public resource identifier for presence\n * @property {string} subject: User ID for the user the returned composed presence represents\n * @property {string} status: Current composed presence state\n * @property {string} statusTime: DateTime in RFC3339 format that the current status began\n * @property {string} lastActive: DateTime in RFC3339 format that the service last saw activity from the user.\n * @property {string} expires: DEPRECATED - DateTime in RFC3339 format that represents when the current\n * status will expire. Will not exist if expiresTTL is -1.\n * @property {Number} expiresTTL: TTL in seconds until the status will expire. If TTL is -1 the current\n * status has no known expiration.\n * @property {string} expiresTime: DateTime in RFC3339 format that the current status will expire. Missing\n * field means no known expiration.\n * @property {Object} vectorCounters: Used for packet ordering and tracking.\n * @property {Boolean} suppressNotifications: Indicates if notification suppression is recommended for this status.\n * @property {string} lastSeenDeviceUrl: Resource Identifier of the last device to post presence activity for\n * this user.\n */\n\n /**\n * Gets the current presence status of a given person id\n * @param {string} personId\n * @returns {Promise<PresenceStatusObject>} resolves with status object of person\n */\n get(personId) {\n if (!personId) {\n return Promise.reject(new Error('A person id is required'));\n }\n\n return this.webex\n .request({\n method: 'GET',\n service: 'apheleia',\n resource: `compositions?userId=${personId}`,\n })\n .then((response) => response.body);\n },\n\n /**\n * @typedef {Object} PresenceStatusesObject\n * @property {Array.<PresenceStatusObject>} statusList\n */\n /**\n * Gets the current presence statuses of an array of people ids\n * @param {Array} personIds\n * @returns {Promise<PresenceStatusesObject>} resolves with an object with key of `statusList` array\n */\n list(personIds) {\n if (!personIds || !Array.isArray(personIds)) {\n return Promise.reject(new Error('An array of person ids is required'));\n }\n\n return Promise.all(personIds.map((id) => this.batcher.request(id))).then((presences) => ({\n statusList: presences,\n }));\n },\n\n /**\n * Subscribes to a person's presence status updates\n * Updates are sent via mercury events `apheleia.subscription_update`\n * @param {string | Array} personIds\n * @param {number} subscriptionTtl - Requested length of subscriptions in seconds.\n * @returns {Promise}\n */\n subscribe(personIds, subscriptionTtl = defaultSubscriptionTtl) {\n let subjects;\n const batches = [];\n const batchLimit = 50;\n\n if (!personIds) {\n return Promise.reject(new Error('A person id is required'));\n }\n if (Array.isArray(personIds)) {\n subjects = personIds;\n } else {\n subjects = [personIds];\n }\n // Limit batches to 50 ids per request\n for (let i = 0; i < subjects.length; i += batchLimit) {\n batches.push(subjects.slice(i, i + batchLimit));\n }\n\n return Promise.all(\n batches.map((ids) =>\n this.webex\n .request({\n method: 'POST',\n api: 'apheleia',\n resource: 'subscriptions',\n body: {\n subjects: ids,\n subscriptionTtl,\n includeStatus: true,\n },\n })\n .then((response) => response.body.responses)\n )\n ).then((idBatches) => ({responses: [].concat(...idBatches)}));\n },\n\n /**\n * Unsubscribes from a person or group of people's presence subscription\n * @param {string | Array} personIds\n * @returns {Promise}\n */\n unsubscribe(personIds) {\n let subjects;\n\n if (!personIds) {\n return Promise.reject(new Error('A person id is required'));\n }\n if (Array.isArray(personIds)) {\n subjects = personIds;\n } else {\n subjects = [personIds];\n }\n\n return this.webex.request({\n method: 'POST',\n api: 'apheleia',\n resource: 'subscriptions',\n body: {\n subjects,\n subscriptionTtl: 0,\n includeStatus: true,\n },\n });\n },\n\n /**\n * Sets the status of the current user\n * @param {string} status - active | inactive | ooo | dnd\n * @param {number} ttl - Time To Live for the event in seconds.\n * @returns {Promise}\n */\n setStatus(status, ttl) {\n if (!status) {\n return Promise.reject(new Error('A status is required'));\n }\n\n return this.webex\n .request({\n method: 'POST',\n api: 'apheleia',\n resource: 'events',\n body: {\n subject: this.webex.internal.device.userId,\n eventType: status,\n ttl,\n },\n })\n .then((response) => response.body);\n },\n\n /**\n * Retrieves and subscribes to a user's presence.\n * @param {string} id\n * @returns {undefined}\n */\n enqueue(id) {\n return this.worker.enqueue(id);\n },\n\n /**\n * Retract from subscribing to a user's presence.\n * @param {string} id\n * @returns {undefined}\n */\n dequeue(id) {\n return this.worker.dequeue(id);\n },\n});\n\nexport default Presence;\n"],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ // This file is read by tools that parse documentation comments conforming to the TSDoc standard.
2
+ // It should be published with your NPM package. It should not be tracked by Git.
3
+ {
4
+ "tsdocVersion": "0.12",
5
+ "toolPackages": [
6
+ {
7
+ "packageName": "@microsoft/api-extractor",
8
+ "packageVersion": "7.34.4"
9
+ }
10
+ ]
11
+ }
@@ -0,0 +1,8 @@
1
+ declare namespace _default {
2
+ namespace presence {
3
+ const batcherWait: number;
4
+ const batcherMaxCalls: number;
5
+ const batcherMaxWait: number;
6
+ }
7
+ }
8
+ export default _default;
@@ -0,0 +1,14 @@
1
+ export const GROUNDSKEEPER_INTERVAL: number;
2
+ export const FETCH_DELAY: 300;
3
+ export const UPDATE_PRESENCE_DELAY: number;
4
+ export const EXPIRED_PRESENCE_TIME: number;
5
+ export const SUBSCRIPTION_DELAY: number;
6
+ export const PREMATURE_EXPIRATION_SUBSCRIPTION_TIME: number;
7
+ export const DEFAULT_SUBSCRIPTION_TTL: number;
8
+ export const APHELEIA_SUBSCRIPTION_UPDATE: "event:apheleia.subscription_update";
9
+ export const PRESENCE_UPDATE: "updated";
10
+ export namespace ENVELOPE_TYPE {
11
+ const SUBSCRIPTION: string;
12
+ const PRESENCE: string;
13
+ const DELETE: string;
14
+ }
@@ -0,0 +1 @@
1
+ export { default } from "./presence";
@@ -0,0 +1,6 @@
1
+ export default PresenceBatcher;
2
+ /**
3
+ * @class
4
+ * @ignore
5
+ */
6
+ declare const PresenceBatcher: any;
@@ -0,0 +1,68 @@
1
+ /**
2
+ * Presence Worker
3
+ * Manages fetches and subscriptions for presence
4
+ * @class
5
+ */
6
+ export default class PresenceWorker {
7
+ presences: {};
8
+ watchers: {};
9
+ fetchers: {};
10
+ flights: {};
11
+ campers: {};
12
+ subscribers: {};
13
+ /**
14
+ * Connect to the mercury for presence and starts worker.
15
+ * @param {object} webex
16
+ * @returns {undefined}
17
+ */
18
+ initialize(webex: object): undefined;
19
+ webex: any;
20
+ /**
21
+ * Trigger a subscription update event.
22
+ * @param {string} event
23
+ * @returns {undefined}
24
+ */
25
+ subscriptionUpdate(event: string): undefined;
26
+ /**
27
+ * Retrieves and subscribes to a user's presence.
28
+ * @param {string} id
29
+ * @returns {undefined}
30
+ */
31
+ enqueue(id: string): undefined;
32
+ /**
33
+ * Retract from subscribing to a user's presence.
34
+ * @param {string} id
35
+ * @returns {undefined}
36
+ */
37
+ dequeue(id: string): undefined;
38
+ /**
39
+ * Retrieve users' presences.
40
+ * @returns {undefined}
41
+ */
42
+ checkFetchers(): undefined;
43
+ debouncedFetch: import("lodash").DebouncedFunc<() => undefined>;
44
+ /**
45
+ * Determine if we should subscribe to users' presences.
46
+ * @returns {Array}: User ids to subscribe.
47
+ */
48
+ checkCampers(): any[];
49
+ /**
50
+ * Determine if we should re-subscribe or remove users' subscriptions.
51
+ * @returns {Array}: User ids to re-subscribe.
52
+ */
53
+ checkSubscriptions(): any[];
54
+ /**
55
+ * Remove expired presence objects.
56
+ * @returns {undefined}
57
+ */
58
+ cleanPresences(): undefined;
59
+ /**
60
+ * Execute chores on an interval.
61
+ * Checks if we should make new subscribe,
62
+ * checks if we should re-subscribe,
63
+ * removes expired subscriptions,
64
+ * removes expired presence objects.
65
+ * @returns {undefined}
66
+ */
67
+ groundskeeper(): undefined;
68
+ }
@@ -0,0 +1,6 @@
1
+ export default Presence;
2
+ /**
3
+ * @class
4
+ * @extends WebexPlugin
5
+ */
6
+ declare const Presence: any;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@webex/internal-plugin-presence",
3
- "version": "3.0.0-beta.9",
3
+ "version": "3.0.0-bnr.2",
4
4
  "description": "",
5
5
  "license": "MIT",
6
6
  "main": "dist/index.js",
@@ -23,14 +23,14 @@
23
23
  "sinon": "^9.2.4"
24
24
  },
25
25
  "dependencies": {
26
- "@webex/internal-plugin-device": "3.0.0-beta.9",
27
- "@webex/internal-plugin-mercury": "3.0.0-beta.9",
28
- "@webex/internal-plugin-presence": "3.0.0-beta.9",
29
- "@webex/test-helper-chai": "3.0.0-beta.9",
30
- "@webex/test-helper-mocha": "3.0.0-beta.9",
31
- "@webex/test-helper-mock-webex": "3.0.0-beta.9",
32
- "@webex/test-helper-test-users": "3.0.0-beta.9",
33
- "@webex/webex-core": "3.0.0-beta.9",
26
+ "@webex/internal-plugin-device": "3.0.0-bnr.2",
27
+ "@webex/internal-plugin-mercury": "3.0.0-bnr.2",
28
+ "@webex/internal-plugin-presence": "3.0.0-bnr.2",
29
+ "@webex/test-helper-chai": "3.0.0-bnr.2",
30
+ "@webex/test-helper-mocha": "3.0.0-bnr.2",
31
+ "@webex/test-helper-mock-webex": "3.0.0-bnr.2",
32
+ "@webex/test-helper-test-users": "3.0.0-bnr.2",
33
+ "@webex/webex-core": "3.0.0-bnr.2",
34
34
  "lodash": "^4.17.21"
35
35
  }
36
36
  }
package/src/config.js CHANGED
@@ -6,6 +6,6 @@ export default {
6
6
  presence: {
7
7
  batcherWait: 50,
8
8
  batcherMaxCalls: 50,
9
- batcherMaxWait: 150
10
- }
9
+ batcherMaxWait: 150,
10
+ },
11
11
  };
package/src/constants.js CHANGED
@@ -1,4 +1,3 @@
1
-
2
1
  export const GROUNDSKEEPER_INTERVAL = 20 * 1000; // 20 seconds in ms
3
2
 
4
3
  export const FETCH_DELAY = 300; // ms
@@ -10,12 +9,11 @@ export const SUBSCRIPTION_DELAY = 60 * 1000; // 1 minute in ms
10
9
  export const PREMATURE_EXPIRATION_SUBSCRIPTION_TIME = 60 * 1000; // 1 minute in ms
11
10
  export const DEFAULT_SUBSCRIPTION_TTL = 10 * 60 * 1000; // 10 minutes in ms
12
11
 
13
- export const APHELEIA_SUBSCRIPTION_UPDATE =
14
- 'event:apheleia.subscription_update';
12
+ export const APHELEIA_SUBSCRIPTION_UPDATE = 'event:apheleia.subscription_update';
15
13
  export const PRESENCE_UPDATE = 'updated';
16
14
 
17
15
  export const ENVELOPE_TYPE = {
18
16
  SUBSCRIPTION: 'subscription',
19
17
  PRESENCE: 'presence',
20
- DELETE: 'delete'
18
+ DELETE: 'delete',
21
19
  };
package/src/index.js CHANGED
@@ -22,8 +22,8 @@ registerInternalPlugin('presence', Presence, {
22
22
  },
23
23
  extract(response) {
24
24
  return Promise.resolve(response);
25
- }
26
- }
25
+ },
26
+ },
27
27
  ],
28
28
  transforms: [
29
29
  {
@@ -31,11 +31,11 @@ registerInternalPlugin('presence', Presence, {
31
31
  direction: 'inbound',
32
32
  fn(ctx, response) {
33
33
  response.body.status = response.body.eventType;
34
- }
35
- }
36
- ]
34
+ },
35
+ },
36
+ ],
37
37
  },
38
- config
38
+ config,
39
39
  });
40
40
 
41
41
  export {default} from './presence';
@@ -18,8 +18,11 @@ const PresenceBatcher = Batcher.extend({
18
18
  * @returns {Promise}
19
19
  */
20
20
  handleHttpSuccess(res) {
21
- return Promise.all(res.body.statusList.map((presenceResponse) =>
22
- this.handleItemSuccess(presenceResponse.subject, presenceResponse)));
21
+ return Promise.all(
22
+ res.body.statusList.map((presenceResponse) =>
23
+ this.handleItemSuccess(presenceResponse.subject, presenceResponse)
24
+ )
25
+ );
23
26
  },
24
27
 
25
28
  /**
@@ -30,10 +33,9 @@ const PresenceBatcher = Batcher.extend({
30
33
  * @returns {Promise}
31
34
  */
32
35
  handleItemFailure(item, response) {
33
- return this.getDeferredForResponse(item)
34
- .then((defer) => {
35
- defer.reject(response);
36
- });
36
+ return this.getDeferredForResponse(item).then((defer) => {
37
+ defer.reject(response);
38
+ });
37
39
  },
38
40
 
39
41
  /**
@@ -44,10 +46,9 @@ const PresenceBatcher = Batcher.extend({
44
46
  * @returns {Promise}
45
47
  */
46
48
  handleItemSuccess(item, response) {
47
- return this.getDeferredForResponse(item)
48
- .then((defer) => {
49
- defer.resolve(response);
50
- });
49
+ return this.getDeferredForResponse(item).then((defer) => {
50
+ defer.resolve(response);
51
+ });
51
52
  },
52
53
 
53
54
  /**
@@ -91,9 +92,9 @@ const PresenceBatcher = Batcher.extend({
91
92
  method: 'POST',
92
93
  api: 'apheleia',
93
94
  resource: 'compositions',
94
- body: {subjects}
95
+ body: {subjects},
95
96
  });
96
- }
97
+ },
97
98
  });
98
99
 
99
100
  export default PresenceBatcher;