PluginProbe ʕ •ᴥ•ʔ
Tutor LMS – eLearning and online course solution / 1.9.13
Tutor LMS – eLearning and online course solution v1.9.13
3.9.14 3.9.13 3.9.12 3.9.11 trunk 1.0.0 1.0.0-alpha 1.0.1 1.0.2 1.0.3 1.0.4 1.0.5 1.0.6 1.0.7 1.0.8 1.0.9 1.1.0 1.1.1 1.2.0 1.2.1 1.2.11 1.2.12 1.2.13 1.2.20 1.3.0 1.3.1 1.3.2 1.3.3 1.3.4 1.3.5 1.3.6 1.3.7 1.3.8 1.3.9 1.4.0 1.4.1 1.4.2 1.4.3 1.4.4 1.4.5 1.4.6 1.4.7 1.4.8 1.4.9 1.5.0 1.5.1 1.5.2 1.5.3 1.5.4 1.5.5 1.5.6 1.5.7 1.5.8 1.5.9 1.6.0 1.6.1 1.6.2 1.6.3 1.6.4 1.6.5 1.6.6 1.6.7 1.6.8 1.6.9 1.7.0 1.7.1 1.7.2 1.7.3 1.7.4 1.7.5 1.7.6 1.7.7 1.7.8 1.7.9 1.8.0 1.8.1 1.8.10 1.8.2 1.8.3 1.8.4 1.8.5 1.8.6 1.8.7 1.8.8 1.8.9 1.9.0 1.9.1 1.9.10 1.9.11 1.9.12 1.9.13 1.9.14 1.9.15 1.9.16 1.9.2 1.9.3 1.9.4 1.9.5 1.9.6 1.9.7 1.9.8 1.9.9 2.0.0 2.0.1 2.0.10 2.0.2 2.0.3 2.0.4 2.0.5 2.0.6 2.0.7 2.0.8 2.0.9 2.1.0 2.1.1 2.1.10 2.1.2 2.1.3 2.1.4 2.1.5 2.1.6 2.1.7 2.1.8 2.1.9 2.2.0 2.2.1 2.2.2 2.2.3 2.2.4 2.3.0 2.4.0 2.5.0 2.6.0 2.6.1 2.6.2 2.7.0 2.7.1 2.7.2 2.7.3 2.7.4 2.7.5 2.7.6 2.7.7 3.0.0 3.0.1 3.0.2 3.1.0 3.2.0 3.2.1 3.2.2 3.2.3 3.3.0 3.3.1 3.4.0 3.4.1 3.4.2 3.5.0 3.6.0 3.6.1 3.6.2 3.6.3 3.6.4 3.7.0 3.7.1 3.7.2 3.7.3 3.7.4 3.8.0 3.8.1 3.8.2 3.8.3 3.9.0 3.9.1 3.9.10 3.9.2 3.9.3 3.9.4 3.9.5 3.9.6 3.9.7 3.9.8 3.9.9
tutor / classes / Upgrader.php
tutor / classes Last commit date
Addons.php 4 years ago Admin.php 4 years ago Ajax.php 4 years ago Assets.php 4 years ago Course.php 4 years ago Course_Filter.php 4 years ago Course_Settings_Tabs.php 4 years ago Course_Widget.php 4 years ago Custom_Validation.php 5 years ago Dashboard.php 4 years ago Email.php 5 years ago FormHandler.php 4 years ago Frontend.php 5 years ago Gutenberg.php 4 years ago Instructor.php 5 years ago Instructors_List.php 4 years ago Lesson.php 4 years ago Options.php 4 years ago Post_types.php 4 years ago Private_Course_Access.php 5 years ago Q_and_A.php 5 years ago Question_Answers_List.php 4 years ago Quiz.php 4 years ago Quiz_Attempts_List.php 4 years ago RestAPI.php 4 years ago Rewrite_Rules.php 4 years ago Shortcode.php 4 years ago Student.php 4 years ago Students_List.php 4 years ago Taxonomies.php 4 years ago Template.php 4 years ago Theme_Compatibility.php 5 years ago Tools.php 4 years ago Tutor.php 4 years ago TutorEDD.php 4 years ago Tutor_Base.php 5 years ago Tutor_List_Table.php 4 years ago Tutor_Setup.php 4 years ago Upgrader.php 4 years ago User.php 4 years ago Utils.php 4 years ago Video_Stream.php 4 years ago Withdraw.php 4 years ago Withdraw_Requests_List.php 4 years ago WooCommerce.php 4 years ago
Upgrader.php
159 lines
1 <?php
2
3 namespace TUTOR;
4
5 if ( ! defined( 'ABSPATH' ) ) {
6 exit;
7 }
8
9 class Upgrader {
10
11 public function __construct() {
12 add_action( 'admin_init', array( $this, 'init_upgrader' ) );
13
14 $base_name = tutor()->basename;
15 add_action( 'in_plugin_update_message-' . $base_name, array( $this, 'in_plugin_update_message' ), 10, 2 );
16
17 /**
18 * Installing Gradebook Addon from TutorPro
19 */
20 add_action( 'tutor_addon_before_enable_tutor-pro/addons/gradebook/gradebook.php', array( $this, 'install_gradebook' ) );
21 add_action( 'tutor_addon_before_enable_tutor-pro/addons/tutor-email/tutor-email.php', array( $this, 'install_tutor_email_queue' ) );
22 add_action( 'upgrader_process_complete', array( $this, 'init_email_table_deployment' ), 10, 2 );
23 }
24
25 public function init_upgrader() {
26 $upgrades = $this->available_upgrades();
27
28 if ( tutor_utils()->count( $upgrades ) ) {
29 foreach ( $upgrades as $upgrade ) {
30 $this->{$upgrade}();
31 }
32 }
33 }
34
35 public function available_upgrades() {
36 $version = get_option( 'tutor_version' );
37
38 $upgrades = array();
39 if ( $version ) {
40 $upgrades[] = 'upgrade_to_1_3_1';
41 }
42
43 return $upgrades;
44 }
45
46 /**
47 * Upgrade to version 1.3.1
48 */
49 public function upgrade_to_1_3_1() {
50 if ( version_compare( get_option( 'tutor_version' ), '1.3.1', '<' ) ) {
51 global $wpdb;
52
53 if ( ! get_option( 'is_course_post_type_updated' ) ) {
54 $wpdb->update( $wpdb->posts, array( 'post_type' => 'courses' ), array( 'post_type' => 'course' ) );
55 update_option( 'is_course_post_type_updated', true );
56 update_option( 'tutor_version', '1.3.1' );
57 flush_rewrite_rules();
58 }
59 }
60 }
61
62
63 public function in_plugin_update_message( $args, $response ) {
64 $upgrade_notice = strip_tags( tutils()->array_get( 'upgrade_notice', $response ) );
65 if ( $upgrade_notice ) {
66 $upgrade_notice = '<span class="version"><code>v.' . $response->new_version . '</code></span> <br />' . $upgrade_notice;
67
68 echo apply_filters( 'tutor_in_plugin_update_message', ($upgrade_notice ? '</p> <div class="tutor_plugin_update_notice">' . $upgrade_notice . '</div> <p class="dummy">' : '') );
69 }
70 }
71
72
73 /**
74 * Installing Gradebook if Tutor Pro exists
75 *
76 * @since v.1.4.2
77 */
78 public function install_gradebook() {
79 global $wpdb;
80
81 $exists_gradebook_table = $wpdb->query( "SHOW TABLES LIKE '{$wpdb->tutor_gradebooks}';" );
82 $exists_gradebook_results_table = $wpdb->query( "SHOW TABLES LIKE '{$wpdb->tutor_gradebooks_results}';" );
83 $charset_collate = $wpdb->get_charset_collate();
84
85 require_once ABSPATH . 'wp-admin/includes/upgrade.php';
86
87 if ( ! $exists_gradebook_table ) {
88 $gradebook_table = "CREATE TABLE IF NOT EXISTS {$wpdb->tutor_gradebooks} (
89 gradebook_id int(11) NOT NULL AUTO_INCREMENT,
90 grade_name varchar(50) DEFAULT NULL,
91 grade_point varchar(20) DEFAULT NULL,
92 grade_point_to varchar(20) DEFAULT NULL,
93 percent_from int(3) DEFAULT NULL,
94 percent_to int(3) DEFAULT NULL,
95 grade_config longtext,
96 PRIMARY KEY (gradebook_id)
97 ) $charset_collate;";
98 dbDelta( $gradebook_table );
99 }
100 if ( ! $exists_gradebook_results_table ) {
101 $gradebook_results = "CREATE TABLE IF NOT EXISTS {$wpdb->tutor_gradebooks_results} (
102 gradebook_result_id int(11) NOT NULL AUTO_INCREMENT,
103 user_id int(11) DEFAULT NULL,
104 course_id int(11) DEFAULT NULL,
105 quiz_id int(11) DEFAULT NULL,
106 assignment_id int(11) DEFAULT NULL,
107 gradebook_id int(11) DEFAULT NULL,
108 result_for varchar(50) DEFAULT NULL,
109 grade_name varchar(50) DEFAULT NULL,
110 grade_point varchar(20) DEFAULT NULL,
111 earned_grade_point varchar(20) DEFAULT NULL,
112 earned_percent int(3) DEFAULT NULL,
113 generate_date datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
114 update_date datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
115 PRIMARY KEY (gradebook_result_id)
116 ) {$charset_collate};";
117 dbDelta( $gradebook_results );
118 }
119
120 }
121
122 public function init_email_table_deployment( $upgrader_object, $options ) {
123
124 if ( is_object( $upgrader_object ) && is_array( $upgrader_object->result ) && isset( $upgrader_object->result['destination_name'] ) && $upgrader_object->result['destination_name'] == 'tutor-pro' ) {
125 $addonConfig = tutor_utils()->get_addon_config( 'tutor-pro/addons/tutor-email/tutor-email.php' );
126 $isEnable = (bool) tutor_utils()->avalue_dot( 'is_enable', $addonConfig );
127
128 $isEnable ? $this->install_tutor_email_queue() : 0;
129 }
130 }
131
132 /**
133 * Installing email addon if Tutor Pro exists
134 *
135 * @since v.1.8.6
136 */
137 public function install_tutor_email_queue() {
138
139 global $wpdb;
140 $exists_email_queue_table = $wpdb->query( "SHOW TABLES LIKE '{$wpdb->tutor_email_queue}';" );
141 $charset_collate = $wpdb->get_charset_collate();
142
143 require_once ABSPATH . 'wp-admin/includes/upgrade.php';
144
145 if ( ! $exists_email_queue_table ) {
146 $table = "CREATE TABLE IF NOT EXISTS {$wpdb->tutor_email_queue} (
147 id bigint(20) unsigned NOT NULL AUTO_INCREMENT,
148 mail_to varchar(255) NOT NULL,
149 subject text NOT NULL,
150 message text NOT NULL,
151 headers text NOT NULL,
152 PRIMARY KEY (id)
153 ) {$charset_collate};";
154
155 dbDelta( $table );
156 }
157 }
158 }
159