mirror of
https://github.com/gosticks/DefinitelyTyped.git
synced 2025-10-16 12:05:41 +00:00
88 lines
3.1 KiB
TypeScript
88 lines
3.1 KiB
TypeScript
// Type definitions for hapi-auth-cookie 10.0
|
|
// Project: https://github.com/hapijs/hapi-auth-cookie
|
|
// Definitions by: Silas Rech <https://github.com/lenovouser>
|
|
// Simon Schick <https://github.com/SimonSchick>
|
|
// Matt Erickson <https://github.com/Mutmatt>
|
|
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
|
|
// TypeScript Version: 2.8
|
|
|
|
import { Request, ResponseObject, Plugin, ResponseToolkit, AuthCredentials, ServerStateCookieOptions } from 'hapi';
|
|
|
|
declare module 'hapi' {
|
|
interface ServerAuth {
|
|
strategy(name: string, scheme: 'cookie', options?: hapiAuthCookie.Options): void;
|
|
}
|
|
|
|
interface PluginSpecificConfiguration {
|
|
'hapi-auth-cookie'?: {
|
|
redirectTo?: boolean;
|
|
};
|
|
}
|
|
|
|
interface Request {
|
|
cookieAuth: {
|
|
set(session: object): void;
|
|
set(key: string, value: object | string): void;
|
|
clear(key?: string): void;
|
|
ttl(milliseconds: number): void;
|
|
};
|
|
}
|
|
}
|
|
|
|
declare namespace hapiAuthCookie {
|
|
interface ValidateResponse { valid: boolean; credentials?: AuthCredentials; }
|
|
type ValidateFunction = (request?: Request, session?: object) => Promise<ValidateResponse>;
|
|
type RedirectToFunction = (request?: Request) => string;
|
|
|
|
/**
|
|
* Options passed to 'hapi.auth.strategy' when this plugin is used
|
|
*/
|
|
interface Options {
|
|
/**
|
|
* Cookie options.
|
|
*
|
|
* @default { name: 'sid', clearInvalid: false, isSameSite: 'Strict', isSecure: true, isHttpOnly: true }
|
|
*/
|
|
cookie?: ServerStateCookieOptions & { name: string };
|
|
|
|
/**
|
|
* Automatically sets the session cookie after validation to extend the current session for a new TTL duration.
|
|
*
|
|
* @default false
|
|
*/
|
|
keepAlive?: boolean;
|
|
|
|
/**
|
|
* Login URI or function that returns a URI to redirect unauthenticated requests to.
|
|
* Note that it will only trigger when the authentication mode is 'required'.
|
|
* Defaults to no redirection.
|
|
*/
|
|
redirectTo?: string | RedirectToFunction;
|
|
|
|
/**
|
|
* Only works if 'redirectTo' is true
|
|
* If set to true, a string, or an object, appends the current request path to the query component of the 'redirectTo' URI.
|
|
*/
|
|
appendNext?: boolean | string;
|
|
|
|
/**
|
|
* An optional session validation function used to validate the content of the session cookie on each request.
|
|
* Used to verify that the internal session state is still valid (e.g. user account still exists).
|
|
*/
|
|
validateFunc?: ValidateFunction;
|
|
|
|
/**
|
|
* A name to use with decorating the request object.
|
|
* Using multiple decorator names for separate authentication strategies could allow a developer to call the methods for the wrong strategy.
|
|
* Potentially resulting in unintended authorized access.
|
|
*
|
|
* @default 'cookieAuth'
|
|
*/
|
|
requestDecoratorName?: string;
|
|
}
|
|
}
|
|
|
|
declare const hapiAuthCookie: Plugin<void>;
|
|
|
|
export = hapiAuthCookie;
|