2010-11-30 09:41:08 +11:00
|
|
|
<?php defined('SYSPATH') or die('No direct access allowed.');
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This class provides User Service functions
|
|
|
|
*
|
2013-03-20 09:35:19 +11:00
|
|
|
* @package Service
|
2010-11-30 09:41:08 +11:00
|
|
|
* @category Controllers/User
|
|
|
|
* @author Deon George
|
2013-03-20 09:35:19 +11:00
|
|
|
* @copyright (c) 2009-2013 Open Source Billing
|
2011-09-28 16:46:22 +10:00
|
|
|
* @license http://dev.osbill.net/license.html
|
2010-11-30 09:41:08 +11:00
|
|
|
*/
|
2013-06-04 21:50:41 +10:00
|
|
|
class Controller_User_Service extends Controller_Service {
|
2011-08-26 11:16:48 +10:00
|
|
|
protected $secure_actions = array(
|
2012-04-17 20:50:06 +10:00
|
|
|
'ajaxmanage'=>TRUE,
|
2010-11-30 09:41:08 +11:00
|
|
|
'list'=>TRUE,
|
|
|
|
'view'=>TRUE,
|
|
|
|
);
|
|
|
|
|
2013-06-04 21:50:41 +10:00
|
|
|
/**
|
|
|
|
* This ajax functions obtains the manage button login/password for this service
|
|
|
|
*/
|
2012-04-17 20:50:06 +10:00
|
|
|
public function action_ajaxmanage() {
|
2012-11-10 10:13:57 +11:00
|
|
|
$so = ORM::factory('Service',$this->request->param('id'));
|
2012-04-17 20:50:06 +10:00
|
|
|
$k = Session::instance()->get_once('manage_button');
|
2012-06-22 15:12:59 +10:00
|
|
|
$amo = $so->plugin(isset($_REQUEST['t']) ? $_REQUEST['t'] : '');
|
2012-04-17 20:50:06 +10:00
|
|
|
|
|
|
|
$o = array(
|
2012-06-22 15:12:59 +10:00
|
|
|
'u'=>$amo->username_value() ? $amo->username_value() : strtolower($amo->name()),
|
|
|
|
'p'=>(! $k OR ! $this->request->is_ajax() OR ! $so->loaded() OR ! isset($_REQUEST['k']) OR $k != $_REQUEST['k']) ? Random::char() : $amo->password_value(),
|
2012-04-17 20:50:06 +10:00
|
|
|
);
|
|
|
|
|
|
|
|
$this->response->headers('Content-Type','application/json');
|
|
|
|
$this->response->body(json_encode($o));
|
|
|
|
}
|
|
|
|
|
2010-11-30 09:41:08 +11:00
|
|
|
/**
|
2011-08-27 16:33:46 +10:00
|
|
|
* Show a list of services
|
2010-11-30 09:41:08 +11:00
|
|
|
*/
|
|
|
|
public function action_list() {
|
2013-06-04 21:50:41 +10:00
|
|
|
Block::factory()
|
|
|
|
->title(sprintf('Services for Account: %s',$this->ao->accnum()))
|
|
|
|
->title_icon('icon-th-list')
|
|
|
|
->body(Table::factory()
|
|
|
|
->jssort('services')
|
|
|
|
->data($this->ao->service->find_all())
|
|
|
|
->columns(array(
|
|
|
|
'id'=>'ID',
|
|
|
|
'service_name()'=>'Service',
|
|
|
|
'recur_schedule'=>'Billing',
|
|
|
|
'price(TRUE,TRUE)'=>'Price',
|
|
|
|
'status(TRUE)'=>'Active',
|
|
|
|
))
|
|
|
|
->prepend(array(
|
|
|
|
'id'=>array('url'=>URL::link('user','service/view/')),
|
|
|
|
))
|
|
|
|
);
|
2010-11-30 09:41:08 +11:00
|
|
|
}
|
|
|
|
|
2011-08-27 16:33:46 +10:00
|
|
|
public function action_view() {
|
2011-12-21 12:39:21 +11:00
|
|
|
list($id,$output) = Table::page(__METHOD__);
|
2011-08-27 16:33:46 +10:00
|
|
|
|
2012-11-10 10:13:57 +11:00
|
|
|
$so = ORM::factory('Service',$id);
|
2010-11-30 09:41:08 +11:00
|
|
|
|
2013-06-04 21:50:41 +10:00
|
|
|
if (! $so->loaded() OR ! Auth::instance()->authorised($so->account))
|
|
|
|
throw HTTP_Exception::factory(403,'Service either doesnt exist, or you are not authorised to see it');
|
2010-11-30 09:41:08 +11:00
|
|
|
|
2013-06-04 21:50:41 +10:00
|
|
|
$output .= View::factory('service/user/view')
|
|
|
|
->set('o',$so);
|
2011-08-27 16:33:46 +10:00
|
|
|
|
2013-06-04 21:50:41 +10:00
|
|
|
Block::factory()
|
|
|
|
->title(sprintf('%s: %s',$so->id(),$so->service_name()))
|
|
|
|
->title_icon('icon-list-alt')
|
|
|
|
->body($output);
|
2010-11-30 09:41:08 +11:00
|
|
|
}
|
|
|
|
}
|
|
|
|
?>
|