v0.0.5
+ Добавлены проверки на обновление/добавление/удаление номера + Реализовано: просмотр и удаление SMS - Необходим рефакторинг (убрать повторяющийся код в JS), оптимизировать - Объединить запросы в D в модули (подпапки)
This commit is contained in:
		
							parent
							
								
									de17e88d37
								
							
						
					
					
						commit
						ab4b8c6bad
					
				
					 20 changed files with 467 additions and 33 deletions
				
			
		
							
								
								
									
										6
									
								
								dub.json
									
										
									
									
									
								
							
							
						
						
									
										6
									
								
								dub.json
									
										
									
									
									
								
							| 
						 | 
					@ -5,10 +5,10 @@
 | 
				
			||||||
    "copyright": "Copyright © 2023, Alexander Zhirov",
 | 
					    "copyright": "Copyright © 2023, Alexander Zhirov",
 | 
				
			||||||
    "dependencies": {
 | 
					    "dependencies": {
 | 
				
			||||||
        "vibe-d": "~>0.9",
 | 
					        "vibe-d": "~>0.9",
 | 
				
			||||||
        "ldap": "~>0.4",
 | 
					        "singlog": "~>0.3.2",
 | 
				
			||||||
        "singlog": "~>0.3.1",
 | 
					 | 
				
			||||||
        "arsd-official:postgres": "~>10.9.10",
 | 
					        "arsd-official:postgres": "~>10.9.10",
 | 
				
			||||||
        "readconf": "~>0.3.1"
 | 
					        "readconf": "~>0.3.1",
 | 
				
			||||||
 | 
					        "datefmt": "1.0.4"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "buildTypes": {
 | 
					    "buildTypes": {
 | 
				
			||||||
        "debug": {
 | 
					        "debug": {
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -5,7 +5,6 @@
 | 
				
			||||||
		"datefmt": "1.0.4",
 | 
							"datefmt": "1.0.4",
 | 
				
			||||||
		"diet-ng": "1.8.1",
 | 
							"diet-ng": "1.8.1",
 | 
				
			||||||
		"eventcore": "0.9.25",
 | 
							"eventcore": "0.9.25",
 | 
				
			||||||
		"ldap": "0.4.0",
 | 
					 | 
				
			||||||
		"libasync": "0.8.6",
 | 
							"libasync": "0.8.6",
 | 
				
			||||||
		"memutils": "1.0.9",
 | 
							"memutils": "1.0.9",
 | 
				
			||||||
		"mir-linux-kernel": "1.0.1",
 | 
							"mir-linux-kernel": "1.0.1",
 | 
				
			||||||
| 
						 | 
					@ -13,7 +12,7 @@
 | 
				
			||||||
		"openssl-static": "1.0.2+3.0.8",
 | 
							"openssl-static": "1.0.2+3.0.8",
 | 
				
			||||||
		"readconf": "0.3.1",
 | 
							"readconf": "0.3.1",
 | 
				
			||||||
		"silly": "1.1.1",
 | 
							"silly": "1.1.1",
 | 
				
			||||||
		"singlog": "0.3.1",
 | 
							"singlog": "0.3.2",
 | 
				
			||||||
		"stdx-allocator": "2.77.5",
 | 
							"stdx-allocator": "2.77.5",
 | 
				
			||||||
		"taggedalgebraic": "0.11.22",
 | 
							"taggedalgebraic": "0.11.22",
 | 
				
			||||||
		"vibe-core": "2.2.0",
 | 
							"vibe-core": "2.2.0",
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										4
									
								
								js/noticer.min.js
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								js/noticer.min.js
									
										
									
									
										vendored
									
									
								
							| 
						 | 
					@ -1,4 +1,4 @@
 | 
				
			||||||
/*! noticer - v0.1.0 - 2023-05-31
 | 
					/*! noticer - v0.1.1 - 2023-06-02
 | 
				
			||||||
* https://git.zhirov.kz/alexander/noticer
 | 
					* https://git.zhirov.kz/alexander/noticer
 | 
				
			||||||
* Copyright Alexander Zhirov; Licensed GPL-2.0 */
 | 
					* Copyright Alexander Zhirov; Licensed GPL-2.0 */
 | 
				
			||||||
class Noticer{timer;constructor(){this.div=$('<div id="noticer"></div>'),this.div.css({position:"absolute",top:"10px",right:"20px","z-index":"1000"}),$("body").append(this.div)}success(e,t=6e3){this.print(e,t,"#52b818","#bffdc0")}warning(e,t=6e3){this.print(e,t,"#b8ae18","#f8fdbf")}error(e,t=6e3){this.print(e,t,"#b96161","#fddede")}print=function(e,t,n,s){t<6e3&&(t=6e3);let i=function(e,t){let n,s,o=t;this.pause=function(){clearTimeout(n),o-=new Date-s},this.resume=function(){s=new Date,clearTimeout(n),n=setTimeout(e,o)},this.dead=function(){clearTimeout(n)},this.resume()},o=$(`<div class="notice">${e}</div>`);o.css({border:`1px solid ${n}`,"background-color":`${s}`,color:"#333",padding:"10px 30px","text-align":"center",display:"none",margin:"10px 0 0 0",width:"350px",opacity:"1",cursor:"pointer"}),o.hover(function(){$(this).css({opacity:"1"})},function(){$(this).css({opacity:"0.3"})}),this.div.append(o);let a=setTimeout(function(){o.fadeTo(1e3,.3)},2500);o.fadeIn(500).mouseenter(()=>{clearTimeout(a),this.timer.pause()}).mouseleave(()=>{this.timer.resume()}).click(()=>{this.timer.dead(),o.fadeOut(0,function(){this.remove()})}),this.timer=new i(()=>{o.fadeOut(500,function(){this.remove()})},t)}}
 | 
					class Noticer{constructor(){this.div=$('<div id="noticer"></div>'),this.div.css({position:"absolute",top:"10px",right:"20px","z-index":"1000"}),$("body").append(this.div)}success(e,t=6e3){this.print(e,t,"#52b818","#bffdc0")}warning(e,t=6e3){this.print(e,t,"#b8ae18","#f8fdbf")}error(e,t=6e3){this.print(e,t,"#b96161","#fddede")}print=function(e,t,n,s){t<6e3&&(t=6e3);let a=function(e,t){let n,s,o=t;this.pause=function(){clearTimeout(n),o-=new Date-s},this.resume=function(){s=new Date,clearTimeout(n),n=setTimeout(e,o)},this.dead=function(){clearTimeout(n)},this.resume()},o=$(`<div class="notice">${e}</div>`);o.css({border:`1px solid ${n}`,"background-color":`${s}`,color:"#333",padding:"10px 30px","text-align":"center",display:"none",margin:"10px 0 0 0",width:"350px",opacity:"1",cursor:"pointer"}),o.hover(function(){$(this).css({opacity:"1"})},function(){$(this).css({opacity:"0.3"})}),this.div.append(o);let r=setTimeout(function(){o.fadeTo(1e3,.3)},2500);o.fadeIn(500).mouseenter(()=>{clearTimeout(r),i.pause()}).mouseleave(()=>{i.resume()}).click(()=>{i.dead(),o.fadeOut(0,function(){this.remove()})});let i=new a(()=>{o.fadeOut(500,function(){this.remove()})},t)}}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										200
									
								
								js/script.js
									
										
									
									
									
								
							
							
						
						
									
										200
									
								
								js/script.js
									
										
									
									
									
								
							| 
						 | 
					@ -1,21 +1,31 @@
 | 
				
			||||||
var numbers = [];
 | 
					var numbers = [];
 | 
				
			||||||
 | 
					var sms = [];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$(document).ready(function () {
 | 
					$(document).ready(function () {
 | 
				
			||||||
    noticer = new Noticer;
 | 
					    noticer = new Noticer;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    $("button").button();
 | 
					    $("button").button();
 | 
				
			||||||
    $("#tabs").tabs();
 | 
					    $("#tabs").tabs({
 | 
				
			||||||
 | 
					        activate: function( event, ui ) {
 | 
				
			||||||
 | 
					            ({
 | 
				
			||||||
 | 
					                0: () => { showNumbers($("#accordion-numbers .ui-accordion-content-active")) },
 | 
				
			||||||
 | 
					                1: () => { showSMS($("#accordion-sms .ui-accordion-content-active")) },
 | 
				
			||||||
 | 
					                2: () => {},
 | 
				
			||||||
 | 
					                3: () => {}
 | 
				
			||||||
 | 
					            })[$(this).tabs( "option", "active" )]();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            $("#add-number").button( "option", "disabled", $(this).tabs( "option", "active" ) > 0 );
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    $("#update").button("option", "icon", "ui-icon-refresh");
 | 
					    $("#update").button("option", "icon", "ui-icon-refresh");
 | 
				
			||||||
    $("#add-number").button("option", "icon", "ui-icon-plusthick");
 | 
					    $("#add-number").button("option", "icon", "ui-icon-plusthick");
 | 
				
			||||||
    $("#logout").button("option", "icon", "ui-icon-power");
 | 
					    $("#logout").button("option", "icon", "ui-icon-power");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // За каждым индексом закреплена функция для выполнения действия
 | 
					 | 
				
			||||||
    // на активной вкладке при нажатии на кнопку обновления
 | 
					 | 
				
			||||||
    $("#update").click(() => {
 | 
					    $("#update").click(() => {
 | 
				
			||||||
        ({
 | 
					        ({
 | 
				
			||||||
            0: () => { generateGroupNumbers($("#accordion-numbers .ui-accordion-content-active")) },
 | 
					            0: () => { generateGroupNumbers($("#accordion-numbers .ui-accordion-content-active")) },
 | 
				
			||||||
            1: () => { noticer.success('Вкладка "SMS"') },
 | 
					            1: () => { generateListSMS($("#accordion-sms .ui-accordion-content-active")) },
 | 
				
			||||||
            2: () => { noticer.success('Вкладка "USSD"') },
 | 
					            2: () => { noticer.success('Вкладка "USSD"') },
 | 
				
			||||||
            3: () => { noticer.success('Вкладка "Сервер"') }
 | 
					            3: () => { noticer.success('Вкладка "Сервер"') }
 | 
				
			||||||
        })[$("#tabs").tabs( "option", "active" )]()
 | 
					        })[$("#tabs").tabs( "option", "active" )]()
 | 
				
			||||||
| 
						 | 
					@ -28,15 +38,24 @@ $(document).ready(function () {
 | 
				
			||||||
    $("body").fadeTo(500, 1);
 | 
					    $("body").fadeTo(500, 1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    $("#search").on("input", function () {
 | 
					    $("#search").on("input", function () {
 | 
				
			||||||
        showNumbers(
 | 
					        ({
 | 
				
			||||||
            $("#accordion-numbers .ui-accordion-content-active"),
 | 
					            0: () => { showNumbers($("#accordion-numbers .ui-accordion-content-active")) },
 | 
				
			||||||
            numbers.filter(e => e.number.includes($(this).val()))
 | 
					            1: () => { showSMS($("#accordion-sms .ui-accordion-content-active")) },
 | 
				
			||||||
        )
 | 
					            2: () => {},
 | 
				
			||||||
 | 
					            3: () => {}
 | 
				
			||||||
 | 
					        })[$("#tabs").tabs( "option", "active" )]()
 | 
				
			||||||
    }).keydown(function (e) {
 | 
					    }).keydown(function (e) {
 | 
				
			||||||
        e.key == "Escape" && ($(this).val(""), showNumbers($("#accordion-numbers .ui-accordion-content-active")))
 | 
					        e.key == "Escape" && ($(this).val(""), ({
 | 
				
			||||||
 | 
					                0: () => { showNumbers($("#accordion-numbers .ui-accordion-content-active")) },
 | 
				
			||||||
 | 
					                1: () => { showSMS($("#accordion-sms .ui-accordion-content-active")) },
 | 
				
			||||||
 | 
					                2: () => {},
 | 
				
			||||||
 | 
					                3: () => {}
 | 
				
			||||||
 | 
					            })[$("#tabs").tabs( "option", "active" )]()
 | 
				
			||||||
 | 
					        )
 | 
				
			||||||
    });
 | 
					    });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    loadData();
 | 
					    loadNumbers();
 | 
				
			||||||
 | 
					    loadSMS();
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
async function request(query, type, queryData = {}) {
 | 
					async function request(query, type, queryData = {}) {
 | 
				
			||||||
| 
						 | 
					@ -66,7 +85,11 @@ function isJSON(str) {
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function loadData() {
 | 
					function isNumeric(value) {
 | 
				
			||||||
 | 
					    return /^-?\d+$/.test(value);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function loadNumbers() {
 | 
				
			||||||
    request('listsgroups', 'text').then(data => {
 | 
					    request('listsgroups', 'text').then(data => {
 | 
				
			||||||
        data.error ? noticer.error(data.message) : generateListsGroups(data);
 | 
					        data.error ? noticer.error(data.message) : generateListsGroups(data);
 | 
				
			||||||
    }).catch(error => {
 | 
					    }).catch(error => {
 | 
				
			||||||
| 
						 | 
					@ -74,7 +97,142 @@ function loadData() {
 | 
				
			||||||
    });
 | 
					    });
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function loadSMS() {
 | 
				
			||||||
 | 
					    request('smsnumbers', 'text').then(data => {
 | 
				
			||||||
 | 
					        data.error ? noticer.error(data.message) : generateListsSMSNumber(data);
 | 
				
			||||||
 | 
					    }).catch(error => {
 | 
				
			||||||
 | 
					        noticer.error(error.message);
 | 
				
			||||||
 | 
					    });
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function generateListsSMSNumber(data) {
 | 
				
			||||||
 | 
					    if (!$(data).children().length) {
 | 
				
			||||||
 | 
					        $("#tabs-sms").html('<p>SMS отсутствуют</p>');
 | 
				
			||||||
 | 
					        return;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    $("#tabs-sms").html(data);
 | 
				
			||||||
 | 
					    $("#accordion-sms").accordion({
 | 
				
			||||||
 | 
					        heightStyle: "content",
 | 
				
			||||||
 | 
					        create: function( event, ui ) {
 | 
				
			||||||
 | 
					            generateListSMS(ui.panel);
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        beforeActivate: function( event, ui ) {
 | 
				
			||||||
 | 
					            generateListSMS(ui.newPanel);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function generateListSMS(panel) {
 | 
				
			||||||
 | 
					    if (!$("#accordion-sms").children().length) {
 | 
				
			||||||
 | 
					        noticer.warning("SMS отсутствуют");
 | 
				
			||||||
 | 
					        $("#tabs-sms").html('<p>SMS отсутствуют</p>');
 | 
				
			||||||
 | 
					        return;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    request('listsms', 'json', { to: panel.data("to") }).then(data => {
 | 
				
			||||||
 | 
					        if (isJSON(data) && JSON.parse(data).error)
 | 
				
			||||||
 | 
					            noticer.error(JSON.parse(data).message);
 | 
				
			||||||
 | 
					        else {
 | 
				
			||||||
 | 
					            sms = data;
 | 
				
			||||||
 | 
					            showSMS(panel);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }).catch(error => {
 | 
				
			||||||
 | 
					        noticer.error(error.message);
 | 
				
			||||||
 | 
					    });
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function showSMS(panel, data = sms.filter(e => e.from.includes($("#search").val()))) {
 | 
				
			||||||
 | 
					    (new divNotFoundNumbers).remove();
 | 
				
			||||||
 | 
					    let body = panel.find('.body').html('');
 | 
				
			||||||
 | 
					    $(data).each((i, j) => {
 | 
				
			||||||
 | 
					        let row = $(`<tr class="row" data-sms-id="${j.id}"></tr>`);
 | 
				
			||||||
 | 
					        row.append(`<td class="sms-content-width">${j.date}</td>`);
 | 
				
			||||||
 | 
					        row.append(`<td class="sms-content-width">${j.from}</td>`);
 | 
				
			||||||
 | 
					        row.append(`<td>${j.text}</td>`);
 | 
				
			||||||
 | 
					        body.append(row);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        row.click(function() {
 | 
				
			||||||
 | 
					            viewSMS(panel, $(this).data('sms-id'), j.from);
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					    });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (!body.children().length)
 | 
				
			||||||
 | 
					        (new divNotFoundNumbers).push();
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function viewSMS(panel, id, number) {
 | 
				
			||||||
 | 
					    request('viewsms', 'text', {id: id}).then(data => {
 | 
				
			||||||
 | 
					        if (isJSON(data) && JSON.parse(data).error)
 | 
				
			||||||
 | 
					            noticer.error(JSON.parse(data).message);
 | 
				
			||||||
 | 
					        else {
 | 
				
			||||||
 | 
					            showViewSMS(data, [
 | 
				
			||||||
 | 
					                {
 | 
				
			||||||
 | 
					                    id: "btn-delete",
 | 
				
			||||||
 | 
					                    text: "Удалить",
 | 
				
			||||||
 | 
					                    icon: "ui-icon-trash",
 | 
				
			||||||
 | 
					                    click: function() {
 | 
				
			||||||
 | 
					                        delSMS(panel, $(this));
 | 
				
			||||||
 | 
					                    }
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					            ], `SMS от ${number}`);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }).catch(error => {
 | 
				
			||||||
 | 
					        noticer.error(error.message);
 | 
				
			||||||
 | 
					    });
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function showViewSMS(data, actionButton, title) {
 | 
				
			||||||
 | 
					    let form = $(data);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    form.appendTo('body').dialog({
 | 
				
			||||||
 | 
					        title: title,
 | 
				
			||||||
 | 
					        height: 'auto',
 | 
				
			||||||
 | 
					        width: 'auto',
 | 
				
			||||||
 | 
					        resizable: false,
 | 
				
			||||||
 | 
					        modal: true,
 | 
				
			||||||
 | 
					        show: { effect: "fade", duration: 500 },
 | 
				
			||||||
 | 
					        close: function(event, ui) {
 | 
				
			||||||
 | 
					            $(this).dialog('destroy').remove()
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        buttons: [
 | 
				
			||||||
 | 
					            ...actionButton,
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                text: "Отмена",
 | 
				
			||||||
 | 
					                icon: "ui-icon-cancel",
 | 
				
			||||||
 | 
					                click: function() {
 | 
				
			||||||
 | 
					                    $(this).dialog("close");
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    });
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function delSMS(panel, currentWindow) {
 | 
				
			||||||
 | 
					    let id = $('#sms-content').data('id');
 | 
				
			||||||
 | 
					    let from = $('#sms-content').data('from');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    request('delsms', 'json', {
 | 
				
			||||||
 | 
					        id: id
 | 
				
			||||||
 | 
					    }).then(data => {
 | 
				
			||||||
 | 
					        if (data.error)
 | 
				
			||||||
 | 
					            noticer.error(data.message);
 | 
				
			||||||
 | 
					        else {
 | 
				
			||||||
 | 
					            noticer.success(`SMS от ${from} было удалено`);
 | 
				
			||||||
 | 
					            generateListSMS(panel);
 | 
				
			||||||
 | 
					            currentWindow.dialog("close");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }).catch(error => {
 | 
				
			||||||
 | 
					        noticer.error(error.message);
 | 
				
			||||||
 | 
					    });
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function generateListsGroups(data) {
 | 
					function generateListsGroups(data) {
 | 
				
			||||||
 | 
					    if (!$(data).children().length) {
 | 
				
			||||||
 | 
					        $("#tabs-numbers").html('<p>Номера телефонов отсутствуют</p>');
 | 
				
			||||||
 | 
					        return;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    $("#tabs-numbers").html(data);
 | 
					    $("#tabs-numbers").html(data);
 | 
				
			||||||
    $("#accordion-numbers").accordion({
 | 
					    $("#accordion-numbers").accordion({
 | 
				
			||||||
        heightStyle: "content",
 | 
					        heightStyle: "content",
 | 
				
			||||||
| 
						 | 
					@ -88,6 +246,12 @@ function generateListsGroups(data) {
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function generateGroupNumbers(panel) {
 | 
					function generateGroupNumbers(panel) {
 | 
				
			||||||
 | 
					    if (!$("#accordion-numbers").children().length) {
 | 
				
			||||||
 | 
					        noticer.warning("Номера телефонов отсутствуют");
 | 
				
			||||||
 | 
					        $("#tabs-numbers").html('<p>Номера телефонов отсутствуют</p>');
 | 
				
			||||||
 | 
					        return;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    request('groupnumbers', 'json', { group: panel.data("group-name") }).then(data => {
 | 
					    request('groupnumbers', 'json', { group: panel.data("group-name") }).then(data => {
 | 
				
			||||||
        if (isJSON(data) && JSON.parse(data).error)
 | 
					        if (isJSON(data) && JSON.parse(data).error)
 | 
				
			||||||
            noticer.error(JSON.parse(data).message);
 | 
					            noticer.error(JSON.parse(data).message);
 | 
				
			||||||
| 
						 | 
					@ -203,8 +367,7 @@ function showEditNumber(data, actionButton, title) {
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function actionNumber(panel, currentWindow, query) {
 | 
					function actionNumber(panel, currentWindow, query) {
 | 
				
			||||||
    // Только числа, начинающие с >0 или только 0
 | 
					    let pattern_number = /^\+7\d{10}$/g;
 | 
				
			||||||
    let regexp = /^(?=\d)(\d|([^0]\d+))$/g;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    let number = $('#number-number').val();
 | 
					    let number = $('#number-number').val();
 | 
				
			||||||
    let group = $('#number-group').val();
 | 
					    let group = $('#number-group').val();
 | 
				
			||||||
| 
						 | 
					@ -216,10 +379,13 @@ function actionNumber(panel, currentWindow, query) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    let error = false;
 | 
					    let error = false;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (!number.length) { noticer.warning('Номер не может быть пуст'); error = true; }
 | 
					    if (number.match(pattern_number) === null) { noticer.warning("Номер не соответствует формату +7XXXXXXXXXX"); error = true; }
 | 
				
			||||||
    if (all_cc.match(regexp) === null) { noticer.warning("Не верно указано общее количество звонков"); error = true; }
 | 
					    if (!isNumeric(all_cc)) { noticer.warning("Общее количество звонков должно быть числом"); error = true; }
 | 
				
			||||||
    if (white_cc.match(regexp) === null) { noticer.warning("Не верно указано белое количество звонков"); error = true; }
 | 
					    if (all_cc < 0) { noticer.warning("Общее количество звонков не может быть отрицательным"); error = true; }
 | 
				
			||||||
    if (black_cc.match(regexp) === null) { noticer.warning("Не верно указано черное количество звонков"); error = true; }
 | 
					    if (!isNumeric(white_cc)) { noticer.warning("Белое количество звонков должно быть числом"); error = true; }
 | 
				
			||||||
 | 
					    if (white_cc < 0) { noticer.warning("Белое количество звонков не может быть отрицательным"); error = true; }
 | 
				
			||||||
 | 
					    if (!isNumeric(black_cc)) { noticer.warning("Черное количество звонков должно быть числом"); error = true; }
 | 
				
			||||||
 | 
					    if (black_cc < 0) { noticer.warning("Черное количество звонков не может быть отрицательным"); error = true; }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (error) return;
 | 
					    if (error) return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -121,7 +121,7 @@ tr.row:hover, tr.row:nth-child(even):hover {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* EDIT NUMBER */
 | 
					/* EDIT NUMBER */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.number-label {
 | 
					.number-label, .sms-label {
 | 
				
			||||||
    color: #333;
 | 
					    color: #333;
 | 
				
			||||||
    text-align: right;
 | 
					    text-align: right;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -130,6 +130,15 @@ tr.row:hover, tr.row:nth-child(even):hover {
 | 
				
			||||||
    height: 30px;
 | 
					    height: 30px;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.sms-label-text {
 | 
				
			||||||
 | 
					    vertical-align:top
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.sms-value {
 | 
				
			||||||
 | 
					    width: 300px;
 | 
				
			||||||
 | 
					    text-align: left;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.number-input-main {
 | 
					.number-input-main {
 | 
				
			||||||
    height: 25px;
 | 
					    height: 25px;
 | 
				
			||||||
    width: 194px;
 | 
					    width: 194px;
 | 
				
			||||||
| 
						 | 
					@ -158,12 +167,25 @@ tr.row:hover, tr.row:nth-child(even):hover {
 | 
				
			||||||
    padding: 15px 0 5px 0;
 | 
					    padding: 15px 0 5px 0;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.comment-content {
 | 
					.comment-content, .sms-content {
 | 
				
			||||||
    width: 100%;
 | 
					    width: 100%;
 | 
				
			||||||
    height: 100%;
 | 
					    height: 100%;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#number-comment {
 | 
					#number-comment, #sms-content {
 | 
				
			||||||
    width: calc(100% - 6px);
 | 
					    width: calc(100% - 6px);
 | 
				
			||||||
    resize: none;
 | 
					    resize: none;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#sms-content {
 | 
				
			||||||
 | 
					    height: 150px;
 | 
				
			||||||
 | 
					    outline: none;
 | 
				
			||||||
 | 
					    border: 1px solid#c5c5c5;
 | 
				
			||||||
 | 
					    color: #333;
 | 
				
			||||||
 | 
					    width: 400px;
 | 
				
			||||||
 | 
					    padding: 5px 10px 5px 10px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					th.sms-content-width, td.sms-content-width {
 | 
				
			||||||
 | 
					    width: 155px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,14 +1,14 @@
 | 
				
			||||||
[web-host]
 | 
					[web-host]
 | 
				
			||||||
title           => "Управление диалпланом"
 | 
					title           => "Управление диалпланом"
 | 
				
			||||||
addresses       => 127.0.0.1
 | 
					addresses       => 127.0.0.1
 | 
				
			||||||
http            => 8080
 | 
					http            => 80
 | 
				
			||||||
https           => 443
 | 
					https           => 443
 | 
				
			||||||
cert            => certs/test.local.crt
 | 
					cert            => certs/test.local.crt
 | 
				
			||||||
key             => certs/test.local.key
 | 
					key             => certs/test.local.key
 | 
				
			||||||
data            => ./                                   ; Путь к каталогу, в котором расположены каталоги public, js, images
 | 
					data            => ./                                   ; Путь к каталогу, в котором расположены каталоги public, jq, js, images
 | 
				
			||||||
loglevel        => 0                                    ; 0 - debug, 1 - crit, 2 - err, 3 - warn, 4 - notice, 5 - info, 6 - alert
 | 
					loglevel        => 0                                    ; 0 - debug, 1 - crit, 2 - err, 3 - warn, 4 - notice, 5 - info, 6 - alert
 | 
				
			||||||
logoutput       => 1, 4                                 ; 1 - syslog, 2 - stout, 4 - file => example: 1,2 or 1,2,4
 | 
					logoutput       => 1, 4                                 ; 1 - syslog, 2 - stout, 4 - file => example: 1,2 or 1,2,4
 | 
				
			||||||
logfile         => /var/log/jaster.log                  ; if log-output set with 4
 | 
					logfile         => /var/log/daster.log                  ; if log-output set with 4
 | 
				
			||||||
 | 
					
 | 
				
			||||||
[daster-db]
 | 
					[daster-db]
 | 
				
			||||||
host            => 127.0.0.1
 | 
					host            => 127.0.0.1
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -23,6 +23,10 @@ import requests.updatenumber;
 | 
				
			||||||
import requests.addnumber;
 | 
					import requests.addnumber;
 | 
				
			||||||
import requests.delnumber;
 | 
					import requests.delnumber;
 | 
				
			||||||
import requests.writenumber;
 | 
					import requests.writenumber;
 | 
				
			||||||
 | 
					import requests.smsnumbers;
 | 
				
			||||||
 | 
					import requests.listsms;
 | 
				
			||||||
 | 
					import requests.viewsms;
 | 
				
			||||||
 | 
					import requests.delsms;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static ServerInfo serverInfo;
 | 
					static ServerInfo serverInfo;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -200,6 +204,18 @@ void postReq(HTTPServerRequest req, HTTPServerResponse res) {
 | 
				
			||||||
        case "delnumber":
 | 
					        case "delnumber":
 | 
				
			||||||
            delNumber(req, res);
 | 
					            delNumber(req, res);
 | 
				
			||||||
            break;
 | 
					            break;
 | 
				
			||||||
 | 
					        case "smsnumbers":
 | 
				
			||||||
 | 
					            smsNumbers(req, res);
 | 
				
			||||||
 | 
					            break;
 | 
				
			||||||
 | 
					        case "listsms":
 | 
				
			||||||
 | 
					            listSMS(req, res);
 | 
				
			||||||
 | 
					            break;
 | 
				
			||||||
 | 
					        case "viewsms":
 | 
				
			||||||
 | 
					            viewSMS(req, res);
 | 
				
			||||||
 | 
					            break;
 | 
				
			||||||
 | 
					        case "delsms":
 | 
				
			||||||
 | 
					            delSMS(req, res);
 | 
				
			||||||
 | 
					            break;
 | 
				
			||||||
        default:
 | 
					        default:
 | 
				
			||||||
            res.redirect("/");
 | 
					            res.redirect("/");
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -200,3 +200,96 @@ bool sqlInsertNumber(NumberDB number) {
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    return true;
 | 
					    return true;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SMSDB[] sqlGetSMSNumbers() {
 | 
				
			||||||
 | 
					    SMSDB[] numbers;
 | 
				
			||||||
 | 
					    try {
 | 
				
			||||||
 | 
					        auto queryResult = pgsql.sql(
 | 
				
			||||||
 | 
					            "select distinct da_to from da_sms"
 | 
				
			||||||
 | 
					        );
 | 
				
			||||||
 | 
					        foreach (row; queryResult) {
 | 
				
			||||||
 | 
					            SMSDB data;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            data.to = row["da_to"];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            numbers ~= data;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    } catch (Exception e) {
 | 
				
			||||||
 | 
					        log.e("Не удалось выполнить запрос к БД. " ~ e.msg);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return numbers;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SMSDB[] sqlGetListSMS(string to) {
 | 
				
			||||||
 | 
					    SMSDB[] sms;
 | 
				
			||||||
 | 
					    try {
 | 
				
			||||||
 | 
					        auto queryResult = pgsql.sql(
 | 
				
			||||||
 | 
					            "select
 | 
				
			||||||
 | 
					                da_id,
 | 
				
			||||||
 | 
					                to_char(da_date, 'YYYY.MM.DD HH24:MI:SS') da_date,
 | 
				
			||||||
 | 
					                da_to,
 | 
				
			||||||
 | 
					                da_from,
 | 
				
			||||||
 | 
					                da_text
 | 
				
			||||||
 | 
					            from da_sms
 | 
				
			||||||
 | 
					            where da_to = ?
 | 
				
			||||||
 | 
					            order by da_date desc",
 | 
				
			||||||
 | 
					            to
 | 
				
			||||||
 | 
					        );
 | 
				
			||||||
 | 
					        foreach (row; queryResult) {
 | 
				
			||||||
 | 
					            SMSDB data;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            data.id = row["da_id"].to!int;
 | 
				
			||||||
 | 
					            data.date = row["da_date"];
 | 
				
			||||||
 | 
					            data.to = row["da_to"];
 | 
				
			||||||
 | 
					            data.from = row["da_from"];
 | 
				
			||||||
 | 
					            data.text = row["da_text"];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            sms ~= data;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    } catch (Exception e) {
 | 
				
			||||||
 | 
					        log.e("Не удалось выполнить запрос к БД. " ~ e.msg);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return sms;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SMSDB sqlGetSMS(int idsms) {
 | 
				
			||||||
 | 
					    SMSDB data;
 | 
				
			||||||
 | 
					    try {
 | 
				
			||||||
 | 
					        auto queryResult = pgsql.sql(
 | 
				
			||||||
 | 
					            "select
 | 
				
			||||||
 | 
					                da_id,
 | 
				
			||||||
 | 
					                to_char(da_date, 'YYYY.MM.DD HH24:MI:SS') da_date,
 | 
				
			||||||
 | 
					                da_to,
 | 
				
			||||||
 | 
					                da_from,
 | 
				
			||||||
 | 
					                da_text
 | 
				
			||||||
 | 
					            from da_sms
 | 
				
			||||||
 | 
					            where da_id = ?",
 | 
				
			||||||
 | 
					            idsms
 | 
				
			||||||
 | 
					        );
 | 
				
			||||||
 | 
					        foreach (row; queryResult) {
 | 
				
			||||||
 | 
					            data.id = row["da_id"].to!int;
 | 
				
			||||||
 | 
					            data.date = row["da_date"];
 | 
				
			||||||
 | 
					            data.to = row["da_to"];
 | 
				
			||||||
 | 
					            data.from = row["da_from"];
 | 
				
			||||||
 | 
					            data.text = row["da_text"];
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    } catch (Exception e) {
 | 
				
			||||||
 | 
					        log.e("Не удалось выполнить запрос к БД. " ~ e.msg);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return data;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					bool sqlDeleteSMS(int idsms) {
 | 
				
			||||||
 | 
					    try {
 | 
				
			||||||
 | 
					        pgsql.sql(
 | 
				
			||||||
 | 
					            "delete from da_sms where da_id = ?", idsms
 | 
				
			||||||
 | 
					        );
 | 
				
			||||||
 | 
					    } catch (Exception e) {
 | 
				
			||||||
 | 
					        log.e("Ошибка удаления SMS в БД. " ~ e.msg);
 | 
				
			||||||
 | 
					        return false;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    return true;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										19
									
								
								source/requests/delsms.d
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								source/requests/delsms.d
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,19 @@
 | 
				
			||||||
 | 
					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();
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										10
									
								
								source/requests/listsms.d
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								source/requests/listsms.d
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,10 @@
 | 
				
			||||||
 | 
					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());
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										15
									
								
								source/requests/smsnumbers.d
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								source/requests/smsnumbers.d
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,15 @@
 | 
				
			||||||
 | 
					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);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -6,8 +6,34 @@ import data;
 | 
				
			||||||
import singlog;
 | 
					import singlog;
 | 
				
			||||||
import structures;
 | 
					import structures;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import std.regex;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void updateNumber(HTTPServerRequest req, HTTPServerResponse res) {
 | 
					void updateNumber(HTTPServerRequest req, HTTPServerResponse res) {
 | 
				
			||||||
    NumberDB number = deserializeJson!NumberDB(req.json);
 | 
					    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)) {
 | 
					    if (!sqlUpdateNumber(number)) {
 | 
				
			||||||
        res.send(true, "Не удалось обновить номер");
 | 
					        res.send(true, "Не удалось обновить номер");
 | 
				
			||||||
        return;
 | 
					        return;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										12
									
								
								source/requests/viewsms.d
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								source/requests/viewsms.d
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,12 @@
 | 
				
			||||||
 | 
					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);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -6,8 +6,34 @@ import structures;
 | 
				
			||||||
import data;
 | 
					import data;
 | 
				
			||||||
import singlog;
 | 
					import singlog;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import std.regex;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void writeNumber(HTTPServerRequest req, HTTPServerResponse res) {
 | 
					void writeNumber(HTTPServerRequest req, HTTPServerResponse res) {
 | 
				
			||||||
    NumberDB number = deserializeJson!NumberDB(req.json);
 | 
					    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)) {
 | 
					    if (!sqlInsertNumber(number)) {
 | 
				
			||||||
        res.send(true, "Не удалось записать номер");
 | 
					        res.send(true, "Не удалось записать номер");
 | 
				
			||||||
        return;
 | 
					        return;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -36,3 +36,11 @@ struct NumberDB {
 | 
				
			||||||
    int black_cc;
 | 
					    int black_cc;
 | 
				
			||||||
    string comment;
 | 
					    string comment;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					struct SMSDB {
 | 
				
			||||||
 | 
					    int id;
 | 
				
			||||||
 | 
					    string date;
 | 
				
			||||||
 | 
					    string to;
 | 
				
			||||||
 | 
					    string from;
 | 
				
			||||||
 | 
					    string text;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,3 +1,3 @@
 | 
				
			||||||
module version_;
 | 
					module version_;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
enum dasterVersion = "v0.0.4";
 | 
					enum dasterVersion = "v0.0.5";
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,4 +1,3 @@
 | 
				
			||||||
- import structures;
 | 
					 | 
				
			||||||
div#number-data
 | 
					div#number-data
 | 
				
			||||||
    table
 | 
					    table
 | 
				
			||||||
        tbody
 | 
					        tbody
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -33,7 +33,6 @@ body
 | 
				
			||||||
                    a(href='#tabs-server') Сервер
 | 
					                    a(href='#tabs-server') Сервер
 | 
				
			||||||
            div#tabs-numbers
 | 
					            div#tabs-numbers
 | 
				
			||||||
            div#tabs-sms
 | 
					            div#tabs-sms
 | 
				
			||||||
                p Список SMS сообщений
 | 
					 | 
				
			||||||
            div#tabs-ussd
 | 
					            div#tabs-ussd
 | 
				
			||||||
                p Список результатов USSD запросов
 | 
					                p Список результатов USSD запросов
 | 
				
			||||||
            div#tabs-server
 | 
					            div#tabs-server
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										13
									
								
								views/sms-numbers.dt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								views/sms-numbers.dt
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,13 @@
 | 
				
			||||||
 | 
					div#accordion-sms
 | 
				
			||||||
 | 
					    - foreach (number; numbers)
 | 
				
			||||||
 | 
					        h3 На номер #{number.to}
 | 
				
			||||||
 | 
					        div.group-content(data-to='#{number.to}')
 | 
				
			||||||
 | 
					            table
 | 
				
			||||||
 | 
					                thead.head
 | 
				
			||||||
 | 
					                    tr
 | 
				
			||||||
 | 
					                        th.sms-content-width Дата
 | 
				
			||||||
 | 
					                        th.sms-content-width От кого
 | 
				
			||||||
 | 
					                        th Текст сообщения
 | 
				
			||||||
 | 
					            div.body-rows
 | 
				
			||||||
 | 
					                table
 | 
				
			||||||
 | 
					                    tbody.body
 | 
				
			||||||
							
								
								
									
										11
									
								
								views/view-sms.dt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								views/view-sms.dt
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,11 @@
 | 
				
			||||||
 | 
					div#sms-data
 | 
				
			||||||
 | 
					    table
 | 
				
			||||||
 | 
					        tbody
 | 
				
			||||||
 | 
					            tr
 | 
				
			||||||
 | 
					                td.sms-label Дата:
 | 
				
			||||||
 | 
					                td.sms-value #{dataSMS.date}
 | 
				
			||||||
 | 
					            tr
 | 
				
			||||||
 | 
					                td.sms-label.sms-label-text Текст:
 | 
				
			||||||
 | 
					                td.sms-value
 | 
				
			||||||
 | 
					                    div.sms-content
 | 
				
			||||||
 | 
					                        textarea#sms-content(readonly, data-id="#{dataSMS.id}", data-from="#{dataSMS.from}") #{dataSMS.text}
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue