@sveltejs/adapter-netlify 1.0.0-next.52 → 1.0.0-next.55
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.
|
File without changes
|
package/files/edge.js
ADDED
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { Server } from '0SERVER';
|
|
2
|
+
import { manifest, prerendered } from 'MANIFEST';
|
|
3
|
+
|
|
4
|
+
const server = new Server(manifest);
|
|
5
|
+
const prefix = `/${manifest.appDir}/`;
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* @param { Request } request
|
|
9
|
+
* @param { any } context
|
|
10
|
+
* @returns { Promise<Response> }
|
|
11
|
+
*/
|
|
12
|
+
export default async function handler(request, context) {
|
|
13
|
+
if (is_static_file(request)) {
|
|
14
|
+
// Static files can skip the handler
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
try {
|
|
18
|
+
const response = await server.respond(request, {
|
|
19
|
+
platform: { context },
|
|
20
|
+
getClientAddress() {
|
|
21
|
+
return request.headers.get('x-nf-client-connection-ip');
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
return response;
|
|
25
|
+
} catch (error) {
|
|
26
|
+
return new Response('Error rendering route:' + (error.message || error.toString()), {
|
|
27
|
+
status: 500
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
/**
|
|
33
|
+
* @param {Request} request
|
|
34
|
+
*/
|
|
35
|
+
function is_static_file(request) {
|
|
36
|
+
const url = new URL(request.url);
|
|
37
|
+
|
|
38
|
+
// Assets in the app dir
|
|
39
|
+
if (url.pathname.startsWith(prefix)) {
|
|
40
|
+
return true;
|
|
41
|
+
}
|
|
42
|
+
// prerendered pages and index.html files
|
|
43
|
+
const pathname = url.pathname.replace(/\/$/, '');
|
|
44
|
+
let file = pathname.substring(1);
|
|
45
|
+
|
|
46
|
+
try {
|
|
47
|
+
file = decodeURIComponent(file);
|
|
48
|
+
} catch (err) {
|
|
49
|
+
// ignore
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
return (
|
|
53
|
+
manifest.assets.has(file) ||
|
|
54
|
+
manifest.assets.has(file + '/index.html') ||
|
|
55
|
+
prerendered.has(pathname || '/')
|
|
56
|
+
);
|
|
57
|
+
}
|
|
File without changes
|
package/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { appendFileSync, existsSync, readFileSync, writeFileSync } from 'fs';
|
|
2
|
-
import { join, resolve, posix } from 'path';
|
|
2
|
+
import { dirname, join, resolve, posix } from 'path';
|
|
3
3
|
import { fileURLToPath } from 'url';
|
|
4
4
|
import glob from 'tiny-glob/sync.js';
|
|
5
5
|
import esbuild from 'esbuild';
|
|
@@ -29,13 +29,13 @@ import toml from '@iarna/toml';
|
|
|
29
29
|
*/
|
|
30
30
|
|
|
31
31
|
const files = fileURLToPath(new URL('./files', import.meta.url).href);
|
|
32
|
-
|
|
33
|
-
const
|
|
32
|
+
|
|
33
|
+
const edge_set_in_env_var =
|
|
34
34
|
process.env.NETLIFY_SVELTEKIT_USE_EDGE === 'true' ||
|
|
35
35
|
process.env.NETLIFY_SVELTEKIT_USE_EDGE === '1';
|
|
36
36
|
|
|
37
37
|
/** @type {import('.')} */
|
|
38
|
-
export default function ({ split = false, edge =
|
|
38
|
+
export default function ({ split = false, edge = edge_set_in_env_var } = {}) {
|
|
39
39
|
return {
|
|
40
40
|
name: '@sveltejs/adapter-netlify',
|
|
41
41
|
|
|
@@ -50,7 +50,7 @@ export default function ({ split = false, edge = edgeSetInEnvVar } = {}) {
|
|
|
50
50
|
builder.rimraf('.netlify/functions-internal');
|
|
51
51
|
builder.rimraf('.netlify/server');
|
|
52
52
|
builder.rimraf('.netlify/package.json');
|
|
53
|
-
builder.rimraf('.netlify/
|
|
53
|
+
builder.rimraf('.netlify/serverless.js');
|
|
54
54
|
|
|
55
55
|
builder.log.minor(`Publishing to "${publish}"`);
|
|
56
56
|
|
|
@@ -62,7 +62,7 @@ export default function ({ split = false, edge = edgeSetInEnvVar } = {}) {
|
|
|
62
62
|
if (split) {
|
|
63
63
|
throw new Error('Cannot use `split: true` alongside `edge: true`');
|
|
64
64
|
}
|
|
65
|
-
|
|
65
|
+
|
|
66
66
|
await generate_edge_functions({ builder });
|
|
67
67
|
} else {
|
|
68
68
|
await generate_lambda_functions({ builder, esm, split, publish });
|
|
@@ -88,6 +88,12 @@ export default function ({ split = false, edge = edgeSetInEnvVar } = {}) {
|
|
|
88
88
|
* @param {import('@sveltejs/kit').Builder} params.builder
|
|
89
89
|
*/
|
|
90
90
|
async function generate_edge_functions({ builder }) {
|
|
91
|
+
const tmp = builder.getBuildDirectory('netlify-tmp');
|
|
92
|
+
builder.rimraf(tmp);
|
|
93
|
+
builder.mkdirp(tmp);
|
|
94
|
+
|
|
95
|
+
builder.mkdirp('.netlify/edge-functions');
|
|
96
|
+
|
|
91
97
|
// Don't match the static directory
|
|
92
98
|
const pattern = '^/.*$';
|
|
93
99
|
|
|
@@ -104,16 +110,11 @@ async function generate_edge_functions({ builder }) {
|
|
|
104
110
|
],
|
|
105
111
|
version: 1
|
|
106
112
|
};
|
|
107
|
-
const tmp = builder.getBuildDirectory('netlify-tmp');
|
|
108
|
-
|
|
109
|
-
builder.rimraf(tmp);
|
|
110
|
-
|
|
111
|
-
builder.mkdirp('.netlify/edge-functions');
|
|
112
113
|
|
|
113
114
|
builder.log.minor('Generating Edge Function...');
|
|
114
115
|
const relativePath = posix.relative(tmp, builder.getServerDirectory());
|
|
115
116
|
|
|
116
|
-
builder.copy(`${
|
|
117
|
+
builder.copy(`${files}/edge.js`, `${tmp}/entry.js`, {
|
|
117
118
|
replace: {
|
|
118
119
|
'0SERVER': `${relativePath}/index.js`,
|
|
119
120
|
MANIFEST: './manifest.js'
|
|
@@ -204,8 +205,8 @@ function generate_lambda_functions({ builder, publish, split, esm }) {
|
|
|
204
205
|
});
|
|
205
206
|
|
|
206
207
|
const fn = esm
|
|
207
|
-
? `import { init } from '../
|
|
208
|
-
: `const { init } = require('../
|
|
208
|
+
? `import { init } from '../serverless.js';\n\nexport const handler = init(${manifest});\n`
|
|
209
|
+
: `const { init } = require('../serverless.js');\n\nexports.handler = init(${manifest});\n`;
|
|
209
210
|
|
|
210
211
|
writeFileSync(`.netlify/functions-internal/${name}.js`, fn);
|
|
211
212
|
|
|
@@ -222,8 +223,8 @@ function generate_lambda_functions({ builder, publish, split, esm }) {
|
|
|
222
223
|
});
|
|
223
224
|
|
|
224
225
|
const fn = esm
|
|
225
|
-
? `import { init } from '../
|
|
226
|
-
: `const { init } = require('../
|
|
226
|
+
? `import { init } from '../serverless.js';\n\nexport const handler = init(${manifest});\n`
|
|
227
|
+
: `const { init } = require('../serverless.js');\n\nexports.handler = init(${manifest});\n`;
|
|
227
228
|
|
|
228
229
|
writeFileSync('.netlify/functions-internal/render.js', fn);
|
|
229
230
|
redirects.push('* /.netlify/functions/render 200');
|
|
@@ -234,6 +235,7 @@ function generate_lambda_functions({ builder, publish, split, esm }) {
|
|
|
234
235
|
if (existsSync('_redirects')) {
|
|
235
236
|
builder.copy('_redirects', redirect_file);
|
|
236
237
|
}
|
|
238
|
+
builder.mkdirp(dirname(redirect_file));
|
|
237
239
|
appendFileSync(redirect_file, `\n\n${redirects.join('\n')}`);
|
|
238
240
|
}
|
|
239
241
|
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@sveltejs/adapter-netlify",
|
|
3
|
-
"version": "1.0.0-next.
|
|
3
|
+
"version": "1.0.0-next.55",
|
|
4
4
|
"repository": {
|
|
5
5
|
"type": "git",
|
|
6
6
|
"url": "https://github.com/sveltejs/kit",
|
|
@@ -31,7 +31,7 @@
|
|
|
31
31
|
"@rollup/plugin-commonjs": "^21.0.0",
|
|
32
32
|
"@rollup/plugin-json": "^4.1.0",
|
|
33
33
|
"@rollup/plugin-node-resolve": "^13.0.5",
|
|
34
|
-
"@sveltejs/kit": "1.0.0-next.
|
|
34
|
+
"@sveltejs/kit": "1.0.0-next.320",
|
|
35
35
|
"rimraf": "^3.0.2",
|
|
36
36
|
"rollup": "^2.58.0",
|
|
37
37
|
"typescript": "^4.6.2",
|
|
@@ -39,7 +39,7 @@
|
|
|
39
39
|
},
|
|
40
40
|
"scripts": {
|
|
41
41
|
"dev": "rimraf files && rollup -cw",
|
|
42
|
-
"build": "rimraf files && rollup -c",
|
|
42
|
+
"build": "rimraf files && rollup -c && cp src/edge.js files/edge.js",
|
|
43
43
|
"test": "uvu src \"(spec\\.js|test[\\\\/]index\\.js)\"",
|
|
44
44
|
"check": "tsc",
|
|
45
45
|
"lint": "eslint --ignore-path .gitignore \"**/*.{ts,js,svelte}\" && npm run check-format",
|