rg-psgi
rg-smsd
t/App-RemoteGnokii.t
+t/perlcritic.t
+t/perlcriticrc
use strict;
use warnings;
our $VERSION = '0.000_001';
-$VERSION = eval $VERSION;
use Config::Any;
use File::Copy qw/move/;
my $cfg;
-sub cfg ($){
+sub cfg ($){ ## no critic (ProhibitSubroutinePrototypes)
unless ($cfg) {
$cfg = Config::Any->load_stems({stems => [$ENV{RGCONFIG} // '/etc/rg'], use_ext => 1, flatten_to_hash => 1});
my @cfg = values %$cfg;
sub sendsms {
my ($number, $text) = @_;
my ($fh, $file) = tempfile 'smsXXXX', TMPDIR => 1;
- print $fh "$number\n$text";
- close $fh;
+ print $fh "$number\n$text" or warn "print: $!"; ## no critic (RequireCarping)
+ close $fh or warn "close: $!"; ## no critic (RequireCarping)
move $file, cfg 'spool';
}
sub action {
my ($number, $date, $text) = @_;
my $password = cfg 'password';
- sendsms cfg 'number', <<EOF
+ sendsms cfg 'number', <<"EOF"
$password
$number
$date
my $correct_password = cfg 'password';
sub {
my $r = Plack::Request->new(shift);
- my @numbers = split ',', $r->param('numbers');
+ my @numbers = split /,/s, $r->param('numbers');
my $password = $r->param('password');
return [403, ['Content-Type', 'text/plain'], ['Bad password']] unless $password eq $correct_password;
my $text = $r->param('text');
--- /dev/null
+#!/usr/bin/perl
+use v5.14;
+use warnings;
+
+use Test::More;
+
+BEGIN { plan skip_all => '$ENV{RELEASE_TESTING} is false' unless $ENV{RELEASE_TESTING} }
+use Test::Perl::Critic -profile => 't/perlcriticrc';
+use Test::More tests => 1;
+
+critic_ok 'lib/App/RemoteGnokii.pm';
--- /dev/null
+severity = 1
+
+[-BuiltinFunctions::ProhibitComplexMappings]
+[-CodeLayout::RequireTidyCode]
+[-ControlStructures::ProhibitPostfixControls]
+[-ControlStructures::ProhibitUnlessBlocks]
+[-Documentation::PodSpelling]
+[-Documentation::RequirePodLinksIncludeText]
+[-InputOutput::RequireBracedFileHandleWithPrint]
+[-Modules::ProhibitAutomaticExportation]
+[-References::ProhibitDoubleSigils]
+[-RegularExpressions::ProhibitEnumeratedClasses]
+[-RegularExpressions::RequireLineBoundaryMatching]
+[-Subroutines::RequireFinalReturn]
+[-ValuesAndExpressions::ProhibitConstantPragma]
+[-ValuesAndExpressions::ProhibitEmptyQuotes]
+[-ValuesAndExpressions::ProhibitLeadingZeros]
+[-ValuesAndExpressions::ProhibitMagicNumbers]
+[-ValuesAndExpressions::ProhibitNoisyQuotes]
+[-Variables::ProhibitLocalVars]
+[-Variables::ProhibitPackageVars]
+[-Variables::ProhibitPunctuationVars]
+
+[BuiltinFunctions::ProhibitStringyEval]
+allow_includes = 1
+
+[RegularExpressions::RequireExtendedFormatting]
+minimum_regex_length_to_complain_about = 20
+
+[Documentation::RequirePodSections]
+lib_sections = NAME | SYNOPSIS | DESCRIPTION | AUTHOR | COPYRIGHT AND LICENSE
+script_sections = NAME | SYNOPSIS | DESCRIPTION | AUTHOR | COPYRIGHT AND LICENSE
+
+[Subroutines::RequireArgUnpacking]
+short_subroutine_statements = 5
+allow_subscripts = 1