Skip to content

Commit

Permalink
feat(nuxt): Add Nuxt SDK docs (#1728)
Browse files Browse the repository at this point in the history
Co-authored-by: Brad Cornes <[email protected]>
Co-authored-by: victoria <[email protected]>
Co-authored-by: Alexis Aguilar <[email protected]>
  • Loading branch information
4 people authored Dec 19, 2024
1 parent 2569e26 commit 2aefa83
Show file tree
Hide file tree
Showing 11 changed files with 539 additions and 3 deletions.
15 changes: 15 additions & 0 deletions docs/_partials/nuxt/use-auth.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
The `useAuth()` composable provides access to the current authentication state and methods to manage the active session. You can use this composable to protect [pages](/docs/references/nuxt/protect-pages).

In the following example, the `isLoaded` property checks if Clerk has finished initializing and the `userId` property checks if the user is signed in.

```vue {{ filename: 'pages/protected-page.vue' }}
<script setup>
const { userId, isLoaded } = useAuth()
</script>
<template>
<div v-if="!isLoaded">Loading...</div>
<div v-else-if="!userId">Sign in to access this page</div>
<div v-else>Hello, {{ userId }}!</div>
</template>
```
6 changes: 6 additions & 0 deletions docs/index.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,12 @@ Find all the guides and resources you need to develop with Clerk.

---

- [Nuxt](/docs/quickstarts/nuxt)
- Easily add secure, beautiful, and fast authentication to Nuxt with Clerk.
- {<svg viewBox="0 0 300 300"><path fill="#00DC82" d="M168 250h111c3.542 0 6.932-1.244 10-3 3.068-1.756 6.23-3.959 8-7 1.77-3.041 3.002-6.49 3-10.001-.002-3.511-1.227-6.959-3-9.998L222 91c-1.77-3.04-3.933-5.245-7-7s-7.458-3-11-3-6.933 1.245-10 3-5.23 3.96-7 7l-19 33-38-64.002c-1.772-3.04-3.932-6.243-7-7.998s-6.458-2-10-2-6.932.245-10 2c-3.068 1.755-6.228 4.958-8 7.998L2 220c-1.773 3.039-1.998 6.487-2 9.998-.002 3.511.23 6.96 2 10.001 1.77 3.04 4.932 5.244 8 7 3.068 1.756 6.458 3 10 3h70c27.737 0 47.925-12.442 62-36l34-59 18-31 55 94h-73l-18 32Zm-79-32H40l73-126 37 63-24.509 42.725C116.144 213.01 105.488 218 89 218Z"/></svg>}

---

- [Vue](/docs/quickstarts/vue)
- Get started installing and initializing Clerk in a new Vue + Vite app.
- {<svg viewBox="0 0 196.32 170.02"><path fill="#42b883" d="M120.83 0L98.16 39.26 75.49 0H0l98.16 170.02L196.32 0h-75.49z"/><path fill="#35495e" d="M120.83 0L98.16 39.26 75.49 0H39.26l58.9 102.01L157.06 0h-36.23z"/></svg>}
Expand Down
56 changes: 56 additions & 0 deletions docs/manifest.json
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,11 @@
"tag": "(Beta)",
"href": "/docs/quickstarts/tanstack-start",
"icon": "tanstack"
},
{
"title": "Nuxt",
"href": "/docs/quickstarts/nuxt",
"icon": "nuxt"
}
]
]
Expand Down Expand Up @@ -2691,6 +2696,45 @@
]
]
},
{
"title": "Nuxt",
"collapse": true,
"icon": "nuxt",
"items": [
[
{ "title": "Overview", "href": "/docs/references/nuxt/overview" },
{
"title": "Guides",
"items": [
[
{
"title": "Read session and user data",
"wrap": false,
"href": "/docs/references/nuxt/read-session-data"
},
{
"title": "Protect pages",
"wrap": false,
"href": "/docs/references/nuxt/protect-pages"
}
]
]
},
{
"title": "General Reference",
"items": [
[
{
"title": "`clerkMiddleware()`",
"wrap": false,
"href": "/docs/references/nuxt/clerk-middleware"
}
]
]
}
]
]
},
{
"title": "Vue",
"collapse": true,
Expand Down Expand Up @@ -2755,6 +2799,18 @@
}
]
]
},
{
"title": "General Reference",
"items": [
[
{
"title": "`clerkMiddleware()`",
"wrap": false,
"href": "/docs/references/nuxt/clerk-middleware"
}
]
]
}
]
]
Expand Down
3 changes: 2 additions & 1 deletion docs/manifest.schema.json
Original file line number Diff line number Diff line change
Expand Up @@ -139,7 +139,8 @@
"user-dotted-circle",
"vue",
"x",
"expo"
"expo",
"nuxt"
]
}
}
Expand Down
162 changes: 162 additions & 0 deletions docs/quickstarts/nuxt.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,162 @@
---
title: Nuxt Quickstart
description: Add authentication and user management to your Nuxt app with Clerk.
---

