Initial boiler plate project
This commit is contained in:
96
node_modules/next/dist/server/web/edge-route-module-wrapper.js
generated
vendored
Normal file
96
node_modules/next/dist/server/web/edge-route-module-wrapper.js
generated
vendored
Normal file
@ -0,0 +1,96 @@
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
Object.defineProperty(exports, "EdgeRouteModuleWrapper", {
|
||||
enumerable: true,
|
||||
get: function() {
|
||||
return EdgeRouteModuleWrapper;
|
||||
}
|
||||
});
|
||||
require("./globals");
|
||||
const _adapter = require("./adapter");
|
||||
const _incrementalcache = require("../lib/incremental-cache");
|
||||
const _routematcher = require("../future/route-matchers/route-matcher");
|
||||
const _internaledgewaituntil = require("./internal-edge-wait-until");
|
||||
const _serverutils = require("../server-utils");
|
||||
const _querystring = require("../../shared/lib/router/utils/querystring");
|
||||
const _getedgepreviewprops = require("./get-edge-preview-props");
|
||||
class EdgeRouteModuleWrapper {
|
||||
/**
|
||||
* The constructor is wrapped with private to ensure that it can only be
|
||||
* constructed by the static wrap method.
|
||||
*
|
||||
* @param routeModule the route module to wrap
|
||||
*/ constructor(routeModule){
|
||||
this.routeModule = routeModule;
|
||||
// TODO: (wyattjoh) possibly allow the module to define it's own matcher
|
||||
this.matcher = new _routematcher.RouteMatcher(routeModule.definition);
|
||||
}
|
||||
/**
|
||||
* This will wrap a module with the EdgeModuleWrapper and return a function
|
||||
* that can be used as a handler for the edge runtime.
|
||||
*
|
||||
* @param module the module to wrap
|
||||
* @param options any options that should be passed to the adapter and
|
||||
* override the ones passed from the runtime
|
||||
* @returns a function that can be used as a handler for the edge runtime
|
||||
*/ static wrap(routeModule, options = {}) {
|
||||
// Create the module wrapper.
|
||||
const wrapper = new EdgeRouteModuleWrapper(routeModule);
|
||||
// Return the wrapping function.
|
||||
return (opts)=>{
|
||||
return (0, _adapter.adapter)({
|
||||
...opts,
|
||||
...options,
|
||||
IncrementalCache: _incrementalcache.IncrementalCache,
|
||||
// Bind the handler method to the wrapper so it still has context.
|
||||
handler: wrapper.handler.bind(wrapper)
|
||||
});
|
||||
};
|
||||
}
|
||||
async handler(request, evt) {
|
||||
const utils = (0, _serverutils.getUtils)({
|
||||
pageIsDynamic: this.matcher.isDynamic,
|
||||
page: this.matcher.definition.pathname,
|
||||
basePath: request.nextUrl.basePath,
|
||||
// We don't need the `handleRewrite` util, so can just pass an empty object
|
||||
rewrites: {},
|
||||
// only used for rewrites, so setting an arbitrary default value here
|
||||
caseSensitive: false
|
||||
});
|
||||
const { params } = utils.normalizeDynamicRouteParams((0, _querystring.searchParamsToUrlQuery)(request.nextUrl.searchParams));
|
||||
const previewProps = (0, _getedgepreviewprops.getEdgePreviewProps)();
|
||||
// Create the context for the handler. This contains the params from the
|
||||
// match (if any).
|
||||
const context = {
|
||||
params,
|
||||
prerenderManifest: {
|
||||
version: 4,
|
||||
routes: {},
|
||||
dynamicRoutes: {},
|
||||
preview: previewProps,
|
||||
notFoundRoutes: []
|
||||
},
|
||||
renderOpts: {
|
||||
supportsDynamicResponse: true,
|
||||
// App Route's cannot be postponed.
|
||||
experimental: {
|
||||
ppr: false
|
||||
}
|
||||
}
|
||||
};
|
||||
// Get the response from the handler.
|
||||
const res = await this.routeModule.handle(request, context);
|
||||
const waitUntilPromises = [
|
||||
(0, _internaledgewaituntil.internal_getCurrentFunctionWaitUntil)()
|
||||
];
|
||||
if (context.renderOpts.waitUntil) {
|
||||
waitUntilPromises.push(context.renderOpts.waitUntil);
|
||||
}
|
||||
evt.waitUntil(Promise.all(waitUntilPromises));
|
||||
return res;
|
||||
}
|
||||
}
|
||||
|
||||
//# sourceMappingURL=edge-route-module-wrapper.js.map
|
||||
Reference in New Issue
Block a user