@cartridge/controller 0.5.9 → 0.6.0

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.
Files changed (51) hide show
  1. package/.turbo/turbo-build$colon$deps.log +44 -82
  2. package/.turbo/turbo-build.log +47 -85
  3. package/dist/__tests__/parseChainId.test.js.map +1 -1
  4. package/dist/account.js +4 -0
  5. package/dist/account.js.map +1 -1
  6. package/dist/controller.js +177 -109
  7. package/dist/controller.js.map +1 -1
  8. package/dist/iframe/base.js +4 -0
  9. package/dist/iframe/base.js.map +1 -1
  10. package/dist/iframe/index.js +4 -0
  11. package/dist/iframe/index.js.map +1 -1
  12. package/dist/iframe/keychain.js +4 -0
  13. package/dist/iframe/keychain.js.map +1 -1
  14. package/dist/iframe/profile.js +4 -0
  15. package/dist/iframe/profile.js.map +1 -1
  16. package/dist/index.d.ts +1 -0
  17. package/dist/index.js +181 -111
  18. package/dist/index.js.map +1 -1
  19. package/dist/mutex.d.ts +14 -0
  20. package/dist/mutex.js +22 -0
  21. package/dist/mutex.js.map +1 -0
  22. package/dist/policies.d.ts +19 -0
  23. package/dist/policies.js +26 -0
  24. package/dist/policies.js.map +1 -0
  25. package/dist/provider.d.ts +2 -0
  26. package/dist/provider.js +163 -109
  27. package/dist/provider.js.map +1 -1
  28. package/dist/session/account.js +2 -0
  29. package/dist/session/account.js.map +1 -1
  30. package/dist/session/index.d.ts +1 -0
  31. package/dist/session/index.js +286 -121
  32. package/dist/session/index.js.map +1 -1
  33. package/dist/session/provider.d.ts +7 -2
  34. package/dist/session/provider.js +286 -121
  35. package/dist/session/provider.js.map +1 -1
  36. package/dist/telegram/provider.d.ts +2 -1
  37. package/dist/telegram/provider.js +198 -112
  38. package/dist/telegram/provider.js.map +1 -1
  39. package/dist/utils.d.ts +2 -1
  40. package/dist/utils.js +4 -2
  41. package/dist/utils.js.map +1 -1
  42. package/package.json +22 -8
  43. package/src/controller.ts +1 -0
  44. package/src/mutex.ts +22 -0
  45. package/src/policies.ts +49 -0
  46. package/src/provider.ts +33 -2
  47. package/src/session/account.ts +1 -0
  48. package/src/session/provider.ts +139 -10
  49. package/src/telegram/provider.ts +3 -2
  50. package/src/utils.ts +4 -1
  51. package/tsconfig.json +1 -2
