polfan-server-js-client 0.2.73 → 0.2.75

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.
@@ -4,10 +4,7 @@
4
4
  <option name="autoReloadType" value="SELECTIVE" />
5
5
  </component>
6
6
  <component name="ChangeListManager">
7
- <list default="true" id="831dae43-0da1-47fd-a5f7-33dd5eec2992" name="Changes" comment="Bump version">
8
- <change beforePath="$PROJECT_DIR$/package.json" beforeDir="false" afterPath="$PROJECT_DIR$/package.json" afterDir="false" />
9
- <change beforePath="$PROJECT_DIR$/src/state-tracker/PermissionsManager.ts" beforeDir="false" afterPath="$PROJECT_DIR$/src/state-tracker/PermissionsManager.ts" afterDir="false" />
10
- </list>
7
+ <list default="true" id="831dae43-0da1-47fd-a5f7-33dd5eec2992" name="Changes" comment="Fix permission check (caching overwrites)" />
11
8
  <option name="SHOW_DIALOG" value="false" />
12
9
  <option name="HIGHLIGHT_CONFLICTS" value="true" />
13
10
  <option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
@@ -164,15 +161,7 @@
164
161
  <workItem from="1765445100442" duration="586000" />
165
162
  <workItem from="1765805497689" duration="6758000" />
166
163
  <workItem from="1765961123241" duration="6316000" />
167
- <workItem from="1767385708366" duration="2678000" />
168
- </task>
169
- <task id="LOCAL-00021" summary="Client data and room stream support">
170
- <option name="closed" value="true" />
171
- <created>1741970680171</created>
172
- <option name="number" value="00021" />
173
- <option name="presentableId" value="LOCAL-00021" />
174
- <option name="project" value="LOCAL" />
175
- <updated>1741970680171</updated>
164
+ <workItem from="1767385708366" duration="3390000" />
176
165
  </task>
177
166
  <task id="LOCAL-00022" summary="Client data and room stream support">
178
167
  <option name="closed" value="true" />
@@ -558,7 +547,15 @@
558
547
  <option name="project" value="LOCAL" />
559
548
  <updated>1766071099183</updated>
560
549
  </task>
561
- <option name="localTasksCounter" value="70" />
550
+ <task id="LOCAL-00070" summary="Fix permission check (caching overwrites)">
551
+ <option name="closed" value="true" />
552
+ <created>1767389582834</created>
553
+ <option name="number" value="00070" />
554
+ <option name="presentableId" value="LOCAL-00070" />
555
+ <option name="project" value="LOCAL" />
556
+ <updated>1767389582834</updated>
557
+ </task>
558
+ <option name="localTasksCounter" value="71" />
562
559
  <servers />
563
560
  </component>
564
561
  <component name="TypeScriptGeneratedFilesManager">
@@ -576,7 +573,6 @@
576
573
  </option>
577
574
  </component>
578
575
  <component name="VcsManagerConfiguration">
579
- <MESSAGE value="Fix update the latest message in a room default topic" />
580
576
  <MESSAGE value="Adapt FilesClient to new files API" />
581
577
  <MESSAGE value="Fix global emoticons support" />
582
578
  <MESSAGE value="Update schemes" />
@@ -601,7 +597,8 @@
601
597
  <MESSAGE value="Ping-pong connection monitoring" />
602
598
  <MESSAGE value="Improve reconnect on timeout" />
603
599
  <MESSAGE value="Bump version" />
604
- <option name="LAST_COMMIT_MESSAGE" value="Bump version" />
600
+ <MESSAGE value="Fix permission check (caching overwrites)" />
601
+ <option name="LAST_COMMIT_MESSAGE" value="Fix permission check (caching overwrites)" />
605
602
  </component>
606
603
  <component name="github-copilot-workspace">
607
604
  <instructionFileLocations>
