supertokens-node
Version:
NodeJS driver for SuperTokens core
145 lines (144 loc) • 4.5 kB
TypeScript
// @ts-nocheck
import type { BaseRequest, BaseResponse } from "../../framework";
import OverrideableBuilder from "supertokens-js-override";
import { ProviderConfig, ProviderInput } from "../thirdparty/types";
import { GeneralErrorResponse, UserContext } from "../../types";
import RecipeUserId from "../../recipeUserId";
export type TypeInput = {
getAllowedDomainsForTenantId?: (tenantId: string, userContext: UserContext) => Promise<string[] | undefined>;
override?: {
functions?: (originalImplementation: RecipeInterface, builder: OverrideableBuilder<RecipeInterface>) => RecipeInterface;
apis?: (originalImplementation: APIInterface, builder: OverrideableBuilder<APIInterface>) => APIInterface;
};
};
export type TypeNormalisedInput = {
getAllowedDomainsForTenantId?: (tenantId: string, userContext: UserContext) => Promise<string[] | undefined>;
override: {
functions: (originalImplementation: RecipeInterface, builder: OverrideableBuilder<RecipeInterface>) => RecipeInterface;
apis: (originalImplementation: APIInterface, builder: OverrideableBuilder<APIInterface>) => APIInterface;
};
};
export type TenantConfig = {
thirdParty: {
providers: ProviderConfig[];
};
firstFactors?: string[];
requiredSecondaryFactors?: string[];
coreConfig: {
[key: string]: any;
};
};
export type RecipeInterface = {
getTenantId: (input: {
tenantIdFromFrontend: string;
userContext: UserContext;
}) => Promise<string>;
createOrUpdateTenant: (input: {
tenantId: string;
config?: {
firstFactors?: string[] | null;
requiredSecondaryFactors?: string[] | null;
coreConfig?: {
[key: string]: any;
};
};
userContext: UserContext;
}) => Promise<{
status: "OK";
createdNew: boolean;
}>;
deleteTenant: (input: {
tenantId: string;
userContext: UserContext;
}) => Promise<{
status: "OK";
didExist: boolean;
}>;
getTenant: (input: {
tenantId: string;
userContext: UserContext;
}) => Promise<({
status: "OK";
} & TenantConfig) | undefined>;
listAllTenants: (input: {
userContext: UserContext;
}) => Promise<{
status: "OK";
tenants: (TenantConfig & {
tenantId: string;
})[];
}>;
createOrUpdateThirdPartyConfig: (input: {
tenantId: string;
config: ProviderConfig;
skipValidation?: boolean;
userContext: UserContext;
}) => Promise<{
status: "OK";
createdNew: boolean;
}>;
deleteThirdPartyConfig: (input: {
tenantId: string;
thirdPartyId: string;
userContext: UserContext;
}) => Promise<{
status: "OK";
didConfigExist: boolean;
}>;
associateUserToTenant: (input: {
tenantId: string;
recipeUserId: RecipeUserId;
userContext: UserContext;
}) => Promise<{
status: "OK";
wasAlreadyAssociated: boolean;
} | {
status: "UNKNOWN_USER_ID_ERROR" | "EMAIL_ALREADY_EXISTS_ERROR" | "PHONE_NUMBER_ALREADY_EXISTS_ERROR" | "THIRD_PARTY_USER_ALREADY_EXISTS_ERROR";
} | {
status: "ASSOCIATION_NOT_ALLOWED_ERROR";
reason: string;
}>;
disassociateUserFromTenant: (input: {
tenantId: string;
recipeUserId: RecipeUserId;
userContext: UserContext;
}) => Promise<{
status: "OK";
wasAssociated: boolean;
}>;
};
export type APIOptions = {
recipeImplementation: RecipeInterface;
config: TypeNormalisedInput;
recipeId: string;
isInServerlessEnv: boolean;
req: BaseRequest;
res: BaseResponse;
staticThirdPartyProviders: ProviderInput[];
allAvailableFirstFactors: string[];
staticFirstFactors: string[] | undefined;
};
export type APIInterface = {
loginMethodsGET: (input: {
tenantId: string;
clientType?: string;
options: APIOptions;
userContext: UserContext;
}) => Promise<{
status: "OK";
emailPassword: {
enabled: boolean;
};
thirdParty: {
enabled: boolean;
providers: {
id: string;
name?: string;
}[];
};
passwordless: {
enabled: boolean;
};
firstFactors: string[];
} | GeneralErrorResponse>;
};