WARNING: translation string unused: Captive 1week
WARNING: translation string unused: Captive activate
WARNING: translation string unused: Captive auth_lic
+WARNING: translation string unused: Captive auth_vou
+WARNING: translation string unused: Captive genvoucher
WARNING: translation string unused: Captive invalid_voucher
WARNING: translation string unused: Captive ip
WARNING: translation string unused: Captive nr
WARNING: translation string unused: Captive time
+WARNING: translation string unused: Captive voucher
WARNING: translation string unused: ConnSched scheduler
WARNING: translation string unused: ConnSched select profile
WARNING: translation string unused: HDD temperature
WARNING: translation string unused: yearly firewallhits
WARNING: untranslated string: Captive GAIN ACCESS
WARNING: untranslated string: Captive agree tac
-WARNING: untranslated string: Captive heading terms
-WARNING: untranslated string: Captive heading voucher
WARNING: untranslated string: Captive terms
WARNING: untranslated string: Scan for Songs
WARNING: untranslated string: addons
WARNING: translation string unused: Captive 1week
WARNING: translation string unused: Captive activate
WARNING: translation string unused: Captive auth_lic
+WARNING: translation string unused: Captive auth_vou
+WARNING: translation string unused: Captive heading terms
+WARNING: translation string unused: Captive heading voucher
WARNING: translation string unused: Captive invalid_voucher
WARNING: translation string unused: Captive ip
WARNING: translation string unused: Captive nr
WARNING: translation string unused: Captive time
+WARNING: translation string unused: Captive voucher
WARNING: translation string unused: ConnSched scheduler
WARNING: translation string unused: ConnSched select profile
WARNING: translation string unused: HDD temperature
WARNING: untranslated string: Captive activated
WARNING: untranslated string: Captive active on
WARNING: untranslated string: Captive agree tac
-WARNING: untranslated string: Captive auth_vou
WARNING: untranslated string: Captive authentication
WARNING: untranslated string: Captive brand color
WARNING: untranslated string: Captive config
+WARNING: untranslated string: Captive coupon
WARNING: untranslated string: Captive err doublevoucher
WARNING: untranslated string: Captive expire
-WARNING: untranslated string: Captive genvoucher
-WARNING: untranslated string: Captive heading terms
-WARNING: untranslated string: Captive heading voucher
+WARNING: untranslated string: Captive generate coupon
WARNING: untranslated string: Captive invalid logosize
WARNING: untranslated string: Captive logo_set
WARNING: untranslated string: Captive logo_upload
WARNING: untranslated string: Captive terms
WARNING: untranslated string: Captive title
WARNING: untranslated string: Captive voactive
-WARNING: untranslated string: Captive voucher
WARNING: untranslated string: Captive vouchervalid
WARNING: untranslated string: Captive vout
WARNING: untranslated string: Captive wrong ext
WARNING: untranslated string: Captive activated
WARNING: untranslated string: Captive active on
WARNING: untranslated string: Captive agree tac
-WARNING: untranslated string: Captive auth_vou
WARNING: untranslated string: Captive authentication
WARNING: untranslated string: Captive brand color
WARNING: untranslated string: Captive config
+WARNING: untranslated string: Captive coupon
WARNING: untranslated string: Captive err doublevoucher
WARNING: untranslated string: Captive expire
-WARNING: untranslated string: Captive genvoucher
-WARNING: untranslated string: Captive heading terms
-WARNING: untranslated string: Captive heading voucher
+WARNING: untranslated string: Captive generate coupon
WARNING: untranslated string: Captive invalid logosize
WARNING: untranslated string: Captive logo_set
WARNING: untranslated string: Captive logo_upload
WARNING: untranslated string: Captive terms
WARNING: untranslated string: Captive title
WARNING: untranslated string: Captive voactive
-WARNING: untranslated string: Captive voucher
WARNING: untranslated string: Captive vouchervalid
WARNING: untranslated string: Captive vout
WARNING: untranslated string: Captive wrong ext
WARNING: untranslated string: Captive activated
WARNING: untranslated string: Captive active on
WARNING: untranslated string: Captive agree tac
-WARNING: untranslated string: Captive auth_vou
WARNING: untranslated string: Captive authentication
WARNING: untranslated string: Captive brand color
WARNING: untranslated string: Captive config
+WARNING: untranslated string: Captive coupon
WARNING: untranslated string: Captive err doublevoucher
WARNING: untranslated string: Captive expire
-WARNING: untranslated string: Captive genvoucher
-WARNING: untranslated string: Captive heading terms
-WARNING: untranslated string: Captive heading voucher
+WARNING: untranslated string: Captive generate coupon
WARNING: untranslated string: Captive invalid logosize
WARNING: untranslated string: Captive logo_set
WARNING: untranslated string: Captive logo_upload
WARNING: untranslated string: Captive terms
WARNING: untranslated string: Captive title
WARNING: untranslated string: Captive voactive
-WARNING: untranslated string: Captive voucher
WARNING: untranslated string: Captive vouchervalid
WARNING: untranslated string: Captive vout
WARNING: untranslated string: Captive wrong ext
WARNING: untranslated string: Captive activated
WARNING: untranslated string: Captive active on
WARNING: untranslated string: Captive agree tac
-WARNING: untranslated string: Captive auth_vou
WARNING: untranslated string: Captive authentication
WARNING: untranslated string: Captive brand color
WARNING: untranslated string: Captive config
+WARNING: untranslated string: Captive coupon
WARNING: untranslated string: Captive err doublevoucher
WARNING: untranslated string: Captive expire
-WARNING: untranslated string: Captive genvoucher
-WARNING: untranslated string: Captive heading terms
-WARNING: untranslated string: Captive heading voucher
+WARNING: untranslated string: Captive generate coupon
WARNING: untranslated string: Captive invalid logosize
WARNING: untranslated string: Captive logo_set
WARNING: untranslated string: Captive logo_upload
WARNING: untranslated string: Captive terms
WARNING: untranslated string: Captive title
WARNING: untranslated string: Captive voactive
-WARNING: untranslated string: Captive voucher
WARNING: untranslated string: Captive vouchervalid
WARNING: untranslated string: Captive vout
WARNING: untranslated string: Captive wrong ext
WARNING: untranslated string: Captive activated
WARNING: untranslated string: Captive active on
WARNING: untranslated string: Captive agree tac
-WARNING: untranslated string: Captive auth_vou
WARNING: untranslated string: Captive authentication
WARNING: untranslated string: Captive brand color
WARNING: untranslated string: Captive config
+WARNING: untranslated string: Captive coupon
WARNING: untranslated string: Captive err doublevoucher
WARNING: untranslated string: Captive expire
-WARNING: untranslated string: Captive genvoucher
-WARNING: untranslated string: Captive heading terms
-WARNING: untranslated string: Captive heading voucher
+WARNING: untranslated string: Captive generate coupon
WARNING: untranslated string: Captive invalid logosize
WARNING: untranslated string: Captive logo_set
WARNING: untranslated string: Captive logo_upload
WARNING: untranslated string: Captive terms
WARNING: untranslated string: Captive title
WARNING: untranslated string: Captive voactive
-WARNING: untranslated string: Captive voucher
WARNING: untranslated string: Captive vouchervalid
WARNING: untranslated string: Captive vout
WARNING: untranslated string: Captive wrong ext
WARNING: untranslated string: Captive activated
WARNING: untranslated string: Captive active on
WARNING: untranslated string: Captive agree tac
-WARNING: untranslated string: Captive auth_vou
WARNING: untranslated string: Captive authentication
WARNING: untranslated string: Captive brand color
WARNING: untranslated string: Captive config
+WARNING: untranslated string: Captive coupon
WARNING: untranslated string: Captive err doublevoucher
WARNING: untranslated string: Captive expire
-WARNING: untranslated string: Captive genvoucher
-WARNING: untranslated string: Captive heading terms
-WARNING: untranslated string: Captive heading voucher
+WARNING: untranslated string: Captive generate coupon
WARNING: untranslated string: Captive invalid logosize
WARNING: untranslated string: Captive logo_set
WARNING: untranslated string: Captive logo_upload
WARNING: untranslated string: Captive terms
WARNING: untranslated string: Captive title
WARNING: untranslated string: Captive voactive
-WARNING: untranslated string: Captive voucher
WARNING: untranslated string: Captive vouchervalid
WARNING: untranslated string: Captive vout
WARNING: untranslated string: Captive wrong ext
WARNING: untranslated string: Captive activated
WARNING: untranslated string: Captive active on
WARNING: untranslated string: Captive agree tac
-WARNING: untranslated string: Captive auth_vou
WARNING: untranslated string: Captive authentication
WARNING: untranslated string: Captive brand color
WARNING: untranslated string: Captive config
+WARNING: untranslated string: Captive coupon
WARNING: untranslated string: Captive err doublevoucher
WARNING: untranslated string: Captive expire
-WARNING: untranslated string: Captive genvoucher
-WARNING: untranslated string: Captive heading terms
-WARNING: untranslated string: Captive heading voucher
+WARNING: untranslated string: Captive generate coupon
WARNING: untranslated string: Captive invalid logosize
WARNING: untranslated string: Captive logo_set
WARNING: untranslated string: Captive logo_upload
WARNING: untranslated string: Captive terms
WARNING: untranslated string: Captive title
WARNING: untranslated string: Captive voactive
-WARNING: untranslated string: Captive voucher
WARNING: untranslated string: Captive vouchervalid
WARNING: untranslated string: Captive vout
WARNING: untranslated string: Captive wrong ext
# Checking cgi-bin translations for language: en #
############################################################################
< addon
+< Captive genvoucher
< ccd maxclients
< ovpn_fragment
############################################################################
< Captive auth_vou
< Captive brand color
< Captive config
+< Captive coupon
< Captive err doublevoucher
< Captive expire
+< Captive generate coupon
< Captive genvoucher
< Captive invalid logosize
< Captive invalid_voucher
< Captive auth_vou
< Captive brand color
< Captive config
+< Captive coupon
< Captive err doublevoucher
< Captive expire
+< Captive generate coupon
< Captive genvoucher
< Captive invalid logosize
< Captive invalid_voucher
< Captive auth_vou
< Captive brand color
< Captive config
+< Captive coupon
< Captive err doublevoucher
< Captive expire
+< Captive generate coupon
< Captive genvoucher
< Captive invalid logosize
< Captive invalid_voucher
< Captive auth_vou
< Captive brand color
< Captive config
+< Captive coupon
< Captive err doublevoucher
< Captive expire
+< Captive generate coupon
< Captive genvoucher
< Captive invalid logosize
< Captive invalid_voucher
require "${General::swroot}/lang.pl";
require "${General::swroot}/header.pl";
+my $coupons = "${General::swroot}/captive/coupons";
+my %couponhash = ();
+
my %settings=();
my %mainsettings;
my %color;
my %netsettings=();
my %checked=();
my $errormessage='';
-my $voucherout="${General::swroot}/captive/voucher_out";
my $clients="${General::swroot}/captive/clients";
-my %voucherhash=();
my %clientshash=();
my $settingsfile="${General::swroot}/captive/settings";
my $logopath = "/srv/web/ipfire/html/captive/logo";
unless (-e $settingsfile) { system("touch $settingsfile"); }
-unless (-e $voucherout) { system("touch $voucherout"); }
&Header::getcgihash(\%cgiparams);
}
}
-if ($cgiparams{'ACTION'} eq "$Lang::tr{'Captive genvoucher'}"){
- #generates a voucher and writes it to /var/ipfire/voucher_out
+if ($cgiparams{'ACTION'} eq "$Lang::tr{'Captive generate coupon'}"){
+ # Generates a new coupon
#calculate expiredate
my $expire;
if($cgiparams{'EXP_HOUR'}+$cgiparams{'EXP_DAY'}+$cgiparams{'EXP_WEEK'}+$cgiparams{'EXP_MONTH'} == 0 && $cgiparams{'UNLIMITED'} == ''){
$errormessage=$Lang::tr{'Captive noexpiretime'};
}
- #check if we already have a voucher with same code
- &General::readhasharray("$voucherout", \%voucherhash);
- foreach my $key (keys %voucherhash) {
- if($voucherhash{$key}[1] eq $cgiparams{'CODE'}){
+ #check if we already have a coupon with same code
+ &General::readhasharray($coupons, \%couponhash) if (-e $coupons);
+ foreach my $key (keys %couponhash) {
+ if($couponhash{$key}[1] eq $cgiparams{'CODE'}){
$errormessage=$Lang::tr{'Captive err doublevoucher'};
last;
}
my $date=time(); #seconds in utc
#first get new key from hash
- my $key=&General::findhasharraykey (\%voucherhash);
+ my $key=&General::findhasharraykey (\%couponhash);
#initialize all fields with ''
- foreach my $i (0 .. 3) { $voucherhash{$key}[$i] = "";}
+ foreach my $i (0 .. 3) { $couponhash{$key}[$i] = "";}
#define fields
- $voucherhash{$key}[0] = $date;
- $voucherhash{$key}[1] = $cgiparams{'CODE'};
- $voucherhash{$key}[2] = $settings{'EXPIRE'};
- $voucherhash{$key}[3] = $cgiparams{'REMARK'};
+ $couponhash{$key}[0] = $date;
+ $couponhash{$key}[1] = $cgiparams{'CODE'};
+ $couponhash{$key}[2] = $settings{'EXPIRE'};
+ $couponhash{$key}[3] = $cgiparams{'REMARK'};
#write values to disk
- &General::writehasharray("$voucherout", \%voucherhash);
+ &General::writehasharray($coupons, \%couponhash);
#now prepare log entry, get expiring date for voucher and decode remark for logfile
- my $expdate=localtime(time()+$voucherhash{$key}[3]);
- my $rem=HTML::Entities::decode_entities($voucherhash{$key}[4]);
+ my $expdate=localtime(time()+$couponhash{$key}[3]);
+ my $rem=HTML::Entities::decode_entities($couponhash{$key}[4]);
#write logfile entry
- &General::log("Captive", "Generated new voucher $voucherhash{$key}[1] $voucherhash{$key}[2] hours valid expires on $expdate remark $rem");
+ &General::log("Captive", "Generated new coupon $couponhash{$key}[1] $couponhash{$key}[2] hours valid expires on $expdate remark $rem");
}
}
-if ($cgiparams{'ACTION'} eq 'delvoucherout'){
+if ($cgiparams{'ACTION'} eq 'delete-coupon') {
#deletes an already generated but unused voucher
#read all generated vouchers
- &General::readhasharray("$voucherout", \%voucherhash);
- foreach my $key (keys %voucherhash) {
- if($cgiparams{'key'} eq $voucherhash{$key}[0]){
+ &General::readhasharray($coupons, \%couponhash) if (-e $coupons);
+ foreach my $key (keys %couponhash) {
+ if($cgiparams{'key'} eq $couponhash{$key}[0]){
#write logenty with decoded remark
- my $rem=HTML::Entities::decode_entities($voucherhash{$key}[4]);
- &General::log("Captive", "Delete unused voucher $voucherhash{$key}[1] $voucherhash{$key}[2] hours valid expires on $voucherhash{$key}[3] remark $rem");
+ my $rem=HTML::Entities::decode_entities($couponhash{$key}[4]);
+ &General::log("Captive", "Delete unused coupon $couponhash{$key}[1] $couponhash{$key}[2] hours valid expires on $couponhash{$key}[3] remark $rem");
#delete line from hash
- delete $voucherhash{$key};
+ delete $couponhash{$key};
last;
}
}
#write back hash
- &General::writehasharray("$voucherout", \%voucherhash);
+ &General::writehasharray($coupons, \%couponhash);
}
-if ($cgiparams{'ACTION'} eq 'delvoucherinuse'){
+if ($cgiparams{'ACTION'} eq 'delete-client') {
#delete voucher and connection in use
#read all active clients
- &General::readhasharray("$clients", \%clientshash);
+ &General::readhasharray($clients, \%clientshash) if (-e $clients);
foreach my $key (keys %clientshash) {
if($cgiparams{'key'} eq $clientshash{$key}[0]){
#prepare log entry with decoded remark
my $rem=HTML::Entities::decode_entities($clientshash{$key}[7]);
#write logentry
- &General::log("Captive", "Delete voucher in use $clientshash{$key}[1] $clientshash{$key}[2] hours valid expires on $clientshash{$key}[3] remark $rem - Connection will be terminated");
+ &General::log("Captive", "Deleted client in use $clientshash{$key}[1] $clientshash{$key}[2] hours valid expires on $clientshash{$key}[3] remark $rem - Connection will be terminated");
#delete line from hash
delete $clientshash{$key};
last;
print " selected='selected'" if ($settings{'AUTH'} eq 'TERMS');
print ">$Lang::tr{'Captive terms'}</option>";
- print "<option value='VOUCHER' ";
- print " selected='selected'" if ($settings{'AUTH'} eq 'VOUCHER');
- print ">$Lang::tr{'Captive auth_vou'}</option>";
+ print "<option value='COUPON' ";
+ print " selected='selected'" if ($settings{'AUTH'} eq 'COUPON');
+ print ">$Lang::tr{'Captive coupon'}</option>";
print<<END
</select>
&Header::closebox();
- #if settings is set to use vouchers, the voucher part has to be displayed
- if ($settings{'AUTH'} eq 'VOUCHER'){
- &voucher();
+ #if settings is set to use coupons, the coupon part has to be displayed
+ if ($settings{'AUTH'} eq 'COUPON'){
+ &coupons();
}else{
#otherwise we show the licensepart
&show_license_connections();
return $randomstring;
}
-sub voucher(){
- #show voucher part
- &Header::openbox('100%', 'left', $Lang::tr{'Captive genvoucher'});
+sub coupons() {
+ &Header::openbox('100%', 'left', $Lang::tr{'Captive generate coupon'});
print "<form method='post' action='$ENV{'SCRIPT_NAME'}'>";
print "<table border='0' width='100%'>";
print "<tr><td width='30%'><br>$Lang::tr{'Captive vouchervalid'}</td><td width='70%'><br>";
print "<tr><td><br>$Lang::tr{'remark'}</td><td><br><input type='text' style='width: 98%;' name='REMARK' align='left'></td></tr>";
print "<tr><td> </td><td></td></tr></table><br><br>";
$cgiparams{'CODE'} = &gencode();
- print "<div align='right'><input type='submit' name='ACTION' value='$Lang::tr{'Captive genvoucher'}'><input type='hidden' name='CODE' value='$cgiparams{'CODE'}'></form></div>";
+ print "<div align='right'><input type='submit' name='ACTION' value='$Lang::tr{'Captive generate coupon'}'><input type='hidden' name='CODE' value='$cgiparams{'CODE'}'></form></div>";
&Header::closebox();
- if (! -z $voucherout) { &show_voucher_out();}
- if (! -z $clients) { &show_voucher_in_use();}
+
+ # Show all coupons if exist
+ if (! -z $coupons) {
+ &show_coupons();
+ }
+
+ if (! -z $clients) {
+ &show_clients();
+ }
}
sub show_license_connections(){
print<<END
<center><table class='tbl'>
<tr>
- <th align='center' width='15%'>$Lang::tr{'Captive voucher'}</th><th th align='center' width='15%'>$Lang::tr{'Captive activated'}</th><th th align='center' width='15%'>$Lang::tr{'Captive expire'}</th><th align='center' width='50%'><font size='1'>$Lang::tr{'Captive mac'}</th><th th align='center' width='5%'>$Lang::tr{'delete'}</th></tr>
+ <th align='center' width='15%'>$Lang::tr{'Captive coupon'}</th><th th align='center' width='15%'>$Lang::tr{'Captive activated'}</th><th th align='center' width='15%'>$Lang::tr{'Captive expire'}</th><th align='center' width='50%'><font size='1'>$Lang::tr{'Captive mac'}</th><th th align='center' width='5%'>$Lang::tr{'delete'}</th></tr>
END
;
#read all clients from hash and show table
- &General::readhasharray("$clients", \%clientshash);
+ &General::readhasharray($clients, \%clientshash) if (-e $clients);
foreach my $key (keys %clientshash){
my $starttime = sub{sprintf '%02d.%02d.%04d %02d:%02d', $_[3], $_[4]+1, $_[5]+1900, $_[2], $_[1] }->(localtime($clientshash{$key}[2]));
my $endtime;
}
print "<td $col><center>$clientshash{$key}[4]</td><td $col><center>$starttime ";
print "</center></td><td $col><center>$endtime ";
- print "</td><td $col><center>$clientshash{$key}[0]</td><td $col><form method='post'><center><input type='image' src='/images/delete.gif' align='middle' alt='$Lang::tr{'delete'}' title='$Lang::tr{'delete'}' /><form method='post'><input type='hidden' name='ACTION' value='delvoucherinuse' /><input type='hidden' name='key' value='$clientshash{$key}[0]' /></form></tr>";
+ print "</td><td $col><center>$clientshash{$key}[0]</td><td $col><form method='post'><center><input type='image' src='/images/delete.gif' align='middle' alt='$Lang::tr{'delete'}' title='$Lang::tr{'delete'}' /><form method='post'><input type='hidden' name='ACTION' value='delete-client' /><input type='hidden' name='key' value='$clientshash{$key}[0]' /></form></tr>";
$count++;
}
&Header::closebox();
}
-sub show_voucher_out(){
- #if there are already generated but unsused vouchers, print a table
- return if ( -z $voucherout);
+sub show_coupons() {
+ #if there are already generated but unsused coupons, print a table
my $count=0;
my $col;
&Header::openbox('100%', 'left', $Lang::tr{'Captive vout'});
print<<END
<center><table class='tbl' border='0'>
<tr>
- <th align='center' width='15%'>$Lang::tr{'Captive voucher'}</th><th align='center' width='15%'>$Lang::tr{'date'}</th><th th align='center' width='15%'>$Lang::tr{'Captive expire'}</th><th align='center' width='60%'>$Lang::tr{'remark'}</th><th align='center' width='5%'>$Lang::tr{'delete'}</th></tr>
+ <th align='center' width='15%'>$Lang::tr{'Captive coupon'}</th><th align='center' width='15%'>$Lang::tr{'date'}</th><th th align='center' width='15%'>$Lang::tr{'Captive expire'}</th><th align='center' width='60%'>$Lang::tr{'remark'}</th><th align='center' width='5%'>$Lang::tr{'delete'}</th></tr>
END
;
- &General::readhasharray("$voucherout", \%voucherhash);
- foreach my $key (keys %voucherhash)
+ &General::readhasharray($coupons, \%couponhash) if (-e $coupons);
+ foreach my $key (keys %couponhash)
{
- my $starttime = sub{sprintf '%02d.%02d.%04d %02d:%02d', $_[3], $_[4]+1, $_[5]+1900, $_[2], $_[1] }->(localtime($voucherhash{$key}[0]));
+ my $starttime = sub{sprintf '%02d.%02d.%04d %02d:%02d', $_[3], $_[4]+1, $_[5]+1900, $_[2], $_[1] }->(localtime($couponhash{$key}[0]));
my $endtime;
- if ($voucherhash{$key}[2] eq '0'){
+ if ($couponhash{$key}[2] eq '0'){
$endtime=$Lang::tr{'Captive nolimit'};
}else{
- $endtime=sub{sprintf '%02d.%02d.%04d %02d:%02d', $_[3], $_[4]+1, $_[5]+1900, $_[2], $_[1] }->(localtime(time()+$voucherhash{$key}[2]));
+ $endtime=sub{sprintf '%02d.%02d.%04d %02d:%02d', $_[3], $_[4]+1, $_[5]+1900, $_[2], $_[1] }->(localtime(time()+$couponhash{$key}[2]));
}
if ($count % 2){
print" <tr>";
}
- print "<td $col><center><b>$voucherhash{$key}[1]</b></td>";
+ print "<td $col><center><b>$couponhash{$key}[1]</b></td>";
print "<td $col><center>$starttime</td>";
print "<td $col><center>$endtime</td>";
- print "<td $col align='center'>$voucherhash{$key}[3]</td>";
- print "<td $col><form method='post'><center><input type='image' src='/images/delete.gif' align='middle' alt='$Lang::tr{'delete'}' title='$Lang::tr{'delete'}' /><form method='post'><input type='hidden' name='ACTION' value='delvoucherout' /><input type='hidden' name='key' value='$voucherhash{$key}[0]' /></form></tr>";
+ print "<td $col align='center'>$couponhash{$key}[3]</td>";
+ print "<td $col><form method='post'><center><input type='image' src='/images/delete.gif' align='middle' alt='$Lang::tr{'delete'}' title='$Lang::tr{'delete'}' /><form method='post'><input type='hidden' name='ACTION' value='delete-coupon' /><input type='hidden' name='key' value='$couponhash{$key}[0]' /></form></tr>";
$count++;
}
&Header::closebox();
}
-sub show_voucher_in_use(){
- #if there are active clients which use vouchers show table
+sub show_clients() {
+ #if there are active clients which use coupons show table
return if ( -z $clients || ! -f $clients );
my $count=0;
my $col;
print<<END
<center><table class='tbl' width='100%'>
<tr>
- <th align='center' width='15%'>$Lang::tr{'Captive voucher'}</th><th th align='center' width='15%'>$Lang::tr{'Captive activated'}</th><th align='center' width='15%'>$Lang::tr{'Captive expire'}</th><th align='center' width='10%'>$Lang::tr{'Captive mac'}</th><th align='center' width='43%'>$Lang::tr{'remark'}</th><th th align='center' width='5%'>$Lang::tr{'delete'}</th></tr>
+ <th align='center' width='15%'>$Lang::tr{'Captive coupon'}</th><th th align='center' width='15%'>$Lang::tr{'Captive activated'}</th><th align='center' width='15%'>$Lang::tr{'Captive expire'}</th><th align='center' width='10%'>$Lang::tr{'Captive mac'}</th><th align='center' width='43%'>$Lang::tr{'remark'}</th><th th align='center' width='5%'>$Lang::tr{'delete'}</th></tr>
END
;
- &General::readhasharray("$clients", \%clientshash);
+ &General::readhasharray($clients, \%clientshash) if (-e $clients);
foreach my $key (keys %clientshash)
{
#calculate time from clientshash (starttime)
print "<td $col><center><b>$clientshash{$key}[4]</b></td><td $col><center>$starttime ";
print "</center></td><td $col><center>$endtime</center></td><td $col><center>$clientshash{$key}[0]</td><td $col><center>$clientshash{$key}[5]</center>";
- print "</td><td $col><form method='post'><center><input type='image' src='/images/delete.gif' align='middle' alt='$Lang::tr{'delete'}' title='$Lang::tr{'delete'}' /><form method='post'><input type='hidden' name='ACTION' value='delvoucherinuse' /><input type='hidden' name='key' value='$clientshash{$key}[0]' /></form></tr>";
+ print "</td><td $col><form method='post'><center><input type='image' src='/images/delete.gif' align='middle' alt='$Lang::tr{'delete'}' title='$Lang::tr{'delete'}' /><form method='post'><input type='hidden' name='ACTION' value='delete-client' /><input type='hidden' name='key' value='$clientshash{$key}[0]' /></form></tr>";
$count++;
}
require '/var/ipfire/general-functions.pl';
require "${General::swroot}/lang.pl";
-#Set Variables
-my %voucherhash=();
+my $coupons = "${General::swroot}/captive/coupons";
+my %couponhash = ();
+
my %clientshash=();
my %cgiparams=();
my %settings=();
-my $voucherout="${General::swroot}/captive/voucher_out";
my $clients="${General::swroot}/captive/clients";
my $settingsfile="${General::swroot}/captive/settings";
my $errormessage;
# Current time
$clientshash{$key}[2] = time();
- if ($settings{"AUTH"} eq "VOUCHER") {
- &General::readhasharray("$voucherout", \%voucherhash);
+ if ($settings{"AUTH"} eq "COUPON") {
+ &General::readhasharray($coupons, \%couponhash);
- # Convert voucher input to uppercase
- $cgiparams{'VOUCHER'} = uc $cgiparams{'VOUCHER'};
+ # Convert coupon input to uppercase
+ $cgiparams{'COUPON'} = uc $cgiparams{'COUPON'};
- # Walk through all valid vouchers and find the right one
+ # Walk through all valid coupons and find the right one
my $found = 0;
- foreach my $voucher (keys %voucherhash) {
- if ($voucherhash{$voucher}[1] eq $cgiparams{'VOUCHER'}) {
+ foreach my $coupon (keys %couponhash) {
+ if ($couponhash{$coupon}[1] eq $cgiparams{'COUPON'}) {
$found = 1;
# Copy expiry time
- $clientshash{$key}[3] = $voucherhash{$voucher}[2];
+ $clientshash{$key}[3] = $couponhash{$coupon}[2];
- # Save voucher code
- $clientshash{$key}[4] = $cgiparams{'VOUCHER'};
+ # Save coupon code
+ $clientshash{$key}[4] = $cgiparams{'COUPON'};
- # Copy voucher remark
- $clientshash{$key}[5] = $voucherhash{$voucher}[3];
+ # Copy coupon remark
+ $clientshash{$key}[5] = $couponhash{$coupon}[3];
- # Delete used voucher
- delete $voucherhash{$voucher};
- &General::writehasharray("$voucherout", \%voucherhash);
+ # Delete used coupon
+ delete $couponhash{$coupon};
+ &General::writehasharray($coupons, \%couponhash);
last;
}
}
if ($found == 1) {
- &General::log("Captive", "Internet access granted via voucher ($clientshash{$key}[4]) for $ip_address until $clientshash{$key}[3]");
+ &General::log("Captive", "Internet access granted via coupon ($clientshash{$key}[4]) for $ip_address until $clientshash{$key}[3]");
} else {
- $errormessage = $Lang::tr{"Captive invalid_voucher"};
+ $errormessage = $Lang::tr{"Captive invalid coupon"};
}
# License
# Copy expiry time
$clientshash{$key}[3] = $settings{'EXPIRE'};
- # No voucher code
+ # No coupon code
$clientshash{$key}[4] = "LICENSE";
&General::log("Captive", "Internet access granted via license agreement for $ip_address until $clientshash{$key}[3]");
$tmpl->param(REDIRECT_URL => $url);
# Voucher
-if ($settings{'AUTH'} eq "VOUCHER") {
- $tmpl->param(VOUCHER => 1);
+if ($settings{'AUTH'} eq "COUPON") {
+ $tmpl->param(COUPON => 1);
}
$tmpl->param(TITLE => $settings{'TITLE'});
# Some translated strings
$tmpl->param(L_ACTIVATE => $Lang::tr{'Captive ACTIVATE'});
$tmpl->param(L_GAIN_ACCESS => $Lang::tr{'Captive GAIN ACCESS'});
-$tmpl->param(L_HEADING_TERMS => $Lang::tr{'Captive heading terms'});
-$tmpl->param(L_HEADING_VOUCHER => $Lang::tr{'Captive heading voucher'});
+$tmpl->param(L_HEADING_COUPON => $Lang::tr{'Captive coupon'});
+$tmpl->param(L_HEADING_TERMS => $Lang::tr{'Captive terms'});
$tmpl->param(L_AGREE_TAC => $Lang::tr{'Captive agree tac'});
# Print header
'Captive authentication' => 'Art der Anmeldung',
'Captive brand color' => 'Highlight-Farbe',
'Captive config' => 'Konfiguration',
+'Captive coupon' => 'Coupon',
'Captive err doublevoucher' => 'Ein Gutschein mit diesem Code ist bereits im Umlauf',
'Captive expire' => 'Ablauf',
+'Captive generate coupon' => 'Coupon generieren',
'Captive genvoucher' => 'Gutschein generieren',
'Captive invalid logosize' => 'Die hochgeladene Datei entspricht nicht der vorgegeben Auflösung von mindestens 1280x400 und maximal 1920x800 Pixeln',
'Captive invalid_voucher' => 'Dieser Code ist ungültig. Bitte versuchen Sie es erneut',
'Captive authentication' => 'Type of Access',
'Captive brand color' => 'Brand Color',
'Captive config' => 'Settings',
+'Captive coupon' => 'Coupon',
'Captive err doublevoucher' => 'A voucher with this code already exists',
'Captive expire' => 'Expire',
-'Captive genvoucher' => 'Generate voucher',
+'Captive generate coupon' => 'Generate Coupon',
'Captive heading terms' => 'Terms & Conditions',
'Captive heading voucher' => 'Voucher or Access Code',
'Captive invalid logosize' => 'The uploaded image file does not meet the required resolution of at least 1280x400 but not larger than 1920x800 pixels',