+ Запросы объеденины в соответствующие модули
+ Оптимизация кода
This commit is contained in:
Alexander Zhirov 2023-06-03 21:27:07 +03:00
parent ab4b8c6bad
commit 2ba510adac
23 changed files with 462 additions and 530 deletions

View file

@ -16,17 +16,8 @@ import verinfo;
import pgdb;
import structures;
import requests.listsgroups;
import requests.groupnumbers;
import requests.editnumber;
import requests.updatenumber;
import requests.addnumber;
import requests.delnumber;
import requests.writenumber;
import requests.smsnumbers;
import requests.listsms;
import requests.viewsms;
import requests.delsms;
import requests.numbers;
import requests.sms;
static ServerInfo serverInfo;
@ -82,15 +73,16 @@ int main(string[] args) {
}
rc.read(flagSettings);
rcAsteriskDB();
auto webHost = rcWebHost();
auto webHost = rcWebHost();
serverInfo = ServerInfo(webHost.title);
if (webHost.loglevel != -1) log.level(webHost.loglevel);
if (webHost.logoutput) log.output(webHost.logoutput);
if (webHost.logfile.length) log.file(webHost.logfile);
rcAsteriskDB();
auto router = new URLRouter;
router.post("/", &postReq);
router.get("/", &getReq);
@ -176,45 +168,47 @@ void postReq(HTTPServerRequest req, HTTPServerResponse res) {
// return;
// }
log.d("json request: " ~ jsr.to!string);
switch (query) {
case "listsgroups":
listsGroups(req, res);
break;
case "groupnumbers":
groupNumbers(req, res);
break;
// case "authorization":
// authorization(req, res);
// break;
// case "logout":
// logout(req, res);
// break;
case "listnumbergroups":
getListNumberGroups(req, res);
break;
case "listgroupnumbers":
getListGroupNumbers(req, res);
break;
case "viewnumber":
getViewNumber(req, res);
break;
case "addnumber":
addNumber(req, res);
getAddNumber(req, res);
break;
case "writenumber":
writeNumber(req, res);
break;
case "editnumber":
editNumber(req, res);
sendWriteNumber(req, res);
break;
case "updatenumber":
updateNumber(req, res);
sendUpdateNumber(req, res);
break;
case "delnumber":
delNumber(req, res);
sendDelNumber(req, res);
break;
case "smsnumbers":
smsNumbers(req, res);
case "listsmsgroups":
getListSMSGroups(req, res);
break;
case "listsms":
listSMS(req, res);
case "listgroupsms":
getListGroupSMS(req, res);
break;
case "viewsms":
viewSMS(req, res);
getViewSMS(req, res);
break;
case "delsms":
delSMS(req, res);
sendDelSMS(req, res);
break;
default:
res.redirect("/");
@ -260,7 +254,7 @@ void rcAsteriskDB() {
" password=" ~ asteriskDB["password"]
);
} catch (Exception e) {
log.c(e);
log.c(e.msg);
exit(1);
}
}

View file

@ -1,18 +0,0 @@
module requests.addnumber;
import vibe.vibe;
import response;
import structures;
import data;
import singlog;
void addNumber(HTTPServerRequest req, HTTPServerResponse res) {
auto jsr = req.json;
bool edit = false;
NumberDB dataNumber;
dataNumber.group = jsr["group"].get!string;
// auto dataNumber = sqlGetDataNumber(jsr["number"].get!string);
auto groups = sqlGetGroups();
auto lists = sqlGetLists();
render!("edit-number.dt", edit, dataNumber, groups, lists)(res);
}

View file

@ -1,24 +0,0 @@
module requests.delnumber;
import vibe.vibe;
import response;
import structures;
import data;
import singlog;
void delNumber(HTTPServerRequest req, HTTPServerResponse res) {
auto jsr = req.json;
string number = jsr["number"].get!string;
if (!number.length) {
res.send(true, "Номер не может быть пуст");
return;
}
if (!sqlDeleteNumber(number)) {
res.send(true, "Не удалось удалить номер");
return;
}
res.send();
}

View file

@ -1,19 +0,0 @@
module requests.delsms;
import vibe.vibe;
import response;
import structures;
import data;
import singlog;
void delSMS(HTTPServerRequest req, HTTPServerResponse res) {
auto jsr = req.json;
int idsms = jsr["id"].get!int;
if (!sqlDeleteSMS(idsms)) {
res.send(true, "Не удалось удалить SMS");
return;
}
res.send();
}

View file

