mirror of
https://github.com/moodle/moodle.git
synced 2025-02-24 12:03:12 +01:00
an_nextmail config deleted, instead of old config new an_dailysettlement inserted into config_plugins table. Merged from MOODLE_16_STABLE.
135 lines
6.8 KiB
PHP
135 lines
6.8 KiB
PHP
<?PHP //$Id$
|
|
|
|
// PostgreSQL commands for upgrading this enrolment module
|
|
|
|
function enrol_authorize_upgrade($oldversion=0) {
|
|
global $CFG, $THEME, $db;
|
|
require_once("$CFG->dirroot/enrol/authorize/const.php");
|
|
|
|
$result = true;
|
|
|
|
if (!$tables = $db->MetaColumns($CFG->prefix . 'enrol_authorize')) {
|
|
$installfirst = true;
|
|
}
|
|
|
|
if ($oldversion == 0 || !empty($installfirst)) { // First time install
|
|
$result = modify_database("$CFG->dirroot/enrol/authorize/db/postgres7.sql");
|
|
return $result; // RETURN, sql file contains last upgrades.
|
|
}
|
|
|
|
// Authorize module was installed before. Upgrades must be applied to SQL file.
|
|
|
|
if ($oldversion && $oldversion < 2005071602) {
|
|
notify("If you are using the authorize.net enrolment plugin for credit card
|
|
handling, please ensure that you have turned loginhttps ON in Admin >> Variables >> Security.");
|
|
}
|
|
|
|
if ($oldversion < 2005080200) {
|
|
// Be sure, only last 4 digit is inserted.
|
|
table_column('enrol_authorize', 'cclastfour', 'cclastfour', 'integer', '4', 'unsigned', '0', 'not null');
|
|
table_column('enrol_authorize', 'courseid', 'courseid', 'integer', '10', 'unsigned', '0', 'not null');
|
|
table_column('enrol_authorize', 'userid', 'userid', 'integer', '10', 'unsigned', '0', 'not null');
|
|
// Add some indexes for speed.
|
|
execute_sql("CREATE INDEX {$CFG->prefix}enrol_authorize_courseid_idx ON {$CFG->prefix}enrol_authorize (courseid);", false);
|
|
execute_sql("CREATE INDEX {$CFG->prefix}enrol_authorize_userid_idx ON {$CFG->prefix}enrol_authorize (userid);", false);
|
|
}
|
|
|
|
if ($oldversion < 2005112100) {
|
|
table_column('enrol_authorize', '', 'authcode', 'varchar', '6', '', '', '', 'avscode'); // CAPTURE_ONLY
|
|
table_column('enrol_authorize', '', 'status', 'integer', '10', 'unsigned', '0', 'not null', 'transid');
|
|
table_column('enrol_authorize', '', 'timecreated', 'integer', '10', 'unsigned', '0', 'not null', 'status');
|
|
table_column('enrol_authorize', '', 'timeupdated', 'integer', '10', 'unsigned', '0', 'not null', 'timecreated');
|
|
// status index for speed.
|
|
modify_database('',"CREATE INDEX prefix_enrol_authorize_status_idx ON prefix_enrol_authorize (status);");
|
|
// defaults.
|
|
$status = AN_STATUS_AUTH | AN_STATUS_CAPTURE;
|
|
execute_sql("UPDATE {$CFG->prefix}enrol_authorize SET status='$status' WHERE transid<>'0'", false);
|
|
$timenow = time();
|
|
execute_sql("UPDATE {$CFG->prefix}enrol_authorize SET timecreated='$timenow', timeupdated='$timenow'", false);
|
|
}
|
|
|
|
if ($oldversion < 2005121200) {
|
|
// new fields for refund and sales reports.
|
|
$defaultcurrency = empty($CFG->enrol_currency) ? 'USD' : $CFG->enrol_currency;
|
|
table_column('enrol_authorize', '', 'amount', 'varchar', '10', '', '0', 'not null', 'timeupdated');
|
|
table_column('enrol_authorize', '', 'currency', 'varchar', '3', '', $defaultcurrency, 'not null', 'amount');
|
|
modify_database("","CREATE TABLE prefix_enrol_authorize_refunds (
|
|
id SERIAL PRIMARY KEY,
|
|
orderid INTEGER NOT NULL default 0,
|
|
refundtype INTEGER NOT NULL default 0,
|
|
amount varchar(10) NOT NULL default '',
|
|
transid INTEGER NULL default 0
|
|
);");
|
|
modify_database("","CREATE INDEX prefix_enrol_authorize_refunds_orderid_idx ON prefix_enrol_authorize_refunds (orderid);");
|
|
// defaults.
|
|
if ($courses = get_records_select('course', '', '', 'id, cost, currency')) {
|
|
foreach ($courses as $course) {
|
|
execute_sql("UPDATE {$CFG->prefix}enrol_authorize
|
|
SET amount = '$course->cost', currency = '$course->currency'
|
|
WHERE courseid = '$course->id'", false);
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($oldversion < 2005122200) { // settletime
|
|
table_column('enrol_authorize_refunds', 'refundtype', 'status', 'integer', '1', 'unsigned', '0', 'not null');
|
|
table_column('enrol_authorize_refunds', '', 'settletime', 'integer', '10', 'unsigned', '0', 'not null', 'transid');
|
|
table_column('enrol_authorize', 'timeupdated', 'settletime', 'integer', '10', 'unsigned', '0', 'not null');
|
|
$status = AN_STATUS_AUTH | AN_STATUS_CAPTURE;
|
|
if ($settlements = get_records_select('enrol_authorize', "status='$status'", '', 'id, settletime')) {
|
|
include_once("$CFG->dirroot/enrol/authorize/authorizenetlib.php");
|
|
foreach ($settlements as $settlement) {
|
|
execute_sql("UPDATE {$CFG->prefix}enrol_authorize SET settletime = '" .
|
|
getsettletime($settlement->settletime) . "' WHERE id = '$settlement->id'", false);
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($oldversion < 2005122800) { // no need anymore some fields.
|
|
execute_sql("ALTER TABLE {$CFG->prefix}enrol_authorize DROP ccexp", false);
|
|
execute_sql("ALTER TABLE {$CFG->prefix}enrol_authorize DROP cvv", false);
|
|
execute_sql("ALTER TABLE {$CFG->prefix}enrol_authorize DROP avscode", false);
|
|
execute_sql("ALTER TABLE {$CFG->prefix}enrol_authorize DROP authcode", false);
|
|
}
|
|
|
|
if ($oldversion < 2006010200) { // rename an_review_day
|
|
if (isset($CFG->an_review_day)) {
|
|
set_config('an_capture_day', $CFG->an_review_day);
|
|
delete_records('config', 'name', 'an_review_day');
|
|
}
|
|
}
|
|
|
|
if ($oldversion < 2006020100) { // rename an_cutoff_hour and an_cutoff_min to an_cutoff
|
|
if (isset($CFG->an_cutoff_hour) && isset($CFG->an_cutoff_min)) {
|
|
$an_cutoff_hour = intval($CFG->an_cutoff_hour);
|
|
$an_cutoff_min = intval($CFG->an_cutoff_min);
|
|
$an_cutoff = ($an_cutoff_hour * 60) + $an_cutoff_min;
|
|
if (set_config('an_cutoff', $an_cutoff)) {
|
|
delete_records('config', 'name', 'an_cutoff_hour');
|
|
delete_records('config', 'name', 'an_cutoff_min');
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($oldversion < 2006021500) { // transid is int
|
|
table_column('enrol_authorize', 'transid', 'transid', 'integer', '10', 'unsigned', '0', 'not null');
|
|
}
|
|
|
|
if ($oldversion < 2006021501) { // delete an_nextmail record from config_plugins table
|
|
delete_records('config_plugins', 'name', 'an_nextmail');
|
|
}
|
|
|
|
if ($oldversion < 2006050400) { // Create transid indexes for backup & restore speed.
|
|
execute_sql("CREATE INDEX {$CFG->prefix}enrol_authorize_transid_idx ON {$CFG->prefix}enrol_authorize(transid);", false);
|
|
execute_sql("CREATE INDEX {$CFG->prefix}enrol_authorize_refunds_transid_idx ON {$CFG->prefix}enrol_authorize_refunds(transid);", false);
|
|
}
|
|
|
|
if ($oldversion < 2006060500) { // delete an_nextmail record from config_plugins table
|
|
delete_records('config_plugins', 'name', 'an_nextmail'); // run twice.
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
|
|
?>
|