From c1eee1f1d0b67289cd311a67110c3ec65bf88893 Mon Sep 17 00:00:00 2001 From: Ougi Date: Fri, 10 Nov 2023 12:00:53 +0300 Subject: [PATCH] add new func --- TestProject/lib/TestProject.pm | 43 ++++++++++++++--------------- create_log_in_table/create_table.pl | 1 + 2 files changed, 21 insertions(+), 23 deletions(-) diff --git a/TestProject/lib/TestProject.pm b/TestProject/lib/TestProject.pm index 2e9d7c8..d8d0809 100644 --- a/TestProject/lib/TestProject.pm +++ b/TestProject/lib/TestProject.pm @@ -11,37 +11,34 @@ our $VERSION = '0.1'; my $regex_for_email = qr((?:[a-z0-9!#$%&'*+/=?^_`{|}~-]+(?:\.[a-z0-9!#$%&'*+/=?^_`{|}~-]+)*|"(?:[\x01-\x08\x0b\x0c\x0e-\x1f\x21\x23-\x5b\x5d-\x7f]|\\[\x01-\x09\x0b\x0c\x0e-\x7f])*")@(?:(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?|\[(?:(?:(2(5[0-5]|[0-4][0-9])|1[0-9][0-9]|[1-9]?[0-9]))\.){3}(?:(2(5[0-5]|[0-4][0-9])|1[0-9][0-9]|[1-9]?[0-9])|[a-z0-9-]*[a-z0-9]:(?:[\x01-\x08\x0b\x0c\x0e-\x1f\x21-\x5a\x53-\x7f]|\\[\x01-\x09\x0b\x0c\x0e-\x7f])+)\])); +sub valid_param { + my $address = shift; + if ( $address =~ $regex_for_email ) { + return { + flag => 0, + address => $1 + }; + } + return { + flag => 1, + address => "Error Address" + }; +} + get '/' => sub { template 'get_address' => { title => 'Поиск Логов' }; }; post '/logs' => sub { - my $address = body_parameters->get('address'); - my $err; + my %params = %{ valid_param( body_parameters->get('address') ) }; - if ($address) { - if ( $address =~ $regex_for_email ) { - $err = 0; - } - else { - $err = 'Ошибка: не верно указанный адрес'; - } - } - else { - $err = 'Ошибка: пустой адрес'; - } - - my %res_get_rows; - - unless ($err) { - my $dbh = DB->new(); - $dbh->connect(); - %res_get_rows = $dbh->get_rows($address); - } + my $dbh = DB->new(); + $dbh->connect(); + my %res_get_rows = %{ $dbh->get_rows( $params{address} ) }; template 'logs' => { - title => $address, - err => $err, + title => $params{flag}, + err => $params{address}, alert => $res_get_rows{alert}, rows => $res_get_rows{table}, get_address => uri_for('/'), diff --git a/create_log_in_table/create_table.pl b/create_log_in_table/create_table.pl index 6f9115b..08c22a4 100644 --- a/create_log_in_table/create_table.pl +++ b/create_log_in_table/create_table.pl @@ -1,6 +1,7 @@ #!/usr/bin/perl use strict; use warnings FATAL => 'all'; +use DBI; my $dbi_info = 'dbi:Pg:dbname=postgres;host=localhost;port=5432'; my $db_username = 'postgres';