@duplojs/http 0.8.5 → 0.9.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (138) hide show
  1. package/dist/core/builders/preflight/builder.d.ts +5 -6
  2. package/dist/core/builders/preflight/process.d.ts +3 -4
  3. package/dist/core/builders/preflight/route.d.ts +4 -5
  4. package/dist/core/builders/process/builder.d.ts +4 -5
  5. package/dist/core/builders/process/checker.d.ts +2 -3
  6. package/dist/core/builders/process/cut.d.ts +4 -5
  7. package/dist/core/builders/process/exports.d.ts +3 -4
  8. package/dist/core/builders/process/extract.d.ts +2 -3
  9. package/dist/core/builders/process/presetChecker.d.ts +2 -3
  10. package/dist/core/builders/process/process.d.ts +3 -4
  11. package/dist/core/builders/route/builder.d.ts +6 -6
  12. package/dist/core/builders/route/checker.d.ts +2 -3
  13. package/dist/core/builders/route/cut.d.ts +4 -5
  14. package/dist/core/builders/route/extract.d.ts +3 -3
  15. package/dist/core/builders/route/handler.d.ts +3 -4
  16. package/dist/core/builders/route/presetChecker.d.ts +2 -3
  17. package/dist/core/builders/route/process.d.ts +3 -4
  18. package/dist/core/defaultHooks/index.d.ts +1 -1
  19. package/dist/core/functionsBuilders/index.cjs +1 -0
  20. package/dist/core/functionsBuilders/index.d.ts +1 -0
  21. package/dist/core/functionsBuilders/index.mjs +1 -0
  22. package/dist/core/functionsBuilders/route/build.d.ts +5 -2
  23. package/dist/core/functionsBuilders/route/create.d.ts +3 -5
  24. package/dist/core/functionsBuilders/route/{hook.cjs → default/hook.cjs} +16 -7
  25. package/dist/core/functionsBuilders/route/{hook.d.ts → default/hook.d.ts} +5 -5
  26. package/dist/core/functionsBuilders/route/{hook.mjs → default/hook.mjs} +16 -7
  27. package/dist/core/functionsBuilders/route/{default.cjs → default/index.cjs} +22 -34
  28. package/dist/core/functionsBuilders/route/default/index.d.ts +2 -0
  29. package/dist/core/functionsBuilders/route/{default.mjs → default/index.mjs} +11 -29
  30. package/dist/core/functionsBuilders/route/index.cjs +2 -9
  31. package/dist/core/functionsBuilders/route/index.d.ts +0 -1
  32. package/dist/core/functionsBuilders/route/index.mjs +1 -2
  33. package/dist/core/functionsBuilders/router/build.cjs +7 -0
  34. package/dist/core/functionsBuilders/router/build.d.ts +14 -0
  35. package/dist/core/functionsBuilders/router/build.mjs +5 -0
  36. package/dist/core/functionsBuilders/router/create.cjs +7 -0
  37. package/dist/core/functionsBuilders/router/create.d.ts +15 -0
  38. package/dist/core/functionsBuilders/router/create.mjs +5 -0
  39. package/dist/core/functionsBuilders/router/default/index.cjs +52 -0
  40. package/dist/core/functionsBuilders/router/default/index.d.ts +1 -0
  41. package/dist/core/functionsBuilders/router/default/index.mjs +50 -0
  42. package/dist/core/functionsBuilders/router/index.cjs +11 -0
  43. package/dist/core/functionsBuilders/router/index.d.ts +3 -0
  44. package/dist/core/functionsBuilders/router/index.mjs +3 -0
  45. package/dist/core/functionsBuilders/steps/create.d.ts +3 -6
  46. package/dist/core/hub/defaultMalformedUrlHandler.d.ts +1 -1
  47. package/dist/core/hub/defaultNotfoundHandler.d.ts +1 -1
  48. package/dist/core/hub/hooks.d.ts +2 -2
  49. package/dist/core/hub/index.cjs +5 -0
  50. package/dist/core/hub/index.d.ts +6 -3
  51. package/dist/core/hub/index.mjs +5 -0
  52. package/dist/core/implementHttpServer.cjs +1 -1
  53. package/dist/core/implementHttpServer.d.ts +2 -2
  54. package/dist/core/implementHttpServer.mjs +2 -2
  55. package/dist/core/index.cjs +15 -14
  56. package/dist/core/index.mjs +8 -6
  57. package/dist/core/process/index.d.ts +0 -7
  58. package/dist/core/route/hooks.cjs +2 -17
  59. package/dist/core/route/hooks.d.ts +15 -32
  60. package/dist/core/route/hooks.mjs +3 -17
  61. package/dist/core/route/index.cjs +0 -1
  62. package/dist/core/route/index.mjs +1 -1
  63. package/dist/core/router/{buildSystemRoute.cjs → createRouterElementSystem.cjs} +4 -3
  64. package/dist/core/router/createRouterElementSystem.d.ts +9 -0
  65. package/dist/core/router/{buildSystemRoute.mjs → createRouterElementSystem.mjs} +4 -3
  66. package/dist/core/router/index.cjs +19 -60
  67. package/dist/core/router/index.d.ts +3 -4
  68. package/dist/core/router/index.mjs +17 -56
  69. package/dist/core/router/types/buildedRouter.d.ts +2 -12
  70. package/dist/core/router/types/index.cjs +4 -0
  71. package/dist/core/router/types/index.d.ts +4 -0
  72. package/dist/core/router/types/index.mjs +4 -0
  73. package/dist/core/router/types/router.cjs +2 -0
  74. package/dist/core/router/types/router.d.ts +12 -0
  75. package/dist/core/router/types/router.mjs +1 -0
  76. package/dist/core/router/types/routerElement.cjs +2 -0
  77. package/dist/core/router/types/routerElement.d.ts +8 -0
  78. package/dist/core/router/types/routerElement.mjs +1 -0
  79. package/dist/core/router/types/routerElementSystem.cjs +2 -0
  80. package/dist/core/router/types/routerElementSystem.d.ts +6 -0
  81. package/dist/core/router/types/routerElementSystem.mjs +1 -0
  82. package/dist/core/router/types/routerElementWrapper.cjs +2 -0
  83. package/dist/core/router/types/routerElementWrapper.d.ts +2 -0
  84. package/dist/core/router/types/routerElementWrapper.mjs +1 -0
  85. package/dist/core/steps/cut.d.ts +1 -2
  86. package/dist/core/steps/handler.d.ts +1 -2
  87. package/dist/core/steps/types/stepFunctionParams.d.ts +2 -2
  88. package/dist/interfaces/node/createHttpServer.cjs +2 -2
  89. package/dist/interfaces/node/createHttpServer.mjs +2 -2
  90. package/dist/interfaces/node/hooks/index.d.ts +3 -3
  91. package/dist/plugins/cacheController/hooks.cjs +2 -1
  92. package/dist/plugins/cacheController/hooks.d.ts +1 -1
  93. package/dist/plugins/cacheController/hooks.mjs +2 -1
  94. package/dist/plugins/cors/headerFunctions/allowHeaders.cjs +11 -0
  95. package/dist/plugins/cors/headerFunctions/allowHeaders.d.ts +5 -0
  96. package/dist/plugins/cors/headerFunctions/allowHeaders.mjs +9 -0
  97. package/dist/plugins/cors/headerFunctions/allowMethods.cjs +16 -0
  98. package/dist/plugins/cors/headerFunctions/allowMethods.d.ts +6 -0
  99. package/dist/plugins/cors/headerFunctions/allowMethods.mjs +14 -0
  100. package/dist/plugins/cors/headerFunctions/allowOrigin.cjs +24 -0
  101. package/dist/plugins/cors/headerFunctions/allowOrigin.d.ts +7 -0
  102. package/dist/plugins/cors/headerFunctions/allowOrigin.mjs +22 -0
  103. package/dist/plugins/cors/headerFunctions/credentials.cjs +11 -0
  104. package/dist/plugins/cors/headerFunctions/credentials.d.ts +5 -0
  105. package/dist/plugins/cors/headerFunctions/credentials.mjs +9 -0
  106. package/dist/plugins/cors/headerFunctions/exposeHeaders.cjs +11 -0
  107. package/dist/plugins/cors/headerFunctions/exposeHeaders.d.ts +5 -0
  108. package/dist/plugins/cors/headerFunctions/exposeHeaders.mjs +9 -0
  109. package/dist/plugins/cors/headerFunctions/index.cjs +19 -0
  110. package/dist/plugins/cors/headerFunctions/index.d.ts +7 -0
  111. package/dist/plugins/cors/headerFunctions/index.mjs +7 -0
  112. package/dist/plugins/cors/headerFunctions/maxAge.cjs +11 -0
  113. package/dist/plugins/cors/headerFunctions/maxAge.d.ts +5 -0
  114. package/dist/plugins/cors/headerFunctions/maxAge.mjs +9 -0
  115. package/dist/plugins/cors/headerFunctions/vary.cjs +35 -0
  116. package/dist/plugins/cors/headerFunctions/vary.d.ts +5 -0
  117. package/dist/plugins/cors/headerFunctions/vary.mjs +33 -0
  118. package/dist/plugins/cors/index.cjs +9 -0
  119. package/dist/plugins/cors/index.d.ts +2 -0
  120. package/dist/plugins/cors/index.mjs +2 -0
  121. package/dist/plugins/cors/metadata.cjs +8 -0
  122. package/dist/plugins/cors/metadata.d.ts +1 -0
  123. package/dist/plugins/cors/metadata.mjs +6 -0
  124. package/dist/plugins/cors/plugin.cjs +108 -0
  125. package/dist/plugins/cors/plugin.d.ts +12 -0
  126. package/dist/plugins/cors/plugin.mjs +106 -0
  127. package/dist/plugins/openApiGenerator/makeOpenApiRoute.d.ts +1 -1
  128. package/dist/plugins/static/makeRouteFile.d.ts +2 -2
  129. package/dist/plugins/static/makeRouteFolder.cjs +1 -1
  130. package/dist/plugins/static/makeRouteFolder.d.ts +2 -2
  131. package/dist/plugins/static/makeRouteFolder.mjs +1 -1
  132. package/dist/plugins/static/plugin.d.ts +1 -1
  133. package/package.json +30 -5
  134. package/dist/core/functionsBuilders/route/default.d.ts +0 -1
  135. package/dist/core/router/buildSystemRoute.d.ts +0 -11
  136. /package/dist/core/{router/decodeUrl.cjs → decodeUrl.cjs} +0 -0
  137. /package/dist/core/{router/decodeUrl.d.ts → decodeUrl.d.ts} +0 -0
  138. /package/dist/core/{router/decodeUrl.mjs → decodeUrl.mjs} +0 -0
