Module: types
This module contains public types and interfaces of the core package.
Installation​
- npm
- yarn
- pnpm
npm install @auth/core
yarn add @auth/core
pnpm add @auth/core
You can then import this submodule from @auth/core/type
.
Usage​
Even if you don't use TypeScript, IDEs like VSCode will pick up types to provide you with a better developer experience. While you are typing, you will get suggestions about what certain objects/functions look like, and sometimes links to documentation, examples, and other valuable resources.
Generally, you will not need to import types from this module.
Mostly when using the Auth
function and optionally the AuthConfig
interface,
everything inside there will already be typed.
Inside the Auth
function, you won't need to use a single type from this module.
Example
import { Auth } from "@auth/core"
const request = new Request("https://example.com")
const response = await Auth(request, {
callbacks: {
jwt(): JWT { // <-- This is unnecessary!
return { foo: "bar" }
},
session(
{ session, token }: { session: Session; token: JWT } // <-- This is unnecessary!
) {
return session
},
}
})
We are advocates of TypeScript, as it will help you catch errors at build-time, before your users do. 😉
Resources​
Interfaces​
- Account
- CallbacksOptions
- CookieOption
- CookiesOptions
- EventCallbacks
- LoggerInstance
- Profile
- Session
- SessionOptions
- Theme
- User
Type Aliases​
ErrorPageParam​
Ƭ ErrorPageParam: "Configuration"
| "AccessDenied"
| "Verification"
TODO: Check if all these are used/correct
SignInPageErrorParam​
Ƭ SignInPageErrorParam: "Signin"
| "OAuthSignin"
| "OAuthCallback"
| "OAuthCreateAccount"
| "EmailCreateAccount"
| "Callback"
| "OAuthAccountNotLinked"
| "EmailSignin"
| "CredentialsSignin"
| "SessionRequired"
TODO: Check if all these are used/correct
TokenSet​
Ƭ TokenSet: Partial
<OAuth2TokenEndpointResponse
| OpenIDTokenEndpointResponse
>
Different tokens returned by OAuth Providers. Some of them are available with different casing, but they refer to the same value.