@learncard/learn-cloud-client 1.4.16 → 1.4.18

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/CHANGELOG.md CHANGED
@@ -1,5 +1,18 @@
1
1
  # @learncard/network-brain-client
2
2
 
3
+ ## 1.4.18
4
+
5
+ ### Patch Changes
6
+
7
+ - [#801](https://github.com/learningeconomy/LearnCard/pull/801) [`53da9a38a1cc07d2c4c5721dd3a9d9ddc4ecb316`](https://github.com/learningeconomy/LearnCard/commit/53da9a38a1cc07d2c4c5721dd3a9d9ddc4ecb316) Thanks [@TaylorBeeston](https://github.com/TaylorBeeston)! - Lower the `maxItems` in the tRPC client to 50 to prevent AWS payload response limits
8
+
9
+ ## 1.4.17
10
+
11
+ ### Patch Changes
12
+
13
+ - Updated dependencies []:
14
+ - @learncard/learn-cloud-service@2.3.17
15
+
3
16
  ## 1.4.16
4
17
 
5
18
  ### Patch Changes
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,UAAU,EAAiB,MAAM,cAAc,CAAC;AAC3E,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gCAAgC,CAAC;AAIhE,KAAK,MAAM,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC;AAEpC,MAAM,MAAM,gBAAgB,GAAG,MAAM,CAAC;AAEtC,eAAO,MAAM,SAAS,QACb,MAAM,mBACM,CAAC,SAAS,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,CAAC,KACzD,OAAO,CAAC,MAAM,CAyChB,CAAC;AAEF,eAAe,SAAS,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,UAAU,EAAiB,MAAM,cAAc,CAAC;AAC3E,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gCAAgC,CAAC;AAIhE,KAAK,MAAM,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC;AAEpC,MAAM,MAAM,gBAAgB,GAAG,MAAM,CAAC;AAEtC,eAAO,MAAM,SAAS,QACb,MAAM,mBACM,CAAC,SAAS,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,CAAC,KACzD,OAAO,CAAC,MAAM,CA2ChB,CAAC;AAEF,eAAe,SAAS,CAAC"}
@@ -72,6 +72,7 @@ var getClient = /* @__PURE__ */ __name(async (url, didAuthFunction) => {
72
72
  methodOverride: "POST",
73
73
  url,
74
74
  maxURLLength: 3072,
75
+ maxItems: 50,
75
76
  headers: { Authorization: `Bearer ${await didAuthFunction()}` }
76
77
  })
77
78
  ]
