Simpify passing endpoint logging option (#7584)
This commit is contained in:
parent
2ca5bdde2b
commit
2d9c621c77
5 changed files with 7 additions and 10 deletions
|
@ -301,7 +301,7 @@ export class App {
|
||||||
mod: handler as any,
|
mod: handler as any,
|
||||||
});
|
});
|
||||||
|
|
||||||
const result = await callEndpoint(handler, this.#env, ctx, this.#logging, page.onRequest);
|
const result = await callEndpoint(handler, this.#env, ctx, page.onRequest);
|
||||||
|
|
||||||
if (result.type === 'response') {
|
if (result.type === 'response') {
|
||||||
if (result.response.headers.get('X-Astro-Response') === 'Not-Found') {
|
if (result.response.headers.get('X-Astro-Response') === 'Not-Found') {
|
||||||
|
|
|
@ -559,7 +559,6 @@ async function generatePath(
|
||||||
endpointHandler,
|
endpointHandler,
|
||||||
env,
|
env,
|
||||||
renderContext,
|
renderContext,
|
||||||
logging,
|
|
||||||
onRequest as MiddlewareHandler<Response | EndpointOutput>
|
onRequest as MiddlewareHandler<Response | EndpointOutput>
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,9 @@
|
||||||
import type { EndpointHandler } from '../../../@types/astro';
|
import type { EndpointHandler } from '../../../@types/astro';
|
||||||
import type { LogOptions } from '../../logger/core';
|
|
||||||
import type { SSROptions } from '../../render/dev';
|
import type { SSROptions } from '../../render/dev';
|
||||||
import { createRenderContext } from '../../render/index.js';
|
import { createRenderContext } from '../../render/index.js';
|
||||||
import { callEndpoint } from '../index.js';
|
import { callEndpoint } from '../index.js';
|
||||||
|
|
||||||
export async function call(options: SSROptions, logging: LogOptions) {
|
export async function call(options: SSROptions) {
|
||||||
const { env, preload, middleware } = options;
|
const { env, preload, middleware } = options;
|
||||||
const endpointHandler = preload as unknown as EndpointHandler;
|
const endpointHandler = preload as unknown as EndpointHandler;
|
||||||
|
|
||||||
|
@ -16,5 +15,5 @@ export async function call(options: SSROptions, logging: LogOptions) {
|
||||||
mod: preload,
|
mod: preload,
|
||||||
});
|
});
|
||||||
|
|
||||||
return await callEndpoint(endpointHandler, env, ctx, logging, middleware?.onRequest);
|
return await callEndpoint(endpointHandler, env, ctx, middleware?.onRequest);
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,7 +14,7 @@ import { renderEndpoint } from '../../runtime/server/index.js';
|
||||||
import { ASTRO_VERSION } from '../constants.js';
|
import { ASTRO_VERSION } from '../constants.js';
|
||||||
import { AstroCookies, attachToResponse } from '../cookies/index.js';
|
import { AstroCookies, attachToResponse } from '../cookies/index.js';
|
||||||
import { AstroError, AstroErrorData } from '../errors/index.js';
|
import { AstroError, AstroErrorData } from '../errors/index.js';
|
||||||
import { warn, type LogOptions } from '../logger/core.js';
|
import { warn } from '../logger/core.js';
|
||||||
import { callMiddleware } from '../middleware/callMiddleware.js';
|
import { callMiddleware } from '../middleware/callMiddleware.js';
|
||||||
const clientAddressSymbol = Symbol.for('astro.clientAddress');
|
const clientAddressSymbol = Symbol.for('astro.clientAddress');
|
||||||
const clientLocalsSymbol = Symbol.for('astro.locals');
|
const clientLocalsSymbol = Symbol.for('astro.locals');
|
||||||
|
@ -104,7 +104,6 @@ export async function callEndpoint<MiddlewareResult = Response | EndpointOutput>
|
||||||
mod: EndpointHandler,
|
mod: EndpointHandler,
|
||||||
env: Environment,
|
env: Environment,
|
||||||
ctx: RenderContext,
|
ctx: RenderContext,
|
||||||
logging: LogOptions,
|
|
||||||
onRequest?: MiddlewareHandler<MiddlewareResult> | undefined
|
onRequest?: MiddlewareHandler<MiddlewareResult> | undefined
|
||||||
): Promise<EndpointCallResult> {
|
): Promise<EndpointCallResult> {
|
||||||
const context = createAPIContext({
|
const context = createAPIContext({
|
||||||
|
@ -140,7 +139,7 @@ export async function callEndpoint<MiddlewareResult = Response | EndpointOutput>
|
||||||
if (env.ssr && !ctx.route?.prerender) {
|
if (env.ssr && !ctx.route?.prerender) {
|
||||||
if (response.hasOwnProperty('headers')) {
|
if (response.hasOwnProperty('headers')) {
|
||||||
warn(
|
warn(
|
||||||
logging,
|
env.logging,
|
||||||
'ssr',
|
'ssr',
|
||||||
'Setting headers is not supported when returning an object. Please return an instance of Response. See https://docs.astro.build/en/core-concepts/endpoints/#server-endpoints-api-routes for more information.'
|
'Setting headers is not supported when returning an object. Please return an instance of Response. See https://docs.astro.build/en/core-concepts/endpoints/#server-endpoints-api-routes for more information.'
|
||||||
);
|
);
|
||||||
|
@ -148,7 +147,7 @@ export async function callEndpoint<MiddlewareResult = Response | EndpointOutput>
|
||||||
|
|
||||||
if (response.encoding) {
|
if (response.encoding) {
|
||||||
warn(
|
warn(
|
||||||
logging,
|
env.logging,
|
||||||
'ssr',
|
'ssr',
|
||||||
'`encoding` is ignored in SSR. To return a charset other than UTF-8, please return an instance of Response. See https://docs.astro.build/en/core-concepts/endpoints/#server-endpoints-api-routes for more information.'
|
'`encoding` is ignored in SSR. To return a charset other than UTF-8, please return an instance of Response. See https://docs.astro.build/en/core-concepts/endpoints/#server-endpoints-api-routes for more information.'
|
||||||
);
|
);
|
||||||
|
|
|
@ -176,7 +176,7 @@ export async function handleRoute(
|
||||||
}
|
}
|
||||||
// Route successfully matched! Render it.
|
// Route successfully matched! Render it.
|
||||||
if (route.type === 'endpoint') {
|
if (route.type === 'endpoint') {
|
||||||
const result = await callEndpoint(options, logging);
|
const result = await callEndpoint(options);
|
||||||
if (result.type === 'response') {
|
if (result.type === 'response') {
|
||||||
if (result.response.headers.get('X-Astro-Response') === 'Not-Found') {
|
if (result.response.headers.get('X-Astro-Response') === 'Not-Found') {
|
||||||
const fourOhFourRoute = await matchRoute('/404', env, manifest);
|
const fourOhFourRoute = await matchRoute('/404', env, manifest);
|
||||||
|
|
Loading…
Reference in a new issue