@@ -1,13 +1,3 @@
1
- import { type createStepFunctionBuilder, type createRouteFunctionBuilder } from "../../functionsBuilders";
2
- import { type HookHubLifeCycle } from "../../hub";
3
1
  import { type RequestInitializationData } from "../../request";
4
- import { type HookRouteLifeCycle, type Route } from "../../route";
5
- export type RouterInitializationData = Omit<RequestInitializationData, "matchedPath" | "bodyReader" | "params" | "path" | "query">;
6
- export interface BuildedRouter {
7
- exec(initializationData: RouterInitializationData): Promise<void>;
8
- readonly routes: ReadonlySet<Route>;
9
- readonly hooksRouteLifeCycle: readonly HookRouteLifeCycle[];
10
- readonly routeFunctionBuilders: readonly ReturnType<typeof createRouteFunctionBuilder>[];
11
- readonly stepFunctionBuilders: readonly ReturnType<typeof createStepFunctionBuilder>[];
12
- readonly hooksHubLifeCycle: readonly HookHubLifeCycle[];
13
- }
2
+ export type RouterParams = Omit<RequestInitializationData, "matchedPath" | "bodyReader" | "params" | "path" | "query">;
3
+ export type BuildedRouter = (params: RouterParams) => Promise<void>;
@@ -1,4 +1,8 @@
1
1
  'use strict';