@@ -42,6 +42,10 @@ function parseChainId(url) {
42
42
 
43
43
  // src/account.ts
44
44
  var ControllerAccount = class extends WalletAccount {
45
+ address;
46
+ keychain;
47
+ modal;
48
+ options;
45
49
  constructor(provider, rpcUrl, address, keychain, options, modal) {
46
50
  super({ nodeUrl: rpcUrl }, provider);
47
51
  this.address = address;
@@ -126,6 +130,10 @@ var account_default = ControllerAccount;
126
130
  // src/iframe/base.ts
127
131
  import { connectToChild } from "@cartridge/penpal";
128
132
  var IFrame = class {
133
+ url;
134
+ iframe;
135
+ container;
136
+ onClose;
129
137
  constructor({
130
138
  id,
131
139
  url,
@@ -318,7 +326,7 @@ import {
318
326
  // package.json
319
327
  var package_default = {
320
328
  name: "@cartridge/controller",
321
- version: "0.5.9",
329
+ version: "0.6.0",
322
330
  description: "Cartridge Controller",
323
331
  module: "dist/index.js",
324
332
  types: "dist/index.d.ts",
@@ -332,10 +340,22 @@ var package_default = {
332
340
  version: "pnpm pkg get version"
333
341
  },
334
342
  exports: {
335
- ".": "./dist/index.js",
336
- "./session": "./dist/session/index.js",
337
- "./provider": "./dist/provider/index.js",
338
- "./types": "./dist/types/index.js"
343
+ ".": {
344
+ types: "./dist/index.d.ts",
345
+ default: "./dist/index.js"
346
+ },
347
+ "./session": {
348
+ types: "./dist/session/index.d.ts",
349
+ default: "./dist/session/index.js"
350
+ },
351
+ "./provider": {
352
+ types: "./dist/provider/index.d.ts",
353
+ default: "./dist/provider/index.js"
354
+ },
355
+ "./types": {
356
+ types: "./dist/types/index.d.ts",
357
+ default: "./dist/types/index.js"
358
+ }
339
359
  },
340
360
  tsup: {
341
361
  entry: [
@@ -348,6 +368,9 @@ var package_default = {
348
368
  sourcemap: true,
349
369
  clean: true
350
370
  },
371
+ peerDependencies: {
372
+ starknet: "^6.21.0"
373
+ },
351
374
  dependencies: {
352
375
  "@cartridge/account-wasm": "workspace:*",
353
376
  "@cartridge/penpal": "^6.2.3",
@@ -356,8 +379,7 @@ var package_default = {
356
379
  base64url: "^3.0.1",
357
380
  "cbor-x": "^1.5.0",
358
381
  "fast-deep-equal": "^3.1.3",
359
- "query-string": "^7.1.1",
360
- starknet: "^6.11.0"
382
+ "query-string": "^7.1.1"
361
383
  },
362
384
  devDependencies: {
363
385
  "@cartridge/tsconfig": "workspace:*",
@@ -372,127 +394,167 @@ var package_default = {
372
394
  // src/icon.ts
373
395
  var icon = "";
374
396
 
397
+ // src/mutex.ts
398
+ function releaseStub() {
399
+ }
400
+ var Mutex = class {
401
+ m_lastPromise = Promise.resolve();
402
+ /**
403
+ * Acquire lock
404
+ * @param [bypass=false] option to skip lock acquisition
405
+ */
406
+ async obtain(bypass = false) {
407
+ let release = releaseStub;
408
+ if (bypass) return release;
409
+ const lastPromise = this.m_lastPromise;
410
+ this.m_lastPromise = new Promise((resolve) => release = resolve);
411
+ await lastPromise;
412
+ return release;
413
+ }
414
+ };
415
+
375
416
  // src/provider.ts
417
+ var mutex = new Mutex();
376
418
  var BaseProvider = class {
377
- constructor() {
378
- this.id = "controller";
379
- this.name = "Controller";
380
- this.version = package_default.version;
381
- this.icon = icon;
382
- this.subscriptions = [];
383
- this.request = async (call) => {
384
- switch (call.type) {
385
- case "wallet_getPermissions":
386
- await this.probe();
387
- if (this.account) {
388
- return [Permission.ACCOUNTS];
389
- }
390
- return [];
391
- case "wallet_requestAccounts": {
392
- if (this.account) {
393
- return [this.account.address];
394
- }
395
- const silentMode = call.params && call.params.silent_mode;
396
- this.account = await this.probe();
397
- if (!this.account && !silentMode) {
398
- this.account = await this.connect();
399
- }
400
- if (this.account) {
401
- return [this.account.address];
402
- }
403
- return [];
419
+ id = "controller";
420
+ name = "Controller";
421
+ version = package_default.version;
422
+ icon = icon;
423
+ account;
424
+ subscriptions = [];
425
+ _probePromise = null;
426
+ async safeProbe() {
427
+ if (this.account) {
428
+ return this.account;
429
+ }
430
+ if (this._probePromise) {
431
+ return this._probePromise;
432
+ }
433
+ const release = await mutex.obtain();
434
+ return await new Promise(async (resolve) => {
435
+ try {
436
+ this._probePromise = this.probe();
437
+ const result = await this._probePromise;
438
+ resolve(result);
439
+ } finally {
440
+ this._probePromise = null;
441
+ }
442
+ }).finally(() => {
443
+ release();
444
+ });
445
+ }
446
+ request = async (call) => {
447
+ switch (call.type) {
448
+ case "wallet_getPermissions":
449
+ await this.safeProbe();
450
+ if (this.account) {
451
+ return [Permission.ACCOUNTS];
404
452
  }
405
- case "wallet_watchAsset":
406
- throw {
407
- code: 63,
408
- message: "An unexpected error occurred",
409
- data: "wallet_watchAsset not implemented"
410
- };
411
- case "wallet_addStarknetChain": {
412
- let params2 = call.params;
413
- return this.addStarknetChain(params2);
453
+ return [];
454
+ case "wallet_requestAccounts": {
455
+ if (this.account) {
456
+ return [this.account.address];
457
+ }
458
+ const silentMode = call.params && call.params.silent_mode;
459
+ this.account = await this.safeProbe();
460
+ if (!this.account && !silentMode) {
461
+ this.account = await this.connect();
414
462
  }
415
- case "wallet_switchStarknetChain": {
416
- let params2 = call.params;
417
- return this.switchStarknetChain(params2.chainId);
463
+ if (this.account) {
464
+ return [this.account.address];
418
465
  }
419
- case "wallet_requestChainId":
420
- if (!this.account) {
421
- throw {
422
- code: 63,
423
- message: "An unexpected error occurred",
424
- data: "Account not initialized"
425
- };
426
- }
427
- return await this.account.getChainId();
428
- case "wallet_deploymentData":
466
+ return [];
467
+ }
468
+ case "wallet_watchAsset":
469
+ throw {
470
+ code: 63,
471
+ message: "An unexpected error occurred",
472
+ data: "wallet_watchAsset not implemented"
473
+ };
474
+ case "wallet_addStarknetChain": {
475
+ let params2 = call.params;
476
+ return this.addStarknetChain(params2);
477
+ }
478
+ case "wallet_switchStarknetChain": {
479
+ let params2 = call.params;
480
+ return this.switchStarknetChain(params2.chainId);
481
+ }
482
+ case "wallet_requestChainId":
483
+ if (!this.account) {
429
484
  throw {
430
485
  code: 63,
431
486
  message: "An unexpected error occurred",
432
- data: "wallet_deploymentData not implemented"
487
+ data: "Account not initialized"
433
488
  };
434
- case "wallet_addInvokeTransaction":
435
- if (!this.account) {
436
- throw {
437
- code: 63,
438
- message: "An unexpected error occurred",
439
- data: "Account not initialized"
440
- };
441
- }
442
- let params = call.params;
443
- return await this.account.execute(
444
- params.calls.map((call2) => ({
445
- contractAddress: call2.contract_address,
446
- entrypoint: call2.entry_point,
447
- calldata: call2.calldata
448
- }))
449
- );
450
- case "wallet_addDeclareTransaction":
489
+ }
490
+ return await this.account.getChainId();
491
+ case "wallet_deploymentData":
492
+ throw {
493
+ code: 63,
494
+ message: "An unexpected error occurred",
495
+ data: "wallet_deploymentData not implemented"
496
+ };
497
+ case "wallet_addInvokeTransaction":
498
+ if (!this.account) {
451
499
  throw {
452
500
  code: 63,
453
501
  message: "An unexpected error occurred",
454
- data: "wallet_addDeclareTransaction not implemented"
502
+ data: "Account not initialized"
455
503
  };
456
- case "wallet_signTypedData": {
457
- if (!this.account) {
458
- throw {
459
- code: 63,
460
- message: "An unexpected error occurred",
461
- data: "Account not initialized"
462
- };
463
- }
464
- return await this.account.signMessage(call.params);
465
504
  }
466
- case "wallet_supportedSpecs":
467
- return [];
468
- case "wallet_supportedWalletApi":
469
- return [];
470
- default:
505
+ let params = call.params;
506
+ return await this.account.execute(
507
+ params.calls.map((call2) => ({
508
+ contractAddress: call2.contract_address,
509
+ entrypoint: call2.entry_point,
510
+ calldata: call2.calldata
511
+ }))
512
+ );
513
+ case "wallet_addDeclareTransaction":
514
+ throw {
515
+ code: 63,
516
+ message: "An unexpected error occurred",
517
+ data: "wallet_addDeclareTransaction not implemented"
518
+ };
519
+ case "wallet_signTypedData": {
520
+ if (!this.account) {
471
521
  throw {
472
522
  code: 63,
473
523
  message: "An unexpected error occurred",
474
- data: `Unknown RPC call type: ${call.type}`
524
+ data: "Account not initialized"
475
525
  };
526
+ }
527
+ return await this.account.signMessage(call.params);
476
528
  }
477
- };
478
- this.on = (event, handler) => {
479
- if (event !== "accountsChanged" && event !== "networkChanged") {
480
- throw new Error(`Unknown event: ${event}`);
481
- }
482
- this.subscriptions.push({ type: event, handler });
483
- };
484
- this.off = (event, handler) => {
485
- if (event !== "accountsChanged" && event !== "networkChanged") {
486
- throw new Error(`Unknown event: ${event}`);
487
- }
488
- const idx = this.subscriptions.findIndex(
489
- (sub) => sub.type === event && sub.handler === handler
490
- );
491
- if (idx >= 0) {
492
- this.subscriptions.splice(idx, 1);
493
- }
494
- };
495
- }
529
+ case "wallet_supportedSpecs":
530
+ return [];
531
+ case "wallet_supportedWalletApi":
532
+ return [];
533
+ default:
534
+ throw {
535
+ code: 63,
536
+ message: "An unexpected error occurred",
537
+ data: `Unknown RPC call type: ${call.type}`
538
+ };
539
+ }
540
+ };
541
+ on = (event, handler) => {
542
+ if (event !== "accountsChanged" && event !== "networkChanged") {
543
+ throw new Error(`Unknown event: ${event}`);
544
+ }
545
+ this.subscriptions.push({ type: event, handler });
546
+ };
547
+ off = (event, handler) => {
548
+ if (event !== "accountsChanged" && event !== "networkChanged") {
549
+ throw new Error(`Unknown event: ${event}`);
550
+ }
551
+ const idx = this.subscriptions.findIndex(
552
+ (sub) => sub.type === event && sub.handler === handler
553
+ );
554
+ if (idx >= 0) {
555
+ this.subscriptions.splice(idx, 1);
556
+ }
557
+ };
496
558
  emitNetworkChanged(chainId) {
497
559
  this.subscriptions.filter((sub) => sub.type === "networkChanged").forEach((sub) => {
498
560
  sub.handler(chainId);
@@ -507,6 +569,12 @@ var BaseProvider = class {
507
569
 
508
570
  // src/controller.ts
509
571
  var ControllerProvider = class extends BaseProvider {
572
+ keychain;
573
+ profile;
574
+ options;
575
+ iframes;
576
+ selectedChain;
577
+ chains;
510
578
  constructor(options) {
511
579
  super();
512
580
  const chains = /* @__PURE__ */ new Map();