mirror of
https://github.com/LukeHagar/better-auth.git
synced 2025-12-06 12:27:44 +00:00
* fix(email-verification): improve email verification logic to check session and user email consistency (#3042) * docs(passkey): Fixed signIn passkey props (#3014) callbackURL doesn't exist. * fix(email-otp): auto-verify on email otp reset (#3022) * fix: delete user should respect freshAge config (#3075) * fix: delete user needs to enforced through fresh age * cleanup * cleanup * chore(org): add comments explaining what shimContext does (#3098) * feat: Allow passing `id` in DB hook `create` (#3048) * feat(database-hooks): Allow passing `id` in DB hook `create` It's the same to using a custom `idGenerator`, except configurable by the database hook which would in theory provide more data. A use-case is to generate the id based on user info in the user before DB hook. Solves https://discord.com/channels/1288403910284935179/1379190465588367540/1384217435535835216 * chore: lint * fix: tests failing * docs: basic errs with svg props (#3102) * docs: corrected github user email scope name (#3099) * docs: corrected github user email scope name * docs: cubic dev suggestion * fix: use correct refresh token endpoint for github (#3095) * chore: fix typo in authorize comment (#3106) * docs: fix session parameter spelling (#3108) * docs: input field usage on additional fields (#2991) * fix: onLinkAccount trigger on phone number verification (#3007) * fix: expose headers override in jwt plugin (#3019) * expose headers override in jwt plugin * clean up * lint * fix(expo): remove duplicated trusted origins * feat: link account with idToken (#1830) * add idToken to link account * add docs * Implemented linking accounts based on idToken * fix: tests * docs: prevent diff * docs: prevent diff --------- Co-authored-by: kzlar <120426485+kzlar@users.noreply.github.com> * feat: add Hugging Face provider (#3089) * feat: add huggingface provider * Add hugging face to doc * chore: update hugging face logo * chore: release v1.2.10 * docs: fix builder failing to open * docs(NextJS): Improve middleware example to be more secure (#3135) * docs(NextJS): Improve middleware example to be more secure Users can skim code without reading the text, and LLMs can read code and miss-understand context correctly. Our current middleware example only checks for existence of a cookie, and doesn't validate it. While we do warn users this isn't secure, some users has raised concern in a Github issue saying it's not obvious enough for users who skim. Also we don't provide examples on how to authenticate users on each route, we only show middleware optimistic check examples. * Update docs/content/docs/integrations/next.mdx Co-authored-by: cubic-dev-ai[bot] <191113872+cubic-dev-ai[bot]@users.noreply.github.com> --------- Co-authored-by: cubic-dev-ai[bot] <191113872+cubic-dev-ai[bot]@users.noreply.github.com> * fix(username): log the correct username (#3127) * docs: fix typo in plugin (#3122) * typo * typo * typo * typo * typo * docs: fix typos on mcp guide (#3146) * docs: update TanStack Start integration guide (#3142) * fix(sveltekit): only dynamic import $app/environment once (#3152) Co-authored-by: Work <work@Jasons-MacBook-Pro.local> * docs: fix typo in oauth proxy documentation (#3151) * blog: seed round announcement (#3168) * init * cleanup * fix seed round announcemnt * fix seed round announcemnt * seed round blog * add nav mobile * fix typo * Update docs/content/blogs/seed-round.mdx Co-authored-by: cubic-dev-ai[bot] <191113872+cubic-dev-ai[bot]@users.noreply.github.com> * Update docs/app/blog/[[...slug]]/page.tsx Co-authored-by: cubic-dev-ai[bot] <191113872+cubic-dev-ai[bot]@users.noreply.github.com> * Update docs/app/blog/[[...slug]]/page.tsx Co-authored-by: cubic-dev-ai[bot] <191113872+cubic-dev-ai[bot]@users.noreply.github.com> * update og * cleanup --------- Co-authored-by: cubic-dev-ai[bot] <191113872+cubic-dev-ai[bot]@users.noreply.github.com> * docs: fix email address * refactor(mongo-adapter): migrate to createAdapter (#3170) In the past we didn't have mongoDb adapter move over to createAdapter since we've seen users running into issues. However some time ago I've merged a PR which I believe fixed the issue, and after testing the org plugin with the mongo adapter that uses `createAdapter` I don't see any issues. * fix(api-key): update should only use by ID * docs: fix blog page layout (#3176) * fix/blog-page-layouts * clean up * docs: update contact email in seed round blog * init * cleanup * feat(better-auth): add test utilities and update dependencies - Introduced a new test utility module in `src/test-utils/index.ts` for better testing support. - Updated `package.json` to include new test utilities in the build configuration. - Added `oauth2-mock-server` dependency to `pnpm-lock.yaml` and `sso/package.json` for OAuth2 testing. - Enhanced the SSO provider registration process with improved error handling. * docs update --------- Co-authored-by: Maxwell <145994855+ping-maxwell@users.noreply.github.com> Co-authored-by: KinfeMichael Tariku <65047246+Kinfe123@users.noreply.github.com> Co-authored-by: Undefined Ninja <74867549+0xCodeMaieutics@users.noreply.github.com> Co-authored-by: artemoire <18062266+artemoire@users.noreply.github.com> Co-authored-by: reslear <12596485+reslear@users.noreply.github.com> Co-authored-by: kzlar <120426485+kzlar@users.noreply.github.com> Co-authored-by: Eliott C. <coyotte508@protonmail.com> Co-authored-by: cubic-dev-ai[bot] <191113872+cubic-dev-ai[bot]@users.noreply.github.com> Co-authored-by: Alessandro Bortolin <bortolin.alessandro@outlook.it> Co-authored-by: Lakshya Thakur <lapstjup@gmail.com> Co-authored-by: Usman S. (Max Programming) <51731966+max-programming@users.noreply.github.com> Co-authored-by: Jason Venable <jason.venable@gmail.com> Co-authored-by: Work <work@Jasons-MacBook-Pro.local> Co-authored-by: Dan McGrath <daniel.mcgrath9@gmail.com>
132 lines
12 KiB
TypeScript
132 lines
12 KiB
TypeScript
import Link from "next/link";
|
|
import { ThemeToggle } from "@/components/theme-toggler";
|
|
import { NavbarMobile, NavbarMobileBtn } from "./nav-mobile";
|
|
import { NavLink } from "./nav-link";
|
|
import { Logo } from "./logo";
|
|
import LogoContextMenu from "./logo-context-menu";
|
|
import DarkPng from "../public/branding/better-auth-logo-dark.png";
|
|
import WhitePng from "../public/branding/better-auth-logo-light.png";
|
|
export const Navbar = () => {
|
|
const logoAssets = {
|
|
darkSvg: `
|
|
<svg width="500" height="500" viewBox="0 0 500 500" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
<rect width="500" height="500" fill="black"/>
|
|
<rect x="69" y="121" width="86.9879" height="259" fill="white"/>
|
|
<rect x="337.575" y="121" width="92.4247" height="259" fill="white"/>
|
|
<rect x="427.282" y="121" width="83.4555" height="174.52" transform="rotate(90 427.282 121)" fill="white"/>
|
|
<rect x="430" y="296.544" width="83.4555" height="177.238" transform="rotate(90 430 296.544)" fill="white"/>
|
|
<rect x="252.762" y="204.455" width="92.0888" height="96.7741" transform="rotate(90 252.762 204.455)" fill="white"/>
|
|
</svg>
|
|
`,
|
|
whiteSvg: `
|
|
<svg width="500" height="500" viewBox="0 0 500 500" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
<rect width="500" height="500" fill="white"/>
|
|
<rect x="69" y="121" width="86.9879" height="259" fill="black"/>
|
|
<rect x="337.575" y="121" width="92.4247" height="259" fill="black"/>
|
|
<rect x="427.282" y="121" width="83.4555" height="174.52" transform="rotate(90 427.282 121)" fill="black"/>
|
|
<rect x="430" y="296.544" width="83.4555" height="177.238" transform="rotate(90 430 296.544)" fill="black"/>
|
|
<rect x="252.762" y="204.455" width="92.0888" height="96.7741" transform="rotate(90 252.762 204.455)" fill="black"/>
|
|
</svg>
|
|
`,
|
|
darkWordmark: `
|
|
<svg width="1024" height="256" viewBox="0 0 1024 256" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
<rect width="1024" height="256" fill="black"/>
|
|
<rect x="96" y="79" width="34.6988" height="97.5904" fill="white"/>
|
|
<rect x="203.133" y="79" width="36.8675" height="97.5904" fill="white"/>
|
|
<rect x="238.916" y="79" width="31.4458" height="69.6144" transform="rotate(90 238.916 79)" fill="white"/>
|
|
<rect x="240" y="145.145" width="31.4458" height="70.6988" transform="rotate(90 240 145.145)" fill="white"/>
|
|
<rect x="169.301" y="110.446" width="34.6988" height="38.6024" transform="rotate(90 169.301 110.446)" fill="white"/>
|
|
<path d="M281.832 162V93.84H305.256C313.32 93.84 319.368 95.312 323.4 98.256C327.432 101.2 329.448 105.84 329.448 112.176C329.448 116.016 328.36 119.248 326.184 121.872C324.072 124.432 321.128 126.064 317.352 126.768C322.024 127.408 325.672 129.232 328.296 132.24C330.984 135.184 332.328 138.864 332.328 143.28C332.328 149.488 330.312 154.16 326.28 157.296C322.248 160.432 316.52 162 309.096 162H281.832ZM290.088 123.312H305.256C310.248 123.312 314.088 122.384 316.776 120.528C319.464 118.608 320.808 115.952 320.808 112.56C320.808 105.456 315.624 101.904 305.256 101.904H290.088V123.312ZM290.088 153.936H309.096C313.768 153.936 317.352 152.976 319.848 151.056C322.408 149.136 323.688 146.384 323.688 142.8C323.688 139.216 322.408 136.432 319.848 134.448C317.352 132.4 313.768 131.376 309.096 131.376H290.088V153.936ZM345.301 162V93.84H388.117V101.904H353.557V123.888H386.965V131.76H353.557V153.936H388.885V162H345.301ZM416.681 162V101.904H395.465V93.84H446.153V101.904H424.937V162H416.681ZM470.587 162V101.904H449.371V93.84H500.059V101.904H478.843V162H470.587ZM507.113 162V93.84H549.929V101.904H515.369V123.888H548.777V131.76H515.369V153.936H550.697V162H507.113ZM564.02 162V93.84H589.844C597.012 93.84 602.676 95.696 606.836 99.408C610.996 103.12 613.076 108.144 613.076 114.48C613.076 117.104 612.532 119.504 611.444 121.68C610.356 123.792 608.948 125.584 607.22 127.056C605.492 128.528 603.604 129.552 601.556 130.128C604.564 130.64 606.932 131.856 608.66 133.776C610.452 135.696 611.508 138.416 611.828 141.936L613.748 162H605.396L603.667 142.8C603.412 139.984 602.388 137.904 600.596 136.56C598.868 135.216 596.02 134.544 592.052 134.544H572.276V162H564.02ZM572.276 126.48H590.9C595.06 126.48 598.356 125.424 600.788 123.312C603.22 121.2 604.436 118.192 604.436 114.288C604.436 110.32 603.188 107.28 600.692 105.168C598.196 102.992 594.58 101.904 589.844 101.904H572.276V126.48ZM623.912 137.808V130.224H655.688V137.808H623.912ZM661.826 162L686.402 93.84H697.538L722.114 162H713.09L706.274 142.608H677.666L670.85 162H661.826ZM680.45 134.544H703.49L691.97 101.04L680.45 134.544ZM755.651 163.536C750.403 163.536 745.827 162.512 741.923 160.464C738.083 158.416 735.107 155.504 732.995 151.728C730.947 147.888 729.923 143.376 729.923 138.192V93.744H738.179V138.192C738.179 143.696 739.683 147.952 742.691 150.96C745.763 153.968 750.083 155.472 755.651 155.472C761.155 155.472 765.411 153.968 768.419 150.96C771.491 147.952 773.027 143.696 773.027 138.192V93.744H781.283V138.192C781.283 143.376 780.227 147.888 778.115 151.728C776.067 155.504 773.123 158.416 769.283 160.464C765.443 162.512 760.899 163.536 755.651 163.536ZM811.087 162V101.904H789.871V93.84H840.559V101.904H819.343V162H811.087ZM847.613 162V93.84H855.869V123.696H890.141V93.84H898.397V162H890.141V131.76H855.869V162H847.613ZM911.443 162V151.152H922.291V162H911.443Z" fill="white"/>
|
|
</svg>
|
|
`,
|
|
whiteWordmark: `
|
|
<svg width="1024" height="256" viewBox="0 0 1024 256" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
<rect width="1024" height="256" fill="#FFEAEA"/>
|
|
<rect x="96" y="79" width="34.6988" height="97.5904" fill="black"/>
|
|
<rect x="203.133" y="79" width="36.8675" height="97.5904" fill="black"/>
|
|
<rect x="238.916" y="79" width="31.4458" height="69.6144" transform="rotate(90 238.916 79)" fill="black"/>
|
|
<rect x="240" y="145.145" width="31.4458" height="70.6988" transform="rotate(90 240 145.145)" fill="black"/>
|
|
<rect x="169.301" y="110.446" width="34.6988" height="38.6024" transform="rotate(90 169.301 110.446)" fill="black"/>
|
|
<path d="M281.832 162V93.84H305.256C313.32 93.84 319.368 95.312 323.4 98.256C327.432 101.2 329.448 105.84 329.448 112.176C329.448 116.016 328.36 119.248 326.184 121.872C324.072 124.432 321.128 126.064 317.352 126.768C322.024 127.408 325.672 129.232 328.296 132.24C330.984 135.184 332.328 138.864 332.328 143.28C332.328 149.488 330.312 154.16 326.28 157.296C322.248 160.432 316.52 162 309.096 162H281.832ZM290.088 123.312H305.256C310.248 123.312 314.088 122.384 316.776 120.528C319.464 118.608 320.808 115.952 320.808 112.56C320.808 105.456 315.624 101.904 305.256 101.904H290.088V123.312ZM290.088 153.936H309.096C313.768 153.936 317.352 152.976 319.848 151.056C322.408 149.136 323.688 146.384 323.688 142.8C323.688 139.216 322.408 136.432 319.848 134.448C317.352 132.4 313.768 131.376 309.096 131.376H290.088V153.936ZM345.301 162V93.84H388.117V101.904H353.557V123.888H386.965V131.76H353.557V153.936H388.885V162H345.301ZM416.681 162V101.904H395.465V93.84H446.153V101.904H424.937V162H416.681ZM470.587 162V101.904H449.371V93.84H500.059V101.904H478.843V162H470.587ZM507.113 162V93.84H549.929V101.904H515.369V123.888H548.777V131.76H515.369V153.936H550.697V162H507.113ZM564.02 162V93.84H589.844C597.012 93.84 602.676 95.696 606.836 99.408C610.996 103.12 613.076 108.144 613.076 114.48C613.076 117.104 612.532 119.504 611.444 121.68C610.356 123.792 608.948 125.584 607.22 127.056C605.492 128.528 603.604 129.552 601.556 130.128C604.564 130.64 606.932 131.856 608.66 133.776C610.452 135.696 611.508 138.416 611.828 141.936L613.748 162H605.396L603.667 142.8C603.412 139.984 602.388 137.904 600.596 136.56C598.868 135.216 596.02 134.544 592.052 134.544H572.276V162H564.02ZM572.276 126.48H590.9C595.06 126.48 598.356 125.424 600.788 123.312C603.22 121.2 604.436 118.192 604.436 114.288C604.436 110.32 603.188 107.28 600.692 105.168C598.196 102.992 594.58 101.904 589.844 101.904H572.276V126.48ZM623.912 137.808V130.224H655.688V137.808H623.912ZM661.826 162L686.402 93.84H697.538L722.114 162H713.09L706.274 142.608H677.666L670.85 162H661.826ZM680.45 134.544H703.49L691.97 101.04L680.45 134.544ZM755.651 163.536C750.403 163.536 745.827 162.512 741.923 160.464C738.083 158.416 735.107 155.504 732.995 151.728C730.947 147.888 729.923 143.376 729.923 138.192V93.744H738.179V138.192C738.179 143.696 739.683 147.952 742.691 150.96C745.763 153.968 750.083 155.472 755.651 155.472C761.155 155.472 765.411 153.968 768.419 150.96C771.491 147.952 773.027 143.696 773.027 138.192V93.744H781.283V138.192C781.283 143.376 780.227 147.888 778.115 151.728C776.067 155.504 773.123 158.416 769.283 160.464C765.443 162.512 760.899 163.536 755.651 163.536ZM811.087 162V101.904H789.871V93.84H840.559V101.904H819.343V162H811.087ZM847.613 162V93.84H855.869V123.696H890.141V93.84H898.397V162H890.141V131.76H855.869V162H847.613ZM911.443 162V151.152H922.291V162H911.443Z" fill="black"/>
|
|
</svg>
|
|
`,
|
|
darkPng: DarkPng,
|
|
whitePng: WhitePng,
|
|
};
|
|
return (
|
|
<div className="flex flex-col sticky top-0 bg-background backdrop-blur-md z-30">
|
|
<nav className="md:grid grid-cols-12 md:border-b top-0 flex items-center justify-between">
|
|
<Link
|
|
href="/"
|
|
className="md:border-r md:px-5 px-2.5 py-4 text-foreground md:col-span-2 shrink-0 transition-colors md:w-[268px] lg:w-[286px]"
|
|
>
|
|
<div className="flex flex-col gap-2 w-full">
|
|
<LogoContextMenu
|
|
logo={
|
|
<div className="flex items-center gap-2">
|
|
<Logo />
|
|
<p className="select-none">BETTER-AUTH.</p>
|
|
</div>
|
|
}
|
|
logoAssets={logoAssets}
|
|
/>
|
|
</div>
|
|
</Link>
|
|
<div className="md:col-span-10 flex items-center justify-end relative">
|
|
<ul className="md:flex items-center divide-x w-max hidden shrink-0">
|
|
{navMenu.map((menu, i) => (
|
|
<NavLink key={menu.name} href={menu.path}>
|
|
{menu.name}
|
|
</NavLink>
|
|
))}
|
|
<NavLink
|
|
href="https://github.com/better-auth/better-auth"
|
|
className=" bg-muted/20"
|
|
external
|
|
>
|
|
<svg
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
width="1.4em"
|
|
height="1.4em"
|
|
viewBox="0 0 496 512"
|
|
>
|
|
<path
|
|
fill="currentColor"
|
|
d="M165.9 397.4c0 2-2.3 3.6-5.2 3.6c-3.3.3-5.6-1.3-5.6-3.6c0-2 2.3-3.6 5.2-3.6c3-.3 5.6 1.3 5.6 3.6m-31.1-4.5c-.7 2 1.3 4.3 4.3 4.9c2.6 1 5.6 0 6.2-2s-1.3-4.3-4.3-5.2c-2.6-.7-5.5.3-6.2 2.3m44.2-1.7c-2.9.7-4.9 2.6-4.6 4.9c.3 2 2.9 3.3 5.9 2.6c2.9-.7 4.9-2.6 4.6-4.6c-.3-1.9-3-3.2-5.9-2.9M244.8 8C106.1 8 0 113.3 0 252c0 110.9 69.8 205.8 169.5 239.2c12.8 2.3 17.3-5.6 17.3-12.1c0-6.2-.3-40.4-.3-61.4c0 0-70 15-84.7-29.8c0 0-11.4-29.1-27.8-36.6c0 0-22.9-15.7 1.6-15.4c0 0 24.9 2 38.6 25.8c21.9 38.6 58.6 27.5 72.9 20.9c2.3-16 8.8-27.1 16-33.7c-55.9-6.2-112.3-14.3-112.3-110.5c0-27.5 7.6-41.3 23.6-58.9c-2.6-6.5-11.1-33.3 2.6-67.9c20.9-6.5 69 27 69 27c20-5.6 41.5-8.5 62.8-8.5s42.8 2.9 62.8 8.5c0 0 48.1-33.6 69-27c13.7 34.7 5.2 61.4 2.6 67.9c16 17.7 25.8 31.5 25.8 58.9c0 96.5-58.9 104.2-114.8 110.5c9.2 7.9 17 22.9 17 46.4c0 33.7-.3 75.4-.3 83.6c0 6.5 4.6 14.4 17.3 12.1C428.2 457.8 496 362.9 496 252C496 113.3 383.5 8 244.8 8M97.2 352.9c-1.3 1-1 3.3.7 5.2c1.6 1.6 3.9 2.3 5.2 1c1.3-1 1-3.3-.7-5.2c-1.6-1.6-3.9-2.3-5.2-1m-10.8-8.1c-.7 1.3.3 2.9 2.3 3.9c1.6 1 3.6.7 4.3-.7c.7-1.3-.3-2.9-2.3-3.9c-2-.6-3.6-.3-4.3.7m32.4 35.6c-1.6 1.3-1 4.3 1.3 6.2c2.3 2.3 5.2 2.6 6.5 1c1.3-1.3.7-4.3-1.3-6.2c-2.2-2.3-5.2-2.6-6.5-1m-11.4-14.7c-1.6 1-1.6 3.6 0 5.9s4.3 3.3 5.6 2.3c1.6-1.3 1.6-3.9 0-6.2c-1.4-2.3-4-3.3-5.6-2"
|
|
></path>
|
|
</svg>
|
|
</NavLink>
|
|
</ul>
|
|
<ThemeToggle />
|
|
<NavbarMobileBtn />
|
|
</div>
|
|
</nav>
|
|
<NavbarMobile />
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export const navMenu = [
|
|
{
|
|
name: "helo_",
|
|
path: "/",
|
|
},
|
|
{
|
|
name: "docs",
|
|
|
|
path: "/docs",
|
|
},
|
|
{
|
|
name: "changelogs",
|
|
path: "/changelogs",
|
|
},
|
|
{
|
|
name: "blogs",
|
|
path: "/blog",
|
|
},
|
|
{
|
|
name: "community",
|
|
path: "/community",
|
|
},
|
|
];
|