2005-05-13 09:05:39 +00:00
|
|
|
<?php // $Id$
|
|
|
|
|
|
|
|
// Authorize.net
|
|
|
|
define('AN_HOST', 'secure.authorize.net');
|
|
|
|
define('AN_PORT', 443);
|
|
|
|
define('AN_PATH', '/gateway/transact.dll');
|
|
|
|
define('AN_APPROVED', '1');
|
|
|
|
define('AN_DECLINED', '2');
|
|
|
|
define('AN_ERROR', '3');
|
2005-05-16 15:37:11 +00:00
|
|
|
define('AN_DELIM', '|');
|
|
|
|
define('AN_ENCAP', '"');
|
2005-05-13 09:05:39 +00:00
|
|
|
|
|
|
|
require_once("$CFG->dirroot/enrol/enrol.class.php");
|
|
|
|
|
|
|
|
class enrolment_plugin extends enrolment_base {
|
|
|
|
|
2005-07-13 20:26:16 +00:00
|
|
|
var $ccerrormsg;
|
|
|
|
|
2005-05-13 09:05:39 +00:00
|
|
|
/// Override: print_entry()
|
|
|
|
function print_entry($course) {
|
2005-05-16 22:22:31 +00:00
|
|
|
global $CFG, $USER, $form;
|
|
|
|
|
2005-08-03 10:11:16 +00:00
|
|
|
if ($this->zero_cost($course) || isguest()) { // No money for guests ;)
|
2005-07-13 20:26:16 +00:00
|
|
|
parent::print_entry($course);
|
|
|
|
return;
|
|
|
|
}
|
2005-06-02 17:56:31 +00:00
|
|
|
|
2005-07-13 20:26:16 +00:00
|
|
|
// check payment
|
|
|
|
$this->check_paid();
|
2005-05-16 22:22:31 +00:00
|
|
|
|
2005-08-05 15:05:05 +00:00
|
|
|
// I want to paid on SSL.
|
|
|
|
if (empty($_SERVER['HTTPS'])) {
|
|
|
|
if (empty($CFG->loginhttps)) {
|
|
|
|
error(get_string("httpsrequired", "enrol_authorize"));
|
|
|
|
} else {
|
|
|
|
$wwwsroot = str_replace('http://','https://', $CFG->wwwroot);
|
|
|
|
$sdestination = "$wwwsroot/course/enrol.php?id=$course->id";
|
|
|
|
redirect($sdestination);
|
|
|
|
exit;
|
|
|
|
}
|
2005-07-18 16:42:30 +00:00
|
|
|
}
|
|
|
|
|
2005-07-13 20:26:16 +00:00
|
|
|
$CCTYPES = array(
|
2005-08-03 10:11:16 +00:00
|
|
|
'mcd' => 'Master Card', 'vis' => 'Visa', 'amx' => 'American Express',
|
|
|
|
'dsc' => 'Discover', 'dnc' => 'Diners Club', 'jcb' => 'JCB',
|
|
|
|
'swi' => 'Switch', 'dlt' => 'Delta', 'enr' => 'EnRoute'
|
2005-07-13 20:26:16 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
$formvars = array('password','ccfirstname','cclastname','cc','ccexpiremm','ccexpireyyyy','cctype','cvv','cczip');
|
|
|
|
foreach ($formvars as $var) {
|
|
|
|
if (!isset($form->$var)) {
|
|
|
|
$form->$var = '';
|
2005-08-03 10:11:16 +00:00
|
|
|
}
|
2005-07-13 20:26:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
$teacher = get_teacher($course->id);
|
|
|
|
$strloginto = get_string("loginto", "", $course->shortname);
|
|
|
|
$strcourses = get_string("courses");
|
|
|
|
$userfirstname = empty($form->ccfirstname) ? $USER->firstname : $form->ccfirstname;
|
|
|
|
$userlastname = empty($form->cclastname) ? $USER->lastname : $form->cclastname;
|
2005-07-14 16:17:28 +00:00
|
|
|
$curcost = $this->get_course_cost($course);
|
2005-07-13 20:26:16 +00:00
|
|
|
|
|
|
|
print_header($strloginto, $course->fullname, "<a href=\"$CFG->wwwroot/course/\">$strcourses</a> -> $strloginto");
|
|
|
|
print_course($course, "80%");
|
2005-08-05 15:05:05 +00:00
|
|
|
|
2005-08-03 10:11:16 +00:00
|
|
|
if ($course->password) {
|
2005-07-13 20:26:16 +00:00
|
|
|
print_simple_box(get_string('choosemethod', 'enrol_authorize'), 'center');
|
|
|
|
$password = '';
|
|
|
|
include($CFG->dirroot . '/enrol/internal/enrol.html');
|
|
|
|
}
|
|
|
|
|
2005-08-03 10:11:16 +00:00
|
|
|
print_simple_box_start("center");
|
|
|
|
include($CFG->dirroot . '/enrol/authorize/enrol.html');
|
|
|
|
print_simple_box_end();
|
2005-07-13 20:26:16 +00:00
|
|
|
|
|
|
|
print_footer();
|
2005-05-13 09:05:39 +00:00
|
|
|
}
|
|
|
|
|
2005-05-16 15:37:11 +00:00
|
|
|
/// Override: check_entry()
|
2005-05-13 09:05:39 +00:00
|
|
|
function check_entry($form, $course) {
|
2005-08-03 10:11:16 +00:00
|
|
|
if ($this->zero_cost($course) || isguest() || (!empty($form->password))) {
|
2005-07-13 20:26:16 +00:00
|
|
|
parent::check_entry($form, $course);
|
2005-05-16 22:22:31 +00:00
|
|
|
} else {
|
2005-07-13 20:26:16 +00:00
|
|
|
$this->cc_submit($form, $course);
|
2005-05-16 22:22:31 +00:00
|
|
|
}
|
2005-05-13 09:05:39 +00:00
|
|
|
}
|
|
|
|
|
2005-08-03 10:11:16 +00:00
|
|
|
function cc_submit($form, $course) {
|
2005-05-16 22:22:31 +00:00
|
|
|
global $CFG, $USER, $SESSION;
|
|
|
|
require_once($CFG->dirroot . '/enrol/authorize/ccval.php');
|
|
|
|
|
|
|
|
if (empty($form->ccfirstname) || empty($form->cclastname) ||
|
2005-08-01 14:34:30 +00:00
|
|
|
empty($form->cc) || empty($form->cvv) || empty($form->cctype) ||
|
|
|
|
empty($form->ccexpiremm) || empty($form->ccexpireyyyy) || empty($form->cczip)) {
|
2005-07-13 20:26:16 +00:00
|
|
|
$this->ccerrormsg = get_string("allfieldsrequired");
|
2005-06-02 17:56:31 +00:00
|
|
|
return;
|
2005-08-01 14:34:30 +00:00
|
|
|
}
|
2005-05-16 22:22:31 +00:00
|
|
|
|
2005-08-05 15:05:05 +00:00
|
|
|
$exp_date = ($form->ccexpiremm < 10) ? strval('0'.$form->ccexpiremm) : strval($form->ccexpiremm);
|
|
|
|
$exp_date .= $form->ccexpireyyyy;
|
2005-05-26 13:22:01 +00:00
|
|
|
$valid_cc = CCVal($form->cc, $form->cctype, $exp_date);
|
2005-07-14 16:17:28 +00:00
|
|
|
$curcost = $this->get_course_cost($course);
|
2005-07-25 13:17:25 +00:00
|
|
|
$useripno = getremoteaddr(); // HTTP_CLIENT_IP, HTTP_X_FORWARDED_FOR, REMOTE_ADDR
|
|
|
|
$order_number = 0; // can be get from db
|
2005-05-26 07:32:26 +00:00
|
|
|
|
2005-05-26 13:22:01 +00:00
|
|
|
if (!$valid_cc) {
|
2005-08-01 14:34:30 +00:00
|
|
|
$this->ccerrormsg = get_string( (($valid_cc===0) ? 'ccexpired' : 'ccinvalid'), 'enrol_authorize' );
|
2005-05-26 13:22:01 +00:00
|
|
|
return;
|
2005-05-16 22:22:31 +00:00
|
|
|
}
|
2005-05-26 13:22:01 +00:00
|
|
|
|
2005-05-16 22:22:31 +00:00
|
|
|
$this->check_paid();
|
|
|
|
$formdata = array (
|
2005-06-02 17:56:31 +00:00
|
|
|
'x_version' => '3.1',
|
|
|
|
'x_delim_data' => 'True',
|
|
|
|
'x_delim_char' => AN_DELIM,
|
|
|
|
'x_encap_char' => AN_ENCAP,
|
|
|
|
'x_relay_response' => 'False',
|
|
|
|
'x_login' => $CFG->an_login,
|
|
|
|
'x_test_request' => (!empty($CFG->an_test)) ? 'True' : 'False',
|
|
|
|
'x_type' => 'AUTH_CAPTURE',
|
|
|
|
'x_method' => 'CC',
|
|
|
|
'x_first_name' => (empty($form->ccfirstname) ? $USER->firstname : $form->ccfirstname),
|
|
|
|
'x_last_name' => (empty($form->cclastname) ? $USER->lastname : $form->cclastname),
|
|
|
|
'x_address' => $USER->address,
|
|
|
|
'x_city' => $USER->city,
|
|
|
|
'x_zip' => $form->cczip,
|
|
|
|
'x_country' => $USER->country,
|
|
|
|
'x_state' => '',
|
|
|
|
'x_card_num' => $form->cc,
|
|
|
|
'x_card_code' => $form->cvv,
|
2005-07-14 16:17:28 +00:00
|
|
|
'x_currency_code' => $curcost['currency'],
|
|
|
|
'x_amount' => $curcost['cost'],
|
2005-06-02 17:56:31 +00:00
|
|
|
'x_exp_date' => $exp_date,
|
|
|
|
'x_email' => $USER->email,
|
|
|
|
'x_email_customer' => 'False',
|
|
|
|
'x_cust_id' => $USER->id,
|
2005-07-25 13:17:25 +00:00
|
|
|
'x_customer_ip' => $useripno,
|
2005-06-02 17:56:31 +00:00
|
|
|
'x_phone' => '',
|
|
|
|
'x_fax' => '',
|
|
|
|
'x_invoice_num' => $order_number,
|
|
|
|
'x_description' => $course->shortname
|
2005-05-16 22:22:31 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
//build the post string
|
|
|
|
$poststring = '';
|
|
|
|
if (!empty($CFG->an_tran_key)) {
|
2005-08-01 14:34:30 +00:00
|
|
|
$poststring .= urlencode("x_tran_key") . "=" . urlencode($CFG->an_tran_key);
|
|
|
|
} else { // MUST be x_tran_key or x_password
|
|
|
|
$poststring .= urlencode("x_password") . "=" . urlencode($CFG->an_password);
|
2005-05-16 22:22:31 +00:00
|
|
|
}
|
|
|
|
foreach($formdata as $key => $val) {
|
2005-08-01 14:34:30 +00:00
|
|
|
$poststring .= "&" . urlencode($key) . "=" . urlencode($val);
|
2005-05-16 22:22:31 +00:00
|
|
|
}
|
|
|
|
//built
|
|
|
|
|
|
|
|
$response = array();
|
2005-08-01 14:34:30 +00:00
|
|
|
$anrefererheader = '';
|
2005-08-03 10:11:16 +00:00
|
|
|
if((!empty($CFG->an_referer)) && ($CFG->an_referer != "http://") && ($CFG->an_referer != "https://")) {
|
|
|
|
$anrefererheader = "Referer: " . $CFG->an_referer . "\r\n";
|
2005-05-16 22:22:31 +00:00
|
|
|
}
|
2005-06-02 17:56:31 +00:00
|
|
|
|
2005-05-16 22:22:31 +00:00
|
|
|
$fp = fsockopen("ssl://" . AN_HOST, AN_PORT, $errno, $errstr, 60);
|
|
|
|
if(!$fp) {
|
2005-08-01 14:34:30 +00:00
|
|
|
$this->ccerrormsg = "$errstr ($errno)";
|
|
|
|
return;
|
2005-05-16 22:22:31 +00:00
|
|
|
} else {
|
2005-07-25 15:03:38 +00:00
|
|
|
fputs($fp,
|
2005-06-02 17:56:31 +00:00
|
|
|
"POST " . AN_PATH . " HTTP/1.0\r\n" .
|
|
|
|
"Host: " . AN_HOST . "\r\n" .
|
|
|
|
$anrefererheader .
|
|
|
|
"Content-type: application/x-www-form-urlencoded\r\n" .
|
|
|
|
"Content-length: " . strlen($poststring) . "\r\n" .
|
|
|
|
"Connection: close\r\n\r\n" .
|
|
|
|
$poststring . "\r\n\r\n");
|
2005-07-25 15:03:38 +00:00
|
|
|
|
|
|
|
$str = '';
|
|
|
|
while(!feof($fp) && !stristr($str, 'content-length')) {
|
2005-06-02 17:56:31 +00:00
|
|
|
$str = fgets($fp, 4096);
|
|
|
|
}
|
2005-08-01 14:34:30 +00:00
|
|
|
// If didnt get content-lenght, something is wrong.
|
|
|
|
if (!stristr($str, 'content-length')) {
|
2005-07-25 15:03:38 +00:00
|
|
|
$this->ccerrormsg = "content-length error";
|
|
|
|
@fclose($fp);
|
|
|
|
return;
|
|
|
|
}
|
2005-08-01 14:34:30 +00:00
|
|
|
// Get length of data to be received.
|
2005-07-25 15:03:38 +00:00
|
|
|
$length = trim(substr($str,strpos($str,'content-length') + 15));
|
|
|
|
// Get buffer (blank data before real data)
|
|
|
|
fgets($fp, 4096);
|
|
|
|
// Get real data
|
|
|
|
$data = fgets($fp, $length);
|
|
|
|
@fclose($fp);
|
|
|
|
$response = explode(AN_ENCAP.AN_DELIM.AN_ENCAP, $data);
|
|
|
|
if ($response === false) {
|
|
|
|
$this->ccerrormsg = "response error";
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
$rcount = count($response) - 1;
|
|
|
|
if ($response[0]{0} == AN_ENCAP) {
|
|
|
|
$response[0] = substr($response[0], 1);
|
|
|
|
}
|
|
|
|
if (substr($response[$rcount], -1) == AN_ENCAP) {
|
|
|
|
$response[$rcount] = substr($response[$rcount], 0, -1);
|
|
|
|
}
|
2005-05-16 22:22:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($response[0] != AN_APPROVED) {
|
2005-07-25 15:03:38 +00:00
|
|
|
$this->ccerrormsg = isset($response[3]) ? $response[3] : 'unknown error';
|
2005-05-16 22:22:31 +00:00
|
|
|
} else {
|
2005-07-25 15:03:38 +00:00
|
|
|
$SESSION->ccpaid = 1; // security check: don't duplicate payment
|
|
|
|
if ($course->enrolperiod) {
|
|
|
|
$timestart = time();
|
|
|
|
$timeend = $timestart + $course->enrolperiod;
|
|
|
|
} else {
|
|
|
|
$timestart = $timeend = 0;
|
|
|
|
}
|
2005-05-16 22:22:31 +00:00
|
|
|
|
2005-07-25 15:03:38 +00:00
|
|
|
if (!enrol_student($USER->id, $course->id, $timestart, $timeend)) {
|
2005-08-05 15:05:05 +00:00
|
|
|
$this->email_to_admin("Error while trying to enrol ".fullname($USER)." in '$course->fullname'", $response);
|
2005-07-25 15:03:38 +00:00
|
|
|
} else {
|
|
|
|
// begin: send email
|
|
|
|
$teacher = get_teacher($course->id);
|
|
|
|
if (!empty($CFG->enrol_mailstudents)) {
|
|
|
|
$a->coursename = "$course->fullname";
|
|
|
|
$a->profileurl = "$CFG->wwwroot/user/view.php?id=$USER->id";
|
|
|
|
email_to_user($USER, $teacher, get_string("enrolmentnew", '', $course->shortname),
|
|
|
|
get_string('welcometocoursetext', '', $a));
|
|
|
|
}
|
|
|
|
if (!empty($CFG->enrol_mailteachers)) {
|
|
|
|
$a->course = "$course->fullname";
|
|
|
|
$a->user = fullname($USER);
|
|
|
|
email_to_user($teacher, $USER, get_string("enrolmentnew", '', $course->shortname),
|
|
|
|
get_string('enrolmentnewuser', '', $a));
|
|
|
|
}
|
|
|
|
if (!empty($CFG->enrol_mailadmins)) {
|
|
|
|
$a->course = "$course->fullname";
|
|
|
|
$a->user = fullname($USER);
|
|
|
|
$admins = get_admins();
|
|
|
|
foreach ($admins as $admin) {
|
|
|
|
email_to_user($admin, $USER, get_string("enrolmentnew", '', $course->shortname),
|
2005-08-01 14:34:30 +00:00
|
|
|
get_string('enrolmentnewuser', '', $a));
|
|
|
|
}
|
2005-07-25 15:03:38 +00:00
|
|
|
}
|
|
|
|
// end: send email
|
|
|
|
// begin: authorize_table
|
|
|
|
$datax->cclastfour = substr($form->cc, -4);
|
|
|
|
$datax->ccexp = $exp_date;
|
|
|
|
$datax->cvv = $form->cvv;
|
|
|
|
$datax->ccname = $formdata['x_first_name'] . " " . $formdata['x_last_name'];
|
|
|
|
$datax->courseid = $course->id;
|
|
|
|
$datax->userid = $USER->id;
|
|
|
|
$datax->avscode = strval($response[5]);
|
|
|
|
$datax->transid = strval($response[6]);
|
|
|
|
if (!insert_record("enrol_authorize", $datax)) { // Insert a transaction record
|
2005-08-05 15:05:05 +00:00
|
|
|
$this->email_to_admin("Error while trying to insert valid transaction", $datax);
|
2005-07-25 15:03:38 +00:00
|
|
|
}
|
|
|
|
} // end if (!enrol_student)
|
|
|
|
|
|
|
|
if ($SESSION->wantsurl) {
|
|
|
|
$destination = $SESSION->wantsurl;
|
|
|
|
unset($SESSION->wantsurl);
|
|
|
|
} else {
|
|
|
|
$destination = "$CFG->wwwroot/course/view.php?id=$course->id";
|
|
|
|
}
|
|
|
|
redirect($destination);
|
|
|
|
} // end if ($response[0] != AN_APPROVED)
|
2005-05-13 09:05:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function zero_cost($course) {
|
2005-07-14 16:17:28 +00:00
|
|
|
$curcost = $this->get_course_cost($course);
|
|
|
|
return (abs($curcost['cost']) < 0.01);
|
2005-05-13 09:05:39 +00:00
|
|
|
}
|
|
|
|
|
2005-05-25 16:27:53 +00:00
|
|
|
function get_course_cost($course) {
|
2005-05-16 22:22:31 +00:00
|
|
|
global $CFG;
|
|
|
|
$cost = (float)0;
|
2005-07-16 15:15:41 +00:00
|
|
|
|
|
|
|
if (!empty($course->cost)) {
|
2005-08-03 10:11:16 +00:00
|
|
|
$cost = (float)(((float)$course->cost) < 0) ? $CFG->enrol_cost : $course->cost;
|
2005-07-14 16:17:28 +00:00
|
|
|
}
|
|
|
|
|
2005-08-05 15:05:05 +00:00
|
|
|
$currency = (!empty($course->currency))
|
|
|
|
? $course->currency :( empty($CFG->enrol_currency)
|
|
|
|
? 'USD' : $CFG->enrol_currency );
|
2005-07-14 16:17:28 +00:00
|
|
|
|
2005-05-16 22:22:31 +00:00
|
|
|
$cost = format_float($cost, 2);
|
2005-08-03 10:11:16 +00:00
|
|
|
$ret = array('cost' => $cost, 'currency' => $currency);
|
2005-07-14 16:17:28 +00:00
|
|
|
|
2005-08-01 14:34:30 +00:00
|
|
|
return $ret;
|
2005-05-13 09:05:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Override the get_access_icons() function
|
|
|
|
function get_access_icons($course) {
|
2005-05-16 22:22:31 +00:00
|
|
|
|
2005-08-01 14:34:30 +00:00
|
|
|
$str = parent::get_access_icons($course);
|
2005-07-14 16:17:28 +00:00
|
|
|
$curcost = $this->get_course_cost($course);
|
2005-05-16 22:22:31 +00:00
|
|
|
|
2005-08-01 14:34:30 +00:00
|
|
|
if (abs($curcost['cost']) > 0.00) {
|
|
|
|
$strrequirespayment = get_string("requirespayment");
|
|
|
|
$strcost = get_string("cost");
|
|
|
|
$currency = $curcost['currency'];
|
|
|
|
|
|
|
|
switch ($currency) {
|
|
|
|
case 'USD': $currency = 'US$'; break;
|
|
|
|
case 'CAD': $currency = 'C$'; break;
|
|
|
|
case 'EUR': $currency = '€'; break;
|
|
|
|
case 'GBP': $currency = '£'; break;
|
|
|
|
case 'JPY': $currency = '¥'; break;
|
|
|
|
}
|
2005-05-16 22:22:31 +00:00
|
|
|
|
2005-08-01 14:34:30 +00:00
|
|
|
$str .= '<div class="cost" title="'.$strrequirespayment.'">'.$strcost.': ';
|
|
|
|
$str .= $currency . ' ' . $curcost['cost'].'</div>';
|
2005-05-16 22:22:31 +00:00
|
|
|
}
|
2005-08-01 14:34:30 +00:00
|
|
|
|
2005-05-16 22:22:31 +00:00
|
|
|
return $str;
|
2005-05-13 09:05:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function config_form($frm) {
|
2005-05-16 22:22:31 +00:00
|
|
|
global $CFG;
|
|
|
|
|
2005-08-24 14:59:42 +00:00
|
|
|
$vars = array('an_login', 'an_tran_key', 'an_password', 'an_referer', 'an_test', 'an_review', 'an_review_day',
|
2005-07-13 20:26:16 +00:00
|
|
|
'enrol_cost', 'enrol_currency', 'enrol_mailstudents', 'enrol_mailteachers', 'enrol_mailadmins');
|
2005-05-25 16:27:53 +00:00
|
|
|
|
2005-05-16 22:22:31 +00:00
|
|
|
foreach ($vars as $var) {
|
2005-07-13 20:26:16 +00:00
|
|
|
if (!isset($frm->$var)) {
|
|
|
|
$frm->$var = '';
|
|
|
|
}
|
2005-05-16 22:22:31 +00:00
|
|
|
}
|
|
|
|
|
2005-05-25 16:27:53 +00:00
|
|
|
if (!$this->check_openssl_loaded()) {
|
2005-08-01 14:34:30 +00:00
|
|
|
notify('PHP must be compiled with SSL support (--with-openssl)');
|
2005-05-25 16:27:53 +00:00
|
|
|
}
|
2005-08-03 10:11:16 +00:00
|
|
|
|
2005-05-25 16:27:53 +00:00
|
|
|
if (data_submitted()) { // something POSTed
|
|
|
|
// Some required fields
|
|
|
|
if (empty($frm->an_login)) {
|
2005-08-01 14:34:30 +00:00
|
|
|
notify("an_login required");
|
2005-05-25 16:27:53 +00:00
|
|
|
}
|
|
|
|
if (empty($frm->an_tran_key) && empty($frm->an_password)) {
|
2005-08-01 14:34:30 +00:00
|
|
|
notify("an_tran_key or an_password required");
|
2005-05-25 16:27:53 +00:00
|
|
|
}
|
2005-07-18 16:42:30 +00:00
|
|
|
if (empty($CFG->loginhttps)) {
|
2005-08-01 14:34:30 +00:00
|
|
|
notify("\$CFG->loginhttps MUST BE ON");
|
2005-07-18 16:42:30 +00:00
|
|
|
}
|
2005-05-25 16:27:53 +00:00
|
|
|
}
|
2005-05-13 09:05:39 +00:00
|
|
|
|
2005-08-03 10:11:16 +00:00
|
|
|
include($CFG->dirroot.'/enrol/authorize/config.html');
|
2005-05-13 09:05:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function process_config($config) {
|
2005-07-18 16:42:30 +00:00
|
|
|
global $CFG;
|
2005-05-13 09:05:39 +00:00
|
|
|
|
2005-07-25 15:03:38 +00:00
|
|
|
// enrol config
|
|
|
|
$val = optional_param('enrol_cost', 0, PARAM_INT);
|
|
|
|
set_config('enrol_cost', $val);
|
2005-05-25 16:27:53 +00:00
|
|
|
|
2005-07-25 15:03:38 +00:00
|
|
|
$val = optional_param('enrol_currency', 'USD', PARAM_ALPHA);
|
|
|
|
set_config('enrol_currency', $val);
|
2005-05-16 22:22:31 +00:00
|
|
|
|
2005-07-25 15:03:38 +00:00
|
|
|
$val = optional_param('enrol_mailstudents', '');
|
|
|
|
set_config('enrol_mailstudents', $val);
|
2005-05-16 22:22:31 +00:00
|
|
|
|
2005-07-25 15:03:38 +00:00
|
|
|
$val = optional_param('enrol_mailteachers', '');
|
|
|
|
set_config('enrol_mailteachers', $val);
|
2005-05-16 22:22:31 +00:00
|
|
|
|
2005-07-25 15:03:38 +00:00
|
|
|
$val = optional_param('enrol_mailadmins', '');
|
|
|
|
set_config('enrol_mailadmins', $val);
|
2005-05-16 22:22:31 +00:00
|
|
|
|
2005-07-25 15:03:38 +00:00
|
|
|
// authorize config
|
|
|
|
$return = $this->check_openssl_loaded();
|
2005-05-16 22:22:31 +00:00
|
|
|
|
2005-07-25 15:03:38 +00:00
|
|
|
$login_val = optional_param('an_login', '');
|
|
|
|
set_config('an_login', $login_val);
|
2005-05-16 22:22:31 +00:00
|
|
|
|
2005-07-25 15:03:38 +00:00
|
|
|
$password_val = optional_param('an_password', '');
|
|
|
|
set_config('an_password', $password_val);
|
2005-05-16 22:22:31 +00:00
|
|
|
|
2005-07-25 15:03:38 +00:00
|
|
|
$tran_val = optional_param('an_tran_key', '');
|
|
|
|
set_config('an_tran_key', $tran_val);
|
2005-05-16 22:22:31 +00:00
|
|
|
|
2005-07-25 15:03:38 +00:00
|
|
|
$test_val = optional_param('an_test', '');
|
|
|
|
set_config('an_test', $test_val);
|
2005-05-16 22:22:31 +00:00
|
|
|
|
2005-08-24 14:59:42 +00:00
|
|
|
$review_val = optional_param('an_review', '');
|
|
|
|
set_config('an_review', $review_val);
|
|
|
|
|
|
|
|
$review_day_val = optional_param('an_review_day', 5, PARAM_INT);
|
|
|
|
if ($review_day_val > 7) $review_day_val = 7;
|
|
|
|
set_config('an_review_day', $review_day_val);
|
|
|
|
|
2005-07-25 15:03:38 +00:00
|
|
|
$referer_val = optional_param('an_referer', 'http://', PARAM_URL);
|
|
|
|
set_config('an_referer', $referer_val);
|
2005-05-16 22:22:31 +00:00
|
|
|
|
2005-07-25 15:03:38 +00:00
|
|
|
// some required fields
|
|
|
|
if (empty($login_val)) {
|
2005-08-01 14:34:30 +00:00
|
|
|
$return = false;
|
2005-07-25 15:03:38 +00:00
|
|
|
}
|
|
|
|
if (empty($tran_val) && empty($password_val)) {
|
2005-08-01 14:34:30 +00:00
|
|
|
$return = false;
|
2005-07-25 15:03:38 +00:00
|
|
|
}
|
|
|
|
if (empty($CFG->loginhttps)) {
|
|
|
|
$return = false;
|
2005-05-16 22:22:31 +00:00
|
|
|
}
|
|
|
|
|
2005-05-25 16:27:53 +00:00
|
|
|
return $return;
|
2005-05-13 09:05:39 +00:00
|
|
|
}
|
|
|
|
|
2005-08-05 15:05:05 +00:00
|
|
|
function email_to_admin($subject, $data) {
|
2005-05-16 22:22:31 +00:00
|
|
|
$admin = get_admin();
|
2005-07-13 20:26:16 +00:00
|
|
|
$site = get_site();
|
2005-05-16 22:22:31 +00:00
|
|
|
|
|
|
|
$message = "$site->fullname: Transaction failed.\n\n$subject\n\n";
|
|
|
|
foreach ($data as $key => $value) {
|
2005-08-01 14:34:30 +00:00
|
|
|
$message .= "$key => $value\n";
|
2005-05-16 22:22:31 +00:00
|
|
|
}
|
|
|
|
email_to_user($admin, $admin, "CC ERROR: ".$subject, $message);
|
2005-05-13 09:27:26 +00:00
|
|
|
}
|
2005-05-13 09:05:39 +00:00
|
|
|
|
2005-05-16 15:37:11 +00:00
|
|
|
function check_paid() {
|
2005-05-16 22:22:31 +00:00
|
|
|
global $CFG, $SESSION;
|
2005-05-16 15:37:11 +00:00
|
|
|
|
2005-05-16 22:22:31 +00:00
|
|
|
if (isset($SESSION->ccpaid)) {
|
2005-08-01 14:34:30 +00:00
|
|
|
unset($SESSION->ccpaid);
|
|
|
|
redirect($CFG->wwwroot . '/login/logout.php');
|
|
|
|
exit;
|
2005-05-16 22:22:31 +00:00
|
|
|
}
|
2005-05-16 15:37:11 +00:00
|
|
|
}
|
|
|
|
|
2005-08-03 10:11:16 +00:00
|
|
|
function check_openssl_loaded() {
|
|
|
|
return extension_loaded('openssl');
|
|
|
|
}
|
|
|
|
|
2005-08-24 14:59:42 +00:00
|
|
|
function cron() {
|
|
|
|
global $CFG;
|
|
|
|
parent::cron();
|
|
|
|
|
|
|
|
if ( empty($CFG->an_review) || empty($CFG->an_review_day) || $CFG->an_review_day==0 )
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2005-05-13 09:27:26 +00:00
|
|
|
} // end of class definition
|
2005-05-16 22:22:31 +00:00
|
|
|
?>
|