@sima-land/isomorph 11.0.0-alpha.45 → 11.0.0-alpha.46
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 +1 -0
- package/dist/cjs/http/types.js.map +1 -1
- package/dist/cjs/package.json +1 -1
- package/dist/cjs/preset/bun-handler/index.js +0 -2
- package/dist/cjs/preset/bun-handler/index.js.map +1 -1
- package/dist/cjs/preset/bun-handler/providers/fetch-middleware.js +1 -2
- package/dist/cjs/preset/bun-handler/providers/fetch-middleware.js.map +1 -1
- package/dist/cjs/preset/bun-handler/providers/handler-main.js +1 -21
- package/dist/cjs/preset/bun-handler/providers/handler-main.js.map +1 -1
- package/dist/cjs/preset/node-handler/index.js +2 -2
- package/dist/cjs/preset/node-handler/index.js.map +1 -1
- package/dist/cjs/preset/node-handler/providers/axios-middleware.js +1 -2
- package/dist/cjs/preset/node-handler/providers/axios-middleware.js.map +1 -1
- package/dist/cjs/preset/node-handler/providers/fetch-middleware.js +1 -2
- package/dist/cjs/preset/node-handler/providers/fetch-middleware.js.map +1 -1
- package/dist/cjs/preset/node-handler/providers/handler-main.js +1 -14
- package/dist/cjs/preset/node-handler/providers/handler-main.js.map +1 -1
- package/dist/cjs/preset/server/index.js +6 -0
- package/dist/cjs/preset/server/index.js.map +1 -1
- package/dist/cjs/preset/server/providers/format-page-response.js +4 -1
- package/dist/cjs/preset/server/providers/format-page-response.js.map +1 -1
- package/dist/cjs/preset/server/types.js.map +1 -1
- package/dist/cjs/preset/server/utils/get-forwarded-headers.js +6 -0
- package/dist/cjs/preset/server/utils/get-forwarded-headers.js.map +1 -1
- package/dist/esm/http/types.js.map +1 -1
- package/dist/esm/package.json +1 -1
- package/dist/esm/preset/bun-handler/index.js +0 -2
- package/dist/esm/preset/bun-handler/index.js.map +1 -1
- package/dist/esm/preset/bun-handler/providers/fetch-middleware.js +2 -3
- package/dist/esm/preset/bun-handler/providers/fetch-middleware.js.map +1 -1
- package/dist/esm/preset/bun-handler/providers/handler-main.js +1 -21
- package/dist/esm/preset/bun-handler/providers/handler-main.js.map +1 -1
- package/dist/esm/preset/node-handler/index.js +2 -2
- package/dist/esm/preset/node-handler/index.js.map +1 -1
- package/dist/esm/preset/node-handler/providers/axios-middleware.js +2 -3
- package/dist/esm/preset/node-handler/providers/axios-middleware.js.map +1 -1
- package/dist/esm/preset/node-handler/providers/fetch-middleware.js +2 -3
- package/dist/esm/preset/node-handler/providers/fetch-middleware.js.map +1 -1
- package/dist/esm/preset/node-handler/providers/handler-main.js +1 -14
- package/dist/esm/preset/node-handler/providers/handler-main.js.map +1 -1
- package/dist/esm/preset/server/index.js +1 -1
- package/dist/esm/preset/server/index.js.map +1 -1
- package/dist/esm/preset/server/providers/format-page-response.js +4 -1
- package/dist/esm/preset/server/providers/format-page-response.js.map +1 -1
- package/dist/esm/preset/server/types.js.map +1 -1
- package/dist/esm/preset/server/utils/get-forwarded-headers.js +6 -0
- package/dist/esm/preset/server/utils/get-forwarded-headers.js.map +1 -1
- package/dist/types/http/types.d.ts +1 -1
- package/dist/types/http/types.d.ts.map +1 -1
- package/dist/types/preset/bun-handler/index.d.ts.map +1 -1
- package/dist/types/preset/bun-handler/providers/fetch-middleware.d.ts.map +1 -1
- package/dist/types/preset/bun-handler/providers/handler-main.d.ts.map +1 -1
- package/dist/types/preset/node-handler/providers/axios-middleware.d.ts.map +1 -1
- package/dist/types/preset/node-handler/providers/fetch-middleware.d.ts.map +1 -1
- package/dist/types/preset/node-handler/providers/handler-main.d.ts.map +1 -1
- package/dist/types/preset/server/index.d.ts +2 -2
- package/dist/types/preset/server/index.d.ts.map +1 -1
- package/dist/types/preset/server/providers/format-page-response.d.ts.map +1 -1
- package/dist/types/preset/server/types.d.ts +1 -1
- package/dist/types/preset/server/types.d.ts.map +1 -1
- package/dist/types/preset/server/utils/get-forwarded-headers.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["createPreset","KnownToken","provideAbortController","provideFetch","provideReduxMiddlewareSaga","providePageRender","provideFetchLogHandler","provideFetchMiddleware","provideHandlerMain","providePageHelmet","provideSpecificParams","
|
|
1
|
+
{"version":3,"file":"index.js","names":["createPreset","KnownToken","provideAbortController","provideFetch","provideReduxMiddlewareSaga","providePageRender","provideFetchLogHandler","provideFetchMiddleware","provideHandlerMain","providePageHelmet","provideSpecificParams","SpecificExtras","provideElementToString","provideFormatPageResponse","provideAcceptType","provideResponseEvents","PresetBunHandler","customize","preset","set","Http","fetch","Fetch","abortController","middleware","Middleware","Log","handler","Handler","main","Request","acceptType","specificParams","Response","events","specificExtras","Page","assets","js","css","helmet","render","elementToString","formatResponse","Redux","saga","override","bind"],"sources":["../../../../src/preset/bun-handler/index.ts"],"sourcesContent":["/* eslint-disable require-jsdoc, jsdoc/require-jsdoc */\nimport { createPreset } from '../../di';\nimport { KnownToken } from '../../tokens';\nimport { PresetTuner } from '../isomorphic';\nimport { provideAbortController } from '../isomorphic/providers/abort-controller';\nimport { provideFetch } from '../isomorphic/providers/fetch';\nimport { provideReduxMiddlewareSaga } from '../isomorphic/providers/redux-middleware-saga';\nimport { providePageRender } from '../server/providers/page-render';\nimport { provideFetchLogHandler } from '../server/providers/fetch-log-handler';\nimport { provideFetchMiddleware } from './providers/fetch-middleware';\nimport { provideHandlerMain } from './providers/handler-main';\nimport { providePageHelmet } from '../server/providers/page-helmet';\nimport { provideSpecificParams } from './providers/specific-params';\nimport { SpecificExtras } from '../server/utils/specific-extras';\nimport { provideElementToString } from '../server/providers/element-to-string';\nimport { provideFormatPageResponse } from '../server/providers/format-page-response';\nimport { provideAcceptType } from './providers/accept-type';\nimport { provideResponseEvents } from '../server/providers/response-events';\n\n/**\n * Возвращает preset с зависимостями для формирования обработчика входящего http-запроса.\n * @param customize Получит функцию с помощью которой можно переопределить предустановленные провайдеры.\n * @todo Возможно стоит переименовать в PresetPageHandler.\n * @return Preset.\n */\nexport function PresetBunHandler(customize?: PresetTuner) {\n const preset = createPreset();\n\n // http fetch\n preset.set(KnownToken.Http.fetch, provideFetch);\n preset.set(KnownToken.Http.Fetch.abortController, provideAbortController);\n preset.set(KnownToken.Http.Fetch.middleware, provideFetchMiddleware);\n preset.set(KnownToken.Http.Fetch.Middleware.Log.handler, provideFetchLogHandler);\n\n // handler\n preset.set(KnownToken.Http.Handler.main, provideHandlerMain);\n preset.set(KnownToken.Http.Handler.Request.acceptType, provideAcceptType);\n preset.set(KnownToken.Http.Handler.Request.specificParams, provideSpecificParams);\n preset.set(KnownToken.Http.Handler.Response.events, provideResponseEvents);\n preset.set(KnownToken.Http.Handler.Response.specificExtras, () => new SpecificExtras());\n preset.set(KnownToken.Http.Handler.Page.assets, () => ({ js: '', css: '' }));\n preset.set(KnownToken.Http.Handler.Page.helmet, providePageHelmet);\n preset.set(KnownToken.Http.Handler.Page.render, providePageRender);\n preset.set(KnownToken.Http.Handler.Page.elementToString, provideElementToString);\n preset.set(KnownToken.Http.Handler.Page.formatResponse, provideFormatPageResponse);\n\n // redux saga\n preset.set(KnownToken.Redux.Middleware.saga, provideReduxMiddlewareSaga);\n\n if (customize) {\n customize({ override: preset.set.bind(preset) });\n }\n\n return preset;\n}\n"],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
/* eslint-disable require-jsdoc, jsdoc/require-jsdoc */
|
|
2
2
|
|
|
3
3
|
import { KnownToken } from "../../../tokens.js";
|
|
4
|
-
import {
|
|
4
|
+
import { defaultHeaders } from "./../../../http/index.js";
|
|
5
5
|
import { getFetchErrorLogging } from "../../isomorphic/utils/get-fetch-error-logging.js";
|
|
6
6
|
import { getFetchExtraAborting } from "../../isomorphic/utils/get-fetch-extra-aborting.js";
|
|
7
7
|
import { getFetchLogging } from "../../isomorphic/utils/get-fetch-logging.js";
|
|
@@ -10,13 +10,12 @@ export function provideFetchMiddleware(resolve) {
|
|
|
10
10
|
const config = resolve(KnownToken.Config.base);
|
|
11
11
|
const context = resolve(KnownToken.Http.Handler.context);
|
|
12
12
|
const logHandler = resolve(KnownToken.Http.Fetch.Middleware.Log.handler);
|
|
13
|
-
const cookieStore = resolve(KnownToken.Http.Fetch.cookieStore);
|
|
14
13
|
const abortController = resolve(KnownToken.Http.Fetch.abortController);
|
|
15
14
|
return [
|
|
16
15
|
// ВАЖНО: слой логирования ошибки ПЕРЕД остальными слоями чтобы не упустить ошибки выше
|
|
17
16
|
getFetchErrorLogging(logHandler),
|
|
18
17
|
// обрывание по сигналу из обработчика входящего запроса и по сигналу из конфига исходящего запроса
|
|
19
|
-
getFetchExtraAborting(abortController),
|
|
18
|
+
getFetchExtraAborting(abortController), defaultHeaders(getForwardedHeaders(config, context.request)),
|
|
20
19
|
// @todo tracing
|
|
21
20
|
|
|
22
21
|
// ВАЖНО: слой логирования запроса и ответа ПОСЛЕ остальных слоев чтобы использовать актуальные данные
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fetch-middleware.js","names":["KnownToken","
|
|
1
|
+
{"version":3,"file":"fetch-middleware.js","names":["KnownToken","defaultHeaders","getFetchErrorLogging","getFetchExtraAborting","getFetchLogging","getForwardedHeaders","provideFetchMiddleware","resolve","config","Config","base","context","Http","Handler","logHandler","Fetch","Middleware","Log","handler","abortController","request"],"sources":["../../../../../src/preset/bun-handler/providers/fetch-middleware.ts"],"sourcesContent":["/* eslint-disable require-jsdoc, jsdoc/require-jsdoc */\nimport { Resolve } from '../../../di';\nimport { KnownToken } from '../../../tokens';\nimport { Middleware, defaultHeaders } from '../../../http';\nimport { getFetchErrorLogging } from '../../isomorphic/utils/get-fetch-error-logging';\nimport { getFetchExtraAborting } from '../../isomorphic/utils/get-fetch-extra-aborting';\nimport { getFetchLogging } from '../../isomorphic/utils/get-fetch-logging';\nimport { getForwardedHeaders } from '../../server/utils/get-forwarded-headers';\n\nexport function provideFetchMiddleware(resolve: Resolve): Middleware[] {\n const config = resolve(KnownToken.Config.base);\n const context = resolve(KnownToken.Http.Handler.context);\n const logHandler = resolve(KnownToken.Http.Fetch.Middleware.Log.handler);\n const abortController = resolve(KnownToken.Http.Fetch.abortController);\n\n return [\n // ВАЖНО: слой логирования ошибки ПЕРЕД остальными слоями чтобы не упустить ошибки выше\n getFetchErrorLogging(logHandler),\n\n // обрывание по сигналу из обработчика входящего запроса и по сигналу из конфига исходящего запроса\n getFetchExtraAborting(abortController),\n\n defaultHeaders(getForwardedHeaders(config, context.request)),\n\n // @todo tracing\n\n // ВАЖНО: слой логирования запроса и ответа ПОСЛЕ остальных слоев чтобы использовать актуальные данные\n getFetchLogging(logHandler),\n ];\n}\n"],"mappings":"AAAA;;AAEA,SAASA,UAAU,QAAQ,oBAAiB;AAC5C,SAAqBC,cAAc,QAAQ,0BAAe;AAC1D,SAASC,oBAAoB,QAAQ,mDAAgD;AACrF,SAASC,qBAAqB,QAAQ,oDAAiD;AACvF,SAASC,eAAe,QAAQ,6CAA0C;AAC1E,SAASC,mBAAmB,QAAQ,6CAA0C;AAE9E,OAAO,SAASC,sBAAsBA,CAACC,OAAgB,EAAgB;EACrE,MAAMC,MAAM,GAAGD,OAAO,CAACP,UAAU,CAACS,MAAM,CAACC,IAAI,CAAC;EAC9C,MAAMC,OAAO,GAAGJ,OAAO,CAACP,UAAU,CAACY,IAAI,CAACC,OAAO,CAACF,OAAO,CAAC;EACxD,MAAMG,UAAU,GAAGP,OAAO,CAACP,UAAU,CAACY,IAAI,CAACG,KAAK,CAACC,UAAU,CAACC,GAAG,CAACC,OAAO,CAAC;EACxE,MAAMC,eAAe,GAAGZ,OAAO,CAACP,UAAU,CAACY,IAAI,CAACG,KAAK,CAACI,eAAe,CAAC;EAEtE,OAAO;EACL;EACAjB,oBAAoB,CAACY,UAAU,CAAC;EAEhC;EACAX,qBAAqB,CAACgB,eAAe,CAAC,EAEtClB,cAAc,CAACI,mBAAmB,CAACG,MAAM,EAAEG,OAAO,CAACS,OAAO,CAAC,CAAC;EAE5D;;EAEA;EACAhB,eAAe,CAACU,UAAU,CAAC,CAC5B;AACH"}
|
|
@@ -10,23 +10,13 @@ export function provideHandlerMain(resolve) {
|
|
|
10
10
|
const logger = resolve(KnownToken.logger);
|
|
11
11
|
const assetsInit = resolve(KnownToken.Http.Handler.Page.assets);
|
|
12
12
|
const render = resolve(KnownToken.Http.Handler.Page.render);
|
|
13
|
-
const extras = resolve(KnownToken.Http.Handler.Response.specificExtras);
|
|
14
13
|
const Helmet = resolve(KnownToken.Http.Handler.Page.helmet);
|
|
15
14
|
const abortController = resolve(KnownToken.Http.Fetch.abortController);
|
|
16
15
|
const formatResponse = resolve(KnownToken.Http.Handler.Page.formatResponse);
|
|
17
|
-
|
|
18
|
-
// @todo https://github.com/sima-land/isomorph/issues/69
|
|
19
|
-
// const cookieStore = resolve(KnownToken.Http.Fetch.cookieStore);
|
|
20
|
-
// const forwardedSetCookie: string[] = [];
|
|
21
|
-
// const unsubscribeCookieStore = cookieStore.subscribe(setCookieList => {
|
|
22
|
-
// forwardedSetCookie.push(...setCookieList);
|
|
23
|
-
// });
|
|
24
|
-
|
|
25
16
|
const getAssets = typeof assetsInit === 'function' ? assetsInit : () => assetsInit;
|
|
26
17
|
const handler = async () => {
|
|
27
18
|
try {
|
|
28
19
|
const assets = await getAssets();
|
|
29
|
-
const meta = extras.getMeta();
|
|
30
20
|
const jsx = /*#__PURE__*/React.createElement(HelmetContext.Provider, {
|
|
31
21
|
value: {
|
|
32
22
|
title: config.appName,
|
|
@@ -36,7 +26,7 @@ export function provideHandlerMain(resolve) {
|
|
|
36
26
|
const {
|
|
37
27
|
body,
|
|
38
28
|
headers
|
|
39
|
-
} = await formatResponse(jsx, assets
|
|
29
|
+
} = await formatResponse(jsx, assets);
|
|
40
30
|
return new Response(body, {
|
|
41
31
|
headers
|
|
42
32
|
});
|
|
@@ -63,16 +53,6 @@ export function provideHandlerMain(resolve) {
|
|
|
63
53
|
}
|
|
64
54
|
};
|
|
65
55
|
const enhancer = applyMiddleware(
|
|
66
|
-
// @todo https://github.com/sima-land/isomorph/issues/69
|
|
67
|
-
// async (request, next) => {
|
|
68
|
-
// const response = await next(request);
|
|
69
|
-
// for (const item of forwardedSetCookie) {
|
|
70
|
-
// response.headers.append('set-cookie', item);
|
|
71
|
-
// }
|
|
72
|
-
// unsubscribeCookieStore();
|
|
73
|
-
// return response;
|
|
74
|
-
// },
|
|
75
|
-
|
|
76
56
|
// ВАЖНО: прерываем исходящие в рамках обработчика http-запросы
|
|
77
57
|
async (request, next) => {
|
|
78
58
|
const response = await next(request);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"handler-main.js","names":["KnownToken","applyMiddleware","HelmetContext","formatHandlerError","provideHandlerMain","resolve","config","Config","base","logger","assetsInit","Http","Handler","Page","assets","render","
|
|
1
|
+
{"version":3,"file":"handler-main.js","names":["KnownToken","applyMiddleware","HelmetContext","formatHandlerError","provideHandlerMain","resolve","config","Config","base","logger","assetsInit","Http","Handler","Page","assets","render","Helmet","helmet","abortController","Fetch","formatResponse","getAssets","handler","jsx","React","createElement","Provider","value","title","appName","body","headers","Response","error","response","log","level","status","redirectLocation","Location","enhancer","request","next","abort"],"sources":["../../../../../src/preset/bun-handler/providers/handler-main.tsx"],"sourcesContent":["/* eslint-disable require-jsdoc, jsdoc/require-jsdoc */\nimport { Resolve } from '../../../di';\nimport { KnownToken } from '../../../tokens';\nimport { applyMiddleware } from '../../../http';\nimport { HelmetContext } from '../../server/utils/regular-helmet';\nimport { formatHandlerError } from '../../server/utils/format-handler-error';\n\nexport function provideHandlerMain(resolve: Resolve) {\n const config = resolve(KnownToken.Config.base);\n const logger = resolve(KnownToken.logger);\n const assetsInit = resolve(KnownToken.Http.Handler.Page.assets);\n const render = resolve(KnownToken.Http.Handler.Page.render);\n const Helmet = resolve(KnownToken.Http.Handler.Page.helmet);\n const abortController = resolve(KnownToken.Http.Fetch.abortController);\n const formatResponse = resolve(KnownToken.Http.Handler.Page.formatResponse);\n\n const getAssets = typeof assetsInit === 'function' ? assetsInit : () => assetsInit;\n\n const handler = async (): Promise<Response> => {\n try {\n const assets = await getAssets();\n\n const jsx = (\n <HelmetContext.Provider value={{ title: config.appName, assets }}>\n <Helmet>{await render()}</Helmet>\n </HelmetContext.Provider>\n );\n\n const { body, headers } = await formatResponse(jsx, assets);\n\n return new Response(body, { headers });\n } catch (error) {\n const { response, log } = formatHandlerError(error);\n\n if (log.level && logger[log.level]) {\n logger[log.level](error);\n }\n\n if (response.status > 299 && response.status < 400 && response.redirectLocation) {\n return new Response(null, {\n status: response.status,\n headers: {\n Location: response.redirectLocation,\n },\n });\n } else {\n return new Response(response.body, {\n status: response.status,\n });\n }\n }\n };\n\n const enhancer = applyMiddleware(\n // ВАЖНО: прерываем исходящие в рамках обработчика http-запросы\n async (request, next) => {\n const response = await next(request);\n\n abortController.abort();\n\n return response;\n },\n );\n\n return enhancer(handler);\n}\n"],"mappings":"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"}
|
|
@@ -13,10 +13,10 @@ import { providePageHelmet } from "../server/providers/page-helmet.js";
|
|
|
13
13
|
import { providePageRender } from "../server/providers/page-render.js";
|
|
14
14
|
import { provideFetchMiddleware } from "./providers/fetch-middleware.js";
|
|
15
15
|
import { provideFetchLogHandler } from "../server/providers/fetch-log-handler.js";
|
|
16
|
-
import { provideCookieStore } from "./providers/cookie-store.js";
|
|
17
16
|
import { SpecificExtras } from "../server/utils/specific-extras.js";
|
|
18
17
|
import { provideAcceptType } from "./providers/accepts-type.js";
|
|
19
18
|
import { provideResponseEvents } from "./providers/response-events.js";
|
|
19
|
+
import { provideAxiosFactory } from "../isomorphic/providers/axios-factory.js";
|
|
20
20
|
|
|
21
21
|
/**
|
|
22
22
|
* Возвращает preset с зависимостями по умолчанию для работы в рамках ответа на http-запрос.
|
|
@@ -31,7 +31,6 @@ export function PresetHandler(customize) {
|
|
|
31
31
|
// fetch
|
|
32
32
|
preset.set(KnownToken.Http.fetch, provideFetch);
|
|
33
33
|
preset.set(KnownToken.Http.Fetch.middleware, provideFetchMiddleware);
|
|
34
|
-
preset.set(KnownToken.Http.Fetch.cookieStore, provideCookieStore);
|
|
35
34
|
preset.set(KnownToken.Http.Fetch.abortController, provideAbortController);
|
|
36
35
|
preset.set(KnownToken.Http.Fetch.Middleware.Log.handler, provideFetchLogHandler);
|
|
37
36
|
|
|
@@ -39,6 +38,7 @@ export function PresetHandler(customize) {
|
|
|
39
38
|
preset.set(KnownToken.Redux.Middleware.saga, provideReduxMiddlewareSaga);
|
|
40
39
|
|
|
41
40
|
// axios
|
|
41
|
+
preset.set(KnownToken.Axios.factory, provideAxiosFactory);
|
|
42
42
|
preset.set(KnownToken.Axios.middleware, provideAxiosMiddleware);
|
|
43
43
|
preset.set(KnownToken.Axios.Middleware.Log.handler, provideAxiosLogHandler);
|
|
44
44
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["createPreset","KnownToken","provideReduxMiddlewareSaga","provideFetch","provideAbortController","provideFormatPageResponse","provideElementToString","provideAxiosMiddleware","provideAxiosLogHandler","provideHandlerMain","provideSpecificParams","providePageHelmet","providePageRender","provideFetchMiddleware","provideFetchLogHandler","
|
|
1
|
+
{"version":3,"file":"index.js","names":["createPreset","KnownToken","provideReduxMiddlewareSaga","provideFetch","provideAbortController","provideFormatPageResponse","provideElementToString","provideAxiosMiddleware","provideAxiosLogHandler","provideHandlerMain","provideSpecificParams","providePageHelmet","providePageRender","provideFetchMiddleware","provideFetchLogHandler","SpecificExtras","provideAcceptType","provideResponseEvents","provideAxiosFactory","PresetHandler","customize","preset","set","Http","fetch","Fetch","middleware","abortController","Middleware","Log","handler","Redux","saga","Axios","factory","ExpressHandler","main","Handler","Request","acceptType","specificParams","Response","specificExtras","events","Page","assets","js","css","helmet","render","elementToString","formatResponse","override","bind"],"sources":["../../../../src/preset/node-handler/index.ts"],"sourcesContent":["import { Preset, createPreset } from '../../di';\nimport { KnownToken } from '../../tokens';\nimport { provideReduxMiddlewareSaga } from '../isomorphic/providers/redux-middleware-saga';\nimport { provideFetch } from '../isomorphic/providers/fetch';\nimport { provideAbortController } from '../isomorphic/providers/abort-controller';\nimport { PresetTuner } from '../isomorphic/types';\nimport { provideFormatPageResponse } from '../server/providers/format-page-response';\nimport { provideElementToString } from '../server/providers/element-to-string';\nimport { provideAxiosMiddleware } from './providers/axios-middleware';\nimport { provideAxiosLogHandler } from './providers/axios-log-handler';\nimport { provideHandlerMain } from './providers/handler-main';\nimport { provideSpecificParams } from './providers/specific-params';\nimport { providePageHelmet } from '../server/providers/page-helmet';\nimport { providePageRender } from '../server/providers/page-render';\nimport { provideFetchMiddleware } from './providers/fetch-middleware';\nimport { provideFetchLogHandler } from '../server/providers/fetch-log-handler';\nimport { SpecificExtras } from '../server/utils/specific-extras';\nimport { provideAcceptType } from './providers/accepts-type';\nimport { provideResponseEvents } from './providers/response-events';\nimport { provideAxiosFactory } from '../isomorphic/providers/axios-factory';\n\n/**\n * Возвращает preset с зависимостями по умолчанию для работы в рамках ответа на http-запрос.\n * @param customize Получит функцию с помощью которой можно переопределить предустановленные провайдеры.\n * @todo Возможно стоит переименовать в PresetPageHandler.\n * @return Preset.\n */\nexport function PresetHandler(customize?: PresetTuner): Preset {\n // ВАЖНО: используем .set() вместо аргумента defaults функции createPreset из-за скорости\n const preset = createPreset();\n\n // fetch\n preset.set(KnownToken.Http.fetch, provideFetch);\n preset.set(KnownToken.Http.Fetch.middleware, provideFetchMiddleware);\n preset.set(KnownToken.Http.Fetch.abortController, provideAbortController);\n preset.set(KnownToken.Http.Fetch.Middleware.Log.handler, provideFetchLogHandler);\n\n // saga\n preset.set(KnownToken.Redux.Middleware.saga, provideReduxMiddlewareSaga);\n\n // axios\n preset.set(KnownToken.Axios.factory, provideAxiosFactory);\n preset.set(KnownToken.Axios.middleware, provideAxiosMiddleware);\n preset.set(KnownToken.Axios.Middleware.Log.handler, provideAxiosLogHandler);\n\n // express handler\n preset.set(KnownToken.ExpressHandler.main, provideHandlerMain);\n\n // http handler\n preset.set(KnownToken.Http.Handler.Request.acceptType, provideAcceptType);\n preset.set(KnownToken.Http.Handler.Request.specificParams, provideSpecificParams);\n preset.set(KnownToken.Http.Handler.Response.specificExtras, () => new SpecificExtras());\n preset.set(KnownToken.Http.Handler.Response.events, provideResponseEvents);\n preset.set(KnownToken.Http.Handler.Page.assets, () => ({ js: '', css: '' }));\n preset.set(KnownToken.Http.Handler.Page.helmet, providePageHelmet);\n preset.set(KnownToken.Http.Handler.Page.render, providePageRender);\n preset.set(KnownToken.Http.Handler.Page.elementToString, provideElementToString);\n preset.set(KnownToken.Http.Handler.Page.formatResponse, provideFormatPageResponse);\n\n if (customize) {\n customize({ override: preset.set.bind(preset) });\n }\n\n return preset;\n}\n"],"mappings":"AAAA,SAAiBA,YAAY,QAAQ,qBAAU;AAC/C,SAASC,UAAU,QAAQ,iBAAc;AACzC,SAASC,0BAA0B,QAAQ,kDAA+C;AAC1F,SAASC,YAAY,QAAQ,kCAA+B;AAC5D,SAASC,sBAAsB,QAAQ,6CAA0C;AAEjF,SAASC,yBAAyB,QAAQ,6CAA0C;AACpF,SAASC,sBAAsB,QAAQ,0CAAuC;AAC9E,SAASC,sBAAsB,QAAQ,iCAA8B;AACrE,SAASC,sBAAsB,QAAQ,kCAA+B;AACtE,SAASC,kBAAkB,QAAQ,6BAA0B;AAC7D,SAASC,qBAAqB,QAAQ,gCAA6B;AACnE,SAASC,iBAAiB,QAAQ,oCAAiC;AACnE,SAASC,iBAAiB,QAAQ,oCAAiC;AACnE,SAASC,sBAAsB,QAAQ,iCAA8B;AACrE,SAASC,sBAAsB,QAAQ,0CAAuC;AAC9E,SAASC,cAAc,QAAQ,oCAAiC;AAChE,SAASC,iBAAiB,QAAQ,6BAA0B;AAC5D,SAASC,qBAAqB,QAAQ,gCAA6B;AACnE,SAASC,mBAAmB,QAAQ,0CAAuC;;AAE3E;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASC,aAAaA,CAACC,SAAuB,EAAU;EAC7D;EACA,MAAMC,MAAM,GAAGrB,YAAY,CAAC,CAAC;;EAE7B;EACAqB,MAAM,CAACC,GAAG,CAACrB,UAAU,CAACsB,IAAI,CAACC,KAAK,EAAErB,YAAY,CAAC;EAC/CkB,MAAM,CAACC,GAAG,CAACrB,UAAU,CAACsB,IAAI,CAACE,KAAK,CAACC,UAAU,EAAEb,sBAAsB,CAAC;EACpEQ,MAAM,CAACC,GAAG,CAACrB,UAAU,CAACsB,IAAI,CAACE,KAAK,CAACE,eAAe,EAAEvB,sBAAsB,CAAC;EACzEiB,MAAM,CAACC,GAAG,CAACrB,UAAU,CAACsB,IAAI,CAACE,KAAK,CAACG,UAAU,CAACC,GAAG,CAACC,OAAO,EAAEhB,sBAAsB,CAAC;;EAEhF;EACAO,MAAM,CAACC,GAAG,CAACrB,UAAU,CAAC8B,KAAK,CAACH,UAAU,CAACI,IAAI,EAAE9B,0BAA0B,CAAC;;EAExE;EACAmB,MAAM,CAACC,GAAG,CAACrB,UAAU,CAACgC,KAAK,CAACC,OAAO,EAAEhB,mBAAmB,CAAC;EACzDG,MAAM,CAACC,GAAG,CAACrB,UAAU,CAACgC,KAAK,CAACP,UAAU,EAAEnB,sBAAsB,CAAC;EAC/Dc,MAAM,CAACC,GAAG,CAACrB,UAAU,CAACgC,KAAK,CAACL,UAAU,CAACC,GAAG,CAACC,OAAO,EAAEtB,sBAAsB,CAAC;;EAE3E;EACAa,MAAM,CAACC,GAAG,CAACrB,UAAU,CAACkC,cAAc,CAACC,IAAI,EAAE3B,kBAAkB,CAAC;;EAE9D;EACAY,MAAM,CAACC,GAAG,CAACrB,UAAU,CAACsB,IAAI,CAACc,OAAO,CAACC,OAAO,CAACC,UAAU,EAAEvB,iBAAiB,CAAC;EACzEK,MAAM,CAACC,GAAG,CAACrB,UAAU,CAACsB,IAAI,CAACc,OAAO,CAACC,OAAO,CAACE,cAAc,EAAE9B,qBAAqB,CAAC;EACjFW,MAAM,CAACC,GAAG,CAACrB,UAAU,CAACsB,IAAI,CAACc,OAAO,CAACI,QAAQ,CAACC,cAAc,EAAE,MAAM,IAAI3B,cAAc,CAAC,CAAC,CAAC;EACvFM,MAAM,CAACC,GAAG,CAACrB,UAAU,CAACsB,IAAI,CAACc,OAAO,CAACI,QAAQ,CAACE,MAAM,EAAE1B,qBAAqB,CAAC;EAC1EI,MAAM,CAACC,GAAG,CAACrB,UAAU,CAACsB,IAAI,CAACc,OAAO,CAACO,IAAI,CAACC,MAAM,EAAE,OAAO;IAAEC,EAAE,EAAE,EAAE;IAAEC,GAAG,EAAE;EAAG,CAAC,CAAC,CAAC;EAC5E1B,MAAM,CAACC,GAAG,CAACrB,UAAU,CAACsB,IAAI,CAACc,OAAO,CAACO,IAAI,CAACI,MAAM,EAAErC,iBAAiB,CAAC;EAClEU,MAAM,CAACC,GAAG,CAACrB,UAAU,CAACsB,IAAI,CAACc,OAAO,CAACO,IAAI,CAACK,MAAM,EAAErC,iBAAiB,CAAC;EAClES,MAAM,CAACC,GAAG,CAACrB,UAAU,CAACsB,IAAI,CAACc,OAAO,CAACO,IAAI,CAACM,eAAe,EAAE5C,sBAAsB,CAAC;EAChFe,MAAM,CAACC,GAAG,CAACrB,UAAU,CAACsB,IAAI,CAACc,OAAO,CAACO,IAAI,CAACO,cAAc,EAAE9C,yBAAyB,CAAC;EAElF,IAAIe,SAAS,EAAE;IACbA,SAAS,CAAC;MAAEgC,QAAQ,EAAE/B,MAAM,CAACC,GAAG,CAAC+B,IAAI,CAAChC,MAAM;IAAE,CAAC,CAAC;EAClD;EAEA,OAAOA,MAAM;AACf"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { KnownToken } from "../../../tokens.js";
|
|
2
2
|
import { HttpStatus } from "../../isomorphic/utils/http-status.js";
|
|
3
3
|
import { axiosTracingMiddleware } from "../../node/utils/axios-tracing-middleware.js";
|
|
4
|
-
import {
|
|
4
|
+
import { logMiddleware } from "./../../../utils/axios/index.js";
|
|
5
5
|
import { getForwardedHeaders } from "../../node/utils/get-forwarded-headers.js";
|
|
6
6
|
|
|
7
7
|
/**
|
|
@@ -14,7 +14,6 @@ export function provideAxiosMiddleware(resolve) {
|
|
|
14
14
|
const tracer = resolve(KnownToken.Tracing.tracer);
|
|
15
15
|
const context = resolve(KnownToken.ExpressHandler.context);
|
|
16
16
|
const logHandler = resolve(KnownToken.Axios.Middleware.Log.handler);
|
|
17
|
-
const cookieStore = resolve(KnownToken.Http.Fetch.cookieStore);
|
|
18
17
|
const abortController = resolve(KnownToken.Http.Fetch.abortController);
|
|
19
18
|
return [
|
|
20
19
|
// пробрасываемые заголовки по соглашению
|
|
@@ -45,6 +44,6 @@ export function provideAxiosMiddleware(resolve) {
|
|
|
45
44
|
...config,
|
|
46
45
|
signal: innerController.signal
|
|
47
46
|
});
|
|
48
|
-
}, HttpStatus.axiosMiddleware(), axiosTracingMiddleware(tracer, context.res.locals.tracing.rootContext), logMiddleware(logHandler)
|
|
47
|
+
}, HttpStatus.axiosMiddleware(), axiosTracingMiddleware(tracer, context.res.locals.tracing.rootContext), logMiddleware(logHandler)];
|
|
49
48
|
}
|
|
50
49
|
//# sourceMappingURL=axios-middleware.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"axios-middleware.js","names":["KnownToken","HttpStatus","axiosTracingMiddleware","
|
|
1
|
+
{"version":3,"file":"axios-middleware.js","names":["KnownToken","HttpStatus","axiosTracingMiddleware","logMiddleware","getForwardedHeaders","provideAxiosMiddleware","resolve","appConfig","Config","base","tracer","Tracing","context","ExpressHandler","logHandler","Axios","Middleware","Log","handler","abortController","Http","Fetch","config","next","headers","req","innerController","AbortController","signal","addEventListener","abort","once","axiosMiddleware","res","locals","tracing","rootContext"],"sources":["../../../../../src/preset/node-handler/providers/axios-middleware.ts"],"sourcesContent":["import { Middleware } from 'middleware-axios';\nimport { Resolve } from '../../../di';\nimport { KnownToken } from '../../../tokens';\nimport { HttpStatus } from '../../isomorphic/utils/http-status';\nimport { axiosTracingMiddleware } from '../../node/utils/axios-tracing-middleware';\nimport { logMiddleware } from '../../../utils/axios';\nimport { getForwardedHeaders } from '../../node/utils/get-forwarded-headers';\n\n/**\n * Провайдер фабрики http-клиентов.\n * @param resolve Функция для получения зависимости по токену.\n * @return Фабрика.\n */\nexport function provideAxiosMiddleware(resolve: Resolve): Middleware<any>[] {\n const appConfig = resolve(KnownToken.Config.base);\n const tracer = resolve(KnownToken.Tracing.tracer);\n const context = resolve(KnownToken.ExpressHandler.context);\n const logHandler = resolve(KnownToken.Axios.Middleware.Log.handler);\n const abortController = resolve(KnownToken.Http.Fetch.abortController);\n\n return [\n // пробрасываемые заголовки по соглашению\n async (config, next) => {\n await next({\n ...config,\n headers: {\n ...getForwardedHeaders(appConfig, context.req),\n\n // ВАЖНО: заголовки из конфига важнее, поэтому идут в конце\n ...config.headers,\n },\n });\n },\n\n // обрывание по сигналу из обработчика входящего запроса и по сигналу из конфига исходящего запроса\n async (config, next) => {\n const innerController = new AbortController();\n\n abortController.signal.addEventListener(\n 'abort',\n () => {\n innerController.abort();\n },\n { once: true },\n );\n\n config.signal?.addEventListener?.(\n 'abort',\n () => {\n innerController.abort();\n },\n { once: true },\n );\n\n await next({ ...config, signal: innerController.signal });\n },\n\n HttpStatus.axiosMiddleware(),\n axiosTracingMiddleware(tracer, context.res.locals.tracing.rootContext),\n logMiddleware(logHandler),\n ];\n}\n"],"mappings":"AAEA,SAASA,UAAU,QAAQ,oBAAiB;AAC5C,SAASC,UAAU,QAAQ,uCAAoC;AAC/D,SAASC,sBAAsB,QAAQ,8CAA2C;AAClF,SAASC,aAAa,QAAQ,iCAAsB;AACpD,SAASC,mBAAmB,QAAQ,2CAAwC;;AAE5E;AACA;AACA;AACA;AACA;AACA,OAAO,SAASC,sBAAsBA,CAACC,OAAgB,EAAqB;EAC1E,MAAMC,SAAS,GAAGD,OAAO,CAACN,UAAU,CAACQ,MAAM,CAACC,IAAI,CAAC;EACjD,MAAMC,MAAM,GAAGJ,OAAO,CAACN,UAAU,CAACW,OAAO,CAACD,MAAM,CAAC;EACjD,MAAME,OAAO,GAAGN,OAAO,CAACN,UAAU,CAACa,cAAc,CAACD,OAAO,CAAC;EAC1D,MAAME,UAAU,GAAGR,OAAO,CAACN,UAAU,CAACe,KAAK,CAACC,UAAU,CAACC,GAAG,CAACC,OAAO,CAAC;EACnE,MAAMC,eAAe,GAAGb,OAAO,CAACN,UAAU,CAACoB,IAAI,CAACC,KAAK,CAACF,eAAe,CAAC;EAEtE,OAAO;EACL;EACA,OAAOG,MAAM,EAAEC,IAAI,KAAK;IACtB,MAAMA,IAAI,CAAC;MACT,GAAGD,MAAM;MACTE,OAAO,EAAE;QACP,GAAGpB,mBAAmB,CAACG,SAAS,EAAEK,OAAO,CAACa,GAAG,CAAC;QAE9C;QACA,GAAGH,MAAM,CAACE;MACZ;IACF,CAAC,CAAC;EACJ,CAAC;EAED;EACA,OAAOF,MAAM,EAAEC,IAAI,KAAK;IACtB,MAAMG,eAAe,GAAG,IAAIC,eAAe,CAAC,CAAC;IAE7CR,eAAe,CAACS,MAAM,CAACC,gBAAgB,CACrC,OAAO,EACP,MAAM;MACJH,eAAe,CAACI,KAAK,CAAC,CAAC;IACzB,CAAC,EACD;MAAEC,IAAI,EAAE;IAAK,CACf,CAAC;IAEDT,MAAM,CAACM,MAAM,EAAEC,gBAAgB,GAC7B,OAAO,EACP,MAAM;MACJH,eAAe,CAACI,KAAK,CAAC,CAAC;IACzB,CAAC,EACD;MAAEC,IAAI,EAAE;IAAK,CACf,CAAC;IAED,MAAMR,IAAI,CAAC;MAAE,GAAGD,MAAM;MAAEM,MAAM,EAAEF,eAAe,CAACE;IAAO,CAAC,CAAC;EAC3D,CAAC,EAED3B,UAAU,CAAC+B,eAAe,CAAC,CAAC,EAC5B9B,sBAAsB,CAACQ,MAAM,EAAEE,OAAO,CAACqB,GAAG,CAACC,MAAM,CAACC,OAAO,CAACC,WAAW,CAAC,EACtEjC,aAAa,CAACW,UAAU,CAAC,CAC1B;AACH"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { defaultHeaders } from "./../../../http/index.js";
|
|
2
2
|
import { KnownToken } from "../../../tokens.js";
|
|
3
3
|
import { getFetchErrorLogging } from "../../isomorphic/utils/get-fetch-error-logging.js";
|
|
4
4
|
import { getFetchExtraAborting } from "../../isomorphic/utils/get-fetch-extra-aborting.js";
|
|
@@ -16,7 +16,6 @@ export function provideFetchMiddleware(resolve) {
|
|
|
16
16
|
const tracer = resolve(KnownToken.Tracing.tracer);
|
|
17
17
|
const context = resolve(KnownToken.ExpressHandler.context);
|
|
18
18
|
const logHandler = resolve(KnownToken.Http.Fetch.Middleware.Log.handler);
|
|
19
|
-
const cookieStore = resolve(KnownToken.Http.Fetch.cookieStore);
|
|
20
19
|
const abortController = resolve(KnownToken.Http.Fetch.abortController);
|
|
21
20
|
return [
|
|
22
21
|
// ВАЖНО: слой логирования ошибки ПЕРЕД остальными слоями чтобы не упустить ошибки выше
|
|
@@ -24,7 +23,7 @@ export function provideFetchMiddleware(resolve) {
|
|
|
24
23
|
// пробрасываемые заголовки по соглашению
|
|
25
24
|
defaultHeaders(getForwardedHeaders(config, context.req)),
|
|
26
25
|
// обрывание по сигналу из обработчика входящего запроса и по сигналу из конфига исходящего запроса
|
|
27
|
-
getFetchExtraAborting(abortController),
|
|
26
|
+
getFetchExtraAborting(abortController), getFetchTracing(tracer, context.res.locals.tracing.rootContext),
|
|
28
27
|
// ВАЖНО: слой логирования запроса и ответа ПОСЛЕ остальных слоев чтобы использовать актуальные данные
|
|
29
28
|
getFetchLogging(logHandler)];
|
|
30
29
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fetch-middleware.js","names":["
|
|
1
|
+
{"version":3,"file":"fetch-middleware.js","names":["defaultHeaders","KnownToken","getFetchErrorLogging","getFetchExtraAborting","getFetchLogging","getFetchTracing","getForwardedHeaders","provideFetchMiddleware","resolve","config","Config","base","tracer","Tracing","context","ExpressHandler","logHandler","Http","Fetch","Middleware","Log","handler","abortController","req","res","locals","tracing","rootContext"],"sources":["../../../../../src/preset/node-handler/providers/fetch-middleware.ts"],"sourcesContent":["import { Resolve } from '../../../di';\nimport { Middleware, defaultHeaders } from '../../../http';\nimport { KnownToken } from '../../../tokens';\nimport { getFetchErrorLogging } from '../../isomorphic/utils/get-fetch-error-logging';\nimport { getFetchExtraAborting } from '../../isomorphic/utils/get-fetch-extra-aborting';\nimport { getFetchLogging } from '../../isomorphic/utils/get-fetch-logging';\nimport { getFetchTracing } from '../../server/utils/get-fetch-tracing';\nimport { getForwardedHeaders } from '../../node/utils/get-forwarded-headers';\n\n/**\n * Провайдер промежуточных слоев для fetch.\n * @param resolve Функция для получения зависимости по токену.\n * @return Массив промежуточных слоев.\n */\nexport function provideFetchMiddleware(resolve: Resolve): Middleware[] {\n const config = resolve(KnownToken.Config.base);\n const tracer = resolve(KnownToken.Tracing.tracer);\n const context = resolve(KnownToken.ExpressHandler.context);\n const logHandler = resolve(KnownToken.Http.Fetch.Middleware.Log.handler);\n const abortController = resolve(KnownToken.Http.Fetch.abortController);\n\n return [\n // ВАЖНО: слой логирования ошибки ПЕРЕД остальными слоями чтобы не упустить ошибки выше\n getFetchErrorLogging(logHandler),\n\n // пробрасываемые заголовки по соглашению\n defaultHeaders(getForwardedHeaders(config, context.req)),\n\n // обрывание по сигналу из обработчика входящего запроса и по сигналу из конфига исходящего запроса\n getFetchExtraAborting(abortController),\n\n getFetchTracing(tracer, context.res.locals.tracing.rootContext),\n\n // ВАЖНО: слой логирования запроса и ответа ПОСЛЕ остальных слоев чтобы использовать актуальные данные\n getFetchLogging(logHandler),\n ];\n}\n"],"mappings":"AACA,SAAqBA,cAAc,QAAQ,0BAAe;AAC1D,SAASC,UAAU,QAAQ,oBAAiB;AAC5C,SAASC,oBAAoB,QAAQ,mDAAgD;AACrF,SAASC,qBAAqB,QAAQ,oDAAiD;AACvF,SAASC,eAAe,QAAQ,6CAA0C;AAC1E,SAASC,eAAe,QAAQ,yCAAsC;AACtE,SAASC,mBAAmB,QAAQ,2CAAwC;;AAE5E;AACA;AACA;AACA;AACA;AACA,OAAO,SAASC,sBAAsBA,CAACC,OAAgB,EAAgB;EACrE,MAAMC,MAAM,GAAGD,OAAO,CAACP,UAAU,CAACS,MAAM,CAACC,IAAI,CAAC;EAC9C,MAAMC,MAAM,GAAGJ,OAAO,CAACP,UAAU,CAACY,OAAO,CAACD,MAAM,CAAC;EACjD,MAAME,OAAO,GAAGN,OAAO,CAACP,UAAU,CAACc,cAAc,CAACD,OAAO,CAAC;EAC1D,MAAME,UAAU,GAAGR,OAAO,CAACP,UAAU,CAACgB,IAAI,CAACC,KAAK,CAACC,UAAU,CAACC,GAAG,CAACC,OAAO,CAAC;EACxE,MAAMC,eAAe,GAAGd,OAAO,CAACP,UAAU,CAACgB,IAAI,CAACC,KAAK,CAACI,eAAe,CAAC;EAEtE,OAAO;EACL;EACApB,oBAAoB,CAACc,UAAU,CAAC;EAEhC;EACAhB,cAAc,CAACM,mBAAmB,CAACG,MAAM,EAAEK,OAAO,CAACS,GAAG,CAAC,CAAC;EAExD;EACApB,qBAAqB,CAACmB,eAAe,CAAC,EAEtCjB,eAAe,CAACO,MAAM,EAAEE,OAAO,CAACU,GAAG,CAACC,MAAM,CAACC,OAAO,CAACC,WAAW,CAAC;EAE/D;EACAvB,eAAe,CAACY,UAAU,CAAC,CAC5B;AACH"}
|
|
@@ -14,26 +14,13 @@ export function provideHandlerMain(resolve) {
|
|
|
14
14
|
const context = resolve(KnownToken.ExpressHandler.context);
|
|
15
15
|
const render = resolve(KnownToken.Http.Handler.Page.render);
|
|
16
16
|
const assetsInit = resolve(KnownToken.Http.Handler.Page.assets);
|
|
17
|
-
const extras = resolve(KnownToken.Http.Handler.Response.specificExtras);
|
|
18
17
|
const Helmet = resolve(KnownToken.Http.Handler.Page.helmet);
|
|
19
18
|
const abortController = resolve(KnownToken.Http.Fetch.abortController);
|
|
20
19
|
const formatResponse = resolve(KnownToken.Http.Handler.Page.formatResponse);
|
|
21
20
|
const getAssets = typeof assetsInit === 'function' ? assetsInit : () => assetsInit;
|
|
22
|
-
|
|
23
|
-
// @todo https://github.com/sima-land/isomorph/issues/69
|
|
24
|
-
// const cookieStore = resolve(KnownToken.Http.Fetch.cookieStore);
|
|
25
|
-
// cookieStore.subscribe(setCookieList => {
|
|
26
|
-
// for (const setCookie of setCookieList) {
|
|
27
|
-
// const parsed = parseSetCookieHeader(setCookie);
|
|
28
|
-
|
|
29
|
-
// parsed && res.cookie(parsed.name, parsed.value, parsed.attrs);
|
|
30
|
-
// }
|
|
31
|
-
// });
|
|
32
|
-
|
|
33
21
|
return async () => {
|
|
34
22
|
try {
|
|
35
23
|
const assets = await getAssets();
|
|
36
|
-
const meta = extras.getMeta();
|
|
37
24
|
const jsx = /*#__PURE__*/React.createElement(HelmetContext.Provider, {
|
|
38
25
|
value: {
|
|
39
26
|
title: config.appName,
|
|
@@ -43,7 +30,7 @@ export function provideHandlerMain(resolve) {
|
|
|
43
30
|
const {
|
|
44
31
|
body,
|
|
45
32
|
headers
|
|
46
|
-
} = await formatResponse(jsx, assets
|
|
33
|
+
} = await formatResponse(jsx, assets);
|
|
47
34
|
headers.forEach((hValue, hName) => context.res.setHeader(hName, hValue));
|
|
48
35
|
context.res.send(body);
|
|
49
36
|
} catch (error) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"handler-main.js","names":["KnownToken","HelmetContext","formatHandlerError","provideHandlerMain","resolve","config","Config","base","logger","context","ExpressHandler","render","Http","Handler","Page","assetsInit","assets","
|
|
1
|
+
{"version":3,"file":"handler-main.js","names":["KnownToken","HelmetContext","formatHandlerError","provideHandlerMain","resolve","config","Config","base","logger","context","ExpressHandler","render","Http","Handler","Page","assetsInit","assets","Helmet","helmet","abortController","Fetch","formatResponse","getAssets","jsx","React","createElement","Provider","value","title","appName","body","headers","forEach","hValue","hName","res","setHeader","send","error","response","log","status","redirectLocation","redirect","level","abort"],"sources":["../../../../../src/preset/node-handler/providers/handler-main.tsx"],"sourcesContent":["import type { Resolve } from '../../../di';\nimport type express from 'express';\nimport { KnownToken } from '../../../tokens';\nimport { HelmetContext } from '../../server/utils/regular-helmet';\nimport { formatHandlerError } from '../../server/utils/format-handler-error';\n\n/**\n * Провайдер главной функции обработчика входящего http-запроса.\n * @param resolve Функция для получения зависимости по токену.\n * @return Главная функция.\n */\nexport function provideHandlerMain(resolve: Resolve): express.Handler {\n const config = resolve(KnownToken.Config.base);\n const logger = resolve(KnownToken.logger);\n const context = resolve(KnownToken.ExpressHandler.context);\n const render = resolve(KnownToken.Http.Handler.Page.render);\n const assetsInit = resolve(KnownToken.Http.Handler.Page.assets);\n const Helmet = resolve(KnownToken.Http.Handler.Page.helmet);\n const abortController = resolve(KnownToken.Http.Fetch.abortController);\n const formatResponse = resolve(KnownToken.Http.Handler.Page.formatResponse);\n\n const getAssets = typeof assetsInit === 'function' ? assetsInit : () => assetsInit;\n\n return async () => {\n try {\n const assets = await getAssets();\n\n const jsx = (\n <HelmetContext.Provider value={{ title: config.appName, assets }}>\n <Helmet>{await render()}</Helmet>\n </HelmetContext.Provider>\n );\n\n const { body, headers } = await formatResponse(jsx, assets);\n\n headers.forEach((hValue, hName) => context.res.setHeader(hName, hValue));\n context.res.send(body);\n } catch (error) {\n const { response, log } = formatHandlerError(error);\n\n if (response.status > 299 && response.status < 400 && response.redirectLocation) {\n context.res.redirect(response.status, response.redirectLocation);\n } else {\n context.res.status(response.status).send(response.body);\n }\n\n if (log.level && logger[log.level]) {\n logger[log.level](error);\n }\n }\n\n // ВАЖНО: прерываем исходящие в рамках обработчика http-запросы\n abortController.abort();\n };\n}\n\n// @todo а что если привести все зависимости к виду:\n// const getAppConfig = resolve.lazy(KnownToken.Config.base);\n"],"mappings":"AAEA,SAASA,UAAU,QAAQ,oBAAiB;AAC5C,SAASC,aAAa,QAAQ,sCAAmC;AACjE,SAASC,kBAAkB,QAAQ,4CAAyC;;AAE5E;AACA;AACA;AACA;AACA;AACA,OAAO,SAASC,kBAAkBA,CAACC,OAAgB,EAAmB;EACpE,MAAMC,MAAM,GAAGD,OAAO,CAACJ,UAAU,CAACM,MAAM,CAACC,IAAI,CAAC;EAC9C,MAAMC,MAAM,GAAGJ,OAAO,CAACJ,UAAU,CAACQ,MAAM,CAAC;EACzC,MAAMC,OAAO,GAAGL,OAAO,CAACJ,UAAU,CAACU,cAAc,CAACD,OAAO,CAAC;EAC1D,MAAME,MAAM,GAAGP,OAAO,CAACJ,UAAU,CAACY,IAAI,CAACC,OAAO,CAACC,IAAI,CAACH,MAAM,CAAC;EAC3D,MAAMI,UAAU,GAAGX,OAAO,CAACJ,UAAU,CAACY,IAAI,CAACC,OAAO,CAACC,IAAI,CAACE,MAAM,CAAC;EAC/D,MAAMC,MAAM,GAAGb,OAAO,CAACJ,UAAU,CAACY,IAAI,CAACC,OAAO,CAACC,IAAI,CAACI,MAAM,CAAC;EAC3D,MAAMC,eAAe,GAAGf,OAAO,CAACJ,UAAU,CAACY,IAAI,CAACQ,KAAK,CAACD,eAAe,CAAC;EACtE,MAAME,cAAc,GAAGjB,OAAO,CAACJ,UAAU,CAACY,IAAI,CAACC,OAAO,CAACC,IAAI,CAACO,cAAc,CAAC;EAE3E,MAAMC,SAAS,GAAG,OAAOP,UAAU,KAAK,UAAU,GAAGA,UAAU,GAAG,MAAMA,UAAU;EAElF,OAAO,YAAY;IACjB,IAAI;MACF,MAAMC,MAAM,GAAG,MAAMM,SAAS,CAAC,CAAC;MAEhC,MAAMC,GAAG,gBACPC,KAAA,CAAAC,aAAA,CAACxB,aAAa,CAACyB,QAAQ;QAACC,KAAK,EAAE;UAAEC,KAAK,EAAEvB,MAAM,CAACwB,OAAO;UAAEb;QAAO;MAAE,gBAC/DQ,KAAA,CAAAC,aAAA,CAACR,MAAM,QAAE,MAAMN,MAAM,CAAC,CAAU,CACV,CACzB;MAED,MAAM;QAAEmB,IAAI;QAAEC;MAAQ,CAAC,GAAG,MAAMV,cAAc,CAACE,GAAG,EAAEP,MAAM,CAAC;MAE3De,OAAO,CAACC,OAAO,CAAC,CAACC,MAAM,EAAEC,KAAK,KAAKzB,OAAO,CAAC0B,GAAG,CAACC,SAAS,CAACF,KAAK,EAAED,MAAM,CAAC,CAAC;MACxExB,OAAO,CAAC0B,GAAG,CAACE,IAAI,CAACP,IAAI,CAAC;IACxB,CAAC,CAAC,OAAOQ,KAAK,EAAE;MACd,MAAM;QAAEC,QAAQ;QAAEC;MAAI,CAAC,GAAGtC,kBAAkB,CAACoC,KAAK,CAAC;MAEnD,IAAIC,QAAQ,CAACE,MAAM,GAAG,GAAG,IAAIF,QAAQ,CAACE,MAAM,GAAG,GAAG,IAAIF,QAAQ,CAACG,gBAAgB,EAAE;QAC/EjC,OAAO,CAAC0B,GAAG,CAACQ,QAAQ,CAACJ,QAAQ,CAACE,MAAM,EAAEF,QAAQ,CAACG,gBAAgB,CAAC;MAClE,CAAC,MAAM;QACLjC,OAAO,CAAC0B,GAAG,CAACM,MAAM,CAACF,QAAQ,CAACE,MAAM,CAAC,CAACJ,IAAI,CAACE,QAAQ,CAACT,IAAI,CAAC;MACzD;MAEA,IAAIU,GAAG,CAACI,KAAK,IAAIpC,MAAM,CAACgC,GAAG,CAACI,KAAK,CAAC,EAAE;QAClCpC,MAAM,CAACgC,GAAG,CAACI,KAAK,CAAC,CAACN,KAAK,CAAC;MAC1B;IACF;;IAEA;IACAnB,eAAe,CAAC0B,KAAK,CAAC,CAAC;EACzB,CAAC;AACH;;AAEA;AACA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["PAGE_HANDLER_EVENT_TYPE","applyServerMiddleware","getClientIp","getForwardedHeaders","getHealthCheck","getPageResponseFormat","getServeErrorLogging","getServeLogging","HandlerProvider","RegularHelmet","HelmetContext","SpecificExtras"],"sources":["../../../../src/preset/server/index.ts"],"sourcesContent":["export type {
|
|
1
|
+
{"version":3,"file":"index.js","names":["PAGE_HANDLER_EVENT_TYPE","PAGE_FORMAT_PRIORITY","applyServerMiddleware","getClientIp","getForwardedHeaders","getHealthCheck","getPageResponseFormat","getServeErrorLogging","getServeLogging","HandlerProvider","RegularHelmet","HelmetContext","SpecificExtras"],"sources":["../../../../src/preset/server/index.ts"],"sourcesContent":["export type {\n ServerHandler,\n ServerMiddleware,\n ServerHandlerContext,\n PageResponseFormatter,\n PageResponseFormatResult,\n} from './types';\nexport { PAGE_HANDLER_EVENT_TYPE, PAGE_FORMAT_PRIORITY } from './constants';\n\n// доступные утилиты\nexport { applyServerMiddleware } from './utils/apply-server-middleware';\nexport { getClientIp } from './utils/get-client-ip';\nexport { getForwardedHeaders } from './utils/get-forwarded-headers';\nexport { getHealthCheck } from './utils/get-health-check';\nexport { getPageResponseFormat } from './utils/get-page-response-format';\nexport { getServeErrorLogging } from './utils/get-serve-error-logging';\nexport { getServeLogging } from './utils/get-serve-logging';\nexport { HandlerProvider } from './utils/handler-provider';\nexport { RegularHelmet, HelmetContext } from './utils/regular-helmet';\nexport { SpecificExtras } from './utils/specific-extras';\n"],"mappings":"AAOA,SAASA,uBAAuB,EAAEC,oBAAoB,QAAQ,gBAAa;;AAE3E;AACA,SAASC,qBAAqB,QAAQ,oCAAiC;AACvE,SAASC,WAAW,QAAQ,0BAAuB;AACnD,SAASC,mBAAmB,QAAQ,kCAA+B;AACnE,SAASC,cAAc,QAAQ,6BAA0B;AACzD,SAASC,qBAAqB,QAAQ,qCAAkC;AACxE,SAASC,oBAAoB,QAAQ,oCAAiC;AACtE,SAASC,eAAe,QAAQ,8BAA2B;AAC3D,SAASC,eAAe,QAAQ,6BAA0B;AAC1D,SAASC,aAAa,EAAEC,aAAa,QAAQ,2BAAwB;AACrE,SAASC,cAAc,QAAQ,4BAAyB"}
|
|
@@ -11,7 +11,9 @@ export function provideFormatPageResponse(resolve) {
|
|
|
11
11
|
const config = resolve(KnownToken.Config.base);
|
|
12
12
|
const acceptType = resolve(KnownToken.Http.Handler.Request.acceptType);
|
|
13
13
|
const elementToString = resolve(KnownToken.Http.Handler.Page.elementToString);
|
|
14
|
-
|
|
14
|
+
const extras = resolve(KnownToken.Http.Handler.Response.specificExtras);
|
|
15
|
+
return async (jsx, assets) => {
|
|
16
|
+
const meta = extras.getMeta();
|
|
15
17
|
const headers = new Headers();
|
|
16
18
|
let body;
|
|
17
19
|
switch (acceptType(PAGE_FORMAT_PRIORITY)) {
|
|
@@ -46,6 +48,7 @@ export function provideFormatPageResponse(resolve) {
|
|
|
46
48
|
|
|
47
49
|
// ВАЖНО: DOCTYPE обязательно нужен так как влияет на то как браузер будет парсить html/css
|
|
48
50
|
// ВАЖНО: DOCTYPE нужен только когда отдаем полноценную страницу
|
|
51
|
+
// @todo переделать на проверку параметра ?html-doctype=false
|
|
49
52
|
if (config.env === 'development') {
|
|
50
53
|
body = `<!DOCTYPE html>${await elementToString(jsx)}`;
|
|
51
54
|
} else {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"format-page-response.js","names":["KnownToken","PAGE_FORMAT_PRIORITY","provideFormatPageResponse","resolve","config","Config","base","acceptType","Http","Handler","Request","elementToString","Page","jsx","assets","meta","headers","Headers","body","set","JSON","stringify","markup","bundle_js","js","bundle_css","css","critical_js","criticalJs","critical_css","criticalCss","env"],"sources":["../../../../../src/preset/server/providers/format-page-response.ts"],"sourcesContent":["import type { Resolve } from '../../../di';\nimport type { ConventionalJson } from '../../isomorphic';\nimport type { PageResponseFormatter } from '../types';\nimport { KnownToken } from '../../../tokens';\nimport { PAGE_FORMAT_PRIORITY } from '../constants';\n\n/**\n * Провайдер функции форматирования ответа.\n * Функция форматирования вернёт данные ответа на запрос страницы в нужном формате в зависимости от заголовка Accept.\n * @param resolve Резолвер.\n * @return Функция форматирования.\n */\nexport function provideFormatPageResponse(resolve: Resolve): PageResponseFormatter {\n const config = resolve(KnownToken.Config.base);\n const acceptType = resolve(KnownToken.Http.Handler.Request.acceptType);\n const elementToString = resolve(KnownToken.Http.Handler.Page.elementToString);\n\n return async (jsx, assets
|
|
1
|
+
{"version":3,"file":"format-page-response.js","names":["KnownToken","PAGE_FORMAT_PRIORITY","provideFormatPageResponse","resolve","config","Config","base","acceptType","Http","Handler","Request","elementToString","Page","extras","Response","specificExtras","jsx","assets","meta","getMeta","headers","Headers","body","set","JSON","stringify","markup","bundle_js","js","bundle_css","css","critical_js","criticalJs","critical_css","criticalCss","env"],"sources":["../../../../../src/preset/server/providers/format-page-response.ts"],"sourcesContent":["import type { Resolve } from '../../../di';\nimport type { ConventionalJson } from '../../isomorphic';\nimport type { PageResponseFormatter } from '../types';\nimport { KnownToken } from '../../../tokens';\nimport { PAGE_FORMAT_PRIORITY } from '../constants';\n\n/**\n * Провайдер функции форматирования ответа.\n * Функция форматирования вернёт данные ответа на запрос страницы в нужном формате в зависимости от заголовка Accept.\n * @param resolve Резолвер.\n * @return Функция форматирования.\n */\nexport function provideFormatPageResponse(resolve: Resolve): PageResponseFormatter {\n const config = resolve(KnownToken.Config.base);\n const acceptType = resolve(KnownToken.Http.Handler.Request.acceptType);\n const elementToString = resolve(KnownToken.Http.Handler.Page.elementToString);\n const extras = resolve(KnownToken.Http.Handler.Response.specificExtras);\n\n return async (jsx, assets) => {\n const meta = extras.getMeta();\n const headers = new Headers();\n\n let body: string;\n\n switch (acceptType(PAGE_FORMAT_PRIORITY)) {\n case 'json': {\n headers.set('content-type', 'application/json');\n\n body = JSON.stringify({\n markup: await elementToString(jsx),\n bundle_js: assets.js,\n bundle_css: assets.css,\n critical_js: assets.criticalJs,\n critical_css: assets.criticalCss,\n meta,\n } satisfies ConventionalJson);\n\n break;\n }\n\n case 'html':\n default: {\n headers.set('content-type', 'text/html');\n headers.set('simaland-bundle-js', assets.js);\n headers.set('simaland-bundle-css', assets.css);\n\n if (assets.criticalJs) {\n headers.set('simaland-critical-js', assets.criticalJs);\n }\n\n if (assets.criticalCss) {\n headers.set('simaland-critical-css', assets.criticalCss);\n }\n\n if (meta) {\n headers.set('simaland-meta', JSON.stringify(meta));\n }\n\n // ВАЖНО: DOCTYPE обязательно нужен так как влияет на то как браузер будет парсить html/css\n // ВАЖНО: DOCTYPE нужен только когда отдаем полноценную страницу\n // @todo переделать на проверку параметра ?html-doctype=false\n if (config.env === 'development') {\n body = `<!DOCTYPE html>${await elementToString(jsx)}`;\n } else {\n body = await elementToString(jsx);\n }\n\n break;\n }\n }\n\n return { body, headers };\n };\n}\n"],"mappings":"AAGA,SAASA,UAAU,QAAQ,oBAAiB;AAC5C,SAASC,oBAAoB,QAAQ,iBAAc;;AAEnD;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASC,yBAAyBA,CAACC,OAAgB,EAAyB;EACjF,MAAMC,MAAM,GAAGD,OAAO,CAACH,UAAU,CAACK,MAAM,CAACC,IAAI,CAAC;EAC9C,MAAMC,UAAU,GAAGJ,OAAO,CAACH,UAAU,CAACQ,IAAI,CAACC,OAAO,CAACC,OAAO,CAACH,UAAU,CAAC;EACtE,MAAMI,eAAe,GAAGR,OAAO,CAACH,UAAU,CAACQ,IAAI,CAACC,OAAO,CAACG,IAAI,CAACD,eAAe,CAAC;EAC7E,MAAME,MAAM,GAAGV,OAAO,CAACH,UAAU,CAACQ,IAAI,CAACC,OAAO,CAACK,QAAQ,CAACC,cAAc,CAAC;EAEvE,OAAO,OAAOC,GAAG,EAAEC,MAAM,KAAK;IAC5B,MAAMC,IAAI,GAAGL,MAAM,CAACM,OAAO,CAAC,CAAC;IAC7B,MAAMC,OAAO,GAAG,IAAIC,OAAO,CAAC,CAAC;IAE7B,IAAIC,IAAY;IAEhB,QAAQf,UAAU,CAACN,oBAAoB,CAAC;MACtC,KAAK,MAAM;QAAE;UACXmB,OAAO,CAACG,GAAG,CAAC,cAAc,EAAE,kBAAkB,CAAC;UAE/CD,IAAI,GAAGE,IAAI,CAACC,SAAS,CAAC;YACpBC,MAAM,EAAE,MAAMf,eAAe,CAACK,GAAG,CAAC;YAClCW,SAAS,EAAEV,MAAM,CAACW,EAAE;YACpBC,UAAU,EAAEZ,MAAM,CAACa,GAAG;YACtBC,WAAW,EAAEd,MAAM,CAACe,UAAU;YAC9BC,YAAY,EAAEhB,MAAM,CAACiB,WAAW;YAChChB;UACF,CAA4B,CAAC;UAE7B;QACF;MAEA,KAAK,MAAM;MACX;QAAS;UACPE,OAAO,CAACG,GAAG,CAAC,cAAc,EAAE,WAAW,CAAC;UACxCH,OAAO,CAACG,GAAG,CAAC,oBAAoB,EAAEN,MAAM,CAACW,EAAE,CAAC;UAC5CR,OAAO,CAACG,GAAG,CAAC,qBAAqB,EAAEN,MAAM,CAACa,GAAG,CAAC;UAE9C,IAAIb,MAAM,CAACe,UAAU,EAAE;YACrBZ,OAAO,CAACG,GAAG,CAAC,sBAAsB,EAAEN,MAAM,CAACe,UAAU,CAAC;UACxD;UAEA,IAAIf,MAAM,CAACiB,WAAW,EAAE;YACtBd,OAAO,CAACG,GAAG,CAAC,uBAAuB,EAAEN,MAAM,CAACiB,WAAW,CAAC;UAC1D;UAEA,IAAIhB,IAAI,EAAE;YACRE,OAAO,CAACG,GAAG,CAAC,eAAe,EAAEC,IAAI,CAACC,SAAS,CAACP,IAAI,CAAC,CAAC;UACpD;;UAEA;UACA;UACA;UACA,IAAId,MAAM,CAAC+B,GAAG,KAAK,aAAa,EAAE;YAChCb,IAAI,GAAI,kBAAiB,MAAMX,eAAe,CAACK,GAAG,CAAE,EAAC;UACvD,CAAC,MAAM;YACLM,IAAI,GAAG,MAAMX,eAAe,CAACK,GAAG,CAAC;UACnC;UAEA;QACF;IACF;IAEA,OAAO;MAAEM,IAAI;MAAEF;IAAQ,CAAC;EAC1B,CAAC;AACH"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","names":[],"sources":["../../../../src/preset/server/types.ts"],"sourcesContent":["import type { PageAssets } from '../isomorphic';\n\n/**\n * На сервере между промежуточными слоями надо обмениваться данными поэтому появился такой интерфейс.\n * Возможно в будущем он перейдет в `@krutoo/fetch-tools`.\n */\nexport interface ServerHandlerContext {\n events: EventTarget;\n}\n\nexport interface ServerHandler {\n (request: Request, context: ServerHandlerContext): Response | Promise<Response>;\n}\n\nexport interface ServerEnhancer {\n (request: ServerHandler): ServerHandler;\n}\n\nexport interface ServerMiddleware {\n (\n request: Request,\n next: (req: Request, ctx?: ServerHandlerContext) => Response | Promise<Response>,\n context: ServerHandlerContext,\n ): Response | Promise<Response>;\n}\n\nexport interface PageResponseFormatResult {\n body: string;\n headers: Headers;\n}\n\nexport interface PageResponseFormatter {\n (\n jsx: JSX.Element,\n assets: PageAssets,\n
|
|
1
|
+
{"version":3,"file":"types.js","names":[],"sources":["../../../../src/preset/server/types.ts"],"sourcesContent":["import type { PageAssets } from '../isomorphic';\n\n/**\n * На сервере между промежуточными слоями надо обмениваться данными поэтому появился такой интерфейс.\n * Возможно в будущем он перейдет в `@krutoo/fetch-tools`.\n */\nexport interface ServerHandlerContext {\n events: EventTarget;\n}\n\nexport interface ServerHandler {\n (request: Request, context: ServerHandlerContext): Response | Promise<Response>;\n}\n\nexport interface ServerEnhancer {\n (request: ServerHandler): ServerHandler;\n}\n\nexport interface ServerMiddleware {\n (\n request: Request,\n next: (req: Request, ctx?: ServerHandlerContext) => Response | Promise<Response>,\n context: ServerHandlerContext,\n ): Response | Promise<Response>;\n}\n\nexport interface PageResponseFormatResult {\n body: string;\n headers: Headers;\n}\n\nexport interface PageResponseFormatter {\n (\n jsx: JSX.Element,\n assets: PageAssets,\n ): PageResponseFormatResult | Promise<PageResponseFormatResult>;\n}\n\nexport interface RenderToString {\n (jsx: JSX.Element): string | Promise<string>;\n}\n"],"mappings":""}
|
|
@@ -18,6 +18,12 @@ export function getForwardedHeaders(config, request) {
|
|
|
18
18
|
result.set('X-Client-Ip', clientIp);
|
|
19
19
|
}
|
|
20
20
|
|
|
21
|
+
// cookie
|
|
22
|
+
const cookie = request.headers.get('cookie');
|
|
23
|
+
if (cookie) {
|
|
24
|
+
result.set('cookie', cookie);
|
|
25
|
+
}
|
|
26
|
+
|
|
21
27
|
// service headers
|
|
22
28
|
request.headers.forEach((headerValue, headerName) => {
|
|
23
29
|
if (headerName.toLowerCase().startsWith('simaland-') && headerName.toLowerCase() !== 'simaland-params') {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-forwarded-headers.js","names":["getClientIp","getForwardedHeaders","config","request","result","Headers","set","appName","appVersion","clientIp","headers","forEach","headerValue","headerName","toLowerCase","startsWith"],"sources":["../../../../../src/preset/server/utils/get-forwarded-headers.ts"],"sourcesContent":["import type { BaseConfig } from '../../../config';\nimport { getClientIp } from './get-client-ip';\n\n/**\n * Вернет заголовки, которые должны содержаться в исходящих http-запросах при обработке входящего http-запроса.\n * @param config Конфигурация.\n * @param request Входящий запрос.\n * @return Заголовки.\n */\nexport function getForwardedHeaders(config: BaseConfig, request: Request): Headers {\n const result = new Headers();\n\n // user agent\n result.set('User-Agent', `simaland-${config.appName}/${config.appVersion}`);\n\n // client ip\n const clientIp = getClientIp(request);\n
|
|
1
|
+
{"version":3,"file":"get-forwarded-headers.js","names":["getClientIp","getForwardedHeaders","config","request","result","Headers","set","appName","appVersion","clientIp","cookie","headers","get","forEach","headerValue","headerName","toLowerCase","startsWith"],"sources":["../../../../../src/preset/server/utils/get-forwarded-headers.ts"],"sourcesContent":["import type { BaseConfig } from '../../../config';\nimport { getClientIp } from './get-client-ip';\n\n/**\n * Вернет заголовки, которые должны содержаться в исходящих http-запросах при обработке входящего http-запроса.\n * @param config Конфигурация.\n * @param request Входящий запрос.\n * @return Заголовки.\n */\nexport function getForwardedHeaders(config: BaseConfig, request: Request): Headers {\n const result = new Headers();\n\n // user agent\n result.set('User-Agent', `simaland-${config.appName}/${config.appVersion}`);\n\n // client ip\n const clientIp = getClientIp(request);\n if (clientIp) {\n result.set('X-Client-Ip', clientIp);\n }\n\n // cookie\n const cookie = request.headers.get('cookie');\n if (cookie) {\n result.set('cookie', cookie);\n }\n\n // service headers\n request.headers.forEach((headerValue, headerName) => {\n if (\n headerName.toLowerCase().startsWith('simaland-') &&\n headerName.toLowerCase() !== 'simaland-params'\n ) {\n result.set(headerName, headerValue);\n }\n });\n\n return result;\n}\n"],"mappings":"AACA,SAASA,WAAW,QAAQ,oBAAiB;;AAE7C;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASC,mBAAmBA,CAACC,MAAkB,EAAEC,OAAgB,EAAW;EACjF,MAAMC,MAAM,GAAG,IAAIC,OAAO,CAAC,CAAC;;EAE5B;EACAD,MAAM,CAACE,GAAG,CAAC,YAAY,EAAG,YAAWJ,MAAM,CAACK,OAAQ,IAAGL,MAAM,CAACM,UAAW,EAAC,CAAC;;EAE3E;EACA,MAAMC,QAAQ,GAAGT,WAAW,CAACG,OAAO,CAAC;EACrC,IAAIM,QAAQ,EAAE;IACZL,MAAM,CAACE,GAAG,CAAC,aAAa,EAAEG,QAAQ,CAAC;EACrC;;EAEA;EACA,MAAMC,MAAM,GAAGP,OAAO,CAACQ,OAAO,CAACC,GAAG,CAAC,QAAQ,CAAC;EAC5C,IAAIF,MAAM,EAAE;IACVN,MAAM,CAACE,GAAG,CAAC,QAAQ,EAAEI,MAAM,CAAC;EAC9B;;EAEA;EACAP,OAAO,CAACQ,OAAO,CAACE,OAAO,CAAC,CAACC,WAAW,EAAEC,UAAU,KAAK;IACnD,IACEA,UAAU,CAACC,WAAW,CAAC,CAAC,CAACC,UAAU,CAAC,WAAW,CAAC,IAChDF,UAAU,CAACC,WAAW,CAAC,CAAC,KAAK,iBAAiB,EAC9C;MACAZ,MAAM,CAACE,GAAG,CAACS,UAAU,EAAED,WAAW,CAAC;IACrC;EACF,CAAC,CAAC;EAEF,OAAOV,MAAM;AACf"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { LogLevel } from '../log';
|
|
1
|
+
import type { LogLevel } from '../log';
|
|
2
2
|
export type { Handler, Enhancer, Middleware, CookieStore } from '@krutoo/fetch-tools';
|
|
3
3
|
export type { LogData, DoneLogData, FailLogData, LogHandler, LogHandlerFactory, } from '@krutoo/fetch-tools/middleware';
|
|
4
4
|
export type URLSearchParamsInit = Record<string, string | number | boolean | undefined | null>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/http/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/http/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAEvC,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAEtF,YAAY,EACV,OAAO,EACP,WAAW,EACX,WAAW,EACX,UAAU,EACV,iBAAiB,GAClB,MAAM,gCAAgC,CAAC;AAExC,MAAM,MAAM,mBAAmB,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,SAAS,GAAG,IAAI,CAAC,CAAC;AAE/F,MAAM,WAAW,YAAY,CAAC,CAAC,GAAG,OAAO;IACvC,EAAE,EAAE,IAAI,CAAC;IACT,IAAI,EAAE,CAAC,CAAC;IACR,KAAK,EAAE,IAAI,CAAC;IACZ,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,YAAY,CAAC,CAAC,GAAG,OAAO;IACvC,EAAE,EAAE,KAAK,CAAC;IACV,IAAI,CAAC,EAAE,CAAC,CAAC;IACT,KAAK,EAAE,OAAO,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,MAAM,cAAc,CAAC,CAAC,IAAI,YAAY,CAAC,CAAC,CAAC,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;AAElE,MAAM,WAAW,iBAAiB;IAChC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,EAAE,QAAQ,GAAG,IAAI,CAAC;CAC5B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/preset/bun-handler/index.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/preset/bun-handler/index.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAgB5C;;;;;GAKG;AACH,wBAAgB,gBAAgB,CAAC,SAAS,CAAC,EAAE,WAAW,6BA6BvD"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fetch-middleware.d.ts","sourceRoot":"","sources":["../../../../../src/preset/bun-handler/providers/fetch-middleware.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAEtC,OAAO,EAAE,UAAU,
|
|
1
|
+
{"version":3,"file":"fetch-middleware.d.ts","sourceRoot":"","sources":["../../../../../src/preset/bun-handler/providers/fetch-middleware.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAEtC,OAAO,EAAE,UAAU,EAAkB,MAAM,eAAe,CAAC;AAM3D,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,OAAO,GAAG,UAAU,EAAE,CAoBrE"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"handler-main.d.ts","sourceRoot":"","sources":["../../../../../src/preset/bun-handler/providers/handler-main.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAMtC,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,OAAO,
|
|
1
|
+
{"version":3,"file":"handler-main.d.ts","sourceRoot":"","sources":["../../../../../src/preset/bun-handler/providers/handler-main.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAMtC,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,OAAO,0DA0DlD"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"axios-middleware.d.ts","sourceRoot":"","sources":["../../../../../src/preset/node-handler/providers/axios-middleware.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAOtC;;;;GAIG;AACH,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,OAAO,GAAG,UAAU,CAAC,GAAG,CAAC,EAAE,
|
|
1
|
+
{"version":3,"file":"axios-middleware.d.ts","sourceRoot":"","sources":["../../../../../src/preset/node-handler/providers/axios-middleware.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAOtC;;;;GAIG;AACH,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,OAAO,GAAG,UAAU,CAAC,GAAG,CAAC,EAAE,CAgD1E"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fetch-middleware.d.ts","sourceRoot":"","sources":["../../../../../src/preset/node-handler/providers/fetch-middleware.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AACtC,OAAO,EAAE,UAAU,
|
|
1
|
+
{"version":3,"file":"fetch-middleware.d.ts","sourceRoot":"","sources":["../../../../../src/preset/node-handler/providers/fetch-middleware.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AACtC,OAAO,EAAE,UAAU,EAAkB,MAAM,eAAe,CAAC;AAQ3D;;;;GAIG;AACH,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,OAAO,GAAG,UAAU,EAAE,CAsBrE"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"handler-main.d.ts","sourceRoot":"","sources":["../../../../../src/preset/node-handler/providers/handler-main.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,KAAK,OAAO,MAAM,SAAS,CAAC;AAKnC;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,
|
|
1
|
+
{"version":3,"file":"handler-main.d.ts","sourceRoot":"","sources":["../../../../../src/preset/node-handler/providers/handler-main.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,KAAK,OAAO,MAAM,SAAS,CAAC;AAKnC;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CA2CpE"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
export type { ServerHandler, ServerMiddleware, ServerHandlerContext } from './types';
|
|
2
|
-
export { PAGE_HANDLER_EVENT_TYPE } from './constants';
|
|
1
|
+
export type { ServerHandler, ServerMiddleware, ServerHandlerContext, PageResponseFormatter, PageResponseFormatResult, } from './types';
|
|
2
|
+
export { PAGE_HANDLER_EVENT_TYPE, PAGE_FORMAT_PRIORITY } from './constants';
|
|
3
3
|
export { applyServerMiddleware } from './utils/apply-server-middleware';
|
|
4
4
|
export { getClientIp } from './utils/get-client-ip';
|
|
5
5
|
export { getForwardedHeaders } from './utils/get-forwarded-headers';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/preset/server/index.ts"],"names":[],"mappings":"AAAA,YAAY,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/preset/server/index.ts"],"names":[],"mappings":"AAAA,YAAY,EACV,aAAa,EACb,gBAAgB,EAChB,oBAAoB,EACpB,qBAAqB,EACrB,wBAAwB,GACzB,MAAM,SAAS,CAAC;AACjB,OAAO,EAAE,uBAAuB,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AAG5E,OAAO,EAAE,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;AACxE,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AACpE,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,qBAAqB,EAAE,MAAM,kCAAkC,CAAC;AACzE,OAAO,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AACvE,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACtE,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC"}
|