Skip to content

Commit 6a9fa7d

Browse files
authored
Add membership type field (#426)
feat(app-context): add membership type field Add `type` field for members and membership objects and subscribe response. fix(app-context): fix type which limited options setting membership Fixed type, which limited number of options which can be included into response / used in sorting for members / membership setting API. fix(presence): fix missing presence event flag Fix missing `hereNowRefresh` flag from the presence object received from subscribe. refactor(logging): change format and add proper request body output * fix(logger): for logger for Node.js Fix issue because of which `logVerbosity` set to `true` still didn't print logs for Node.js.
1 parent d9af3ec commit 6a9fa7d

File tree

32 files changed

+796
-186
lines changed

32 files changed

+796
-186
lines changed

.pubnub.yml

Lines changed: 16 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,18 @@
11
---
22
changelog:
3+
- date: 2024-12-17
4+
version: v8.4.0
5+
changes:
6+
- type: feature
7+
text: "Add `type` field for members and membership objects and subscribe response."
8+
- type: bug
9+
text: "Fixed type which limited number of options which can be included into response / used in sorting for members / membership setting API."
10+
- type: bug
11+
text: "Fix missing `hereNowRefresh` flag from the presence object received from subscribe."
12+
- type: bug
13+
text: "Fix issue because of which `logVerbosity` set to `true` still didn't print logs for Node.js."
14+
- type: improvement
15+
text: "Change format and add proper request body output."
316
- date: 2024-12-12
417
version: v8.3.2
518
changes:
@@ -1081,7 +1094,7 @@ supported-platforms:
10811094
- 'Ubuntu 14.04 and up'
10821095
- 'Windows 7 and up'
10831096
version: 'Pubnub Javascript for Node'
1084-
version: '8.3.2'
1097+
version: '8.4.0'
10851098
sdks:
10861099
- full-name: PubNub Javascript SDK
10871100
short-name: Javascript
@@ -1097,7 +1110,7 @@ sdks:
10971110
- distribution-type: source
10981111
distribution-repository: GitHub release
10991112
package-name: pubnub.js
1100-
location: https://github.com/pubnub/javascript/archive/refs/tags/v8.3.2.zip
1113+
location: https://github.com/pubnub/javascript/archive/refs/tags/v8.4.0.zip
11011114
requires:
11021115
- name: 'agentkeepalive'
11031116
min-version: '3.5.2'
@@ -1768,7 +1781,7 @@ sdks:
17681781
- distribution-type: library
17691782
distribution-repository: GitHub release
17701783
package-name: pubnub.js
1771-
location: https://github.com/pubnub/javascript/releases/download/v8.3.2/pubnub.8.3.2.js
1784+
location: https://github.com/pubnub/javascript/releases/download/v8.4.0/pubnub.8.4.0.js
17721785
requires:
17731786
- name: 'agentkeepalive'
17741787
min-version: '3.5.2'

CHANGELOG.md

Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,17 @@
1+
## v8.4.0
2+
December 17 2024
3+
4+
#### Added
5+
- Add `type` field for members and membership objects and subscribe response.
6+
7+
#### Fixed
8+
- Fixed type which limited number of options which can be included into response / used in sorting for members / membership setting API.
9+
- Fix missing `hereNowRefresh` flag from the presence object received from subscribe.
10+
- Fix issue because of which `logVerbosity` set to `true` still didn't print logs for Node.js.
11+
12+
#### Modified
13+
- Change format and add proper request body output.
14+
115
## v8.3.2
216
December 12 2024
317

README.md

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -28,8 +28,8 @@ Watch [Getting Started with PubNub JS SDK](https://app.dashcam.io/replay/64ee0d2
2828
npm install pubnub
2929
```
3030
* or download one of our builds from our CDN:
31-
* https://cdn.pubnub.com/sdk/javascript/pubnub.8.3.2.js
32-
* https://cdn.pubnub.com/sdk/javascript/pubnub.8.3.2.min.js
31+
* https://cdn.pubnub.com/sdk/javascript/pubnub.8.4.0.js
32+
* https://cdn.pubnub.com/sdk/javascript/pubnub.8.4.0.min.js
3333
3434
2. Configure your keys:
3535

dist/web/pubnub.js

Lines changed: 143 additions & 56 deletions
Large diffs are not rendered by default.

dist/web/pubnub.min.js

Lines changed: 2 additions & 2 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

lib/core/components/configuration.js

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -112,7 +112,7 @@ const makeConfiguration = (base, setupCryptoModule) => {
112112
return base.PubNubFile;
113113
},
114114
get version() {
115-
return '8.3.2';
115+
return '8.4.0';
116116
},
117117
getVersion() {
118118
return this.version;

lib/core/endpoints/objects/member/get.js

Lines changed: 18 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -32,9 +32,13 @@ const utils_1 = require("../../../utils");
3232
*/
3333
const INCLUDE_CUSTOM_FIELDS = false;
3434
/**
35-
* Whether member's status field should be included in response or not.
35+
* Whether member's `status` field should be included in response or not.
3636
*/
3737
const INCLUDE_STATUS = false;
38+
/**
39+
* Whether member's `type` field should be included in response or not.
40+
*/
41+
const INCLUDE_TYPE = false;
3842
/**
3943
* Whether total number of members should be included in response or not.
4044
*/
@@ -67,20 +71,21 @@ const LIMIT = 100;
6771
*/
6872
class GetChannelMembersRequest extends request_1.AbstractRequest {
6973
constructor(parameters) {
70-
var _a, _b, _c, _d, _e, _f, _g, _h, _j;
71-
var _k, _l, _m, _o, _p, _q, _r;
74+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
75+
var _l, _m, _o, _p, _q, _r, _s, _t;
7276
super();
7377
this.parameters = parameters;
7478
// Apply default request parameters.
7579
(_a = parameters.include) !== null && _a !== void 0 ? _a : (parameters.include = {});
76-
(_b = (_k = parameters.include).customFields) !== null && _b !== void 0 ? _b : (_k.customFields = INCLUDE_CUSTOM_FIELDS);
77-
(_c = (_l = parameters.include).totalCount) !== null && _c !== void 0 ? _c : (_l.totalCount = INCLUDE_TOTAL_COUNT);
78-
(_d = (_m = parameters.include).statusField) !== null && _d !== void 0 ? _d : (_m.statusField = INCLUDE_STATUS);
79-
(_e = (_o = parameters.include).UUIDFields) !== null && _e !== void 0 ? _e : (_o.UUIDFields = INCLUDE_UUID_FIELDS);
80-
(_f = (_p = parameters.include).customUUIDFields) !== null && _f !== void 0 ? _f : (_p.customUUIDFields = INCLUDE_UUID_CUSTOM_FIELDS);
81-
(_g = (_q = parameters.include).UUIDStatusField) !== null && _g !== void 0 ? _g : (_q.UUIDStatusField = INCLUDE_UUID_STATUS_FIELD);
82-
(_h = (_r = parameters.include).UUIDTypeField) !== null && _h !== void 0 ? _h : (_r.UUIDTypeField = INCLUDE_UUID_TYPE_FIELD);
83-
(_j = parameters.limit) !== null && _j !== void 0 ? _j : (parameters.limit = LIMIT);
80+
(_b = (_l = parameters.include).customFields) !== null && _b !== void 0 ? _b : (_l.customFields = INCLUDE_CUSTOM_FIELDS);
81+
(_c = (_m = parameters.include).totalCount) !== null && _c !== void 0 ? _c : (_m.totalCount = INCLUDE_TOTAL_COUNT);
82+
(_d = (_o = parameters.include).statusField) !== null && _d !== void 0 ? _d : (_o.statusField = INCLUDE_STATUS);
83+
(_e = (_p = parameters.include).typeField) !== null && _e !== void 0 ? _e : (_p.typeField = INCLUDE_TYPE);
84+
(_f = (_q = parameters.include).UUIDFields) !== null && _f !== void 0 ? _f : (_q.UUIDFields = INCLUDE_UUID_FIELDS);
85+
(_g = (_r = parameters.include).customUUIDFields) !== null && _g !== void 0 ? _g : (_r.customUUIDFields = INCLUDE_UUID_CUSTOM_FIELDS);
86+
(_h = (_s = parameters.include).UUIDStatusField) !== null && _h !== void 0 ? _h : (_s.UUIDStatusField = INCLUDE_UUID_STATUS_FIELD);
87+
(_j = (_t = parameters.include).UUIDTypeField) !== null && _j !== void 0 ? _j : (_t.UUIDTypeField = INCLUDE_UUID_TYPE_FIELD);
88+
(_k = parameters.limit) !== null && _k !== void 0 ? _k : (parameters.limit = LIMIT);
8489
}
8590
operation() {
8691
return operations_1.default.PNSetMembersOperation;
@@ -114,6 +119,8 @@ class GetChannelMembersRequest extends request_1.AbstractRequest {
114119
const includeFlags = [];
115120
if (include.statusField)
116121
includeFlags.push('status');
122+
if (include.typeField)
123+
includeFlags.push('type');
117124
if (include.customFields)
118125
includeFlags.push('custom');
119126
if (include.UUIDFields)

lib/core/endpoints/objects/member/set.js

Lines changed: 36 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -32,6 +32,14 @@ const utils_1 = require("../../../utils");
3232
* Whether `Member` custom field should be included in response or not.
3333
*/
3434
const INCLUDE_CUSTOM_FIELDS = false;
35+
/**
36+
* Whether member's `status` field should be included in response or not.
37+
*/
38+
const INCLUDE_STATUS = false;
39+
/**
40+
* Whether member's `type` field should be included in response or not.
41+
*/
42+
const INCLUDE_TYPE = false;
3543
/**
3644
* Whether total number of members should be included in response or not.
3745
*/
@@ -40,6 +48,14 @@ const INCLUDE_TOTAL_COUNT = false;
4048
* Whether `UUID` fields should be included in response or not.
4149
*/
4250
const INCLUDE_UUID_FIELDS = false;
51+
/**
52+
* Whether `UUID` status field should be included in response or not.
53+
*/
54+
const INCLUDE_UUID_STATUS_FIELD = false;
55+
/**
56+
* Whether `UUID` type field should be included in response or not.
57+
*/
58+
const INCLUDE_UUID_TYPE_FIELD = false;
4359
/**
4460
* Whether `UUID` custom field should be included in response or not.
4561
*/
@@ -56,17 +72,21 @@ const LIMIT = 100;
5672
*/
5773
class SetChannelMembersRequest extends request_1.AbstractRequest {
5874
constructor(parameters) {
59-
var _a, _b, _c, _d, _e, _f;
60-
var _g, _h, _j, _k;
75+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
76+
var _l, _m, _o, _p, _q, _r, _s, _t;
6177
super({ method: transport_request_1.TransportMethod.PATCH });
6278
this.parameters = parameters;
6379
// Apply default request parameters.
6480
(_a = parameters.include) !== null && _a !== void 0 ? _a : (parameters.include = {});
65-
(_b = (_g = parameters.include).customFields) !== null && _b !== void 0 ? _b : (_g.customFields = INCLUDE_CUSTOM_FIELDS);
66-
(_c = (_h = parameters.include).totalCount) !== null && _c !== void 0 ? _c : (_h.totalCount = INCLUDE_TOTAL_COUNT);
67-
(_d = (_j = parameters.include).UUIDFields) !== null && _d !== void 0 ? _d : (_j.UUIDFields = INCLUDE_UUID_FIELDS);
68-
(_e = (_k = parameters.include).customUUIDFields) !== null && _e !== void 0 ? _e : (_k.customUUIDFields = INCLUDE_UUID_CUSTOM_FIELDS);
69-
(_f = parameters.limit) !== null && _f !== void 0 ? _f : (parameters.limit = LIMIT);
81+
(_b = (_l = parameters.include).customFields) !== null && _b !== void 0 ? _b : (_l.customFields = INCLUDE_CUSTOM_FIELDS);
82+
(_c = (_m = parameters.include).totalCount) !== null && _c !== void 0 ? _c : (_m.totalCount = INCLUDE_TOTAL_COUNT);
83+
(_d = (_o = parameters.include).statusField) !== null && _d !== void 0 ? _d : (_o.statusField = INCLUDE_STATUS);
84+
(_e = (_p = parameters.include).typeField) !== null && _e !== void 0 ? _e : (_p.typeField = INCLUDE_TYPE);
85+
(_f = (_q = parameters.include).UUIDFields) !== null && _f !== void 0 ? _f : (_q.UUIDFields = INCLUDE_UUID_FIELDS);
86+
(_g = (_r = parameters.include).customUUIDFields) !== null && _g !== void 0 ? _g : (_r.customUUIDFields = INCLUDE_UUID_CUSTOM_FIELDS);
87+
(_h = (_s = parameters.include).UUIDStatusField) !== null && _h !== void 0 ? _h : (_s.UUIDStatusField = INCLUDE_UUID_STATUS_FIELD);
88+
(_j = (_t = parameters.include).UUIDTypeField) !== null && _j !== void 0 ? _j : (_t.UUIDTypeField = INCLUDE_UUID_TYPE_FIELD);
89+
(_k = parameters.limit) !== null && _k !== void 0 ? _k : (parameters.limit = LIMIT);
7090
}
7191
operation() {
7292
return operations_1.default.PNSetMembersOperation;
@@ -101,10 +121,18 @@ class SetChannelMembersRequest extends request_1.AbstractRequest {
101121
else
102122
sorting = Object.entries(sort !== null && sort !== void 0 ? sort : {}).map(([option, order]) => (order !== null ? `${option}:${order}` : option));
103123
const includeFlags = ['uuid.status', 'uuid.type', 'type'];
124+
if (include.statusField)
125+
includeFlags.push('status');
126+
if (include.typeField)
127+
includeFlags.push('type');
104128
if (include.customFields)
105129
includeFlags.push('custom');
106130
if (include.UUIDFields)
107131
includeFlags.push('uuid');
132+
if (include.UUIDStatusField)
133+
includeFlags.push('uuid.status');
134+
if (include.UUIDTypeField)
135+
includeFlags.push('uuid.type');
108136
if (include.customUUIDFields)
109137
includeFlags.push('uuid.custom');
110138
return Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({ count: `${include.totalCount}` }, (includeFlags.length > 0 ? { include: includeFlags.join(',') } : {})), (filter ? { filter } : {})), ((page === null || page === void 0 ? void 0 : page.next) ? { start: page.next } : {})), ((page === null || page === void 0 ? void 0 : page.prev) ? { end: page.prev } : {})), (limit ? { limit } : {})), (sorting.length ? { sort: sorting } : {}));
@@ -117,7 +145,7 @@ class SetChannelMembersRequest extends request_1.AbstractRequest {
117145
return { uuid: { id: uuid } };
118146
}
119147
else {
120-
return { uuid: { id: uuid.id }, status: uuid.status, custom: uuid.custom };
148+
return { uuid: { id: uuid.id }, status: uuid.status, type: uuid.type, custom: uuid.custom };
121149
}
122150
}),
123151
});

lib/core/endpoints/objects/membership/get.js

Lines changed: 18 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -32,9 +32,13 @@ const utils_1 = require("../../../utils");
3232
*/
3333
const INCLUDE_CUSTOM_FIELDS = false;
3434
/**
35-
* Whether membership's status field should be included in response or not.
35+
* Whether membership's `status` field should be included in response or not.
3636
*/
3737
const INCLUDE_STATUS = false;
38+
/**
39+
* Whether membership's `type` field should be included in response or not.
40+
*/
41+
const INCLUDE_TYPE = false;
3842
/**
3943
* Whether total number of memberships should be included in response or not.
4044
*/
@@ -67,20 +71,21 @@ const LIMIT = 100;
6771
*/
6872
class GetUUIDMembershipsRequest extends request_1.AbstractRequest {
6973
constructor(parameters) {
70-
var _a, _b, _c, _d, _e, _f, _g, _h, _j;
71-
var _k, _l, _m, _o, _p, _q, _r;
74+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
75+
var _l, _m, _o, _p, _q, _r, _s, _t;
7276
super();
7377
this.parameters = parameters;
7478
// Apply default request parameters.
7579
(_a = parameters.include) !== null && _a !== void 0 ? _a : (parameters.include = {});
76-
(_b = (_k = parameters.include).customFields) !== null && _b !== void 0 ? _b : (_k.customFields = INCLUDE_CUSTOM_FIELDS);
77-
(_c = (_l = parameters.include).totalCount) !== null && _c !== void 0 ? _c : (_l.totalCount = INCLUDE_TOTAL_COUNT);
78-
(_d = (_m = parameters.include).statusField) !== null && _d !== void 0 ? _d : (_m.statusField = INCLUDE_STATUS);
79-
(_e = (_o = parameters.include).channelFields) !== null && _e !== void 0 ? _e : (_o.channelFields = INCLUDE_CHANNEL_FIELDS);
80-
(_f = (_p = parameters.include).customChannelFields) !== null && _f !== void 0 ? _f : (_p.customChannelFields = INCLUDE_CHANNEL_CUSTOM_FIELDS);
81-
(_g = (_q = parameters.include).channelStatusField) !== null && _g !== void 0 ? _g : (_q.channelStatusField = INCLUDE_CHANNEL_STATUS_FIELD);
82-
(_h = (_r = parameters.include).channelTypeField) !== null && _h !== void 0 ? _h : (_r.channelTypeField = INCLUDE_CHANNEL_TYPE_FIELD);
83-
(_j = parameters.limit) !== null && _j !== void 0 ? _j : (parameters.limit = LIMIT);
80+
(_b = (_l = parameters.include).customFields) !== null && _b !== void 0 ? _b : (_l.customFields = INCLUDE_CUSTOM_FIELDS);
81+
(_c = (_m = parameters.include).totalCount) !== null && _c !== void 0 ? _c : (_m.totalCount = INCLUDE_TOTAL_COUNT);
82+
(_d = (_o = parameters.include).statusField) !== null && _d !== void 0 ? _d : (_o.statusField = INCLUDE_STATUS);
83+
(_e = (_p = parameters.include).typeField) !== null && _e !== void 0 ? _e : (_p.typeField = INCLUDE_TYPE);
84+
(_f = (_q = parameters.include).channelFields) !== null && _f !== void 0 ? _f : (_q.channelFields = INCLUDE_CHANNEL_FIELDS);
85+
(_g = (_r = parameters.include).customChannelFields) !== null && _g !== void 0 ? _g : (_r.customChannelFields = INCLUDE_CHANNEL_CUSTOM_FIELDS);
86+
(_h = (_s = parameters.include).channelStatusField) !== null && _h !== void 0 ? _h : (_s.channelStatusField = INCLUDE_CHANNEL_STATUS_FIELD);
87+
(_j = (_t = parameters.include).channelTypeField) !== null && _j !== void 0 ? _j : (_t.channelTypeField = INCLUDE_CHANNEL_TYPE_FIELD);
88+
(_k = parameters.limit) !== null && _k !== void 0 ? _k : (parameters.limit = LIMIT);
8489
// Remap for backward compatibility.
8590
if (this.parameters.userId)
8691
this.parameters.uuid = this.parameters.userId;
@@ -117,6 +122,8 @@ class GetUUIDMembershipsRequest extends request_1.AbstractRequest {
117122
const includeFlags = [];
118123
if (include.statusField)
119124
includeFlags.push('status');
125+
if (include.typeField)
126+
includeFlags.push('type');
120127
if (include.customFields)
121128
includeFlags.push('custom');
122129
if (include.channelFields)

0 commit comments

Comments
 (0)