113 lines
5.2 KiB
JavaScript
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;
|