mirror of
https://github.com/vitejs/vite.git
synced 2024-11-21 14:48:41 +00:00
fix: backport #18112, fs raw query
This commit is contained in:
parent
aac695e9f8
commit
b901438f99
@ -29,7 +29,7 @@ import { FS_PREFIX } from '../constants'
|
||||
|
||||
export const assetUrlRE = /__VITE_ASSET__([a-z\d]+)__(?:\$_(.*?)__)?/g
|
||||
|
||||
const rawRE = /(?:\?|&)raw(?:&|$)/
|
||||
export const rawRE = /(?:\?|&)raw(?:&|$)/
|
||||
export const urlRE = /(\?|&)url(?:&|$)/
|
||||
const jsSourceMapRE = /\.[cm]?js\.map$/
|
||||
const unnededFinalQueryCharRE = /[?&]$/
|
||||
|
@ -211,7 +211,7 @@ export function isFileServingAllowed(
|
||||
return false
|
||||
}
|
||||
|
||||
function ensureServingAccess(
|
||||
export function ensureServingAccess(
|
||||
url: string,
|
||||
server: ViteDevServer,
|
||||
res: ServerResponse,
|
||||
|
@ -38,7 +38,8 @@ import {
|
||||
} from '../../plugins/optimizedDeps'
|
||||
import { ERR_CLOSED_SERVER } from '../pluginContainer'
|
||||
import { getDepsOptimizer } from '../../optimizer'
|
||||
import { urlRE } from '../../plugins/asset'
|
||||
import { rawRE, urlRE } from '../../plugins/asset'
|
||||
import { ensureServingAccess } from './static'
|
||||
|
||||
const debugCache = createDebugger('vite:cache')
|
||||
|
||||
@ -166,6 +167,13 @@ export function transformMiddleware(
|
||||
}
|
||||
}
|
||||
|
||||
if (
|
||||
(rawRE.test(url) || urlRE.test(url)) &&
|
||||
!ensureServingAccess(url, server, res, next)
|
||||
) {
|
||||
return
|
||||
}
|
||||
|
||||
if (
|
||||
isJSRequest(url) ||
|
||||
isImportRequest(url) ||
|
||||
|
@ -77,6 +77,11 @@ describe.runIf(isServe)('main', () => {
|
||||
expect(await page.textContent('.unsafe-fs-fetch-status')).toBe('403')
|
||||
})
|
||||
|
||||
test('unsafe fs fetch', async () => {
|
||||
expect(await page.textContent('.unsafe-fs-fetch-raw')).toBe('')
|
||||
expect(await page.textContent('.unsafe-fs-fetch-raw-status')).toBe('403')
|
||||
})
|
||||
|
||||
test('unsafe fs fetch with special characters (#8498)', async () => {
|
||||
expect(await page.textContent('.unsafe-fs-fetch-8498')).toBe('')
|
||||
expect(await page.textContent('.unsafe-fs-fetch-8498-status')).toBe('404')
|
||||
|
@ -35,6 +35,8 @@
|
||||
<h2>Unsafe /@fs/ Fetch</h2>
|
||||
<pre class="unsafe-fs-fetch-status"></pre>
|
||||
<pre class="unsafe-fs-fetch"></pre>
|
||||
<pre class="unsafe-fs-fetch-raw-status"></pre>
|
||||
<pre class="unsafe-fs-fetch-raw"></pre>
|
||||
<pre class="unsafe-fs-fetch-8498-status"></pre>
|
||||
<pre class="unsafe-fs-fetch-8498"></pre>
|
||||
<pre class="unsafe-fs-fetch-8498-2-status"></pre>
|
||||
@ -188,6 +190,24 @@
|
||||
console.error(e)
|
||||
})
|
||||
|
||||
// not imported before, outside of root, treated as unsafe
|
||||
fetch(
|
||||
joinUrlSegments(
|
||||
base,
|
||||
joinUrlSegments('/@fs/', ROOT) + '/unsafe.json?import&raw',
|
||||
),
|
||||
)
|
||||
.then((r) => {
|
||||
text('.unsafe-fs-fetch-raw-status', r.status)
|
||||
return r.json()
|
||||
})
|
||||
.then((data) => {
|
||||
text('.unsafe-fs-fetch-raw', JSON.stringify(data))
|
||||
})
|
||||
.catch((e) => {
|
||||
console.error(e)
|
||||
})
|
||||
|
||||
// outside root with special characters #8498
|
||||
fetch(
|
||||
joinUrlSegments(
|
||||
|
Loading…
Reference in New Issue
Block a user