<TutorialHero
framework="vue"
exampleRepo={[
{
title: "Nuxt Quickstart Repo",
link: "https://github.com/clerk/clerk-nuxt-quickstart",
icon: "clerk"
}
]}
beforeYouStart={[
{
title: "Set up a Clerk application",
link: "/docs/quickstarts/setup-clerk",
icon: "clerk",
},
{
title: "Create a Nuxt application",
link: "https://nuxt.com/docs/getting-started/installation",
icon: "nuxt"
}
]}
>
- Install `@clerk/nuxt`
- Set your Clerk API keys
- Configure `nuxt.config.ts`
- Create a header with Clerk components
- Protect your API routes
</TutorialHero>

<Steps>
## Install `@clerk/nuxt`

Clerk's [Nuxt SDK](/docs/references/nuxt/overview) gives you access to prebuilt components, Vue composables, and helpers to make user authentication easier.

Run the following command to install the SDK:

<CodeBlockTabs options={["npm", "yarn", "pnpm" ]}>
```bash {{ filename: 'terminal' }}
npm install @clerk/nuxt
```

```bash {{ filename: 'terminal' }}
yarn add @clerk/nuxt
```

```bash {{ filename: 'terminal' }}
pnpm add @clerk/nuxt
```
</CodeBlockTabs>

## Set your Clerk API keys

