Simpify passing endpoint logging option (#7584)

This commit is contained in:
Bjorn Lu 2023-07-06 20:28:18 +08:00 committed by GitHub
parent 2ca5bdde2b
commit 2d9c621c77
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 7 additions and 10 deletions

View file

@ -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') {

View file

@ -559,7 +559,6 @@ async function generatePath(
endpointHandler, endpointHandler,
env, env,
renderContext, renderContext,
logging,
onRequest as MiddlewareHandler<Response | EndpointOutput> onRequest as MiddlewareHandler<Response | EndpointOutput>
); );

View file

@ -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);
} }

View file

@ -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.'
); );

View file

@ -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);