trackmyd-bot/server.js

152 lines
4.2 KiB
JavaScript
Raw Normal View History

2019-02-19 14:21:58 +01:00
const Telebot = require('telebot');
const config = require('./config');
2019-02-19 14:57:47 +01:00
const utils = require('./utils');
2019-02-20 14:31:23 +01:00
const auth = require('./auth');
2019-02-20 17:48:26 +01:00
const api = require('./api');
2019-02-21 14:56:08 +01:00
const logger = require('./logger');
logger.logConsole('Server started');
logger.logInfo('Server started');
2019-02-19 14:21:58 +01:00
const bot = new Telebot({
token: config.app.tokenBot,
usePlugins: ['askUser'],
});
bot.on('/start', (msg) => {
2019-02-20 17:48:26 +01:00
if (!auth(msg.from.id)) {
return bot.sendMessage(msg.from.id, utils.templateUnauthorizedUser(), { parseMode: 'Markdown' });
}
bot.sendMessage(msg.from.id, utils.templateStart(), { parseMode: 'Markdown' });
bot.event('/help', msg);
2019-02-19 14:21:58 +01:00
});
2019-02-19 14:29:57 +01:00
bot.on('/help', (msg) => {
2019-02-20 17:48:26 +01:00
if (!auth(msg.from.id)) {
return bot.sendMessage(msg.from.id, utils.templateUnauthorizedUser(), { parseMode: 'Markdown' });
}
bot.sendMessage(msg.from.id, utils.templateHelp(), { parseMode: 'Markdown' });
2019-02-19 14:29:57 +01:00
});
bot.on('/list', (msg) => {
2019-02-20 17:48:26 +01:00
if (!auth(msg.from.id)) {
return bot.sendMessage(msg.from.id, utils.templateUnauthorizedUser(), { parseMode: 'Markdown' });
}
api.getDevices()
.then(res => res.json())
.then((json) => {
json.forEach((elem) => {
2019-02-21 14:56:08 +01:00
bot.sendMessage(msg.from.id, utils.templateDevicesList(elem), { parseMode: 'Markdown' });
2019-02-20 17:48:26 +01:00
});
})
.catch((err) => {
2019-02-21 14:56:08 +01:00
bot.sendMessage(msg.from.id, utils.templateError());
logger.logError(err);
2019-02-20 17:48:26 +01:00
});
2019-02-19 14:29:57 +01:00
});
bot.on('/position', (msg) => {
2019-02-20 17:48:26 +01:00
if (!auth(msg.from.id)) {
return bot.sendMessage(msg.from.id, utils.templateUnauthorizedUser(), { parseMode: 'Markdown' });
}
api.getDevices()
.then(res => res.json())
.then((devicesJSON) => {
const devices = [];
devicesJSON.forEach((device) => {
devices.push(device.name);
});
const replyMarkup = bot.keyboard([devices], { resize: true, once: true });
bot.sendMessage(msg.from.id, 'Select device', { ask: 'devicePosition', replyMarkup });
})
.catch((err) => {
2019-02-21 14:56:08 +01:00
bot.sendMessage(msg.from.id, utils.templateError());
logger.logError(err);
2019-02-20 17:48:26 +01:00
});
});
bot.on('ask.devicePosition', (msg) => {
if (!auth(msg.from.id)) {
return bot.sendMessage(msg.from.id, utils.templateUnauthorizedUser(), { parseMode: 'Markdown' });
}
api.getInfoDevice(msg.text)
2019-02-21 14:56:08 +01:00
.then((res) => {
if (res.ok) {
return res.json();
}
return null;
})
2019-02-20 17:48:26 +01:00
.then((json) => {
2019-02-21 14:56:08 +01:00
if (json) {
bot.sendLocation(msg.from.id, [json.position.latitude, json.position.longtitude]);
bot.sendMessage(msg.from.id, utils.templatePosition(json), { parseMode: 'Markdown' });
} else {
bot.sendMessage(msg.from.id, utils.templateDeviceNotFound(msg.text), { parseMode: 'Markdown' });
}
2019-02-20 17:48:26 +01:00
})
.catch((err) => {
2019-02-21 14:56:08 +01:00
bot.sendMessage(msg.from.id, utils.templateError());
logger.logError(err);
2019-02-20 17:48:26 +01:00
});
2019-02-19 14:29:57 +01:00
});
bot.on('/add', (msg) => {
2019-02-20 17:48:26 +01:00
if (!auth(msg.from.id)) {
return bot.sendMessage(msg.from.id, utils.templateUnauthorizedUser(), { parseMode: 'Markdown' });
}
bot.sendMessage(msg.from.id, 'insert name', { ask: 'addDevice' });
});
bot.on('ask.addDevice', (msg) => {
if (!auth(msg.from.id)) {
return bot.sendMessage(msg.from.id, utils.templateUnauthorizedUser(), { parseMode: 'Markdown' });
}
api.addDevice(msg.text)
2019-02-21 14:56:08 +01:00
.then((res) => {
if (res.ok) {
return res.json();
}
return null;
})
2019-02-20 17:48:26 +01:00
.then((json) => {
2019-02-21 14:56:08 +01:00
bot.sendMessage(msg.from.id, utils.templateAddDeviceURL(json));
bot.sendMessage(msg.from.id, utils.templateAddDeviceHeader());
bot.sendMessage(msg.from.id, utils.templateAddDeviceBody());
})
.catch((err) => {
bot.sendMessage(msg.from.id, utils.templateError());
logger.logError(err);
2019-02-20 17:48:26 +01:00
});
2019-02-19 14:29:57 +01:00
});
bot.on('/remove', (msg) => {
2019-02-20 17:48:26 +01:00
bot.sendMessage(msg.from.id, 'Insert Device ID', { ask: 'removeDevice' });
2019-02-19 14:29:57 +01:00
});
2019-02-20 17:48:26 +01:00
bot.on('ask.removeDevice', (msg) => {
api.removeDevice(msg.text)
.then((res) => {
bot.sendMessage(msg.from.id, 'Device Deleted');
})
.catch((err) => {
2019-02-21 14:56:08 +01:00
bot.sendMessage(msg.from.id, utils.templateError());
logger.logError(err);
2019-02-20 17:48:26 +01:00
});
});
2019-02-19 14:21:58 +01:00
bot.start();
2019-02-21 14:56:08 +01:00
process.on('uncaughtException', (err) => {
logger.logError(err);
});
process.on('SIGINT', () => {
logger.logInfo('Server stopped');
logger.logConsole('Server stopped');
process.exit(0);
});