NF_VersionSwitcher.php 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280
  1. <?php
  2. final class NF_VersionSwitcher
  3. {
  4. public function __construct()
  5. {
  6. $this->ajax_check();
  7. add_action( 'init', array( $this, 'version_bypass_check' ) );
  8. add_action( 'admin_init', array( $this, 'listener' ) );
  9. add_filter( 'ninja_forms_admin_notices', array( $this, 'upgrade_complete_notice' ) );
  10. if( defined( 'NF_DEV' ) && NF_DEV ) {
  11. add_action('admin_bar_menu', array( $this, 'admin_bar_menu'), 999);
  12. }
  13. }
  14. public function ajax_check()
  15. {
  16. $nf2to3 = isset( $_POST[ 'nf2to3' ] );
  17. $doing_ajax = ( defined( 'DOING_AJAX' ) && DOING_AJAX );
  18. if( $nf2to3 && ! $doing_ajax ){
  19. wp_die(
  20. __( 'You do not have permission.', 'ninja-forms' ),
  21. __( 'Permission Denied', 'ninja-forms' )
  22. );
  23. }
  24. }
  25. public function version_bypass_check()
  26. {
  27. if( ! isset( $_POST[ 'nf2to3' ] ) ) return TRUE;
  28. $capability = apply_filters( 'ninja_forms_admin_version_bypass_capabilities', 'manage_options' );
  29. $current_user_can = current_user_can( $capability );
  30. if( $current_user_can ) return TRUE;
  31. wp_die(
  32. __( 'You do not have permission.', 'ninja-forms' ),
  33. __( 'Permission Denied', 'ninja-forms' )
  34. );
  35. }
  36. public function listener()
  37. {
  38. if( ! current_user_can( apply_filters( 'ninja_forms_admin_version_switcher_capabilities', 'manage_options' ) ) ) return;
  39. if( isset( $_GET[ 'nf-switcher' ] ) ){
  40. $notice = '';
  41. switch( $_GET[ 'nf-switcher' ] ){
  42. case 'upgrade':
  43. update_option( 'ninja_forms_load_deprecated', FALSE );
  44. update_option( 'ninja_forms_upgrade_complete', true );
  45. do_action( 'ninja_forms_upgrade' );
  46. $notice = '&nf-upgrade=complete';
  47. break;
  48. case 'rollback':
  49. update_option( 'ninja_forms_load_deprecated', TRUE );
  50. update_option( 'ninja_forms_upgrade_complete', false );
  51. $this->rollback_activation();
  52. do_action( 'ninja_forms_rollback' );
  53. $notice = '&nf-rollback=complete';
  54. break;
  55. }
  56. header( 'Location: ' . admin_url( 'admin.php?page=ninja-forms' . $notice ) );
  57. }
  58. }
  59. public function admin_bar_menu( $wp_admin_bar )
  60. {
  61. $args = array(
  62. 'id' => 'nf',
  63. 'title' => __( 'Ninja Forms Dev', 'ninja-forms' ),
  64. 'href' => '#',
  65. );
  66. $wp_admin_bar->add_node( $args );
  67. $args = array(
  68. 'id' => 'nf_switcher',
  69. 'href' => admin_url(),
  70. 'parent' => 'nf'
  71. );
  72. if( ! get_option( 'ninja_forms_load_deprecated' ) ) {
  73. $args[ 'title' ] = __( 'DEBUG: Switch to 2.9.x', 'ninja-forms' );
  74. $args[ 'href' ] .= '?nf-switcher=rollback';
  75. } else {
  76. $args[ 'title' ] = __( 'DEBUG: Switch to 3.0.x', 'ninja-forms' );
  77. $args[ 'href' ] .= '?nf-switcher=upgrade';
  78. }
  79. $wp_admin_bar->add_node($args);
  80. }
  81. public function rollback_activation()
  82. {
  83. global $wpdb;
  84. $table_name = $wpdb->prefix . 'nf_objects';
  85. if( $wpdb->get_var( $wpdb->prepare( "SHOW TABLES LIKE %s", $table_name ) ) == $table_name ) return;
  86. if ( ! is_multisite() ) { // This is a single-site activation.
  87. require_once(ABSPATH . 'wp-admin/includes/upgrade.php');
  88. if( ! defined( 'NINJA_FORMS_FAV_FIELDS_TABLE_NAME' ) ){
  89. define( 'NINJA_FORMS_FAV_FIELDS_TABLE_NAME', $wpdb->prefix . 'ninja_forms_fav_fields' );
  90. }
  91. if( ! defined( 'NINJA_FORMS_FIELDS_TABLE_NAME' ) ){
  92. define( 'NINJA_FORMS_FIELDS_TABLE_NAME', $wpdb->prefix . 'ninja_forms_fields' );
  93. }
  94. if( ! defined( 'NF_OBJECT_META_TABLE_NAME' ) ){
  95. define( 'NF_OBJECT_META_TABLE_NAME', $wpdb->prefix .'nf_objectmeta' );
  96. }
  97. if( ! defined( 'NF_OBJECTS_TABLE_NAME' ) ){
  98. define( 'NF_OBJECTS_TABLE_NAME', $wpdb->prefix .'nf_objects' );
  99. }
  100. if( ! defined( 'NF_OBJECT_RELATIONSHIPS_TABLE_NAME' ) ){
  101. define( 'NF_OBJECT_RELATIONSHIPS_TABLE_NAME', $wpdb->prefix .'nf_relationships' );
  102. }
  103. if( ! defined( 'NF_PLUGIN_VERSION' ) ){
  104. define( 'NF_PLUGIN_VERSION', Ninja_Forms::VERSION );
  105. }
  106. $opt = get_option( 'ninja_forms_settings' );
  107. $sql = "CREATE TABLE IF NOT EXISTS ".NINJA_FORMS_FAV_FIELDS_TABLE_NAME." (
  108. `id` int(11) NOT NULL AUTO_INCREMENT,
  109. `row_type` int(11) NOT NULL,
  110. `type` varchar(255) CHARACTER SET utf8 NOT NULL,
  111. `order` int(11) NOT NULL,
  112. `data` longtext CHARACTER SET utf8 NOT NULL,
  113. `name` varchar(255) CHARACTER SET utf8 NOT NULL,
  114. PRIMARY KEY (`id`)
  115. ) DEFAULT CHARSET=utf8;";
  116. dbDelta($sql);
  117. $state_dropdown = $wpdb->get_row( $wpdb->prepare( "SELECT * FROM ".NINJA_FORMS_FAV_FIELDS_TABLE_NAME." WHERE name = %s AND row_type = 0", 'State Dropdown' ), ARRAY_A );
  118. if( !isset($state_dropdown['id']) ){
  119. $sql = 'INSERT INTO `'.NINJA_FORMS_FAV_FIELDS_TABLE_NAME.'` (`id`, `row_type`, `type`, `order`, `data`, `name`) VALUES
  120. (2, 0, \'_list\', 0, \'a:10:{s:5:\"label\";s:14:\"State Dropdown\";s:9:\"label_pos\";s:4:\"left\";s:9:\"list_type\";s:8:\"dropdown\";s:10:\"multi_size\";s:1:\"5\";s:15:\"list_show_value\";s:1:\"1\";s:4:\"list\";a:1:{s:7:\"options\";a:51:{i:0;a:3:{s:5:\"label\";s:7:\"Alabama\";s:5:\"value\";s:2:\"AL\";s:8:\"selected\";s:1:\"0\";}i:1;a:3:{s:5:\"label\";s:6:\"Alaska\";s:5:\"value\";s:2:\"AK\";s:8:\"selected\";s:1:\"0\";}i:2;a:3:{s:5:\"label\";s:7:\"Arizona\";s:5:\"value\";s:2:\"AZ\";s:8:\"selected\";s:1:\"0\";}i:3;a:3:{s:5:\"label\";s:8:\"Arkansas\";s:5:\"value\";s:2:\"AR\";s:8:\"selected\";s:1:\"0\";}i:4;a:3:{s:5:\"label\";s:10:\"California\";s:5:\"value\";s:2:\"CA\";s:8:\"selected\";s:1:\"0\";}i:5;a:3:{s:5:\"label\";s:8:\"Colorado\";s:5:\"value\";s:2:\"CO\";s:8:\"selected\";s:1:\"0\";}i:6;a:3:{s:5:\"label\";s:11:\"Connecticut\";s:5:\"value\";s:2:\"CT\";s:8:\"selected\";s:1:\"0\";}i:7;a:3:{s:5:\"label\";s:8:\"Delaware\";s:5:\"value\";s:2:\"DE\";s:8:\"selected\";s:1:\"0\";}i:8;a:3:{s:5:\"label\";s:20:\"District of Columbia\";s:5:\"value\";s:2:\"DC\";s:8:\"selected\";s:1:\"0\";}i:9;a:3:{s:5:\"label\";s:7:\"Florida\";s:5:\"value\";s:2:\"FL\";s:8:\"selected\";s:1:\"0\";}i:10;a:3:{s:5:\"label\";s:7:\"Georgia\";s:5:\"value\";s:2:\"GA\";s:8:\"selected\";s:1:\"0\";}i:11;a:3:{s:5:\"label\";s:6:\"Hawaii\";s:5:\"value\";s:2:\"HI\";s:8:\"selected\";s:1:\"0\";}i:12;a:3:{s:5:\"label\";s:5:\"Idaho\";s:5:\"value\";s:2:\"ID\";s:8:\"selected\";s:1:\"0\";}i:13;a:3:{s:5:\"label\";s:8:\"Illinois\";s:5:\"value\";s:2:\"IL\";s:8:\"selected\";s:1:\"0\";}i:14;a:3:{s:5:\"label\";s:7:\"Indiana\";s:5:\"value\";s:2:\"IN\";s:8:\"selected\";s:1:\"0\";}i:15;a:3:{s:5:\"label\";s:4:\"Iowa\";s:5:\"value\";s:2:\"IA\";s:8:\"selected\";s:1:\"0\";}i:16;a:3:{s:5:\"label\";s:6:\"Kansas\";s:5:\"value\";s:2:\"KS\";s:8:\"selected\";s:1:\"0\";}i:17;a:3:{s:5:\"label\";s:8:\"Kentucky\";s:5:\"value\";s:2:\"KY\";s:8:\"selected\";s:1:\"0\";}i:18;a:3:{s:5:\"label\";s:9:\"Louisiana\";s:5:\"value\";s:2:\"LA\";s:8:\"selected\";s:1:\"0\";}i:19;a:3:{s:5:\"label\";s:5:\"Maine\";s:5:\"value\";s:2:\"ME\";s:8:\"selected\";s:1:\"0\";}i:20;a:3:{s:5:\"label\";s:8:\"Maryland\";s:5:\"value\";s:2:\"MD\";s:8:\"selected\";s:1:\"0\";}i:21;a:3:{s:5:\"label\";s:13:\"Massachusetts\";s:5:\"value\";s:2:\"MA\";s:8:\"selected\";s:1:\"0\";}i:22;a:3:{s:5:\"label\";s:8:\"Michigan\";s:5:\"value\";s:2:\"MI\";s:8:\"selected\";s:1:\"0\";}i:23;a:3:{s:5:\"label\";s:9:\"Minnesota\";s:5:\"value\";s:2:\"MN\";s:8:\"selected\";s:1:\"0\";}i:24;a:3:{s:5:\"label\";s:11:\"Mississippi\";s:5:\"value\";s:2:\"MS\";s:8:\"selected\";s:1:\"0\";}i:25;a:3:{s:5:\"label\";s:8:\"Missouri\";s:5:\"value\";s:2:\"MO\";s:8:\"selected\";s:1:\"0\";}i:26;a:3:{s:5:\"label\";s:7:\"Montana\";s:5:\"value\";s:2:\"MT\";s:8:\"selected\";s:1:\"0\";}i:27;a:3:{s:5:\"label\";s:8:\"Nebraska\";s:5:\"value\";s:2:\"NE\";s:8:\"selected\";s:1:\"0\";}i:28;a:3:{s:5:\"label\";s:6:\"Nevada\";s:5:\"value\";s:2:\"NV\";s:8:\"selected\";s:1:\"0\";}i:29;a:3:{s:5:\"label\";s:13:\"New Hampshire\";s:5:\"value\";s:2:\"NH\";s:8:\"selected\";s:1:\"0\";}i:30;a:3:{s:5:\"label\";s:10:\"New Jersey\";s:5:\"value\";s:2:\"NJ\";s:8:\"selected\";s:1:\"0\";}i:31;a:3:{s:5:\"label\";s:10:\"New Mexico\";s:5:\"value\";s:2:\"NM\";s:8:\"selected\";s:1:\"0\";}i:32;a:3:{s:5:\"label\";s:8:\"New York\";s:5:\"value\";s:2:\"NY\";s:8:\"selected\";s:1:\"0\";}i:33;a:3:{s:5:\"label\";s:14:\"North Carolina\";s:5:\"value\";s:2:\"NC\";s:8:\"selected\";s:1:\"0\";}i:34;a:3:{s:5:\"label\";s:12:\"North Dakota\";s:5:\"value\";s:2:\"ND\";s:8:\"selected\";s:1:\"0\";}i:35;a:3:{s:5:\"label\";s:4:\"Ohio\";s:5:\"value\";s:2:\"OH\";s:8:\"selected\";s:1:\"0\";}i:36;a:3:{s:5:\"label\";s:8:\"Oklahoma\";s:5:\"value\";s:2:\"OK\";s:8:\"selected\";s:1:\"0\";}i:37;a:3:{s:5:\"label\";s:6:\"Oregon\";s:5:\"value\";s:2:\"OR\";s:8:\"selected\";s:1:\"0\";}i:38;a:3:{s:5:\"label\";s:12:\"Pennsylvania\";s:5:\"value\";s:2:\"PA\";s:8:\"selected\";s:1:\"0\";}i:39;a:3:{s:5:\"label\";s:12:\"Rhode Island\";s:5:\"value\";s:2:\"RI\";s:8:\"selected\";s:1:\"0\";}i:40;a:3:{s:5:\"label\";s:14:\"South Carolina\";s:5:\"value\";s:2:\"SC\";s:8:\"selected\";s:1:\"0\";}i:41;a:3:{s:5:\"label\";s:12:\"South Dakota\";s:5:\"value\";s:2:\"SD\";s:8:\"selected\";s:1:\"0\";}i:42;a:3:{s:5:\"label\";s:9:\"Tennessee\";s:5:\"value\";s:2:\"TN\";s:8:\"selected\";s:1:\"0\";}i:43;a:3:{s:5:\"label\";s:5:\"Texas\";s:5:\"value\";s:2:\"TX\";s:8:\"selected\";s:1:\"0\";}i:44;a:3:{s:5:\"label\";s:4:\"Utah\";s:5:\"value\";s:2:\"UT\";s:8:\"selected\";s:1:\"0\";}i:45;a:3:{s:5:\"label\";s:7:\"Vermont\";s:5:\"value\";s:2:\"VT\";s:8:\"selected\";s:1:\"0\";}i:46;a:3:{s:5:\"label\";s:8:\"Virginia\";s:5:\"value\";s:2:\"VA\";s:8:\"selected\";s:1:\"0\";}i:47;a:3:{s:5:\"label\";s:10:\"Washington\";s:5:\"value\";s:2:\"WA\";s:8:\"selected\";s:1:\"0\";}i:48;a:3:{s:5:\"label\";s:13:\"West Virginia\";s:5:\"value\";s:2:\"WV\";s:8:\"selected\";s:1:\"0\";}i:49;a:3:{s:5:\"label\";s:9:\"Wisconsin\";s:5:\"value\";s:2:\"WI\";s:8:\"selected\";s:1:\"0\";}i:50;a:3:{s:5:\"label\";s:7:\"Wyoming\";s:5:\"value\";s:2:\"WY\";s:8:\"selected\";s:1:\"0\";}}}s:3:\"req\";s:1:\"0\";s:5:\"class\";s:0:\"\";s:9:\"show_help\";s:1:\"0\";s:9:\"help_text\";s:0:\"\";}\', \'State Dropdown\')';
  121. $wpdb->query($sql);
  122. }
  123. $anti_spam = $wpdb->get_row( $wpdb->prepare( "SELECT * FROM ".NINJA_FORMS_FAV_FIELDS_TABLE_NAME." WHERE name = %s AND row_type = 0", 'Anti-Spam' ), ARRAY_A );
  124. if( !isset($anti_spam['id']) ){
  125. $sql = 'INSERT INTO `'.NINJA_FORMS_FAV_FIELDS_TABLE_NAME.'` (`id`, `row_type`, `type`, `order`, `data`, `name`) VALUES
  126. (3, 0, \'_spam\', 0, \'a:6:{s:9:"label_pos";s:4:"left";s:5:"label";s:18:"Anti-Spam Question";s:6:"answer";s:16:"Anti-Spam Answer";s:5:"class";s:0:"";s:9:"show_help";s:1:"0";s:9:"help_text";s:0:"";}\', \'Anti-Spam\')';
  127. $wpdb->query($sql);
  128. }
  129. $submit = $wpdb->get_row( $wpdb->prepare( "SELECT * FROM ".NINJA_FORMS_FAV_FIELDS_TABLE_NAME." WHERE name = %s AND row_type = 0", 'Submit' ), ARRAY_A );
  130. if( !isset($submit['id']) ){
  131. $sql = 'INSERT INTO `'.NINJA_FORMS_FAV_FIELDS_TABLE_NAME.'` (`id`, `row_type`, `type`, `order`, `data`, `name`) VALUES
  132. (4, 0, \'_submit\', 0, \'a:4:{s:5:\"label\";s:6:\"Submit\";s:5:\"class\";s:0:\"\";s:9:\"show_help\";s:1:\"0\";s:9:\"help_text\";s:0:\"\";}\', \'Submit\');';
  133. $wpdb->query($sql);
  134. }
  135. $sql = "CREATE TABLE IF NOT EXISTS ".NINJA_FORMS_FIELDS_TABLE_NAME." (
  136. `id` int(11) NOT NULL AUTO_INCREMENT,
  137. `form_id` int(11) NOT NULL,
  138. `type` varchar(255) CHARACTER SET utf8 NOT NULL,
  139. `order` int(11) NOT NULL,
  140. `data` longtext CHARACTER SET utf8 NOT NULL,
  141. `fav_id` int(11) DEFAULT NULL,
  142. `def_id` int(11) DEFAULT NULL,
  143. PRIMARY KEY (`id`)
  144. ) DEFAULT CHARSET=utf8 ;";
  145. dbDelta($sql);
  146. /**
  147. * Add our table structure for version 2.8.
  148. */
  149. // Create our object meta table
  150. $sql = "CREATE TABLE IF NOT EXISTS ". NF_OBJECT_META_TABLE_NAME . " (
  151. `id` bigint(20) NOT NULL AUTO_INCREMENT,
  152. `object_id` bigint(20) NOT NULL,
  153. `meta_key` varchar(255) NOT NULL,
  154. `meta_value` longtext NOT NULL,
  155. PRIMARY KEY (`id`)
  156. ) DEFAULT CHARSET=utf8;";
  157. dbDelta( $sql );
  158. // Create our object table
  159. $sql = "CREATE TABLE IF NOT EXISTS " . NF_OBJECTS_TABLE_NAME . " (
  160. `id` bigint(20) NOT NULL AUTO_INCREMENT,
  161. `type` varchar(255) NOT NULL,
  162. PRIMARY KEY (`id`)
  163. ) DEFAULT CHARSET=utf8;";
  164. dbDelta( $sql );
  165. // Create our object relationships table
  166. $sql = "CREATE TABLE IF NOT EXISTS " . NF_OBJECT_RELATIONSHIPS_TABLE_NAME . " (
  167. `id` bigint(20) NOT NULL AUTO_INCREMENT,
  168. `child_id` bigint(20) NOT NULL,
  169. `parent_id` bigint(20) NOT NULL,
  170. `child_type` varchar(255) NOT NULL,
  171. `parent_type` varchar(255) NOT NULL,
  172. PRIMARY KEY (`id`)
  173. ) DEFAULT CHARSET=utf8;";
  174. dbDelta( $sql );
  175. $title = apply_filters( 'ninja_forms_preview_page_title', 'ninja_forms_preview_page' );
  176. $preview_page = get_page_by_title( $title );
  177. if( !$preview_page ) {
  178. // Create preview page object
  179. $preview_post = array(
  180. 'post_title' => $title,
  181. 'post_content' => 'This is a preview of how this form will appear on your website',
  182. 'post_status' => 'draft',
  183. 'post_type' => 'page'
  184. );
  185. // Insert the page into the database
  186. $page_id = wp_insert_post( $preview_post );
  187. }else{
  188. $page_id = $preview_page->ID;
  189. }
  190. $opt['preview_id'] = $page_id;
  191. $current_settings = get_option( 'ninja_forms_settings', false );
  192. if ( ! $current_settings ) {
  193. update_option( 'nf_convert_notifications_complete', true );
  194. update_option( 'nf_convert_subs_step', 'complete' );
  195. update_option( 'nf_upgrade_notice', 'closed' );
  196. update_option( 'nf_update_email_settings_complete', true );
  197. update_option( 'nf_email_fav_updated', true );
  198. update_option( 'nf_convert_forms_complete', true );
  199. update_option( 'nf_database_migrations', true );
  200. }
  201. update_option( "ninja_forms_settings", $opt );
  202. update_option( 'ninja_forms_version', '2.9.56.2' );
  203. } else { // We're network activating.
  204. header( 'Location: ' . network_admin_url( 'plugins.php?deactivate=true&nf_action=network_activation_error' ) );
  205. exit;
  206. }
  207. }
  208. public function upgrade_complete_notice( $notices )
  209. {
  210. if( get_option( 'ninja_forms_upgrade_complete', false ) ){
  211. // Persistance notice, until dismissed.
  212. $notices[ 'upgrade_compelte_notice' ] = array(
  213. 'title' => __( 'How do I look?', 'ninja-forms' ),
  214. 'msg' => __( 'Your forms were upgraded. Take a look around and make sure everything looks right.', 'ninja-forms' ),
  215. 'link' => '<li><span class="dashicons dashicons-welcome-learn-more"></span><a target="_blank" href="https://ninjaforms.com/documentation/?utm_medium=plugin&utm_source=admin-notice&utm_campaign=Ninja+Forms+Upsell&utm_content=Ninja+Forms+Docs">' . __( 'Learn More', 'ninja-forms' ) . '</a></li>
  216. <li><span class="dashicons dashicons-sos"></span><a target="_blank" href="https://ninjaforms.com/docs/rollback/">' . __( 'Something is wrong...', 'ninja-forms' ) . '</a></li>
  217. <li><span class="dashicons dashicons-thumbs-up"></span><a href="' . add_query_arg( array( 'nf_admin_notice_ignore' => __( 'upgrade_compelte_notice', 'ninja-forms' ) ) ) . '">' . __( 'Looks Good!' ,'ninja-forms' ) . '</a></li>',
  218. 'int' => 0,
  219. 'pages' => array( 'ninja-forms' )
  220. );
  221. }
  222. return $notices;
  223. }
  224. }
  225. new NF_VersionSwitcher();