Skip to content

Commit ead85a3

Browse files
author
Peter Bengtsson
authored
Port language-code-redirects.js to TypeScript (#51056)
1 parent 87e8031 commit ead85a3

3 files changed

Lines changed: 42 additions & 9 deletions

File tree

src/frame/middleware/index.ts

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -21,7 +21,7 @@ import detectLanguage from '@/languages/middleware/detect-language'
2121
import reloadTree from './reload-tree'
2222
import context from './context/context'
2323
import shortVersions from '@/versions/middleware/short-versions.js'
24-
import languageCodeRedirects from '@/redirects/middleware/language-code-redirects.js'
24+
import languageCodeRedirects from '@/redirects/middleware/language-code-redirects'
2525
import handleRedirects from '@/redirects/middleware/handle-redirects'
2626
import findPage from './find-page.js'
2727
import blockRobots from './block-robots.js'

src/languages/lib/languages.d.ts

Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
1+
type Language = {
2+
name: string
3+
nativeName?: string
4+
code: string
5+
hreflang: string
6+
redirectPatterns?: RegExp[]
7+
dir: string
8+
}
9+
type Languages = {
10+
[code: string]: Language
11+
}
12+
13+
export const allLanguageKeys: string[]
14+
15+
export const languageKeys: string[]
16+
17+
export const languagePrefixPathRegex: RegExp
18+
19+
export declare function pathLanguagePrefixed(path: string): boolean
20+
21+
const languages: Languages
22+
23+
export default languages

src/redirects/middleware/language-code-redirects.js renamed to src/redirects/middleware/language-code-redirects.ts

Lines changed: 18 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,8 @@
1-
import languages from '#src/languages/lib/languages.js'
2-
import { defaultCacheControl } from '#src/frame/middleware/cache-control.js'
1+
import type { NextFunction, Response } from 'express'
2+
3+
import languages from '@/languages/lib/languages.js'
4+
import { defaultCacheControl } from '@/frame/middleware/cache-control.js'
5+
import { ExtendedRequest } from '@/types'
36

47
const redirectPatterns = Object.values(languages)
58
.map((language) => language.redirectPatterns || [])
@@ -16,14 +19,18 @@ const allRedirectPatterns = Object.values(languages)
1619
.map((language) =>
1720
(language.redirectPatterns || []).map((redirectPattern) => [language.code, redirectPattern]),
1821
)
19-
.flat()
22+
.flat() as [string, RegExp][] // Seems TypeScript didn't understand the .flat()
2023

2124
// This middleware handles redirects for mistyped language codes
2225
//
2326
// Examples:
2427
// /jp* -> /ja*
2528
// /zh-TW* -> /zh*
26-
export default function languageCodeRedirects(req, res, next) {
29+
export default function languageCodeRedirects(
30+
req: ExtendedRequest,
31+
res: Response,
32+
next: NextFunction,
33+
) {
2734
// Only in the unlikely event that the `req.path` starts with one of these
2835
// prefixes do we bother looking up what the redirect should be.
2936
if (req.path.startsWith('/_next/static')) return next()
@@ -32,10 +39,13 @@ export default function languageCodeRedirects(req, res, next) {
3239

3340
// This loop is almost never ever used so it doesn't have to be
3441
// particularly smart or fast.
35-
const [code, pattern] = allRedirectPatterns.find(([, pattern]) => pattern.test(req.path))
36-
if (code && pattern) {
37-
defaultCacheControl(res)
38-
return res.redirect(301, req.path.replace(pattern, `/${code}`))
42+
const matched = allRedirectPatterns.find(([, pattern]) => pattern.test(req.path))
43+
if (matched) {
44+
const [code, pattern] = matched
45+
if (code && pattern) {
46+
defaultCacheControl(res)
47+
return res.redirect(301, req.path.replace(pattern, `/${code}`))
48+
}
3949
}
4050
return next()
4151
}

0 commit comments

Comments
 (0)