@mapl/web 0.2.0-alpha.8 → 0.2.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/README.md +0 -10
- package/compiler/jit.js +1 -1
- package/core/handler.d.ts +3 -3
- package/core/handler.js +1 -1
- package/package.json +8 -8
- package/utils/cors.js +1 -1
- package/utils/static-headers.d.ts +1 -1
- package/utils/static-headers.js +1 -1
package/README.md
CHANGED
|
@@ -97,13 +97,3 @@ await input.write({
|
|
|
97
97
|
});
|
|
98
98
|
```
|
|
99
99
|
As of rn only `terser` can DCE `@mapl/web` well.
|
|
100
|
-
|
|
101
|
-
### Hydration
|
|
102
|
-
```ts
|
|
103
|
-
import { isHydrating } from 'runtime-compiler/config';
|
|
104
|
-
|
|
105
|
-
// false while building the output string
|
|
106
|
-
// true while only building dependencies
|
|
107
|
-
// Use this to for minifiedrs to eliminate unused code path in final output
|
|
108
|
-
isHydrating;
|
|
109
|
-
```
|
package/compiler/jit.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{compileGroup,createArgSet,AsyncFunction,setHooks,contextInit,setContextInit}from"@mapl/framework";import compile from"@mapl/router/method/compiler";import{countParams}from"@mapl/router/path";import{insertItem}from"@mapl/router/method";import{exportDependency,getDependency,injectDependency,injectExternalDependency}from"runtime-compiler";import{evaluate,evaluateSync}from"runtime-compiler/jit";let urlRouter;let paramArgs=createArgSet(new Array(16).fill(0).map((_1,i)=>`q`+i));let compileReturn=(dat,fnAsync,scopeAsync,contextCreated,result)=>{let typ=dat
|
|
1
|
+
import{compileGroup,createArgSet,AsyncFunction,setHooks,contextInit,setContextInit}from"@mapl/framework";import compile from"@mapl/router/method/compiler";import{countParams}from"@mapl/router/path";import{insertItem}from"@mapl/router/method";import{exportDependency,getDependency,injectDependency,injectExternalDependency}from"runtime-compiler";import{evaluate,evaluateSync}from"runtime-compiler/jit";let urlRouter;let paramArgs=createArgSet(new Array(16).fill(0).map((_1,i)=>`q`+i));let compileReturn=(dat,fnAsync,scopeAsync,contextCreated,result)=>{let typ=dat?.type;if(typ===`raw`)return`return `+result;fnAsync&&(result=`await `+result);let str=typ==null?`return new Response(`+result+(contextCreated?`,c)`:`)`):contextCreated?`hd.push(`+(typ===`json`?`j`:`h`)+`);return new Response(`+(typ===`json`?`JSON.stringify(`+result+`)`:result)+`,c)`:`return new Response(`+(typ===`json`?`JSON.stringify(`+result+`),oj`:result+`,oh`)+`)`;return fnAsync&&!scopeAsync?`return (async()=>{`+str+`})()`:str};let compileToState=router=>{urlRouter={};setHooks({compileHandler:(fn,dat,path,scope)=>{let call=injectExternalDependency(fn)+`(`;let paramCount=countParams(path);paramCount>0&&(call+=paramArgs[paramCount]);if(fn.length>paramCount){call+=paramCount===0?`c`:`,c`;if(!scope[1])return contextInit+compileReturn(dat,fn instanceof AsyncFunction,scope[0],true,call+`)`)}return compileReturn(dat,fn instanceof AsyncFunction,scope[0],scope[1],call+`)`)},compileErrorHandler:(fn,dat,scope)=>{let call=injectExternalDependency(fn)+`(t`;if(fn.length>1){call+=`,c`;if(!scope[1])return contextInit+compileReturn(dat,fn instanceof AsyncFunction,scope[0],true,call+`)`)}return compileReturn(dat,fn instanceof AsyncFunction,scope[0],scope[1],call+`)`)},registerCompiled:(method,path,content)=>insertItem(urlRouter,method,path,content)});setContextInit(`let hd=[],c={status:200,req:r,headers:hd};`);compileGroup(router,[false,false,,`return b`,false],``,``)};export let compileToString=router=>{compileToState(router);return`()=>{var t=["text/html","application/json"].map(c=>["Content-Type",c]),[h,j]=t,[oh,oj]=t.map(c=>({headers:[c]})),[n,b]=[404,400].map(s=>new Response(null,{status:s}));return(r)=>{`+compile(urlRouter,`r.method`,`let u=r.url,s=u.indexOf("/",12)+1,e=u.indexOf("?",s),p=e===-1?u.slice(s):u.slice(s,e);`,1)+`return n}}`};export let compileToDependency=router=>exportDependency(injectDependency(`(`+compileToString(router)+`)()`));export let compileToHandler=async router=>{let id=compileToDependency(router);await evaluate();return getDependency(id)};export let compileToHandlerSync=router=>{let id=compileToDependency(router);evaluateSync();return getDependency(id)};
|
package/core/handler.d.ts
CHANGED
|
@@ -10,7 +10,7 @@ export type Handler<
|
|
|
10
10
|
export type DefineHandler = <
|
|
11
11
|
P extends string,
|
|
12
12
|
S = {}
|
|
13
|
-
>(path: P, handler: Handler<InferPath<P>, Required<S>>,
|
|
13
|
+
>(path: P, handler: Handler<InferPath<P>, Required<S>>, dat?: HandlerData) => HandlerTag<S>;
|
|
14
14
|
export interface HandlerData extends Record<symbol, any> {
|
|
15
15
|
type?: "json" | "html" | "raw" | null;
|
|
16
16
|
}
|
|
@@ -41,7 +41,7 @@ export declare const raw: {
|
|
|
41
41
|
* Handle errors of a router
|
|
42
42
|
* @param f
|
|
43
43
|
*/
|
|
44
|
-
export declare const error: <const E extends Err>(r: RouterTag<E>, f: ErrorHandler<E>,
|
|
44
|
+
export declare const error: <const E extends Err>(r: RouterTag<E>, f: ErrorHandler<E>, dat?: HandlerData) => RouterTag<never>;
|
|
45
45
|
/**
|
|
46
46
|
* Handle requests to a path with a specific method
|
|
47
47
|
* @param method
|
|
@@ -52,7 +52,7 @@ export declare const error: <const E extends Err>(r: RouterTag<E>, f: ErrorHandl
|
|
|
52
52
|
export declare const route: <
|
|
53
53
|
P extends string,
|
|
54
54
|
S = {}
|
|
55
|
-
>(method: RequestMethod, path: P, handler: Handler<InferPath<P>, Required<S>>,
|
|
55
|
+
>(method: RequestMethod, path: P, handler: Handler<InferPath<P>, Required<S>>, dat: HandlerData) => HandlerTag<S>;
|
|
56
56
|
export declare const any: DefineHandler;
|
|
57
57
|
export declare const get: DefineHandler;
|
|
58
58
|
export declare const post: DefineHandler;
|
package/core/handler.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export let json={type:`json`};export let html={type:`html`};export let raw={type:`raw`};
|
|
1
|
+
export let json={type:`json`};export let html={type:`html`};export let raw={type:`raw`};export let error=(r,f,dat)=>{r[2]=[f,dat];return r};export let route=(method,path,handler,dat)=>[method,path,handler,dat];export let any=(path,handler,dat)=>[``,path,handler,dat];export let get=(path,handler,dat)=>[`GET`,path,handler,dat];export let post=(path,handler,dat)=>[`POST`,path,handler,dat];export let put=(path,handler,dat)=>[`PUT`,path,handler,dat];export let del=(path,handler,dat)=>[`DELETE`,path,handler,dat];export let patch=(path,handler,dat)=>[`PATCH`,path,handler,dat];export let options=(path,handler,dat)=>[`OPTIONS`,path,handler,dat];export let trace=(path,handler,dat)=>[`TRACE`,path,handler,dat];
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@mapl/web",
|
|
3
|
-
"version": "0.2.
|
|
3
|
+
"version": "0.2.1",
|
|
4
4
|
"description": "A compiled web framework for all runtimes",
|
|
5
5
|
"keywords": ["fast", "lightweight", "cross-runtime", "framework", "web", "backend"],
|
|
6
6
|
"repository": {
|
|
@@ -22,16 +22,16 @@
|
|
|
22
22
|
},
|
|
23
23
|
"exports": {
|
|
24
24
|
"./constants": "./constants.js",
|
|
25
|
-
"./core/
|
|
25
|
+
"./core/utils": "./core/utils.js",
|
|
26
|
+
".": "./index.js",
|
|
27
|
+
"./core/handler": "./core/handler.js",
|
|
28
|
+
"./core/context": "./core/context.js",
|
|
26
29
|
"./core": "./core/index.js",
|
|
27
30
|
"./utils/static-headers": "./utils/static-headers.js",
|
|
28
31
|
"./utils/cors": "./utils/cors.js",
|
|
29
|
-
"./core/
|
|
32
|
+
"./core/middleware": "./core/middleware.js",
|
|
30
33
|
"./utils/secure-headers": "./utils/secure-headers.js",
|
|
31
|
-
"./compiler/
|
|
32
|
-
"./
|
|
33
|
-
"./core/context": "./core/context.js",
|
|
34
|
-
".": "./index.js",
|
|
35
|
-
"./compiler/jit": "./compiler/jit.js"
|
|
34
|
+
"./compiler/jit": "./compiler/jit.js",
|
|
35
|
+
"./compiler/aot": "./compiler/aot.js"
|
|
36
36
|
}
|
|
37
37
|
}
|
package/utils/cors.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{injectDependency}from"runtime-compiler";import{macro}from"../core/middleware.js";import{
|
|
1
|
+
import{injectDependency}from"runtime-compiler";import{macro}from"../core/middleware.js";import{isHydrating}from"runtime-compiler/config";import{createContext}from"@mapl/framework";import{injectList}from"./static-headers.js";export let allowMethods=v=>[`access-control-allow-methods`,v];export let allowHeaders=v=>[`access-control-allow-headers`,``+v];export let maxAge=v=>[`access-control-max-age`,``+v];export let allowCredentials=[`access-control-allow-credentials`,`true`];export let exposeHeaders=v=>[`access-control-expose-headers`,``+v];let createContextMacro=macro(createContext);export let init=isHydrating?()=>createContextMacro:(origins,preflightHeaders=[],headers=[])=>{if(origins!==`*`){headers.push([`vary`,`origin`]);if(Array.isArray(origins))return macro(scope=>{let originList=injectDependency(JSON.stringify(origins));return createContext(scope)+(injectDependency(`(r,h)=>{let o=r.headers.get("origin");h.push(["access-control-allow-origin",typeof o==="string"&&`+originList+`.includes(o)?o:`+originList+`[0]]);`+(headers.length>0?`h.push(`+injectList(headers)+`);`:``)+(preflightHeaders.length>0?`r.method==="OPTIONS"&&h.push(`+injectList(preflightHeaders)+`)}`:`}`))+`(r,hd);`)})}headers.push([`access-control-allow-origin`,origins]);return macro(scope=>{let pushHeaders=headers.length>0?`h.push(`+injectList(headers)+`);`:``;return createContext(scope)+(preflightHeaders.length>0?injectDependency(`(r,h)=>{`+pushHeaders+`r.method==="OPTIONS"&&h.push(`+injectList(preflightHeaders)+`)}`)+`(r,hd);`:pushHeaders)})};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { Header } from "../core/context.js";
|
|
2
2
|
import { type MiddlewareTypes } from "../core/middleware.js";
|
|
3
|
-
export declare const
|
|
3
|
+
export declare const injectList: (list: any[]) => string;
|
|
4
4
|
declare const _default: (headers: Headers | Header[] | Record<string, any>) => MiddlewareTypes<never, {}>;
|
|
5
5
|
export default _default;
|
package/utils/static-headers.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{isHydrating}from"runtime-compiler/config";import{macro,noOpMacro}from"../core/middleware.js";import{injectDependency}from"runtime-compiler";export let
|
|
1
|
+
import{isHydrating}from"runtime-compiler/config";import{macro,noOpMacro}from"../core/middleware.js";import{injectDependency}from"runtime-compiler";export let injectList=list=>list.length>1?`...`+injectDependency(JSON.stringify(list)):injectDependency(JSON.stringify(list[0]));export default isHydrating?()=>noOpMacro:headers=>macro(()=>`hd.push(`+injectList(Array.isArray(headers)?headers:headers instanceof Headers?headers.entries().toArray():Object.entries(headers))+`);`);
|