/*****************************************************************************\ | █████ █████ ██ █ █████ █████ ████ ██ ████ █████ █████ ███ ® | | ██ █ ███ █ █ ██ ██ ██ ██ ██ ██ █ ██ ██ █ █ | | ██ ███ ████ █ ██ █ ████ █████ ██████ ██ ████ █ █ █ ██ | | ██ ██ █ █ ██ █ █ ██ ██ ██ ██ ██ ██ █ ██ ██ █ █ | | █████ █████ █ ███ █████ ██ ██ ██ ██ █████ ████ █████ █ ███ | | | | General Bots Copyright (c) pragmatismo.cloud. All rights reserved. | | Licensed under the AGPL-3.0. | | | | According to our dual licensing model, this program can be used either | | under the terms of the GNU Affero General Public License, version 3, | | or under a proprietary license. | | | | The texts of the GNU Affero General Public License with an additional | | permission and of our proprietary license can be found at and | | in the LICENSE file you have received along with this program. | | | | This program is distributed in the hope that it will be useful, | | but WITHOUT ANY WARRANTY, without even the implied warranty of | | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | | GNU Affero General Public License for more details. | | | | "General Bots" is a registered trademark of pragmatismo.cloud. | | The licensing of the program under the AGPLv3 does not imply a | | trademark license. Therefore any rights, title and interest in | | our trademarks remain entirely with us. | | | \*****************************************************************************/ /** * @fileoverview Dialog for handling OAuth scenarios. */ 'use strict'; import { TokenResponse } from 'botbuilder'; import { GBLog, GBMinInstance, IGBDialog } from 'botlib'; import { Messages } from '../strings.js'; import { GBAdminService } from '../../admin.gbapp/services/GBAdminService.js'; import { SecService } from '../services/SecService.js'; import { GBLogEx } from '../../core.gbapp/services/GBLogEx.js'; /** * Dialogs for handling Menu control. */ export class SMSAuthDialog extends IGBDialog { public static getSMSAuthDialog(min: GBMinInstance) { return { id: '/smsauth', waterfall: [ async (step) => { const msg = 'Por favor, qual o seu celular? Ex: 55 21 99999-0000.'; step.activeDialog.state.resetInfo = {}; return await min.conversationalService.prompt(min, step, msg); }, async (step) => { await step.context.sendActivity('Por favor, digite o código enviado para seu celular.'); const mobile = step.result.replace(/\+|\s|\-/g, ''); const locale = step.context.activity.locale; step.activeDialog.state.resetInfo.mobile = mobile; // Generates a new mobile code. let code = GBAdminService.getMobileCode(); GBLogEx.info(min, `SMS Auth: Generated new code: ${code} is being sent.`); step.activeDialog.state.resetInfo.sentCode = code; step.activeDialog.state.resetInfo.mobile = mobile; // Sends a confirmation SMS. await min.conversationalService.sendSms(min, mobile, Messages[locale].please_use_code(code)); return await min.conversationalService.prompt(min, step, Messages[locale].confirm_mobile); }, async (step) => { const typed = step.result; const locale = step.context.activity.locale; // Checks if the typed code is equal to the one // sent to the registered mobile. if (typed == step.activeDialog.state.resetInfo.sentCode) { let sec = new SecService(); const member = step.context.activity.from; GBLogEx.info(min, `SMS Auth: User Authenticated.`); await step.context.sendActivity(Messages[locale].authenticated); return await step.endDialog(step.activeDialog.state.resetInfo.mobile); } else { await step.context.sendActivity(Messages[locale].not_authorized); return await step.endDialog(false); } } ] }; } }