@ -1,15 +0,0 @@
module requests.editnumber;
import vibe.vibe;
import response;
import data;
import singlog;
void editNumber(HTTPServerRequest req, HTTPServerResponse res) {
auto jsr = req.json;
bool edit = true;
auto dataNumber = sqlGetDataNumber(jsr["number"].get!string);
auto groups = sqlGetGroups();
auto lists = sqlGetLists();
render!("edit-number.dt", edit, dataNumber, groups, lists)(res);
}

View file

@ -1,11 +0,0 @@
module requests.groupnumbers;
import vibe.vibe;
import response;
import data;
import singlog;
void groupNumbers(HTTPServerRequest req, HTTPServerResponse res) {
auto jsr = req.json;
res.writeJsonBody(sqlGetListNumbers(jsr["group"].get!string).serializeToJson());
}

View file

@ -1,10 +0,0 @@
module requests.listsgroups;
import vibe.vibe;
import response;
import data;
void listsGroups(HTTPServerRequest req, HTTPServerResponse res) {
auto listGroups = sqlGetListGroups();
render!("group-numbers-list.dt", listGroups)(res);
}

View file

@ -1,10 +0,0 @@
module requests.listsms;
import vibe.vibe;
import response;
import data;
void listSMS(HTTPServerRequest req, HTTPServerResponse res) {
auto jsr = req.json;
res.writeJsonBody(sqlGetListSMS(jsr["to"].get!string).serializeToJson());
}

113
source/requests/numbers.d Normal file
View file

@ -0,0 +1,113 @@
module requests.numbers;
import vibe.vibe;
import response;
import structures;
import sql;
import singlog;
import std.regex;
// Получить список всех групп номеров
void getListNumberGroups(HTTPServerRequest req, HTTPServerResponse res) {
auto listGroups = sqlGetListGroups();
render!("list_number_groups.dt", listGroups)(res);
}
// Получить список номеров конкретной группы
void getListGroupNumbers(HTTPServerRequest req, HTTPServerResponse res) {
auto jsr = req.json;
res.writeJsonBody(sqlGetListNumbers(jsr["group"].get!string).serializeToJson());
}
// Добавление номера телефона
void getAddNumber(HTTPServerRequest req, HTTPServerResponse res) {
auto jsr = req.json;
bool edit = false;
NumberDB dataNumber;
dataNumber.group = jsr["group"].get!string;
auto groups = sqlGetGroups();
auto lists = sqlGetLists();
render!("number.dt", edit, dataNumber, groups, lists)(res);
}
// Просмотр номера телефона
void getViewNumber(HTTPServerRequest req, HTTPServerResponse res) {
auto jsr = req.json;
bool edit = true;
auto dataNumber = sqlGetDataNumber(jsr["number"].get!string);
auto groups = sqlGetGroups();
auto lists = sqlGetLists();
render!("number.dt", edit, dataNumber, groups, lists)(res);
}
// Обновить номер телефона
void sendUpdateNumber(HTTPServerRequest req, HTTPServerResponse res) {
NumberDB number = deserializeJson!NumberDB(req.json);
if (!checkNumber(number, res))
return;
if (!sqlUpdateNumber(number)) {
res.send(true, "Не удалось обновить номер");
return;
}
res.send();
}
// Записать номер телефона
void sendWriteNumber(HTTPServerRequest req, HTTPServerResponse res) {
NumberDB number = deserializeJson!NumberDB(req.json);
if (!checkNumber(number, res))
return;
if (!sqlInsertNumber(number)) {
res.send(true, "Не удалось записать номер");
return;
}
res.send();
}
// Удалить номера телефона
void sendDelNumber(HTTPServerRequest req, HTTPServerResponse res) {
auto jsr = req.json;
string number = jsr["number"].get!string;
if (!number.length) {
res.send(true, "Номер не может быть пуст");
return;
}
if (!sqlDeleteNumber(number)) {
res.send(true, "Не удалось удалить номер");
return;
}
res.send();
}
// Проверка номера перед изменением
bool checkNumber(NumberDB number, HTTPServerResponse res) {
if (!number.number.matchFirst(regex(r"^\+7\d{10}$", "g"))) {
res.send(true, "Номер не соответствует формату +7XXXXXXXXXX");
return false;
}
if (number.all_cc < 0) {
res.send(true, "Общее количество звонков не может быть отрицательным");
return false;
}
if (number.white_cc < 0) {
res.send(true, "Белое количество звонков не может быть отрицательным");
return false;
}
if (number.black_cc < 0) {
res.send(true, "Черное количество звонков не может быть отрицательным");
return false;
}
return true;
}

