/* tslint:disable */ /* eslint-disable */ /** * authentik * Making authentication simple. * * The version of the OpenAPI document: 2025.6.3 * Contact: hello@goauthentik.io * * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). * https://openapi-generator.tech * Do not edit the class manually. */ import { mapValues } from '../runtime'; import type { FlowSet } from './FlowSet'; import { FlowSetFromJSON, FlowSetFromJSONTyped, FlowSetToJSON, FlowSetToJSONTyped, } from './FlowSet'; import type { ProviderEnum } from './ProviderEnum'; import { ProviderEnumFromJSON, ProviderEnumFromJSONTyped, ProviderEnumToJSON, ProviderEnumToJSONTyped, } from './ProviderEnum'; import type { AuthTypeEnum } from './AuthTypeEnum'; import { AuthTypeEnumFromJSON, AuthTypeEnumFromJSONTyped, AuthTypeEnumToJSON, AuthTypeEnumToJSONTyped, } from './AuthTypeEnum'; /** * AuthenticatorSMSStage Serializer * @export * @interface AuthenticatorSMSStage */ export interface AuthenticatorSMSStage { /** * * @type {string} * @memberof AuthenticatorSMSStage */ readonly pk: string; /** * * @type {string} * @memberof AuthenticatorSMSStage */ name: string; /** * Get object type so that we know how to edit the object * @type {string} * @memberof AuthenticatorSMSStage */ readonly component: string; /** * Return object's verbose_name * @type {string} * @memberof AuthenticatorSMSStage */ readonly verboseName: string; /** * Return object's plural verbose_name * @type {string} * @memberof AuthenticatorSMSStage */ readonly verboseNamePlural: string; /** * Return internal model name * @type {string} * @memberof AuthenticatorSMSStage */ readonly metaModelName: string; /** * * @type {Array} * @memberof AuthenticatorSMSStage */ flowSet?: Array; /** * Flow used by an authenticated user to configure this Stage. If empty, user will not be able to configure this stage. * @type {string} * @memberof AuthenticatorSMSStage */ configureFlow?: string | null; /** * * @type {string} * @memberof AuthenticatorSMSStage */ friendlyName?: string | null; /** * * @type {ProviderEnum} * @memberof AuthenticatorSMSStage */ provider: ProviderEnum; /** * * @type {string} * @memberof AuthenticatorSMSStage */ fromNumber: string; /** * * @type {string} * @memberof AuthenticatorSMSStage */ accountSid: string; /** * * @type {string} * @memberof AuthenticatorSMSStage */ auth: string; /** * * @type {string} * @memberof AuthenticatorSMSStage */ authPassword?: string; /** * * @type {AuthTypeEnum} * @memberof AuthenticatorSMSStage */ authType?: AuthTypeEnum; /** * When enabled, the Phone number is only used during enrollment to verify the users authenticity. Only a hash of the phone number is saved to ensure it is not reused in the future. * @type {boolean} * @memberof AuthenticatorSMSStage */ verifyOnly?: boolean; /** * Optionally modify the payload being sent to custom providers. * @type {string} * @memberof AuthenticatorSMSStage */ mapping?: string | null; } /** * Check if a given object implements the AuthenticatorSMSStage interface. */ export function instanceOfAuthenticatorSMSStage(value: object): value is AuthenticatorSMSStage { if (!('pk' in value) || value['pk'] === undefined) return false; if (!('name' in value) || value['name'] === undefined) return false; if (!('component' in value) || value['component'] === undefined) return false; if (!('verboseName' in value) || value['verboseName'] === undefined) return false; if (!('verboseNamePlural' in value) || value['verboseNamePlural'] === undefined) return false; if (!('metaModelName' in value) || value['metaModelName'] === undefined) return false; if (!('provider' in value) || value['provider'] === undefined) return false; if (!('fromNumber' in value) || value['fromNumber'] === undefined) return false; if (!('accountSid' in value) || value['accountSid'] === undefined) return false; if (!('auth' in value) || value['auth'] === undefined) return false; return true; } export function AuthenticatorSMSStageFromJSON(json: any): AuthenticatorSMSStage { return AuthenticatorSMSStageFromJSONTyped(json, false); } export function AuthenticatorSMSStageFromJSONTyped(json: any, ignoreDiscriminator: boolean): AuthenticatorSMSStage { if (json == null) { return json; } return { 'pk': json['pk'], 'name': json['name'], 'component': json['component'], 'verboseName': json['verbose_name'], 'verboseNamePlural': json['verbose_name_plural'], 'metaModelName': json['meta_model_name'], 'flowSet': json['flow_set'] == null ? undefined : ((json['flow_set'] as Array).map(FlowSetFromJSON)), 'configureFlow': json['configure_flow'] == null ? undefined : json['configure_flow'], 'friendlyName': json['friendly_name'] == null ? undefined : json['friendly_name'], 'provider': ProviderEnumFromJSON(json['provider']), 'fromNumber': json['from_number'], 'accountSid': json['account_sid'], 'auth': json['auth'], 'authPassword': json['auth_password'] == null ? undefined : json['auth_password'], 'authType': json['auth_type'] == null ? undefined : AuthTypeEnumFromJSON(json['auth_type']), 'verifyOnly': json['verify_only'] == null ? undefined : json['verify_only'], 'mapping': json['mapping'] == null ? undefined : json['mapping'], }; } export function AuthenticatorSMSStageToJSON(json: any): AuthenticatorSMSStage { return AuthenticatorSMSStageToJSONTyped(json, false); } export function AuthenticatorSMSStageToJSONTyped(value?: Omit | null, ignoreDiscriminator: boolean = false): any { if (value == null) { return value; } return { 'name': value['name'], 'flow_set': value['flowSet'] == null ? undefined : ((value['flowSet'] as Array).map(FlowSetToJSON)), 'configure_flow': value['configureFlow'], 'friendly_name': value['friendlyName'], 'provider': ProviderEnumToJSON(value['provider']), 'from_number': value['fromNumber'], 'account_sid': value['accountSid'], 'auth': value['auth'], 'auth_password': value['authPassword'], 'auth_type': AuthTypeEnumToJSON(value['authType']), 'verify_only': value['verifyOnly'], 'mapping': value['mapping'], }; }