/* tslint:disable */ /* eslint-disable */ /** * Bandwidth * Bandwidth\'s Communication APIs * * The version of the OpenAPI document: 1.0.0 * Contact: letstalk@bandwidth.com * * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). * https://openapi-generator.tech * Do not edit the class manually. */ import type { Configuration } from '../configuration'; import type { AxiosPromise, AxiosInstance, RawAxiosRequestConfig } from 'axios'; import globalAxios from 'axios'; // Some imports not used depending on template conditions // @ts-ignore import { DUMMY_BASE_URL, assertParamExists, setApiKeyToObject, setBasicAuthToObject, setBearerAuthToObject, setOAuthToObject, setSearchParams, serializeDataIfNeeded, toPathString, createRequestFunction } from '../common'; // @ts-ignore import { BASE_PATH, COLLECTION_FORMATS, type RequestArgs, BaseAPI, RequiredError, operationServerMap } from '../base'; // @ts-ignore import type { CodeRequest } from '../models'; // @ts-ignore import type { MessagingCodeResponse } from '../models'; // @ts-ignore import type { MfaForbiddenRequestError } from '../models'; // @ts-ignore import type { MfaRequestError } from '../models'; // @ts-ignore import type { MfaUnauthorizedRequestError } from '../models'; // @ts-ignore import type { VerifyCodeRequest } from '../models'; // @ts-ignore import type { VerifyCodeResponse } from '../models'; // @ts-ignore import type { VoiceCodeResponse } from '../models'; /** * MFAApi - axios parameter creator */ export const MFAApiAxiosParamCreator = function (configuration?: Configuration) { return { /** * Send an MFA code via text message (SMS). * @summary Messaging Authentication Code * @param {string} accountId Your Bandwidth Account ID. * @param {CodeRequest} codeRequest MFA code request body. * @param {*} [options] Override http request option. * @throws {RequiredError} */ generateMessagingCode: async (accountId: string, codeRequest: CodeRequest, options: RawAxiosRequestConfig = {}): Promise => { // verify required parameter 'accountId' is not null or undefined assertParamExists('generateMessagingCode', 'accountId', accountId) // verify required parameter 'codeRequest' is not null or undefined assertParamExists('generateMessagingCode', 'codeRequest', codeRequest) const localVarPath = `/accounts/{accountId}/code/messaging` .replace(`{${"accountId"}}`, encodeURIComponent(String(accountId))); // use dummy base URL string because the URL constructor only accepts absolute URLs. const localVarUrlObj = new URL(localVarPath, DUMMY_BASE_URL); let baseOptions; if (configuration) { baseOptions = configuration.baseOptions; } const localVarRequestOptions = { method: 'POST', ...baseOptions, ...options}; const localVarHeaderParameter = {} as any; const localVarQueryParameter = {} as any; // authentication Basic required // http basic authentication required setBasicAuthToObject(localVarRequestOptions, configuration) // authentication OAuth2 required // oauth required await setOAuthToObject(localVarHeaderParameter, "OAuth2", [], configuration) localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; localVarRequestOptions.data = serializeDataIfNeeded(codeRequest, localVarRequestOptions, configuration) return { url: toPathString(localVarUrlObj), options: localVarRequestOptions, }; }, /** * Send an MFA Code via a phone call. * @summary Voice Authentication Code * @param {string} accountId Your Bandwidth Account ID. * @param {CodeRequest} codeRequest MFA code request body. * @param {*} [options] Override http request option. * @throws {RequiredError} */ generateVoiceCode: async (accountId: string, codeRequest: CodeRequest, options: RawAxiosRequestConfig = {}): Promise => { // verify required parameter 'accountId' is not null or undefined assertParamExists('generateVoiceCode', 'accountId', accountId) // verify required parameter 'codeRequest' is not null or undefined assertParamExists('generateVoiceCode', 'codeRequest', codeRequest) const localVarPath = `/accounts/{accountId}/code/voice` .replace(`{${"accountId"}}`, encodeURIComponent(String(accountId))); // use dummy base URL string because the URL constructor only accepts absolute URLs. const localVarUrlObj = new URL(localVarPath, DUMMY_BASE_URL); let baseOptions; if (configuration) { baseOptions = configuration.baseOptions; } const localVarRequestOptions = { method: 'POST', ...baseOptions, ...options}; const localVarHeaderParameter = {} as any; const localVarQueryParameter = {} as any; // authentication Basic required // http basic authentication required setBasicAuthToObject(localVarRequestOptions, configuration) // authentication OAuth2 required // oauth required await setOAuthToObject(localVarHeaderParameter, "OAuth2", [], configuration) localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; localVarRequestOptions.data = serializeDataIfNeeded(codeRequest, localVarRequestOptions, configuration) return { url: toPathString(localVarUrlObj), options: localVarRequestOptions, }; }, /** * Verify a previously sent MFA code. * @summary Verify Authentication Code * @param {string} accountId Your Bandwidth Account ID. * @param {VerifyCodeRequest} verifyCodeRequest MFA code verify request body. * @param {*} [options] Override http request option. * @throws {RequiredError} */ verifyCode: async (accountId: string, verifyCodeRequest: VerifyCodeRequest, options: RawAxiosRequestConfig = {}): Promise => { // verify required parameter 'accountId' is not null or undefined assertParamExists('verifyCode', 'accountId', accountId) // verify required parameter 'verifyCodeRequest' is not null or undefined assertParamExists('verifyCode', 'verifyCodeRequest', verifyCodeRequest) const localVarPath = `/accounts/{accountId}/code/verify` .replace(`{${"accountId"}}`, encodeURIComponent(String(accountId))); // use dummy base URL string because the URL constructor only accepts absolute URLs. const localVarUrlObj = new URL(localVarPath, DUMMY_BASE_URL); let baseOptions; if (configuration) { baseOptions = configuration.baseOptions; } const localVarRequestOptions = { method: 'POST', ...baseOptions, ...options}; const localVarHeaderParameter = {} as any; const localVarQueryParameter = {} as any; // authentication Basic required // http basic authentication required setBasicAuthToObject(localVarRequestOptions, configuration) // authentication OAuth2 required // oauth required await setOAuthToObject(localVarHeaderParameter, "OAuth2", [], configuration) localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; localVarRequestOptions.data = serializeDataIfNeeded(verifyCodeRequest, localVarRequestOptions, configuration) return { url: toPathString(localVarUrlObj), options: localVarRequestOptions, }; }, } }; /** * MFAApi - functional programming interface */ export const MFAApiFp = function(configuration?: Configuration) { const localVarAxiosParamCreator = MFAApiAxiosParamCreator(configuration) return { /** * Send an MFA code via text message (SMS). * @summary Messaging Authentication Code * @param {string} accountId Your Bandwidth Account ID. * @param {CodeRequest} codeRequest MFA code request body. * @param {*} [options] Override http request option. * @throws {RequiredError} */ async generateMessagingCode(accountId: string, codeRequest: CodeRequest, options?: RawAxiosRequestConfig): Promise<(axios?: AxiosInstance, basePath?: string) => AxiosPromise> { const localVarAxiosArgs = await localVarAxiosParamCreator.generateMessagingCode(accountId, codeRequest, options); const localVarOperationServerIndex = configuration?.serverIndex ?? 0; const localVarOperationServerBasePath = operationServerMap['MFAApi.generateMessagingCode']?.[localVarOperationServerIndex]?.url; return (axios, basePath) => createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration)(axios, localVarOperationServerBasePath || basePath); }, /** * Send an MFA Code via a phone call. * @summary Voice Authentication Code * @param {string} accountId Your Bandwidth Account ID. * @param {CodeRequest} codeRequest MFA code request body. * @param {*} [options] Override http request option. * @throws {RequiredError} */ async generateVoiceCode(accountId: string, codeRequest: CodeRequest, options?: RawAxiosRequestConfig): Promise<(axios?: AxiosInstance, basePath?: string) => AxiosPromise> { const localVarAxiosArgs = await localVarAxiosParamCreator.generateVoiceCode(accountId, codeRequest, options); const localVarOperationServerIndex = configuration?.serverIndex ?? 0; const localVarOperationServerBasePath = operationServerMap['MFAApi.generateVoiceCode']?.[localVarOperationServerIndex]?.url; return (axios, basePath) => createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration)(axios, localVarOperationServerBasePath || basePath); }, /** * Verify a previously sent MFA code. * @summary Verify Authentication Code * @param {string} accountId Your Bandwidth Account ID. * @param {VerifyCodeRequest} verifyCodeRequest MFA code verify request body. * @param {*} [options] Override http request option. * @throws {RequiredError} */ async verifyCode(accountId: string, verifyCodeRequest: VerifyCodeRequest, options?: RawAxiosRequestConfig): Promise<(axios?: AxiosInstance, basePath?: string) => AxiosPromise> { const localVarAxiosArgs = await localVarAxiosParamCreator.verifyCode(accountId, verifyCodeRequest, options); const localVarOperationServerIndex = configuration?.serverIndex ?? 0; const localVarOperationServerBasePath = operationServerMap['MFAApi.verifyCode']?.[localVarOperationServerIndex]?.url; return (axios, basePath) => createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration)(axios, localVarOperationServerBasePath || basePath); }, } }; /** * MFAApi - factory interface */ export const MFAApiFactory = function (configuration?: Configuration, basePath?: string, axios?: AxiosInstance) { const localVarFp = MFAApiFp(configuration) return { /** * Send an MFA code via text message (SMS). * @summary Messaging Authentication Code * @param {string} accountId Your Bandwidth Account ID. * @param {CodeRequest} codeRequest MFA code request body. * @param {*} [options] Override http request option. * @throws {RequiredError} */ generateMessagingCode(accountId: string, codeRequest: CodeRequest, options?: RawAxiosRequestConfig): AxiosPromise { return localVarFp.generateMessagingCode(accountId, codeRequest, options).then((request) => request(axios, basePath)); }, /** * Send an MFA Code via a phone call. * @summary Voice Authentication Code * @param {string} accountId Your Bandwidth Account ID. * @param {CodeRequest} codeRequest MFA code request body. * @param {*} [options] Override http request option. * @throws {RequiredError} */ generateVoiceCode(accountId: string, codeRequest: CodeRequest, options?: RawAxiosRequestConfig): AxiosPromise { return localVarFp.generateVoiceCode(accountId, codeRequest, options).then((request) => request(axios, basePath)); }, /** * Verify a previously sent MFA code. * @summary Verify Authentication Code * @param {string} accountId Your Bandwidth Account ID. * @param {VerifyCodeRequest} verifyCodeRequest MFA code verify request body. * @param {*} [options] Override http request option. * @throws {RequiredError} */ verifyCode(accountId: string, verifyCodeRequest: VerifyCodeRequest, options?: RawAxiosRequestConfig): AxiosPromise { return localVarFp.verifyCode(accountId, verifyCodeRequest, options).then((request) => request(axios, basePath)); }, }; }; /** * MFAApi - object-oriented interface */ export class MFAApi extends BaseAPI { /** * Send an MFA code via text message (SMS). * @summary Messaging Authentication Code * @param {string} accountId Your Bandwidth Account ID. * @param {CodeRequest} codeRequest MFA code request body. * @param {*} [options] Override http request option. * @throws {RequiredError} */ public generateMessagingCode(accountId: string, codeRequest: CodeRequest, options?: RawAxiosRequestConfig) { return MFAApiFp(this.configuration).generateMessagingCode(accountId, codeRequest, options).then((request) => request(this.axios, this.basePath)); } /** * Send an MFA Code via a phone call. * @summary Voice Authentication Code * @param {string} accountId Your Bandwidth Account ID. * @param {CodeRequest} codeRequest MFA code request body. * @param {*} [options] Override http request option. * @throws {RequiredError} */ public generateVoiceCode(accountId: string, codeRequest: CodeRequest, options?: RawAxiosRequestConfig) { return MFAApiFp(this.configuration).generateVoiceCode(accountId, codeRequest, options).then((request) => request(this.axios, this.basePath)); } /** * Verify a previously sent MFA code. * @summary Verify Authentication Code * @param {string} accountId Your Bandwidth Account ID. * @param {VerifyCodeRequest} verifyCodeRequest MFA code verify request body. * @param {*} [options] Override http request option. * @throws {RequiredError} */ public verifyCode(accountId: string, verifyCodeRequest: VerifyCodeRequest, options?: RawAxiosRequestConfig) { return MFAApiFp(this.configuration).verifyCode(accountId, verifyCodeRequest, options).then((request) => request(this.axios, this.basePath)); } }