-
Notifications
You must be signed in to change notification settings - Fork 27.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'canary' into not-found-default
- Loading branch information
Showing
11 changed files
with
191 additions
and
19 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,5 @@ | ||
packages/next/bundles/** -text | ||
packages/next/compiled/** -text | ||
packages/next/bundles/** -text linguist-vendored | ||
packages/next/compiled/** -text linguist-vendored | ||
|
||
# Make next/src/build folder indexable for github search | ||
build/** linguist-generated=false |
58 changes: 58 additions & 0 deletions
58
docs/02-app/02-api-reference/04-functions/permanentRedirect.mdx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
--- | ||
title: permanentRedirect | ||
description: API Reference for the permanentRedirect function. | ||
--- | ||
|
||
The `permanentRedirect` function allows you to redirect the user to another URL. `permanentRedirect` can be used in Server Components, Client Components, [Route Handlers](/docs/app/building-your-application/routing/route-handlers), and [Server Actions](/docs/app/building-your-application/data-fetching/forms-and-mutations). | ||
|
||
When used in a streaming context, this will insert a meta tag to emit the redirect on the client side. Otherwise, it will serve a 308 (Permanent) HTTP redirect response to the caller. | ||
|
||
If a resource doesn't exist, you can use the [`notFound` function](/docs/app/api-reference/functions/not-found) instead. | ||
|
||
> **Good to know**: If you prefer to return a 307 (Temporary) HTTP redirect instead of 308 (Permanent), you can use the [`redirect` function](/docs/app/api-reference/functions/redirect) instead. | ||
## Parameters | ||
|
||
The `permanentRedirect` function accepts two arguments: | ||
|
||
```js | ||
permanentRedirect(path, type) | ||
``` | ||
|
||
| Parameter | Type | Description | | ||
| --------- | ------------------------------------------------------------- | ----------------------------------------------------------- | | ||
| `path` | `string` | The URL to redirect to. Can be a relative or absolute path. | | ||
| `type` | `'replace'` (default) or `'push'` (default in Server Actions) | The type of redirect to perform. | | ||
|
||
By default, `permanentRedirect` will use `push` (adding a new entry to the browser history stack) in [Server Actions](/docs/app/building-your-application/data-fetching/forms-and-mutations) and `replace` (replacing the current URL in the browser history stack) everywhere else. You can override this behavior by specifying the `type` parameter. | ||
|
||
The `type` parameter has no effect when used in Server Components. | ||
|
||
## Returns | ||
|
||
`permanentRedirect` does not return any value. | ||
|
||
## Example | ||
|
||
Invoking the `permanentRedirect()` function throws a `NEXT_REDIRECT` error and terminates rendering of the route segment in which it was thrown. | ||
|
||
```jsx filename="app/team/[id]/page.js" | ||
import { permanentRedirect } from 'next/navigation' | ||
|
||
async function fetchTeam(id) { | ||
const res = await fetch('https://...') | ||
if (!res.ok) return undefined | ||
return res.json() | ||
} | ||
|
||
export default async function Profile({ params }) { | ||
const team = await fetchTeam(params.id) | ||
if (!team) { | ||
permanentRedirect('/login') | ||
} | ||
|
||
// ... | ||
} | ||
``` | ||
|
||
> **Good to know**: `permanentRedirect` does not require you to use `return permanentRedirect()` as it uses the TypeScript [`never`](https://www.typescriptlang.org/docs/handbook/2/functions.html#never) type. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
11 changes: 11 additions & 0 deletions
11
packages/next/src/client/components/get-redirect-status-code-from-error.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
import { type RedirectError, isRedirectError } from './redirect' | ||
|
||
export function getRedirectStatusCodeFromError<U extends string>( | ||
error: RedirectError<U> | ||
): number { | ||
if (!isRedirectError(error)) { | ||
throw new Error('Not a redirect error') | ||
} | ||
|
||
return error.digest.split(';', 4)[3] === 'true' ? 308 : 307 | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
6 changes: 6 additions & 0 deletions
6
test/e2e/app-dir/navigation/app/redirect/servercomponent-2/page.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
import { permanentRedirect } from 'next/navigation' | ||
|
||
export default function Page() { | ||
permanentRedirect('/redirect/result') | ||
return <></> | ||
} |
41 changes: 41 additions & 0 deletions
41
test/e2e/app-dir/navigation/app/redirect/suspense-2/page.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
import { Suspense } from 'react' | ||
import { permanentRedirect } from 'next/navigation' | ||
|
||
function createSuspenseyComponent(Component, { timeout = 0, expire = 10 }) { | ||
let result | ||
let promise | ||
return function Data() { | ||
if (result) return result | ||
if (!promise) | ||
promise = new Promise((resolve) => { | ||
setTimeout(() => { | ||
result = <Component /> | ||
setTimeout(() => { | ||
result = undefined | ||
promise = undefined | ||
}, expire) | ||
resolve() | ||
}, timeout) | ||
}) | ||
throw promise | ||
} | ||
} | ||
|
||
function Redirect() { | ||
permanentRedirect('/redirect/result') | ||
return <></> | ||
} | ||
|
||
const SuspenseyRedirect = createSuspenseyComponent(Redirect, { | ||
timeout: 300, | ||
}) | ||
|
||
export default function () { | ||
return ( | ||
<div className="suspense"> | ||
<Suspense fallback="fallback"> | ||
<SuspenseyRedirect /> | ||
</Suspense> | ||
</div> | ||
) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters