@elysiajs/eden 1.0.0-rc.0 → 1.0.0-rc.1

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/dist/index.d.mts CHANGED
@@ -32,11 +32,15 @@ declare namespace Treaty {
32
32
  _routes: infer Schema extends Record<string, any>;
33
33
  } ? Prettify<Sign<Schema>> : 'Please install Elysia before using Eden';
34
34
  export type Sign<in out Route extends Record<string, any>> = {
35
- [K in keyof Route as K extends '/' | '' ? 'index' : K extends `:${string}` ? never : K]: K extends 'subscribe' ? undefined extends Route['subscribe']['query'] ? (params?: {
36
- query?: Record<string, string>;
37
- }) => EdenWS<Route['subscribe']> : (params: {
35
+ [K in keyof Route as K extends '/' | '' ? 'index' : K extends `:${string}` ? never : K]: K extends 'subscribe' ? (undefined extends Route['subscribe']['headers'] ? {
36
+ headers?: Record<string, unknown>;
37
+ } : {
38
+ headers: Route['subscribe']['headers'];
39
+ }) & (undefined extends Route['subscribe']['query'] ? {
40
+ query?: Record<string, unknown>;
41
+ } : {
38
42
  query: Route['subscribe']['query'];
39
- }) => EdenWS<Route['subscribe']> : Route[K] extends {
43
+ }) extends infer Param ? {} extends Param ? (options?: Param) => EdenWS<Route['subscribe']> : (options?: Param) => EdenWS<Route['subscribe']> : never : Route[K] extends {
40
44
  body: infer Body;
41
45
  headers: infer Headers;
42
46
  params: any;
@@ -52,28 +56,35 @@ declare namespace Treaty {
52
56
  query: Query;
53
57
  }) extends infer Param ? {} extends Param ? undefined extends Body ? K extends 'get' | 'head' ? (options?: Prettify<Param & TreatyParam>) => Promise<TreatyResponse<Response>> : (body?: Body, options?: Prettify<Param & TreatyParam>) => Promise<TreatyResponse<Response>> : (body: Body extends Record<string, unknown> ? ReplaceBlobWithFiles<Body> : Body, options?: Prettify<Param & TreatyParam>) => Promise<TreatyResponse<Response>> : K extends 'get' | 'head' ? (options: Prettify<Param & TreatyParam>) => Promise<TreatyResponse<Response>> : (body: Body extends Record<string, unknown> ? ReplaceBlobWithFiles<Body> : Body, options: Prettify<Param & TreatyParam>) => Promise<TreatyResponse<Response>> : never : keyof Route[K] extends `:${infer Param}` ? (params: Record<Param, string>) => Prettify<Prettify<Sign<Route[K]>> & Sign<Route[K][`:${Param}`]>> : Prettify<Sign<Route[K]>>;
54
58
  };
55
- export interface Config extends Omit<RequestInit, 'headers'> {
59
+ export interface Config {
60
+ fetch?: Omit<RequestInit, 'headers' | 'method'>;
56
61
  fetcher?: typeof fetch;
57
62
  headers?: RequestInit['headers'] | MaybeArray<(path: string, options: RequestInit) => RequestInit['headers'] | void>;
58
63
  onRequest?: MaybeArray<(path: string, options: FetchRequestInit) => MaybePromise<FetchRequestInit | void>>;
59
64
  onResponse?: MaybeArray<(response: Response) => MaybePromise<unknown>>;
60
65
  }
61
- type TreatyResponse<Response extends Record<number, unknown>> = {
62
- data: Response[200];
66
+ type TreatyResponse<Res extends Record<number, unknown>> = {
67
+ data: Res[200];
63
68
  error: null;
69
+ response: Response;
70
+ status: number;
71
+ headers: FetchRequestInit['headers'];
64
72
  } | {
65
73
  data: null;
66
- error: Response extends {
74
+ error: Res extends {
67
75
  200: unknown;
68
76
  } ? {
69
- [Status in keyof Response as Status extends 200 ? never : Status]: {
77
+ [Status in keyof Res as Status extends 200 ? never : Status]: {
70
78
  status: Status;
71
- value: Response[Status];
79
+ value: Res[Status];
72
80
  };
73
81
  }[Exclude<keyof Response, 200>] : {
74
82
  status: unknown;
75
83
  value: unknown;
76
84
  };
85
+ response: Response;
86
+ status: number;
87
+ headers: FetchRequestInit['headers'];
77
88
  };
78
89
  export interface OnMessage<Data = unknown> extends MessageEvent {
79
90
  data: Data;
package/dist/index.d.ts CHANGED
@@ -32,11 +32,15 @@ declare namespace Treaty {
32
32
  _routes: infer Schema extends Record<string, any>;
33
33
  } ? Prettify<Sign<Schema>> : 'Please install Elysia before using Eden';
34
34
  export type Sign<in out Route extends Record<string, any>> = {
35
- [K in keyof Route as K extends '/' | '' ? 'index' : K extends `:${string}` ? never : K]: K extends 'subscribe' ? undefined extends Route['subscribe']['query'] ? (params?: {
36
- query?: Record<string, string>;
37
- }) => EdenWS<Route['subscribe']> : (params: {
35
+ [K in keyof Route as K extends '/' | '' ? 'index' : K extends `:${string}` ? never : K]: K extends 'subscribe' ? (undefined extends Route['subscribe']['headers'] ? {
36
+ headers?: Record<string, unknown>;
37
+ } : {
38
+ headers: Route['subscribe']['headers'];
39
+ }) & (undefined extends Route['subscribe']['query'] ? {
40
+ query?: Record<string, unknown>;
41
+ } : {
38
42
  query: Route['subscribe']['query'];
39
- }) => EdenWS<Route['subscribe']> : Route[K] extends {
43
+ }) extends infer Param ? {} extends Param ? (options?: Param) => EdenWS<Route['subscribe']> : (options?: Param) => EdenWS<Route['subscribe']> : never : Route[K] extends {
40
44
  body: infer Body;
41
45
  headers: infer Headers;
42
46
  params: any;
@@ -52,28 +56,35 @@ declare namespace Treaty {
52
56
  query: Query;
53
57
  }) extends infer Param ? {} extends Param ? undefined extends Body ? K extends 'get' | 'head' ? (options?: Prettify<Param & TreatyParam>) => Promise<TreatyResponse<Response>> : (body?: Body, options?: Prettify<Param & TreatyParam>) => Promise<TreatyResponse<Response>> : (body: Body extends Record<string, unknown> ? ReplaceBlobWithFiles<Body> : Body, options?: Prettify<Param & TreatyParam>) => Promise<TreatyResponse<Response>> : K extends 'get' | 'head' ? (options: Prettify<Param & TreatyParam>) => Promise<TreatyResponse<Response>> : (body: Body extends Record<string, unknown> ? ReplaceBlobWithFiles<Body> : Body, options: Prettify<Param & TreatyParam>) => Promise<TreatyResponse<Response>> : never : keyof Route[K] extends `:${infer Param}` ? (params: Record<Param, string>) => Prettify<Prettify<Sign<Route[K]>> & Sign<Route[K][`:${Param}`]>> : Prettify<Sign<Route[K]>>;
54
58
  };
55
- export interface Config extends Omit<RequestInit, 'headers'> {
59
+ export interface Config {
60
+ fetch?: Omit<RequestInit, 'headers' | 'method'>;
56
61
  fetcher?: typeof fetch;
57
62
  headers?: RequestInit['headers'] | MaybeArray<(path: string, options: RequestInit) => RequestInit['headers'] | void>;
58
63
  onRequest?: MaybeArray<(path: string, options: FetchRequestInit) => MaybePromise<FetchRequestInit | void>>;
59
64
  onResponse?: MaybeArray<(response: Response) => MaybePromise<unknown>>;
60
65
  }
61
- type TreatyResponse<Response extends Record<number, unknown>> = {
62
- data: Response[200];
66
+ type TreatyResponse<Res extends Record<number, unknown>> = {
67
+ data: Res[200];
63
68
  error: null;
69
+ response: Response;
70
+ status: number;
71
+ headers: FetchRequestInit['headers'];
64
72
  } | {
65
73
  data: null;
66
- error: Response extends {
74
+ error: Res extends {
67
75
  200: unknown;
68
76
  } ? {
69
- [Status in keyof Response as Status extends 200 ? never : Status]: {
77
+ [Status in keyof Res as Status extends 200 ? never : Status]: {
70
78
  status: Status;
71
- value: Response[Status];
79
+ value: Res[Status];
72
80
  };
73
81
  }[Exclude<keyof Response, 200>] : {
74
82
  status: unknown;
75
83
  value: unknown;
76
84
  };
85
+ response: Response;
86
+ status: number;
87
+ headers: FetchRequestInit['headers'];
77
88
  };
78
89
  export interface OnMessage<Data = unknown> extends MessageEvent {
79
90
  data: Data;
@@ -1 +1 @@
1
- "use strict";var Eden=(()=>{var P=Object.defineProperty;var Z=Object.getOwnPropertyDescriptor;var ee=Object.getOwnPropertyNames;var te=Object.prototype.hasOwnProperty;var re=(t,e)=>{for(var r in e)P(t,r,{get:e[r],enumerable:!0})},ne=(t,e,r,a)=>{if(e&&typeof e=="object"||typeof e=="function")for(let f of ee(e))!te.call(t,f)&&f!==r&&P(t,f,{get:()=>e[f],enumerable:!(a=Z(e,f))||a.enumerable});return t};var se=t=>ne(P({},"__esModule",{value:!0}),t);var ce={};re(ce,{edenFetch:()=>Y,edenTreaty:()=>X,treaty:()=>V});var U=(t,e,r)=>{if(t.endsWith("/")||(t+="/"),e==="index"&&(e=""),!r||!Object.keys(r).length)return`${t}${e}`;let a="";for(let[f,n]of Object.entries(r))a+=`${f}=${n}&`;return`${t}${e}?${a.slice(0,-1)}`},x=t=>t.trim().length!==0&&!Number.isNaN(Number(t));var A=class extends Error{constructor(r,a){super(a+"");this.status=r;this.value=a}};var N=class{constructor(e){this.url=e;this.ws=new WebSocket(e)}ws;send(e){return Array.isArray(e)?(e.forEach(r=>this.send(r)),this):(this.ws.send(typeof e=="object"?JSON.stringify(e):e.toString()),this)}on(e,r,a){return this.addEventListener(e,r,a)}off(e,r,a){return this.ws.removeEventListener(e,r,a),this}subscribe(e,r){return this.addEventListener("message",e,r)}addEventListener(e,r,a){return this.ws.addEventListener(e,f=>{if(e==="message"){let n=f.data.toString(),i=n.charCodeAt(0);if(i===47||i===123)try{n=JSON.parse(n)}catch{}else x(n)?n=+n:n==="true"?n=!0:n==="false"&&(n=!1);r({...f,data:n})}else r(f)},a),this}removeEventListener(e,r,a){return this.off(e,r,a),this}close(){return this.ws.close(),this}};var ae=["get","post","put","delete","patch","options","head","connect","subscribe"],G=["localhost","127.0.0.1","0.0.0.0"],J=typeof FileList>"u",_=t=>J?t instanceof Blob:t instanceof FileList||t instanceof File,ie=t=>{if(!t)return!1;for(let e in t)if(_(t[e])||Array.isArray(t[e])&&t[e].find(_))return!0;return!1},q=t=>J?t:new Promise(e=>{let r=new FileReader;r.onload=()=>{let a=new File([r.result],t.name,{lastModified:t.lastModified,type:t.type});e(a)},r.readAsArrayBuffer(t)}),M=(t,e,r=[],a)=>new Proxy(()=>{},{get(f,n){return M(t,e,n==="index"?r:[...r,n],a)},apply(f,n,[i,p={}]){if(!i||p||typeof i=="object"&&Object.keys(i).length!==1||ae.includes(r.at(-1))){let k=r.pop(),w="/"+r.join("/"),{fetcher:T=fetch,headers:s,onRequest:h,onResponse:E,...K}=e,F=k==="get"||k==="head"||k==="subscribe";s={...typeof s=="object"&&!Array.isArray(s)?s:{},...F?i?.headers:p?.headers};let L=F?i?.query:p?.query,R="";if(L)for(let[c,u]of Object.entries(L))R+=(R?"&":"?")+`${c}=${u}`;if(typeof e.headers=="function"&&!(s instanceof Headers)){let c=e.headers(w,p);c&&(s={...s,...c})}else if(Array.isArray(e.headers)&&e.headers.every(c=>typeof c=="function"))for(let c of e.headers){let u=c(w,p);u&&(s={...s,...u})}else if(s instanceof Headers){s||(s={});for(let[c,u]of Object.entries(s))s[c]=u}if(k==="subscribe"){let c=t.replace(/^([^]+):\/\//,t.startsWith("https://")?"wss://":t.startsWith("http://")||G.find(u=>t.includes(u))?"ws://":"wss://")+w+R;return new N(c)}return(async()=>{let c=(s instanceof Headers?s.get("content-type"):Array.isArray(s)?s.find(o=>Array.isArray(o)&&o[0]==="headers"?o[1]:!1):typeof s=="function"?s(w,p):s?.contentType)||p?.headers?.contentType;if(!c)if(typeof i=="object")c="application/json",i=JSON.stringify(i);else if(ie(i)){let o=new FormData;for(let[d,m]of Object.entries(i)){if(J){o.append(d,m);continue}if(m instanceof File){o.append(d,await q(m));continue}if(m instanceof FileList){for(let l=0;l<m.length;l++)o.append(d,await q(m[l]));continue}if(Array.isArray(m)){for(let l=0;l<m.length;l++){let b=m[l];o.append(d,b instanceof File?await q(b):b)}continue}o.append(d,m)}i=o}else i!=null&&(c="text/plain");let u={method:k,body:i,...K,headers:{...s,"content-type":c}};if(F&&delete u.body,h){Array.isArray(h)||(h=[h]);for(let o of h){let d=await o(w,u);typeof d=="object"&&(u={...u,...d,headers:{...u.headers,...d.headers}})}}let C=t+w+R,g=await(a?.handle(new Request(C,u))??T(C,u)),y,O;if(E){Array.isArray(E)||(E=[E]);for(let o of E)try{if(y=await o(g.clone()),y!==void 0)break}catch(d){d instanceof A?O=d:O=new A(422,d);break}}if(y===void 0){switch(g.headers.get("Content-Type")?.split(";")[0]){case"application/json":y=await g.json();break;case"application/octet-stream":y=await g.arrayBuffer();break;default:y=await g.text().then(o=>x(o)?+o:o==="true"?!0:o==="false"?!1:o)}(g.status>=300||g.status<200)&&(O=new A(g.status,y),y=void 0)}return{data:y,error:O,response:g,status:g.status,headers:g.headers}})()}return typeof i=="object"?M(t,e,[...r,Object.values(i)[0]],a):M(t,e,r)}}),V=(t,e={})=>typeof t=="string"?(t.includes("://")||(t=(G.find(r=>t.includes(r))?"http://":"https://")+t),t.endsWith("/")&&(t=t.slice(0,-1)),M(t,e)):(typeof window<"u"&&console.warn("Elysia instance server found on client side, this is not recommended for security reason. Use generic type instead."),M("http://e.ly",e,[],t));var B=typeof FileList>"u",z=t=>B?t instanceof Blob:t instanceof FileList||t instanceof File,oe=t=>{if(!t)return!1;for(let e in t){if(z(t[e]))return!0;if(Array.isArray(t[e])&&t[e].find(r=>z(r)))return!0}return!1},D=t=>B?t:new Promise(e=>{let r=new FileReader;r.onload=()=>{let a=new File([r.result],t.name,{lastModified:t.lastModified,type:t.type});e(a)},r.readAsArrayBuffer(t)}),H=class{ws;url;constructor(e){this.ws=new WebSocket(e),this.url=e}send(e){return Array.isArray(e)?(e.forEach(r=>this.send(r)),this):(this.ws.send(typeof e=="object"?JSON.stringify(e):e.toString()),this)}on(e,r,a){return this.addEventListener(e,r,a)}off(e,r,a){return this.ws.removeEventListener(e,r,a),this}subscribe(e,r){return this.addEventListener("message",e,r)}addEventListener(e,r,a){return this.ws.addEventListener(e,f=>{if(e==="message"){let n=f.data.toString(),i=n.charCodeAt(0);if(i===47||i===123)try{n=JSON.parse(n)}catch{}else x(n)?n=+n:n==="true"?n=!0:n==="false"&&(n=!1);r({...f,data:n})}else r(f)},a),this}removeEventListener(e,r,a){return this.off(e,r,a),this}close(){return this.ws.close(),this}},Q=(t,e="",r)=>new Proxy(()=>{},{get(a,f,n){return Q(t,`${e}/${f.toString()}`,r)},apply(a,f,[n,i={}]=[{},{}]){let p=n!==void 0&&(typeof n!="object"||Array.isArray(n))?n:void 0,{$query:k,$fetch:w,$headers:T,$transform:s,getRaw:h,...E}=n??{};p??=E;let K=e.lastIndexOf("/"),F=e.slice(K+1).toUpperCase(),L=U(t,K===-1?"/":e.slice(0,K),Object.assign(i.query??{},k)),R=r.fetcher??fetch,c=r.transform?Array.isArray(r.transform)?r.transform:[r.transform]:void 0,u=s?Array.isArray(s)?s:[s]:void 0;return u&&(c?c=u.concat(c):c=u),F==="SUBSCRIBE"?new H(L.replace(/^([^]+):\/\//,L.startsWith("https://")?"wss://":"ws://")):(async g=>{let y,O={...r.$fetch?.headers,...w?.headers,...i.headers,...T};if(F!=="GET"&&F!=="HEAD"){y=Object.keys(p).length||Array.isArray(p)?p:void 0;let l=y&&(typeof y=="object"||Array.isArray(p));if(l&&oe(y)){let j=new FormData;for(let[$,v]of Object.entries(y))if(B)j.append($,v);else if(v instanceof File)j.append($,await D(v));else if(v instanceof FileList)for(let W=0;W<v.length;W++)j.append($,await D(v[W]));else if(Array.isArray(v))for(let W=0;W<v.length;W++){let I=v[W];j.append($,I instanceof File?await D(I):I)}else j.append($,v);y=j}else y!=null&&(O["content-type"]=l?"application/json":"text/plain",y=l?JSON.stringify(y):p)}let S=await R(L,{method:F,body:y,...r.$fetch,...i.fetch,...w,headers:O}),o;if(g.getRaw)return S;switch(S.headers.get("Content-Type")?.split(";")[0]){case"application/json":o=await S.json();break;default:o=await S.text().then(l=>x(l)?+l:l==="true"?!0:l==="false"?!1:l)}let d=S.status>=300||S.status<200?new A(S.status,o):null,m={data:o,error:d,response:S,status:S.status,headers:S.headers};if(c)for(let l of c){let b=l(m);b instanceof Promise&&(b=await b),b!=null&&(m=b)}return m})({getRaw:h})}}),X=(t,e={fetcher:fetch})=>new Proxy({},{get(r,a){return Q(t,a,e)}});var Y=(t,e)=>(r,{query:a,params:f,body:n,...i}={})=>{f&&Object.entries(f).forEach(([s,h])=>{r=r.replace(`:${s}`,h)});let p=i.headers?.["Content-Type"];if(!p||p==="application/json")try{n=JSON.stringify(n)}catch{}let k=e?.fetcher||globalThis.fetch,w=a?`?${new URLSearchParams(a).toString()}`:"",T=()=>k(t+r+w,{...i,method:i.method?.toUpperCase()||"GET",headers:n?{"content-type":"application/json",...i.headers}:i.headers,body:n}).then(async s=>{let h;switch(s.headers.get("Content-Type")?.split(";")[0]){case"application/json":h=await s.json();break;default:h=await s.text().then(E=>x(E)?parseInt(E):E==="true"?!0:E==="false"?!1:E);break}return s.status>300?{data:null,status:s.status,headers:s.headers,retry:T,error:new A(s.status,h)}:{data:h,error:null,status:s.status,headers:s.headers,retry:T}});return T()};return se(ce);})();
1
+ "use strict";var Eden=(()=>{var P=Object.defineProperty;var Z=Object.getOwnPropertyDescriptor;var ee=Object.getOwnPropertyNames;var te=Object.prototype.hasOwnProperty;var re=(t,e)=>{for(var r in e)P(t,r,{get:e[r],enumerable:!0})},ne=(t,e,r,a)=>{if(e&&typeof e=="object"||typeof e=="function")for(let f of ee(e))!te.call(t,f)&&f!==r&&P(t,f,{get:()=>e[f],enumerable:!(a=Z(e,f))||a.enumerable});return t};var se=t=>ne(P({},"__esModule",{value:!0}),t);var ce={};re(ce,{edenFetch:()=>Y,edenTreaty:()=>X,treaty:()=>V});var U=(t,e,r)=>{if(t.endsWith("/")||(t+="/"),e==="index"&&(e=""),!r||!Object.keys(r).length)return`${t}${e}`;let a="";for(let[f,n]of Object.entries(r))a+=`${f}=${n}&`;return`${t}${e}?${a.slice(0,-1)}`},x=t=>t.trim().length!==0&&!Number.isNaN(Number(t));var A=class extends Error{constructor(r,a){super(a+"");this.status=r;this.value=a}};var N=class{constructor(e){this.url=e;this.ws=new WebSocket(e)}ws;send(e){return Array.isArray(e)?(e.forEach(r=>this.send(r)),this):(this.ws.send(typeof e=="object"?JSON.stringify(e):e.toString()),this)}on(e,r,a){return this.addEventListener(e,r,a)}off(e,r,a){return this.ws.removeEventListener(e,r,a),this}subscribe(e,r){return this.addEventListener("message",e,r)}addEventListener(e,r,a){return this.ws.addEventListener(e,f=>{if(e==="message"){let n=f.data.toString(),i=n.charCodeAt(0);if(i===47||i===123)try{n=JSON.parse(n)}catch{}else x(n)?n=+n:n==="true"?n=!0:n==="false"&&(n=!1);r({...f,data:n})}else r(f)},a),this}removeEventListener(e,r,a){return this.off(e,r,a),this}close(){return this.ws.close(),this}};var ae=["get","post","put","delete","patch","options","head","connect","subscribe"],G=["localhost","127.0.0.1","0.0.0.0"],J=typeof FileList>"u",_=t=>J?t instanceof Blob:t instanceof FileList||t instanceof File,ie=t=>{if(!t)return!1;for(let e in t)if(_(t[e])||Array.isArray(t[e])&&t[e].find(_))return!0;return!1},q=t=>J?t:new Promise(e=>{let r=new FileReader;r.onload=()=>{let a=new File([r.result],t.name,{lastModified:t.lastModified,type:t.type});e(a)},r.readAsArrayBuffer(t)}),M=(t,e,r=[],a)=>new Proxy(()=>{},{get(f,n){return M(t,e,n==="index"?r:[...r,n],a)},apply(f,n,[i,p={}]){if(!i||p||typeof i=="object"&&Object.keys(i).length!==1||ae.includes(r.at(-1))){let k=r.pop(),w="/"+r.join("/"),{fetcher:T=fetch,headers:s,onRequest:h,onResponse:E,fetch:K}=e,F=k==="get"||k==="head"||k==="subscribe";s={...typeof s=="object"&&!Array.isArray(s)?s:{},...F?i?.headers:p?.headers};let L=F?i?.query:p?.query,R="";if(L)for(let[c,u]of Object.entries(L))R+=(R?"&":"?")+`${c}=${u}`;if(typeof e.headers=="function"&&!(s instanceof Headers)){let c=e.headers(w,p);c&&(s={...s,...c})}else if(Array.isArray(e.headers)&&e.headers.every(c=>typeof c=="function"))for(let c of e.headers){let u=c(w,p);u&&(s={...s,...u})}else if(s instanceof Headers){s||(s={});for(let[c,u]of Object.entries(s))s[c]=u}if(k==="subscribe"){let c=t.replace(/^([^]+):\/\//,t.startsWith("https://")?"wss://":t.startsWith("http://")||G.find(u=>t.includes(u))?"ws://":"wss://")+w+R;return new N(c)}return(async()=>{let c=(s instanceof Headers?s.get("content-type"):Array.isArray(s)?s.find(o=>Array.isArray(o)&&o[0]==="headers"?o[1]:!1):typeof s=="function"?s(w,p):s?.contentType)||p?.headers?.contentType;if(!c)if(typeof i=="object")c="application/json",i=JSON.stringify(i);else if(ie(i)){let o=new FormData;for(let[d,m]of Object.entries(i)){if(J){o.append(d,m);continue}if(m instanceof File){o.append(d,await q(m));continue}if(m instanceof FileList){for(let l=0;l<m.length;l++)o.append(d,await q(m[l]));continue}if(Array.isArray(m)){for(let l=0;l<m.length;l++){let b=m[l];o.append(d,b instanceof File?await q(b):b)}continue}o.append(d,m)}i=o}else i!=null&&(c="text/plain");let u={method:k,body:i,...K,headers:{...s,"content-type":c}};if(F&&delete u.body,h){Array.isArray(h)||(h=[h]);for(let o of h){let d=await o(w,u);typeof d=="object"&&(u={...u,...d,headers:{...u.headers,...d.headers}})}}let C=t+w+R,g=await(a?.handle(new Request(C,u))??T(C,u)),y,O;if(E){Array.isArray(E)||(E=[E]);for(let o of E)try{if(y=await o(g.clone()),y!==void 0)break}catch(d){d instanceof A?O=d:O=new A(422,d);break}}if(y===void 0){switch(g.headers.get("Content-Type")?.split(";")[0]){case"application/json":y=await g.json();break;case"application/octet-stream":y=await g.arrayBuffer();break;default:y=await g.text().then(o=>x(o)?+o:o==="true"?!0:o==="false"?!1:o)}(g.status>=300||g.status<200)&&(O=new A(g.status,y),y=void 0)}return{data:y,error:O,response:g,status:g.status,headers:g.headers}})()}return typeof i=="object"?M(t,e,[...r,Object.values(i)[0]],a):M(t,e,r)}}),V=(t,e={})=>typeof t=="string"?(t.includes("://")||(t=(G.find(r=>t.includes(r))?"http://":"https://")+t),t.endsWith("/")&&(t=t.slice(0,-1)),M(t,e)):(typeof window<"u"&&console.warn("Elysia instance server found on client side, this is not recommended for security reason. Use generic type instead."),M("http://e.ly",e,[],t));var B=typeof FileList>"u",z=t=>B?t instanceof Blob:t instanceof FileList||t instanceof File,oe=t=>{if(!t)return!1;for(let e in t){if(z(t[e]))return!0;if(Array.isArray(t[e])&&t[e].find(r=>z(r)))return!0}return!1},D=t=>B?t:new Promise(e=>{let r=new FileReader;r.onload=()=>{let a=new File([r.result],t.name,{lastModified:t.lastModified,type:t.type});e(a)},r.readAsArrayBuffer(t)}),H=class{ws;url;constructor(e){this.ws=new WebSocket(e),this.url=e}send(e){return Array.isArray(e)?(e.forEach(r=>this.send(r)),this):(this.ws.send(typeof e=="object"?JSON.stringify(e):e.toString()),this)}on(e,r,a){return this.addEventListener(e,r,a)}off(e,r,a){return this.ws.removeEventListener(e,r,a),this}subscribe(e,r){return this.addEventListener("message",e,r)}addEventListener(e,r,a){return this.ws.addEventListener(e,f=>{if(e==="message"){let n=f.data.toString(),i=n.charCodeAt(0);if(i===47||i===123)try{n=JSON.parse(n)}catch{}else x(n)?n=+n:n==="true"?n=!0:n==="false"&&(n=!1);r({...f,data:n})}else r(f)},a),this}removeEventListener(e,r,a){return this.off(e,r,a),this}close(){return this.ws.close(),this}},Q=(t,e="",r)=>new Proxy(()=>{},{get(a,f,n){return Q(t,`${e}/${f.toString()}`,r)},apply(a,f,[n,i={}]=[{},{}]){let p=n!==void 0&&(typeof n!="object"||Array.isArray(n))?n:void 0,{$query:k,$fetch:w,$headers:T,$transform:s,getRaw:h,...E}=n??{};p??=E;let K=e.lastIndexOf("/"),F=e.slice(K+1).toUpperCase(),L=U(t,K===-1?"/":e.slice(0,K),Object.assign(i.query??{},k)),R=r.fetcher??fetch,c=r.transform?Array.isArray(r.transform)?r.transform:[r.transform]:void 0,u=s?Array.isArray(s)?s:[s]:void 0;return u&&(c?c=u.concat(c):c=u),F==="SUBSCRIBE"?new H(L.replace(/^([^]+):\/\//,L.startsWith("https://")?"wss://":"ws://")):(async g=>{let y,O={...r.$fetch?.headers,...w?.headers,...i.headers,...T};if(F!=="GET"&&F!=="HEAD"){y=Object.keys(p).length||Array.isArray(p)?p:void 0;let l=y&&(typeof y=="object"||Array.isArray(p));if(l&&oe(y)){let j=new FormData;for(let[$,v]of Object.entries(y))if(B)j.append($,v);else if(v instanceof File)j.append($,await D(v));else if(v instanceof FileList)for(let W=0;W<v.length;W++)j.append($,await D(v[W]));else if(Array.isArray(v))for(let W=0;W<v.length;W++){let I=v[W];j.append($,I instanceof File?await D(I):I)}else j.append($,v);y=j}else y!=null&&(O["content-type"]=l?"application/json":"text/plain",y=l?JSON.stringify(y):p)}let S=await R(L,{method:F,body:y,...r.$fetch,...i.fetch,...w,headers:O}),o;if(g.getRaw)return S;switch(S.headers.get("Content-Type")?.split(";")[0]){case"application/json":o=await S.json();break;default:o=await S.text().then(l=>x(l)?+l:l==="true"?!0:l==="false"?!1:l)}let d=S.status>=300||S.status<200?new A(S.status,o):null,m={data:o,error:d,response:S,status:S.status,headers:S.headers};if(c)for(let l of c){let b=l(m);b instanceof Promise&&(b=await b),b!=null&&(m=b)}return m})({getRaw:h})}}),X=(t,e={fetcher:fetch})=>new Proxy({},{get(r,a){return Q(t,a,e)}});var Y=(t,e)=>(r,{query:a,params:f,body:n,...i}={})=>{f&&Object.entries(f).forEach(([s,h])=>{r=r.replace(`:${s}`,h)});let p=i.headers?.["Content-Type"];if(!p||p==="application/json")try{n=JSON.stringify(n)}catch{}let k=e?.fetcher||globalThis.fetch,w=a?`?${new URLSearchParams(a).toString()}`:"",T=()=>k(t+r+w,{...i,method:i.method?.toUpperCase()||"GET",headers:n?{"content-type":"application/json",...i.headers}:i.headers,body:n}).then(async s=>{let h;switch(s.headers.get("Content-Type")?.split(";")[0]){case"application/json":h=await s.json();break;default:h=await s.text().then(E=>x(E)?parseInt(E):E==="true"?!0:E==="false"?!1:E);break}return s.status>300?{data:null,status:s.status,headers:s.headers,retry:T,error:new A(s.status,h)}:{data:h,error:null,status:s.status,headers:s.headers,retry:T}});return T()};return se(ce);})();
package/dist/index.js CHANGED
@@ -1 +1 @@
1
- "use strict";var P=Object.defineProperty;var Z=Object.getOwnPropertyDescriptor;var ee=Object.getOwnPropertyNames;var te=Object.prototype.hasOwnProperty;var re=(t,e)=>{for(var r in e)P(t,r,{get:e[r],enumerable:!0})},ne=(t,e,r,a)=>{if(e&&typeof e=="object"||typeof e=="function")for(let f of ee(e))!te.call(t,f)&&f!==r&&P(t,f,{get:()=>e[f],enumerable:!(a=Z(e,f))||a.enumerable});return t};var se=t=>ne(P({},"__esModule",{value:!0}),t);var ce={};re(ce,{edenFetch:()=>Y,edenTreaty:()=>X,treaty:()=>V});module.exports=se(ce);var U=(t,e,r)=>{if(t.endsWith("/")||(t+="/"),e==="index"&&(e=""),!r||!Object.keys(r).length)return`${t}${e}`;let a="";for(let[f,n]of Object.entries(r))a+=`${f}=${n}&`;return`${t}${e}?${a.slice(0,-1)}`},x=t=>t.trim().length!==0&&!Number.isNaN(Number(t));var A=class extends Error{constructor(r,a){super(a+"");this.status=r;this.value=a}};var N=class{constructor(e){this.url=e;this.ws=new WebSocket(e)}ws;send(e){return Array.isArray(e)?(e.forEach(r=>this.send(r)),this):(this.ws.send(typeof e=="object"?JSON.stringify(e):e.toString()),this)}on(e,r,a){return this.addEventListener(e,r,a)}off(e,r,a){return this.ws.removeEventListener(e,r,a),this}subscribe(e,r){return this.addEventListener("message",e,r)}addEventListener(e,r,a){return this.ws.addEventListener(e,f=>{if(e==="message"){let n=f.data.toString(),i=n.charCodeAt(0);if(i===47||i===123)try{n=JSON.parse(n)}catch{}else x(n)?n=+n:n==="true"?n=!0:n==="false"&&(n=!1);r({...f,data:n})}else r(f)},a),this}removeEventListener(e,r,a){return this.off(e,r,a),this}close(){return this.ws.close(),this}};var ae=["get","post","put","delete","patch","options","head","connect","subscribe"],G=["localhost","127.0.0.1","0.0.0.0"],J=typeof FileList>"u",_=t=>J?t instanceof Blob:t instanceof FileList||t instanceof File,ie=t=>{if(!t)return!1;for(let e in t)if(_(t[e])||Array.isArray(t[e])&&t[e].find(_))return!0;return!1},q=t=>J?t:new Promise(e=>{let r=new FileReader;r.onload=()=>{let a=new File([r.result],t.name,{lastModified:t.lastModified,type:t.type});e(a)},r.readAsArrayBuffer(t)}),M=(t,e,r=[],a)=>new Proxy(()=>{},{get(f,n){return M(t,e,n==="index"?r:[...r,n],a)},apply(f,n,[i,p={}]){if(!i||p||typeof i=="object"&&Object.keys(i).length!==1||ae.includes(r.at(-1))){let k=r.pop(),w="/"+r.join("/"),{fetcher:T=fetch,headers:s,onRequest:h,onResponse:E,...K}=e,F=k==="get"||k==="head"||k==="subscribe";s={...typeof s=="object"&&!Array.isArray(s)?s:{},...F?i?.headers:p?.headers};let L=F?i?.query:p?.query,R="";if(L)for(let[c,u]of Object.entries(L))R+=(R?"&":"?")+`${c}=${u}`;if(typeof e.headers=="function"&&!(s instanceof Headers)){let c=e.headers(w,p);c&&(s={...s,...c})}else if(Array.isArray(e.headers)&&e.headers.every(c=>typeof c=="function"))for(let c of e.headers){let u=c(w,p);u&&(s={...s,...u})}else if(s instanceof Headers){s||(s={});for(let[c,u]of Object.entries(s))s[c]=u}if(k==="subscribe"){let c=t.replace(/^([^]+):\/\//,t.startsWith("https://")?"wss://":t.startsWith("http://")||G.find(u=>t.includes(u))?"ws://":"wss://")+w+R;return new N(c)}return(async()=>{let c=(s instanceof Headers?s.get("content-type"):Array.isArray(s)?s.find(o=>Array.isArray(o)&&o[0]==="headers"?o[1]:!1):typeof s=="function"?s(w,p):s?.contentType)||p?.headers?.contentType;if(!c)if(typeof i=="object")c="application/json",i=JSON.stringify(i);else if(ie(i)){let o=new FormData;for(let[d,m]of Object.entries(i)){if(J){o.append(d,m);continue}if(m instanceof File){o.append(d,await q(m));continue}if(m instanceof FileList){for(let l=0;l<m.length;l++)o.append(d,await q(m[l]));continue}if(Array.isArray(m)){for(let l=0;l<m.length;l++){let b=m[l];o.append(d,b instanceof File?await q(b):b)}continue}o.append(d,m)}i=o}else i!=null&&(c="text/plain");let u={method:k,body:i,...K,headers:{...s,"content-type":c}};if(F&&delete u.body,h){Array.isArray(h)||(h=[h]);for(let o of h){let d=await o(w,u);typeof d=="object"&&(u={...u,...d,headers:{...u.headers,...d.headers}})}}let C=t+w+R,g=await(a?.handle(new Request(C,u))??T(C,u)),y,O;if(E){Array.isArray(E)||(E=[E]);for(let o of E)try{if(y=await o(g.clone()),y!==void 0)break}catch(d){d instanceof A?O=d:O=new A(422,d);break}}if(y===void 0){switch(g.headers.get("Content-Type")?.split(";")[0]){case"application/json":y=await g.json();break;case"application/octet-stream":y=await g.arrayBuffer();break;default:y=await g.text().then(o=>x(o)?+o:o==="true"?!0:o==="false"?!1:o)}(g.status>=300||g.status<200)&&(O=new A(g.status,y),y=void 0)}return{data:y,error:O,response:g,status:g.status,headers:g.headers}})()}return typeof i=="object"?M(t,e,[...r,Object.values(i)[0]],a):M(t,e,r)}}),V=(t,e={})=>typeof t=="string"?(t.includes("://")||(t=(G.find(r=>t.includes(r))?"http://":"https://")+t),t.endsWith("/")&&(t=t.slice(0,-1)),M(t,e)):(typeof window<"u"&&console.warn("Elysia instance server found on client side, this is not recommended for security reason. Use generic type instead."),M("http://e.ly",e,[],t));var B=typeof FileList>"u",z=t=>B?t instanceof Blob:t instanceof FileList||t instanceof File,oe=t=>{if(!t)return!1;for(let e in t){if(z(t[e]))return!0;if(Array.isArray(t[e])&&t[e].find(r=>z(r)))return!0}return!1},D=t=>B?t:new Promise(e=>{let r=new FileReader;r.onload=()=>{let a=new File([r.result],t.name,{lastModified:t.lastModified,type:t.type});e(a)},r.readAsArrayBuffer(t)}),H=class{ws;url;constructor(e){this.ws=new WebSocket(e),this.url=e}send(e){return Array.isArray(e)?(e.forEach(r=>this.send(r)),this):(this.ws.send(typeof e=="object"?JSON.stringify(e):e.toString()),this)}on(e,r,a){return this.addEventListener(e,r,a)}off(e,r,a){return this.ws.removeEventListener(e,r,a),this}subscribe(e,r){return this.addEventListener("message",e,r)}addEventListener(e,r,a){return this.ws.addEventListener(e,f=>{if(e==="message"){let n=f.data.toString(),i=n.charCodeAt(0);if(i===47||i===123)try{n=JSON.parse(n)}catch{}else x(n)?n=+n:n==="true"?n=!0:n==="false"&&(n=!1);r({...f,data:n})}else r(f)},a),this}removeEventListener(e,r,a){return this.off(e,r,a),this}close(){return this.ws.close(),this}},Q=(t,e="",r)=>new Proxy(()=>{},{get(a,f,n){return Q(t,`${e}/${f.toString()}`,r)},apply(a,f,[n,i={}]=[{},{}]){let p=n!==void 0&&(typeof n!="object"||Array.isArray(n))?n:void 0,{$query:k,$fetch:w,$headers:T,$transform:s,getRaw:h,...E}=n??{};p??=E;let K=e.lastIndexOf("/"),F=e.slice(K+1).toUpperCase(),L=U(t,K===-1?"/":e.slice(0,K),Object.assign(i.query??{},k)),R=r.fetcher??fetch,c=r.transform?Array.isArray(r.transform)?r.transform:[r.transform]:void 0,u=s?Array.isArray(s)?s:[s]:void 0;return u&&(c?c=u.concat(c):c=u),F==="SUBSCRIBE"?new H(L.replace(/^([^]+):\/\//,L.startsWith("https://")?"wss://":"ws://")):(async g=>{let y,O={...r.$fetch?.headers,...w?.headers,...i.headers,...T};if(F!=="GET"&&F!=="HEAD"){y=Object.keys(p).length||Array.isArray(p)?p:void 0;let l=y&&(typeof y=="object"||Array.isArray(p));if(l&&oe(y)){let j=new FormData;for(let[$,v]of Object.entries(y))if(B)j.append($,v);else if(v instanceof File)j.append($,await D(v));else if(v instanceof FileList)for(let W=0;W<v.length;W++)j.append($,await D(v[W]));else if(Array.isArray(v))for(let W=0;W<v.length;W++){let I=v[W];j.append($,I instanceof File?await D(I):I)}else j.append($,v);y=j}else y!=null&&(O["content-type"]=l?"application/json":"text/plain",y=l?JSON.stringify(y):p)}let S=await R(L,{method:F,body:y,...r.$fetch,...i.fetch,...w,headers:O}),o;if(g.getRaw)return S;switch(S.headers.get("Content-Type")?.split(";")[0]){case"application/json":o=await S.json();break;default:o=await S.text().then(l=>x(l)?+l:l==="true"?!0:l==="false"?!1:l)}let d=S.status>=300||S.status<200?new A(S.status,o):null,m={data:o,error:d,response:S,status:S.status,headers:S.headers};if(c)for(let l of c){let b=l(m);b instanceof Promise&&(b=await b),b!=null&&(m=b)}return m})({getRaw:h})}}),X=(t,e={fetcher:fetch})=>new Proxy({},{get(r,a){return Q(t,a,e)}});var Y=(t,e)=>(r,{query:a,params:f,body:n,...i}={})=>{f&&Object.entries(f).forEach(([s,h])=>{r=r.replace(`:${s}`,h)});let p=i.headers?.["Content-Type"];if(!p||p==="application/json")try{n=JSON.stringify(n)}catch{}let k=e?.fetcher||globalThis.fetch,w=a?`?${new URLSearchParams(a).toString()}`:"",T=()=>k(t+r+w,{...i,method:i.method?.toUpperCase()||"GET",headers:n?{"content-type":"application/json",...i.headers}:i.headers,body:n}).then(async s=>{let h;switch(s.headers.get("Content-Type")?.split(";")[0]){case"application/json":h=await s.json();break;default:h=await s.text().then(E=>x(E)?parseInt(E):E==="true"?!0:E==="false"?!1:E);break}return s.status>300?{data:null,status:s.status,headers:s.headers,retry:T,error:new A(s.status,h)}:{data:h,error:null,status:s.status,headers:s.headers,retry:T}});return T()};0&&(module.exports={edenFetch,edenTreaty,treaty});
1
+ "use strict";var P=Object.defineProperty;var Z=Object.getOwnPropertyDescriptor;var ee=Object.getOwnPropertyNames;var te=Object.prototype.hasOwnProperty;var re=(t,e)=>{for(var r in e)P(t,r,{get:e[r],enumerable:!0})},ne=(t,e,r,a)=>{if(e&&typeof e=="object"||typeof e=="function")for(let f of ee(e))!te.call(t,f)&&f!==r&&P(t,f,{get:()=>e[f],enumerable:!(a=Z(e,f))||a.enumerable});return t};var se=t=>ne(P({},"__esModule",{value:!0}),t);var ce={};re(ce,{edenFetch:()=>Y,edenTreaty:()=>X,treaty:()=>V});module.exports=se(ce);var U=(t,e,r)=>{if(t.endsWith("/")||(t+="/"),e==="index"&&(e=""),!r||!Object.keys(r).length)return`${t}${e}`;let a="";for(let[f,n]of Object.entries(r))a+=`${f}=${n}&`;return`${t}${e}?${a.slice(0,-1)}`},x=t=>t.trim().length!==0&&!Number.isNaN(Number(t));var A=class extends Error{constructor(r,a){super(a+"");this.status=r;this.value=a}};var N=class{constructor(e){this.url=e;this.ws=new WebSocket(e)}ws;send(e){return Array.isArray(e)?(e.forEach(r=>this.send(r)),this):(this.ws.send(typeof e=="object"?JSON.stringify(e):e.toString()),this)}on(e,r,a){return this.addEventListener(e,r,a)}off(e,r,a){return this.ws.removeEventListener(e,r,a),this}subscribe(e,r){return this.addEventListener("message",e,r)}addEventListener(e,r,a){return this.ws.addEventListener(e,f=>{if(e==="message"){let n=f.data.toString(),i=n.charCodeAt(0);if(i===47||i===123)try{n=JSON.parse(n)}catch{}else x(n)?n=+n:n==="true"?n=!0:n==="false"&&(n=!1);r({...f,data:n})}else r(f)},a),this}removeEventListener(e,r,a){return this.off(e,r,a),this}close(){return this.ws.close(),this}};var ae=["get","post","put","delete","patch","options","head","connect","subscribe"],G=["localhost","127.0.0.1","0.0.0.0"],J=typeof FileList>"u",_=t=>J?t instanceof Blob:t instanceof FileList||t instanceof File,ie=t=>{if(!t)return!1;for(let e in t)if(_(t[e])||Array.isArray(t[e])&&t[e].find(_))return!0;return!1},q=t=>J?t:new Promise(e=>{let r=new FileReader;r.onload=()=>{let a=new File([r.result],t.name,{lastModified:t.lastModified,type:t.type});e(a)},r.readAsArrayBuffer(t)}),M=(t,e,r=[],a)=>new Proxy(()=>{},{get(f,n){return M(t,e,n==="index"?r:[...r,n],a)},apply(f,n,[i,p={}]){if(!i||p||typeof i=="object"&&Object.keys(i).length!==1||ae.includes(r.at(-1))){let k=r.pop(),w="/"+r.join("/"),{fetcher:T=fetch,headers:s,onRequest:h,onResponse:E,fetch:K}=e,F=k==="get"||k==="head"||k==="subscribe";s={...typeof s=="object"&&!Array.isArray(s)?s:{},...F?i?.headers:p?.headers};let L=F?i?.query:p?.query,R="";if(L)for(let[c,u]of Object.entries(L))R+=(R?"&":"?")+`${c}=${u}`;if(typeof e.headers=="function"&&!(s instanceof Headers)){let c=e.headers(w,p);c&&(s={...s,...c})}else if(Array.isArray(e.headers)&&e.headers.every(c=>typeof c=="function"))for(let c of e.headers){let u=c(w,p);u&&(s={...s,...u})}else if(s instanceof Headers){s||(s={});for(let[c,u]of Object.entries(s))s[c]=u}if(k==="subscribe"){let c=t.replace(/^([^]+):\/\//,t.startsWith("https://")?"wss://":t.startsWith("http://")||G.find(u=>t.includes(u))?"ws://":"wss://")+w+R;return new N(c)}return(async()=>{let c=(s instanceof Headers?s.get("content-type"):Array.isArray(s)?s.find(o=>Array.isArray(o)&&o[0]==="headers"?o[1]:!1):typeof s=="function"?s(w,p):s?.contentType)||p?.headers?.contentType;if(!c)if(typeof i=="object")c="application/json",i=JSON.stringify(i);else if(ie(i)){let o=new FormData;for(let[d,m]of Object.entries(i)){if(J){o.append(d,m);continue}if(m instanceof File){o.append(d,await q(m));continue}if(m instanceof FileList){for(let l=0;l<m.length;l++)o.append(d,await q(m[l]));continue}if(Array.isArray(m)){for(let l=0;l<m.length;l++){let b=m[l];o.append(d,b instanceof File?await q(b):b)}continue}o.append(d,m)}i=o}else i!=null&&(c="text/plain");let u={method:k,body:i,...K,headers:{...s,"content-type":c}};if(F&&delete u.body,h){Array.isArray(h)||(h=[h]);for(let o of h){let d=await o(w,u);typeof d=="object"&&(u={...u,...d,headers:{...u.headers,...d.headers}})}}let C=t+w+R,g=await(a?.handle(new Request(C,u))??T(C,u)),y,O;if(E){Array.isArray(E)||(E=[E]);for(let o of E)try{if(y=await o(g.clone()),y!==void 0)break}catch(d){d instanceof A?O=d:O=new A(422,d);break}}if(y===void 0){switch(g.headers.get("Content-Type")?.split(";")[0]){case"application/json":y=await g.json();break;case"application/octet-stream":y=await g.arrayBuffer();break;default:y=await g.text().then(o=>x(o)?+o:o==="true"?!0:o==="false"?!1:o)}(g.status>=300||g.status<200)&&(O=new A(g.status,y),y=void 0)}return{data:y,error:O,response:g,status:g.status,headers:g.headers}})()}return typeof i=="object"?M(t,e,[...r,Object.values(i)[0]],a):M(t,e,r)}}),V=(t,e={})=>typeof t=="string"?(t.includes("://")||(t=(G.find(r=>t.includes(r))?"http://":"https://")+t),t.endsWith("/")&&(t=t.slice(0,-1)),M(t,e)):(typeof window<"u"&&console.warn("Elysia instance server found on client side, this is not recommended for security reason. Use generic type instead."),M("http://e.ly",e,[],t));var B=typeof FileList>"u",z=t=>B?t instanceof Blob:t instanceof FileList||t instanceof File,oe=t=>{if(!t)return!1;for(let e in t){if(z(t[e]))return!0;if(Array.isArray(t[e])&&t[e].find(r=>z(r)))return!0}return!1},D=t=>B?t:new Promise(e=>{let r=new FileReader;r.onload=()=>{let a=new File([r.result],t.name,{lastModified:t.lastModified,type:t.type});e(a)},r.readAsArrayBuffer(t)}),H=class{ws;url;constructor(e){this.ws=new WebSocket(e),this.url=e}send(e){return Array.isArray(e)?(e.forEach(r=>this.send(r)),this):(this.ws.send(typeof e=="object"?JSON.stringify(e):e.toString()),this)}on(e,r,a){return this.addEventListener(e,r,a)}off(e,r,a){return this.ws.removeEventListener(e,r,a),this}subscribe(e,r){return this.addEventListener("message",e,r)}addEventListener(e,r,a){return this.ws.addEventListener(e,f=>{if(e==="message"){let n=f.data.toString(),i=n.charCodeAt(0);if(i===47||i===123)try{n=JSON.parse(n)}catch{}else x(n)?n=+n:n==="true"?n=!0:n==="false"&&(n=!1);r({...f,data:n})}else r(f)},a),this}removeEventListener(e,r,a){return this.off(e,r,a),this}close(){return this.ws.close(),this}},Q=(t,e="",r)=>new Proxy(()=>{},{get(a,f,n){return Q(t,`${e}/${f.toString()}`,r)},apply(a,f,[n,i={}]=[{},{}]){let p=n!==void 0&&(typeof n!="object"||Array.isArray(n))?n:void 0,{$query:k,$fetch:w,$headers:T,$transform:s,getRaw:h,...E}=n??{};p??=E;let K=e.lastIndexOf("/"),F=e.slice(K+1).toUpperCase(),L=U(t,K===-1?"/":e.slice(0,K),Object.assign(i.query??{},k)),R=r.fetcher??fetch,c=r.transform?Array.isArray(r.transform)?r.transform:[r.transform]:void 0,u=s?Array.isArray(s)?s:[s]:void 0;return u&&(c?c=u.concat(c):c=u),F==="SUBSCRIBE"?new H(L.replace(/^([^]+):\/\//,L.startsWith("https://")?"wss://":"ws://")):(async g=>{let y,O={...r.$fetch?.headers,...w?.headers,...i.headers,...T};if(F!=="GET"&&F!=="HEAD"){y=Object.keys(p).length||Array.isArray(p)?p:void 0;let l=y&&(typeof y=="object"||Array.isArray(p));if(l&&oe(y)){let j=new FormData;for(let[$,v]of Object.entries(y))if(B)j.append($,v);else if(v instanceof File)j.append($,await D(v));else if(v instanceof FileList)for(let W=0;W<v.length;W++)j.append($,await D(v[W]));else if(Array.isArray(v))for(let W=0;W<v.length;W++){let I=v[W];j.append($,I instanceof File?await D(I):I)}else j.append($,v);y=j}else y!=null&&(O["content-type"]=l?"application/json":"text/plain",y=l?JSON.stringify(y):p)}let S=await R(L,{method:F,body:y,...r.$fetch,...i.fetch,...w,headers:O}),o;if(g.getRaw)return S;switch(S.headers.get("Content-Type")?.split(";")[0]){case"application/json":o=await S.json();break;default:o=await S.text().then(l=>x(l)?+l:l==="true"?!0:l==="false"?!1:l)}let d=S.status>=300||S.status<200?new A(S.status,o):null,m={data:o,error:d,response:S,status:S.status,headers:S.headers};if(c)for(let l of c){let b=l(m);b instanceof Promise&&(b=await b),b!=null&&(m=b)}return m})({getRaw:h})}}),X=(t,e={fetcher:fetch})=>new Proxy({},{get(r,a){return Q(t,a,e)}});var Y=(t,e)=>(r,{query:a,params:f,body:n,...i}={})=>{f&&Object.entries(f).forEach(([s,h])=>{r=r.replace(`:${s}`,h)});let p=i.headers?.["Content-Type"];if(!p||p==="application/json")try{n=JSON.stringify(n)}catch{}let k=e?.fetcher||globalThis.fetch,w=a?`?${new URLSearchParams(a).toString()}`:"",T=()=>k(t+r+w,{...i,method:i.method?.toUpperCase()||"GET",headers:n?{"content-type":"application/json",...i.headers}:i.headers,body:n}).then(async s=>{let h;switch(s.headers.get("Content-Type")?.split(";")[0]){case"application/json":h=await s.json();break;default:h=await s.text().then(E=>x(E)?parseInt(E):E==="true"?!0:E==="false"?!1:E);break}return s.status>300?{data:null,status:s.status,headers:s.headers,retry:T,error:new A(s.status,h)}:{data:h,error:null,status:s.status,headers:s.headers,retry:T}});return T()};0&&(module.exports={edenFetch,edenTreaty,treaty});
package/dist/index.mjs CHANGED
@@ -1 +1 @@
1
- import{b as C}from"./chunk-Q3DJMDQ2.mjs";import{a as H}from"./chunk-FGCQ7BRI.mjs";import{b as k,c as F}from"./chunk-HUZ6GXDC.mjs";var T=class{constructor(e){this.url=e;this.ws=new WebSocket(e)}ws;send(e){return Array.isArray(e)?(e.forEach(r=>this.send(r)),this):(this.ws.send(typeof e=="object"?JSON.stringify(e):e.toString()),this)}on(e,r,c){return this.addEventListener(e,r,c)}off(e,r,c){return this.ws.removeEventListener(e,r,c),this}subscribe(e,r){return this.addEventListener("message",e,r)}addEventListener(e,r,c){return this.ws.addEventListener(e,v=>{if(e==="message"){let f=v.data.toString(),i=f.charCodeAt(0);if(i===47||i===123)try{f=JSON.parse(f)}catch{}else k(f)?f=+f:f==="true"?f=!0:f==="false"&&(f=!1);r({...v,data:f})}else r(v)},c),this}removeEventListener(e,r,c){return this.off(e,r,c),this}close(){return this.ws.close(),this}};var I=["get","post","put","delete","patch","options","head","connect","subscribe"],R=["localhost","127.0.0.1","0.0.0.0"],O=typeof FileList>"u",M=t=>O?t instanceof Blob:t instanceof FileList||t instanceof File,P=t=>{if(!t)return!1;for(let e in t)if(M(t[e])||Array.isArray(t[e])&&t[e].find(M))return!0;return!1},L=t=>O?t:new Promise(e=>{let r=new FileReader;r.onload=()=>{let c=new File([r.result],t.name,{lastModified:t.lastModified,type:t.type});e(c)},r.readAsArrayBuffer(t)}),g=(t,e,r=[],c)=>new Proxy(()=>{},{get(v,f){return g(t,e,f==="index"?r:[...r,f],c)},apply(v,f,[i,d={}]){if(!i||d||typeof i=="object"&&Object.keys(i).length!==1||I.includes(r.at(-1))){let w=r.pop(),m="/"+r.join("/"),{fetcher:q=fetch,headers:n,onRequest:E,onResponse:S,...N}=e,W=w==="get"||w==="head"||w==="subscribe";n={...typeof n=="object"&&!Array.isArray(n)?n:{},...W?i?.headers:d?.headers};let K=W?i?.query:d?.query,A="";if(K)for(let[a,o]of Object.entries(K))A+=(A?"&":"?")+`${a}=${o}`;if(typeof e.headers=="function"&&!(n instanceof Headers)){let a=e.headers(m,d);a&&(n={...n,...a})}else if(Array.isArray(e.headers)&&e.headers.every(a=>typeof a=="function"))for(let a of e.headers){let o=a(m,d);o&&(n={...n,...o})}else if(n instanceof Headers){n||(n={});for(let[a,o]of Object.entries(n))n[a]=o}if(w==="subscribe"){let a=t.replace(/^([^]+):\/\//,t.startsWith("https://")?"wss://":t.startsWith("http://")||R.find(o=>t.includes(o))?"ws://":"wss://")+m+A;return new T(a)}return(async()=>{let a=(n instanceof Headers?n.get("content-type"):Array.isArray(n)?n.find(s=>Array.isArray(s)&&s[0]==="headers"?s[1]:!1):typeof n=="function"?n(m,d):n?.contentType)||d?.headers?.contentType;if(!a)if(typeof i=="object")a="application/json",i=JSON.stringify(i);else if(P(i)){let s=new FormData;for(let[y,l]of Object.entries(i)){if(O){s.append(y,l);continue}if(l instanceof File){s.append(y,await L(l));continue}if(l instanceof FileList){for(let h=0;h<l.length;h++)s.append(y,await L(l[h]));continue}if(Array.isArray(l)){for(let h=0;h<l.length;h++){let x=l[h];s.append(y,x instanceof File?await L(x):x)}continue}s.append(y,l)}i=s}else i!=null&&(a="text/plain");let o={method:w,body:i,...N,headers:{...n,"content-type":a}};if(W&&delete o.body,E){Array.isArray(E)||(E=[E]);for(let s of E){let y=await s(m,o);typeof y=="object"&&(o={...o,...y,headers:{...o.headers,...y.headers}})}}let j=t+m+A,p=await(c?.handle(new Request(j,o))??q(j,o)),u,b;if(S){Array.isArray(S)||(S=[S]);for(let s of S)try{if(u=await s(p.clone()),u!==void 0)break}catch(y){y instanceof F?b=y:b=new F(422,y);break}}if(u===void 0){switch(p.headers.get("Content-Type")?.split(";")[0]){case"application/json":u=await p.json();break;case"application/octet-stream":u=await p.arrayBuffer();break;default:u=await p.text().then(s=>k(s)?+s:s==="true"?!0:s==="false"?!1:s)}(p.status>=300||p.status<200)&&(b=new F(p.status,u),u=void 0)}return{data:u,error:b,response:p,status:p.status,headers:p.headers}})()}return typeof i=="object"?g(t,e,[...r,Object.values(i)[0]],c):g(t,e,r)}}),_=(t,e={})=>typeof t=="string"?(t.includes("://")||(t=(R.find(r=>t.includes(r))?"http://":"https://")+t),t.endsWith("/")&&(t=t.slice(0,-1)),g(t,e)):(typeof window<"u"&&console.warn("Elysia instance server found on client side, this is not recommended for security reason. Use generic type instead."),g("http://e.ly",e,[],t));export{H as edenFetch,C as edenTreaty,_ as treaty};
1
+ import{b as C}from"./chunk-Q3DJMDQ2.mjs";import{a as H}from"./chunk-FGCQ7BRI.mjs";import{b as k,c as F}from"./chunk-HUZ6GXDC.mjs";var T=class{constructor(e){this.url=e;this.ws=new WebSocket(e)}ws;send(e){return Array.isArray(e)?(e.forEach(r=>this.send(r)),this):(this.ws.send(typeof e=="object"?JSON.stringify(e):e.toString()),this)}on(e,r,c){return this.addEventListener(e,r,c)}off(e,r,c){return this.ws.removeEventListener(e,r,c),this}subscribe(e,r){return this.addEventListener("message",e,r)}addEventListener(e,r,c){return this.ws.addEventListener(e,v=>{if(e==="message"){let f=v.data.toString(),i=f.charCodeAt(0);if(i===47||i===123)try{f=JSON.parse(f)}catch{}else k(f)?f=+f:f==="true"?f=!0:f==="false"&&(f=!1);r({...v,data:f})}else r(v)},c),this}removeEventListener(e,r,c){return this.off(e,r,c),this}close(){return this.ws.close(),this}};var I=["get","post","put","delete","patch","options","head","connect","subscribe"],R=["localhost","127.0.0.1","0.0.0.0"],O=typeof FileList>"u",M=t=>O?t instanceof Blob:t instanceof FileList||t instanceof File,P=t=>{if(!t)return!1;for(let e in t)if(M(t[e])||Array.isArray(t[e])&&t[e].find(M))return!0;return!1},L=t=>O?t:new Promise(e=>{let r=new FileReader;r.onload=()=>{let c=new File([r.result],t.name,{lastModified:t.lastModified,type:t.type});e(c)},r.readAsArrayBuffer(t)}),g=(t,e,r=[],c)=>new Proxy(()=>{},{get(v,f){return g(t,e,f==="index"?r:[...r,f],c)},apply(v,f,[i,d={}]){if(!i||d||typeof i=="object"&&Object.keys(i).length!==1||I.includes(r.at(-1))){let w=r.pop(),m="/"+r.join("/"),{fetcher:q=fetch,headers:n,onRequest:E,onResponse:S,fetch:N}=e,W=w==="get"||w==="head"||w==="subscribe";n={...typeof n=="object"&&!Array.isArray(n)?n:{},...W?i?.headers:d?.headers};let K=W?i?.query:d?.query,A="";if(K)for(let[a,o]of Object.entries(K))A+=(A?"&":"?")+`${a}=${o}`;if(typeof e.headers=="function"&&!(n instanceof Headers)){let a=e.headers(m,d);a&&(n={...n,...a})}else if(Array.isArray(e.headers)&&e.headers.every(a=>typeof a=="function"))for(let a of e.headers){let o=a(m,d);o&&(n={...n,...o})}else if(n instanceof Headers){n||(n={});for(let[a,o]of Object.entries(n))n[a]=o}if(w==="subscribe"){let a=t.replace(/^([^]+):\/\//,t.startsWith("https://")?"wss://":t.startsWith("http://")||R.find(o=>t.includes(o))?"ws://":"wss://")+m+A;return new T(a)}return(async()=>{let a=(n instanceof Headers?n.get("content-type"):Array.isArray(n)?n.find(s=>Array.isArray(s)&&s[0]==="headers"?s[1]:!1):typeof n=="function"?n(m,d):n?.contentType)||d?.headers?.contentType;if(!a)if(typeof i=="object")a="application/json",i=JSON.stringify(i);else if(P(i)){let s=new FormData;for(let[y,l]of Object.entries(i)){if(O){s.append(y,l);continue}if(l instanceof File){s.append(y,await L(l));continue}if(l instanceof FileList){for(let h=0;h<l.length;h++)s.append(y,await L(l[h]));continue}if(Array.isArray(l)){for(let h=0;h<l.length;h++){let x=l[h];s.append(y,x instanceof File?await L(x):x)}continue}s.append(y,l)}i=s}else i!=null&&(a="text/plain");let o={method:w,body:i,...N,headers:{...n,"content-type":a}};if(W&&delete o.body,E){Array.isArray(E)||(E=[E]);for(let s of E){let y=await s(m,o);typeof y=="object"&&(o={...o,...y,headers:{...o.headers,...y.headers}})}}let j=t+m+A,p=await(c?.handle(new Request(j,o))??q(j,o)),u,b;if(S){Array.isArray(S)||(S=[S]);for(let s of S)try{if(u=await s(p.clone()),u!==void 0)break}catch(y){y instanceof F?b=y:b=new F(422,y);break}}if(u===void 0){switch(p.headers.get("Content-Type")?.split(";")[0]){case"application/json":u=await p.json();break;case"application/octet-stream":u=await p.arrayBuffer();break;default:u=await p.text().then(s=>k(s)?+s:s==="true"?!0:s==="false"?!1:s)}(p.status>=300||p.status<200)&&(b=new F(p.status,u),u=void 0)}return{data:u,error:b,response:p,status:p.status,headers:p.headers}})()}return typeof i=="object"?g(t,e,[...r,Object.values(i)[0]],c):g(t,e,r)}}),_=(t,e={})=>typeof t=="string"?(t.includes("://")||(t=(R.find(r=>t.includes(r))?"http://":"https://")+t),t.endsWith("/")&&(t=t.slice(0,-1)),g(t,e)):(typeof window<"u"&&console.warn("Elysia instance server found on client side, this is not recommended for security reason. Use generic type instead."),g("http://e.ly",e,[],t));export{H as edenFetch,C as edenTreaty,_ as treaty};
@@ -17,11 +17,15 @@ export declare namespace Treaty {
17
17
  _routes: infer Schema extends Record<string, any>;
18
18
  } ? Prettify<Sign<Schema>> : 'Please install Elysia before using Eden';
19
19
  export type Sign<in out Route extends Record<string, any>> = {
20
- [K in keyof Route as K extends '/' | '' ? 'index' : K extends `:${string}` ? never : K]: K extends 'subscribe' ? undefined extends Route['subscribe']['query'] ? (params?: {
21
- query?: Record<string, string>;
22
- }) => EdenWS<Route['subscribe']> : (params: {
20
+ [K in keyof Route as K extends '/' | '' ? 'index' : K extends `:${string}` ? never : K]: K extends 'subscribe' ? (undefined extends Route['subscribe']['headers'] ? {
21
+ headers?: Record<string, unknown>;
22
+ } : {
23
+ headers: Route['subscribe']['headers'];
24
+ }) & (undefined extends Route['subscribe']['query'] ? {
25
+ query?: Record<string, unknown>;
26
+ } : {
23
27
  query: Route['subscribe']['query'];
24
- }) => EdenWS<Route['subscribe']> : Route[K] extends {
28
+ }) extends infer Param ? {} extends Param ? (options?: Param) => EdenWS<Route['subscribe']> : (options?: Param) => EdenWS<Route['subscribe']> : never : Route[K] extends {
25
29
  body: infer Body;
26
30
  headers: infer Headers;
27
31
  params: any;
@@ -37,28 +41,35 @@ export declare namespace Treaty {
37
41
  query: Query;
38
42
  }) extends infer Param ? {} extends Param ? undefined extends Body ? K extends 'get' | 'head' ? (options?: Prettify<Param & TreatyParam>) => Promise<TreatyResponse<Response>> : (body?: Body, options?: Prettify<Param & TreatyParam>) => Promise<TreatyResponse<Response>> : (body: Body extends Record<string, unknown> ? ReplaceBlobWithFiles<Body> : Body, options?: Prettify<Param & TreatyParam>) => Promise<TreatyResponse<Response>> : K extends 'get' | 'head' ? (options: Prettify<Param & TreatyParam>) => Promise<TreatyResponse<Response>> : (body: Body extends Record<string, unknown> ? ReplaceBlobWithFiles<Body> : Body, options: Prettify<Param & TreatyParam>) => Promise<TreatyResponse<Response>> : never : keyof Route[K] extends `:${infer Param}` ? (params: Record<Param, string>) => Prettify<Prettify<Sign<Route[K]>> & Sign<Route[K][`:${Param}`]>> : Prettify<Sign<Route[K]>>;
39
43
  };
40
- export interface Config extends Omit<RequestInit, 'headers'> {
44
+ export interface Config {
45
+ fetch?: Omit<RequestInit, 'headers' | 'method'>;
41
46
  fetcher?: typeof fetch;
42
47
  headers?: RequestInit['headers'] | MaybeArray<(path: string, options: RequestInit) => RequestInit['headers'] | void>;
43
48
  onRequest?: MaybeArray<(path: string, options: FetchRequestInit) => MaybePromise<FetchRequestInit | void>>;
44
49
  onResponse?: MaybeArray<(response: Response) => MaybePromise<unknown>>;
45
50
  }
46
- type TreatyResponse<Response extends Record<number, unknown>> = {
47
- data: Response[200];
51
+ type TreatyResponse<Res extends Record<number, unknown>> = {
52
+ data: Res[200];
48
53
  error: null;
54
+ response: Response;
55
+ status: number;
56
+ headers: FetchRequestInit['headers'];
49
57
  } | {
50
58
  data: null;
51
- error: Response extends {
59
+ error: Res extends {
52
60
  200: unknown;
53
61
  } ? {
54
- [Status in keyof Response as Status extends 200 ? never : Status]: {
62
+ [Status in keyof Res as Status extends 200 ? never : Status]: {
55
63
  status: Status;
56
- value: Response[Status];
64
+ value: Res[Status];
57
65
  };
58
66
  }[Exclude<keyof Response, 200>] : {
59
67
  status: unknown;
60
68
  value: unknown;
61
69
  };
70
+ response: Response;
71
+ status: number;
72
+ headers: FetchRequestInit['headers'];
62
73
  };
63
74
  export interface OnMessage<Data = unknown> extends MessageEvent {
64
75
  data: Data;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@elysiajs/eden",
3
- "version": "1.0.0-rc.0",
3
+ "version": "1.0.0-rc.1",
4
4
  "description": "Fully type-safe Elysia client",
5
5
  "author": {
6
6
  "name": "saltyAom",