2013-10-10 13:44:53 +11:00
|
|
|
<?php defined('SYSPATH') or die('No direct access allowed.');
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This class supports Service Plugins.
|
|
|
|
*
|
|
|
|
* @package Service
|
|
|
|
* @category Models
|
|
|
|
* @author Deon George
|
|
|
|
* @copyright (c) 2009-2013 Open Source Billing
|
|
|
|
* @license http://dev.osbill.net/license.html
|
|
|
|
*/
|
|
|
|
abstract class Model_Service_Plugin extends ORM_OSB {
|
|
|
|
// Reset any sorting that may be defined in our parent
|
|
|
|
protected $_sorting = array();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Our service name as defined in the DB
|
|
|
|
*/
|
|
|
|
abstract public function name();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* When does our service expire
|
|
|
|
*/
|
|
|
|
abstract public function expire();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Show our service name as defined in the DB with product suffix.
|
|
|
|
*/
|
|
|
|
public function service_name() {
|
2013-04-26 11:42:09 +10:00
|
|
|
return sprintf('%s - %s',$this->service->product->title(),$this->name());
|
2013-10-10 13:44:53 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* View details of the service
|
|
|
|
*/
|
|
|
|
abstract public function service_view();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The table attributes that provide username/password values
|
|
|
|
*/
|
|
|
|
abstract public function username_value();
|
|
|
|
abstract public function password_value();
|
|
|
|
|
2013-11-09 15:51:08 +11:00
|
|
|
/**
|
|
|
|
* Form info for admins to update
|
|
|
|
*/
|
|
|
|
public function admin_update() {
|
|
|
|
return View::factory(sprintf('service/admin/plugin/%s/edit',$this->plugin()))
|
|
|
|
->set('o',$this);
|
|
|
|
}
|
|
|
|
|
2013-10-10 13:44:53 +11:00
|
|
|
public function manage_button() {
|
2013-09-06 15:39:56 +10:00
|
|
|
if (! $this->service->status OR $this->service->expiring())
|
2013-10-10 13:44:53 +11:00
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
static $k = '';
|
|
|
|
|
|
|
|
// If $k is already set, we've rendered this JS
|
|
|
|
if ($k)
|
|
|
|
return TRUE;
|
|
|
|
|
|
|
|
$k = Random::char();
|
|
|
|
Session::instance()->set('manage_button',$k);
|
|
|
|
|
|
|
|
Script::add(array('type'=>'stdin','data'=>'
|
|
|
|
$(document).ready(function() {
|
|
|
|
var x=0;
|
|
|
|
$("button[name=submit]").click(function() {
|
|
|
|
var t=$(this).val().split(":");
|
|
|
|
if (x++) { alert("Session expired, please refresh the page!"); return false; }
|
|
|
|
$.getJSON("'.URL::link('user','service/ajaxmanage/'.$this->service_id,TRUE).'", { k: "'.$k.'",t: t[1] }, function(data) {
|
|
|
|
$.each(data, function(key, val) { $("#"+key+"_"+t[0]+"_"+t[1]).val(val); });
|
|
|
|
}).error(function() { alert("There was a problem with the request"); return false; }).success(
|
|
|
|
function() { $("form[id=id_"+t[0]+"_"+t[1]+"]").submit(); });
|
|
|
|
});
|
|
|
|
});'
|
|
|
|
));
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2013-11-09 15:51:08 +11:00
|
|
|
protected function plugin() {
|
|
|
|
return strtolower(preg_replace('/(.*)_([a-zA-Z]+)$/',"$2",get_class($this)));
|
|
|
|
}
|
|
|
|
|
2013-10-10 13:44:53 +11:00
|
|
|
/**
|
|
|
|
* Get specific service details for use in other modules
|
|
|
|
* For Example: Invoice
|
|
|
|
*
|
|
|
|
* @todo Make the rendered items configurable
|
|
|
|
* @todo Change this method name, now that it is public
|
|
|
|
*/
|
|
|
|
public function _details($type) {
|
|
|
|
switch ($type) {
|
|
|
|
// Nothing to add for invoices
|
|
|
|
case 'invoice_detail_items':
|
|
|
|
return array();
|
|
|
|
|
|
|
|
default:
|
|
|
|
throw new Kohana_Exception('Unkown detail request :type',array(':type'=>$type));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
?>
|