@@ -17,9 +17,9 @@ discard block |
||
| 17 | 17 | $stages = glob(EE_CORE . 'data_migration_scripts/4_8_0_stages/*'); |
| 18 | 18 | $class_to_filepath = array(); |
| 19 | 19 | foreach ($stages as $filepath) { |
| 20 | - $matches = array(); |
|
| 21 | - preg_match('~4_8_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
|
| 22 | - $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 20 | + $matches = array(); |
|
| 21 | + preg_match('~4_8_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
|
| 22 | + $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 23 | 23 | } |
| 24 | 24 | // give addons a chance to autoload their stages too |
| 25 | 25 | $class_to_filepath = apply_filters('FHEE__EE_DMS_4_8_0__autoloaded_stages', $class_to_filepath); |
@@ -38,71 +38,71 @@ discard block |
||
| 38 | 38 | class EE_DMS_Core_4_8_0 extends EE_Data_Migration_Script_Base |
| 39 | 39 | { |
| 40 | 40 | |
| 41 | - /** |
|
| 42 | - * return EE_DMS_Core_4_8_0 |
|
| 43 | - * |
|
| 44 | - * @param TableManager $table_manager |
|
| 45 | - * @param TableAnalysis $table_analysis |
|
| 46 | - */ |
|
| 47 | - public function __construct(TableManager $table_manager = null, TableAnalysis $table_analysis = null) |
|
| 48 | - { |
|
| 49 | - $this->_pretty_name = esc_html__("Data Update to Event Espresso 4.8.0", "event_espresso"); |
|
| 50 | - $this->_priority = 10; |
|
| 51 | - $this->_migration_stages = array( |
|
| 52 | - new EE_DMS_4_8_0_pretax_totals(), |
|
| 53 | - new EE_DMS_4_8_0_event_subtotals(), |
|
| 54 | - ); |
|
| 55 | - parent::__construct($table_manager, $table_analysis); |
|
| 56 | - } |
|
| 41 | + /** |
|
| 42 | + * return EE_DMS_Core_4_8_0 |
|
| 43 | + * |
|
| 44 | + * @param TableManager $table_manager |
|
| 45 | + * @param TableAnalysis $table_analysis |
|
| 46 | + */ |
|
| 47 | + public function __construct(TableManager $table_manager = null, TableAnalysis $table_analysis = null) |
|
| 48 | + { |
|
| 49 | + $this->_pretty_name = esc_html__("Data Update to Event Espresso 4.8.0", "event_espresso"); |
|
| 50 | + $this->_priority = 10; |
|
| 51 | + $this->_migration_stages = array( |
|
| 52 | + new EE_DMS_4_8_0_pretax_totals(), |
|
| 53 | + new EE_DMS_4_8_0_event_subtotals(), |
|
| 54 | + ); |
|
| 55 | + parent::__construct($table_manager, $table_analysis); |
|
| 56 | + } |
|
| 57 | 57 | |
| 58 | 58 | |
| 59 | 59 | |
| 60 | - /** |
|
| 61 | - * Because this is being done at basically the same time as the MER-ready branch |
|
| 62 | - * of core, it's possible people might have installed MEr-ready branch first, |
|
| 63 | - * and then this one, in which case we still want to perform this migration, |
|
| 64 | - * even though the version might not have increased |
|
| 65 | - * |
|
| 66 | - * @param array $version_array |
|
| 67 | - * @return bool |
|
| 68 | - */ |
|
| 69 | - public function can_migrate_from_version($version_array) |
|
| 70 | - { |
|
| 71 | - $version_string = $version_array['Core']; |
|
| 72 | - if (version_compare($version_string, '4.8.0.decaf', '<') && version_compare($version_string, '4.7.0.decaf', '>=')) { |
|
| 60 | + /** |
|
| 61 | + * Because this is being done at basically the same time as the MER-ready branch |
|
| 62 | + * of core, it's possible people might have installed MEr-ready branch first, |
|
| 63 | + * and then this one, in which case we still want to perform this migration, |
|
| 64 | + * even though the version might not have increased |
|
| 65 | + * |
|
| 66 | + * @param array $version_array |
|
| 67 | + * @return bool |
|
| 68 | + */ |
|
| 69 | + public function can_migrate_from_version($version_array) |
|
| 70 | + { |
|
| 71 | + $version_string = $version_array['Core']; |
|
| 72 | + if (version_compare($version_string, '4.8.0.decaf', '<') && version_compare($version_string, '4.7.0.decaf', '>=')) { |
|
| 73 | 73 | // echo "$version_string can be migrated from"; |
| 74 | - return true; |
|
| 75 | - } elseif (! $version_string) { |
|
| 74 | + return true; |
|
| 75 | + } elseif (! $version_string) { |
|
| 76 | 76 | // echo "no version string provided: $version_string"; |
| 77 | - // no version string provided... this must be pre 4.3 |
|
| 78 | - return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 79 | - } else { |
|
| 77 | + // no version string provided... this must be pre 4.3 |
|
| 78 | + return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 79 | + } else { |
|
| 80 | 80 | // echo "$version_string doesnt apply"; |
| 81 | - return false; |
|
| 82 | - } |
|
| 83 | - } |
|
| 81 | + return false; |
|
| 82 | + } |
|
| 83 | + } |
|
| 84 | 84 | |
| 85 | 85 | |
| 86 | 86 | |
| 87 | - /** |
|
| 88 | - * @return bool |
|
| 89 | - */ |
|
| 90 | - public function schema_changes_before_migration() |
|
| 91 | - { |
|
| 92 | - require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 93 | - $now_in_mysql = current_time('mysql', true); |
|
| 94 | - require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 95 | - $table_name = 'esp_answer'; |
|
| 96 | - $sql = " ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 87 | + /** |
|
| 88 | + * @return bool |
|
| 89 | + */ |
|
| 90 | + public function schema_changes_before_migration() |
|
| 91 | + { |
|
| 92 | + require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 93 | + $now_in_mysql = current_time('mysql', true); |
|
| 94 | + require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 95 | + $table_name = 'esp_answer'; |
|
| 96 | + $sql = " ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 97 | 97 | REG_ID int(10) unsigned NOT NULL, |
| 98 | 98 | QST_ID int(10) unsigned NOT NULL, |
| 99 | 99 | ANS_value text NOT NULL, |
| 100 | 100 | PRIMARY KEY (ANS_ID), |
| 101 | 101 | KEY REG_ID (REG_ID), |
| 102 | 102 | KEY QST_ID (QST_ID)"; |
| 103 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 104 | - $table_name = 'esp_attendee_meta'; |
|
| 105 | - $sql = "ATTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 103 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 104 | + $table_name = 'esp_attendee_meta'; |
|
| 105 | + $sql = "ATTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 106 | 106 | ATT_ID bigint(20) unsigned NOT NULL, |
| 107 | 107 | ATT_fname varchar(45) NOT NULL, |
| 108 | 108 | ATT_lname varchar(45) NOT NULL, |
@@ -117,9 +117,9 @@ discard block |
||
| 117 | 117 | PRIMARY KEY (ATTM_ID), |
| 118 | 118 | KEY ATT_ID (ATT_ID), |
| 119 | 119 | KEY ATT_email (ATT_email(191))"; |
| 120 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 121 | - $table_name = 'esp_country'; |
|
| 122 | - $sql = "CNT_ISO varchar(2) collate utf8_bin NOT NULL, |
|
| 120 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 121 | + $table_name = 'esp_country'; |
|
| 122 | + $sql = "CNT_ISO varchar(2) collate utf8_bin NOT NULL, |
|
| 123 | 123 | CNT_ISO3 varchar(3) collate utf8_bin NOT NULL, |
| 124 | 124 | RGN_ID tinyint(3) unsigned DEFAULT NULL, |
| 125 | 125 | CNT_name varchar(45) collate utf8_bin NOT NULL, |
@@ -135,25 +135,25 @@ discard block |
||
| 135 | 135 | CNT_is_EU tinyint(1) DEFAULT '0', |
| 136 | 136 | CNT_active tinyint(1) DEFAULT '0', |
| 137 | 137 | PRIMARY KEY (CNT_ISO)"; |
| 138 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 139 | - $table_name = 'esp_currency'; |
|
| 140 | - $sql = "CUR_code varchar(6) collate utf8_bin NOT NULL, |
|
| 138 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 139 | + $table_name = 'esp_currency'; |
|
| 140 | + $sql = "CUR_code varchar(6) collate utf8_bin NOT NULL, |
|
| 141 | 141 | CUR_single varchar(45) collate utf8_bin DEFAULT 'dollar', |
| 142 | 142 | CUR_plural varchar(45) collate utf8_bin DEFAULT 'dollars', |
| 143 | 143 | CUR_sign varchar(45) collate utf8_bin DEFAULT '$', |
| 144 | 144 | CUR_dec_plc varchar(1) collate utf8_bin NOT NULL DEFAULT '2', |
| 145 | 145 | CUR_active tinyint(1) DEFAULT '0', |
| 146 | 146 | PRIMARY KEY (CUR_code)"; |
| 147 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 148 | - $table_name = 'esp_currency_payment_method'; |
|
| 149 | - $sql = "CPM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 147 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 148 | + $table_name = 'esp_currency_payment_method'; |
|
| 149 | + $sql = "CPM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 150 | 150 | CUR_code varchar(6) collate utf8_bin NOT NULL, |
| 151 | 151 | PMD_ID int(11) NOT NULL, |
| 152 | 152 | PRIMARY KEY (CPM_ID), |
| 153 | 153 | KEY PMD_ID (PMD_ID)"; |
| 154 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 155 | - $table_name = 'esp_datetime'; |
|
| 156 | - $sql = "DTT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 154 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 155 | + $table_name = 'esp_datetime'; |
|
| 156 | + $sql = "DTT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 157 | 157 | EVT_ID bigint(20) unsigned NOT NULL, |
| 158 | 158 | DTT_name varchar(255) NOT NULL DEFAULT '', |
| 159 | 159 | DTT_description text NOT NULL, |
@@ -169,9 +169,9 @@ discard block |
||
| 169 | 169 | KEY DTT_EVT_start (DTT_EVT_start), |
| 170 | 170 | KEY EVT_ID (EVT_ID), |
| 171 | 171 | KEY DTT_is_primary (DTT_is_primary)"; |
| 172 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 173 | - $table_name = 'esp_event_meta'; |
|
| 174 | - $sql = " |
|
| 172 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 173 | + $table_name = 'esp_event_meta'; |
|
| 174 | + $sql = " |
|
| 175 | 175 | EVTM_ID int(10) NOT NULL AUTO_INCREMENT, |
| 176 | 176 | EVT_ID bigint(20) unsigned NOT NULL, |
| 177 | 177 | EVT_display_desc tinyint(1) unsigned NOT NULL DEFAULT 1, |
@@ -187,34 +187,34 @@ discard block |
||
| 187 | 187 | EVT_donations tinyint(1) NULL, |
| 188 | 188 | PRIMARY KEY (EVTM_ID), |
| 189 | 189 | KEY EVT_ID (EVT_ID)"; |
| 190 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 191 | - $table_name = 'esp_event_question_group'; |
|
| 192 | - $sql = "EQG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 190 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 191 | + $table_name = 'esp_event_question_group'; |
|
| 192 | + $sql = "EQG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 193 | 193 | EVT_ID bigint(20) unsigned NOT NULL, |
| 194 | 194 | QSG_ID int(10) unsigned NOT NULL, |
| 195 | 195 | EQG_primary tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 196 | 196 | PRIMARY KEY (EQG_ID), |
| 197 | 197 | KEY EVT_ID (EVT_ID), |
| 198 | 198 | KEY QSG_ID (QSG_ID)"; |
| 199 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 200 | - $table_name = 'esp_event_venue'; |
|
| 201 | - $sql = "EVV_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 199 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 200 | + $table_name = 'esp_event_venue'; |
|
| 201 | + $sql = "EVV_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 202 | 202 | EVT_ID bigint(20) unsigned NOT NULL, |
| 203 | 203 | VNU_ID bigint(20) unsigned NOT NULL, |
| 204 | 204 | EVV_primary tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 205 | 205 | PRIMARY KEY (EVV_ID)"; |
| 206 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 207 | - $table_name = 'esp_extra_meta'; |
|
| 208 | - $sql = "EXM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 206 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 207 | + $table_name = 'esp_extra_meta'; |
|
| 208 | + $sql = "EXM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 209 | 209 | OBJ_ID int(11) DEFAULT NULL, |
| 210 | 210 | EXM_type varchar(45) DEFAULT NULL, |
| 211 | 211 | EXM_key varchar(45) DEFAULT NULL, |
| 212 | 212 | EXM_value text, |
| 213 | 213 | PRIMARY KEY (EXM_ID), |
| 214 | 214 | KEY EXM_type (EXM_type,OBJ_ID,EXM_key)"; |
| 215 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 216 | - $table_name = 'esp_extra_join'; |
|
| 217 | - $sql = "EXJ_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 215 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 216 | + $table_name = 'esp_extra_join'; |
|
| 217 | + $sql = "EXJ_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 218 | 218 | EXJ_first_model_id varchar(6) NOT NULL, |
| 219 | 219 | EXJ_first_model_name varchar(20) NOT NULL, |
| 220 | 220 | EXJ_second_model_id varchar(6) NOT NULL, |
@@ -222,9 +222,9 @@ discard block |
||
| 222 | 222 | PRIMARY KEY (EXJ_ID), |
| 223 | 223 | KEY first_model (EXJ_first_model_name,EXJ_first_model_id), |
| 224 | 224 | KEY second_model (EXJ_second_model_name,EXJ_second_model_id)"; |
| 225 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 226 | - $table_name = 'esp_line_item'; |
|
| 227 | - $sql = "LIN_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 225 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 226 | + $table_name = 'esp_line_item'; |
|
| 227 | + $sql = "LIN_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 228 | 228 | LIN_code varchar(245) NOT NULL DEFAULT '', |
| 229 | 229 | TXN_ID int(11) DEFAULT NULL, |
| 230 | 230 | LIN_name varchar(245) NOT NULL DEFAULT '', |
@@ -243,9 +243,9 @@ discard block |
||
| 243 | 243 | PRIMARY KEY (LIN_ID), |
| 244 | 244 | KEY LIN_code (LIN_code(191)), |
| 245 | 245 | KEY TXN_ID (TXN_ID)"; |
| 246 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 247 | - $table_name = 'esp_log'; |
|
| 248 | - $sql = "LOG_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 246 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 247 | + $table_name = 'esp_log'; |
|
| 248 | + $sql = "LOG_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 249 | 249 | LOG_time datetime DEFAULT NULL, |
| 250 | 250 | OBJ_ID varchar(45) DEFAULT NULL, |
| 251 | 251 | OBJ_type varchar(45) DEFAULT NULL, |
@@ -256,18 +256,18 @@ discard block |
||
| 256 | 256 | KEY LOG_time (LOG_time), |
| 257 | 257 | KEY OBJ (OBJ_type,OBJ_ID), |
| 258 | 258 | KEY LOG_type (LOG_type)"; |
| 259 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 260 | - $table_name = 'esp_message_template'; |
|
| 261 | - $sql = "MTP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 259 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 260 | + $table_name = 'esp_message_template'; |
|
| 261 | + $sql = "MTP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 262 | 262 | GRP_ID int(10) unsigned NOT NULL, |
| 263 | 263 | MTP_context varchar(50) NOT NULL, |
| 264 | 264 | MTP_template_field varchar(30) NOT NULL, |
| 265 | 265 | MTP_content text NOT NULL, |
| 266 | 266 | PRIMARY KEY (MTP_ID), |
| 267 | 267 | KEY GRP_ID (GRP_ID)"; |
| 268 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 269 | - $table_name = 'esp_message_template_group'; |
|
| 270 | - $sql = "GRP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 268 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 269 | + $table_name = 'esp_message_template_group'; |
|
| 270 | + $sql = "GRP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 271 | 271 | MTP_user_id int(10) NOT NULL DEFAULT '1', |
| 272 | 272 | MTP_name varchar(245) NOT NULL DEFAULT '', |
| 273 | 273 | MTP_description varchar(245) NOT NULL DEFAULT '', |
@@ -279,17 +279,17 @@ discard block |
||
| 279 | 279 | MTP_is_active tinyint(1) NOT NULL DEFAULT '1', |
| 280 | 280 | PRIMARY KEY (GRP_ID), |
| 281 | 281 | KEY MTP_user_id (MTP_user_id)"; |
| 282 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 283 | - $table_name = 'esp_event_message_template'; |
|
| 284 | - $sql = "EMT_ID bigint(20) unsigned NOT NULL AUTO_INCREMENT, |
|
| 282 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 283 | + $table_name = 'esp_event_message_template'; |
|
| 284 | + $sql = "EMT_ID bigint(20) unsigned NOT NULL AUTO_INCREMENT, |
|
| 285 | 285 | EVT_ID bigint(20) unsigned NOT NULL DEFAULT 0, |
| 286 | 286 | GRP_ID int(10) unsigned NOT NULL DEFAULT 0, |
| 287 | 287 | PRIMARY KEY (EMT_ID), |
| 288 | 288 | KEY EVT_ID (EVT_ID), |
| 289 | 289 | KEY GRP_ID (GRP_ID)"; |
| 290 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 291 | - $table_name = 'esp_payment'; |
|
| 292 | - $sql = "PAY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 290 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 291 | + $table_name = 'esp_payment'; |
|
| 292 | + $sql = "PAY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 293 | 293 | TXN_ID int(10) unsigned DEFAULT NULL, |
| 294 | 294 | STS_ID varchar(3) collate utf8_bin DEFAULT NULL, |
| 295 | 295 | PAY_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
@@ -306,9 +306,9 @@ discard block |
||
| 306 | 306 | PRIMARY KEY (PAY_ID), |
| 307 | 307 | KEY PAY_timestamp (PAY_timestamp), |
| 308 | 308 | KEY TXN_ID (TXN_ID)"; |
| 309 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 310 | - $table_name = 'esp_payment_method'; |
|
| 311 | - $sql = "PMD_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 309 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 310 | + $table_name = 'esp_payment_method'; |
|
| 311 | + $sql = "PMD_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 312 | 312 | PMD_type varchar(124) DEFAULT NULL, |
| 313 | 313 | PMD_name varchar(255) DEFAULT NULL, |
| 314 | 314 | PMD_desc text, |
@@ -324,32 +324,32 @@ discard block |
||
| 324 | 324 | PRIMARY KEY (PMD_ID), |
| 325 | 325 | UNIQUE KEY PMD_slug_UNIQUE (PMD_slug), |
| 326 | 326 | KEY PMD_type (PMD_type)"; |
| 327 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 328 | - $table_name = "esp_ticket_price"; |
|
| 329 | - $sql = "TKP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 327 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 328 | + $table_name = "esp_ticket_price"; |
|
| 329 | + $sql = "TKP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 330 | 330 | TKT_ID int(10) unsigned NOT NULL, |
| 331 | 331 | PRC_ID int(10) unsigned NOT NULL, |
| 332 | 332 | PRIMARY KEY (TKP_ID), |
| 333 | 333 | KEY TKT_ID (TKT_ID), |
| 334 | 334 | KEY PRC_ID (PRC_ID)"; |
| 335 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 336 | - $table_name = "esp_datetime_ticket"; |
|
| 337 | - $sql = "DTK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 335 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 336 | + $table_name = "esp_datetime_ticket"; |
|
| 337 | + $sql = "DTK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 338 | 338 | DTT_ID int(10) unsigned NOT NULL, |
| 339 | 339 | TKT_ID int(10) unsigned NOT NULL, |
| 340 | 340 | PRIMARY KEY (DTK_ID), |
| 341 | 341 | KEY DTT_ID (DTT_ID), |
| 342 | 342 | KEY TKT_ID (TKT_ID)"; |
| 343 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 344 | - $table_name = "esp_ticket_template"; |
|
| 345 | - $sql = "TTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 343 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 344 | + $table_name = "esp_ticket_template"; |
|
| 345 | + $sql = "TTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 346 | 346 | TTM_name varchar(45) NOT NULL, |
| 347 | 347 | TTM_description text, |
| 348 | 348 | TTM_file varchar(45), |
| 349 | 349 | PRIMARY KEY (TTM_ID)"; |
| 350 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 351 | - $table_name = 'esp_question'; |
|
| 352 | - $sql = 'QST_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 350 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 351 | + $table_name = 'esp_question'; |
|
| 352 | + $sql = 'QST_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 353 | 353 | QST_display_text text NOT NULL, |
| 354 | 354 | QST_admin_label varchar(255) NOT NULL, |
| 355 | 355 | QST_system varchar(25) NOT NULL DEFAULT "", |
@@ -363,18 +363,18 @@ discard block |
||
| 363 | 363 | QST_deleted tinyint(2) unsigned NOT NULL DEFAULT 0, |
| 364 | 364 | PRIMARY KEY (QST_ID), |
| 365 | 365 | KEY QST_order (QST_order)'; |
| 366 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 367 | - $table_name = 'esp_question_group_question'; |
|
| 368 | - $sql = "QGQ_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 366 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 367 | + $table_name = 'esp_question_group_question'; |
|
| 368 | + $sql = "QGQ_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 369 | 369 | QSG_ID int(10) unsigned NOT NULL, |
| 370 | 370 | QST_ID int(10) unsigned NOT NULL, |
| 371 | 371 | QGQ_order int(10) unsigned NOT NULL DEFAULT 0, |
| 372 | 372 | PRIMARY KEY (QGQ_ID), |
| 373 | 373 | KEY QST_ID (QST_ID), |
| 374 | 374 | KEY QSG_ID_order (QSG_ID,QGQ_order)"; |
| 375 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 376 | - $table_name = 'esp_question_option'; |
|
| 377 | - $sql = "QSO_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 375 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 376 | + $table_name = 'esp_question_option'; |
|
| 377 | + $sql = "QSO_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 378 | 378 | QSO_value varchar(255) NOT NULL, |
| 379 | 379 | QSO_desc text NOT NULL, |
| 380 | 380 | QST_ID int(10) unsigned NOT NULL, |
@@ -384,9 +384,9 @@ discard block |
||
| 384 | 384 | PRIMARY KEY (QSO_ID), |
| 385 | 385 | KEY QST_ID (QST_ID), |
| 386 | 386 | KEY QSO_order (QSO_order)"; |
| 387 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 388 | - $table_name = 'esp_registration'; |
|
| 389 | - $sql = "REG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 387 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 388 | + $table_name = 'esp_registration'; |
|
| 389 | + $sql = "REG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 390 | 390 | EVT_ID bigint(20) unsigned NOT NULL, |
| 391 | 391 | ATT_ID bigint(20) unsigned NOT NULL, |
| 392 | 392 | TXN_ID int(10) unsigned NOT NULL, |
@@ -410,18 +410,18 @@ discard block |
||
| 410 | 410 | KEY TKT_ID (TKT_ID), |
| 411 | 411 | KEY EVT_ID (EVT_ID), |
| 412 | 412 | KEY STS_ID (STS_ID)"; |
| 413 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 414 | - $table_name = 'esp_registration_payment'; |
|
| 415 | - $sql = "RPY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 413 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 414 | + $table_name = 'esp_registration_payment'; |
|
| 415 | + $sql = "RPY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 416 | 416 | REG_ID int(10) unsigned NOT NULL, |
| 417 | 417 | PAY_ID int(10) unsigned NULL, |
| 418 | 418 | RPY_amount decimal(10,3) NOT NULL DEFAULT '0.00', |
| 419 | 419 | PRIMARY KEY (RPY_ID), |
| 420 | 420 | KEY REG_ID (REG_ID), |
| 421 | 421 | KEY PAY_ID (PAY_ID)"; |
| 422 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 423 | - $table_name = 'esp_checkin'; |
|
| 424 | - $sql = "CHK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 422 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 423 | + $table_name = 'esp_checkin'; |
|
| 424 | + $sql = "CHK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 425 | 425 | REG_ID int(10) unsigned NOT NULL, |
| 426 | 426 | DTT_ID int(10) unsigned NOT NULL, |
| 427 | 427 | CHK_in tinyint(1) unsigned NOT NULL DEFAULT 1, |
@@ -429,9 +429,9 @@ discard block |
||
| 429 | 429 | PRIMARY KEY (CHK_ID), |
| 430 | 430 | KEY REG_ID (REG_ID), |
| 431 | 431 | KEY DTT_ID (DTT_ID)"; |
| 432 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 433 | - $table_name = 'esp_state'; |
|
| 434 | - $sql = "STA_ID smallint(5) unsigned NOT NULL AUTO_INCREMENT, |
|
| 432 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 433 | + $table_name = 'esp_state'; |
|
| 434 | + $sql = "STA_ID smallint(5) unsigned NOT NULL AUTO_INCREMENT, |
|
| 435 | 435 | CNT_ISO varchar(2) collate utf8_bin NOT NULL, |
| 436 | 436 | STA_abbrev varchar(24) collate utf8_bin NOT NULL, |
| 437 | 437 | STA_name varchar(100) collate utf8_bin NOT NULL, |
@@ -439,9 +439,9 @@ discard block |
||
| 439 | 439 | PRIMARY KEY (STA_ID), |
| 440 | 440 | KEY STA_abbrev (STA_abbrev), |
| 441 | 441 | KEY CNT_ISO (CNT_ISO)"; |
| 442 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 443 | - $table_name = 'esp_status'; |
|
| 444 | - $sql = "STS_ID varchar(3) NOT NULL, |
|
| 442 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 443 | + $table_name = 'esp_status'; |
|
| 444 | + $sql = "STS_ID varchar(3) NOT NULL, |
|
| 445 | 445 | STS_code varchar(45) NOT NULL, |
| 446 | 446 | STS_type varchar(45) NOT NULL, |
| 447 | 447 | STS_can_edit tinyint(1) NOT NULL DEFAULT 0, |
@@ -449,9 +449,9 @@ discard block |
||
| 449 | 449 | STS_open tinyint(1) NOT NULL DEFAULT 1, |
| 450 | 450 | UNIQUE KEY STS_ID_UNIQUE (STS_ID), |
| 451 | 451 | KEY STS_type (STS_type)"; |
| 452 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 453 | - $table_name = 'esp_transaction'; |
|
| 454 | - $sql = "TXN_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 452 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 453 | + $table_name = 'esp_transaction'; |
|
| 454 | + $sql = "TXN_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 455 | 455 | TXN_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
| 456 | 456 | TXN_total decimal(10,3) DEFAULT '0.00', |
| 457 | 457 | TXN_paid decimal(10,3) NOT NULL DEFAULT '0.00', |
@@ -463,9 +463,9 @@ discard block |
||
| 463 | 463 | PRIMARY KEY (TXN_ID), |
| 464 | 464 | KEY TXN_timestamp (TXN_timestamp), |
| 465 | 465 | KEY STS_ID (STS_ID)"; |
| 466 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 467 | - $table_name = 'esp_venue_meta'; |
|
| 468 | - $sql = "VNUM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 466 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 467 | + $table_name = 'esp_venue_meta'; |
|
| 468 | + $sql = "VNUM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 469 | 469 | VNU_ID bigint(20) unsigned NOT NULL DEFAULT 0, |
| 470 | 470 | VNU_address varchar(255) DEFAULT NULL, |
| 471 | 471 | VNU_address2 varchar(255) DEFAULT NULL, |
@@ -484,10 +484,10 @@ discard block |
||
| 484 | 484 | KEY VNU_ID (VNU_ID), |
| 485 | 485 | KEY STA_ID (STA_ID), |
| 486 | 486 | KEY CNT_ISO (CNT_ISO)"; |
| 487 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 488 | - // modified tables |
|
| 489 | - $table_name = "esp_price"; |
|
| 490 | - $sql = "PRC_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 487 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 488 | + // modified tables |
|
| 489 | + $table_name = "esp_price"; |
|
| 490 | + $sql = "PRC_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 491 | 491 | PRT_ID tinyint(3) unsigned NOT NULL, |
| 492 | 492 | PRC_amount decimal(10,3) NOT NULL DEFAULT '0.00', |
| 493 | 493 | PRC_name varchar(245) NOT NULL, |
@@ -500,9 +500,9 @@ discard block |
||
| 500 | 500 | PRC_parent int(10) unsigned DEFAULT 0, |
| 501 | 501 | PRIMARY KEY (PRC_ID), |
| 502 | 502 | KEY PRT_ID (PRT_ID)"; |
| 503 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 504 | - $table_name = "esp_price_type"; |
|
| 505 | - $sql = "PRT_ID tinyint(3) unsigned NOT NULL AUTO_INCREMENT, |
|
| 503 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 504 | + $table_name = "esp_price_type"; |
|
| 505 | + $sql = "PRT_ID tinyint(3) unsigned NOT NULL AUTO_INCREMENT, |
|
| 506 | 506 | PRT_name varchar(45) NOT NULL, |
| 507 | 507 | PBT_ID tinyint(3) unsigned NOT NULL DEFAULT '1', |
| 508 | 508 | PRT_is_percent tinyint(1) NOT NULL DEFAULT '0', |
@@ -511,9 +511,9 @@ discard block |
||
| 511 | 511 | PRT_deleted tinyint(1) NOT NULL DEFAULT '0', |
| 512 | 512 | UNIQUE KEY PRT_name_UNIQUE (PRT_name), |
| 513 | 513 | PRIMARY KEY (PRT_ID)"; |
| 514 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 515 | - $table_name = "esp_ticket"; |
|
| 516 | - $sql = "TKT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 514 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 515 | + $table_name = "esp_ticket"; |
|
| 516 | + $sql = "TKT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 517 | 517 | TTM_ID int(10) unsigned NOT NULL, |
| 518 | 518 | TKT_name varchar(245) NOT NULL DEFAULT '', |
| 519 | 519 | TKT_description text NOT NULL, |
@@ -535,9 +535,9 @@ discard block |
||
| 535 | 535 | TKT_deleted tinyint(1) NOT NULL DEFAULT '0', |
| 536 | 536 | PRIMARY KEY (TKT_ID), |
| 537 | 537 | KEY TKT_start_date (TKT_start_date)"; |
| 538 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 539 | - $table_name = 'esp_question_group'; |
|
| 540 | - $sql = 'QSG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 538 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 539 | + $table_name = 'esp_question_group'; |
|
| 540 | + $sql = 'QSG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 541 | 541 | QSG_name varchar(255) NOT NULL, |
| 542 | 542 | QSG_identifier varchar(100) NOT NULL, |
| 543 | 543 | QSG_desc text NULL, |
@@ -550,223 +550,223 @@ discard block |
||
| 550 | 550 | PRIMARY KEY (QSG_ID), |
| 551 | 551 | UNIQUE KEY QSG_identifier_UNIQUE (QSG_identifier), |
| 552 | 552 | KEY QSG_order (QSG_order)'; |
| 553 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 554 | - /** @var EE_DMS_Core_4_1_0 $script_4_1_defaults */ |
|
| 555 | - $script_4_1_defaults = EE_Registry::instance()->load_dms('Core_4_1_0'); |
|
| 556 | - // (because many need to convert old string states to foreign keys into the states table) |
|
| 557 | - $script_4_1_defaults->insert_default_states(); |
|
| 558 | - $script_4_1_defaults->insert_default_countries(); |
|
| 559 | - /** @var EE_DMS_Core_4_5_0 $script_4_5_defaults */ |
|
| 560 | - $script_4_5_defaults = EE_Registry::instance()->load_dms('Core_4_5_0'); |
|
| 561 | - $script_4_5_defaults->insert_default_price_types(); |
|
| 562 | - $script_4_5_defaults->insert_default_prices(); |
|
| 563 | - $script_4_5_defaults->insert_default_tickets(); |
|
| 564 | - /** @var EE_DMS_Core_4_6_0 $script_4_6_defaults */ |
|
| 565 | - $script_4_6_defaults = EE_Registry::instance()->load_dms('Core_4_6_0'); |
|
| 566 | - $script_4_6_defaults->add_default_admin_only_payments(); |
|
| 567 | - $script_4_6_defaults->insert_default_currencies(); |
|
| 568 | - $this->verify_new_countries(); |
|
| 569 | - $this->verify_new_currencies(); |
|
| 570 | - return true; |
|
| 571 | - } |
|
| 553 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 554 | + /** @var EE_DMS_Core_4_1_0 $script_4_1_defaults */ |
|
| 555 | + $script_4_1_defaults = EE_Registry::instance()->load_dms('Core_4_1_0'); |
|
| 556 | + // (because many need to convert old string states to foreign keys into the states table) |
|
| 557 | + $script_4_1_defaults->insert_default_states(); |
|
| 558 | + $script_4_1_defaults->insert_default_countries(); |
|
| 559 | + /** @var EE_DMS_Core_4_5_0 $script_4_5_defaults */ |
|
| 560 | + $script_4_5_defaults = EE_Registry::instance()->load_dms('Core_4_5_0'); |
|
| 561 | + $script_4_5_defaults->insert_default_price_types(); |
|
| 562 | + $script_4_5_defaults->insert_default_prices(); |
|
| 563 | + $script_4_5_defaults->insert_default_tickets(); |
|
| 564 | + /** @var EE_DMS_Core_4_6_0 $script_4_6_defaults */ |
|
| 565 | + $script_4_6_defaults = EE_Registry::instance()->load_dms('Core_4_6_0'); |
|
| 566 | + $script_4_6_defaults->add_default_admin_only_payments(); |
|
| 567 | + $script_4_6_defaults->insert_default_currencies(); |
|
| 568 | + $this->verify_new_countries(); |
|
| 569 | + $this->verify_new_currencies(); |
|
| 570 | + return true; |
|
| 571 | + } |
|
| 572 | 572 | |
| 573 | 573 | |
| 574 | 574 | |
| 575 | - /** |
|
| 576 | - * @return boolean |
|
| 577 | - */ |
|
| 578 | - public function schema_changes_after_migration() |
|
| 579 | - { |
|
| 580 | - $this->fix_non_default_taxes(); |
|
| 581 | - // this is actually the same as the last DMS |
|
| 582 | - /** @var EE_DMS_Core_4_7_0 $script_4_7_defaults */ |
|
| 583 | - $script_4_7_defaults = EE_Registry::instance()->load_dms('Core_4_7_0'); |
|
| 584 | - return $script_4_7_defaults->schema_changes_after_migration(); |
|
| 585 | - } |
|
| 575 | + /** |
|
| 576 | + * @return boolean |
|
| 577 | + */ |
|
| 578 | + public function schema_changes_after_migration() |
|
| 579 | + { |
|
| 580 | + $this->fix_non_default_taxes(); |
|
| 581 | + // this is actually the same as the last DMS |
|
| 582 | + /** @var EE_DMS_Core_4_7_0 $script_4_7_defaults */ |
|
| 583 | + $script_4_7_defaults = EE_Registry::instance()->load_dms('Core_4_7_0'); |
|
| 584 | + return $script_4_7_defaults->schema_changes_after_migration(); |
|
| 585 | + } |
|
| 586 | 586 | |
| 587 | 587 | |
| 588 | 588 | |
| 589 | - public function migration_page_hooks() |
|
| 590 | - { |
|
| 591 | - } |
|
| 589 | + public function migration_page_hooks() |
|
| 590 | + { |
|
| 591 | + } |
|
| 592 | 592 | |
| 593 | 593 | |
| 594 | 594 | |
| 595 | - /** |
|
| 596 | - * verifies each of the new countries exists that somehow we missed in 4.1 |
|
| 597 | - */ |
|
| 598 | - public function verify_new_countries() |
|
| 599 | - { |
|
| 600 | - // a list of countries (and specifically some which were missed in another list):https://gist.github.com/adhipg/1600028 |
|
| 601 | - // how many decimal places? https://en.wikipedia.org/wiki/ISO_4217 |
|
| 602 | - // currency symbols: http://www.xe.com/symbols.php |
|
| 603 | - // CNT_ISO, CNT_ISO3, RGN_ID, CNT_name, CNT_cur_code, CNT_cur_single, CNT_cur_plural, CNT_cur_sign, CNT_cur_sign_b4, CNT_cur_dec_plc, CNT_tel_code, CNT_is_EU, CNT_active |
|
| 604 | - // ('AD', 'AND', 0, 'Andorra', 'EUR', 'Euro', 'Euros', '€', 1, 2, '+376', 0, 0), |
|
| 605 | - $newer_countries = array( |
|
| 606 | - array('AX', 'ALA', 0, 'Åland Islands', 'EUR', 'Euro', 'Euros', '€', 1, 2, '+358', 1, 0), |
|
| 607 | - array('BL', 'BLM', 0, 'Saint Barthelemy', 'EUR', 'Euro', 'Euros', '€', 1, 2, '+590', 1, 0), |
|
| 608 | - array('CW', 'CUW', 0, 'Curacao', 'ANG', 'Guilder', 'Guilders', 'ƒ', 1, 2, '+599', 1, 0), |
|
| 609 | - array('GG', 'GGY', 0, 'Guernsey', 'EUR', 'Euro', 'Euros', '€', 1, 2, '+44', 0, 0), |
|
| 610 | - array('IM', 'IMN', 0, 'Isle of Man', 'GBP', 'Pound', 'Pounds', '£', 1, 2, '+44', 0, 0), |
|
| 611 | - array('JE', 'JEY', 0, 'Jersey', 'GBP', 'Pound', 'Pounds', '£', 1, 2, '+44', 0, 0), |
|
| 612 | - array('MF', 'MAF', 0, 'Saint Martin', 'EUR', 'Euro', 'Euros', '€', 1, 2, '+590', 1, 0), |
|
| 613 | - array('ME', 'MNE', 0, 'Montenegro', 'EUR', 'Euro', 'Euros', '€', 1, 2, '+382', 0, 0), |
|
| 614 | - array('RS', 'SRB', 0, 'Serbia', 'RSD', 'Dinar', 'Dinars', '', 0, 2, '+381', 1, 0), |
|
| 615 | - array('SS', 'SSD', 0, 'South Sudan', 'SSP', 'Pound', 'Pounds', '£', 1, 2, '+211', 0, 0), |
|
| 616 | - array('SX', 'SXM', 0, 'Sint Maarten', 'ANG', 'Guilder', 'Guilders', 'ƒ', 1, 2, '+1', 1, 0), |
|
| 617 | - array('XK', 'XKX', 0, 'Kosovo', 'EUR', 'Euro', 'Euros', '€', 1, 2, '+383', 0, 0), |
|
| 618 | - array('YT', 'MYT', 0, 'Mayotte', 'EUR', 'Euro', 'Euros', '€', 0, 2, '+262', 1, 0), |
|
| 619 | - array( |
|
| 620 | - 'BQ', |
|
| 621 | - 'BES', |
|
| 622 | - 0, |
|
| 623 | - 'Bonaire, Saint Eustatius and Saba', |
|
| 624 | - 'USD', |
|
| 625 | - 'Dollar', |
|
| 626 | - 'Dollars', |
|
| 627 | - '$', |
|
| 628 | - 1, |
|
| 629 | - 2, |
|
| 630 | - '+599', |
|
| 631 | - 0, |
|
| 632 | - 0, |
|
| 633 | - ), |
|
| 634 | - array('BV', 'BVT', 0, 'Bouvet Island', 'NOK', 'Krone', 'Krones', 'kr', 1, 2, '+47', 0, 0), |
|
| 635 | - array('IO', 'IOT', 0, 'British Indian Ocean Territory', 'GBP', 'Pound', 'Pounds', '£', 1, 2, '+246', 0, 0), |
|
| 636 | - array('CX', 'CXR', 0, 'Christmas Island', 'AUD', 'Dollar', 'Dollars', '$', 1, 2, '+61', 0, 0), |
|
| 637 | - array('CC', 'CCK', 0, 'Cocos (Keeling) Islands', 'AUD', 'Dollar', 'Dollars', '$', 1, 2, '+891', 0, 0), |
|
| 638 | - array( |
|
| 639 | - 'HM', |
|
| 640 | - 'HMD', |
|
| 641 | - 0, |
|
| 642 | - 'Heard Island and McDonald Islands', |
|
| 643 | - 'AUD', |
|
| 644 | - 'Dollar', |
|
| 645 | - 'Dollars', |
|
| 646 | - '$', |
|
| 647 | - 1, |
|
| 648 | - 2, |
|
| 649 | - '+891', |
|
| 650 | - 0, |
|
| 651 | - 0, |
|
| 652 | - ), |
|
| 653 | - array('PS', 'PSE', 0, 'Palestinian Territory', 'ILS', 'Shekel', 'Shekels', '₪', 1, 2, '+970', 0, 0), |
|
| 654 | - array( |
|
| 655 | - 'GS', |
|
| 656 | - 'SGS', |
|
| 657 | - 0, |
|
| 658 | - 'South Georgia and the South Sandwich Islands', |
|
| 659 | - 'GBP', |
|
| 660 | - 'Pound', |
|
| 661 | - 'Pounds', |
|
| 662 | - '£', |
|
| 663 | - 1, |
|
| 664 | - 2, |
|
| 665 | - '+500', |
|
| 666 | - 0, |
|
| 667 | - 0, |
|
| 668 | - ), |
|
| 669 | - array('TL', 'TLS', 0, 'Timor-Leste', 'USD', 'Dollar', 'Dollars', '$', 1, 2, '+670', 0, 0), |
|
| 670 | - array('TF', 'ATF', 0, 'French Southern Territories', 'EUR', 'Euro', 'Euros', '€', 1, 2, '+262', 0, 0), |
|
| 671 | - array( |
|
| 672 | - 'UM', |
|
| 673 | - 'UMI', |
|
| 674 | - 0, |
|
| 675 | - 'United States Minor Outlying Islands', |
|
| 676 | - 'USD', |
|
| 677 | - 'Dollar', |
|
| 678 | - 'Dollars', |
|
| 679 | - '$', |
|
| 680 | - 1, |
|
| 681 | - 2, |
|
| 682 | - '+1', |
|
| 683 | - 0, |
|
| 684 | - 0, |
|
| 685 | - ), |
|
| 686 | - ); |
|
| 687 | - global $wpdb; |
|
| 688 | - $country_table = $wpdb->prefix . "esp_country"; |
|
| 689 | - $country_format = array( |
|
| 690 | - "CNT_ISO" => '%s', |
|
| 691 | - "CNT_ISO3" => '%s', |
|
| 692 | - "RGN_ID" => '%d', |
|
| 693 | - "CNT_name" => '%s', |
|
| 694 | - "CNT_cur_code" => '%s', |
|
| 695 | - "CNT_cur_single" => '%s', |
|
| 696 | - "CNT_cur_plural" => '%s', |
|
| 697 | - "CNT_cur_sign" => '%s', |
|
| 698 | - "CNT_cur_sign_b4" => '%d', |
|
| 699 | - "CNT_cur_dec_plc" => '%d', |
|
| 700 | - "CNT_tel_code" => '%s', |
|
| 701 | - "CNT_is_EU" => '%d', |
|
| 702 | - "CNT_active" => '%d', |
|
| 703 | - ); |
|
| 704 | - if ($this->_get_table_analysis()->tableExists($country_table)) { |
|
| 705 | - foreach ($newer_countries as $country) { |
|
| 706 | - $SQL = "SELECT COUNT('CNT_ISO') FROM {$country_table} WHERE CNT_ISO='{$country[0]}' LIMIT 1"; |
|
| 707 | - $countries = $wpdb->get_var($SQL); |
|
| 708 | - if (! $countries) { |
|
| 709 | - $wpdb->insert( |
|
| 710 | - $country_table, |
|
| 711 | - array_combine(array_keys($country_format), $country), |
|
| 712 | - $country_format |
|
| 713 | - ); |
|
| 714 | - } |
|
| 715 | - } |
|
| 716 | - } |
|
| 717 | - } |
|
| 595 | + /** |
|
| 596 | + * verifies each of the new countries exists that somehow we missed in 4.1 |
|
| 597 | + */ |
|
| 598 | + public function verify_new_countries() |
|
| 599 | + { |
|
| 600 | + // a list of countries (and specifically some which were missed in another list):https://gist.github.com/adhipg/1600028 |
|
| 601 | + // how many decimal places? https://en.wikipedia.org/wiki/ISO_4217 |
|
| 602 | + // currency symbols: http://www.xe.com/symbols.php |
|
| 603 | + // CNT_ISO, CNT_ISO3, RGN_ID, CNT_name, CNT_cur_code, CNT_cur_single, CNT_cur_plural, CNT_cur_sign, CNT_cur_sign_b4, CNT_cur_dec_plc, CNT_tel_code, CNT_is_EU, CNT_active |
|
| 604 | + // ('AD', 'AND', 0, 'Andorra', 'EUR', 'Euro', 'Euros', '€', 1, 2, '+376', 0, 0), |
|
| 605 | + $newer_countries = array( |
|
| 606 | + array('AX', 'ALA', 0, 'Åland Islands', 'EUR', 'Euro', 'Euros', '€', 1, 2, '+358', 1, 0), |
|
| 607 | + array('BL', 'BLM', 0, 'Saint Barthelemy', 'EUR', 'Euro', 'Euros', '€', 1, 2, '+590', 1, 0), |
|
| 608 | + array('CW', 'CUW', 0, 'Curacao', 'ANG', 'Guilder', 'Guilders', 'ƒ', 1, 2, '+599', 1, 0), |
|
| 609 | + array('GG', 'GGY', 0, 'Guernsey', 'EUR', 'Euro', 'Euros', '€', 1, 2, '+44', 0, 0), |
|
| 610 | + array('IM', 'IMN', 0, 'Isle of Man', 'GBP', 'Pound', 'Pounds', '£', 1, 2, '+44', 0, 0), |
|
| 611 | + array('JE', 'JEY', 0, 'Jersey', 'GBP', 'Pound', 'Pounds', '£', 1, 2, '+44', 0, 0), |
|
| 612 | + array('MF', 'MAF', 0, 'Saint Martin', 'EUR', 'Euro', 'Euros', '€', 1, 2, '+590', 1, 0), |
|
| 613 | + array('ME', 'MNE', 0, 'Montenegro', 'EUR', 'Euro', 'Euros', '€', 1, 2, '+382', 0, 0), |
|
| 614 | + array('RS', 'SRB', 0, 'Serbia', 'RSD', 'Dinar', 'Dinars', '', 0, 2, '+381', 1, 0), |
|
| 615 | + array('SS', 'SSD', 0, 'South Sudan', 'SSP', 'Pound', 'Pounds', '£', 1, 2, '+211', 0, 0), |
|
| 616 | + array('SX', 'SXM', 0, 'Sint Maarten', 'ANG', 'Guilder', 'Guilders', 'ƒ', 1, 2, '+1', 1, 0), |
|
| 617 | + array('XK', 'XKX', 0, 'Kosovo', 'EUR', 'Euro', 'Euros', '€', 1, 2, '+383', 0, 0), |
|
| 618 | + array('YT', 'MYT', 0, 'Mayotte', 'EUR', 'Euro', 'Euros', '€', 0, 2, '+262', 1, 0), |
|
| 619 | + array( |
|
| 620 | + 'BQ', |
|
| 621 | + 'BES', |
|
| 622 | + 0, |
|
| 623 | + 'Bonaire, Saint Eustatius and Saba', |
|
| 624 | + 'USD', |
|
| 625 | + 'Dollar', |
|
| 626 | + 'Dollars', |
|
| 627 | + '$', |
|
| 628 | + 1, |
|
| 629 | + 2, |
|
| 630 | + '+599', |
|
| 631 | + 0, |
|
| 632 | + 0, |
|
| 633 | + ), |
|
| 634 | + array('BV', 'BVT', 0, 'Bouvet Island', 'NOK', 'Krone', 'Krones', 'kr', 1, 2, '+47', 0, 0), |
|
| 635 | + array('IO', 'IOT', 0, 'British Indian Ocean Territory', 'GBP', 'Pound', 'Pounds', '£', 1, 2, '+246', 0, 0), |
|
| 636 | + array('CX', 'CXR', 0, 'Christmas Island', 'AUD', 'Dollar', 'Dollars', '$', 1, 2, '+61', 0, 0), |
|
| 637 | + array('CC', 'CCK', 0, 'Cocos (Keeling) Islands', 'AUD', 'Dollar', 'Dollars', '$', 1, 2, '+891', 0, 0), |
|
| 638 | + array( |
|
| 639 | + 'HM', |
|
| 640 | + 'HMD', |
|
| 641 | + 0, |
|
| 642 | + 'Heard Island and McDonald Islands', |
|
| 643 | + 'AUD', |
|
| 644 | + 'Dollar', |
|
| 645 | + 'Dollars', |
|
| 646 | + '$', |
|
| 647 | + 1, |
|
| 648 | + 2, |
|
| 649 | + '+891', |
|
| 650 | + 0, |
|
| 651 | + 0, |
|
| 652 | + ), |
|
| 653 | + array('PS', 'PSE', 0, 'Palestinian Territory', 'ILS', 'Shekel', 'Shekels', '₪', 1, 2, '+970', 0, 0), |
|
| 654 | + array( |
|
| 655 | + 'GS', |
|
| 656 | + 'SGS', |
|
| 657 | + 0, |
|
| 658 | + 'South Georgia and the South Sandwich Islands', |
|
| 659 | + 'GBP', |
|
| 660 | + 'Pound', |
|
| 661 | + 'Pounds', |
|
| 662 | + '£', |
|
| 663 | + 1, |
|
| 664 | + 2, |
|
| 665 | + '+500', |
|
| 666 | + 0, |
|
| 667 | + 0, |
|
| 668 | + ), |
|
| 669 | + array('TL', 'TLS', 0, 'Timor-Leste', 'USD', 'Dollar', 'Dollars', '$', 1, 2, '+670', 0, 0), |
|
| 670 | + array('TF', 'ATF', 0, 'French Southern Territories', 'EUR', 'Euro', 'Euros', '€', 1, 2, '+262', 0, 0), |
|
| 671 | + array( |
|
| 672 | + 'UM', |
|
| 673 | + 'UMI', |
|
| 674 | + 0, |
|
| 675 | + 'United States Minor Outlying Islands', |
|
| 676 | + 'USD', |
|
| 677 | + 'Dollar', |
|
| 678 | + 'Dollars', |
|
| 679 | + '$', |
|
| 680 | + 1, |
|
| 681 | + 2, |
|
| 682 | + '+1', |
|
| 683 | + 0, |
|
| 684 | + 0, |
|
| 685 | + ), |
|
| 686 | + ); |
|
| 687 | + global $wpdb; |
|
| 688 | + $country_table = $wpdb->prefix . "esp_country"; |
|
| 689 | + $country_format = array( |
|
| 690 | + "CNT_ISO" => '%s', |
|
| 691 | + "CNT_ISO3" => '%s', |
|
| 692 | + "RGN_ID" => '%d', |
|
| 693 | + "CNT_name" => '%s', |
|
| 694 | + "CNT_cur_code" => '%s', |
|
| 695 | + "CNT_cur_single" => '%s', |
|
| 696 | + "CNT_cur_plural" => '%s', |
|
| 697 | + "CNT_cur_sign" => '%s', |
|
| 698 | + "CNT_cur_sign_b4" => '%d', |
|
| 699 | + "CNT_cur_dec_plc" => '%d', |
|
| 700 | + "CNT_tel_code" => '%s', |
|
| 701 | + "CNT_is_EU" => '%d', |
|
| 702 | + "CNT_active" => '%d', |
|
| 703 | + ); |
|
| 704 | + if ($this->_get_table_analysis()->tableExists($country_table)) { |
|
| 705 | + foreach ($newer_countries as $country) { |
|
| 706 | + $SQL = "SELECT COUNT('CNT_ISO') FROM {$country_table} WHERE CNT_ISO='{$country[0]}' LIMIT 1"; |
|
| 707 | + $countries = $wpdb->get_var($SQL); |
|
| 708 | + if (! $countries) { |
|
| 709 | + $wpdb->insert( |
|
| 710 | + $country_table, |
|
| 711 | + array_combine(array_keys($country_format), $country), |
|
| 712 | + $country_format |
|
| 713 | + ); |
|
| 714 | + } |
|
| 715 | + } |
|
| 716 | + } |
|
| 717 | + } |
|
| 718 | 718 | |
| 719 | 719 | |
| 720 | 720 | |
| 721 | - /** |
|
| 722 | - * verifies each of the new currencies exists that somehow we missed in 4.6 |
|
| 723 | - */ |
|
| 724 | - public function verify_new_currencies() |
|
| 725 | - { |
|
| 726 | - // a list of countries (and specifically some which were missed in another list):https://gist.github.com/adhipg/1600028 |
|
| 727 | - // how many decimal places? https://en.wikipedia.org/wiki/ISO_4217 |
|
| 728 | - // currency symbols: http://www.xe.com/symbols.php |
|
| 729 | - // CUR_code, CUR_single, CUR_plural, CUR_sign, CUR_dec_plc, CUR_active |
|
| 730 | - // ( 'EUR', 'Euro', 'Euros', '€', 2,1), |
|
| 731 | - $newer_currencies = array( |
|
| 732 | - array('RSD', 'Dinar', 'Dinars', '', 3, 1), |
|
| 733 | - ); |
|
| 734 | - global $wpdb; |
|
| 735 | - $currency_table = $wpdb->prefix . "esp_currency"; |
|
| 736 | - $currency_format = array( |
|
| 737 | - "CUR_code" => '%s', |
|
| 738 | - "CUR_single" => '%s', |
|
| 739 | - "CUR_plural" => '%s', |
|
| 740 | - "CUR_sign" => '%s', |
|
| 741 | - "CUR_dec_plc" => '%d', |
|
| 742 | - "CUR_active" => '%d', |
|
| 743 | - ); |
|
| 744 | - if ($this->_get_table_analysis()->tableExists($currency_table)) { |
|
| 745 | - foreach ($newer_currencies as $currency) { |
|
| 746 | - $SQL = "SELECT COUNT('CUR_code') FROM {$currency_table} WHERE CUR_code='{$currency[0]}' LIMIT 1"; |
|
| 747 | - $countries = $wpdb->get_var($SQL); |
|
| 748 | - if (! $countries) { |
|
| 749 | - $wpdb->insert( |
|
| 750 | - $currency_table, |
|
| 751 | - array_combine(array_keys($currency_format), $currency), |
|
| 752 | - $currency_format |
|
| 753 | - ); |
|
| 754 | - } |
|
| 755 | - } |
|
| 756 | - } |
|
| 757 | - } |
|
| 721 | + /** |
|
| 722 | + * verifies each of the new currencies exists that somehow we missed in 4.6 |
|
| 723 | + */ |
|
| 724 | + public function verify_new_currencies() |
|
| 725 | + { |
|
| 726 | + // a list of countries (and specifically some which were missed in another list):https://gist.github.com/adhipg/1600028 |
|
| 727 | + // how many decimal places? https://en.wikipedia.org/wiki/ISO_4217 |
|
| 728 | + // currency symbols: http://www.xe.com/symbols.php |
|
| 729 | + // CUR_code, CUR_single, CUR_plural, CUR_sign, CUR_dec_plc, CUR_active |
|
| 730 | + // ( 'EUR', 'Euro', 'Euros', '€', 2,1), |
|
| 731 | + $newer_currencies = array( |
|
| 732 | + array('RSD', 'Dinar', 'Dinars', '', 3, 1), |
|
| 733 | + ); |
|
| 734 | + global $wpdb; |
|
| 735 | + $currency_table = $wpdb->prefix . "esp_currency"; |
|
| 736 | + $currency_format = array( |
|
| 737 | + "CUR_code" => '%s', |
|
| 738 | + "CUR_single" => '%s', |
|
| 739 | + "CUR_plural" => '%s', |
|
| 740 | + "CUR_sign" => '%s', |
|
| 741 | + "CUR_dec_plc" => '%d', |
|
| 742 | + "CUR_active" => '%d', |
|
| 743 | + ); |
|
| 744 | + if ($this->_get_table_analysis()->tableExists($currency_table)) { |
|
| 745 | + foreach ($newer_currencies as $currency) { |
|
| 746 | + $SQL = "SELECT COUNT('CUR_code') FROM {$currency_table} WHERE CUR_code='{$currency[0]}' LIMIT 1"; |
|
| 747 | + $countries = $wpdb->get_var($SQL); |
|
| 748 | + if (! $countries) { |
|
| 749 | + $wpdb->insert( |
|
| 750 | + $currency_table, |
|
| 751 | + array_combine(array_keys($currency_format), $currency), |
|
| 752 | + $currency_format |
|
| 753 | + ); |
|
| 754 | + } |
|
| 755 | + } |
|
| 756 | + } |
|
| 757 | + } |
|
| 758 | 758 | |
| 759 | 759 | |
| 760 | 760 | |
| 761 | - /** |
|
| 762 | - * addresses https://events.codebasehq.com/projects/event-espresso/tickets/8731 |
|
| 763 | - * which should just be a temporary issue for folks who installed 4.8.0-4.8.5; |
|
| 764 | - * we should be able to stop doing this in 4.9 |
|
| 765 | - */ |
|
| 766 | - public function fix_non_default_taxes() |
|
| 767 | - { |
|
| 768 | - global $wpdb; |
|
| 769 | - $query = $wpdb->prepare("UPDATE |
|
| 761 | + /** |
|
| 762 | + * addresses https://events.codebasehq.com/projects/event-espresso/tickets/8731 |
|
| 763 | + * which should just be a temporary issue for folks who installed 4.8.0-4.8.5; |
|
| 764 | + * we should be able to stop doing this in 4.9 |
|
| 765 | + */ |
|
| 766 | + public function fix_non_default_taxes() |
|
| 767 | + { |
|
| 768 | + global $wpdb; |
|
| 769 | + $query = $wpdb->prepare("UPDATE |
|
| 770 | 770 | {$wpdb->prefix}esp_price p INNER JOIN |
| 771 | 771 | {$wpdb->prefix}esp_price_type pt ON p.PRT_ID = pt.PRT_ID |
| 772 | 772 | SET |
@@ -775,6 +775,6 @@ discard block |
||
| 775 | 775 | p.PRC_is_default = 0 AND |
| 776 | 776 | pt.PBT_ID = %d |
| 777 | 777 | ", EEM_Price_Type::base_type_tax); |
| 778 | - $wpdb->query($query); |
|
| 779 | - } |
|
| 778 | + $wpdb->query($query); |
|
| 779 | + } |
|
| 780 | 780 | } |
@@ -14,12 +14,12 @@ discard block |
||
| 14 | 14 | // unfortunately, this needs to be done upon INCLUSION of this file, |
| 15 | 15 | // instead of construction, because it only gets constructed on first page load |
| 16 | 16 | // (all other times it gets resurrected from a wordpress option) |
| 17 | -$stages = glob(EE_CORE . 'data_migration_scripts/4_8_0_stages/*'); |
|
| 17 | +$stages = glob(EE_CORE.'data_migration_scripts/4_8_0_stages/*'); |
|
| 18 | 18 | $class_to_filepath = array(); |
| 19 | 19 | foreach ($stages as $filepath) { |
| 20 | 20 | $matches = array(); |
| 21 | 21 | preg_match('~4_8_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
| 22 | - $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 22 | + $class_to_filepath[$matches[1]] = $filepath; |
|
| 23 | 23 | } |
| 24 | 24 | // give addons a chance to autoload their stages too |
| 25 | 25 | $class_to_filepath = apply_filters('FHEE__EE_DMS_4_8_0__autoloaded_stages', $class_to_filepath); |
@@ -72,10 +72,10 @@ discard block |
||
| 72 | 72 | if (version_compare($version_string, '4.8.0.decaf', '<') && version_compare($version_string, '4.7.0.decaf', '>=')) { |
| 73 | 73 | // echo "$version_string can be migrated from"; |
| 74 | 74 | return true; |
| 75 | - } elseif (! $version_string) { |
|
| 75 | + } elseif ( ! $version_string) { |
|
| 76 | 76 | // echo "no version string provided: $version_string"; |
| 77 | 77 | // no version string provided... this must be pre 4.3 |
| 78 | - return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 78 | + return false; // changed mind. dont want people thinking they should migrate yet because they cant |
|
| 79 | 79 | } else { |
| 80 | 80 | // echo "$version_string doesnt apply"; |
| 81 | 81 | return false; |
@@ -89,9 +89,9 @@ discard block |
||
| 89 | 89 | */ |
| 90 | 90 | public function schema_changes_before_migration() |
| 91 | 91 | { |
| 92 | - require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 92 | + require_once(EE_HELPERS.'EEH_Activation.helper.php'); |
|
| 93 | 93 | $now_in_mysql = current_time('mysql', true); |
| 94 | - require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 94 | + require_once(EE_HELPERS.'EEH_Activation.helper.php'); |
|
| 95 | 95 | $table_name = 'esp_answer'; |
| 96 | 96 | $sql = " ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
| 97 | 97 | REG_ID int(10) unsigned NOT NULL, |
@@ -685,7 +685,7 @@ discard block |
||
| 685 | 685 | ), |
| 686 | 686 | ); |
| 687 | 687 | global $wpdb; |
| 688 | - $country_table = $wpdb->prefix . "esp_country"; |
|
| 688 | + $country_table = $wpdb->prefix."esp_country"; |
|
| 689 | 689 | $country_format = array( |
| 690 | 690 | "CNT_ISO" => '%s', |
| 691 | 691 | "CNT_ISO3" => '%s', |
@@ -705,7 +705,7 @@ discard block |
||
| 705 | 705 | foreach ($newer_countries as $country) { |
| 706 | 706 | $SQL = "SELECT COUNT('CNT_ISO') FROM {$country_table} WHERE CNT_ISO='{$country[0]}' LIMIT 1"; |
| 707 | 707 | $countries = $wpdb->get_var($SQL); |
| 708 | - if (! $countries) { |
|
| 708 | + if ( ! $countries) { |
|
| 709 | 709 | $wpdb->insert( |
| 710 | 710 | $country_table, |
| 711 | 711 | array_combine(array_keys($country_format), $country), |
@@ -732,7 +732,7 @@ discard block |
||
| 732 | 732 | array('RSD', 'Dinar', 'Dinars', '', 3, 1), |
| 733 | 733 | ); |
| 734 | 734 | global $wpdb; |
| 735 | - $currency_table = $wpdb->prefix . "esp_currency"; |
|
| 735 | + $currency_table = $wpdb->prefix."esp_currency"; |
|
| 736 | 736 | $currency_format = array( |
| 737 | 737 | "CUR_code" => '%s', |
| 738 | 738 | "CUR_single" => '%s', |
@@ -745,7 +745,7 @@ discard block |
||
| 745 | 745 | foreach ($newer_currencies as $currency) { |
| 746 | 746 | $SQL = "SELECT COUNT('CUR_code') FROM {$currency_table} WHERE CUR_code='{$currency[0]}' LIMIT 1"; |
| 747 | 747 | $countries = $wpdb->get_var($SQL); |
| 748 | - if (! $countries) { |
|
| 748 | + if ( ! $countries) { |
|
| 749 | 749 | $wpdb->insert( |
| 750 | 750 | $currency_table, |
| 751 | 751 | array_combine(array_keys($currency_format), $currency), |
@@ -16,9 +16,9 @@ discard block |
||
| 16 | 16 | $stages = glob(EE_CORE . 'data_migration_scripts/4_5_0_stages/*'); |
| 17 | 17 | $class_to_filepath = array(); |
| 18 | 18 | foreach ($stages as $filepath) { |
| 19 | - $matches = array(); |
|
| 20 | - preg_match('~4_5_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
|
| 21 | - $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 19 | + $matches = array(); |
|
| 20 | + preg_match('~4_5_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
|
| 21 | + $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 22 | 22 | } |
| 23 | 23 | // give addons a chance to autoload their stages too |
| 24 | 24 | $class_to_filepath = apply_filters('FHEE__EE_DMS_4_5_0__autoloaded_stages', $class_to_filepath); |
@@ -31,59 +31,59 @@ discard block |
||
| 31 | 31 | |
| 32 | 32 | |
| 33 | 33 | |
| 34 | - /** |
|
| 35 | - * EE_DMS_Core_4_5_0 constructor. |
|
| 36 | - * |
|
| 37 | - * @param TableManager $table_manager |
|
| 38 | - * @param TableAnalysis $table_analysis |
|
| 39 | - */ |
|
| 40 | - public function __construct(TableManager $table_manager = null, TableAnalysis $table_analysis = null) |
|
| 41 | - { |
|
| 42 | - $this->_pretty_name = __("Data Update to Event Espresso 4.5.0", "event_espresso"); |
|
| 43 | - $this->_priority = 10; |
|
| 44 | - $this->_migration_stages = array( |
|
| 45 | - new EE_DMS_4_5_0_update_wp_user_for_tickets(), |
|
| 46 | - new EE_DMS_4_5_0_update_wp_user_for_prices(), |
|
| 47 | - new EE_DMS_4_5_0_update_wp_user_for_price_types(), |
|
| 48 | - new EE_DMS_4_5_0_update_wp_user_for_question_groups(), |
|
| 49 | - new EE_DMS_4_5_0_invoice_settings(), |
|
| 50 | - ); |
|
| 51 | - parent::__construct($table_manager, $table_analysis); |
|
| 52 | - } |
|
| 34 | + /** |
|
| 35 | + * EE_DMS_Core_4_5_0 constructor. |
|
| 36 | + * |
|
| 37 | + * @param TableManager $table_manager |
|
| 38 | + * @param TableAnalysis $table_analysis |
|
| 39 | + */ |
|
| 40 | + public function __construct(TableManager $table_manager = null, TableAnalysis $table_analysis = null) |
|
| 41 | + { |
|
| 42 | + $this->_pretty_name = __("Data Update to Event Espresso 4.5.0", "event_espresso"); |
|
| 43 | + $this->_priority = 10; |
|
| 44 | + $this->_migration_stages = array( |
|
| 45 | + new EE_DMS_4_5_0_update_wp_user_for_tickets(), |
|
| 46 | + new EE_DMS_4_5_0_update_wp_user_for_prices(), |
|
| 47 | + new EE_DMS_4_5_0_update_wp_user_for_price_types(), |
|
| 48 | + new EE_DMS_4_5_0_update_wp_user_for_question_groups(), |
|
| 49 | + new EE_DMS_4_5_0_invoice_settings(), |
|
| 50 | + ); |
|
| 51 | + parent::__construct($table_manager, $table_analysis); |
|
| 52 | + } |
|
| 53 | 53 | |
| 54 | 54 | |
| 55 | 55 | |
| 56 | - public function can_migrate_from_version($version_array) |
|
| 57 | - { |
|
| 58 | - $version_string = $version_array['Core']; |
|
| 59 | - if (version_compare($version_string, '4.5.0.decaf', '<') && version_compare($version_string, '4.3.0.decaf', '>=')) { |
|
| 56 | + public function can_migrate_from_version($version_array) |
|
| 57 | + { |
|
| 58 | + $version_string = $version_array['Core']; |
|
| 59 | + if (version_compare($version_string, '4.5.0.decaf', '<') && version_compare($version_string, '4.3.0.decaf', '>=')) { |
|
| 60 | 60 | // echo "$version_string can be migrated from"; |
| 61 | - return true; |
|
| 62 | - } elseif (! $version_string) { |
|
| 61 | + return true; |
|
| 62 | + } elseif (! $version_string) { |
|
| 63 | 63 | // echo "no version string provided: $version_string"; |
| 64 | - // no version string provided... this must be pre 4.3 |
|
| 65 | - return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 66 | - } else { |
|
| 64 | + // no version string provided... this must be pre 4.3 |
|
| 65 | + return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 66 | + } else { |
|
| 67 | 67 | // echo "$version_string doesnt apply"; |
| 68 | - return false; |
|
| 69 | - } |
|
| 70 | - } |
|
| 68 | + return false; |
|
| 69 | + } |
|
| 70 | + } |
|
| 71 | 71 | |
| 72 | 72 | |
| 73 | 73 | |
| 74 | - public function schema_changes_before_migration() |
|
| 75 | - { |
|
| 76 | - // relies on 4.1's EEH_Activation::create_table |
|
| 77 | - require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 78 | - $table_name = 'esp_answer'; |
|
| 79 | - $sql = "ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 74 | + public function schema_changes_before_migration() |
|
| 75 | + { |
|
| 76 | + // relies on 4.1's EEH_Activation::create_table |
|
| 77 | + require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 78 | + $table_name = 'esp_answer'; |
|
| 79 | + $sql = "ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 80 | 80 | REG_ID int(10) unsigned NOT NULL, |
| 81 | 81 | QST_ID int(10) unsigned NOT NULL, |
| 82 | 82 | ANS_value text NOT NULL, |
| 83 | 83 | PRIMARY KEY (ANS_ID)"; |
| 84 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 85 | - $table_name = 'esp_attendee_meta'; |
|
| 86 | - $sql = "ATTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 84 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 85 | + $table_name = 'esp_attendee_meta'; |
|
| 86 | + $sql = "ATTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 87 | 87 | ATT_ID bigint(20) unsigned NOT NULL, |
| 88 | 88 | ATT_fname varchar(45) NOT NULL, |
| 89 | 89 | ATT_lname varchar(45) NOT NULL, |
@@ -99,9 +99,9 @@ discard block |
||
| 99 | 99 | KEY ATT_fname (ATT_fname), |
| 100 | 100 | KEY ATT_lname (ATT_lname), |
| 101 | 101 | KEY ATT_email (ATT_email(191))"; |
| 102 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 103 | - $table_name = 'esp_country'; |
|
| 104 | - $sql = "CNT_ISO varchar(2) COLLATE utf8_bin NOT NULL, |
|
| 102 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 103 | + $table_name = 'esp_country'; |
|
| 104 | + $sql = "CNT_ISO varchar(2) COLLATE utf8_bin NOT NULL, |
|
| 105 | 105 | CNT_ISO3 varchar(3) COLLATE utf8_bin NOT NULL, |
| 106 | 106 | RGN_ID tinyint(3) unsigned DEFAULT NULL, |
| 107 | 107 | CNT_name varchar(45) COLLATE utf8_bin NOT NULL, |
@@ -117,9 +117,9 @@ discard block |
||
| 117 | 117 | CNT_is_EU tinyint(1) DEFAULT '0', |
| 118 | 118 | CNT_active tinyint(1) DEFAULT '0', |
| 119 | 119 | PRIMARY KEY (CNT_ISO)"; |
| 120 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 121 | - $table_name = 'esp_datetime'; |
|
| 122 | - $sql = "DTT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 120 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 121 | + $table_name = 'esp_datetime'; |
|
| 122 | + $sql = "DTT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 123 | 123 | EVT_ID bigint(20) unsigned NOT NULL, |
| 124 | 124 | DTT_name varchar(255) NOT NULL DEFAULT '', |
| 125 | 125 | DTT_description text NOT NULL, |
@@ -134,9 +134,9 @@ discard block |
||
| 134 | 134 | PRIMARY KEY (DTT_ID), |
| 135 | 135 | KEY EVT_ID (EVT_ID), |
| 136 | 136 | KEY DTT_is_primary (DTT_is_primary)"; |
| 137 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 138 | - $table_name = 'esp_event_meta'; |
|
| 139 | - $sql = " |
|
| 137 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 138 | + $table_name = 'esp_event_meta'; |
|
| 139 | + $sql = " |
|
| 140 | 140 | EVTM_ID int(10) NOT NULL AUTO_INCREMENT, |
| 141 | 141 | EVT_ID bigint(20) unsigned NOT NULL, |
| 142 | 142 | EVT_display_desc tinyint(1) unsigned NOT NULL DEFAULT 1, |
@@ -151,31 +151,31 @@ discard block |
||
| 151 | 151 | EVT_external_URL varchar(200) NULL, |
| 152 | 152 | EVT_donations tinyint(1) NULL, |
| 153 | 153 | PRIMARY KEY (EVTM_ID)"; |
| 154 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 155 | - $table_name = 'esp_event_question_group'; |
|
| 156 | - $sql = "EQG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 154 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 155 | + $table_name = 'esp_event_question_group'; |
|
| 156 | + $sql = "EQG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 157 | 157 | EVT_ID bigint(20) unsigned NOT NULL, |
| 158 | 158 | QSG_ID int(10) unsigned NOT NULL, |
| 159 | 159 | EQG_primary tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 160 | 160 | PRIMARY KEY (EQG_ID)"; |
| 161 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 162 | - $table_name = 'esp_event_venue'; |
|
| 163 | - $sql = "EVV_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 161 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 162 | + $table_name = 'esp_event_venue'; |
|
| 163 | + $sql = "EVV_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 164 | 164 | EVT_ID bigint(20) unsigned NOT NULL, |
| 165 | 165 | VNU_ID bigint(20) unsigned NOT NULL, |
| 166 | 166 | EVV_primary tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 167 | 167 | PRIMARY KEY (EVV_ID)"; |
| 168 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 169 | - $table_name = 'esp_extra_meta'; |
|
| 170 | - $sql = "EXM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 168 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 169 | + $table_name = 'esp_extra_meta'; |
|
| 170 | + $sql = "EXM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 171 | 171 | OBJ_ID int(11) DEFAULT NULL, |
| 172 | 172 | EXM_type varchar(45) DEFAULT NULL, |
| 173 | 173 | EXM_key varchar(45) DEFAULT NULL, |
| 174 | 174 | EXM_value text, |
| 175 | 175 | PRIMARY KEY (EXM_ID)"; |
| 176 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 177 | - $table_name = 'esp_line_item'; |
|
| 178 | - $sql = "LIN_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 176 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 177 | + $table_name = 'esp_line_item'; |
|
| 178 | + $sql = "LIN_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 179 | 179 | LIN_code varchar(245) NOT NULL DEFAULT '', |
| 180 | 180 | TXN_ID int(11) DEFAULT NULL, |
| 181 | 181 | LIN_name varchar(245) NOT NULL DEFAULT '', |
@@ -191,19 +191,19 @@ discard block |
||
| 191 | 191 | OBJ_ID int(11) DEFAULT NULL, |
| 192 | 192 | OBJ_type varchar(45)DEFAULT NULL, |
| 193 | 193 | PRIMARY KEY (LIN_ID)"; |
| 194 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 195 | - $table_name = 'esp_message_template'; |
|
| 196 | - $sql = "MTP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 194 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 195 | + $table_name = 'esp_message_template'; |
|
| 196 | + $sql = "MTP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 197 | 197 | GRP_ID int(10) unsigned NOT NULL, |
| 198 | 198 | MTP_context varchar(50) NOT NULL, |
| 199 | 199 | MTP_template_field varchar(30) NOT NULL, |
| 200 | 200 | MTP_content text NOT NULL, |
| 201 | 201 | PRIMARY KEY (MTP_ID), |
| 202 | 202 | KEY GRP_ID (GRP_ID)"; |
| 203 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 204 | - $this->_get_table_manager()->dropIndex('esp_message_template_group', 'EVT_ID'); |
|
| 205 | - $table_name = 'esp_message_template_group'; |
|
| 206 | - $sql = "GRP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 203 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 204 | + $this->_get_table_manager()->dropIndex('esp_message_template_group', 'EVT_ID'); |
|
| 205 | + $table_name = 'esp_message_template_group'; |
|
| 206 | + $sql = "GRP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 207 | 207 | MTP_user_id int(10) NOT NULL DEFAULT '1', |
| 208 | 208 | MTP_name varchar(245) NOT NULL DEFAULT '', |
| 209 | 209 | MTP_description varchar(245) NOT NULL DEFAULT '', |
@@ -215,17 +215,17 @@ discard block |
||
| 215 | 215 | MTP_is_active tinyint(1) NOT NULL DEFAULT '1', |
| 216 | 216 | PRIMARY KEY (GRP_ID), |
| 217 | 217 | KEY MTP_user_id (MTP_user_id)"; |
| 218 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 219 | - $table_name = 'esp_event_message_template'; |
|
| 220 | - $sql = "EMT_ID bigint(20) unsigned NOT NULL AUTO_INCREMENT, |
|
| 218 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 219 | + $table_name = 'esp_event_message_template'; |
|
| 220 | + $sql = "EMT_ID bigint(20) unsigned NOT NULL AUTO_INCREMENT, |
|
| 221 | 221 | EVT_ID bigint(20) unsigned NOT NULL DEFAULT 0, |
| 222 | 222 | GRP_ID int(10) unsigned NOT NULL DEFAULT 0, |
| 223 | 223 | PRIMARY KEY (EMT_ID), |
| 224 | 224 | KEY EVT_ID (EVT_ID), |
| 225 | 225 | KEY GRP_ID (GRP_ID)"; |
| 226 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 227 | - $table_name = 'esp_payment'; |
|
| 228 | - $sql = "PAY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 226 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 227 | + $table_name = 'esp_payment'; |
|
| 228 | + $sql = "PAY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 229 | 229 | TXN_ID int(10) unsigned DEFAULT NULL, |
| 230 | 230 | STS_ID varchar(3) COLLATE utf8_bin DEFAULT NULL, |
| 231 | 231 | PAY_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
@@ -241,28 +241,28 @@ discard block |
||
| 241 | 241 | PRIMARY KEY (PAY_ID), |
| 242 | 242 | KEY TXN_ID (TXN_ID), |
| 243 | 243 | KEY PAY_timestamp (PAY_timestamp)"; |
| 244 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 245 | - $table_name = "esp_ticket_price"; |
|
| 246 | - $sql = "TKP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 244 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 245 | + $table_name = "esp_ticket_price"; |
|
| 246 | + $sql = "TKP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 247 | 247 | TKT_ID int(10) unsigned NOT NULL, |
| 248 | 248 | PRC_ID int(10) unsigned NOT NULL, |
| 249 | 249 | PRIMARY KEY (TKP_ID)"; |
| 250 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 251 | - $table_name = "esp_datetime_ticket"; |
|
| 252 | - $sql = "DTK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 250 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 251 | + $table_name = "esp_datetime_ticket"; |
|
| 252 | + $sql = "DTK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 253 | 253 | DTT_ID int(10) unsigned NOT NULL, |
| 254 | 254 | TKT_ID int(10) unsigned NOT NULL, |
| 255 | 255 | PRIMARY KEY (DTK_ID)"; |
| 256 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 257 | - $table_name = "esp_ticket_template"; |
|
| 258 | - $sql = "TTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 256 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 257 | + $table_name = "esp_ticket_template"; |
|
| 258 | + $sql = "TTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 259 | 259 | TTM_name varchar(45) NOT NULL, |
| 260 | 260 | TTM_description text, |
| 261 | 261 | TTM_file varchar(45), |
| 262 | 262 | PRIMARY KEY (TTM_ID)"; |
| 263 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 264 | - $table_name = 'esp_question'; |
|
| 265 | - $sql = 'QST_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 263 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 264 | + $table_name = 'esp_question'; |
|
| 265 | + $sql = 'QST_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 266 | 266 | QST_display_text text NOT NULL, |
| 267 | 267 | QST_admin_label varchar(255) NOT NULL, |
| 268 | 268 | QST_system varchar(25) DEFAULT NULL, |
@@ -274,25 +274,25 @@ discard block |
||
| 274 | 274 | QST_wp_user bigint(20) unsigned NULL, |
| 275 | 275 | QST_deleted tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 276 | 276 | PRIMARY KEY (QST_ID)'; |
| 277 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 278 | - $table_name = 'esp_question_group_question'; |
|
| 279 | - $sql = "QGQ_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 277 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 278 | + $table_name = 'esp_question_group_question'; |
|
| 279 | + $sql = "QGQ_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 280 | 280 | QSG_ID int(10) unsigned NOT NULL, |
| 281 | 281 | QST_ID int(10) unsigned NOT NULL, |
| 282 | 282 | QGQ_order int(10) unsigned NOT NULL DEFAULT 0, |
| 283 | 283 | PRIMARY KEY (QGQ_ID) "; |
| 284 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 285 | - $table_name = 'esp_question_option'; |
|
| 286 | - $sql = "QSO_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 284 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 285 | + $table_name = 'esp_question_option'; |
|
| 286 | + $sql = "QSO_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 287 | 287 | QSO_value varchar(255) NOT NULL, |
| 288 | 288 | QSO_desc text NOT NULL, |
| 289 | 289 | QST_ID int(10) unsigned NOT NULL, |
| 290 | 290 | QSO_order int(10) unsigned NOT NULL DEFAULT 0, |
| 291 | 291 | QSO_deleted tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 292 | 292 | PRIMARY KEY (QSO_ID)"; |
| 293 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 294 | - $table_name = 'esp_registration'; |
|
| 295 | - $sql = "REG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 293 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 294 | + $table_name = 'esp_registration'; |
|
| 295 | + $sql = "REG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 296 | 296 | EVT_ID bigint(20) unsigned NOT NULL, |
| 297 | 297 | ATT_ID bigint(20) unsigned NOT NULL, |
| 298 | 298 | TXN_ID int(10) unsigned NOT NULL, |
@@ -315,25 +315,25 @@ discard block |
||
| 315 | 315 | KEY STS_ID (STS_ID), |
| 316 | 316 | KEY REG_url_link (REG_url_link), |
| 317 | 317 | KEY REG_code (REG_code)"; |
| 318 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 319 | - $table_name = 'esp_checkin'; |
|
| 320 | - $sql = "CHK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 318 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 319 | + $table_name = 'esp_checkin'; |
|
| 320 | + $sql = "CHK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 321 | 321 | REG_ID int(10) unsigned NOT NULL, |
| 322 | 322 | DTT_ID int(10) unsigned NOT NULL, |
| 323 | 323 | CHK_in tinyint(1) unsigned NOT NULL DEFAULT 1, |
| 324 | 324 | CHK_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
| 325 | 325 | PRIMARY KEY (CHK_ID)"; |
| 326 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 327 | - $table_name = 'esp_state'; |
|
| 328 | - $sql = "STA_ID smallint(5) unsigned NOT NULL AUTO_INCREMENT, |
|
| 326 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 327 | + $table_name = 'esp_state'; |
|
| 328 | + $sql = "STA_ID smallint(5) unsigned NOT NULL AUTO_INCREMENT, |
|
| 329 | 329 | CNT_ISO varchar(2) COLLATE utf8_bin NOT NULL, |
| 330 | 330 | STA_abbrev varchar(6) COLLATE utf8_bin NOT NULL, |
| 331 | 331 | STA_name varchar(100) COLLATE utf8_bin NOT NULL, |
| 332 | 332 | STA_active tinyint(1) DEFAULT '1', |
| 333 | 333 | PRIMARY KEY (STA_ID)"; |
| 334 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 335 | - $table_name = 'esp_status'; |
|
| 336 | - $sql = "STS_ID varchar(3) COLLATE utf8_bin NOT NULL, |
|
| 334 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 335 | + $table_name = 'esp_status'; |
|
| 336 | + $sql = "STS_ID varchar(3) COLLATE utf8_bin NOT NULL, |
|
| 337 | 337 | STS_code varchar(45) COLLATE utf8_bin NOT NULL, |
| 338 | 338 | STS_type set('event','registration','transaction','payment','email') COLLATE utf8_bin NOT NULL, |
| 339 | 339 | STS_can_edit tinyint(1) NOT NULL DEFAULT 0, |
@@ -341,9 +341,9 @@ discard block |
||
| 341 | 341 | STS_open tinyint(1) NOT NULL DEFAULT 1, |
| 342 | 342 | UNIQUE KEY STS_ID_UNIQUE (STS_ID), |
| 343 | 343 | KEY STS_type (STS_type)"; |
| 344 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 345 | - $table_name = 'esp_transaction'; |
|
| 346 | - $sql = "TXN_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 344 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 345 | + $table_name = 'esp_transaction'; |
|
| 346 | + $sql = "TXN_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 347 | 347 | TXN_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
| 348 | 348 | TXN_total decimal(10,3) DEFAULT '0.00', |
| 349 | 349 | TXN_paid decimal(10,3) NOT NULL DEFAULT '0.00', |
@@ -354,9 +354,9 @@ discard block |
||
| 354 | 354 | PRIMARY KEY (TXN_ID), |
| 355 | 355 | KEY TXN_timestamp (TXN_timestamp), |
| 356 | 356 | KEY STS_ID (STS_ID)"; |
| 357 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 358 | - $table_name = 'esp_venue_meta'; |
|
| 359 | - $sql = "VNUM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 357 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 358 | + $table_name = 'esp_venue_meta'; |
|
| 359 | + $sql = "VNUM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 360 | 360 | VNU_ID bigint(20) unsigned NOT NULL DEFAULT 0, |
| 361 | 361 | VNU_address varchar(255) DEFAULT NULL, |
| 362 | 362 | VNU_address2 varchar(255) DEFAULT NULL, |
@@ -374,10 +374,10 @@ discard block |
||
| 374 | 374 | PRIMARY KEY (VNUM_ID), |
| 375 | 375 | KEY STA_ID (STA_ID), |
| 376 | 376 | KEY CNT_ISO (CNT_ISO)"; |
| 377 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 378 | - // modified tables |
|
| 379 | - $table_name = "esp_price"; |
|
| 380 | - $sql = "PRC_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 377 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 378 | + // modified tables |
|
| 379 | + $table_name = "esp_price"; |
|
| 380 | + $sql = "PRC_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 381 | 381 | PRT_ID tinyint(3) unsigned NOT NULL, |
| 382 | 382 | PRC_amount decimal(10,3) NOT NULL DEFAULT '0.00', |
| 383 | 383 | PRC_name varchar(245) NOT NULL, |
@@ -389,9 +389,9 @@ discard block |
||
| 389 | 389 | PRC_wp_user bigint(20) unsigned NULL, |
| 390 | 390 | PRC_parent int(10) unsigned DEFAULT 0, |
| 391 | 391 | PRIMARY KEY (PRC_ID)"; |
| 392 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 393 | - $table_name = "esp_price_type"; |
|
| 394 | - $sql = "PRT_ID tinyint(3) unsigned NOT NULL AUTO_INCREMENT, |
|
| 392 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 393 | + $table_name = "esp_price_type"; |
|
| 394 | + $sql = "PRT_ID tinyint(3) unsigned NOT NULL AUTO_INCREMENT, |
|
| 395 | 395 | PRT_name varchar(45) NOT NULL, |
| 396 | 396 | PBT_ID tinyint(3) unsigned NOT NULL DEFAULT '1', |
| 397 | 397 | PRT_is_percent tinyint(1) NOT NULL DEFAULT '0', |
@@ -400,9 +400,9 @@ discard block |
||
| 400 | 400 | PRT_deleted tinyint(1) NOT NULL DEFAULT '0', |
| 401 | 401 | UNIQUE KEY PRT_name_UNIQUE (PRT_name), |
| 402 | 402 | PRIMARY KEY (PRT_ID)"; |
| 403 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 404 | - $table_name = "esp_ticket"; |
|
| 405 | - $sql = "TKT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 403 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 404 | + $table_name = "esp_ticket"; |
|
| 405 | + $sql = "TKT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 406 | 406 | TTM_ID int(10) unsigned NOT NULL, |
| 407 | 407 | TKT_name varchar(245) NOT NULL DEFAULT '', |
| 408 | 408 | TKT_description text NOT NULL, |
@@ -423,10 +423,10 @@ discard block |
||
| 423 | 423 | TKT_parent int(10) unsigned DEFAULT '0', |
| 424 | 424 | TKT_deleted tinyint(1) NOT NULL DEFAULT '0', |
| 425 | 425 | PRIMARY KEY (TKT_ID)"; |
| 426 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 427 | - $this->_get_table_manager()->dropIndex('esp_question_group', 'QSG_identifier_UNIQUE'); |
|
| 428 | - $table_name = 'esp_question_group'; |
|
| 429 | - $sql = 'QSG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 426 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 427 | + $this->_get_table_manager()->dropIndex('esp_question_group', 'QSG_identifier_UNIQUE'); |
|
| 428 | + $table_name = 'esp_question_group'; |
|
| 429 | + $sql = 'QSG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 430 | 430 | QSG_name varchar(255) NOT NULL, |
| 431 | 431 | QSG_identifier varchar(100) NOT NULL, |
| 432 | 432 | QSG_desc text NULL, |
@@ -438,133 +438,133 @@ discard block |
||
| 438 | 438 | QSG_wp_user bigint(20) unsigned NULL, |
| 439 | 439 | PRIMARY KEY (QSG_ID), |
| 440 | 440 | UNIQUE KEY QSG_identifier_UNIQUE (QSG_identifier ASC)'; |
| 441 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 442 | - $script_4_1_defaults = EE_Registry::instance()->load_dms('Core_4_1_0'); |
|
| 443 | - // (because many need to convert old string states to foreign keys into the states table) |
|
| 444 | - $script_4_1_defaults->insert_default_states(); |
|
| 445 | - $script_4_1_defaults->insert_default_countries(); |
|
| 446 | - // schema on price, price_types and tickets has changed so use the DEFAULT method in here instead of 4.1's and later. |
|
| 447 | - $this->insert_default_price_types(); |
|
| 448 | - $this->insert_default_prices(); |
|
| 449 | - $this->insert_default_tickets(); |
|
| 450 | - // setting up the config wp option pretty well counts as a 'schema change', or at least should happen ehre |
|
| 451 | - EE_Config::instance()->update_espresso_config(false, true); |
|
| 452 | - return true; |
|
| 453 | - } |
|
| 441 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 442 | + $script_4_1_defaults = EE_Registry::instance()->load_dms('Core_4_1_0'); |
|
| 443 | + // (because many need to convert old string states to foreign keys into the states table) |
|
| 444 | + $script_4_1_defaults->insert_default_states(); |
|
| 445 | + $script_4_1_defaults->insert_default_countries(); |
|
| 446 | + // schema on price, price_types and tickets has changed so use the DEFAULT method in here instead of 4.1's and later. |
|
| 447 | + $this->insert_default_price_types(); |
|
| 448 | + $this->insert_default_prices(); |
|
| 449 | + $this->insert_default_tickets(); |
|
| 450 | + // setting up the config wp option pretty well counts as a 'schema change', or at least should happen ehre |
|
| 451 | + EE_Config::instance()->update_espresso_config(false, true); |
|
| 452 | + return true; |
|
| 453 | + } |
|
| 454 | 454 | |
| 455 | 455 | |
| 456 | 456 | |
| 457 | - /** |
|
| 458 | - * @return boolean |
|
| 459 | - */ |
|
| 460 | - public function schema_changes_after_migration() |
|
| 461 | - { |
|
| 462 | - return true; |
|
| 463 | - } |
|
| 457 | + /** |
|
| 458 | + * @return boolean |
|
| 459 | + */ |
|
| 460 | + public function schema_changes_after_migration() |
|
| 461 | + { |
|
| 462 | + return true; |
|
| 463 | + } |
|
| 464 | 464 | |
| 465 | 465 | |
| 466 | 466 | |
| 467 | - public function migration_page_hooks() |
|
| 468 | - { |
|
| 469 | - } |
|
| 467 | + public function migration_page_hooks() |
|
| 468 | + { |
|
| 469 | + } |
|
| 470 | 470 | |
| 471 | 471 | |
| 472 | 472 | |
| 473 | - /** |
|
| 474 | - * insert_default_price_types |
|
| 475 | - * |
|
| 476 | - * @since 4.5.0 |
|
| 477 | - * @return void |
|
| 478 | - */ |
|
| 479 | - public function insert_default_price_types() |
|
| 480 | - { |
|
| 481 | - global $wpdb; |
|
| 482 | - $price_type_table = $wpdb->prefix . "esp_price_type"; |
|
| 483 | - if ($this->_get_table_analysis()->tableExists($price_type_table)) { |
|
| 484 | - $SQL = 'SELECT COUNT(PRT_ID) FROM ' . $price_type_table; |
|
| 485 | - $price_types_exist = $wpdb->get_var($SQL); |
|
| 486 | - if (! $price_types_exist) { |
|
| 487 | - $user_id = EEH_Activation::get_default_creator_id(); |
|
| 488 | - $SQL = "INSERT INTO $price_type_table ( PRT_ID, PRT_name, PBT_ID, PRT_is_percent, PRT_order, PRT_wp_user, PRT_deleted ) VALUES |
|
| 473 | + /** |
|
| 474 | + * insert_default_price_types |
|
| 475 | + * |
|
| 476 | + * @since 4.5.0 |
|
| 477 | + * @return void |
|
| 478 | + */ |
|
| 479 | + public function insert_default_price_types() |
|
| 480 | + { |
|
| 481 | + global $wpdb; |
|
| 482 | + $price_type_table = $wpdb->prefix . "esp_price_type"; |
|
| 483 | + if ($this->_get_table_analysis()->tableExists($price_type_table)) { |
|
| 484 | + $SQL = 'SELECT COUNT(PRT_ID) FROM ' . $price_type_table; |
|
| 485 | + $price_types_exist = $wpdb->get_var($SQL); |
|
| 486 | + if (! $price_types_exist) { |
|
| 487 | + $user_id = EEH_Activation::get_default_creator_id(); |
|
| 488 | + $SQL = "INSERT INTO $price_type_table ( PRT_ID, PRT_name, PBT_ID, PRT_is_percent, PRT_order, PRT_wp_user, PRT_deleted ) VALUES |
|
| 489 | 489 | (1, '" . __('Base Price', 'event_espresso') . "', 1, 0, 0, $user_id, 0), |
| 490 | 490 | (2, '" . __('Percent Discount', 'event_espresso') . "', 2, 1, 20, $user_id, 0), |
| 491 | 491 | (3, '" . __('Dollar Discount', 'event_espresso') . "', 2, 0, 30, $user_id, 0), |
| 492 | 492 | (4, '" . __('Percent Surcharge', 'event_espresso') . "', 3, 1, 40, $user_id, 0), |
| 493 | 493 | (5, '" . __('Dollar Surcharge', 'event_espresso') . "', 3, 0, 50, $user_id, 0);"; |
| 494 | - $SQL = apply_filters('FHEE__EE_DMS_4_5_0__insert_default_price_types__SQL', $SQL); |
|
| 495 | - $wpdb->query($SQL); |
|
| 496 | - } |
|
| 497 | - } |
|
| 498 | - } |
|
| 494 | + $SQL = apply_filters('FHEE__EE_DMS_4_5_0__insert_default_price_types__SQL', $SQL); |
|
| 495 | + $wpdb->query($SQL); |
|
| 496 | + } |
|
| 497 | + } |
|
| 498 | + } |
|
| 499 | 499 | |
| 500 | 500 | |
| 501 | 501 | |
| 502 | - /** |
|
| 503 | - * insert DEFAULT prices. |
|
| 504 | - * If we're INSTALLING 4.x CAF, then we add a few extra DEFAULT prices |
|
| 505 | - * when EEH_Activaion's initialize_db_content is called via ahook in |
|
| 506 | - * EE_Brewing_regular |
|
| 507 | - * |
|
| 508 | - * @since 4.5.0 |
|
| 509 | - * @return void |
|
| 510 | - */ |
|
| 511 | - public function insert_default_prices() |
|
| 512 | - { |
|
| 513 | - global $wpdb; |
|
| 514 | - $price_table = $wpdb->prefix . "esp_price"; |
|
| 515 | - if ($this->_get_table_analysis()->tableExists($price_table)) { |
|
| 516 | - $SQL = 'SELECT COUNT(PRC_ID) FROM ' . $price_table; |
|
| 517 | - $prices_exist = $wpdb->get_var($SQL); |
|
| 518 | - if (! $prices_exist) { |
|
| 519 | - $user_id = EEH_Activation::get_default_creator_id(); |
|
| 520 | - $SQL = "INSERT INTO $price_table |
|
| 502 | + /** |
|
| 503 | + * insert DEFAULT prices. |
|
| 504 | + * If we're INSTALLING 4.x CAF, then we add a few extra DEFAULT prices |
|
| 505 | + * when EEH_Activaion's initialize_db_content is called via ahook in |
|
| 506 | + * EE_Brewing_regular |
|
| 507 | + * |
|
| 508 | + * @since 4.5.0 |
|
| 509 | + * @return void |
|
| 510 | + */ |
|
| 511 | + public function insert_default_prices() |
|
| 512 | + { |
|
| 513 | + global $wpdb; |
|
| 514 | + $price_table = $wpdb->prefix . "esp_price"; |
|
| 515 | + if ($this->_get_table_analysis()->tableExists($price_table)) { |
|
| 516 | + $SQL = 'SELECT COUNT(PRC_ID) FROM ' . $price_table; |
|
| 517 | + $prices_exist = $wpdb->get_var($SQL); |
|
| 518 | + if (! $prices_exist) { |
|
| 519 | + $user_id = EEH_Activation::get_default_creator_id(); |
|
| 520 | + $SQL = "INSERT INTO $price_table |
|
| 521 | 521 | (PRC_ID, PRT_ID, PRC_amount, PRC_name, PRC_desc, PRC_is_default, PRC_overrides, PRC_wp_user, PRC_order, PRC_deleted, PRC_parent ) VALUES |
| 522 | 522 | (1, 1, '0.00', 'Free Admission', '', 1, NULL, $user_id, 0, 0, 0);"; |
| 523 | - $SQL = apply_filters('FHEE__EE_DMS_4_5_0__insert_default_prices__SQL', $SQL); |
|
| 524 | - $wpdb->query($SQL); |
|
| 525 | - } |
|
| 526 | - } |
|
| 527 | - } |
|
| 523 | + $SQL = apply_filters('FHEE__EE_DMS_4_5_0__insert_default_prices__SQL', $SQL); |
|
| 524 | + $wpdb->query($SQL); |
|
| 525 | + } |
|
| 526 | + } |
|
| 527 | + } |
|
| 528 | 528 | |
| 529 | 529 | |
| 530 | 530 | |
| 531 | - /** |
|
| 532 | - * insert DEFAULT ticket |
|
| 533 | - * Almost identical to EE_DMS_Core_4_3_0::insert_default_tickets, except is aware of the TKT_wp_user field |
|
| 534 | - * |
|
| 535 | - * @since 4.5.0 |
|
| 536 | - * @return void |
|
| 537 | - */ |
|
| 538 | - public function insert_default_tickets() |
|
| 539 | - { |
|
| 540 | - global $wpdb; |
|
| 541 | - $ticket_table = $wpdb->prefix . "esp_ticket"; |
|
| 542 | - if ($this->_get_table_analysis()->tableExists($ticket_table)) { |
|
| 543 | - $SQL = 'SELECT COUNT(TKT_ID) FROM ' . $ticket_table; |
|
| 544 | - $tickets_exist = $wpdb->get_var($SQL); |
|
| 545 | - if (! $tickets_exist) { |
|
| 546 | - $user_id = EEH_Activation::get_default_creator_id(); |
|
| 547 | - $SQL = "INSERT INTO $ticket_table |
|
| 531 | + /** |
|
| 532 | + * insert DEFAULT ticket |
|
| 533 | + * Almost identical to EE_DMS_Core_4_3_0::insert_default_tickets, except is aware of the TKT_wp_user field |
|
| 534 | + * |
|
| 535 | + * @since 4.5.0 |
|
| 536 | + * @return void |
|
| 537 | + */ |
|
| 538 | + public function insert_default_tickets() |
|
| 539 | + { |
|
| 540 | + global $wpdb; |
|
| 541 | + $ticket_table = $wpdb->prefix . "esp_ticket"; |
|
| 542 | + if ($this->_get_table_analysis()->tableExists($ticket_table)) { |
|
| 543 | + $SQL = 'SELECT COUNT(TKT_ID) FROM ' . $ticket_table; |
|
| 544 | + $tickets_exist = $wpdb->get_var($SQL); |
|
| 545 | + if (! $tickets_exist) { |
|
| 546 | + $user_id = EEH_Activation::get_default_creator_id(); |
|
| 547 | + $SQL = "INSERT INTO $ticket_table |
|
| 548 | 548 | ( TKT_ID, TTM_ID, TKT_name, TKT_description, TKT_qty, TKT_sold, TKT_uses, TKT_required, TKT_min, TKT_max, TKT_price, TKT_start_date, TKT_end_date, TKT_taxable, TKT_order, TKT_row, TKT_is_default, TKT_parent, TKT_wp_user, TKT_deleted ) VALUES |
| 549 | 549 | ( 1, 0, '" |
| 550 | - . __("Free Ticket", "event_espresso") |
|
| 551 | - . "', '', 100, 0, -1, 0, 0, -1, 0.00, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 0, 0, 1, 1, 0, $user_id, 0);"; |
|
| 552 | - $SQL = apply_filters('FHEE__EE_DMS_4_5_0__insert_default_tickets__SQL', $SQL); |
|
| 553 | - $wpdb->query($SQL); |
|
| 554 | - } |
|
| 555 | - } |
|
| 556 | - $ticket_price_table = $wpdb->prefix . "esp_ticket_price"; |
|
| 557 | - if ($this->_get_table_analysis()->tableExists($ticket_price_table)) { |
|
| 558 | - $SQL = 'SELECT COUNT(TKP_ID) FROM ' . $ticket_price_table; |
|
| 559 | - $ticket_prc_exist = $wpdb->get_var($SQL); |
|
| 560 | - if (! $ticket_prc_exist) { |
|
| 561 | - $SQL = "INSERT INTO $ticket_price_table |
|
| 550 | + . __("Free Ticket", "event_espresso") |
|
| 551 | + . "', '', 100, 0, -1, 0, 0, -1, 0.00, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 0, 0, 1, 1, 0, $user_id, 0);"; |
|
| 552 | + $SQL = apply_filters('FHEE__EE_DMS_4_5_0__insert_default_tickets__SQL', $SQL); |
|
| 553 | + $wpdb->query($SQL); |
|
| 554 | + } |
|
| 555 | + } |
|
| 556 | + $ticket_price_table = $wpdb->prefix . "esp_ticket_price"; |
|
| 557 | + if ($this->_get_table_analysis()->tableExists($ticket_price_table)) { |
|
| 558 | + $SQL = 'SELECT COUNT(TKP_ID) FROM ' . $ticket_price_table; |
|
| 559 | + $ticket_prc_exist = $wpdb->get_var($SQL); |
|
| 560 | + if (! $ticket_prc_exist) { |
|
| 561 | + $SQL = "INSERT INTO $ticket_price_table |
|
| 562 | 562 | ( TKP_ID, TKT_ID, PRC_ID ) VALUES |
| 563 | 563 | ( 1, 1, 1 ) |
| 564 | 564 | "; |
| 565 | - $SQL = apply_filters('FHEE__EE_DMS_4_5_0__insert_default_tickets__SQL__ticket_price', $SQL); |
|
| 566 | - $wpdb->query($SQL); |
|
| 567 | - } |
|
| 568 | - } |
|
| 569 | - } |
|
| 565 | + $SQL = apply_filters('FHEE__EE_DMS_4_5_0__insert_default_tickets__SQL__ticket_price', $SQL); |
|
| 566 | + $wpdb->query($SQL); |
|
| 567 | + } |
|
| 568 | + } |
|
| 569 | + } |
|
| 570 | 570 | } |
@@ -13,12 +13,12 @@ discard block |
||
| 13 | 13 | // unfortunately, this needs to be done upon INCLUSION of this file, |
| 14 | 14 | // instead of construction, because it only gets constructed on first page load |
| 15 | 15 | // (all other times it gets resurrected from a wordpress option) |
| 16 | -$stages = glob(EE_CORE . 'data_migration_scripts/4_5_0_stages/*'); |
|
| 16 | +$stages = glob(EE_CORE.'data_migration_scripts/4_5_0_stages/*'); |
|
| 17 | 17 | $class_to_filepath = array(); |
| 18 | 18 | foreach ($stages as $filepath) { |
| 19 | 19 | $matches = array(); |
| 20 | 20 | preg_match('~4_5_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
| 21 | - $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 21 | + $class_to_filepath[$matches[1]] = $filepath; |
|
| 22 | 22 | } |
| 23 | 23 | // give addons a chance to autoload their stages too |
| 24 | 24 | $class_to_filepath = apply_filters('FHEE__EE_DMS_4_5_0__autoloaded_stages', $class_to_filepath); |
@@ -59,10 +59,10 @@ discard block |
||
| 59 | 59 | if (version_compare($version_string, '4.5.0.decaf', '<') && version_compare($version_string, '4.3.0.decaf', '>=')) { |
| 60 | 60 | // echo "$version_string can be migrated from"; |
| 61 | 61 | return true; |
| 62 | - } elseif (! $version_string) { |
|
| 62 | + } elseif ( ! $version_string) { |
|
| 63 | 63 | // echo "no version string provided: $version_string"; |
| 64 | 64 | // no version string provided... this must be pre 4.3 |
| 65 | - return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 65 | + return false; // changed mind. dont want people thinking they should migrate yet because they cant |
|
| 66 | 66 | } else { |
| 67 | 67 | // echo "$version_string doesnt apply"; |
| 68 | 68 | return false; |
@@ -74,7 +74,7 @@ discard block |
||
| 74 | 74 | public function schema_changes_before_migration() |
| 75 | 75 | { |
| 76 | 76 | // relies on 4.1's EEH_Activation::create_table |
| 77 | - require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 77 | + require_once(EE_HELPERS.'EEH_Activation.helper.php'); |
|
| 78 | 78 | $table_name = 'esp_answer'; |
| 79 | 79 | $sql = "ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
| 80 | 80 | REG_ID int(10) unsigned NOT NULL, |
@@ -479,18 +479,18 @@ discard block |
||
| 479 | 479 | public function insert_default_price_types() |
| 480 | 480 | { |
| 481 | 481 | global $wpdb; |
| 482 | - $price_type_table = $wpdb->prefix . "esp_price_type"; |
|
| 482 | + $price_type_table = $wpdb->prefix."esp_price_type"; |
|
| 483 | 483 | if ($this->_get_table_analysis()->tableExists($price_type_table)) { |
| 484 | - $SQL = 'SELECT COUNT(PRT_ID) FROM ' . $price_type_table; |
|
| 484 | + $SQL = 'SELECT COUNT(PRT_ID) FROM '.$price_type_table; |
|
| 485 | 485 | $price_types_exist = $wpdb->get_var($SQL); |
| 486 | - if (! $price_types_exist) { |
|
| 486 | + if ( ! $price_types_exist) { |
|
| 487 | 487 | $user_id = EEH_Activation::get_default_creator_id(); |
| 488 | 488 | $SQL = "INSERT INTO $price_type_table ( PRT_ID, PRT_name, PBT_ID, PRT_is_percent, PRT_order, PRT_wp_user, PRT_deleted ) VALUES |
| 489 | - (1, '" . __('Base Price', 'event_espresso') . "', 1, 0, 0, $user_id, 0), |
|
| 490 | - (2, '" . __('Percent Discount', 'event_espresso') . "', 2, 1, 20, $user_id, 0), |
|
| 491 | - (3, '" . __('Dollar Discount', 'event_espresso') . "', 2, 0, 30, $user_id, 0), |
|
| 492 | - (4, '" . __('Percent Surcharge', 'event_espresso') . "', 3, 1, 40, $user_id, 0), |
|
| 493 | - (5, '" . __('Dollar Surcharge', 'event_espresso') . "', 3, 0, 50, $user_id, 0);"; |
|
| 489 | + (1, '".__('Base Price', 'event_espresso')."', 1, 0, 0, $user_id, 0), |
|
| 490 | + (2, '".__('Percent Discount', 'event_espresso')."', 2, 1, 20, $user_id, 0), |
|
| 491 | + (3, '".__('Dollar Discount', 'event_espresso')."', 2, 0, 30, $user_id, 0), |
|
| 492 | + (4, '".__('Percent Surcharge', 'event_espresso')."', 3, 1, 40, $user_id, 0), |
|
| 493 | + (5, '".__('Dollar Surcharge', 'event_espresso')."', 3, 0, 50, $user_id, 0);"; |
|
| 494 | 494 | $SQL = apply_filters('FHEE__EE_DMS_4_5_0__insert_default_price_types__SQL', $SQL); |
| 495 | 495 | $wpdb->query($SQL); |
| 496 | 496 | } |
@@ -511,11 +511,11 @@ discard block |
||
| 511 | 511 | public function insert_default_prices() |
| 512 | 512 | { |
| 513 | 513 | global $wpdb; |
| 514 | - $price_table = $wpdb->prefix . "esp_price"; |
|
| 514 | + $price_table = $wpdb->prefix."esp_price"; |
|
| 515 | 515 | if ($this->_get_table_analysis()->tableExists($price_table)) { |
| 516 | - $SQL = 'SELECT COUNT(PRC_ID) FROM ' . $price_table; |
|
| 516 | + $SQL = 'SELECT COUNT(PRC_ID) FROM '.$price_table; |
|
| 517 | 517 | $prices_exist = $wpdb->get_var($SQL); |
| 518 | - if (! $prices_exist) { |
|
| 518 | + if ( ! $prices_exist) { |
|
| 519 | 519 | $user_id = EEH_Activation::get_default_creator_id(); |
| 520 | 520 | $SQL = "INSERT INTO $price_table |
| 521 | 521 | (PRC_ID, PRT_ID, PRC_amount, PRC_name, PRC_desc, PRC_is_default, PRC_overrides, PRC_wp_user, PRC_order, PRC_deleted, PRC_parent ) VALUES |
@@ -538,11 +538,11 @@ discard block |
||
| 538 | 538 | public function insert_default_tickets() |
| 539 | 539 | { |
| 540 | 540 | global $wpdb; |
| 541 | - $ticket_table = $wpdb->prefix . "esp_ticket"; |
|
| 541 | + $ticket_table = $wpdb->prefix."esp_ticket"; |
|
| 542 | 542 | if ($this->_get_table_analysis()->tableExists($ticket_table)) { |
| 543 | - $SQL = 'SELECT COUNT(TKT_ID) FROM ' . $ticket_table; |
|
| 543 | + $SQL = 'SELECT COUNT(TKT_ID) FROM '.$ticket_table; |
|
| 544 | 544 | $tickets_exist = $wpdb->get_var($SQL); |
| 545 | - if (! $tickets_exist) { |
|
| 545 | + if ( ! $tickets_exist) { |
|
| 546 | 546 | $user_id = EEH_Activation::get_default_creator_id(); |
| 547 | 547 | $SQL = "INSERT INTO $ticket_table |
| 548 | 548 | ( TKT_ID, TTM_ID, TKT_name, TKT_description, TKT_qty, TKT_sold, TKT_uses, TKT_required, TKT_min, TKT_max, TKT_price, TKT_start_date, TKT_end_date, TKT_taxable, TKT_order, TKT_row, TKT_is_default, TKT_parent, TKT_wp_user, TKT_deleted ) VALUES |
@@ -553,11 +553,11 @@ discard block |
||
| 553 | 553 | $wpdb->query($SQL); |
| 554 | 554 | } |
| 555 | 555 | } |
| 556 | - $ticket_price_table = $wpdb->prefix . "esp_ticket_price"; |
|
| 556 | + $ticket_price_table = $wpdb->prefix."esp_ticket_price"; |
|
| 557 | 557 | if ($this->_get_table_analysis()->tableExists($ticket_price_table)) { |
| 558 | - $SQL = 'SELECT COUNT(TKP_ID) FROM ' . $ticket_price_table; |
|
| 558 | + $SQL = 'SELECT COUNT(TKP_ID) FROM '.$ticket_price_table; |
|
| 559 | 559 | $ticket_prc_exist = $wpdb->get_var($SQL); |
| 560 | - if (! $ticket_prc_exist) { |
|
| 560 | + if ( ! $ticket_prc_exist) { |
|
| 561 | 561 | $SQL = "INSERT INTO $ticket_price_table |
| 562 | 562 | ( TKP_ID, TKT_ID, PRC_ID ) VALUES |
| 563 | 563 | ( 1, 1, 1 ) |
@@ -12,11 +12,11 @@ discard block |
||
| 12 | 12 | $stages = glob(EE_CORE . 'data_migration_scripts/4_1_0_stages/*'); |
| 13 | 13 | $class_to_filepath = array(); |
| 14 | 14 | if (! empty($stages)) { |
| 15 | - foreach ($stages as $filepath) { |
|
| 16 | - $matches = array(); |
|
| 17 | - preg_match('~4_1_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
|
| 18 | - $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 19 | - } |
|
| 15 | + foreach ($stages as $filepath) { |
|
| 16 | + $matches = array(); |
|
| 17 | + preg_match('~4_1_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
|
| 18 | + $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 19 | + } |
|
| 20 | 20 | } |
| 21 | 21 | // give addons a chance to autoload their stages too |
| 22 | 22 | $class_to_filepath = apply_filters('FHEE__EE_DMS_4_1_0__autoloaded_stages', $class_to_filepath); |
@@ -44,91 +44,91 @@ discard block |
||
| 44 | 44 | |
| 45 | 45 | |
| 46 | 46 | |
| 47 | - /** |
|
| 48 | - * EE_DMS_Core_4_1_0 constructor. |
|
| 49 | - * |
|
| 50 | - * @param TableManager $table_manager |
|
| 51 | - * @param TableAnalysis $table_analysis |
|
| 52 | - */ |
|
| 53 | - public function __construct(TableManager $table_manager = null, TableAnalysis $table_analysis = null) |
|
| 54 | - { |
|
| 55 | - $this->_pretty_name = esc_html__("Data Migration from Event Espresso 3 to Event Espresso 4.1.0", "event_espresso"); |
|
| 56 | - $this->_priority = 10; |
|
| 57 | - $this->_migration_stages = array( |
|
| 58 | - new EE_DMS_4_1_0_org_options(), |
|
| 59 | - new EE_DMS_4_1_0_shortcodes(), |
|
| 60 | - new EE_DMS_4_1_0_gateways(), |
|
| 61 | - new EE_DMS_4_1_0_events(), |
|
| 62 | - new EE_DMS_4_1_0_prices(), |
|
| 63 | - new EE_DMS_4_1_0_category_details(), |
|
| 64 | - new EE_DMS_4_1_0_event_category(), |
|
| 65 | - new EE_DMS_4_1_0_venues(), |
|
| 66 | - new EE_DMS_4_1_0_event_venue(), |
|
| 67 | - new EE_DMS_4_1_0_question_groups(), |
|
| 68 | - new EE_DMS_4_1_0_questions(), |
|
| 69 | - new EE_DMS_4_1_0_question_group_question(), |
|
| 70 | - new EE_DMS_4_1_0_event_question_group(), |
|
| 71 | - new EE_DMS_4_1_0_attendees(), |
|
| 72 | - new EE_DMS_4_1_0_line_items(), |
|
| 73 | - new EE_DMS_4_1_0_answers(), |
|
| 74 | - new EE_DMS_4_1_0_checkins(), |
|
| 75 | - ); |
|
| 76 | - parent::__construct($table_manager, $table_analysis); |
|
| 77 | - } |
|
| 78 | - |
|
| 79 | - |
|
| 80 | - |
|
| 81 | - /** |
|
| 82 | - * Checks if this 3.1 Check-in table exists. If it doesn't we can't migrate Check-ins |
|
| 83 | - * |
|
| 84 | - * @global wpdb $wpdb |
|
| 85 | - * @return boolean |
|
| 86 | - */ |
|
| 87 | - private function _checkin_table_exists() |
|
| 88 | - { |
|
| 89 | - global $wpdb; |
|
| 90 | - $results = $wpdb->get_results("SHOW TABLES LIKE '" . $wpdb->prefix . "events_attendee_checkin" . "'"); |
|
| 91 | - if ($results) { |
|
| 92 | - return true; |
|
| 93 | - } else { |
|
| 94 | - return false; |
|
| 95 | - } |
|
| 96 | - } |
|
| 97 | - |
|
| 98 | - |
|
| 99 | - |
|
| 100 | - public function can_migrate_from_version($version_array) |
|
| 101 | - { |
|
| 102 | - $version_string = $version_array['Core']; |
|
| 103 | - if (version_compare($version_string, '4.0.0.decaf', '<') && version_compare($version_string, '3.1.26', '>=')) { |
|
| 47 | + /** |
|
| 48 | + * EE_DMS_Core_4_1_0 constructor. |
|
| 49 | + * |
|
| 50 | + * @param TableManager $table_manager |
|
| 51 | + * @param TableAnalysis $table_analysis |
|
| 52 | + */ |
|
| 53 | + public function __construct(TableManager $table_manager = null, TableAnalysis $table_analysis = null) |
|
| 54 | + { |
|
| 55 | + $this->_pretty_name = esc_html__("Data Migration from Event Espresso 3 to Event Espresso 4.1.0", "event_espresso"); |
|
| 56 | + $this->_priority = 10; |
|
| 57 | + $this->_migration_stages = array( |
|
| 58 | + new EE_DMS_4_1_0_org_options(), |
|
| 59 | + new EE_DMS_4_1_0_shortcodes(), |
|
| 60 | + new EE_DMS_4_1_0_gateways(), |
|
| 61 | + new EE_DMS_4_1_0_events(), |
|
| 62 | + new EE_DMS_4_1_0_prices(), |
|
| 63 | + new EE_DMS_4_1_0_category_details(), |
|
| 64 | + new EE_DMS_4_1_0_event_category(), |
|
| 65 | + new EE_DMS_4_1_0_venues(), |
|
| 66 | + new EE_DMS_4_1_0_event_venue(), |
|
| 67 | + new EE_DMS_4_1_0_question_groups(), |
|
| 68 | + new EE_DMS_4_1_0_questions(), |
|
| 69 | + new EE_DMS_4_1_0_question_group_question(), |
|
| 70 | + new EE_DMS_4_1_0_event_question_group(), |
|
| 71 | + new EE_DMS_4_1_0_attendees(), |
|
| 72 | + new EE_DMS_4_1_0_line_items(), |
|
| 73 | + new EE_DMS_4_1_0_answers(), |
|
| 74 | + new EE_DMS_4_1_0_checkins(), |
|
| 75 | + ); |
|
| 76 | + parent::__construct($table_manager, $table_analysis); |
|
| 77 | + } |
|
| 78 | + |
|
| 79 | + |
|
| 80 | + |
|
| 81 | + /** |
|
| 82 | + * Checks if this 3.1 Check-in table exists. If it doesn't we can't migrate Check-ins |
|
| 83 | + * |
|
| 84 | + * @global wpdb $wpdb |
|
| 85 | + * @return boolean |
|
| 86 | + */ |
|
| 87 | + private function _checkin_table_exists() |
|
| 88 | + { |
|
| 89 | + global $wpdb; |
|
| 90 | + $results = $wpdb->get_results("SHOW TABLES LIKE '" . $wpdb->prefix . "events_attendee_checkin" . "'"); |
|
| 91 | + if ($results) { |
|
| 92 | + return true; |
|
| 93 | + } else { |
|
| 94 | + return false; |
|
| 95 | + } |
|
| 96 | + } |
|
| 97 | + |
|
| 98 | + |
|
| 99 | + |
|
| 100 | + public function can_migrate_from_version($version_array) |
|
| 101 | + { |
|
| 102 | + $version_string = $version_array['Core']; |
|
| 103 | + if (version_compare($version_string, '4.0.0.decaf', '<') && version_compare($version_string, '3.1.26', '>=')) { |
|
| 104 | 104 | // echo "$version_string can be migrated fro"; |
| 105 | - return true; |
|
| 106 | - } elseif (! $version_string) { |
|
| 105 | + return true; |
|
| 106 | + } elseif (! $version_string) { |
|
| 107 | 107 | // echo "no version string provided: $version_string"; |
| 108 | - // no version string provided... this must be pre 4.1 |
|
| 109 | - // because since 4.1 we're |
|
| 110 | - return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 111 | - } else { |
|
| 108 | + // no version string provided... this must be pre 4.1 |
|
| 109 | + // because since 4.1 we're |
|
| 110 | + return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 111 | + } else { |
|
| 112 | 112 | // echo "$version_string doesnt apply"; |
| 113 | - return false; |
|
| 114 | - } |
|
| 115 | - } |
|
| 113 | + return false; |
|
| 114 | + } |
|
| 115 | + } |
|
| 116 | 116 | |
| 117 | 117 | |
| 118 | 118 | |
| 119 | - public function schema_changes_before_migration() |
|
| 120 | - { |
|
| 121 | - // relies on 4.1's EEH_Activation::create_table |
|
| 122 | - require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 123 | - $table_name = 'esp_answer'; |
|
| 124 | - $sql = "ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 119 | + public function schema_changes_before_migration() |
|
| 120 | + { |
|
| 121 | + // relies on 4.1's EEH_Activation::create_table |
|
| 122 | + require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 123 | + $table_name = 'esp_answer'; |
|
| 124 | + $sql = "ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 125 | 125 | REG_ID int(10) unsigned NOT NULL, |
| 126 | 126 | QST_ID int(10) unsigned NOT NULL, |
| 127 | 127 | ANS_value text NOT NULL, |
| 128 | 128 | PRIMARY KEY (ANS_ID)"; |
| 129 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 130 | - $table_name = 'esp_attendee_meta'; |
|
| 131 | - $sql = "ATTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 129 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 130 | + $table_name = 'esp_attendee_meta'; |
|
| 131 | + $sql = "ATTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 132 | 132 | ATT_ID bigint(20) unsigned NOT NULL, |
| 133 | 133 | ATT_fname varchar(45) NOT NULL, |
| 134 | 134 | ATT_lname varchar(45) NOT NULL, |
@@ -144,9 +144,9 @@ discard block |
||
| 144 | 144 | KEY ATT_fname (ATT_fname), |
| 145 | 145 | KEY ATT_lname (ATT_lname), |
| 146 | 146 | KEY ATT_email (ATT_email(191))"; |
| 147 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 148 | - $table_name = 'esp_country'; |
|
| 149 | - $sql = "CNT_ISO varchar(2) COLLATE utf8_bin NOT NULL, |
|
| 147 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 148 | + $table_name = 'esp_country'; |
|
| 149 | + $sql = "CNT_ISO varchar(2) COLLATE utf8_bin NOT NULL, |
|
| 150 | 150 | CNT_ISO3 varchar(3) COLLATE utf8_bin NOT NULL, |
| 151 | 151 | RGN_ID tinyint(3) unsigned DEFAULT NULL, |
| 152 | 152 | CNT_name varchar(45) COLLATE utf8_bin NOT NULL, |
@@ -162,9 +162,9 @@ discard block |
||
| 162 | 162 | CNT_is_EU tinyint(1) DEFAULT '0', |
| 163 | 163 | CNT_active tinyint(1) DEFAULT '0', |
| 164 | 164 | PRIMARY KEY (CNT_ISO)"; |
| 165 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 166 | - $table_name = 'esp_datetime'; |
|
| 167 | - $sql = "DTT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 165 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 166 | + $table_name = 'esp_datetime'; |
|
| 167 | + $sql = "DTT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 168 | 168 | EVT_ID bigint(20) unsigned NOT NULL, |
| 169 | 169 | DTT_EVT_start datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
| 170 | 170 | DTT_EVT_end datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
@@ -177,9 +177,9 @@ discard block |
||
| 177 | 177 | PRIMARY KEY (DTT_ID), |
| 178 | 178 | KEY EVT_ID (EVT_ID), |
| 179 | 179 | KEY DTT_is_primary (DTT_is_primary)"; |
| 180 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 181 | - $table_name = 'esp_event_meta'; |
|
| 182 | - $sql = " |
|
| 180 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 181 | + $table_name = 'esp_event_meta'; |
|
| 182 | + $sql = " |
|
| 183 | 183 | EVTM_ID int(10) NOT NULL AUTO_INCREMENT, |
| 184 | 184 | EVT_ID bigint(20) unsigned NOT NULL, |
| 185 | 185 | EVT_display_desc tinyint(1) unsigned NOT NULL DEFAULT 1, |
@@ -194,31 +194,31 @@ discard block |
||
| 194 | 194 | EVT_external_URL varchar(200) NULL, |
| 195 | 195 | EVT_donations tinyint(1) NULL, |
| 196 | 196 | PRIMARY KEY (EVTM_ID)"; |
| 197 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 198 | - $table_name = 'esp_event_question_group'; |
|
| 199 | - $sql = "EQG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 197 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 198 | + $table_name = 'esp_event_question_group'; |
|
| 199 | + $sql = "EQG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 200 | 200 | EVT_ID bigint(20) unsigned NOT NULL, |
| 201 | 201 | QSG_ID int(10) unsigned NOT NULL, |
| 202 | 202 | EQG_primary tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 203 | 203 | PRIMARY KEY (EQG_ID)"; |
| 204 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 205 | - $table_name = 'esp_event_venue'; |
|
| 206 | - $sql = "EVV_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 204 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 205 | + $table_name = 'esp_event_venue'; |
|
| 206 | + $sql = "EVV_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 207 | 207 | EVT_ID bigint(20) unsigned NOT NULL, |
| 208 | 208 | VNU_ID bigint(20) unsigned NOT NULL, |
| 209 | 209 | EVV_primary tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 210 | 210 | PRIMARY KEY (EVV_ID)"; |
| 211 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 212 | - $table_name = 'esp_extra_meta'; |
|
| 213 | - $sql = "EXM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 211 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 212 | + $table_name = 'esp_extra_meta'; |
|
| 213 | + $sql = "EXM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 214 | 214 | OBJ_ID int(11) DEFAULT NULL, |
| 215 | 215 | EXM_type varchar(45) DEFAULT NULL, |
| 216 | 216 | EXM_key varchar(45) DEFAULT NULL, |
| 217 | 217 | EXM_value text, |
| 218 | 218 | PRIMARY KEY (EXM_ID)"; |
| 219 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 220 | - $table_name = 'esp_line_item'; |
|
| 221 | - $sql = "LIN_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 219 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 220 | + $table_name = 'esp_line_item'; |
|
| 221 | + $sql = "LIN_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 222 | 222 | LIN_code varchar(245) NOT NULL DEFAULT '', |
| 223 | 223 | TXN_ID int(11) DEFAULT NULL, |
| 224 | 224 | LIN_name varchar(245) NOT NULL DEFAULT '', |
@@ -234,18 +234,18 @@ discard block |
||
| 234 | 234 | OBJ_ID int(11) DEFAULT NULL, |
| 235 | 235 | OBJ_type varchar(45)DEFAULT NULL, |
| 236 | 236 | PRIMARY KEY (LIN_ID)"; |
| 237 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 238 | - $table_name = 'esp_message_template'; |
|
| 239 | - $sql = "MTP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 237 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 238 | + $table_name = 'esp_message_template'; |
|
| 239 | + $sql = "MTP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 240 | 240 | GRP_ID int(10) unsigned NOT NULL, |
| 241 | 241 | MTP_context varchar(50) NOT NULL, |
| 242 | 242 | MTP_template_field varchar(30) NOT NULL, |
| 243 | 243 | MTP_content text NOT NULL, |
| 244 | 244 | PRIMARY KEY (MTP_ID), |
| 245 | 245 | KEY GRP_ID (GRP_ID)"; |
| 246 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 247 | - $table_name = 'esp_message_template_group'; |
|
| 248 | - $sql = "GRP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 246 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 247 | + $table_name = 'esp_message_template_group'; |
|
| 248 | + $sql = "GRP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 249 | 249 | EVT_ID bigint(20) unsigned DEFAULT NULL, |
| 250 | 250 | MTP_user_id int(10) NOT NULL DEFAULT '1', |
| 251 | 251 | MTP_messenger varchar(30) NOT NULL, |
@@ -257,9 +257,9 @@ discard block |
||
| 257 | 257 | PRIMARY KEY (GRP_ID), |
| 258 | 258 | KEY EVT_ID (EVT_ID), |
| 259 | 259 | KEY MTP_user_id (MTP_user_id)"; |
| 260 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 261 | - $table_name = 'esp_payment'; |
|
| 262 | - $sql = "PAY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 260 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 261 | + $table_name = 'esp_payment'; |
|
| 262 | + $sql = "PAY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 263 | 263 | TXN_ID int(10) unsigned DEFAULT NULL, |
| 264 | 264 | STS_ID varchar(3) COLLATE utf8_bin DEFAULT NULL, |
| 265 | 265 | PAY_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
@@ -275,9 +275,9 @@ discard block |
||
| 275 | 275 | PRIMARY KEY (PAY_ID), |
| 276 | 276 | KEY TXN_ID (TXN_ID), |
| 277 | 277 | KEY PAY_timestamp (PAY_timestamp)"; |
| 278 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 279 | - $table_name = "esp_ticket"; |
|
| 280 | - $sql = "TKT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 278 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 279 | + $table_name = "esp_ticket"; |
|
| 280 | + $sql = "TKT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 281 | 281 | TTM_ID int(10) unsigned NOT NULL, |
| 282 | 282 | TKT_name varchar(245) NOT NULL DEFAULT '', |
| 283 | 283 | TKT_description text NOT NULL, |
@@ -296,28 +296,28 @@ discard block |
||
| 296 | 296 | TKT_parent int(10) unsigned DEFAULT '0', |
| 297 | 297 | TKT_deleted tinyint(1) NOT NULL DEFAULT '0', |
| 298 | 298 | PRIMARY KEY (TKT_ID)"; |
| 299 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 300 | - $table_name = "esp_ticket_price"; |
|
| 301 | - $sql = "TKP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 299 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 300 | + $table_name = "esp_ticket_price"; |
|
| 301 | + $sql = "TKP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 302 | 302 | TKT_ID int(10) unsigned NOT NULL, |
| 303 | 303 | PRC_ID int(10) unsigned NOT NULL, |
| 304 | 304 | PRIMARY KEY (TKP_ID)"; |
| 305 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 306 | - $table_name = "esp_datetime_ticket"; |
|
| 307 | - $sql = "DTK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 305 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 306 | + $table_name = "esp_datetime_ticket"; |
|
| 307 | + $sql = "DTK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 308 | 308 | DTT_ID int(10) unsigned NOT NULL, |
| 309 | 309 | TKT_ID int(10) unsigned NOT NULL, |
| 310 | 310 | PRIMARY KEY (DTK_ID)"; |
| 311 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 312 | - $table_name = "esp_ticket_template"; |
|
| 313 | - $sql = "TTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 311 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 312 | + $table_name = "esp_ticket_template"; |
|
| 313 | + $sql = "TTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 314 | 314 | TTM_name varchar(45) NOT NULL, |
| 315 | 315 | TTM_description text, |
| 316 | 316 | TTM_file varchar(45), |
| 317 | 317 | PRIMARY KEY (TTM_ID)"; |
| 318 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 319 | - $table_name = "esp_price"; |
|
| 320 | - $sql = "PRC_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 318 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 319 | + $table_name = "esp_price"; |
|
| 320 | + $sql = "PRC_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 321 | 321 | PRT_ID tinyint(3) unsigned NOT NULL, |
| 322 | 322 | PRC_amount decimal(10,3) NOT NULL DEFAULT '0.00', |
| 323 | 323 | PRC_name varchar(245) NOT NULL, |
@@ -328,9 +328,9 @@ discard block |
||
| 328 | 328 | PRC_order tinyint(3) unsigned NOT NULL DEFAULT '0', |
| 329 | 329 | PRC_parent int(10) unsigned DEFAULT 0, |
| 330 | 330 | PRIMARY KEY (PRC_ID)"; |
| 331 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 332 | - $table_name = "esp_price_type"; |
|
| 333 | - $sql = "PRT_ID tinyint(3) unsigned NOT NULL AUTO_INCREMENT, |
|
| 331 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 332 | + $table_name = "esp_price_type"; |
|
| 333 | + $sql = "PRT_ID tinyint(3) unsigned NOT NULL AUTO_INCREMENT, |
|
| 334 | 334 | PRT_name varchar(45) NOT NULL, |
| 335 | 335 | PBT_ID tinyint(3) unsigned NOT NULL DEFAULT '1', |
| 336 | 336 | PRT_is_percent tinyint(1) NOT NULL DEFAULT '0', |
@@ -338,9 +338,9 @@ discard block |
||
| 338 | 338 | PRT_deleted tinyint(1) NOT NULL DEFAULT '0', |
| 339 | 339 | UNIQUE KEY PRT_name_UNIQUE (PRT_name), |
| 340 | 340 | PRIMARY KEY (PRT_ID)"; |
| 341 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 342 | - $table_name = 'esp_question'; |
|
| 343 | - $sql = 'QST_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 341 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 342 | + $table_name = 'esp_question'; |
|
| 343 | + $sql = 'QST_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 344 | 344 | QST_display_text text NOT NULL, |
| 345 | 345 | QST_admin_label varchar(255) NOT NULL, |
| 346 | 346 | QST_system varchar(25) DEFAULT NULL, |
@@ -352,10 +352,10 @@ discard block |
||
| 352 | 352 | QST_wp_user bigint(20) unsigned NULL, |
| 353 | 353 | QST_deleted tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 354 | 354 | PRIMARY KEY (QST_ID)'; |
| 355 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 356 | - $this->_get_table_manager()->dropIndex('esp_question_group', 'QSG_identifier_UNIQUE'); |
|
| 357 | - $table_name = 'esp_question_group'; |
|
| 358 | - $sql = 'QSG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 355 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 356 | + $this->_get_table_manager()->dropIndex('esp_question_group', 'QSG_identifier_UNIQUE'); |
|
| 357 | + $table_name = 'esp_question_group'; |
|
| 358 | + $sql = 'QSG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 359 | 359 | QSG_name varchar(255) NOT NULL, |
| 360 | 360 | QSG_identifier varchar(100) NOT NULL, |
| 361 | 361 | QSG_desc text NULL, |
@@ -366,23 +366,23 @@ discard block |
||
| 366 | 366 | QSG_deleted tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 367 | 367 | PRIMARY KEY (QSG_ID), |
| 368 | 368 | UNIQUE KEY QSG_identifier_UNIQUE (QSG_identifier ASC)'; |
| 369 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 370 | - $table_name = 'esp_question_group_question'; |
|
| 371 | - $sql = "QGQ_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 369 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 370 | + $table_name = 'esp_question_group_question'; |
|
| 371 | + $sql = "QGQ_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 372 | 372 | QSG_ID int(10) unsigned NOT NULL, |
| 373 | 373 | QST_ID int(10) unsigned NOT NULL, |
| 374 | 374 | PRIMARY KEY (QGQ_ID) "; |
| 375 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 376 | - $table_name = 'esp_question_option'; |
|
| 377 | - $sql = "QSO_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 375 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 376 | + $table_name = 'esp_question_option'; |
|
| 377 | + $sql = "QSO_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 378 | 378 | QSO_value varchar(255) NOT NULL, |
| 379 | 379 | QSO_desc text NOT NULL, |
| 380 | 380 | QST_ID int(10) unsigned NOT NULL, |
| 381 | 381 | QSO_deleted tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 382 | 382 | PRIMARY KEY (QSO_ID)"; |
| 383 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 384 | - $table_name = 'esp_registration'; |
|
| 385 | - $sql = "REG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 383 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 384 | + $table_name = 'esp_registration'; |
|
| 385 | + $sql = "REG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 386 | 386 | EVT_ID bigint(20) unsigned NOT NULL, |
| 387 | 387 | ATT_ID bigint(20) unsigned NOT NULL, |
| 388 | 388 | TXN_ID int(10) unsigned NOT NULL, |
@@ -405,25 +405,25 @@ discard block |
||
| 405 | 405 | KEY STS_ID (STS_ID), |
| 406 | 406 | KEY REG_url_link (REG_url_link), |
| 407 | 407 | KEY REG_code (REG_code)"; |
| 408 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 409 | - $table_name = 'esp_checkin'; |
|
| 410 | - $sql = "CHK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 408 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 409 | + $table_name = 'esp_checkin'; |
|
| 410 | + $sql = "CHK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 411 | 411 | REG_ID int(10) unsigned NOT NULL, |
| 412 | 412 | DTT_ID int(10) unsigned NOT NULL, |
| 413 | 413 | CHK_in tinyint(1) unsigned NOT NULL DEFAULT 1, |
| 414 | 414 | CHK_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
| 415 | 415 | PRIMARY KEY (CHK_ID)"; |
| 416 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 417 | - $table_name = 'esp_state'; |
|
| 418 | - $sql = "STA_ID smallint(5) unsigned NOT NULL AUTO_INCREMENT, |
|
| 416 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 417 | + $table_name = 'esp_state'; |
|
| 418 | + $sql = "STA_ID smallint(5) unsigned NOT NULL AUTO_INCREMENT, |
|
| 419 | 419 | CNT_ISO varchar(2) COLLATE utf8_bin NOT NULL, |
| 420 | 420 | STA_abbrev varchar(6) COLLATE utf8_bin NOT NULL, |
| 421 | 421 | STA_name varchar(100) COLLATE utf8_bin NOT NULL, |
| 422 | 422 | STA_active tinyint(1) DEFAULT '1', |
| 423 | 423 | PRIMARY KEY (STA_ID)"; |
| 424 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 425 | - $table_name = 'esp_status'; |
|
| 426 | - $sql = "STS_ID varchar(3) COLLATE utf8_bin NOT NULL, |
|
| 424 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 425 | + $table_name = 'esp_status'; |
|
| 426 | + $sql = "STS_ID varchar(3) COLLATE utf8_bin NOT NULL, |
|
| 427 | 427 | STS_code varchar(45) COLLATE utf8_bin NOT NULL, |
| 428 | 428 | STS_type set('event','registration','transaction','payment','email') COLLATE utf8_bin NOT NULL, |
| 429 | 429 | STS_can_edit tinyint(1) NOT NULL DEFAULT 0, |
@@ -431,9 +431,9 @@ discard block |
||
| 431 | 431 | STS_open tinyint(1) NOT NULL DEFAULT 1, |
| 432 | 432 | UNIQUE KEY STS_ID_UNIQUE (STS_ID), |
| 433 | 433 | KEY STS_type (STS_type)"; |
| 434 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 435 | - $table_name = 'esp_transaction'; |
|
| 436 | - $sql = "TXN_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 434 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 435 | + $table_name = 'esp_transaction'; |
|
| 436 | + $sql = "TXN_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 437 | 437 | TXN_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
| 438 | 438 | TXN_total decimal(10,3) DEFAULT '0.00', |
| 439 | 439 | TXN_paid decimal(10,3) NOT NULL DEFAULT '0.00', |
@@ -443,9 +443,9 @@ discard block |
||
| 443 | 443 | PRIMARY KEY (TXN_ID), |
| 444 | 444 | KEY TXN_timestamp (TXN_timestamp), |
| 445 | 445 | KEY STS_ID (STS_ID)"; |
| 446 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 447 | - $table_name = 'esp_venue_meta'; |
|
| 448 | - $sql = "VNUM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 446 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 447 | + $table_name = 'esp_venue_meta'; |
|
| 448 | + $sql = "VNUM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 449 | 449 | VNU_ID bigint(20) unsigned NOT NULL DEFAULT 0, |
| 450 | 450 | VNU_address varchar(255) DEFAULT NULL, |
| 451 | 451 | VNU_address2 varchar(255) DEFAULT NULL, |
@@ -463,52 +463,52 @@ discard block |
||
| 463 | 463 | PRIMARY KEY (VNUM_ID), |
| 464 | 464 | KEY STA_ID (STA_ID), |
| 465 | 465 | KEY CNT_ISO (CNT_ISO)"; |
| 466 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 467 | - // setting up the default stats and countries is also essential for the data migrations to run |
|
| 468 | - // (because many need to convert old string states to foreign keys into the states table) |
|
| 469 | - $this->insert_default_states(); |
|
| 470 | - $this->insert_default_countries(); |
|
| 471 | - // setting up default prices, price types, and tickets is also essential for the price migrations |
|
| 472 | - $this->insert_default_price_types(); |
|
| 473 | - $this->insert_default_prices(); |
|
| 474 | - $this->insert_default_tickets(); |
|
| 475 | - // setting up the config wp option pretty well counts as a 'schema change', or at least should happen ehre |
|
| 476 | - EE_Config::instance()->update_espresso_config(false, true); |
|
| 477 | - return true; |
|
| 478 | - } |
|
| 479 | - |
|
| 480 | - |
|
| 481 | - |
|
| 482 | - /** |
|
| 483 | - * Yes we could have cleaned up the ee3 tables here. But just in case someone |
|
| 484 | - * didn't backup their DB, and decides they want ot keep using EE3, we'll |
|
| 485 | - * leave them for now. Mayeb remove them in 4.5 or something. |
|
| 486 | - * |
|
| 487 | - * @return boolean |
|
| 488 | - */ |
|
| 489 | - public function schema_changes_after_migration() |
|
| 490 | - { |
|
| 491 | - return true; |
|
| 492 | - } |
|
| 493 | - |
|
| 494 | - |
|
| 495 | - |
|
| 496 | - /** |
|
| 497 | - * insert_default_states |
|
| 498 | - * |
|
| 499 | - * @access public |
|
| 500 | - * @static |
|
| 501 | - * @return void |
|
| 502 | - */ |
|
| 503 | - public function insert_default_states() |
|
| 504 | - { |
|
| 505 | - global $wpdb; |
|
| 506 | - $state_table = $wpdb->prefix . "esp_state"; |
|
| 507 | - if ($this->_get_table_analysis()->tableExists($state_table)) { |
|
| 508 | - $SQL = "SELECT COUNT('STA_ID') FROM " . $state_table; |
|
| 509 | - $states = $wpdb->get_var($SQL); |
|
| 510 | - if (! $states) { |
|
| 511 | - $SQL = "INSERT INTO " . $state_table . " |
|
| 466 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 467 | + // setting up the default stats and countries is also essential for the data migrations to run |
|
| 468 | + // (because many need to convert old string states to foreign keys into the states table) |
|
| 469 | + $this->insert_default_states(); |
|
| 470 | + $this->insert_default_countries(); |
|
| 471 | + // setting up default prices, price types, and tickets is also essential for the price migrations |
|
| 472 | + $this->insert_default_price_types(); |
|
| 473 | + $this->insert_default_prices(); |
|
| 474 | + $this->insert_default_tickets(); |
|
| 475 | + // setting up the config wp option pretty well counts as a 'schema change', or at least should happen ehre |
|
| 476 | + EE_Config::instance()->update_espresso_config(false, true); |
|
| 477 | + return true; |
|
| 478 | + } |
|
| 479 | + |
|
| 480 | + |
|
| 481 | + |
|
| 482 | + /** |
|
| 483 | + * Yes we could have cleaned up the ee3 tables here. But just in case someone |
|
| 484 | + * didn't backup their DB, and decides they want ot keep using EE3, we'll |
|
| 485 | + * leave them for now. Mayeb remove them in 4.5 or something. |
|
| 486 | + * |
|
| 487 | + * @return boolean |
|
| 488 | + */ |
|
| 489 | + public function schema_changes_after_migration() |
|
| 490 | + { |
|
| 491 | + return true; |
|
| 492 | + } |
|
| 493 | + |
|
| 494 | + |
|
| 495 | + |
|
| 496 | + /** |
|
| 497 | + * insert_default_states |
|
| 498 | + * |
|
| 499 | + * @access public |
|
| 500 | + * @static |
|
| 501 | + * @return void |
|
| 502 | + */ |
|
| 503 | + public function insert_default_states() |
|
| 504 | + { |
|
| 505 | + global $wpdb; |
|
| 506 | + $state_table = $wpdb->prefix . "esp_state"; |
|
| 507 | + if ($this->_get_table_analysis()->tableExists($state_table)) { |
|
| 508 | + $SQL = "SELECT COUNT('STA_ID') FROM " . $state_table; |
|
| 509 | + $states = $wpdb->get_var($SQL); |
|
| 510 | + if (! $states) { |
|
| 511 | + $SQL = "INSERT INTO " . $state_table . " |
|
| 512 | 512 | (STA_ID, CNT_ISO, STA_abbrev, STA_name, STA_active) VALUES |
| 513 | 513 | (1, 'US', 'AK', 'Alaska', 1), |
| 514 | 514 | (2, 'US', 'AL', 'Alabama', 1), |
@@ -579,29 +579,29 @@ discard block |
||
| 579 | 579 | (67, 'CA', 'PE', 'Prince Edward Island', 1), |
| 580 | 580 | (68, 'CA', 'QC', 'Quebec', 1), |
| 581 | 581 | (69, 'CA', 'SK', 'Saskatchewan', 1);"; |
| 582 | - $wpdb->query($SQL); |
|
| 583 | - } |
|
| 584 | - } |
|
| 585 | - } |
|
| 586 | - |
|
| 587 | - |
|
| 588 | - |
|
| 589 | - /** |
|
| 590 | - * insert_default_countries |
|
| 591 | - * |
|
| 592 | - * @access public |
|
| 593 | - * @static |
|
| 594 | - * @return void |
|
| 595 | - */ |
|
| 596 | - public function insert_default_countries() |
|
| 597 | - { |
|
| 598 | - global $wpdb; |
|
| 599 | - $country_table = $wpdb->prefix . "esp_country"; |
|
| 600 | - if ($this->_get_table_analysis()->tableExists($country_table)) { |
|
| 601 | - $SQL = "SELECT COUNT('CNT_ISO') FROM " . $country_table; |
|
| 602 | - $countries = $wpdb->get_var($SQL); |
|
| 603 | - if (! $countries) { |
|
| 604 | - $SQL = "INSERT INTO " . $country_table . " |
|
| 582 | + $wpdb->query($SQL); |
|
| 583 | + } |
|
| 584 | + } |
|
| 585 | + } |
|
| 586 | + |
|
| 587 | + |
|
| 588 | + |
|
| 589 | + /** |
|
| 590 | + * insert_default_countries |
|
| 591 | + * |
|
| 592 | + * @access public |
|
| 593 | + * @static |
|
| 594 | + * @return void |
|
| 595 | + */ |
|
| 596 | + public function insert_default_countries() |
|
| 597 | + { |
|
| 598 | + global $wpdb; |
|
| 599 | + $country_table = $wpdb->prefix . "esp_country"; |
|
| 600 | + if ($this->_get_table_analysis()->tableExists($country_table)) { |
|
| 601 | + $SQL = "SELECT COUNT('CNT_ISO') FROM " . $country_table; |
|
| 602 | + $countries = $wpdb->get_var($SQL); |
|
| 603 | + if (! $countries) { |
|
| 604 | + $SQL = "INSERT INTO " . $country_table . " |
|
| 605 | 605 | (CNT_ISO, CNT_ISO3, RGN_ID, CNT_name, CNT_cur_code, CNT_cur_single, CNT_cur_plural, CNT_cur_sign, CNT_cur_sign_b4, CNT_cur_dec_plc, CNT_tel_code, CNT_is_EU, CNT_active) VALUES |
| 606 | 606 | ('AD', 'AND', 0, 'Andorra', 'EUR', 'Euro', 'Euros', '€', 1, 2, '+376', 0, 0), |
| 607 | 607 | ('AE', 'ARE', 0, 'United Arab Emirates', 'AED', 'Dirham', 'Dirhams', 'د.إ', 1, 2, '+971', 0, 0), |
@@ -829,984 +829,984 @@ discard block |
||
| 829 | 829 | ('ZA', 'ZAF', 0, 'South Africa', 'ZAR', 'Rand', 'Rands', 'R', 1, 2, '+27', 0, 0), |
| 830 | 830 | ('ZM', 'ZMB', 0, 'Zambia', 'ZMK', 'Kwacha', 'Kwachas', '', 1, 2, '+260', 0, 0), |
| 831 | 831 | ('ZW', 'ZWE', 0, 'Zimbabwe', 'ZWD', 'Dollar', 'Dollars', 'Z$', 1, 2, '+263', 0, 0);"; |
| 832 | - $wpdb->query($SQL); |
|
| 833 | - } |
|
| 834 | - } |
|
| 835 | - } |
|
| 836 | - |
|
| 837 | - |
|
| 838 | - |
|
| 839 | - /** |
|
| 840 | - * insert_default_price_types |
|
| 841 | - * |
|
| 842 | - * @access public |
|
| 843 | - * @static |
|
| 844 | - * @return void |
|
| 845 | - */ |
|
| 846 | - public function insert_default_price_types() |
|
| 847 | - { |
|
| 848 | - global $wpdb; |
|
| 849 | - $price_type_table = $wpdb->prefix . "esp_price_type"; |
|
| 850 | - if ($this->_get_table_analysis()->tableExists($price_type_table)) { |
|
| 851 | - $SQL = 'SELECT COUNT(PRT_ID) FROM ' . $price_type_table; |
|
| 852 | - $price_types_exist = $wpdb->get_var($SQL); |
|
| 853 | - if (! $price_types_exist) { |
|
| 854 | - $SQL = "INSERT INTO $price_type_table ( PRT_ID, PRT_name, PBT_ID, PRT_is_percent, PRT_order, PRT_deleted ) VALUES |
|
| 832 | + $wpdb->query($SQL); |
|
| 833 | + } |
|
| 834 | + } |
|
| 835 | + } |
|
| 836 | + |
|
| 837 | + |
|
| 838 | + |
|
| 839 | + /** |
|
| 840 | + * insert_default_price_types |
|
| 841 | + * |
|
| 842 | + * @access public |
|
| 843 | + * @static |
|
| 844 | + * @return void |
|
| 845 | + */ |
|
| 846 | + public function insert_default_price_types() |
|
| 847 | + { |
|
| 848 | + global $wpdb; |
|
| 849 | + $price_type_table = $wpdb->prefix . "esp_price_type"; |
|
| 850 | + if ($this->_get_table_analysis()->tableExists($price_type_table)) { |
|
| 851 | + $SQL = 'SELECT COUNT(PRT_ID) FROM ' . $price_type_table; |
|
| 852 | + $price_types_exist = $wpdb->get_var($SQL); |
|
| 853 | + if (! $price_types_exist) { |
|
| 854 | + $SQL = "INSERT INTO $price_type_table ( PRT_ID, PRT_name, PBT_ID, PRT_is_percent, PRT_order, PRT_deleted ) VALUES |
|
| 855 | 855 | (1, '" . esc_html__('Base Price', 'event_espresso') . "', 1, 0, 0, 0), |
| 856 | 856 | (2, '" . esc_html__('Percent Discount', 'event_espresso') . "', 2, 1, 20, 0), |
| 857 | 857 | (3, '" . esc_html__('Fixed Discount', 'event_espresso') . "', 2, 0, 30, 0), |
| 858 | 858 | (4, '" . esc_html__('Percent Surcharge', 'event_espresso') . "', 3, 1, 40, 0), |
| 859 | 859 | (5, '" . esc_html__('Fixed Surcharge', 'event_espresso') . "', 3, 0, 50, 0);"; |
| 860 | - $SQL = apply_filters('FHEE__EE_DMS_4_1_0__insert_default_price_types__SQL', $SQL); |
|
| 861 | - $wpdb->query($SQL); |
|
| 862 | - } |
|
| 863 | - } |
|
| 864 | - } |
|
| 865 | - |
|
| 866 | - |
|
| 867 | - |
|
| 868 | - /** |
|
| 869 | - * insert_default_prices. We assume we're upgrading to regular here. |
|
| 870 | - * If we're INSTALLING 4.1 CAF, then we add a few extra default prices |
|
| 871 | - * when EEH_Activaion's initialize_db_content is called via ahook in |
|
| 872 | - * EE_BRewing_regular |
|
| 873 | - * |
|
| 874 | - * @access public |
|
| 875 | - * @static |
|
| 876 | - * @return void |
|
| 877 | - */ |
|
| 878 | - public function insert_default_prices() |
|
| 879 | - { |
|
| 880 | - global $wpdb; |
|
| 881 | - $price_table = $wpdb->prefix . "esp_price"; |
|
| 882 | - if ($this->_get_table_analysis()->tableExists($price_table)) { |
|
| 883 | - $SQL = 'SELECT COUNT(PRC_ID) FROM ' . $price_table; |
|
| 884 | - $prices_exist = $wpdb->get_var($SQL); |
|
| 885 | - if (! $prices_exist) { |
|
| 886 | - $SQL = "INSERT INTO $price_table |
|
| 860 | + $SQL = apply_filters('FHEE__EE_DMS_4_1_0__insert_default_price_types__SQL', $SQL); |
|
| 861 | + $wpdb->query($SQL); |
|
| 862 | + } |
|
| 863 | + } |
|
| 864 | + } |
|
| 865 | + |
|
| 866 | + |
|
| 867 | + |
|
| 868 | + /** |
|
| 869 | + * insert_default_prices. We assume we're upgrading to regular here. |
|
| 870 | + * If we're INSTALLING 4.1 CAF, then we add a few extra default prices |
|
| 871 | + * when EEH_Activaion's initialize_db_content is called via ahook in |
|
| 872 | + * EE_BRewing_regular |
|
| 873 | + * |
|
| 874 | + * @access public |
|
| 875 | + * @static |
|
| 876 | + * @return void |
|
| 877 | + */ |
|
| 878 | + public function insert_default_prices() |
|
| 879 | + { |
|
| 880 | + global $wpdb; |
|
| 881 | + $price_table = $wpdb->prefix . "esp_price"; |
|
| 882 | + if ($this->_get_table_analysis()->tableExists($price_table)) { |
|
| 883 | + $SQL = 'SELECT COUNT(PRC_ID) FROM ' . $price_table; |
|
| 884 | + $prices_exist = $wpdb->get_var($SQL); |
|
| 885 | + if (! $prices_exist) { |
|
| 886 | + $SQL = "INSERT INTO $price_table |
|
| 887 | 887 | (PRC_ID, PRT_ID, PRC_amount, PRC_name, PRC_desc, PRC_is_default, PRC_overrides, PRC_order, PRC_deleted, PRC_parent ) VALUES |
| 888 | 888 | (1, 1, '0.00', 'Free Admission', '', 1, null, 0, 0, 0);"; |
| 889 | - $SQL = apply_filters('FHEE__EE_DMS_4_1_0__insert_default_prices__SQL', $SQL); |
|
| 890 | - $wpdb->query($SQL); |
|
| 891 | - } |
|
| 892 | - } |
|
| 893 | - } |
|
| 894 | - |
|
| 895 | - |
|
| 896 | - |
|
| 897 | - /** |
|
| 898 | - * insert default ticket |
|
| 899 | - * |
|
| 900 | - * @access public |
|
| 901 | - * @static |
|
| 902 | - * @return void |
|
| 903 | - */ |
|
| 904 | - public function insert_default_tickets() |
|
| 905 | - { |
|
| 906 | - global $wpdb; |
|
| 907 | - $ticket_table = $wpdb->prefix . "esp_ticket"; |
|
| 908 | - if ($this->_get_table_analysis()->tableExists($ticket_table)) { |
|
| 909 | - $SQL = 'SELECT COUNT(TKT_ID) FROM ' . $ticket_table; |
|
| 910 | - $tickets_exist = $wpdb->get_var($SQL); |
|
| 911 | - if (! $tickets_exist) { |
|
| 912 | - $SQL = "INSERT INTO $ticket_table |
|
| 889 | + $SQL = apply_filters('FHEE__EE_DMS_4_1_0__insert_default_prices__SQL', $SQL); |
|
| 890 | + $wpdb->query($SQL); |
|
| 891 | + } |
|
| 892 | + } |
|
| 893 | + } |
|
| 894 | + |
|
| 895 | + |
|
| 896 | + |
|
| 897 | + /** |
|
| 898 | + * insert default ticket |
|
| 899 | + * |
|
| 900 | + * @access public |
|
| 901 | + * @static |
|
| 902 | + * @return void |
|
| 903 | + */ |
|
| 904 | + public function insert_default_tickets() |
|
| 905 | + { |
|
| 906 | + global $wpdb; |
|
| 907 | + $ticket_table = $wpdb->prefix . "esp_ticket"; |
|
| 908 | + if ($this->_get_table_analysis()->tableExists($ticket_table)) { |
|
| 909 | + $SQL = 'SELECT COUNT(TKT_ID) FROM ' . $ticket_table; |
|
| 910 | + $tickets_exist = $wpdb->get_var($SQL); |
|
| 911 | + if (! $tickets_exist) { |
|
| 912 | + $SQL = "INSERT INTO $ticket_table |
|
| 913 | 913 | ( TKT_ID, TTM_ID, TKT_name, TKT_description, TKT_qty, TKT_sold, TKT_uses, TKT_min, TKT_max, TKT_price, TKT_start_date, TKT_end_date, TKT_taxable, TKT_order, TKT_row, TKT_is_default, TKT_parent, TKT_deleted ) VALUES |
| 914 | 914 | ( 1, 0, '" |
| 915 | - . esc_html__("Free Ticket", "event_espresso") |
|
| 916 | - . "', '', 100, 0, -1, 0, -1, 0.00, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 0, 0, 1, 1, 0, 0);"; |
|
| 917 | - $SQL = apply_filters('FHEE__EE_DMS_4_1_0__insert_default_tickets__SQL', $SQL); |
|
| 918 | - $wpdb->query($SQL); |
|
| 919 | - } |
|
| 920 | - } |
|
| 921 | - $ticket_price_table = $wpdb->prefix . "esp_ticket_price"; |
|
| 922 | - if ($this->_get_table_analysis()->tableExists($ticket_price_table)) { |
|
| 923 | - $SQL = 'SELECT COUNT(TKP_ID) FROM ' . $ticket_price_table; |
|
| 924 | - $ticket_prc_exist = $wpdb->get_var($SQL); |
|
| 925 | - if (! $ticket_prc_exist) { |
|
| 926 | - $SQL = "INSERT INTO $ticket_price_table |
|
| 915 | + . esc_html__("Free Ticket", "event_espresso") |
|
| 916 | + . "', '', 100, 0, -1, 0, -1, 0.00, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 0, 0, 1, 1, 0, 0);"; |
|
| 917 | + $SQL = apply_filters('FHEE__EE_DMS_4_1_0__insert_default_tickets__SQL', $SQL); |
|
| 918 | + $wpdb->query($SQL); |
|
| 919 | + } |
|
| 920 | + } |
|
| 921 | + $ticket_price_table = $wpdb->prefix . "esp_ticket_price"; |
|
| 922 | + if ($this->_get_table_analysis()->tableExists($ticket_price_table)) { |
|
| 923 | + $SQL = 'SELECT COUNT(TKP_ID) FROM ' . $ticket_price_table; |
|
| 924 | + $ticket_prc_exist = $wpdb->get_var($SQL); |
|
| 925 | + if (! $ticket_prc_exist) { |
|
| 926 | + $SQL = "INSERT INTO $ticket_price_table |
|
| 927 | 927 | ( TKP_ID, TKT_ID, PRC_ID ) VALUES |
| 928 | 928 | ( 1, 1, 1 ) |
| 929 | 929 | "; |
| 930 | - $SQL = apply_filters('FHEE__EE_DMS_4_1_0__insert_default_tickets__SQL__ticket_price', $SQL); |
|
| 931 | - $wpdb->query($SQL); |
|
| 932 | - } |
|
| 933 | - } |
|
| 934 | - } |
|
| 935 | - |
|
| 936 | - |
|
| 937 | - |
|
| 938 | - /** |
|
| 939 | - * Gets a country entry as an array, or creates one if none is found. Much like EEM_Country::instance()->get_one(), |
|
| 940 | - * but is independent of outside code which can change in future versions of EE. Also, $country_name CAN be a 3.1 |
|
| 941 | - * country ID (int), a 2-letter ISO, 3-letter ISO, or name |
|
| 942 | - * |
|
| 943 | - * @global type $wpdb |
|
| 944 | - * @param string $country_name |
|
| 945 | - * @return array where keys are columns, values are column values |
|
| 946 | - */ |
|
| 947 | - public function get_or_create_country($country_name) |
|
| 948 | - { |
|
| 949 | - if (! $country_name) { |
|
| 950 | - throw new EE_Error(esc_html__("Could not get a country because country name is blank", "event_espresso")); |
|
| 951 | - } |
|
| 952 | - global $wpdb; |
|
| 953 | - $country_table = $wpdb->prefix . "esp_country"; |
|
| 954 | - if (is_int($country_name)) { |
|
| 955 | - $country_name = $this->get_iso_from_3_1_country_id($country_name); |
|
| 956 | - } |
|
| 957 | - $country = $wpdb->get_row($wpdb->prepare("SELECT * FROM $country_table WHERE |
|
| 930 | + $SQL = apply_filters('FHEE__EE_DMS_4_1_0__insert_default_tickets__SQL__ticket_price', $SQL); |
|
| 931 | + $wpdb->query($SQL); |
|
| 932 | + } |
|
| 933 | + } |
|
| 934 | + } |
|
| 935 | + |
|
| 936 | + |
|
| 937 | + |
|
| 938 | + /** |
|
| 939 | + * Gets a country entry as an array, or creates one if none is found. Much like EEM_Country::instance()->get_one(), |
|
| 940 | + * but is independent of outside code which can change in future versions of EE. Also, $country_name CAN be a 3.1 |
|
| 941 | + * country ID (int), a 2-letter ISO, 3-letter ISO, or name |
|
| 942 | + * |
|
| 943 | + * @global type $wpdb |
|
| 944 | + * @param string $country_name |
|
| 945 | + * @return array where keys are columns, values are column values |
|
| 946 | + */ |
|
| 947 | + public function get_or_create_country($country_name) |
|
| 948 | + { |
|
| 949 | + if (! $country_name) { |
|
| 950 | + throw new EE_Error(esc_html__("Could not get a country because country name is blank", "event_espresso")); |
|
| 951 | + } |
|
| 952 | + global $wpdb; |
|
| 953 | + $country_table = $wpdb->prefix . "esp_country"; |
|
| 954 | + if (is_int($country_name)) { |
|
| 955 | + $country_name = $this->get_iso_from_3_1_country_id($country_name); |
|
| 956 | + } |
|
| 957 | + $country = $wpdb->get_row($wpdb->prepare("SELECT * FROM $country_table WHERE |
|
| 958 | 958 | CNT_ISO LIKE %s OR |
| 959 | 959 | CNT_ISO3 LIKE %s OR |
| 960 | 960 | CNT_name LIKE %s LIMIT 1", $country_name, $country_name, $country_name), ARRAY_A); |
| 961 | - if (! $country) { |
|
| 962 | - // insert a new one then |
|
| 963 | - $cols_n_values = array( |
|
| 964 | - 'CNT_ISO' => $this->_find_available_country_iso(2), |
|
| 965 | - 'CNT_ISO3' => $this->_find_available_country_iso(3), |
|
| 966 | - 'RGN_ID' => 0, |
|
| 967 | - 'CNT_name' => $country_name, |
|
| 968 | - 'CNT_cur_code' => 'USD', |
|
| 969 | - 'CNT_cur_single' => 'Dollar', |
|
| 970 | - 'CNT_cur_plural' => 'Dollars', |
|
| 971 | - 'CNT_cur_sign' => '$', |
|
| 972 | - 'CNT_cur_sign_b4' => true, |
|
| 973 | - 'CNT_cur_dec_plc' => 2, |
|
| 974 | - 'CNT_cur_dec_mrk' => '.', |
|
| 975 | - 'CNT_cur_thsnds' => ',', |
|
| 976 | - 'CNT_tel_code' => '+1', |
|
| 977 | - 'CNT_is_EU' => false, |
|
| 978 | - 'CNT_active' => true, |
|
| 979 | - ); |
|
| 980 | - $data_types = array( |
|
| 981 | - '%s',// CNT_ISO |
|
| 982 | - '%s',// CNT_ISO3 |
|
| 983 | - '%d',// RGN_ID |
|
| 984 | - '%s',// CNT_name |
|
| 985 | - '%s',// CNT_cur_code |
|
| 986 | - '%s',// CNT_cur_single |
|
| 987 | - '%s',// CNT_cur_plural |
|
| 988 | - '%s',// CNT_cur_sign |
|
| 989 | - '%d',// CNT_cur_sign_b4 |
|
| 990 | - '%d',// CNT_cur_dec_plc |
|
| 991 | - '%s',// CNT_cur_dec_mrk |
|
| 992 | - '%s',// CNT_cur_thsnds |
|
| 993 | - '%s',// CNT_tel_code |
|
| 994 | - '%d',// CNT_is_EU |
|
| 995 | - '%d',// CNT_active |
|
| 996 | - ); |
|
| 997 | - $success = $wpdb->insert( |
|
| 998 | - $country_table, |
|
| 999 | - $cols_n_values, |
|
| 1000 | - $data_types |
|
| 1001 | - ); |
|
| 1002 | - if (! $success) { |
|
| 1003 | - throw new EE_Error($this->_create_error_message_for_db_insertion( |
|
| 1004 | - 'N/A', |
|
| 1005 | - array('country_id' => $country_name), |
|
| 1006 | - $country_table, |
|
| 1007 | - $cols_n_values, |
|
| 1008 | - $data_types |
|
| 1009 | - )); |
|
| 1010 | - } |
|
| 1011 | - $country = $cols_n_values; |
|
| 1012 | - } |
|
| 1013 | - return $country; |
|
| 1014 | - } |
|
| 1015 | - |
|
| 1016 | - |
|
| 1017 | - |
|
| 1018 | - /** |
|
| 1019 | - * finds a country iso which hasnt been used yet |
|
| 1020 | - * |
|
| 1021 | - * @global type $wpdb |
|
| 1022 | - * @return string |
|
| 1023 | - */ |
|
| 1024 | - private function _find_available_country_iso($num_letters = 2) |
|
| 1025 | - { |
|
| 1026 | - global $wpdb; |
|
| 1027 | - $country_table = $wpdb->prefix . "esp_country"; |
|
| 1028 | - $attempts = 0; |
|
| 1029 | - do { |
|
| 1030 | - $current_iso = strtoupper(wp_generate_password($num_letters, false)); |
|
| 1031 | - $country_with_that_iso = $wpdb->get_var($wpdb->prepare("SELECT count(CNT_ISO) FROM " |
|
| 1032 | - . $country_table |
|
| 1033 | - . " WHERE CNT_ISO=%s", $current_iso)); |
|
| 1034 | - $attempts++; |
|
| 1035 | - // keep going until we find an available country code, or we arbitrarily |
|
| 1036 | - // decide we've tried this enough. Somehow they have way too many countries |
|
| 1037 | - // (probably because they're mis-using the EE3 country_id like a custom question) |
|
| 1038 | - } while (intval($country_with_that_iso) && $attempts < 200); |
|
| 1039 | - return $current_iso; |
|
| 1040 | - } |
|
| 1041 | - |
|
| 1042 | - |
|
| 1043 | - |
|
| 1044 | - /** |
|
| 1045 | - * Gets a state entry as an array, or creates one if none is found. Much like EEM_State::instance()->get_one(), but |
|
| 1046 | - * is independent of outside code which can change in future versions of EE |
|
| 1047 | - * |
|
| 1048 | - * @global type $wpdb |
|
| 1049 | - * @param string $state_name |
|
| 1050 | - * @return array where keys are columns, values are column values |
|
| 1051 | - */ |
|
| 1052 | - public function get_or_create_state($state_name, $country_name = '') |
|
| 1053 | - { |
|
| 1054 | - if (! $state_name) { |
|
| 1055 | - throw new EE_Error(esc_html__( |
|
| 1056 | - "Could not get-or-create state because no state name was provided", |
|
| 1057 | - "event_espresso" |
|
| 1058 | - )); |
|
| 1059 | - } |
|
| 1060 | - try { |
|
| 1061 | - $country = $this->get_or_create_country($country_name); |
|
| 1062 | - $country_iso = $country['CNT_ISO']; |
|
| 1063 | - } catch (EE_Error $e) { |
|
| 1064 | - $country_iso = $this->get_default_country_iso(); |
|
| 1065 | - } |
|
| 1066 | - global $wpdb; |
|
| 1067 | - $state_table = $wpdb->prefix . "esp_state"; |
|
| 1068 | - $state = $wpdb->get_row($wpdb->prepare("SELECT * FROM $state_table WHERE |
|
| 961 | + if (! $country) { |
|
| 962 | + // insert a new one then |
|
| 963 | + $cols_n_values = array( |
|
| 964 | + 'CNT_ISO' => $this->_find_available_country_iso(2), |
|
| 965 | + 'CNT_ISO3' => $this->_find_available_country_iso(3), |
|
| 966 | + 'RGN_ID' => 0, |
|
| 967 | + 'CNT_name' => $country_name, |
|
| 968 | + 'CNT_cur_code' => 'USD', |
|
| 969 | + 'CNT_cur_single' => 'Dollar', |
|
| 970 | + 'CNT_cur_plural' => 'Dollars', |
|
| 971 | + 'CNT_cur_sign' => '$', |
|
| 972 | + 'CNT_cur_sign_b4' => true, |
|
| 973 | + 'CNT_cur_dec_plc' => 2, |
|
| 974 | + 'CNT_cur_dec_mrk' => '.', |
|
| 975 | + 'CNT_cur_thsnds' => ',', |
|
| 976 | + 'CNT_tel_code' => '+1', |
|
| 977 | + 'CNT_is_EU' => false, |
|
| 978 | + 'CNT_active' => true, |
|
| 979 | + ); |
|
| 980 | + $data_types = array( |
|
| 981 | + '%s',// CNT_ISO |
|
| 982 | + '%s',// CNT_ISO3 |
|
| 983 | + '%d',// RGN_ID |
|
| 984 | + '%s',// CNT_name |
|
| 985 | + '%s',// CNT_cur_code |
|
| 986 | + '%s',// CNT_cur_single |
|
| 987 | + '%s',// CNT_cur_plural |
|
| 988 | + '%s',// CNT_cur_sign |
|
| 989 | + '%d',// CNT_cur_sign_b4 |
|
| 990 | + '%d',// CNT_cur_dec_plc |
|
| 991 | + '%s',// CNT_cur_dec_mrk |
|
| 992 | + '%s',// CNT_cur_thsnds |
|
| 993 | + '%s',// CNT_tel_code |
|
| 994 | + '%d',// CNT_is_EU |
|
| 995 | + '%d',// CNT_active |
|
| 996 | + ); |
|
| 997 | + $success = $wpdb->insert( |
|
| 998 | + $country_table, |
|
| 999 | + $cols_n_values, |
|
| 1000 | + $data_types |
|
| 1001 | + ); |
|
| 1002 | + if (! $success) { |
|
| 1003 | + throw new EE_Error($this->_create_error_message_for_db_insertion( |
|
| 1004 | + 'N/A', |
|
| 1005 | + array('country_id' => $country_name), |
|
| 1006 | + $country_table, |
|
| 1007 | + $cols_n_values, |
|
| 1008 | + $data_types |
|
| 1009 | + )); |
|
| 1010 | + } |
|
| 1011 | + $country = $cols_n_values; |
|
| 1012 | + } |
|
| 1013 | + return $country; |
|
| 1014 | + } |
|
| 1015 | + |
|
| 1016 | + |
|
| 1017 | + |
|
| 1018 | + /** |
|
| 1019 | + * finds a country iso which hasnt been used yet |
|
| 1020 | + * |
|
| 1021 | + * @global type $wpdb |
|
| 1022 | + * @return string |
|
| 1023 | + */ |
|
| 1024 | + private function _find_available_country_iso($num_letters = 2) |
|
| 1025 | + { |
|
| 1026 | + global $wpdb; |
|
| 1027 | + $country_table = $wpdb->prefix . "esp_country"; |
|
| 1028 | + $attempts = 0; |
|
| 1029 | + do { |
|
| 1030 | + $current_iso = strtoupper(wp_generate_password($num_letters, false)); |
|
| 1031 | + $country_with_that_iso = $wpdb->get_var($wpdb->prepare("SELECT count(CNT_ISO) FROM " |
|
| 1032 | + . $country_table |
|
| 1033 | + . " WHERE CNT_ISO=%s", $current_iso)); |
|
| 1034 | + $attempts++; |
|
| 1035 | + // keep going until we find an available country code, or we arbitrarily |
|
| 1036 | + // decide we've tried this enough. Somehow they have way too many countries |
|
| 1037 | + // (probably because they're mis-using the EE3 country_id like a custom question) |
|
| 1038 | + } while (intval($country_with_that_iso) && $attempts < 200); |
|
| 1039 | + return $current_iso; |
|
| 1040 | + } |
|
| 1041 | + |
|
| 1042 | + |
|
| 1043 | + |
|
| 1044 | + /** |
|
| 1045 | + * Gets a state entry as an array, or creates one if none is found. Much like EEM_State::instance()->get_one(), but |
|
| 1046 | + * is independent of outside code which can change in future versions of EE |
|
| 1047 | + * |
|
| 1048 | + * @global type $wpdb |
|
| 1049 | + * @param string $state_name |
|
| 1050 | + * @return array where keys are columns, values are column values |
|
| 1051 | + */ |
|
| 1052 | + public function get_or_create_state($state_name, $country_name = '') |
|
| 1053 | + { |
|
| 1054 | + if (! $state_name) { |
|
| 1055 | + throw new EE_Error(esc_html__( |
|
| 1056 | + "Could not get-or-create state because no state name was provided", |
|
| 1057 | + "event_espresso" |
|
| 1058 | + )); |
|
| 1059 | + } |
|
| 1060 | + try { |
|
| 1061 | + $country = $this->get_or_create_country($country_name); |
|
| 1062 | + $country_iso = $country['CNT_ISO']; |
|
| 1063 | + } catch (EE_Error $e) { |
|
| 1064 | + $country_iso = $this->get_default_country_iso(); |
|
| 1065 | + } |
|
| 1066 | + global $wpdb; |
|
| 1067 | + $state_table = $wpdb->prefix . "esp_state"; |
|
| 1068 | + $state = $wpdb->get_row($wpdb->prepare("SELECT * FROM $state_table WHERE |
|
| 1069 | 1069 | (STA_abbrev LIKE %s OR |
| 1070 | 1070 | STA_name LIKE %s) AND |
| 1071 | 1071 | CNT_ISO LIKE %s LIMIT 1", $state_name, $state_name, $country_iso), ARRAY_A); |
| 1072 | - if (! $state) { |
|
| 1073 | - // insert a new one then |
|
| 1074 | - $cols_n_values = array( |
|
| 1075 | - 'CNT_ISO' => $country_iso, |
|
| 1076 | - 'STA_abbrev' => substr($state_name, 0, 6), |
|
| 1077 | - 'STA_name' => $state_name, |
|
| 1078 | - 'STA_active' => true, |
|
| 1079 | - ); |
|
| 1080 | - $data_types = array( |
|
| 1081 | - '%s',// CNT_ISO |
|
| 1082 | - '%s',// STA_abbrev |
|
| 1083 | - '%s',// STA_name |
|
| 1084 | - '%d',// STA_active |
|
| 1085 | - ); |
|
| 1086 | - $success = $wpdb->insert($state_table, $cols_n_values, $data_types); |
|
| 1087 | - if (! $success) { |
|
| 1088 | - throw new EE_Error($this->_create_error_message_for_db_insertion( |
|
| 1089 | - 'N/A', |
|
| 1090 | - array('state' => $state_name, 'country_id' => $country_name), |
|
| 1091 | - $state_table, |
|
| 1092 | - $cols_n_values, |
|
| 1093 | - $data_types |
|
| 1094 | - )); |
|
| 1095 | - } |
|
| 1096 | - $state = $cols_n_values; |
|
| 1097 | - $state['STA_ID'] = $wpdb->insert_id; |
|
| 1098 | - } |
|
| 1099 | - return $state; |
|
| 1100 | - } |
|
| 1101 | - |
|
| 1102 | - |
|
| 1103 | - |
|
| 1104 | - /** |
|
| 1105 | - * Fixes times like "5:00 PM" into the expected 24-hour format "17:00". |
|
| 1106 | - * THis is actually just copied from the 3.1 JSON API because it needed to do the exact same thing |
|
| 1107 | - * |
|
| 1108 | - * @param type $timeString |
|
| 1109 | - * @return string in the php DATETIME format: "G:i" (24-hour format hour with leading zeros, a colon, and minutes |
|
| 1110 | - * with leading zeros) |
|
| 1111 | - */ |
|
| 1112 | - public function convertTimeFromAMPM($timeString) |
|
| 1113 | - { |
|
| 1114 | - $matches = array(); |
|
| 1115 | - preg_match("~(\\d*):(\\d*)~", $timeString, $matches); |
|
| 1116 | - if (! $matches || count($matches) < 3) { |
|
| 1117 | - $hour = '00'; |
|
| 1118 | - $minutes = '00'; |
|
| 1119 | - } else { |
|
| 1120 | - $hour = intval($matches[1]); |
|
| 1121 | - $minutes = $matches[2]; |
|
| 1122 | - } |
|
| 1123 | - if (strpos($timeString, 'PM') || strpos($timeString, 'pm')) { |
|
| 1124 | - $hour = intval($hour) + 12; |
|
| 1125 | - } |
|
| 1126 | - $hour = str_pad("$hour", 2, '0', STR_PAD_LEFT); |
|
| 1127 | - $minutes = str_pad("$minutes", 2, '0', STR_PAD_LEFT); |
|
| 1128 | - return "$hour:$minutes"; |
|
| 1129 | - } |
|
| 1130 | - |
|
| 1131 | - |
|
| 1132 | - |
|
| 1133 | - /** |
|
| 1134 | - * Gets the ISO3 fora country given its 3.1 country ID. |
|
| 1135 | - * |
|
| 1136 | - * @param int $country_id |
|
| 1137 | - * @return string the country's ISO3 code |
|
| 1138 | - */ |
|
| 1139 | - public function get_iso_from_3_1_country_id($country_id) |
|
| 1140 | - { |
|
| 1141 | - $old_countries = array( |
|
| 1142 | - array(64, 'United States', 'US', 'USA', 1), |
|
| 1143 | - array(15, 'Australia', 'AU', 'AUS', 1), |
|
| 1144 | - array(39, 'Canada', 'CA', 'CAN', 1), |
|
| 1145 | - array(171, 'United Kingdom', 'GB', 'GBR', 1), |
|
| 1146 | - array(70, 'France', 'FR', 'FRA', 2), |
|
| 1147 | - array(111, 'Italy', 'IT', 'ITA', 2), |
|
| 1148 | - array(63, 'Spain', 'ES', 'ESP', 2), |
|
| 1149 | - array(1, 'Afghanistan', 'AF', 'AFG', 1), |
|
| 1150 | - array(2, 'Albania', 'AL', 'ALB', 1), |
|
| 1151 | - array(3, 'Germany', 'DE', 'DEU', 2), |
|
| 1152 | - array(198, 'Switzerland', 'CH', 'CHE', 1), |
|
| 1153 | - array(87, 'Netherlands', 'NL', 'NLD', 2), |
|
| 1154 | - array(197, 'Sweden', 'SE', 'SWE', 1), |
|
| 1155 | - array(230, 'Akrotiri and Dhekelia', 'CY', 'CYP', 2), |
|
| 1156 | - array(4, 'Andorra', 'AD', 'AND', 2), |
|
| 1157 | - array(5, 'Angola', 'AO', 'AGO', 1), |
|
| 1158 | - array(6, 'Anguilla', 'AI', 'AIA', 1), |
|
| 1159 | - array(7, 'Antarctica', 'AQ', 'ATA', 1), |
|
| 1160 | - array(8, 'Antigua and Barbuda', 'AG', 'ATG', 1), |
|
| 1161 | - array(10, 'Saudi Arabia', 'SA', 'SAU', 1), |
|
| 1162 | - array(11, 'Algeria', 'DZ', 'DZA', 1), |
|
| 1163 | - array(12, 'Argentina', 'AR', 'ARG', 1), |
|
| 1164 | - array(13, 'Armenia', 'AM', 'ARM', 1), |
|
| 1165 | - array(14, 'Aruba', 'AW', 'ABW', 1), |
|
| 1166 | - array(16, 'Austria', 'AT', 'AUT', 2), |
|
| 1167 | - array(17, 'Azerbaijan', 'AZ', 'AZE', 1), |
|
| 1168 | - array(18, 'Bahamas', 'BS', 'BHS', 1), |
|
| 1169 | - array(19, 'Bahrain', 'BH', 'BHR', 1), |
|
| 1170 | - array(20, 'Bangladesh', 'BD', 'BGD', 1), |
|
| 1171 | - array(21, 'Barbados', 'BB', 'BRB', 1), |
|
| 1172 | - array(22, 'Belgium ', 'BE', 'BEL', 2), |
|
| 1173 | - array(23, 'Belize', 'BZ', 'BLZ', 1), |
|
| 1174 | - array(24, 'Benin', 'BJ', 'BEN', 1), |
|
| 1175 | - array(25, 'Bermudas', 'BM', 'BMU', 1), |
|
| 1176 | - array(26, 'Belarus', 'BY', 'BLR', 1), |
|
| 1177 | - array(27, 'Bolivia', 'BO', 'BOL', 1), |
|
| 1178 | - array(28, 'Bosnia and Herzegovina', 'BA', 'BIH', 1), |
|
| 1179 | - array(29, 'Botswana', 'BW', 'BWA', 1), |
|
| 1180 | - array(96, 'Bouvet Island', 'BV', 'BVT', 1), |
|
| 1181 | - array(30, 'Brazil', 'BR', 'BRA', 1), |
|
| 1182 | - array(31, 'Brunei', 'BN', 'BRN', 1), |
|
| 1183 | - array(32, 'Bulgaria', 'BG', 'BGR', 1), |
|
| 1184 | - array(33, 'Burkina Faso', 'BF', 'BFA', 1), |
|
| 1185 | - array(34, 'Burundi', 'BI', 'BDI', 1), |
|
| 1186 | - array(35, 'Bhutan', 'BT', 'BTN', 1), |
|
| 1187 | - array(36, 'Cape Verde', 'CV', 'CPV', 1), |
|
| 1188 | - array(37, 'Cambodia', 'KH', 'KHM', 1), |
|
| 1189 | - array(38, 'Cameroon', 'CM', 'CMR', 1), |
|
| 1190 | - array(98, 'Cayman Islands', 'KY', 'CYM', 1), |
|
| 1191 | - array(172, 'Central African Republic', 'CF', 'CAF', 1), |
|
| 1192 | - array(40, 'Chad', 'TD', 'TCD', 1), |
|
| 1193 | - array(41, 'Chile', 'CL', 'CHL', 1), |
|
| 1194 | - array(42, 'China', 'CN', 'CHN', 1), |
|
| 1195 | - array(105, 'Christmas Island', 'CX', 'CXR', 1), |
|
| 1196 | - array(43, 'Cyprus', 'CY', 'CYP', 2), |
|
| 1197 | - array(99, 'Cocos Island', 'CC', 'CCK', 1), |
|
| 1198 | - array(100, 'Cook Islands', 'CK', 'COK', 1), |
|
| 1199 | - array(44, 'Colombia', 'CO', 'COL', 1), |
|
| 1200 | - array(45, 'Comoros', 'KM', 'COM', 1), |
|
| 1201 | - array(46, 'Congo', 'CG', 'COG', 1), |
|
| 1202 | - array(47, 'North Korea', 'KP', 'PRK', 1), |
|
| 1203 | - array(50, 'Costa Rica', 'CR', 'CRI', 1), |
|
| 1204 | - array(51, 'Croatia', 'HR', 'HRV', 1), |
|
| 1205 | - array(52, 'Cuba', 'CU', 'CUB', 1), |
|
| 1206 | - array(173, 'Czech Republic', 'CZ', 'CZE', 1), |
|
| 1207 | - array(53, 'Denmark', 'DK', 'DNK', 1), |
|
| 1208 | - array(54, 'Djibouti', 'DJ', 'DJI', 1), |
|
| 1209 | - array(55, 'Dominica', 'DM', 'DMA', 1), |
|
| 1210 | - array(174, 'Dominican Republic', 'DO', 'DOM', 1), |
|
| 1211 | - array(56, 'Ecuador', 'EC', 'ECU', 1), |
|
| 1212 | - array(57, 'Egypt', 'EG', 'EGY', 1), |
|
| 1213 | - array(58, 'El Salvador', 'SV', 'SLV', 1), |
|
| 1214 | - array(60, 'Eritrea', 'ER', 'ERI', 1), |
|
| 1215 | - array(61, 'Slovakia', 'SK', 'SVK', 2), |
|
| 1216 | - array(62, 'Slovenia', 'SI', 'SVN', 2), |
|
| 1217 | - array(65, 'Estonia', 'EE', 'EST', 2), |
|
| 1218 | - array(66, 'Ethiopia', 'ET', 'ETH', 1), |
|
| 1219 | - array(102, 'Faroe islands', 'FO', 'FRO', 1), |
|
| 1220 | - array(103, 'Falkland Islands', 'FK', 'FLK', 1), |
|
| 1221 | - array(67, 'Fiji', 'FJ', 'FJI', 1), |
|
| 1222 | - array(69, 'Finland', 'FI', 'FIN', 2), |
|
| 1223 | - array(71, 'Gabon', 'GA', 'GAB', 1), |
|
| 1224 | - array(72, 'Gambia', 'GM', 'GMB', 1), |
|
| 1225 | - array(73, 'Georgia', 'GE', 'GEO', 1), |
|
| 1226 | - array(74, 'Ghana', 'GH', 'GHA', 1), |
|
| 1227 | - array(75, 'Gibraltar', 'GI', 'GIB', 1), |
|
| 1228 | - array(76, 'Greece', 'GR', 'GRC', 2), |
|
| 1229 | - array(77, 'Grenada', 'GD', 'GRD', 1), |
|
| 1230 | - array(78, 'Greenland', 'GL', 'GRL', 1), |
|
| 1231 | - array(79, 'Guadeloupe', 'GP', 'GLP', 1), |
|
| 1232 | - array(80, 'Guam', 'GU', 'GUM', 1), |
|
| 1233 | - array(81, 'Guatemala', 'GT', 'GTM', 1), |
|
| 1234 | - array(82, 'Guinea', 'GN', 'GIN', 1), |
|
| 1235 | - array(83, 'Equatorial Guinea', 'GQ', 'GNQ', 1), |
|
| 1236 | - array(84, 'Guinea-Bissau', 'GW', 'GNB', 1), |
|
| 1237 | - array(85, 'Guyana', 'GY', 'GUY', 1), |
|
| 1238 | - array(86, 'Haiti', 'HT', 'HTI', 1), |
|
| 1239 | - array(88, 'Honduras', 'HN', 'HND', 1), |
|
| 1240 | - array(89, 'Hong Kong', 'HK', 'HKG', 1), |
|
| 1241 | - array(90, 'Hungary', 'HU', 'HUN', 1), |
|
| 1242 | - array(91, 'India', 'IN', 'IND', 1), |
|
| 1243 | - array(205, 'British Indian Ocean Territory', 'IO', 'IOT', 1), |
|
| 1244 | - array(92, 'Indonesia', 'ID', 'IDN', 1), |
|
| 1245 | - array(93, 'Iraq', 'IQ', 'IRQ', 1), |
|
| 1246 | - array(94, 'Iran', 'IR', 'IRN', 1), |
|
| 1247 | - array(95, 'Ireland', 'IE', 'IRL', 2), |
|
| 1248 | - array(97, 'Iceland', 'IS', 'ISL', 1), |
|
| 1249 | - array(110, 'Israel', 'IL', 'ISR', 1), |
|
| 1250 | - array(49, 'Ivory Coast ', 'CI', 'CIV', 1), |
|
| 1251 | - array(112, 'Jamaica', 'JM', 'JAM', 1), |
|
| 1252 | - array(113, 'Japan', 'JP', 'JPN', 1), |
|
| 1253 | - array(114, 'Jordan', 'JO', 'JOR', 1), |
|
| 1254 | - array(115, 'Kazakhstan', 'KZ', 'KAZ', 1), |
|
| 1255 | - array(116, 'Kenya', 'KE', 'KEN', 1), |
|
| 1256 | - array(117, 'Kyrgyzstan', 'KG', 'KGZ', 1), |
|
| 1257 | - array(118, 'Kiribati', 'KI', 'KIR', 1), |
|
| 1258 | - array(48, 'South Korea', 'KR', 'KOR', 1), |
|
| 1259 | - array(228, 'Kosovo', 'XK', 'XKV', 2), |
|
| 1260 | - // there is no official ISO code for Kosovo yet (http://geonames.wordpress.com/2010/03/08/xk-country-code-for-kosovo/) so using a temporary country code and a modified 3 character code for ISO code -- this should be updated if/when Kosovo gets its own ISO code |
|
| 1261 | - array(119, 'Kuwait', 'KW', 'KWT', 1), |
|
| 1262 | - array(120, 'Laos', 'LA', 'LAO', 1), |
|
| 1263 | - array(121, 'Latvia', 'LV', 'LVA', 2), |
|
| 1264 | - array(122, 'Lesotho', 'LS', 'LSO', 1), |
|
| 1265 | - array(123, 'Lebanon', 'LB', 'LBN', 1), |
|
| 1266 | - array(124, 'Liberia', 'LR', 'LBR', 1), |
|
| 1267 | - array(125, 'Libya', 'LY', 'LBY', 1), |
|
| 1268 | - array(126, 'Liechtenstein', 'LI', 'LIE', 1), |
|
| 1269 | - array(127, 'Lithuania', 'LT', 'LTU', 2), |
|
| 1270 | - array(128, 'Luxemburg', 'LU', 'LUX', 2), |
|
| 1271 | - array(129, 'Macao', 'MO', 'MAC', 1), |
|
| 1272 | - array(130, 'Macedonia', 'MK', 'MKD', 1), |
|
| 1273 | - array(131, 'Madagascar', 'MG', 'MDG', 1), |
|
| 1274 | - array(132, 'Malaysia', 'MY', 'MYS', 1), |
|
| 1275 | - array(133, 'Malawi', 'MW', 'MWI', 1), |
|
| 1276 | - array(134, 'Maldivas', 'MV', 'MDV', 1), |
|
| 1277 | - array(135, 'Mali', 'ML', 'MLI', 1), |
|
| 1278 | - array(136, 'Malta', 'MT', 'MLT', 2), |
|
| 1279 | - array(101, 'Northern Marianas', 'MP', 'MNP', 1), |
|
| 1280 | - array(137, 'Morocco', 'MA', 'MAR', 1), |
|
| 1281 | - array(104, 'Marshall islands', 'MH', 'MHL', 1), |
|
| 1282 | - array(138, 'Martinique', 'MQ', 'MTQ', 1), |
|
| 1283 | - array(139, 'Mauritius', 'MU', 'MUS', 1), |
|
| 1284 | - array(140, 'Mauritania', 'MR', 'MRT', 1), |
|
| 1285 | - array(141, 'Mayote', 'YT', 'MYT', 2), |
|
| 1286 | - array(142, 'Mexico', 'MX', 'MEX', 1), |
|
| 1287 | - array(143, 'Micronesia', 'FM', 'FSM', 1), |
|
| 1288 | - array(144, 'Moldova', 'MD', 'MDA', 1), |
|
| 1289 | - array(145, 'Monaco', 'MC', 'MCO', 2), |
|
| 1290 | - array(146, 'Mongolia', 'MN', 'MNG', 1), |
|
| 1291 | - array(147, 'Montserrat', 'MS', 'MSR', 1), |
|
| 1292 | - array(227, 'Montenegro', 'ME', 'MNE', 2), |
|
| 1293 | - array(148, 'Mozambique', 'MZ', 'MOZ', 1), |
|
| 1294 | - array(149, 'Myanmar', 'MM', 'MMR', 1), |
|
| 1295 | - array(150, 'Namibia', 'NA', 'NAM', 1), |
|
| 1296 | - array(151, 'Nauru', 'NR', 'NRU', 1), |
|
| 1297 | - array(152, 'Nepal', 'NP', 'NPL', 1), |
|
| 1298 | - array(9, 'Netherlands Antilles', 'AN', 'ANT', 1), |
|
| 1299 | - array(153, 'Nicaragua', 'NI', 'NIC', 1), |
|
| 1300 | - array(154, 'Niger', 'NE', 'NER', 1), |
|
| 1301 | - array(155, 'Nigeria', 'NG', 'NGA', 1), |
|
| 1302 | - array(156, 'Niue', 'NU', 'NIU', 1), |
|
| 1303 | - array(157, 'Norway', 'NO', 'NOR', 1), |
|
| 1304 | - array(158, 'New Caledonia', 'NC', 'NCL', 1), |
|
| 1305 | - array(159, 'New Zealand', 'NZ', 'NZL', 1), |
|
| 1306 | - array(160, 'Oman', 'OM', 'OMN', 1), |
|
| 1307 | - array(161, 'Pakistan', 'PK', 'PAK', 1), |
|
| 1308 | - array(162, 'Palau', 'PW', 'PLW', 1), |
|
| 1309 | - array(163, 'Panama', 'PA', 'PAN', 1), |
|
| 1310 | - array(164, 'Papua New Guinea', 'PG', 'PNG', 1), |
|
| 1311 | - array(165, 'Paraguay', 'PY', 'PRY', 1), |
|
| 1312 | - array(166, 'Peru', 'PE', 'PER', 1), |
|
| 1313 | - array(68, 'Philippines', 'PH', 'PHL', 1), |
|
| 1314 | - array(167, 'Poland', 'PL', 'POL', 1), |
|
| 1315 | - array(168, 'Portugal', 'PT', 'PRT', 2), |
|
| 1316 | - array(169, 'Puerto Rico', 'PR', 'PRI', 1), |
|
| 1317 | - array(170, 'Qatar', 'QA', 'QAT', 1), |
|
| 1318 | - array(176, 'Rwanda', 'RW', 'RWA', 1), |
|
| 1319 | - array(177, 'Romania', 'RO', 'ROM', 2), |
|
| 1320 | - array(178, 'Russia', 'RU', 'RUS', 1), |
|
| 1321 | - array(229, 'Saint Pierre and Miquelon', 'PM', 'SPM', 2), |
|
| 1322 | - array(180, 'Samoa', 'WS', 'WSM', 1), |
|
| 1323 | - array(181, 'American Samoa', 'AS', 'ASM', 1), |
|
| 1324 | - array(183, 'San Marino', 'SM', 'SMR', 2), |
|
| 1325 | - array(184, 'Saint Vincent and the Grenadines', 'VC', 'VCT', 1), |
|
| 1326 | - array(185, 'Saint Helena', 'SH', 'SHN', 1), |
|
| 1327 | - array(186, 'Saint Lucia', 'LC', 'LCA', 1), |
|
| 1328 | - array(188, 'Senegal', 'SN', 'SEN', 1), |
|
| 1329 | - array(189, 'Seychelles', 'SC', 'SYC', 1), |
|
| 1330 | - array(190, 'Sierra Leona', 'SL', 'SLE', 1), |
|
| 1331 | - array(191, 'Singapore', 'SG', 'SGP', 1), |
|
| 1332 | - array(192, 'Syria', 'SY', 'SYR', 1), |
|
| 1333 | - array(193, 'Somalia', 'SO', 'SOM', 1), |
|
| 1334 | - array(194, 'Sri Lanka', 'LK', 'LKA', 1), |
|
| 1335 | - array(195, 'South Africa', 'ZA', 'ZAF', 1), |
|
| 1336 | - array(196, 'Sudan', 'SD', 'SDN', 1), |
|
| 1337 | - array(199, 'Suriname', 'SR', 'SUR', 1), |
|
| 1338 | - array(200, 'Swaziland', 'SZ', 'SWZ', 1), |
|
| 1339 | - array(201, 'Thailand', 'TH', 'THA', 1), |
|
| 1340 | - array(202, 'Taiwan', 'TW', 'TWN', 1), |
|
| 1341 | - array(203, 'Tanzania', 'TZ', 'TZA', 1), |
|
| 1342 | - array(204, 'Tajikistan', 'TJ', 'TJK', 1), |
|
| 1343 | - array(206, 'Timor-Leste', 'TL', 'TLS', 1), |
|
| 1344 | - array(207, 'Togo', 'TG', 'TGO', 1), |
|
| 1345 | - array(208, 'Tokelau', 'TK', 'TKL', 1), |
|
| 1346 | - array(209, 'Tonga', 'TO', 'TON', 1), |
|
| 1347 | - array(210, 'Trinidad and Tobago', 'TT', 'TTO', 1), |
|
| 1348 | - array(211, 'Tunisia', 'TN', 'TUN', 1), |
|
| 1349 | - array(212, 'Turkmenistan', 'TM', 'TKM', 1), |
|
| 1350 | - array(213, 'Turkey', 'TR', 'TUR', 1), |
|
| 1351 | - array(214, 'Tuvalu', 'TV', 'TUV', 1), |
|
| 1352 | - array(215, 'Ukraine', 'UA', 'UKR', 1), |
|
| 1353 | - array(216, 'Uganda', 'UG', 'UGA', 1), |
|
| 1354 | - array(59, 'United Arab Emirates', 'AE', 'ARE', 1), |
|
| 1355 | - array(217, 'Uruguay', 'UY', 'URY', 1), |
|
| 1356 | - array(218, 'Uzbekistan', 'UZ', 'UZB', 1), |
|
| 1357 | - array(219, 'Vanuatu', 'VU', 'VUT', 1), |
|
| 1358 | - array(220, 'Vatican City', 'VA', 'VAT', 2), |
|
| 1359 | - array(221, 'Venezuela', 'VE', 'VEN', 1), |
|
| 1360 | - array(222, 'Vietnam', 'VN', 'VNM', 1), |
|
| 1361 | - array(108, 'Virgin Islands', 'VI', 'VIR', 1), |
|
| 1362 | - array(223, 'Yemen', 'YE', 'YEM', 1), |
|
| 1363 | - array(225, 'Zambia', 'ZM', 'ZMB', 1), |
|
| 1364 | - array(226, 'Zimbabwe', 'ZW', 'ZWE', 1), |
|
| 1365 | - ); |
|
| 1366 | - $country_iso = 'US'; |
|
| 1367 | - foreach ($old_countries as $country_array) { |
|
| 1368 | - // note: index 0 is the 3.1 country ID |
|
| 1369 | - if ($country_array[0] == $country_id) { |
|
| 1370 | - // note: index 2 is the ISO |
|
| 1371 | - $country_iso = $country_array[2]; |
|
| 1372 | - break; |
|
| 1373 | - } |
|
| 1374 | - } |
|
| 1375 | - return $country_iso; |
|
| 1376 | - } |
|
| 1377 | - |
|
| 1378 | - |
|
| 1379 | - |
|
| 1380 | - /** |
|
| 1381 | - * Gets the ISO3 for the |
|
| 1382 | - * |
|
| 1383 | - * @return string |
|
| 1384 | - */ |
|
| 1385 | - public function get_default_country_iso() |
|
| 1386 | - { |
|
| 1387 | - $old_org_options = get_option('events_organization_settings'); |
|
| 1388 | - $iso = $this->get_iso_from_3_1_country_id($old_org_options['organization_country']); |
|
| 1389 | - return $iso; |
|
| 1390 | - } |
|
| 1391 | - |
|
| 1392 | - |
|
| 1393 | - |
|
| 1394 | - /** |
|
| 1395 | - * Converst a 3.1 payment status to its equivalent 4.1 regisration status |
|
| 1396 | - * |
|
| 1397 | - * @param string $payment_status possible value for 3.1's evens_attendee.payment_status |
|
| 1398 | - * @param boolean $this_thing_required_pre_approval whether the thing we're considering (the general setting's |
|
| 1399 | - * default payment status, the event's default payment status, or |
|
| 1400 | - * the attendee's payment status) required pre-approval. |
|
| 1401 | - * @return string STS_ID for use in 4.1 |
|
| 1402 | - */ |
|
| 1403 | - public function convert_3_1_payment_status_to_4_1_STS_ID($payment_status, $this_thing_required_pre_approval = false) |
|
| 1404 | - { |
|
| 1405 | - // EE team can read the related discussion: https://app.asana.com/0/2400967562914/9418495544455 |
|
| 1406 | - if ($this_thing_required_pre_approval) { |
|
| 1407 | - return 'RNA'; |
|
| 1408 | - } else { |
|
| 1409 | - $mapping = $default_reg_stati_conversions = array( |
|
| 1410 | - 'Completed' => 'RAP', |
|
| 1411 | - '' => 'RPP', |
|
| 1412 | - 'Incomplete' => 'RPP', |
|
| 1413 | - 'Pending' => 'RAP', |
|
| 1414 | - // stati that only occurred on 3.1 attendees: |
|
| 1415 | - 'Payment Declined' => 'RPP', |
|
| 1416 | - 'Not Completed' => 'RPP', |
|
| 1417 | - 'Cancelled' => 'RPP', |
|
| 1418 | - 'Declined' => 'RPP', |
|
| 1419 | - ); |
|
| 1420 | - } |
|
| 1421 | - return isset($mapping[ $payment_status ]) ? $mapping[ $payment_status ] : 'RNA'; |
|
| 1422 | - } |
|
| 1423 | - |
|
| 1424 | - |
|
| 1425 | - |
|
| 1426 | - /** |
|
| 1427 | - * Makes sure the 3.1's image url is converted to an image attachment post to the 4.1 CPT event |
|
| 1428 | - * and sets it as the featured image on the CPT event |
|
| 1429 | - * |
|
| 1430 | - * @param type $old_event |
|
| 1431 | - * @param type $new_cpt_id |
|
| 1432 | - * @param EE_Data_Migration_Script_Stage $migration_stage the stage which called this, where errors should be added |
|
| 1433 | - * @return boolean whether or not we had to do the big job of creating an image attachment |
|
| 1434 | - */ |
|
| 1435 | - public function convert_image_url_to_attachment_and_attach_to_post( |
|
| 1436 | - $guid, |
|
| 1437 | - $new_cpt_id, |
|
| 1438 | - EE_Data_Migration_Script_Stage $migration_stage |
|
| 1439 | - ) { |
|
| 1440 | - $created_attachment_post = false; |
|
| 1441 | - $guid = $this->_get_original_guid($guid); |
|
| 1442 | - if ($guid) { |
|
| 1443 | - // check for an existing attachment post with this guid |
|
| 1444 | - $attachment_post_id = $this->_get_image_attachment_id_by_GUID($guid); |
|
| 1445 | - if (! $attachment_post_id) { |
|
| 1446 | - // post thumbnail with that GUID doesn't exist, we should create one |
|
| 1447 | - $attachment_post_id = $this->_create_image_attachment_from_GUID($guid, $migration_stage); |
|
| 1448 | - $created_attachment_post = true; |
|
| 1449 | - } |
|
| 1450 | - // double-check we actually have an attachment post |
|
| 1451 | - if ($attachment_post_id) { |
|
| 1452 | - update_post_meta($new_cpt_id, '_thumbnail_id', $attachment_post_id); |
|
| 1453 | - } else { |
|
| 1454 | - $migration_stage->add_error(sprintf(esc_html__( |
|
| 1455 | - "Could not update event image %s for CPT with ID %d, but attachments post ID is %d", |
|
| 1456 | - "event_espresso" |
|
| 1457 | - ), $guid, $new_cpt_id, $attachment_post_id)); |
|
| 1458 | - } |
|
| 1459 | - } |
|
| 1460 | - return $created_attachment_post; |
|
| 1461 | - } |
|
| 1462 | - |
|
| 1463 | - |
|
| 1464 | - |
|
| 1465 | - /** |
|
| 1466 | - * In 3.1, the event thumbnail image DOESN'T point to the orignal image, but instead |
|
| 1467 | - * to a large thumbnail (which has nearly the same GUID, except it adds "-{width}x{height}" before the filetype, |
|
| 1468 | - * or whatever dimensions it is. Eg 'http://mysite.com/image1-300x400.jpg' instead of |
|
| 1469 | - * 'http://mysite.com/image1.jpg' ). This function attempts to strip that off and get the original file, if it |
|
| 1470 | - * exists |
|
| 1471 | - * |
|
| 1472 | - * @param string $guid_in_old_event |
|
| 1473 | - * @return string either the original guid, or $guid_in_old_event if we couldn't figure out what the original was |
|
| 1474 | - */ |
|
| 1475 | - private function _get_original_guid($guid_in_old_event) |
|
| 1476 | - { |
|
| 1477 | - $original_guid = preg_replace('~-\d*x\d*\.~', '.', $guid_in_old_event, 1); |
|
| 1478 | - // do a head request to verify the file exists |
|
| 1479 | - $head_response = wp_remote_head($original_guid); |
|
| 1480 | - if (! $head_response instanceof WP_Error && $head_response['response']['message'] == 'OK') { |
|
| 1481 | - return $original_guid; |
|
| 1482 | - } else { |
|
| 1483 | - return $guid_in_old_event; |
|
| 1484 | - } |
|
| 1485 | - } |
|
| 1486 | - |
|
| 1487 | - |
|
| 1488 | - |
|
| 1489 | - /** |
|
| 1490 | - * Creates an image attachment post for the GUID. If the GUID points to a remote image, |
|
| 1491 | - * we download it to our uploads directory so that it can be properly processed (eg, creates different sizes of |
|
| 1492 | - * thumbnails) |
|
| 1493 | - * |
|
| 1494 | - * @param type $guid |
|
| 1495 | - * @param EE_Data_Migration_Script_Stage $migration_stage |
|
| 1496 | - * @return int |
|
| 1497 | - */ |
|
| 1498 | - private function _create_image_attachment_from_GUID($guid, EE_Data_Migration_Script_Stage $migration_stage) |
|
| 1499 | - { |
|
| 1500 | - if (! $guid) { |
|
| 1501 | - $migration_stage->add_error(sprintf(esc_html__( |
|
| 1502 | - "Cannot create image attachment for a blank GUID!", |
|
| 1503 | - "event_espresso" |
|
| 1504 | - ))); |
|
| 1505 | - return 0; |
|
| 1506 | - } |
|
| 1507 | - $wp_filetype = wp_check_filetype(basename($guid), null); |
|
| 1508 | - $wp_upload_dir = wp_upload_dir(); |
|
| 1509 | - // if the file is located remotely, download it to our uploads DIR, because wp_genereate_attachmnet_metadata needs the file to be local |
|
| 1510 | - if (strpos($guid, $wp_upload_dir['url']) === false) { |
|
| 1511 | - // image is located remotely. download it and place it in the uploads directory |
|
| 1512 | - if (! is_readable($guid)) { |
|
| 1513 | - $migration_stage->add_error(sprintf(esc_html__( |
|
| 1514 | - "Could not create image attachment from non-existent file: %s", |
|
| 1515 | - "event_espresso" |
|
| 1516 | - ), $guid)); |
|
| 1517 | - return 0; |
|
| 1518 | - } |
|
| 1519 | - $contents = file_get_contents($guid); |
|
| 1520 | - if ($contents === false) { |
|
| 1521 | - $migration_stage->add_error(sprintf(esc_html__( |
|
| 1522 | - "Could not read image at %s, and therefore couldnt create an attachment post for it.", |
|
| 1523 | - "event_espresso" |
|
| 1524 | - ), $guid)); |
|
| 1525 | - return false; |
|
| 1526 | - } |
|
| 1527 | - $local_filepath = $wp_upload_dir['path'] . '/' . basename($guid); |
|
| 1528 | - $savefile = fopen($local_filepath, 'w'); |
|
| 1529 | - fwrite($savefile, $contents); |
|
| 1530 | - fclose($savefile); |
|
| 1531 | - $guid = str_replace($wp_upload_dir['path'], $wp_upload_dir['url'], $local_filepath); |
|
| 1532 | - } else { |
|
| 1533 | - $local_filepath = str_replace($wp_upload_dir['url'], $wp_upload_dir['path'], $guid); |
|
| 1534 | - } |
|
| 1535 | - $attachment = array( |
|
| 1536 | - 'guid' => $guid, |
|
| 1537 | - 'post_mime_type' => $wp_filetype['type'], |
|
| 1538 | - 'post_title' => preg_replace('/\.[^.]+$/', '', basename($guid)), |
|
| 1539 | - 'post_content' => '', |
|
| 1540 | - 'post_status' => 'inherit', |
|
| 1541 | - ); |
|
| 1542 | - $attach_id = wp_insert_attachment($attachment, $guid); |
|
| 1543 | - if (! $attach_id) { |
|
| 1544 | - $migration_stage->add_error(sprintf(esc_html__( |
|
| 1545 | - "Could not create image attachment post from image '%s'. Attachment data was %s.", |
|
| 1546 | - "event_espresso" |
|
| 1547 | - ), $guid, $this->_json_encode($attachment))); |
|
| 1548 | - return $attach_id; |
|
| 1549 | - } |
|
| 1550 | - // you must first include the image.php file |
|
| 1551 | - // for the function wp_generate_attachment_metadata() to work |
|
| 1552 | - require_once(ABSPATH . 'wp-admin/includes/image.php'); |
|
| 1553 | - $attach_data = wp_generate_attachment_metadata($attach_id, $local_filepath); |
|
| 1554 | - if (! $attach_data) { |
|
| 1555 | - $migration_stage->add_error(sprintf(esc_html__( |
|
| 1556 | - "Coudl not genereate attachment metadata for attachment post %d with filepath %s and GUID %s. Please check the file was downloaded properly.", |
|
| 1557 | - "event_espresso" |
|
| 1558 | - ), $attach_id, $local_filepath, $guid)); |
|
| 1559 | - return $attach_id; |
|
| 1560 | - } |
|
| 1561 | - $metadata_save_result = wp_update_attachment_metadata($attach_id, $attach_data); |
|
| 1562 | - if (! $metadata_save_result) { |
|
| 1563 | - $migration_stage->add_error(sprintf(esc_html__( |
|
| 1564 | - "Could not update attachment metadata for attachment %d with data %s", |
|
| 1565 | - "event_espresso" |
|
| 1566 | - ), $attach_id, $this->_json_encode($attach_data))); |
|
| 1567 | - } |
|
| 1568 | - return $attach_id; |
|
| 1569 | - } |
|
| 1570 | - |
|
| 1571 | - |
|
| 1572 | - |
|
| 1573 | - /** |
|
| 1574 | - * Finds the attachment post containing info about an image attachment given the GUID (link to the image itself), |
|
| 1575 | - * and returns its ID. |
|
| 1576 | - * |
|
| 1577 | - * @global type $wpdb |
|
| 1578 | - * @param string $guid |
|
| 1579 | - * @return int |
|
| 1580 | - */ |
|
| 1581 | - private function _get_image_attachment_id_by_GUID($guid) |
|
| 1582 | - { |
|
| 1583 | - global $wpdb; |
|
| 1584 | - $attachment_id = $wpdb->get_var($wpdb->prepare("SELECT ID FROM $wpdb->posts WHERE guid=%s LIMIT 1", $guid)); |
|
| 1585 | - return $attachment_id; |
|
| 1586 | - } |
|
| 1587 | - |
|
| 1588 | - |
|
| 1589 | - |
|
| 1590 | - /** |
|
| 1591 | - * Returns a mysql-formatted DATETIME in UTC time, given a $DATETIME_string |
|
| 1592 | - * (and optionally a timezone; if none is given, the wp default is used) |
|
| 1593 | - * |
|
| 1594 | - * @param EE_Data_Migration_Script_base $stage |
|
| 1595 | - * @param array $row_of_data , the row from the DB (as an array) we're trying to find the |
|
| 1596 | - * UTC time for |
|
| 1597 | - * @param string $DATETIME_string |
|
| 1598 | - * @param string $timezone |
|
| 1599 | - * @return string |
|
| 1600 | - */ |
|
| 1601 | - public function convert_date_string_to_utc( |
|
| 1602 | - EE_Data_Migration_Script_Stage $stage, |
|
| 1603 | - $row_of_data, |
|
| 1604 | - $DATETIME_string, |
|
| 1605 | - $timezone = null |
|
| 1606 | - ) { |
|
| 1607 | - $original_tz = $timezone; |
|
| 1608 | - if (! $timezone) { |
|
| 1609 | - $timezone = $this->_get_wp_timezone(); |
|
| 1610 | - } |
|
| 1611 | - if (! $timezone) { |
|
| 1612 | - $stage->add_error(sprintf( |
|
| 1613 | - esc_html__("Could not find timezone given %s for %s", "event_espresso"), |
|
| 1614 | - $original_tz, |
|
| 1615 | - $row_of_data |
|
| 1616 | - )); |
|
| 1617 | - $timezone = 'UTC'; |
|
| 1618 | - } |
|
| 1619 | - try { |
|
| 1620 | - $date_obj = new DateTime($DATETIME_string, new DateTimeZone($timezone)); |
|
| 1621 | - EEH_DTT_Helper::setTimezone($date_obj, new DateTimeZone('UTC')); |
|
| 1622 | - } catch (Exception $e) { |
|
| 1623 | - $stage->add_error(sprintf(esc_html__( |
|
| 1624 | - "Could not convert time string '%s' using timezone '%s' into a proper DATETIME. Using current time instead.", |
|
| 1625 | - "event_espresso" |
|
| 1626 | - ), $DATETIME_string, $timezone)); |
|
| 1627 | - $date_obj = new DateTime(); |
|
| 1628 | - } |
|
| 1629 | - return $date_obj->format('Y-m-d H:i:s'); |
|
| 1630 | - } |
|
| 1631 | - |
|
| 1632 | - |
|
| 1633 | - |
|
| 1634 | - /** |
|
| 1635 | - * Gets the default timezone string from wordpress (even if they set a gmt offset) |
|
| 1636 | - * |
|
| 1637 | - * @return string |
|
| 1638 | - */ |
|
| 1639 | - private function _get_wp_timezone() |
|
| 1640 | - { |
|
| 1641 | - $timezone = empty($timezone) ? get_option('timezone_string') : $timezone; |
|
| 1642 | - // if timezone is STILL empty then let's get the GMT offset and then set the timezone_string using our converter |
|
| 1643 | - if (empty($timezone)) { |
|
| 1644 | - // let's get a the WordPress UTC offset |
|
| 1645 | - $offset = get_option('gmt_offset'); |
|
| 1646 | - $timezone = $this->timezone_convert_to_string_from_offset($offset); |
|
| 1647 | - } |
|
| 1648 | - return $timezone; |
|
| 1649 | - } |
|
| 1650 | - |
|
| 1651 | - |
|
| 1652 | - |
|
| 1653 | - /** |
|
| 1654 | - * Gets the wordpress timezone string from a UTC offset |
|
| 1655 | - * |
|
| 1656 | - * @param int $offset |
|
| 1657 | - * @return boolean |
|
| 1658 | - */ |
|
| 1659 | - private function timezone_convert_to_string_from_offset($offset) |
|
| 1660 | - { |
|
| 1661 | - // shamelessly taken from bottom comment at http://ca1.php.net/manual/en/function.timezone-name-from-abbr.php because timezone_name_from_abbr() did not work as expected - its not reliable |
|
| 1662 | - $offset *= 3600; // convert hour offset to seconds |
|
| 1663 | - $abbrarray = timezone_abbreviations_list(); |
|
| 1664 | - foreach ($abbrarray as $abbr) { |
|
| 1665 | - foreach ($abbr as $city) { |
|
| 1666 | - if ($city['offset'] == $offset) { |
|
| 1667 | - return $city['timezone_id']; |
|
| 1668 | - } |
|
| 1669 | - } |
|
| 1670 | - } |
|
| 1671 | - return false; |
|
| 1672 | - } |
|
| 1673 | - |
|
| 1674 | - |
|
| 1675 | - |
|
| 1676 | - public function migration_page_hooks() |
|
| 1677 | - { |
|
| 1678 | - add_filter( |
|
| 1679 | - 'FHEE__ee_migration_page__header', |
|
| 1680 | - array($this, '_migrate_page_hook_simplify_version_strings'), |
|
| 1681 | - 10, |
|
| 1682 | - 3 |
|
| 1683 | - ); |
|
| 1684 | - add_filter( |
|
| 1685 | - 'FHEE__ee_migration_page__p_after_header', |
|
| 1686 | - array($this, '_migration_page_hook_simplify_next_db_state'), |
|
| 1687 | - 10, |
|
| 1688 | - 2 |
|
| 1689 | - ); |
|
| 1690 | - add_filter( |
|
| 1691 | - 'FHEE__ee_migration_page__option_1_main', |
|
| 1692 | - array($this, '_migrate_page_hook_simplify_version_strings'), |
|
| 1693 | - 10, |
|
| 1694 | - 3 |
|
| 1695 | - ); |
|
| 1696 | - add_filter( |
|
| 1697 | - 'FHEE__ee_migration_page__option_1_button_text', |
|
| 1698 | - array($this, '_migrate_page_hook_simplify_version_strings'), |
|
| 1699 | - 10, |
|
| 1700 | - 3 |
|
| 1701 | - ); |
|
| 1702 | - add_action( |
|
| 1703 | - 'AHEE__ee_migration_page__option_1_extra_details', |
|
| 1704 | - array($this, '_migration_page_hook_option_1_extra_details'), |
|
| 1705 | - 10, |
|
| 1706 | - 3 |
|
| 1707 | - ); |
|
| 1708 | - add_filter( |
|
| 1709 | - 'FHEE__ee_migration_page__option_2_main', |
|
| 1710 | - array($this, '_migrate_page_hook_simplify_version_strings'), |
|
| 1711 | - 10, |
|
| 1712 | - 4 |
|
| 1713 | - ); |
|
| 1714 | - add_filter( |
|
| 1715 | - 'FHEE__ee_migration_page__option_2_button_text', |
|
| 1716 | - array($this, '_migration_page_hook_simplify_next_db_state'), |
|
| 1717 | - 10, |
|
| 1718 | - 2 |
|
| 1719 | - ); |
|
| 1720 | - add_filter( |
|
| 1721 | - 'FHEE__ee_migration_page__option_2_details', |
|
| 1722 | - array($this, '_migration_page_hook_simplify_next_db_state'), |
|
| 1723 | - 10, |
|
| 1724 | - 2 |
|
| 1725 | - ); |
|
| 1726 | - add_action( |
|
| 1727 | - 'AHEE__ee_migration_page__after_migration_options_table', |
|
| 1728 | - array($this, '_migration_page_hook_after_migration_options_table') |
|
| 1729 | - ); |
|
| 1730 | - add_filter( |
|
| 1731 | - 'FHEE__ee_migration_page__done_migration_header', |
|
| 1732 | - array($this, '_migration_page_hook_simplify_next_db_state'), |
|
| 1733 | - 10, |
|
| 1734 | - 2 |
|
| 1735 | - ); |
|
| 1736 | - add_filter( |
|
| 1737 | - 'FHEE__ee_migration_page__p_after_done_migration_header', |
|
| 1738 | - array($this, '_migration_page_hook_simplify_next_db_state'), |
|
| 1739 | - 10, |
|
| 1740 | - 2 |
|
| 1741 | - ); |
|
| 1742 | - add_filter( |
|
| 1743 | - 'FHEE__ee_migration_page__migration_options_template', |
|
| 1744 | - array($this,'use_migration_options_from_ee3_template') |
|
| 1745 | - ); |
|
| 1746 | - } |
|
| 1747 | - |
|
| 1748 | - |
|
| 1749 | - |
|
| 1750 | - public function _migrate_page_hook_simplify_version_strings( |
|
| 1751 | - $old_content, |
|
| 1752 | - $current_db_state, |
|
| 1753 | - $next_db_state, |
|
| 1754 | - $ultimate_db_state = null |
|
| 1755 | - ) { |
|
| 1756 | - return str_replace( |
|
| 1757 | - array($current_db_state, $next_db_state, $ultimate_db_state), |
|
| 1758 | - array(esc_html__('EE3', 'event_espresso'), esc_html__('EE4', 'event_espresso'), esc_html__("EE4", 'event_espresso')), |
|
| 1759 | - $old_content |
|
| 1760 | - ); |
|
| 1761 | - } |
|
| 1762 | - |
|
| 1763 | - |
|
| 1764 | - |
|
| 1765 | - public function _migration_page_hook_simplify_next_db_state($old_content, $next_db_state) |
|
| 1766 | - { |
|
| 1767 | - return str_replace($next_db_state, esc_html__("EE4", 'event_espresso'), $old_content); |
|
| 1768 | - } |
|
| 1769 | - |
|
| 1770 | - |
|
| 1771 | - |
|
| 1772 | - public function _migration_page_hook_option_1_extra_details() |
|
| 1773 | - { |
|
| 1774 | - ?> |
|
| 1072 | + if (! $state) { |
|
| 1073 | + // insert a new one then |
|
| 1074 | + $cols_n_values = array( |
|
| 1075 | + 'CNT_ISO' => $country_iso, |
|
| 1076 | + 'STA_abbrev' => substr($state_name, 0, 6), |
|
| 1077 | + 'STA_name' => $state_name, |
|
| 1078 | + 'STA_active' => true, |
|
| 1079 | + ); |
|
| 1080 | + $data_types = array( |
|
| 1081 | + '%s',// CNT_ISO |
|
| 1082 | + '%s',// STA_abbrev |
|
| 1083 | + '%s',// STA_name |
|
| 1084 | + '%d',// STA_active |
|
| 1085 | + ); |
|
| 1086 | + $success = $wpdb->insert($state_table, $cols_n_values, $data_types); |
|
| 1087 | + if (! $success) { |
|
| 1088 | + throw new EE_Error($this->_create_error_message_for_db_insertion( |
|
| 1089 | + 'N/A', |
|
| 1090 | + array('state' => $state_name, 'country_id' => $country_name), |
|
| 1091 | + $state_table, |
|
| 1092 | + $cols_n_values, |
|
| 1093 | + $data_types |
|
| 1094 | + )); |
|
| 1095 | + } |
|
| 1096 | + $state = $cols_n_values; |
|
| 1097 | + $state['STA_ID'] = $wpdb->insert_id; |
|
| 1098 | + } |
|
| 1099 | + return $state; |
|
| 1100 | + } |
|
| 1101 | + |
|
| 1102 | + |
|
| 1103 | + |
|
| 1104 | + /** |
|
| 1105 | + * Fixes times like "5:00 PM" into the expected 24-hour format "17:00". |
|
| 1106 | + * THis is actually just copied from the 3.1 JSON API because it needed to do the exact same thing |
|
| 1107 | + * |
|
| 1108 | + * @param type $timeString |
|
| 1109 | + * @return string in the php DATETIME format: "G:i" (24-hour format hour with leading zeros, a colon, and minutes |
|
| 1110 | + * with leading zeros) |
|
| 1111 | + */ |
|
| 1112 | + public function convertTimeFromAMPM($timeString) |
|
| 1113 | + { |
|
| 1114 | + $matches = array(); |
|
| 1115 | + preg_match("~(\\d*):(\\d*)~", $timeString, $matches); |
|
| 1116 | + if (! $matches || count($matches) < 3) { |
|
| 1117 | + $hour = '00'; |
|
| 1118 | + $minutes = '00'; |
|
| 1119 | + } else { |
|
| 1120 | + $hour = intval($matches[1]); |
|
| 1121 | + $minutes = $matches[2]; |
|
| 1122 | + } |
|
| 1123 | + if (strpos($timeString, 'PM') || strpos($timeString, 'pm')) { |
|
| 1124 | + $hour = intval($hour) + 12; |
|
| 1125 | + } |
|
| 1126 | + $hour = str_pad("$hour", 2, '0', STR_PAD_LEFT); |
|
| 1127 | + $minutes = str_pad("$minutes", 2, '0', STR_PAD_LEFT); |
|
| 1128 | + return "$hour:$minutes"; |
|
| 1129 | + } |
|
| 1130 | + |
|
| 1131 | + |
|
| 1132 | + |
|
| 1133 | + /** |
|
| 1134 | + * Gets the ISO3 fora country given its 3.1 country ID. |
|
| 1135 | + * |
|
| 1136 | + * @param int $country_id |
|
| 1137 | + * @return string the country's ISO3 code |
|
| 1138 | + */ |
|
| 1139 | + public function get_iso_from_3_1_country_id($country_id) |
|
| 1140 | + { |
|
| 1141 | + $old_countries = array( |
|
| 1142 | + array(64, 'United States', 'US', 'USA', 1), |
|
| 1143 | + array(15, 'Australia', 'AU', 'AUS', 1), |
|
| 1144 | + array(39, 'Canada', 'CA', 'CAN', 1), |
|
| 1145 | + array(171, 'United Kingdom', 'GB', 'GBR', 1), |
|
| 1146 | + array(70, 'France', 'FR', 'FRA', 2), |
|
| 1147 | + array(111, 'Italy', 'IT', 'ITA', 2), |
|
| 1148 | + array(63, 'Spain', 'ES', 'ESP', 2), |
|
| 1149 | + array(1, 'Afghanistan', 'AF', 'AFG', 1), |
|
| 1150 | + array(2, 'Albania', 'AL', 'ALB', 1), |
|
| 1151 | + array(3, 'Germany', 'DE', 'DEU', 2), |
|
| 1152 | + array(198, 'Switzerland', 'CH', 'CHE', 1), |
|
| 1153 | + array(87, 'Netherlands', 'NL', 'NLD', 2), |
|
| 1154 | + array(197, 'Sweden', 'SE', 'SWE', 1), |
|
| 1155 | + array(230, 'Akrotiri and Dhekelia', 'CY', 'CYP', 2), |
|
| 1156 | + array(4, 'Andorra', 'AD', 'AND', 2), |
|
| 1157 | + array(5, 'Angola', 'AO', 'AGO', 1), |
|
| 1158 | + array(6, 'Anguilla', 'AI', 'AIA', 1), |
|
| 1159 | + array(7, 'Antarctica', 'AQ', 'ATA', 1), |
|
| 1160 | + array(8, 'Antigua and Barbuda', 'AG', 'ATG', 1), |
|
| 1161 | + array(10, 'Saudi Arabia', 'SA', 'SAU', 1), |
|
| 1162 | + array(11, 'Algeria', 'DZ', 'DZA', 1), |
|
| 1163 | + array(12, 'Argentina', 'AR', 'ARG', 1), |
|
| 1164 | + array(13, 'Armenia', 'AM', 'ARM', 1), |
|
| 1165 | + array(14, 'Aruba', 'AW', 'ABW', 1), |
|
| 1166 | + array(16, 'Austria', 'AT', 'AUT', 2), |
|
| 1167 | + array(17, 'Azerbaijan', 'AZ', 'AZE', 1), |
|
| 1168 | + array(18, 'Bahamas', 'BS', 'BHS', 1), |
|
| 1169 | + array(19, 'Bahrain', 'BH', 'BHR', 1), |
|
| 1170 | + array(20, 'Bangladesh', 'BD', 'BGD', 1), |
|
| 1171 | + array(21, 'Barbados', 'BB', 'BRB', 1), |
|
| 1172 | + array(22, 'Belgium ', 'BE', 'BEL', 2), |
|
| 1173 | + array(23, 'Belize', 'BZ', 'BLZ', 1), |
|
| 1174 | + array(24, 'Benin', 'BJ', 'BEN', 1), |
|
| 1175 | + array(25, 'Bermudas', 'BM', 'BMU', 1), |
|
| 1176 | + array(26, 'Belarus', 'BY', 'BLR', 1), |
|
| 1177 | + array(27, 'Bolivia', 'BO', 'BOL', 1), |
|
| 1178 | + array(28, 'Bosnia and Herzegovina', 'BA', 'BIH', 1), |
|
| 1179 | + array(29, 'Botswana', 'BW', 'BWA', 1), |
|
| 1180 | + array(96, 'Bouvet Island', 'BV', 'BVT', 1), |
|
| 1181 | + array(30, 'Brazil', 'BR', 'BRA', 1), |
|
| 1182 | + array(31, 'Brunei', 'BN', 'BRN', 1), |
|
| 1183 | + array(32, 'Bulgaria', 'BG', 'BGR', 1), |
|
| 1184 | + array(33, 'Burkina Faso', 'BF', 'BFA', 1), |
|
| 1185 | + array(34, 'Burundi', 'BI', 'BDI', 1), |
|
| 1186 | + array(35, 'Bhutan', 'BT', 'BTN', 1), |
|
| 1187 | + array(36, 'Cape Verde', 'CV', 'CPV', 1), |
|
| 1188 | + array(37, 'Cambodia', 'KH', 'KHM', 1), |
|
| 1189 | + array(38, 'Cameroon', 'CM', 'CMR', 1), |
|
| 1190 | + array(98, 'Cayman Islands', 'KY', 'CYM', 1), |
|
| 1191 | + array(172, 'Central African Republic', 'CF', 'CAF', 1), |
|
| 1192 | + array(40, 'Chad', 'TD', 'TCD', 1), |
|
| 1193 | + array(41, 'Chile', 'CL', 'CHL', 1), |
|
| 1194 | + array(42, 'China', 'CN', 'CHN', 1), |
|
| 1195 | + array(105, 'Christmas Island', 'CX', 'CXR', 1), |
|
| 1196 | + array(43, 'Cyprus', 'CY', 'CYP', 2), |
|
| 1197 | + array(99, 'Cocos Island', 'CC', 'CCK', 1), |
|
| 1198 | + array(100, 'Cook Islands', 'CK', 'COK', 1), |
|
| 1199 | + array(44, 'Colombia', 'CO', 'COL', 1), |
|
| 1200 | + array(45, 'Comoros', 'KM', 'COM', 1), |
|
| 1201 | + array(46, 'Congo', 'CG', 'COG', 1), |
|
| 1202 | + array(47, 'North Korea', 'KP', 'PRK', 1), |
|
| 1203 | + array(50, 'Costa Rica', 'CR', 'CRI', 1), |
|
| 1204 | + array(51, 'Croatia', 'HR', 'HRV', 1), |
|
| 1205 | + array(52, 'Cuba', 'CU', 'CUB', 1), |
|
| 1206 | + array(173, 'Czech Republic', 'CZ', 'CZE', 1), |
|
| 1207 | + array(53, 'Denmark', 'DK', 'DNK', 1), |
|
| 1208 | + array(54, 'Djibouti', 'DJ', 'DJI', 1), |
|
| 1209 | + array(55, 'Dominica', 'DM', 'DMA', 1), |
|
| 1210 | + array(174, 'Dominican Republic', 'DO', 'DOM', 1), |
|
| 1211 | + array(56, 'Ecuador', 'EC', 'ECU', 1), |
|
| 1212 | + array(57, 'Egypt', 'EG', 'EGY', 1), |
|
| 1213 | + array(58, 'El Salvador', 'SV', 'SLV', 1), |
|
| 1214 | + array(60, 'Eritrea', 'ER', 'ERI', 1), |
|
| 1215 | + array(61, 'Slovakia', 'SK', 'SVK', 2), |
|
| 1216 | + array(62, 'Slovenia', 'SI', 'SVN', 2), |
|
| 1217 | + array(65, 'Estonia', 'EE', 'EST', 2), |
|
| 1218 | + array(66, 'Ethiopia', 'ET', 'ETH', 1), |
|
| 1219 | + array(102, 'Faroe islands', 'FO', 'FRO', 1), |
|
| 1220 | + array(103, 'Falkland Islands', 'FK', 'FLK', 1), |
|
| 1221 | + array(67, 'Fiji', 'FJ', 'FJI', 1), |
|
| 1222 | + array(69, 'Finland', 'FI', 'FIN', 2), |
|
| 1223 | + array(71, 'Gabon', 'GA', 'GAB', 1), |
|
| 1224 | + array(72, 'Gambia', 'GM', 'GMB', 1), |
|
| 1225 | + array(73, 'Georgia', 'GE', 'GEO', 1), |
|
| 1226 | + array(74, 'Ghana', 'GH', 'GHA', 1), |
|
| 1227 | + array(75, 'Gibraltar', 'GI', 'GIB', 1), |
|
| 1228 | + array(76, 'Greece', 'GR', 'GRC', 2), |
|
| 1229 | + array(77, 'Grenada', 'GD', 'GRD', 1), |
|
| 1230 | + array(78, 'Greenland', 'GL', 'GRL', 1), |
|
| 1231 | + array(79, 'Guadeloupe', 'GP', 'GLP', 1), |
|
| 1232 | + array(80, 'Guam', 'GU', 'GUM', 1), |
|
| 1233 | + array(81, 'Guatemala', 'GT', 'GTM', 1), |
|
| 1234 | + array(82, 'Guinea', 'GN', 'GIN', 1), |
|
| 1235 | + array(83, 'Equatorial Guinea', 'GQ', 'GNQ', 1), |
|
| 1236 | + array(84, 'Guinea-Bissau', 'GW', 'GNB', 1), |
|
| 1237 | + array(85, 'Guyana', 'GY', 'GUY', 1), |
|
| 1238 | + array(86, 'Haiti', 'HT', 'HTI', 1), |
|
| 1239 | + array(88, 'Honduras', 'HN', 'HND', 1), |
|
| 1240 | + array(89, 'Hong Kong', 'HK', 'HKG', 1), |
|
| 1241 | + array(90, 'Hungary', 'HU', 'HUN', 1), |
|
| 1242 | + array(91, 'India', 'IN', 'IND', 1), |
|
| 1243 | + array(205, 'British Indian Ocean Territory', 'IO', 'IOT', 1), |
|
| 1244 | + array(92, 'Indonesia', 'ID', 'IDN', 1), |
|
| 1245 | + array(93, 'Iraq', 'IQ', 'IRQ', 1), |
|
| 1246 | + array(94, 'Iran', 'IR', 'IRN', 1), |
|
| 1247 | + array(95, 'Ireland', 'IE', 'IRL', 2), |
|
| 1248 | + array(97, 'Iceland', 'IS', 'ISL', 1), |
|
| 1249 | + array(110, 'Israel', 'IL', 'ISR', 1), |
|
| 1250 | + array(49, 'Ivory Coast ', 'CI', 'CIV', 1), |
|
| 1251 | + array(112, 'Jamaica', 'JM', 'JAM', 1), |
|
| 1252 | + array(113, 'Japan', 'JP', 'JPN', 1), |
|
| 1253 | + array(114, 'Jordan', 'JO', 'JOR', 1), |
|
| 1254 | + array(115, 'Kazakhstan', 'KZ', 'KAZ', 1), |
|
| 1255 | + array(116, 'Kenya', 'KE', 'KEN', 1), |
|
| 1256 | + array(117, 'Kyrgyzstan', 'KG', 'KGZ', 1), |
|
| 1257 | + array(118, 'Kiribati', 'KI', 'KIR', 1), |
|
| 1258 | + array(48, 'South Korea', 'KR', 'KOR', 1), |
|
| 1259 | + array(228, 'Kosovo', 'XK', 'XKV', 2), |
|
| 1260 | + // there is no official ISO code for Kosovo yet (http://geonames.wordpress.com/2010/03/08/xk-country-code-for-kosovo/) so using a temporary country code and a modified 3 character code for ISO code -- this should be updated if/when Kosovo gets its own ISO code |
|
| 1261 | + array(119, 'Kuwait', 'KW', 'KWT', 1), |
|
| 1262 | + array(120, 'Laos', 'LA', 'LAO', 1), |
|
| 1263 | + array(121, 'Latvia', 'LV', 'LVA', 2), |
|
| 1264 | + array(122, 'Lesotho', 'LS', 'LSO', 1), |
|
| 1265 | + array(123, 'Lebanon', 'LB', 'LBN', 1), |
|
| 1266 | + array(124, 'Liberia', 'LR', 'LBR', 1), |
|
| 1267 | + array(125, 'Libya', 'LY', 'LBY', 1), |
|
| 1268 | + array(126, 'Liechtenstein', 'LI', 'LIE', 1), |
|
| 1269 | + array(127, 'Lithuania', 'LT', 'LTU', 2), |
|
| 1270 | + array(128, 'Luxemburg', 'LU', 'LUX', 2), |
|
| 1271 | + array(129, 'Macao', 'MO', 'MAC', 1), |
|
| 1272 | + array(130, 'Macedonia', 'MK', 'MKD', 1), |
|
| 1273 | + array(131, 'Madagascar', 'MG', 'MDG', 1), |
|
| 1274 | + array(132, 'Malaysia', 'MY', 'MYS', 1), |
|
| 1275 | + array(133, 'Malawi', 'MW', 'MWI', 1), |
|
| 1276 | + array(134, 'Maldivas', 'MV', 'MDV', 1), |
|
| 1277 | + array(135, 'Mali', 'ML', 'MLI', 1), |
|
| 1278 | + array(136, 'Malta', 'MT', 'MLT', 2), |
|
| 1279 | + array(101, 'Northern Marianas', 'MP', 'MNP', 1), |
|
| 1280 | + array(137, 'Morocco', 'MA', 'MAR', 1), |
|
| 1281 | + array(104, 'Marshall islands', 'MH', 'MHL', 1), |
|
| 1282 | + array(138, 'Martinique', 'MQ', 'MTQ', 1), |
|
| 1283 | + array(139, 'Mauritius', 'MU', 'MUS', 1), |
|
| 1284 | + array(140, 'Mauritania', 'MR', 'MRT', 1), |
|
| 1285 | + array(141, 'Mayote', 'YT', 'MYT', 2), |
|
| 1286 | + array(142, 'Mexico', 'MX', 'MEX', 1), |
|
| 1287 | + array(143, 'Micronesia', 'FM', 'FSM', 1), |
|
| 1288 | + array(144, 'Moldova', 'MD', 'MDA', 1), |
|
| 1289 | + array(145, 'Monaco', 'MC', 'MCO', 2), |
|
| 1290 | + array(146, 'Mongolia', 'MN', 'MNG', 1), |
|
| 1291 | + array(147, 'Montserrat', 'MS', 'MSR', 1), |
|
| 1292 | + array(227, 'Montenegro', 'ME', 'MNE', 2), |
|
| 1293 | + array(148, 'Mozambique', 'MZ', 'MOZ', 1), |
|
| 1294 | + array(149, 'Myanmar', 'MM', 'MMR', 1), |
|
| 1295 | + array(150, 'Namibia', 'NA', 'NAM', 1), |
|
| 1296 | + array(151, 'Nauru', 'NR', 'NRU', 1), |
|
| 1297 | + array(152, 'Nepal', 'NP', 'NPL', 1), |
|
| 1298 | + array(9, 'Netherlands Antilles', 'AN', 'ANT', 1), |
|
| 1299 | + array(153, 'Nicaragua', 'NI', 'NIC', 1), |
|
| 1300 | + array(154, 'Niger', 'NE', 'NER', 1), |
|
| 1301 | + array(155, 'Nigeria', 'NG', 'NGA', 1), |
|
| 1302 | + array(156, 'Niue', 'NU', 'NIU', 1), |
|
| 1303 | + array(157, 'Norway', 'NO', 'NOR', 1), |
|
| 1304 | + array(158, 'New Caledonia', 'NC', 'NCL', 1), |
|
| 1305 | + array(159, 'New Zealand', 'NZ', 'NZL', 1), |
|
| 1306 | + array(160, 'Oman', 'OM', 'OMN', 1), |
|
| 1307 | + array(161, 'Pakistan', 'PK', 'PAK', 1), |
|
| 1308 | + array(162, 'Palau', 'PW', 'PLW', 1), |
|
| 1309 | + array(163, 'Panama', 'PA', 'PAN', 1), |
|
| 1310 | + array(164, 'Papua New Guinea', 'PG', 'PNG', 1), |
|
| 1311 | + array(165, 'Paraguay', 'PY', 'PRY', 1), |
|
| 1312 | + array(166, 'Peru', 'PE', 'PER', 1), |
|
| 1313 | + array(68, 'Philippines', 'PH', 'PHL', 1), |
|
| 1314 | + array(167, 'Poland', 'PL', 'POL', 1), |
|
| 1315 | + array(168, 'Portugal', 'PT', 'PRT', 2), |
|
| 1316 | + array(169, 'Puerto Rico', 'PR', 'PRI', 1), |
|
| 1317 | + array(170, 'Qatar', 'QA', 'QAT', 1), |
|
| 1318 | + array(176, 'Rwanda', 'RW', 'RWA', 1), |
|
| 1319 | + array(177, 'Romania', 'RO', 'ROM', 2), |
|
| 1320 | + array(178, 'Russia', 'RU', 'RUS', 1), |
|
| 1321 | + array(229, 'Saint Pierre and Miquelon', 'PM', 'SPM', 2), |
|
| 1322 | + array(180, 'Samoa', 'WS', 'WSM', 1), |
|
| 1323 | + array(181, 'American Samoa', 'AS', 'ASM', 1), |
|
| 1324 | + array(183, 'San Marino', 'SM', 'SMR', 2), |
|
| 1325 | + array(184, 'Saint Vincent and the Grenadines', 'VC', 'VCT', 1), |
|
| 1326 | + array(185, 'Saint Helena', 'SH', 'SHN', 1), |
|
| 1327 | + array(186, 'Saint Lucia', 'LC', 'LCA', 1), |
|
| 1328 | + array(188, 'Senegal', 'SN', 'SEN', 1), |
|
| 1329 | + array(189, 'Seychelles', 'SC', 'SYC', 1), |
|
| 1330 | + array(190, 'Sierra Leona', 'SL', 'SLE', 1), |
|
| 1331 | + array(191, 'Singapore', 'SG', 'SGP', 1), |
|
| 1332 | + array(192, 'Syria', 'SY', 'SYR', 1), |
|
| 1333 | + array(193, 'Somalia', 'SO', 'SOM', 1), |
|
| 1334 | + array(194, 'Sri Lanka', 'LK', 'LKA', 1), |
|
| 1335 | + array(195, 'South Africa', 'ZA', 'ZAF', 1), |
|
| 1336 | + array(196, 'Sudan', 'SD', 'SDN', 1), |
|
| 1337 | + array(199, 'Suriname', 'SR', 'SUR', 1), |
|
| 1338 | + array(200, 'Swaziland', 'SZ', 'SWZ', 1), |
|
| 1339 | + array(201, 'Thailand', 'TH', 'THA', 1), |
|
| 1340 | + array(202, 'Taiwan', 'TW', 'TWN', 1), |
|
| 1341 | + array(203, 'Tanzania', 'TZ', 'TZA', 1), |
|
| 1342 | + array(204, 'Tajikistan', 'TJ', 'TJK', 1), |
|
| 1343 | + array(206, 'Timor-Leste', 'TL', 'TLS', 1), |
|
| 1344 | + array(207, 'Togo', 'TG', 'TGO', 1), |
|
| 1345 | + array(208, 'Tokelau', 'TK', 'TKL', 1), |
|
| 1346 | + array(209, 'Tonga', 'TO', 'TON', 1), |
|
| 1347 | + array(210, 'Trinidad and Tobago', 'TT', 'TTO', 1), |
|
| 1348 | + array(211, 'Tunisia', 'TN', 'TUN', 1), |
|
| 1349 | + array(212, 'Turkmenistan', 'TM', 'TKM', 1), |
|
| 1350 | + array(213, 'Turkey', 'TR', 'TUR', 1), |
|
| 1351 | + array(214, 'Tuvalu', 'TV', 'TUV', 1), |
|
| 1352 | + array(215, 'Ukraine', 'UA', 'UKR', 1), |
|
| 1353 | + array(216, 'Uganda', 'UG', 'UGA', 1), |
|
| 1354 | + array(59, 'United Arab Emirates', 'AE', 'ARE', 1), |
|
| 1355 | + array(217, 'Uruguay', 'UY', 'URY', 1), |
|
| 1356 | + array(218, 'Uzbekistan', 'UZ', 'UZB', 1), |
|
| 1357 | + array(219, 'Vanuatu', 'VU', 'VUT', 1), |
|
| 1358 | + array(220, 'Vatican City', 'VA', 'VAT', 2), |
|
| 1359 | + array(221, 'Venezuela', 'VE', 'VEN', 1), |
|
| 1360 | + array(222, 'Vietnam', 'VN', 'VNM', 1), |
|
| 1361 | + array(108, 'Virgin Islands', 'VI', 'VIR', 1), |
|
| 1362 | + array(223, 'Yemen', 'YE', 'YEM', 1), |
|
| 1363 | + array(225, 'Zambia', 'ZM', 'ZMB', 1), |
|
| 1364 | + array(226, 'Zimbabwe', 'ZW', 'ZWE', 1), |
|
| 1365 | + ); |
|
| 1366 | + $country_iso = 'US'; |
|
| 1367 | + foreach ($old_countries as $country_array) { |
|
| 1368 | + // note: index 0 is the 3.1 country ID |
|
| 1369 | + if ($country_array[0] == $country_id) { |
|
| 1370 | + // note: index 2 is the ISO |
|
| 1371 | + $country_iso = $country_array[2]; |
|
| 1372 | + break; |
|
| 1373 | + } |
|
| 1374 | + } |
|
| 1375 | + return $country_iso; |
|
| 1376 | + } |
|
| 1377 | + |
|
| 1378 | + |
|
| 1379 | + |
|
| 1380 | + /** |
|
| 1381 | + * Gets the ISO3 for the |
|
| 1382 | + * |
|
| 1383 | + * @return string |
|
| 1384 | + */ |
|
| 1385 | + public function get_default_country_iso() |
|
| 1386 | + { |
|
| 1387 | + $old_org_options = get_option('events_organization_settings'); |
|
| 1388 | + $iso = $this->get_iso_from_3_1_country_id($old_org_options['organization_country']); |
|
| 1389 | + return $iso; |
|
| 1390 | + } |
|
| 1391 | + |
|
| 1392 | + |
|
| 1393 | + |
|
| 1394 | + /** |
|
| 1395 | + * Converst a 3.1 payment status to its equivalent 4.1 regisration status |
|
| 1396 | + * |
|
| 1397 | + * @param string $payment_status possible value for 3.1's evens_attendee.payment_status |
|
| 1398 | + * @param boolean $this_thing_required_pre_approval whether the thing we're considering (the general setting's |
|
| 1399 | + * default payment status, the event's default payment status, or |
|
| 1400 | + * the attendee's payment status) required pre-approval. |
|
| 1401 | + * @return string STS_ID for use in 4.1 |
|
| 1402 | + */ |
|
| 1403 | + public function convert_3_1_payment_status_to_4_1_STS_ID($payment_status, $this_thing_required_pre_approval = false) |
|
| 1404 | + { |
|
| 1405 | + // EE team can read the related discussion: https://app.asana.com/0/2400967562914/9418495544455 |
|
| 1406 | + if ($this_thing_required_pre_approval) { |
|
| 1407 | + return 'RNA'; |
|
| 1408 | + } else { |
|
| 1409 | + $mapping = $default_reg_stati_conversions = array( |
|
| 1410 | + 'Completed' => 'RAP', |
|
| 1411 | + '' => 'RPP', |
|
| 1412 | + 'Incomplete' => 'RPP', |
|
| 1413 | + 'Pending' => 'RAP', |
|
| 1414 | + // stati that only occurred on 3.1 attendees: |
|
| 1415 | + 'Payment Declined' => 'RPP', |
|
| 1416 | + 'Not Completed' => 'RPP', |
|
| 1417 | + 'Cancelled' => 'RPP', |
|
| 1418 | + 'Declined' => 'RPP', |
|
| 1419 | + ); |
|
| 1420 | + } |
|
| 1421 | + return isset($mapping[ $payment_status ]) ? $mapping[ $payment_status ] : 'RNA'; |
|
| 1422 | + } |
|
| 1423 | + |
|
| 1424 | + |
|
| 1425 | + |
|
| 1426 | + /** |
|
| 1427 | + * Makes sure the 3.1's image url is converted to an image attachment post to the 4.1 CPT event |
|
| 1428 | + * and sets it as the featured image on the CPT event |
|
| 1429 | + * |
|
| 1430 | + * @param type $old_event |
|
| 1431 | + * @param type $new_cpt_id |
|
| 1432 | + * @param EE_Data_Migration_Script_Stage $migration_stage the stage which called this, where errors should be added |
|
| 1433 | + * @return boolean whether or not we had to do the big job of creating an image attachment |
|
| 1434 | + */ |
|
| 1435 | + public function convert_image_url_to_attachment_and_attach_to_post( |
|
| 1436 | + $guid, |
|
| 1437 | + $new_cpt_id, |
|
| 1438 | + EE_Data_Migration_Script_Stage $migration_stage |
|
| 1439 | + ) { |
|
| 1440 | + $created_attachment_post = false; |
|
| 1441 | + $guid = $this->_get_original_guid($guid); |
|
| 1442 | + if ($guid) { |
|
| 1443 | + // check for an existing attachment post with this guid |
|
| 1444 | + $attachment_post_id = $this->_get_image_attachment_id_by_GUID($guid); |
|
| 1445 | + if (! $attachment_post_id) { |
|
| 1446 | + // post thumbnail with that GUID doesn't exist, we should create one |
|
| 1447 | + $attachment_post_id = $this->_create_image_attachment_from_GUID($guid, $migration_stage); |
|
| 1448 | + $created_attachment_post = true; |
|
| 1449 | + } |
|
| 1450 | + // double-check we actually have an attachment post |
|
| 1451 | + if ($attachment_post_id) { |
|
| 1452 | + update_post_meta($new_cpt_id, '_thumbnail_id', $attachment_post_id); |
|
| 1453 | + } else { |
|
| 1454 | + $migration_stage->add_error(sprintf(esc_html__( |
|
| 1455 | + "Could not update event image %s for CPT with ID %d, but attachments post ID is %d", |
|
| 1456 | + "event_espresso" |
|
| 1457 | + ), $guid, $new_cpt_id, $attachment_post_id)); |
|
| 1458 | + } |
|
| 1459 | + } |
|
| 1460 | + return $created_attachment_post; |
|
| 1461 | + } |
|
| 1462 | + |
|
| 1463 | + |
|
| 1464 | + |
|
| 1465 | + /** |
|
| 1466 | + * In 3.1, the event thumbnail image DOESN'T point to the orignal image, but instead |
|
| 1467 | + * to a large thumbnail (which has nearly the same GUID, except it adds "-{width}x{height}" before the filetype, |
|
| 1468 | + * or whatever dimensions it is. Eg 'http://mysite.com/image1-300x400.jpg' instead of |
|
| 1469 | + * 'http://mysite.com/image1.jpg' ). This function attempts to strip that off and get the original file, if it |
|
| 1470 | + * exists |
|
| 1471 | + * |
|
| 1472 | + * @param string $guid_in_old_event |
|
| 1473 | + * @return string either the original guid, or $guid_in_old_event if we couldn't figure out what the original was |
|
| 1474 | + */ |
|
| 1475 | + private function _get_original_guid($guid_in_old_event) |
|
| 1476 | + { |
|
| 1477 | + $original_guid = preg_replace('~-\d*x\d*\.~', '.', $guid_in_old_event, 1); |
|
| 1478 | + // do a head request to verify the file exists |
|
| 1479 | + $head_response = wp_remote_head($original_guid); |
|
| 1480 | + if (! $head_response instanceof WP_Error && $head_response['response']['message'] == 'OK') { |
|
| 1481 | + return $original_guid; |
|
| 1482 | + } else { |
|
| 1483 | + return $guid_in_old_event; |
|
| 1484 | + } |
|
| 1485 | + } |
|
| 1486 | + |
|
| 1487 | + |
|
| 1488 | + |
|
| 1489 | + /** |
|
| 1490 | + * Creates an image attachment post for the GUID. If the GUID points to a remote image, |
|
| 1491 | + * we download it to our uploads directory so that it can be properly processed (eg, creates different sizes of |
|
| 1492 | + * thumbnails) |
|
| 1493 | + * |
|
| 1494 | + * @param type $guid |
|
| 1495 | + * @param EE_Data_Migration_Script_Stage $migration_stage |
|
| 1496 | + * @return int |
|
| 1497 | + */ |
|
| 1498 | + private function _create_image_attachment_from_GUID($guid, EE_Data_Migration_Script_Stage $migration_stage) |
|
| 1499 | + { |
|
| 1500 | + if (! $guid) { |
|
| 1501 | + $migration_stage->add_error(sprintf(esc_html__( |
|
| 1502 | + "Cannot create image attachment for a blank GUID!", |
|
| 1503 | + "event_espresso" |
|
| 1504 | + ))); |
|
| 1505 | + return 0; |
|
| 1506 | + } |
|
| 1507 | + $wp_filetype = wp_check_filetype(basename($guid), null); |
|
| 1508 | + $wp_upload_dir = wp_upload_dir(); |
|
| 1509 | + // if the file is located remotely, download it to our uploads DIR, because wp_genereate_attachmnet_metadata needs the file to be local |
|
| 1510 | + if (strpos($guid, $wp_upload_dir['url']) === false) { |
|
| 1511 | + // image is located remotely. download it and place it in the uploads directory |
|
| 1512 | + if (! is_readable($guid)) { |
|
| 1513 | + $migration_stage->add_error(sprintf(esc_html__( |
|
| 1514 | + "Could not create image attachment from non-existent file: %s", |
|
| 1515 | + "event_espresso" |
|
| 1516 | + ), $guid)); |
|
| 1517 | + return 0; |
|
| 1518 | + } |
|
| 1519 | + $contents = file_get_contents($guid); |
|
| 1520 | + if ($contents === false) { |
|
| 1521 | + $migration_stage->add_error(sprintf(esc_html__( |
|
| 1522 | + "Could not read image at %s, and therefore couldnt create an attachment post for it.", |
|
| 1523 | + "event_espresso" |
|
| 1524 | + ), $guid)); |
|
| 1525 | + return false; |
|
| 1526 | + } |
|
| 1527 | + $local_filepath = $wp_upload_dir['path'] . '/' . basename($guid); |
|
| 1528 | + $savefile = fopen($local_filepath, 'w'); |
|
| 1529 | + fwrite($savefile, $contents); |
|
| 1530 | + fclose($savefile); |
|
| 1531 | + $guid = str_replace($wp_upload_dir['path'], $wp_upload_dir['url'], $local_filepath); |
|
| 1532 | + } else { |
|
| 1533 | + $local_filepath = str_replace($wp_upload_dir['url'], $wp_upload_dir['path'], $guid); |
|
| 1534 | + } |
|
| 1535 | + $attachment = array( |
|
| 1536 | + 'guid' => $guid, |
|
| 1537 | + 'post_mime_type' => $wp_filetype['type'], |
|
| 1538 | + 'post_title' => preg_replace('/\.[^.]+$/', '', basename($guid)), |
|
| 1539 | + 'post_content' => '', |
|
| 1540 | + 'post_status' => 'inherit', |
|
| 1541 | + ); |
|
| 1542 | + $attach_id = wp_insert_attachment($attachment, $guid); |
|
| 1543 | + if (! $attach_id) { |
|
| 1544 | + $migration_stage->add_error(sprintf(esc_html__( |
|
| 1545 | + "Could not create image attachment post from image '%s'. Attachment data was %s.", |
|
| 1546 | + "event_espresso" |
|
| 1547 | + ), $guid, $this->_json_encode($attachment))); |
|
| 1548 | + return $attach_id; |
|
| 1549 | + } |
|
| 1550 | + // you must first include the image.php file |
|
| 1551 | + // for the function wp_generate_attachment_metadata() to work |
|
| 1552 | + require_once(ABSPATH . 'wp-admin/includes/image.php'); |
|
| 1553 | + $attach_data = wp_generate_attachment_metadata($attach_id, $local_filepath); |
|
| 1554 | + if (! $attach_data) { |
|
| 1555 | + $migration_stage->add_error(sprintf(esc_html__( |
|
| 1556 | + "Coudl not genereate attachment metadata for attachment post %d with filepath %s and GUID %s. Please check the file was downloaded properly.", |
|
| 1557 | + "event_espresso" |
|
| 1558 | + ), $attach_id, $local_filepath, $guid)); |
|
| 1559 | + return $attach_id; |
|
| 1560 | + } |
|
| 1561 | + $metadata_save_result = wp_update_attachment_metadata($attach_id, $attach_data); |
|
| 1562 | + if (! $metadata_save_result) { |
|
| 1563 | + $migration_stage->add_error(sprintf(esc_html__( |
|
| 1564 | + "Could not update attachment metadata for attachment %d with data %s", |
|
| 1565 | + "event_espresso" |
|
| 1566 | + ), $attach_id, $this->_json_encode($attach_data))); |
|
| 1567 | + } |
|
| 1568 | + return $attach_id; |
|
| 1569 | + } |
|
| 1570 | + |
|
| 1571 | + |
|
| 1572 | + |
|
| 1573 | + /** |
|
| 1574 | + * Finds the attachment post containing info about an image attachment given the GUID (link to the image itself), |
|
| 1575 | + * and returns its ID. |
|
| 1576 | + * |
|
| 1577 | + * @global type $wpdb |
|
| 1578 | + * @param string $guid |
|
| 1579 | + * @return int |
|
| 1580 | + */ |
|
| 1581 | + private function _get_image_attachment_id_by_GUID($guid) |
|
| 1582 | + { |
|
| 1583 | + global $wpdb; |
|
| 1584 | + $attachment_id = $wpdb->get_var($wpdb->prepare("SELECT ID FROM $wpdb->posts WHERE guid=%s LIMIT 1", $guid)); |
|
| 1585 | + return $attachment_id; |
|
| 1586 | + } |
|
| 1587 | + |
|
| 1588 | + |
|
| 1589 | + |
|
| 1590 | + /** |
|
| 1591 | + * Returns a mysql-formatted DATETIME in UTC time, given a $DATETIME_string |
|
| 1592 | + * (and optionally a timezone; if none is given, the wp default is used) |
|
| 1593 | + * |
|
| 1594 | + * @param EE_Data_Migration_Script_base $stage |
|
| 1595 | + * @param array $row_of_data , the row from the DB (as an array) we're trying to find the |
|
| 1596 | + * UTC time for |
|
| 1597 | + * @param string $DATETIME_string |
|
| 1598 | + * @param string $timezone |
|
| 1599 | + * @return string |
|
| 1600 | + */ |
|
| 1601 | + public function convert_date_string_to_utc( |
|
| 1602 | + EE_Data_Migration_Script_Stage $stage, |
|
| 1603 | + $row_of_data, |
|
| 1604 | + $DATETIME_string, |
|
| 1605 | + $timezone = null |
|
| 1606 | + ) { |
|
| 1607 | + $original_tz = $timezone; |
|
| 1608 | + if (! $timezone) { |
|
| 1609 | + $timezone = $this->_get_wp_timezone(); |
|
| 1610 | + } |
|
| 1611 | + if (! $timezone) { |
|
| 1612 | + $stage->add_error(sprintf( |
|
| 1613 | + esc_html__("Could not find timezone given %s for %s", "event_espresso"), |
|
| 1614 | + $original_tz, |
|
| 1615 | + $row_of_data |
|
| 1616 | + )); |
|
| 1617 | + $timezone = 'UTC'; |
|
| 1618 | + } |
|
| 1619 | + try { |
|
| 1620 | + $date_obj = new DateTime($DATETIME_string, new DateTimeZone($timezone)); |
|
| 1621 | + EEH_DTT_Helper::setTimezone($date_obj, new DateTimeZone('UTC')); |
|
| 1622 | + } catch (Exception $e) { |
|
| 1623 | + $stage->add_error(sprintf(esc_html__( |
|
| 1624 | + "Could not convert time string '%s' using timezone '%s' into a proper DATETIME. Using current time instead.", |
|
| 1625 | + "event_espresso" |
|
| 1626 | + ), $DATETIME_string, $timezone)); |
|
| 1627 | + $date_obj = new DateTime(); |
|
| 1628 | + } |
|
| 1629 | + return $date_obj->format('Y-m-d H:i:s'); |
|
| 1630 | + } |
|
| 1631 | + |
|
| 1632 | + |
|
| 1633 | + |
|
| 1634 | + /** |
|
| 1635 | + * Gets the default timezone string from wordpress (even if they set a gmt offset) |
|
| 1636 | + * |
|
| 1637 | + * @return string |
|
| 1638 | + */ |
|
| 1639 | + private function _get_wp_timezone() |
|
| 1640 | + { |
|
| 1641 | + $timezone = empty($timezone) ? get_option('timezone_string') : $timezone; |
|
| 1642 | + // if timezone is STILL empty then let's get the GMT offset and then set the timezone_string using our converter |
|
| 1643 | + if (empty($timezone)) { |
|
| 1644 | + // let's get a the WordPress UTC offset |
|
| 1645 | + $offset = get_option('gmt_offset'); |
|
| 1646 | + $timezone = $this->timezone_convert_to_string_from_offset($offset); |
|
| 1647 | + } |
|
| 1648 | + return $timezone; |
|
| 1649 | + } |
|
| 1650 | + |
|
| 1651 | + |
|
| 1652 | + |
|
| 1653 | + /** |
|
| 1654 | + * Gets the wordpress timezone string from a UTC offset |
|
| 1655 | + * |
|
| 1656 | + * @param int $offset |
|
| 1657 | + * @return boolean |
|
| 1658 | + */ |
|
| 1659 | + private function timezone_convert_to_string_from_offset($offset) |
|
| 1660 | + { |
|
| 1661 | + // shamelessly taken from bottom comment at http://ca1.php.net/manual/en/function.timezone-name-from-abbr.php because timezone_name_from_abbr() did not work as expected - its not reliable |
|
| 1662 | + $offset *= 3600; // convert hour offset to seconds |
|
| 1663 | + $abbrarray = timezone_abbreviations_list(); |
|
| 1664 | + foreach ($abbrarray as $abbr) { |
|
| 1665 | + foreach ($abbr as $city) { |
|
| 1666 | + if ($city['offset'] == $offset) { |
|
| 1667 | + return $city['timezone_id']; |
|
| 1668 | + } |
|
| 1669 | + } |
|
| 1670 | + } |
|
| 1671 | + return false; |
|
| 1672 | + } |
|
| 1673 | + |
|
| 1674 | + |
|
| 1675 | + |
|
| 1676 | + public function migration_page_hooks() |
|
| 1677 | + { |
|
| 1678 | + add_filter( |
|
| 1679 | + 'FHEE__ee_migration_page__header', |
|
| 1680 | + array($this, '_migrate_page_hook_simplify_version_strings'), |
|
| 1681 | + 10, |
|
| 1682 | + 3 |
|
| 1683 | + ); |
|
| 1684 | + add_filter( |
|
| 1685 | + 'FHEE__ee_migration_page__p_after_header', |
|
| 1686 | + array($this, '_migration_page_hook_simplify_next_db_state'), |
|
| 1687 | + 10, |
|
| 1688 | + 2 |
|
| 1689 | + ); |
|
| 1690 | + add_filter( |
|
| 1691 | + 'FHEE__ee_migration_page__option_1_main', |
|
| 1692 | + array($this, '_migrate_page_hook_simplify_version_strings'), |
|
| 1693 | + 10, |
|
| 1694 | + 3 |
|
| 1695 | + ); |
|
| 1696 | + add_filter( |
|
| 1697 | + 'FHEE__ee_migration_page__option_1_button_text', |
|
| 1698 | + array($this, '_migrate_page_hook_simplify_version_strings'), |
|
| 1699 | + 10, |
|
| 1700 | + 3 |
|
| 1701 | + ); |
|
| 1702 | + add_action( |
|
| 1703 | + 'AHEE__ee_migration_page__option_1_extra_details', |
|
| 1704 | + array($this, '_migration_page_hook_option_1_extra_details'), |
|
| 1705 | + 10, |
|
| 1706 | + 3 |
|
| 1707 | + ); |
|
| 1708 | + add_filter( |
|
| 1709 | + 'FHEE__ee_migration_page__option_2_main', |
|
| 1710 | + array($this, '_migrate_page_hook_simplify_version_strings'), |
|
| 1711 | + 10, |
|
| 1712 | + 4 |
|
| 1713 | + ); |
|
| 1714 | + add_filter( |
|
| 1715 | + 'FHEE__ee_migration_page__option_2_button_text', |
|
| 1716 | + array($this, '_migration_page_hook_simplify_next_db_state'), |
|
| 1717 | + 10, |
|
| 1718 | + 2 |
|
| 1719 | + ); |
|
| 1720 | + add_filter( |
|
| 1721 | + 'FHEE__ee_migration_page__option_2_details', |
|
| 1722 | + array($this, '_migration_page_hook_simplify_next_db_state'), |
|
| 1723 | + 10, |
|
| 1724 | + 2 |
|
| 1725 | + ); |
|
| 1726 | + add_action( |
|
| 1727 | + 'AHEE__ee_migration_page__after_migration_options_table', |
|
| 1728 | + array($this, '_migration_page_hook_after_migration_options_table') |
|
| 1729 | + ); |
|
| 1730 | + add_filter( |
|
| 1731 | + 'FHEE__ee_migration_page__done_migration_header', |
|
| 1732 | + array($this, '_migration_page_hook_simplify_next_db_state'), |
|
| 1733 | + 10, |
|
| 1734 | + 2 |
|
| 1735 | + ); |
|
| 1736 | + add_filter( |
|
| 1737 | + 'FHEE__ee_migration_page__p_after_done_migration_header', |
|
| 1738 | + array($this, '_migration_page_hook_simplify_next_db_state'), |
|
| 1739 | + 10, |
|
| 1740 | + 2 |
|
| 1741 | + ); |
|
| 1742 | + add_filter( |
|
| 1743 | + 'FHEE__ee_migration_page__migration_options_template', |
|
| 1744 | + array($this,'use_migration_options_from_ee3_template') |
|
| 1745 | + ); |
|
| 1746 | + } |
|
| 1747 | + |
|
| 1748 | + |
|
| 1749 | + |
|
| 1750 | + public function _migrate_page_hook_simplify_version_strings( |
|
| 1751 | + $old_content, |
|
| 1752 | + $current_db_state, |
|
| 1753 | + $next_db_state, |
|
| 1754 | + $ultimate_db_state = null |
|
| 1755 | + ) { |
|
| 1756 | + return str_replace( |
|
| 1757 | + array($current_db_state, $next_db_state, $ultimate_db_state), |
|
| 1758 | + array(esc_html__('EE3', 'event_espresso'), esc_html__('EE4', 'event_espresso'), esc_html__("EE4", 'event_espresso')), |
|
| 1759 | + $old_content |
|
| 1760 | + ); |
|
| 1761 | + } |
|
| 1762 | + |
|
| 1763 | + |
|
| 1764 | + |
|
| 1765 | + public function _migration_page_hook_simplify_next_db_state($old_content, $next_db_state) |
|
| 1766 | + { |
|
| 1767 | + return str_replace($next_db_state, esc_html__("EE4", 'event_espresso'), $old_content); |
|
| 1768 | + } |
|
| 1769 | + |
|
| 1770 | + |
|
| 1771 | + |
|
| 1772 | + public function _migration_page_hook_option_1_extra_details() |
|
| 1773 | + { |
|
| 1774 | + ?> |
|
| 1775 | 1775 | <p><?php printf(esc_html__( |
| 1776 | - "Note: many of your EE3 shortcodes will be changed to EE4 shortcodes during this migration (among many other things). Should you revert to EE3, then you should restore to your backup or manually change the EE4 shortcodes back to their EE3 equivalents", |
|
| 1777 | - "event_espresso" |
|
| 1778 | - )); ?></p><?php |
|
| 1779 | - } |
|
| 1776 | + "Note: many of your EE3 shortcodes will be changed to EE4 shortcodes during this migration (among many other things). Should you revert to EE3, then you should restore to your backup or manually change the EE4 shortcodes back to their EE3 equivalents", |
|
| 1777 | + "event_espresso" |
|
| 1778 | + )); ?></p><?php |
|
| 1779 | + } |
|
| 1780 | 1780 | |
| 1781 | 1781 | |
| 1782 | 1782 | |
| 1783 | - public function _migration_page_hook_after_migration_options_table() |
|
| 1784 | - { |
|
| 1785 | - ?><p class="ee-attention"> |
|
| 1783 | + public function _migration_page_hook_after_migration_options_table() |
|
| 1784 | + { |
|
| 1785 | + ?><p class="ee-attention"> |
|
| 1786 | 1786 | <strong><span class="reminder-spn"> |
| 1787 | 1787 | <?php _e( |
| 1788 | - "Important note to those using Event Espresso 3 addons: ", |
|
| 1789 | - "event_espresso" |
|
| 1790 | - ); ?></span></strong> |
|
| 1788 | + "Important note to those using Event Espresso 3 addons: ", |
|
| 1789 | + "event_espresso" |
|
| 1790 | + ); ?></span></strong> |
|
| 1791 | 1791 | <br/> |
| 1792 | 1792 | <?php _e( |
| 1793 | - "Unless an addon's description on our website explicitly states that it is compatible with EE4, you should consider it incompatible and know that it WILL NOT WORK correctly with this new version of Event Espresso 4 (EE4). As well, any data for incompatible addons will NOT BE MIGRATED until an updated EE4 compatible version of the addon is available. If you want, or need to keep using your EE3 addons, you should simply continue using EE3 until EE4 compatible versions of your addons become available. To continue using EE3 for now, just deactivate EE4 and reactivate EE3.", |
|
| 1794 | - "event_espresso" |
|
| 1795 | - ); ?> |
|
| 1793 | + "Unless an addon's description on our website explicitly states that it is compatible with EE4, you should consider it incompatible and know that it WILL NOT WORK correctly with this new version of Event Espresso 4 (EE4). As well, any data for incompatible addons will NOT BE MIGRATED until an updated EE4 compatible version of the addon is available. If you want, or need to keep using your EE3 addons, you should simply continue using EE3 until EE4 compatible versions of your addons become available. To continue using EE3 for now, just deactivate EE4 and reactivate EE3.", |
|
| 1794 | + "event_espresso" |
|
| 1795 | + ); ?> |
|
| 1796 | 1796 | </p><?php |
| 1797 | - } |
|
| 1797 | + } |
|
| 1798 | 1798 | |
| 1799 | 1799 | |
| 1800 | 1800 | |
| 1801 | - /** |
|
| 1802 | - * When showing the migration options, show more options and info than normal (ie, give folks the option |
|
| 1803 | - * to start using EE4 without migrating. From EE3 that's fine, because it doesn't actually remove any data, because |
|
| 1804 | - * EE4 doesn't have any yet. But when migrating from EE4 it would remove old data, so its not a great idea). |
|
| 1805 | - * @param $template_filepath |
|
| 1806 | - * @return string |
|
| 1807 | - */ |
|
| 1808 | - public function use_migration_options_from_ee3_template($template_filepath) |
|
| 1809 | - { |
|
| 1810 | - return EE_MAINTENANCE_TEMPLATE_PATH . 'migration_options_from_ee3.template.php'; |
|
| 1811 | - } |
|
| 1801 | + /** |
|
| 1802 | + * When showing the migration options, show more options and info than normal (ie, give folks the option |
|
| 1803 | + * to start using EE4 without migrating. From EE3 that's fine, because it doesn't actually remove any data, because |
|
| 1804 | + * EE4 doesn't have any yet. But when migrating from EE4 it would remove old data, so its not a great idea). |
|
| 1805 | + * @param $template_filepath |
|
| 1806 | + * @return string |
|
| 1807 | + */ |
|
| 1808 | + public function use_migration_options_from_ee3_template($template_filepath) |
|
| 1809 | + { |
|
| 1810 | + return EE_MAINTENANCE_TEMPLATE_PATH . 'migration_options_from_ee3.template.php'; |
|
| 1811 | + } |
|
| 1812 | 1812 | } |
@@ -9,13 +9,13 @@ discard block |
||
| 9 | 9 | // unfortunately, this needs to be done upon INCLUSION of this file, |
| 10 | 10 | // instead of construction, because it only gets constructed on first page load |
| 11 | 11 | // (all other times it gets resurrected from a wordpress option) |
| 12 | -$stages = glob(EE_CORE . 'data_migration_scripts/4_1_0_stages/*'); |
|
| 12 | +$stages = glob(EE_CORE.'data_migration_scripts/4_1_0_stages/*'); |
|
| 13 | 13 | $class_to_filepath = array(); |
| 14 | -if (! empty($stages)) { |
|
| 14 | +if ( ! empty($stages)) { |
|
| 15 | 15 | foreach ($stages as $filepath) { |
| 16 | 16 | $matches = array(); |
| 17 | 17 | preg_match('~4_1_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
| 18 | - $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 18 | + $class_to_filepath[$matches[1]] = $filepath; |
|
| 19 | 19 | } |
| 20 | 20 | } |
| 21 | 21 | // give addons a chance to autoload their stages too |
@@ -87,7 +87,7 @@ discard block |
||
| 87 | 87 | private function _checkin_table_exists() |
| 88 | 88 | { |
| 89 | 89 | global $wpdb; |
| 90 | - $results = $wpdb->get_results("SHOW TABLES LIKE '" . $wpdb->prefix . "events_attendee_checkin" . "'"); |
|
| 90 | + $results = $wpdb->get_results("SHOW TABLES LIKE '".$wpdb->prefix."events_attendee_checkin"."'"); |
|
| 91 | 91 | if ($results) { |
| 92 | 92 | return true; |
| 93 | 93 | } else { |
@@ -103,11 +103,11 @@ discard block |
||
| 103 | 103 | if (version_compare($version_string, '4.0.0.decaf', '<') && version_compare($version_string, '3.1.26', '>=')) { |
| 104 | 104 | // echo "$version_string can be migrated fro"; |
| 105 | 105 | return true; |
| 106 | - } elseif (! $version_string) { |
|
| 106 | + } elseif ( ! $version_string) { |
|
| 107 | 107 | // echo "no version string provided: $version_string"; |
| 108 | 108 | // no version string provided... this must be pre 4.1 |
| 109 | 109 | // because since 4.1 we're |
| 110 | - return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 110 | + return false; // changed mind. dont want people thinking they should migrate yet because they cant |
|
| 111 | 111 | } else { |
| 112 | 112 | // echo "$version_string doesnt apply"; |
| 113 | 113 | return false; |
@@ -119,7 +119,7 @@ discard block |
||
| 119 | 119 | public function schema_changes_before_migration() |
| 120 | 120 | { |
| 121 | 121 | // relies on 4.1's EEH_Activation::create_table |
| 122 | - require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 122 | + require_once(EE_HELPERS.'EEH_Activation.helper.php'); |
|
| 123 | 123 | $table_name = 'esp_answer'; |
| 124 | 124 | $sql = "ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
| 125 | 125 | REG_ID int(10) unsigned NOT NULL, |
@@ -503,12 +503,12 @@ discard block |
||
| 503 | 503 | public function insert_default_states() |
| 504 | 504 | { |
| 505 | 505 | global $wpdb; |
| 506 | - $state_table = $wpdb->prefix . "esp_state"; |
|
| 506 | + $state_table = $wpdb->prefix."esp_state"; |
|
| 507 | 507 | if ($this->_get_table_analysis()->tableExists($state_table)) { |
| 508 | - $SQL = "SELECT COUNT('STA_ID') FROM " . $state_table; |
|
| 508 | + $SQL = "SELECT COUNT('STA_ID') FROM ".$state_table; |
|
| 509 | 509 | $states = $wpdb->get_var($SQL); |
| 510 | - if (! $states) { |
|
| 511 | - $SQL = "INSERT INTO " . $state_table . " |
|
| 510 | + if ( ! $states) { |
|
| 511 | + $SQL = "INSERT INTO ".$state_table." |
|
| 512 | 512 | (STA_ID, CNT_ISO, STA_abbrev, STA_name, STA_active) VALUES |
| 513 | 513 | (1, 'US', 'AK', 'Alaska', 1), |
| 514 | 514 | (2, 'US', 'AL', 'Alabama', 1), |
@@ -596,12 +596,12 @@ discard block |
||
| 596 | 596 | public function insert_default_countries() |
| 597 | 597 | { |
| 598 | 598 | global $wpdb; |
| 599 | - $country_table = $wpdb->prefix . "esp_country"; |
|
| 599 | + $country_table = $wpdb->prefix."esp_country"; |
|
| 600 | 600 | if ($this->_get_table_analysis()->tableExists($country_table)) { |
| 601 | - $SQL = "SELECT COUNT('CNT_ISO') FROM " . $country_table; |
|
| 601 | + $SQL = "SELECT COUNT('CNT_ISO') FROM ".$country_table; |
|
| 602 | 602 | $countries = $wpdb->get_var($SQL); |
| 603 | - if (! $countries) { |
|
| 604 | - $SQL = "INSERT INTO " . $country_table . " |
|
| 603 | + if ( ! $countries) { |
|
| 604 | + $SQL = "INSERT INTO ".$country_table." |
|
| 605 | 605 | (CNT_ISO, CNT_ISO3, RGN_ID, CNT_name, CNT_cur_code, CNT_cur_single, CNT_cur_plural, CNT_cur_sign, CNT_cur_sign_b4, CNT_cur_dec_plc, CNT_tel_code, CNT_is_EU, CNT_active) VALUES |
| 606 | 606 | ('AD', 'AND', 0, 'Andorra', 'EUR', 'Euro', 'Euros', '€', 1, 2, '+376', 0, 0), |
| 607 | 607 | ('AE', 'ARE', 0, 'United Arab Emirates', 'AED', 'Dirham', 'Dirhams', 'د.إ', 1, 2, '+971', 0, 0), |
@@ -846,17 +846,17 @@ discard block |
||
| 846 | 846 | public function insert_default_price_types() |
| 847 | 847 | { |
| 848 | 848 | global $wpdb; |
| 849 | - $price_type_table = $wpdb->prefix . "esp_price_type"; |
|
| 849 | + $price_type_table = $wpdb->prefix."esp_price_type"; |
|
| 850 | 850 | if ($this->_get_table_analysis()->tableExists($price_type_table)) { |
| 851 | - $SQL = 'SELECT COUNT(PRT_ID) FROM ' . $price_type_table; |
|
| 851 | + $SQL = 'SELECT COUNT(PRT_ID) FROM '.$price_type_table; |
|
| 852 | 852 | $price_types_exist = $wpdb->get_var($SQL); |
| 853 | - if (! $price_types_exist) { |
|
| 853 | + if ( ! $price_types_exist) { |
|
| 854 | 854 | $SQL = "INSERT INTO $price_type_table ( PRT_ID, PRT_name, PBT_ID, PRT_is_percent, PRT_order, PRT_deleted ) VALUES |
| 855 | - (1, '" . esc_html__('Base Price', 'event_espresso') . "', 1, 0, 0, 0), |
|
| 856 | - (2, '" . esc_html__('Percent Discount', 'event_espresso') . "', 2, 1, 20, 0), |
|
| 857 | - (3, '" . esc_html__('Fixed Discount', 'event_espresso') . "', 2, 0, 30, 0), |
|
| 858 | - (4, '" . esc_html__('Percent Surcharge', 'event_espresso') . "', 3, 1, 40, 0), |
|
| 859 | - (5, '" . esc_html__('Fixed Surcharge', 'event_espresso') . "', 3, 0, 50, 0);"; |
|
| 855 | + (1, '".esc_html__('Base Price', 'event_espresso')."', 1, 0, 0, 0), |
|
| 856 | + (2, '" . esc_html__('Percent Discount', 'event_espresso')."', 2, 1, 20, 0), |
|
| 857 | + (3, '" . esc_html__('Fixed Discount', 'event_espresso')."', 2, 0, 30, 0), |
|
| 858 | + (4, '" . esc_html__('Percent Surcharge', 'event_espresso')."', 3, 1, 40, 0), |
|
| 859 | + (5, '" . esc_html__('Fixed Surcharge', 'event_espresso')."', 3, 0, 50, 0);"; |
|
| 860 | 860 | $SQL = apply_filters('FHEE__EE_DMS_4_1_0__insert_default_price_types__SQL', $SQL); |
| 861 | 861 | $wpdb->query($SQL); |
| 862 | 862 | } |
@@ -878,11 +878,11 @@ discard block |
||
| 878 | 878 | public function insert_default_prices() |
| 879 | 879 | { |
| 880 | 880 | global $wpdb; |
| 881 | - $price_table = $wpdb->prefix . "esp_price"; |
|
| 881 | + $price_table = $wpdb->prefix."esp_price"; |
|
| 882 | 882 | if ($this->_get_table_analysis()->tableExists($price_table)) { |
| 883 | - $SQL = 'SELECT COUNT(PRC_ID) FROM ' . $price_table; |
|
| 883 | + $SQL = 'SELECT COUNT(PRC_ID) FROM '.$price_table; |
|
| 884 | 884 | $prices_exist = $wpdb->get_var($SQL); |
| 885 | - if (! $prices_exist) { |
|
| 885 | + if ( ! $prices_exist) { |
|
| 886 | 886 | $SQL = "INSERT INTO $price_table |
| 887 | 887 | (PRC_ID, PRT_ID, PRC_amount, PRC_name, PRC_desc, PRC_is_default, PRC_overrides, PRC_order, PRC_deleted, PRC_parent ) VALUES |
| 888 | 888 | (1, 1, '0.00', 'Free Admission', '', 1, null, 0, 0, 0);"; |
@@ -904,11 +904,11 @@ discard block |
||
| 904 | 904 | public function insert_default_tickets() |
| 905 | 905 | { |
| 906 | 906 | global $wpdb; |
| 907 | - $ticket_table = $wpdb->prefix . "esp_ticket"; |
|
| 907 | + $ticket_table = $wpdb->prefix."esp_ticket"; |
|
| 908 | 908 | if ($this->_get_table_analysis()->tableExists($ticket_table)) { |
| 909 | - $SQL = 'SELECT COUNT(TKT_ID) FROM ' . $ticket_table; |
|
| 909 | + $SQL = 'SELECT COUNT(TKT_ID) FROM '.$ticket_table; |
|
| 910 | 910 | $tickets_exist = $wpdb->get_var($SQL); |
| 911 | - if (! $tickets_exist) { |
|
| 911 | + if ( ! $tickets_exist) { |
|
| 912 | 912 | $SQL = "INSERT INTO $ticket_table |
| 913 | 913 | ( TKT_ID, TTM_ID, TKT_name, TKT_description, TKT_qty, TKT_sold, TKT_uses, TKT_min, TKT_max, TKT_price, TKT_start_date, TKT_end_date, TKT_taxable, TKT_order, TKT_row, TKT_is_default, TKT_parent, TKT_deleted ) VALUES |
| 914 | 914 | ( 1, 0, '" |
@@ -918,11 +918,11 @@ discard block |
||
| 918 | 918 | $wpdb->query($SQL); |
| 919 | 919 | } |
| 920 | 920 | } |
| 921 | - $ticket_price_table = $wpdb->prefix . "esp_ticket_price"; |
|
| 921 | + $ticket_price_table = $wpdb->prefix."esp_ticket_price"; |
|
| 922 | 922 | if ($this->_get_table_analysis()->tableExists($ticket_price_table)) { |
| 923 | - $SQL = 'SELECT COUNT(TKP_ID) FROM ' . $ticket_price_table; |
|
| 923 | + $SQL = 'SELECT COUNT(TKP_ID) FROM '.$ticket_price_table; |
|
| 924 | 924 | $ticket_prc_exist = $wpdb->get_var($SQL); |
| 925 | - if (! $ticket_prc_exist) { |
|
| 925 | + if ( ! $ticket_prc_exist) { |
|
| 926 | 926 | $SQL = "INSERT INTO $ticket_price_table |
| 927 | 927 | ( TKP_ID, TKT_ID, PRC_ID ) VALUES |
| 928 | 928 | ( 1, 1, 1 ) |
@@ -946,11 +946,11 @@ discard block |
||
| 946 | 946 | */ |
| 947 | 947 | public function get_or_create_country($country_name) |
| 948 | 948 | { |
| 949 | - if (! $country_name) { |
|
| 949 | + if ( ! $country_name) { |
|
| 950 | 950 | throw new EE_Error(esc_html__("Could not get a country because country name is blank", "event_espresso")); |
| 951 | 951 | } |
| 952 | 952 | global $wpdb; |
| 953 | - $country_table = $wpdb->prefix . "esp_country"; |
|
| 953 | + $country_table = $wpdb->prefix."esp_country"; |
|
| 954 | 954 | if (is_int($country_name)) { |
| 955 | 955 | $country_name = $this->get_iso_from_3_1_country_id($country_name); |
| 956 | 956 | } |
@@ -958,7 +958,7 @@ discard block |
||
| 958 | 958 | CNT_ISO LIKE %s OR |
| 959 | 959 | CNT_ISO3 LIKE %s OR |
| 960 | 960 | CNT_name LIKE %s LIMIT 1", $country_name, $country_name, $country_name), ARRAY_A); |
| 961 | - if (! $country) { |
|
| 961 | + if ( ! $country) { |
|
| 962 | 962 | // insert a new one then |
| 963 | 963 | $cols_n_values = array( |
| 964 | 964 | 'CNT_ISO' => $this->_find_available_country_iso(2), |
@@ -978,28 +978,28 @@ discard block |
||
| 978 | 978 | 'CNT_active' => true, |
| 979 | 979 | ); |
| 980 | 980 | $data_types = array( |
| 981 | - '%s',// CNT_ISO |
|
| 982 | - '%s',// CNT_ISO3 |
|
| 983 | - '%d',// RGN_ID |
|
| 984 | - '%s',// CNT_name |
|
| 985 | - '%s',// CNT_cur_code |
|
| 986 | - '%s',// CNT_cur_single |
|
| 987 | - '%s',// CNT_cur_plural |
|
| 988 | - '%s',// CNT_cur_sign |
|
| 989 | - '%d',// CNT_cur_sign_b4 |
|
| 990 | - '%d',// CNT_cur_dec_plc |
|
| 991 | - '%s',// CNT_cur_dec_mrk |
|
| 992 | - '%s',// CNT_cur_thsnds |
|
| 993 | - '%s',// CNT_tel_code |
|
| 994 | - '%d',// CNT_is_EU |
|
| 995 | - '%d',// CNT_active |
|
| 981 | + '%s', // CNT_ISO |
|
| 982 | + '%s', // CNT_ISO3 |
|
| 983 | + '%d', // RGN_ID |
|
| 984 | + '%s', // CNT_name |
|
| 985 | + '%s', // CNT_cur_code |
|
| 986 | + '%s', // CNT_cur_single |
|
| 987 | + '%s', // CNT_cur_plural |
|
| 988 | + '%s', // CNT_cur_sign |
|
| 989 | + '%d', // CNT_cur_sign_b4 |
|
| 990 | + '%d', // CNT_cur_dec_plc |
|
| 991 | + '%s', // CNT_cur_dec_mrk |
|
| 992 | + '%s', // CNT_cur_thsnds |
|
| 993 | + '%s', // CNT_tel_code |
|
| 994 | + '%d', // CNT_is_EU |
|
| 995 | + '%d', // CNT_active |
|
| 996 | 996 | ); |
| 997 | 997 | $success = $wpdb->insert( |
| 998 | 998 | $country_table, |
| 999 | 999 | $cols_n_values, |
| 1000 | 1000 | $data_types |
| 1001 | 1001 | ); |
| 1002 | - if (! $success) { |
|
| 1002 | + if ( ! $success) { |
|
| 1003 | 1003 | throw new EE_Error($this->_create_error_message_for_db_insertion( |
| 1004 | 1004 | 'N/A', |
| 1005 | 1005 | array('country_id' => $country_name), |
@@ -1024,7 +1024,7 @@ discard block |
||
| 1024 | 1024 | private function _find_available_country_iso($num_letters = 2) |
| 1025 | 1025 | { |
| 1026 | 1026 | global $wpdb; |
| 1027 | - $country_table = $wpdb->prefix . "esp_country"; |
|
| 1027 | + $country_table = $wpdb->prefix."esp_country"; |
|
| 1028 | 1028 | $attempts = 0; |
| 1029 | 1029 | do { |
| 1030 | 1030 | $current_iso = strtoupper(wp_generate_password($num_letters, false)); |
@@ -1035,7 +1035,7 @@ discard block |
||
| 1035 | 1035 | // keep going until we find an available country code, or we arbitrarily |
| 1036 | 1036 | // decide we've tried this enough. Somehow they have way too many countries |
| 1037 | 1037 | // (probably because they're mis-using the EE3 country_id like a custom question) |
| 1038 | - } while (intval($country_with_that_iso) && $attempts < 200); |
|
| 1038 | + }while (intval($country_with_that_iso) && $attempts < 200); |
|
| 1039 | 1039 | return $current_iso; |
| 1040 | 1040 | } |
| 1041 | 1041 | |
@@ -1051,7 +1051,7 @@ discard block |
||
| 1051 | 1051 | */ |
| 1052 | 1052 | public function get_or_create_state($state_name, $country_name = '') |
| 1053 | 1053 | { |
| 1054 | - if (! $state_name) { |
|
| 1054 | + if ( ! $state_name) { |
|
| 1055 | 1055 | throw new EE_Error(esc_html__( |
| 1056 | 1056 | "Could not get-or-create state because no state name was provided", |
| 1057 | 1057 | "event_espresso" |
@@ -1064,12 +1064,12 @@ discard block |
||
| 1064 | 1064 | $country_iso = $this->get_default_country_iso(); |
| 1065 | 1065 | } |
| 1066 | 1066 | global $wpdb; |
| 1067 | - $state_table = $wpdb->prefix . "esp_state"; |
|
| 1067 | + $state_table = $wpdb->prefix."esp_state"; |
|
| 1068 | 1068 | $state = $wpdb->get_row($wpdb->prepare("SELECT * FROM $state_table WHERE |
| 1069 | 1069 | (STA_abbrev LIKE %s OR |
| 1070 | 1070 | STA_name LIKE %s) AND |
| 1071 | 1071 | CNT_ISO LIKE %s LIMIT 1", $state_name, $state_name, $country_iso), ARRAY_A); |
| 1072 | - if (! $state) { |
|
| 1072 | + if ( ! $state) { |
|
| 1073 | 1073 | // insert a new one then |
| 1074 | 1074 | $cols_n_values = array( |
| 1075 | 1075 | 'CNT_ISO' => $country_iso, |
@@ -1078,13 +1078,13 @@ discard block |
||
| 1078 | 1078 | 'STA_active' => true, |
| 1079 | 1079 | ); |
| 1080 | 1080 | $data_types = array( |
| 1081 | - '%s',// CNT_ISO |
|
| 1082 | - '%s',// STA_abbrev |
|
| 1083 | - '%s',// STA_name |
|
| 1084 | - '%d',// STA_active |
|
| 1081 | + '%s', // CNT_ISO |
|
| 1082 | + '%s', // STA_abbrev |
|
| 1083 | + '%s', // STA_name |
|
| 1084 | + '%d', // STA_active |
|
| 1085 | 1085 | ); |
| 1086 | 1086 | $success = $wpdb->insert($state_table, $cols_n_values, $data_types); |
| 1087 | - if (! $success) { |
|
| 1087 | + if ( ! $success) { |
|
| 1088 | 1088 | throw new EE_Error($this->_create_error_message_for_db_insertion( |
| 1089 | 1089 | 'N/A', |
| 1090 | 1090 | array('state' => $state_name, 'country_id' => $country_name), |
@@ -1113,7 +1113,7 @@ discard block |
||
| 1113 | 1113 | { |
| 1114 | 1114 | $matches = array(); |
| 1115 | 1115 | preg_match("~(\\d*):(\\d*)~", $timeString, $matches); |
| 1116 | - if (! $matches || count($matches) < 3) { |
|
| 1116 | + if ( ! $matches || count($matches) < 3) { |
|
| 1117 | 1117 | $hour = '00'; |
| 1118 | 1118 | $minutes = '00'; |
| 1119 | 1119 | } else { |
@@ -1418,7 +1418,7 @@ discard block |
||
| 1418 | 1418 | 'Declined' => 'RPP', |
| 1419 | 1419 | ); |
| 1420 | 1420 | } |
| 1421 | - return isset($mapping[ $payment_status ]) ? $mapping[ $payment_status ] : 'RNA'; |
|
| 1421 | + return isset($mapping[$payment_status]) ? $mapping[$payment_status] : 'RNA'; |
|
| 1422 | 1422 | } |
| 1423 | 1423 | |
| 1424 | 1424 | |
@@ -1442,7 +1442,7 @@ discard block |
||
| 1442 | 1442 | if ($guid) { |
| 1443 | 1443 | // check for an existing attachment post with this guid |
| 1444 | 1444 | $attachment_post_id = $this->_get_image_attachment_id_by_GUID($guid); |
| 1445 | - if (! $attachment_post_id) { |
|
| 1445 | + if ( ! $attachment_post_id) { |
|
| 1446 | 1446 | // post thumbnail with that GUID doesn't exist, we should create one |
| 1447 | 1447 | $attachment_post_id = $this->_create_image_attachment_from_GUID($guid, $migration_stage); |
| 1448 | 1448 | $created_attachment_post = true; |
@@ -1477,7 +1477,7 @@ discard block |
||
| 1477 | 1477 | $original_guid = preg_replace('~-\d*x\d*\.~', '.', $guid_in_old_event, 1); |
| 1478 | 1478 | // do a head request to verify the file exists |
| 1479 | 1479 | $head_response = wp_remote_head($original_guid); |
| 1480 | - if (! $head_response instanceof WP_Error && $head_response['response']['message'] == 'OK') { |
|
| 1480 | + if ( ! $head_response instanceof WP_Error && $head_response['response']['message'] == 'OK') { |
|
| 1481 | 1481 | return $original_guid; |
| 1482 | 1482 | } else { |
| 1483 | 1483 | return $guid_in_old_event; |
@@ -1497,7 +1497,7 @@ discard block |
||
| 1497 | 1497 | */ |
| 1498 | 1498 | private function _create_image_attachment_from_GUID($guid, EE_Data_Migration_Script_Stage $migration_stage) |
| 1499 | 1499 | { |
| 1500 | - if (! $guid) { |
|
| 1500 | + if ( ! $guid) { |
|
| 1501 | 1501 | $migration_stage->add_error(sprintf(esc_html__( |
| 1502 | 1502 | "Cannot create image attachment for a blank GUID!", |
| 1503 | 1503 | "event_espresso" |
@@ -1509,7 +1509,7 @@ discard block |
||
| 1509 | 1509 | // if the file is located remotely, download it to our uploads DIR, because wp_genereate_attachmnet_metadata needs the file to be local |
| 1510 | 1510 | if (strpos($guid, $wp_upload_dir['url']) === false) { |
| 1511 | 1511 | // image is located remotely. download it and place it in the uploads directory |
| 1512 | - if (! is_readable($guid)) { |
|
| 1512 | + if ( ! is_readable($guid)) { |
|
| 1513 | 1513 | $migration_stage->add_error(sprintf(esc_html__( |
| 1514 | 1514 | "Could not create image attachment from non-existent file: %s", |
| 1515 | 1515 | "event_espresso" |
@@ -1524,7 +1524,7 @@ discard block |
||
| 1524 | 1524 | ), $guid)); |
| 1525 | 1525 | return false; |
| 1526 | 1526 | } |
| 1527 | - $local_filepath = $wp_upload_dir['path'] . '/' . basename($guid); |
|
| 1527 | + $local_filepath = $wp_upload_dir['path'].'/'.basename($guid); |
|
| 1528 | 1528 | $savefile = fopen($local_filepath, 'w'); |
| 1529 | 1529 | fwrite($savefile, $contents); |
| 1530 | 1530 | fclose($savefile); |
@@ -1540,7 +1540,7 @@ discard block |
||
| 1540 | 1540 | 'post_status' => 'inherit', |
| 1541 | 1541 | ); |
| 1542 | 1542 | $attach_id = wp_insert_attachment($attachment, $guid); |
| 1543 | - if (! $attach_id) { |
|
| 1543 | + if ( ! $attach_id) { |
|
| 1544 | 1544 | $migration_stage->add_error(sprintf(esc_html__( |
| 1545 | 1545 | "Could not create image attachment post from image '%s'. Attachment data was %s.", |
| 1546 | 1546 | "event_espresso" |
@@ -1549,9 +1549,9 @@ discard block |
||
| 1549 | 1549 | } |
| 1550 | 1550 | // you must first include the image.php file |
| 1551 | 1551 | // for the function wp_generate_attachment_metadata() to work |
| 1552 | - require_once(ABSPATH . 'wp-admin/includes/image.php'); |
|
| 1552 | + require_once(ABSPATH.'wp-admin/includes/image.php'); |
|
| 1553 | 1553 | $attach_data = wp_generate_attachment_metadata($attach_id, $local_filepath); |
| 1554 | - if (! $attach_data) { |
|
| 1554 | + if ( ! $attach_data) { |
|
| 1555 | 1555 | $migration_stage->add_error(sprintf(esc_html__( |
| 1556 | 1556 | "Coudl not genereate attachment metadata for attachment post %d with filepath %s and GUID %s. Please check the file was downloaded properly.", |
| 1557 | 1557 | "event_espresso" |
@@ -1559,7 +1559,7 @@ discard block |
||
| 1559 | 1559 | return $attach_id; |
| 1560 | 1560 | } |
| 1561 | 1561 | $metadata_save_result = wp_update_attachment_metadata($attach_id, $attach_data); |
| 1562 | - if (! $metadata_save_result) { |
|
| 1562 | + if ( ! $metadata_save_result) { |
|
| 1563 | 1563 | $migration_stage->add_error(sprintf(esc_html__( |
| 1564 | 1564 | "Could not update attachment metadata for attachment %d with data %s", |
| 1565 | 1565 | "event_espresso" |
@@ -1605,10 +1605,10 @@ discard block |
||
| 1605 | 1605 | $timezone = null |
| 1606 | 1606 | ) { |
| 1607 | 1607 | $original_tz = $timezone; |
| 1608 | - if (! $timezone) { |
|
| 1608 | + if ( ! $timezone) { |
|
| 1609 | 1609 | $timezone = $this->_get_wp_timezone(); |
| 1610 | 1610 | } |
| 1611 | - if (! $timezone) { |
|
| 1611 | + if ( ! $timezone) { |
|
| 1612 | 1612 | $stage->add_error(sprintf( |
| 1613 | 1613 | esc_html__("Could not find timezone given %s for %s", "event_espresso"), |
| 1614 | 1614 | $original_tz, |
@@ -1741,7 +1741,7 @@ discard block |
||
| 1741 | 1741 | ); |
| 1742 | 1742 | add_filter( |
| 1743 | 1743 | 'FHEE__ee_migration_page__migration_options_template', |
| 1744 | - array($this,'use_migration_options_from_ee3_template') |
|
| 1744 | + array($this, 'use_migration_options_from_ee3_template') |
|
| 1745 | 1745 | ); |
| 1746 | 1746 | } |
| 1747 | 1747 | |
@@ -1807,6 +1807,6 @@ discard block |
||
| 1807 | 1807 | */ |
| 1808 | 1808 | public function use_migration_options_from_ee3_template($template_filepath) |
| 1809 | 1809 | { |
| 1810 | - return EE_MAINTENANCE_TEMPLATE_PATH . 'migration_options_from_ee3.template.php'; |
|
| 1810 | + return EE_MAINTENANCE_TEMPLATE_PATH.'migration_options_from_ee3.template.php'; |
|
| 1811 | 1811 | } |
| 1812 | 1812 | } |
@@ -15,9 +15,9 @@ discard block |
||
| 15 | 15 | $stages = glob(EE_CORE . 'data_migration_scripts/4_9_0_stages/*'); |
| 16 | 16 | $class_to_filepath = array(); |
| 17 | 17 | foreach ($stages as $filepath) { |
| 18 | - $matches = array(); |
|
| 19 | - preg_match('~4_9_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
|
| 20 | - $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 18 | + $matches = array(); |
|
| 19 | + preg_match('~4_9_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
|
| 20 | + $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 21 | 21 | } |
| 22 | 22 | // give addons a chance to autoload their stages too |
| 23 | 23 | $class_to_filepath = apply_filters('FHEE__EE_DMS_4_9_0__autoloaded_stages', $class_to_filepath); |
@@ -36,68 +36,68 @@ discard block |
||
| 36 | 36 | class EE_DMS_Core_4_9_0 extends EE_Data_Migration_Script_Base |
| 37 | 37 | { |
| 38 | 38 | |
| 39 | - /** |
|
| 40 | - * return EE_DMS_Core_4_9_0 |
|
| 41 | - * |
|
| 42 | - * @param TableManager $table_manager |
|
| 43 | - * @param TableAnalysis $table_analysis |
|
| 44 | - */ |
|
| 45 | - public function __construct(TableManager $table_manager = null, TableAnalysis $table_analysis = null) |
|
| 46 | - { |
|
| 47 | - $this->_pretty_name = esc_html__("Data Update to Event Espresso 4.9.0", "event_espresso"); |
|
| 48 | - $this->_priority = 10; |
|
| 49 | - $this->_migration_stages = array( |
|
| 50 | - new EE_DMS_4_9_0_Email_System_Question(), |
|
| 51 | - new EE_DMS_4_9_0_Answers_With_No_Registration(), |
|
| 52 | - ); |
|
| 53 | - parent::__construct($table_manager, $table_analysis); |
|
| 54 | - } |
|
| 39 | + /** |
|
| 40 | + * return EE_DMS_Core_4_9_0 |
|
| 41 | + * |
|
| 42 | + * @param TableManager $table_manager |
|
| 43 | + * @param TableAnalysis $table_analysis |
|
| 44 | + */ |
|
| 45 | + public function __construct(TableManager $table_manager = null, TableAnalysis $table_analysis = null) |
|
| 46 | + { |
|
| 47 | + $this->_pretty_name = esc_html__("Data Update to Event Espresso 4.9.0", "event_espresso"); |
|
| 48 | + $this->_priority = 10; |
|
| 49 | + $this->_migration_stages = array( |
|
| 50 | + new EE_DMS_4_9_0_Email_System_Question(), |
|
| 51 | + new EE_DMS_4_9_0_Answers_With_No_Registration(), |
|
| 52 | + ); |
|
| 53 | + parent::__construct($table_manager, $table_analysis); |
|
| 54 | + } |
|
| 55 | 55 | |
| 56 | 56 | |
| 57 | 57 | |
| 58 | - /** |
|
| 59 | - * Whether to migrate or not. |
|
| 60 | - * |
|
| 61 | - * @param array $version_array |
|
| 62 | - * @return bool |
|
| 63 | - */ |
|
| 64 | - public function can_migrate_from_version($version_array) |
|
| 65 | - { |
|
| 66 | - $version_string = $version_array['Core']; |
|
| 67 | - if (version_compare($version_string, '4.9.0.decaf', '<') && version_compare($version_string, '4.8.0.decaf', '>=')) { |
|
| 68 | - // echo "$version_string can be migrated from"; |
|
| 69 | - return true; |
|
| 70 | - } elseif (! $version_string) { |
|
| 71 | - // echo "no version string provided: $version_string"; |
|
| 72 | - // no version string provided... this must be pre 4.3 |
|
| 73 | - return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 74 | - } else { |
|
| 75 | - // echo "$version_string doesnt apply"; |
|
| 76 | - return false; |
|
| 77 | - } |
|
| 78 | - } |
|
| 58 | + /** |
|
| 59 | + * Whether to migrate or not. |
|
| 60 | + * |
|
| 61 | + * @param array $version_array |
|
| 62 | + * @return bool |
|
| 63 | + */ |
|
| 64 | + public function can_migrate_from_version($version_array) |
|
| 65 | + { |
|
| 66 | + $version_string = $version_array['Core']; |
|
| 67 | + if (version_compare($version_string, '4.9.0.decaf', '<') && version_compare($version_string, '4.8.0.decaf', '>=')) { |
|
| 68 | + // echo "$version_string can be migrated from"; |
|
| 69 | + return true; |
|
| 70 | + } elseif (! $version_string) { |
|
| 71 | + // echo "no version string provided: $version_string"; |
|
| 72 | + // no version string provided... this must be pre 4.3 |
|
| 73 | + return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 74 | + } else { |
|
| 75 | + // echo "$version_string doesnt apply"; |
|
| 76 | + return false; |
|
| 77 | + } |
|
| 78 | + } |
|
| 79 | 79 | |
| 80 | 80 | |
| 81 | 81 | |
| 82 | - /** |
|
| 83 | - * @return bool |
|
| 84 | - */ |
|
| 85 | - public function schema_changes_before_migration() |
|
| 86 | - { |
|
| 87 | - require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 88 | - $now_in_mysql = current_time('mysql', true); |
|
| 89 | - $table_name = 'esp_answer'; |
|
| 90 | - $sql = " ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 82 | + /** |
|
| 83 | + * @return bool |
|
| 84 | + */ |
|
| 85 | + public function schema_changes_before_migration() |
|
| 86 | + { |
|
| 87 | + require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 88 | + $now_in_mysql = current_time('mysql', true); |
|
| 89 | + $table_name = 'esp_answer'; |
|
| 90 | + $sql = " ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 91 | 91 | REG_ID int(10) unsigned NOT NULL, |
| 92 | 92 | QST_ID int(10) unsigned NOT NULL, |
| 93 | 93 | ANS_value text NOT NULL, |
| 94 | 94 | PRIMARY KEY (ANS_ID), |
| 95 | 95 | KEY REG_ID (REG_ID), |
| 96 | 96 | KEY QST_ID (QST_ID)"; |
| 97 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 98 | - $table_name = 'esp_attendee_meta'; |
|
| 99 | - $this->_get_table_manager()->dropIndexIfSizeNot($table_name, 'ATT_email'); |
|
| 100 | - $sql = "ATTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 97 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 98 | + $table_name = 'esp_attendee_meta'; |
|
| 99 | + $this->_get_table_manager()->dropIndexIfSizeNot($table_name, 'ATT_email'); |
|
| 100 | + $sql = "ATTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 101 | 101 | ATT_ID bigint(20) unsigned NOT NULL, |
| 102 | 102 | ATT_fname varchar(45) NOT NULL, |
| 103 | 103 | ATT_lname varchar(45) NOT NULL, |
@@ -114,9 +114,9 @@ discard block |
||
| 114 | 114 | KEY ATT_email (ATT_email(191)), |
| 115 | 115 | KEY ATT_lname (ATT_lname), |
| 116 | 116 | KEY ATT_fname (ATT_fname)"; |
| 117 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 118 | - $table_name = 'esp_checkin'; |
|
| 119 | - $sql = "CHK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 117 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 118 | + $table_name = 'esp_checkin'; |
|
| 119 | + $sql = "CHK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 120 | 120 | REG_ID int(10) unsigned NOT NULL, |
| 121 | 121 | DTT_ID int(10) unsigned NOT NULL, |
| 122 | 122 | CHK_in tinyint(1) unsigned NOT NULL DEFAULT 1, |
@@ -124,9 +124,9 @@ discard block |
||
| 124 | 124 | PRIMARY KEY (CHK_ID), |
| 125 | 125 | KEY REG_ID (REG_ID), |
| 126 | 126 | KEY DTT_ID (DTT_ID)"; |
| 127 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 128 | - $table_name = 'esp_country'; |
|
| 129 | - $sql = "CNT_ISO varchar(2) NOT NULL, |
|
| 127 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 128 | + $table_name = 'esp_country'; |
|
| 129 | + $sql = "CNT_ISO varchar(2) NOT NULL, |
|
| 130 | 130 | CNT_ISO3 varchar(3) NOT NULL, |
| 131 | 131 | RGN_ID tinyint(3) unsigned DEFAULT NULL, |
| 132 | 132 | CNT_name varchar(45) NOT NULL, |
@@ -142,29 +142,29 @@ discard block |
||
| 142 | 142 | CNT_is_EU tinyint(1) DEFAULT '0', |
| 143 | 143 | CNT_active tinyint(1) DEFAULT '0', |
| 144 | 144 | PRIMARY KEY (CNT_ISO)"; |
| 145 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 146 | - $table_name = 'esp_currency'; |
|
| 147 | - $sql = "CUR_code varchar(6) NOT NULL, |
|
| 145 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 146 | + $table_name = 'esp_currency'; |
|
| 147 | + $sql = "CUR_code varchar(6) NOT NULL, |
|
| 148 | 148 | CUR_single varchar(45) DEFAULT 'dollar', |
| 149 | 149 | CUR_plural varchar(45) DEFAULT 'dollars', |
| 150 | 150 | CUR_sign varchar(45) DEFAULT '$', |
| 151 | 151 | CUR_dec_plc varchar(1) NOT NULL DEFAULT '2', |
| 152 | 152 | CUR_active tinyint(1) DEFAULT '0', |
| 153 | 153 | PRIMARY KEY (CUR_code)"; |
| 154 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 155 | - // note: although this table is no longer in use, |
|
| 156 | - // it hasn't been removed because then queries to the model will have errors. |
|
| 157 | - // but you should expect this table and its corresponding model to be removed in |
|
| 158 | - // the next few months |
|
| 159 | - $table_name = 'esp_currency_payment_method'; |
|
| 160 | - $sql = "CPM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 154 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 155 | + // note: although this table is no longer in use, |
|
| 156 | + // it hasn't been removed because then queries to the model will have errors. |
|
| 157 | + // but you should expect this table and its corresponding model to be removed in |
|
| 158 | + // the next few months |
|
| 159 | + $table_name = 'esp_currency_payment_method'; |
|
| 160 | + $sql = "CPM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 161 | 161 | CUR_code varchar(6) NOT NULL, |
| 162 | 162 | PMD_ID int(11) NOT NULL, |
| 163 | 163 | PRIMARY KEY (CPM_ID), |
| 164 | 164 | KEY PMD_ID (PMD_ID)"; |
| 165 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 166 | - $table_name = 'esp_datetime'; |
|
| 167 | - $sql = "DTT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 165 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 166 | + $table_name = 'esp_datetime'; |
|
| 167 | + $sql = "DTT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 168 | 168 | EVT_ID bigint(20) unsigned NOT NULL, |
| 169 | 169 | DTT_name varchar(255) NOT NULL DEFAULT '', |
| 170 | 170 | DTT_description text NOT NULL, |
@@ -181,25 +181,25 @@ discard block |
||
| 181 | 181 | KEY DTT_EVT_start (DTT_EVT_start), |
| 182 | 182 | KEY EVT_ID (EVT_ID), |
| 183 | 183 | KEY DTT_is_primary (DTT_is_primary)"; |
| 184 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 185 | - $table_name = "esp_datetime_ticket"; |
|
| 186 | - $sql = "DTK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 184 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 185 | + $table_name = "esp_datetime_ticket"; |
|
| 186 | + $sql = "DTK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 187 | 187 | DTT_ID int(10) unsigned NOT NULL, |
| 188 | 188 | TKT_ID int(10) unsigned NOT NULL, |
| 189 | 189 | PRIMARY KEY (DTK_ID), |
| 190 | 190 | KEY DTT_ID (DTT_ID), |
| 191 | 191 | KEY TKT_ID (TKT_ID)"; |
| 192 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 193 | - $table_name = 'esp_event_message_template'; |
|
| 194 | - $sql = "EMT_ID bigint(20) unsigned NOT NULL AUTO_INCREMENT, |
|
| 192 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 193 | + $table_name = 'esp_event_message_template'; |
|
| 194 | + $sql = "EMT_ID bigint(20) unsigned NOT NULL AUTO_INCREMENT, |
|
| 195 | 195 | EVT_ID bigint(20) unsigned NOT NULL DEFAULT 0, |
| 196 | 196 | GRP_ID int(10) unsigned NOT NULL DEFAULT 0, |
| 197 | 197 | PRIMARY KEY (EMT_ID), |
| 198 | 198 | KEY EVT_ID (EVT_ID), |
| 199 | 199 | KEY GRP_ID (GRP_ID)"; |
| 200 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 201 | - $table_name = 'esp_event_meta'; |
|
| 202 | - $sql = "EVTM_ID int(10) NOT NULL AUTO_INCREMENT, |
|
| 200 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 201 | + $table_name = 'esp_event_meta'; |
|
| 202 | + $sql = "EVTM_ID int(10) NOT NULL AUTO_INCREMENT, |
|
| 203 | 203 | EVT_ID bigint(20) unsigned NOT NULL, |
| 204 | 204 | EVT_display_desc tinyint(1) unsigned NOT NULL DEFAULT 1, |
| 205 | 205 | EVT_display_ticket_selector tinyint(1) unsigned NOT NULL DEFAULT 1, |
@@ -214,34 +214,34 @@ discard block |
||
| 214 | 214 | EVT_donations tinyint(1) NULL, |
| 215 | 215 | PRIMARY KEY (EVTM_ID), |
| 216 | 216 | KEY EVT_ID (EVT_ID)"; |
| 217 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 218 | - $table_name = 'esp_event_question_group'; |
|
| 219 | - $sql = "EQG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 217 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 218 | + $table_name = 'esp_event_question_group'; |
|
| 219 | + $sql = "EQG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 220 | 220 | EVT_ID bigint(20) unsigned NOT NULL, |
| 221 | 221 | QSG_ID int(10) unsigned NOT NULL, |
| 222 | 222 | EQG_primary tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 223 | 223 | PRIMARY KEY (EQG_ID), |
| 224 | 224 | KEY EVT_ID (EVT_ID), |
| 225 | 225 | KEY QSG_ID (QSG_ID)"; |
| 226 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 227 | - $table_name = 'esp_event_venue'; |
|
| 228 | - $sql = "EVV_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 226 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 227 | + $table_name = 'esp_event_venue'; |
|
| 228 | + $sql = "EVV_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 229 | 229 | EVT_ID bigint(20) unsigned NOT NULL, |
| 230 | 230 | VNU_ID bigint(20) unsigned NOT NULL, |
| 231 | 231 | EVV_primary tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 232 | 232 | PRIMARY KEY (EVV_ID)"; |
| 233 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 234 | - $table_name = 'esp_extra_meta'; |
|
| 235 | - $sql = "EXM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 233 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 234 | + $table_name = 'esp_extra_meta'; |
|
| 235 | + $sql = "EXM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 236 | 236 | OBJ_ID int(11) DEFAULT NULL, |
| 237 | 237 | EXM_type varchar(45) DEFAULT NULL, |
| 238 | 238 | EXM_key varchar(45) DEFAULT NULL, |
| 239 | 239 | EXM_value text, |
| 240 | 240 | PRIMARY KEY (EXM_ID), |
| 241 | 241 | KEY EXM_type (EXM_type,OBJ_ID,EXM_key)"; |
| 242 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 243 | - $table_name = 'esp_extra_join'; |
|
| 244 | - $sql = "EXJ_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 242 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 243 | + $table_name = 'esp_extra_join'; |
|
| 244 | + $sql = "EXJ_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 245 | 245 | EXJ_first_model_id varchar(6) NOT NULL, |
| 246 | 246 | EXJ_first_model_name varchar(20) NOT NULL, |
| 247 | 247 | EXJ_second_model_id varchar(6) NOT NULL, |
@@ -249,9 +249,9 @@ discard block |
||
| 249 | 249 | PRIMARY KEY (EXJ_ID), |
| 250 | 250 | KEY first_model (EXJ_first_model_name,EXJ_first_model_id), |
| 251 | 251 | KEY second_model (EXJ_second_model_name,EXJ_second_model_id)"; |
| 252 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 253 | - $table_name = 'esp_line_item'; |
|
| 254 | - $sql = "LIN_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 252 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 253 | + $table_name = 'esp_line_item'; |
|
| 254 | + $sql = "LIN_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 255 | 255 | LIN_code varchar(245) NOT NULL DEFAULT '', |
| 256 | 256 | TXN_ID int(11) DEFAULT NULL, |
| 257 | 257 | LIN_name varchar(245) NOT NULL DEFAULT '', |
@@ -272,11 +272,11 @@ discard block |
||
| 272 | 272 | KEY txn_type_timestamp (TXN_ID,LIN_type,LIN_timestamp), |
| 273 | 273 | KEY txn_obj_id_obj_type (TXN_ID,OBJ_ID,OBJ_type), |
| 274 | 274 | KEY obj_id_obj_type (OBJ_ID,OBJ_type)"; |
| 275 | - $this->_get_table_manager()->dropIndex('esp_line_item', 'TXN_ID'); |
|
| 276 | - $this->_get_table_manager()->dropIndex('esp_line_item', 'LIN_code'); |
|
| 277 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 278 | - $table_name = 'esp_log'; |
|
| 279 | - $sql = "LOG_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 275 | + $this->_get_table_manager()->dropIndex('esp_line_item', 'TXN_ID'); |
|
| 276 | + $this->_get_table_manager()->dropIndex('esp_line_item', 'LIN_code'); |
|
| 277 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 278 | + $table_name = 'esp_log'; |
|
| 279 | + $sql = "LOG_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 280 | 280 | LOG_time datetime DEFAULT NULL, |
| 281 | 281 | OBJ_ID varchar(45) DEFAULT NULL, |
| 282 | 282 | OBJ_type varchar(45) DEFAULT NULL, |
@@ -287,12 +287,12 @@ discard block |
||
| 287 | 287 | KEY LOG_time (LOG_time), |
| 288 | 288 | KEY OBJ (OBJ_type,OBJ_ID), |
| 289 | 289 | KEY LOG_type (LOG_type)"; |
| 290 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 291 | - $table_name = 'esp_message'; |
|
| 292 | - $this->_get_table_manager()->dropIndexIfSizeNot($table_name, 'MSG_to'); |
|
| 293 | - $this->_get_table_manager()->dropIndexIfSizeNot($table_name, 'MSG_from'); |
|
| 294 | - $this->_get_table_manager()->dropIndexIfSizeNot($table_name, 'MSG_subject'); |
|
| 295 | - $sql = "MSG_ID bigint(20) unsigned NOT NULL AUTO_INCREMENT, |
|
| 290 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 291 | + $table_name = 'esp_message'; |
|
| 292 | + $this->_get_table_manager()->dropIndexIfSizeNot($table_name, 'MSG_to'); |
|
| 293 | + $this->_get_table_manager()->dropIndexIfSizeNot($table_name, 'MSG_from'); |
|
| 294 | + $this->_get_table_manager()->dropIndexIfSizeNot($table_name, 'MSG_subject'); |
|
| 295 | + $sql = "MSG_ID bigint(20) unsigned NOT NULL AUTO_INCREMENT, |
|
| 296 | 296 | GRP_ID int(10) unsigned NULL, |
| 297 | 297 | MSG_token varchar(255) NULL, |
| 298 | 298 | TXN_ID int(10) unsigned NULL, |
@@ -324,18 +324,18 @@ discard block |
||
| 324 | 324 | KEY STS_ID (STS_ID), |
| 325 | 325 | KEY MSG_created (MSG_created), |
| 326 | 326 | KEY MSG_modified (MSG_modified)"; |
| 327 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 328 | - $table_name = 'esp_message_template'; |
|
| 329 | - $sql = "MTP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 327 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 328 | + $table_name = 'esp_message_template'; |
|
| 329 | + $sql = "MTP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 330 | 330 | GRP_ID int(10) unsigned NOT NULL, |
| 331 | 331 | MTP_context varchar(50) NOT NULL, |
| 332 | 332 | MTP_template_field varchar(30) NOT NULL, |
| 333 | 333 | MTP_content text NOT NULL, |
| 334 | 334 | PRIMARY KEY (MTP_ID), |
| 335 | 335 | KEY GRP_ID (GRP_ID)"; |
| 336 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 337 | - $table_name = 'esp_message_template_group'; |
|
| 338 | - $sql = "GRP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 336 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 337 | + $table_name = 'esp_message_template_group'; |
|
| 338 | + $sql = "GRP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 339 | 339 | MTP_user_id int(10) NOT NULL DEFAULT '1', |
| 340 | 340 | MTP_name varchar(245) NOT NULL DEFAULT '', |
| 341 | 341 | MTP_description varchar(245) NOT NULL DEFAULT '', |
@@ -347,9 +347,9 @@ discard block |
||
| 347 | 347 | MTP_is_active tinyint(1) NOT NULL DEFAULT '1', |
| 348 | 348 | PRIMARY KEY (GRP_ID), |
| 349 | 349 | KEY MTP_user_id (MTP_user_id)"; |
| 350 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 351 | - $table_name = 'esp_payment'; |
|
| 352 | - $sql = "PAY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 350 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 351 | + $table_name = 'esp_payment'; |
|
| 352 | + $sql = "PAY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 353 | 353 | TXN_ID int(10) unsigned DEFAULT NULL, |
| 354 | 354 | STS_ID varchar(3) DEFAULT NULL, |
| 355 | 355 | PAY_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
@@ -366,9 +366,9 @@ discard block |
||
| 366 | 366 | PRIMARY KEY (PAY_ID), |
| 367 | 367 | KEY PAY_timestamp (PAY_timestamp), |
| 368 | 368 | KEY TXN_ID (TXN_ID)"; |
| 369 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 370 | - $table_name = 'esp_payment_method'; |
|
| 371 | - $sql = "PMD_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 369 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 370 | + $table_name = 'esp_payment_method'; |
|
| 371 | + $sql = "PMD_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 372 | 372 | PMD_type varchar(124) DEFAULT NULL, |
| 373 | 373 | PMD_name varchar(255) DEFAULT NULL, |
| 374 | 374 | PMD_desc text, |
@@ -384,24 +384,24 @@ discard block |
||
| 384 | 384 | PRIMARY KEY (PMD_ID), |
| 385 | 385 | UNIQUE KEY PMD_slug_UNIQUE (PMD_slug), |
| 386 | 386 | KEY PMD_type (PMD_type)"; |
| 387 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 388 | - $table_name = "esp_ticket_price"; |
|
| 389 | - $sql = "TKP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 387 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 388 | + $table_name = "esp_ticket_price"; |
|
| 389 | + $sql = "TKP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 390 | 390 | TKT_ID int(10) unsigned NOT NULL, |
| 391 | 391 | PRC_ID int(10) unsigned NOT NULL, |
| 392 | 392 | PRIMARY KEY (TKP_ID), |
| 393 | 393 | KEY TKT_ID (TKT_ID), |
| 394 | 394 | KEY PRC_ID (PRC_ID)"; |
| 395 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 396 | - $table_name = "esp_ticket_template"; |
|
| 397 | - $sql = "TTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 395 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 396 | + $table_name = "esp_ticket_template"; |
|
| 397 | + $sql = "TTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 398 | 398 | TTM_name varchar(45) NOT NULL, |
| 399 | 399 | TTM_description text, |
| 400 | 400 | TTM_file varchar(45), |
| 401 | 401 | PRIMARY KEY (TTM_ID)"; |
| 402 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 403 | - $table_name = 'esp_question'; |
|
| 404 | - $sql = 'QST_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 402 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 403 | + $table_name = 'esp_question'; |
|
| 404 | + $sql = 'QST_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 405 | 405 | QST_display_text text NOT NULL, |
| 406 | 406 | QST_admin_label varchar(255) NOT NULL, |
| 407 | 407 | QST_system varchar(25) DEFAULT NULL, |
@@ -415,18 +415,18 @@ discard block |
||
| 415 | 415 | QST_deleted tinyint(2) unsigned NOT NULL DEFAULT 0, |
| 416 | 416 | PRIMARY KEY (QST_ID), |
| 417 | 417 | KEY QST_order (QST_order)'; |
| 418 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 419 | - $table_name = 'esp_question_group_question'; |
|
| 420 | - $sql = "QGQ_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 418 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 419 | + $table_name = 'esp_question_group_question'; |
|
| 420 | + $sql = "QGQ_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 421 | 421 | QSG_ID int(10) unsigned NOT NULL, |
| 422 | 422 | QST_ID int(10) unsigned NOT NULL, |
| 423 | 423 | QGQ_order int(10) unsigned NOT NULL DEFAULT 0, |
| 424 | 424 | PRIMARY KEY (QGQ_ID), |
| 425 | 425 | KEY QST_ID (QST_ID), |
| 426 | 426 | KEY QSG_ID_order (QSG_ID,QGQ_order)"; |
| 427 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 428 | - $table_name = 'esp_question_option'; |
|
| 429 | - $sql = "QSO_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 427 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 428 | + $table_name = 'esp_question_option'; |
|
| 429 | + $sql = "QSO_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 430 | 430 | QSO_value varchar(255) NOT NULL, |
| 431 | 431 | QSO_desc text NOT NULL, |
| 432 | 432 | QST_ID int(10) unsigned NOT NULL, |
@@ -436,9 +436,9 @@ discard block |
||
| 436 | 436 | PRIMARY KEY (QSO_ID), |
| 437 | 437 | KEY QST_ID (QST_ID), |
| 438 | 438 | KEY QSO_order (QSO_order)"; |
| 439 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 440 | - $table_name = 'esp_registration'; |
|
| 441 | - $sql = "REG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 439 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 440 | + $table_name = 'esp_registration'; |
|
| 441 | + $sql = "REG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 442 | 442 | EVT_ID bigint(20) unsigned NOT NULL, |
| 443 | 443 | ATT_ID bigint(20) unsigned NOT NULL, |
| 444 | 444 | TXN_ID int(10) unsigned NOT NULL, |
@@ -462,18 +462,18 @@ discard block |
||
| 462 | 462 | KEY TKT_ID (TKT_ID), |
| 463 | 463 | KEY EVT_ID (EVT_ID), |
| 464 | 464 | KEY STS_ID (STS_ID)"; |
| 465 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 466 | - $table_name = 'esp_registration_payment'; |
|
| 467 | - $sql = "RPY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 465 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 466 | + $table_name = 'esp_registration_payment'; |
|
| 467 | + $sql = "RPY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 468 | 468 | REG_ID int(10) unsigned NOT NULL, |
| 469 | 469 | PAY_ID int(10) unsigned NULL, |
| 470 | 470 | RPY_amount decimal(12,3) NOT NULL DEFAULT '0.00', |
| 471 | 471 | PRIMARY KEY (RPY_ID), |
| 472 | 472 | KEY REG_ID (REG_ID), |
| 473 | 473 | KEY PAY_ID (PAY_ID)"; |
| 474 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 475 | - $table_name = 'esp_state'; |
|
| 476 | - $sql = "STA_ID smallint(5) unsigned NOT NULL AUTO_INCREMENT, |
|
| 474 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 475 | + $table_name = 'esp_state'; |
|
| 476 | + $sql = "STA_ID smallint(5) unsigned NOT NULL AUTO_INCREMENT, |
|
| 477 | 477 | CNT_ISO varchar(2) NOT NULL, |
| 478 | 478 | STA_abbrev varchar(24) NOT NULL, |
| 479 | 479 | STA_name varchar(100) NOT NULL, |
@@ -481,9 +481,9 @@ discard block |
||
| 481 | 481 | PRIMARY KEY (STA_ID), |
| 482 | 482 | KEY STA_abbrev (STA_abbrev), |
| 483 | 483 | KEY CNT_ISO (CNT_ISO)"; |
| 484 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 485 | - $table_name = 'esp_status'; |
|
| 486 | - $sql = "STS_ID varchar(3) NOT NULL, |
|
| 484 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 485 | + $table_name = 'esp_status'; |
|
| 486 | + $sql = "STS_ID varchar(3) NOT NULL, |
|
| 487 | 487 | STS_code varchar(45) NOT NULL, |
| 488 | 488 | STS_type varchar(45) NOT NULL, |
| 489 | 489 | STS_can_edit tinyint(1) NOT NULL DEFAULT 0, |
@@ -491,9 +491,9 @@ discard block |
||
| 491 | 491 | STS_open tinyint(1) NOT NULL DEFAULT 1, |
| 492 | 492 | UNIQUE KEY STS_ID_UNIQUE (STS_ID), |
| 493 | 493 | KEY STS_type (STS_type)"; |
| 494 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 495 | - $table_name = 'esp_transaction'; |
|
| 496 | - $sql = "TXN_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 494 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 495 | + $table_name = 'esp_transaction'; |
|
| 496 | + $sql = "TXN_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 497 | 497 | TXN_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
| 498 | 498 | TXN_total decimal(12,3) DEFAULT '0.00', |
| 499 | 499 | TXN_paid decimal(12,3) NOT NULL DEFAULT '0.00', |
@@ -505,9 +505,9 @@ discard block |
||
| 505 | 505 | PRIMARY KEY (TXN_ID), |
| 506 | 506 | KEY TXN_timestamp (TXN_timestamp), |
| 507 | 507 | KEY STS_ID (STS_ID)"; |
| 508 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 509 | - $table_name = 'esp_venue_meta'; |
|
| 510 | - $sql = "VNUM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 508 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 509 | + $table_name = 'esp_venue_meta'; |
|
| 510 | + $sql = "VNUM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 511 | 511 | VNU_ID bigint(20) unsigned NOT NULL DEFAULT 0, |
| 512 | 512 | VNU_address varchar(255) DEFAULT NULL, |
| 513 | 513 | VNU_address2 varchar(255) DEFAULT NULL, |
@@ -526,10 +526,10 @@ discard block |
||
| 526 | 526 | KEY VNU_ID (VNU_ID), |
| 527 | 527 | KEY STA_ID (STA_ID), |
| 528 | 528 | KEY CNT_ISO (CNT_ISO)"; |
| 529 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 530 | - // modified tables |
|
| 531 | - $table_name = "esp_price"; |
|
| 532 | - $sql = "PRC_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 529 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 530 | + // modified tables |
|
| 531 | + $table_name = "esp_price"; |
|
| 532 | + $sql = "PRC_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 533 | 533 | PRT_ID tinyint(3) unsigned NOT NULL, |
| 534 | 534 | PRC_amount decimal(12,3) NOT NULL DEFAULT '0.00', |
| 535 | 535 | PRC_name varchar(245) NOT NULL, |
@@ -542,9 +542,9 @@ discard block |
||
| 542 | 542 | PRC_parent int(10) unsigned DEFAULT 0, |
| 543 | 543 | PRIMARY KEY (PRC_ID), |
| 544 | 544 | KEY PRT_ID (PRT_ID)"; |
| 545 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 546 | - $table_name = "esp_price_type"; |
|
| 547 | - $sql = "PRT_ID tinyint(3) unsigned NOT NULL AUTO_INCREMENT, |
|
| 545 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 546 | + $table_name = "esp_price_type"; |
|
| 547 | + $sql = "PRT_ID tinyint(3) unsigned NOT NULL AUTO_INCREMENT, |
|
| 548 | 548 | PRT_name varchar(45) NOT NULL, |
| 549 | 549 | PBT_ID tinyint(3) unsigned NOT NULL DEFAULT '1', |
| 550 | 550 | PRT_is_percent tinyint(1) NOT NULL DEFAULT '0', |
@@ -553,9 +553,9 @@ discard block |
||
| 553 | 553 | PRT_deleted tinyint(1) NOT NULL DEFAULT '0', |
| 554 | 554 | UNIQUE KEY PRT_name_UNIQUE (PRT_name), |
| 555 | 555 | PRIMARY KEY (PRT_ID)"; |
| 556 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 557 | - $table_name = "esp_ticket"; |
|
| 558 | - $sql = "TKT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 556 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 557 | + $table_name = "esp_ticket"; |
|
| 558 | + $sql = "TKT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 559 | 559 | TTM_ID int(10) unsigned NOT NULL, |
| 560 | 560 | TKT_name varchar(245) NOT NULL DEFAULT '', |
| 561 | 561 | TKT_description text NOT NULL, |
@@ -578,9 +578,9 @@ discard block |
||
| 578 | 578 | TKT_deleted tinyint(1) NOT NULL DEFAULT '0', |
| 579 | 579 | PRIMARY KEY (TKT_ID), |
| 580 | 580 | KEY TKT_start_date (TKT_start_date)"; |
| 581 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 582 | - $table_name = 'esp_question_group'; |
|
| 583 | - $sql = 'QSG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 581 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 582 | + $table_name = 'esp_question_group'; |
|
| 583 | + $sql = 'QSG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 584 | 584 | QSG_name varchar(255) NOT NULL, |
| 585 | 585 | QSG_identifier varchar(100) NOT NULL, |
| 586 | 586 | QSG_desc text NULL, |
@@ -593,159 +593,159 @@ discard block |
||
| 593 | 593 | PRIMARY KEY (QSG_ID), |
| 594 | 594 | UNIQUE KEY QSG_identifier_UNIQUE (QSG_identifier), |
| 595 | 595 | KEY QSG_order (QSG_order)'; |
| 596 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 597 | - $this->insert_default_data(); |
|
| 598 | - return true; |
|
| 599 | - } |
|
| 596 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 597 | + $this->insert_default_data(); |
|
| 598 | + return true; |
|
| 599 | + } |
|
| 600 | 600 | |
| 601 | - /** |
|
| 602 | - * Inserts default data after parent was called. |
|
| 603 | - * @since 4.10.0.p |
|
| 604 | - * @throws EE_Error |
|
| 605 | - * @throws InvalidArgumentException |
|
| 606 | - * @throws ReflectionException |
|
| 607 | - * @throws InvalidDataTypeException |
|
| 608 | - * @throws InvalidInterfaceException |
|
| 609 | - */ |
|
| 610 | - public function insert_default_data() |
|
| 611 | - { |
|
| 612 | - /** @var EE_DMS_Core_4_1_0 $script_4_1_defaults */ |
|
| 613 | - $script_4_1_defaults = EE_Registry::instance()->load_dms('Core_4_1_0'); |
|
| 614 | - // (because many need to convert old string states to foreign keys into the states table) |
|
| 615 | - $script_4_1_defaults->insert_default_states(); |
|
| 616 | - $script_4_1_defaults->insert_default_countries(); |
|
| 617 | - /** @var EE_DMS_Core_4_5_0 $script_4_5_defaults */ |
|
| 618 | - $script_4_5_defaults = EE_Registry::instance()->load_dms('Core_4_5_0'); |
|
| 619 | - $script_4_5_defaults->insert_default_price_types(); |
|
| 620 | - $script_4_5_defaults->insert_default_prices(); |
|
| 621 | - $script_4_5_defaults->insert_default_tickets(); |
|
| 622 | - /** @var EE_DMS_Core_4_6_0 $script_4_6_defaults */ |
|
| 623 | - $script_4_6_defaults = EE_Registry::instance()->load_dms('Core_4_6_0'); |
|
| 624 | - $script_4_6_defaults->add_default_admin_only_payments(); |
|
| 625 | - $script_4_6_defaults->insert_default_currencies(); |
|
| 626 | - /** @var EE_DMS_Core_4_8_0 $script_4_8_defaults */ |
|
| 627 | - $script_4_8_defaults = EE_Registry::instance()->load_dms('Core_4_8_0'); |
|
| 628 | - $script_4_8_defaults->verify_new_countries(); |
|
| 629 | - $script_4_8_defaults->verify_new_currencies(); |
|
| 630 | - $this->verify_db_collations(); |
|
| 631 | - $this->verify_db_collations_again(); |
|
| 632 | - } |
|
| 601 | + /** |
|
| 602 | + * Inserts default data after parent was called. |
|
| 603 | + * @since 4.10.0.p |
|
| 604 | + * @throws EE_Error |
|
| 605 | + * @throws InvalidArgumentException |
|
| 606 | + * @throws ReflectionException |
|
| 607 | + * @throws InvalidDataTypeException |
|
| 608 | + * @throws InvalidInterfaceException |
|
| 609 | + */ |
|
| 610 | + public function insert_default_data() |
|
| 611 | + { |
|
| 612 | + /** @var EE_DMS_Core_4_1_0 $script_4_1_defaults */ |
|
| 613 | + $script_4_1_defaults = EE_Registry::instance()->load_dms('Core_4_1_0'); |
|
| 614 | + // (because many need to convert old string states to foreign keys into the states table) |
|
| 615 | + $script_4_1_defaults->insert_default_states(); |
|
| 616 | + $script_4_1_defaults->insert_default_countries(); |
|
| 617 | + /** @var EE_DMS_Core_4_5_0 $script_4_5_defaults */ |
|
| 618 | + $script_4_5_defaults = EE_Registry::instance()->load_dms('Core_4_5_0'); |
|
| 619 | + $script_4_5_defaults->insert_default_price_types(); |
|
| 620 | + $script_4_5_defaults->insert_default_prices(); |
|
| 621 | + $script_4_5_defaults->insert_default_tickets(); |
|
| 622 | + /** @var EE_DMS_Core_4_6_0 $script_4_6_defaults */ |
|
| 623 | + $script_4_6_defaults = EE_Registry::instance()->load_dms('Core_4_6_0'); |
|
| 624 | + $script_4_6_defaults->add_default_admin_only_payments(); |
|
| 625 | + $script_4_6_defaults->insert_default_currencies(); |
|
| 626 | + /** @var EE_DMS_Core_4_8_0 $script_4_8_defaults */ |
|
| 627 | + $script_4_8_defaults = EE_Registry::instance()->load_dms('Core_4_8_0'); |
|
| 628 | + $script_4_8_defaults->verify_new_countries(); |
|
| 629 | + $script_4_8_defaults->verify_new_currencies(); |
|
| 630 | + $this->verify_db_collations(); |
|
| 631 | + $this->verify_db_collations_again(); |
|
| 632 | + } |
|
| 633 | 633 | |
| 634 | 634 | |
| 635 | 635 | |
| 636 | - /** |
|
| 637 | - * @return boolean |
|
| 638 | - */ |
|
| 639 | - public function schema_changes_after_migration() |
|
| 640 | - { |
|
| 641 | - return true; |
|
| 642 | - } |
|
| 636 | + /** |
|
| 637 | + * @return boolean |
|
| 638 | + */ |
|
| 639 | + public function schema_changes_after_migration() |
|
| 640 | + { |
|
| 641 | + return true; |
|
| 642 | + } |
|
| 643 | 643 | |
| 644 | 644 | |
| 645 | 645 | |
| 646 | - public function migration_page_hooks() |
|
| 647 | - { |
|
| 648 | - } |
|
| 646 | + public function migration_page_hooks() |
|
| 647 | + { |
|
| 648 | + } |
|
| 649 | 649 | |
| 650 | 650 | |
| 651 | 651 | |
| 652 | - /** |
|
| 653 | - * Verify all EE4 models' tables use utf8mb4 collation |
|
| 654 | - * |
|
| 655 | - * @return void |
|
| 656 | - */ |
|
| 657 | - public function verify_db_collations() |
|
| 658 | - { |
|
| 659 | - global $wpdb; |
|
| 660 | - // double-check we haven't already done it or that that the DB doesn't support utf8mb4 |
|
| 661 | - if ('utf8mb4' !== $wpdb->charset |
|
| 662 | - || get_option('ee_verified_db_collations', false)) { |
|
| 663 | - return; |
|
| 664 | - } |
|
| 665 | - // grab tables from each model |
|
| 666 | - $tables_to_check = array(); |
|
| 667 | - foreach (EE_Registry::instance()->non_abstract_db_models as $model_name) { |
|
| 668 | - if (method_exists($model_name, 'instance')) { |
|
| 669 | - $model_obj = call_user_func(array($model_name, 'instance')); |
|
| 670 | - if ($model_obj instanceof EEM_Base) { |
|
| 671 | - foreach ($model_obj->get_tables() as $table) { |
|
| 672 | - if (strpos($table->get_table_name(), 'esp_') |
|
| 673 | - && (is_main_site()// for main tables, verify global tables |
|
| 674 | - || ! $table->is_global()// if not the main site, then only verify non-global tables (avoid doubling up) |
|
| 675 | - ) |
|
| 676 | - && function_exists('maybe_convert_table_to_utf8mb4') |
|
| 677 | - ) { |
|
| 678 | - $tables_to_check[] = $table->get_table_name(); |
|
| 679 | - } |
|
| 680 | - } |
|
| 681 | - } |
|
| 682 | - } |
|
| 683 | - } |
|
| 684 | - // and let's just be sure these addons' tables get migrated too. They already get handled if their addons are active |
|
| 685 | - // when this code is run, but not otherwise. Once we record what tables EE added, we'll be able to use that instead |
|
| 686 | - // of hard-coding this |
|
| 687 | - $addon_tables = array( |
|
| 688 | - // mailchimp |
|
| 689 | - 'esp_event_mailchimp_list_group', |
|
| 690 | - 'esp_event_question_mailchimp_field', |
|
| 691 | - // multisite |
|
| 692 | - 'esp_blog_meta', |
|
| 693 | - // people |
|
| 694 | - 'esp_people_to_post', |
|
| 695 | - // promotions |
|
| 696 | - 'esp_promotion', |
|
| 697 | - 'esp_promotion_object', |
|
| 698 | - ); |
|
| 699 | - foreach ($addon_tables as $table_name) { |
|
| 700 | - $tables_to_check[] = $table_name; |
|
| 701 | - } |
|
| 702 | - $this->_verify_db_collations_for_tables(array_unique($tables_to_check)); |
|
| 703 | - // ok and now let's remember this was done (without needing to check the db schemas all over again) |
|
| 704 | - add_option('ee_verified_db_collations', true, null, 'no'); |
|
| 705 | - // seeing how this ran with the fix from 10435, no need to check again |
|
| 706 | - add_option('ee_verified_db_collations_again', true, null, 'no'); |
|
| 707 | - } |
|
| 652 | + /** |
|
| 653 | + * Verify all EE4 models' tables use utf8mb4 collation |
|
| 654 | + * |
|
| 655 | + * @return void |
|
| 656 | + */ |
|
| 657 | + public function verify_db_collations() |
|
| 658 | + { |
|
| 659 | + global $wpdb; |
|
| 660 | + // double-check we haven't already done it or that that the DB doesn't support utf8mb4 |
|
| 661 | + if ('utf8mb4' !== $wpdb->charset |
|
| 662 | + || get_option('ee_verified_db_collations', false)) { |
|
| 663 | + return; |
|
| 664 | + } |
|
| 665 | + // grab tables from each model |
|
| 666 | + $tables_to_check = array(); |
|
| 667 | + foreach (EE_Registry::instance()->non_abstract_db_models as $model_name) { |
|
| 668 | + if (method_exists($model_name, 'instance')) { |
|
| 669 | + $model_obj = call_user_func(array($model_name, 'instance')); |
|
| 670 | + if ($model_obj instanceof EEM_Base) { |
|
| 671 | + foreach ($model_obj->get_tables() as $table) { |
|
| 672 | + if (strpos($table->get_table_name(), 'esp_') |
|
| 673 | + && (is_main_site()// for main tables, verify global tables |
|
| 674 | + || ! $table->is_global()// if not the main site, then only verify non-global tables (avoid doubling up) |
|
| 675 | + ) |
|
| 676 | + && function_exists('maybe_convert_table_to_utf8mb4') |
|
| 677 | + ) { |
|
| 678 | + $tables_to_check[] = $table->get_table_name(); |
|
| 679 | + } |
|
| 680 | + } |
|
| 681 | + } |
|
| 682 | + } |
|
| 683 | + } |
|
| 684 | + // and let's just be sure these addons' tables get migrated too. They already get handled if their addons are active |
|
| 685 | + // when this code is run, but not otherwise. Once we record what tables EE added, we'll be able to use that instead |
|
| 686 | + // of hard-coding this |
|
| 687 | + $addon_tables = array( |
|
| 688 | + // mailchimp |
|
| 689 | + 'esp_event_mailchimp_list_group', |
|
| 690 | + 'esp_event_question_mailchimp_field', |
|
| 691 | + // multisite |
|
| 692 | + 'esp_blog_meta', |
|
| 693 | + // people |
|
| 694 | + 'esp_people_to_post', |
|
| 695 | + // promotions |
|
| 696 | + 'esp_promotion', |
|
| 697 | + 'esp_promotion_object', |
|
| 698 | + ); |
|
| 699 | + foreach ($addon_tables as $table_name) { |
|
| 700 | + $tables_to_check[] = $table_name; |
|
| 701 | + } |
|
| 702 | + $this->_verify_db_collations_for_tables(array_unique($tables_to_check)); |
|
| 703 | + // ok and now let's remember this was done (without needing to check the db schemas all over again) |
|
| 704 | + add_option('ee_verified_db_collations', true, null, 'no'); |
|
| 705 | + // seeing how this ran with the fix from 10435, no need to check again |
|
| 706 | + add_option('ee_verified_db_collations_again', true, null, 'no'); |
|
| 707 | + } |
|
| 708 | 708 | |
| 709 | 709 | |
| 710 | 710 | |
| 711 | - /** |
|
| 712 | - * Verifies DB collations because a bug was discovered on https://events.codebasehq.com/projects/event-espresso/tickets/10435 |
|
| 713 | - * which meant some DB collations might not have been updated |
|
| 714 | - * @return void |
|
| 715 | - */ |
|
| 716 | - public function verify_db_collations_again() |
|
| 717 | - { |
|
| 718 | - global $wpdb; |
|
| 719 | - // double-check we haven't already done this or that the DB doesn't support it |
|
| 720 | - // compare to how WordPress' upgrade_430() function does this check |
|
| 721 | - if ('utf8mb4' !== $wpdb->charset |
|
| 722 | - || get_option('ee_verified_db_collations_again', false)) { |
|
| 723 | - return; |
|
| 724 | - } |
|
| 725 | - $tables_to_check = array( |
|
| 726 | - 'esp_attendee_meta', |
|
| 727 | - 'esp_message' |
|
| 728 | - ); |
|
| 729 | - $this->_verify_db_collations_for_tables(array_unique($tables_to_check)); |
|
| 730 | - add_option('ee_verified_db_collations_again', true, null, 'no'); |
|
| 731 | - } |
|
| 711 | + /** |
|
| 712 | + * Verifies DB collations because a bug was discovered on https://events.codebasehq.com/projects/event-espresso/tickets/10435 |
|
| 713 | + * which meant some DB collations might not have been updated |
|
| 714 | + * @return void |
|
| 715 | + */ |
|
| 716 | + public function verify_db_collations_again() |
|
| 717 | + { |
|
| 718 | + global $wpdb; |
|
| 719 | + // double-check we haven't already done this or that the DB doesn't support it |
|
| 720 | + // compare to how WordPress' upgrade_430() function does this check |
|
| 721 | + if ('utf8mb4' !== $wpdb->charset |
|
| 722 | + || get_option('ee_verified_db_collations_again', false)) { |
|
| 723 | + return; |
|
| 724 | + } |
|
| 725 | + $tables_to_check = array( |
|
| 726 | + 'esp_attendee_meta', |
|
| 727 | + 'esp_message' |
|
| 728 | + ); |
|
| 729 | + $this->_verify_db_collations_for_tables(array_unique($tables_to_check)); |
|
| 730 | + add_option('ee_verified_db_collations_again', true, null, 'no'); |
|
| 731 | + } |
|
| 732 | 732 | |
| 733 | 733 | |
| 734 | 734 | |
| 735 | - /** |
|
| 736 | - * Runs maybe_convert_table_to_utf8mb4 on the specified tables |
|
| 737 | - * @param $tables_to_check |
|
| 738 | - * @return boolean true if logic ran, false if it didn't |
|
| 739 | - */ |
|
| 740 | - protected function _verify_db_collations_for_tables($tables_to_check) |
|
| 741 | - { |
|
| 742 | - foreach ($tables_to_check as $table_name) { |
|
| 743 | - $table_name = $this->_table_analysis->ensureTableNameHasPrefix($table_name); |
|
| 744 | - if (! apply_filters('FHEE__EE_DMS_Core_4_9_0__verify_db_collations__check_overridden', false, $table_name) |
|
| 745 | - && $this->_get_table_analysis()->tableExists($table_name) |
|
| 746 | - ) { |
|
| 747 | - maybe_convert_table_to_utf8mb4($table_name); |
|
| 748 | - } |
|
| 749 | - } |
|
| 750 | - } |
|
| 735 | + /** |
|
| 736 | + * Runs maybe_convert_table_to_utf8mb4 on the specified tables |
|
| 737 | + * @param $tables_to_check |
|
| 738 | + * @return boolean true if logic ran, false if it didn't |
|
| 739 | + */ |
|
| 740 | + protected function _verify_db_collations_for_tables($tables_to_check) |
|
| 741 | + { |
|
| 742 | + foreach ($tables_to_check as $table_name) { |
|
| 743 | + $table_name = $this->_table_analysis->ensureTableNameHasPrefix($table_name); |
|
| 744 | + if (! apply_filters('FHEE__EE_DMS_Core_4_9_0__verify_db_collations__check_overridden', false, $table_name) |
|
| 745 | + && $this->_get_table_analysis()->tableExists($table_name) |
|
| 746 | + ) { |
|
| 747 | + maybe_convert_table_to_utf8mb4($table_name); |
|
| 748 | + } |
|
| 749 | + } |
|
| 750 | + } |
|
| 751 | 751 | } |
@@ -12,12 +12,12 @@ discard block |
||
| 12 | 12 | // unfortunately, this needs to be done upon INCLUSION of this file, |
| 13 | 13 | // instead of construction, because it only gets constructed on first page load |
| 14 | 14 | // (all other times it gets resurrected from a wordpress option) |
| 15 | -$stages = glob(EE_CORE . 'data_migration_scripts/4_9_0_stages/*'); |
|
| 15 | +$stages = glob(EE_CORE.'data_migration_scripts/4_9_0_stages/*'); |
|
| 16 | 16 | $class_to_filepath = array(); |
| 17 | 17 | foreach ($stages as $filepath) { |
| 18 | 18 | $matches = array(); |
| 19 | 19 | preg_match('~4_9_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
| 20 | - $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 20 | + $class_to_filepath[$matches[1]] = $filepath; |
|
| 21 | 21 | } |
| 22 | 22 | // give addons a chance to autoload their stages too |
| 23 | 23 | $class_to_filepath = apply_filters('FHEE__EE_DMS_4_9_0__autoloaded_stages', $class_to_filepath); |
@@ -67,10 +67,10 @@ discard block |
||
| 67 | 67 | if (version_compare($version_string, '4.9.0.decaf', '<') && version_compare($version_string, '4.8.0.decaf', '>=')) { |
| 68 | 68 | // echo "$version_string can be migrated from"; |
| 69 | 69 | return true; |
| 70 | - } elseif (! $version_string) { |
|
| 70 | + } elseif ( ! $version_string) { |
|
| 71 | 71 | // echo "no version string provided: $version_string"; |
| 72 | 72 | // no version string provided... this must be pre 4.3 |
| 73 | - return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 73 | + return false; // changed mind. dont want people thinking they should migrate yet because they cant |
|
| 74 | 74 | } else { |
| 75 | 75 | // echo "$version_string doesnt apply"; |
| 76 | 76 | return false; |
@@ -84,7 +84,7 @@ discard block |
||
| 84 | 84 | */ |
| 85 | 85 | public function schema_changes_before_migration() |
| 86 | 86 | { |
| 87 | - require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 87 | + require_once(EE_HELPERS.'EEH_Activation.helper.php'); |
|
| 88 | 88 | $now_in_mysql = current_time('mysql', true); |
| 89 | 89 | $table_name = 'esp_answer'; |
| 90 | 90 | $sql = " ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
@@ -741,7 +741,7 @@ discard block |
||
| 741 | 741 | { |
| 742 | 742 | foreach ($tables_to_check as $table_name) { |
| 743 | 743 | $table_name = $this->_table_analysis->ensureTableNameHasPrefix($table_name); |
| 744 | - if (! apply_filters('FHEE__EE_DMS_Core_4_9_0__verify_db_collations__check_overridden', false, $table_name) |
|
| 744 | + if ( ! apply_filters('FHEE__EE_DMS_Core_4_9_0__verify_db_collations__check_overridden', false, $table_name) |
|
| 745 | 745 | && $this->_get_table_analysis()->tableExists($table_name) |
| 746 | 746 | ) { |
| 747 | 747 | maybe_convert_table_to_utf8mb4($table_name); |
@@ -14,11 +14,11 @@ discard block |
||
| 14 | 14 | $stages = glob(EE_CORE . 'data_migration_scripts/4_3_0_stages/*'); |
| 15 | 15 | $class_to_filepath = array(); |
| 16 | 16 | if (! empty($stages)) { |
| 17 | - foreach ($stages as $filepath) { |
|
| 18 | - $matches = array(); |
|
| 19 | - preg_match('~4_3_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
|
| 20 | - $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 21 | - } |
|
| 17 | + foreach ($stages as $filepath) { |
|
| 18 | + $matches = array(); |
|
| 19 | + preg_match('~4_3_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
|
| 20 | + $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 21 | + } |
|
| 22 | 22 | } |
| 23 | 23 | // give addons a chance to autoload their stages too |
| 24 | 24 | $class_to_filepath = apply_filters('FHEE__EE_DMS_4_3_0__autoloaded_stages', $class_to_filepath); |
@@ -31,56 +31,56 @@ discard block |
||
| 31 | 31 | |
| 32 | 32 | |
| 33 | 33 | |
| 34 | - /** |
|
| 35 | - * EE_DMS_Core_4_3_0 constructor. |
|
| 36 | - * |
|
| 37 | - * @param TableManager $table_manager |
|
| 38 | - * @param TableAnalysis $table_analysis |
|
| 39 | - */ |
|
| 40 | - public function __construct(TableManager $table_manager = null, TableAnalysis $table_analysis = null) |
|
| 41 | - { |
|
| 42 | - $this->_pretty_name = __("Data Update to Event Espresso 4.3.0", "event_espresso"); |
|
| 43 | - $this->_priority = 10; |
|
| 44 | - $this->_migration_stages = array( |
|
| 45 | - new EE_DMS_4_3_0_question_option_order(), |
|
| 46 | - new EE_DMS_4_3_0_event_message_templates(), |
|
| 47 | - ); |
|
| 48 | - parent::__construct($table_manager, $table_analysis); |
|
| 49 | - } |
|
| 34 | + /** |
|
| 35 | + * EE_DMS_Core_4_3_0 constructor. |
|
| 36 | + * |
|
| 37 | + * @param TableManager $table_manager |
|
| 38 | + * @param TableAnalysis $table_analysis |
|
| 39 | + */ |
|
| 40 | + public function __construct(TableManager $table_manager = null, TableAnalysis $table_analysis = null) |
|
| 41 | + { |
|
| 42 | + $this->_pretty_name = __("Data Update to Event Espresso 4.3.0", "event_espresso"); |
|
| 43 | + $this->_priority = 10; |
|
| 44 | + $this->_migration_stages = array( |
|
| 45 | + new EE_DMS_4_3_0_question_option_order(), |
|
| 46 | + new EE_DMS_4_3_0_event_message_templates(), |
|
| 47 | + ); |
|
| 48 | + parent::__construct($table_manager, $table_analysis); |
|
| 49 | + } |
|
| 50 | 50 | |
| 51 | 51 | |
| 52 | 52 | |
| 53 | - public function can_migrate_from_version($version_array) |
|
| 54 | - { |
|
| 55 | - $version_string = $version_array['Core']; |
|
| 56 | - if (version_compare($version_string, '4.3.0.decaf', '<') && version_compare($version_string, '4.2.0.decaf', '>=')) { |
|
| 53 | + public function can_migrate_from_version($version_array) |
|
| 54 | + { |
|
| 55 | + $version_string = $version_array['Core']; |
|
| 56 | + if (version_compare($version_string, '4.3.0.decaf', '<') && version_compare($version_string, '4.2.0.decaf', '>=')) { |
|
| 57 | 57 | // echo "$version_string can be migrated fro"; |
| 58 | - return true; |
|
| 59 | - } elseif (! $version_string) { |
|
| 58 | + return true; |
|
| 59 | + } elseif (! $version_string) { |
|
| 60 | 60 | // echo "no version string provided: $version_string"; |
| 61 | - // no version string provided... this must be pre 4.2 |
|
| 62 | - return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 63 | - } else { |
|
| 61 | + // no version string provided... this must be pre 4.2 |
|
| 62 | + return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 63 | + } else { |
|
| 64 | 64 | // echo "$version_string doesnt apply"; |
| 65 | - return false; |
|
| 66 | - } |
|
| 67 | - } |
|
| 65 | + return false; |
|
| 66 | + } |
|
| 67 | + } |
|
| 68 | 68 | |
| 69 | 69 | |
| 70 | 70 | |
| 71 | - public function schema_changes_before_migration() |
|
| 72 | - { |
|
| 73 | - // relies on 4.1's EEH_Activation::create_table |
|
| 74 | - require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 75 | - $table_name = 'esp_answer'; |
|
| 76 | - $sql = "ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 71 | + public function schema_changes_before_migration() |
|
| 72 | + { |
|
| 73 | + // relies on 4.1's EEH_Activation::create_table |
|
| 74 | + require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 75 | + $table_name = 'esp_answer'; |
|
| 76 | + $sql = "ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 77 | 77 | REG_ID int(10) unsigned NOT NULL, |
| 78 | 78 | QST_ID int(10) unsigned NOT NULL, |
| 79 | 79 | ANS_value text NOT NULL, |
| 80 | 80 | PRIMARY KEY (ANS_ID)"; |
| 81 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 82 | - $table_name = 'esp_attendee_meta'; |
|
| 83 | - $sql = "ATTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 81 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 82 | + $table_name = 'esp_attendee_meta'; |
|
| 83 | + $sql = "ATTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 84 | 84 | ATT_ID bigint(20) unsigned NOT NULL, |
| 85 | 85 | ATT_fname varchar(45) NOT NULL, |
| 86 | 86 | ATT_lname varchar(45) NOT NULL, |
@@ -96,9 +96,9 @@ discard block |
||
| 96 | 96 | KEY ATT_fname (ATT_fname), |
| 97 | 97 | KEY ATT_lname (ATT_lname), |
| 98 | 98 | KEY ATT_email (ATT_email(191))"; |
| 99 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 100 | - $table_name = 'esp_country'; |
|
| 101 | - $sql = "CNT_ISO varchar(2) COLLATE utf8_bin NOT NULL, |
|
| 99 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 100 | + $table_name = 'esp_country'; |
|
| 101 | + $sql = "CNT_ISO varchar(2) COLLATE utf8_bin NOT NULL, |
|
| 102 | 102 | CNT_ISO3 varchar(3) COLLATE utf8_bin NOT NULL, |
| 103 | 103 | RGN_ID tinyint(3) unsigned DEFAULT NULL, |
| 104 | 104 | CNT_name varchar(45) COLLATE utf8_bin NOT NULL, |
@@ -114,9 +114,9 @@ discard block |
||
| 114 | 114 | CNT_is_EU tinyint(1) DEFAULT '0', |
| 115 | 115 | CNT_active tinyint(1) DEFAULT '0', |
| 116 | 116 | PRIMARY KEY (CNT_ISO)"; |
| 117 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 118 | - $table_name = 'esp_datetime'; |
|
| 119 | - $sql = "DTT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 117 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 118 | + $table_name = 'esp_datetime'; |
|
| 119 | + $sql = "DTT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 120 | 120 | EVT_ID bigint(20) unsigned NOT NULL, |
| 121 | 121 | DTT_name varchar(255) NOT NULL DEFAULT '', |
| 122 | 122 | DTT_description text NOT NULL, |
@@ -131,9 +131,9 @@ discard block |
||
| 131 | 131 | PRIMARY KEY (DTT_ID), |
| 132 | 132 | KEY EVT_ID (EVT_ID), |
| 133 | 133 | KEY DTT_is_primary (DTT_is_primary)"; |
| 134 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 135 | - $table_name = 'esp_event_meta'; |
|
| 136 | - $sql = " |
|
| 134 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 135 | + $table_name = 'esp_event_meta'; |
|
| 136 | + $sql = " |
|
| 137 | 137 | EVTM_ID int(10) NOT NULL AUTO_INCREMENT, |
| 138 | 138 | EVT_ID bigint(20) unsigned NOT NULL, |
| 139 | 139 | EVT_display_desc tinyint(1) unsigned NOT NULL DEFAULT 1, |
@@ -148,31 +148,31 @@ discard block |
||
| 148 | 148 | EVT_external_URL varchar(200) NULL, |
| 149 | 149 | EVT_donations tinyint(1) NULL, |
| 150 | 150 | PRIMARY KEY (EVTM_ID)"; |
| 151 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 152 | - $table_name = 'esp_event_question_group'; |
|
| 153 | - $sql = "EQG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 151 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 152 | + $table_name = 'esp_event_question_group'; |
|
| 153 | + $sql = "EQG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 154 | 154 | EVT_ID bigint(20) unsigned NOT NULL, |
| 155 | 155 | QSG_ID int(10) unsigned NOT NULL, |
| 156 | 156 | EQG_primary tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 157 | 157 | PRIMARY KEY (EQG_ID)"; |
| 158 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 159 | - $table_name = 'esp_event_venue'; |
|
| 160 | - $sql = "EVV_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 158 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 159 | + $table_name = 'esp_event_venue'; |
|
| 160 | + $sql = "EVV_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 161 | 161 | EVT_ID bigint(20) unsigned NOT NULL, |
| 162 | 162 | VNU_ID bigint(20) unsigned NOT NULL, |
| 163 | 163 | EVV_primary tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 164 | 164 | PRIMARY KEY (EVV_ID)"; |
| 165 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 166 | - $table_name = 'esp_extra_meta'; |
|
| 167 | - $sql = "EXM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 165 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 166 | + $table_name = 'esp_extra_meta'; |
|
| 167 | + $sql = "EXM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 168 | 168 | OBJ_ID int(11) DEFAULT NULL, |
| 169 | 169 | EXM_type varchar(45) DEFAULT NULL, |
| 170 | 170 | EXM_key varchar(45) DEFAULT NULL, |
| 171 | 171 | EXM_value text, |
| 172 | 172 | PRIMARY KEY (EXM_ID)"; |
| 173 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 174 | - $table_name = 'esp_line_item'; |
|
| 175 | - $sql = "LIN_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 173 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 174 | + $table_name = 'esp_line_item'; |
|
| 175 | + $sql = "LIN_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 176 | 176 | LIN_code varchar(245) NOT NULL DEFAULT '', |
| 177 | 177 | TXN_ID int(11) DEFAULT NULL, |
| 178 | 178 | LIN_name varchar(245) NOT NULL DEFAULT '', |
@@ -188,19 +188,19 @@ discard block |
||
| 188 | 188 | OBJ_ID int(11) DEFAULT NULL, |
| 189 | 189 | OBJ_type varchar(45)DEFAULT NULL, |
| 190 | 190 | PRIMARY KEY (LIN_ID)"; |
| 191 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 192 | - $table_name = 'esp_message_template'; |
|
| 193 | - $sql = "MTP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 191 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 192 | + $table_name = 'esp_message_template'; |
|
| 193 | + $sql = "MTP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 194 | 194 | GRP_ID int(10) unsigned NOT NULL, |
| 195 | 195 | MTP_context varchar(50) NOT NULL, |
| 196 | 196 | MTP_template_field varchar(30) NOT NULL, |
| 197 | 197 | MTP_content text NOT NULL, |
| 198 | 198 | PRIMARY KEY (MTP_ID), |
| 199 | 199 | KEY GRP_ID (GRP_ID)"; |
| 200 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 201 | - $this->_get_table_manager()->dropIndex('esp_message_template_group', 'EVT_ID'); |
|
| 202 | - $table_name = 'esp_message_template_group'; |
|
| 203 | - $sql = "GRP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 200 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 201 | + $this->_get_table_manager()->dropIndex('esp_message_template_group', 'EVT_ID'); |
|
| 202 | + $table_name = 'esp_message_template_group'; |
|
| 203 | + $sql = "GRP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 204 | 204 | MTP_user_id int(10) NOT NULL DEFAULT '1', |
| 205 | 205 | MTP_name varchar(245) NOT NULL DEFAULT '', |
| 206 | 206 | MTP_description varchar(245) NOT NULL DEFAULT '', |
@@ -212,17 +212,17 @@ discard block |
||
| 212 | 212 | MTP_is_active tinyint(1) NOT NULL DEFAULT '1', |
| 213 | 213 | PRIMARY KEY (GRP_ID), |
| 214 | 214 | KEY MTP_user_id (MTP_user_id)"; |
| 215 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 216 | - $table_name = 'esp_event_message_template'; |
|
| 217 | - $sql = "EMT_ID bigint(20) unsigned NOT NULL AUTO_INCREMENT, |
|
| 215 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 216 | + $table_name = 'esp_event_message_template'; |
|
| 217 | + $sql = "EMT_ID bigint(20) unsigned NOT NULL AUTO_INCREMENT, |
|
| 218 | 218 | EVT_ID bigint(20) unsigned NOT NULL DEFAULT 0, |
| 219 | 219 | GRP_ID int(10) unsigned NOT NULL DEFAULT 0, |
| 220 | 220 | PRIMARY KEY (EMT_ID), |
| 221 | 221 | KEY EVT_ID (EVT_ID), |
| 222 | 222 | KEY GRP_ID (GRP_ID)"; |
| 223 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 224 | - $table_name = 'esp_payment'; |
|
| 225 | - $sql = "PAY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 223 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 224 | + $table_name = 'esp_payment'; |
|
| 225 | + $sql = "PAY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 226 | 226 | TXN_ID int(10) unsigned DEFAULT NULL, |
| 227 | 227 | STS_ID varchar(3) COLLATE utf8_bin DEFAULT NULL, |
| 228 | 228 | PAY_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
@@ -238,9 +238,9 @@ discard block |
||
| 238 | 238 | PRIMARY KEY (PAY_ID), |
| 239 | 239 | KEY TXN_ID (TXN_ID), |
| 240 | 240 | KEY PAY_timestamp (PAY_timestamp)"; |
| 241 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 242 | - $table_name = "esp_ticket"; |
|
| 243 | - $sql = "TKT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 241 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 242 | + $table_name = "esp_ticket"; |
|
| 243 | + $sql = "TKT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 244 | 244 | TTM_ID int(10) unsigned NOT NULL, |
| 245 | 245 | TKT_name varchar(245) NOT NULL DEFAULT '', |
| 246 | 246 | TKT_description text NOT NULL, |
@@ -260,28 +260,28 @@ discard block |
||
| 260 | 260 | TKT_parent int(10) unsigned DEFAULT '0', |
| 261 | 261 | TKT_deleted tinyint(1) NOT NULL DEFAULT '0', |
| 262 | 262 | PRIMARY KEY (TKT_ID)"; |
| 263 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 264 | - $table_name = "esp_ticket_price"; |
|
| 265 | - $sql = "TKP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 263 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 264 | + $table_name = "esp_ticket_price"; |
|
| 265 | + $sql = "TKP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 266 | 266 | TKT_ID int(10) unsigned NOT NULL, |
| 267 | 267 | PRC_ID int(10) unsigned NOT NULL, |
| 268 | 268 | PRIMARY KEY (TKP_ID)"; |
| 269 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 270 | - $table_name = "esp_datetime_ticket"; |
|
| 271 | - $sql = "DTK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 269 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 270 | + $table_name = "esp_datetime_ticket"; |
|
| 271 | + $sql = "DTK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 272 | 272 | DTT_ID int(10) unsigned NOT NULL, |
| 273 | 273 | TKT_ID int(10) unsigned NOT NULL, |
| 274 | 274 | PRIMARY KEY (DTK_ID)"; |
| 275 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 276 | - $table_name = "esp_ticket_template"; |
|
| 277 | - $sql = "TTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 275 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 276 | + $table_name = "esp_ticket_template"; |
|
| 277 | + $sql = "TTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 278 | 278 | TTM_name varchar(45) NOT NULL, |
| 279 | 279 | TTM_description text, |
| 280 | 280 | TTM_file varchar(45), |
| 281 | 281 | PRIMARY KEY (TTM_ID)"; |
| 282 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 283 | - $table_name = "esp_price"; |
|
| 284 | - $sql = "PRC_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 282 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 283 | + $table_name = "esp_price"; |
|
| 284 | + $sql = "PRC_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 285 | 285 | PRT_ID tinyint(3) unsigned NOT NULL, |
| 286 | 286 | PRC_amount decimal(10,3) NOT NULL DEFAULT '0.00', |
| 287 | 287 | PRC_name varchar(245) NOT NULL, |
@@ -292,9 +292,9 @@ discard block |
||
| 292 | 292 | PRC_order tinyint(3) unsigned NOT NULL DEFAULT '0', |
| 293 | 293 | PRC_parent int(10) unsigned DEFAULT 0, |
| 294 | 294 | PRIMARY KEY (PRC_ID)"; |
| 295 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 296 | - $table_name = "esp_price_type"; |
|
| 297 | - $sql = "PRT_ID tinyint(3) unsigned NOT NULL AUTO_INCREMENT, |
|
| 295 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 296 | + $table_name = "esp_price_type"; |
|
| 297 | + $sql = "PRT_ID tinyint(3) unsigned NOT NULL AUTO_INCREMENT, |
|
| 298 | 298 | PRT_name varchar(45) NOT NULL, |
| 299 | 299 | PBT_ID tinyint(3) unsigned NOT NULL DEFAULT '1', |
| 300 | 300 | PRT_is_percent tinyint(1) NOT NULL DEFAULT '0', |
@@ -302,9 +302,9 @@ discard block |
||
| 302 | 302 | PRT_deleted tinyint(1) NOT NULL DEFAULT '0', |
| 303 | 303 | UNIQUE KEY PRT_name_UNIQUE (PRT_name), |
| 304 | 304 | PRIMARY KEY (PRT_ID)"; |
| 305 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 306 | - $table_name = 'esp_question'; |
|
| 307 | - $sql = 'QST_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 305 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 306 | + $table_name = 'esp_question'; |
|
| 307 | + $sql = 'QST_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 308 | 308 | QST_display_text text NOT NULL, |
| 309 | 309 | QST_admin_label varchar(255) NOT NULL, |
| 310 | 310 | QST_system varchar(25) DEFAULT NULL, |
@@ -316,10 +316,10 @@ discard block |
||
| 316 | 316 | QST_wp_user bigint(20) unsigned NULL, |
| 317 | 317 | QST_deleted tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 318 | 318 | PRIMARY KEY (QST_ID)'; |
| 319 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 320 | - $this->_get_table_manager()->dropIndex('esp_question_group', 'QSG_identifier_UNIQUE'); |
|
| 321 | - $table_name = 'esp_question_group'; |
|
| 322 | - $sql = 'QSG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 319 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 320 | + $this->_get_table_manager()->dropIndex('esp_question_group', 'QSG_identifier_UNIQUE'); |
|
| 321 | + $table_name = 'esp_question_group'; |
|
| 322 | + $sql = 'QSG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 323 | 323 | QSG_name varchar(255) NOT NULL, |
| 324 | 324 | QSG_identifier varchar(100) NOT NULL, |
| 325 | 325 | QSG_desc text NULL, |
@@ -330,25 +330,25 @@ discard block |
||
| 330 | 330 | QSG_deleted tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 331 | 331 | PRIMARY KEY (QSG_ID), |
| 332 | 332 | UNIQUE KEY QSG_identifier_UNIQUE (QSG_identifier ASC)'; |
| 333 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 334 | - $table_name = 'esp_question_group_question'; |
|
| 335 | - $sql = "QGQ_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 333 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 334 | + $table_name = 'esp_question_group_question'; |
|
| 335 | + $sql = "QGQ_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 336 | 336 | QSG_ID int(10) unsigned NOT NULL, |
| 337 | 337 | QST_ID int(10) unsigned NOT NULL, |
| 338 | 338 | QGQ_order int(10) unsigned NOT NULL DEFAULT 0, |
| 339 | 339 | PRIMARY KEY (QGQ_ID) "; |
| 340 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 341 | - $table_name = 'esp_question_option'; |
|
| 342 | - $sql = "QSO_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 340 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 341 | + $table_name = 'esp_question_option'; |
|
| 342 | + $sql = "QSO_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 343 | 343 | QSO_value varchar(255) NOT NULL, |
| 344 | 344 | QSO_desc text NOT NULL, |
| 345 | 345 | QST_ID int(10) unsigned NOT NULL, |
| 346 | 346 | QSO_order int(10) unsigned NOT NULL DEFAULT 0, |
| 347 | 347 | QSO_deleted tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 348 | 348 | PRIMARY KEY (QSO_ID)"; |
| 349 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 350 | - $table_name = 'esp_registration'; |
|
| 351 | - $sql = "REG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 349 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 350 | + $table_name = 'esp_registration'; |
|
| 351 | + $sql = "REG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 352 | 352 | EVT_ID bigint(20) unsigned NOT NULL, |
| 353 | 353 | ATT_ID bigint(20) unsigned NOT NULL, |
| 354 | 354 | TXN_ID int(10) unsigned NOT NULL, |
@@ -371,25 +371,25 @@ discard block |
||
| 371 | 371 | KEY STS_ID (STS_ID), |
| 372 | 372 | KEY REG_url_link (REG_url_link), |
| 373 | 373 | KEY REG_code (REG_code)"; |
| 374 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 375 | - $table_name = 'esp_checkin'; |
|
| 376 | - $sql = "CHK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 374 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 375 | + $table_name = 'esp_checkin'; |
|
| 376 | + $sql = "CHK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 377 | 377 | REG_ID int(10) unsigned NOT NULL, |
| 378 | 378 | DTT_ID int(10) unsigned NOT NULL, |
| 379 | 379 | CHK_in tinyint(1) unsigned NOT NULL DEFAULT 1, |
| 380 | 380 | CHK_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
| 381 | 381 | PRIMARY KEY (CHK_ID)"; |
| 382 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 383 | - $table_name = 'esp_state'; |
|
| 384 | - $sql = "STA_ID smallint(5) unsigned NOT NULL AUTO_INCREMENT, |
|
| 382 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 383 | + $table_name = 'esp_state'; |
|
| 384 | + $sql = "STA_ID smallint(5) unsigned NOT NULL AUTO_INCREMENT, |
|
| 385 | 385 | CNT_ISO varchar(2) COLLATE utf8_bin NOT NULL, |
| 386 | 386 | STA_abbrev varchar(6) COLLATE utf8_bin NOT NULL, |
| 387 | 387 | STA_name varchar(100) COLLATE utf8_bin NOT NULL, |
| 388 | 388 | STA_active tinyint(1) DEFAULT '1', |
| 389 | 389 | PRIMARY KEY (STA_ID)"; |
| 390 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 391 | - $table_name = 'esp_status'; |
|
| 392 | - $sql = "STS_ID varchar(3) COLLATE utf8_bin NOT NULL, |
|
| 390 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 391 | + $table_name = 'esp_status'; |
|
| 392 | + $sql = "STS_ID varchar(3) COLLATE utf8_bin NOT NULL, |
|
| 393 | 393 | STS_code varchar(45) COLLATE utf8_bin NOT NULL, |
| 394 | 394 | STS_type set('event','registration','transaction','payment','email') COLLATE utf8_bin NOT NULL, |
| 395 | 395 | STS_can_edit tinyint(1) NOT NULL DEFAULT 0, |
@@ -397,9 +397,9 @@ discard block |
||
| 397 | 397 | STS_open tinyint(1) NOT NULL DEFAULT 1, |
| 398 | 398 | UNIQUE KEY STS_ID_UNIQUE (STS_ID), |
| 399 | 399 | KEY STS_type (STS_type)"; |
| 400 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 401 | - $table_name = 'esp_transaction'; |
|
| 402 | - $sql = "TXN_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 400 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 401 | + $table_name = 'esp_transaction'; |
|
| 402 | + $sql = "TXN_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 403 | 403 | TXN_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
| 404 | 404 | TXN_total decimal(10,3) DEFAULT '0.00', |
| 405 | 405 | TXN_paid decimal(10,3) NOT NULL DEFAULT '0.00', |
@@ -409,9 +409,9 @@ discard block |
||
| 409 | 409 | PRIMARY KEY (TXN_ID), |
| 410 | 410 | KEY TXN_timestamp (TXN_timestamp), |
| 411 | 411 | KEY STS_ID (STS_ID)"; |
| 412 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 413 | - $table_name = 'esp_venue_meta'; |
|
| 414 | - $sql = "VNUM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 412 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 413 | + $table_name = 'esp_venue_meta'; |
|
| 414 | + $sql = "VNUM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 415 | 415 | VNU_ID bigint(20) unsigned NOT NULL DEFAULT 0, |
| 416 | 416 | VNU_address varchar(255) DEFAULT NULL, |
| 417 | 417 | VNU_address2 varchar(255) DEFAULT NULL, |
@@ -429,77 +429,77 @@ discard block |
||
| 429 | 429 | PRIMARY KEY (VNUM_ID), |
| 430 | 430 | KEY STA_ID (STA_ID), |
| 431 | 431 | KEY CNT_ISO (CNT_ISO)"; |
| 432 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 433 | - $script_with_defaults = EE_Registry::instance()->load_dms('Core_4_1_0'); |
|
| 434 | - // setting up the DEFAULT stats and countries is also essential for the data migrations to run |
|
| 435 | - // (because many need to convert old string states to foreign keys into the states table) |
|
| 436 | - $script_with_defaults->insert_default_states(); |
|
| 437 | - $script_with_defaults->insert_default_countries(); |
|
| 438 | - // setting up DEFAULT prices, price types, and tickets is also essential for the price migrations |
|
| 439 | - $script_with_defaults->insert_default_price_types(); |
|
| 440 | - $script_with_defaults->insert_default_prices(); |
|
| 441 | - // but the schema on the tickets table has changed since 4.1, so use our DEFAULT ticket method instead of 4.1's |
|
| 442 | - $this->insert_default_tickets(); |
|
| 443 | - // setting up the config wp option pretty well counts as a 'schema change', or at least should happen ehre |
|
| 444 | - EE_Config::instance()->update_espresso_config(false, true); |
|
| 445 | - return true; |
|
| 446 | - } |
|
| 432 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 433 | + $script_with_defaults = EE_Registry::instance()->load_dms('Core_4_1_0'); |
|
| 434 | + // setting up the DEFAULT stats and countries is also essential for the data migrations to run |
|
| 435 | + // (because many need to convert old string states to foreign keys into the states table) |
|
| 436 | + $script_with_defaults->insert_default_states(); |
|
| 437 | + $script_with_defaults->insert_default_countries(); |
|
| 438 | + // setting up DEFAULT prices, price types, and tickets is also essential for the price migrations |
|
| 439 | + $script_with_defaults->insert_default_price_types(); |
|
| 440 | + $script_with_defaults->insert_default_prices(); |
|
| 441 | + // but the schema on the tickets table has changed since 4.1, so use our DEFAULT ticket method instead of 4.1's |
|
| 442 | + $this->insert_default_tickets(); |
|
| 443 | + // setting up the config wp option pretty well counts as a 'schema change', or at least should happen ehre |
|
| 444 | + EE_Config::instance()->update_espresso_config(false, true); |
|
| 445 | + return true; |
|
| 446 | + } |
|
| 447 | 447 | |
| 448 | 448 | |
| 449 | 449 | |
| 450 | - /** |
|
| 451 | - * @return boolean |
|
| 452 | - */ |
|
| 453 | - public function schema_changes_after_migration() |
|
| 454 | - { |
|
| 455 | - return true; |
|
| 456 | - } |
|
| 450 | + /** |
|
| 451 | + * @return boolean |
|
| 452 | + */ |
|
| 453 | + public function schema_changes_after_migration() |
|
| 454 | + { |
|
| 455 | + return true; |
|
| 456 | + } |
|
| 457 | 457 | |
| 458 | 458 | |
| 459 | 459 | |
| 460 | - public function migration_page_hooks() |
|
| 461 | - { |
|
| 462 | - } |
|
| 460 | + public function migration_page_hooks() |
|
| 461 | + { |
|
| 462 | + } |
|
| 463 | 463 | |
| 464 | 464 | |
| 465 | 465 | |
| 466 | - /** |
|
| 467 | - * insert DEFAULT ticket |
|
| 468 | - * Almost identical to EE_DMS_Core_4_1_0::insert_default_tickets, except is aware of the TKT_required field |
|
| 469 | - * |
|
| 470 | - * @access public |
|
| 471 | - * @static |
|
| 472 | - * @return void |
|
| 473 | - */ |
|
| 474 | - public function insert_default_tickets() |
|
| 475 | - { |
|
| 476 | - global $wpdb; |
|
| 477 | - $ticket_table = $wpdb->prefix . "esp_ticket"; |
|
| 478 | - if ($this->_get_table_analysis()->tableExists($ticket_table)) { |
|
| 479 | - $SQL = 'SELECT COUNT(TKT_ID) FROM ' . $ticket_table; |
|
| 480 | - $tickets_exist = $wpdb->get_var($SQL); |
|
| 481 | - if (! $tickets_exist) { |
|
| 482 | - $SQL = "INSERT INTO $ticket_table |
|
| 466 | + /** |
|
| 467 | + * insert DEFAULT ticket |
|
| 468 | + * Almost identical to EE_DMS_Core_4_1_0::insert_default_tickets, except is aware of the TKT_required field |
|
| 469 | + * |
|
| 470 | + * @access public |
|
| 471 | + * @static |
|
| 472 | + * @return void |
|
| 473 | + */ |
|
| 474 | + public function insert_default_tickets() |
|
| 475 | + { |
|
| 476 | + global $wpdb; |
|
| 477 | + $ticket_table = $wpdb->prefix . "esp_ticket"; |
|
| 478 | + if ($this->_get_table_analysis()->tableExists($ticket_table)) { |
|
| 479 | + $SQL = 'SELECT COUNT(TKT_ID) FROM ' . $ticket_table; |
|
| 480 | + $tickets_exist = $wpdb->get_var($SQL); |
|
| 481 | + if (! $tickets_exist) { |
|
| 482 | + $SQL = "INSERT INTO $ticket_table |
|
| 483 | 483 | ( TKT_ID, TTM_ID, TKT_name, TKT_description, TKT_qty, TKT_sold, TKT_uses, TKT_required, TKT_min, TKT_max, TKT_price, TKT_start_date, TKT_end_date, TKT_taxable, TKT_order, TKT_row, TKT_is_default, TKT_parent, TKT_deleted ) VALUES |
| 484 | 484 | ( 1, 0, '" |
| 485 | - . __("Free Ticket", "event_espresso") |
|
| 486 | - . "', '', 100, 0, -1, 0, 0, -1, 0.00, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 0, 0, 1, 1, 0, 0);"; |
|
| 487 | - $SQL = apply_filters('FHEE__EE_DMS_4_1_0__insert_default_tickets__SQL', $SQL); |
|
| 488 | - $wpdb->query($SQL); |
|
| 489 | - } |
|
| 490 | - } |
|
| 491 | - $ticket_price_table = $wpdb->prefix . "esp_ticket_price"; |
|
| 492 | - if ($this->_get_table_analysis()->tableExists($ticket_price_table)) { |
|
| 493 | - $SQL = 'SELECT COUNT(TKP_ID) FROM ' . $ticket_price_table; |
|
| 494 | - $ticket_prc_exist = $wpdb->get_var($SQL); |
|
| 495 | - if (! $ticket_prc_exist) { |
|
| 496 | - $SQL = "INSERT INTO $ticket_price_table |
|
| 485 | + . __("Free Ticket", "event_espresso") |
|
| 486 | + . "', '', 100, 0, -1, 0, 0, -1, 0.00, '0000-00-00 00:00:00', '0000-00-00 00:00:00', 0, 0, 1, 1, 0, 0);"; |
|
| 487 | + $SQL = apply_filters('FHEE__EE_DMS_4_1_0__insert_default_tickets__SQL', $SQL); |
|
| 488 | + $wpdb->query($SQL); |
|
| 489 | + } |
|
| 490 | + } |
|
| 491 | + $ticket_price_table = $wpdb->prefix . "esp_ticket_price"; |
|
| 492 | + if ($this->_get_table_analysis()->tableExists($ticket_price_table)) { |
|
| 493 | + $SQL = 'SELECT COUNT(TKP_ID) FROM ' . $ticket_price_table; |
|
| 494 | + $ticket_prc_exist = $wpdb->get_var($SQL); |
|
| 495 | + if (! $ticket_prc_exist) { |
|
| 496 | + $SQL = "INSERT INTO $ticket_price_table |
|
| 497 | 497 | ( TKP_ID, TKT_ID, PRC_ID ) VALUES |
| 498 | 498 | ( 1, 1, 1 ) |
| 499 | 499 | "; |
| 500 | - $SQL = apply_filters('FHEE__EE_DMS_4_1_0__insert_default_tickets__SQL__ticket_price', $SQL); |
|
| 501 | - $wpdb->query($SQL); |
|
| 502 | - } |
|
| 503 | - } |
|
| 504 | - } |
|
| 500 | + $SQL = apply_filters('FHEE__EE_DMS_4_1_0__insert_default_tickets__SQL__ticket_price', $SQL); |
|
| 501 | + $wpdb->query($SQL); |
|
| 502 | + } |
|
| 503 | + } |
|
| 504 | + } |
|
| 505 | 505 | } |
@@ -11,13 +11,13 @@ discard block |
||
| 11 | 11 | // unfortunately, this needs to be done upon INCLUSION of this file, |
| 12 | 12 | // instead of construction, because it only gets constructed on first page load |
| 13 | 13 | // (all other times it gets resurrected from a wordpress option) |
| 14 | -$stages = glob(EE_CORE . 'data_migration_scripts/4_3_0_stages/*'); |
|
| 14 | +$stages = glob(EE_CORE.'data_migration_scripts/4_3_0_stages/*'); |
|
| 15 | 15 | $class_to_filepath = array(); |
| 16 | -if (! empty($stages)) { |
|
| 16 | +if ( ! empty($stages)) { |
|
| 17 | 17 | foreach ($stages as $filepath) { |
| 18 | 18 | $matches = array(); |
| 19 | 19 | preg_match('~4_3_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
| 20 | - $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 20 | + $class_to_filepath[$matches[1]] = $filepath; |
|
| 21 | 21 | } |
| 22 | 22 | } |
| 23 | 23 | // give addons a chance to autoload their stages too |
@@ -56,10 +56,10 @@ discard block |
||
| 56 | 56 | if (version_compare($version_string, '4.3.0.decaf', '<') && version_compare($version_string, '4.2.0.decaf', '>=')) { |
| 57 | 57 | // echo "$version_string can be migrated fro"; |
| 58 | 58 | return true; |
| 59 | - } elseif (! $version_string) { |
|
| 59 | + } elseif ( ! $version_string) { |
|
| 60 | 60 | // echo "no version string provided: $version_string"; |
| 61 | 61 | // no version string provided... this must be pre 4.2 |
| 62 | - return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 62 | + return false; // changed mind. dont want people thinking they should migrate yet because they cant |
|
| 63 | 63 | } else { |
| 64 | 64 | // echo "$version_string doesnt apply"; |
| 65 | 65 | return false; |
@@ -71,7 +71,7 @@ discard block |
||
| 71 | 71 | public function schema_changes_before_migration() |
| 72 | 72 | { |
| 73 | 73 | // relies on 4.1's EEH_Activation::create_table |
| 74 | - require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 74 | + require_once(EE_HELPERS.'EEH_Activation.helper.php'); |
|
| 75 | 75 | $table_name = 'esp_answer'; |
| 76 | 76 | $sql = "ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
| 77 | 77 | REG_ID int(10) unsigned NOT NULL, |
@@ -474,11 +474,11 @@ discard block |
||
| 474 | 474 | public function insert_default_tickets() |
| 475 | 475 | { |
| 476 | 476 | global $wpdb; |
| 477 | - $ticket_table = $wpdb->prefix . "esp_ticket"; |
|
| 477 | + $ticket_table = $wpdb->prefix."esp_ticket"; |
|
| 478 | 478 | if ($this->_get_table_analysis()->tableExists($ticket_table)) { |
| 479 | - $SQL = 'SELECT COUNT(TKT_ID) FROM ' . $ticket_table; |
|
| 479 | + $SQL = 'SELECT COUNT(TKT_ID) FROM '.$ticket_table; |
|
| 480 | 480 | $tickets_exist = $wpdb->get_var($SQL); |
| 481 | - if (! $tickets_exist) { |
|
| 481 | + if ( ! $tickets_exist) { |
|
| 482 | 482 | $SQL = "INSERT INTO $ticket_table |
| 483 | 483 | ( TKT_ID, TTM_ID, TKT_name, TKT_description, TKT_qty, TKT_sold, TKT_uses, TKT_required, TKT_min, TKT_max, TKT_price, TKT_start_date, TKT_end_date, TKT_taxable, TKT_order, TKT_row, TKT_is_default, TKT_parent, TKT_deleted ) VALUES |
| 484 | 484 | ( 1, 0, '" |
@@ -488,11 +488,11 @@ discard block |
||
| 488 | 488 | $wpdb->query($SQL); |
| 489 | 489 | } |
| 490 | 490 | } |
| 491 | - $ticket_price_table = $wpdb->prefix . "esp_ticket_price"; |
|
| 491 | + $ticket_price_table = $wpdb->prefix."esp_ticket_price"; |
|
| 492 | 492 | if ($this->_get_table_analysis()->tableExists($ticket_price_table)) { |
| 493 | - $SQL = 'SELECT COUNT(TKP_ID) FROM ' . $ticket_price_table; |
|
| 493 | + $SQL = 'SELECT COUNT(TKP_ID) FROM '.$ticket_price_table; |
|
| 494 | 494 | $ticket_prc_exist = $wpdb->get_var($SQL); |
| 495 | - if (! $ticket_prc_exist) { |
|
| 495 | + if ( ! $ticket_prc_exist) { |
|
| 496 | 496 | $SQL = "INSERT INTO $ticket_price_table |
| 497 | 497 | ( TKP_ID, TKT_ID, PRC_ID ) VALUES |
| 498 | 498 | ( 1, 1, 1 ) |
@@ -14,9 +14,9 @@ discard block |
||
| 14 | 14 | $stages = glob(EE_CORE . 'data_migration_scripts/4_6_0_stages/*'); |
| 15 | 15 | $class_to_filepath = array(); |
| 16 | 16 | foreach ($stages as $filepath) { |
| 17 | - $matches = array(); |
|
| 18 | - preg_match('~4_6_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
|
| 19 | - $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 17 | + $matches = array(); |
|
| 18 | + preg_match('~4_6_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
|
| 19 | + $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 20 | 20 | } |
| 21 | 21 | // give addons a chance to autoload their stages too |
| 22 | 22 | $class_to_filepath = apply_filters('FHEE__EE_DMS_4_6_0__autoloaded_stages', $class_to_filepath); |
@@ -35,69 +35,69 @@ discard block |
||
| 35 | 35 | class EE_DMS_Core_4_6_0 extends EE_Data_Migration_Script_Base |
| 36 | 36 | { |
| 37 | 37 | |
| 38 | - /** |
|
| 39 | - * return EE_DMS_Core_4_6_0 |
|
| 40 | - * |
|
| 41 | - * @param TableManager $table_manager |
|
| 42 | - * @param TableAnalysis $table_analysis |
|
| 43 | - */ |
|
| 44 | - public function __construct(TableManager $table_manager = null, TableAnalysis $table_analysis = null) |
|
| 45 | - { |
|
| 46 | - $this->_pretty_name = __("Data Update to Event Espresso 4.6.0", "event_espresso"); |
|
| 47 | - $this->_priority = 10; |
|
| 48 | - $this->_migration_stages = array( |
|
| 49 | - new EE_DMS_4_6_0_gateways(), |
|
| 50 | - new EE_DMS_4_6_0_question_types(), |
|
| 51 | - new EE_DMS_4_6_0_country_system_question(), |
|
| 52 | - new EE_DMS_4_6_0_state_system_question(), |
|
| 53 | - new EE_DMS_4_6_0_billing_info(), |
|
| 54 | - new EE_DMS_4_6_0_transactions(), |
|
| 55 | - new EE_DMS_4_6_0_payments(), |
|
| 56 | - new EE_DMS_4_6_0_invoice_settings(), |
|
| 57 | - ); |
|
| 58 | - parent::__construct($table_manager, $table_analysis); |
|
| 59 | - } |
|
| 38 | + /** |
|
| 39 | + * return EE_DMS_Core_4_6_0 |
|
| 40 | + * |
|
| 41 | + * @param TableManager $table_manager |
|
| 42 | + * @param TableAnalysis $table_analysis |
|
| 43 | + */ |
|
| 44 | + public function __construct(TableManager $table_manager = null, TableAnalysis $table_analysis = null) |
|
| 45 | + { |
|
| 46 | + $this->_pretty_name = __("Data Update to Event Espresso 4.6.0", "event_espresso"); |
|
| 47 | + $this->_priority = 10; |
|
| 48 | + $this->_migration_stages = array( |
|
| 49 | + new EE_DMS_4_6_0_gateways(), |
|
| 50 | + new EE_DMS_4_6_0_question_types(), |
|
| 51 | + new EE_DMS_4_6_0_country_system_question(), |
|
| 52 | + new EE_DMS_4_6_0_state_system_question(), |
|
| 53 | + new EE_DMS_4_6_0_billing_info(), |
|
| 54 | + new EE_DMS_4_6_0_transactions(), |
|
| 55 | + new EE_DMS_4_6_0_payments(), |
|
| 56 | + new EE_DMS_4_6_0_invoice_settings(), |
|
| 57 | + ); |
|
| 58 | + parent::__construct($table_manager, $table_analysis); |
|
| 59 | + } |
|
| 60 | 60 | |
| 61 | 61 | |
| 62 | 62 | |
| 63 | - /** |
|
| 64 | - * @param array $version_array |
|
| 65 | - * @return bool |
|
| 66 | - */ |
|
| 67 | - public function can_migrate_from_version($version_array) |
|
| 68 | - { |
|
| 69 | - $version_string = $version_array['Core']; |
|
| 70 | - if (version_compare($version_string, '4.6.0.decaf', '<') && version_compare($version_string, '4.5.0.decaf', '>=')) { |
|
| 63 | + /** |
|
| 64 | + * @param array $version_array |
|
| 65 | + * @return bool |
|
| 66 | + */ |
|
| 67 | + public function can_migrate_from_version($version_array) |
|
| 68 | + { |
|
| 69 | + $version_string = $version_array['Core']; |
|
| 70 | + if (version_compare($version_string, '4.6.0.decaf', '<') && version_compare($version_string, '4.5.0.decaf', '>=')) { |
|
| 71 | 71 | // echo "$version_string can be migrated from"; |
| 72 | - return true; |
|
| 73 | - } elseif (! $version_string) { |
|
| 72 | + return true; |
|
| 73 | + } elseif (! $version_string) { |
|
| 74 | 74 | // echo "no version string provided: $version_string"; |
| 75 | - // no version string provided... this must be pre 4.3 |
|
| 76 | - return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 77 | - } else { |
|
| 75 | + // no version string provided... this must be pre 4.3 |
|
| 76 | + return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 77 | + } else { |
|
| 78 | 78 | // echo "$version_string doesnt apply"; |
| 79 | - return false; |
|
| 80 | - } |
|
| 81 | - } |
|
| 79 | + return false; |
|
| 80 | + } |
|
| 81 | + } |
|
| 82 | 82 | |
| 83 | 83 | |
| 84 | 84 | |
| 85 | - /** |
|
| 86 | - * @return bool |
|
| 87 | - */ |
|
| 88 | - public function schema_changes_before_migration() |
|
| 89 | - { |
|
| 90 | - // relies on 4.1's EEH_Activation::create_table |
|
| 91 | - require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 92 | - $table_name = 'esp_answer'; |
|
| 93 | - $sql = "ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 85 | + /** |
|
| 86 | + * @return bool |
|
| 87 | + */ |
|
| 88 | + public function schema_changes_before_migration() |
|
| 89 | + { |
|
| 90 | + // relies on 4.1's EEH_Activation::create_table |
|
| 91 | + require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 92 | + $table_name = 'esp_answer'; |
|
| 93 | + $sql = "ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 94 | 94 | REG_ID int(10) unsigned NOT NULL, |
| 95 | 95 | QST_ID int(10) unsigned NOT NULL, |
| 96 | 96 | ANS_value text NOT NULL, |
| 97 | 97 | PRIMARY KEY (ANS_ID)"; |
| 98 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 99 | - $table_name = 'esp_attendee_meta'; |
|
| 100 | - $sql = "ATTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 98 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 99 | + $table_name = 'esp_attendee_meta'; |
|
| 100 | + $sql = "ATTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 101 | 101 | ATT_ID bigint(20) unsigned NOT NULL, |
| 102 | 102 | ATT_fname varchar(45) NOT NULL, |
| 103 | 103 | ATT_lname varchar(45) NOT NULL, |
@@ -113,9 +113,9 @@ discard block |
||
| 113 | 113 | KEY ATT_fname (ATT_fname), |
| 114 | 114 | KEY ATT_lname (ATT_lname), |
| 115 | 115 | KEY ATT_email (ATT_email(191))"; |
| 116 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 117 | - $table_name = 'esp_country'; |
|
| 118 | - $sql = "CNT_ISO varchar(2) COLLATE utf8_bin NOT NULL, |
|
| 116 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 117 | + $table_name = 'esp_country'; |
|
| 118 | + $sql = "CNT_ISO varchar(2) COLLATE utf8_bin NOT NULL, |
|
| 119 | 119 | CNT_ISO3 varchar(3) COLLATE utf8_bin NOT NULL, |
| 120 | 120 | RGN_ID tinyint(3) unsigned DEFAULT NULL, |
| 121 | 121 | CNT_name varchar(45) COLLATE utf8_bin NOT NULL, |
@@ -131,24 +131,24 @@ discard block |
||
| 131 | 131 | CNT_is_EU tinyint(1) DEFAULT '0', |
| 132 | 132 | CNT_active tinyint(1) DEFAULT '0', |
| 133 | 133 | PRIMARY KEY (CNT_ISO)"; |
| 134 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 135 | - $table_name = 'esp_currency'; |
|
| 136 | - $sql = "CUR_code varchar(6) COLLATE utf8_bin NOT NULL, |
|
| 134 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 135 | + $table_name = 'esp_currency'; |
|
| 136 | + $sql = "CUR_code varchar(6) COLLATE utf8_bin NOT NULL, |
|
| 137 | 137 | CUR_single varchar(45) COLLATE utf8_bin DEFAULT 'dollar', |
| 138 | 138 | CUR_plural varchar(45) COLLATE utf8_bin DEFAULT 'dollars', |
| 139 | 139 | CUR_sign varchar(45) COLLATE utf8_bin DEFAULT '$', |
| 140 | 140 | CUR_dec_plc varchar(1) COLLATE utf8_bin NOT NULL DEFAULT '2', |
| 141 | 141 | CUR_active tinyint(1) DEFAULT '0', |
| 142 | 142 | PRIMARY KEY (CUR_code)"; |
| 143 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 144 | - $table_name = 'esp_currency_payment_method'; |
|
| 145 | - $sql = "CPM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 143 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 144 | + $table_name = 'esp_currency_payment_method'; |
|
| 145 | + $sql = "CPM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 146 | 146 | CUR_code varchar(6) COLLATE utf8_bin NOT NULL, |
| 147 | 147 | PMD_ID int(11) NOT NULL, |
| 148 | 148 | PRIMARY KEY (CPM_ID)"; |
| 149 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 150 | - $table_name = 'esp_datetime'; |
|
| 151 | - $sql = "DTT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 149 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 150 | + $table_name = 'esp_datetime'; |
|
| 151 | + $sql = "DTT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 152 | 152 | EVT_ID bigint(20) unsigned NOT NULL, |
| 153 | 153 | DTT_name varchar(255) NOT NULL DEFAULT '', |
| 154 | 154 | DTT_description text NOT NULL, |
@@ -163,9 +163,9 @@ discard block |
||
| 163 | 163 | PRIMARY KEY (DTT_ID), |
| 164 | 164 | KEY EVT_ID (EVT_ID), |
| 165 | 165 | KEY DTT_is_primary (DTT_is_primary)"; |
| 166 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 167 | - $table_name = 'esp_event_meta'; |
|
| 168 | - $sql = " |
|
| 166 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 167 | + $table_name = 'esp_event_meta'; |
|
| 168 | + $sql = " |
|
| 169 | 169 | EVTM_ID int(10) NOT NULL AUTO_INCREMENT, |
| 170 | 170 | EVT_ID bigint(20) unsigned NOT NULL, |
| 171 | 171 | EVT_display_desc tinyint(1) unsigned NOT NULL DEFAULT 1, |
@@ -180,31 +180,31 @@ discard block |
||
| 180 | 180 | EVT_external_URL varchar(200) NULL, |
| 181 | 181 | EVT_donations tinyint(1) NULL, |
| 182 | 182 | PRIMARY KEY (EVTM_ID)"; |
| 183 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 184 | - $table_name = 'esp_event_question_group'; |
|
| 185 | - $sql = "EQG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 183 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 184 | + $table_name = 'esp_event_question_group'; |
|
| 185 | + $sql = "EQG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 186 | 186 | EVT_ID bigint(20) unsigned NOT NULL, |
| 187 | 187 | QSG_ID int(10) unsigned NOT NULL, |
| 188 | 188 | EQG_primary tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 189 | 189 | PRIMARY KEY (EQG_ID)"; |
| 190 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 191 | - $table_name = 'esp_event_venue'; |
|
| 192 | - $sql = "EVV_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 190 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 191 | + $table_name = 'esp_event_venue'; |
|
| 192 | + $sql = "EVV_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 193 | 193 | EVT_ID bigint(20) unsigned NOT NULL, |
| 194 | 194 | VNU_ID bigint(20) unsigned NOT NULL, |
| 195 | 195 | EVV_primary tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 196 | 196 | PRIMARY KEY (EVV_ID)"; |
| 197 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 198 | - $table_name = 'esp_extra_meta'; |
|
| 199 | - $sql = "EXM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 197 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 198 | + $table_name = 'esp_extra_meta'; |
|
| 199 | + $sql = "EXM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 200 | 200 | OBJ_ID int(11) DEFAULT NULL, |
| 201 | 201 | EXM_type varchar(45) DEFAULT NULL, |
| 202 | 202 | EXM_key varchar(45) DEFAULT NULL, |
| 203 | 203 | EXM_value text, |
| 204 | 204 | PRIMARY KEY (EXM_ID)"; |
| 205 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 206 | - $table_name = 'esp_line_item'; |
|
| 207 | - $sql = "LIN_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 205 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 206 | + $table_name = 'esp_line_item'; |
|
| 207 | + $sql = "LIN_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 208 | 208 | LIN_code varchar(245) NOT NULL DEFAULT '', |
| 209 | 209 | TXN_ID int(11) DEFAULT NULL, |
| 210 | 210 | LIN_name varchar(245) NOT NULL DEFAULT '', |
@@ -220,9 +220,9 @@ discard block |
||
| 220 | 220 | OBJ_ID int(11) DEFAULT NULL, |
| 221 | 221 | OBJ_type varchar(45)DEFAULT NULL, |
| 222 | 222 | PRIMARY KEY (LIN_ID)"; |
| 223 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 224 | - $table_name = 'esp_log'; |
|
| 225 | - $sql = "LOG_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 223 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 224 | + $table_name = 'esp_log'; |
|
| 225 | + $sql = "LOG_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 226 | 226 | LOG_time datetime DEFAULT NULL, |
| 227 | 227 | OBJ_ID varchar(45) DEFAULT NULL, |
| 228 | 228 | OBJ_type varchar(45) DEFAULT NULL, |
@@ -230,19 +230,19 @@ discard block |
||
| 230 | 230 | LOG_message text, |
| 231 | 231 | LOG_wp_user int(11) DEFAULT NULL, |
| 232 | 232 | PRIMARY KEY (LOG_ID)"; |
| 233 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 234 | - $table_name = 'esp_message_template'; |
|
| 235 | - $sql = "MTP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 233 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 234 | + $table_name = 'esp_message_template'; |
|
| 235 | + $sql = "MTP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 236 | 236 | GRP_ID int(10) unsigned NOT NULL, |
| 237 | 237 | MTP_context varchar(50) NOT NULL, |
| 238 | 238 | MTP_template_field varchar(30) NOT NULL, |
| 239 | 239 | MTP_content text NOT NULL, |
| 240 | 240 | PRIMARY KEY (MTP_ID), |
| 241 | 241 | KEY GRP_ID (GRP_ID)"; |
| 242 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 243 | - $this->_get_table_manager()->dropIndex('esp_message_template_group', 'EVT_ID'); |
|
| 244 | - $table_name = 'esp_message_template_group'; |
|
| 245 | - $sql = "GRP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 242 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 243 | + $this->_get_table_manager()->dropIndex('esp_message_template_group', 'EVT_ID'); |
|
| 244 | + $table_name = 'esp_message_template_group'; |
|
| 245 | + $sql = "GRP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 246 | 246 | MTP_user_id int(10) NOT NULL DEFAULT '1', |
| 247 | 247 | MTP_name varchar(245) NOT NULL DEFAULT '', |
| 248 | 248 | MTP_description varchar(245) NOT NULL DEFAULT '', |
@@ -254,17 +254,17 @@ discard block |
||
| 254 | 254 | MTP_is_active tinyint(1) NOT NULL DEFAULT '1', |
| 255 | 255 | PRIMARY KEY (GRP_ID), |
| 256 | 256 | KEY MTP_user_id (MTP_user_id)"; |
| 257 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 258 | - $table_name = 'esp_event_message_template'; |
|
| 259 | - $sql = "EMT_ID bigint(20) unsigned NOT NULL AUTO_INCREMENT, |
|
| 257 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 258 | + $table_name = 'esp_event_message_template'; |
|
| 259 | + $sql = "EMT_ID bigint(20) unsigned NOT NULL AUTO_INCREMENT, |
|
| 260 | 260 | EVT_ID bigint(20) unsigned NOT NULL DEFAULT 0, |
| 261 | 261 | GRP_ID int(10) unsigned NOT NULL DEFAULT 0, |
| 262 | 262 | PRIMARY KEY (EMT_ID), |
| 263 | 263 | KEY EVT_ID (EVT_ID), |
| 264 | 264 | KEY GRP_ID (GRP_ID)"; |
| 265 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 266 | - $table_name = 'esp_payment'; |
|
| 267 | - $sql = "PAY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 265 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 266 | + $table_name = 'esp_payment'; |
|
| 267 | + $sql = "PAY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 268 | 268 | TXN_ID int(10) unsigned DEFAULT NULL, |
| 269 | 269 | STS_ID varchar(3) COLLATE utf8_bin DEFAULT NULL, |
| 270 | 270 | PAY_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
@@ -281,9 +281,9 @@ discard block |
||
| 281 | 281 | PRIMARY KEY (PAY_ID), |
| 282 | 282 | KEY TXN_ID (TXN_ID), |
| 283 | 283 | KEY PAY_timestamp (PAY_timestamp)"; |
| 284 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 285 | - $table_name = 'esp_payment_method'; |
|
| 286 | - $sql = "PMD_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 284 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 285 | + $table_name = 'esp_payment_method'; |
|
| 286 | + $sql = "PMD_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 287 | 287 | PMD_type varchar(124) DEFAULT NULL, |
| 288 | 288 | PMD_name varchar(255) DEFAULT NULL, |
| 289 | 289 | PMD_desc text, |
@@ -298,28 +298,28 @@ discard block |
||
| 298 | 298 | PMD_scope varchar(255) NULL DEFAULT 'frontend', |
| 299 | 299 | PRIMARY KEY (PMD_ID), |
| 300 | 300 | UNIQUE KEY PMD_slug_UNIQUE (PMD_slug)"; |
| 301 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 302 | - $table_name = "esp_ticket_price"; |
|
| 303 | - $sql = "TKP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 301 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 302 | + $table_name = "esp_ticket_price"; |
|
| 303 | + $sql = "TKP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 304 | 304 | TKT_ID int(10) unsigned NOT NULL, |
| 305 | 305 | PRC_ID int(10) unsigned NOT NULL, |
| 306 | 306 | PRIMARY KEY (TKP_ID)"; |
| 307 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 308 | - $table_name = "esp_datetime_ticket"; |
|
| 309 | - $sql = "DTK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 307 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 308 | + $table_name = "esp_datetime_ticket"; |
|
| 309 | + $sql = "DTK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 310 | 310 | DTT_ID int(10) unsigned NOT NULL, |
| 311 | 311 | TKT_ID int(10) unsigned NOT NULL, |
| 312 | 312 | PRIMARY KEY (DTK_ID)"; |
| 313 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 314 | - $table_name = "esp_ticket_template"; |
|
| 315 | - $sql = "TTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 313 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 314 | + $table_name = "esp_ticket_template"; |
|
| 315 | + $sql = "TTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 316 | 316 | TTM_name varchar(45) NOT NULL, |
| 317 | 317 | TTM_description text, |
| 318 | 318 | TTM_file varchar(45), |
| 319 | 319 | PRIMARY KEY (TTM_ID)"; |
| 320 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 321 | - $table_name = 'esp_question'; |
|
| 322 | - $sql = 'QST_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 320 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 321 | + $table_name = 'esp_question'; |
|
| 322 | + $sql = 'QST_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 323 | 323 | QST_display_text text NOT NULL, |
| 324 | 324 | QST_admin_label varchar(255) NOT NULL, |
| 325 | 325 | QST_system varchar(25) DEFAULT NULL, |
@@ -331,25 +331,25 @@ discard block |
||
| 331 | 331 | QST_wp_user bigint(20) unsigned NULL, |
| 332 | 332 | QST_deleted tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 333 | 333 | PRIMARY KEY (QST_ID)'; |
| 334 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 335 | - $table_name = 'esp_question_group_question'; |
|
| 336 | - $sql = "QGQ_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 334 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 335 | + $table_name = 'esp_question_group_question'; |
|
| 336 | + $sql = "QGQ_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 337 | 337 | QSG_ID int(10) unsigned NOT NULL, |
| 338 | 338 | QST_ID int(10) unsigned NOT NULL, |
| 339 | 339 | QGQ_order int(10) unsigned NOT NULL DEFAULT 0, |
| 340 | 340 | PRIMARY KEY (QGQ_ID) "; |
| 341 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 342 | - $table_name = 'esp_question_option'; |
|
| 343 | - $sql = "QSO_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 341 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 342 | + $table_name = 'esp_question_option'; |
|
| 343 | + $sql = "QSO_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 344 | 344 | QSO_value varchar(255) NOT NULL, |
| 345 | 345 | QSO_desc text NOT NULL, |
| 346 | 346 | QST_ID int(10) unsigned NOT NULL, |
| 347 | 347 | QSO_order int(10) unsigned NOT NULL DEFAULT 0, |
| 348 | 348 | QSO_deleted tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 349 | 349 | PRIMARY KEY (QSO_ID)"; |
| 350 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 351 | - $table_name = 'esp_registration'; |
|
| 352 | - $sql = "REG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 350 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 351 | + $table_name = 'esp_registration'; |
|
| 352 | + $sql = "REG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 353 | 353 | EVT_ID bigint(20) unsigned NOT NULL, |
| 354 | 354 | ATT_ID bigint(20) unsigned NOT NULL, |
| 355 | 355 | TXN_ID int(10) unsigned NOT NULL, |
@@ -372,25 +372,25 @@ discard block |
||
| 372 | 372 | KEY STS_ID (STS_ID), |
| 373 | 373 | KEY REG_url_link (REG_url_link), |
| 374 | 374 | KEY REG_code (REG_code)"; |
| 375 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 376 | - $table_name = 'esp_checkin'; |
|
| 377 | - $sql = "CHK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 375 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 376 | + $table_name = 'esp_checkin'; |
|
| 377 | + $sql = "CHK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 378 | 378 | REG_ID int(10) unsigned NOT NULL, |
| 379 | 379 | DTT_ID int(10) unsigned NOT NULL, |
| 380 | 380 | CHK_in tinyint(1) unsigned NOT NULL DEFAULT 1, |
| 381 | 381 | CHK_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
| 382 | 382 | PRIMARY KEY (CHK_ID)"; |
| 383 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 384 | - $table_name = 'esp_state'; |
|
| 385 | - $sql = "STA_ID smallint(5) unsigned NOT NULL AUTO_INCREMENT, |
|
| 383 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 384 | + $table_name = 'esp_state'; |
|
| 385 | + $sql = "STA_ID smallint(5) unsigned NOT NULL AUTO_INCREMENT, |
|
| 386 | 386 | CNT_ISO varchar(2) COLLATE utf8_bin NOT NULL, |
| 387 | 387 | STA_abbrev varchar(24) COLLATE utf8_bin NOT NULL, |
| 388 | 388 | STA_name varchar(100) COLLATE utf8_bin NOT NULL, |
| 389 | 389 | STA_active tinyint(1) DEFAULT '1', |
| 390 | 390 | PRIMARY KEY (STA_ID)"; |
| 391 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 392 | - $table_name = 'esp_status'; |
|
| 393 | - $sql = "STS_ID varchar(3) COLLATE utf8_bin NOT NULL, |
|
| 391 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 392 | + $table_name = 'esp_status'; |
|
| 393 | + $sql = "STS_ID varchar(3) COLLATE utf8_bin NOT NULL, |
|
| 394 | 394 | STS_code varchar(45) COLLATE utf8_bin NOT NULL, |
| 395 | 395 | STS_type set('event','registration','transaction','payment','email') COLLATE utf8_bin NOT NULL, |
| 396 | 396 | STS_can_edit tinyint(1) NOT NULL DEFAULT 0, |
@@ -398,9 +398,9 @@ discard block |
||
| 398 | 398 | STS_open tinyint(1) NOT NULL DEFAULT 1, |
| 399 | 399 | UNIQUE KEY STS_ID_UNIQUE (STS_ID), |
| 400 | 400 | KEY STS_type (STS_type)"; |
| 401 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 402 | - $table_name = 'esp_transaction'; |
|
| 403 | - $sql = "TXN_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 401 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 402 | + $table_name = 'esp_transaction'; |
|
| 403 | + $sql = "TXN_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 404 | 404 | TXN_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
| 405 | 405 | TXN_total decimal(10,3) DEFAULT '0.00', |
| 406 | 406 | TXN_paid decimal(10,3) NOT NULL DEFAULT '0.00', |
@@ -412,9 +412,9 @@ discard block |
||
| 412 | 412 | PRIMARY KEY (TXN_ID), |
| 413 | 413 | KEY TXN_timestamp (TXN_timestamp), |
| 414 | 414 | KEY STS_ID (STS_ID)"; |
| 415 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 416 | - $table_name = 'esp_venue_meta'; |
|
| 417 | - $sql = "VNUM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 415 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 416 | + $table_name = 'esp_venue_meta'; |
|
| 417 | + $sql = "VNUM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 418 | 418 | VNU_ID bigint(20) unsigned NOT NULL DEFAULT 0, |
| 419 | 419 | VNU_address varchar(255) DEFAULT NULL, |
| 420 | 420 | VNU_address2 varchar(255) DEFAULT NULL, |
@@ -432,10 +432,10 @@ discard block |
||
| 432 | 432 | PRIMARY KEY (VNUM_ID), |
| 433 | 433 | KEY STA_ID (STA_ID), |
| 434 | 434 | KEY CNT_ISO (CNT_ISO)"; |
| 435 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 436 | - // modified tables |
|
| 437 | - $table_name = "esp_price"; |
|
| 438 | - $sql = "PRC_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 435 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 436 | + // modified tables |
|
| 437 | + $table_name = "esp_price"; |
|
| 438 | + $sql = "PRC_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 439 | 439 | PRT_ID tinyint(3) unsigned NOT NULL, |
| 440 | 440 | PRC_amount decimal(10,3) NOT NULL DEFAULT '0.00', |
| 441 | 441 | PRC_name varchar(245) NOT NULL, |
@@ -447,9 +447,9 @@ discard block |
||
| 447 | 447 | PRC_wp_user bigint(20) unsigned NULL, |
| 448 | 448 | PRC_parent int(10) unsigned DEFAULT 0, |
| 449 | 449 | PRIMARY KEY (PRC_ID)"; |
| 450 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 451 | - $table_name = "esp_price_type"; |
|
| 452 | - $sql = "PRT_ID tinyint(3) unsigned NOT NULL AUTO_INCREMENT, |
|
| 450 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 451 | + $table_name = "esp_price_type"; |
|
| 452 | + $sql = "PRT_ID tinyint(3) unsigned NOT NULL AUTO_INCREMENT, |
|
| 453 | 453 | PRT_name varchar(45) NOT NULL, |
| 454 | 454 | PBT_ID tinyint(3) unsigned NOT NULL DEFAULT '1', |
| 455 | 455 | PRT_is_percent tinyint(1) NOT NULL DEFAULT '0', |
@@ -458,9 +458,9 @@ discard block |
||
| 458 | 458 | PRT_deleted tinyint(1) NOT NULL DEFAULT '0', |
| 459 | 459 | UNIQUE KEY PRT_name_UNIQUE (PRT_name), |
| 460 | 460 | PRIMARY KEY (PRT_ID)"; |
| 461 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 462 | - $table_name = "esp_ticket"; |
|
| 463 | - $sql = "TKT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 461 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 462 | + $table_name = "esp_ticket"; |
|
| 463 | + $sql = "TKT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 464 | 464 | TTM_ID int(10) unsigned NOT NULL, |
| 465 | 465 | TKT_name varchar(245) NOT NULL DEFAULT '', |
| 466 | 466 | TKT_description text NOT NULL, |
@@ -481,10 +481,10 @@ discard block |
||
| 481 | 481 | TKT_parent int(10) unsigned DEFAULT '0', |
| 482 | 482 | TKT_deleted tinyint(1) NOT NULL DEFAULT '0', |
| 483 | 483 | PRIMARY KEY (TKT_ID)"; |
| 484 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 485 | - $this->_get_table_manager()->dropIndex('esp_question_group', 'QSG_identifier_UNIQUE'); |
|
| 486 | - $table_name = 'esp_question_group'; |
|
| 487 | - $sql = 'QSG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 484 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 485 | + $this->_get_table_manager()->dropIndex('esp_question_group', 'QSG_identifier_UNIQUE'); |
|
| 486 | + $table_name = 'esp_question_group'; |
|
| 487 | + $sql = 'QSG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 488 | 488 | QSG_name varchar(255) NOT NULL, |
| 489 | 489 | QSG_identifier varchar(100) NOT NULL, |
| 490 | 490 | QSG_desc text NULL, |
@@ -496,124 +496,124 @@ discard block |
||
| 496 | 496 | QSG_wp_user bigint(20) unsigned NULL, |
| 497 | 497 | PRIMARY KEY (QSG_ID), |
| 498 | 498 | UNIQUE KEY QSG_identifier_UNIQUE (QSG_identifier ASC)'; |
| 499 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 500 | - /** @var EE_DMS_Core_4_1_0 $script_4_1_defaults */ |
|
| 501 | - $script_4_1_defaults = EE_Registry::instance()->load_dms('Core_4_1_0'); |
|
| 502 | - // (because many need to convert old string states to foreign keys into the states table) |
|
| 503 | - $script_4_1_defaults->insert_default_states(); |
|
| 504 | - $script_4_1_defaults->insert_default_countries(); |
|
| 505 | - /** @var EE_DMS_Core_4_5_0 $script_4_5_defaults */ |
|
| 506 | - $script_4_5_defaults = EE_Registry::instance()->load_dms('Core_4_5_0'); |
|
| 507 | - $script_4_5_defaults->insert_default_price_types(); |
|
| 508 | - $script_4_5_defaults->insert_default_prices(); |
|
| 509 | - $script_4_5_defaults->insert_default_tickets(); |
|
| 510 | - // setting up the config wp option pretty well counts as a 'schema change', or at least should happen here |
|
| 511 | - EE_Config::instance()->update_espresso_config(false, true); |
|
| 512 | - $this->add_default_admin_only_payments(); |
|
| 513 | - $this->insert_default_currencies(); |
|
| 514 | - return true; |
|
| 515 | - } |
|
| 499 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 500 | + /** @var EE_DMS_Core_4_1_0 $script_4_1_defaults */ |
|
| 501 | + $script_4_1_defaults = EE_Registry::instance()->load_dms('Core_4_1_0'); |
|
| 502 | + // (because many need to convert old string states to foreign keys into the states table) |
|
| 503 | + $script_4_1_defaults->insert_default_states(); |
|
| 504 | + $script_4_1_defaults->insert_default_countries(); |
|
| 505 | + /** @var EE_DMS_Core_4_5_0 $script_4_5_defaults */ |
|
| 506 | + $script_4_5_defaults = EE_Registry::instance()->load_dms('Core_4_5_0'); |
|
| 507 | + $script_4_5_defaults->insert_default_price_types(); |
|
| 508 | + $script_4_5_defaults->insert_default_prices(); |
|
| 509 | + $script_4_5_defaults->insert_default_tickets(); |
|
| 510 | + // setting up the config wp option pretty well counts as a 'schema change', or at least should happen here |
|
| 511 | + EE_Config::instance()->update_espresso_config(false, true); |
|
| 512 | + $this->add_default_admin_only_payments(); |
|
| 513 | + $this->insert_default_currencies(); |
|
| 514 | + return true; |
|
| 515 | + } |
|
| 516 | 516 | |
| 517 | 517 | |
| 518 | 518 | |
| 519 | - /** |
|
| 520 | - * @return boolean |
|
| 521 | - */ |
|
| 522 | - public function schema_changes_after_migration() |
|
| 523 | - { |
|
| 524 | - return true; |
|
| 525 | - } |
|
| 519 | + /** |
|
| 520 | + * @return boolean |
|
| 521 | + */ |
|
| 522 | + public function schema_changes_after_migration() |
|
| 523 | + { |
|
| 524 | + return true; |
|
| 525 | + } |
|
| 526 | 526 | |
| 527 | 527 | |
| 528 | 528 | |
| 529 | - public function migration_page_hooks() |
|
| 530 | - { |
|
| 531 | - } |
|
| 529 | + public function migration_page_hooks() |
|
| 530 | + { |
|
| 531 | + } |
|
| 532 | 532 | |
| 533 | 533 | |
| 534 | 534 | |
| 535 | - public function add_default_admin_only_payments() |
|
| 536 | - { |
|
| 537 | - global $wpdb; |
|
| 538 | - $table_name = $wpdb->prefix . "esp_payment_method"; |
|
| 539 | - $user_id = EEH_Activation::get_default_creator_id(); |
|
| 540 | - if ($this->_get_table_analysis()->tableExists($table_name)) { |
|
| 541 | - $SQL = "SELECT COUNT( * ) FROM $table_name"; |
|
| 542 | - $existing_payment_methods = $wpdb->get_var($SQL); |
|
| 543 | - $default_admin_only_payment_methods = apply_filters( |
|
| 544 | - 'FHEE__EEH_Activation__add_default_admin_only_payments__default_admin_only_payment_methods', |
|
| 545 | - array( |
|
| 546 | - (string) __("Bank", 'event_espresso') => __("Bank Draft", 'event_espresso'), |
|
| 547 | - (string) __("Cash", 'event_espresso') => __("Cash Delivered Physically", 'event_espresso'), |
|
| 548 | - (string) __("Check", 'event_espresso') => __("Paper Check", 'event_espresso'), |
|
| 549 | - (string) __("Credit Card", 'event_espresso') => __("Offline Credit Card Payment", 'event_espresso'), |
|
| 550 | - (string) __("Debit Card", 'event_espresso') => __("Offline Debit Payment", 'event_espresso'), |
|
| 551 | - (string) __("Invoice", 'event_espresso') => __( |
|
| 552 | - "Invoice received with monies included", |
|
| 553 | - 'event_espresso' |
|
| 554 | - ), |
|
| 555 | - (string) __("Money Order", 'event_espresso') => '', |
|
| 556 | - (string) __("Paypal", 'event_espresso') => __("Paypal eCheck, Invoice, etc", 'event_espresso'), |
|
| 557 | - (string) __('Other', 'event_espresso') => __('Other method of payment', 'event_espresso'), |
|
| 558 | - ) |
|
| 559 | - ); |
|
| 560 | - // make sure we hae payment method records for the following |
|
| 561 | - // so admins can record payments for them from the admin page |
|
| 562 | - foreach ($default_admin_only_payment_methods as $nicename => $description) { |
|
| 563 | - $slug = sanitize_key($nicename); |
|
| 564 | - // check that such a payment method exists |
|
| 565 | - $exists = $wpdb->get_var($wpdb->prepare("SELECT count(*) FROM $table_name WHERE PMD_slug = %s", $slug)); |
|
| 566 | - if (! $exists) { |
|
| 567 | - $values = array( |
|
| 568 | - 'PMD_type' => 'Admin_Only', |
|
| 569 | - 'PMD_name' => $nicename, |
|
| 570 | - 'PMD_admin_name' => $nicename, |
|
| 571 | - 'PMD_admin_desc' => $description, |
|
| 572 | - 'PMD_slug' => $slug, |
|
| 573 | - 'PMD_wp_user' => $user_id, |
|
| 574 | - 'PMD_scope' => serialize(array('ADMIN')), |
|
| 575 | - ); |
|
| 576 | - $success = $wpdb->insert( |
|
| 577 | - $table_name, |
|
| 578 | - $values, |
|
| 579 | - array( |
|
| 580 | - '%s',// PMD_type |
|
| 581 | - '%s',// PMD_name |
|
| 582 | - '%s',// PMD_admin_name |
|
| 583 | - '%s',// PMD_admin_desc |
|
| 584 | - '%s',// PMD_slug |
|
| 585 | - '%d',// PMD_wp_user |
|
| 586 | - '%s',// PMD_scope |
|
| 587 | - ) |
|
| 588 | - ); |
|
| 589 | - if (! $success) { |
|
| 590 | - $this->add_error(sprintf(__( |
|
| 591 | - "Could not insert new admin-only payment method with values %s during migration", |
|
| 592 | - "event_espresso" |
|
| 593 | - ), $this->_json_encode($values))); |
|
| 594 | - } |
|
| 595 | - } |
|
| 596 | - } |
|
| 597 | - } |
|
| 598 | - } |
|
| 535 | + public function add_default_admin_only_payments() |
|
| 536 | + { |
|
| 537 | + global $wpdb; |
|
| 538 | + $table_name = $wpdb->prefix . "esp_payment_method"; |
|
| 539 | + $user_id = EEH_Activation::get_default_creator_id(); |
|
| 540 | + if ($this->_get_table_analysis()->tableExists($table_name)) { |
|
| 541 | + $SQL = "SELECT COUNT( * ) FROM $table_name"; |
|
| 542 | + $existing_payment_methods = $wpdb->get_var($SQL); |
|
| 543 | + $default_admin_only_payment_methods = apply_filters( |
|
| 544 | + 'FHEE__EEH_Activation__add_default_admin_only_payments__default_admin_only_payment_methods', |
|
| 545 | + array( |
|
| 546 | + (string) __("Bank", 'event_espresso') => __("Bank Draft", 'event_espresso'), |
|
| 547 | + (string) __("Cash", 'event_espresso') => __("Cash Delivered Physically", 'event_espresso'), |
|
| 548 | + (string) __("Check", 'event_espresso') => __("Paper Check", 'event_espresso'), |
|
| 549 | + (string) __("Credit Card", 'event_espresso') => __("Offline Credit Card Payment", 'event_espresso'), |
|
| 550 | + (string) __("Debit Card", 'event_espresso') => __("Offline Debit Payment", 'event_espresso'), |
|
| 551 | + (string) __("Invoice", 'event_espresso') => __( |
|
| 552 | + "Invoice received with monies included", |
|
| 553 | + 'event_espresso' |
|
| 554 | + ), |
|
| 555 | + (string) __("Money Order", 'event_espresso') => '', |
|
| 556 | + (string) __("Paypal", 'event_espresso') => __("Paypal eCheck, Invoice, etc", 'event_espresso'), |
|
| 557 | + (string) __('Other', 'event_espresso') => __('Other method of payment', 'event_espresso'), |
|
| 558 | + ) |
|
| 559 | + ); |
|
| 560 | + // make sure we hae payment method records for the following |
|
| 561 | + // so admins can record payments for them from the admin page |
|
| 562 | + foreach ($default_admin_only_payment_methods as $nicename => $description) { |
|
| 563 | + $slug = sanitize_key($nicename); |
|
| 564 | + // check that such a payment method exists |
|
| 565 | + $exists = $wpdb->get_var($wpdb->prepare("SELECT count(*) FROM $table_name WHERE PMD_slug = %s", $slug)); |
|
| 566 | + if (! $exists) { |
|
| 567 | + $values = array( |
|
| 568 | + 'PMD_type' => 'Admin_Only', |
|
| 569 | + 'PMD_name' => $nicename, |
|
| 570 | + 'PMD_admin_name' => $nicename, |
|
| 571 | + 'PMD_admin_desc' => $description, |
|
| 572 | + 'PMD_slug' => $slug, |
|
| 573 | + 'PMD_wp_user' => $user_id, |
|
| 574 | + 'PMD_scope' => serialize(array('ADMIN')), |
|
| 575 | + ); |
|
| 576 | + $success = $wpdb->insert( |
|
| 577 | + $table_name, |
|
| 578 | + $values, |
|
| 579 | + array( |
|
| 580 | + '%s',// PMD_type |
|
| 581 | + '%s',// PMD_name |
|
| 582 | + '%s',// PMD_admin_name |
|
| 583 | + '%s',// PMD_admin_desc |
|
| 584 | + '%s',// PMD_slug |
|
| 585 | + '%d',// PMD_wp_user |
|
| 586 | + '%s',// PMD_scope |
|
| 587 | + ) |
|
| 588 | + ); |
|
| 589 | + if (! $success) { |
|
| 590 | + $this->add_error(sprintf(__( |
|
| 591 | + "Could not insert new admin-only payment method with values %s during migration", |
|
| 592 | + "event_espresso" |
|
| 593 | + ), $this->_json_encode($values))); |
|
| 594 | + } |
|
| 595 | + } |
|
| 596 | + } |
|
| 597 | + } |
|
| 598 | + } |
|
| 599 | 599 | |
| 600 | 600 | |
| 601 | 601 | |
| 602 | - /** |
|
| 603 | - * insert_default_countries |
|
| 604 | - * |
|
| 605 | - * @static |
|
| 606 | - * @return void |
|
| 607 | - */ |
|
| 608 | - public function insert_default_currencies() |
|
| 609 | - { |
|
| 610 | - global $wpdb; |
|
| 611 | - $currency_table = $wpdb->prefix . "esp_currency"; |
|
| 612 | - if ($this->_get_table_analysis()->tableExists($currency_table)) { |
|
| 613 | - $SQL = "SELECT COUNT('CUR_code') FROM $currency_table"; |
|
| 614 | - $countries = $wpdb->get_var($SQL); |
|
| 615 | - if (! $countries) { |
|
| 616 | - $SQL = "INSERT INTO $currency_table |
|
| 602 | + /** |
|
| 603 | + * insert_default_countries |
|
| 604 | + * |
|
| 605 | + * @static |
|
| 606 | + * @return void |
|
| 607 | + */ |
|
| 608 | + public function insert_default_currencies() |
|
| 609 | + { |
|
| 610 | + global $wpdb; |
|
| 611 | + $currency_table = $wpdb->prefix . "esp_currency"; |
|
| 612 | + if ($this->_get_table_analysis()->tableExists($currency_table)) { |
|
| 613 | + $SQL = "SELECT COUNT('CUR_code') FROM $currency_table"; |
|
| 614 | + $countries = $wpdb->get_var($SQL); |
|
| 615 | + if (! $countries) { |
|
| 616 | + $SQL = "INSERT INTO $currency_table |
|
| 617 | 617 | ( CUR_code, CUR_single, CUR_plural, CUR_sign, CUR_dec_plc, CUR_active) VALUES |
| 618 | 618 | ( 'EUR', 'Euro', 'Euros', '€', 2,1), |
| 619 | 619 | ( 'AED', 'Dirham', 'Dirhams', 'د.إ',2,1), |
@@ -767,8 +767,8 @@ discard block |
||
| 767 | 767 | ( 'ZAR', 'Rand', 'Rands', 'R', 2,1), |
| 768 | 768 | ( 'ZMK', 'Kwacha', 'Kwachas', '', 2,1), |
| 769 | 769 | ( 'ZWD', 'Dollar', 'Dollars', 'Z$', 2,1);"; |
| 770 | - $wpdb->query($SQL); |
|
| 771 | - } |
|
| 772 | - } |
|
| 773 | - } |
|
| 770 | + $wpdb->query($SQL); |
|
| 771 | + } |
|
| 772 | + } |
|
| 773 | + } |
|
| 774 | 774 | } |
@@ -11,12 +11,12 @@ discard block |
||
| 11 | 11 | // unfortunately, this needs to be done upon INCLUSION of this file, |
| 12 | 12 | // instead of construction, because it only gets constructed on first page load |
| 13 | 13 | // (all other times it gets resurrected from a wordpress option) |
| 14 | -$stages = glob(EE_CORE . 'data_migration_scripts/4_6_0_stages/*'); |
|
| 14 | +$stages = glob(EE_CORE.'data_migration_scripts/4_6_0_stages/*'); |
|
| 15 | 15 | $class_to_filepath = array(); |
| 16 | 16 | foreach ($stages as $filepath) { |
| 17 | 17 | $matches = array(); |
| 18 | 18 | preg_match('~4_6_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
| 19 | - $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 19 | + $class_to_filepath[$matches[1]] = $filepath; |
|
| 20 | 20 | } |
| 21 | 21 | // give addons a chance to autoload their stages too |
| 22 | 22 | $class_to_filepath = apply_filters('FHEE__EE_DMS_4_6_0__autoloaded_stages', $class_to_filepath); |
@@ -70,10 +70,10 @@ discard block |
||
| 70 | 70 | if (version_compare($version_string, '4.6.0.decaf', '<') && version_compare($version_string, '4.5.0.decaf', '>=')) { |
| 71 | 71 | // echo "$version_string can be migrated from"; |
| 72 | 72 | return true; |
| 73 | - } elseif (! $version_string) { |
|
| 73 | + } elseif ( ! $version_string) { |
|
| 74 | 74 | // echo "no version string provided: $version_string"; |
| 75 | 75 | // no version string provided... this must be pre 4.3 |
| 76 | - return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 76 | + return false; // changed mind. dont want people thinking they should migrate yet because they cant |
|
| 77 | 77 | } else { |
| 78 | 78 | // echo "$version_string doesnt apply"; |
| 79 | 79 | return false; |
@@ -88,7 +88,7 @@ discard block |
||
| 88 | 88 | public function schema_changes_before_migration() |
| 89 | 89 | { |
| 90 | 90 | // relies on 4.1's EEH_Activation::create_table |
| 91 | - require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 91 | + require_once(EE_HELPERS.'EEH_Activation.helper.php'); |
|
| 92 | 92 | $table_name = 'esp_answer'; |
| 93 | 93 | $sql = "ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
| 94 | 94 | REG_ID int(10) unsigned NOT NULL, |
@@ -535,7 +535,7 @@ discard block |
||
| 535 | 535 | public function add_default_admin_only_payments() |
| 536 | 536 | { |
| 537 | 537 | global $wpdb; |
| 538 | - $table_name = $wpdb->prefix . "esp_payment_method"; |
|
| 538 | + $table_name = $wpdb->prefix."esp_payment_method"; |
|
| 539 | 539 | $user_id = EEH_Activation::get_default_creator_id(); |
| 540 | 540 | if ($this->_get_table_analysis()->tableExists($table_name)) { |
| 541 | 541 | $SQL = "SELECT COUNT( * ) FROM $table_name"; |
@@ -563,7 +563,7 @@ discard block |
||
| 563 | 563 | $slug = sanitize_key($nicename); |
| 564 | 564 | // check that such a payment method exists |
| 565 | 565 | $exists = $wpdb->get_var($wpdb->prepare("SELECT count(*) FROM $table_name WHERE PMD_slug = %s", $slug)); |
| 566 | - if (! $exists) { |
|
| 566 | + if ( ! $exists) { |
|
| 567 | 567 | $values = array( |
| 568 | 568 | 'PMD_type' => 'Admin_Only', |
| 569 | 569 | 'PMD_name' => $nicename, |
@@ -577,16 +577,16 @@ discard block |
||
| 577 | 577 | $table_name, |
| 578 | 578 | $values, |
| 579 | 579 | array( |
| 580 | - '%s',// PMD_type |
|
| 581 | - '%s',// PMD_name |
|
| 582 | - '%s',// PMD_admin_name |
|
| 583 | - '%s',// PMD_admin_desc |
|
| 584 | - '%s',// PMD_slug |
|
| 585 | - '%d',// PMD_wp_user |
|
| 586 | - '%s',// PMD_scope |
|
| 580 | + '%s', // PMD_type |
|
| 581 | + '%s', // PMD_name |
|
| 582 | + '%s', // PMD_admin_name |
|
| 583 | + '%s', // PMD_admin_desc |
|
| 584 | + '%s', // PMD_slug |
|
| 585 | + '%d', // PMD_wp_user |
|
| 586 | + '%s', // PMD_scope |
|
| 587 | 587 | ) |
| 588 | 588 | ); |
| 589 | - if (! $success) { |
|
| 589 | + if ( ! $success) { |
|
| 590 | 590 | $this->add_error(sprintf(__( |
| 591 | 591 | "Could not insert new admin-only payment method with values %s during migration", |
| 592 | 592 | "event_espresso" |
@@ -608,11 +608,11 @@ discard block |
||
| 608 | 608 | public function insert_default_currencies() |
| 609 | 609 | { |
| 610 | 610 | global $wpdb; |
| 611 | - $currency_table = $wpdb->prefix . "esp_currency"; |
|
| 611 | + $currency_table = $wpdb->prefix."esp_currency"; |
|
| 612 | 612 | if ($this->_get_table_analysis()->tableExists($currency_table)) { |
| 613 | 613 | $SQL = "SELECT COUNT('CUR_code') FROM $currency_table"; |
| 614 | 614 | $countries = $wpdb->get_var($SQL); |
| 615 | - if (! $countries) { |
|
| 615 | + if ( ! $countries) { |
|
| 616 | 616 | $SQL = "INSERT INTO $currency_table |
| 617 | 617 | ( CUR_code, CUR_single, CUR_plural, CUR_sign, CUR_dec_plc, CUR_active) VALUES |
| 618 | 618 | ( 'EUR', 'Euro', 'Euros', '€', 2,1), |
@@ -9,7 +9,6 @@ discard block |
||
| 9 | 9 | * and recalculates esp_registration.REG_final_price to actually be the final price |
| 10 | 10 | * for that registration (before this it was just the ticket's price, NOT including |
| 11 | 11 | * taxes or other price modifiers) |
| 12 | - |
|
| 13 | 12 | */ |
| 14 | 13 | // make sure we have all the stages loaded too |
| 15 | 14 | // unfortunately, this needs to be done upon INCLUSION of this file, |
@@ -18,9 +17,9 @@ discard block |
||
| 18 | 17 | $stages = glob(EE_CORE . 'data_migration_scripts/4_7_0_stages/*'); |
| 19 | 18 | $class_to_filepath = array(); |
| 20 | 19 | foreach ($stages as $filepath) { |
| 21 | - $matches = array(); |
|
| 22 | - preg_match('~4_7_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
|
| 23 | - $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 20 | + $matches = array(); |
|
| 21 | + preg_match('~4_7_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
|
| 22 | + $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 24 | 23 | } |
| 25 | 24 | // give addons a chance to autoload their stages too |
| 26 | 25 | $class_to_filepath = apply_filters('FHEE__EE_DMS_4_7_0__autoloaded_stages', $class_to_filepath); |
@@ -39,71 +38,71 @@ discard block |
||
| 39 | 38 | class EE_DMS_Core_4_7_0 extends EE_Data_Migration_Script_Base |
| 40 | 39 | { |
| 41 | 40 | |
| 42 | - /** |
|
| 43 | - * return EE_DMS_Core_4_7_0 |
|
| 44 | - * |
|
| 45 | - * @param TableManager $table_manager |
|
| 46 | - * @param TableAnalysis $table_analysis |
|
| 47 | - */ |
|
| 48 | - public function __construct(TableManager $table_manager = null, TableAnalysis $table_analysis = null) |
|
| 49 | - { |
|
| 50 | - $this->_pretty_name = __("Data Update to Event Espresso 4.7.0", "event_espresso"); |
|
| 51 | - $this->_priority = 10; |
|
| 52 | - $this->_migration_stages = array( |
|
| 53 | - new EE_DMS_4_7_0_Add_Taxes_To_REG_Final_Price(), |
|
| 54 | - new EE_DMS_4_7_0_Registration_Payments(), |
|
| 55 | - ); |
|
| 56 | - parent::__construct($table_manager, $table_analysis); |
|
| 57 | - } |
|
| 41 | + /** |
|
| 42 | + * return EE_DMS_Core_4_7_0 |
|
| 43 | + * |
|
| 44 | + * @param TableManager $table_manager |
|
| 45 | + * @param TableAnalysis $table_analysis |
|
| 46 | + */ |
|
| 47 | + public function __construct(TableManager $table_manager = null, TableAnalysis $table_analysis = null) |
|
| 48 | + { |
|
| 49 | + $this->_pretty_name = __("Data Update to Event Espresso 4.7.0", "event_espresso"); |
|
| 50 | + $this->_priority = 10; |
|
| 51 | + $this->_migration_stages = array( |
|
| 52 | + new EE_DMS_4_7_0_Add_Taxes_To_REG_Final_Price(), |
|
| 53 | + new EE_DMS_4_7_0_Registration_Payments(), |
|
| 54 | + ); |
|
| 55 | + parent::__construct($table_manager, $table_analysis); |
|
| 56 | + } |
|
| 58 | 57 | |
| 59 | 58 | |
| 60 | 59 | |
| 61 | - /** |
|
| 62 | - * @param array $version_array |
|
| 63 | - * @return bool |
|
| 64 | - */ |
|
| 65 | - public function can_migrate_from_version($version_array) |
|
| 66 | - { |
|
| 67 | - $version_string = $version_array['Core']; |
|
| 68 | - if (( |
|
| 69 | - version_compare($version_string, '4.7.0.decaf', '<') |
|
| 70 | - && version_compare($version_string, '4.6.0.decaf', '>=') |
|
| 71 | - ) |
|
| 72 | - || ( |
|
| 73 | - version_compare($version_string, '4.7.0.decaf', '>=') |
|
| 74 | - && ! $this->_get_table_analysis()->tableExists('esp_registration_payment') |
|
| 75 | - && $this->_get_table_analysis()->tableExists('esp_registration') |
|
| 76 | - ) |
|
| 77 | - ) { |
|
| 78 | - return true; |
|
| 79 | - } elseif (! $version_string) { |
|
| 80 | - // no version string provided... this must be pre 4.3 |
|
| 81 | - return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 82 | - } else { |
|
| 83 | - return false; |
|
| 84 | - } |
|
| 85 | - } |
|
| 60 | + /** |
|
| 61 | + * @param array $version_array |
|
| 62 | + * @return bool |
|
| 63 | + */ |
|
| 64 | + public function can_migrate_from_version($version_array) |
|
| 65 | + { |
|
| 66 | + $version_string = $version_array['Core']; |
|
| 67 | + if (( |
|
| 68 | + version_compare($version_string, '4.7.0.decaf', '<') |
|
| 69 | + && version_compare($version_string, '4.6.0.decaf', '>=') |
|
| 70 | + ) |
|
| 71 | + || ( |
|
| 72 | + version_compare($version_string, '4.7.0.decaf', '>=') |
|
| 73 | + && ! $this->_get_table_analysis()->tableExists('esp_registration_payment') |
|
| 74 | + && $this->_get_table_analysis()->tableExists('esp_registration') |
|
| 75 | + ) |
|
| 76 | + ) { |
|
| 77 | + return true; |
|
| 78 | + } elseif (! $version_string) { |
|
| 79 | + // no version string provided... this must be pre 4.3 |
|
| 80 | + return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 81 | + } else { |
|
| 82 | + return false; |
|
| 83 | + } |
|
| 84 | + } |
|
| 86 | 85 | |
| 87 | 86 | |
| 88 | 87 | |
| 89 | - /** |
|
| 90 | - * @return bool |
|
| 91 | - */ |
|
| 92 | - public function schema_changes_before_migration() |
|
| 93 | - { |
|
| 94 | - // relies on 4.1's EEH_Activation::create_table |
|
| 95 | - require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 96 | - $table_name = 'esp_answer'; |
|
| 97 | - $sql = " ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 88 | + /** |
|
| 89 | + * @return bool |
|
| 90 | + */ |
|
| 91 | + public function schema_changes_before_migration() |
|
| 92 | + { |
|
| 93 | + // relies on 4.1's EEH_Activation::create_table |
|
| 94 | + require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 95 | + $table_name = 'esp_answer'; |
|
| 96 | + $sql = " ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 98 | 97 | REG_ID int(10) unsigned NOT NULL, |
| 99 | 98 | QST_ID int(10) unsigned NOT NULL, |
| 100 | 99 | ANS_value text NOT NULL, |
| 101 | 100 | PRIMARY KEY (ANS_ID), |
| 102 | 101 | KEY REG_ID (REG_ID), |
| 103 | 102 | KEY QST_ID (QST_ID)"; |
| 104 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 105 | - $table_name = 'esp_attendee_meta'; |
|
| 106 | - $sql = "ATTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 103 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 104 | + $table_name = 'esp_attendee_meta'; |
|
| 105 | + $sql = "ATTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 107 | 106 | ATT_ID bigint(20) unsigned NOT NULL, |
| 108 | 107 | ATT_fname varchar(45) NOT NULL, |
| 109 | 108 | ATT_lname varchar(45) NOT NULL, |
@@ -120,9 +119,9 @@ discard block |
||
| 120 | 119 | KEY ATT_email (ATT_email(191)), |
| 121 | 120 | KEY ATT_lname (ATT_lname), |
| 122 | 121 | KEY ATT_fname (ATT_fname)"; |
| 123 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 124 | - $table_name = 'esp_country'; |
|
| 125 | - $sql = "CNT_ISO varchar(2) COLLATE utf8_bin NOT NULL, |
|
| 122 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 123 | + $table_name = 'esp_country'; |
|
| 124 | + $sql = "CNT_ISO varchar(2) COLLATE utf8_bin NOT NULL, |
|
| 126 | 125 | CNT_ISO3 varchar(3) COLLATE utf8_bin NOT NULL, |
| 127 | 126 | RGN_ID tinyint(3) unsigned DEFAULT NULL, |
| 128 | 127 | CNT_name varchar(45) COLLATE utf8_bin NOT NULL, |
@@ -138,25 +137,25 @@ discard block |
||
| 138 | 137 | CNT_is_EU tinyint(1) DEFAULT '0', |
| 139 | 138 | CNT_active tinyint(1) DEFAULT '0', |
| 140 | 139 | PRIMARY KEY (CNT_ISO)"; |
| 141 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 142 | - $table_name = 'esp_currency'; |
|
| 143 | - $sql = "CUR_code varchar(6) COLLATE utf8_bin NOT NULL, |
|
| 140 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 141 | + $table_name = 'esp_currency'; |
|
| 142 | + $sql = "CUR_code varchar(6) COLLATE utf8_bin NOT NULL, |
|
| 144 | 143 | CUR_single varchar(45) COLLATE utf8_bin DEFAULT 'dollar', |
| 145 | 144 | CUR_plural varchar(45) COLLATE utf8_bin DEFAULT 'dollars', |
| 146 | 145 | CUR_sign varchar(45) COLLATE utf8_bin DEFAULT '$', |
| 147 | 146 | CUR_dec_plc varchar(1) COLLATE utf8_bin NOT NULL DEFAULT '2', |
| 148 | 147 | CUR_active tinyint(1) DEFAULT '0', |
| 149 | 148 | PRIMARY KEY (CUR_code)"; |
| 150 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 151 | - $table_name = 'esp_currency_payment_method'; |
|
| 152 | - $sql = "CPM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 149 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 150 | + $table_name = 'esp_currency_payment_method'; |
|
| 151 | + $sql = "CPM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 153 | 152 | CUR_code varchar(6) COLLATE utf8_bin NOT NULL, |
| 154 | 153 | PMD_ID int(11) NOT NULL, |
| 155 | 154 | PRIMARY KEY (CPM_ID), |
| 156 | 155 | KEY PMD_ID (PMD_ID)"; |
| 157 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 158 | - $table_name = 'esp_datetime'; |
|
| 159 | - $sql = "DTT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 156 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 157 | + $table_name = 'esp_datetime'; |
|
| 158 | + $sql = "DTT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 160 | 159 | EVT_ID bigint(20) unsigned NOT NULL, |
| 161 | 160 | DTT_name varchar(255) NOT NULL DEFAULT '', |
| 162 | 161 | DTT_description text NOT NULL, |
@@ -172,9 +171,9 @@ discard block |
||
| 172 | 171 | KEY DTT_EVT_start (DTT_EVT_start), |
| 173 | 172 | KEY EVT_ID (EVT_ID), |
| 174 | 173 | KEY DTT_is_primary (DTT_is_primary)"; |
| 175 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 176 | - $table_name = 'esp_event_meta'; |
|
| 177 | - $sql = " |
|
| 174 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 175 | + $table_name = 'esp_event_meta'; |
|
| 176 | + $sql = " |
|
| 178 | 177 | EVTM_ID int(10) NOT NULL AUTO_INCREMENT, |
| 179 | 178 | EVT_ID bigint(20) unsigned NOT NULL, |
| 180 | 179 | EVT_display_desc tinyint(1) unsigned NOT NULL DEFAULT 1, |
@@ -190,34 +189,34 @@ discard block |
||
| 190 | 189 | EVT_donations tinyint(1) NULL, |
| 191 | 190 | PRIMARY KEY (EVTM_ID), |
| 192 | 191 | KEY EVT_ID (EVT_ID)"; |
| 193 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 194 | - $table_name = 'esp_event_question_group'; |
|
| 195 | - $sql = "EQG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 192 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 193 | + $table_name = 'esp_event_question_group'; |
|
| 194 | + $sql = "EQG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 196 | 195 | EVT_ID bigint(20) unsigned NOT NULL, |
| 197 | 196 | QSG_ID int(10) unsigned NOT NULL, |
| 198 | 197 | EQG_primary tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 199 | 198 | PRIMARY KEY (EQG_ID), |
| 200 | 199 | KEY EVT_ID (EVT_ID), |
| 201 | 200 | KEY QSG_ID (QSG_ID)"; |
| 202 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 203 | - $table_name = 'esp_event_venue'; |
|
| 204 | - $sql = "EVV_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 201 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 202 | + $table_name = 'esp_event_venue'; |
|
| 203 | + $sql = "EVV_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 205 | 204 | EVT_ID bigint(20) unsigned NOT NULL, |
| 206 | 205 | VNU_ID bigint(20) unsigned NOT NULL, |
| 207 | 206 | EVV_primary tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 208 | 207 | PRIMARY KEY (EVV_ID)"; |
| 209 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 210 | - $table_name = 'esp_extra_meta'; |
|
| 211 | - $sql = "EXM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 208 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 209 | + $table_name = 'esp_extra_meta'; |
|
| 210 | + $sql = "EXM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 212 | 211 | OBJ_ID int(11) DEFAULT NULL, |
| 213 | 212 | EXM_type varchar(45) DEFAULT NULL, |
| 214 | 213 | EXM_key varchar(45) DEFAULT NULL, |
| 215 | 214 | EXM_value text, |
| 216 | 215 | PRIMARY KEY (EXM_ID), |
| 217 | 216 | KEY EXM_type (EXM_type, OBJ_ID, EXM_key(45))"; |
| 218 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 219 | - $table_name = 'esp_line_item'; |
|
| 220 | - $sql = "LIN_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 217 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 218 | + $table_name = 'esp_line_item'; |
|
| 219 | + $sql = "LIN_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 221 | 220 | LIN_code varchar(245) NOT NULL DEFAULT '', |
| 222 | 221 | TXN_ID int(11) DEFAULT NULL, |
| 223 | 222 | LIN_name varchar(245) NOT NULL DEFAULT '', |
@@ -235,9 +234,9 @@ discard block |
||
| 235 | 234 | PRIMARY KEY (LIN_ID), |
| 236 | 235 | KEY LIN_code (LIN_code(191)), |
| 237 | 236 | KEY TXN_ID (TXN_ID)"; |
| 238 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 239 | - $table_name = 'esp_log'; |
|
| 240 | - $sql = "LOG_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 237 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 238 | + $table_name = 'esp_log'; |
|
| 239 | + $sql = "LOG_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 241 | 240 | LOG_time datetime DEFAULT NULL, |
| 242 | 241 | OBJ_ID varchar(45) DEFAULT NULL, |
| 243 | 242 | OBJ_type varchar(45) DEFAULT NULL, |
@@ -248,18 +247,18 @@ discard block |
||
| 248 | 247 | KEY LOG_time (LOG_time), |
| 249 | 248 | KEY OBJ (OBJ_type,OBJ_ID), |
| 250 | 249 | KEY LOG_type (LOG_type)"; |
| 251 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 252 | - $table_name = 'esp_message_template'; |
|
| 253 | - $sql = "MTP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 250 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 251 | + $table_name = 'esp_message_template'; |
|
| 252 | + $sql = "MTP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 254 | 253 | GRP_ID int(10) unsigned NOT NULL, |
| 255 | 254 | MTP_context varchar(50) NOT NULL, |
| 256 | 255 | MTP_template_field varchar(30) NOT NULL, |
| 257 | 256 | MTP_content text NOT NULL, |
| 258 | 257 | PRIMARY KEY (MTP_ID), |
| 259 | 258 | KEY GRP_ID (GRP_ID)"; |
| 260 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 261 | - $table_name = 'esp_message_template_group'; |
|
| 262 | - $sql = "GRP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 259 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 260 | + $table_name = 'esp_message_template_group'; |
|
| 261 | + $sql = "GRP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 263 | 262 | MTP_user_id int(10) NOT NULL DEFAULT '1', |
| 264 | 263 | MTP_name varchar(245) NOT NULL DEFAULT '', |
| 265 | 264 | MTP_description varchar(245) NOT NULL DEFAULT '', |
@@ -271,17 +270,17 @@ discard block |
||
| 271 | 270 | MTP_is_active tinyint(1) NOT NULL DEFAULT '1', |
| 272 | 271 | PRIMARY KEY (GRP_ID), |
| 273 | 272 | KEY MTP_user_id (MTP_user_id)"; |
| 274 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 275 | - $table_name = 'esp_event_message_template'; |
|
| 276 | - $sql = "EMT_ID bigint(20) unsigned NOT NULL AUTO_INCREMENT, |
|
| 273 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 274 | + $table_name = 'esp_event_message_template'; |
|
| 275 | + $sql = "EMT_ID bigint(20) unsigned NOT NULL AUTO_INCREMENT, |
|
| 277 | 276 | EVT_ID bigint(20) unsigned NOT NULL DEFAULT 0, |
| 278 | 277 | GRP_ID int(10) unsigned NOT NULL DEFAULT 0, |
| 279 | 278 | PRIMARY KEY (EMT_ID), |
| 280 | 279 | KEY EVT_ID (EVT_ID), |
| 281 | 280 | KEY GRP_ID (GRP_ID)"; |
| 282 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 283 | - $table_name = 'esp_payment'; |
|
| 284 | - $sql = "PAY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 281 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 282 | + $table_name = 'esp_payment'; |
|
| 283 | + $sql = "PAY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 285 | 284 | TXN_ID int(10) unsigned DEFAULT NULL, |
| 286 | 285 | STS_ID varchar(3) COLLATE utf8_bin DEFAULT NULL, |
| 287 | 286 | PAY_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
@@ -298,9 +297,9 @@ discard block |
||
| 298 | 297 | PRIMARY KEY (PAY_ID), |
| 299 | 298 | KEY PAY_timestamp (PAY_timestamp), |
| 300 | 299 | KEY TXN_ID (TXN_ID)"; |
| 301 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 302 | - $table_name = 'esp_payment_method'; |
|
| 303 | - $sql = "PMD_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 300 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 301 | + $table_name = 'esp_payment_method'; |
|
| 302 | + $sql = "PMD_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 304 | 303 | PMD_type varchar(124) DEFAULT NULL, |
| 305 | 304 | PMD_name varchar(255) DEFAULT NULL, |
| 306 | 305 | PMD_desc text, |
@@ -316,32 +315,32 @@ discard block |
||
| 316 | 315 | PRIMARY KEY (PMD_ID), |
| 317 | 316 | UNIQUE KEY PMD_slug_UNIQUE (PMD_slug), |
| 318 | 317 | KEY PMD_type (PMD_type)"; |
| 319 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 320 | - $table_name = "esp_ticket_price"; |
|
| 321 | - $sql = "TKP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 318 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 319 | + $table_name = "esp_ticket_price"; |
|
| 320 | + $sql = "TKP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 322 | 321 | TKT_ID int(10) unsigned NOT NULL, |
| 323 | 322 | PRC_ID int(10) unsigned NOT NULL, |
| 324 | 323 | PRIMARY KEY (TKP_ID), |
| 325 | 324 | KEY TKT_ID (TKT_ID), |
| 326 | 325 | KEY PRC_ID (PRC_ID)"; |
| 327 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 328 | - $table_name = "esp_datetime_ticket"; |
|
| 329 | - $sql = "DTK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 326 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 327 | + $table_name = "esp_datetime_ticket"; |
|
| 328 | + $sql = "DTK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 330 | 329 | DTT_ID int(10) unsigned NOT NULL, |
| 331 | 330 | TKT_ID int(10) unsigned NOT NULL, |
| 332 | 331 | PRIMARY KEY (DTK_ID), |
| 333 | 332 | KEY DTT_ID (DTT_ID), |
| 334 | 333 | KEY TKT_ID (TKT_ID)"; |
| 335 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 336 | - $table_name = "esp_ticket_template"; |
|
| 337 | - $sql = "TTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 334 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 335 | + $table_name = "esp_ticket_template"; |
|
| 336 | + $sql = "TTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 338 | 337 | TTM_name varchar(45) NOT NULL, |
| 339 | 338 | TTM_description text, |
| 340 | 339 | TTM_file varchar(45), |
| 341 | 340 | PRIMARY KEY (TTM_ID)"; |
| 342 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 343 | - $table_name = 'esp_question'; |
|
| 344 | - $sql = 'QST_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 341 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 342 | + $table_name = 'esp_question'; |
|
| 343 | + $sql = 'QST_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 345 | 344 | QST_display_text text NOT NULL, |
| 346 | 345 | QST_admin_label varchar(255) NOT NULL, |
| 347 | 346 | QST_system varchar(25) DEFAULT NULL, |
@@ -354,18 +353,18 @@ discard block |
||
| 354 | 353 | QST_deleted tinyint(2) unsigned NOT NULL DEFAULT 0, |
| 355 | 354 | PRIMARY KEY (QST_ID), |
| 356 | 355 | KEY QST_order (QST_order)'; |
| 357 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 358 | - $table_name = 'esp_question_group_question'; |
|
| 359 | - $sql = "QGQ_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 356 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 357 | + $table_name = 'esp_question_group_question'; |
|
| 358 | + $sql = "QGQ_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 360 | 359 | QSG_ID int(10) unsigned NOT NULL, |
| 361 | 360 | QST_ID int(10) unsigned NOT NULL, |
| 362 | 361 | QGQ_order int(10) unsigned NOT NULL DEFAULT 0, |
| 363 | 362 | PRIMARY KEY (QGQ_ID), |
| 364 | 363 | KEY QST_ID (QST_ID), |
| 365 | 364 | KEY QSG_ID_order (QSG_ID, QGQ_order)"; |
| 366 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 367 | - $table_name = 'esp_question_option'; |
|
| 368 | - $sql = "QSO_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 365 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 366 | + $table_name = 'esp_question_option'; |
|
| 367 | + $sql = "QSO_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 369 | 368 | QSO_value varchar(255) NOT NULL, |
| 370 | 369 | QSO_desc text NOT NULL, |
| 371 | 370 | QST_ID int(10) unsigned NOT NULL, |
@@ -374,9 +373,9 @@ discard block |
||
| 374 | 373 | PRIMARY KEY (QSO_ID), |
| 375 | 374 | KEY QST_ID (QST_ID), |
| 376 | 375 | KEY QSO_order (QSO_order)"; |
| 377 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 378 | - $table_name = 'esp_registration'; |
|
| 379 | - $sql = "REG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 376 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 377 | + $table_name = 'esp_registration'; |
|
| 378 | + $sql = "REG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 380 | 379 | EVT_ID bigint(20) unsigned NOT NULL, |
| 381 | 380 | ATT_ID bigint(20) unsigned NOT NULL, |
| 382 | 381 | TXN_ID int(10) unsigned NOT NULL, |
@@ -400,18 +399,18 @@ discard block |
||
| 400 | 399 | KEY TKT_ID (TKT_ID), |
| 401 | 400 | KEY EVT_ID (EVT_ID), |
| 402 | 401 | KEY STS_ID (STS_ID)"; |
| 403 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 404 | - $table_name = 'esp_registration_payment'; |
|
| 405 | - $sql = "RPY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 402 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 403 | + $table_name = 'esp_registration_payment'; |
|
| 404 | + $sql = "RPY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 406 | 405 | REG_ID int(10) unsigned NOT NULL, |
| 407 | 406 | PAY_ID int(10) unsigned NULL, |
| 408 | 407 | RPY_amount decimal(10,3) NOT NULL DEFAULT '0.00', |
| 409 | 408 | PRIMARY KEY (RPY_ID), |
| 410 | 409 | KEY REG_ID (REG_ID), |
| 411 | 410 | KEY PAY_ID (PAY_ID)"; |
| 412 | - $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 413 | - $table_name = 'esp_checkin'; |
|
| 414 | - $sql = "CHK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 411 | + $this->_table_is_new_in_this_version($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 412 | + $table_name = 'esp_checkin'; |
|
| 413 | + $sql = "CHK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 415 | 414 | REG_ID int(10) unsigned NOT NULL, |
| 416 | 415 | DTT_ID int(10) unsigned NOT NULL, |
| 417 | 416 | CHK_in tinyint(1) unsigned NOT NULL DEFAULT 1, |
@@ -419,9 +418,9 @@ discard block |
||
| 419 | 418 | PRIMARY KEY (CHK_ID), |
| 420 | 419 | KEY REG_ID (REG_ID), |
| 421 | 420 | KEY DTT_ID (DTT_ID)"; |
| 422 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 423 | - $table_name = 'esp_state'; |
|
| 424 | - $sql = "STA_ID smallint(5) unsigned NOT NULL AUTO_INCREMENT, |
|
| 421 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 422 | + $table_name = 'esp_state'; |
|
| 423 | + $sql = "STA_ID smallint(5) unsigned NOT NULL AUTO_INCREMENT, |
|
| 425 | 424 | CNT_ISO varchar(2) COLLATE utf8_bin NOT NULL, |
| 426 | 425 | STA_abbrev varchar(24) COLLATE utf8_bin NOT NULL, |
| 427 | 426 | STA_name varchar(100) COLLATE utf8_bin NOT NULL, |
@@ -429,9 +428,9 @@ discard block |
||
| 429 | 428 | PRIMARY KEY (STA_ID), |
| 430 | 429 | KEY STA_abbrev (STA_abbrev), |
| 431 | 430 | KEY CNT_ISO (CNT_ISO)"; |
| 432 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 433 | - $table_name = 'esp_status'; |
|
| 434 | - $sql = "STS_ID varchar(3) COLLATE utf8_bin NOT NULL, |
|
| 431 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 432 | + $table_name = 'esp_status'; |
|
| 433 | + $sql = "STS_ID varchar(3) COLLATE utf8_bin NOT NULL, |
|
| 435 | 434 | STS_code varchar(45) COLLATE utf8_bin NOT NULL, |
| 436 | 435 | STS_type set('event','registration','transaction','payment','email') COLLATE utf8_bin NOT NULL, |
| 437 | 436 | STS_can_edit tinyint(1) NOT NULL DEFAULT 0, |
@@ -439,9 +438,9 @@ discard block |
||
| 439 | 438 | STS_open tinyint(1) NOT NULL DEFAULT 1, |
| 440 | 439 | UNIQUE KEY STS_ID_UNIQUE (STS_ID), |
| 441 | 440 | KEY STS_type (STS_type)"; |
| 442 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 443 | - $table_name = 'esp_transaction'; |
|
| 444 | - $sql = "TXN_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 441 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 442 | + $table_name = 'esp_transaction'; |
|
| 443 | + $sql = "TXN_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 445 | 444 | TXN_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
| 446 | 445 | TXN_total decimal(10,3) DEFAULT '0.00', |
| 447 | 446 | TXN_paid decimal(10,3) NOT NULL DEFAULT '0.00', |
@@ -453,9 +452,9 @@ discard block |
||
| 453 | 452 | PRIMARY KEY (TXN_ID), |
| 454 | 453 | KEY TXN_timestamp (TXN_timestamp), |
| 455 | 454 | KEY STS_ID (STS_ID)"; |
| 456 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 457 | - $table_name = 'esp_venue_meta'; |
|
| 458 | - $sql = "VNUM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 455 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 456 | + $table_name = 'esp_venue_meta'; |
|
| 457 | + $sql = "VNUM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 459 | 458 | VNU_ID bigint(20) unsigned NOT NULL DEFAULT 0, |
| 460 | 459 | VNU_address varchar(255) DEFAULT NULL, |
| 461 | 460 | VNU_address2 varchar(255) DEFAULT NULL, |
@@ -474,10 +473,10 @@ discard block |
||
| 474 | 473 | KEY VNU_ID (VNU_ID), |
| 475 | 474 | KEY STA_ID (STA_ID), |
| 476 | 475 | KEY CNT_ISO (CNT_ISO)"; |
| 477 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 478 | - // modified tables |
|
| 479 | - $table_name = "esp_price"; |
|
| 480 | - $sql = "PRC_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 476 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 477 | + // modified tables |
|
| 478 | + $table_name = "esp_price"; |
|
| 479 | + $sql = "PRC_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 481 | 480 | PRT_ID tinyint(3) unsigned NOT NULL, |
| 482 | 481 | PRC_amount decimal(10,3) NOT NULL DEFAULT '0.00', |
| 483 | 482 | PRC_name varchar(245) NOT NULL, |
@@ -490,9 +489,9 @@ discard block |
||
| 490 | 489 | PRC_parent int(10) unsigned DEFAULT 0, |
| 491 | 490 | PRIMARY KEY (PRC_ID), |
| 492 | 491 | KEY PRT_ID (PRT_ID)"; |
| 493 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 494 | - $table_name = "esp_price_type"; |
|
| 495 | - $sql = "PRT_ID tinyint(3) unsigned NOT NULL AUTO_INCREMENT, |
|
| 492 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 493 | + $table_name = "esp_price_type"; |
|
| 494 | + $sql = "PRT_ID tinyint(3) unsigned NOT NULL AUTO_INCREMENT, |
|
| 496 | 495 | PRT_name varchar(45) NOT NULL, |
| 497 | 496 | PBT_ID tinyint(3) unsigned NOT NULL DEFAULT '1', |
| 498 | 497 | PRT_is_percent tinyint(1) NOT NULL DEFAULT '0', |
@@ -501,9 +500,9 @@ discard block |
||
| 501 | 500 | PRT_deleted tinyint(1) NOT NULL DEFAULT '0', |
| 502 | 501 | UNIQUE KEY PRT_name_UNIQUE (PRT_name), |
| 503 | 502 | PRIMARY KEY (PRT_ID)"; |
| 504 | - $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 505 | - $table_name = "esp_ticket"; |
|
| 506 | - $sql = "TKT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 503 | + $this->_table_has_not_changed_since_previous($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 504 | + $table_name = "esp_ticket"; |
|
| 505 | + $sql = "TKT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 507 | 506 | TTM_ID int(10) unsigned NOT NULL, |
| 508 | 507 | TKT_name varchar(245) NOT NULL DEFAULT '', |
| 509 | 508 | TKT_description text NOT NULL, |
@@ -525,9 +524,9 @@ discard block |
||
| 525 | 524 | TKT_deleted tinyint(1) NOT NULL DEFAULT '0', |
| 526 | 525 | PRIMARY KEY (TKT_ID), |
| 527 | 526 | KEY TKT_start_date (TKT_start_date)"; |
| 528 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 529 | - $table_name = 'esp_question_group'; |
|
| 530 | - $sql = 'QSG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 527 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 528 | + $table_name = 'esp_question_group'; |
|
| 529 | + $sql = 'QSG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 531 | 530 | QSG_name varchar(255) NOT NULL, |
| 532 | 531 | QSG_identifier varchar(100) NOT NULL, |
| 533 | 532 | QSG_desc text NULL, |
@@ -540,38 +539,38 @@ discard block |
||
| 540 | 539 | PRIMARY KEY (QSG_ID), |
| 541 | 540 | UNIQUE KEY QSG_identifier_UNIQUE (QSG_identifier), |
| 542 | 541 | KEY QSG_order (QSG_order)'; |
| 543 | - $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 544 | - /** @var EE_DMS_Core_4_1_0 $script_4_1_defaults */ |
|
| 545 | - $script_4_1_defaults = EE_Registry::instance()->load_dms('Core_4_1_0'); |
|
| 546 | - // (because many need to convert old string states to foreign keys into the states table) |
|
| 547 | - $script_4_1_defaults->insert_default_states(); |
|
| 548 | - $script_4_1_defaults->insert_default_countries(); |
|
| 549 | - /** @var EE_DMS_Core_4_5_0 $script_4_5_defaults */ |
|
| 550 | - $script_4_5_defaults = EE_Registry::instance()->load_dms('Core_4_5_0'); |
|
| 551 | - $script_4_5_defaults->insert_default_price_types(); |
|
| 552 | - $script_4_5_defaults->insert_default_prices(); |
|
| 553 | - $script_4_5_defaults->insert_default_tickets(); |
|
| 554 | - /** @var EE_DMS_Core_4_6_0 $script_4_6_defaults */ |
|
| 555 | - $script_4_6_defaults = EE_Registry::instance()->load_dms('Core_4_6_0'); |
|
| 556 | - $script_4_6_defaults->add_default_admin_only_payments(); |
|
| 557 | - $script_4_6_defaults->insert_default_currencies(); |
|
| 558 | - return true; |
|
| 559 | - } |
|
| 542 | + $this->_table_is_changed_in_this_version($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 543 | + /** @var EE_DMS_Core_4_1_0 $script_4_1_defaults */ |
|
| 544 | + $script_4_1_defaults = EE_Registry::instance()->load_dms('Core_4_1_0'); |
|
| 545 | + // (because many need to convert old string states to foreign keys into the states table) |
|
| 546 | + $script_4_1_defaults->insert_default_states(); |
|
| 547 | + $script_4_1_defaults->insert_default_countries(); |
|
| 548 | + /** @var EE_DMS_Core_4_5_0 $script_4_5_defaults */ |
|
| 549 | + $script_4_5_defaults = EE_Registry::instance()->load_dms('Core_4_5_0'); |
|
| 550 | + $script_4_5_defaults->insert_default_price_types(); |
|
| 551 | + $script_4_5_defaults->insert_default_prices(); |
|
| 552 | + $script_4_5_defaults->insert_default_tickets(); |
|
| 553 | + /** @var EE_DMS_Core_4_6_0 $script_4_6_defaults */ |
|
| 554 | + $script_4_6_defaults = EE_Registry::instance()->load_dms('Core_4_6_0'); |
|
| 555 | + $script_4_6_defaults->add_default_admin_only_payments(); |
|
| 556 | + $script_4_6_defaults->insert_default_currencies(); |
|
| 557 | + return true; |
|
| 558 | + } |
|
| 560 | 559 | |
| 561 | 560 | |
| 562 | 561 | |
| 563 | - /** |
|
| 564 | - * @return boolean |
|
| 565 | - */ |
|
| 566 | - public function schema_changes_after_migration() |
|
| 567 | - { |
|
| 568 | - return true; |
|
| 569 | - } |
|
| 562 | + /** |
|
| 563 | + * @return boolean |
|
| 564 | + */ |
|
| 565 | + public function schema_changes_after_migration() |
|
| 566 | + { |
|
| 567 | + return true; |
|
| 568 | + } |
|
| 570 | 569 | |
| 571 | 570 | |
| 572 | 571 | |
| 573 | - public function migration_page_hooks() |
|
| 574 | - { |
|
| 575 | - } |
|
| 572 | + public function migration_page_hooks() |
|
| 573 | + { |
|
| 574 | + } |
|
| 576 | 575 | } |
| 577 | 576 | // end of file: /core/data_migration_scripts/EE_DMS_Core_4_7_0.dms.php |
@@ -15,11 +15,11 @@ discard block |
||
| 15 | 15 | $stages = glob(EE_CORE . 'data_migration_scripts/4_2_0_stages/*'); |
| 16 | 16 | $class_to_filepath = array(); |
| 17 | 17 | if (! empty($stages)) { |
| 18 | - foreach ($stages as $filepath) { |
|
| 19 | - $matches = array(); |
|
| 20 | - preg_match('~4_2_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
|
| 21 | - $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 22 | - } |
|
| 18 | + foreach ($stages as $filepath) { |
|
| 19 | + $matches = array(); |
|
| 20 | + preg_match('~4_2_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
|
| 21 | + $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 22 | + } |
|
| 23 | 23 | } |
| 24 | 24 | // give addons a chance to autoload their stages too |
| 25 | 25 | $class_to_filepath = apply_filters('FHEE__EE_DMS_4_2_0__autoloaded_stages', $class_to_filepath); |
@@ -32,57 +32,57 @@ discard block |
||
| 32 | 32 | |
| 33 | 33 | |
| 34 | 34 | |
| 35 | - /** |
|
| 36 | - * EE_DMS_Core_4_2_0 constructor. |
|
| 37 | - * |
|
| 38 | - * @param TableManager $table_manager |
|
| 39 | - * @param TableAnalysis $table_analysis |
|
| 40 | - */ |
|
| 41 | - public function __construct(TableManager $table_manager = null, TableAnalysis $table_analysis = null) |
|
| 42 | - { |
|
| 43 | - $this->_pretty_name = esc_html__("Data Update to Event Espresso 4.2.0", "event_espresso"); |
|
| 44 | - $this->_priority = 10; |
|
| 45 | - $this->_migration_stages = array( |
|
| 46 | - new EE_DMS_4_2_0_question_group_questions(), |
|
| 47 | - new EE_DMS_4_2_0_datetime_fields(), |
|
| 48 | - ); |
|
| 49 | - parent::__construct($table_manager, $table_analysis); |
|
| 50 | - } |
|
| 35 | + /** |
|
| 36 | + * EE_DMS_Core_4_2_0 constructor. |
|
| 37 | + * |
|
| 38 | + * @param TableManager $table_manager |
|
| 39 | + * @param TableAnalysis $table_analysis |
|
| 40 | + */ |
|
| 41 | + public function __construct(TableManager $table_manager = null, TableAnalysis $table_analysis = null) |
|
| 42 | + { |
|
| 43 | + $this->_pretty_name = esc_html__("Data Update to Event Espresso 4.2.0", "event_espresso"); |
|
| 44 | + $this->_priority = 10; |
|
| 45 | + $this->_migration_stages = array( |
|
| 46 | + new EE_DMS_4_2_0_question_group_questions(), |
|
| 47 | + new EE_DMS_4_2_0_datetime_fields(), |
|
| 48 | + ); |
|
| 49 | + parent::__construct($table_manager, $table_analysis); |
|
| 50 | + } |
|
| 51 | 51 | |
| 52 | 52 | |
| 53 | 53 | |
| 54 | - public function can_migrate_from_version($version_array) |
|
| 55 | - { |
|
| 56 | - $version_string = $version_array['Core']; |
|
| 57 | - if (version_compare($version_string, '4.2.0.decaf', '<') && version_compare($version_string, '4.1.0.decaf', '>=')) { |
|
| 54 | + public function can_migrate_from_version($version_array) |
|
| 55 | + { |
|
| 56 | + $version_string = $version_array['Core']; |
|
| 57 | + if (version_compare($version_string, '4.2.0.decaf', '<') && version_compare($version_string, '4.1.0.decaf', '>=')) { |
|
| 58 | 58 | // echo "$version_string can be migrated fro"; |
| 59 | - return true; |
|
| 60 | - } elseif (! $version_string) { |
|
| 59 | + return true; |
|
| 60 | + } elseif (! $version_string) { |
|
| 61 | 61 | // echo "no version string provided: $version_string"; |
| 62 | - // no version string provided... this must be pre 4.1 |
|
| 63 | - // because since 4.1 we're |
|
| 64 | - return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 65 | - } else { |
|
| 62 | + // no version string provided... this must be pre 4.1 |
|
| 63 | + // because since 4.1 we're |
|
| 64 | + return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 65 | + } else { |
|
| 66 | 66 | // echo "$version_string doesnt apply"; |
| 67 | - return false; |
|
| 68 | - } |
|
| 69 | - } |
|
| 67 | + return false; |
|
| 68 | + } |
|
| 69 | + } |
|
| 70 | 70 | |
| 71 | 71 | |
| 72 | 72 | |
| 73 | - public function schema_changes_before_migration() |
|
| 74 | - { |
|
| 75 | - // relies on 4.1's EEH_Activation::create_table |
|
| 76 | - require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 77 | - $table_name = 'esp_answer'; |
|
| 78 | - $sql = "ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 73 | + public function schema_changes_before_migration() |
|
| 74 | + { |
|
| 75 | + // relies on 4.1's EEH_Activation::create_table |
|
| 76 | + require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 77 | + $table_name = 'esp_answer'; |
|
| 78 | + $sql = "ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 79 | 79 | REG_ID int(10) unsigned NOT NULL, |
| 80 | 80 | QST_ID int(10) unsigned NOT NULL, |
| 81 | 81 | ANS_value text NOT NULL, |
| 82 | 82 | PRIMARY KEY (ANS_ID)"; |
| 83 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 84 | - $table_name = 'esp_attendee_meta'; |
|
| 85 | - $sql = "ATTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 83 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 84 | + $table_name = 'esp_attendee_meta'; |
|
| 85 | + $sql = "ATTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 86 | 86 | ATT_ID bigint(20) unsigned NOT NULL, |
| 87 | 87 | ATT_fname varchar(45) NOT NULL, |
| 88 | 88 | ATT_lname varchar(45) NOT NULL, |
@@ -98,9 +98,9 @@ discard block |
||
| 98 | 98 | KEY ATT_fname (ATT_fname), |
| 99 | 99 | KEY ATT_lname (ATT_lname), |
| 100 | 100 | KEY ATT_email (ATT_email(191))"; |
| 101 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 102 | - $table_name = 'esp_country'; |
|
| 103 | - $sql = "CNT_ISO varchar(2) COLLATE utf8_bin NOT NULL, |
|
| 101 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 102 | + $table_name = 'esp_country'; |
|
| 103 | + $sql = "CNT_ISO varchar(2) COLLATE utf8_bin NOT NULL, |
|
| 104 | 104 | CNT_ISO3 varchar(3) COLLATE utf8_bin NOT NULL, |
| 105 | 105 | RGN_ID tinyint(3) unsigned DEFAULT NULL, |
| 106 | 106 | CNT_name varchar(45) COLLATE utf8_bin NOT NULL, |
@@ -116,9 +116,9 @@ discard block |
||
| 116 | 116 | CNT_is_EU tinyint(1) DEFAULT '0', |
| 117 | 117 | CNT_active tinyint(1) DEFAULT '0', |
| 118 | 118 | PRIMARY KEY (CNT_ISO)"; |
| 119 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 120 | - $table_name = 'esp_datetime'; |
|
| 121 | - $sql = "DTT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 119 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 120 | + $table_name = 'esp_datetime'; |
|
| 121 | + $sql = "DTT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 122 | 122 | EVT_ID bigint(20) unsigned NOT NULL, |
| 123 | 123 | DTT_name varchar(255) NOT NULL DEFAULT '', |
| 124 | 124 | DTT_description text NOT NULL, |
@@ -133,9 +133,9 @@ discard block |
||
| 133 | 133 | PRIMARY KEY (DTT_ID), |
| 134 | 134 | KEY EVT_ID (EVT_ID), |
| 135 | 135 | KEY DTT_is_primary (DTT_is_primary)"; |
| 136 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 137 | - $table_name = 'esp_event_meta'; |
|
| 138 | - $sql = " |
|
| 136 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 137 | + $table_name = 'esp_event_meta'; |
|
| 138 | + $sql = " |
|
| 139 | 139 | EVTM_ID int(10) NOT NULL AUTO_INCREMENT, |
| 140 | 140 | EVT_ID bigint(20) unsigned NOT NULL, |
| 141 | 141 | EVT_display_desc tinyint(1) unsigned NOT NULL DEFAULT 1, |
@@ -150,31 +150,31 @@ discard block |
||
| 150 | 150 | EVT_external_URL varchar(200) NULL, |
| 151 | 151 | EVT_donations tinyint(1) NULL, |
| 152 | 152 | PRIMARY KEY (EVTM_ID)"; |
| 153 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 154 | - $table_name = 'esp_event_question_group'; |
|
| 155 | - $sql = "EQG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 153 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 154 | + $table_name = 'esp_event_question_group'; |
|
| 155 | + $sql = "EQG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 156 | 156 | EVT_ID bigint(20) unsigned NOT NULL, |
| 157 | 157 | QSG_ID int(10) unsigned NOT NULL, |
| 158 | 158 | EQG_primary tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 159 | 159 | PRIMARY KEY (EQG_ID)"; |
| 160 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 161 | - $table_name = 'esp_event_venue'; |
|
| 162 | - $sql = "EVV_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 160 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 161 | + $table_name = 'esp_event_venue'; |
|
| 162 | + $sql = "EVV_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 163 | 163 | EVT_ID bigint(20) unsigned NOT NULL, |
| 164 | 164 | VNU_ID bigint(20) unsigned NOT NULL, |
| 165 | 165 | EVV_primary tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 166 | 166 | PRIMARY KEY (EVV_ID)"; |
| 167 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 168 | - $table_name = 'esp_extra_meta'; |
|
| 169 | - $sql = "EXM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 167 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 168 | + $table_name = 'esp_extra_meta'; |
|
| 169 | + $sql = "EXM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 170 | 170 | OBJ_ID int(11) DEFAULT NULL, |
| 171 | 171 | EXM_type varchar(45) DEFAULT NULL, |
| 172 | 172 | EXM_key varchar(45) DEFAULT NULL, |
| 173 | 173 | EXM_value text, |
| 174 | 174 | PRIMARY KEY (EXM_ID)"; |
| 175 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 176 | - $table_name = 'esp_line_item'; |
|
| 177 | - $sql = "LIN_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 175 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 176 | + $table_name = 'esp_line_item'; |
|
| 177 | + $sql = "LIN_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 178 | 178 | LIN_code varchar(245) NOT NULL DEFAULT '', |
| 179 | 179 | TXN_ID int(11) DEFAULT NULL, |
| 180 | 180 | LIN_name varchar(245) NOT NULL DEFAULT '', |
@@ -190,18 +190,18 @@ discard block |
||
| 190 | 190 | OBJ_ID int(11) DEFAULT NULL, |
| 191 | 191 | OBJ_type varchar(45)DEFAULT NULL, |
| 192 | 192 | PRIMARY KEY (LIN_ID)"; |
| 193 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 194 | - $table_name = 'esp_message_template'; |
|
| 195 | - $sql = "MTP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 193 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 194 | + $table_name = 'esp_message_template'; |
|
| 195 | + $sql = "MTP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 196 | 196 | GRP_ID int(10) unsigned NOT NULL, |
| 197 | 197 | MTP_context varchar(50) NOT NULL, |
| 198 | 198 | MTP_template_field varchar(30) NOT NULL, |
| 199 | 199 | MTP_content text NOT NULL, |
| 200 | 200 | PRIMARY KEY (MTP_ID), |
| 201 | 201 | KEY GRP_ID (GRP_ID)"; |
| 202 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 203 | - $table_name = 'esp_message_template_group'; |
|
| 204 | - $sql = "GRP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 202 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 203 | + $table_name = 'esp_message_template_group'; |
|
| 204 | + $sql = "GRP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 205 | 205 | EVT_ID bigint(20) unsigned DEFAULT NULL, |
| 206 | 206 | MTP_user_id int(10) NOT NULL DEFAULT '1', |
| 207 | 207 | MTP_messenger varchar(30) NOT NULL, |
@@ -213,9 +213,9 @@ discard block |
||
| 213 | 213 | PRIMARY KEY (GRP_ID), |
| 214 | 214 | KEY EVT_ID (EVT_ID), |
| 215 | 215 | KEY MTP_user_id (MTP_user_id)"; |
| 216 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 217 | - $table_name = 'esp_payment'; |
|
| 218 | - $sql = "PAY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 216 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 217 | + $table_name = 'esp_payment'; |
|
| 218 | + $sql = "PAY_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 219 | 219 | TXN_ID int(10) unsigned DEFAULT NULL, |
| 220 | 220 | STS_ID varchar(3) COLLATE utf8_bin DEFAULT NULL, |
| 221 | 221 | PAY_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
@@ -231,9 +231,9 @@ discard block |
||
| 231 | 231 | PRIMARY KEY (PAY_ID), |
| 232 | 232 | KEY TXN_ID (TXN_ID), |
| 233 | 233 | KEY PAY_timestamp (PAY_timestamp)"; |
| 234 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 235 | - $table_name = "esp_ticket"; |
|
| 236 | - $sql = "TKT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 234 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 235 | + $table_name = "esp_ticket"; |
|
| 236 | + $sql = "TKT_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 237 | 237 | TTM_ID int(10) unsigned NOT NULL, |
| 238 | 238 | TKT_name varchar(245) NOT NULL DEFAULT '', |
| 239 | 239 | TKT_description text NOT NULL, |
@@ -252,28 +252,28 @@ discard block |
||
| 252 | 252 | TKT_parent int(10) unsigned DEFAULT '0', |
| 253 | 253 | TKT_deleted tinyint(1) NOT NULL DEFAULT '0', |
| 254 | 254 | PRIMARY KEY (TKT_ID)"; |
| 255 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 256 | - $table_name = "esp_ticket_price"; |
|
| 257 | - $sql = "TKP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 255 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 256 | + $table_name = "esp_ticket_price"; |
|
| 257 | + $sql = "TKP_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 258 | 258 | TKT_ID int(10) unsigned NOT NULL, |
| 259 | 259 | PRC_ID int(10) unsigned NOT NULL, |
| 260 | 260 | PRIMARY KEY (TKP_ID)"; |
| 261 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 262 | - $table_name = "esp_datetime_ticket"; |
|
| 263 | - $sql = "DTK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 261 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 262 | + $table_name = "esp_datetime_ticket"; |
|
| 263 | + $sql = "DTK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 264 | 264 | DTT_ID int(10) unsigned NOT NULL, |
| 265 | 265 | TKT_ID int(10) unsigned NOT NULL, |
| 266 | 266 | PRIMARY KEY (DTK_ID)"; |
| 267 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 268 | - $table_name = "esp_ticket_template"; |
|
| 269 | - $sql = "TTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 267 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 268 | + $table_name = "esp_ticket_template"; |
|
| 269 | + $sql = "TTM_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 270 | 270 | TTM_name varchar(45) NOT NULL, |
| 271 | 271 | TTM_description text, |
| 272 | 272 | TTM_file varchar(45), |
| 273 | 273 | PRIMARY KEY (TTM_ID)"; |
| 274 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 275 | - $table_name = "esp_price"; |
|
| 276 | - $sql = "PRC_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 274 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 275 | + $table_name = "esp_price"; |
|
| 276 | + $sql = "PRC_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 277 | 277 | PRT_ID tinyint(3) unsigned NOT NULL, |
| 278 | 278 | PRC_amount decimal(10,3) NOT NULL DEFAULT '0.00', |
| 279 | 279 | PRC_name varchar(245) NOT NULL, |
@@ -284,9 +284,9 @@ discard block |
||
| 284 | 284 | PRC_order tinyint(3) unsigned NOT NULL DEFAULT '0', |
| 285 | 285 | PRC_parent int(10) unsigned DEFAULT 0, |
| 286 | 286 | PRIMARY KEY (PRC_ID)"; |
| 287 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 288 | - $table_name = "esp_price_type"; |
|
| 289 | - $sql = "PRT_ID tinyint(3) unsigned NOT NULL AUTO_INCREMENT, |
|
| 287 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 288 | + $table_name = "esp_price_type"; |
|
| 289 | + $sql = "PRT_ID tinyint(3) unsigned NOT NULL AUTO_INCREMENT, |
|
| 290 | 290 | PRT_name varchar(45) NOT NULL, |
| 291 | 291 | PBT_ID tinyint(3) unsigned NOT NULL DEFAULT '1', |
| 292 | 292 | PRT_is_percent tinyint(1) NOT NULL DEFAULT '0', |
@@ -294,9 +294,9 @@ discard block |
||
| 294 | 294 | PRT_deleted tinyint(1) NOT NULL DEFAULT '0', |
| 295 | 295 | UNIQUE KEY PRT_name_UNIQUE (PRT_name), |
| 296 | 296 | PRIMARY KEY (PRT_ID)"; |
| 297 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 298 | - $table_name = 'esp_question'; |
|
| 299 | - $sql = 'QST_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 297 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 298 | + $table_name = 'esp_question'; |
|
| 299 | + $sql = 'QST_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 300 | 300 | QST_display_text text NOT NULL, |
| 301 | 301 | QST_admin_label varchar(255) NOT NULL, |
| 302 | 302 | QST_system varchar(25) DEFAULT NULL, |
@@ -308,10 +308,10 @@ discard block |
||
| 308 | 308 | QST_wp_user bigint(20) unsigned NULL, |
| 309 | 309 | QST_deleted tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 310 | 310 | PRIMARY KEY (QST_ID)'; |
| 311 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 312 | - $this->_get_table_manager()->dropIndex('esp_question_group', 'QSG_identifier_UNIQUE'); |
|
| 313 | - $table_name = 'esp_question_group'; |
|
| 314 | - $sql = 'QSG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 311 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 312 | + $this->_get_table_manager()->dropIndex('esp_question_group', 'QSG_identifier_UNIQUE'); |
|
| 313 | + $table_name = 'esp_question_group'; |
|
| 314 | + $sql = 'QSG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 315 | 315 | QSG_name varchar(255) NOT NULL, |
| 316 | 316 | QSG_identifier varchar(100) NOT NULL, |
| 317 | 317 | QSG_desc text NULL, |
@@ -322,24 +322,24 @@ discard block |
||
| 322 | 322 | QSG_deleted tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 323 | 323 | PRIMARY KEY (QSG_ID), |
| 324 | 324 | UNIQUE KEY QSG_identifier_UNIQUE (QSG_identifier ASC)'; |
| 325 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 326 | - $table_name = 'esp_question_group_question'; |
|
| 327 | - $sql = "QGQ_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 325 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 326 | + $table_name = 'esp_question_group_question'; |
|
| 327 | + $sql = "QGQ_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 328 | 328 | QSG_ID int(10) unsigned NOT NULL, |
| 329 | 329 | QST_ID int(10) unsigned NOT NULL, |
| 330 | 330 | QGQ_order int(10) unsigned NOT NULL DEFAULT 0, |
| 331 | 331 | PRIMARY KEY (QGQ_ID) "; |
| 332 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 333 | - $table_name = 'esp_question_option'; |
|
| 334 | - $sql = "QSO_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 332 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 333 | + $table_name = 'esp_question_option'; |
|
| 334 | + $sql = "QSO_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 335 | 335 | QSO_value varchar(255) NOT NULL, |
| 336 | 336 | QSO_desc text NOT NULL, |
| 337 | 337 | QST_ID int(10) unsigned NOT NULL, |
| 338 | 338 | QSO_deleted tinyint(1) unsigned NOT NULL DEFAULT 0, |
| 339 | 339 | PRIMARY KEY (QSO_ID)"; |
| 340 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 341 | - $table_name = 'esp_registration'; |
|
| 342 | - $sql = "REG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 340 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 341 | + $table_name = 'esp_registration'; |
|
| 342 | + $sql = "REG_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 343 | 343 | EVT_ID bigint(20) unsigned NOT NULL, |
| 344 | 344 | ATT_ID bigint(20) unsigned NOT NULL, |
| 345 | 345 | TXN_ID int(10) unsigned NOT NULL, |
@@ -362,25 +362,25 @@ discard block |
||
| 362 | 362 | KEY STS_ID (STS_ID), |
| 363 | 363 | KEY REG_url_link (REG_url_link), |
| 364 | 364 | KEY REG_code (REG_code)"; |
| 365 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 366 | - $table_name = 'esp_checkin'; |
|
| 367 | - $sql = "CHK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 365 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB '); |
|
| 366 | + $table_name = 'esp_checkin'; |
|
| 367 | + $sql = "CHK_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 368 | 368 | REG_ID int(10) unsigned NOT NULL, |
| 369 | 369 | DTT_ID int(10) unsigned NOT NULL, |
| 370 | 370 | CHK_in tinyint(1) unsigned NOT NULL DEFAULT 1, |
| 371 | 371 | CHK_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
| 372 | 372 | PRIMARY KEY (CHK_ID)"; |
| 373 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 374 | - $table_name = 'esp_state'; |
|
| 375 | - $sql = "STA_ID smallint(5) unsigned NOT NULL AUTO_INCREMENT, |
|
| 373 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 374 | + $table_name = 'esp_state'; |
|
| 375 | + $sql = "STA_ID smallint(5) unsigned NOT NULL AUTO_INCREMENT, |
|
| 376 | 376 | CNT_ISO varchar(2) COLLATE utf8_bin NOT NULL, |
| 377 | 377 | STA_abbrev varchar(6) COLLATE utf8_bin NOT NULL, |
| 378 | 378 | STA_name varchar(100) COLLATE utf8_bin NOT NULL, |
| 379 | 379 | STA_active tinyint(1) DEFAULT '1', |
| 380 | 380 | PRIMARY KEY (STA_ID)"; |
| 381 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 382 | - $table_name = 'esp_status'; |
|
| 383 | - $sql = "STS_ID varchar(3) COLLATE utf8_bin NOT NULL, |
|
| 381 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 382 | + $table_name = 'esp_status'; |
|
| 383 | + $sql = "STS_ID varchar(3) COLLATE utf8_bin NOT NULL, |
|
| 384 | 384 | STS_code varchar(45) COLLATE utf8_bin NOT NULL, |
| 385 | 385 | STS_type set('event','registration','transaction','payment','email') COLLATE utf8_bin NOT NULL, |
| 386 | 386 | STS_can_edit tinyint(1) NOT NULL DEFAULT 0, |
@@ -388,9 +388,9 @@ discard block |
||
| 388 | 388 | STS_open tinyint(1) NOT NULL DEFAULT 1, |
| 389 | 389 | UNIQUE KEY STS_ID_UNIQUE (STS_ID), |
| 390 | 390 | KEY STS_type (STS_type)"; |
| 391 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 392 | - $table_name = 'esp_transaction'; |
|
| 393 | - $sql = "TXN_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 391 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 392 | + $table_name = 'esp_transaction'; |
|
| 393 | + $sql = "TXN_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
|
| 394 | 394 | TXN_timestamp datetime NOT NULL DEFAULT '0000-00-00 00:00:00', |
| 395 | 395 | TXN_total decimal(10,3) DEFAULT '0.00', |
| 396 | 396 | TXN_paid decimal(10,3) NOT NULL DEFAULT '0.00', |
@@ -400,9 +400,9 @@ discard block |
||
| 400 | 400 | PRIMARY KEY (TXN_ID), |
| 401 | 401 | KEY TXN_timestamp (TXN_timestamp), |
| 402 | 402 | KEY STS_ID (STS_ID)"; |
| 403 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 404 | - $table_name = 'esp_venue_meta'; |
|
| 405 | - $sql = "VNUM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 403 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 404 | + $table_name = 'esp_venue_meta'; |
|
| 405 | + $sql = "VNUM_ID int(11) NOT NULL AUTO_INCREMENT, |
|
| 406 | 406 | VNU_ID bigint(20) unsigned NOT NULL DEFAULT 0, |
| 407 | 407 | VNU_address varchar(255) DEFAULT NULL, |
| 408 | 408 | VNU_address2 varchar(255) DEFAULT NULL, |
@@ -420,36 +420,36 @@ discard block |
||
| 420 | 420 | PRIMARY KEY (VNUM_ID), |
| 421 | 421 | KEY STA_ID (STA_ID), |
| 422 | 422 | KEY CNT_ISO (CNT_ISO)"; |
| 423 | - $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 424 | - $script_with_defaults = EE_Registry::instance()->load_dms('Core_4_1_0'); |
|
| 425 | - // setting up the DEFAULT stats and countries is also essential for the data migrations to run |
|
| 426 | - // (because many need to convert old string states to foreign keys into the states table) |
|
| 427 | - $script_with_defaults->insert_default_states(); |
|
| 428 | - $script_with_defaults->insert_default_countries(); |
|
| 429 | - // setting up DEFAULT prices, price types, and tickets is also essential for the price migrations |
|
| 430 | - $script_with_defaults->insert_default_price_types(); |
|
| 431 | - $script_with_defaults->insert_default_prices(); |
|
| 432 | - $script_with_defaults->insert_default_tickets(); |
|
| 433 | - // setting up the config wp option pretty well counts as a 'schema change', or at least should happen ehre |
|
| 434 | - EE_Config::instance()->update_espresso_config(false, true); |
|
| 435 | - return true; |
|
| 436 | - } |
|
| 423 | + $this->_table_should_exist_previously($table_name, $sql, 'ENGINE=InnoDB'); |
|
| 424 | + $script_with_defaults = EE_Registry::instance()->load_dms('Core_4_1_0'); |
|
| 425 | + // setting up the DEFAULT stats and countries is also essential for the data migrations to run |
|
| 426 | + // (because many need to convert old string states to foreign keys into the states table) |
|
| 427 | + $script_with_defaults->insert_default_states(); |
|
| 428 | + $script_with_defaults->insert_default_countries(); |
|
| 429 | + // setting up DEFAULT prices, price types, and tickets is also essential for the price migrations |
|
| 430 | + $script_with_defaults->insert_default_price_types(); |
|
| 431 | + $script_with_defaults->insert_default_prices(); |
|
| 432 | + $script_with_defaults->insert_default_tickets(); |
|
| 433 | + // setting up the config wp option pretty well counts as a 'schema change', or at least should happen ehre |
|
| 434 | + EE_Config::instance()->update_espresso_config(false, true); |
|
| 435 | + return true; |
|
| 436 | + } |
|
| 437 | 437 | |
| 438 | 438 | |
| 439 | 439 | |
| 440 | - /** |
|
| 441 | - * We COULD clean up the esp_question.QST_order field here. We'll leave it for now |
|
| 442 | - * |
|
| 443 | - * @return boolean |
|
| 444 | - */ |
|
| 445 | - public function schema_changes_after_migration() |
|
| 446 | - { |
|
| 447 | - return true; |
|
| 448 | - } |
|
| 440 | + /** |
|
| 441 | + * We COULD clean up the esp_question.QST_order field here. We'll leave it for now |
|
| 442 | + * |
|
| 443 | + * @return boolean |
|
| 444 | + */ |
|
| 445 | + public function schema_changes_after_migration() |
|
| 446 | + { |
|
| 447 | + return true; |
|
| 448 | + } |
|
| 449 | 449 | |
| 450 | 450 | |
| 451 | 451 | |
| 452 | - public function migration_page_hooks() |
|
| 453 | - { |
|
| 454 | - } |
|
| 452 | + public function migration_page_hooks() |
|
| 453 | + { |
|
| 454 | + } |
|
| 455 | 455 | } |
@@ -12,13 +12,13 @@ discard block |
||
| 12 | 12 | // unfortunately, this needs to be done upon INCLUSION of this file, |
| 13 | 13 | // instead of construction, because it only gets constructed on first page load |
| 14 | 14 | // (all other times it gets resurrected from a wordpress option) |
| 15 | -$stages = glob(EE_CORE . 'data_migration_scripts/4_2_0_stages/*'); |
|
| 15 | +$stages = glob(EE_CORE.'data_migration_scripts/4_2_0_stages/*'); |
|
| 16 | 16 | $class_to_filepath = array(); |
| 17 | -if (! empty($stages)) { |
|
| 17 | +if ( ! empty($stages)) { |
|
| 18 | 18 | foreach ($stages as $filepath) { |
| 19 | 19 | $matches = array(); |
| 20 | 20 | preg_match('~4_2_0_stages/(.*).dmsstage.php~', $filepath, $matches); |
| 21 | - $class_to_filepath[ $matches[1] ] = $filepath; |
|
| 21 | + $class_to_filepath[$matches[1]] = $filepath; |
|
| 22 | 22 | } |
| 23 | 23 | } |
| 24 | 24 | // give addons a chance to autoload their stages too |
@@ -57,11 +57,11 @@ discard block |
||
| 57 | 57 | if (version_compare($version_string, '4.2.0.decaf', '<') && version_compare($version_string, '4.1.0.decaf', '>=')) { |
| 58 | 58 | // echo "$version_string can be migrated fro"; |
| 59 | 59 | return true; |
| 60 | - } elseif (! $version_string) { |
|
| 60 | + } elseif ( ! $version_string) { |
|
| 61 | 61 | // echo "no version string provided: $version_string"; |
| 62 | 62 | // no version string provided... this must be pre 4.1 |
| 63 | 63 | // because since 4.1 we're |
| 64 | - return false;// changed mind. dont want people thinking they should migrate yet because they cant |
|
| 64 | + return false; // changed mind. dont want people thinking they should migrate yet because they cant |
|
| 65 | 65 | } else { |
| 66 | 66 | // echo "$version_string doesnt apply"; |
| 67 | 67 | return false; |
@@ -73,7 +73,7 @@ discard block |
||
| 73 | 73 | public function schema_changes_before_migration() |
| 74 | 74 | { |
| 75 | 75 | // relies on 4.1's EEH_Activation::create_table |
| 76 | - require_once(EE_HELPERS . 'EEH_Activation.helper.php'); |
|
| 76 | + require_once(EE_HELPERS.'EEH_Activation.helper.php'); |
|
| 77 | 77 | $table_name = 'esp_answer'; |
| 78 | 78 | $sql = "ANS_ID int(10) unsigned NOT NULL AUTO_INCREMENT, |
| 79 | 79 | REG_ID int(10) unsigned NOT NULL, |
@@ -49,7 +49,7 @@ discard block |
||
| 49 | 49 | { |
| 50 | 50 | $this->_slug = 'attendee_information'; |
| 51 | 51 | $this->_name = esc_html__('Attendee Information', 'event_espresso'); |
| 52 | - $this->_template = SPCO_REG_STEPS_PATH . $this->_slug . '/attendee_info_main.template.php'; |
|
| 52 | + $this->_template = SPCO_REG_STEPS_PATH.$this->_slug.'/attendee_info_main.template.php'; |
|
| 53 | 53 | $this->checkout = $checkout; |
| 54 | 54 | $this->_reset_success_message(); |
| 55 | 55 | $this->set_instructions( |
@@ -143,7 +143,7 @@ discard block |
||
| 143 | 143 | ); |
| 144 | 144 | |
| 145 | 145 | // if this isn't a revisit, and they have the privacy consent box enalbed, add it |
| 146 | - if (! $this->checkout->revisit && $reg_config->isConsentCheckboxEnabled()) { |
|
| 146 | + if ( ! $this->checkout->revisit && $reg_config->isConsentCheckboxEnabled()) { |
|
| 147 | 147 | $extra_inputs_section->add_subsections( |
| 148 | 148 | array( |
| 149 | 149 | 'consent_box' => new EE_Form_Section_Proper( |
@@ -151,7 +151,7 @@ discard block |
||
| 151 | 151 | 'layout_strategy' => |
| 152 | 152 | new EE_Template_Layout( |
| 153 | 153 | array( |
| 154 | - 'input_template_file' => SPCO_REG_STEPS_PATH . $this->_slug . '/privacy_consent.template.php', |
|
| 154 | + 'input_template_file' => SPCO_REG_STEPS_PATH.$this->_slug.'/privacy_consent.template.php', |
|
| 155 | 155 | ) |
| 156 | 156 | ), |
| 157 | 157 | 'subsections' => array( |
@@ -189,13 +189,13 @@ discard block |
||
| 189 | 189 | if ($registration instanceof EE_Registration |
| 190 | 190 | && $this->checkout->visit_allows_processing_of_this_registration($registration) |
| 191 | 191 | ) { |
| 192 | - $subsections[ $registration->reg_url_link() ] = $this->_registrations_reg_form($registration); |
|
| 193 | - if (! $this->checkout->admin_request) { |
|
| 194 | - $template_args['registrations'][ $registration->reg_url_link() ] = $registration; |
|
| 195 | - $template_args['ticket_count'][ $registration->ticket()->ID() ] = isset( |
|
| 196 | - $template_args['ticket_count'][ $registration->ticket()->ID() ] |
|
| 192 | + $subsections[$registration->reg_url_link()] = $this->_registrations_reg_form($registration); |
|
| 193 | + if ( ! $this->checkout->admin_request) { |
|
| 194 | + $template_args['registrations'][$registration->reg_url_link()] = $registration; |
|
| 195 | + $template_args['ticket_count'][$registration->ticket()->ID()] = isset( |
|
| 196 | + $template_args['ticket_count'][$registration->ticket()->ID()] |
|
| 197 | 197 | ) |
| 198 | - ? $template_args['ticket_count'][ $registration->ticket()->ID() ] + 1 |
|
| 198 | + ? $template_args['ticket_count'][$registration->ticket()->ID()] + 1 |
|
| 199 | 199 | : 1; |
| 200 | 200 | $ticket_line_item = EEH_Line_Item::get_line_items_by_object_type_and_IDs( |
| 201 | 201 | $this->checkout->cart->get_grand_total(), |
@@ -205,7 +205,7 @@ discard block |
||
| 205 | 205 | $ticket_line_item = is_array($ticket_line_item) |
| 206 | 206 | ? reset($ticket_line_item) |
| 207 | 207 | : $ticket_line_item; |
| 208 | - $template_args['ticket_line_item'][ $registration->ticket()->ID() ] = |
|
| 208 | + $template_args['ticket_line_item'][$registration->ticket()->ID()] = |
|
| 209 | 209 | $Line_Item_Display->display_line_item($ticket_line_item); |
| 210 | 210 | } |
| 211 | 211 | if ($registration->is_primary_registrant()) { |
@@ -218,10 +218,10 @@ discard block |
||
| 218 | 218 | ? $this->_copy_attendee_info_form() |
| 219 | 219 | : $this->_auto_copy_attendee_info(); |
| 220 | 220 | // generate hidden input |
| 221 | - if (isset($subsections[ $primary_registrant ]) |
|
| 222 | - && $subsections[ $primary_registrant ] instanceof EE_Form_Section_Proper |
|
| 221 | + if (isset($subsections[$primary_registrant]) |
|
| 222 | + && $subsections[$primary_registrant] instanceof EE_Form_Section_Proper |
|
| 223 | 223 | ) { |
| 224 | - $subsections[ $primary_registrant ]->add_subsections( |
|
| 224 | + $subsections[$primary_registrant]->add_subsections( |
|
| 225 | 225 | $copy_options, |
| 226 | 226 | 'primary_registrant', |
| 227 | 227 | false |
@@ -288,7 +288,7 @@ discard block |
||
| 288 | 288 | if ($question_groups) { |
| 289 | 289 | // array of params to pass to parent constructor |
| 290 | 290 | $form_args = array( |
| 291 | - 'html_id' => 'ee-registration-' . $registration->reg_url_link(), |
|
| 291 | + 'html_id' => 'ee-registration-'.$registration->reg_url_link(), |
|
| 292 | 292 | 'html_class' => 'ee-reg-form-attendee-dv', |
| 293 | 293 | 'html_style' => $this->checkout->admin_request |
| 294 | 294 | ? 'padding:0em 2em 1em; margin:3em 0 0; border:1px solid #ddd;' |
@@ -310,7 +310,7 @@ discard block |
||
| 310 | 310 | ); |
| 311 | 311 | foreach ($question_groups as $question_group) { |
| 312 | 312 | if ($question_group instanceof EE_Question_Group) { |
| 313 | - $form_args['subsections'][ $question_group->identifier() ] = $this->_question_group_reg_form( |
|
| 313 | + $form_args['subsections'][$question_group->identifier()] = $this->_question_group_reg_form( |
|
| 314 | 314 | $registration, |
| 315 | 315 | $question_group |
| 316 | 316 | ); |
@@ -356,7 +356,7 @@ discard block |
||
| 356 | 356 | // generate hidden input |
| 357 | 357 | return new EE_Hidden_Input( |
| 358 | 358 | array( |
| 359 | - 'html_id' => 'additional-attendee-reg-info-' . $registration->reg_url_link(), |
|
| 359 | + 'html_id' => 'additional-attendee-reg-info-'.$registration->reg_url_link(), |
|
| 360 | 360 | 'default' => $additional_attendee_reg_info, |
| 361 | 361 | ) |
| 362 | 362 | ); |
@@ -377,12 +377,12 @@ discard block |
||
| 377 | 377 | { |
| 378 | 378 | // array of params to pass to parent constructor |
| 379 | 379 | $form_args = array( |
| 380 | - 'html_id' => 'ee-reg-form-qstn-grp-' . $question_group->identifier() . '-' . $registration->ID(), |
|
| 380 | + 'html_id' => 'ee-reg-form-qstn-grp-'.$question_group->identifier().'-'.$registration->ID(), |
|
| 381 | 381 | 'html_class' => $this->checkout->admin_request |
| 382 | 382 | ? 'form-table ee-reg-form-qstn-grp-dv' |
| 383 | 383 | : 'ee-reg-form-qstn-grp-dv', |
| 384 | - 'html_label_id' => 'ee-reg-form-qstn-grp-' . $question_group->identifier() . '-' |
|
| 385 | - . $registration->ID() . '-lbl', |
|
| 384 | + 'html_label_id' => 'ee-reg-form-qstn-grp-'.$question_group->identifier().'-' |
|
| 385 | + . $registration->ID().'-lbl', |
|
| 386 | 386 | 'subsections' => array( |
| 387 | 387 | 'reg_form_qstn_grp_hdr' => $this->_question_group_header($question_group), |
| 388 | 388 | ), |
@@ -393,7 +393,7 @@ discard block |
||
| 393 | 393 | // where params |
| 394 | 394 | $query_params = array('QST_deleted' => 0); |
| 395 | 395 | // don't load admin only questions on the frontend |
| 396 | - if (! $this->checkout->admin_request) { |
|
| 396 | + if ( ! $this->checkout->admin_request) { |
|
| 397 | 397 | $query_params['QST_admin_only'] = array('!=', true); |
| 398 | 398 | } |
| 399 | 399 | $questions = $question_group->get_many_related( |
@@ -427,7 +427,7 @@ discard block |
||
| 427 | 427 | $identifier = $question->is_system_question() |
| 428 | 428 | ? $question->system_ID() |
| 429 | 429 | : $question->ID(); |
| 430 | - $form_args['subsections'][ $identifier ] = $this->reg_form_question($registration, $question); |
|
| 430 | + $form_args['subsections'][$identifier] = $this->reg_form_question($registration, $question); |
|
| 431 | 431 | } |
| 432 | 432 | } |
| 433 | 433 | $form_args['subsections'] = apply_filters( |
@@ -539,7 +539,7 @@ discard block |
||
| 539 | 539 | { |
| 540 | 540 | return new EE_Form_Section_HTML( |
| 541 | 541 | EEH_Template::locate_template( |
| 542 | - SPCO_REG_STEPS_PATH . $this->_slug . '/_auto_copy_attendee_info.template.php', |
|
| 542 | + SPCO_REG_STEPS_PATH.$this->_slug.'/_auto_copy_attendee_info.template.php', |
|
| 543 | 543 | apply_filters( |
| 544 | 544 | 'FHEE__EE_SPCO_Reg_Step_Attendee_Information__auto_copy_attendee_info__template_args', |
| 545 | 545 | array() |
@@ -572,17 +572,17 @@ discard block |
||
| 572 | 572 | if ($registration->ticket()->ID() !== $prev_ticket) { |
| 573 | 573 | $item_name = $registration->ticket()->name(); |
| 574 | 574 | $item_name .= $registration->ticket()->description() !== '' |
| 575 | - ? ' - ' . $registration->ticket()->description() |
|
| 575 | + ? ' - '.$registration->ticket()->description() |
|
| 576 | 576 | : ''; |
| 577 | - $copy_attendee_info_inputs[ 'spco_copy_attendee_chk[ticket-' . $registration->ticket()->ID( |
|
| 578 | - ) . ']' ] = |
|
| 577 | + $copy_attendee_info_inputs['spco_copy_attendee_chk[ticket-'.$registration->ticket()->ID( |
|
| 578 | + ).']'] = |
|
| 579 | 579 | new EE_Form_Section_HTML( |
| 580 | - '<h6 class="spco-copy-attendee-event-hdr">' . $item_name . '</h6>' |
|
| 580 | + '<h6 class="spco-copy-attendee-event-hdr">'.$item_name.'</h6>' |
|
| 581 | 581 | ); |
| 582 | 582 | $prev_ticket = $registration->ticket()->ID(); |
| 583 | 583 | } |
| 584 | 584 | |
| 585 | - $copy_attendee_info_inputs[ 'spco_copy_attendee_chk[' . $registration->ID() . ']' ] = |
|
| 585 | + $copy_attendee_info_inputs['spco_copy_attendee_chk['.$registration->ID().']'] = |
|
| 586 | 586 | new EE_Checkbox_Multi_Input( |
| 587 | 587 | array( |
| 588 | 588 | $registration->ID() => sprintf( |
@@ -591,7 +591,7 @@ discard block |
||
| 591 | 591 | ), |
| 592 | 592 | ), |
| 593 | 593 | array( |
| 594 | - 'html_id' => 'spco-copy-attendee-chk-' . $registration->reg_url_link(), |
|
| 594 | + 'html_id' => 'spco-copy-attendee-chk-'.$registration->reg_url_link(), |
|
| 595 | 595 | 'html_class' => 'spco-copy-attendee-chk ee-do-not-validate', |
| 596 | 596 | 'display_html_label_text' => false, |
| 597 | 597 | ) |
@@ -656,14 +656,14 @@ discard block |
||
| 656 | 656 | } |
| 657 | 657 | // verify instance |
| 658 | 658 | if ($answer instanceof EE_Answer) { |
| 659 | - if (! empty($answer_value)) { |
|
| 659 | + if ( ! empty($answer_value)) { |
|
| 660 | 660 | $answer->set('ANS_value', $answer_value); |
| 661 | 661 | } |
| 662 | 662 | $answer->cache('Question', $question); |
| 663 | 663 | // remember system ID had a bug where sometimes it could be null |
| 664 | 664 | $answer_cache_id = $question->is_system_question() |
| 665 | - ? $question->system_ID() . '-' . $registration->reg_url_link() |
|
| 666 | - : $question->ID() . '-' . $registration->reg_url_link(); |
|
| 665 | + ? $question->system_ID().'-'.$registration->reg_url_link() |
|
| 666 | + : $question->ID().'-'.$registration->reg_url_link(); |
|
| 667 | 667 | $registration->cache('Answer', $answer, $answer_cache_id); |
| 668 | 668 | } |
| 669 | 669 | return $this->_generate_question_input($registration, $question, $answer); |
@@ -686,7 +686,7 @@ discard block |
||
| 686 | 686 | $identifier = $question->is_system_question() |
| 687 | 687 | ? $question->system_ID() |
| 688 | 688 | : $question->ID(); |
| 689 | - $this->_required_questions[ $identifier ] = $question->required() ? true : false; |
|
| 689 | + $this->_required_questions[$identifier] = $question->required() ? true : false; |
|
| 690 | 690 | add_filter( |
| 691 | 691 | 'FHEE__EE_Question__generate_form_input__country_options', |
| 692 | 692 | array($this, 'use_cached_countries_for_form_input'), |
@@ -700,17 +700,17 @@ discard block |
||
| 700 | 700 | 4 |
| 701 | 701 | ); |
| 702 | 702 | $input_constructor_args = array( |
| 703 | - 'html_name' => 'ee_reg_qstn[' . $registration->ID() . '][' . $identifier . ']', |
|
| 704 | - 'html_id' => 'ee_reg_qstn-' . $registration->ID() . '-' . $identifier, |
|
| 705 | - 'html_class' => 'ee-reg-qstn ee-reg-qstn-' . $identifier, |
|
| 706 | - 'html_label_id' => 'ee_reg_qstn-' . $registration->ID() . '-' . $identifier, |
|
| 703 | + 'html_name' => 'ee_reg_qstn['.$registration->ID().']['.$identifier.']', |
|
| 704 | + 'html_id' => 'ee_reg_qstn-'.$registration->ID().'-'.$identifier, |
|
| 705 | + 'html_class' => 'ee-reg-qstn ee-reg-qstn-'.$identifier, |
|
| 706 | + 'html_label_id' => 'ee_reg_qstn-'.$registration->ID().'-'.$identifier, |
|
| 707 | 707 | 'html_label_class' => 'ee-reg-qstn', |
| 708 | 708 | ); |
| 709 | 709 | $input_constructor_args['html_label_id'] .= '-lbl'; |
| 710 | 710 | if ($answer instanceof EE_Answer && $answer->ID()) { |
| 711 | - $input_constructor_args['html_name'] .= '[' . $answer->ID() . ']'; |
|
| 712 | - $input_constructor_args['html_id'] .= '-' . $answer->ID(); |
|
| 713 | - $input_constructor_args['html_label_id'] .= '-' . $answer->ID(); |
|
| 711 | + $input_constructor_args['html_name'] .= '['.$answer->ID().']'; |
|
| 712 | + $input_constructor_args['html_id'] .= '-'.$answer->ID(); |
|
| 713 | + $input_constructor_args['html_label_id'] .= '-'.$answer->ID(); |
|
| 714 | 714 | } |
| 715 | 715 | $form_input = $question->generate_form_input( |
| 716 | 716 | $registration, |
@@ -754,10 +754,10 @@ discard block |
||
| 754 | 754 | $countries = $this->checkout->action === 'process_reg_step' |
| 755 | 755 | ? EEM_Country::instance()->get_all_countries() |
| 756 | 756 | : EEM_Country::instance()->get_all_active_countries(); |
| 757 | - if (! empty($countries)) { |
|
| 757 | + if ( ! empty($countries)) { |
|
| 758 | 758 | foreach ($countries as $country) { |
| 759 | 759 | if ($country instanceof EE_Country) { |
| 760 | - $country_options[ $country->ID() ] = $country->name(); |
|
| 760 | + $country_options[$country->ID()] = $country->name(); |
|
| 761 | 761 | } |
| 762 | 762 | } |
| 763 | 763 | } |
@@ -804,10 +804,10 @@ discard block |
||
| 804 | 804 | $states = $this->checkout->action === 'process_reg_step' |
| 805 | 805 | ? EEM_State::instance()->get_all_states() |
| 806 | 806 | : EEM_State::instance()->get_all_active_states(); |
| 807 | - if (! empty($states)) { |
|
| 807 | + if ( ! empty($states)) { |
|
| 808 | 808 | foreach ($states as $state) { |
| 809 | 809 | if ($state instanceof EE_State) { |
| 810 | - $state_options[ $state->country()->name() ][ $state->ID() ] = $state->name(); |
|
| 810 | + $state_options[$state->country()->name()][$state->ID()] = $state->name(); |
|
| 811 | 811 | } |
| 812 | 812 | } |
| 813 | 813 | } |
@@ -854,7 +854,7 @@ discard block |
||
| 854 | 854 | ); |
| 855 | 855 | return false; |
| 856 | 856 | } |
| 857 | - if (! $this->checkout->transaction instanceof EE_Transaction || ! $this->checkout->continue_reg) { |
|
| 857 | + if ( ! $this->checkout->transaction instanceof EE_Transaction || ! $this->checkout->continue_reg) { |
|
| 858 | 858 | EE_Error::add_error( |
| 859 | 859 | esc_html__( |
| 860 | 860 | 'A valid transaction could not be initiated for processing your registrations.', |
@@ -881,7 +881,7 @@ discard block |
||
| 881 | 881 | '(line break)This can sometimes happen if too much time has been taken to complete the registration process.(line break)Please return to the (link)Event List(end link) and reselect your tickets. If the problem continues, please contact the site administrator.', |
| 882 | 882 | 'event_espresso' |
| 883 | 883 | ), |
| 884 | - '<a href="' . get_post_type_archive_link('espresso_events') . '" >', |
|
| 884 | + '<a href="'.get_post_type_archive_link('espresso_events').'" >', |
|
| 885 | 885 | '</a>', |
| 886 | 886 | '<br />' |
| 887 | 887 | ); |
@@ -901,7 +901,7 @@ discard block |
||
| 901 | 901 | // but return immediately if the previous step exited early due to errors |
| 902 | 902 | return false; |
| 903 | 903 | } |
| 904 | - if (! $this->checkout->revisit && $registrations_processed !== $this->checkout->total_ticket_count) { |
|
| 904 | + if ( ! $this->checkout->revisit && $registrations_processed !== $this->checkout->total_ticket_count) { |
|
| 905 | 905 | // generate a correctly translated string for all possible singular/plural combinations |
| 906 | 906 | if ($this->checkout->total_ticket_count === 1 && $registrations_processed !== 1) { |
| 907 | 907 | $error_msg = sprintf( |
@@ -984,7 +984,7 @@ discard block |
||
| 984 | 984 | // grab the saved registrations from the transaction |
| 985 | 985 | foreach ($registrations as $registration) { |
| 986 | 986 | // verify EE_Registration object |
| 987 | - if (! $registration instanceof EE_Registration) { |
|
| 987 | + if ( ! $registration instanceof EE_Registration) { |
|
| 988 | 988 | EE_Error::add_error( |
| 989 | 989 | esc_html__( |
| 990 | 990 | 'An invalid Registration object was discovered when attempting to process your registration information.', |
@@ -999,12 +999,12 @@ discard block |
||
| 999 | 999 | /** @var string $reg_url_link */ |
| 1000 | 1000 | $reg_url_link = $registration->reg_url_link(); |
| 1001 | 1001 | // reg_url_link exists ? |
| 1002 | - if (! empty($reg_url_link)) { |
|
| 1002 | + if ( ! empty($reg_url_link)) { |
|
| 1003 | 1003 | // should this registration be processed during this visit ? |
| 1004 | 1004 | if ($this->checkout->visit_allows_processing_of_this_registration($registration)) { |
| 1005 | 1005 | // if NOT revisiting, then let's save the registration now, |
| 1006 | 1006 | // so that we have a REG_ID to use when generating other objects |
| 1007 | - if (! $this->checkout->revisit) { |
|
| 1007 | + if ( ! $this->checkout->revisit) { |
|
| 1008 | 1008 | $registration->save(); |
| 1009 | 1009 | } |
| 1010 | 1010 | /** |
@@ -1028,18 +1028,18 @@ discard block |
||
| 1028 | 1028 | |
| 1029 | 1029 | // Houston, we have a registration! |
| 1030 | 1030 | $att_nmbr++; |
| 1031 | - $this->_attendee_data[ $reg_url_link ] = array(); |
|
| 1031 | + $this->_attendee_data[$reg_url_link] = array(); |
|
| 1032 | 1032 | // grab any existing related answer objects |
| 1033 | 1033 | $this->_registration_answers = $registration->answers(); |
| 1034 | 1034 | // unset( $valid_data[ $reg_url_link ]['additional_attendee_reg_info'] ); |
| 1035 | - if (isset($valid_data[ $reg_url_link ])) { |
|
| 1035 | + if (isset($valid_data[$reg_url_link])) { |
|
| 1036 | 1036 | // do we need to copy basic info from primary attendee ? |
| 1037 | - $copy_primary = isset($valid_data[ $reg_url_link ]['additional_attendee_reg_info']) |
|
| 1038 | - && absint($valid_data[ $reg_url_link ]['additional_attendee_reg_info']) === 0; |
|
| 1037 | + $copy_primary = isset($valid_data[$reg_url_link]['additional_attendee_reg_info']) |
|
| 1038 | + && absint($valid_data[$reg_url_link]['additional_attendee_reg_info']) === 0; |
|
| 1039 | 1039 | // filter form input data for this registration |
| 1040 | - $valid_data[ $reg_url_link ] = (array) apply_filters( |
|
| 1040 | + $valid_data[$reg_url_link] = (array) apply_filters( |
|
| 1041 | 1041 | 'FHEE__EE_Single_Page_Checkout__process_attendee_information__valid_data_line_item', |
| 1042 | - $valid_data[ $reg_url_link ] |
|
| 1042 | + $valid_data[$reg_url_link] |
|
| 1043 | 1043 | ); |
| 1044 | 1044 | if (isset($valid_data['primary_attendee'])) { |
| 1045 | 1045 | $primary_registrant['line_item_id'] = ! empty($valid_data['primary_attendee']) |
@@ -1048,12 +1048,12 @@ discard block |
||
| 1048 | 1048 | unset($valid_data['primary_attendee']); |
| 1049 | 1049 | } |
| 1050 | 1050 | // now loop through our array of valid post data && process attendee reg forms |
| 1051 | - foreach ($valid_data[ $reg_url_link ] as $form_section => $form_inputs) { |
|
| 1052 | - if (! in_array($form_section, $non_input_form_sections, true)) { |
|
| 1051 | + foreach ($valid_data[$reg_url_link] as $form_section => $form_inputs) { |
|
| 1052 | + if ( ! in_array($form_section, $non_input_form_sections, true)) { |
|
| 1053 | 1053 | foreach ($form_inputs as $form_input => $input_value) { |
| 1054 | 1054 | // \EEH_Debug_Tools::printr( $input_value, $form_input, __FILE__, __LINE__ ); |
| 1055 | 1055 | // check for critical inputs |
| 1056 | - if (! $this->_verify_critical_attendee_details_are_set_and_validate_email( |
|
| 1056 | + if ( ! $this->_verify_critical_attendee_details_are_set_and_validate_email( |
|
| 1057 | 1057 | $form_input, |
| 1058 | 1058 | $input_value |
| 1059 | 1059 | ) |
@@ -1065,15 +1065,15 @@ discard block |
||
| 1065 | 1065 | && ! empty($input_value) |
| 1066 | 1066 | && $reg_url_link === $primary_registrant['line_item_id'] |
| 1067 | 1067 | ) { |
| 1068 | - $primary_registrant[ $form_input ] = $input_value; |
|
| 1068 | + $primary_registrant[$form_input] = $input_value; |
|
| 1069 | 1069 | } elseif ($copy_primary |
| 1070 | 1070 | && $input_value === null |
| 1071 | - && isset($primary_registrant[ $form_input ]) |
|
| 1071 | + && isset($primary_registrant[$form_input]) |
|
| 1072 | 1072 | ) { |
| 1073 | - $input_value = $primary_registrant[ $form_input ]; |
|
| 1073 | + $input_value = $primary_registrant[$form_input]; |
|
| 1074 | 1074 | } |
| 1075 | 1075 | // now attempt to save the input data |
| 1076 | - if (! $this->_save_registration_form_input( |
|
| 1076 | + if ( ! $this->_save_registration_form_input( |
|
| 1077 | 1077 | $registration, |
| 1078 | 1078 | $form_input, |
| 1079 | 1079 | $input_value |
@@ -1109,15 +1109,15 @@ discard block |
||
| 1109 | 1109 | $attendee = $this->checkout->primary_attendee_obj; |
| 1110 | 1110 | } else { |
| 1111 | 1111 | // ensure critical details are set for additional attendees |
| 1112 | - $this->_attendee_data[ $reg_url_link ] = $att_nmbr > 1 |
|
| 1112 | + $this->_attendee_data[$reg_url_link] = $att_nmbr > 1 |
|
| 1113 | 1113 | ? $this->_copy_critical_attendee_details_from_primary_registrant( |
| 1114 | - $this->_attendee_data[ $reg_url_link ] |
|
| 1114 | + $this->_attendee_data[$reg_url_link] |
|
| 1115 | 1115 | ) |
| 1116 | - : $this->_attendee_data[ $reg_url_link ]; |
|
| 1116 | + : $this->_attendee_data[$reg_url_link]; |
|
| 1117 | 1117 | // execute create attendee command (which may return an existing attendee) |
| 1118 | 1118 | $attendee = EE_Registry::instance()->BUS->execute( |
| 1119 | 1119 | new CreateAttendeeCommand( |
| 1120 | - $this->_attendee_data[ $reg_url_link ], |
|
| 1120 | + $this->_attendee_data[$reg_url_link], |
|
| 1121 | 1121 | $registration |
| 1122 | 1122 | ) |
| 1123 | 1123 | ); |
@@ -1130,7 +1130,7 @@ discard block |
||
| 1130 | 1130 | // add relation to registration, set attendee ID, and cache attendee |
| 1131 | 1131 | $this->_associate_attendee_with_registration($registration, $attendee); |
| 1132 | 1132 | // \EEH_Debug_Tools::printr( $registration, '$registration', __FILE__, __LINE__ ); |
| 1133 | - if (! $registration->attendee() instanceof EE_Attendee) { |
|
| 1133 | + if ( ! $registration->attendee() instanceof EE_Attendee) { |
|
| 1134 | 1134 | EE_Error::add_error( |
| 1135 | 1135 | sprintf( |
| 1136 | 1136 | esc_html_x( |
@@ -1180,7 +1180,7 @@ discard block |
||
| 1180 | 1180 | __LINE__ |
| 1181 | 1181 | ); |
| 1182 | 1182 | // remove malformed data |
| 1183 | - unset($valid_data[ $reg_url_link ]); |
|
| 1183 | + unset($valid_data[$reg_url_link]); |
|
| 1184 | 1184 | return false; |
| 1185 | 1185 | } |
| 1186 | 1186 | } // end of foreach ( $this->checkout->transaction->registrations() as $registration ) |
@@ -1226,10 +1226,10 @@ discard block |
||
| 1226 | 1226 | * @see https://events.codebasehq.com/projects/event-espresso/tickets/10477 |
| 1227 | 1227 | */ |
| 1228 | 1228 | $answer_cache_id = $this->checkout->reg_url_link |
| 1229 | - ? $form_input . '-' . $registration->reg_url_link() |
|
| 1229 | + ? $form_input.'-'.$registration->reg_url_link() |
|
| 1230 | 1230 | : $form_input; |
| 1231 | - $answer_is_obj = isset($this->_registration_answers[ $answer_cache_id ]) |
|
| 1232 | - && $this->_registration_answers[ $answer_cache_id ] instanceof EE_Answer; |
|
| 1231 | + $answer_is_obj = isset($this->_registration_answers[$answer_cache_id]) |
|
| 1232 | + && $this->_registration_answers[$answer_cache_id] instanceof EE_Answer; |
|
| 1233 | 1233 | // rename form_inputs if they are EE_Attendee properties |
| 1234 | 1234 | switch ((string) $form_input) { |
| 1235 | 1235 | case 'state': |
@@ -1245,28 +1245,28 @@ discard block |
||
| 1245 | 1245 | break; |
| 1246 | 1246 | |
| 1247 | 1247 | default: |
| 1248 | - $ATT_input = 'ATT_' . $form_input; |
|
| 1248 | + $ATT_input = 'ATT_'.$form_input; |
|
| 1249 | 1249 | // EEH_Debug_Tools::printr( $ATT_input, '$ATT_input', __FILE__, __LINE__ ); |
| 1250 | 1250 | $attendee_property = EEM_Attendee::instance()->has_field($ATT_input) ? true : false; |
| 1251 | - $form_input = $attendee_property ? 'ATT_' . $form_input : $form_input; |
|
| 1251 | + $form_input = $attendee_property ? 'ATT_'.$form_input : $form_input; |
|
| 1252 | 1252 | } |
| 1253 | 1253 | // EEH_Debug_Tools::printr( $answer_cache_id, '$answer_cache_id', __FILE__, __LINE__ ); |
| 1254 | 1254 | // EEH_Debug_Tools::printr( $attendee_property, '$attendee_property', __FILE__, __LINE__ ); |
| 1255 | 1255 | // EEH_Debug_Tools::printr( $answer_is_obj, '$answer_is_obj', __FILE__, __LINE__ ); |
| 1256 | 1256 | // if this form input has a corresponding attendee property |
| 1257 | 1257 | if ($attendee_property) { |
| 1258 | - $this->_attendee_data[ $registration->reg_url_link() ][ $form_input ] = $input_value; |
|
| 1258 | + $this->_attendee_data[$registration->reg_url_link()][$form_input] = $input_value; |
|
| 1259 | 1259 | if ($answer_is_obj) { |
| 1260 | 1260 | // and delete the corresponding answer since we won't be storing this data in that object |
| 1261 | - $registration->_remove_relation_to($this->_registration_answers[ $answer_cache_id ], 'Answer'); |
|
| 1262 | - $this->_registration_answers[ $answer_cache_id ]->delete_permanently(); |
|
| 1261 | + $registration->_remove_relation_to($this->_registration_answers[$answer_cache_id], 'Answer'); |
|
| 1262 | + $this->_registration_answers[$answer_cache_id]->delete_permanently(); |
|
| 1263 | 1263 | } |
| 1264 | 1264 | return true; |
| 1265 | 1265 | } |
| 1266 | 1266 | if ($answer_is_obj) { |
| 1267 | 1267 | // save this data to the answer object |
| 1268 | - $this->_registration_answers[ $answer_cache_id ]->set_value($input_value); |
|
| 1269 | - $result = $this->_registration_answers[ $answer_cache_id ]->save(); |
|
| 1268 | + $this->_registration_answers[$answer_cache_id]->set_value($input_value); |
|
| 1269 | + $result = $this->_registration_answers[$answer_cache_id]->save(); |
|
| 1270 | 1270 | return $result !== false; |
| 1271 | 1271 | } |
| 1272 | 1272 | foreach ($this->_registration_answers as $answer) { |
@@ -1293,7 +1293,7 @@ discard block |
||
| 1293 | 1293 | ) { |
| 1294 | 1294 | if (empty($input_value)) { |
| 1295 | 1295 | // if the form input isn't marked as being required, then just return |
| 1296 | - if (! isset($this->_required_questions[ $form_input ]) || ! $this->_required_questions[ $form_input ]) { |
|
| 1296 | + if ( ! isset($this->_required_questions[$form_input]) || ! $this->_required_questions[$form_input]) { |
|
| 1297 | 1297 | return true; |
| 1298 | 1298 | } |
| 1299 | 1299 | switch ($form_input) { |
@@ -1404,10 +1404,10 @@ discard block |
||
| 1404 | 1404 | $critical_attendee_details = array_merge($critical_attendee_details, $address_details); |
| 1405 | 1405 | } |
| 1406 | 1406 | foreach ($critical_attendee_details as $critical_attendee_detail) { |
| 1407 | - if (! isset($attendee_data[ $critical_attendee_detail ]) |
|
| 1408 | - || empty($attendee_data[ $critical_attendee_detail ]) |
|
| 1407 | + if ( ! isset($attendee_data[$critical_attendee_detail]) |
|
| 1408 | + || empty($attendee_data[$critical_attendee_detail]) |
|
| 1409 | 1409 | ) { |
| 1410 | - $attendee_data[ $critical_attendee_detail ] = $this->checkout->primary_attendee_obj->get( |
|
| 1410 | + $attendee_data[$critical_attendee_detail] = $this->checkout->primary_attendee_obj->get( |
|
| 1411 | 1411 | $critical_attendee_detail |
| 1412 | 1412 | ); |
| 1413 | 1413 | } |
@@ -18,1432 +18,1432 @@ |
||
| 18 | 18 | class EE_SPCO_Reg_Step_Attendee_Information extends EE_SPCO_Reg_Step |
| 19 | 19 | { |
| 20 | 20 | |
| 21 | - /** |
|
| 22 | - * @type bool $_print_copy_info |
|
| 23 | - */ |
|
| 24 | - private $_print_copy_info = false; |
|
| 25 | - |
|
| 26 | - /** |
|
| 27 | - * @type array $_attendee_data |
|
| 28 | - */ |
|
| 29 | - private $_attendee_data = array(); |
|
| 30 | - |
|
| 31 | - /** |
|
| 32 | - * @type array $_required_questions |
|
| 33 | - */ |
|
| 34 | - private $_required_questions = array(); |
|
| 35 | - |
|
| 36 | - /** |
|
| 37 | - * @type array $_registration_answers |
|
| 38 | - */ |
|
| 39 | - private $_registration_answers = array(); |
|
| 40 | - |
|
| 41 | - |
|
| 42 | - /** |
|
| 43 | - * class constructor |
|
| 44 | - * |
|
| 45 | - * @access public |
|
| 46 | - * @param EE_Checkout $checkout |
|
| 47 | - */ |
|
| 48 | - public function __construct(EE_Checkout $checkout) |
|
| 49 | - { |
|
| 50 | - $this->_slug = 'attendee_information'; |
|
| 51 | - $this->_name = esc_html__('Attendee Information', 'event_espresso'); |
|
| 52 | - $this->_template = SPCO_REG_STEPS_PATH . $this->_slug . '/attendee_info_main.template.php'; |
|
| 53 | - $this->checkout = $checkout; |
|
| 54 | - $this->_reset_success_message(); |
|
| 55 | - $this->set_instructions( |
|
| 56 | - esc_html__('Please answer the following registration questions before proceeding.', 'event_espresso') |
|
| 57 | - ); |
|
| 58 | - } |
|
| 59 | - |
|
| 60 | - |
|
| 61 | - public function translate_js_strings() |
|
| 62 | - { |
|
| 63 | - EE_Registry::$i18n_js_strings['required_field'] = esc_html__( |
|
| 64 | - ' is a required question.', |
|
| 65 | - 'event_espresso' |
|
| 66 | - ); |
|
| 67 | - EE_Registry::$i18n_js_strings['required_multi_field'] = esc_html__( |
|
| 68 | - ' is a required question. Please enter a value for at least one of the options.', |
|
| 69 | - 'event_espresso' |
|
| 70 | - ); |
|
| 71 | - EE_Registry::$i18n_js_strings['answer_required_questions'] = esc_html__( |
|
| 72 | - 'Please answer all required questions correctly before proceeding.', |
|
| 73 | - 'event_espresso' |
|
| 74 | - ); |
|
| 75 | - EE_Registry::$i18n_js_strings['attendee_info_copied'] = sprintf( |
|
| 76 | - esc_html_x( |
|
| 77 | - 'The attendee information was successfully copied.%sPlease ensure the rest of the registration form is completed before proceeding.', |
|
| 78 | - 'The attendee information was successfully copied.(line break)Please ensure the rest of the registration form is completed before proceeding.', |
|
| 79 | - 'event_espresso' |
|
| 80 | - ), |
|
| 81 | - '<br/>' |
|
| 82 | - ); |
|
| 83 | - EE_Registry::$i18n_js_strings['attendee_info_copy_error'] = esc_html__( |
|
| 84 | - 'An unknown error occurred on the server while attempting to copy the attendee information. Please refresh the page and try again.', |
|
| 85 | - 'event_espresso' |
|
| 86 | - ); |
|
| 87 | - EE_Registry::$i18n_js_strings['enter_valid_email'] = esc_html__( |
|
| 88 | - 'You must enter a valid email address.', |
|
| 89 | - 'event_espresso' |
|
| 90 | - ); |
|
| 91 | - EE_Registry::$i18n_js_strings['valid_email_and_questions'] = esc_html__( |
|
| 92 | - 'You must enter a valid email address and answer all other required questions before you can proceed.', |
|
| 93 | - 'event_espresso' |
|
| 94 | - ); |
|
| 95 | - } |
|
| 96 | - |
|
| 97 | - |
|
| 98 | - public function enqueue_styles_and_scripts() |
|
| 99 | - { |
|
| 100 | - } |
|
| 101 | - |
|
| 102 | - |
|
| 103 | - /** |
|
| 104 | - * @return boolean |
|
| 105 | - */ |
|
| 106 | - public function initialize_reg_step() |
|
| 107 | - { |
|
| 108 | - return true; |
|
| 109 | - } |
|
| 110 | - |
|
| 111 | - |
|
| 112 | - /** |
|
| 113 | - * @return EE_Form_Section_Proper |
|
| 114 | - * @throws DomainException |
|
| 115 | - * @throws EE_Error |
|
| 116 | - * @throws InvalidArgumentException |
|
| 117 | - * @throws ReflectionException |
|
| 118 | - * @throws EntityNotFoundException |
|
| 119 | - * @throws InvalidDataTypeException |
|
| 120 | - * @throws InvalidInterfaceException |
|
| 121 | - */ |
|
| 122 | - public function generate_reg_form() |
|
| 123 | - { |
|
| 124 | - /** |
|
| 125 | - * @var $reg_config EE_Registration_Config |
|
| 126 | - */ |
|
| 127 | - $reg_config = LoaderFactory::getLoader()->getShared('EE_Registration_Config'); |
|
| 21 | + /** |
|
| 22 | + * @type bool $_print_copy_info |
|
| 23 | + */ |
|
| 24 | + private $_print_copy_info = false; |
|
| 25 | + |
|
| 26 | + /** |
|
| 27 | + * @type array $_attendee_data |
|
| 28 | + */ |
|
| 29 | + private $_attendee_data = array(); |
|
| 30 | + |
|
| 31 | + /** |
|
| 32 | + * @type array $_required_questions |
|
| 33 | + */ |
|
| 34 | + private $_required_questions = array(); |
|
| 35 | + |
|
| 36 | + /** |
|
| 37 | + * @type array $_registration_answers |
|
| 38 | + */ |
|
| 39 | + private $_registration_answers = array(); |
|
| 40 | + |
|
| 41 | + |
|
| 42 | + /** |
|
| 43 | + * class constructor |
|
| 44 | + * |
|
| 45 | + * @access public |
|
| 46 | + * @param EE_Checkout $checkout |
|
| 47 | + */ |
|
| 48 | + public function __construct(EE_Checkout $checkout) |
|
| 49 | + { |
|
| 50 | + $this->_slug = 'attendee_information'; |
|
| 51 | + $this->_name = esc_html__('Attendee Information', 'event_espresso'); |
|
| 52 | + $this->_template = SPCO_REG_STEPS_PATH . $this->_slug . '/attendee_info_main.template.php'; |
|
| 53 | + $this->checkout = $checkout; |
|
| 54 | + $this->_reset_success_message(); |
|
| 55 | + $this->set_instructions( |
|
| 56 | + esc_html__('Please answer the following registration questions before proceeding.', 'event_espresso') |
|
| 57 | + ); |
|
| 58 | + } |
|
| 59 | + |
|
| 60 | + |
|
| 61 | + public function translate_js_strings() |
|
| 62 | + { |
|
| 63 | + EE_Registry::$i18n_js_strings['required_field'] = esc_html__( |
|
| 64 | + ' is a required question.', |
|
| 65 | + 'event_espresso' |
|
| 66 | + ); |
|
| 67 | + EE_Registry::$i18n_js_strings['required_multi_field'] = esc_html__( |
|
| 68 | + ' is a required question. Please enter a value for at least one of the options.', |
|
| 69 | + 'event_espresso' |
|
| 70 | + ); |
|
| 71 | + EE_Registry::$i18n_js_strings['answer_required_questions'] = esc_html__( |
|
| 72 | + 'Please answer all required questions correctly before proceeding.', |
|
| 73 | + 'event_espresso' |
|
| 74 | + ); |
|
| 75 | + EE_Registry::$i18n_js_strings['attendee_info_copied'] = sprintf( |
|
| 76 | + esc_html_x( |
|
| 77 | + 'The attendee information was successfully copied.%sPlease ensure the rest of the registration form is completed before proceeding.', |
|
| 78 | + 'The attendee information was successfully copied.(line break)Please ensure the rest of the registration form is completed before proceeding.', |
|
| 79 | + 'event_espresso' |
|
| 80 | + ), |
|
| 81 | + '<br/>' |
|
| 82 | + ); |
|
| 83 | + EE_Registry::$i18n_js_strings['attendee_info_copy_error'] = esc_html__( |
|
| 84 | + 'An unknown error occurred on the server while attempting to copy the attendee information. Please refresh the page and try again.', |
|
| 85 | + 'event_espresso' |
|
| 86 | + ); |
|
| 87 | + EE_Registry::$i18n_js_strings['enter_valid_email'] = esc_html__( |
|
| 88 | + 'You must enter a valid email address.', |
|
| 89 | + 'event_espresso' |
|
| 90 | + ); |
|
| 91 | + EE_Registry::$i18n_js_strings['valid_email_and_questions'] = esc_html__( |
|
| 92 | + 'You must enter a valid email address and answer all other required questions before you can proceed.', |
|
| 93 | + 'event_espresso' |
|
| 94 | + ); |
|
| 95 | + } |
|
| 96 | + |
|
| 97 | + |
|
| 98 | + public function enqueue_styles_and_scripts() |
|
| 99 | + { |
|
| 100 | + } |
|
| 101 | + |
|
| 102 | + |
|
| 103 | + /** |
|
| 104 | + * @return boolean |
|
| 105 | + */ |
|
| 106 | + public function initialize_reg_step() |
|
| 107 | + { |
|
| 108 | + return true; |
|
| 109 | + } |
|
| 110 | + |
|
| 111 | + |
|
| 112 | + /** |
|
| 113 | + * @return EE_Form_Section_Proper |
|
| 114 | + * @throws DomainException |
|
| 115 | + * @throws EE_Error |
|
| 116 | + * @throws InvalidArgumentException |
|
| 117 | + * @throws ReflectionException |
|
| 118 | + * @throws EntityNotFoundException |
|
| 119 | + * @throws InvalidDataTypeException |
|
| 120 | + * @throws InvalidInterfaceException |
|
| 121 | + */ |
|
| 122 | + public function generate_reg_form() |
|
| 123 | + { |
|
| 124 | + /** |
|
| 125 | + * @var $reg_config EE_Registration_Config |
|
| 126 | + */ |
|
| 127 | + $reg_config = LoaderFactory::getLoader()->getShared('EE_Registration_Config'); |
|
| 128 | 128 | |
| 129 | - $this->_print_copy_info = $reg_config->copyAttendeeInfo(); |
|
| 130 | - $primary_registrant = null; |
|
| 131 | - // autoload Line_Item_Display classes |
|
| 132 | - EEH_Autoloader::register_line_item_display_autoloaders(); |
|
| 133 | - $Line_Item_Display = new EE_Line_Item_Display(); |
|
| 134 | - // calculate taxes |
|
| 135 | - $Line_Item_Display->display_line_item( |
|
| 136 | - $this->checkout->cart->get_grand_total(), |
|
| 137 | - array('set_tax_rate' => true) |
|
| 138 | - ); |
|
| 139 | - /** @var $subsections EE_Form_Section_Proper[] */ |
|
| 140 | - $extra_inputs_section = $this->reg_step_hidden_inputs(); |
|
| 141 | - $subsections = array( |
|
| 142 | - 'default_hidden_inputs' => $extra_inputs_section, |
|
| 143 | - ); |
|
| 144 | - |
|
| 145 | - // if this isn't a revisit, and they have the privacy consent box enalbed, add it |
|
| 146 | - if (! $this->checkout->revisit && $reg_config->isConsentCheckboxEnabled()) { |
|
| 147 | - $extra_inputs_section->add_subsections( |
|
| 148 | - array( |
|
| 149 | - 'consent_box' => new EE_Form_Section_Proper( |
|
| 150 | - array( |
|
| 151 | - 'layout_strategy' => |
|
| 152 | - new EE_Template_Layout( |
|
| 153 | - array( |
|
| 154 | - 'input_template_file' => SPCO_REG_STEPS_PATH . $this->_slug . '/privacy_consent.template.php', |
|
| 155 | - ) |
|
| 156 | - ), |
|
| 157 | - 'subsections' => array( |
|
| 158 | - 'consent' => new EE_Checkbox_Multi_Input( |
|
| 159 | - array( |
|
| 160 | - 'consent' => $reg_config->getConsentCheckboxLabelText(), |
|
| 161 | - ), |
|
| 162 | - array( |
|
| 163 | - 'required' => true, |
|
| 164 | - 'required_validation_error_message' => esc_html__( |
|
| 165 | - 'You must consent to these terms in order to register.', |
|
| 166 | - 'event_espresso' |
|
| 167 | - ), |
|
| 168 | - 'html_label_text' => '', |
|
| 169 | - ) |
|
| 170 | - ), |
|
| 171 | - ), |
|
| 172 | - ) |
|
| 173 | - ), |
|
| 174 | - ), |
|
| 175 | - null, |
|
| 176 | - false |
|
| 177 | - ); |
|
| 178 | - } |
|
| 179 | - $template_args = array( |
|
| 180 | - 'revisit' => $this->checkout->revisit, |
|
| 181 | - 'registrations' => array(), |
|
| 182 | - 'ticket_count' => array(), |
|
| 183 | - ); |
|
| 184 | - // grab the saved registrations from the transaction |
|
| 185 | - $registrations = $this->checkout->transaction->registrations($this->checkout->reg_cache_where_params); |
|
| 186 | - if ($registrations) { |
|
| 187 | - foreach ($registrations as $registration) { |
|
| 188 | - // can this registration be processed during this visit ? |
|
| 189 | - if ($registration instanceof EE_Registration |
|
| 190 | - && $this->checkout->visit_allows_processing_of_this_registration($registration) |
|
| 191 | - ) { |
|
| 192 | - $subsections[ $registration->reg_url_link() ] = $this->_registrations_reg_form($registration); |
|
| 193 | - if (! $this->checkout->admin_request) { |
|
| 194 | - $template_args['registrations'][ $registration->reg_url_link() ] = $registration; |
|
| 195 | - $template_args['ticket_count'][ $registration->ticket()->ID() ] = isset( |
|
| 196 | - $template_args['ticket_count'][ $registration->ticket()->ID() ] |
|
| 197 | - ) |
|
| 198 | - ? $template_args['ticket_count'][ $registration->ticket()->ID() ] + 1 |
|
| 199 | - : 1; |
|
| 200 | - $ticket_line_item = EEH_Line_Item::get_line_items_by_object_type_and_IDs( |
|
| 201 | - $this->checkout->cart->get_grand_total(), |
|
| 202 | - 'Ticket', |
|
| 203 | - array($registration->ticket()->ID()) |
|
| 204 | - ); |
|
| 205 | - $ticket_line_item = is_array($ticket_line_item) |
|
| 206 | - ? reset($ticket_line_item) |
|
| 207 | - : $ticket_line_item; |
|
| 208 | - $template_args['ticket_line_item'][ $registration->ticket()->ID() ] = |
|
| 209 | - $Line_Item_Display->display_line_item($ticket_line_item); |
|
| 210 | - } |
|
| 211 | - if ($registration->is_primary_registrant()) { |
|
| 212 | - $primary_registrant = $registration->reg_url_link(); |
|
| 213 | - } |
|
| 214 | - } |
|
| 215 | - } |
|
| 216 | - if ($primary_registrant && ! $this->checkout->admin_request && count($registrations) > 1) { |
|
| 217 | - $copy_options['spco_copy_attendee_chk'] = $this->_print_copy_info |
|
| 218 | - ? $this->_copy_attendee_info_form() |
|
| 219 | - : $this->_auto_copy_attendee_info(); |
|
| 220 | - // generate hidden input |
|
| 221 | - if (isset($subsections[ $primary_registrant ]) |
|
| 222 | - && $subsections[ $primary_registrant ] instanceof EE_Form_Section_Proper |
|
| 223 | - ) { |
|
| 224 | - $subsections[ $primary_registrant ]->add_subsections( |
|
| 225 | - $copy_options, |
|
| 226 | - 'primary_registrant', |
|
| 227 | - false |
|
| 228 | - ); |
|
| 229 | - } |
|
| 230 | - } |
|
| 231 | - } |
|
| 232 | - return new EE_Form_Section_Proper( |
|
| 233 | - array( |
|
| 234 | - 'name' => $this->reg_form_name(), |
|
| 235 | - 'html_id' => $this->reg_form_name(), |
|
| 236 | - 'subsections' => $subsections, |
|
| 237 | - 'layout_strategy' => $this->checkout->admin_request |
|
| 238 | - ? |
|
| 239 | - new EE_Div_Per_Section_Layout() |
|
| 240 | - : |
|
| 241 | - new EE_Template_Layout( |
|
| 242 | - array( |
|
| 243 | - 'layout_template_file' => $this->_template, // layout_template |
|
| 244 | - 'template_args' => $template_args, |
|
| 245 | - ) |
|
| 246 | - ), |
|
| 247 | - ) |
|
| 248 | - ); |
|
| 249 | - } |
|
| 250 | - |
|
| 251 | - |
|
| 252 | - /** |
|
| 253 | - * @param EE_Registration $registration |
|
| 254 | - * @return EE_Form_Section_Base |
|
| 255 | - * @throws EE_Error |
|
| 256 | - * @throws InvalidArgumentException |
|
| 257 | - * @throws EntityNotFoundException |
|
| 258 | - * @throws InvalidDataTypeException |
|
| 259 | - * @throws InvalidInterfaceException |
|
| 260 | - * @throws ReflectionException |
|
| 261 | - */ |
|
| 262 | - private function _registrations_reg_form(EE_Registration $registration) |
|
| 263 | - { |
|
| 264 | - static $attendee_nmbr = 1; |
|
| 265 | - $form_args = array(); |
|
| 266 | - // verify that registration has valid event |
|
| 267 | - if ($registration->event() instanceof EE_Event) { |
|
| 268 | - $field_name = 'Event_Question_Group.' |
|
| 269 | - . EEM_Event_Question_Group::instance()->fieldNameForContext( |
|
| 270 | - $registration->is_primary_registrant() |
|
| 271 | - ); |
|
| 272 | - $question_groups = $registration->event()->question_groups( |
|
| 273 | - apply_filters( |
|
| 274 | - // @codingStandardsIgnoreStart |
|
| 275 | - 'FHEE__EE_SPCO_Reg_Step_Attendee_Information___registrations_reg_form__question_groups_query_parameters', |
|
| 276 | - // @codingStandardsIgnoreEnd |
|
| 277 | - [ |
|
| 278 | - [ |
|
| 279 | - 'Event.EVT_ID' => $registration->event()->ID(), |
|
| 280 | - $field_name => true, |
|
| 281 | - ], |
|
| 282 | - 'order_by' => ['QSG_order' => 'ASC'], |
|
| 283 | - ], |
|
| 284 | - $registration, |
|
| 285 | - $this |
|
| 286 | - ) |
|
| 287 | - ); |
|
| 288 | - if ($question_groups) { |
|
| 289 | - // array of params to pass to parent constructor |
|
| 290 | - $form_args = array( |
|
| 291 | - 'html_id' => 'ee-registration-' . $registration->reg_url_link(), |
|
| 292 | - 'html_class' => 'ee-reg-form-attendee-dv', |
|
| 293 | - 'html_style' => $this->checkout->admin_request |
|
| 294 | - ? 'padding:0em 2em 1em; margin:3em 0 0; border:1px solid #ddd;' |
|
| 295 | - : '', |
|
| 296 | - 'subsections' => array(), |
|
| 297 | - 'layout_strategy' => new EE_Fieldset_Section_Layout( |
|
| 298 | - array( |
|
| 299 | - 'legend_class' => 'spco-attendee-lgnd smaller-text lt-grey-text', |
|
| 300 | - 'legend_text' => sprintf( |
|
| 301 | - esc_html_x( |
|
| 302 | - 'Attendee %d', |
|
| 303 | - 'Attendee 123', |
|
| 304 | - 'event_espresso' |
|
| 305 | - ), |
|
| 306 | - $attendee_nmbr |
|
| 307 | - ), |
|
| 308 | - ) |
|
| 309 | - ), |
|
| 310 | - ); |
|
| 311 | - foreach ($question_groups as $question_group) { |
|
| 312 | - if ($question_group instanceof EE_Question_Group) { |
|
| 313 | - $form_args['subsections'][ $question_group->identifier() ] = $this->_question_group_reg_form( |
|
| 314 | - $registration, |
|
| 315 | - $question_group |
|
| 316 | - ); |
|
| 317 | - } |
|
| 318 | - } |
|
| 319 | - // add hidden input |
|
| 320 | - $form_args['subsections']['additional_attendee_reg_info'] = $this->_additional_attendee_reg_info_input( |
|
| 321 | - $registration |
|
| 322 | - ); |
|
| 323 | - |
|
| 324 | - /** |
|
| 325 | - * @var $reg_config EE_Registration_Config |
|
| 326 | - */ |
|
| 327 | - $reg_config = LoaderFactory::getLoader()->getShared('EE_Registration_Config'); |
|
| 328 | - |
|
| 329 | - // if we have question groups for additional attendees, then display the copy options |
|
| 330 | - $this->_print_copy_info = $attendee_nmbr > 1 ? $reg_config->copyAttendeeInfo() : false; |
|
| 331 | - if ($registration->is_primary_registrant()) { |
|
| 332 | - // generate hidden input |
|
| 333 | - $form_args['subsections']['primary_registrant'] = $this->_additional_primary_registrant_inputs( |
|
| 334 | - $registration |
|
| 335 | - ); |
|
| 336 | - } |
|
| 337 | - } |
|
| 338 | - } |
|
| 339 | - $attendee_nmbr++; |
|
| 340 | - return ! empty($form_args) |
|
| 341 | - ? new EE_Form_Section_Proper($form_args) |
|
| 342 | - : new EE_Form_Section_HTML(); |
|
| 343 | - } |
|
| 344 | - |
|
| 345 | - |
|
| 346 | - /** |
|
| 347 | - * @param EE_Registration $registration |
|
| 348 | - * @param bool $additional_attendee_reg_info |
|
| 349 | - * @return EE_Form_Input_Base |
|
| 350 | - * @throws EE_Error |
|
| 351 | - */ |
|
| 352 | - private function _additional_attendee_reg_info_input( |
|
| 353 | - EE_Registration $registration, |
|
| 354 | - $additional_attendee_reg_info = true |
|
| 355 | - ) { |
|
| 356 | - // generate hidden input |
|
| 357 | - return new EE_Hidden_Input( |
|
| 358 | - array( |
|
| 359 | - 'html_id' => 'additional-attendee-reg-info-' . $registration->reg_url_link(), |
|
| 360 | - 'default' => $additional_attendee_reg_info, |
|
| 361 | - ) |
|
| 362 | - ); |
|
| 363 | - } |
|
| 364 | - |
|
| 365 | - |
|
| 366 | - /** |
|
| 367 | - * @param EE_Registration $registration |
|
| 368 | - * @param EE_Question_Group $question_group |
|
| 369 | - * @return EE_Form_Section_Proper |
|
| 370 | - * @throws EE_Error |
|
| 371 | - * @throws InvalidArgumentException |
|
| 372 | - * @throws InvalidDataTypeException |
|
| 373 | - * @throws InvalidInterfaceException |
|
| 374 | - * @throws ReflectionException |
|
| 375 | - */ |
|
| 376 | - private function _question_group_reg_form(EE_Registration $registration, EE_Question_Group $question_group) |
|
| 377 | - { |
|
| 378 | - // array of params to pass to parent constructor |
|
| 379 | - $form_args = array( |
|
| 380 | - 'html_id' => 'ee-reg-form-qstn-grp-' . $question_group->identifier() . '-' . $registration->ID(), |
|
| 381 | - 'html_class' => $this->checkout->admin_request |
|
| 382 | - ? 'form-table ee-reg-form-qstn-grp-dv' |
|
| 383 | - : 'ee-reg-form-qstn-grp-dv', |
|
| 384 | - 'html_label_id' => 'ee-reg-form-qstn-grp-' . $question_group->identifier() . '-' |
|
| 385 | - . $registration->ID() . '-lbl', |
|
| 386 | - 'subsections' => array( |
|
| 387 | - 'reg_form_qstn_grp_hdr' => $this->_question_group_header($question_group), |
|
| 388 | - ), |
|
| 389 | - 'layout_strategy' => $this->checkout->admin_request |
|
| 390 | - ? new EE_Admin_Two_Column_Layout() |
|
| 391 | - : new EE_Div_Per_Section_Layout(), |
|
| 392 | - ); |
|
| 393 | - // where params |
|
| 394 | - $query_params = array('QST_deleted' => 0); |
|
| 395 | - // don't load admin only questions on the frontend |
|
| 396 | - if (! $this->checkout->admin_request) { |
|
| 397 | - $query_params['QST_admin_only'] = array('!=', true); |
|
| 398 | - } |
|
| 399 | - $questions = $question_group->get_many_related( |
|
| 400 | - 'Question', |
|
| 401 | - apply_filters( |
|
| 402 | - 'FHEE__EE_SPCO_Reg_Step_Attendee_Information___question_group_reg_form__related_questions_query_params', |
|
| 403 | - array( |
|
| 404 | - $query_params, |
|
| 405 | - 'order_by' => array( |
|
| 406 | - 'Question_Group_Question.QGQ_order' => 'ASC', |
|
| 407 | - ), |
|
| 408 | - ), |
|
| 409 | - $question_group, |
|
| 410 | - $registration, |
|
| 411 | - $this |
|
| 412 | - ) |
|
| 413 | - ); |
|
| 414 | - // filter for additional content before questions |
|
| 415 | - $form_args['subsections']['reg_form_questions_before'] = new EE_Form_Section_HTML( |
|
| 416 | - apply_filters( |
|
| 417 | - 'FHEE__EEH_Form_Fields__generate_question_groups_html__before_question_group_questions', |
|
| 418 | - '', |
|
| 419 | - $registration, |
|
| 420 | - $question_group, |
|
| 421 | - $this |
|
| 422 | - ) |
|
| 423 | - ); |
|
| 424 | - // loop thru questions |
|
| 425 | - foreach ($questions as $question) { |
|
| 426 | - if ($question instanceof EE_Question) { |
|
| 427 | - $identifier = $question->is_system_question() |
|
| 428 | - ? $question->system_ID() |
|
| 429 | - : $question->ID(); |
|
| 430 | - $form_args['subsections'][ $identifier ] = $this->reg_form_question($registration, $question); |
|
| 431 | - } |
|
| 432 | - } |
|
| 433 | - $form_args['subsections'] = apply_filters( |
|
| 434 | - 'FHEE__EE_SPCO_Reg_Step_Attendee_Information__question_group_reg_form__subsections_array', |
|
| 435 | - $form_args['subsections'], |
|
| 436 | - $registration, |
|
| 437 | - $question_group, |
|
| 438 | - $this |
|
| 439 | - ); |
|
| 440 | - // filter for additional content after questions |
|
| 441 | - $form_args['subsections']['reg_form_questions_after'] = new EE_Form_Section_HTML( |
|
| 442 | - apply_filters( |
|
| 443 | - 'FHEE__EEH_Form_Fields__generate_question_groups_html__after_question_group_questions', |
|
| 444 | - '', |
|
| 445 | - $registration, |
|
| 446 | - $question_group, |
|
| 447 | - $this |
|
| 448 | - ) |
|
| 449 | - ); |
|
| 450 | - // d($form_args); |
|
| 451 | - $question_group_reg_form = new EE_Form_Section_Proper($form_args); |
|
| 452 | - return apply_filters( |
|
| 453 | - 'FHEE__EE_SPCO_Reg_Step_Attendee_Information___question_group_reg_form__question_group_reg_form', |
|
| 454 | - $question_group_reg_form, |
|
| 455 | - $registration, |
|
| 456 | - $question_group, |
|
| 457 | - $this |
|
| 458 | - ); |
|
| 459 | - } |
|
| 460 | - |
|
| 461 | - |
|
| 462 | - /** |
|
| 463 | - * @param EE_Question_Group $question_group |
|
| 464 | - * @return EE_Form_Section_HTML |
|
| 465 | - */ |
|
| 466 | - private function _question_group_header(EE_Question_Group $question_group) |
|
| 467 | - { |
|
| 468 | - $html = ''; |
|
| 469 | - // group_name |
|
| 470 | - if ($question_group->show_group_name() && $question_group->name() !== '') { |
|
| 471 | - if ($this->checkout->admin_request) { |
|
| 472 | - $html .= EEH_HTML::br(); |
|
| 473 | - $html .= EEH_HTML::h3( |
|
| 474 | - $question_group->name(), |
|
| 475 | - '', |
|
| 476 | - 'ee-reg-form-qstn-grp-title title', |
|
| 477 | - 'font-size: 1.3em; padding-left:0;' |
|
| 478 | - ); |
|
| 479 | - } else { |
|
| 480 | - $html .= EEH_HTML::h4( |
|
| 481 | - $question_group->name(), |
|
| 482 | - '', |
|
| 483 | - 'ee-reg-form-qstn-grp-title section-title' |
|
| 484 | - ); |
|
| 485 | - } |
|
| 486 | - } |
|
| 487 | - // group_desc |
|
| 488 | - if ($question_group->show_group_desc() && $question_group->desc() !== '') { |
|
| 489 | - $html .= EEH_HTML::p( |
|
| 490 | - $question_group->desc(), |
|
| 491 | - '', |
|
| 492 | - $this->checkout->admin_request |
|
| 493 | - ? 'ee-reg-form-qstn-grp-desc-pg' |
|
| 494 | - : 'ee-reg-form-qstn-grp-desc-pg small-text lt-grey-text' |
|
| 495 | - ); |
|
| 496 | - } |
|
| 497 | - return new EE_Form_Section_HTML($html); |
|
| 498 | - } |
|
| 499 | - |
|
| 500 | - |
|
| 501 | - /** |
|
| 502 | - * @return EE_Form_Section_Proper |
|
| 503 | - * @throws EE_Error |
|
| 504 | - * @throws InvalidArgumentException |
|
| 505 | - * @throws ReflectionException |
|
| 506 | - * @throws InvalidDataTypeException |
|
| 507 | - * @throws InvalidInterfaceException |
|
| 508 | - */ |
|
| 509 | - private function _copy_attendee_info_form() |
|
| 510 | - { |
|
| 511 | - // array of params to pass to parent constructor |
|
| 512 | - return new EE_Form_Section_Proper( |
|
| 513 | - array( |
|
| 514 | - 'subsections' => $this->_copy_attendee_info_inputs(), |
|
| 515 | - 'layout_strategy' => new EE_Template_Layout( |
|
| 516 | - array( |
|
| 517 | - 'layout_template_file' => SPCO_REG_STEPS_PATH |
|
| 518 | - . $this->_slug |
|
| 519 | - . '/copy_attendee_info.template.php', |
|
| 520 | - 'begin_template_file' => null, |
|
| 521 | - 'input_template_file' => null, |
|
| 522 | - 'subsection_template_file' => null, |
|
| 523 | - 'end_template_file' => null, |
|
| 524 | - ) |
|
| 525 | - ), |
|
| 526 | - ) |
|
| 527 | - ); |
|
| 528 | - } |
|
| 529 | - |
|
| 530 | - |
|
| 531 | - /** |
|
| 532 | - * @return EE_Form_Section_HTML |
|
| 533 | - * @throws DomainException |
|
| 534 | - * @throws InvalidArgumentException |
|
| 535 | - * @throws InvalidDataTypeException |
|
| 536 | - * @throws InvalidInterfaceException |
|
| 537 | - */ |
|
| 538 | - private function _auto_copy_attendee_info() |
|
| 539 | - { |
|
| 540 | - return new EE_Form_Section_HTML( |
|
| 541 | - EEH_Template::locate_template( |
|
| 542 | - SPCO_REG_STEPS_PATH . $this->_slug . '/_auto_copy_attendee_info.template.php', |
|
| 543 | - apply_filters( |
|
| 544 | - 'FHEE__EE_SPCO_Reg_Step_Attendee_Information__auto_copy_attendee_info__template_args', |
|
| 545 | - array() |
|
| 546 | - ), |
|
| 547 | - true, |
|
| 548 | - true |
|
| 549 | - ) |
|
| 550 | - ); |
|
| 551 | - } |
|
| 552 | - |
|
| 553 | - |
|
| 554 | - /** |
|
| 555 | - * @return array |
|
| 556 | - * @throws EE_Error |
|
| 557 | - * @throws InvalidArgumentException |
|
| 558 | - * @throws ReflectionException |
|
| 559 | - * @throws InvalidDataTypeException |
|
| 560 | - * @throws InvalidInterfaceException |
|
| 561 | - */ |
|
| 562 | - private function _copy_attendee_info_inputs() |
|
| 563 | - { |
|
| 564 | - $copy_attendee_info_inputs = array(); |
|
| 565 | - $prev_ticket = null; |
|
| 566 | - // grab the saved registrations from the transaction |
|
| 567 | - $registrations = $this->checkout->transaction->registrations($this->checkout->reg_cache_where_params); |
|
| 568 | - foreach ($registrations as $registration) { |
|
| 569 | - // for all attendees other than the primary attendee |
|
| 570 | - if ($registration instanceof EE_Registration && ! $registration->is_primary_registrant()) { |
|
| 571 | - // if this is a new ticket OR if this is the very first additional attendee after the primary attendee |
|
| 572 | - if ($registration->ticket()->ID() !== $prev_ticket) { |
|
| 573 | - $item_name = $registration->ticket()->name(); |
|
| 574 | - $item_name .= $registration->ticket()->description() !== '' |
|
| 575 | - ? ' - ' . $registration->ticket()->description() |
|
| 576 | - : ''; |
|
| 577 | - $copy_attendee_info_inputs[ 'spco_copy_attendee_chk[ticket-' . $registration->ticket()->ID( |
|
| 578 | - ) . ']' ] = |
|
| 579 | - new EE_Form_Section_HTML( |
|
| 580 | - '<h6 class="spco-copy-attendee-event-hdr">' . $item_name . '</h6>' |
|
| 581 | - ); |
|
| 582 | - $prev_ticket = $registration->ticket()->ID(); |
|
| 583 | - } |
|
| 584 | - |
|
| 585 | - $copy_attendee_info_inputs[ 'spco_copy_attendee_chk[' . $registration->ID() . ']' ] = |
|
| 586 | - new EE_Checkbox_Multi_Input( |
|
| 587 | - array( |
|
| 588 | - $registration->ID() => sprintf( |
|
| 589 | - esc_html_x('Attendee #%s', 'Attendee #123', 'event_espresso'), |
|
| 590 | - $registration->count() |
|
| 591 | - ), |
|
| 592 | - ), |
|
| 593 | - array( |
|
| 594 | - 'html_id' => 'spco-copy-attendee-chk-' . $registration->reg_url_link(), |
|
| 595 | - 'html_class' => 'spco-copy-attendee-chk ee-do-not-validate', |
|
| 596 | - 'display_html_label_text' => false, |
|
| 597 | - ) |
|
| 598 | - ); |
|
| 599 | - } |
|
| 600 | - } |
|
| 601 | - return $copy_attendee_info_inputs; |
|
| 602 | - } |
|
| 603 | - |
|
| 604 | - |
|
| 605 | - /** |
|
| 606 | - * @param EE_Registration $registration |
|
| 607 | - * @return EE_Form_Input_Base |
|
| 608 | - * @throws EE_Error |
|
| 609 | - */ |
|
| 610 | - private function _additional_primary_registrant_inputs(EE_Registration $registration) |
|
| 611 | - { |
|
| 612 | - // generate hidden input |
|
| 613 | - return new EE_Hidden_Input( |
|
| 614 | - array( |
|
| 615 | - 'html_id' => 'primary_registrant', |
|
| 616 | - 'default' => $registration->reg_url_link(), |
|
| 617 | - ) |
|
| 618 | - ); |
|
| 619 | - } |
|
| 620 | - |
|
| 621 | - |
|
| 622 | - /** |
|
| 623 | - * @param EE_Registration $registration |
|
| 624 | - * @param EE_Question $question |
|
| 625 | - * @return EE_Form_Input_Base |
|
| 626 | - * @throws EE_Error |
|
| 627 | - * @throws InvalidArgumentException |
|
| 628 | - * @throws InvalidDataTypeException |
|
| 629 | - * @throws InvalidInterfaceException |
|
| 630 | - * @throws ReflectionException |
|
| 631 | - */ |
|
| 632 | - public function reg_form_question(EE_Registration $registration, EE_Question $question) |
|
| 633 | - { |
|
| 634 | - |
|
| 635 | - // if this question was for an attendee detail, then check for that answer |
|
| 636 | - $answer_value = EEM_Answer::instance()->get_attendee_property_answer_value( |
|
| 637 | - $registration, |
|
| 638 | - $question->system_ID() |
|
| 639 | - ); |
|
| 640 | - $answer = $answer_value === null |
|
| 641 | - ? EEM_Answer::instance()->get_one( |
|
| 642 | - array(array('QST_ID' => $question->ID(), 'REG_ID' => $registration->ID())) |
|
| 643 | - ) |
|
| 644 | - : null; |
|
| 645 | - // if NOT returning to edit an existing registration |
|
| 646 | - // OR if this question is for an attendee property |
|
| 647 | - // OR we still don't have an EE_Answer object |
|
| 648 | - if ($answer_value || ! $answer instanceof EE_Answer || ! $registration->reg_url_link()) { |
|
| 649 | - // create an EE_Answer object for storing everything in |
|
| 650 | - $answer = EE_Answer::new_instance( |
|
| 651 | - array( |
|
| 652 | - 'QST_ID' => $question->ID(), |
|
| 653 | - 'REG_ID' => $registration->ID(), |
|
| 654 | - ) |
|
| 655 | - ); |
|
| 656 | - } |
|
| 657 | - // verify instance |
|
| 658 | - if ($answer instanceof EE_Answer) { |
|
| 659 | - if (! empty($answer_value)) { |
|
| 660 | - $answer->set('ANS_value', $answer_value); |
|
| 661 | - } |
|
| 662 | - $answer->cache('Question', $question); |
|
| 663 | - // remember system ID had a bug where sometimes it could be null |
|
| 664 | - $answer_cache_id = $question->is_system_question() |
|
| 665 | - ? $question->system_ID() . '-' . $registration->reg_url_link() |
|
| 666 | - : $question->ID() . '-' . $registration->reg_url_link(); |
|
| 667 | - $registration->cache('Answer', $answer, $answer_cache_id); |
|
| 668 | - } |
|
| 669 | - return $this->_generate_question_input($registration, $question, $answer); |
|
| 670 | - } |
|
| 671 | - |
|
| 672 | - |
|
| 673 | - /** |
|
| 674 | - * @param EE_Registration $registration |
|
| 675 | - * @param EE_Question $question |
|
| 676 | - * @param $answer |
|
| 677 | - * @return EE_Form_Input_Base |
|
| 678 | - * @throws EE_Error |
|
| 679 | - * @throws InvalidArgumentException |
|
| 680 | - * @throws ReflectionException |
|
| 681 | - * @throws InvalidDataTypeException |
|
| 682 | - * @throws InvalidInterfaceException |
|
| 683 | - */ |
|
| 684 | - private function _generate_question_input(EE_Registration $registration, EE_Question $question, $answer) |
|
| 685 | - { |
|
| 686 | - $identifier = $question->is_system_question() |
|
| 687 | - ? $question->system_ID() |
|
| 688 | - : $question->ID(); |
|
| 689 | - $this->_required_questions[ $identifier ] = $question->required() ? true : false; |
|
| 690 | - add_filter( |
|
| 691 | - 'FHEE__EE_Question__generate_form_input__country_options', |
|
| 692 | - array($this, 'use_cached_countries_for_form_input'), |
|
| 693 | - 10, |
|
| 694 | - 4 |
|
| 695 | - ); |
|
| 696 | - add_filter( |
|
| 697 | - 'FHEE__EE_Question__generate_form_input__state_options', |
|
| 698 | - array($this, 'use_cached_states_for_form_input'), |
|
| 699 | - 10, |
|
| 700 | - 4 |
|
| 701 | - ); |
|
| 702 | - $input_constructor_args = array( |
|
| 703 | - 'html_name' => 'ee_reg_qstn[' . $registration->ID() . '][' . $identifier . ']', |
|
| 704 | - 'html_id' => 'ee_reg_qstn-' . $registration->ID() . '-' . $identifier, |
|
| 705 | - 'html_class' => 'ee-reg-qstn ee-reg-qstn-' . $identifier, |
|
| 706 | - 'html_label_id' => 'ee_reg_qstn-' . $registration->ID() . '-' . $identifier, |
|
| 707 | - 'html_label_class' => 'ee-reg-qstn', |
|
| 708 | - ); |
|
| 709 | - $input_constructor_args['html_label_id'] .= '-lbl'; |
|
| 710 | - if ($answer instanceof EE_Answer && $answer->ID()) { |
|
| 711 | - $input_constructor_args['html_name'] .= '[' . $answer->ID() . ']'; |
|
| 712 | - $input_constructor_args['html_id'] .= '-' . $answer->ID(); |
|
| 713 | - $input_constructor_args['html_label_id'] .= '-' . $answer->ID(); |
|
| 714 | - } |
|
| 715 | - $form_input = $question->generate_form_input( |
|
| 716 | - $registration, |
|
| 717 | - $answer, |
|
| 718 | - $input_constructor_args |
|
| 719 | - ); |
|
| 720 | - remove_filter( |
|
| 721 | - 'FHEE__EE_Question__generate_form_input__country_options', |
|
| 722 | - array($this, 'use_cached_countries_for_form_input') |
|
| 723 | - ); |
|
| 724 | - remove_filter( |
|
| 725 | - 'FHEE__EE_Question__generate_form_input__state_options', |
|
| 726 | - array($this, 'use_cached_states_for_form_input') |
|
| 727 | - ); |
|
| 728 | - return $form_input; |
|
| 729 | - } |
|
| 730 | - |
|
| 731 | - |
|
| 732 | - /** |
|
| 733 | - * Gets the list of countries for the form input |
|
| 734 | - * |
|
| 735 | - * @param array|null $countries_list |
|
| 736 | - * @param EE_Question $question |
|
| 737 | - * @param EE_Registration $registration |
|
| 738 | - * @param EE_Answer $answer |
|
| 739 | - * @return array 2d keys are country IDs, values are their names |
|
| 740 | - * @throws EE_Error |
|
| 741 | - * @throws InvalidArgumentException |
|
| 742 | - * @throws InvalidDataTypeException |
|
| 743 | - * @throws InvalidInterfaceException |
|
| 744 | - * @throws ReflectionException |
|
| 745 | - */ |
|
| 746 | - public function use_cached_countries_for_form_input( |
|
| 747 | - $countries_list, |
|
| 748 | - EE_Question $question = null, |
|
| 749 | - EE_Registration $registration = null, |
|
| 750 | - EE_Answer $answer = null |
|
| 751 | - ) { |
|
| 752 | - $country_options = array('' => ''); |
|
| 753 | - // get possibly cached list of countries |
|
| 754 | - $countries = $this->checkout->action === 'process_reg_step' |
|
| 755 | - ? EEM_Country::instance()->get_all_countries() |
|
| 756 | - : EEM_Country::instance()->get_all_active_countries(); |
|
| 757 | - if (! empty($countries)) { |
|
| 758 | - foreach ($countries as $country) { |
|
| 759 | - if ($country instanceof EE_Country) { |
|
| 760 | - $country_options[ $country->ID() ] = $country->name(); |
|
| 761 | - } |
|
| 762 | - } |
|
| 763 | - } |
|
| 764 | - if ($question instanceof EE_Question && $registration instanceof EE_Registration) { |
|
| 765 | - $answer = EEM_Answer::instance()->get_one( |
|
| 766 | - array(array('QST_ID' => $question->ID(), 'REG_ID' => $registration->ID())) |
|
| 767 | - ); |
|
| 768 | - } else { |
|
| 769 | - $answer = EE_Answer::new_instance(); |
|
| 770 | - } |
|
| 771 | - $country_options = apply_filters( |
|
| 772 | - 'FHEE__EE_SPCO_Reg_Step_Attendee_Information___generate_question_input__country_options', |
|
| 773 | - $country_options, |
|
| 774 | - $this, |
|
| 775 | - $registration, |
|
| 776 | - $question, |
|
| 777 | - $answer |
|
| 778 | - ); |
|
| 779 | - return $country_options; |
|
| 780 | - } |
|
| 781 | - |
|
| 782 | - |
|
| 783 | - /** |
|
| 784 | - * Gets the list of states for the form input |
|
| 785 | - * |
|
| 786 | - * @param array|null $states_list |
|
| 787 | - * @param EE_Question $question |
|
| 788 | - * @param EE_Registration $registration |
|
| 789 | - * @param EE_Answer $answer |
|
| 790 | - * @return array 2d keys are state IDs, values are their names |
|
| 791 | - * @throws EE_Error |
|
| 792 | - * @throws InvalidArgumentException |
|
| 793 | - * @throws InvalidDataTypeException |
|
| 794 | - * @throws InvalidInterfaceException |
|
| 795 | - * @throws ReflectionException |
|
| 796 | - */ |
|
| 797 | - public function use_cached_states_for_form_input( |
|
| 798 | - $states_list, |
|
| 799 | - EE_Question $question = null, |
|
| 800 | - EE_Registration $registration = null, |
|
| 801 | - EE_Answer $answer = null |
|
| 802 | - ) { |
|
| 803 | - $state_options = array('' => array('' => '')); |
|
| 804 | - $states = $this->checkout->action === 'process_reg_step' |
|
| 805 | - ? EEM_State::instance()->get_all_states() |
|
| 806 | - : EEM_State::instance()->get_all_active_states(); |
|
| 807 | - if (! empty($states)) { |
|
| 808 | - foreach ($states as $state) { |
|
| 809 | - if ($state instanceof EE_State) { |
|
| 810 | - $state_options[ $state->country()->name() ][ $state->ID() ] = $state->name(); |
|
| 811 | - } |
|
| 812 | - } |
|
| 813 | - } |
|
| 814 | - $state_options = apply_filters( |
|
| 815 | - 'FHEE__EE_SPCO_Reg_Step_Attendee_Information___generate_question_input__state_options', |
|
| 816 | - $state_options, |
|
| 817 | - $this, |
|
| 818 | - $registration, |
|
| 819 | - $question, |
|
| 820 | - $answer |
|
| 821 | - ); |
|
| 822 | - return $state_options; |
|
| 823 | - } |
|
| 824 | - |
|
| 825 | - |
|
| 826 | - /********************************************************************************************************/ |
|
| 827 | - /**************************************** PROCESS REG STEP ****************************************/ |
|
| 828 | - /********************************************************************************************************/ |
|
| 829 | - |
|
| 830 | - |
|
| 831 | - /** |
|
| 832 | - * @return bool |
|
| 833 | - * @throws EE_Error |
|
| 834 | - * @throws InvalidArgumentException |
|
| 835 | - * @throws ReflectionException |
|
| 836 | - * @throws RuntimeException |
|
| 837 | - * @throws InvalidDataTypeException |
|
| 838 | - * @throws InvalidInterfaceException |
|
| 839 | - */ |
|
| 840 | - public function process_reg_step() |
|
| 841 | - { |
|
| 842 | - do_action('AHEE_log', __FILE__, __FUNCTION__, ''); |
|
| 843 | - // grab validated data from form |
|
| 844 | - $valid_data = $this->checkout->current_step->valid_data(); |
|
| 845 | - // EEH_Debug_Tools::printr( $_REQUEST, '$_REQUEST', __FILE__, __LINE__ ); |
|
| 846 | - // EEH_Debug_Tools::printr( $valid_data, '$valid_data', __FILE__, __LINE__ ); |
|
| 847 | - // if we don't have any $valid_data then something went TERRIBLY WRONG !!! |
|
| 848 | - if (empty($valid_data)) { |
|
| 849 | - EE_Error::add_error( |
|
| 850 | - esc_html__('No valid question responses were received.', 'event_espresso'), |
|
| 851 | - __FILE__, |
|
| 852 | - __FUNCTION__, |
|
| 853 | - __LINE__ |
|
| 854 | - ); |
|
| 855 | - return false; |
|
| 856 | - } |
|
| 857 | - if (! $this->checkout->transaction instanceof EE_Transaction || ! $this->checkout->continue_reg) { |
|
| 858 | - EE_Error::add_error( |
|
| 859 | - esc_html__( |
|
| 860 | - 'A valid transaction could not be initiated for processing your registrations.', |
|
| 861 | - 'event_espresso' |
|
| 862 | - ), |
|
| 863 | - __FILE__, |
|
| 864 | - __FUNCTION__, |
|
| 865 | - __LINE__ |
|
| 866 | - ); |
|
| 867 | - return false; |
|
| 868 | - } |
|
| 869 | - // get cached registrations |
|
| 870 | - $registrations = $this->checkout->transaction->registrations($this->checkout->reg_cache_where_params); |
|
| 871 | - // verify we got the goods |
|
| 872 | - if (empty($registrations)) { |
|
| 873 | - // combine the old translated string with a new one, in order to not break translations |
|
| 874 | - $error_message = esc_html__( |
|
| 875 | - 'Your form data could not be applied to any valid registrations.', |
|
| 876 | - 'event_espresso' |
|
| 877 | - ) |
|
| 878 | - . sprintf( |
|
| 879 | - esc_html_x( |
|
| 880 | - '%3$sThis can sometimes happen if too much time has been taken to complete the registration process.%3$sPlease return to the %1$sEvent List%2$s and reselect your tickets. If the problem continues, please contact the site administrator.', |
|
| 881 | - '(line break)This can sometimes happen if too much time has been taken to complete the registration process.(line break)Please return to the (link)Event List(end link) and reselect your tickets. If the problem continues, please contact the site administrator.', |
|
| 882 | - 'event_espresso' |
|
| 883 | - ), |
|
| 884 | - '<a href="' . get_post_type_archive_link('espresso_events') . '" >', |
|
| 885 | - '</a>', |
|
| 886 | - '<br />' |
|
| 887 | - ); |
|
| 888 | - EE_Error::add_error( |
|
| 889 | - $error_message, |
|
| 890 | - __FILE__, |
|
| 891 | - __FUNCTION__, |
|
| 892 | - __LINE__ |
|
| 893 | - ); |
|
| 894 | - return false; |
|
| 895 | - } |
|
| 896 | - // extract attendee info from form data and save to model objects |
|
| 897 | - $registrations_processed = $this->_process_registrations($registrations, $valid_data); |
|
| 898 | - // if first pass thru SPCO, |
|
| 899 | - // then let's check processed registrations against the total number of tickets in the cart |
|
| 900 | - if ($registrations_processed === false) { |
|
| 901 | - // but return immediately if the previous step exited early due to errors |
|
| 902 | - return false; |
|
| 903 | - } |
|
| 904 | - if (! $this->checkout->revisit && $registrations_processed !== $this->checkout->total_ticket_count) { |
|
| 905 | - // generate a correctly translated string for all possible singular/plural combinations |
|
| 906 | - if ($this->checkout->total_ticket_count === 1 && $registrations_processed !== 1) { |
|
| 907 | - $error_msg = sprintf( |
|
| 908 | - esc_html_x( |
|
| 909 | - 'There was %1$d ticket in the Event Queue, but %2$ds registrations were processed', |
|
| 910 | - 'There was 1 ticket in the Event Queue, but 2 registrations were processed', |
|
| 911 | - 'event_espresso' |
|
| 912 | - ), |
|
| 913 | - $this->checkout->total_ticket_count, |
|
| 914 | - $registrations_processed |
|
| 915 | - ); |
|
| 916 | - } elseif ($this->checkout->total_ticket_count !== 1 && $registrations_processed === 1) { |
|
| 917 | - $error_msg = sprintf( |
|
| 918 | - esc_html_x( |
|
| 919 | - 'There was a total of %1$d tickets in the Event Queue, but only %2$ds registration was processed', |
|
| 920 | - 'There was a total of 2 tickets in the Event Queue, but only 1 registration was processed', |
|
| 921 | - 'event_espresso' |
|
| 922 | - ), |
|
| 923 | - $this->checkout->total_ticket_count, |
|
| 924 | - $registrations_processed |
|
| 925 | - ); |
|
| 926 | - } else { |
|
| 927 | - $error_msg = sprintf( |
|
| 928 | - esc_html__( |
|
| 929 | - 'There was a total of 2 tickets in the Event Queue, but 2 registrations were processed', |
|
| 930 | - 'event_espresso' |
|
| 931 | - ), |
|
| 932 | - $this->checkout->total_ticket_count, |
|
| 933 | - $registrations_processed |
|
| 934 | - ); |
|
| 935 | - } |
|
| 936 | - EE_Error::add_error($error_msg, __FILE__, __FUNCTION__, __LINE__); |
|
| 937 | - return false; |
|
| 938 | - } |
|
| 939 | - // mark this reg step as completed |
|
| 940 | - $this->set_completed(); |
|
| 941 | - $this->_set_success_message( |
|
| 942 | - esc_html__('The Attendee Information Step has been successfully completed.', 'event_espresso') |
|
| 943 | - ); |
|
| 944 | - // do action in case a plugin wants to do something with the data submitted in step 1. |
|
| 945 | - // passes EE_Single_Page_Checkout, and it's posted data |
|
| 946 | - do_action('AHEE__EE_Single_Page_Checkout__process_attendee_information__end', $this, $valid_data); |
|
| 947 | - return true; |
|
| 948 | - } |
|
| 949 | - |
|
| 950 | - |
|
| 951 | - /** |
|
| 952 | - * _process_registrations |
|
| 953 | - * |
|
| 954 | - * @param EE_Registration[] $registrations |
|
| 955 | - * @param array[][] $valid_data |
|
| 956 | - * @return bool|int |
|
| 957 | - * @throws EntityNotFoundException |
|
| 958 | - * @throws EE_Error |
|
| 959 | - * @throws InvalidArgumentException |
|
| 960 | - * @throws ReflectionException |
|
| 961 | - * @throws RuntimeException |
|
| 962 | - * @throws InvalidDataTypeException |
|
| 963 | - * @throws InvalidInterfaceException |
|
| 964 | - */ |
|
| 965 | - private function _process_registrations($registrations = array(), $valid_data = array()) |
|
| 966 | - { |
|
| 967 | - // load resources and set some defaults |
|
| 968 | - EE_Registry::instance()->load_model('Attendee'); |
|
| 969 | - // holder for primary registrant attendee object |
|
| 970 | - $this->checkout->primary_attendee_obj = null; |
|
| 971 | - // array for tracking reg form data for the primary registrant |
|
| 972 | - $primary_registrant = array( |
|
| 973 | - 'line_item_id' => null, |
|
| 974 | - ); |
|
| 975 | - $copy_primary = false; |
|
| 976 | - // reg form sections that do not contain inputs |
|
| 977 | - $non_input_form_sections = array( |
|
| 978 | - 'primary_registrant', |
|
| 979 | - 'additional_attendee_reg_info', |
|
| 980 | - 'spco_copy_attendee_chk', |
|
| 981 | - ); |
|
| 982 | - // attendee counter |
|
| 983 | - $att_nmbr = 0; |
|
| 984 | - // grab the saved registrations from the transaction |
|
| 985 | - foreach ($registrations as $registration) { |
|
| 986 | - // verify EE_Registration object |
|
| 987 | - if (! $registration instanceof EE_Registration) { |
|
| 988 | - EE_Error::add_error( |
|
| 989 | - esc_html__( |
|
| 990 | - 'An invalid Registration object was discovered when attempting to process your registration information.', |
|
| 991 | - 'event_espresso' |
|
| 992 | - ), |
|
| 993 | - __FILE__, |
|
| 994 | - __FUNCTION__, |
|
| 995 | - __LINE__ |
|
| 996 | - ); |
|
| 997 | - return false; |
|
| 998 | - } |
|
| 999 | - /** @var string $reg_url_link */ |
|
| 1000 | - $reg_url_link = $registration->reg_url_link(); |
|
| 1001 | - // reg_url_link exists ? |
|
| 1002 | - if (! empty($reg_url_link)) { |
|
| 1003 | - // should this registration be processed during this visit ? |
|
| 1004 | - if ($this->checkout->visit_allows_processing_of_this_registration($registration)) { |
|
| 1005 | - // if NOT revisiting, then let's save the registration now, |
|
| 1006 | - // so that we have a REG_ID to use when generating other objects |
|
| 1007 | - if (! $this->checkout->revisit) { |
|
| 1008 | - $registration->save(); |
|
| 1009 | - } |
|
| 1010 | - /** |
|
| 1011 | - * This allows plugins to trigger a fail on processing of a |
|
| 1012 | - * registration for any conditions they may have for it to pass. |
|
| 1013 | - * |
|
| 1014 | - * @var bool if true is returned by the plugin then the |
|
| 1015 | - * registration processing is halted. |
|
| 1016 | - */ |
|
| 1017 | - if (apply_filters( |
|
| 1018 | - 'FHEE__EE_SPCO_Reg_Step_Attendee_Information___process_registrations__pre_registration_process', |
|
| 1019 | - false, |
|
| 1020 | - $att_nmbr, |
|
| 1021 | - $registration, |
|
| 1022 | - $registrations, |
|
| 1023 | - $valid_data, |
|
| 1024 | - $this |
|
| 1025 | - )) { |
|
| 1026 | - return false; |
|
| 1027 | - } |
|
| 1028 | - |
|
| 1029 | - // Houston, we have a registration! |
|
| 1030 | - $att_nmbr++; |
|
| 1031 | - $this->_attendee_data[ $reg_url_link ] = array(); |
|
| 1032 | - // grab any existing related answer objects |
|
| 1033 | - $this->_registration_answers = $registration->answers(); |
|
| 1034 | - // unset( $valid_data[ $reg_url_link ]['additional_attendee_reg_info'] ); |
|
| 1035 | - if (isset($valid_data[ $reg_url_link ])) { |
|
| 1036 | - // do we need to copy basic info from primary attendee ? |
|
| 1037 | - $copy_primary = isset($valid_data[ $reg_url_link ]['additional_attendee_reg_info']) |
|
| 1038 | - && absint($valid_data[ $reg_url_link ]['additional_attendee_reg_info']) === 0; |
|
| 1039 | - // filter form input data for this registration |
|
| 1040 | - $valid_data[ $reg_url_link ] = (array) apply_filters( |
|
| 1041 | - 'FHEE__EE_Single_Page_Checkout__process_attendee_information__valid_data_line_item', |
|
| 1042 | - $valid_data[ $reg_url_link ] |
|
| 1043 | - ); |
|
| 1044 | - if (isset($valid_data['primary_attendee'])) { |
|
| 1045 | - $primary_registrant['line_item_id'] = ! empty($valid_data['primary_attendee']) |
|
| 1046 | - ? $valid_data['primary_attendee'] |
|
| 1047 | - : false; |
|
| 1048 | - unset($valid_data['primary_attendee']); |
|
| 1049 | - } |
|
| 1050 | - // now loop through our array of valid post data && process attendee reg forms |
|
| 1051 | - foreach ($valid_data[ $reg_url_link ] as $form_section => $form_inputs) { |
|
| 1052 | - if (! in_array($form_section, $non_input_form_sections, true)) { |
|
| 1053 | - foreach ($form_inputs as $form_input => $input_value) { |
|
| 1054 | - // \EEH_Debug_Tools::printr( $input_value, $form_input, __FILE__, __LINE__ ); |
|
| 1055 | - // check for critical inputs |
|
| 1056 | - if (! $this->_verify_critical_attendee_details_are_set_and_validate_email( |
|
| 1057 | - $form_input, |
|
| 1058 | - $input_value |
|
| 1059 | - ) |
|
| 1060 | - ) { |
|
| 1061 | - return false; |
|
| 1062 | - } |
|
| 1063 | - // store a bit of data about the primary attendee |
|
| 1064 | - if ($att_nmbr === 1 |
|
| 1065 | - && ! empty($input_value) |
|
| 1066 | - && $reg_url_link === $primary_registrant['line_item_id'] |
|
| 1067 | - ) { |
|
| 1068 | - $primary_registrant[ $form_input ] = $input_value; |
|
| 1069 | - } elseif ($copy_primary |
|
| 1070 | - && $input_value === null |
|
| 1071 | - && isset($primary_registrant[ $form_input ]) |
|
| 1072 | - ) { |
|
| 1073 | - $input_value = $primary_registrant[ $form_input ]; |
|
| 1074 | - } |
|
| 1075 | - // now attempt to save the input data |
|
| 1076 | - if (! $this->_save_registration_form_input( |
|
| 1077 | - $registration, |
|
| 1078 | - $form_input, |
|
| 1079 | - $input_value |
|
| 1080 | - ) |
|
| 1081 | - ) { |
|
| 1082 | - EE_Error::add_error( |
|
| 1083 | - sprintf( |
|
| 1084 | - esc_html_x( |
|
| 1085 | - 'Unable to save registration form data for the form input: "%1$s" with the submitted value: "%2$s"', |
|
| 1086 | - 'Unable to save registration form data for the form input: "form input name" with the submitted value: "form input value"', |
|
| 1087 | - 'event_espresso' |
|
| 1088 | - ), |
|
| 1089 | - $form_input, |
|
| 1090 | - $input_value |
|
| 1091 | - ), |
|
| 1092 | - __FILE__, |
|
| 1093 | - __FUNCTION__, |
|
| 1094 | - __LINE__ |
|
| 1095 | - ); |
|
| 1096 | - return false; |
|
| 1097 | - } |
|
| 1098 | - } |
|
| 1099 | - } |
|
| 1100 | - } // end of foreach ( $valid_data[ $reg_url_link ] as $form_section => $form_inputs ) |
|
| 1101 | - } |
|
| 1102 | - // EEH_Debug_Tools::printr( $this->_attendee_data, '$this->_attendee_data', __FILE__, __LINE__ ); |
|
| 1103 | - // this registration does not require additional attendee information ? |
|
| 1104 | - if ($copy_primary |
|
| 1105 | - && $att_nmbr > 1 |
|
| 1106 | - && $this->checkout->primary_attendee_obj instanceof EE_Attendee |
|
| 1107 | - ) { |
|
| 1108 | - // just copy the primary registrant |
|
| 1109 | - $attendee = $this->checkout->primary_attendee_obj; |
|
| 1110 | - } else { |
|
| 1111 | - // ensure critical details are set for additional attendees |
|
| 1112 | - $this->_attendee_data[ $reg_url_link ] = $att_nmbr > 1 |
|
| 1113 | - ? $this->_copy_critical_attendee_details_from_primary_registrant( |
|
| 1114 | - $this->_attendee_data[ $reg_url_link ] |
|
| 1115 | - ) |
|
| 1116 | - : $this->_attendee_data[ $reg_url_link ]; |
|
| 1117 | - // execute create attendee command (which may return an existing attendee) |
|
| 1118 | - $attendee = EE_Registry::instance()->BUS->execute( |
|
| 1119 | - new CreateAttendeeCommand( |
|
| 1120 | - $this->_attendee_data[ $reg_url_link ], |
|
| 1121 | - $registration |
|
| 1122 | - ) |
|
| 1123 | - ); |
|
| 1124 | - // who's #1 ? |
|
| 1125 | - if ($att_nmbr === 1) { |
|
| 1126 | - $this->checkout->primary_attendee_obj = $attendee; |
|
| 1127 | - } |
|
| 1128 | - } |
|
| 1129 | - // EEH_Debug_Tools::printr( $attendee, '$attendee', __FILE__, __LINE__ ); |
|
| 1130 | - // add relation to registration, set attendee ID, and cache attendee |
|
| 1131 | - $this->_associate_attendee_with_registration($registration, $attendee); |
|
| 1132 | - // \EEH_Debug_Tools::printr( $registration, '$registration', __FILE__, __LINE__ ); |
|
| 1133 | - if (! $registration->attendee() instanceof EE_Attendee) { |
|
| 1134 | - EE_Error::add_error( |
|
| 1135 | - sprintf( |
|
| 1136 | - esc_html_x( |
|
| 1137 | - 'Registration %s has an invalid or missing Attendee object.', |
|
| 1138 | - 'Registration 123-456-789 has an invalid or missing Attendee object.', |
|
| 1139 | - 'event_espresso' |
|
| 1140 | - ), |
|
| 1141 | - $reg_url_link |
|
| 1142 | - ), |
|
| 1143 | - __FILE__, |
|
| 1144 | - __FUNCTION__, |
|
| 1145 | - __LINE__ |
|
| 1146 | - ); |
|
| 1147 | - return false; |
|
| 1148 | - } |
|
| 1149 | - /** @type EE_Registration_Processor $registration_processor */ |
|
| 1150 | - $registration_processor = EE_Registry::instance()->load_class('Registration_Processor'); |
|
| 1151 | - // at this point, we should have enough details about the registrant to consider the registration |
|
| 1152 | - // NOT incomplete |
|
| 1153 | - $registration_processor->toggle_incomplete_registration_status_to_default( |
|
| 1154 | - $registration, |
|
| 1155 | - false, |
|
| 1156 | - new Context( |
|
| 1157 | - 'spco_reg_step_attendee_information_process_registrations', |
|
| 1158 | - esc_html__( |
|
| 1159 | - 'Finished populating registration with details from the registration form after submitting the Attendee Information Reg Step.', |
|
| 1160 | - 'event_espresso' |
|
| 1161 | - ) |
|
| 1162 | - ) |
|
| 1163 | - ); |
|
| 1164 | - // we can also consider the TXN to not have been failed, so temporarily upgrade it's status to |
|
| 1165 | - // abandoned |
|
| 1166 | - $this->checkout->transaction->toggle_failed_transaction_status(); |
|
| 1167 | - // if we've gotten this far, then let's save what we have |
|
| 1168 | - $registration->save(); |
|
| 1169 | - // add relation between TXN and registration |
|
| 1170 | - $this->_associate_registration_with_transaction($registration); |
|
| 1171 | - } |
|
| 1172 | - } else { |
|
| 1173 | - EE_Error::add_error( |
|
| 1174 | - esc_html__( |
|
| 1175 | - 'An invalid or missing line item ID was encountered while attempting to process the registration form.', |
|
| 1176 | - 'event_espresso' |
|
| 1177 | - ), |
|
| 1178 | - __FILE__, |
|
| 1179 | - __FUNCTION__, |
|
| 1180 | - __LINE__ |
|
| 1181 | - ); |
|
| 1182 | - // remove malformed data |
|
| 1183 | - unset($valid_data[ $reg_url_link ]); |
|
| 1184 | - return false; |
|
| 1185 | - } |
|
| 1186 | - } // end of foreach ( $this->checkout->transaction->registrations() as $registration ) |
|
| 1187 | - return $att_nmbr; |
|
| 1188 | - } |
|
| 1189 | - |
|
| 1190 | - |
|
| 1191 | - /** |
|
| 1192 | - * _save_registration_form_input |
|
| 1193 | - * |
|
| 1194 | - * @param EE_Registration $registration |
|
| 1195 | - * @param string $form_input |
|
| 1196 | - * @param string $input_value |
|
| 1197 | - * @return bool |
|
| 1198 | - * @throws EE_Error |
|
| 1199 | - * @throws InvalidArgumentException |
|
| 1200 | - * @throws InvalidDataTypeException |
|
| 1201 | - * @throws InvalidInterfaceException |
|
| 1202 | - * @throws ReflectionException |
|
| 1203 | - */ |
|
| 1204 | - private function _save_registration_form_input( |
|
| 1205 | - EE_Registration $registration, |
|
| 1206 | - $form_input = '', |
|
| 1207 | - $input_value = '' |
|
| 1208 | - ) { |
|
| 1209 | - // \EEH_Debug_Tools::printr( __FUNCTION__, __CLASS__, __FILE__, __LINE__, 2 ); |
|
| 1210 | - // \EEH_Debug_Tools::printr( $form_input, '$form_input', __FILE__, __LINE__ ); |
|
| 1211 | - // \EEH_Debug_Tools::printr( $input_value, '$input_value', __FILE__, __LINE__ ); |
|
| 1212 | - // allow for plugins to hook in and do their own processing of the form input. |
|
| 1213 | - // For plugins to bypass normal processing here, they just need to return a boolean value. |
|
| 1214 | - if (apply_filters( |
|
| 1215 | - 'FHEE__EE_SPCO_Reg_Step_Attendee_Information___save_registration_form_input', |
|
| 1216 | - false, |
|
| 1217 | - $registration, |
|
| 1218 | - $form_input, |
|
| 1219 | - $input_value, |
|
| 1220 | - $this |
|
| 1221 | - )) { |
|
| 1222 | - return true; |
|
| 1223 | - } |
|
| 1224 | - /* |
|
| 129 | + $this->_print_copy_info = $reg_config->copyAttendeeInfo(); |
|
| 130 | + $primary_registrant = null; |
|
| 131 | + // autoload Line_Item_Display classes |
|
| 132 | + EEH_Autoloader::register_line_item_display_autoloaders(); |
|
| 133 | + $Line_Item_Display = new EE_Line_Item_Display(); |
|
| 134 | + // calculate taxes |
|
| 135 | + $Line_Item_Display->display_line_item( |
|
| 136 | + $this->checkout->cart->get_grand_total(), |
|
| 137 | + array('set_tax_rate' => true) |
|
| 138 | + ); |
|
| 139 | + /** @var $subsections EE_Form_Section_Proper[] */ |
|
| 140 | + $extra_inputs_section = $this->reg_step_hidden_inputs(); |
|
| 141 | + $subsections = array( |
|
| 142 | + 'default_hidden_inputs' => $extra_inputs_section, |
|
| 143 | + ); |
|
| 144 | + |
|
| 145 | + // if this isn't a revisit, and they have the privacy consent box enalbed, add it |
|
| 146 | + if (! $this->checkout->revisit && $reg_config->isConsentCheckboxEnabled()) { |
|
| 147 | + $extra_inputs_section->add_subsections( |
|
| 148 | + array( |
|
| 149 | + 'consent_box' => new EE_Form_Section_Proper( |
|
| 150 | + array( |
|
| 151 | + 'layout_strategy' => |
|
| 152 | + new EE_Template_Layout( |
|
| 153 | + array( |
|
| 154 | + 'input_template_file' => SPCO_REG_STEPS_PATH . $this->_slug . '/privacy_consent.template.php', |
|
| 155 | + ) |
|
| 156 | + ), |
|
| 157 | + 'subsections' => array( |
|
| 158 | + 'consent' => new EE_Checkbox_Multi_Input( |
|
| 159 | + array( |
|
| 160 | + 'consent' => $reg_config->getConsentCheckboxLabelText(), |
|
| 161 | + ), |
|
| 162 | + array( |
|
| 163 | + 'required' => true, |
|
| 164 | + 'required_validation_error_message' => esc_html__( |
|
| 165 | + 'You must consent to these terms in order to register.', |
|
| 166 | + 'event_espresso' |
|
| 167 | + ), |
|
| 168 | + 'html_label_text' => '', |
|
| 169 | + ) |
|
| 170 | + ), |
|
| 171 | + ), |
|
| 172 | + ) |
|
| 173 | + ), |
|
| 174 | + ), |
|
| 175 | + null, |
|
| 176 | + false |
|
| 177 | + ); |
|
| 178 | + } |
|
| 179 | + $template_args = array( |
|
| 180 | + 'revisit' => $this->checkout->revisit, |
|
| 181 | + 'registrations' => array(), |
|
| 182 | + 'ticket_count' => array(), |
|
| 183 | + ); |
|
| 184 | + // grab the saved registrations from the transaction |
|
| 185 | + $registrations = $this->checkout->transaction->registrations($this->checkout->reg_cache_where_params); |
|
| 186 | + if ($registrations) { |
|
| 187 | + foreach ($registrations as $registration) { |
|
| 188 | + // can this registration be processed during this visit ? |
|
| 189 | + if ($registration instanceof EE_Registration |
|
| 190 | + && $this->checkout->visit_allows_processing_of_this_registration($registration) |
|
| 191 | + ) { |
|
| 192 | + $subsections[ $registration->reg_url_link() ] = $this->_registrations_reg_form($registration); |
|
| 193 | + if (! $this->checkout->admin_request) { |
|
| 194 | + $template_args['registrations'][ $registration->reg_url_link() ] = $registration; |
|
| 195 | + $template_args['ticket_count'][ $registration->ticket()->ID() ] = isset( |
|
| 196 | + $template_args['ticket_count'][ $registration->ticket()->ID() ] |
|
| 197 | + ) |
|
| 198 | + ? $template_args['ticket_count'][ $registration->ticket()->ID() ] + 1 |
|
| 199 | + : 1; |
|
| 200 | + $ticket_line_item = EEH_Line_Item::get_line_items_by_object_type_and_IDs( |
|
| 201 | + $this->checkout->cart->get_grand_total(), |
|
| 202 | + 'Ticket', |
|
| 203 | + array($registration->ticket()->ID()) |
|
| 204 | + ); |
|
| 205 | + $ticket_line_item = is_array($ticket_line_item) |
|
| 206 | + ? reset($ticket_line_item) |
|
| 207 | + : $ticket_line_item; |
|
| 208 | + $template_args['ticket_line_item'][ $registration->ticket()->ID() ] = |
|
| 209 | + $Line_Item_Display->display_line_item($ticket_line_item); |
|
| 210 | + } |
|
| 211 | + if ($registration->is_primary_registrant()) { |
|
| 212 | + $primary_registrant = $registration->reg_url_link(); |
|
| 213 | + } |
|
| 214 | + } |
|
| 215 | + } |
|
| 216 | + if ($primary_registrant && ! $this->checkout->admin_request && count($registrations) > 1) { |
|
| 217 | + $copy_options['spco_copy_attendee_chk'] = $this->_print_copy_info |
|
| 218 | + ? $this->_copy_attendee_info_form() |
|
| 219 | + : $this->_auto_copy_attendee_info(); |
|
| 220 | + // generate hidden input |
|
| 221 | + if (isset($subsections[ $primary_registrant ]) |
|
| 222 | + && $subsections[ $primary_registrant ] instanceof EE_Form_Section_Proper |
|
| 223 | + ) { |
|
| 224 | + $subsections[ $primary_registrant ]->add_subsections( |
|
| 225 | + $copy_options, |
|
| 226 | + 'primary_registrant', |
|
| 227 | + false |
|
| 228 | + ); |
|
| 229 | + } |
|
| 230 | + } |
|
| 231 | + } |
|
| 232 | + return new EE_Form_Section_Proper( |
|
| 233 | + array( |
|
| 234 | + 'name' => $this->reg_form_name(), |
|
| 235 | + 'html_id' => $this->reg_form_name(), |
|
| 236 | + 'subsections' => $subsections, |
|
| 237 | + 'layout_strategy' => $this->checkout->admin_request |
|
| 238 | + ? |
|
| 239 | + new EE_Div_Per_Section_Layout() |
|
| 240 | + : |
|
| 241 | + new EE_Template_Layout( |
|
| 242 | + array( |
|
| 243 | + 'layout_template_file' => $this->_template, // layout_template |
|
| 244 | + 'template_args' => $template_args, |
|
| 245 | + ) |
|
| 246 | + ), |
|
| 247 | + ) |
|
| 248 | + ); |
|
| 249 | + } |
|
| 250 | + |
|
| 251 | + |
|
| 252 | + /** |
|
| 253 | + * @param EE_Registration $registration |
|
| 254 | + * @return EE_Form_Section_Base |
|
| 255 | + * @throws EE_Error |
|
| 256 | + * @throws InvalidArgumentException |
|
| 257 | + * @throws EntityNotFoundException |
|
| 258 | + * @throws InvalidDataTypeException |
|
| 259 | + * @throws InvalidInterfaceException |
|
| 260 | + * @throws ReflectionException |
|
| 261 | + */ |
|
| 262 | + private function _registrations_reg_form(EE_Registration $registration) |
|
| 263 | + { |
|
| 264 | + static $attendee_nmbr = 1; |
|
| 265 | + $form_args = array(); |
|
| 266 | + // verify that registration has valid event |
|
| 267 | + if ($registration->event() instanceof EE_Event) { |
|
| 268 | + $field_name = 'Event_Question_Group.' |
|
| 269 | + . EEM_Event_Question_Group::instance()->fieldNameForContext( |
|
| 270 | + $registration->is_primary_registrant() |
|
| 271 | + ); |
|
| 272 | + $question_groups = $registration->event()->question_groups( |
|
| 273 | + apply_filters( |
|
| 274 | + // @codingStandardsIgnoreStart |
|
| 275 | + 'FHEE__EE_SPCO_Reg_Step_Attendee_Information___registrations_reg_form__question_groups_query_parameters', |
|
| 276 | + // @codingStandardsIgnoreEnd |
|
| 277 | + [ |
|
| 278 | + [ |
|
| 279 | + 'Event.EVT_ID' => $registration->event()->ID(), |
|
| 280 | + $field_name => true, |
|
| 281 | + ], |
|
| 282 | + 'order_by' => ['QSG_order' => 'ASC'], |
|
| 283 | + ], |
|
| 284 | + $registration, |
|
| 285 | + $this |
|
| 286 | + ) |
|
| 287 | + ); |
|
| 288 | + if ($question_groups) { |
|
| 289 | + // array of params to pass to parent constructor |
|
| 290 | + $form_args = array( |
|
| 291 | + 'html_id' => 'ee-registration-' . $registration->reg_url_link(), |
|
| 292 | + 'html_class' => 'ee-reg-form-attendee-dv', |
|
| 293 | + 'html_style' => $this->checkout->admin_request |
|
| 294 | + ? 'padding:0em 2em 1em; margin:3em 0 0; border:1px solid #ddd;' |
|
| 295 | + : '', |
|
| 296 | + 'subsections' => array(), |
|
| 297 | + 'layout_strategy' => new EE_Fieldset_Section_Layout( |
|
| 298 | + array( |
|
| 299 | + 'legend_class' => 'spco-attendee-lgnd smaller-text lt-grey-text', |
|
| 300 | + 'legend_text' => sprintf( |
|
| 301 | + esc_html_x( |
|
| 302 | + 'Attendee %d', |
|
| 303 | + 'Attendee 123', |
|
| 304 | + 'event_espresso' |
|
| 305 | + ), |
|
| 306 | + $attendee_nmbr |
|
| 307 | + ), |
|
| 308 | + ) |
|
| 309 | + ), |
|
| 310 | + ); |
|
| 311 | + foreach ($question_groups as $question_group) { |
|
| 312 | + if ($question_group instanceof EE_Question_Group) { |
|
| 313 | + $form_args['subsections'][ $question_group->identifier() ] = $this->_question_group_reg_form( |
|
| 314 | + $registration, |
|
| 315 | + $question_group |
|
| 316 | + ); |
|
| 317 | + } |
|
| 318 | + } |
|
| 319 | + // add hidden input |
|
| 320 | + $form_args['subsections']['additional_attendee_reg_info'] = $this->_additional_attendee_reg_info_input( |
|
| 321 | + $registration |
|
| 322 | + ); |
|
| 323 | + |
|
| 324 | + /** |
|
| 325 | + * @var $reg_config EE_Registration_Config |
|
| 326 | + */ |
|
| 327 | + $reg_config = LoaderFactory::getLoader()->getShared('EE_Registration_Config'); |
|
| 328 | + |
|
| 329 | + // if we have question groups for additional attendees, then display the copy options |
|
| 330 | + $this->_print_copy_info = $attendee_nmbr > 1 ? $reg_config->copyAttendeeInfo() : false; |
|
| 331 | + if ($registration->is_primary_registrant()) { |
|
| 332 | + // generate hidden input |
|
| 333 | + $form_args['subsections']['primary_registrant'] = $this->_additional_primary_registrant_inputs( |
|
| 334 | + $registration |
|
| 335 | + ); |
|
| 336 | + } |
|
| 337 | + } |
|
| 338 | + } |
|
| 339 | + $attendee_nmbr++; |
|
| 340 | + return ! empty($form_args) |
|
| 341 | + ? new EE_Form_Section_Proper($form_args) |
|
| 342 | + : new EE_Form_Section_HTML(); |
|
| 343 | + } |
|
| 344 | + |
|
| 345 | + |
|
| 346 | + /** |
|
| 347 | + * @param EE_Registration $registration |
|
| 348 | + * @param bool $additional_attendee_reg_info |
|
| 349 | + * @return EE_Form_Input_Base |
|
| 350 | + * @throws EE_Error |
|
| 351 | + */ |
|
| 352 | + private function _additional_attendee_reg_info_input( |
|
| 353 | + EE_Registration $registration, |
|
| 354 | + $additional_attendee_reg_info = true |
|
| 355 | + ) { |
|
| 356 | + // generate hidden input |
|
| 357 | + return new EE_Hidden_Input( |
|
| 358 | + array( |
|
| 359 | + 'html_id' => 'additional-attendee-reg-info-' . $registration->reg_url_link(), |
|
| 360 | + 'default' => $additional_attendee_reg_info, |
|
| 361 | + ) |
|
| 362 | + ); |
|
| 363 | + } |
|
| 364 | + |
|
| 365 | + |
|
| 366 | + /** |
|
| 367 | + * @param EE_Registration $registration |
|
| 368 | + * @param EE_Question_Group $question_group |
|
| 369 | + * @return EE_Form_Section_Proper |
|
| 370 | + * @throws EE_Error |
|
| 371 | + * @throws InvalidArgumentException |
|
| 372 | + * @throws InvalidDataTypeException |
|
| 373 | + * @throws InvalidInterfaceException |
|
| 374 | + * @throws ReflectionException |
|
| 375 | + */ |
|
| 376 | + private function _question_group_reg_form(EE_Registration $registration, EE_Question_Group $question_group) |
|
| 377 | + { |
|
| 378 | + // array of params to pass to parent constructor |
|
| 379 | + $form_args = array( |
|
| 380 | + 'html_id' => 'ee-reg-form-qstn-grp-' . $question_group->identifier() . '-' . $registration->ID(), |
|
| 381 | + 'html_class' => $this->checkout->admin_request |
|
| 382 | + ? 'form-table ee-reg-form-qstn-grp-dv' |
|
| 383 | + : 'ee-reg-form-qstn-grp-dv', |
|
| 384 | + 'html_label_id' => 'ee-reg-form-qstn-grp-' . $question_group->identifier() . '-' |
|
| 385 | + . $registration->ID() . '-lbl', |
|
| 386 | + 'subsections' => array( |
|
| 387 | + 'reg_form_qstn_grp_hdr' => $this->_question_group_header($question_group), |
|
| 388 | + ), |
|
| 389 | + 'layout_strategy' => $this->checkout->admin_request |
|
| 390 | + ? new EE_Admin_Two_Column_Layout() |
|
| 391 | + : new EE_Div_Per_Section_Layout(), |
|
| 392 | + ); |
|
| 393 | + // where params |
|
| 394 | + $query_params = array('QST_deleted' => 0); |
|
| 395 | + // don't load admin only questions on the frontend |
|
| 396 | + if (! $this->checkout->admin_request) { |
|
| 397 | + $query_params['QST_admin_only'] = array('!=', true); |
|
| 398 | + } |
|
| 399 | + $questions = $question_group->get_many_related( |
|
| 400 | + 'Question', |
|
| 401 | + apply_filters( |
|
| 402 | + 'FHEE__EE_SPCO_Reg_Step_Attendee_Information___question_group_reg_form__related_questions_query_params', |
|
| 403 | + array( |
|
| 404 | + $query_params, |
|
| 405 | + 'order_by' => array( |
|
| 406 | + 'Question_Group_Question.QGQ_order' => 'ASC', |
|
| 407 | + ), |
|
| 408 | + ), |
|
| 409 | + $question_group, |
|
| 410 | + $registration, |
|
| 411 | + $this |
|
| 412 | + ) |
|
| 413 | + ); |
|
| 414 | + // filter for additional content before questions |
|
| 415 | + $form_args['subsections']['reg_form_questions_before'] = new EE_Form_Section_HTML( |
|
| 416 | + apply_filters( |
|
| 417 | + 'FHEE__EEH_Form_Fields__generate_question_groups_html__before_question_group_questions', |
|
| 418 | + '', |
|
| 419 | + $registration, |
|
| 420 | + $question_group, |
|
| 421 | + $this |
|
| 422 | + ) |
|
| 423 | + ); |
|
| 424 | + // loop thru questions |
|
| 425 | + foreach ($questions as $question) { |
|
| 426 | + if ($question instanceof EE_Question) { |
|
| 427 | + $identifier = $question->is_system_question() |
|
| 428 | + ? $question->system_ID() |
|
| 429 | + : $question->ID(); |
|
| 430 | + $form_args['subsections'][ $identifier ] = $this->reg_form_question($registration, $question); |
|
| 431 | + } |
|
| 432 | + } |
|
| 433 | + $form_args['subsections'] = apply_filters( |
|
| 434 | + 'FHEE__EE_SPCO_Reg_Step_Attendee_Information__question_group_reg_form__subsections_array', |
|
| 435 | + $form_args['subsections'], |
|
| 436 | + $registration, |
|
| 437 | + $question_group, |
|
| 438 | + $this |
|
| 439 | + ); |
|
| 440 | + // filter for additional content after questions |
|
| 441 | + $form_args['subsections']['reg_form_questions_after'] = new EE_Form_Section_HTML( |
|
| 442 | + apply_filters( |
|
| 443 | + 'FHEE__EEH_Form_Fields__generate_question_groups_html__after_question_group_questions', |
|
| 444 | + '', |
|
| 445 | + $registration, |
|
| 446 | + $question_group, |
|
| 447 | + $this |
|
| 448 | + ) |
|
| 449 | + ); |
|
| 450 | + // d($form_args); |
|
| 451 | + $question_group_reg_form = new EE_Form_Section_Proper($form_args); |
|
| 452 | + return apply_filters( |
|
| 453 | + 'FHEE__EE_SPCO_Reg_Step_Attendee_Information___question_group_reg_form__question_group_reg_form', |
|
| 454 | + $question_group_reg_form, |
|
| 455 | + $registration, |
|
| 456 | + $question_group, |
|
| 457 | + $this |
|
| 458 | + ); |
|
| 459 | + } |
|
| 460 | + |
|
| 461 | + |
|
| 462 | + /** |
|
| 463 | + * @param EE_Question_Group $question_group |
|
| 464 | + * @return EE_Form_Section_HTML |
|
| 465 | + */ |
|
| 466 | + private function _question_group_header(EE_Question_Group $question_group) |
|
| 467 | + { |
|
| 468 | + $html = ''; |
|
| 469 | + // group_name |
|
| 470 | + if ($question_group->show_group_name() && $question_group->name() !== '') { |
|
| 471 | + if ($this->checkout->admin_request) { |
|
| 472 | + $html .= EEH_HTML::br(); |
|
| 473 | + $html .= EEH_HTML::h3( |
|
| 474 | + $question_group->name(), |
|
| 475 | + '', |
|
| 476 | + 'ee-reg-form-qstn-grp-title title', |
|
| 477 | + 'font-size: 1.3em; padding-left:0;' |
|
| 478 | + ); |
|
| 479 | + } else { |
|
| 480 | + $html .= EEH_HTML::h4( |
|
| 481 | + $question_group->name(), |
|
| 482 | + '', |
|
| 483 | + 'ee-reg-form-qstn-grp-title section-title' |
|
| 484 | + ); |
|
| 485 | + } |
|
| 486 | + } |
|
| 487 | + // group_desc |
|
| 488 | + if ($question_group->show_group_desc() && $question_group->desc() !== '') { |
|
| 489 | + $html .= EEH_HTML::p( |
|
| 490 | + $question_group->desc(), |
|
| 491 | + '', |
|
| 492 | + $this->checkout->admin_request |
|
| 493 | + ? 'ee-reg-form-qstn-grp-desc-pg' |
|
| 494 | + : 'ee-reg-form-qstn-grp-desc-pg small-text lt-grey-text' |
|
| 495 | + ); |
|
| 496 | + } |
|
| 497 | + return new EE_Form_Section_HTML($html); |
|
| 498 | + } |
|
| 499 | + |
|
| 500 | + |
|
| 501 | + /** |
|
| 502 | + * @return EE_Form_Section_Proper |
|
| 503 | + * @throws EE_Error |
|
| 504 | + * @throws InvalidArgumentException |
|
| 505 | + * @throws ReflectionException |
|
| 506 | + * @throws InvalidDataTypeException |
|
| 507 | + * @throws InvalidInterfaceException |
|
| 508 | + */ |
|
| 509 | + private function _copy_attendee_info_form() |
|
| 510 | + { |
|
| 511 | + // array of params to pass to parent constructor |
|
| 512 | + return new EE_Form_Section_Proper( |
|
| 513 | + array( |
|
| 514 | + 'subsections' => $this->_copy_attendee_info_inputs(), |
|
| 515 | + 'layout_strategy' => new EE_Template_Layout( |
|
| 516 | + array( |
|
| 517 | + 'layout_template_file' => SPCO_REG_STEPS_PATH |
|
| 518 | + . $this->_slug |
|
| 519 | + . '/copy_attendee_info.template.php', |
|
| 520 | + 'begin_template_file' => null, |
|
| 521 | + 'input_template_file' => null, |
|
| 522 | + 'subsection_template_file' => null, |
|
| 523 | + 'end_template_file' => null, |
|
| 524 | + ) |
|
| 525 | + ), |
|
| 526 | + ) |
|
| 527 | + ); |
|
| 528 | + } |
|
| 529 | + |
|
| 530 | + |
|
| 531 | + /** |
|
| 532 | + * @return EE_Form_Section_HTML |
|
| 533 | + * @throws DomainException |
|
| 534 | + * @throws InvalidArgumentException |
|
| 535 | + * @throws InvalidDataTypeException |
|
| 536 | + * @throws InvalidInterfaceException |
|
| 537 | + */ |
|
| 538 | + private function _auto_copy_attendee_info() |
|
| 539 | + { |
|
| 540 | + return new EE_Form_Section_HTML( |
|
| 541 | + EEH_Template::locate_template( |
|
| 542 | + SPCO_REG_STEPS_PATH . $this->_slug . '/_auto_copy_attendee_info.template.php', |
|
| 543 | + apply_filters( |
|
| 544 | + 'FHEE__EE_SPCO_Reg_Step_Attendee_Information__auto_copy_attendee_info__template_args', |
|
| 545 | + array() |
|
| 546 | + ), |
|
| 547 | + true, |
|
| 548 | + true |
|
| 549 | + ) |
|
| 550 | + ); |
|
| 551 | + } |
|
| 552 | + |
|
| 553 | + |
|
| 554 | + /** |
|
| 555 | + * @return array |
|
| 556 | + * @throws EE_Error |
|
| 557 | + * @throws InvalidArgumentException |
|
| 558 | + * @throws ReflectionException |
|
| 559 | + * @throws InvalidDataTypeException |
|
| 560 | + * @throws InvalidInterfaceException |
|
| 561 | + */ |
|
| 562 | + private function _copy_attendee_info_inputs() |
|
| 563 | + { |
|
| 564 | + $copy_attendee_info_inputs = array(); |
|
| 565 | + $prev_ticket = null; |
|
| 566 | + // grab the saved registrations from the transaction |
|
| 567 | + $registrations = $this->checkout->transaction->registrations($this->checkout->reg_cache_where_params); |
|
| 568 | + foreach ($registrations as $registration) { |
|
| 569 | + // for all attendees other than the primary attendee |
|
| 570 | + if ($registration instanceof EE_Registration && ! $registration->is_primary_registrant()) { |
|
| 571 | + // if this is a new ticket OR if this is the very first additional attendee after the primary attendee |
|
| 572 | + if ($registration->ticket()->ID() !== $prev_ticket) { |
|
| 573 | + $item_name = $registration->ticket()->name(); |
|
| 574 | + $item_name .= $registration->ticket()->description() !== '' |
|
| 575 | + ? ' - ' . $registration->ticket()->description() |
|
| 576 | + : ''; |
|
| 577 | + $copy_attendee_info_inputs[ 'spco_copy_attendee_chk[ticket-' . $registration->ticket()->ID( |
|
| 578 | + ) . ']' ] = |
|
| 579 | + new EE_Form_Section_HTML( |
|
| 580 | + '<h6 class="spco-copy-attendee-event-hdr">' . $item_name . '</h6>' |
|
| 581 | + ); |
|
| 582 | + $prev_ticket = $registration->ticket()->ID(); |
|
| 583 | + } |
|
| 584 | + |
|
| 585 | + $copy_attendee_info_inputs[ 'spco_copy_attendee_chk[' . $registration->ID() . ']' ] = |
|
| 586 | + new EE_Checkbox_Multi_Input( |
|
| 587 | + array( |
|
| 588 | + $registration->ID() => sprintf( |
|
| 589 | + esc_html_x('Attendee #%s', 'Attendee #123', 'event_espresso'), |
|
| 590 | + $registration->count() |
|
| 591 | + ), |
|
| 592 | + ), |
|
| 593 | + array( |
|
| 594 | + 'html_id' => 'spco-copy-attendee-chk-' . $registration->reg_url_link(), |
|
| 595 | + 'html_class' => 'spco-copy-attendee-chk ee-do-not-validate', |
|
| 596 | + 'display_html_label_text' => false, |
|
| 597 | + ) |
|
| 598 | + ); |
|
| 599 | + } |
|
| 600 | + } |
|
| 601 | + return $copy_attendee_info_inputs; |
|
| 602 | + } |
|
| 603 | + |
|
| 604 | + |
|
| 605 | + /** |
|
| 606 | + * @param EE_Registration $registration |
|
| 607 | + * @return EE_Form_Input_Base |
|
| 608 | + * @throws EE_Error |
|
| 609 | + */ |
|
| 610 | + private function _additional_primary_registrant_inputs(EE_Registration $registration) |
|
| 611 | + { |
|
| 612 | + // generate hidden input |
|
| 613 | + return new EE_Hidden_Input( |
|
| 614 | + array( |
|
| 615 | + 'html_id' => 'primary_registrant', |
|
| 616 | + 'default' => $registration->reg_url_link(), |
|
| 617 | + ) |
|
| 618 | + ); |
|
| 619 | + } |
|
| 620 | + |
|
| 621 | + |
|
| 622 | + /** |
|
| 623 | + * @param EE_Registration $registration |
|
| 624 | + * @param EE_Question $question |
|
| 625 | + * @return EE_Form_Input_Base |
|
| 626 | + * @throws EE_Error |
|
| 627 | + * @throws InvalidArgumentException |
|
| 628 | + * @throws InvalidDataTypeException |
|
| 629 | + * @throws InvalidInterfaceException |
|
| 630 | + * @throws ReflectionException |
|
| 631 | + */ |
|
| 632 | + public function reg_form_question(EE_Registration $registration, EE_Question $question) |
|
| 633 | + { |
|
| 634 | + |
|
| 635 | + // if this question was for an attendee detail, then check for that answer |
|
| 636 | + $answer_value = EEM_Answer::instance()->get_attendee_property_answer_value( |
|
| 637 | + $registration, |
|
| 638 | + $question->system_ID() |
|
| 639 | + ); |
|
| 640 | + $answer = $answer_value === null |
|
| 641 | + ? EEM_Answer::instance()->get_one( |
|
| 642 | + array(array('QST_ID' => $question->ID(), 'REG_ID' => $registration->ID())) |
|
| 643 | + ) |
|
| 644 | + : null; |
|
| 645 | + // if NOT returning to edit an existing registration |
|
| 646 | + // OR if this question is for an attendee property |
|
| 647 | + // OR we still don't have an EE_Answer object |
|
| 648 | + if ($answer_value || ! $answer instanceof EE_Answer || ! $registration->reg_url_link()) { |
|
| 649 | + // create an EE_Answer object for storing everything in |
|
| 650 | + $answer = EE_Answer::new_instance( |
|
| 651 | + array( |
|
| 652 | + 'QST_ID' => $question->ID(), |
|
| 653 | + 'REG_ID' => $registration->ID(), |
|
| 654 | + ) |
|
| 655 | + ); |
|
| 656 | + } |
|
| 657 | + // verify instance |
|
| 658 | + if ($answer instanceof EE_Answer) { |
|
| 659 | + if (! empty($answer_value)) { |
|
| 660 | + $answer->set('ANS_value', $answer_value); |
|
| 661 | + } |
|
| 662 | + $answer->cache('Question', $question); |
|
| 663 | + // remember system ID had a bug where sometimes it could be null |
|
| 664 | + $answer_cache_id = $question->is_system_question() |
|
| 665 | + ? $question->system_ID() . '-' . $registration->reg_url_link() |
|
| 666 | + : $question->ID() . '-' . $registration->reg_url_link(); |
|
| 667 | + $registration->cache('Answer', $answer, $answer_cache_id); |
|
| 668 | + } |
|
| 669 | + return $this->_generate_question_input($registration, $question, $answer); |
|
| 670 | + } |
|
| 671 | + |
|
| 672 | + |
|
| 673 | + /** |
|
| 674 | + * @param EE_Registration $registration |
|
| 675 | + * @param EE_Question $question |
|
| 676 | + * @param $answer |
|
| 677 | + * @return EE_Form_Input_Base |
|
| 678 | + * @throws EE_Error |
|
| 679 | + * @throws InvalidArgumentException |
|
| 680 | + * @throws ReflectionException |
|
| 681 | + * @throws InvalidDataTypeException |
|
| 682 | + * @throws InvalidInterfaceException |
|
| 683 | + */ |
|
| 684 | + private function _generate_question_input(EE_Registration $registration, EE_Question $question, $answer) |
|
| 685 | + { |
|
| 686 | + $identifier = $question->is_system_question() |
|
| 687 | + ? $question->system_ID() |
|
| 688 | + : $question->ID(); |
|
| 689 | + $this->_required_questions[ $identifier ] = $question->required() ? true : false; |
|
| 690 | + add_filter( |
|
| 691 | + 'FHEE__EE_Question__generate_form_input__country_options', |
|
| 692 | + array($this, 'use_cached_countries_for_form_input'), |
|
| 693 | + 10, |
|
| 694 | + 4 |
|
| 695 | + ); |
|
| 696 | + add_filter( |
|
| 697 | + 'FHEE__EE_Question__generate_form_input__state_options', |
|
| 698 | + array($this, 'use_cached_states_for_form_input'), |
|
| 699 | + 10, |
|
| 700 | + 4 |
|
| 701 | + ); |
|
| 702 | + $input_constructor_args = array( |
|
| 703 | + 'html_name' => 'ee_reg_qstn[' . $registration->ID() . '][' . $identifier . ']', |
|
| 704 | + 'html_id' => 'ee_reg_qstn-' . $registration->ID() . '-' . $identifier, |
|
| 705 | + 'html_class' => 'ee-reg-qstn ee-reg-qstn-' . $identifier, |
|
| 706 | + 'html_label_id' => 'ee_reg_qstn-' . $registration->ID() . '-' . $identifier, |
|
| 707 | + 'html_label_class' => 'ee-reg-qstn', |
|
| 708 | + ); |
|
| 709 | + $input_constructor_args['html_label_id'] .= '-lbl'; |
|
| 710 | + if ($answer instanceof EE_Answer && $answer->ID()) { |
|
| 711 | + $input_constructor_args['html_name'] .= '[' . $answer->ID() . ']'; |
|
| 712 | + $input_constructor_args['html_id'] .= '-' . $answer->ID(); |
|
| 713 | + $input_constructor_args['html_label_id'] .= '-' . $answer->ID(); |
|
| 714 | + } |
|
| 715 | + $form_input = $question->generate_form_input( |
|
| 716 | + $registration, |
|
| 717 | + $answer, |
|
| 718 | + $input_constructor_args |
|
| 719 | + ); |
|
| 720 | + remove_filter( |
|
| 721 | + 'FHEE__EE_Question__generate_form_input__country_options', |
|
| 722 | + array($this, 'use_cached_countries_for_form_input') |
|
| 723 | + ); |
|
| 724 | + remove_filter( |
|
| 725 | + 'FHEE__EE_Question__generate_form_input__state_options', |
|
| 726 | + array($this, 'use_cached_states_for_form_input') |
|
| 727 | + ); |
|
| 728 | + return $form_input; |
|
| 729 | + } |
|
| 730 | + |
|
| 731 | + |
|
| 732 | + /** |
|
| 733 | + * Gets the list of countries for the form input |
|
| 734 | + * |
|
| 735 | + * @param array|null $countries_list |
|
| 736 | + * @param EE_Question $question |
|
| 737 | + * @param EE_Registration $registration |
|
| 738 | + * @param EE_Answer $answer |
|
| 739 | + * @return array 2d keys are country IDs, values are their names |
|
| 740 | + * @throws EE_Error |
|
| 741 | + * @throws InvalidArgumentException |
|
| 742 | + * @throws InvalidDataTypeException |
|
| 743 | + * @throws InvalidInterfaceException |
|
| 744 | + * @throws ReflectionException |
|
| 745 | + */ |
|
| 746 | + public function use_cached_countries_for_form_input( |
|
| 747 | + $countries_list, |
|
| 748 | + EE_Question $question = null, |
|
| 749 | + EE_Registration $registration = null, |
|
| 750 | + EE_Answer $answer = null |
|
| 751 | + ) { |
|
| 752 | + $country_options = array('' => ''); |
|
| 753 | + // get possibly cached list of countries |
|
| 754 | + $countries = $this->checkout->action === 'process_reg_step' |
|
| 755 | + ? EEM_Country::instance()->get_all_countries() |
|
| 756 | + : EEM_Country::instance()->get_all_active_countries(); |
|
| 757 | + if (! empty($countries)) { |
|
| 758 | + foreach ($countries as $country) { |
|
| 759 | + if ($country instanceof EE_Country) { |
|
| 760 | + $country_options[ $country->ID() ] = $country->name(); |
|
| 761 | + } |
|
| 762 | + } |
|
| 763 | + } |
|
| 764 | + if ($question instanceof EE_Question && $registration instanceof EE_Registration) { |
|
| 765 | + $answer = EEM_Answer::instance()->get_one( |
|
| 766 | + array(array('QST_ID' => $question->ID(), 'REG_ID' => $registration->ID())) |
|
| 767 | + ); |
|
| 768 | + } else { |
|
| 769 | + $answer = EE_Answer::new_instance(); |
|
| 770 | + } |
|
| 771 | + $country_options = apply_filters( |
|
| 772 | + 'FHEE__EE_SPCO_Reg_Step_Attendee_Information___generate_question_input__country_options', |
|
| 773 | + $country_options, |
|
| 774 | + $this, |
|
| 775 | + $registration, |
|
| 776 | + $question, |
|
| 777 | + $answer |
|
| 778 | + ); |
|
| 779 | + return $country_options; |
|
| 780 | + } |
|
| 781 | + |
|
| 782 | + |
|
| 783 | + /** |
|
| 784 | + * Gets the list of states for the form input |
|
| 785 | + * |
|
| 786 | + * @param array|null $states_list |
|
| 787 | + * @param EE_Question $question |
|
| 788 | + * @param EE_Registration $registration |
|
| 789 | + * @param EE_Answer $answer |
|
| 790 | + * @return array 2d keys are state IDs, values are their names |
|
| 791 | + * @throws EE_Error |
|
| 792 | + * @throws InvalidArgumentException |
|
| 793 | + * @throws InvalidDataTypeException |
|
| 794 | + * @throws InvalidInterfaceException |
|
| 795 | + * @throws ReflectionException |
|
| 796 | + */ |
|
| 797 | + public function use_cached_states_for_form_input( |
|
| 798 | + $states_list, |
|
| 799 | + EE_Question $question = null, |
|
| 800 | + EE_Registration $registration = null, |
|
| 801 | + EE_Answer $answer = null |
|
| 802 | + ) { |
|
| 803 | + $state_options = array('' => array('' => '')); |
|
| 804 | + $states = $this->checkout->action === 'process_reg_step' |
|
| 805 | + ? EEM_State::instance()->get_all_states() |
|
| 806 | + : EEM_State::instance()->get_all_active_states(); |
|
| 807 | + if (! empty($states)) { |
|
| 808 | + foreach ($states as $state) { |
|
| 809 | + if ($state instanceof EE_State) { |
|
| 810 | + $state_options[ $state->country()->name() ][ $state->ID() ] = $state->name(); |
|
| 811 | + } |
|
| 812 | + } |
|
| 813 | + } |
|
| 814 | + $state_options = apply_filters( |
|
| 815 | + 'FHEE__EE_SPCO_Reg_Step_Attendee_Information___generate_question_input__state_options', |
|
| 816 | + $state_options, |
|
| 817 | + $this, |
|
| 818 | + $registration, |
|
| 819 | + $question, |
|
| 820 | + $answer |
|
| 821 | + ); |
|
| 822 | + return $state_options; |
|
| 823 | + } |
|
| 824 | + |
|
| 825 | + |
|
| 826 | + /********************************************************************************************************/ |
|
| 827 | + /**************************************** PROCESS REG STEP ****************************************/ |
|
| 828 | + /********************************************************************************************************/ |
|
| 829 | + |
|
| 830 | + |
|
| 831 | + /** |
|
| 832 | + * @return bool |
|
| 833 | + * @throws EE_Error |
|
| 834 | + * @throws InvalidArgumentException |
|
| 835 | + * @throws ReflectionException |
|
| 836 | + * @throws RuntimeException |
|
| 837 | + * @throws InvalidDataTypeException |
|
| 838 | + * @throws InvalidInterfaceException |
|
| 839 | + */ |
|
| 840 | + public function process_reg_step() |
|
| 841 | + { |
|
| 842 | + do_action('AHEE_log', __FILE__, __FUNCTION__, ''); |
|
| 843 | + // grab validated data from form |
|
| 844 | + $valid_data = $this->checkout->current_step->valid_data(); |
|
| 845 | + // EEH_Debug_Tools::printr( $_REQUEST, '$_REQUEST', __FILE__, __LINE__ ); |
|
| 846 | + // EEH_Debug_Tools::printr( $valid_data, '$valid_data', __FILE__, __LINE__ ); |
|
| 847 | + // if we don't have any $valid_data then something went TERRIBLY WRONG !!! |
|
| 848 | + if (empty($valid_data)) { |
|
| 849 | + EE_Error::add_error( |
|
| 850 | + esc_html__('No valid question responses were received.', 'event_espresso'), |
|
| 851 | + __FILE__, |
|
| 852 | + __FUNCTION__, |
|
| 853 | + __LINE__ |
|
| 854 | + ); |
|
| 855 | + return false; |
|
| 856 | + } |
|
| 857 | + if (! $this->checkout->transaction instanceof EE_Transaction || ! $this->checkout->continue_reg) { |
|
| 858 | + EE_Error::add_error( |
|
| 859 | + esc_html__( |
|
| 860 | + 'A valid transaction could not be initiated for processing your registrations.', |
|
| 861 | + 'event_espresso' |
|
| 862 | + ), |
|
| 863 | + __FILE__, |
|
| 864 | + __FUNCTION__, |
|
| 865 | + __LINE__ |
|
| 866 | + ); |
|
| 867 | + return false; |
|
| 868 | + } |
|
| 869 | + // get cached registrations |
|
| 870 | + $registrations = $this->checkout->transaction->registrations($this->checkout->reg_cache_where_params); |
|
| 871 | + // verify we got the goods |
|
| 872 | + if (empty($registrations)) { |
|
| 873 | + // combine the old translated string with a new one, in order to not break translations |
|
| 874 | + $error_message = esc_html__( |
|
| 875 | + 'Your form data could not be applied to any valid registrations.', |
|
| 876 | + 'event_espresso' |
|
| 877 | + ) |
|
| 878 | + . sprintf( |
|
| 879 | + esc_html_x( |
|
| 880 | + '%3$sThis can sometimes happen if too much time has been taken to complete the registration process.%3$sPlease return to the %1$sEvent List%2$s and reselect your tickets. If the problem continues, please contact the site administrator.', |
|
| 881 | + '(line break)This can sometimes happen if too much time has been taken to complete the registration process.(line break)Please return to the (link)Event List(end link) and reselect your tickets. If the problem continues, please contact the site administrator.', |
|
| 882 | + 'event_espresso' |
|
| 883 | + ), |
|
| 884 | + '<a href="' . get_post_type_archive_link('espresso_events') . '" >', |
|
| 885 | + '</a>', |
|
| 886 | + '<br />' |
|
| 887 | + ); |
|
| 888 | + EE_Error::add_error( |
|
| 889 | + $error_message, |
|
| 890 | + __FILE__, |
|
| 891 | + __FUNCTION__, |
|
| 892 | + __LINE__ |
|
| 893 | + ); |
|
| 894 | + return false; |
|
| 895 | + } |
|
| 896 | + // extract attendee info from form data and save to model objects |
|
| 897 | + $registrations_processed = $this->_process_registrations($registrations, $valid_data); |
|
| 898 | + // if first pass thru SPCO, |
|
| 899 | + // then let's check processed registrations against the total number of tickets in the cart |
|
| 900 | + if ($registrations_processed === false) { |
|
| 901 | + // but return immediately if the previous step exited early due to errors |
|
| 902 | + return false; |
|
| 903 | + } |
|
| 904 | + if (! $this->checkout->revisit && $registrations_processed !== $this->checkout->total_ticket_count) { |
|
| 905 | + // generate a correctly translated string for all possible singular/plural combinations |
|
| 906 | + if ($this->checkout->total_ticket_count === 1 && $registrations_processed !== 1) { |
|
| 907 | + $error_msg = sprintf( |
|
| 908 | + esc_html_x( |
|
| 909 | + 'There was %1$d ticket in the Event Queue, but %2$ds registrations were processed', |
|
| 910 | + 'There was 1 ticket in the Event Queue, but 2 registrations were processed', |
|
| 911 | + 'event_espresso' |
|
| 912 | + ), |
|
| 913 | + $this->checkout->total_ticket_count, |
|
| 914 | + $registrations_processed |
|
| 915 | + ); |
|
| 916 | + } elseif ($this->checkout->total_ticket_count !== 1 && $registrations_processed === 1) { |
|
| 917 | + $error_msg = sprintf( |
|
| 918 | + esc_html_x( |
|
| 919 | + 'There was a total of %1$d tickets in the Event Queue, but only %2$ds registration was processed', |
|
| 920 | + 'There was a total of 2 tickets in the Event Queue, but only 1 registration was processed', |
|
| 921 | + 'event_espresso' |
|
| 922 | + ), |
|
| 923 | + $this->checkout->total_ticket_count, |
|
| 924 | + $registrations_processed |
|
| 925 | + ); |
|
| 926 | + } else { |
|
| 927 | + $error_msg = sprintf( |
|
| 928 | + esc_html__( |
|
| 929 | + 'There was a total of 2 tickets in the Event Queue, but 2 registrations were processed', |
|
| 930 | + 'event_espresso' |
|
| 931 | + ), |
|
| 932 | + $this->checkout->total_ticket_count, |
|
| 933 | + $registrations_processed |
|
| 934 | + ); |
|
| 935 | + } |
|
| 936 | + EE_Error::add_error($error_msg, __FILE__, __FUNCTION__, __LINE__); |
|
| 937 | + return false; |
|
| 938 | + } |
|
| 939 | + // mark this reg step as completed |
|
| 940 | + $this->set_completed(); |
|
| 941 | + $this->_set_success_message( |
|
| 942 | + esc_html__('The Attendee Information Step has been successfully completed.', 'event_espresso') |
|
| 943 | + ); |
|
| 944 | + // do action in case a plugin wants to do something with the data submitted in step 1. |
|
| 945 | + // passes EE_Single_Page_Checkout, and it's posted data |
|
| 946 | + do_action('AHEE__EE_Single_Page_Checkout__process_attendee_information__end', $this, $valid_data); |
|
| 947 | + return true; |
|
| 948 | + } |
|
| 949 | + |
|
| 950 | + |
|
| 951 | + /** |
|
| 952 | + * _process_registrations |
|
| 953 | + * |
|
| 954 | + * @param EE_Registration[] $registrations |
|
| 955 | + * @param array[][] $valid_data |
|
| 956 | + * @return bool|int |
|
| 957 | + * @throws EntityNotFoundException |
|
| 958 | + * @throws EE_Error |
|
| 959 | + * @throws InvalidArgumentException |
|
| 960 | + * @throws ReflectionException |
|
| 961 | + * @throws RuntimeException |
|
| 962 | + * @throws InvalidDataTypeException |
|
| 963 | + * @throws InvalidInterfaceException |
|
| 964 | + */ |
|
| 965 | + private function _process_registrations($registrations = array(), $valid_data = array()) |
|
| 966 | + { |
|
| 967 | + // load resources and set some defaults |
|
| 968 | + EE_Registry::instance()->load_model('Attendee'); |
|
| 969 | + // holder for primary registrant attendee object |
|
| 970 | + $this->checkout->primary_attendee_obj = null; |
|
| 971 | + // array for tracking reg form data for the primary registrant |
|
| 972 | + $primary_registrant = array( |
|
| 973 | + 'line_item_id' => null, |
|
| 974 | + ); |
|
| 975 | + $copy_primary = false; |
|
| 976 | + // reg form sections that do not contain inputs |
|
| 977 | + $non_input_form_sections = array( |
|
| 978 | + 'primary_registrant', |
|
| 979 | + 'additional_attendee_reg_info', |
|
| 980 | + 'spco_copy_attendee_chk', |
|
| 981 | + ); |
|
| 982 | + // attendee counter |
|
| 983 | + $att_nmbr = 0; |
|
| 984 | + // grab the saved registrations from the transaction |
|
| 985 | + foreach ($registrations as $registration) { |
|
| 986 | + // verify EE_Registration object |
|
| 987 | + if (! $registration instanceof EE_Registration) { |
|
| 988 | + EE_Error::add_error( |
|
| 989 | + esc_html__( |
|
| 990 | + 'An invalid Registration object was discovered when attempting to process your registration information.', |
|
| 991 | + 'event_espresso' |
|
| 992 | + ), |
|
| 993 | + __FILE__, |
|
| 994 | + __FUNCTION__, |
|
| 995 | + __LINE__ |
|
| 996 | + ); |
|
| 997 | + return false; |
|
| 998 | + } |
|
| 999 | + /** @var string $reg_url_link */ |
|
| 1000 | + $reg_url_link = $registration->reg_url_link(); |
|
| 1001 | + // reg_url_link exists ? |
|
| 1002 | + if (! empty($reg_url_link)) { |
|
| 1003 | + // should this registration be processed during this visit ? |
|
| 1004 | + if ($this->checkout->visit_allows_processing_of_this_registration($registration)) { |
|
| 1005 | + // if NOT revisiting, then let's save the registration now, |
|
| 1006 | + // so that we have a REG_ID to use when generating other objects |
|
| 1007 | + if (! $this->checkout->revisit) { |
|
| 1008 | + $registration->save(); |
|
| 1009 | + } |
|
| 1010 | + /** |
|
| 1011 | + * This allows plugins to trigger a fail on processing of a |
|
| 1012 | + * registration for any conditions they may have for it to pass. |
|
| 1013 | + * |
|
| 1014 | + * @var bool if true is returned by the plugin then the |
|
| 1015 | + * registration processing is halted. |
|
| 1016 | + */ |
|
| 1017 | + if (apply_filters( |
|
| 1018 | + 'FHEE__EE_SPCO_Reg_Step_Attendee_Information___process_registrations__pre_registration_process', |
|
| 1019 | + false, |
|
| 1020 | + $att_nmbr, |
|
| 1021 | + $registration, |
|
| 1022 | + $registrations, |
|
| 1023 | + $valid_data, |
|
| 1024 | + $this |
|
| 1025 | + )) { |
|
| 1026 | + return false; |
|
| 1027 | + } |
|
| 1028 | + |
|
| 1029 | + // Houston, we have a registration! |
|
| 1030 | + $att_nmbr++; |
|
| 1031 | + $this->_attendee_data[ $reg_url_link ] = array(); |
|
| 1032 | + // grab any existing related answer objects |
|
| 1033 | + $this->_registration_answers = $registration->answers(); |
|
| 1034 | + // unset( $valid_data[ $reg_url_link ]['additional_attendee_reg_info'] ); |
|
| 1035 | + if (isset($valid_data[ $reg_url_link ])) { |
|
| 1036 | + // do we need to copy basic info from primary attendee ? |
|
| 1037 | + $copy_primary = isset($valid_data[ $reg_url_link ]['additional_attendee_reg_info']) |
|
| 1038 | + && absint($valid_data[ $reg_url_link ]['additional_attendee_reg_info']) === 0; |
|
| 1039 | + // filter form input data for this registration |
|
| 1040 | + $valid_data[ $reg_url_link ] = (array) apply_filters( |
|
| 1041 | + 'FHEE__EE_Single_Page_Checkout__process_attendee_information__valid_data_line_item', |
|
| 1042 | + $valid_data[ $reg_url_link ] |
|
| 1043 | + ); |
|
| 1044 | + if (isset($valid_data['primary_attendee'])) { |
|
| 1045 | + $primary_registrant['line_item_id'] = ! empty($valid_data['primary_attendee']) |
|
| 1046 | + ? $valid_data['primary_attendee'] |
|
| 1047 | + : false; |
|
| 1048 | + unset($valid_data['primary_attendee']); |
|
| 1049 | + } |
|
| 1050 | + // now loop through our array of valid post data && process attendee reg forms |
|
| 1051 | + foreach ($valid_data[ $reg_url_link ] as $form_section => $form_inputs) { |
|
| 1052 | + if (! in_array($form_section, $non_input_form_sections, true)) { |
|
| 1053 | + foreach ($form_inputs as $form_input => $input_value) { |
|
| 1054 | + // \EEH_Debug_Tools::printr( $input_value, $form_input, __FILE__, __LINE__ ); |
|
| 1055 | + // check for critical inputs |
|
| 1056 | + if (! $this->_verify_critical_attendee_details_are_set_and_validate_email( |
|
| 1057 | + $form_input, |
|
| 1058 | + $input_value |
|
| 1059 | + ) |
|
| 1060 | + ) { |
|
| 1061 | + return false; |
|
| 1062 | + } |
|
| 1063 | + // store a bit of data about the primary attendee |
|
| 1064 | + if ($att_nmbr === 1 |
|
| 1065 | + && ! empty($input_value) |
|
| 1066 | + && $reg_url_link === $primary_registrant['line_item_id'] |
|
| 1067 | + ) { |
|
| 1068 | + $primary_registrant[ $form_input ] = $input_value; |
|
| 1069 | + } elseif ($copy_primary |
|
| 1070 | + && $input_value === null |
|
| 1071 | + && isset($primary_registrant[ $form_input ]) |
|
| 1072 | + ) { |
|
| 1073 | + $input_value = $primary_registrant[ $form_input ]; |
|
| 1074 | + } |
|
| 1075 | + // now attempt to save the input data |
|
| 1076 | + if (! $this->_save_registration_form_input( |
|
| 1077 | + $registration, |
|
| 1078 | + $form_input, |
|
| 1079 | + $input_value |
|
| 1080 | + ) |
|
| 1081 | + ) { |
|
| 1082 | + EE_Error::add_error( |
|
| 1083 | + sprintf( |
|
| 1084 | + esc_html_x( |
|
| 1085 | + 'Unable to save registration form data for the form input: "%1$s" with the submitted value: "%2$s"', |
|
| 1086 | + 'Unable to save registration form data for the form input: "form input name" with the submitted value: "form input value"', |
|
| 1087 | + 'event_espresso' |
|
| 1088 | + ), |
|
| 1089 | + $form_input, |
|
| 1090 | + $input_value |
|
| 1091 | + ), |
|
| 1092 | + __FILE__, |
|
| 1093 | + __FUNCTION__, |
|
| 1094 | + __LINE__ |
|
| 1095 | + ); |
|
| 1096 | + return false; |
|
| 1097 | + } |
|
| 1098 | + } |
|
| 1099 | + } |
|
| 1100 | + } // end of foreach ( $valid_data[ $reg_url_link ] as $form_section => $form_inputs ) |
|
| 1101 | + } |
|
| 1102 | + // EEH_Debug_Tools::printr( $this->_attendee_data, '$this->_attendee_data', __FILE__, __LINE__ ); |
|
| 1103 | + // this registration does not require additional attendee information ? |
|
| 1104 | + if ($copy_primary |
|
| 1105 | + && $att_nmbr > 1 |
|
| 1106 | + && $this->checkout->primary_attendee_obj instanceof EE_Attendee |
|
| 1107 | + ) { |
|
| 1108 | + // just copy the primary registrant |
|
| 1109 | + $attendee = $this->checkout->primary_attendee_obj; |
|
| 1110 | + } else { |
|
| 1111 | + // ensure critical details are set for additional attendees |
|
| 1112 | + $this->_attendee_data[ $reg_url_link ] = $att_nmbr > 1 |
|
| 1113 | + ? $this->_copy_critical_attendee_details_from_primary_registrant( |
|
| 1114 | + $this->_attendee_data[ $reg_url_link ] |
|
| 1115 | + ) |
|
| 1116 | + : $this->_attendee_data[ $reg_url_link ]; |
|
| 1117 | + // execute create attendee command (which may return an existing attendee) |
|
| 1118 | + $attendee = EE_Registry::instance()->BUS->execute( |
|
| 1119 | + new CreateAttendeeCommand( |
|
| 1120 | + $this->_attendee_data[ $reg_url_link ], |
|
| 1121 | + $registration |
|
| 1122 | + ) |
|
| 1123 | + ); |
|
| 1124 | + // who's #1 ? |
|
| 1125 | + if ($att_nmbr === 1) { |
|
| 1126 | + $this->checkout->primary_attendee_obj = $attendee; |
|
| 1127 | + } |
|
| 1128 | + } |
|
| 1129 | + // EEH_Debug_Tools::printr( $attendee, '$attendee', __FILE__, __LINE__ ); |
|
| 1130 | + // add relation to registration, set attendee ID, and cache attendee |
|
| 1131 | + $this->_associate_attendee_with_registration($registration, $attendee); |
|
| 1132 | + // \EEH_Debug_Tools::printr( $registration, '$registration', __FILE__, __LINE__ ); |
|
| 1133 | + if (! $registration->attendee() instanceof EE_Attendee) { |
|
| 1134 | + EE_Error::add_error( |
|
| 1135 | + sprintf( |
|
| 1136 | + esc_html_x( |
|
| 1137 | + 'Registration %s has an invalid or missing Attendee object.', |
|
| 1138 | + 'Registration 123-456-789 has an invalid or missing Attendee object.', |
|
| 1139 | + 'event_espresso' |
|
| 1140 | + ), |
|
| 1141 | + $reg_url_link |
|
| 1142 | + ), |
|
| 1143 | + __FILE__, |
|
| 1144 | + __FUNCTION__, |
|
| 1145 | + __LINE__ |
|
| 1146 | + ); |
|
| 1147 | + return false; |
|
| 1148 | + } |
|
| 1149 | + /** @type EE_Registration_Processor $registration_processor */ |
|
| 1150 | + $registration_processor = EE_Registry::instance()->load_class('Registration_Processor'); |
|
| 1151 | + // at this point, we should have enough details about the registrant to consider the registration |
|
| 1152 | + // NOT incomplete |
|
| 1153 | + $registration_processor->toggle_incomplete_registration_status_to_default( |
|
| 1154 | + $registration, |
|
| 1155 | + false, |
|
| 1156 | + new Context( |
|
| 1157 | + 'spco_reg_step_attendee_information_process_registrations', |
|
| 1158 | + esc_html__( |
|
| 1159 | + 'Finished populating registration with details from the registration form after submitting the Attendee Information Reg Step.', |
|
| 1160 | + 'event_espresso' |
|
| 1161 | + ) |
|
| 1162 | + ) |
|
| 1163 | + ); |
|
| 1164 | + // we can also consider the TXN to not have been failed, so temporarily upgrade it's status to |
|
| 1165 | + // abandoned |
|
| 1166 | + $this->checkout->transaction->toggle_failed_transaction_status(); |
|
| 1167 | + // if we've gotten this far, then let's save what we have |
|
| 1168 | + $registration->save(); |
|
| 1169 | + // add relation between TXN and registration |
|
| 1170 | + $this->_associate_registration_with_transaction($registration); |
|
| 1171 | + } |
|
| 1172 | + } else { |
|
| 1173 | + EE_Error::add_error( |
|
| 1174 | + esc_html__( |
|
| 1175 | + 'An invalid or missing line item ID was encountered while attempting to process the registration form.', |
|
| 1176 | + 'event_espresso' |
|
| 1177 | + ), |
|
| 1178 | + __FILE__, |
|
| 1179 | + __FUNCTION__, |
|
| 1180 | + __LINE__ |
|
| 1181 | + ); |
|
| 1182 | + // remove malformed data |
|
| 1183 | + unset($valid_data[ $reg_url_link ]); |
|
| 1184 | + return false; |
|
| 1185 | + } |
|
| 1186 | + } // end of foreach ( $this->checkout->transaction->registrations() as $registration ) |
|
| 1187 | + return $att_nmbr; |
|
| 1188 | + } |
|
| 1189 | + |
|
| 1190 | + |
|
| 1191 | + /** |
|
| 1192 | + * _save_registration_form_input |
|
| 1193 | + * |
|
| 1194 | + * @param EE_Registration $registration |
|
| 1195 | + * @param string $form_input |
|
| 1196 | + * @param string $input_value |
|
| 1197 | + * @return bool |
|
| 1198 | + * @throws EE_Error |
|
| 1199 | + * @throws InvalidArgumentException |
|
| 1200 | + * @throws InvalidDataTypeException |
|
| 1201 | + * @throws InvalidInterfaceException |
|
| 1202 | + * @throws ReflectionException |
|
| 1203 | + */ |
|
| 1204 | + private function _save_registration_form_input( |
|
| 1205 | + EE_Registration $registration, |
|
| 1206 | + $form_input = '', |
|
| 1207 | + $input_value = '' |
|
| 1208 | + ) { |
|
| 1209 | + // \EEH_Debug_Tools::printr( __FUNCTION__, __CLASS__, __FILE__, __LINE__, 2 ); |
|
| 1210 | + // \EEH_Debug_Tools::printr( $form_input, '$form_input', __FILE__, __LINE__ ); |
|
| 1211 | + // \EEH_Debug_Tools::printr( $input_value, '$input_value', __FILE__, __LINE__ ); |
|
| 1212 | + // allow for plugins to hook in and do their own processing of the form input. |
|
| 1213 | + // For plugins to bypass normal processing here, they just need to return a boolean value. |
|
| 1214 | + if (apply_filters( |
|
| 1215 | + 'FHEE__EE_SPCO_Reg_Step_Attendee_Information___save_registration_form_input', |
|
| 1216 | + false, |
|
| 1217 | + $registration, |
|
| 1218 | + $form_input, |
|
| 1219 | + $input_value, |
|
| 1220 | + $this |
|
| 1221 | + )) { |
|
| 1222 | + return true; |
|
| 1223 | + } |
|
| 1224 | + /* |
|
| 1225 | 1225 | * $answer_cache_id is the key used to find the EE_Answer we want |
| 1226 | 1226 | * @see https://events.codebasehq.com/projects/event-espresso/tickets/10477 |
| 1227 | 1227 | */ |
| 1228 | - $answer_cache_id = $this->checkout->reg_url_link |
|
| 1229 | - ? $form_input . '-' . $registration->reg_url_link() |
|
| 1230 | - : $form_input; |
|
| 1231 | - $answer_is_obj = isset($this->_registration_answers[ $answer_cache_id ]) |
|
| 1232 | - && $this->_registration_answers[ $answer_cache_id ] instanceof EE_Answer; |
|
| 1233 | - // rename form_inputs if they are EE_Attendee properties |
|
| 1234 | - switch ((string) $form_input) { |
|
| 1235 | - case 'state': |
|
| 1236 | - case 'STA_ID': |
|
| 1237 | - $attendee_property = true; |
|
| 1238 | - $form_input = 'STA_ID'; |
|
| 1239 | - break; |
|
| 1240 | - |
|
| 1241 | - case 'country': |
|
| 1242 | - case 'CNT_ISO': |
|
| 1243 | - $attendee_property = true; |
|
| 1244 | - $form_input = 'CNT_ISO'; |
|
| 1245 | - break; |
|
| 1246 | - |
|
| 1247 | - default: |
|
| 1248 | - $ATT_input = 'ATT_' . $form_input; |
|
| 1249 | - // EEH_Debug_Tools::printr( $ATT_input, '$ATT_input', __FILE__, __LINE__ ); |
|
| 1250 | - $attendee_property = EEM_Attendee::instance()->has_field($ATT_input) ? true : false; |
|
| 1251 | - $form_input = $attendee_property ? 'ATT_' . $form_input : $form_input; |
|
| 1252 | - } |
|
| 1253 | - // EEH_Debug_Tools::printr( $answer_cache_id, '$answer_cache_id', __FILE__, __LINE__ ); |
|
| 1254 | - // EEH_Debug_Tools::printr( $attendee_property, '$attendee_property', __FILE__, __LINE__ ); |
|
| 1255 | - // EEH_Debug_Tools::printr( $answer_is_obj, '$answer_is_obj', __FILE__, __LINE__ ); |
|
| 1256 | - // if this form input has a corresponding attendee property |
|
| 1257 | - if ($attendee_property) { |
|
| 1258 | - $this->_attendee_data[ $registration->reg_url_link() ][ $form_input ] = $input_value; |
|
| 1259 | - if ($answer_is_obj) { |
|
| 1260 | - // and delete the corresponding answer since we won't be storing this data in that object |
|
| 1261 | - $registration->_remove_relation_to($this->_registration_answers[ $answer_cache_id ], 'Answer'); |
|
| 1262 | - $this->_registration_answers[ $answer_cache_id ]->delete_permanently(); |
|
| 1263 | - } |
|
| 1264 | - return true; |
|
| 1265 | - } |
|
| 1266 | - if ($answer_is_obj) { |
|
| 1267 | - // save this data to the answer object |
|
| 1268 | - $this->_registration_answers[ $answer_cache_id ]->set_value($input_value); |
|
| 1269 | - $result = $this->_registration_answers[ $answer_cache_id ]->save(); |
|
| 1270 | - return $result !== false; |
|
| 1271 | - } |
|
| 1272 | - foreach ($this->_registration_answers as $answer) { |
|
| 1273 | - if ($answer instanceof EE_Answer && $answer->question_ID() === $answer_cache_id) { |
|
| 1274 | - $answer->set_value($input_value); |
|
| 1275 | - $result = $answer->save(); |
|
| 1276 | - return $result !== false; |
|
| 1277 | - } |
|
| 1278 | - } |
|
| 1279 | - return false; |
|
| 1280 | - } |
|
| 1281 | - |
|
| 1282 | - |
|
| 1283 | - /** |
|
| 1284 | - * _verify_critical_attendee_details_are_set |
|
| 1285 | - * |
|
| 1286 | - * @param string $form_input |
|
| 1287 | - * @param string $input_value |
|
| 1288 | - * @return boolean |
|
| 1289 | - */ |
|
| 1290 | - private function _verify_critical_attendee_details_are_set_and_validate_email( |
|
| 1291 | - $form_input = '', |
|
| 1292 | - $input_value = '' |
|
| 1293 | - ) { |
|
| 1294 | - if (empty($input_value)) { |
|
| 1295 | - // if the form input isn't marked as being required, then just return |
|
| 1296 | - if (! isset($this->_required_questions[ $form_input ]) || ! $this->_required_questions[ $form_input ]) { |
|
| 1297 | - return true; |
|
| 1298 | - } |
|
| 1299 | - switch ($form_input) { |
|
| 1300 | - case 'fname': |
|
| 1301 | - EE_Error::add_error( |
|
| 1302 | - esc_html__('First Name is a required value.', 'event_espresso'), |
|
| 1303 | - __FILE__, |
|
| 1304 | - __FUNCTION__, |
|
| 1305 | - __LINE__ |
|
| 1306 | - ); |
|
| 1307 | - return false; |
|
| 1308 | - break; |
|
| 1309 | - case 'lname': |
|
| 1310 | - EE_Error::add_error( |
|
| 1311 | - esc_html__('Last Name is a required value.', 'event_espresso'), |
|
| 1312 | - __FILE__, |
|
| 1313 | - __FUNCTION__, |
|
| 1314 | - __LINE__ |
|
| 1315 | - ); |
|
| 1316 | - return false; |
|
| 1317 | - break; |
|
| 1318 | - case 'email': |
|
| 1319 | - EE_Error::add_error( |
|
| 1320 | - esc_html__('Please enter a valid email address.', 'event_espresso'), |
|
| 1321 | - __FILE__, |
|
| 1322 | - __FUNCTION__, |
|
| 1323 | - __LINE__ |
|
| 1324 | - ); |
|
| 1325 | - return false; |
|
| 1326 | - break; |
|
| 1327 | - } |
|
| 1328 | - } |
|
| 1329 | - return true; |
|
| 1330 | - } |
|
| 1331 | - |
|
| 1332 | - |
|
| 1333 | - /** |
|
| 1334 | - * _associate_attendee_with_registration |
|
| 1335 | - * |
|
| 1336 | - * @param EE_Registration $registration |
|
| 1337 | - * @param EE_Attendee $attendee |
|
| 1338 | - * @return void |
|
| 1339 | - * @throws EE_Error |
|
| 1340 | - * @throws InvalidArgumentException |
|
| 1341 | - * @throws ReflectionException |
|
| 1342 | - * @throws RuntimeException |
|
| 1343 | - * @throws InvalidDataTypeException |
|
| 1344 | - * @throws InvalidInterfaceException |
|
| 1345 | - */ |
|
| 1346 | - private function _associate_attendee_with_registration(EE_Registration $registration, EE_Attendee $attendee) |
|
| 1347 | - { |
|
| 1348 | - // add relation to attendee |
|
| 1349 | - $registration->_add_relation_to($attendee, 'Attendee'); |
|
| 1350 | - $registration->set_attendee_id($attendee->ID()); |
|
| 1351 | - $registration->update_cache_after_object_save('Attendee', $attendee); |
|
| 1352 | - } |
|
| 1353 | - |
|
| 1354 | - |
|
| 1355 | - /** |
|
| 1356 | - * _associate_registration_with_transaction |
|
| 1357 | - * |
|
| 1358 | - * @param EE_Registration $registration |
|
| 1359 | - * @return void |
|
| 1360 | - * @throws EE_Error |
|
| 1361 | - * @throws InvalidArgumentException |
|
| 1362 | - * @throws ReflectionException |
|
| 1363 | - * @throws InvalidDataTypeException |
|
| 1364 | - * @throws InvalidInterfaceException |
|
| 1365 | - */ |
|
| 1366 | - private function _associate_registration_with_transaction(EE_Registration $registration) |
|
| 1367 | - { |
|
| 1368 | - // add relation to registration |
|
| 1369 | - $this->checkout->transaction->_add_relation_to($registration, 'Registration'); |
|
| 1370 | - $this->checkout->transaction->update_cache_after_object_save('Registration', $registration); |
|
| 1371 | - } |
|
| 1372 | - |
|
| 1373 | - |
|
| 1374 | - /** |
|
| 1375 | - * _copy_critical_attendee_details_from_primary_registrant |
|
| 1376 | - * ensures that all attendees at least have data for first name, last name, and email address |
|
| 1377 | - * |
|
| 1378 | - * @param array $attendee_data |
|
| 1379 | - * @return array |
|
| 1380 | - * @throws EE_Error |
|
| 1381 | - * @throws InvalidArgumentException |
|
| 1382 | - * @throws ReflectionException |
|
| 1383 | - * @throws InvalidDataTypeException |
|
| 1384 | - * @throws InvalidInterfaceException |
|
| 1385 | - */ |
|
| 1386 | - private function _copy_critical_attendee_details_from_primary_registrant($attendee_data = array()) |
|
| 1387 | - { |
|
| 1388 | - // bare minimum critical details include first name, last name, email address |
|
| 1389 | - $critical_attendee_details = array('ATT_fname', 'ATT_lname', 'ATT_email'); |
|
| 1390 | - // add address info to critical details? |
|
| 1391 | - if (apply_filters( |
|
| 1392 | - 'FHEE__EE_SPCO_Reg_Step_Attendee_Information__merge_address_details_with_critical_attendee_details', |
|
| 1393 | - false |
|
| 1394 | - )) { |
|
| 1395 | - $address_details = array( |
|
| 1396 | - 'ATT_address', |
|
| 1397 | - 'ATT_address2', |
|
| 1398 | - 'ATT_city', |
|
| 1399 | - 'STA_ID', |
|
| 1400 | - 'CNT_ISO', |
|
| 1401 | - 'ATT_zip', |
|
| 1402 | - 'ATT_phone', |
|
| 1403 | - ); |
|
| 1404 | - $critical_attendee_details = array_merge($critical_attendee_details, $address_details); |
|
| 1405 | - } |
|
| 1406 | - foreach ($critical_attendee_details as $critical_attendee_detail) { |
|
| 1407 | - if (! isset($attendee_data[ $critical_attendee_detail ]) |
|
| 1408 | - || empty($attendee_data[ $critical_attendee_detail ]) |
|
| 1409 | - ) { |
|
| 1410 | - $attendee_data[ $critical_attendee_detail ] = $this->checkout->primary_attendee_obj->get( |
|
| 1411 | - $critical_attendee_detail |
|
| 1412 | - ); |
|
| 1413 | - } |
|
| 1414 | - } |
|
| 1415 | - return $attendee_data; |
|
| 1416 | - } |
|
| 1417 | - |
|
| 1418 | - |
|
| 1419 | - /** |
|
| 1420 | - * update_reg_step |
|
| 1421 | - * this is the final step after a user revisits the site to edit their attendee information |
|
| 1422 | - * this gets called AFTER the process_reg_step() method above |
|
| 1423 | - * |
|
| 1424 | - * @return bool |
|
| 1425 | - * @throws EE_Error |
|
| 1426 | - * @throws InvalidArgumentException |
|
| 1427 | - * @throws ReflectionException |
|
| 1428 | - * @throws RuntimeException |
|
| 1429 | - * @throws InvalidDataTypeException |
|
| 1430 | - * @throws InvalidInterfaceException |
|
| 1431 | - */ |
|
| 1432 | - public function update_reg_step() |
|
| 1433 | - { |
|
| 1434 | - // save everything |
|
| 1435 | - if ($this->process_reg_step()) { |
|
| 1436 | - $this->checkout->redirect = true; |
|
| 1437 | - $this->checkout->redirect_url = add_query_arg( |
|
| 1438 | - array( |
|
| 1439 | - 'e_reg_url_link' => $this->checkout->reg_url_link, |
|
| 1440 | - 'revisit' => true, |
|
| 1441 | - ), |
|
| 1442 | - $this->checkout->thank_you_page_url |
|
| 1443 | - ); |
|
| 1444 | - $this->checkout->json_response->set_redirect_url($this->checkout->redirect_url); |
|
| 1445 | - return true; |
|
| 1446 | - } |
|
| 1447 | - return false; |
|
| 1448 | - } |
|
| 1228 | + $answer_cache_id = $this->checkout->reg_url_link |
|
| 1229 | + ? $form_input . '-' . $registration->reg_url_link() |
|
| 1230 | + : $form_input; |
|
| 1231 | + $answer_is_obj = isset($this->_registration_answers[ $answer_cache_id ]) |
|
| 1232 | + && $this->_registration_answers[ $answer_cache_id ] instanceof EE_Answer; |
|
| 1233 | + // rename form_inputs if they are EE_Attendee properties |
|
| 1234 | + switch ((string) $form_input) { |
|
| 1235 | + case 'state': |
|
| 1236 | + case 'STA_ID': |
|
| 1237 | + $attendee_property = true; |
|
| 1238 | + $form_input = 'STA_ID'; |
|
| 1239 | + break; |
|
| 1240 | + |
|
| 1241 | + case 'country': |
|
| 1242 | + case 'CNT_ISO': |
|
| 1243 | + $attendee_property = true; |
|
| 1244 | + $form_input = 'CNT_ISO'; |
|
| 1245 | + break; |
|
| 1246 | + |
|
| 1247 | + default: |
|
| 1248 | + $ATT_input = 'ATT_' . $form_input; |
|
| 1249 | + // EEH_Debug_Tools::printr( $ATT_input, '$ATT_input', __FILE__, __LINE__ ); |
|
| 1250 | + $attendee_property = EEM_Attendee::instance()->has_field($ATT_input) ? true : false; |
|
| 1251 | + $form_input = $attendee_property ? 'ATT_' . $form_input : $form_input; |
|
| 1252 | + } |
|
| 1253 | + // EEH_Debug_Tools::printr( $answer_cache_id, '$answer_cache_id', __FILE__, __LINE__ ); |
|
| 1254 | + // EEH_Debug_Tools::printr( $attendee_property, '$attendee_property', __FILE__, __LINE__ ); |
|
| 1255 | + // EEH_Debug_Tools::printr( $answer_is_obj, '$answer_is_obj', __FILE__, __LINE__ ); |
|
| 1256 | + // if this form input has a corresponding attendee property |
|
| 1257 | + if ($attendee_property) { |
|
| 1258 | + $this->_attendee_data[ $registration->reg_url_link() ][ $form_input ] = $input_value; |
|
| 1259 | + if ($answer_is_obj) { |
|
| 1260 | + // and delete the corresponding answer since we won't be storing this data in that object |
|
| 1261 | + $registration->_remove_relation_to($this->_registration_answers[ $answer_cache_id ], 'Answer'); |
|
| 1262 | + $this->_registration_answers[ $answer_cache_id ]->delete_permanently(); |
|
| 1263 | + } |
|
| 1264 | + return true; |
|
| 1265 | + } |
|
| 1266 | + if ($answer_is_obj) { |
|
| 1267 | + // save this data to the answer object |
|
| 1268 | + $this->_registration_answers[ $answer_cache_id ]->set_value($input_value); |
|
| 1269 | + $result = $this->_registration_answers[ $answer_cache_id ]->save(); |
|
| 1270 | + return $result !== false; |
|
| 1271 | + } |
|
| 1272 | + foreach ($this->_registration_answers as $answer) { |
|
| 1273 | + if ($answer instanceof EE_Answer && $answer->question_ID() === $answer_cache_id) { |
|
| 1274 | + $answer->set_value($input_value); |
|
| 1275 | + $result = $answer->save(); |
|
| 1276 | + return $result !== false; |
|
| 1277 | + } |
|
| 1278 | + } |
|
| 1279 | + return false; |
|
| 1280 | + } |
|
| 1281 | + |
|
| 1282 | + |
|
| 1283 | + /** |
|
| 1284 | + * _verify_critical_attendee_details_are_set |
|
| 1285 | + * |
|
| 1286 | + * @param string $form_input |
|
| 1287 | + * @param string $input_value |
|
| 1288 | + * @return boolean |
|
| 1289 | + */ |
|
| 1290 | + private function _verify_critical_attendee_details_are_set_and_validate_email( |
|
| 1291 | + $form_input = '', |
|
| 1292 | + $input_value = '' |
|
| 1293 | + ) { |
|
| 1294 | + if (empty($input_value)) { |
|
| 1295 | + // if the form input isn't marked as being required, then just return |
|
| 1296 | + if (! isset($this->_required_questions[ $form_input ]) || ! $this->_required_questions[ $form_input ]) { |
|
| 1297 | + return true; |
|
| 1298 | + } |
|
| 1299 | + switch ($form_input) { |
|
| 1300 | + case 'fname': |
|
| 1301 | + EE_Error::add_error( |
|
| 1302 | + esc_html__('First Name is a required value.', 'event_espresso'), |
|
| 1303 | + __FILE__, |
|
| 1304 | + __FUNCTION__, |
|
| 1305 | + __LINE__ |
|
| 1306 | + ); |
|
| 1307 | + return false; |
|
| 1308 | + break; |
|
| 1309 | + case 'lname': |
|
| 1310 | + EE_Error::add_error( |
|
| 1311 | + esc_html__('Last Name is a required value.', 'event_espresso'), |
|
| 1312 | + __FILE__, |
|
| 1313 | + __FUNCTION__, |
|
| 1314 | + __LINE__ |
|
| 1315 | + ); |
|
| 1316 | + return false; |
|
| 1317 | + break; |
|
| 1318 | + case 'email': |
|
| 1319 | + EE_Error::add_error( |
|
| 1320 | + esc_html__('Please enter a valid email address.', 'event_espresso'), |
|
| 1321 | + __FILE__, |
|
| 1322 | + __FUNCTION__, |
|
| 1323 | + __LINE__ |
|
| 1324 | + ); |
|
| 1325 | + return false; |
|
| 1326 | + break; |
|
| 1327 | + } |
|
| 1328 | + } |
|
| 1329 | + return true; |
|
| 1330 | + } |
|
| 1331 | + |
|
| 1332 | + |
|
| 1333 | + /** |
|
| 1334 | + * _associate_attendee_with_registration |
|
| 1335 | + * |
|
| 1336 | + * @param EE_Registration $registration |
|
| 1337 | + * @param EE_Attendee $attendee |
|
| 1338 | + * @return void |
|
| 1339 | + * @throws EE_Error |
|
| 1340 | + * @throws InvalidArgumentException |
|
| 1341 | + * @throws ReflectionException |
|
| 1342 | + * @throws RuntimeException |
|
| 1343 | + * @throws InvalidDataTypeException |
|
| 1344 | + * @throws InvalidInterfaceException |
|
| 1345 | + */ |
|
| 1346 | + private function _associate_attendee_with_registration(EE_Registration $registration, EE_Attendee $attendee) |
|
| 1347 | + { |
|
| 1348 | + // add relation to attendee |
|
| 1349 | + $registration->_add_relation_to($attendee, 'Attendee'); |
|
| 1350 | + $registration->set_attendee_id($attendee->ID()); |
|
| 1351 | + $registration->update_cache_after_object_save('Attendee', $attendee); |
|
| 1352 | + } |
|
| 1353 | + |
|
| 1354 | + |
|
| 1355 | + /** |
|
| 1356 | + * _associate_registration_with_transaction |
|
| 1357 | + * |
|
| 1358 | + * @param EE_Registration $registration |
|
| 1359 | + * @return void |
|
| 1360 | + * @throws EE_Error |
|
| 1361 | + * @throws InvalidArgumentException |
|
| 1362 | + * @throws ReflectionException |
|
| 1363 | + * @throws InvalidDataTypeException |
|
| 1364 | + * @throws InvalidInterfaceException |
|
| 1365 | + */ |
|
| 1366 | + private function _associate_registration_with_transaction(EE_Registration $registration) |
|
| 1367 | + { |
|
| 1368 | + // add relation to registration |
|
| 1369 | + $this->checkout->transaction->_add_relation_to($registration, 'Registration'); |
|
| 1370 | + $this->checkout->transaction->update_cache_after_object_save('Registration', $registration); |
|
| 1371 | + } |
|
| 1372 | + |
|
| 1373 | + |
|
| 1374 | + /** |
|
| 1375 | + * _copy_critical_attendee_details_from_primary_registrant |
|
| 1376 | + * ensures that all attendees at least have data for first name, last name, and email address |
|
| 1377 | + * |
|
| 1378 | + * @param array $attendee_data |
|
| 1379 | + * @return array |
|
| 1380 | + * @throws EE_Error |
|
| 1381 | + * @throws InvalidArgumentException |
|
| 1382 | + * @throws ReflectionException |
|
| 1383 | + * @throws InvalidDataTypeException |
|
| 1384 | + * @throws InvalidInterfaceException |
|
| 1385 | + */ |
|
| 1386 | + private function _copy_critical_attendee_details_from_primary_registrant($attendee_data = array()) |
|
| 1387 | + { |
|
| 1388 | + // bare minimum critical details include first name, last name, email address |
|
| 1389 | + $critical_attendee_details = array('ATT_fname', 'ATT_lname', 'ATT_email'); |
|
| 1390 | + // add address info to critical details? |
|
| 1391 | + if (apply_filters( |
|
| 1392 | + 'FHEE__EE_SPCO_Reg_Step_Attendee_Information__merge_address_details_with_critical_attendee_details', |
|
| 1393 | + false |
|
| 1394 | + )) { |
|
| 1395 | + $address_details = array( |
|
| 1396 | + 'ATT_address', |
|
| 1397 | + 'ATT_address2', |
|
| 1398 | + 'ATT_city', |
|
| 1399 | + 'STA_ID', |
|
| 1400 | + 'CNT_ISO', |
|
| 1401 | + 'ATT_zip', |
|
| 1402 | + 'ATT_phone', |
|
| 1403 | + ); |
|
| 1404 | + $critical_attendee_details = array_merge($critical_attendee_details, $address_details); |
|
| 1405 | + } |
|
| 1406 | + foreach ($critical_attendee_details as $critical_attendee_detail) { |
|
| 1407 | + if (! isset($attendee_data[ $critical_attendee_detail ]) |
|
| 1408 | + || empty($attendee_data[ $critical_attendee_detail ]) |
|
| 1409 | + ) { |
|
| 1410 | + $attendee_data[ $critical_attendee_detail ] = $this->checkout->primary_attendee_obj->get( |
|
| 1411 | + $critical_attendee_detail |
|
| 1412 | + ); |
|
| 1413 | + } |
|
| 1414 | + } |
|
| 1415 | + return $attendee_data; |
|
| 1416 | + } |
|
| 1417 | + |
|
| 1418 | + |
|
| 1419 | + /** |
|
| 1420 | + * update_reg_step |
|
| 1421 | + * this is the final step after a user revisits the site to edit their attendee information |
|
| 1422 | + * this gets called AFTER the process_reg_step() method above |
|
| 1423 | + * |
|
| 1424 | + * @return bool |
|
| 1425 | + * @throws EE_Error |
|
| 1426 | + * @throws InvalidArgumentException |
|
| 1427 | + * @throws ReflectionException |
|
| 1428 | + * @throws RuntimeException |
|
| 1429 | + * @throws InvalidDataTypeException |
|
| 1430 | + * @throws InvalidInterfaceException |
|
| 1431 | + */ |
|
| 1432 | + public function update_reg_step() |
|
| 1433 | + { |
|
| 1434 | + // save everything |
|
| 1435 | + if ($this->process_reg_step()) { |
|
| 1436 | + $this->checkout->redirect = true; |
|
| 1437 | + $this->checkout->redirect_url = add_query_arg( |
|
| 1438 | + array( |
|
| 1439 | + 'e_reg_url_link' => $this->checkout->reg_url_link, |
|
| 1440 | + 'revisit' => true, |
|
| 1441 | + ), |
|
| 1442 | + $this->checkout->thank_you_page_url |
|
| 1443 | + ); |
|
| 1444 | + $this->checkout->json_response->set_redirect_url($this->checkout->redirect_url); |
|
| 1445 | + return true; |
|
| 1446 | + } |
|
| 1447 | + return false; |
|
| 1448 | + } |
|
| 1449 | 1449 | } |