X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Fview%2Fcust_bill-pdf.cgi;h=2ac0d0a3a474dce9ca939f67d312d9200a53d1a1;hb=822645aade15a4c4ac0558b116f7aacf9491002c;hp=2a86c32461c07db9206b355690f33b1e6d105e6f;hpb=e5f676566d9fd2dd61d5e48c26ccd9f4387f8cc8;p=freeside.git diff --git a/httemplate/view/cust_bill-pdf.cgi b/httemplate/view/cust_bill-pdf.cgi index 2a86c3246..2ac0d0a3a 100755 --- a/httemplate/view/cust_bill-pdf.cgi +++ b/httemplate/view/cust_bill-pdf.cgi @@ -1,17 +1,44 @@ -<% +<% $pdf %> +<%init> -#untaint invnum +die "access denied" + unless $FS::CurrentUser::CurrentUser->access_right('View invoices'); + +my( $invnum, $template, $notice_name ); my($query) = $cgi->keywords; -$query =~ /^(\d+)(.pdf)?$/; -my $invnum = $1; +if ( $query =~ /^((.+)-)?(\d+)(.pdf)?$/ ) { #probably not necessary anymore? + $template = $2; + $invnum = $3; + $notice_name = 'Invoice'; +} else { + $invnum = $cgi->param('invnum'); + $invnum =~ s/\.pdf//i; #probably not necessary anymore + $template = $cgi->param('template'); + $notice_name = ( $cgi->param('notice_name') || 'Invoice' ); +} + +my $conf = new FS::Conf; -my $cust_bill = qsearchs('cust_bill',{'invnum'=>$invnum}); +my %opt = ( + 'unsquelch_cdr' => $conf->exists('voip-cdr_email'), + 'template' => $template, + 'notice_name' => $notice_name, +); + +my $cust_bill = qsearchs({ + 'select' => 'cust_bill.*', + 'table' => 'cust_bill', + 'addl_from' => 'LEFT JOIN cust_main USING ( custnum )', + 'hashref' => { 'invnum' => $invnum }, + 'extra_sql' => ' AND '. $FS::CurrentUser::CurrentUser->agentnums_sql, +}); die "Invoice #$invnum not found!" unless $cust_bill; -my $pdf = $cust_bill->print_pdf; +my $pdf = $cust_bill->print_pdf(\%opt); http_header('Content-Type' => 'application/pdf' ); +http_header('Content-Disposition' => "filename=$invnum.pdf" ); http_header('Content-Length' => length($pdf) ); http_header('Cache-control' => 'max-age=60' ); -%> -<%= $pdf %> + +