@sveltejs/kit 1.0.0-next.519 → 1.0.0-next.520
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.
package/package.json
CHANGED
|
@@ -160,6 +160,8 @@ export async function render_page(event, route, page, options, state, resolve_op
|
|
|
160
160
|
});
|
|
161
161
|
});
|
|
162
162
|
|
|
163
|
+
const csr = get_option(nodes, 'csr') ?? true;
|
|
164
|
+
|
|
163
165
|
/** @type {Array<Promise<Record<string, any> | null>>} */
|
|
164
166
|
const load_promises = nodes.map((node, i) => {
|
|
165
167
|
if (load_error) throw load_error;
|
|
@@ -178,7 +180,8 @@ export async function render_page(event, route, page, options, state, resolve_op
|
|
|
178
180
|
},
|
|
179
181
|
resolve_opts,
|
|
180
182
|
server_data_promise: server_promises[i],
|
|
181
|
-
state
|
|
183
|
+
state,
|
|
184
|
+
csr
|
|
182
185
|
});
|
|
183
186
|
} catch (e) {
|
|
184
187
|
load_error = /** @type {Error} */ (e);
|
|
@@ -74,6 +74,7 @@ export async function load_server_data({ event, state, node, parent }) {
|
|
|
74
74
|
* resolve_opts: import('types').RequiredResolveOptions;
|
|
75
75
|
* server_data_promise: Promise<import('types').ServerDataNode | null>;
|
|
76
76
|
* state: import('types').SSRState;
|
|
77
|
+
* csr: boolean;
|
|
77
78
|
* }} opts
|
|
78
79
|
* @returns {Promise<Record<string, any> | null>}
|
|
79
80
|
*/
|
|
@@ -84,7 +85,8 @@ export async function load_data({
|
|
|
84
85
|
parent,
|
|
85
86
|
server_data_promise,
|
|
86
87
|
state,
|
|
87
|
-
resolve_opts
|
|
88
|
+
resolve_opts,
|
|
89
|
+
csr
|
|
88
90
|
}) {
|
|
89
91
|
const server_data_node = await server_data_promise;
|
|
90
92
|
|
|
@@ -129,23 +131,6 @@ export async function load_data({
|
|
|
129
131
|
response_body: body,
|
|
130
132
|
response: response
|
|
131
133
|
});
|
|
132
|
-
|
|
133
|
-
// ensure that excluded headers can't be read
|
|
134
|
-
const get = response.headers.get;
|
|
135
|
-
response.headers.get = (key) => {
|
|
136
|
-
const lower = key.toLowerCase();
|
|
137
|
-
const value = get.call(response.headers, lower);
|
|
138
|
-
if (value && !lower.startsWith('x-sveltekit-')) {
|
|
139
|
-
const included = resolve_opts.filterSerializedResponseHeaders(lower, value);
|
|
140
|
-
if (!included) {
|
|
141
|
-
throw new Error(
|
|
142
|
-
`Failed to get response header "${lower}" — it must be included by the \`filterSerializedResponseHeaders\` option: https://kit.svelte.dev/docs/hooks#handle`
|
|
143
|
-
);
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
return value;
|
|
148
|
-
};
|
|
149
134
|
}
|
|
150
135
|
|
|
151
136
|
if (dependency) {
|
|
@@ -186,6 +171,25 @@ export async function load_data({
|
|
|
186
171
|
}
|
|
187
172
|
});
|
|
188
173
|
|
|
174
|
+
if (csr) {
|
|
175
|
+
// ensure that excluded headers can't be read
|
|
176
|
+
const get = response.headers.get;
|
|
177
|
+
response.headers.get = (key) => {
|
|
178
|
+
const lower = key.toLowerCase();
|
|
179
|
+
const value = get.call(response.headers, lower);
|
|
180
|
+
if (value && !lower.startsWith('x-sveltekit-')) {
|
|
181
|
+
const included = resolve_opts.filterSerializedResponseHeaders(lower, value);
|
|
182
|
+
if (!included) {
|
|
183
|
+
throw new Error(
|
|
184
|
+
`Failed to get response header "${lower}" — it must be included by the \`filterSerializedResponseHeaders\` option: https://kit.svelte.dev/docs/hooks#handle (at ${event.routeId})`
|
|
185
|
+
);
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
return value;
|
|
190
|
+
};
|
|
191
|
+
}
|
|
192
|
+
|
|
189
193
|
return proxy;
|
|
190
194
|
},
|
|
191
195
|
setHeaders: event.setHeaders,
|
|
@@ -33,6 +33,7 @@ export async function respond_with_error({ event, options, state, status, error,
|
|
|
33
33
|
const branch = [];
|
|
34
34
|
const default_layout = await options.manifest._.nodes[0](); // 0 is always the root layout
|
|
35
35
|
const ssr = get_option([default_layout], 'ssr') ?? true;
|
|
36
|
+
const csr = get_option([default_layout], 'csr') ?? true;
|
|
36
37
|
|
|
37
38
|
if (ssr) {
|
|
38
39
|
state.initiator = GENERIC_ERROR;
|
|
@@ -53,7 +54,8 @@ export async function respond_with_error({ event, options, state, status, error,
|
|
|
53
54
|
parent: async () => ({}),
|
|
54
55
|
resolve_opts,
|
|
55
56
|
server_data_promise,
|
|
56
|
-
state
|
|
57
|
+
state,
|
|
58
|
+
csr
|
|
57
59
|
});
|
|
58
60
|
|
|
59
61
|
branch.push(
|