2
2
 
3
3
  require('./buildedRouter.cjs');
4
+ require('./router.cjs');
5
+ require('./routerElement.cjs');
6
+ require('./routerElementSystem.cjs');
7
+ require('./routerElementWrapper.cjs');
4
8
 
@@ -1 +1,5 @@
1
1
  export * from "./buildedRouter";
2
+ export * from "./router";
3
+ export * from "./routerElement";
4
+ export * from "./routerElementSystem";
5
+ export * from "./routerElementWrapper";
@@ -1 +1,5 @@
1
1
  import './buildedRouter.mjs';
2
+ import './router.mjs';
3
+ import './routerElement.mjs';
4
+ import './routerElementSystem.mjs';
5
+ import './routerElementWrapper.mjs';
@@ -0,0 +1,2 @@
1
+ 'use strict';
2
+
@@ -0,0 +1,12 @@
1
+ import { type createRouteFunctionBuilder, type createStepFunctionBuilder } from "../../functionsBuilders";
2
+ import { type HookHubLifeCycle } from "../../hub";
3
+ import { type HookRouteLifeCycle, type Route } from "../../route";
4
+ import { type BuildedRouter } from "./buildedRouter";
5
+ export interface Router {
6
+ exec: BuildedRouter;
7
+ readonly routes: ReadonlySet<Route>;
8
+ readonly hooksRouteLifeCycle: readonly HookRouteLifeCycle[];
9
+ readonly routeFunctionBuilders: readonly ReturnType<typeof createRouteFunctionBuilder>[];
10
+ readonly stepFunctionBuilders: readonly ReturnType<typeof createStepFunctionBuilder>[];
11
+ readonly hooksHubLifeCycle: readonly HookHubLifeCycle[];
12
+ }
@@ -0,0 +1 @@
1
+
@@ -0,0 +1,2 @@
1
+ 'use strict';
2
+
@@ -0,0 +1,8 @@
1
+ import { type BodyReader } from "../../request";
2
+ import { type BuildedRoute } from "../../route/types";
3
+ export interface RouterElement {
4
+ readonly pattern: RegExp;
5
+ readonly matchedPath: string;
6
+ readonly bodyReader: BodyReader;
7
+ readonly buildedRoute: BuildedRoute;
8
+ }
@@ -0,0 +1,2 @@
1
+ 'use strict';
2
+
@@ -0,0 +1,6 @@
1
+ import { type BodyReader } from "../../request";
2
+ import { type BuildedRoute } from "../../route/types";
3
+ export interface RouterElementSystem {
4
+ readonly bodyReader: BodyReader;
5
+ readonly buildedRoute: BuildedRoute;
6
+ }
@@ -0,0 +1,2 @@
1
+ 'use strict';
2
+
@@ -0,0 +1,2 @@
1
+ import { type RouterElement } from "./routerElement";
2
+ export type RouterElementWrapper = Record<string, RouterElement[]>;
@@ -3,12 +3,11 @@ import { type StepKind } from "./kind";
3
3
  import { type Floor } from "../floor";
