@cloud-copilot/iam-lens 0.1.24 → 0.1.26

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 (148) hide show
  1. package/dist/cjs/cli.js +9 -3
  2. package/dist/cjs/cli.js.map +1 -1
  3. package/dist/cjs/collect/client.d.ts +12 -3
  4. package/dist/cjs/collect/client.d.ts.map +1 -1
  5. package/dist/cjs/collect/client.js +237 -152
  6. package/dist/cjs/collect/client.js.map +1 -1
  7. package/dist/cjs/collect/collect.d.ts +2 -2
  8. package/dist/cjs/collect/collect.d.ts.map +1 -1
  9. package/dist/cjs/collect/collect.js +2 -2
  10. package/dist/cjs/collect/collect.js.map +1 -1
  11. package/dist/cjs/principals.d.ts +10 -0
  12. package/dist/cjs/principals.d.ts.map +1 -1
  13. package/dist/cjs/principals.js +33 -1
  14. package/dist/cjs/principals.js.map +1 -1
  15. package/dist/cjs/simulate/contextKeys.d.ts.map +1 -1
  16. package/dist/cjs/simulate/contextKeys.js +4 -1
  17. package/dist/cjs/simulate/contextKeys.js.map +1 -1
  18. package/dist/cjs/simulate/simulate.d.ts +1 -0
  19. package/dist/cjs/simulate/simulate.d.ts.map +1 -1
  20. package/dist/cjs/simulate/simulate.js +4 -0
  21. package/dist/cjs/simulate/simulate.js.map +1 -1
  22. package/dist/cjs/test-datasets/testClient.d.ts +2 -0
  23. package/dist/cjs/test-datasets/testClient.d.ts.map +1 -1
  24. package/dist/cjs/test-datasets/testClient.js +12 -0
  25. package/dist/cjs/test-datasets/testClient.js.map +1 -1
  26. package/dist/cjs/utils/workerScript.d.ts +8 -0
  27. package/dist/cjs/utils/workerScript.d.ts.map +1 -0
  28. package/dist/cjs/utils/workerScript.js +18 -0
  29. package/dist/cjs/utils/workerScript.js.map +1 -0
  30. package/dist/cjs/whoCan/WhoCanMainThreadWorker.d.ts +14 -0
  31. package/dist/cjs/whoCan/WhoCanMainThreadWorker.d.ts.map +1 -0
  32. package/dist/cjs/whoCan/WhoCanMainThreadWorker.js +34 -0
  33. package/dist/cjs/whoCan/WhoCanMainThreadWorker.js.map +1 -0
  34. package/dist/cjs/whoCan/WhoCanWorker.d.ts +12 -0
  35. package/dist/cjs/whoCan/WhoCanWorker.d.ts.map +1 -0
  36. package/dist/cjs/whoCan/WhoCanWorker.js +71 -0
  37. package/dist/cjs/whoCan/WhoCanWorker.js.map +1 -0
  38. package/dist/cjs/whoCan/WhoCanWorkerThreadWorker.d.ts +2 -0
  39. package/dist/cjs/whoCan/WhoCanWorkerThreadWorker.d.ts.map +1 -0
  40. package/dist/cjs/whoCan/WhoCanWorkerThreadWorker.js +46 -0
  41. package/dist/cjs/whoCan/WhoCanWorkerThreadWorker.js.map +1 -0
  42. package/dist/cjs/whoCan/whoCan.d.ts +2 -1
  43. package/dist/cjs/whoCan/whoCan.d.ts.map +1 -1
  44. package/dist/cjs/whoCan/whoCan.js +111 -77
  45. package/dist/cjs/whoCan/whoCan.js.map +1 -1
  46. package/dist/cjs/workers/ArrayStreamingWorkQueue.d.ts +15 -0
  47. package/dist/cjs/workers/ArrayStreamingWorkQueue.d.ts.map +1 -0
  48. package/dist/cjs/workers/ArrayStreamingWorkQueue.js +35 -0
  49. package/dist/cjs/workers/ArrayStreamingWorkQueue.js.map +1 -0
  50. package/dist/cjs/workers/JobRunner.d.ts +47 -0
  51. package/dist/cjs/workers/JobRunner.d.ts.map +1 -0
  52. package/dist/cjs/workers/JobRunner.js +101 -0
  53. package/dist/cjs/workers/JobRunner.js.map +1 -0
  54. package/dist/cjs/workers/RingQueue.d.ts +14 -0
  55. package/dist/cjs/workers/RingQueue.d.ts.map +1 -0
  56. package/dist/cjs/workers/RingQueue.js +43 -0
  57. package/dist/cjs/workers/RingQueue.js.map +1 -0
  58. package/dist/cjs/workers/SharedArrayBufferMainCache.d.ts +10 -0
  59. package/dist/cjs/workers/SharedArrayBufferMainCache.d.ts.map +1 -0
  60. package/dist/cjs/workers/SharedArrayBufferMainCache.js +37 -0
  61. package/dist/cjs/workers/SharedArrayBufferMainCache.js.map +1 -0
  62. package/dist/cjs/workers/SharedArrayBufferWorkerCache.d.ts +10 -0
  63. package/dist/cjs/workers/SharedArrayBufferWorkerCache.d.ts.map +1 -0
  64. package/dist/cjs/workers/SharedArrayBufferWorkerCache.js +49 -0
  65. package/dist/cjs/workers/SharedArrayBufferWorkerCache.js.map +1 -0
  66. package/dist/cjs/workers/StreamingWorkQueue.d.ts +18 -0
  67. package/dist/cjs/workers/StreamingWorkQueue.d.ts.map +1 -0
  68. package/dist/cjs/workers/StreamingWorkQueue.js +67 -0
  69. package/dist/cjs/workers/StreamingWorkQueue.js.map +1 -0
  70. package/dist/cjs/workers/buffers.d.ts +4 -0
  71. package/dist/cjs/workers/buffers.d.ts.map +1 -0
  72. package/dist/cjs/workers/buffers.js +26 -0
  73. package/dist/cjs/workers/buffers.js.map +1 -0
  74. package/dist/esm/cli.js +9 -3
  75. package/dist/esm/cli.js.map +1 -1
  76. package/dist/esm/collect/client.d.ts +12 -3
  77. package/dist/esm/collect/client.d.ts.map +1 -1
  78. package/dist/esm/collect/client.js +236 -150
  79. package/dist/esm/collect/client.js.map +1 -1
  80. package/dist/esm/collect/collect.d.ts +2 -2
  81. package/dist/esm/collect/collect.d.ts.map +1 -1
  82. package/dist/esm/collect/collect.js +2 -2
  83. package/dist/esm/collect/collect.js.map +1 -1
  84. package/dist/esm/principals.d.ts +10 -0
  85. package/dist/esm/principals.d.ts.map +1 -1
  86. package/dist/esm/principals.js +30 -1
  87. package/dist/esm/principals.js.map +1 -1
  88. package/dist/esm/simulate/contextKeys.d.ts.map +1 -1
  89. package/dist/esm/simulate/contextKeys.js +4 -1
  90. package/dist/esm/simulate/contextKeys.js.map +1 -1
  91. package/dist/esm/simulate/simulate.d.ts +1 -0
  92. package/dist/esm/simulate/simulate.d.ts.map +1 -1
  93. package/dist/esm/simulate/simulate.js +5 -1
  94. package/dist/esm/simulate/simulate.js.map +1 -1
  95. package/dist/esm/test-datasets/testClient.d.ts +2 -0
  96. package/dist/esm/test-datasets/testClient.d.ts.map +1 -1
  97. package/dist/esm/test-datasets/testClient.js +11 -0
  98. package/dist/esm/test-datasets/testClient.js.map +1 -1
  99. package/dist/esm/utils/workerScript.d.ts +8 -0
  100. package/dist/esm/utils/workerScript.d.ts.map +1 -0
  101. package/dist/esm/utils/workerScript.js +13 -0
  102. package/dist/esm/utils/workerScript.js.map +1 -0
  103. package/dist/esm/utils/workerScriptEsm.d.ts.map +1 -0
  104. package/dist/esm/whoCan/WhoCanMainThreadWorker.d.ts +14 -0
  105. package/dist/esm/whoCan/WhoCanMainThreadWorker.d.ts.map +1 -0
  106. package/dist/esm/whoCan/WhoCanMainThreadWorker.js +28 -0
  107. package/dist/esm/whoCan/WhoCanMainThreadWorker.js.map +1 -0
  108. package/dist/esm/whoCan/WhoCanWorker.d.ts +12 -0
  109. package/dist/esm/whoCan/WhoCanWorker.d.ts.map +1 -0
  110. package/dist/esm/whoCan/WhoCanWorker.js +67 -0
  111. package/dist/esm/whoCan/WhoCanWorker.js.map +1 -0
  112. package/dist/esm/whoCan/WhoCanWorkerThreadWorker.d.ts +2 -0
  113. package/dist/esm/whoCan/WhoCanWorkerThreadWorker.d.ts.map +1 -0
  114. package/dist/esm/whoCan/WhoCanWorkerThreadWorker.js +44 -0
  115. package/dist/esm/whoCan/WhoCanWorkerThreadWorker.js.map +1 -0
  116. package/dist/esm/whoCan/whoCan.d.ts +2 -1
  117. package/dist/esm/whoCan/whoCan.d.ts.map +1 -1
  118. package/dist/esm/whoCan/whoCan.js +111 -77
  119. package/dist/esm/whoCan/whoCan.js.map +1 -1
  120. package/dist/esm/workers/ArrayStreamingWorkQueue.d.ts +15 -0
  121. package/dist/esm/workers/ArrayStreamingWorkQueue.d.ts.map +1 -0
  122. package/dist/esm/workers/ArrayStreamingWorkQueue.js +31 -0
  123. package/dist/esm/workers/ArrayStreamingWorkQueue.js.map +1 -0
  124. package/dist/esm/workers/JobRunner.d.ts +47 -0
  125. package/dist/esm/workers/JobRunner.d.ts.map +1 -0
  126. package/dist/esm/workers/JobRunner.js +93 -0
  127. package/dist/esm/workers/JobRunner.js.map +1 -0
  128. package/dist/esm/workers/RingQueue.d.ts +14 -0
  129. package/dist/esm/workers/RingQueue.d.ts.map +1 -0
  130. package/dist/esm/workers/RingQueue.js +36 -0
  131. package/dist/esm/workers/RingQueue.js.map +1 -0
  132. package/dist/esm/workers/SharedArrayBufferMainCache.d.ts +10 -0
  133. package/dist/esm/workers/SharedArrayBufferMainCache.d.ts.map +1 -0
  134. package/dist/esm/workers/SharedArrayBufferMainCache.js +33 -0
  135. package/dist/esm/workers/SharedArrayBufferMainCache.js.map +1 -0
  136. package/dist/esm/workers/SharedArrayBufferWorkerCache.d.ts +10 -0
  137. package/dist/esm/workers/SharedArrayBufferWorkerCache.d.ts.map +1 -0
  138. package/dist/esm/workers/SharedArrayBufferWorkerCache.js +44 -0
  139. package/dist/esm/workers/SharedArrayBufferWorkerCache.js.map +1 -0
  140. package/dist/esm/workers/StreamingWorkQueue.d.ts +18 -0
  141. package/dist/esm/workers/StreamingWorkQueue.d.ts.map +1 -0
  142. package/dist/esm/workers/StreamingWorkQueue.js +61 -0
  143. package/dist/esm/workers/StreamingWorkQueue.js.map +1 -0
  144. package/dist/esm/workers/buffers.d.ts +4 -0
  145. package/dist/esm/workers/buffers.d.ts.map +1 -0
  146. package/dist/esm/workers/buffers.js +21 -0
  147. package/dist/esm/workers/buffers.js.map +1 -0
  148. package/package.json +6 -4
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SharedArrayBufferMainCache.d.ts","sourceRoot":"","sources":["../../../src/workers/SharedArrayBufferMainCache.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;AAGvC,MAAM,WAAW,KAAK;IACpB,SAAS,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAA;CACtE;AAED,qBAAa,0BAA2B,YAAW,KAAK;IACtD,OAAO,CAAC,KAAK,CAAwC;gBAEzC,OAAO,EAAE,MAAM,EAAE;IAkBvB,SAAS,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;CAS5E"}
@@ -0,0 +1,33 @@
1
+ import { convertArrayBufferToObject, convertObjectToArrayBuffer } from './buffers.js';
2
+ //TODO: Add a Prefix to avoid collisions if there are multiple caches
3
+ export class SharedArrayBufferMainCache {
4
+ constructor(workers) {
5
+ this.cache = {};
6
+ for (const worker of workers) {
7
+ worker.on('message', (message) => {
8
+ if (message.type === 'getCache') {
9
+ const cacheKey = message.cacheKey;
10
+ const value = this.cache[cacheKey];
11
+ if (value) {
12
+ worker.postMessage({ type: 'cacheHit', cacheKey, value });
13
+ }
14
+ else {
15
+ worker.postMessage({ type: 'cacheMiss', cacheKey });
16
+ }
17
+ }
18
+ else if (message.type === 'saveCache') {
19
+ this.cache[message.cacheKey] = message.value;
20
+ }
21
+ });
22
+ }
23
+ }
24
+ async withCache(cacheKey, fetcher) {
25
+ if (this.cache[cacheKey]) {
26
+ return convertArrayBufferToObject(this.cache[cacheKey]);
27
+ }
28
+ const result = await fetcher();
29
+ this.cache[cacheKey] = convertObjectToArrayBuffer(result);
30
+ return result;
31
+ }
32
+ }
33
+ //# sourceMappingURL=SharedArrayBufferMainCache.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SharedArrayBufferMainCache.js","sourceRoot":"","sources":["../../../src/workers/SharedArrayBufferMainCache.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,0BAA0B,EAAE,0BAA0B,EAAE,MAAM,cAAc,CAAA;AAKrF,qEAAqE;AACrE,MAAM,OAAO,0BAA0B;IAGrC,YAAY,OAAiB;QAFrB,UAAK,GAAsC,EAAE,CAAA;QAGnD,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC7B,MAAM,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,OAAO,EAAE,EAAE;gBAC/B,IAAI,OAAO,CAAC,IAAI,KAAK,UAAU,EAAE,CAAC;oBAChC,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAA;oBACjC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;oBAClC,IAAI,KAAK,EAAE,CAAC;wBACV,MAAM,CAAC,WAAW,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAA;oBAC3D,CAAC;yBAAM,CAAC;wBACN,MAAM,CAAC,WAAW,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,QAAQ,EAAE,CAAC,CAAA;oBACrD,CAAC;gBACH,CAAC;qBAAM,IAAI,OAAO,CAAC,IAAI,KAAK,WAAW,EAAE,CAAC;oBACxC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,OAAO,CAAC,KAAK,CAAA;gBAC9C,CAAC;YACH,CAAC,CAAC,CAAA;QACJ,CAAC;IACH,CAAC;IAED,KAAK,CAAC,SAAS,CAAI,QAAgB,EAAE,OAAyB;QAC5D,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC;YACzB,OAAO,0BAA0B,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAA;QACzD,CAAC;QAED,MAAM,MAAM,GAAG,MAAM,OAAO,EAAE,CAAA;QAC9B,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,0BAA0B,CAAC,MAAM,CAAC,CAAA;QACzD,OAAO,MAAM,CAAA;IACf,CAAC;CACF"}
@@ -0,0 +1,10 @@
1
+ import { MessagePort } from 'worker_threads';
2
+ import { Cache } from './SharedArrayBufferMainCache.js';
3
+ export declare class SharedArrayBufferWorkerCache implements Cache {
4
+ private parentPort;
5
+ private requestPromiseMap;
6
+ private parentPromiseMap;
7
+ constructor(parentPort: MessagePort);
8
+ withCache<T>(cacheKey: string, fetcher: () => Promise<T>): Promise<T>;
9
+ }
10
+ //# sourceMappingURL=SharedArrayBufferWorkerCache.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SharedArrayBufferWorkerCache.d.ts","sourceRoot":"","sources":["../../../src/workers/SharedArrayBufferWorkerCache.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,iCAAiC,CAAA;AAIvD,qBAAa,4BAA6B,YAAW,KAAK;IAI5C,OAAO,CAAC,UAAU;IAH9B,OAAO,CAAC,iBAAiB,CAA+C;IACxE,OAAO,CAAC,gBAAgB,CAAiE;gBAErE,UAAU,EAAE,WAAW;IAYrC,SAAS,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;CA6B5E"}
@@ -0,0 +1,44 @@
1
+ import { convertArrayBufferToObject, convertObjectToArrayBuffer } from './buffers.js';
2
+ //TODO: Add a Prefix to avoid collisions if there are multiple caches
3
+ export class SharedArrayBufferWorkerCache {
4
+ constructor(parentPort) {
5
+ this.parentPort = parentPort;
6
+ this.requestPromiseMap = {};
7
+ this.parentPromiseMap = {};
8
+ this.parentPort.on('message', (msg) => {
9
+ if (msg.type === 'cacheHit' || msg.type === 'cacheMiss') {
10
+ const resolver = this.parentPromiseMap[msg.cacheKey];
11
+ if (resolver) {
12
+ delete this.parentPromiseMap[msg.cacheKey]; // clean up
13
+ resolver(msg.type === 'cacheHit' ? msg.value : false);
14
+ }
15
+ }
16
+ });
17
+ }
18
+ async withCache(cacheKey, fetcher) {
19
+ if (this.requestPromiseMap[cacheKey]) {
20
+ return this.requestPromiseMap[cacheKey];
21
+ }
22
+ this.requestPromiseMap[cacheKey] = (async () => {
23
+ try {
24
+ const parentPromise = new Promise((resolve) => {
25
+ this.parentPromiseMap[cacheKey] = resolve;
26
+ this.parentPort.postMessage({ type: 'getCache', cacheKey });
27
+ });
28
+ const response = await parentPromise;
29
+ if (response === false) {
30
+ const theValue = await fetcher(); // your async loader
31
+ const arrayBuffer = convertObjectToArrayBuffer(theValue);
32
+ this.parentPort.postMessage({ type: 'saveCache', cacheKey, value: arrayBuffer });
33
+ return theValue;
34
+ }
35
+ return convertArrayBufferToObject(response);
36
+ }
37
+ finally {
38
+ delete this.requestPromiseMap[cacheKey]; // Clean up the queue regardless of success or failure.
39
+ }
40
+ })();
41
+ return this.requestPromiseMap[cacheKey];
42
+ }
43
+ }
44
+ //# sourceMappingURL=SharedArrayBufferWorkerCache.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SharedArrayBufferWorkerCache.js","sourceRoot":"","sources":["../../../src/workers/SharedArrayBufferWorkerCache.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,0BAA0B,EAAE,0BAA0B,EAAE,MAAM,cAAc,CAAA;AAErF,qEAAqE;AACrE,MAAM,OAAO,4BAA4B;IAIvC,YAAoB,UAAuB;QAAvB,eAAU,GAAV,UAAU,CAAa;QAHnC,sBAAiB,GAA6C,EAAE,CAAA;QAChE,qBAAgB,GAA+D,EAAE,CAAA;QAGvF,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,GAAG,EAAE,EAAE;YACpC,IAAI,GAAG,CAAC,IAAI,KAAK,UAAU,IAAI,GAAG,CAAC,IAAI,KAAK,WAAW,EAAE,CAAC;gBACxD,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;gBACpD,IAAI,QAAQ,EAAE,CAAC;oBACb,OAAO,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA,CAAC,WAAW;oBACtD,QAAQ,CAAC,GAAG,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAA;gBACvD,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,KAAK,CAAC,SAAS,CAAI,QAAgB,EAAE,OAAyB;QAC5D,IAAI,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,EAAE,CAAC;YACrC,OAAO,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAA;QACzC,CAAC;QAED,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,IAAI,EAAE;YAC7C,IAAI,CAAC;gBACH,MAAM,aAAa,GAAG,IAAI,OAAO,CAA4B,CAAC,OAAO,EAAE,EAAE;oBACvE,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,GAAG,OAAO,CAAA;oBACzC,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,CAAC,CAAA;gBAC7D,CAAC,CAAC,CAAA;gBAEF,MAAM,QAAQ,GAAG,MAAM,aAAa,CAAA;gBAEpC,IAAI,QAAQ,KAAK,KAAK,EAAE,CAAC;oBACvB,MAAM,QAAQ,GAAG,MAAM,OAAO,EAAE,CAAA,CAAC,oBAAoB;oBACrD,MAAM,WAAW,GAAG,0BAA0B,CAAC,QAAQ,CAAC,CAAA;oBACxD,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,QAAQ,EAAE,KAAK,EAAE,WAAW,EAAE,CAAC,CAAA;oBAChF,OAAO,QAAQ,CAAA;gBACjB,CAAC;gBAED,OAAO,0BAA0B,CAAC,QAAQ,CAAC,CAAA;YAC7C,CAAC;oBAAS,CAAC;gBACT,OAAO,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAA,CAAC,uDAAuD;YACjG,CAAC;QACH,CAAC,CAAC,EAAE,CAAA;QAEJ,OAAO,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAA;IACzC,CAAC;CACF"}
@@ -0,0 +1,18 @@
1
+ export interface StreamingWorkQueueOptions {
2
+ ringCapacity?: number;
3
+ }
4
+ export declare class StreamingWorkQueue<T> {
5
+ private ringCapacity;
6
+ private rings;
7
+ private enqueueIndex;
8
+ private dequeueIndex;
9
+ private onWorkAvailable?;
10
+ private notifyScheduled;
11
+ constructor(options?: StreamingWorkQueueOptions);
12
+ setWorkAvailableCallback(callback: () => void): void;
13
+ enqueue(item: T): void;
14
+ dequeue(): T | undefined;
15
+ length(): number;
16
+ private scheduleNotify;
17
+ }
18
+ //# sourceMappingURL=StreamingWorkQueue.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StreamingWorkQueue.d.ts","sourceRoot":"","sources":["../../../src/workers/StreamingWorkQueue.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,yBAAyB;IACxC,YAAY,CAAC,EAAE,MAAM,CAAA;CACtB;AAED,qBAAa,kBAAkB,CAAC,CAAC;IAC/B,OAAO,CAAC,YAAY,CAAO;IAC3B,OAAO,CAAC,KAAK,CAAgB;IAC7B,OAAO,CAAC,YAAY,CAAI;IACxB,OAAO,CAAC,YAAY,CAAI;IACxB,OAAO,CAAC,eAAe,CAAC,CAAY;IACpC,OAAO,CAAC,eAAe,CAAQ;gBAEnB,OAAO,GAAE,yBAA8B;IAO5C,wBAAwB,CAAC,QAAQ,EAAE,MAAM,IAAI,GAAG,IAAI;IAIpD,OAAO,CAAC,IAAI,EAAE,CAAC,GAAG,IAAI;IAqBtB,OAAO,IAAI,CAAC,GAAG,SAAS;IAcxB,MAAM,IAAI,MAAM;IAIvB,OAAO,CAAC,cAAc;CAavB"}
@@ -0,0 +1,61 @@
1
+ import { RingQueue } from './RingQueue.js';
2
+ export class StreamingWorkQueue {
3
+ constructor(options = {}) {
4
+ this.ringCapacity = 1024;
5
+ this.enqueueIndex = 0;
6
+ this.dequeueIndex = 0;
7
+ this.notifyScheduled = false;
8
+ if (options.ringCapacity) {
9
+ this.ringCapacity = options.ringCapacity;
10
+ }
11
+ this.rings = [new RingQueue(this.ringCapacity)];
12
+ }
13
+ setWorkAvailableCallback(callback) {
14
+ this.onWorkAvailable = callback;
15
+ }
16
+ enqueue(item) {
17
+ let attempts = 0;
18
+ while (attempts < this.rings.length) {
19
+ const ring = this.rings[this.enqueueIndex];
20
+ if (ring.enqueue(item)) {
21
+ this.scheduleNotify();
22
+ return;
23
+ }
24
+ this.enqueueIndex = (this.enqueueIndex + 1) % this.rings.length;
25
+ attempts++;
26
+ }
27
+ // All rings full, create a new one
28
+ const newRing = new RingQueue(this.ringCapacity);
29
+ newRing.enqueue(item);
30
+ this.rings.push(newRing);
31
+ this.enqueueIndex = this.rings.length - 1;
32
+ this.scheduleNotify();
33
+ }
34
+ dequeue() {
35
+ let attempts = 0;
36
+ while (attempts < this.rings.length) {
37
+ const ring = this.rings[this.dequeueIndex];
38
+ const item = ring.dequeue();
39
+ if (item !== undefined)
40
+ return item;
41
+ this.dequeueIndex = (this.dequeueIndex + 1) % this.rings.length;
42
+ attempts++;
43
+ }
44
+ return undefined;
45
+ }
46
+ length() {
47
+ return this.rings.reduce((sum, ring) => sum + ring.length(), 0);
48
+ }
49
+ scheduleNotify() {
50
+ if (this.notifyScheduled || !this.onWorkAvailable) {
51
+ return;
52
+ }
53
+ this.notifyScheduled = true;
54
+ // Use a microtask to debounce notifications
55
+ queueMicrotask(() => {
56
+ this.notifyScheduled = false;
57
+ this.onWorkAvailable?.();
58
+ });
59
+ }
60
+ }
61
+ //# sourceMappingURL=StreamingWorkQueue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StreamingWorkQueue.js","sourceRoot":"","sources":["../../../src/workers/StreamingWorkQueue.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAM1C,MAAM,OAAO,kBAAkB;IAQ7B,YAAY,UAAqC,EAAE;QAP3C,iBAAY,GAAG,IAAI,CAAA;QAEnB,iBAAY,GAAG,CAAC,CAAA;QAChB,iBAAY,GAAG,CAAC,CAAA;QAEhB,oBAAe,GAAG,KAAK,CAAA;QAG7B,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;YACzB,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,YAAY,CAAA;QAC1C,CAAC;QACD,IAAI,CAAC,KAAK,GAAG,CAAC,IAAI,SAAS,CAAI,IAAI,CAAC,YAAY,CAAC,CAAC,CAAA;IACpD,CAAC;IAEM,wBAAwB,CAAC,QAAoB;QAClD,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAA;IACjC,CAAC;IAEM,OAAO,CAAC,IAAO;QACpB,IAAI,QAAQ,GAAG,CAAC,CAAA;QAChB,OAAO,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;YACpC,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;YAC1C,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;gBACvB,IAAI,CAAC,cAAc,EAAE,CAAA;gBACrB,OAAM;YACR,CAAC;YAED,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAA;YAC/D,QAAQ,EAAE,CAAA;QACZ,CAAC;QAED,mCAAmC;QACnC,MAAM,OAAO,GAAG,IAAI,SAAS,CAAI,IAAI,CAAC,YAAY,CAAC,CAAA;QACnD,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;QACrB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;QACxB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAA;QACzC,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAEM,OAAO;QACZ,IAAI,QAAQ,GAAG,CAAC,CAAA;QAChB,OAAO,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;YACpC,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;YAC1C,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE,CAAA;YAC3B,IAAI,IAAI,KAAK,SAAS;gBAAE,OAAO,IAAI,CAAA;YAEnC,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAA;YAC/D,QAAQ,EAAE,CAAA;QACZ,CAAC;QAED,OAAO,SAAS,CAAA;IAClB,CAAC;IAEM,MAAM;QACX,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,CAAA;IACjE,CAAC;IAEO,cAAc;QACpB,IAAI,IAAI,CAAC,eAAe,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;YAClD,OAAM;QACR,CAAC;QAED,IAAI,CAAC,eAAe,GAAG,IAAI,CAAA;QAE3B,4CAA4C;QAC5C,cAAc,CAAC,GAAG,EAAE;YAClB,IAAI,CAAC,eAAe,GAAG,KAAK,CAAA;YAC5B,IAAI,CAAC,eAAe,EAAE,EAAE,CAAA;QAC1B,CAAC,CAAC,CAAA;IACJ,CAAC;CACF"}
@@ -0,0 +1,4 @@
1
+ export declare function convertArrayBufferToString(buffer: SharedArrayBuffer): string;
2
+ export declare function convertArrayBufferToObject<T>(buffer: SharedArrayBuffer): T;
3
+ export declare function convertObjectToArrayBuffer<T>(obj: T): SharedArrayBuffer;
4
+ //# sourceMappingURL=buffers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buffers.d.ts","sourceRoot":"","sources":["../../../src/workers/buffers.ts"],"names":[],"mappings":"AAAA,wBAAgB,0BAA0B,CAAC,MAAM,EAAE,iBAAiB,GAAG,MAAM,CAG5E;AAED,wBAAgB,0BAA0B,CAAC,CAAC,EAAE,MAAM,EAAE,iBAAiB,GAAG,CAAC,CAM1E;AAED,wBAAgB,0BAA0B,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,iBAAiB,CAQvE"}
@@ -0,0 +1,21 @@
1
+ export function convertArrayBufferToString(buffer) {
2
+ const view = new Uint8Array(buffer);
3
+ return new TextDecoder().decode(view);
4
+ }
5
+ export function convertArrayBufferToObject(buffer) {
6
+ if (!buffer || buffer.byteLength === 0) {
7
+ return undefined;
8
+ }
9
+ const jsonString = convertArrayBufferToString(buffer);
10
+ return JSON.parse(jsonString);
11
+ }
12
+ export function convertObjectToArrayBuffer(obj) {
13
+ const jsonString = JSON.stringify(obj);
14
+ const encoder = new TextEncoder();
15
+ const byteArray = encoder.encode(jsonString);
16
+ const buffer = new SharedArrayBuffer(byteArray.length);
17
+ const view = new Uint8Array(buffer);
18
+ view.set(byteArray);
19
+ return buffer;
20
+ }
21
+ //# sourceMappingURL=buffers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buffers.js","sourceRoot":"","sources":["../../../src/workers/buffers.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,0BAA0B,CAAC,MAAyB;IAClE,MAAM,IAAI,GAAG,IAAI,UAAU,CAAC,MAAM,CAAC,CAAA;IACnC,OAAO,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;AACvC,CAAC;AAED,MAAM,UAAU,0BAA0B,CAAI,MAAyB;IACrE,IAAI,CAAC,MAAM,IAAI,MAAM,CAAC,UAAU,KAAK,CAAC,EAAE,CAAC;QACvC,OAAO,SAAyB,CAAA;IAClC,CAAC;IACD,MAAM,UAAU,GAAG,0BAA0B,CAAC,MAAM,CAAC,CAAA;IACrD,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAM,CAAA;AACpC,CAAC;AAED,MAAM,UAAU,0BAA0B,CAAI,GAAM;IAClD,MAAM,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAA;IACtC,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAA;IACjC,MAAM,SAAS,GAAG,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,CAAA;IAC5C,MAAM,MAAM,GAAG,IAAI,iBAAiB,CAAC,SAAS,CAAC,MAAM,CAAC,CAAA;IACtD,MAAM,IAAI,GAAG,IAAI,UAAU,CAAC,MAAM,CAAC,CAAA;IACnC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;IACnB,OAAO,MAAM,CAAA;AACf,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cloud-copilot/iam-lens",
3
- "version": "0.1.24",
3
+ "version": "0.1.26",
4
4
  "description": "Visibility in IAM in and across AWS accounts",
5
5
  "keywords": [
6
6
  "aws",
@@ -111,12 +111,14 @@
111
111
  },
112
112
  "dependencies": {
113
113
  "@cloud-copilot/cli": "^0.1.30",
114
- "@cloud-copilot/iam-collect": "^0.1.86",
114
+ "@cloud-copilot/iam-collect": "^0.1.92",
115
115
  "@cloud-copilot/iam-data": "^0.9.202505242",
116
116
  "@cloud-copilot/iam-expand": "^0.11.13",
117
117
  "@cloud-copilot/iam-policy": "^0.1.35",
118
118
  "@cloud-copilot/iam-shrink": "^0.1.21",
119
- "@cloud-copilot/iam-simulate": "^0.1.57",
120
- "@cloud-copilot/iam-utils": "^0.1.7"
119
+ "@cloud-copilot/iam-simulate": "^0.1.60",
120
+ "@cloud-copilot/iam-utils": "^0.1.7",
121
+ "@cloud-copilot/job": "^0.1.0",
122
+ "@cloud-copilot/log": "^0.1.0"
121
123
  }
122
124
  }