@psnext/slingcli 2.4.20260522-2 → 2.4.20260522-4

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/bin/sling.js CHANGED
@@ -124,7 +124,10 @@ function syncBundledSkills() {
124
124
  for (const entry of readdirSync(srcSkillsDir, { withFileTypes: true })) {
125
125
  if (!entry.isDirectory()) continue;
126
126
  const dest = path.join(destSkillsDir, entry.name);
127
+ try {
127
128
  cpSync(path.join(srcSkillsDir, entry.name), dest, { recursive: true, force: true });
129
+ } catch (err) {
130
+ }
128
131
  }
129
132
  }
130
133
 
@@ -135,6 +138,7 @@ async function checkAndInstallPackages() {
135
138
  if (!existsSync(configPath)) return;
136
139
 
137
140
  let installed = new Set();
141
+ let unsupported = new Set();
138
142
  const settingsPath = path.resolve(homedir(), ".sling/agent/settings.json");
139
143
  if (existsSync(settingsPath)) {
140
144
  try {
@@ -143,11 +147,45 @@ async function checkAndInstallPackages() {
143
147
  const source = typeof p === "object" && p !== null ? p.source : p;
144
148
  installed.add(source);
145
149
  }
150
+ for (const p of settings.unsupportedPackages || []) {
151
+ const source = typeof p === "object" && p !== null ? p.source : p;
152
+ unsupported.add(source);
153
+ }
146
154
  } catch {}
147
155
  }
148
156
 
149
157
  try {
158
+
159
+ //uninstall unsupported packages
160
+ for (const u of unsupported) {
161
+ console.log(`Removing unsupported package ${u}...`);
162
+ try {
163
+ await runCommand(process.execPath, [__filename, "remove", "-g", u]);
164
+ console.log(`✓ Removed ${u}`);
165
+ } catch (err) {
166
+ console.error(`✗ Failed to remove ${u}:`, err.message);
167
+ console.error(` You may need to manually remove it with: sling remove ${u}`);
168
+ }
169
+ }
170
+
171
+ //remove unsupported packages from installed set
172
+ for (const u of unsupported) installed.delete(u);
173
+
150
174
  const config = JSON.parse(readFileSync(configPath, "utf-8"));
175
+ const updatePackages = (config.packages || []).filter((p) => {
176
+ const source = typeof p === "object" && p !== null ? p.source : p;
177
+ return installed.has(source);
178
+ });
179
+ for (const pkg of updatePackages) {
180
+ console.log(`Updating ${pkg}...`);
181
+ try {
182
+ await runCommand(process.execPath, [__filename, "update", "-g", pkg]);
183
+ console.log(`✓ Updated ${pkg}`);
184
+ } catch (err) {
185
+ console.error(`✗ Failed to update ${pkg}:`, err.message);
186
+ console.error(` You can manually update it later with: sling update ${pkg}`);
187
+ }
188
+ }
151
189
  const packages = (config.packages || []).filter((p) => {
152
190
  const source = typeof p === "object" && p !== null ? p.source : p;
153
191
  return !installed.has(source);
@@ -3515,42 +3515,6 @@ export const MODELS = {
3515
3515
  },
3516
3516
  },
3517
3517
  "fireworks": {
3518
- "accounts/fireworks/models/deepseek-v3p1": {
3519
- id: "accounts/fireworks/models/deepseek-v3p1",
3520
- name: "DeepSeek V3.1",
3521
- api: "anthropic-messages",
3522
- provider: "fireworks",
3523
- baseUrl: "https://api.fireworks.ai/inference",
3524
- compat: { "sendSessionAffinityHeaders": true, "supportsEagerToolInputStreaming": false, "supportsCacheControlOnTools": false, "supportsLongCacheRetention": false },
3525
- reasoning: true,
3526
- input: ["text"],
3527
- cost: {
3528
- input: 0.56,
3529
- output: 1.68,
3530
- cacheRead: 0,
3531
- cacheWrite: 0,
3532
- },
3533
- contextWindow: 163840,
3534
- maxTokens: 163840,
3535
- },
3536
- "accounts/fireworks/models/deepseek-v3p2": {
3537
- id: "accounts/fireworks/models/deepseek-v3p2",
3538
- name: "DeepSeek V3.2",
3539
- api: "anthropic-messages",
3540
- provider: "fireworks",
3541
- baseUrl: "https://api.fireworks.ai/inference",
3542
- compat: { "sendSessionAffinityHeaders": true, "supportsEagerToolInputStreaming": false, "supportsCacheControlOnTools": false, "supportsLongCacheRetention": false },
3543
- reasoning: true,
3544
- input: ["text"],
3545
- cost: {
3546
- input: 0.56,
3547
- output: 1.68,
3548
- cacheRead: 0.28,
3549
- cacheWrite: 0,
3550
- },
3551
- contextWindow: 160000,
3552
- maxTokens: 160000,
3553
- },
3554
3518
  "accounts/fireworks/models/deepseek-v4-flash": {
3555
3519
  id: "accounts/fireworks/models/deepseek-v4-flash",
3556
3520
  name: "DeepSeek V4 Flash",
@@ -3581,84 +3545,12 @@ export const MODELS = {
3581
3545
  cost: {
3582
3546
  input: 1.74,
3583
3547
  output: 3.48,
3584
- cacheRead: 0.15,
3548
+ cacheRead: 0.145,
3585
3549
  cacheWrite: 0,
3586
3550
  },
3587
3551
  contextWindow: 1000000,
3588
3552
  maxTokens: 384000,
3589
3553
  },
3590
- "accounts/fireworks/models/glm-4p5": {
3591
- id: "accounts/fireworks/models/glm-4p5",
3592
- name: "GLM 4.5",
3593
- api: "anthropic-messages",
3594
- provider: "fireworks",
3595
- baseUrl: "https://api.fireworks.ai/inference",
3596
- compat: { "sendSessionAffinityHeaders": true, "supportsEagerToolInputStreaming": false, "supportsCacheControlOnTools": false, "supportsLongCacheRetention": false },
3597
- reasoning: true,
3598
- input: ["text"],
3599
- cost: {
3600
- input: 0.55,
3601
- output: 2.19,
3602
- cacheRead: 0,
3603
- cacheWrite: 0,
3604
- },
3605
- contextWindow: 131072,
3606
- maxTokens: 131072,
3607
- },
3608
- "accounts/fireworks/models/glm-4p5-air": {
3609
- id: "accounts/fireworks/models/glm-4p5-air",
3610
- name: "GLM 4.5 Air",
3611
- api: "anthropic-messages",
3612
- provider: "fireworks",
3613
- baseUrl: "https://api.fireworks.ai/inference",
3614
- compat: { "sendSessionAffinityHeaders": true, "supportsEagerToolInputStreaming": false, "supportsCacheControlOnTools": false, "supportsLongCacheRetention": false },
3615
- reasoning: true,
3616
- input: ["text"],
3617
- cost: {
3618
- input: 0.22,
3619
- output: 0.88,
3620
- cacheRead: 0,
3621
- cacheWrite: 0,
3622
- },
3623
- contextWindow: 131072,
3624
- maxTokens: 131072,
3625
- },
3626
- "accounts/fireworks/models/glm-4p7": {
3627
- id: "accounts/fireworks/models/glm-4p7",
3628
- name: "GLM 4.7",
3629
- api: "anthropic-messages",
3630
- provider: "fireworks",
3631
- baseUrl: "https://api.fireworks.ai/inference",
3632
- compat: { "sendSessionAffinityHeaders": true, "supportsEagerToolInputStreaming": false, "supportsCacheControlOnTools": false, "supportsLongCacheRetention": false },
3633
- reasoning: true,
3634
- input: ["text"],
3635
- cost: {
3636
- input: 0.6,
3637
- output: 2.2,
3638
- cacheRead: 0.3,
3639
- cacheWrite: 0,
3640
- },
3641
- contextWindow: 198000,
3642
- maxTokens: 198000,
3643
- },
3644
- "accounts/fireworks/models/glm-5": {
3645
- id: "accounts/fireworks/models/glm-5",
3646
- name: "GLM 5",
3647
- api: "anthropic-messages",
3648
- provider: "fireworks",
3649
- baseUrl: "https://api.fireworks.ai/inference",
3650
- compat: { "sendSessionAffinityHeaders": true, "supportsEagerToolInputStreaming": false, "supportsCacheControlOnTools": false, "supportsLongCacheRetention": false },
3651
- reasoning: true,
3652
- input: ["text"],
3653
- cost: {
3654
- input: 1,
3655
- output: 3.2,
3656
- cacheRead: 0.5,
3657
- cacheWrite: 0,
3658
- },
3659
- contextWindow: 202752,
3660
- maxTokens: 131072,
3661
- },
3662
3554
  "accounts/fireworks/models/glm-5p1": {
3663
3555
  id: "accounts/fireworks/models/glm-5p1",
3664
3556
  name: "GLM 5.1",
@@ -3689,7 +3581,7 @@ export const MODELS = {
3689
3581
  cost: {
3690
3582
  input: 0.15,
3691
3583
  output: 0.6,
3692
- cacheRead: 0,
3584
+ cacheRead: 0.015,
3693
3585
  cacheWrite: 0,
3694
3586
  },
3695
3587
  contextWindow: 131072,
@@ -3705,50 +3597,14 @@ export const MODELS = {
3705
3597
  reasoning: true,
3706
3598
  input: ["text"],
3707
3599
  cost: {
3708
- input: 0.05,
3709
- output: 0.2,
3710
- cacheRead: 0,
3600
+ input: 0.07,
3601
+ output: 0.3,
3602
+ cacheRead: 0.035,
3711
3603
  cacheWrite: 0,
3712
3604
  },
3713
3605
  contextWindow: 131072,
3714
3606
  maxTokens: 32768,
3715
3607
  },
3716
- "accounts/fireworks/models/kimi-k2-instruct": {
3717
- id: "accounts/fireworks/models/kimi-k2-instruct",
3718
- name: "Kimi K2 Instruct",
3719
- api: "anthropic-messages",
3720
- provider: "fireworks",
3721
- baseUrl: "https://api.fireworks.ai/inference",
3722
- compat: { "sendSessionAffinityHeaders": true, "supportsEagerToolInputStreaming": false, "supportsCacheControlOnTools": false, "supportsLongCacheRetention": false },
3723
- reasoning: false,
3724
- input: ["text"],
3725
- cost: {
3726
- input: 1,
3727
- output: 3,
3728
- cacheRead: 0,
3729
- cacheWrite: 0,
3730
- },
3731
- contextWindow: 128000,
3732
- maxTokens: 16384,
3733
- },
3734
- "accounts/fireworks/models/kimi-k2-thinking": {
3735
- id: "accounts/fireworks/models/kimi-k2-thinking",
3736
- name: "Kimi K2 Thinking",
3737
- api: "anthropic-messages",
3738
- provider: "fireworks",
3739
- baseUrl: "https://api.fireworks.ai/inference",
3740
- compat: { "sendSessionAffinityHeaders": true, "supportsEagerToolInputStreaming": false, "supportsCacheControlOnTools": false, "supportsLongCacheRetention": false },
3741
- reasoning: true,
3742
- input: ["text"],
3743
- cost: {
3744
- input: 0.6,
3745
- output: 2.5,
3746
- cacheRead: 0.3,
3747
- cacheWrite: 0,
3748
- },
3749
- contextWindow: 256000,
3750
- maxTokens: 256000,
3751
- },
3752
3608
  "accounts/fireworks/models/kimi-k2p5": {
3753
3609
  id: "accounts/fireworks/models/kimi-k2p5",
3754
3610
  name: "Kimi K2.5",
@@ -3785,24 +3641,6 @@ export const MODELS = {
3785
3641
  contextWindow: 262000,
3786
3642
  maxTokens: 262000,
3787
3643
  },
3788
- "accounts/fireworks/models/minimax-m2p1": {
3789
- id: "accounts/fireworks/models/minimax-m2p1",
3790
- name: "MiniMax-M2.1",
3791
- api: "anthropic-messages",
3792
- provider: "fireworks",
3793
- baseUrl: "https://api.fireworks.ai/inference",
3794
- compat: { "sendSessionAffinityHeaders": true, "supportsEagerToolInputStreaming": false, "supportsCacheControlOnTools": false, "supportsLongCacheRetention": false },
3795
- reasoning: true,
3796
- input: ["text"],
3797
- cost: {
3798
- input: 0.3,
3799
- output: 1.2,
3800
- cacheRead: 0.03,
3801
- cacheWrite: 0,
3802
- },
3803
- contextWindow: 200000,
3804
- maxTokens: 200000,
3805
- },
3806
3644
  "accounts/fireworks/models/minimax-m2p5": {
3807
3645
  id: "accounts/fireworks/models/minimax-m2p5",
3808
3646
  name: "MiniMax-M2.5",
@@ -3833,7 +3671,7 @@ export const MODELS = {
3833
3671
  cost: {
3834
3672
  input: 0.3,
3835
3673
  output: 1.2,
3836
- cacheRead: 0.03,
3674
+ cacheRead: 0.06,
3837
3675
  cacheWrite: 0,
3838
3676
  },
3839
3677
  contextWindow: 196608,
@@ -3857,9 +3695,27 @@ export const MODELS = {
3857
3695
  contextWindow: 128000,
3858
3696
  maxTokens: 8192,
3859
3697
  },
3860
- "accounts/fireworks/routers/kimi-k2p5-turbo": {
3861
- id: "accounts/fireworks/routers/kimi-k2p5-turbo",
3862
- name: "Kimi K2.5 Turbo",
3698
+ "accounts/fireworks/routers/glm-5p1-fast": {
3699
+ id: "accounts/fireworks/routers/glm-5p1-fast",
3700
+ name: "GLM 5.1 Fast",
3701
+ api: "anthropic-messages",
3702
+ provider: "fireworks",
3703
+ baseUrl: "https://api.fireworks.ai/inference",
3704
+ compat: { "sendSessionAffinityHeaders": true, "supportsEagerToolInputStreaming": false, "supportsCacheControlOnTools": false, "supportsLongCacheRetention": false },
3705
+ reasoning: true,
3706
+ input: ["text"],
3707
+ cost: {
3708
+ input: 2.8,
3709
+ output: 8.8,
3710
+ cacheRead: 0.52,
3711
+ cacheWrite: 0,
3712
+ },
3713
+ contextWindow: 202800,
3714
+ maxTokens: 131072,
3715
+ },
3716
+ "accounts/fireworks/routers/kimi-k2p6-turbo": {
3717
+ id: "accounts/fireworks/routers/kimi-k2p6-turbo",
3718
+ name: "Kimi K2.6 Turbo",
3863
3719
  api: "anthropic-messages",
3864
3720
  provider: "fireworks",
3865
3721
  baseUrl: "https://api.fireworks.ai/inference",
@@ -3867,13 +3723,13 @@ export const MODELS = {
3867
3723
  reasoning: true,
3868
3724
  input: ["text", "image"],
3869
3725
  cost: {
3870
- input: 0,
3871
- output: 0,
3872
- cacheRead: 0,
3726
+ input: 2,
3727
+ output: 8,
3728
+ cacheRead: 0.3,
3873
3729
  cacheWrite: 0,
3874
3730
  },
3875
- contextWindow: 256000,
3876
- maxTokens: 256000,
3731
+ contextWindow: 262000,
3732
+ maxTokens: 262000,
3877
3733
  },
3878
3734
  },
3879
3735
  "github-copilot": {
@@ -8797,13 +8653,13 @@ export const MODELS = {
8797
8653
  thinkingLevelMap: { "minimal": null, "low": null, "medium": null, "high": "high", "xhigh": "max" },
8798
8654
  input: ["text"],
8799
8655
  cost: {
8800
- input: 0.112,
8801
- output: 0.224,
8802
- cacheRead: 0.022,
8656
+ input: 0.09999999999999999,
8657
+ output: 0.19999999999999998,
8658
+ cacheRead: 0.02,
8803
8659
  cacheWrite: 0,
8804
8660
  },
8805
8661
  contextWindow: 1048576,
8806
- maxTokens: 4096,
8662
+ maxTokens: 16384,
8807
8663
  },
8808
8664
  "deepseek/deepseek-v4-flash:free": {
8809
8665
  id: "deepseek/deepseek-v4-flash:free",
@@ -13271,10 +13127,10 @@ export const MODELS = {
13271
13127
  reasoning: true,
13272
13128
  input: ["text", "image"],
13273
13129
  cost: {
13274
- input: 2.5,
13275
- output: 7.5,
13276
- cacheRead: 0.5,
13277
- cacheWrite: 3.125,
13130
+ input: 1.25,
13131
+ output: 3.75,
13132
+ cacheRead: 0.25,
13133
+ cacheWrite: 1.5625,
13278
13134
  },
13279
13135
  contextWindow: 991000,
13280
13136
  maxTokens: 64000,
@@ -14167,7 +14023,7 @@ export const MODELS = {
14167
14023
  },
14168
14024
  "minimax/minimax-m2.7": {
14169
14025
  id: "minimax/minimax-m2.7",
14170
- name: "Minimax M2.7",
14026
+ name: "MiniMax M2.7",
14171
14027
  api: "anthropic-messages",
14172
14028
  provider: "vercel-ai-gateway",
14173
14029
  baseUrl: "https://ai-gateway.vercel.sh",
@@ -40,6 +40,10 @@ class Receiver extends Writable {
40
40
  * extensions
41
41
  * @param {Boolean} [options.isServer=false] Specifies whether to operate in
42
42
  * client or server mode
43
+ * @param {Number} [options.maxBufferedChunks=0] The maximum number of
44
+ * buffered data chunks
45
+ * @param {Number} [options.maxFragments=0] The maximum number of message
46
+ * fragments
43
47
  * @param {Number} [options.maxPayload=0] The maximum allowed message length
44
48
  * @param {Boolean} [options.skipUTF8Validation=false] Specifies whether or
45
49
  * not to skip UTF-8 validation for text and close messages
@@ -54,6 +58,8 @@ class Receiver extends Writable {
54
58
  this._binaryType = options.binaryType || BINARY_TYPES[0];
55
59
  this._extensions = options.extensions || {};
56
60
  this._isServer = !!options.isServer;
61
+ this._maxBufferedChunks = options.maxBufferedChunks | 0;
62
+ this._maxFragments = options.maxFragments | 0;
57
63
  this._maxPayload = options.maxPayload | 0;
58
64
  this._skipUTF8Validation = !!options.skipUTF8Validation;
59
65
  this[kWebSocket] = undefined;
@@ -89,6 +95,22 @@ class Receiver extends Writable {
89
95
  _write(chunk, encoding, cb) {
90
96
  if (this._opcode === 0x08 && this._state == GET_INFO) return cb();
91
97
 
98
+ if (
99
+ this._maxBufferedChunks > 0 &&
100
+ this._buffers.length >= this._maxBufferedChunks
101
+ ) {
102
+ cb(
103
+ this.createError(
104
+ RangeError,
105
+ 'Too many buffered chunks',
106
+ false,
107
+ 1008,
108
+ 'WS_ERR_TOO_MANY_BUFFERED_PARTS'
109
+ )
110
+ );
111
+ return;
112
+ }
113
+
92
114
  this._bufferedBytes += chunk.length;
93
115
  this._buffers.push(chunk);
94
116
  this.startLoop(cb);
@@ -485,6 +507,22 @@ class Receiver extends Writable {
485
507
  }
486
508
 
487
509
  if (data.length) {
510
+ if (
511
+ this._maxFragments > 0 &&
512
+ this._fragments.length >= this._maxFragments
513
+ ) {
514
+ const error = this.createError(
515
+ RangeError,
516
+ 'Too many message fragments',
517
+ false,
518
+ 1008,
519
+ 'WS_ERR_TOO_MANY_BUFFERED_PARTS'
520
+ );
521
+
522
+ cb(error);
523
+ return;
524
+ }
525
+
488
526
  //
489
527
  // This message is not compressed so its length is the sum of the payload
490
528
  // length of all fragments.
@@ -524,6 +562,22 @@ class Receiver extends Writable {
524
562
  return;
525
563
  }
526
564
 
565
+ if (
566
+ this._maxFragments > 0 &&
567
+ this._fragments.length >= this._maxFragments
568
+ ) {
569
+ const error = this.createError(
570
+ RangeError,
571
+ 'Too many message fragments',
572
+ false,
573
+ 1008,
574
+ 'WS_ERR_TOO_MANY_BUFFERED_PARTS'
575
+ );
576
+
577
+ cb(error);
578
+ return;
579
+ }
580
+
527
581
  this._fragments.push(buf);
528
582
  }
529
583
 
@@ -43,6 +43,10 @@ class WebSocketServer extends EventEmitter {
43
43
  * called
44
44
  * @param {Function} [options.handleProtocols] A hook to handle protocols
45
45
  * @param {String} [options.host] The hostname where to bind the server
46
+ * @param {Number} [options.maxBufferedChunks=1048576] The maximum number of
47
+ * buffered data chunks
48
+ * @param {Number} [options.maxFragments=131072] The maximum number of message
49
+ * fragments
46
50
  * @param {Number} [options.maxPayload=104857600] The maximum allowed message
47
51
  * size
48
52
  * @param {Boolean} [options.noServer=false] Enable no server mode
@@ -65,6 +69,8 @@ class WebSocketServer extends EventEmitter {
65
69
  options = {
66
70
  allowSynchronousEvents: true,
67
71
  autoPong: true,
72
+ maxBufferedChunks: 1024 * 1024,
73
+ maxFragments: 128 * 1024,
68
74
  maxPayload: 100 * 1024 * 1024,
69
75
  skipUTF8Validation: false,
70
76
  perMessageDeflate: false,
@@ -424,6 +430,8 @@ class WebSocketServer extends EventEmitter {
424
430
 
425
431
  ws.setSocket(socket, head, {
426
432
  allowSynchronousEvents: this.options.allowSynchronousEvents,
433
+ maxBufferedChunks: this.options.maxBufferedChunks,
434
+ maxFragments: this.options.maxFragments,
427
435
  maxPayload: this.options.maxPayload,
428
436
  skipUTF8Validation: this.options.skipUTF8Validation
429
437
  });
@@ -201,6 +201,10 @@ class WebSocket extends EventEmitter {
201
201
  * multiple times in the same tick
202
202
  * @param {Function} [options.generateMask] The function used to generate the
203
203
  * masking key
204
+ * @param {Number} [options.maxBufferedChunks=0] The maximum number of
205
+ * buffered data chunks
206
+ * @param {Number} [options.maxFragments=0] The maximum number of message
207
+ * fragments
204
208
  * @param {Number} [options.maxPayload=0] The maximum allowed message size
205
209
  * @param {Boolean} [options.skipUTF8Validation=false] Specifies whether or
206
210
  * not to skip UTF-8 validation for text and close messages
@@ -212,6 +216,8 @@ class WebSocket extends EventEmitter {
212
216
  binaryType: this.binaryType,
213
217
  extensions: this._extensions,
214
218
  isServer: this._isServer,
219
+ maxBufferedChunks: options.maxBufferedChunks,
220
+ maxFragments: options.maxFragments,
215
221
  maxPayload: options.maxPayload,
216
222
  skipUTF8Validation: options.skipUTF8Validation
217
223
  });
@@ -640,6 +646,10 @@ module.exports = WebSocket;
640
646
  * masking key
641
647
  * @param {Number} [options.handshakeTimeout] Timeout in milliseconds for the
642
648
  * handshake request
649
+ * @param {Number} [options.maxBufferedChunks=1048576] The maximum number of
650
+ * buffered data chunks
651
+ * @param {Number} [options.maxFragments=131072] The maximum number of message
652
+ * fragments
643
653
  * @param {Number} [options.maxPayload=104857600] The maximum allowed message
644
654
  * size
645
655
  * @param {Number} [options.maxRedirects=10] The maximum number of redirects
@@ -660,6 +670,8 @@ function initAsClient(websocket, address, protocols, options) {
660
670
  autoPong: true,
661
671
  closeTimeout: CLOSE_TIMEOUT,
662
672
  protocolVersion: protocolVersions[1],
673
+ maxBufferedChunks: 1024 * 1024,
674
+ maxFragments: 128 * 1024,
663
675
  maxPayload: 100 * 1024 * 1024,
664
676
  skipUTF8Validation: false,
665
677
  perMessageDeflate: true,
@@ -1017,6 +1029,8 @@ function initAsClient(websocket, address, protocols, options) {
1017
1029
  websocket.setSocket(socket, head, {
1018
1030
  allowSynchronousEvents: opts.allowSynchronousEvents,
1019
1031
  generateMask: opts.generateMask,
1032
+ maxBufferedChunks: opts.maxBufferedChunks,
1033
+ maxFragments: opts.maxFragments,
1020
1034
  maxPayload: opts.maxPayload,
1021
1035
  skipUTF8Validation: opts.skipUTF8Validation
1022
1036
  });
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ws",
3
- "version": "8.20.1",
3
+ "version": "8.21.0",
4
4
  "description": "Simple to use, blazing fast and thoroughly tested websocket client and server for Node.js",
5
5
  "keywords": [
6
6
  "HyBi",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@psnext/slingcli",
3
- "version": "2.4.20260522-2",
3
+ "version": "2.4.20260522-4",
4
4
  "description": "Connects Sling CLI to Publicis Sapient Slingshot enterprise LLM gateway. Bundles the pi coding-agent runtime.",
5
5
  "type": "module",
6
6
  "bin": {
@@ -29,7 +29,7 @@
29
29
  "type": "git",
30
30
  "url": "git+https://pscode.lioncloud.net/psaiproducts/slingcli.git"
31
31
  },
32
- "slingVersion": "2.4.20260522-2",
32
+ "slingVersion": "2.4.20260522-4",
33
33
  "dependencies": {
34
34
  "@earendil-works/pi-tui": "file:../.sling-pack/earendil-works-pi-tui-0.75.4.tgz",
35
35
  "@earendil-works/pi-ai": "file:../.sling-pack/earendil-works-pi-ai-0.75.4.tgz",
@@ -1,9 +1,12 @@
1
1
  {
2
2
  "packages": [
3
- "npm:pi-subagents",
3
+ "npm:@psnext/s-subagents",
4
4
  "npm:pi-ask-user",
5
5
  "npm:pi-hermes-memory",
6
6
  "npm:pi-smart-fetch"
7
7
  ],
8
+ "unsupportedPackages": [
9
+ "npm:pi-subagents"
10
+ ],
8
11
  "comment": "List of packages to automatically install on first run. Add more packages to the array as needed."
9
12
  }