zla 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. #!/usr/bin/perl -w -CSDA
  2. use v5.14;
  3. use strict;
  4. use warnings;
  5. use utf8;
  6. use CGI::Fast qw/header param/;
  7. use CGI::Fast qw/Vars/;
  8. use Data::Dumper;
  9. use Email::Simple;
  10. use Email::Sender::Simple qw/sendmail/;
  11. use File::Slurp qw/append_file/;
  12. use JSON qw/encode_json/;
  13. use YAML::Any qw/Dump LoadFile/;
  14. use Fcntl qw/LOCK_EX LOCK_UN/;
  15. use List::Util qw/sum/;
  16. ##################################################
  17. # Inceput setari
  18. my %events = (
  19. bucuresti => {
  20. date => 'sâmbătă, 15 martie 2014',
  21. locul => '',
  22. sala => '',
  23. locuri => 50,
  24. link => 'http://ceata.org/evenimente/zla-2014.html',
  25. image => '',
  26. }
  27. );
  28. use constant EMAIL_FROM => 'Ziua Libertății Aparatelor 2014 — Fundația Ceata <zla@ceata.org>';
  29. use constant ADMIN_EMAIL => 'zla@ceata.org';
  30. use constant DATAFILE => 'date.yml';
  31. # Sfarsit setari
  32. ##################################################
  33. open LOCK, '<', DATAFILE;
  34. sub nr_participanti { my $oras = shift; sum 0, map { $_->{numar} } grep { $_->{oras} eq $oras } @_ }
  35. sub append{
  36. flock LOCK, LOCK_EX;
  37. eval {
  38. my $prenume = param('prenume') or die 'Nu ați completat prenumele';
  39. utf8::decode($prenume);
  40. my $nume = param('nume') // '';
  41. utf8::decode($nume);
  42. my $adresa = param('adresa') or die 'Nu ați completat adresa de poștă electronică';
  43. utf8::decode($adresa);
  44. my $oras = 'bucuresti';
  45. my $numar = int param('numar') or die 'Nu ați ales numărul de participanți';
  46. die 'Numărul de participanți trebuie să fie între 1 și 5' unless $numar >= 1 && $numar <= 5;
  47. my $captcha = param('captcha') or die 'Nu ați completat corect data evenimentului de Ziua Libertății Aparatelor';
  48. die 'Ați completat greșit data Zilei Libertății Aparatelor' unless $captcha == 15;
  49. my $referinta = param('referinta') || param('referinta2');
  50. my $anunturi = param('anunturi') or 0;
  51. my @db = grep { $_->{oras} eq $oras } LoadFile DATAFILE;
  52. die 'Această adresă de poștă electronică este deja folosită' if grep { $_->{adresa} eq $adresa } @db;
  53. my $participanti = nr_participanti $oras, @db;
  54. die 'Nu sunt suficiente locuri libere' if $events{$oras}{locuri} < $participanti + $numar;
  55. my %entry = (
  56. prenume => $prenume,
  57. nume => $nume,
  58. adresa => $adresa,
  59. oras => $oras,
  60. numar => $numar,
  61. referinta => $referinta,
  62. anunturi => defined($anunturi) && $anunturi ? 1 : 0,
  63. );
  64. my $success_email = Email::Simple->create(
  65. header => [
  66. To => "$nume <$adresa>",
  67. Subject => 'Confirmarea de înscriere la Ziua Libertății Apratelor 2014',
  68. From => EMAIL_FROM,
  69. ],
  70. body => "Aceasta este o confirmare automată de înscriere la evenimentul de Ziua Libertății Aparatelor 2014 organizat de Fundația Ceata și inventeaza.ro sâmbătă, 15 martie de la ora 12:00 la sediul ActiveWatch (Calea Plevnei nr. 98, bl. 10C).\n\n" . Dump \%entry,
  71. );
  72. sendmail $success_email, { to => [$adresa, ADMIN_EMAIL]};
  73. append_file DATAFILE, Dump \%entry;
  74. };
  75. flock LOCK, LOCK_UN;
  76. if ($@) {
  77. my $eroare = $@ =~ s/ at .*//r;
  78. my $error_email = Email::Simple->create(
  79. header => [
  80. To => "Administrator <" . ADMIN_EMAIL . ">",
  81. Subject => 'Eroare de înscriere la Ziua Libertății Aparatelor 2014',
  82. From => EMAIL_FROM,
  83. ],
  84. body => "Eroare: $eroare\n" . Dumper scalar Vars,
  85. );
  86. sendmail $error_email;
  87. print header('text/html; charset=utf-8', '500 Internal Server Error');
  88. print $eroare;
  89. } else {
  90. print header('text/html; charset=utf-8');
  91. print 'Ați fost înscris cu succes';
  92. }
  93. }
  94. sub info{
  95. my $oras = param('oras');
  96. eval {
  97. die 'Eveniment inexistent' unless defined $oras && exists $events{$oras};
  98. my %out = %{$events{$oras}};
  99. my $participanti = nr_participanti $oras, LoadFile DATAFILE;
  100. $out{locuri} = $out{locuri} - $participanti;
  101. print header('application/json; charset=utf-8');
  102. print encode_json \%out;
  103. };
  104. if ($@) {
  105. $@ =~ s/ at .*//;
  106. print header('text/html; charset=utf-8', '500 Internal Server Error');
  107. print $@;
  108. }
  109. }
  110. sub view{
  111. my $oras = param('oras');
  112. unless (exists $events{$oras}) {
  113. print header('text/html; charset=utf-8', '500 Internal Server Error');
  114. print 'Acest eveniment nu există';
  115. return;
  116. }
  117. my @db = grep { $_->{oras} eq $oras } LoadFile DATAFILE;
  118. my $participanti = nr_participanti $oras, @db;
  119. print header('text/html; charset=utf-8');
  120. print "Sunt $participanti participanți înscriși<p>";
  121. # for my $p(@db) {
  122. # print "Nume: $p->{nume}<br>Prenume: $p->{prenume}<br>Adresa: $p->{adresa}<br>Oras: $p->{oras}<br>Numar: $p->{numar}<br>Anunturi: $p->{anunturi}<p>";
  123. # }
  124. }
  125. while (CGI::Fast->new) {
  126. my $op = param 'op' // '';
  127. append if $op eq 'append';
  128. info if $op eq 'info';
  129. view if $op eq 'view';
  130. }
  131. 1;
  132. __END__
  133. =head1 NAME
  134. zla2014 - Formular de înscriere la Ziua Libertății Aparatelor 2014
  135. =head1 AUTHORS
  136. Marius Gavrilescu E<lt>marius@ieval.roE<gt>
  137. Tiberiu C. Turbureanu E<lt>tct@ceata.org<gt>
  138. =head1 COPYRIGHT AND LICENSE
  139. Copyright (C) 2013, 2014 Fundația Ceata
  140. This program is free software: you can redistribute it and/or modify
  141. it under the terms of the GNU Affero General Public License as published by
  142. the Free Software Foundation, either version 3 of the License, or
  143. (at your option) any later version.
  144. This program is distributed in the hope that it will be useful,
  145. but WITHOUT ANY WARRANTY; without even the implied warranty of
  146. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  147. GNU Affero General Public License for more details.
  148. You should have received a copy of the GNU Affero General Public License
  149. along with this program. If not, see <http://www.gnu.org/licenses/>.
  150. =cut