@@ -88,6 +89,7 @@ var getClient = /* @__PURE__ */ __name(async (url, didAuthFunction) => {
88
89
  (0, import_client.httpBatchLink)({
89
90
  methodOverride: "POST",
90
91
  url,
92
+ maxItems: 50,
91
93
  maxURLLength: 3072,
92
94
  headers: async () => {
93
95
  if (challenges.length === 0)
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../src/index.ts", "../src/callbackLink.ts"],
4
- "sourcesContent": ["import { createTRPCClient, TRPCClient, httpBatchLink } from '@trpc/client';\nimport type { AppRouter } from '@learncard/learn-cloud-service';\n\nimport { callbackLink } from './callbackLink';\n\ntype Client = TRPCClient<AppRouter>;\n\nexport type LearnCloudClient = Client;\n\nexport const getClient = async (\n url: string,\n didAuthFunction: (challenge?: string) => Promise<string>\n): Promise<Client> => {\n let challenges: string[] = [];\n\n const challengeRequester = createTRPCClient<AppRouter>({\n links: [\n httpBatchLink({\n methodOverride: 'POST',\n url,\n maxURLLength: 3072,\n headers: { Authorization: `Bearer ${await didAuthFunction()}` },\n }),\n ],\n });\n\n const getChallenges = async (\n amount = 95 + Math.round((Math.random() - 0.5) * 5)\n ): Promise<string[]> => {\n return challengeRequester.utilities.getChallenges.query({ amount });\n };\n\n getChallenges().then(result => (challenges = result));\n\n const trpc = createTRPCClient<AppRouter>({\n links: [\n callbackLink(async () => {\n challenges = await getChallenges();\n }),\n httpBatchLink({\n methodOverride: 'POST',\n url,\n maxURLLength: 3072,\n headers: async () => {\n if (challenges.length === 0) challenges.push(...(await getChallenges()));\n\n return { Authorization: `Bearer ${await didAuthFunction(challenges.pop())}` };\n },\n }),\n ],\n });\n\n return trpc;\n};\n\nexport default getClient;\n", "import { TRPCLink } from '@trpc/client';\nimport { observable, Unsubscribable } from '@trpc/server/observable';\nimport type { AppRouter } from '@learncard/learn-cloud-service';\n\nexport const callbackLink = (callback: () => Promise<void>): TRPCLink<AppRouter> => {\n return () => {\n return ({ next, op }) => {\n return observable(observer => {\n let request: Unsubscribable | null = null;\n let attempts = 0;\n let isDone = false;\n\n const attempt = () => {\n attempts += 1;\n request?.unsubscribe();\n request = next(op).subscribe({\n error: async error => {\n if (attempts > 5 || error.data?.httpStatus !== 401) {\n return observer.error(error);\n }\n\n await callback();\n\n attempt();\n },\n next: result => observer.next(result),\n complete: () => {\n if (isDone) observer.complete();\n },\n });\n };\n\n attempt();\n\n return () => {\n isDone = true;\n request?.unsubscribe();\n };\n });\n };\n };\n};\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAA4D;;;ACC5D,wBAA2C;AAGpC,IAAM,eAAe,wBAAC,aAAuD;AAChF,SAAO,MAAM;AACT,WAAO,CAAC,EAAE,MAAM,GAAG,MAAM;AACrB,iBAAO,8BAAW,cAAY;AAC1B,YAAI,UAAiC;AACrC,YAAI,WAAW;AACf,YAAI,SAAS;AAEb,cAAM,UAAU,6BAAM;AAClB,sBAAY;AACZ,mBAAS,YAAY;AACrB,oBAAU,KAAK,EAAE,EAAE,UAAU;AAAA,YACzB,OAAO,OAAM,UAAS;AAClB,kBAAI,WAAW,KAAK,MAAM,MAAM,eAAe,KAAK;AAChD,uBAAO,SAAS,MAAM,KAAK;AAAA,cAC/B;AAEA,oBAAM,SAAS;AAEf,sBAAQ;AAAA,YACZ;AAAA,YACA,MAAM,YAAU,SAAS,KAAK,MAAM;AAAA,YACpC,UAAU,MAAM;AACZ,kBAAI;AAAQ,yBAAS,SAAS;AAAA,YAClC;AAAA,UACJ,CAAC;AAAA,QACL,GAlBgB;AAoBhB,gBAAQ;AAER,eAAO,MAAM;AACT,mBAAS;AACT,mBAAS,YAAY;AAAA,QACzB;AAAA,MACJ,CAAC;AAAA,IACL;AAAA,EACJ;AACJ,GArC4B;;;ADKrB,IAAM,YAAY,8BACrB,KACA,oBACkB;AAClB,MAAI,aAAuB,CAAC;AAE5B,QAAM,yBAAqB,gCAA4B;AAAA,IACnD,OAAO;AAAA,UACH,6BAAc;AAAA,QACV,gBAAgB;AAAA,QAChB;AAAA,QACA,cAAc;AAAA,QACd,SAAS,EAAE,eAAe,UAAU,MAAM,gBAAgB,IAAI;AAAA,MAClE,CAAC;AAAA,IACL;AAAA,EACJ,CAAC;AAED,QAAM,gBAAgB,8BAClB,SAAS,KAAK,KAAK,OAAO,KAAK,OAAO,IAAI,OAAO,CAAC,MAC9B;AACpB,WAAO,mBAAmB,UAAU,cAAc,MAAM,EAAE,OAAO,CAAC;AAAA,EACtE,GAJsB;AAMtB,gBAAc,EAAE,KAAK,YAAW,aAAa,MAAO;AAEpD,QAAM,WAAO,gCAA4B;AAAA,IACrC,OAAO;AAAA,MACH,aAAa,YAAY;AACrB,qBAAa,MAAM,cAAc;AAAA,MACrC,CAAC;AAAA,UACD,6BAAc;AAAA,QACV,gBAAgB;AAAA,QAChB;AAAA,QACA,cAAc;AAAA,QACd,SAAS,YAAY;AACjB,cAAI,WAAW,WAAW;AAAG,uBAAW,KAAK,GAAI,MAAM,cAAc,CAAE;AAEvE,iBAAO,EAAE,eAAe,UAAU,MAAM,gBAAgB,WAAW,IAAI,CAAC,IAAI;AAAA,QAChF;AAAA,MACJ,CAAC;AAAA,IACL;AAAA,EACJ,CAAC;AAED,SAAO;AACX,GA5CyB;AA8CzB,IAAO,cAAQ;",
4
+ "sourcesContent": ["import { createTRPCClient, TRPCClient, httpBatchLink } from '@trpc/client';\nimport type { AppRouter } from '@learncard/learn-cloud-service';\n\nimport { callbackLink } from './callbackLink';\n\ntype Client = TRPCClient<AppRouter>;\n\nexport type LearnCloudClient = Client;\n\nexport const getClient = async (\n url: string,\n didAuthFunction: (challenge?: string) => Promise<string>\n): Promise<Client> => {\n let challenges: string[] = [];\n\n const challengeRequester = createTRPCClient<AppRouter>({\n links: [\n httpBatchLink({\n methodOverride: 'POST',\n url,\n maxURLLength: 3072,\n maxItems: 50,\n headers: { Authorization: `Bearer ${await didAuthFunction()}` },\n }),\n ],\n });\n\n const getChallenges = async (\n amount = 95 + Math.round((Math.random() - 0.5) * 5)\n ): Promise<string[]> => {\n return challengeRequester.utilities.getChallenges.query({ amount });\n };\n\n getChallenges().then(result => (challenges = result));\n\n const trpc = createTRPCClient<AppRouter>({\n links: [\n callbackLink(async () => {\n challenges = await getChallenges();\n }),\n httpBatchLink({\n methodOverride: 'POST',\n url,\n maxItems: 50,\n maxURLLength: 3072,\n headers: async () => {\n if (challenges.length === 0) challenges.push(...(await getChallenges()));\n\n return { Authorization: `Bearer ${await didAuthFunction(challenges.pop())}` };\n },\n }),\n ],\n });\n\n return trpc;\n};\n\nexport default getClient;\n", "import { TRPCLink } from '@trpc/client';\nimport { observable, Unsubscribable } from '@trpc/server/observable';\nimport type { AppRouter } from '@learncard/learn-cloud-service';\n\nexport const callbackLink = (callback: () => Promise<void>): TRPCLink<AppRouter> => {\n return () => {\n return ({ next, op }) => {\n return observable(observer => {\n let request: Unsubscribable | null = null;\n let attempts = 0;\n let isDone = false;\n\n const attempt = () => {\n attempts += 1;\n request?.unsubscribe();\n request = next(op).subscribe({\n error: async error => {\n if (attempts > 5 || error.data?.httpStatus !== 401) {\n return observer.error(error);\n }\n\n await callback();\n\n attempt();\n },\n next: result => observer.next(result),\n complete: () => {\n if (isDone) observer.complete();\n },\n });\n };\n\n attempt();\n\n return () => {\n isDone = true;\n request?.unsubscribe();\n };\n });\n };\n };\n};\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAA4D;;;ACC5D,wBAA2C;AAGpC,IAAM,eAAe,wBAAC,aAAuD;AAChF,SAAO,MAAM;AACT,WAAO,CAAC,EAAE,MAAM,GAAG,MAAM;AACrB,iBAAO,8BAAW,cAAY;AAC1B,YAAI,UAAiC;AACrC,YAAI,WAAW;AACf,YAAI,SAAS;AAEb,cAAM,UAAU,6BAAM;AAClB,sBAAY;AACZ,mBAAS,YAAY;AACrB,oBAAU,KAAK,EAAE,EAAE,UAAU;AAAA,YACzB,OAAO,OAAM,UAAS;AAClB,kBAAI,WAAW,KAAK,MAAM,MAAM,eAAe,KAAK;AAChD,uBAAO,SAAS,MAAM,KAAK;AAAA,cAC/B;AAEA,oBAAM,SAAS;AAEf,sBAAQ;AAAA,YACZ;AAAA,YACA,MAAM,YAAU,SAAS,KAAK,MAAM;AAAA,YACpC,UAAU,MAAM;AACZ,kBAAI;AAAQ,yBAAS,SAAS;AAAA,YAClC;AAAA,UACJ,CAAC;AAAA,QACL,GAlBgB;AAoBhB,gBAAQ;AAER,eAAO,MAAM;AACT,mBAAS;AACT,mBAAS,YAAY;AAAA,QACzB;AAAA,MACJ,CAAC;AAAA,IACL;AAAA,EACJ;AACJ,GArC4B;;;ADKrB,IAAM,YAAY,8BACrB,KACA,oBACkB;AAClB,MAAI,aAAuB,CAAC;AAE5B,QAAM,yBAAqB,gCAA4B;AAAA,IACnD,OAAO;AAAA,UACH,6BAAc;AAAA,QACV,gBAAgB;AAAA,QAChB;AAAA,QACA,cAAc;AAAA,QACd,UAAU;AAAA,QACV,SAAS,EAAE,eAAe,UAAU,MAAM,gBAAgB,IAAI;AAAA,MAClE,CAAC;AAAA,IACL;AAAA,EACJ,CAAC;AAED,QAAM,gBAAgB,8BAClB,SAAS,KAAK,KAAK,OAAO,KAAK,OAAO,IAAI,OAAO,CAAC,MAC9B;AACpB,WAAO,mBAAmB,UAAU,cAAc,MAAM,EAAE,OAAO,CAAC;AAAA,EACtE,GAJsB;AAMtB,gBAAc,EAAE,KAAK,YAAW,aAAa,MAAO;AAEpD,QAAM,WAAO,gCAA4B;AAAA,IACrC,OAAO;AAAA,MACH,aAAa,YAAY;AACrB,qBAAa,MAAM,cAAc;AAAA,MACrC,CAAC;AAAA,UACD,6BAAc;AAAA,QACV,gBAAgB;AAAA,QAChB;AAAA,QACA,UAAU;AAAA,QACV,cAAc;AAAA,QACd,SAAS,YAAY;AACjB,cAAI,WAAW,WAAW;AAAG,uBAAW,KAAK,GAAI,MAAM,cAAc,CAAE;AAEvE,iBAAO,EAAE,eAAe,UAAU,MAAM,gBAAgB,WAAW,IAAI,CAAC,IAAI;AAAA,QAChF;AAAA,MACJ,CAAC;AAAA,IACL;AAAA,EACJ,CAAC;AAED,SAAO;AACX,GA9CyB;AAgDzB,IAAO,cAAQ;",
6
6
  "names": []
7
7
  }
@@ -1 +1 @@
1
- var p=Object.defineProperty;var C=Object.getOwnPropertyDescriptor;var b=Object.getOwnPropertyNames;var d=Object.prototype.hasOwnProperty;var l=(t,e)=>p(t,"name",{value:e,configurable:!0});var R=(t,e)=>{for(var n in e)p(t,n,{get:e[n],enumerable:!0})},f=(t,e,n,a)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of b(e))!d.call(t,r)&&r!==n&&p(t,r,{get:()=>e[r],enumerable:!(a=C(e,r))||a.enumerable});return t};var P=t=>f(p({},"__esModule",{value:!0}),t);var L={};R(L,{default:()=>y,getClient:()=>g});module.exports=P(L);var o=require("@trpc/client");var m=require("@trpc/server/observable");var h=l(t=>()=>({next:e,op:n})=>(0,m.observable)(a=>{let r=null,c=0,i=!1,u=l(()=>{c+=1,r?.unsubscribe(),r=e(n).subscribe({error:async s=>{if(c>5||s.data?.httpStatus!==401)return a.error(s);await t(),u()},next:s=>a.next(s),complete:()=>{i&&a.complete()}})},"attempt");return u(),()=>{i=!0,r?.unsubscribe()}}),"callbackLink");var g=l(async(t,e)=>{let n=[],a=(0,o.createTRPCClient)({links:[(0,o.httpBatchLink)({methodOverride:"POST",url:t,maxURLLength:3072,headers:{Authorization:`Bearer ${await e()}`}})]}),r=l(async(i=95+Math.round((Math.random()-.5)*5))=>a.utilities.getChallenges.query({amount:i}),"getChallenges");return r().then(i=>n=i),(0,o.createTRPCClient)({links:[h(async()=>{n=await r()}),(0,o.httpBatchLink)({methodOverride:"POST",url:t,maxURLLength:3072,headers:async()=>(n.length===0&&n.push(...await r()),{Authorization:`Bearer ${await e(n.pop())}`})})]})},"getClient"),y=g;
1
+ var p=Object.defineProperty;var C=Object.getOwnPropertyDescriptor;var b=Object.getOwnPropertyNames;var d=Object.prototype.hasOwnProperty;var s=(t,e)=>p(t,"name",{value:e,configurable:!0});var R=(t,e)=>{for(var n in e)p(t,n,{get:e[n],enumerable:!0})},f=(t,e,n,a)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of b(e))!d.call(t,r)&&r!==n&&p(t,r,{get:()=>e[r],enumerable:!(a=C(e,r))||a.enumerable});return t};var P=t=>f(p({},"__esModule",{value:!0}),t);var y={};R(y,{default:()=>x,getClient:()=>g});module.exports=P(y);var l=require("@trpc/client");var m=require("@trpc/server/observable");var h=s(t=>()=>({next:e,op:n})=>(0,m.observable)(a=>{let r=null,c=0,i=!1,u=s(()=>{c+=1,r?.unsubscribe(),r=e(n).subscribe({error:async o=>{if(c>5||o.data?.httpStatus!==401)return a.error(o);await t(),u()},next:o=>a.next(o),complete:()=>{i&&a.complete()}})},"attempt");return u(),()=>{i=!0,r?.unsubscribe()}}),"callbackLink");var g=s(async(t,e)=>{let n=[],a=(0,l.createTRPCClient)({links:[(0,l.httpBatchLink)({methodOverride:"POST",url:t,maxURLLength:3072,maxItems:50,headers:{Authorization:`Bearer ${await e()}`}})]}),r=s(async(i=95+Math.round((Math.random()-.5)*5))=>a.utilities.getChallenges.query({amount:i}),"getChallenges");return r().then(i=>n=i),(0,l.createTRPCClient)({links:[h(async()=>{n=await r()}),(0,l.httpBatchLink)({methodOverride:"POST",url:t,maxItems:50,maxURLLength:3072,headers:async()=>(n.length===0&&n.push(...await r()),{Authorization:`Bearer ${await e(n.pop())}`})})]})},"getClient"),x=g;
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../src/index.ts", "../src/callbackLink.ts"],
4
- "sourcesContent": ["import { createTRPCClient, TRPCClient, httpBatchLink } from '@trpc/client';\nimport type { AppRouter } from '@learncard/learn-cloud-service';\n\nimport { callbackLink } from './callbackLink';\n\ntype Client = TRPCClient<AppRouter>;\n\nexport type LearnCloudClient = Client;\n\nexport const getClient = async (\n url: string,\n didAuthFunction: (challenge?: string) => Promise<string>\n): Promise<Client> => {\n let challenges: string[] = [];\n\n const challengeRequester = createTRPCClient<AppRouter>({\n links: [\n httpBatchLink({\n methodOverride: 'POST',\n url,\n maxURLLength: 3072,\n headers: { Authorization: `Bearer ${await didAuthFunction()}` },\n }),\n ],\n });\n\n const getChallenges = async (\n amount = 95 + Math.round((Math.random() - 0.5) * 5)\n ): Promise<string[]> => {\n return challengeRequester.utilities.getChallenges.query({ amount });\n };\n\n getChallenges().then(result => (challenges = result));\n\n const trpc = createTRPCClient<AppRouter>({\n links: [\n callbackLink(async () => {\n challenges = await getChallenges();\n }),\n httpBatchLink({\n methodOverride: 'POST',\n url,\n maxURLLength: 3072,\n headers: async () => {\n if (challenges.length === 0) challenges.push(...(await getChallenges()));\n\n return { Authorization: `Bearer ${await didAuthFunction(challenges.pop())}` };\n },\n }),\n ],\n });\n\n return trpc;\n};\n\nexport default getClient;\n", "import { TRPCLink } from '@trpc/client';\nimport { observable, Unsubscribable } from '@trpc/server/observable';\nimport type { AppRouter } from '@learncard/learn-cloud-service';\n\nexport const callbackLink = (callback: () => Promise<void>): TRPCLink<AppRouter> => {\n return () => {\n return ({ next, op }) => {\n return observable(observer => {\n let request: Unsubscribable | null = null;\n let attempts = 0;\n let isDone = false;\n\n const attempt = () => {\n attempts += 1;\n request?.unsubscribe();\n request = next(op).subscribe({\n error: async error => {\n if (attempts > 5 || error.data?.httpStatus !== 401) {\n return observer.error(error);\n }\n\n await callback();\n\n attempt();\n },\n next: result => observer.next(result),\n complete: () => {\n if (isDone) observer.complete();\n },\n });\n };\n\n attempt();\n\n return () => {\n isDone = true;\n request?.unsubscribe();\n };\n });\n };\n };\n};\n"],
5
- "mappings": "+cAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,aAAAE,EAAA,cAAAC,IAAA,eAAAC,EAAAJ,GAAA,IAAAK,EAA4D,wBCC5D,IAAAC,EAA2C,mCAGpC,IAAMC,EAAeC,EAACC,GAClB,IACI,CAAC,CAAE,KAAAC,EAAM,GAAAC,CAAG,OACR,cAAWC,GAAY,CAC1B,IAAIC,EAAiC,KACjCC,EAAW,EACXC,EAAS,GAEPC,EAAUR,EAAA,IAAM,CAClBM,GAAY,EACZD,GAAS,YAAY,EACrBA,EAAUH,EAAKC,CAAE,EAAE,UAAU,CACzB,MAAO,MAAMM,GAAS,CAClB,GAAIH,EAAW,GAAKG,EAAM,MAAM,aAAe,IAC3C,OAAOL,EAAS,MAAMK,CAAK,EAG/B,MAAMR,EAAS,EAEfO,EAAQ,CACZ,EACA,KAAME,GAAUN,EAAS,KAAKM,CAAM,EACpC,SAAU,IAAM,CACRH,GAAQH,EAAS,SAAS,CAClC,CACJ,CAAC,CACL,EAlBgB,WAoBhB,OAAAI,EAAQ,EAED,IAAM,CACTD,EAAS,GACTF,GAAS,YAAY,CACzB,CACJ,CAAC,EAlCe,gBDKrB,IAAMM,EAAYC,EAAA,MACrBC,EACAC,IACkB,CAClB,IAAIC,EAAuB,CAAC,EAEtBC,KAAqB,oBAA4B,CACnD,MAAO,IACH,iBAAc,CACV,eAAgB,OAChB,IAAAH,EACA,aAAc,KACd,QAAS,CAAE,cAAe,UAAU,MAAMC,EAAgB,GAAI,CAClE,CAAC,CACL,CACJ,CAAC,EAEKG,EAAgBL,EAAA,MAClBM,EAAS,GAAK,KAAK,OAAO,KAAK,OAAO,EAAI,IAAO,CAAC,IAE3CF,EAAmB,UAAU,cAAc,MAAM,CAAE,OAAAE,CAAO,CAAC,EAHhD,iBAMtB,OAAAD,EAAc,EAAE,KAAKE,GAAWJ,EAAaI,CAAO,KAEvC,oBAA4B,CACrC,MAAO,CACHC,EAAa,SAAY,CACrBL,EAAa,MAAME,EAAc,CACrC,CAAC,KACD,iBAAc,CACV,eAAgB,OAChB,IAAAJ,EACA,aAAc,KACd,QAAS,UACDE,EAAW,SAAW,GAAGA,EAAW,KAAK,GAAI,MAAME,EAAc,CAAE,EAEhE,CAAE,cAAe,UAAU,MAAMH,EAAgBC,EAAW,IAAI,CAAC,GAAI,EAEpF,CAAC,CACL,CACJ,CAAC,CAGL,EA5CyB,aA8ClBM,EAAQV",
4
+ "sourcesContent": ["import { createTRPCClient, TRPCClient, httpBatchLink } from '@trpc/client';\nimport type { AppRouter } from '@learncard/learn-cloud-service';\n\nimport { callbackLink } from './callbackLink';\n\ntype Client = TRPCClient<AppRouter>;\n\nexport type LearnCloudClient = Client;\n\nexport const getClient = async (\n url: string,\n didAuthFunction: (challenge?: string) => Promise<string>\n): Promise<Client> => {\n let challenges: string[] = [];\n\n const challengeRequester = createTRPCClient<AppRouter>({\n links: [\n httpBatchLink({\n methodOverride: 'POST',\n url,\n maxURLLength: 3072,\n maxItems: 50,\n headers: { Authorization: `Bearer ${await didAuthFunction()}` },\n }),\n ],\n });\n\n const getChallenges = async (\n amount = 95 + Math.round((Math.random() - 0.5) * 5)\n ): Promise<string[]> => {\n return challengeRequester.utilities.getChallenges.query({ amount });\n };\n\n getChallenges().then(result => (challenges = result));\n\n const trpc = createTRPCClient<AppRouter>({\n links: [\n callbackLink(async () => {\n challenges = await getChallenges();\n }),\n httpBatchLink({\n methodOverride: 'POST',\n url,\n maxItems: 50,\n maxURLLength: 3072,\n headers: async () => {\n if (challenges.length === 0) challenges.push(...(await getChallenges()));\n\n return { Authorization: `Bearer ${await didAuthFunction(challenges.pop())}` };\n },\n }),\n ],\n });\n\n return trpc;\n};\n\nexport default getClient;\n", "import { TRPCLink } from '@trpc/client';\nimport { observable, Unsubscribable } from '@trpc/server/observable';\nimport type { AppRouter } from '@learncard/learn-cloud-service';\n\nexport const callbackLink = (callback: () => Promise<void>): TRPCLink<AppRouter> => {\n return () => {\n return ({ next, op }) => {\n return observable(observer => {\n let request: Unsubscribable | null = null;\n let attempts = 0;\n let isDone = false;\n\n const attempt = () => {\n attempts += 1;\n request?.unsubscribe();\n request = next(op).subscribe({\n error: async error => {\n if (attempts > 5 || error.data?.httpStatus !== 401) {\n return observer.error(error);\n }\n\n await callback();\n\n attempt();\n },\n next: result => observer.next(result),\n complete: () => {\n if (isDone) observer.complete();\n },\n });\n };\n\n attempt();\n\n return () => {\n isDone = true;\n request?.unsubscribe();\n };\n });\n };\n };\n};\n"],
5
+ "mappings": "+cAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,aAAAE,EAAA,cAAAC,IAAA,eAAAC,EAAAJ,GAAA,IAAAK,EAA4D,wBCC5D,IAAAC,EAA2C,mCAGpC,IAAMC,EAAeC,EAACC,GAClB,IACI,CAAC,CAAE,KAAAC,EAAM,GAAAC,CAAG,OACR,cAAWC,GAAY,CAC1B,IAAIC,EAAiC,KACjCC,EAAW,EACXC,EAAS,GAEPC,EAAUR,EAAA,IAAM,CAClBM,GAAY,EACZD,GAAS,YAAY,EACrBA,EAAUH,EAAKC,CAAE,EAAE,UAAU,CACzB,MAAO,MAAMM,GAAS,CAClB,GAAIH,EAAW,GAAKG,EAAM,MAAM,aAAe,IAC3C,OAAOL,EAAS,MAAMK,CAAK,EAG/B,MAAMR,EAAS,EAEfO,EAAQ,CACZ,EACA,KAAME,GAAUN,EAAS,KAAKM,CAAM,EACpC,SAAU,IAAM,CACRH,GAAQH,EAAS,SAAS,CAClC,CACJ,CAAC,CACL,EAlBgB,WAoBhB,OAAAI,EAAQ,EAED,IAAM,CACTD,EAAS,GACTF,GAAS,YAAY,CACzB,CACJ,CAAC,EAlCe,gBDKrB,IAAMM,EAAYC,EAAA,MACrBC,EACAC,IACkB,CAClB,IAAIC,EAAuB,CAAC,EAEtBC,KAAqB,oBAA4B,CACnD,MAAO,IACH,iBAAc,CACV,eAAgB,OAChB,IAAAH,EACA,aAAc,KACd,SAAU,GACV,QAAS,CAAE,cAAe,UAAU,MAAMC,EAAgB,GAAI,CAClE,CAAC,CACL,CACJ,CAAC,EAEKG,EAAgBL,EAAA,MAClBM,EAAS,GAAK,KAAK,OAAO,KAAK,OAAO,EAAI,IAAO,CAAC,IAE3CF,EAAmB,UAAU,cAAc,MAAM,CAAE,OAAAE,CAAO,CAAC,EAHhD,iBAMtB,OAAAD,EAAc,EAAE,KAAKE,GAAWJ,EAAaI,CAAO,KAEvC,oBAA4B,CACrC,MAAO,CACHC,EAAa,SAAY,CACrBL,EAAa,MAAME,EAAc,CACrC,CAAC,KACD,iBAAc,CACV,eAAgB,OAChB,IAAAJ,EACA,SAAU,GACV,aAAc,KACd,QAAS,UACDE,EAAW,SAAW,GAAGA,EAAW,KAAK,GAAI,MAAME,EAAc,CAAE,EAEhE,CAAE,cAAe,UAAU,MAAMH,EAAgBC,EAAW,IAAI,CAAC,GAAI,EAEpF,CAAC,CACL,CACJ,CAAC,CAGL,EA9CyB,aAgDlBM,EAAQV",
6
6
  "names": ["src_exports", "__export", "src_default", "getClient", "__toCommonJS", "import_client", "import_observable", "callbackLink", "__name", "callback", "next", "op", "observer", "request", "attempts", "isDone", "attempt", "error", "result", "getClient", "__name", "url", "didAuthFunction", "challenges", "challengeRequester", "getChallenges", "amount", "result", "callbackLink", "src_default"]
7
7
  }
@@ -50,6 +50,7 @@ var getClient = /* @__PURE__ */ __name(async (url, didAuthFunction) => {
50
50
  methodOverride: "POST",
51
51
  url,
52
52
  maxURLLength: 3072,
53
+ maxItems: 50,
53
54
  headers: { Authorization: `Bearer ${await didAuthFunction()}` }
54
55
  })
55
56
  ]
