support_bot.js aktualisiert

This commit is contained in:
M_Viper 2024-01-14 10:55:31 +01:00
parent 187f11bf01
commit cd2e2fb54c
1 changed files with 261 additions and 132 deletions

View File

@ -3,6 +3,7 @@ const nodemailer = require('nodemailer');
const fs = require('fs').promises; const fs = require('fs').promises;
const yaml = require('js-yaml'); const yaml = require('js-yaml');
const path = require('path'); const path = require('path');
const axios = require('axios');
require('dotenv').config(); require('dotenv').config();
const emailConfig = { const emailConfig = {
@ -12,6 +13,11 @@ const emailConfig = {
}; };
const botToken = process.env.BOT_TOKEN; const botToken = process.env.BOT_TOKEN;
const ADMIN_ID = process.env.ADMIN_ID;
// Lade die erlaubten Admin-IDs aus der .env-Datei
const allowedAdminIds = ADMIN_ID.split(',');
const botInfo = { const botInfo = {
name: 'Telegram Support Bot', name: 'Telegram Support Bot',
@ -24,7 +30,63 @@ const bot = new TelegramBot(botToken, { polling: true });
const ticketCreationStatus = new Map(); const ticketCreationStatus = new Map();
const logoPath = path.join(__dirname, 'logo.png'); // Setze den korrekten Pfad zu deinem Logo const logoPath = path.join(__dirname, 'logo.png');
function sendErrorNotification(error) {
try {
const adminChatId = 5507179337;
bot.sendMessage(adminChatId, `Es ist ein Fehler aufgetreten:\n${error}`)
.catch((adminError) => {
console.error('Fehler beim Senden der Fehlermeldung an den Administrator:', adminError);
});
} catch (sendErrorNotificationError) {
console.error('Fehler beim Senden der Fehlermeldung:', sendErrorNotificationError);
}
}
async function checkBotStatus(chatId) {
try {
const isBotOnline = true;
const statusMessage = isBotOnline ? 'Der Bot ist online.' : 'Der Bot ist offline.';
bot.sendMessage(chatId, statusMessage);
} catch (error) {
console.error('Fehler beim Überprüfen des Bot-Status:', error);
sendErrorNotification(error);
bot.sendMessage(chatId, 'Fehler beim Überprüfen des Bot-Status.');
}
}
async function checkWebsiteStatus(chatId) {
const websites = [
{
name: process.env.WEBSITE_1_NAME,
url: process.env.WEBSITE_1_URL,
},
{
name: process.env.WEBSITE_2_NAME,
url: process.env.WEBSITE_2_URL,
},
];
for (const website of websites) {
try {
const response = await axios.get(website.url);
const statusMessage = `✅ <b>${website.name}</b> ist <i>online</i>.`;
bot.sendMessage(chatId, statusMessage, { parse_mode: 'HTML' });
} catch (error) {
console.error(`Fehler beim Zugriff auf ${website.name}:`, error);
const errorMessage = `❌ <b>${website.name}</b> ist <i>offline</i>. Fehler: ${error.message}`;
sendErrorNotification(errorMessage);
bot.sendMessage(chatId, errorMessage, { parse_mode: 'HTML' });
}
}
}
setInterval(checkWebsiteStatus, 30000);
async function loadFromYaml(filePath) { async function loadFromYaml(filePath) {
try { try {
@ -32,142 +94,213 @@ async function loadFromYaml(filePath) {
return yaml.load(fileContents); return yaml.load(fileContents);
} catch (error) { } catch (error) {
console.error(`Fehler beim Laden der YAML-Datei für ${path.basename(filePath)}:`, error); console.error(`Fehler beim Laden der YAML-Datei für ${path.basename(filePath)}:`, error);
sendErrorNotification(error);
return []; return [];
} }
} }
async function loadLinks() { async function loadLinks() {
const linksDataPath = path.join(__dirname, 'links.yml'); try {
return await loadFromYaml(linksDataPath); const linksDataPath = path.join(__dirname, 'links.yml');
return await loadFromYaml(linksDataPath);
} catch (error) {
console.error('Fehler beim Laden der Links:', error);
sendErrorNotification(error);
return [];
}
} }
async function loadTeam() { async function loadTeam() {
const teamDataPath = path.join(__dirname, 'team.json'); try {
return await loadFromYaml(teamDataPath); const teamDataPath = path.join(__dirname, 'team.json');
return await loadFromYaml(teamDataPath);
} catch (error) {
console.error('Fehler beim Laden des Teams:', error);
sendErrorNotification(error);
return [];
}
} }
async function loadFragen() { async function loadFragen() {
const fragenDataPath = path.join(__dirname, 'fragen.yml'); try {
return await loadFromYaml(fragenDataPath); const fragenDataPath = path.join(__dirname, 'fragen.yml');
return await loadFromYaml(fragenDataPath);
} catch (error) {
console.error('Fehler beim Laden der Fragen:', error);
sendErrorNotification(error);
return [];
}
} }
function sendWelcomeMessage(chatId) { function sendWelcomeMessage(chatId) {
const welcomeMessage = ` const welcomeMessage = `
**Willkommen beim Support!** **Herzlich willkommen beim Support!**
Herzlich willkommen! Wir schätzen es, dass Sie sich für unseren Support entschieden haben. Unser oberstes Ziel ist es, Ihnen bestmöglich zu helfen und Ihre Anliegen so schnell wie möglich zu klären. Wenn Sie Unterstützung benötigen, haben Sie verschiedene Möglichkeiten: Wir freuen uns, dass Sie sich für unseren Support entschieden haben. Unser vorrangiges Ziel ist es, Ihnen bestmöglich zu helfen und Ihre Anliegen so schnell wie möglich zu klären. Falls Sie Unterstützung benötigen, bieten wir Ihnen verschiedene Optionen:
👉 Um unser Menü anzuzeigen, tippen Sie einfach "/menu" ein.
- Um unser Menü anzuzeigen, geben Sie einfach "/menu" ein. 👉 Sollte Ihre Frage nicht beantwortet werden, können Sie unkompliziert ein Ticket erstellen, um spezifische Unterstützung zu erhalten.
- Sollte Ihre Frage nicht beantwortet werden, können Sie ganz einfach ein Ticket erstellen, um spezifische Unterstützung zu erhalten.
Für weitere Hilfe steht Ihnen unser "/help"-Befehl zur Verfügung.
Wir stehen Ihnen zur Verfügung und sind hier, um Ihre Anfragen zu bearbeiten. Bitte geben Sie uns so viele Details wie möglich, damit wir Ihnen effektiv helfen können.
Wir sind jederzeit für Sie da und bearbeiten gerne Ihre Anfragen. Bitte teilen Sie uns so viele Details wie möglich mit, damit wir Ihnen effektiv helfen können.
Vielen Dank für Ihr Vertrauen.
Vielen Dank für Ihr Vertrauen.
Herzliche Grüße,
Das Support-Team Herzliche Grüße,
Das Support-Team
`; `;
bot.sendMessage(chatId, welcomeMessage, { parse_mode: 'Markdown' }); bot.sendMessage(chatId, welcomeMessage, { parse_mode: 'Markdown' });
} }
async function initializeBot() { async function initializeBot() {
const linksData = await loadLinks(); try {
const teamData = await loadTeam(); const linksData = await loadLinks();
const fragenData = await loadFragen(); const teamData = await loadTeam();
const fragenData = await loadFragen();
// Hinzugefügter Abschnitt für den /info-Befehl bot.onText(/\/info/, (msg) => {
bot.onText(/\/info/, (msg) => { const chatId = msg.chat.id;
const chatId = msg.chat.id; console.log('Info-Befehl empfangen:', msg.text);
console.log('Info-Befehl empfangen:', msg.text); showBotInfo(chatId);
showBotInfo(chatId); });
});
// Hinzugefügter Abschnitt für den /logo-Befehl bot.on('message', async (msg) => {
bot.onText(/\/logo/, (msg) => { const chatId = msg.chat.id;
const chatId = msg.chat.id;
bot.sendPhoto(chatId, logoPath, { caption: 'Hier ist unser Logo!' }) // Überprüfe, ob die Nachricht "/help" ist, und sende die Hilfe-Nachricht
.then(() => { if (msg.text && msg.text.toLowerCase() === '/help') {
console.log('Logo erfolgreich gesendet.'); const helpMessage = `
}) 🤖 ${botInfo.name} - Hilfe 🤖
.catch((error) => {
console.error('Fehler beim Senden des Logos:', error); Verfügbare Befehle:
1. /menu - Zeigt das Hauptmenü an.
2. /help - Zeigt diese Hilfe an.
2. /info - Zeigt Informationen zum Bot an.
3. /status - Überprüft den aktuellen Bot- und Webseitenstatus. "Nur für Administrator"
🎫 Ticket erstellen: 🎫
👉 Erstellt ein Support-Ticket.
🔗 Links: 🔗
👉 Zeigt Links zu verschiedenen Kategorien an.
Fragen:
👉 Zeigt häufig gestellte Fragen (FAQs) an.
👮 Team: 👮
👉 Zeigt Informationen zum Support-Team an.
Hinweis: Weitere Funktionen werden folgen
`;
bot.sendMessage(chatId, helpMessage)
.catch((error) => {
console.error('Fehler beim Senden der Hilfe:', error);
});
return;
}
// Überprüfe, ob es sich um den Befehl /menu handelt
if (msg.text === '/menu') {
handleMainMenu(msg, chatId, linksData, fragenData);
return;
}
// Überprüfe, ob es sich um den Befehl /info handelt
if (msg.text && msg.text.toLowerCase() === '/info') {
// Code für den Befehl /info
return;
}
// Überprüfe, ob sich der Benutzer im Ticketerstellungsstatus befindet
if (ticketCreationStatus.has(chatId)) {
handleTicketCreation(msg, chatId, linksData);
return;
}
// Wenn keiner der speziellen Befehle erkannt wurde, sende die Willkommensnachricht
sendWelcomeMessage(chatId);
bot.onText(/\/status/, (msg) => {
const chatId = msg.chat.id;
const userId = msg.from.id;
// Prüfe, ob der Benutzer die Berechtigung hat, den /status-Befehl zu verwenden
if (allowedAdminIds.includes(userId.toString())) {
// Führe die Logik für den /status-Befehl aus
bot.sendMessage(chatId, 'Aktueller Bot- und Webseitenstatus wird abgerufen...');
// Hier kannst du die Logik für den Statusbefehl implementieren
// Z.B., rufe Funktionen auf, um den aktuellen Bot- und Webseitenstatus zu überprüfen
checkBotStatus(chatId);
checkWebsiteStatus(chatId);
} else {
bot.sendMessage(chatId, 'Du hast keine Berechtigung, diesen Befehl zu verwenden.');
}
}); });
}); });
bot.on('message', async (msg) => { bot.on('callback_query', (callbackQuery) => {
const chatId = msg.chat.id; const chatId = callbackQuery.message.chat.id;
const action = callbackQuery.data;
if (msg.text === '/menu') { if (action === 'create_ticket') {
handleMainMenu(msg, chatId, linksData, fragenData); ticketCreationStatus.set(chatId, { step: 'waiting_for_name' });
return; bot.sendMessage(chatId, 'Um ein Ticket zu erstellen, gib bitte deinen Namen ein:')
} .catch((error) => {
console.error('Fehler beim Senden der Aufforderung für den Namen:', error);
});
} else if (action === 'links') {
showLinksMenu(chatId, linksData);
} else if (action.startsWith('links_')) {
const category = action.replace('links_', '');
showLinksInCategory(chatId, category, linksData);
} else if (action === 'team') {
showTeam(chatId, teamData);
} else if (action === 'fragen') {
handleFragen(chatId, fragenData);
} else if (action.startsWith('fragen_')) {
const category = action.replace('fragen_', '');
showFragenInCategory(chatId, category, fragenData);
} else if (action.startsWith('frage_')) {
const questionId = action.replace('frage_', '');
showFrageAnswer(chatId, questionId, fragenData);
} else {
handleMainMenu(callbackQuery.message, chatId, linksData, fragenData);
}
});
if (msg.text && msg.text.toLowerCase() === '/info') { bot.startPolling();
// /info wird nun auch über onText abgefangen
return;
}
if (ticketCreationStatus.has(chatId)) { console.log(`
handleTicketCreation(msg, chatId, linksData); *Bot Information:*
return; - *Name:* ${escapeMarkdown(botInfo.name)}
} - *Version:* ${escapeMarkdown(botInfo.version)}
- *Author:* ${escapeMarkdown(botInfo.author)}
- *License:* ${escapeMarkdown(botInfo.license)}
Bot ist gestartet und bereit.
`);
} catch (error) {
console.error('Fehler beim Initialisieren des Bots:', error);
sendWelcomeMessage(chatId); sendErrorNotification(error);
}); }
bot.on('callback_query', (callbackQuery) => {
const chatId = callbackQuery.message.chat.id;
const action = callbackQuery.data;
if (action === 'create_ticket') {
ticketCreationStatus.set(chatId, { step: 'waiting_for_name' });
bot.sendMessage(chatId, 'Um ein Ticket zu erstellen, gib bitte deinen Namen ein:')
.catch((error) => {
console.error('Fehler beim Senden der Aufforderung für den Namen:', error);
});
} else if (action === 'links') {
showLinksMenu(chatId, linksData);
} else if (action.startsWith('links_')) {
const category = action.replace('links_', '');
showLinksInCategory(chatId, category, linksData);
} else if (action === 'team') {
showTeam(chatId, teamData);
} else if (action === 'fragen') {
handleFragen(chatId, fragenData);
} else if (action.startsWith('fragen_')) {
const category = action.replace('fragen_', '');
showFragenInCategory(chatId, category, fragenData);
} else if (action.startsWith('frage_')) {
const questionId = action.replace('frage_', '');
showFrageAnswer(chatId, questionId, fragenData);
} else {
handleMainMenu(callbackQuery.message, chatId, linksData, fragenData);
}
});
bot.startPolling();
// Logging Bot Information
console.log(`
*Bot Information:*
- *Name:* ${escapeMarkdown(botInfo.name)}
- *Version:* ${escapeMarkdown(botInfo.version)}
- *Author:* ${escapeMarkdown(botInfo.author)}
- *License:* ${escapeMarkdown(botInfo.license)}
Bot ist gestartet und bereit.
`);
} }
function showBotInfo(chatId) { function showBotInfo(chatId) {
// Sende zuerst das Logo bot.sendPhoto(chatId, logoPath, { caption: '*Der Bot wurde am 08.01.2024 erstellt*' })
bot.sendPhoto(chatId, logoPath, { caption: '*Der Bot wurde am 08.01.2024 erstellt' })
.then(() => { .then(() => {
// Dann sende die Bot-Informationen
const botInfoMessage = ` const botInfoMessage = `
*Bot Information:* 🤖Bot Information:🤖
- *Name:* ${escapeMarkdown(botInfo.name)} - *Name:* ${escapeMarkdown(botInfo.name)}
- *Author:* ${escapeMarkdown(botInfo.author)} - *Author:* ${escapeMarkdown(botInfo.author)}
- *License:* ${escapeMarkdown(botInfo.license)} - *License:* ${escapeMarkdown(botInfo.license)}
`; `;
return bot.sendMessage(chatId, botInfoMessage, { parse_mode: 'Markdown' }); return bot.sendMessage(chatId, botInfoMessage, { parse_mode: 'Markdown' });
@ -181,7 +314,6 @@ function showBotInfo(chatId) {
} }
function escapeMarkdown(text) { function escapeMarkdown(text) {
// Funktion zum Hinzufügen von Escape-Zeichen für Markdown-Sonderzeichen
return text.replace(/[_*[\]()~`>#+-=|{}.!]/g, '\\$&'); return text.replace(/[_*[\]()~`>#+-=|{}.!]/g, '\\$&');
} }
@ -225,7 +357,7 @@ function showLinksInCategory(chatId, category, linksData) {
} }
function showTeam(chatId, teamData) { function showTeam(chatId, teamData) {
let teamMessage = 'Unser Team:\n\n'; let teamMessage = '*Unser Team:*\n\n';
teamData.forEach((member) => { teamData.forEach((member) => {
teamMessage += `*Name:* ${member.name}\n*Position:* ${member.position}\n*zuständig:* ${member.zustaendig}\n*Profil:* [Profil](${member.profil})\n\n`; teamMessage += `*Name:* ${member.name}\n*Position:* ${member.position}\n*zuständig:* ${member.zustaendig}\n*Profil:* [Profil](${member.profil})\n\n`;
@ -304,33 +436,30 @@ async function handleTicketCreation(msg, chatId, linksData) {
const userId = msg.from.id; const userId = msg.from.id;
const userStatus = ticketCreationStatus.get(chatId); const userStatus = ticketCreationStatus.get(chatId);
switch (userStatus.step) { try {
case 'waiting_for_name': switch (userStatus.step) {
userStatus.step = 'waiting_for_email'; case 'waiting_for_name':
userStatus.name = msg.text; userStatus.step = 'waiting_for_email';
bot.sendMessage(chatId, 'Danke! Bitte gib nun deine E-Mail-Adresse ein:') userStatus.name = msg.text;
.catch((error) => { bot.sendMessage(chatId, 'Danke! Bitte gib nun deine E-Mail-Adresse ein:');
console.error('Fehler beim Senden der Aufforderung für den Namen:', error); break;
}); case 'waiting_for_email':
break; userStatus.step = 'waiting_for_message';
case 'waiting_for_email': userStatus.email = msg.text;
userStatus.step = 'waiting_for_message'; bot.sendMessage(chatId, 'Vielen Dank! Bitte schreibe jetzt deine Nachricht:');
userStatus.email = msg.text; break;
bot.sendMessage(chatId, 'Vielen Dank! Bitte schreibe jetzt deine Nachricht:') case 'waiting_for_message':
.catch((error) => { userStatus.message = msg.text;
console.error('Fehler beim Senden der Aufforderung für die E-Mail:', error); sendTicketEmail(chatId, userStatus);
}); ticketCreationStatus.delete(chatId);
break; bot.sendMessage(chatId, 'Vielen Dank! Dein Ticket wurde erstellt. Wir melden uns bald bei dir.');
case 'waiting_for_message': handleMainMenu(msg, chatId, linksData);
userStatus.message = msg.text; break;
sendTicketEmail(chatId, userStatus); }
ticketCreationStatus.delete(chatId); } catch (error) {
bot.sendMessage(chatId, 'Vielen Dank! Dein Ticket wurde erstellt. Wir melden uns bald bei dir.') console.error('Fehler beim Ticket-Erstellen:', error);
.catch((error) => { sendErrorNotification(error);
console.error('Fehler beim Senden der Bestätigungsnachricht für das Ticket:', error); bot.sendMessage(chatId, 'Es ist ein Fehler beim Erstellen des Tickets aufgetreten. Bitte versuche es später erneut.');
});
handleMainMenu(msg, chatId, linksData);
break;
} }
} }
@ -356,7 +485,7 @@ function sendTicketEmail(chatId, ticketInfo) {
const mailOptions = { const mailOptions = {
from: `"${ticketInfo.name}" <${emailConfig.user}>`, from: `"${ticketInfo.name}" <${emailConfig.user}>`,
to: emailConfig.recipient, to: emailConfig.recipient,
subject: 'Supportanfrage', subject: 'Telegram Supportanfrage',
text: `Name: ${ticketInfo.name}\nE-Mail: ${ticketInfo.email}\nNachricht: ${ticketInfo.message}`, text: `Name: ${ticketInfo.name}\nE-Mail: ${ticketInfo.email}\nNachricht: ${ticketInfo.message}`,
}; };
@ -377,4 +506,4 @@ function sendTicketEmail(chatId, ticketInfo) {
}); });
} }
initializeBot(); initializeBot();