@@ -3219,7 +3219,7 @@ function PermissionsManager_toPrimitive(t, r) { if ("object" != PermissionsManag
3219
3219
 
3220
3220
 
3221
3221
  var getOvId = function getOvId(location, target) {
3222
- return [location.roomId, location.topicId, target === null || target === void 0 ? void 0 : target.type, target === null || target === void 0 ? void 0 : target.userId, target === null || target === void 0 ? void 0 : target.roleId].filter(Boolean).join('/');
3222
+ return [location.spaceId, location.roomId, location.topicId, target === null || target === void 0 ? void 0 : target.type, target === null || target === void 0 ? void 0 : target.userId, target === null || target === void 0 ? void 0 : target.roleId].filter(Boolean).join('/');
3223
3223
  };
3224
3224
  var getOvIdByObject = function getOvIdByObject(overwrites) {
3225
3225
  return getOvId(overwrites.location, overwrites.target);
@@ -3364,19 +3364,38 @@ var PermissionsManager = /*#__PURE__*/function (_EventTarget) {
3364
3364
  key: "calculatePermissions",
3365
3365
  value: function () {
3366
3366
  var _calculatePermissions = PermissionsManager_asyncToGenerator(/*#__PURE__*/PermissionsManager_regenerator().m(function _callee4(location) {
3367
- var _spaceMember$roles, _roomMember$roles, _yield$this$tracker$s, _yield$this$tracker$r, _yield$this$tracker$r2;
3368
- var userId, _yield$this$fetchMemb, _yield$this$fetchMemb2, spaceMember, roomMember, userRoles, promises, filterLocation, _filterLocation, _t, _t2, _t3, _t4, _t5, _t6, _t7, _t8, _t9, _t0, _t1, _t10, _t11;
3367
+ var _location$spaceId, _spaceMember$roles, _roomMember$roles, _yield$this$tracker$s, _yield$this$tracker$r;
3368
+ var room, userId, _yield$this$fetchMemb, _yield$this$fetchMemb2, spaceMember, roomMember, userRoles, promises, filterLocation, _filterLocation, _t, _t2, _t3, _t4, _t5, _t6, _t7, _t8, _t9, _t0;
3369
3369
  return PermissionsManager_regenerator().w(function (_context4) {
3370
3370
  while (1) switch (_context4.n) {
3371
3371
  case 0:
3372
- this.validateLocation(location);
3372
+ if (!location.roomId) {
3373
+ _context4.n = 2;
3374
+ break;
3375
+ }
3373
3376
  _context4.n = 1;
3374
- return this.tracker.getMe();
3377
+ return this.tracker.rooms.get();
3375
3378
  case 1:
3379
+ _t = _context4.v.get(location.roomId);
3380
+ _context4.n = 3;
3381
+ break;
3382
+ case 2:
3383
+ _t = null;
3384
+ case 3:
3385
+ room = _t;
3386
+ location = {
3387
+ spaceId: (_location$spaceId = location.spaceId) !== null && _location$spaceId !== void 0 ? _location$spaceId : room === null || room === void 0 ? void 0 : room.spaceId,
3388
+ roomId: location.roomId,
3389
+ topicId: location.topicId
3390
+ };
3391
+ this.validateLocation(location);
3392
+ _context4.n = 4;
3393
+ return this.tracker.getMe();
3394
+ case 4:
3376
3395
  userId = _context4.v.id;
3377
- _context4.n = 2;
3396
+ _context4.n = 5;
3378
3397
  return this.fetchMembersOrFail(location);
3379
- case 2:
3398
+ case 5:
3380
3399
  _yield$this$fetchMemb = _context4.v;
3381
3400
  _yield$this$fetchMemb2 = PermissionsManager_slicedToArray(_yield$this$fetchMemb, 2);
3382
3401
  spaceMember = _yield$this$fetchMemb2[0];
@@ -3390,33 +3409,33 @@ var PermissionsManager = /*#__PURE__*/function (_EventTarget) {
3390
3409
  }).then(function (v) {
3391
3410
  return v.overwrites;
3392
3411
  })];
3393
- _t = location.spaceId;
3394
- if (!_t) {
3395
- _context4.n = 6;
3412
+ _t2 = location.spaceId;
3413
+ if (!_t2) {
3414
+ _context4.n = 9;
3396
3415
  break;
3397
3416
  }
3398
- _context4.n = 3;
3417
+ _context4.n = 6;
3399
3418
  return this.tracker.spaces.get();
3400
- case 3:
3401
- _t4 = _yield$this$tracker$s = _context4.v;
3402
- _t3 = _t4 !== null;
3419
+ case 6:
3420
+ _t5 = _yield$this$tracker$s = _context4.v;
3421
+ _t4 = _t5 !== null;
3422
+ if (!_t4) {
3423
+ _context4.n = 7;
3424
+ break;
3425
+ }
3426
+ _t4 = _yield$this$tracker$s !== void 0;
3427
+ case 7:
3428
+ _t3 = _t4;
3403
3429
  if (!_t3) {
3404
- _context4.n = 4;
3430
+ _context4.n = 8;
3405
3431
  break;
3406
3432
  }
3407
- _t3 = _yield$this$tracker$s !== void 0;
3408
- case 4:
3433
+ _t3 = _yield$this$tracker$s.has(location.spaceId);
3434
+ case 8:
3409
3435
  _t2 = _t3;
3436
+ case 9:
3410
3437
  if (!_t2) {
3411
- _context4.n = 5;
3412
- break;
3413
- }
3414
- _t2 = _yield$this$tracker$s.has(location.spaceId);
3415
- case 5:
3416
- _t = _t2;
3417
- case 6:
3418
- if (!_t) {
3419
- _context4.n = 7;
3438
+ _context4.n = 10;
3420
3439
  break;
3421
3440
  }
3422
3441
  filterLocation = {
@@ -3429,79 +3448,51 @@ var PermissionsManager = /*#__PURE__*/function (_EventTarget) {
3429
3448
  }).then(function (v) {
3430
3449
  return v.overwrites;
3431
3450
  }));
3432
- case 7:
3433
- _t5 = location.roomId;
3434
- if (!_t5) {
3435
- _context4.n = 11;
3436
- break;
3437
- }
3438
- _context4.n = 8;
3439
- return this.tracker.rooms.get();
3440
- case 8:
3441
- _t8 = _yield$this$tracker$r = _context4.v;
3442
- _t7 = _t8 !== null;
3443
- if (!_t7) {
3444
- _context4.n = 9;
3445
- break;
3451
+ case 10:
3452
+ if (room) {
3453
+ _filterLocation = {
3454
+ spaceId: location.spaceId,
3455
+ roomId: location.roomId
3456
+ };
3457
+ if (userRoles.length) {
3458
+ promises.push(this.collectRoleOverwrites(_filterLocation, userRoles));
3459
+ }
3460
+ promises.push(this.getOverwrites(_filterLocation, {
3461
+ type: 'User',
3462
+ userId: userId
3463
+ }).then(function (v) {
3464
+ return v.overwrites;
3465
+ }));
3446
3466
  }
3447
- _t7 = _yield$this$tracker$r !== void 0;
3448
- case 9:
3449
- _t6 = _t7;
3467
+ _t6 = location.topicId;
3450
3468
  if (!_t6) {
3451
- _context4.n = 10;
3469
+ _context4.n = 14;
3452
3470
  break;
3453
3471
  }
3454
- _t6 = _yield$this$tracker$r.has(location.roomId);
3455
- case 10:
3456
- _t5 = _t6;
3472
+ _context4.n = 11;
3473
+ return this.tracker.rooms.getTopics(location.roomId);
3457
3474
  case 11:
3458
- if (!_t5) {
3475
+ _t9 = _yield$this$tracker$r = _context4.v;
3476
+ _t8 = _t9 !== null;
3477
+ if (!_t8) {
3459
3478
  _context4.n = 12;
3460
3479
  break;
3461
3480
  }
3462
- _filterLocation = {
3463
- spaceId: location.spaceId,
3464
- roomId: location.roomId
3465
- };
3466
- if (userRoles.length) {
3467
- promises.push(this.collectRoleOverwrites(_filterLocation, userRoles));
3468
- }
3469
- promises.push(this.getOverwrites(_filterLocation, {
3470
- type: 'User',
3471
- userId: userId
3472
- }).then(function (v) {
3473
- return v.overwrites;
3474
- }));
3481
+ _t8 = _yield$this$tracker$r !== void 0;
3475
3482
  case 12:
3476
- _t9 = location.topicId;
3477
- if (!_t9) {
3478
- _context4.n = 16;
3483
+ _t7 = _t8;
3484
+ if (!_t7) {
3485
+ _context4.n = 13;
3479
3486
  break;
3480
3487
  }
3481
- _context4.n = 13;
3482
- return this.tracker.rooms.getTopics(location.roomId);
3488
+ _t7 = _yield$this$tracker$r.has(location.topicId);
3483
3489
  case 13:
3484
- _t10 = _yield$this$tracker$r2 = _context4.v;
3485
- _t1 = _t10 !== null;
3486
- if (!_t1) {
3487
- _context4.n = 14;
3488
- break;
3489
- }
3490
- _t1 = _yield$this$tracker$r2 !== void 0;
3490
+ _t6 = _t7;
3491
3491
  case 14:
3492
- _t0 = _t1;
3493
- if (!_t0) {
3492
+ if (!_t6) {
3494
3493
  _context4.n = 15;
3495
3494
  break;
3496
3495
  }
3497
- _t0 = _yield$this$tracker$r2.has(location.topicId);
3498
- case 15:
3499
- _t9 = _t0;
3500
- case 16:
3501
- if (!_t9) {
3502
- _context4.n = 17;
3503
- break;
3504
- }
3505
3496
  if (userRoles.length) {
3506
3497
  promises.push(this.collectRoleOverwrites(location, userRoles));
3507
3498
  }
@@ -3511,12 +3502,12 @@ var PermissionsManager = /*#__PURE__*/function (_EventTarget) {
3511
3502
  }).then(function (v) {
3512
3503
  return v.overwrites;
3513
3504
  }));
3514
- case 17:
3515
- _t11 = this;
3516
- _context4.n = 18;
3505
+ case 15:
3506
+ _t0 = this;
3507
+ _context4.n = 16;
3517
3508
  return Promise.all(promises);
3518
- case 18:
3519
- return _context4.a(2, _t11.resolveOverwritesHierarchy.call(_t11, _context4.v));
3509
+ case 16:
3510
+ return _context4.a(2, _t0.resolveOverwritesHierarchy.call(_t0, _context4.v));
3520
3511
  }
3521
3512
  }, _callee4, this);
3522
3513
  }));
@@ -3607,8 +3598,8 @@ var PermissionsManager = /*#__PURE__*/function (_EventTarget) {
3607
3598
  }
3608
3599
  }
3609
3600
 
3610
- /**
3611
- * @return Matched and deleted ids
3601
+ /**
3602
+ * @return Matched and deleted ids
3612
3603
  */
3613
3604
  }, {
3614
3605
  key: "deleteOverwritesByIdPrefix",