Files
Tg-job/mtucijobsbot/dist/modules/scenes/accept.js

113 lines
5.2 KiB
JavaScript

"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.accept = void 0;
const axios_1 = __importDefault(require("axios"));
require("dotenv/config");
// const API_BASE_URL = 'https://mtucitech.ru/api/external/mtuci_jobs';
// const BEARER_TOKEN = 'zKbgaXQv{pvGtQm~U9$urtD#QsiHc@Ie';
function accept(bot) {
bot.action('accept', (ctx) => __awaiter(this, void 0, void 0, function* () {
var _a;
try {
const response = yield axios_1.default.get(`${process.env.MTUCI_TECH}/check?telegram_id=${ctx.from.id}`, {
headers: {
Authorization: `Bearer ${process.env.BEARER_TOKEN}`,
},
});
const data = response.data;
// Логика обработки ответа
switch (data.status) {
case 338:
ctx.answerCbQuery('Ошибка на стороне сервера. Пожалуйста, сообщите нам.');
break;
case 339:
ctx.answerCbQuery('Пользователь не привязан к проекту.');
break;
case 340:
ctx.reply('Можете заполнить своё резюме', {
reply_markup: {
inline_keyboard: [
[
{
text: 'Резюме',
web_app: { url: process.env.WEB_APP || '' },
},
],
],
resize_keyboard: true,
one_time_keyboard: true,
},
});
ctx.answerCbQuery('Пользователь найден, но не привязан LMS.');
break;
case 341:
ctx.reply('Можете заполнить своё резюме', {
reply_markup: {
inline_keyboard: [
[
{
text: 'Резюме',
web_app: { url: process.env.WEB_APP || '' },
},
],
],
resize_keyboard: true,
one_time_keyboard: true,
},
});
ctx.answerCbQuery('Пользователь найден, LMS привязан. Можно запросить дополнительные данные.');
default:
ctx.answerCbQuery('Неизвестный статус.');
break;
}
}
catch (error) {
if (axios_1.default.isAxiosError(error)) {
// Обработка ошибок Axios
if (error.response && error.response.status === 409) {
ctx.answerCbQuery('Вакансия уже добавлена в избранное');
}
else {
ctx.answerCbQuery('Произошла ошибка');
console.error(((_a = error.response) === null || _a === void 0 ? void 0 : _a.data) || error.message);
}
}
else {
// Обработка других типов ошибок
ctx.answerCbQuery('Произошла неизвестная ошибка');
console.error(error);
}
}
}));
bot.action('accept2', (ctx) => __awaiter(this, void 0, void 0, function* () {
ctx.reply('Можете заполнить своё резюме', {
reply_markup: {
inline_keyboard: [
[
{
text: 'Резюме',
web_app: { url: process.env.WEB_APP || '' },
},
],
],
resize_keyboard: true,
one_time_keyboard: true,
},
});
ctx.answerCbQuery();
}));
}
exports.accept = accept;