4
4
  import { type StepFunctionParams } from "./types";
5
5
  import { type PredictedResponse, type ResponseContract } from "../response";
6
- import { type Request } from "../request";
7
6
  import { type Metadata } from "../metadata";
8
7
  export declare const cutStepOutputKind: import("@duplojs/utils").KindHandler<import("@duplojs/utils").KindDefinition<"@DuplojsHttpCore/cut-output", unknown>>;
9
8
  export interface CutStepFunctionOutput<GenericData extends Record<string, unknown> = Record<string, unknown>> extends Kind<typeof cutStepOutputKind.definition>, WrappedValue<GenericData> {
10
9
  }
11
- export interface CutStepFunctionParams<GenericRequest extends Request = Request, GenericResponse extends PredictedResponse = PredictedResponse> extends StepFunctionParams<GenericRequest, GenericResponse> {
10
+ export interface CutStepFunctionParams<GenericResponse extends PredictedResponse = PredictedResponse> extends StepFunctionParams<GenericResponse> {
12
11
  output<GenericData extends Record<string, unknown> = never>(data?: GenericData): CutStepFunctionOutput<NeverCoalescing<GenericData, {}>>;
13
12
  }
14
13
  export interface CutStepDefinition {
@@ -2,7 +2,6 @@ import { type MaybePromise, type Kind, type MaybeArray } from "@duplojs/utils";
2
2
  import { type StepKind } from "./kind";
3
3
  import { type Floor } from "../floor";
4
4
  import { type ServerSentEventsPredictedResponse, type PredictedResponse, type ResponseContract } from "../response";
5
- import { type Request } from "../request";
6
5
  import { type StepFunctionParams } from "./types";
7
6
  import { type Metadata } from "../metadata";
8
7
  interface HandlerStepFunctionParamsServerSentEventsResponse<GenericResponse extends ServerSentEventsPredictedResponse> {
@@ -10,7 +9,7 @@ interface HandlerStepFunctionParamsServerSentEventsResponse<GenericResponse exte
10
9
  information: GenericInformation;
11
10
  }>>(information: GenericInformation, startSendingEvents: GenericFilteredResponse["startSendingEvents"]): GenericFilteredResponse;
12
11
  }
13
- export interface HandlerStepFunctionParams<GenericRequest extends Request = Request, GenericResponse extends PredictedResponse | ServerSentEventsPredictedResponse = PredictedResponse | ServerSentEventsPredictedResponse> extends StepFunctionParams<GenericRequest, Extract<GenericResponse, PredictedResponse>>, HandlerStepFunctionParamsServerSentEventsResponse<Extract<GenericResponse, ServerSentEventsPredictedResponse>> {
12
+ export interface HandlerStepFunctionParams<GenericResponse extends PredictedResponse | ServerSentEventsPredictedResponse = PredictedResponse | ServerSentEventsPredictedResponse> extends StepFunctionParams<Extract<GenericResponse, PredictedResponse>>, HandlerStepFunctionParamsServerSentEventsResponse<Extract<GenericResponse, ServerSentEventsPredictedResponse>> {
14
13
  }
15
14
  export interface HandlerStepDefinition {
16
15
  theFunction(floor: Floor, params: HandlerStepFunctionParams): MaybePromise<PredictedResponse | ServerSentEventsPredictedResponse>;
@@ -1,8 +1,8 @@
1
1
  import { type Request } from "../../request";
2
2
  import { type PredictedResponse } from "../../response";
3
3
  import { type IsEqual, type Or } from "@duplojs/utils";
4
- export interface StepFunctionParams<GenericRequest extends Request = Request, GenericResponse extends PredictedResponse = PredictedResponse> {
5
- request: GenericRequest;
4
+ export interface StepFunctionParams<GenericResponse extends PredictedResponse = PredictedResponse> {
5
+ request: Request;
6
6
  response<GenericInformation extends GenericResponse["information"], GenericFilteredResponse extends Extract<GenericResponse, {
7
7
  information: GenericInformation;
8
8
  }>>(information: GenericInformation, ...args: Or<[
@@ -24,8 +24,8 @@ function createHttpServer(hub, params) {
24
24
  index.createTextBodyReaderImplementation(httpServerParams),
25
25
  index$1.createFormDataBodyReaderImplementation(httpServerParams),
26
26
  ]);
27
- function whenUncaughtError(error, routerInitializationData) {
28
- const serverResponse = routerInitializationData.raw.response;
27
+ function whenUncaughtError(error, routerParams) {
28
+ const serverResponse = routerParams.raw.response;
29
29
  if (!serverResponse.headersSent && !serverResponse.writableEnded) {
30
30
  serverResponse.writeHead(500, {
31
31
  [httpServerParams.informationHeaderKey]: "critical-server-error",
@@ -22,8 +22,8 @@ function createHttpServer(hub, params) {
22
22
  createTextBodyReaderImplementation(httpServerParams),
23
23
  createFormDataBodyReaderImplementation(httpServerParams),
24
24
  ]);
25
- function whenUncaughtError(error, routerInitializationData) {
26
- const serverResponse = routerInitializationData.raw.response;
25
+ function whenUncaughtError(error, routerParams) {
26
+ const serverResponse = routerParams.raw.response;
27
27
  if (!serverResponse.headersSent && !serverResponse.writableEnded) {
28
28
  serverResponse.writeHead(500, {
29
29
  [httpServerParams.informationHeaderKey]: "critical-server-error",
@@ -1,7 +1,7 @@
1
1
  import { type Hub } from "../../../core/hub";
2
2
  import { type HttpServerParams } from "../../../core/types";
3
3
  export declare function initNodeHook(hub: Hub, serverParams: HttpServerParams): {
4
- readonly beforeSendResponse: ({ request, currentResponse, exit }: import("../../../core/route").RouteHookParamsAfter<import("../../../core/request").Request>) => import("../../../core/route").RouteHookExit;
5
- readonly sendResponse: ({ request, currentResponse, exit }: import("../../../core/route").RouteHookParamsAfter<import("../../../core/request").Request>) => Promise<import("../../../core/route").RouteHookExit>;
6
- readonly afterSendResponse: ({ request, next }: import("../../../core/route").RouteHookParamsAfter<import("../../../core/request").Request>) => Promise<import("../../../core/route").RouteHookNext>;
4
+ readonly beforeSendResponse: ({ request, currentResponse, exit }: import("../../../core/route").RouteHookParamsAfter) => import("../../../core/route").RouteHookExit;
5
+ readonly sendResponse: ({ request, currentResponse, exit }: import("../../../core/route").RouteHookParamsAfter) => Promise<import("../../../core/route").RouteHookExit>;
6
+ readonly afterSendResponse: ({ request, next }: import("../../../core/route").RouteHookParamsAfter) => Promise<import("../../../core/route").RouteHookNext>;
7
7
  };
@@ -12,7 +12,8 @@ function createCacheControllerHooks(params) {
12
12
  return hooks.createHookRouteLifeCycle({
13
13
  beforeSendResponse: ({ currentResponse, next }) => {
14
14
  if (cacheControl
15
- && eligibleCodeRegex.test(currentResponse.code)) {
15
+ && eligibleCodeRegex.test(currentResponse.code)
16
+ && currentResponse.headers?.["cache-control"] === undefined) {
16
17
  currentResponse.setHeader("cache-control", cacheControl);
17
18
  }
18
19
  return next();
@@ -1,4 +1,4 @@
1
1
  import type { CacheControlDirectives } from "./types";
2
2
  export declare function createCacheControllerHooks(params?: CacheControlDirectives): {
3
- readonly beforeSendResponse: ({ currentResponse, next }: import("../../core/route").RouteHookParamsAfter<import("../../core/request").Request>) => import("../../core/route").RouteHookNext;
3
+ readonly beforeSendResponse: ({ currentResponse, next }: import("../../core/route").RouteHookParamsAfter) => import("../../core/route").RouteHookNext;
4
4
  };
@@ -10,7 +10,8 @@ function createCacheControllerHooks(params) {
10
10
  return createHookRouteLifeCycle({
11
11
  beforeSendResponse: ({ currentResponse, next }) => {
12
12
  if (cacheControl
13
- && eligibleCodeRegex.test(currentResponse.code)) {
13
+ && eligibleCodeRegex.test(currentResponse.code)
14
+ && currentResponse.headers?.["cache-control"] === undefined) {
14
15
  currentResponse.setHeader("cache-control", cacheControl);
15
16
  }
16
17
  return next();
@@ -0,0 +1,11 @@
1
+ 'use strict';
2
+
3
+ const allowHeadersFunction = {
4
+ default(allowHeaders) {
5
+ return (request, response) => {
6
+ response.setHeader("access-control-allow-headers", allowHeaders);
7
+ };
8
+ },
9
+ };
10
+
11
+ exports.allowHeadersFunction = allowHeadersFunction;
@@ -0,0 +1,5 @@
1
+ import type { Request } from "../../../core/request";
2
+ import type { Response } from "../../../core/response";
3
+ export declare const allowHeadersFunction: {
4
+ default(allowHeaders: string): (request: Request, response: Response) => void;
5
+ };
@@ -0,0 +1,9 @@
1
+ const allowHeadersFunction = {
2
+ default(allowHeaders) {
3
+ return (request, response) => {
4
+ response.setHeader("access-control-allow-headers", allowHeaders);
5
+ };
6
+ },
7
+ };
8
+
9
+ export { allowHeadersFunction };
@@ -0,0 +1,16 @@
1
+ 'use strict';
2
+
3
+ const allowMethodsFunction = {
4
+ default(methods) {
5
+ return (request, response) => {
6
+ response.setHeader("access-control-allow-methods", methods);
7
+ };
8
+ },
9
+ isBool(allowMethods) {
10
+ return (request, response) => {
11
+ response.setHeader("access-control-allow-methods", allowMethods[request.path]);
12
+ };
13
+ },
14
+ };
15
+
16
+ exports.allowMethodsFunction = allowMethodsFunction;
@@ -0,0 +1,6 @@
1
+ import type { Request } from "../../../core/request";
2
+ import type { Response } from "../../../core/response";
3
+ export declare const allowMethodsFunction: {
4
+ default(methods: string): (request: Request, response: Response) => void;
5
+ isBool(allowMethods: Record<string, string>): (request: Request, response: Response) => void;
6
+ };
@@ -0,0 +1,14 @@
1
+ const allowMethodsFunction = {
2
+ default(methods) {
3
+ return (request, response) => {
4
+ response.setHeader("access-control-allow-methods", methods);
5
+ };
6
+ },
7
+ isBool(allowMethods) {
8
+ return (request, response) => {
9
+ response.setHeader("access-control-allow-methods", allowMethods[request.path]);
10
+ };
11
+ },
12
+ };
13
+
14
+ export { allowMethodsFunction };
@@ -0,0 +1,24 @@
1
+ 'use strict';
2
+
3
+ const allowOriginFunction = {
4
+ default(allowOrigin) {
5
+ return (request, response) => {
6
+ if (allowOrigin.test(request.origin)) {
7
+ response.setHeader("access-control-allow-origin", request.origin);
8
+ }
9
+ };
10
+ },
11
+ isFunction(allowOrigin) {
12
+ return async (request, response) => {
13
+ let result = allowOrigin(request.origin);
14
+ if (result instanceof Promise) {
15
+ result = await result;
16
+ }
17
+ if (result === true) {
18
+ response.setHeader("access-control-allow-origin", request.origin);
19
+ }
20
+ };
21
+ },
22
+ };
23
+
24
+ exports.allowOriginFunction = allowOriginFunction;
@@ -0,0 +1,7 @@
1
+ import type { Request } from "../../../core/request";
2
+ import type { Response } from "../../../core/response";
3
+ import type { MaybePromise } from "@duplojs/utils";
4
+ export declare const allowOriginFunction: {
5
+ default(allowOrigin: RegExp): (request: Request, response: Response) => void;
6
+ isFunction(allowOrigin: (origin: string) => MaybePromise<boolean>): (request: Request, response: Response) => Promise<void>;
7
+ };
@@ -0,0 +1,22 @@
1
+ const allowOriginFunction = {
2
+ default(allowOrigin) {
3
+ return (request, response) => {
4
+ if (allowOrigin.test(request.origin)) {
5
+ response.setHeader("access-control-allow-origin", request.origin);
6
+ }
7
+ };
8
+ },
9
+ isFunction(allowOrigin) {
10
+ return async (request, response) => {
11
+ let result = allowOrigin(request.origin);
12
+ if (result instanceof Promise) {
13
+ result = await result;
14
+ }
15
+ if (result === true) {
16
+ response.setHeader("access-control-allow-origin", request.origin);
17
+ }
18
+ };
19
+ },
20
+ };
21
+
22
+ export { allowOriginFunction };
@@ -0,0 +1,11 @@
1
+ 'use strict';
2
+
3
+ const credentialsFunction = {
4
+ default() {
5
+ return (request, response) => {
6
+ response.setHeader("access-control-allow-credentials", "true");
7
+ };
8
+ },
9
+ };
10
+
11
+ exports.credentialsFunction = credentialsFunction;
@@ -0,0 +1,5 @@
1
+ import type { Request } from "../../../core/request";
2
+ import type { Response } from "../../../core/response";
3
+ export declare const credentialsFunction: {
4
+ default(): (request: Request, response: Response) => void;
5
+ };
@@ -0,0 +1,9 @@
1
+ const credentialsFunction = {
2
+ default() {
3
+ return (request, response) => {
4
+ response.setHeader("access-control-allow-credentials", "true");
5
+ };
6
+ },
7
+ };
8
+
9
+ export { credentialsFunction };
@@ -0,0 +1,11 @@
1
+ 'use strict';
2
+
3
+ const exposeHeadersFunction = {
4
+ default(exposeHeaders) {
5
+ return (request, response) => {
6
+ response.setHeader("access-control-expose-headers", exposeHeaders);
7
+ };
8
+ },
9
+ };
10
+
11
+ exports.exposeHeadersFunction = exposeHeadersFunction;
@@ -0,0 +1,5 @@
1
+ import type { Request } from "../../../core/request";
2
+ import type { Response } from "../../../core/response";
3
+ export declare const exposeHeadersFunction: {
4
+ default(exposeHeaders: string): (request: Request, response: Response) => void;
5
+ };
@@ -0,0 +1,9 @@
1
+ const exposeHeadersFunction = {
2
+ default(exposeHeaders) {
3
+ return (request, response) => {
4
+ response.setHeader("access-control-expose-headers", exposeHeaders);
5
+ };
6
+ },
7
+ };
8
+
9
+ export { exposeHeadersFunction };
@@ -0,0 +1,19 @@
1
+ 'use strict';
2
+
3
+ var allowHeaders = require('./allowHeaders.cjs');
4
+ var allowMethods = require('./allowMethods.cjs');
5
+ var allowOrigin = require('./allowOrigin.cjs');
6
+ var credentials = require('./credentials.cjs');
7
+ var exposeHeaders = require('./exposeHeaders.cjs');
8
+ var maxAge = require('./maxAge.cjs');
9
+ var vary = require('./vary.cjs');
10
+
11
+
12
+
13
+ exports.allowHeadersFunction = allowHeaders.allowHeadersFunction;
14
+ exports.allowMethodsFunction = allowMethods.allowMethodsFunction;
15
+ exports.allowOriginFunction = allowOrigin.allowOriginFunction;
16
+ exports.credentialsFunction = credentials.credentialsFunction;
17
+ exports.exposeHeadersFunction = exposeHeaders.exposeHeadersFunction;
18
+ exports.maxAgeFunction = maxAge.maxAgeFunction;
19
+ exports.varyFunction = vary.varyFunction;
@@ -0,0 +1,7 @@
1
+ export * from "./allowHeaders";
2
+ export * from "./allowMethods";
3
+ export * from "./allowOrigin";
4
+ export * from "./credentials";
5
+ export * from "./exposeHeaders";
6
+ export * from "./maxAge";
7
+ export * from "./vary";
@@ -0,0 +1,7 @@
1
+ export { allowHeadersFunction } from './allowHeaders.mjs';
2
+ export { allowMethodsFunction } from './allowMethods.mjs';
3
+ export { allowOriginFunction } from './allowOrigin.mjs';
4
+ export { credentialsFunction } from './credentials.mjs';
5
+ export { exposeHeadersFunction } from './exposeHeaders.mjs';
6
+ export { maxAgeFunction } from './maxAge.mjs';
7
+ export { varyFunction } from './vary.mjs';
@@ -0,0 +1,11 @@
1
+ 'use strict';
2
+
3
+ const maxAgeFunction = {
4
+ default(maxAge) {
5
+ return (request, response) => {
6
+ response.setHeader("access-control-max-age", maxAge);
7
+ };
8
+ },
9
+ };
10
+
11
+ exports.maxAgeFunction = maxAgeFunction;
@@ -0,0 +1,5 @@
1
+ import type { Request } from "../../../core/request";
2
+ import type { Response } from "../../../core/response";
3
+ export declare const maxAgeFunction: {
4
+ default(maxAge: string): (request: Request, response: Response) => void;
5
+ };
@@ -0,0 +1,9 @@
1
+ const maxAgeFunction = {
2
+ default(maxAge) {
3
+ return (request, response) => {
4
+ response.setHeader("access-control-max-age", maxAge);
5
+ };
6
+ },
7
+ };
8
+
9
+ export { maxAgeFunction };
@@ -0,0 +1,35 @@
1
+ 'use strict';
2
+
3
+ const starRegex = /(^|,) *\* *(?=,|$)/;
4
+ const originRegex = /(^|,) *origin *(?=,|$)/i;
5
+ const varyFunction = {
6
+ default() {
7
+ const maxStoreSize = 500;
8
+ const store = new Map();
9
+ return (request, response) => {
10
+ const cachedVary = store.get(request.origin);
11
+ if (cachedVary) {
12
+ response.setHeader("vary", cachedVary);
13
+ return;
14
+ }
15
+ let varyValue = Array.isArray(response.headers?.vary)
16
+ ? response.headers.vary.join(", ")
17
+ : response.headers?.vary;
18
+ if (varyValue === undefined) {
19
+ varyValue = "Origin";
20
+ }
21
+ else if (starRegex.test(varyValue)) {
22
+ varyValue = "*";
23
+ }
24
+ else if (!originRegex.test(varyValue)) {
25
+ varyValue = `${varyValue}, Origin`;
26
+ }
27
+ if (store.size < maxStoreSize) {
28
+ store.set(request.origin, varyValue);
29
+ }
30
+ response.setHeader("vary", varyValue);
31
+ };
32
+ },
33
+ };
34
+
35
+ exports.varyFunction = varyFunction;
@@ -0,0 +1,5 @@
1
+ import type { Request } from "../../../core/request";
2
+ import type { Response } from "../../../core/response";
3
+ export declare const varyFunction: {
4
+ default(): (request: Request, response: Response) => void;
5
+ };
@@ -0,0 +1,33 @@
1
+ const starRegex = /(^|,) *\* *(?=,|$)/;
2
+ const originRegex = /(^|,) *origin *(?=,|$)/i;
3
+ const varyFunction = {
4
+ default() {
5
+ const maxStoreSize = 500;
6
+ const store = new Map();
7
+ return (request, response) => {
8
+ const cachedVary = store.get(request.origin);
9
+ if (cachedVary) {
10
+ response.setHeader("vary", cachedVary);
11
+ return;
12
+ }
13
+ let varyValue = Array.isArray(response.headers?.vary)
14
+ ? response.headers.vary.join(", ")
15
+ : response.headers?.vary;
16
+ if (varyValue === undefined) {
17
+ varyValue = "Origin";
18
+ }
19
+ else if (starRegex.test(varyValue)) {
20
+ varyValue = "*";
21
+ }
22
+ else if (!originRegex.test(varyValue)) {
23
+ varyValue = `${varyValue}, Origin`;
24
+ }
25
+ if (store.size < maxStoreSize) {
26
+ store.set(request.origin, varyValue);
27
+ }
28
+ response.setHeader("vary", varyValue);
29
+ };
30
+ },
31
+ };
32
+
33
+ export { varyFunction };
@@ -0,0 +1,9 @@
1
+ 'use strict';
2
+
3
+ var metadata = require('./metadata.cjs');
4
+ var plugin = require('./plugin.cjs');
5
+
6
+
7
+
8
+ exports.IgnoreRouteCorsMetadata = metadata.IgnoreRouteCorsMetadata;
9
+ exports.corsPlugin = plugin.corsPlugin;
@@ -0,0 +1,2 @@
1
+ export * from "./metadata";
2
+ export * from "./plugin";
@@ -0,0 +1,2 @@
1
+ export { IgnoreRouteCorsMetadata } from './metadata.mjs';
2
+ export { corsPlugin } from './plugin.mjs';
@@ -0,0 +1,8 @@
1
+ 'use strict';
2
+
3
+ require('../../core/metadata/index.cjs');
4
+ var base = require('../../core/metadata/base.cjs');
5
+
6
+ const IgnoreRouteCorsMetadata = base.createMetadata("ignore-by-cors");
7
+
8
+ exports.IgnoreRouteCorsMetadata = IgnoreRouteCorsMetadata;
@@ -0,0 +1 @@
1
+ export declare const IgnoreRouteCorsMetadata: import("../../core/metadata").MetadataHandler<"ignore-by-cors", unknown>;
@@ -0,0 +1,6 @@
1
+ import '../../core/metadata/index.mjs';
2
+ import { createMetadata } from '../../core/metadata/base.mjs';
3
+
4
+ const IgnoreRouteCorsMetadata = createMetadata("ignore-by-cors");
5
+
6
+ export { IgnoreRouteCorsMetadata };