<SignedIn>
Add the following keys to your `.env` file. These keys can always be retrieved from the [**API keys**](https://dashboard.clerk.com/last-active?path=api-keys) page in your Clerk Dashboard.
</SignedIn>

<SignedOut>
1. In the Clerk Dashboard, navigate to the [**API Keys**](https://dashboard.clerk.com/last-active?path=api-keys) page.
1. In the **Quick Copy** section, copy your Clerk publishable and secret key.
1. Paste your key into your `.env` file.

The final result should resemble the following:
</SignedOut>

```env {{ filename: '.env' }}
NUXT_PUBLIC_CLERK_PUBLISHABLE_KEY={{pub_key}}
NUXT_CLERK_SECRET_KEY={{secret}}
```

## Configure `nuxt.config.ts`

To enable Clerk in your Nuxt app, add `@clerk/nuxt` to your modules array in `nuxt.config.ts`. This automatically configures Clerk's middleware and plugins and imports Clerk's components.

```ts {{ filename: 'nuxt.config.ts', mark: [2] }}
export default defineNuxtConfig({
modules: ['@clerk/nuxt'],
})
```

## Create a header with Clerk components

Nuxt 3 automatically imports and makes all components in the `components/` directory globally available without requiring explicit imports. See the [Nuxt docs](https://nuxt.com/docs/guide/concepts/auto-imports) for details.

You can control which content signed-in and signed-out users can see with Clerk's [prebuilt control components](/docs/components/overview#what-are-control-components).

The following example creates a header using the following components:

- [`<SignedIn>`](/docs/components/control/signed-in): Children of this component can only be seen while **signed in**.
- [`<SignedOut>`](/docs/components/control/signed-out): Children of this component can only be seen while **signed out**.
- [`<UserButton />`](/docs/components/user/user-button): Shows the signed-in user's avatar. Selecting it opens a dropdown menu with account management options.
- [`<SignInButton />`](/docs/components/unstyled/sign-in-button): An unstyled component that links to the sign-in page or displays the sign-in modal. In this example, since no props or [environment variables](/docs/deployments/clerk-environment-variables) are set for the sign-in URL, this component links to the [Account Portal sign-in page](/docs/customization/account-portal/overview#sign-in).

```vue {{ filename: 'app.vue', mark: [2, [6, 13]] }}
<script setup lang="ts">
// Components are automatically imported
</script>
<template>
<header>
<SignedOut>
<SignInButton />
</SignedOut>
<SignedIn>
<UserButton />
</SignedIn>
</header>
<main>
<NuxtPage />
</main>
</template>
```

## Create your first user

Run your project with the following command:

<CodeBlockTabs options={["npm", "yarn", "pnpm"]}>
```bash {{ filename: 'terminal' }}
npm run dev
```

```bash {{ filename: 'terminal' }}
yarn dev
```

```bash {{ filename: 'terminal' }}
pnpm dev
```
</CodeBlockTabs>

Visit your app's homepage at [`http://localhost:3000`](http://localhost:3000). Sign up to create your first user.
</Steps>

## More resources

Learn more about Clerk components, how to customize them, and how to use Clerk's client-side helpers using the following guides.

<Cards>
- [Protect API routes using `clerkMiddleware()`](/docs/references/nuxt/clerk-middleware)
- Learn how to protect specific API routes from unauthenticated users.

---

- [Read session and user data](/docs/references/nuxt/read-session-data)
- Learn how to use Clerk's composables and helpers to access the active session and user data in your Nuxt app.

---

- [Client-side helpers](/docs/references/nuxt/overview#client-side-helpers)
- Learn more about Nuxt client-side helpers and how to use them.

---

- [Clerk + Nuxt Quickstart Repo](https://github.com/clerk/clerk-nuxt-quickstart)
- The official companion repo for Clerk's Nuxt Quickstart.
</Cards>
6 changes: 6 additions & 0 deletions docs/quickstarts/overview.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,12 @@ description: See the getting started guides and tutorials.
- [TanStack Start (Beta)](/docs/quickstarts/tanstack-start)
- Easily add secure and SSR-friendly authentication to your TanStack Start application with Clerk.
- ![]()

---

- [Nuxt](/docs/quickstarts/nuxt)
- Easily add secure, beautiful, and fast authentication to Nuxt with Clerk.
- {<svg viewBox="0 0 300 300"><path fill="#00DC82" d="M168 250h111c3.542 0 6.932-1.244 10-3 3.068-1.756 6.23-3.959 8-7 1.77-3.041 3.002-6.49 3-10.001-.002-3.511-1.227-6.959-3-9.998L222 91c-1.77-3.04-3.933-5.245-7-7s-7.458-3-11-3-6.933 1.245-10 3-5.23 3.96-7 7l-19 33-38-64.002c-1.772-3.04-3.932-6.243-7-7.998s-6.458-2-10-2-6.932.245-10 2c-3.068 1.755-6.228 4.958-8 7.998L2 220c-1.773 3.039-1.998 6.487-2 9.998-.002 3.511.23 6.96 2 10.001 1.77 3.04 4.932 5.244 8 7 3.068 1.756 6.458 3 10 3h70c27.737 0 47.925-12.442 62-36l34-59 18-31 55 94h-73l-18 32Zm-79-32H40l73-126 37 63-24.509 42.725C116.144 213.01 105.488 218 89 218Z"/></svg>}
</Cards>

## Frontend
Expand Down
24 changes: 22 additions & 2 deletions docs/references/backend/overview.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,7 @@ To access a resource, you must first instantiate a `clerkClient` instance.

To use the default `clerkClient` instance, set your `CLERK_SECRET_KEY` [environment variable](/docs/deployments/clerk-environment-variables#clerk-publishable-and-secret-keys) and then import the `clerkClient` instance from the SDK as shown in the following example:

<Tabs items={["Next.js", "Remix", "Fastify", "Astro", "Express"]}>
<Tabs items={["Next.js", "Remix", "Fastify", "Astro", "Express", "Nuxt"]}>
<Tab>
```jsx
import { clerkClient } from '@clerk/nextjs/server'
Expand Down Expand Up @@ -88,13 +88,19 @@ To access a resource, you must first instantiate a `clerkClient` instance.
import { clerkClient } from '@clerk/express'
```
</Tab>

<Tab>
```js
import { clerkClient } from '@clerk/nuxt/server'
```
</Tab>
</Tabs>

### Instantiate a custom `clerkClient` instance

If you would like to customize the behavior of the JavaScript Backend SDK, you can instantiate a `clerkClient` instance yourself by calling `createClerkClient()` and passing in [`options`](#create-clerk-client-options).

<Tabs items={["Next.js", "Remix", "Fastify", "Astro", "Tanstack Start", "Express"]}>
<Tabs items={["Next.js", "Remix", "Fastify", "Astro", "Tanstack Start", "Express", "Nuxt"]}>
<Tab>
```jsx
import { createClerkClient } from '@clerk/nextjs/server'
Expand Down Expand Up @@ -243,6 +249,20 @@ To access a resource, you must first instantiate a `clerkClient` instance.
```
</CodeBlockTabs>
</Tab>

<Tab>
```tsx {{ filename: 'server/api/users/index.ts' }}
import { createClerkClient } from '@clerk/nuxt/server'

export default defineEventHandler(async () => {
const config = useRuntimeConfig()
const clerkClient = createClerkClient({ secretKey: config.clerk.secretKey })
const userList = await clerkClient.users.getUserList()

return { userList }
})
```
</Tab>
</Tabs>
</Tab>
</Tabs>
Expand Down
Loading

0 comments on commit 2aefa83

Please sign in to comment.