summaryrefslogtreecommitdiff
path: root/packages/integrations/netlify/src/integration-edge-functions.ts
diff options
context:
space:
mode:
Diffstat (limited to 'packages/integrations/netlify/src/integration-edge-functions.ts')
-rw-r--r--packages/integrations/netlify/src/integration-edge-functions.ts22
1 files changed, 21 insertions, 1 deletions
diff --git a/packages/integrations/netlify/src/integration-edge-functions.ts b/packages/integrations/netlify/src/integration-edge-functions.ts
index a4bd66e51..f82e6ecc2 100644
--- a/packages/integrations/netlify/src/integration-edge-functions.ts
+++ b/packages/integrations/netlify/src/integration-edge-functions.ts
@@ -1,4 +1,5 @@
import type { AstroAdapter, AstroConfig, AstroIntegration, BuildConfig, RouteData } from 'astro';
+import type { Plugin as VitePlugin } from 'vite';
import esbuild from 'esbuild';
import * as fs from 'fs';
import * as npath from 'path';
@@ -97,12 +98,31 @@ export function netlifyEdgeFunctions({ dist }: NetlifyEdgeFunctionsOptions = {})
return {
name: '@astrojs/netlify/edge-functions',
hooks: {
- 'astro:config:setup': ({ config }) => {
+ 'astro:config:setup': ({ config, updateConfig }) => {
if (dist) {
config.outDir = dist;
} else {
config.outDir = new URL('./dist/', config.root);
}
+
+ // Add a plugin that shims the global environment.
+ const injectPlugin: VitePlugin = {
+ name: '@astrojs/netlify/plugin-inject',
+ generateBundle(_options, bundle) {
+ if(_buildConfig.serverEntry in bundle) {
+ const chunk = bundle[_buildConfig.serverEntry];
+ if(chunk && chunk.type === 'chunk') {
+ chunk.code = `globalThis.process = { argv: [], env: {}, };${chunk.code}`;
+ }
+ }
+ }
+ };
+
+ updateConfig({
+ vite: {
+ plugins: [injectPlugin]
+ }
+ });
},
'astro:config:done': ({ config, setAdapter }) => {
setAdapter(getAdapter());