39
source/requests/sms.d Normal file
View file

@ -0,0 +1,39 @@
module requests.sms;
import vibe.vibe;
import response;
import structures;
import sql;
import singlog;
// Получить список всех групп SMS
void getListSMSGroups(HTTPServerRequest req, HTTPServerResponse res) {
auto numbers = sqlGetSMSNumbers();
render!("list_sms_groups.dt", numbers)(res);
}
// Получить список SMS конкретной группы
void getListGroupSMS(HTTPServerRequest req, HTTPServerResponse res) {
auto jsr = req.json;
res.writeJsonBody(sqlGetListSMS(jsr["to"].get!string).serializeToJson());
}
// Просмотр SMS
void getViewSMS(HTTPServerRequest req, HTTPServerResponse res) {
auto jsr = req.json;
auto dataSMS = sqlGetSMS(jsr["id"].to!int);
render!("sms.dt", dataSMS)(res);
}
// Удалить SMS
void sendDelSMS(HTTPServerRequest req, HTTPServerResponse res) {
auto jsr = req.json;
int idsms = jsr["id"].get!int;
if (!sqlDeleteSMS(idsms)) {
res.send(true, "Не удалось удалить SMS");
return;
}
res.send();
}

View file

@ -1,15 +0,0 @@
module requests.smsnumbers;
import vibe.vibe;
import response;
import data;
import singlog;
void smsNumbers(HTTPServerRequest req, HTTPServerResponse res) {
// auto jsr = req.json;
// bool edit = true;
// auto dataNumber = sqlGetDataNumber(jsr["number"].get!string);
// auto groups = sqlGetGroups();
auto numbers = sqlGetSMSNumbers();
render!("sms-numbers.dt", numbers)(res);
}

View file

@ -1,42 +0,0 @@
module requests.updatenumber;
import vibe.vibe;
import response;
import data;
import singlog;
import structures;
import std.regex;
void updateNumber(HTTPServerRequest req, HTTPServerResponse res) {
NumberDB number = deserializeJson!NumberDB(req.json);
// const string pattern_number = r"^\+7\d{10}$";
// auto regular_number = regex(pattern_number, "g");
if (!number.number.matchFirst(regex(r"^\+7\d{10}$", "g"))) {
res.send(true, "Номер не соответствует формату +7XXXXXXXXXX");
return;
}
if (number.all_cc < 0) {
res.send(true, "Общее количество звонков не может быть отрицательным");
return;
}
if (number.white_cc < 0) {
res.send(true, "Белое количество звонков не может быть отрицательным");
return;
}
if (number.black_cc < 0) {
res.send(true, "Черное количество звонков не может быть отрицательным");
return;
}
if (!sqlUpdateNumber(number)) {
res.send(true, "Не удалось обновить номер");
return;
}
res.send();
}

View file

@ -1,12 +0,0 @@
module requests.viewsms;
import vibe.vibe;
import response;
import data;
import singlog;
void viewSMS(HTTPServerRequest req, HTTPServerResponse res) {
auto jsr = req.json;
auto dataSMS = sqlGetSMS(jsr["id"].to!int);
render!("view-sms.dt", dataSMS)(res);
}

View file

@ -1,42 +0,0 @@
module requests.writenumber;
import vibe.vibe;
import response;
import structures;
import data;
import singlog;
import std.regex;
void writeNumber(HTTPServerRequest req, HTTPServerResponse res) {
NumberDB number = deserializeJson!NumberDB(req.json);
// const string pattern_number = r"^\+7\d{10}$";
// auto regular_number = regex(r"^\+7\d{10}$", "g");
if (!number.number.matchFirst(regex(r"^\+7\d{10}$", "g"))) {
res.send(true, "Номер не соответствует формату +7XXXXXXXXXX");
return;
}
if (number.all_cc < 0) {
res.send(true, "Общее количество звонков не может быть отрицательным");
return;
}
if (number.white_cc < 0) {
res.send(true, "Белое количество звонков не может быть отрицательным");
return;
}
if (number.black_cc < 0) {
res.send(true, "Черное количество звонков не может быть отрицательным");
return;
}
if (!sqlInsertNumber(number)) {
res.send(true, "Не удалось записать номер");
return;
}
res.send();
}

View file

@ -1,4 +1,4 @@
module data;
module sql;
import pgdb;
import singlog;

View file

@ -1,3 +1,3 @@
module version_;
enum dasterVersion = "v0.0.5";
enum dasterVersion = "v0.0.6";