@@ -66,6 +67,7 @@ var getClient = /* @__PURE__ */ __name(async (url, didAuthFunction) => {
66
67
  httpBatchLink({
67
68
  methodOverride: "POST",
68
69
  url,
70
+ maxItems: 50,
69
71
  maxURLLength: 3072,
70
72
  headers: async () => {
71
73
  if (challenges.length === 0)
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../src/index.ts", "../src/callbackLink.ts"],
4
- "sourcesContent": ["import { createTRPCClient, TRPCClient, httpBatchLink } from '@trpc/client';\nimport type { AppRouter } from '@learncard/learn-cloud-service';\n\nimport { callbackLink } from './callbackLink';\n\ntype Client = TRPCClient<AppRouter>;\n\nexport type LearnCloudClient = Client;\n\nexport const getClient = async (\n url: string,\n didAuthFunction: (challenge?: string) => Promise<string>\n): Promise<Client> => {\n let challenges: string[] = [];\n\n const challengeRequester = createTRPCClient<AppRouter>({\n links: [\n httpBatchLink({\n methodOverride: 'POST',\n url,\n maxURLLength: 3072,\n headers: { Authorization: `Bearer ${await didAuthFunction()}` },\n }),\n ],\n });\n\n const getChallenges = async (\n amount = 95 + Math.round((Math.random() - 0.5) * 5)\n ): Promise<string[]> => {\n return challengeRequester.utilities.getChallenges.query({ amount });\n };\n\n getChallenges().then(result => (challenges = result));\n\n const trpc = createTRPCClient<AppRouter>({\n links: [\n callbackLink(async () => {\n challenges = await getChallenges();\n }),\n httpBatchLink({\n methodOverride: 'POST',\n url,\n maxURLLength: 3072,\n headers: async () => {\n if (challenges.length === 0) challenges.push(...(await getChallenges()));\n\n return { Authorization: `Bearer ${await didAuthFunction(challenges.pop())}` };\n },\n }),\n ],\n });\n\n return trpc;\n};\n\nexport default getClient;\n", "import { TRPCLink } from '@trpc/client';\nimport { observable, Unsubscribable } from '@trpc/server/observable';\nimport type { AppRouter } from '@learncard/learn-cloud-service';\n\nexport const callbackLink = (callback: () => Promise<void>): TRPCLink<AppRouter> => {\n return () => {\n return ({ next, op }) => {\n return observable(observer => {\n let request: Unsubscribable | null = null;\n let attempts = 0;\n let isDone = false;\n\n const attempt = () => {\n attempts += 1;\n request?.unsubscribe();\n request = next(op).subscribe({\n error: async error => {\n if (attempts > 5 || error.data?.httpStatus !== 401) {\n return observer.error(error);\n }\n\n await callback();\n\n attempt();\n },\n next: result => observer.next(result),\n complete: () => {\n if (isDone) observer.complete();\n },\n });\n };\n\n attempt();\n\n return () => {\n isDone = true;\n request?.unsubscribe();\n };\n });\n };\n };\n};\n"],
5
- "mappings": ";;;;AAAA,SAAS,kBAA8B,qBAAqB;;;ACC5D,SAAS,kBAAkC;AAGpC,IAAM,eAAe,wBAAC,aAAuD;AAChF,SAAO,MAAM;AACT,WAAO,CAAC,EAAE,MAAM,GAAG,MAAM;AACrB,aAAO,WAAW,cAAY;AAC1B,YAAI,UAAiC;AACrC,YAAI,WAAW;AACf,YAAI,SAAS;AAEb,cAAM,UAAU,6BAAM;AAClB,sBAAY;AACZ,mBAAS,YAAY;AACrB,oBAAU,KAAK,EAAE,EAAE,UAAU;AAAA,YACzB,OAAO,OAAM,UAAS;AAClB,kBAAI,WAAW,KAAK,MAAM,MAAM,eAAe,KAAK;AAChD,uBAAO,SAAS,MAAM,KAAK;AAAA,cAC/B;AAEA,oBAAM,SAAS;AAEf,sBAAQ;AAAA,YACZ;AAAA,YACA,MAAM,YAAU,SAAS,KAAK,MAAM;AAAA,YACpC,UAAU,MAAM;AACZ,kBAAI;AAAQ,yBAAS,SAAS;AAAA,YAClC;AAAA,UACJ,CAAC;AAAA,QACL,GAlBgB;AAoBhB,gBAAQ;AAER,eAAO,MAAM;AACT,mBAAS;AACT,mBAAS,YAAY;AAAA,QACzB;AAAA,MACJ,CAAC;AAAA,IACL;AAAA,EACJ;AACJ,GArC4B;;;ADKrB,IAAM,YAAY,8BACrB,KACA,oBACkB;AAClB,MAAI,aAAuB,CAAC;AAE5B,QAAM,qBAAqB,iBAA4B;AAAA,IACnD,OAAO;AAAA,MACH,cAAc;AAAA,QACV,gBAAgB;AAAA,QAChB;AAAA,QACA,cAAc;AAAA,QACd,SAAS,EAAE,eAAe,UAAU,MAAM,gBAAgB,IAAI;AAAA,MAClE,CAAC;AAAA,IACL;AAAA,EACJ,CAAC;AAED,QAAM,gBAAgB,8BAClB,SAAS,KAAK,KAAK,OAAO,KAAK,OAAO,IAAI,OAAO,CAAC,MAC9B;AACpB,WAAO,mBAAmB,UAAU,cAAc,MAAM,EAAE,OAAO,CAAC;AAAA,EACtE,GAJsB;AAMtB,gBAAc,EAAE,KAAK,YAAW,aAAa,MAAO;AAEpD,QAAM,OAAO,iBAA4B;AAAA,IACrC,OAAO;AAAA,MACH,aAAa,YAAY;AACrB,qBAAa,MAAM,cAAc;AAAA,MACrC,CAAC;AAAA,MACD,cAAc;AAAA,QACV,gBAAgB;AAAA,QAChB;AAAA,QACA,cAAc;AAAA,QACd,SAAS,YAAY;AACjB,cAAI,WAAW,WAAW;AAAG,uBAAW,KAAK,GAAI,MAAM,cAAc,CAAE;AAEvE,iBAAO,EAAE,eAAe,UAAU,MAAM,gBAAgB,WAAW,IAAI,CAAC,IAAI;AAAA,QAChF;AAAA,MACJ,CAAC;AAAA,IACL;AAAA,EACJ,CAAC;AAED,SAAO;AACX,GA5CyB;AA8CzB,IAAO,cAAQ;",
4
+ "sourcesContent": ["import { createTRPCClient, TRPCClient, httpBatchLink } from '@trpc/client';\nimport type { AppRouter } from '@learncard/learn-cloud-service';\n\nimport { callbackLink } from './callbackLink';\n\ntype Client = TRPCClient<AppRouter>;\n\nexport type LearnCloudClient = Client;\n\nexport const getClient = async (\n url: string,\n didAuthFunction: (challenge?: string) => Promise<string>\n): Promise<Client> => {\n let challenges: string[] = [];\n\n const challengeRequester = createTRPCClient<AppRouter>({\n links: [\n httpBatchLink({\n methodOverride: 'POST',\n url,\n maxURLLength: 3072,\n maxItems: 50,\n headers: { Authorization: `Bearer ${await didAuthFunction()}` },\n }),\n ],\n });\n\n const getChallenges = async (\n amount = 95 + Math.round((Math.random() - 0.5) * 5)\n ): Promise<string[]> => {\n return challengeRequester.utilities.getChallenges.query({ amount });\n };\n\n getChallenges().then(result => (challenges = result));\n\n const trpc = createTRPCClient<AppRouter>({\n links: [\n callbackLink(async () => {\n challenges = await getChallenges();\n }),\n httpBatchLink({\n methodOverride: 'POST',\n url,\n maxItems: 50,\n maxURLLength: 3072,\n headers: async () => {\n if (challenges.length === 0) challenges.push(...(await getChallenges()));\n\n return { Authorization: `Bearer ${await didAuthFunction(challenges.pop())}` };\n },\n }),\n ],\n });\n\n return trpc;\n};\n\nexport default getClient;\n", "import { TRPCLink } from '@trpc/client';\nimport { observable, Unsubscribable } from '@trpc/server/observable';\nimport type { AppRouter } from '@learncard/learn-cloud-service';\n\nexport const callbackLink = (callback: () => Promise<void>): TRPCLink<AppRouter> => {\n return () => {\n return ({ next, op }) => {\n return observable(observer => {\n let request: Unsubscribable | null = null;\n let attempts = 0;\n let isDone = false;\n\n const attempt = () => {\n attempts += 1;\n request?.unsubscribe();\n request = next(op).subscribe({\n error: async error => {\n if (attempts > 5 || error.data?.httpStatus !== 401) {\n return observer.error(error);\n }\n\n await callback();\n\n attempt();\n },\n next: result => observer.next(result),\n complete: () => {\n if (isDone) observer.complete();\n },\n });\n };\n\n attempt();\n\n return () => {\n isDone = true;\n request?.unsubscribe();\n };\n });\n };\n };\n};\n"],
5
+ "mappings": ";;;;AAAA,SAAS,kBAA8B,qBAAqB;;;ACC5D,SAAS,kBAAkC;AAGpC,IAAM,eAAe,wBAAC,aAAuD;AAChF,SAAO,MAAM;AACT,WAAO,CAAC,EAAE,MAAM,GAAG,MAAM;AACrB,aAAO,WAAW,cAAY;AAC1B,YAAI,UAAiC;AACrC,YAAI,WAAW;AACf,YAAI,SAAS;AAEb,cAAM,UAAU,6BAAM;AAClB,sBAAY;AACZ,mBAAS,YAAY;AACrB,oBAAU,KAAK,EAAE,EAAE,UAAU;AAAA,YACzB,OAAO,OAAM,UAAS;AAClB,kBAAI,WAAW,KAAK,MAAM,MAAM,eAAe,KAAK;AAChD,uBAAO,SAAS,MAAM,KAAK;AAAA,cAC/B;AAEA,oBAAM,SAAS;AAEf,sBAAQ;AAAA,YACZ;AAAA,YACA,MAAM,YAAU,SAAS,KAAK,MAAM;AAAA,YACpC,UAAU,MAAM;AACZ,kBAAI;AAAQ,yBAAS,SAAS;AAAA,YAClC;AAAA,UACJ,CAAC;AAAA,QACL,GAlBgB;AAoBhB,gBAAQ;AAER,eAAO,MAAM;AACT,mBAAS;AACT,mBAAS,YAAY;AAAA,QACzB;AAAA,MACJ,CAAC;AAAA,IACL;AAAA,EACJ;AACJ,GArC4B;;;ADKrB,IAAM,YAAY,8BACrB,KACA,oBACkB;AAClB,MAAI,aAAuB,CAAC;AAE5B,QAAM,qBAAqB,iBAA4B;AAAA,IACnD,OAAO;AAAA,MACH,cAAc;AAAA,QACV,gBAAgB;AAAA,QAChB;AAAA,QACA,cAAc;AAAA,QACd,UAAU;AAAA,QACV,SAAS,EAAE,eAAe,UAAU,MAAM,gBAAgB,IAAI;AAAA,MAClE,CAAC;AAAA,IACL;AAAA,EACJ,CAAC;AAED,QAAM,gBAAgB,8BAClB,SAAS,KAAK,KAAK,OAAO,KAAK,OAAO,IAAI,OAAO,CAAC,MAC9B;AACpB,WAAO,mBAAmB,UAAU,cAAc,MAAM,EAAE,OAAO,CAAC;AAAA,EACtE,GAJsB;AAMtB,gBAAc,EAAE,KAAK,YAAW,aAAa,MAAO;AAEpD,QAAM,OAAO,iBAA4B;AAAA,IACrC,OAAO;AAAA,MACH,aAAa,YAAY;AACrB,qBAAa,MAAM,cAAc;AAAA,MACrC,CAAC;AAAA,MACD,cAAc;AAAA,QACV,gBAAgB;AAAA,QAChB;AAAA,QACA,UAAU;AAAA,QACV,cAAc;AAAA,QACd,SAAS,YAAY;AACjB,cAAI,WAAW,WAAW;AAAG,uBAAW,KAAK,GAAI,MAAM,cAAc,CAAE;AAEvE,iBAAO,EAAE,eAAe,UAAU,MAAM,gBAAgB,WAAW,IAAI,CAAC,IAAI;AAAA,QAChF;AAAA,MACJ,CAAC;AAAA,IACL;AAAA,EACJ,CAAC;AAED,SAAO;AACX,GA9CyB;AAgDzB,IAAO,cAAQ;",
6
6
  "names": []
7
7
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@learncard/learn-cloud-client",
3
- "version": "1.4.16",
3
+ "version": "1.4.18",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "module": "./dist/learn-cloud-client.esm.js",
@@ -11,11 +11,11 @@
11
11
  "devDependencies": {
12
12
  "dts-bundle-generator": "^6.10.0",
13
13
  "esbuild": "^0.16.16",
14
- "@learncard/types": "5.8.4"
14
+ "@learncard/types": "5.8.5"
15
15
  },
16
16
  "dependencies": {
17
17
  "@trpc/client": "^11.3.0",
18
- "@learncard/learn-cloud-service": "2.3.16"
18
+ "@learncard/learn-cloud-service": "2.3.17"
19
19
  },
20
20
  "scripts": {
21
21
  "build": "node ./scripts/build.mjs && shx cp ./scripts/mixedEntypoint.js ./dist/index.js && tsc --p tsconfig.json"
package/src/index.ts CHANGED
@@ -19,6 +19,7 @@ export const getClient = async (
19
19
  methodOverride: 'POST',
20
20
  url,
21
21
  maxURLLength: 3072,
22
+ maxItems: 50,
22
23
  headers: { Authorization: `Bearer ${await didAuthFunction()}` },
23
24
  }),
24
25
  ],
@@ -40,6 +41,7 @@ export const getClient = async (
40
41
  httpBatchLink({
41
42
  methodOverride: 'POST',
42
43
  url,
44
+ maxItems: 50,
43
45
  maxURLLength: 3072,
44
46
  headers: async () => {
45
47
  if (challenges.length === 0) challenges.push(...(await getChallenges()));