@analogjs/router 1.9.2-beta.2 → 1.9.2-beta.4
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/fesm2022/analogjs-router-server-actions.mjs.map +1 -1
- package/fesm2022/analogjs-router-server.mjs.map +1 -1
- package/fesm2022/analogjs-router-tokens.mjs.map +1 -1
- package/fesm2022/analogjs-router.mjs.map +1 -1
- package/package.json +4 -12
- package/tokens/index.d.ts +0 -1
- package/esm2022/analogjs-router.mjs +0 -5
- package/esm2022/index.mjs +0 -8
- package/esm2022/lib/constants.mjs +0 -3
- package/esm2022/lib/cookie-interceptor.mjs +0 -19
- package/esm2022/lib/define-route.mjs +0 -51
- package/esm2022/lib/endpoints.mjs +0 -6
- package/esm2022/lib/get-load-resolver.mjs +0 -10
- package/esm2022/lib/inject-load.mjs +0 -9
- package/esm2022/lib/inject-route-endpoint-url.mjs +0 -23
- package/esm2022/lib/markdown-helpers.mjs +0 -36
- package/esm2022/lib/meta-tags.mjs +0 -50
- package/esm2022/lib/models.mjs +0 -2
- package/esm2022/lib/provide-file-router.mjs +0 -47
- package/esm2022/lib/request-context.mjs +0 -121
- package/esm2022/lib/route-config.mjs +0 -47
- package/esm2022/lib/route-types.mjs +0 -2
- package/esm2022/lib/routes.mjs +0 -176
- package/esm2022/server/actions/actions.mjs +0 -33
- package/esm2022/server/actions/analogjs-router-server-actions.mjs +0 -5
- package/esm2022/server/actions/index.mjs +0 -2
- package/esm2022/server/analogjs-router-server.mjs +0 -5
- package/esm2022/server/index.mjs +0 -2
- package/esm2022/server/provide-server-context.mjs +0 -32
- package/esm2022/tokens/analogjs-router-tokens.mjs +0 -5
- package/esm2022/tokens/index.mjs +0 -18
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
import { ENVIRONMENT_INITIALIZER, makeEnvironmentProviders, } from '@angular/core';
|
|
2
|
-
import { provideRouter, ROUTES } from '@angular/router';
|
|
3
|
-
import { API_PREFIX } from '@analogjs/router/tokens';
|
|
4
|
-
import { ɵHTTP_ROOT_INTERCEPTOR_FNS as HTTP_ROOT_INTERCEPTOR_FNS } from '@angular/common/http';
|
|
5
|
-
import { routes } from './routes';
|
|
6
|
-
import { updateMetaTagsOnRouteChange } from './meta-tags';
|
|
7
|
-
import { cookieInterceptor } from './cookie-interceptor';
|
|
8
|
-
/**
|
|
9
|
-
* Sets up providers for the Angular router, and registers
|
|
10
|
-
* file-based routes. Additional features can be provided
|
|
11
|
-
* to further configure the behavior of the router.
|
|
12
|
-
*
|
|
13
|
-
* @param features
|
|
14
|
-
* @returns Providers and features to configure the router with routes
|
|
15
|
-
*/
|
|
16
|
-
export function provideFileRouter(...features) {
|
|
17
|
-
return makeEnvironmentProviders([
|
|
18
|
-
provideRouter(routes, ...features),
|
|
19
|
-
{
|
|
20
|
-
provide: ENVIRONMENT_INITIALIZER,
|
|
21
|
-
multi: true,
|
|
22
|
-
useValue: () => updateMetaTagsOnRouteChange(),
|
|
23
|
-
},
|
|
24
|
-
{
|
|
25
|
-
provide: HTTP_ROOT_INTERCEPTOR_FNS,
|
|
26
|
-
multi: true,
|
|
27
|
-
useValue: cookieInterceptor,
|
|
28
|
-
},
|
|
29
|
-
{
|
|
30
|
-
provide: API_PREFIX,
|
|
31
|
-
useFactory() {
|
|
32
|
-
return typeof ANALOG_API_PREFIX !== 'undefined'
|
|
33
|
-
? ANALOG_API_PREFIX
|
|
34
|
-
: 'api';
|
|
35
|
-
},
|
|
36
|
-
},
|
|
37
|
-
]);
|
|
38
|
-
}
|
|
39
|
-
export function withExtraRoutes(routes) {
|
|
40
|
-
return [
|
|
41
|
-
{
|
|
42
|
-
ɵkind: 100,
|
|
43
|
-
ɵproviders: [{ provide: ROUTES, useValue: routes }],
|
|
44
|
-
},
|
|
45
|
-
];
|
|
46
|
-
}
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZS1maWxlLXJvdXRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3JvdXRlci9zcmMvbGliL3Byb3ZpZGUtZmlsZS1yb3V0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUV2Qix3QkFBd0IsR0FDekIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGFBQWEsRUFBa0IsTUFBTSxFQUFVLE1BQU0saUJBQWlCLENBQUM7QUFDaEYsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3JELE9BQU8sRUFBRSwwQkFBMEIsSUFBSSx5QkFBeUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRS9GLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDbEMsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQzFELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBSXpEOzs7Ozs7O0dBT0c7QUFDSCxNQUFNLFVBQVUsaUJBQWlCLENBQy9CLEdBQUcsUUFBMEI7SUFFN0IsT0FBTyx3QkFBd0IsQ0FBQztRQUM5QixhQUFhLENBQUMsTUFBTSxFQUFFLEdBQUcsUUFBUSxDQUFDO1FBQ2xDO1lBQ0UsT0FBTyxFQUFFLHVCQUF1QjtZQUNoQyxLQUFLLEVBQUUsSUFBSTtZQUNYLFFBQVEsRUFBRSxHQUFHLEVBQUUsQ0FBQywyQkFBMkIsRUFBRTtTQUM5QztRQUNEO1lBQ0UsT0FBTyxFQUFFLHlCQUF5QjtZQUNsQyxLQUFLLEVBQUUsSUFBSTtZQUNYLFFBQVEsRUFBRSxpQkFBaUI7U0FDNUI7UUFDRDtZQUNFLE9BQU8sRUFBRSxVQUFVO1lBQ25CLFVBQVU7Z0JBQ1IsT0FBTyxPQUFPLGlCQUFpQixLQUFLLFdBQVc7b0JBQzdDLENBQUMsQ0FBQyxpQkFBaUI7b0JBQ25CLENBQUMsQ0FBQyxLQUFLLENBQUM7WUFDWixDQUFDO1NBQ0Y7S0FDRixDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQsTUFBTSxVQUFVLGVBQWUsQ0FBQyxNQUFjO0lBQzVDLE9BQU87UUFDTDtZQUNFLEtBQUssRUFBRSxHQUFVO1lBQ2pCLFVBQVUsRUFBRSxDQUFDLEVBQUUsT0FBTyxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLENBQUM7U0FDcEQ7S0FDRixDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEVOVklST05NRU5UX0lOSVRJQUxJWkVSLFxuICBFbnZpcm9ubWVudFByb3ZpZGVycyxcbiAgbWFrZUVudmlyb25tZW50UHJvdmlkZXJzLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHByb3ZpZGVSb3V0ZXIsIFJvdXRlckZlYXR1cmVzLCBST1VURVMsIFJvdXRlcyB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQgeyBBUElfUFJFRklYIH0gZnJvbSAnQGFuYWxvZ2pzL3JvdXRlci90b2tlbnMnO1xuaW1wb3J0IHsgybVIVFRQX1JPT1RfSU5URVJDRVBUT1JfRk5TIGFzIEhUVFBfUk9PVF9JTlRFUkNFUFRPUl9GTlMgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5cbmltcG9ydCB7IHJvdXRlcyB9IGZyb20gJy4vcm91dGVzJztcbmltcG9ydCB7IHVwZGF0ZU1ldGFUYWdzT25Sb3V0ZUNoYW5nZSB9IGZyb20gJy4vbWV0YS10YWdzJztcbmltcG9ydCB7IGNvb2tpZUludGVyY2VwdG9yIH0gZnJvbSAnLi9jb29raWUtaW50ZXJjZXB0b3InO1xuXG5kZWNsYXJlIGNvbnN0IEFOQUxPR19BUElfUFJFRklYOiBzdHJpbmc7XG5cbi8qKlxuICogU2V0cyB1cCBwcm92aWRlcnMgZm9yIHRoZSBBbmd1bGFyIHJvdXRlciwgYW5kIHJlZ2lzdGVyc1xuICogZmlsZS1iYXNlZCByb3V0ZXMuIEFkZGl0aW9uYWwgZmVhdHVyZXMgY2FuIGJlIHByb3ZpZGVkXG4gKiB0byBmdXJ0aGVyIGNvbmZpZ3VyZSB0aGUgYmVoYXZpb3Igb2YgdGhlIHJvdXRlci5cbiAqXG4gKiBAcGFyYW0gZmVhdHVyZXNcbiAqIEByZXR1cm5zIFByb3ZpZGVycyBhbmQgZmVhdHVyZXMgdG8gY29uZmlndXJlIHRoZSByb3V0ZXIgd2l0aCByb3V0ZXNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHByb3ZpZGVGaWxlUm91dGVyKFxuICAuLi5mZWF0dXJlczogUm91dGVyRmVhdHVyZXNbXVxuKTogRW52aXJvbm1lbnRQcm92aWRlcnMge1xuICByZXR1cm4gbWFrZUVudmlyb25tZW50UHJvdmlkZXJzKFtcbiAgICBwcm92aWRlUm91dGVyKHJvdXRlcywgLi4uZmVhdHVyZXMpLFxuICAgIHtcbiAgICAgIHByb3ZpZGU6IEVOVklST05NRU5UX0lOSVRJQUxJWkVSLFxuICAgICAgbXVsdGk6IHRydWUsXG4gICAgICB1c2VWYWx1ZTogKCkgPT4gdXBkYXRlTWV0YVRhZ3NPblJvdXRlQ2hhbmdlKCksXG4gICAgfSxcbiAgICB7XG4gICAgICBwcm92aWRlOiBIVFRQX1JPT1RfSU5URVJDRVBUT1JfRk5TLFxuICAgICAgbXVsdGk6IHRydWUsXG4gICAgICB1c2VWYWx1ZTogY29va2llSW50ZXJjZXB0b3IsXG4gICAgfSxcbiAgICB7XG4gICAgICBwcm92aWRlOiBBUElfUFJFRklYLFxuICAgICAgdXNlRmFjdG9yeSgpIHtcbiAgICAgICAgcmV0dXJuIHR5cGVvZiBBTkFMT0dfQVBJX1BSRUZJWCAhPT0gJ3VuZGVmaW5lZCdcbiAgICAgICAgICA/IEFOQUxPR19BUElfUFJFRklYXG4gICAgICAgICAgOiAnYXBpJztcbiAgICAgIH0sXG4gICAgfSxcbiAgXSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB3aXRoRXh0cmFSb3V0ZXMocm91dGVzOiBSb3V0ZXMpOiBSb3V0ZXJGZWF0dXJlc1tdIHtcbiAgcmV0dXJuIFtcbiAgICB7XG4gICAgICDJtWtpbmQ6IDEwMCBhcyBhbnksXG4gICAgICDJtXByb3ZpZGVyczogW3sgcHJvdmlkZTogUk9VVEVTLCB1c2VWYWx1ZTogcm91dGVzIH1dLFxuICAgIH0sXG4gIF07XG59XG4iXX0=
|
|
@@ -1,121 +0,0 @@
|
|
|
1
|
-
import { TransferState, inject, makeStateKey } from '@angular/core';
|
|
2
|
-
import { HttpHeaders, HttpResponse, } from '@angular/common/http';
|
|
3
|
-
import { from, of } from 'rxjs';
|
|
4
|
-
import { injectBaseURL, injectAPIPrefix } from '@analogjs/router/tokens';
|
|
5
|
-
/**
|
|
6
|
-
* Interceptor that is server-aware when making HttpClient requests.
|
|
7
|
-
* Server-side requests use the full URL
|
|
8
|
-
* Prerendering uses the internal Nitro $fetch function, along with state transfer
|
|
9
|
-
* Client-side requests use the window.location.origin
|
|
10
|
-
*
|
|
11
|
-
* @param req HttpRequest<unknown>
|
|
12
|
-
* @param next HttpHandlerFn
|
|
13
|
-
* @returns
|
|
14
|
-
*/
|
|
15
|
-
export function requestContextInterceptor(req, next) {
|
|
16
|
-
const apiPrefix = injectAPIPrefix();
|
|
17
|
-
const baseUrl = injectBaseURL();
|
|
18
|
-
const transferState = inject(TransferState);
|
|
19
|
-
// during prerendering with Nitro
|
|
20
|
-
if (typeof global !== 'undefined' &&
|
|
21
|
-
global.$fetch &&
|
|
22
|
-
baseUrl &&
|
|
23
|
-
(req.url.startsWith('/') || req.url.startsWith(baseUrl))) {
|
|
24
|
-
const requestUrl = new URL(req.url, baseUrl);
|
|
25
|
-
const cacheKey = makeCacheKey(req, new URL(requestUrl).pathname);
|
|
26
|
-
const storeKey = makeStateKey(`analog_${cacheKey}`);
|
|
27
|
-
const fetchUrl = req.url.includes(`/${apiPrefix}/`)
|
|
28
|
-
? requestUrl.pathname
|
|
29
|
-
: requestUrl.href;
|
|
30
|
-
const responseType = req.responseType === 'arraybuffer' ? 'arrayBuffer' : req.responseType;
|
|
31
|
-
return from(global.$fetch
|
|
32
|
-
.raw(fetchUrl, {
|
|
33
|
-
method: req.method,
|
|
34
|
-
params: requestUrl.searchParams,
|
|
35
|
-
responseType,
|
|
36
|
-
headers: req.headers.keys().reduce((hdrs, current) => {
|
|
37
|
-
return {
|
|
38
|
-
...hdrs,
|
|
39
|
-
[current]: req.headers.get(current),
|
|
40
|
-
};
|
|
41
|
-
}, {}),
|
|
42
|
-
})
|
|
43
|
-
.then((res) => {
|
|
44
|
-
const cacheResponse = {
|
|
45
|
-
body: res._data,
|
|
46
|
-
headers: new HttpHeaders(res.headers),
|
|
47
|
-
status: 200,
|
|
48
|
-
statusText: 'OK',
|
|
49
|
-
url: fetchUrl,
|
|
50
|
-
};
|
|
51
|
-
const transferResponse = new HttpResponse(cacheResponse);
|
|
52
|
-
transferState.set(storeKey, cacheResponse);
|
|
53
|
-
return transferResponse;
|
|
54
|
-
}));
|
|
55
|
-
}
|
|
56
|
-
// on the client
|
|
57
|
-
if (!import.meta.env.SSR &&
|
|
58
|
-
(req.url.startsWith('/') || req.url.includes('/_analog/'))) {
|
|
59
|
-
// /_analog/ requests are full URLs
|
|
60
|
-
const requestUrl = req.url.includes('/_analog/')
|
|
61
|
-
? req.url
|
|
62
|
-
: `${window.location.origin}${req.url}`;
|
|
63
|
-
const cacheKey = makeCacheKey(req, new URL(requestUrl).pathname);
|
|
64
|
-
const storeKey = makeStateKey(`analog_${cacheKey}`);
|
|
65
|
-
const cacheRestoreResponse = transferState.get(storeKey, null);
|
|
66
|
-
if (cacheRestoreResponse) {
|
|
67
|
-
transferState.remove(storeKey);
|
|
68
|
-
return of(new HttpResponse(cacheRestoreResponse));
|
|
69
|
-
}
|
|
70
|
-
return next(req.clone({
|
|
71
|
-
url: requestUrl,
|
|
72
|
-
}));
|
|
73
|
-
}
|
|
74
|
-
// on the server
|
|
75
|
-
if (baseUrl && (req.url.startsWith('/') || req.url.startsWith(baseUrl))) {
|
|
76
|
-
const requestUrl = req.url.startsWith(baseUrl) && !req.url.startsWith('/')
|
|
77
|
-
? req.url
|
|
78
|
-
: `${baseUrl}${req.url}`;
|
|
79
|
-
return next(req.clone({
|
|
80
|
-
url: requestUrl,
|
|
81
|
-
}));
|
|
82
|
-
}
|
|
83
|
-
return next(req);
|
|
84
|
-
}
|
|
85
|
-
function sortAndConcatParams(params) {
|
|
86
|
-
return [...params.keys()]
|
|
87
|
-
.sort()
|
|
88
|
-
.map((k) => `${k}=${params.getAll(k)}`)
|
|
89
|
-
.join('&');
|
|
90
|
-
}
|
|
91
|
-
function makeCacheKey(request, mappedRequestUrl) {
|
|
92
|
-
// make the params encoded same as a url so it's easy to identify
|
|
93
|
-
const { params, method, responseType } = request;
|
|
94
|
-
const encodedParams = sortAndConcatParams(params);
|
|
95
|
-
let serializedBody = request.serializeBody();
|
|
96
|
-
if (serializedBody instanceof URLSearchParams) {
|
|
97
|
-
serializedBody = sortAndConcatParams(serializedBody);
|
|
98
|
-
}
|
|
99
|
-
else if (typeof serializedBody !== 'string') {
|
|
100
|
-
serializedBody = '';
|
|
101
|
-
}
|
|
102
|
-
const key = [
|
|
103
|
-
method,
|
|
104
|
-
responseType,
|
|
105
|
-
mappedRequestUrl,
|
|
106
|
-
serializedBody,
|
|
107
|
-
encodedParams,
|
|
108
|
-
].join('|');
|
|
109
|
-
const hash = generateHash(key);
|
|
110
|
-
return makeStateKey(hash);
|
|
111
|
-
}
|
|
112
|
-
function generateHash(str) {
|
|
113
|
-
let hash = 0;
|
|
114
|
-
for (let i = 0, len = str.length; i < len; i++) {
|
|
115
|
-
let chr = str.charCodeAt(i);
|
|
116
|
-
hash = (hash << 5) - hash + chr;
|
|
117
|
-
hash |= 0; // Convert to 32bit integer
|
|
118
|
-
}
|
|
119
|
-
return `${hash}`;
|
|
120
|
-
}
|
|
121
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"request-context.js","sourceRoot":"","sources":["../../../../../packages/router/src/lib/request-context.ts"],"names":[],"mappings":"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","sourcesContent":["import { StateKey, TransferState, inject, makeStateKey } from '@angular/core';\nimport {\n  HttpHandlerFn,\n  HttpHeaders,\n  HttpParams,\n  HttpRequest,\n  HttpResponse,\n} from '@angular/common/http';\n\nimport { from, of } from 'rxjs';\n\nimport { injectBaseURL, injectAPIPrefix } from '@analogjs/router/tokens';\n\n/**\n * Interceptor that is server-aware when making HttpClient requests.\n * Server-side requests use the full URL\n * Prerendering uses the internal Nitro $fetch function, along with state transfer\n * Client-side requests use the window.location.origin\n *\n * @param req HttpRequest<unknown>\n * @param next HttpHandlerFn\n * @returns\n */\nexport function requestContextInterceptor(\n  req: HttpRequest<unknown>,\n  next: HttpHandlerFn\n) {\n  const apiPrefix = injectAPIPrefix();\n  const baseUrl = injectBaseURL();\n  const transferState = inject(TransferState);\n\n  // during prerendering with Nitro\n  if (\n    typeof global !== 'undefined' &&\n    global.$fetch &&\n    baseUrl &&\n    (req.url.startsWith('/') || req.url.startsWith(baseUrl))\n  ) {\n    const requestUrl = new URL(req.url, baseUrl);\n    const cacheKey = makeCacheKey(req, new URL(requestUrl).pathname);\n    const storeKey = makeStateKey<unknown>(`analog_${cacheKey}`);\n    const fetchUrl = req.url.includes(`/${apiPrefix}/`)\n      ? requestUrl.pathname\n      : requestUrl.href;\n    const responseType =\n      req.responseType === 'arraybuffer' ? 'arrayBuffer' : req.responseType;\n\n    return from(\n      global.$fetch\n        .raw(fetchUrl, {\n          method: req.method as any,\n          params: requestUrl.searchParams,\n          responseType,\n          headers: req.headers.keys().reduce((hdrs, current) => {\n            return {\n              ...hdrs,\n              [current]: req.headers.get(current),\n            };\n          }, {}),\n        })\n        .then((res) => {\n          const cacheResponse = {\n            body: res._data,\n            headers: new HttpHeaders(res.headers),\n            status: 200,\n            statusText: 'OK',\n            url: fetchUrl,\n          };\n          const transferResponse = new HttpResponse(cacheResponse);\n\n          transferState.set(storeKey, cacheResponse);\n          return transferResponse;\n        })\n    );\n  }\n\n  // on the client\n  if (\n    !import.meta.env.SSR &&\n    (req.url.startsWith('/') || req.url.includes('/_analog/'))\n  ) {\n    // /_analog/ requests are full URLs\n    const requestUrl = req.url.includes('/_analog/')\n      ? req.url\n      : `${window.location.origin}${req.url}`;\n    const cacheKey = makeCacheKey(req, new URL(requestUrl).pathname);\n    const storeKey = makeStateKey<unknown>(`analog_${cacheKey}`);\n    const cacheRestoreResponse = transferState.get(storeKey, null);\n\n    if (cacheRestoreResponse) {\n      transferState.remove(storeKey);\n      return of(new HttpResponse(cacheRestoreResponse));\n    }\n\n    return next(\n      req.clone({\n        url: requestUrl,\n      })\n    );\n  }\n\n  // on the server\n  if (baseUrl && (req.url.startsWith('/') || req.url.startsWith(baseUrl))) {\n    const requestUrl =\n      req.url.startsWith(baseUrl) && !req.url.startsWith('/')\n        ? req.url\n        : `${baseUrl}${req.url}`;\n\n    return next(\n      req.clone({\n        url: requestUrl,\n      })\n    );\n  }\n\n  return next(req);\n}\n\nfunction sortAndConcatParams(params: HttpParams | URLSearchParams): string {\n  return [...params.keys()]\n    .sort()\n    .map((k) => `${k}=${params.getAll(k)}`)\n    .join('&');\n}\n\nfunction makeCacheKey(\n  request: HttpRequest<any>,\n  mappedRequestUrl: string\n): StateKey<unknown> {\n  // make the params encoded same as a url so it's easy to identify\n  const { params, method, responseType } = request;\n  const encodedParams = sortAndConcatParams(params);\n\n  let serializedBody = request.serializeBody();\n  if (serializedBody instanceof URLSearchParams) {\n    serializedBody = sortAndConcatParams(serializedBody);\n  } else if (typeof serializedBody !== 'string') {\n    serializedBody = '';\n  }\n\n  const key = [\n    method,\n    responseType,\n    mappedRequestUrl,\n    serializedBody,\n    encodedParams,\n  ].join('|');\n\n  const hash = generateHash(key);\n\n  return makeStateKey(hash);\n}\n\nfunction generateHash(str: string) {\n  let hash = 0;\n  for (let i = 0, len = str.length; i < len; i++) {\n    let chr = str.charCodeAt(i);\n    hash = (hash << 5) - hash + chr;\n    hash |= 0; // Convert to 32bit integer\n  }\n  return `${hash}`;\n}\n"]}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
import { inject } from '@angular/core';
|
|
2
|
-
import { HttpClient } from '@angular/common/http';
|
|
3
|
-
import { firstValueFrom } from 'rxjs';
|
|
4
|
-
import { ROUTE_META_TAGS_KEY } from './meta-tags';
|
|
5
|
-
import { ANALOG_PAGE_ENDPOINTS, ANALOG_META_KEY } from './endpoints';
|
|
6
|
-
import { injectRouteEndpointURL } from './inject-route-endpoint-url';
|
|
7
|
-
export function toRouteConfig(routeMeta) {
|
|
8
|
-
if (routeMeta && isRedirectRouteMeta(routeMeta)) {
|
|
9
|
-
return routeMeta;
|
|
10
|
-
}
|
|
11
|
-
let { meta, ...routeConfig } = routeMeta ?? {};
|
|
12
|
-
if (Array.isArray(meta)) {
|
|
13
|
-
routeConfig.data = { ...routeConfig.data, [ROUTE_META_TAGS_KEY]: meta };
|
|
14
|
-
}
|
|
15
|
-
else if (typeof meta === 'function') {
|
|
16
|
-
routeConfig.resolve = {
|
|
17
|
-
...routeConfig.resolve,
|
|
18
|
-
[ROUTE_META_TAGS_KEY]: meta,
|
|
19
|
-
};
|
|
20
|
-
}
|
|
21
|
-
if (!routeConfig) {
|
|
22
|
-
routeConfig = {};
|
|
23
|
-
}
|
|
24
|
-
routeConfig.runGuardsAndResolvers =
|
|
25
|
-
routeConfig.runGuardsAndResolvers ?? 'paramsOrQueryParamsChange';
|
|
26
|
-
routeConfig.resolve = {
|
|
27
|
-
...routeConfig.resolve,
|
|
28
|
-
load: async (route) => {
|
|
29
|
-
const routeConfig = route.routeConfig;
|
|
30
|
-
if (ANALOG_PAGE_ENDPOINTS[routeConfig[ANALOG_META_KEY].endpointKey]) {
|
|
31
|
-
const http = inject(HttpClient);
|
|
32
|
-
const url = injectRouteEndpointURL(route);
|
|
33
|
-
if (!!import.meta.env['VITE_ANALOG_PUBLIC_BASE_URL'] &&
|
|
34
|
-
globalThis.$fetch) {
|
|
35
|
-
return globalThis.$fetch(url.pathname);
|
|
36
|
-
}
|
|
37
|
-
return firstValueFrom(http.get(`${url.href}`));
|
|
38
|
-
}
|
|
39
|
-
return {};
|
|
40
|
-
},
|
|
41
|
-
};
|
|
42
|
-
return routeConfig;
|
|
43
|
-
}
|
|
44
|
-
function isRedirectRouteMeta(routeMeta) {
|
|
45
|
-
return !!routeMeta.redirectTo;
|
|
46
|
-
}
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGUtY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvcm91dGVyL3NyYy9saWIvcm91dGUtY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRWxELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFHdEMsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxlQUFlLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDckUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFFckUsTUFBTSxVQUFVLGFBQWEsQ0FBQyxTQUFnQztJQUM1RCxJQUFJLFNBQVMsSUFBSSxtQkFBbUIsQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDO1FBQ2hELE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUM7SUFFRCxJQUFJLEVBQUUsSUFBSSxFQUFFLEdBQUcsV0FBVyxFQUFFLEdBQUcsU0FBUyxJQUFJLEVBQUUsQ0FBQztJQUUvQyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQztRQUN4QixXQUFXLENBQUMsSUFBSSxHQUFHLEVBQUUsR0FBRyxXQUFXLENBQUMsSUFBSSxFQUFFLENBQUMsbUJBQW1CLENBQUMsRUFBRSxJQUFJLEVBQUUsQ0FBQztJQUMxRSxDQUFDO1NBQU0sSUFBSSxPQUFPLElBQUksS0FBSyxVQUFVLEVBQUUsQ0FBQztRQUN0QyxXQUFXLENBQUMsT0FBTyxHQUFHO1lBQ3BCLEdBQUcsV0FBVyxDQUFDLE9BQU87WUFDdEIsQ0FBQyxtQkFBbUIsQ0FBQyxFQUFFLElBQUk7U0FDNUIsQ0FBQztJQUNKLENBQUM7SUFFRCxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDakIsV0FBVyxHQUFHLEVBQUUsQ0FBQztJQUNuQixDQUFDO0lBRUQsV0FBVyxDQUFDLHFCQUFxQjtRQUMvQixXQUFXLENBQUMscUJBQXFCLElBQUksMkJBQTJCLENBQUM7SUFDbkUsV0FBVyxDQUFDLE9BQU8sR0FBRztRQUNwQixHQUFHLFdBQVcsQ0FBQyxPQUFPO1FBQ3RCLElBQUksRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEVBQUU7WUFDcEIsTUFBTSxXQUFXLEdBQUcsS0FBSyxDQUFDLFdBRXpCLENBQUM7WUFFRixJQUFJLHFCQUFxQixDQUFDLFdBQVcsQ0FBQyxlQUFlLENBQUMsQ0FBQyxXQUFXLENBQUMsRUFBRSxDQUFDO2dCQUNwRSxNQUFNLElBQUksR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7Z0JBQ2hDLE1BQU0sR0FBRyxHQUFHLHNCQUFzQixDQUFDLEtBQUssQ0FBQyxDQUFDO2dCQUUxQyxJQUNFLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyw2QkFBNkIsQ0FBQztvQkFDL0MsVUFBa0IsQ0FBQyxNQUFNLEVBQzFCLENBQUM7b0JBQ0QsT0FBUSxVQUFrQixDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLENBQUM7Z0JBQ2xELENBQUM7Z0JBRUQsT0FBTyxjQUFjLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7WUFDakQsQ0FBQztZQUVELE9BQU8sRUFBRSxDQUFDO1FBQ1osQ0FBQztLQUNGLENBQUM7SUFFRixPQUFPLFdBQVcsQ0FBQztBQUNyQixDQUFDO0FBRUQsU0FBUyxtQkFBbUIsQ0FDMUIsU0FBb0I7SUFFcEIsT0FBTyxDQUFDLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQztBQUNoQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHR5cGUgeyBSb3V0ZSB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQgeyBmaXJzdFZhbHVlRnJvbSB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBSZWRpcmVjdFJvdXRlTWV0YSwgUm91dGVDb25maWcsIFJvdXRlTWV0YSB9IGZyb20gJy4vbW9kZWxzJztcbmltcG9ydCB7IFJPVVRFX01FVEFfVEFHU19LRVkgfSBmcm9tICcuL21ldGEtdGFncyc7XG5pbXBvcnQgeyBBTkFMT0dfUEFHRV9FTkRQT0lOVFMsIEFOQUxPR19NRVRBX0tFWSB9IGZyb20gJy4vZW5kcG9pbnRzJztcbmltcG9ydCB7IGluamVjdFJvdXRlRW5kcG9pbnRVUkwgfSBmcm9tICcuL2luamVjdC1yb3V0ZS1lbmRwb2ludC11cmwnO1xuXG5leHBvcnQgZnVuY3Rpb24gdG9Sb3V0ZUNvbmZpZyhyb3V0ZU1ldGE6IFJvdXRlTWV0YSB8IHVuZGVmaW5lZCk6IFJvdXRlQ29uZmlnIHtcbiAgaWYgKHJvdXRlTWV0YSAmJiBpc1JlZGlyZWN0Um91dGVNZXRhKHJvdXRlTWV0YSkpIHtcbiAgICByZXR1cm4gcm91dGVNZXRhO1xuICB9XG5cbiAgbGV0IHsgbWV0YSwgLi4ucm91dGVDb25maWcgfSA9IHJvdXRlTWV0YSA/PyB7fTtcblxuICBpZiAoQXJyYXkuaXNBcnJheShtZXRhKSkge1xuICAgIHJvdXRlQ29uZmlnLmRhdGEgPSB7IC4uLnJvdXRlQ29uZmlnLmRhdGEsIFtST1VURV9NRVRBX1RBR1NfS0VZXTogbWV0YSB9O1xuICB9IGVsc2UgaWYgKHR5cGVvZiBtZXRhID09PSAnZnVuY3Rpb24nKSB7XG4gICAgcm91dGVDb25maWcucmVzb2x2ZSA9IHtcbiAgICAgIC4uLnJvdXRlQ29uZmlnLnJlc29sdmUsXG4gICAgICBbUk9VVEVfTUVUQV9UQUdTX0tFWV06IG1ldGEsXG4gICAgfTtcbiAgfVxuXG4gIGlmICghcm91dGVDb25maWcpIHtcbiAgICByb3V0ZUNvbmZpZyA9IHt9O1xuICB9XG5cbiAgcm91dGVDb25maWcucnVuR3VhcmRzQW5kUmVzb2x2ZXJzID1cbiAgICByb3V0ZUNvbmZpZy5ydW5HdWFyZHNBbmRSZXNvbHZlcnMgPz8gJ3BhcmFtc09yUXVlcnlQYXJhbXNDaGFuZ2UnO1xuICByb3V0ZUNvbmZpZy5yZXNvbHZlID0ge1xuICAgIC4uLnJvdXRlQ29uZmlnLnJlc29sdmUsXG4gICAgbG9hZDogYXN5bmMgKHJvdXRlKSA9PiB7XG4gICAgICBjb25zdCByb3V0ZUNvbmZpZyA9IHJvdXRlLnJvdXRlQ29uZmlnIGFzIFJvdXRlICYge1xuICAgICAgICBbQU5BTE9HX01FVEFfS0VZXTogeyBlbmRwb2ludDogc3RyaW5nOyBlbmRwb2ludEtleTogc3RyaW5nIH07XG4gICAgICB9O1xuXG4gICAgICBpZiAoQU5BTE9HX1BBR0VfRU5EUE9JTlRTW3JvdXRlQ29uZmlnW0FOQUxPR19NRVRBX0tFWV0uZW5kcG9pbnRLZXldKSB7XG4gICAgICAgIGNvbnN0IGh0dHAgPSBpbmplY3QoSHR0cENsaWVudCk7XG4gICAgICAgIGNvbnN0IHVybCA9IGluamVjdFJvdXRlRW5kcG9pbnRVUkwocm91dGUpO1xuXG4gICAgICAgIGlmIChcbiAgICAgICAgICAhIWltcG9ydC5tZXRhLmVudlsnVklURV9BTkFMT0dfUFVCTElDX0JBU0VfVVJMJ10gJiZcbiAgICAgICAgICAoZ2xvYmFsVGhpcyBhcyBhbnkpLiRmZXRjaFxuICAgICAgICApIHtcbiAgICAgICAgICByZXR1cm4gKGdsb2JhbFRoaXMgYXMgYW55KS4kZmV0Y2godXJsLnBhdGhuYW1lKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBmaXJzdFZhbHVlRnJvbShodHRwLmdldChgJHt1cmwuaHJlZn1gKSk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB7fTtcbiAgICB9LFxuICB9O1xuXG4gIHJldHVybiByb3V0ZUNvbmZpZztcbn1cblxuZnVuY3Rpb24gaXNSZWRpcmVjdFJvdXRlTWV0YShcbiAgcm91dGVNZXRhOiBSb3V0ZU1ldGFcbik6IHJvdXRlTWV0YSBpcyBSZWRpcmVjdFJvdXRlTWV0YSB7XG4gIHJldHVybiAhIXJvdXRlTWV0YS5yZWRpcmVjdFRvO1xufVxuIl19
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGUtdHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9yb3V0ZXIvc3JjL2xpYi9yb3V0ZS10eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBIM0V2ZW50LCBIM0V2ZW50Q29udGV4dCB9IGZyb20gJ2gzJztcbmltcG9ydCB0eXBlIHsgJEZldGNoIH0gZnJvbSAnbml0cm9wYWNrJztcblxuZXhwb3J0IHR5cGUgUGFnZVNlcnZlckxvYWQgPSB7XG4gIHBhcmFtczogSDNFdmVudENvbnRleHRbJ3BhcmFtcyddO1xuICByZXE6IEgzRXZlbnRbJ25vZGUnXVsncmVxJ107XG4gIHJlczogSDNFdmVudFsnbm9kZSddWydyZXMnXTtcbiAgZmV0Y2g6ICRGZXRjaDtcbiAgZXZlbnQ6IEgzRXZlbnQ7XG59O1xuXG5leHBvcnQgdHlwZSBMb2FkUmVzdWx0PFxuICBBIGV4dGVuZHMgKHBhZ2VTZXJ2ZXJMb2FkOiBQYWdlU2VydmVyTG9hZCkgPT4gUHJvbWlzZTxhbnk+XG4+ID0gQXdhaXRlZDxSZXR1cm5UeXBlPEE+PjtcbiJdfQ==
|
package/esm2022/lib/routes.mjs
DELETED
|
@@ -1,176 +0,0 @@
|
|
|
1
|
-
/// <reference types="vite/client" />
|
|
2
|
-
import { toRouteConfig } from './route-config';
|
|
3
|
-
import { toMarkdownModule } from './markdown-helpers';
|
|
4
|
-
import { ENDPOINT_EXTENSION } from './constants';
|
|
5
|
-
import { ANALOG_META_KEY } from './endpoints';
|
|
6
|
-
/**
|
|
7
|
-
* This variable reference is replaced with a glob of all page routes.
|
|
8
|
-
*/
|
|
9
|
-
let ANALOG_ROUTE_FILES = {};
|
|
10
|
-
/**
|
|
11
|
-
* This variable reference is replaced with a glob of all content routes.
|
|
12
|
-
*/
|
|
13
|
-
let ANALOG_CONTENT_ROUTE_FILES = {};
|
|
14
|
-
/**
|
|
15
|
-
* A function used to parse list of files and create configuration of routes.
|
|
16
|
-
*
|
|
17
|
-
* @param files
|
|
18
|
-
* @returns Array of routes
|
|
19
|
-
*/
|
|
20
|
-
export function createRoutes(files) {
|
|
21
|
-
const filenames = Object.keys(files);
|
|
22
|
-
if (filenames.length === 0) {
|
|
23
|
-
return [];
|
|
24
|
-
}
|
|
25
|
-
// map filenames to raw routes and group them by level
|
|
26
|
-
const rawRoutesByLevelMap = filenames.reduce((acc, filename) => {
|
|
27
|
-
const rawPath = toRawPath(filename);
|
|
28
|
-
const rawSegments = rawPath.split('/');
|
|
29
|
-
// nesting level starts at 0
|
|
30
|
-
// rawPath: /products => level: 0
|
|
31
|
-
// rawPath: /products/:id => level: 1
|
|
32
|
-
const level = rawSegments.length - 1;
|
|
33
|
-
const rawSegment = rawSegments[level];
|
|
34
|
-
const ancestorRawSegments = rawSegments.slice(0, level);
|
|
35
|
-
return {
|
|
36
|
-
...acc,
|
|
37
|
-
[level]: {
|
|
38
|
-
...acc[level],
|
|
39
|
-
[rawPath]: {
|
|
40
|
-
filename,
|
|
41
|
-
rawSegment,
|
|
42
|
-
ancestorRawSegments,
|
|
43
|
-
segment: toSegment(rawSegment),
|
|
44
|
-
level,
|
|
45
|
-
children: [],
|
|
46
|
-
},
|
|
47
|
-
},
|
|
48
|
-
};
|
|
49
|
-
}, {});
|
|
50
|
-
const allLevels = Object.keys(rawRoutesByLevelMap).map(Number);
|
|
51
|
-
const maxLevel = Math.max(...allLevels);
|
|
52
|
-
// add each raw route to its parent's children array
|
|
53
|
-
for (let level = maxLevel; level > 0; level--) {
|
|
54
|
-
const rawRoutesMap = rawRoutesByLevelMap[level];
|
|
55
|
-
const rawPaths = Object.keys(rawRoutesMap);
|
|
56
|
-
for (const rawPath of rawPaths) {
|
|
57
|
-
const rawRoute = rawRoutesMap[rawPath];
|
|
58
|
-
const parentRawPath = rawRoute.ancestorRawSegments.join('/');
|
|
59
|
-
const parentRawSegmentIndex = rawRoute.ancestorRawSegments.length - 1;
|
|
60
|
-
const parentRawSegment = rawRoute.ancestorRawSegments[parentRawSegmentIndex];
|
|
61
|
-
// create the parent level and/or raw route if it does not exist
|
|
62
|
-
// parent route won't exist for nested routes that don't have a layout route
|
|
63
|
-
rawRoutesByLevelMap[level - 1] ||= {};
|
|
64
|
-
rawRoutesByLevelMap[level - 1][parentRawPath] ||= {
|
|
65
|
-
filename: null,
|
|
66
|
-
rawSegment: parentRawSegment,
|
|
67
|
-
ancestorRawSegments: rawRoute.ancestorRawSegments.slice(0, parentRawSegmentIndex),
|
|
68
|
-
segment: toSegment(parentRawSegment),
|
|
69
|
-
level: level - 1,
|
|
70
|
-
children: [],
|
|
71
|
-
};
|
|
72
|
-
rawRoutesByLevelMap[level - 1][parentRawPath].children.push(rawRoute);
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
// only take raw routes from the root level
|
|
76
|
-
// since they already contain nested routes as their children
|
|
77
|
-
const rootRawRoutesMap = rawRoutesByLevelMap[0];
|
|
78
|
-
const rawRoutes = Object.keys(rootRawRoutesMap).map((segment) => rootRawRoutesMap[segment]);
|
|
79
|
-
sortRawRoutes(rawRoutes);
|
|
80
|
-
return toRoutes(rawRoutes, files);
|
|
81
|
-
}
|
|
82
|
-
function toRawPath(filename) {
|
|
83
|
-
return filename
|
|
84
|
-
.replace(
|
|
85
|
-
// convert to relative path and remove file extension
|
|
86
|
-
/^(?:[a-zA-Z]:[\\/])?(.*?)[\\/](?:routes|pages)[\\/]|(?:[\\/](?:app[\\/](?:routes|pages)[\\/]))|(\.page\.(js|ts|analog|ag)$)|(\.(ts|md|analog|ag)$)/g, '')
|
|
87
|
-
.replace(/\[\.{3}.+\]/, '**') // [...not-found] => **
|
|
88
|
-
.replace(/\[([^\]]+)\]/g, ':$1'); // [id] => :id
|
|
89
|
-
}
|
|
90
|
-
function toSegment(rawSegment) {
|
|
91
|
-
return rawSegment
|
|
92
|
-
.replace(/index|\(.*?\)/g, '') // replace named empty segments
|
|
93
|
-
.replace(/\.|\/+/g, '/') // replace dots with slashes and remove redundant slashes
|
|
94
|
-
.replace(/^\/+|\/+$/g, ''); // remove trailing slashes
|
|
95
|
-
}
|
|
96
|
-
function toRoutes(rawRoutes, files) {
|
|
97
|
-
const routes = [];
|
|
98
|
-
for (const rawRoute of rawRoutes) {
|
|
99
|
-
const children = rawRoute.children.length > 0
|
|
100
|
-
? toRoutes(rawRoute.children, files)
|
|
101
|
-
: undefined;
|
|
102
|
-
let module = undefined;
|
|
103
|
-
let analogMeta = undefined;
|
|
104
|
-
if (rawRoute.filename) {
|
|
105
|
-
const isMarkdownFile = rawRoute.filename.endsWith('.md');
|
|
106
|
-
module = isMarkdownFile
|
|
107
|
-
? toMarkdownModule(files[rawRoute.filename])
|
|
108
|
-
: files[rawRoute.filename];
|
|
109
|
-
const endpointKey = rawRoute.filename.replace(/\.page\.(ts|analog|ag)$/, ENDPOINT_EXTENSION);
|
|
110
|
-
// get endpoint path
|
|
111
|
-
const rawEndpoint = rawRoute.filename
|
|
112
|
-
.replace(/\.page\.(ts|analog|ag)$/, '')
|
|
113
|
-
.replace(/\[\.{3}.+\]/, '**') // [...not-found] => **
|
|
114
|
-
.replace(/^(.*?)\/pages/, '/pages');
|
|
115
|
-
// replace periods, remove (index) paths
|
|
116
|
-
const endpoint = (rawEndpoint || '')
|
|
117
|
-
.replace(/\./g, '/')
|
|
118
|
-
.replace(/\/\((.*?)\)$/, '/-$1-');
|
|
119
|
-
analogMeta = {
|
|
120
|
-
endpoint,
|
|
121
|
-
endpointKey,
|
|
122
|
-
};
|
|
123
|
-
}
|
|
124
|
-
const route = module
|
|
125
|
-
? {
|
|
126
|
-
path: rawRoute.segment,
|
|
127
|
-
loadChildren: () => module().then((m) => {
|
|
128
|
-
if (!import.meta.env.PROD) {
|
|
129
|
-
const hasModuleDefault = !!m.default;
|
|
130
|
-
const hasRedirect = !!m.routeMeta?.redirectTo;
|
|
131
|
-
if (!hasModuleDefault && !hasRedirect) {
|
|
132
|
-
console.warn(`[Analog] Missing default export at ${rawRoute.filename}`);
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
return [
|
|
136
|
-
{
|
|
137
|
-
path: '',
|
|
138
|
-
component: m.default,
|
|
139
|
-
...toRouteConfig(m.routeMeta),
|
|
140
|
-
children,
|
|
141
|
-
[ANALOG_META_KEY]: analogMeta,
|
|
142
|
-
},
|
|
143
|
-
];
|
|
144
|
-
}),
|
|
145
|
-
}
|
|
146
|
-
: { path: rawRoute.segment, children };
|
|
147
|
-
routes.push(route);
|
|
148
|
-
}
|
|
149
|
-
return routes;
|
|
150
|
-
}
|
|
151
|
-
function sortRawRoutes(rawRoutes) {
|
|
152
|
-
rawRoutes.sort((a, b) => {
|
|
153
|
-
let segmentA = deprioritizeSegment(a.segment);
|
|
154
|
-
let segmentB = deprioritizeSegment(b.segment);
|
|
155
|
-
// prioritize routes with fewer children
|
|
156
|
-
if (a.children.length > b.children.length) {
|
|
157
|
-
segmentA = `~${segmentA}`;
|
|
158
|
-
}
|
|
159
|
-
else if (a.children.length < b.children.length) {
|
|
160
|
-
segmentB = `~${segmentB}`;
|
|
161
|
-
}
|
|
162
|
-
return segmentA > segmentB ? 1 : -1;
|
|
163
|
-
});
|
|
164
|
-
for (const rawRoute of rawRoutes) {
|
|
165
|
-
sortRawRoutes(rawRoute.children);
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
function deprioritizeSegment(segment) {
|
|
169
|
-
// deprioritize param and wildcard segments
|
|
170
|
-
return segment.replace(':', '~~').replace('**', '~~~~');
|
|
171
|
-
}
|
|
172
|
-
export const routes = createRoutes({
|
|
173
|
-
...ANALOG_ROUTE_FILES,
|
|
174
|
-
...ANALOG_CONTENT_ROUTE_FILES,
|
|
175
|
-
});
|
|
176
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"routes.js","sourceRoot":"","sources":["../../../../../packages/router/src/lib/routes.ts"],"names":[],"mappings":"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","sourcesContent":["/// <reference types=\"vite/client\" />\n\nimport type { Route } from '@angular/router';\n\nimport type { RouteExport, RouteMeta } from './models';\nimport { toRouteConfig } from './route-config';\nimport { toMarkdownModule } from './markdown-helpers';\nimport { APP_DIR, ENDPOINT_EXTENSION } from './constants';\nimport { ANALOG_META_KEY } from './endpoints';\n\n/**\n * This variable reference is replaced with a glob of all page routes.\n */\nlet ANALOG_ROUTE_FILES = {};\n\n/**\n * This variable reference is replaced with a glob of all content routes.\n */\nlet ANALOG_CONTENT_ROUTE_FILES = {};\n\nexport type Files = Record<string, () => Promise<RouteExport | string>>;\n\ntype RawRoute = {\n  filename: string | null;\n  rawSegment: string;\n  ancestorRawSegments: string[];\n  segment: string;\n  level: number;\n  children: RawRoute[];\n};\n\ntype RawRouteMap = Record<string, RawRoute>;\n\ntype RawRouteByLevelMap = Record<number, RawRouteMap>;\n\n/**\n * A function used to parse list of files and create configuration of routes.\n *\n * @param files\n * @returns Array of routes\n */\nexport function createRoutes(files: Files): Route[] {\n  const filenames = Object.keys(files);\n\n  if (filenames.length === 0) {\n    return [];\n  }\n\n  // map filenames to raw routes and group them by level\n  const rawRoutesByLevelMap = filenames.reduce((acc, filename) => {\n    const rawPath = toRawPath(filename);\n    const rawSegments = rawPath.split('/');\n    // nesting level starts at 0\n    // rawPath: /products => level: 0\n    // rawPath: /products/:id => level: 1\n    const level = rawSegments.length - 1;\n    const rawSegment = rawSegments[level];\n    const ancestorRawSegments = rawSegments.slice(0, level);\n\n    return {\n      ...acc,\n      [level]: {\n        ...acc[level],\n        [rawPath]: {\n          filename,\n          rawSegment,\n          ancestorRawSegments,\n          segment: toSegment(rawSegment),\n          level,\n          children: [],\n        },\n      },\n    };\n  }, {} as RawRouteByLevelMap);\n\n  const allLevels = Object.keys(rawRoutesByLevelMap).map(Number);\n  const maxLevel = Math.max(...allLevels);\n\n  // add each raw route to its parent's children array\n  for (let level = maxLevel; level > 0; level--) {\n    const rawRoutesMap = rawRoutesByLevelMap[level];\n    const rawPaths = Object.keys(rawRoutesMap);\n\n    for (const rawPath of rawPaths) {\n      const rawRoute = rawRoutesMap[rawPath];\n      const parentRawPath = rawRoute.ancestorRawSegments.join('/');\n      const parentRawSegmentIndex = rawRoute.ancestorRawSegments.length - 1;\n      const parentRawSegment =\n        rawRoute.ancestorRawSegments[parentRawSegmentIndex];\n\n      // create the parent level and/or raw route if it does not exist\n      // parent route won't exist for nested routes that don't have a layout route\n      rawRoutesByLevelMap[level - 1] ||= {};\n      rawRoutesByLevelMap[level - 1][parentRawPath] ||= {\n        filename: null,\n        rawSegment: parentRawSegment,\n        ancestorRawSegments: rawRoute.ancestorRawSegments.slice(\n          0,\n          parentRawSegmentIndex\n        ),\n        segment: toSegment(parentRawSegment),\n        level: level - 1,\n        children: [],\n      };\n\n      rawRoutesByLevelMap[level - 1][parentRawPath].children.push(rawRoute);\n    }\n  }\n\n  // only take raw routes from the root level\n  // since they already contain nested routes as their children\n  const rootRawRoutesMap = rawRoutesByLevelMap[0];\n  const rawRoutes = Object.keys(rootRawRoutesMap).map(\n    (segment) => rootRawRoutesMap[segment]\n  );\n  sortRawRoutes(rawRoutes);\n\n  return toRoutes(rawRoutes, files);\n}\n\nfunction toRawPath(filename: string): string {\n  return filename\n    .replace(\n      // convert to relative path and remove file extension\n      /^(?:[a-zA-Z]:[\\\\/])?(.*?)[\\\\/](?:routes|pages)[\\\\/]|(?:[\\\\/](?:app[\\\\/](?:routes|pages)[\\\\/]))|(\\.page\\.(js|ts|analog|ag)$)|(\\.(ts|md|analog|ag)$)/g,\n      ''\n    )\n    .replace(/\\[\\.{3}.+\\]/, '**') // [...not-found] => **\n    .replace(/\\[([^\\]]+)\\]/g, ':$1'); // [id] => :id\n}\n\nfunction toSegment(rawSegment: string): string {\n  return rawSegment\n    .replace(/index|\\(.*?\\)/g, '') // replace named empty segments\n    .replace(/\\.|\\/+/g, '/') // replace dots with slashes and remove redundant slashes\n    .replace(/^\\/+|\\/+$/g, ''); // remove trailing slashes\n}\n\nfunction toRoutes(rawRoutes: RawRoute[], files: Files): Route[] {\n  const routes: Route[] = [];\n\n  for (const rawRoute of rawRoutes) {\n    const children: Route[] | undefined =\n      rawRoute.children.length > 0\n        ? toRoutes(rawRoute.children, files)\n        : undefined;\n    let module: (() => Promise<RouteExport>) | undefined = undefined;\n    let analogMeta: { endpoint: string; endpointKey: string } | undefined =\n      undefined;\n\n    if (rawRoute.filename) {\n      const isMarkdownFile = rawRoute.filename.endsWith('.md');\n      module = isMarkdownFile\n        ? toMarkdownModule(files[rawRoute.filename] as () => Promise<string>)\n        : (files[rawRoute.filename] as () => Promise<RouteExport>);\n\n      const endpointKey = rawRoute.filename.replace(\n        /\\.page\\.(ts|analog|ag)$/,\n        ENDPOINT_EXTENSION\n      );\n\n      // get endpoint path\n      const rawEndpoint = rawRoute.filename\n        .replace(/\\.page\\.(ts|analog|ag)$/, '')\n        .replace(/\\[\\.{3}.+\\]/, '**') // [...not-found] => **\n        .replace(/^(.*?)\\/pages/, '/pages');\n\n      // replace periods, remove (index) paths\n      const endpoint = (rawEndpoint || '')\n        .replace(/\\./g, '/')\n        .replace(/\\/\\((.*?)\\)$/, '/-$1-');\n\n      analogMeta = {\n        endpoint,\n        endpointKey,\n      };\n    }\n\n    const route: Route & { meta?: typeof analogMeta } = module\n      ? {\n          path: rawRoute.segment,\n          loadChildren: () =>\n            module!().then((m) => {\n              if (!import.meta.env.PROD) {\n                const hasModuleDefault = !!m.default;\n                const hasRedirect = !!m.routeMeta?.redirectTo;\n\n                if (!hasModuleDefault && !hasRedirect) {\n                  console.warn(\n                    `[Analog] Missing default export at ${rawRoute.filename}`\n                  );\n                }\n              }\n\n              return [\n                {\n                  path: '',\n                  component: m.default,\n                  ...toRouteConfig(m.routeMeta as RouteMeta | undefined),\n                  children,\n                  [ANALOG_META_KEY]: analogMeta,\n                },\n              ];\n            }),\n        }\n      : { path: rawRoute.segment, children };\n\n    routes.push(route);\n  }\n\n  return routes;\n}\n\nfunction sortRawRoutes(rawRoutes: RawRoute[]): void {\n  rawRoutes.sort((a, b) => {\n    let segmentA = deprioritizeSegment(a.segment);\n    let segmentB = deprioritizeSegment(b.segment);\n\n    // prioritize routes with fewer children\n    if (a.children.length > b.children.length) {\n      segmentA = `~${segmentA}`;\n    } else if (a.children.length < b.children.length) {\n      segmentB = `~${segmentB}`;\n    }\n\n    return segmentA > segmentB ? 1 : -1;\n  });\n\n  for (const rawRoute of rawRoutes) {\n    sortRawRoutes(rawRoute.children);\n  }\n}\n\nfunction deprioritizeSegment(segment: string): string {\n  // deprioritize param and wildcard segments\n  return segment.replace(':', '~~').replace('**', '~~~~');\n}\n\nexport const routes: Route[] = createRoutes({\n  ...ANALOG_ROUTE_FILES,\n  ...ANALOG_CONTENT_ROUTE_FILES,\n});\n"]}
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
export function fail(status, errors) {
|
|
2
|
-
return new Response(JSON.stringify(errors), {
|
|
3
|
-
status,
|
|
4
|
-
headers: {
|
|
5
|
-
'X-Analog-Errors': 'true',
|
|
6
|
-
},
|
|
7
|
-
});
|
|
8
|
-
}
|
|
9
|
-
export function json(data, config) {
|
|
10
|
-
return new Response(JSON.stringify(data), {
|
|
11
|
-
headers: {
|
|
12
|
-
'Content-Type': 'application/json; charset=utf-8',
|
|
13
|
-
},
|
|
14
|
-
...config,
|
|
15
|
-
});
|
|
16
|
-
}
|
|
17
|
-
export function redirect(url, config = 302) {
|
|
18
|
-
if (typeof config === 'number') {
|
|
19
|
-
return new Response(null, {
|
|
20
|
-
status: config,
|
|
21
|
-
headers: {
|
|
22
|
-
Location: `${url}`,
|
|
23
|
-
},
|
|
24
|
-
});
|
|
25
|
-
}
|
|
26
|
-
return new Response(null, {
|
|
27
|
-
headers: {
|
|
28
|
-
Location: `${url}`,
|
|
29
|
-
},
|
|
30
|
-
...config,
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3JvdXRlci9zZXJ2ZXIvYWN0aW9ucy9zcmMvYWN0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXQSxNQUFNLFVBQVUsSUFBSSxDQUFhLE1BQWMsRUFBRSxNQUFTO0lBQ3hELE9BQU8sSUFBSSxRQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsRUFBRTtRQUMxQyxNQUFNO1FBQ04sT0FBTyxFQUFFO1lBQ1AsaUJBQWlCLEVBQUUsTUFBTTtTQUMxQjtLQUNGLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRCxNQUFNLFVBQVUsSUFBSSxDQUFhLElBQU8sRUFBRSxNQUFxQjtJQUM3RCxPQUFPLElBQUksUUFBUSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUU7UUFDeEMsT0FBTyxFQUFFO1lBQ1AsY0FBYyxFQUFFLGlDQUFpQztTQUNsRDtRQUNELEdBQUcsTUFBTTtLQUNWLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRCxNQUFNLFVBQVUsUUFBUSxDQUFDLEdBQVcsRUFBRSxTQUFnQyxHQUFHO0lBQ3ZFLElBQUksT0FBTyxNQUFNLEtBQUssUUFBUSxFQUFFLENBQUM7UUFDL0IsT0FBTyxJQUFJLFFBQVEsQ0FBQyxJQUFJLEVBQUU7WUFDeEIsTUFBTSxFQUFFLE1BQU07WUFDZCxPQUFPLEVBQUU7Z0JBQ1AsUUFBUSxFQUFFLEdBQUcsR0FBRyxFQUFFO2FBQ25CO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELE9BQU8sSUFBSSxRQUFRLENBQUMsSUFBSSxFQUFFO1FBQ3hCLE9BQU8sRUFBRTtZQUNQLFFBQVEsRUFBRSxHQUFHLEdBQUcsRUFBRTtTQUNuQjtRQUNELEdBQUcsTUFBTTtLQUNWLENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEgzRXZlbnQsIEgzRXZlbnRDb250ZXh0IH0gZnJvbSAnaDMnO1xuaW1wb3J0IHR5cGUgeyAkRmV0Y2ggfSBmcm9tICduaXRyb3BhY2snO1xuXG5leHBvcnQgdHlwZSBQYWdlU2VydmVyQWN0aW9uID0ge1xuICBwYXJhbXM6IEgzRXZlbnRDb250ZXh0WydwYXJhbXMnXTtcbiAgcmVxOiBIM0V2ZW50Wydub2RlJ11bJ3JlcSddO1xuICByZXM6IEgzRXZlbnRbJ25vZGUnXVsncmVzJ107XG4gIGZldGNoOiAkRmV0Y2g7XG4gIGV2ZW50OiBIM0V2ZW50O1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIGZhaWw8VCA9IG9iamVjdD4oc3RhdHVzOiBudW1iZXIsIGVycm9yczogVCkge1xuICByZXR1cm4gbmV3IFJlc3BvbnNlKEpTT04uc3RyaW5naWZ5KGVycm9ycyksIHtcbiAgICBzdGF0dXMsXG4gICAgaGVhZGVyczoge1xuICAgICAgJ1gtQW5hbG9nLUVycm9ycyc6ICd0cnVlJyxcbiAgICB9LFxuICB9KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGpzb248VCA9IG9iamVjdD4oZGF0YTogVCwgY29uZmlnPzogUmVzcG9uc2VJbml0KSB7XG4gIHJldHVybiBuZXcgUmVzcG9uc2UoSlNPTi5zdHJpbmdpZnkoZGF0YSksIHtcbiAgICBoZWFkZXJzOiB7XG4gICAgICAnQ29udGVudC1UeXBlJzogJ2FwcGxpY2F0aW9uL2pzb247IGNoYXJzZXQ9dXRmLTgnLFxuICAgIH0sXG4gICAgLi4uY29uZmlnLFxuICB9KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHJlZGlyZWN0KHVybDogc3RyaW5nLCBjb25maWc6IG51bWJlciB8IFJlc3BvbnNlSW5pdCA9IDMwMikge1xuICBpZiAodHlwZW9mIGNvbmZpZyA9PT0gJ251bWJlcicpIHtcbiAgICByZXR1cm4gbmV3IFJlc3BvbnNlKG51bGwsIHtcbiAgICAgIHN0YXR1czogY29uZmlnLFxuICAgICAgaGVhZGVyczoge1xuICAgICAgICBMb2NhdGlvbjogYCR7dXJsfWAsXG4gICAgICB9LFxuICAgIH0pO1xuICB9XG5cbiAgcmV0dXJuIG5ldyBSZXNwb25zZShudWxsLCB7XG4gICAgaGVhZGVyczoge1xuICAgICAgTG9jYXRpb246IGAke3VybH1gLFxuICAgIH0sXG4gICAgLi4uY29uZmlnLFxuICB9KTtcbn1cbiJdfQ==
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Generated bundle index. Do not edit.
|
|
3
|
-
*/
|
|
4
|
-
export * from './index';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5hbG9nanMtcm91dGVyLXNlcnZlci1hY3Rpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvcm91dGVyL3NlcnZlci9hY3Rpb25zL3NyYy9hbmFsb2dqcy1yb3V0ZXItc2VydmVyLWFjdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export { json, redirect, fail } from './actions';
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9yb3V0ZXIvc2VydmVyL2FjdGlvbnMvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBb0IsSUFBSSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsTUFBTSxXQUFXLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBQYWdlU2VydmVyQWN0aW9uLCBqc29uLCByZWRpcmVjdCwgZmFpbCB9IGZyb20gJy4vYWN0aW9ucyc7XG4iXX0=
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Generated bundle index. Do not edit.
|
|
3
|
-
*/
|
|
4
|
-
export * from './index';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5hbG9nanMtcm91dGVyLXNlcnZlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3JvdXRlci9zZXJ2ZXIvc3JjL2FuYWxvZ2pzLXJvdXRlci1zZXJ2ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
|
package/esm2022/server/index.mjs
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export { provideServerContext } from './provide-server-context';
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9yb3V0ZXIvc2VydmVyL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IHByb3ZpZGVTZXJ2ZXJDb250ZXh0IH0gZnJvbSAnLi9wcm92aWRlLXNlcnZlci1jb250ZXh0JztcbiJdfQ==
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
import { ɵresetCompiledComponents } from '@angular/core';
|
|
2
|
-
import { ɵSERVER_CONTEXT as SERVER_CONTEXT } from '@angular/platform-server';
|
|
3
|
-
import { BASE_URL, REQUEST, RESPONSE, } from '@analogjs/router/tokens';
|
|
4
|
-
export function provideServerContext({ req, res, }) {
|
|
5
|
-
const baseUrl = getBaseUrl(req);
|
|
6
|
-
if (import.meta.env.DEV) {
|
|
7
|
-
ɵresetCompiledComponents();
|
|
8
|
-
}
|
|
9
|
-
return [
|
|
10
|
-
{ provide: SERVER_CONTEXT, useValue: 'ssr-analog' },
|
|
11
|
-
{ provide: REQUEST, useValue: req },
|
|
12
|
-
{ provide: RESPONSE, useValue: res },
|
|
13
|
-
{ provide: BASE_URL, useValue: baseUrl },
|
|
14
|
-
];
|
|
15
|
-
}
|
|
16
|
-
export function getBaseUrl(req) {
|
|
17
|
-
const protocol = getRequestProtocol(req);
|
|
18
|
-
const { originalUrl, headers } = req;
|
|
19
|
-
const parsedUrl = new URL('', `${protocol}://${headers.host}${originalUrl.endsWith('/')
|
|
20
|
-
? originalUrl.substring(0, originalUrl.length - 1)
|
|
21
|
-
: originalUrl}`);
|
|
22
|
-
const baseUrl = parsedUrl.origin;
|
|
23
|
-
return baseUrl;
|
|
24
|
-
}
|
|
25
|
-
export function getRequestProtocol(req, opts = {}) {
|
|
26
|
-
if (opts.xForwardedProto !== false &&
|
|
27
|
-
req.headers['x-forwarded-proto'] === 'https') {
|
|
28
|
-
return 'https';
|
|
29
|
-
}
|
|
30
|
-
return req.connection?.encrypted ? 'https' : 'http';
|
|
31
|
-
}
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZS1zZXJ2ZXItY29udGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3JvdXRlci9zZXJ2ZXIvc3JjL3Byb3ZpZGUtc2VydmVyLWNvbnRleHQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFrQix3QkFBd0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6RSxPQUFPLEVBQUUsZUFBZSxJQUFJLGNBQWMsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBRTdFLE9BQU8sRUFDTCxRQUFRLEVBQ1IsT0FBTyxFQUNQLFFBQVEsR0FHVCxNQUFNLHlCQUF5QixDQUFDO0FBRWpDLE1BQU0sVUFBVSxvQkFBb0IsQ0FBQyxFQUNuQyxHQUFHLEVBQ0gsR0FBRyxHQUlKO0lBQ0MsTUFBTSxPQUFPLEdBQUcsVUFBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRWhDLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDeEIsd0JBQXdCLEVBQUUsQ0FBQztJQUM3QixDQUFDO0lBRUQsT0FBTztRQUNMLEVBQUUsT0FBTyxFQUFFLGNBQWMsRUFBRSxRQUFRLEVBQUUsWUFBWSxFQUFFO1FBQ25ELEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsR0FBRyxFQUFFO1FBQ25DLEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsR0FBRyxFQUFFO1FBQ3BDLEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFO0tBQ3pDLENBQUM7QUFDSixDQUFDO0FBRUQsTUFBTSxVQUFVLFVBQVUsQ0FBQyxHQUFrQjtJQUMzQyxNQUFNLFFBQVEsR0FBRyxrQkFBa0IsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUN6QyxNQUFNLEVBQUUsV0FBVyxFQUFFLE9BQU8sRUFBRSxHQUFHLEdBQUcsQ0FBQztJQUNyQyxNQUFNLFNBQVMsR0FBRyxJQUFJLEdBQUcsQ0FDdkIsRUFBRSxFQUNGLEdBQUcsUUFBUSxNQUFNLE9BQU8sQ0FBQyxJQUFJLEdBQzNCLFdBQVcsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDO1FBQ3ZCLENBQUMsQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxXQUFXLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQztRQUNsRCxDQUFDLENBQUMsV0FDTixFQUFFLENBQ0gsQ0FBQztJQUNGLE1BQU0sT0FBTyxHQUFHLFNBQVMsQ0FBQyxNQUFNLENBQUM7SUFFakMsT0FBTyxPQUFPLENBQUM7QUFDakIsQ0FBQztBQUVELE1BQU0sVUFBVSxrQkFBa0IsQ0FDaEMsR0FBa0IsRUFDbEIsT0FBc0MsRUFBRTtJQUV4QyxJQUNFLElBQUksQ0FBQyxlQUFlLEtBQUssS0FBSztRQUM5QixHQUFHLENBQUMsT0FBTyxDQUFDLG1CQUFtQixDQUFDLEtBQUssT0FBTyxFQUM1QyxDQUFDO1FBQ0QsT0FBTyxPQUFPLENBQUM7SUFDakIsQ0FBQztJQUVELE9BQVEsR0FBRyxDQUFDLFVBQWtCLEVBQUUsU0FBUyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQztBQUMvRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU3RhdGljUHJvdmlkZXIsIMm1cmVzZXRDb21waWxlZENvbXBvbmVudHMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IMm1U0VSVkVSX0NPTlRFWFQgYXMgU0VSVkVSX0NPTlRFWFQgfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1zZXJ2ZXInO1xuXG5pbXBvcnQge1xuICBCQVNFX1VSTCxcbiAgUkVRVUVTVCxcbiAgUkVTUE9OU0UsXG4gIFNlcnZlclJlcXVlc3QsXG4gIFNlcnZlclJlc3BvbnNlLFxufSBmcm9tICdAYW5hbG9nanMvcm91dGVyL3Rva2Vucyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBwcm92aWRlU2VydmVyQ29udGV4dCh7XG4gIHJlcSxcbiAgcmVzLFxufToge1xuICByZXE6IFNlcnZlclJlcXVlc3Q7XG4gIHJlczogU2VydmVyUmVzcG9uc2U7XG59KTogU3RhdGljUHJvdmlkZXJbXSB7XG4gIGNvbnN0IGJhc2VVcmwgPSBnZXRCYXNlVXJsKHJlcSk7XG5cbiAgaWYgKGltcG9ydC5tZXRhLmVudi5ERVYpIHtcbiAgICDJtXJlc2V0Q29tcGlsZWRDb21wb25lbnRzKCk7XG4gIH1cblxuICByZXR1cm4gW1xuICAgIHsgcHJvdmlkZTogU0VSVkVSX0NPTlRFWFQsIHVzZVZhbHVlOiAnc3NyLWFuYWxvZycgfSxcbiAgICB7IHByb3ZpZGU6IFJFUVVFU1QsIHVzZVZhbHVlOiByZXEgfSxcbiAgICB7IHByb3ZpZGU6IFJFU1BPTlNFLCB1c2VWYWx1ZTogcmVzIH0sXG4gICAgeyBwcm92aWRlOiBCQVNFX1VSTCwgdXNlVmFsdWU6IGJhc2VVcmwgfSxcbiAgXTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEJhc2VVcmwocmVxOiBTZXJ2ZXJSZXF1ZXN0KSB7XG4gIGNvbnN0IHByb3RvY29sID0gZ2V0UmVxdWVzdFByb3RvY29sKHJlcSk7XG4gIGNvbnN0IHsgb3JpZ2luYWxVcmwsIGhlYWRlcnMgfSA9IHJlcTtcbiAgY29uc3QgcGFyc2VkVXJsID0gbmV3IFVSTChcbiAgICAnJyxcbiAgICBgJHtwcm90b2NvbH06Ly8ke2hlYWRlcnMuaG9zdH0ke1xuICAgICAgb3JpZ2luYWxVcmwuZW5kc1dpdGgoJy8nKVxuICAgICAgICA/IG9yaWdpbmFsVXJsLnN1YnN0cmluZygwLCBvcmlnaW5hbFVybC5sZW5ndGggLSAxKVxuICAgICAgICA6IG9yaWdpbmFsVXJsXG4gICAgfWBcbiAgKTtcbiAgY29uc3QgYmFzZVVybCA9IHBhcnNlZFVybC5vcmlnaW47XG5cbiAgcmV0dXJuIGJhc2VVcmw7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRSZXF1ZXN0UHJvdG9jb2woXG4gIHJlcTogU2VydmVyUmVxdWVzdCxcbiAgb3B0czogeyB4Rm9yd2FyZGVkUHJvdG8/OiBib29sZWFuIH0gPSB7fVxuKSB7XG4gIGlmIChcbiAgICBvcHRzLnhGb3J3YXJkZWRQcm90byAhPT0gZmFsc2UgJiZcbiAgICByZXEuaGVhZGVyc1sneC1mb3J3YXJkZWQtcHJvdG8nXSA9PT0gJ2h0dHBzJ1xuICApIHtcbiAgICByZXR1cm4gJ2h0dHBzJztcbiAgfVxuXG4gIHJldHVybiAocmVxLmNvbm5lY3Rpb24gYXMgYW55KT8uZW5jcnlwdGVkID8gJ2h0dHBzJyA6ICdodHRwJztcbn1cbiJdfQ==
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Generated bundle index. Do not edit.
|
|
3
|
-
*/
|
|
4
|
-
export * from './index';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5hbG9nanMtcm91dGVyLXRva2Vucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3JvdXRlci90b2tlbnMvc3JjL2FuYWxvZ2pzLXJvdXRlci10b2tlbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
|
package/esm2022/tokens/index.mjs
DELETED
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { InjectionToken, inject } from '@angular/core';
|
|
2
|
-
export const REQUEST = new InjectionToken('@analogjs/router Server Request');
|
|
3
|
-
export const RESPONSE = new InjectionToken('@analogjs/router Server Response');
|
|
4
|
-
export const BASE_URL = new InjectionToken('@analogjs/router Base URL');
|
|
5
|
-
export const API_PREFIX = new InjectionToken('@analogjs/router API Prefix');
|
|
6
|
-
export function injectRequest() {
|
|
7
|
-
return inject(REQUEST, { optional: true });
|
|
8
|
-
}
|
|
9
|
-
export function injectResponse() {
|
|
10
|
-
return inject(RESPONSE, { optional: true });
|
|
11
|
-
}
|
|
12
|
-
export function injectBaseURL() {
|
|
13
|
-
return inject(BASE_URL, { optional: true });
|
|
14
|
-
}
|
|
15
|
-
export function injectAPIPrefix() {
|
|
16
|
-
return inject(API_PREFIX);
|
|
17
|
-
}
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9yb3V0ZXIvdG9rZW5zL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQVV2RCxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsSUFBSSxjQUFjLENBQ3ZDLGlDQUFpQyxDQUNsQyxDQUFDO0FBQ0YsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUFHLElBQUksY0FBYyxDQUN4QyxrQ0FBa0MsQ0FDbkMsQ0FBQztBQUNGLE1BQU0sQ0FBQyxNQUFNLFFBQVEsR0FBRyxJQUFJLGNBQWMsQ0FBUywyQkFBMkIsQ0FBQyxDQUFDO0FBRWhGLE1BQU0sQ0FBQyxNQUFNLFVBQVUsR0FBRyxJQUFJLGNBQWMsQ0FDMUMsNkJBQTZCLENBQzlCLENBQUM7QUFFRixNQUFNLFVBQVUsYUFBYTtJQUMzQixPQUFPLE1BQU0sQ0FBQyxPQUFPLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztBQUM3QyxDQUFDO0FBRUQsTUFBTSxVQUFVLGNBQWM7SUFDNUIsT0FBTyxNQUFNLENBQUMsUUFBUSxFQUFFLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7QUFDOUMsQ0FBQztBQUVELE1BQU0sVUFBVSxhQUFhO0lBQzNCLE9BQU8sTUFBTSxDQUFDLFFBQVEsRUFBRSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0FBQzlDLENBQUM7QUFFRCxNQUFNLFVBQVUsZUFBZTtJQUM3QixPQUFPLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztBQUM1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4sIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHR5cGUge1xuICBJbmNvbWluZ01lc3NhZ2UsXG4gIFNlcnZlclJlc3BvbnNlIGFzIE5vZGVTZXJ2ZXJSZXNwb25zZSxcbn0gZnJvbSAnbm9kZTpodHRwJztcblxuZXhwb3J0IHR5cGUgU2VydmVyUmVxdWVzdCA9IEluY29taW5nTWVzc2FnZSAmIHsgb3JpZ2luYWxVcmw6IHN0cmluZyB9O1xuZXhwb3J0IHR5cGUgU2VydmVyUmVzcG9uc2UgPSBOb2RlU2VydmVyUmVzcG9uc2U7XG5leHBvcnQgdHlwZSBTZXJ2ZXJDb250ZXh0ID0geyByZXE6IFNlcnZlclJlcXVlc3Q7IHJlczogU2VydmVyUmVzcG9uc2UgfTtcblxuZXhwb3J0IGNvbnN0IFJFUVVFU1QgPSBuZXcgSW5qZWN0aW9uVG9rZW48U2VydmVyUmVxdWVzdD4oXG4gICdAYW5hbG9nanMvcm91dGVyIFNlcnZlciBSZXF1ZXN0J1xuKTtcbmV4cG9ydCBjb25zdCBSRVNQT05TRSA9IG5ldyBJbmplY3Rpb25Ub2tlbjxTZXJ2ZXJSZXNwb25zZT4oXG4gICdAYW5hbG9nanMvcm91dGVyIFNlcnZlciBSZXNwb25zZSdcbik7XG5leHBvcnQgY29uc3QgQkFTRV9VUkwgPSBuZXcgSW5qZWN0aW9uVG9rZW48c3RyaW5nPignQGFuYWxvZ2pzL3JvdXRlciBCYXNlIFVSTCcpO1xuXG5leHBvcnQgY29uc3QgQVBJX1BSRUZJWCA9IG5ldyBJbmplY3Rpb25Ub2tlbjxzdHJpbmc+KFxuICAnQGFuYWxvZ2pzL3JvdXRlciBBUEkgUHJlZml4J1xuKTtcblxuZXhwb3J0IGZ1bmN0aW9uIGluamVjdFJlcXVlc3QoKSB7XG4gIHJldHVybiBpbmplY3QoUkVRVUVTVCwgeyBvcHRpb25hbDogdHJ1ZSB9KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGluamVjdFJlc3BvbnNlKCkge1xuICByZXR1cm4gaW5qZWN0KFJFU1BPTlNFLCB7IG9wdGlvbmFsOiB0cnVlIH0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaW5qZWN0QmFzZVVSTCgpIHtcbiAgcmV0dXJuIGluamVjdChCQVNFX1VSTCwgeyBvcHRpb25hbDogdHJ1ZSB9KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGluamVjdEFQSVByZWZpeCgpIHtcbiAgcmV0dXJuIGluamVjdChBUElfUFJFRklYKTtcbn1cbiJdfQ==
|