Many misc fixes
This commit is contained in:
parent
f0f6479ca2
commit
d9c3394b0f
@ -222,7 +222,7 @@ class Auth_OSB extends Auth_ORM {
|
|||||||
|
|
||||||
// Load the user
|
// Load the user
|
||||||
$user = ORM::factory('account');
|
$user = ORM::factory('account');
|
||||||
$user->where($user->unique_key($username), '=', $username)->find();
|
$user->where('username','=',$username)->find();
|
||||||
}
|
}
|
||||||
|
|
||||||
// If the passwords match, perform a login
|
// If the passwords match, perform a login
|
||||||
|
@ -88,7 +88,7 @@ abstract class lnApp_Config extends Kohana_Config {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static function login_uri() {
|
public static function login_uri() {
|
||||||
return ($ao = Auth::instance()->get_user()) ? HTML::anchor('user/account/edit',$ao->name()) : HTML::anchor('login',_('Login'));
|
return ($ao = Auth::instance()->get_user() AND is_object($ao)) ? HTML::anchor('user/account/edit',$ao->name()) : HTML::anchor('login',_('Login'));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -130,8 +130,8 @@ class lnApp_Controller_Login extends Controller_TemplateDefault {
|
|||||||
|
|
||||||
// If the user posted their details to reset their password
|
// If the user posted their details to reset their password
|
||||||
if ($_POST) {
|
if ($_POST) {
|
||||||
// If the email address is correct, create a method token
|
// If the username is correct, create a method token
|
||||||
if (! empty($_POST['email']) AND ($ao=ORM::factory('account',array('email'=>$_POST['email']))) AND $ao->loaded()) {
|
if (! empty($_POST['username']) AND ($ao=ORM::factory('account',array('username'=>$_POST['username']))) AND $ao->loaded()) {
|
||||||
$mmto = ORM::factory('module_method_token')
|
$mmto = ORM::factory('module_method_token')
|
||||||
->method(array('account','user_resetpassword'))
|
->method(array('account','user_resetpassword'))
|
||||||
->account($ao)
|
->account($ao)
|
||||||
@ -164,7 +164,7 @@ class lnApp_Controller_Login extends Controller_TemplateDefault {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Show our token screen even if the email was invalid.
|
// Show our token screen even if the email was invalid.
|
||||||
if (isset($_POST['email']))
|
if (isset($_POST['username']))
|
||||||
Block::add(array(
|
Block::add(array(
|
||||||
'title'=>_('Reset your password'),
|
'title'=>_('Reset your password'),
|
||||||
'body'=>View::factory('login_reset_sent'),
|
'body'=>View::factory('login_reset_sent'),
|
||||||
|
@ -82,6 +82,7 @@ class Model_Module_Method_Token extends ORMOSB {
|
|||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// @todo Login Reset: When called within a timelimit (so existing token already exists), is returning true but password reset emails have blanks where the tokens are
|
||||||
public function generate() {
|
public function generate() {
|
||||||
if (! $this->account_id OR ! $this->method_id OR ! ($this->date_expire OR $this->uses))
|
if (! $this->account_id OR ! $this->method_id OR ! ($this->date_expire OR $this->uses))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -5,8 +5,8 @@
|
|||||||
|
|
||||||
<?php echo Form::open(); ?>
|
<?php echo Form::open(); ?>
|
||||||
<table class="login">
|
<table class="login">
|
||||||
<tr><td><b>Email Address</b></td></tr>
|
<tr><td><b>Username</b></td></tr>
|
||||||
<tr><td><?php echo Form::input('email',null,array('id'=>'login-uid','size'=>40));?></td></tr>
|
<tr><td><?php echo Form::input('username',null,array('id'=>'login-uid','size'=>40));?></td></tr>
|
||||||
<tr><td colspan="2" style="text-align: center;"><?php echo Form::submit('submit',_('Reset'),array('class'=>'form_button'));?></td></tr>
|
<tr><td colspan="2" style="text-align: center;"><?php echo Form::submit('submit',_('Reset'),array('class'=>'form_button'));?></td></tr>
|
||||||
</table>
|
</table>
|
||||||
<?php echo Form::close(); ?>
|
<?php echo Form::close(); ?>
|
||||||
|
@ -60,6 +60,13 @@ class Model_ADSL_Supplier extends ORMOSB {
|
|||||||
if (in_array($so->product->prod_plugin_data,$plans) OR in_array($so->plugin()->provided_adsl_plan_id,$plans))
|
if (in_array($so->product->prod_plugin_data,$plans) OR in_array($so->plugin()->provided_adsl_plan_id,$plans))
|
||||||
array_push($services,$so);
|
array_push($services,$so);
|
||||||
|
|
||||||
|
// @todo poor cludge, we should find them without using list_bylistgroup()
|
||||||
|
if (! $services)
|
||||||
|
foreach (ORM::factory('service')->list_bylistgroup('HSPA') as $so)
|
||||||
|
if (! $active OR $so->active)
|
||||||
|
if (in_array($so->product->prod_plugin_data,$plans) OR in_array($so->plugin()->provided_adsl_plan_id,$plans))
|
||||||
|
array_push($services,$so);
|
||||||
|
|
||||||
return $services;
|
return $services;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -70,11 +70,17 @@ class Service_Traffic_ADSL {
|
|||||||
* Traffic data from supplier
|
* Traffic data from supplier
|
||||||
*/
|
*/
|
||||||
public function update_traffic() {
|
public function update_traffic() {
|
||||||
|
if (CLI::options('verbose'))
|
||||||
|
echo ' - Last: '.date('Y-m-d',strtotime($this->last_update().'+1 day'))."\n";
|
||||||
|
|
||||||
$alreadyrun = FALSE;
|
$alreadyrun = FALSE;
|
||||||
for ($querydate=date('Y-m-d',strtotime($this->last_update().'+1 day'));
|
for ($querydate=date('Y-m-d',strtotime($this->last_update().'+1 day'));
|
||||||
$querydate<=$this->today;
|
$querydate<=$this->today;
|
||||||
$querydate=date('Y-m-d',strtotime($querydate.'+1 day'))) {
|
$querydate=date('Y-m-d',strtotime($querydate.'+1 day'))) {
|
||||||
|
|
||||||
|
if (CLI::options('verbose'))
|
||||||
|
echo " - Date: $querydate\n";
|
||||||
|
|
||||||
$goodfetch = false;
|
$goodfetch = false;
|
||||||
// @todo log this fetch in a "log"
|
// @todo log this fetch in a "log"
|
||||||
|
|
||||||
@ -82,6 +88,9 @@ class Service_Traffic_ADSL {
|
|||||||
// Data returned should be in MB's
|
// Data returned should be in MB's
|
||||||
$data = $this->getdata($querydate);
|
$data = $this->getdata($querydate);
|
||||||
|
|
||||||
|
if (CLI::options('verbose'))
|
||||||
|
print_r($data);
|
||||||
|
|
||||||
if (! $this->fetchresult) {
|
if (! $this->fetchresult) {
|
||||||
echo 'Bad fetch'.get_class($this);
|
echo 'Bad fetch'.get_class($this);
|
||||||
break;
|
break;
|
||||||
|
@ -39,6 +39,9 @@ class Service_Traffic_ADSL_ExetelHSPA extends Service_Traffic_ADSL {
|
|||||||
$update = array();
|
$update = array();
|
||||||
|
|
||||||
foreach ($this->so->services() as $so) {
|
foreach ($this->so->services() as $so) {
|
||||||
|
if (CLI::options('verbose'))
|
||||||
|
echo " = Service: ".$so->name()."\n";
|
||||||
|
|
||||||
if ($so->plugin()->service_stats_collect AND $so->plugin()->service_stats_lastupdate < $date) {
|
if ($so->plugin()->service_stats_collect AND $so->plugin()->service_stats_lastupdate < $date) {
|
||||||
// Start Session
|
// Start Session
|
||||||
$request = Request::factory($this->so->stats_url)
|
$request = Request::factory($this->so->stats_url)
|
||||||
|
@ -370,7 +370,7 @@ class Model_Invoice extends ORMOSB {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public function min_due($date) {
|
public function min_due($date) {
|
||||||
return ($date < time()) ? time()+ORM::factory('invoice')->config('DUE_DAYS_MIN')*86400 : $date;
|
return strtotime(date('Y-M-d',($date < time()) ? time()+ORM::factory('invoice')->config('DUE_DAYS_MIN')*86400 : $date));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function save(Validation $validation = NULL) {
|
public function save(Validation $validation = NULL) {
|
||||||
|
@ -534,6 +534,7 @@ class Controller_Admin_Service extends Controller_TemplateDefault_Admin {
|
|||||||
'recur_schedule'=>array('label'=>'Billing'),
|
'recur_schedule'=>array('label'=>'Billing'),
|
||||||
'date_next_invoice'=>array('label'=>'Next Invoice'),
|
'date_next_invoice'=>array('label'=>'Next Invoice'),
|
||||||
'price'=>array('label'=>'Price','class'=>'right'),
|
'price'=>array('label'=>'Price','class'=>'right'),
|
||||||
|
'charges_new()'=>array('label'=>'Charges','class'=>'right'),
|
||||||
'active'=>array('label'=>'Active'),
|
'active'=>array('label'=>'Active'),
|
||||||
'account->accnum()'=>array('label'=>'Cust ID'),
|
'account->accnum()'=>array('label'=>'Cust ID'),
|
||||||
'account->name()'=>array('label'=>'Customer'),
|
'account->name()'=>array('label'=>'Customer'),
|
||||||
|
@ -21,9 +21,13 @@ class Controller_Task_Service extends Controller_Task {
|
|||||||
* List all services by their default checkout method
|
* List all services by their default checkout method
|
||||||
*/
|
*/
|
||||||
public function action_gettraffic() {
|
public function action_gettraffic() {
|
||||||
foreach ($this->_traffic_suppliers(TRUE) as $aso)
|
foreach ($this->_traffic_suppliers(TRUE) as $aso) {
|
||||||
|
if (CLI::options('verbose'))
|
||||||
|
echo $aso->name."\n";
|
||||||
|
|
||||||
$traffic = Service_Traffic_ADSL::instance($aso->name)->update_traffic();
|
$traffic = Service_Traffic_ADSL::instance($aso->name)->update_traffic();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Charges for excess traffic usage
|
* Charges for excess traffic usage
|
||||||
|
@ -123,6 +123,11 @@ class Model_Service extends ORMOSB {
|
|||||||
return $this->invoice_item->order_by('date_start,date_stop')->find_all();
|
return $this->invoice_item->order_by('date_start,date_stop')->find_all();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// @todo To implement
|
||||||
|
public function charges_new() {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
/** LIST FUNCTIONS **/
|
/** LIST FUNCTIONS **/
|
||||||
|
|
||||||
private function _list_active() {
|
private function _list_active() {
|
||||||
|
@ -80,10 +80,7 @@ class Model_Service_Plugin_SSL extends Model_Service_Plugin {
|
|||||||
public function _details($type) {
|
public function _details($type) {
|
||||||
switch ($type) {
|
switch ($type) {
|
||||||
case 'invoice_detail_items':
|
case 'invoice_detail_items':
|
||||||
return array(
|
return array();
|
||||||
_('Service Address')=>$this->service_address ? $this->display('service_address') : '>NotSet<',
|
|
||||||
_('Contract Until')=>$this->contract_date_end(),
|
|
||||||
);
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
return parent::$_details($type);
|
return parent::$_details($type);
|
||||||
@ -125,17 +122,19 @@ class Model_Service_Plugin_SSL extends Model_Service_Plugin {
|
|||||||
public function renew() {
|
public function renew() {
|
||||||
$d = SSL::details($this->cert);
|
$d = SSL::details($this->cert);
|
||||||
$ssl_conf = Kohana::config('ssl');
|
$ssl_conf = Kohana::config('ssl');
|
||||||
|
// @todo change this so an admin can force this.
|
||||||
|
$force = TRUE;
|
||||||
|
|
||||||
// If our certificate is not old enough skip
|
// If our certificate is not old enough skip
|
||||||
if ($d['validTo_time_t'] > time()+$ssl_conf['min_renew_days']*86400)
|
if ($d['validTo_time_t'] > time()+$ssl_conf['min_renew_days']*86400 AND ! $force)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
$res = openssl_csr_sign($this->csr,$this->ssl_ca->sign_cert,$this->ssl_ca->sign_pk,$this->ssl->days,array(
|
$res = openssl_csr_sign($this->csr,$this->ssl_ca->sign_cert,$this->ssl_ca->sign_pk,$this->service->product->plugin()->days,array(
|
||||||
'config'=>$ssl_conf['config'],
|
'config'=>$ssl_conf['config'],
|
||||||
'x509_extensions'=>$this->ssl->extensions,
|
'x509_extensions'=>$this->service->product->plugin()->extensions,
|
||||||
),time());
|
),time());
|
||||||
|
|
||||||
if (openssl_x509_export($res,$cert)) {
|
if ($res AND openssl_x509_export($res,$cert)) {
|
||||||
$this->cert = $cert;
|
$this->cert = $cert;
|
||||||
$this->save();
|
$this->save();
|
||||||
|
|
||||||
|
@ -18,6 +18,6 @@ return array(
|
|||||||
'minpass_length' => 4,
|
'minpass_length' => 4,
|
||||||
|
|
||||||
// Location to openssl config
|
// Location to openssl config
|
||||||
'config' => 'appliation/config/openssl.cnf',
|
'config' => 'application/config/openssl.cnf',
|
||||||
);
|
);
|
||||||
?>
|
?>
|
||||||
|
Reference in New Issue
Block a user