2008-11-26 14:50:40 -08:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* AgileBill - Open Billing Software
|
|
|
|
*
|
|
|
|
* This body of work is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the Open AgileBill License
|
|
|
|
* License as published at http://www.agileco.com/agilebill/license1-4.txt
|
2009-08-03 14:10:16 +10:00
|
|
|
*
|
|
|
|
* Originally authored by Tony Landis, AgileBill LLC
|
|
|
|
*
|
|
|
|
* Recent modifications by Deon George
|
|
|
|
*
|
|
|
|
* @author Deon George <deonATleenooksDOTnet>
|
|
|
|
* @copyright 2009 Deon George
|
|
|
|
* @link http://osb.leenooks.net
|
2008-11-26 14:50:40 -08:00
|
|
|
*
|
|
|
|
* @link http://www.agileco.com/
|
|
|
|
* @copyright 2004-2008 Agileco, LLC.
|
|
|
|
* @license http://www.agileco.com/agilebill/license1-4.txt
|
2009-08-03 14:10:16 +10:00
|
|
|
* @author Tony Landis <tony@agileco.com>
|
2008-11-26 14:50:40 -08:00
|
|
|
* @package AgileBill
|
2009-08-03 14:10:16 +10:00
|
|
|
* @subpackage Module:Campaign
|
2008-11-26 14:50:40 -08:00
|
|
|
*/
|
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
/**
|
|
|
|
* The main AgileBill Campaign Class
|
|
|
|
*
|
|
|
|
* @package AgileBill
|
|
|
|
* @subpackage Module:Campaign
|
|
|
|
*/
|
|
|
|
|
|
|
|
ob_start();
|
|
|
|
|
|
|
|
# Required includes:
|
2008-11-26 14:50:40 -08:00
|
|
|
require_once('../../config.inc.php');
|
2009-08-03 14:10:16 +10:00
|
|
|
require_once(PATH_ADODB.'adodb.inc.php');
|
|
|
|
require_once(PATH_CORE.'database.inc.php');
|
|
|
|
require_once(PATH_CORE.'vars.inc.php');
|
|
|
|
|
|
|
|
$C_debug = new CORE_debugger;
|
|
|
|
$C_vars = new CORE_vars;
|
|
|
|
$VAR = $C_vars->f;
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
if (! isset($VAR['id']))
|
|
|
|
exit;
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
$db = &DB();
|
|
|
|
$result = $db->Execute(sqlSelect($db,'campaign','*',array('id'=>$VAR['id'])));
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
if (! $result || ! $result->RecordCount())
|
|
|
|
exit;
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
if ($VAR['file']) {
|
2008-11-26 14:50:40 -08:00
|
|
|
$file_no = $VAR['file'];
|
2009-08-03 14:10:16 +10:00
|
|
|
|
|
|
|
} else {
|
|
|
|
# Random file:
|
|
|
|
$last = $result->fields['last_served'];
|
|
|
|
if (empty($last))
|
|
|
|
$last = 1;
|
|
|
|
|
|
|
|
$next = false;
|
|
|
|
|
|
|
|
for ($i=1; $i<=12; $i++) {
|
|
|
|
if (! empty($result->fields['file'.$i]) && ! $next) {
|
|
|
|
if ($i == $last)
|
2008-11-26 14:50:40 -08:00
|
|
|
$next = true;
|
2009-08-03 14:10:16 +10:00
|
|
|
} elseif (! empty($result->fields['file'.$i]) && $next) {
|
2008-11-26 14:50:40 -08:00
|
|
|
$file_no = $i;
|
|
|
|
$i = 20;
|
|
|
|
}
|
2009-08-03 14:10:16 +10:00
|
|
|
}
|
2008-11-26 14:50:40 -08:00
|
|
|
}
|
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
if (empty($file_no))
|
|
|
|
$file_no = '1';
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
$file = sprintf(PATH_FILES.'campaign_%s_%s.dat',$VAR['id'],$file_no);
|
|
|
|
$type = 'type'.$file_no;
|
|
|
|
$name = 'file'.$file_no;
|
2008-11-26 14:50:40 -08:00
|
|
|
$count_field= 'served'.$file_no;
|
2009-08-03 14:10:16 +10:00
|
|
|
$count = $result->fields[$count_field]+1;
|
|
|
|
|
|
|
|
# Open the file
|
|
|
|
if ($fh=fopen($file,'r')) {
|
|
|
|
# Display the correct headers:
|
|
|
|
header('Content-type: '.$result->fields[$type]);
|
|
|
|
header('Content-Disposition: inline; filename='.$result->fields[$name]);
|
|
|
|
header('Content-Description: PHP/INTERBASE Generated Data');
|
|
|
|
fpassthru($fh);
|
|
|
|
|
|
|
|
# Increment the file
|
|
|
|
if (! isset($VAR['_log']))
|
|
|
|
$result = $db->Execute(sqlUpdate($db,'campaign',array('last_served'=>$file_no,$count_field=>$count),array('id'=>$VAR['id'])));
|
|
|
|
|
|
|
|
exit;
|
2008-11-26 14:50:40 -08:00
|
|
|
}
|
2009-08-03 14:10:16 +10:00
|
|
|
|
|
|
|
echo _('Sorry, the campaign or required file does not exist!');
|
2008-11-26 14:50:40 -08:00
|
|
|
|
|
|
|
ob_end_flush();
|
2009-08-03 14:10:16 +10:00
|
|
|
?>
|