PageRenderTime 39ms CodeModel.GetById 11ms RepoModel.GetById 0ms app.codeStats 0ms

/plugins/gravityforms/settings.php

https://github.com/petergibbons/OpenCounterWP
PHP | 403 lines | 345 code | 51 blank | 7 comment | 44 complexity | 994fedbe751588d3848afc3af59488b6 MD5 | raw file
  1. <?php
  2. class GFSettings{
  3. public static $addon_pages = array();
  4. public static function add_settings_page($name, $handler, $icon_path){
  5. add_action("gform_settings_" . str_replace(" " , "_", $name), $handler);
  6. self::$addon_pages[$name] = array("name" => $name, "icon" => $icon_path);
  7. }
  8. public static function settings_page(){
  9. $addon_name = RGForms::get("addon");
  10. $icon_path = empty($addon_name) ? "" : self::$addon_pages[$addon_name]["icon"];
  11. $page_title = empty($addon_name) ? __("Gravity Forms Settings", "gravityforms") : $addon_name . " " . __("Settings", "gravityforms");
  12. $icon_path = empty($icon_path) ? GFCommon::get_base_url() . "/images/gravity-settings-icon-32.png" : $icon_path;
  13. echo GFCommon::get_remote_message();
  14. ?>
  15. <link rel="stylesheet" href="<?php echo GFCommon::get_base_url()?>/css/admin.css" />
  16. <div class="wrap">
  17. <div class="icon32" id="gravity-settings-icon"><br></div>
  18. <h2><?php echo $page_title ?></h2>
  19. <?php
  20. if(!empty(self::$addon_pages)){
  21. ?>
  22. <ul class="subsubsub">
  23. <li><a href="?page=gf_settings">Gravity Forms</a> |</li>
  24. <?php
  25. $count = sizeof(self::$addon_pages);
  26. for($i = 0; $i<$count; $i++){
  27. $addon_keys = array_keys(self::$addon_pages);
  28. $addon = $addon_keys[$i];
  29. ?>
  30. <li><a href="?page=gf_settings&addon=<?php echo urlencode($addon) ?>"><?php echo esc_html($addon) ?></a> <?php echo $i < $count-1 ? "|" : ""?></li>
  31. <?php
  32. }
  33. ?>
  34. </ul>
  35. <br style="clear:both;"/>
  36. <?php
  37. }
  38. if(empty($addon_name)){
  39. self::gravityforms_settings_page();
  40. }
  41. else{
  42. do_action("gform_settings_" . str_replace(" ", "_", $addon_name));
  43. }
  44. }
  45. public static function gravityforms_settings_page(){
  46. global $wpdb;
  47. if(!GFCommon::ensure_wp_version())
  48. return;
  49. if(isset($_GET["setup"])){
  50. //forcing setup
  51. RGForms::setup(true);
  52. }
  53. if(isset($_POST["submit"])){
  54. check_admin_referer('gforms_update_settings', 'gforms_update_settings');
  55. if(!GFCommon::current_user_can_any("gravityforms_edit_settings"))
  56. die(__("You don't have adequate permission to edit settings.", "gravityforms"));
  57. RGFormsModel::save_key($_POST["gforms_key"]);
  58. update_option("rg_gforms_disable_css", $_POST["gforms_disable_css"]);
  59. update_option("rg_gforms_enable_html5", $_POST["gforms_enable_html5"]);
  60. update_option("gform_enable_noconflict", $_POST["gform_enable_noconflict"]);
  61. update_option("rg_gforms_enable_akismet", $_POST["gforms_enable_akismet"]);
  62. update_option("rg_gforms_captcha_public_key", $_POST["gforms_captcha_public_key"]);
  63. update_option("rg_gforms_captcha_private_key", $_POST["gforms_captcha_private_key"]);
  64. if(!rgempty("gforms_currency"))
  65. update_option("rg_gforms_currency", rgpost("gforms_currency"));
  66. //Updating message because key could have been changed
  67. GFCommon::cache_remote_message();
  68. //Re-caching version info
  69. $version_info = GFCommon::get_version_info(false);
  70. ?>
  71. <div class="updated fade" style="padding:6px;">
  72. <?php _e("Settings Updated", "gravityforms"); ?>.
  73. </div>
  74. <?php
  75. }
  76. else if(isset($_POST["uninstall"])){
  77. if(!GFCommon::current_user_can_any("gravityforms_uninstall") || (function_exists("is_multisite") && is_multisite() && !is_super_admin()))
  78. die(__("You don't have adequate permission to uninstall Gravity Forms.", "gravityforms"));
  79. //droping all tables
  80. RGFormsModel::drop_tables();
  81. //removing options
  82. delete_option("rg_form_version");
  83. delete_option("rg_gforms_key");
  84. delete_option("rg_gforms_disable_css");
  85. delete_option("rg_gforms_enable_html5");
  86. delete_option("rg_gforms_captcha_public_key");
  87. delete_option("rg_gforms_captcha_private_key");
  88. delete_option("rg_gforms_message");
  89. delete_option("gf_dismissed_upgrades");
  90. delete_option("rg_gforms_currency");
  91. //removing gravity forms upload folder
  92. GFCommon::delete_directory(RGFormsModel::get_upload_root());
  93. //Deactivating plugin
  94. $plugin = "gravityforms/gravityforms.php";
  95. deactivate_plugins($plugin);
  96. update_option('recently_activated', array($plugin => time()) + (array)get_option('recently_activated'));
  97. ?>
  98. <div class="updated fade" style="padding:20px;"><?php echo sprintf(__("Gravity Forms have been successfully uninstalled. It can be re-activated from the %splugins page%s.", "gravityforms"), "<a href='plugins.php'>","</a>")?></div>
  99. <?php
  100. return;
  101. }
  102. if(!isset($version_info))
  103. $version_info = GFCommon::get_version_info();
  104. ?>
  105. <form method="post">
  106. <?php wp_nonce_field('gforms_update_settings', 'gforms_update_settings') ?>
  107. <h3><?php _e("General Settings", "gravityforms"); ?></h3>
  108. <table class="form-table">
  109. <tr valign="top">
  110. <th scope="row"><label for="gforms_key"><?php _e("Support License Key", "gravityforms"); ?></label> <?php gform_tooltip("settings_license_key") ?></th>
  111. <td>
  112. <?php
  113. $key = GFCommon::get_key();
  114. $key_field = '<input type="password" name="gforms_key" id="gforms_key" style="width:350px;" value="' . $key . '" />';
  115. if($version_info["is_valid_key"])
  116. $key_field .= "&nbsp;<img src='" . GFCommon::get_base_url() ."/images/tick.png' class='gf_keystatus_valid' alt='valid key' title='valid key'/>";
  117. else if (!empty($key))
  118. $key_field .= "&nbsp;<img src='" . GFCommon::get_base_url() ."/images/cross.png' class='gf_keystatus_invalid' alt='invalid key' title='invalid key'/>";
  119. echo apply_filters('gform_settings_key_field', $key_field);
  120. ?>
  121. <br />
  122. <?php _e("The license key is used for access to automatic upgrades and support.", "gravityforms"); ?>
  123. </td>
  124. </tr>
  125. <tr valign="top">
  126. <th scope="row"><label for="gforms_disable_css"><?php _e("Output CSS", "gravityforms"); ?></label> <?php gform_tooltip("settings_output_css") ?></th>
  127. <td>
  128. <input type="radio" name="gforms_disable_css" value="0" id="gforms_css_output_enabled" <?php echo get_option('rg_gforms_disable_css') == 1 ? "" : "checked='checked'" ?> /> <?php _e("Yes", "gravityforms"); ?>&nbsp;&nbsp;
  129. <input type="radio" name="gforms_disable_css" value="1" id="gforms_css_output_disabled" <?php echo get_option('rg_gforms_disable_css') == 1 ? "checked='checked'" : "" ?> /> <?php _e("No", "gravityforms"); ?><br />
  130. <?php _e("Set this to No if you would like to disable the plugin from outputting the form CSS.", "gravityforms"); ?>
  131. </td>
  132. </tr>
  133. <tr valign="top">
  134. <th scope="row"><label for="gforms_enable_html5"><?php _e("Output HTML5", "gravityforms"); ?></label> <?php gform_tooltip("settings_html5") ?></th>
  135. <td>
  136. <input type="radio" name="gforms_enable_html5" value="1" <?php echo get_option('rg_gforms_enable_html5') == 1 ? "checked='checked'" : "" ?> id="gforms_enable_html5"/> <?php _e("Yes", "gravityforms"); ?>&nbsp;&nbsp;
  137. <input type="radio" name="gforms_enable_html5" value="0" <?php echo get_option('rg_gforms_enable_html5') == 1 ? "" : "checked='checked'" ?> /> <?php _e("No", "gravityforms"); ?><br />
  138. <?php _e("Set this to No if you would like to disable the plugin from outputting HTML5 form fields.", "gravityforms"); ?>
  139. </td>
  140. </tr>
  141. <tr valign="top">
  142. <th scope="row"><label for="gform_enable_noconflict"><?php _e("No-Conflict Mode", "gravityforms"); ?></label> <?php gform_tooltip("settings_noconflict") ?></th>
  143. <td>
  144. <input type="radio" name="gform_enable_noconflict" value="1" <?php echo get_option('gform_enable_noconflict') == 1 ? "checked='checked'" : "" ?> id="gform_enable_noconflict"/> <?php _e("On", "gravityforms"); ?>&nbsp;&nbsp;
  145. <input type="radio" name="gform_enable_noconflict" value="0" <?php echo get_option('gform_enable_noconflict') == 1 ? "" : "checked='checked'" ?> id="gform_disable_noconflict"/> <?php _e("Off", "gravityforms"); ?><br />
  146. <?php _e("Set this to On to prevent extraneous scripts and styles from being printed on Gravity Forms admin pages, reducing conflicts with other plugins and themes.", "gravityforms"); ?>
  147. </td>
  148. </tr>
  149. <?php if(GFCommon::has_akismet()){ ?>
  150. <tr valign="top">
  151. <th scope="row"><label for="gforms_enable_akismet"><?php _e("Akismet Integration", "gravityforms"); ?></label> <?php gform_tooltip("settings_akismet") ?></th>
  152. <td>
  153. <input type="radio" name="gforms_enable_akismet" value="1" <?php echo get_option('rg_gforms_enable_akismet') == 1 ? "checked='checked'" : "" ?> id="gforms_enable_akismet"/> <?php _e("Yes", "gravityforms"); ?>&nbsp;&nbsp;
  154. <input type="radio" name="gforms_enable_akismet" value="0" <?php echo get_option('rg_gforms_enable_akismet') == 1 ? "" : "checked='checked'" ?> /> <?php _e("No", "gravityforms"); ?><br />
  155. <?php _e("Protect your form entries from spam using Akismet.", "gravityforms"); ?>
  156. </td>
  157. </tr>
  158. <?php } ?>
  159. <tr valign="top">
  160. <th scope="row"><label for="gforms_currency"><?php _e("Currency", "gravityforms"); ?></label> <?php gform_tooltip("settings_currency") ?></th>
  161. <td>
  162. <?php
  163. $disabled = apply_filters("gform_currency_disabled", false) ? "disabled='disabled'" : ""
  164. ?>
  165. <select id="gforms_currency" name="gforms_currency" <?php echo $disabled ?>>
  166. <?php
  167. require_once("currency.php");
  168. $current_currency = GFCommon::get_currency();
  169. foreach(RGCurrency::get_currencies() as $code => $currency){
  170. ?>
  171. <option value="<?php echo $code ?>" <?php echo $current_currency == $code ? "selected='selected'" : "" ?>><?php echo $currency["name"]?></option>
  172. <?php
  173. }
  174. ?>
  175. </select>
  176. <?php do_action("gform_currency_setting_message", ""); ?>
  177. </td>
  178. </tr>
  179. </table>
  180. <div class="hr-divider"></div>
  181. <h3><?php _e("reCAPTCHA Settings", "gravityforms"); ?></h3>
  182. <p style="text-align: left;"><?php _e("Gravity Forms integrates with reCAPTCHA, a free CAPTCHA service that helps to digitize books while protecting your forms from spam bots. ", "gravityforms"); ?><a href="http://www.google.com/recaptcha/" target="_blank"><?php _e("Read more about reCAPTCHA", "gravityforms"); ?></a>.</p>
  183. <table class="form-table">
  184. <tr valign="top">
  185. <th scope="row"><label for="gforms_captcha_public_key"><?php _e("reCAPTCHA Public Key", "gravityforms"); ?></label> <?php gform_tooltip("settings_recaptcha_public") ?></th>
  186. <td>
  187. <input type="text" name="gforms_captcha_public_key" style="width:350px;" value="<?php echo get_option("rg_gforms_captcha_public_key") ?>" /><br />
  188. <?php _e("Required only if you decide to use the reCAPTCHA field.", "gravityforms"); ?> <?php printf(__("%sSign up%s for a free account to get the key.", "gravityforms"), '<a target="_blank" href="http://www.google.com/recaptcha/whyrecaptcha">', '</a>'); ?>
  189. </td>
  190. </tr>
  191. <tr valign="top">
  192. <th scope="row"><label for="gforms_captcha_private_key"><?php _e("reCAPTCHA Private Key", "gravityforms"); ?></label> <?php gform_tooltip("settings_recaptcha_private") ?></th>
  193. <td>
  194. <input type="text" name="gforms_captcha_private_key" style="width:350px;" value="<?php echo esc_attr(get_option("rg_gforms_captcha_private_key")) ?>" /><br />
  195. <?php _e("Required only if you decide to use the reCAPTCHA field.", "gravityforms"); ?> <?php printf(__("%sSign up%s for a free account to get the key.", "gravityforms"), '<a target="_blank" href="http://www.google.com/recaptcha/whyrecaptcha">', '</a>'); ?>
  196. </td>
  197. </tr>
  198. </table>
  199. <?php if(GFCommon::current_user_can_any("gravityforms_edit_settings")){ ?>
  200. <br/><br/>
  201. <p class="submit" style="text-align: left;">
  202. <?php
  203. $save_button = '<input type="submit" name="submit" value="' . __("Save Settings", "gravityforms"). '" class="button-primary gf_settings_savebutton"/>';
  204. echo apply_filters("gform_settings_save_button", $save_button);
  205. ?>
  206. </p>
  207. <?php } ?>
  208. </form>
  209. <div id='gform_upgrade_license' style="display:none;"></div>
  210. <script type="text/javascript">
  211. jQuery(document).ready(function(){
  212. jQuery.post(ajaxurl,{
  213. action:"gf_upgrade_license",
  214. gf_upgrade_license: "<?php echo wp_create_nonce("gf_upgrade_license") ?>",
  215. cookie: encodeURIComponent(document.cookie)},
  216. function(data){
  217. if(data.trim().length > 0)
  218. jQuery("#gform_upgrade_license").replaceWith(data);
  219. }
  220. );
  221. });
  222. </script>
  223. <div class="hr-divider"></div>
  224. <h3><?php _e("Installation Status", "gravityforms"); ?></h3>
  225. <table class="form-table">
  226. <tr valign="top">
  227. <th scope="row"><label><?php _e("PHP Version", "gravityforms"); ?></label></th>
  228. <td class="installation_item_cell">
  229. <strong><?php echo phpversion(); ?></strong>
  230. </td>
  231. <td>
  232. <?php
  233. if(version_compare(phpversion(), '5.0.0', '>')){
  234. ?>
  235. <img src="<?php echo GFCommon::get_base_url() ?>/images/tick.png"/>
  236. <?php
  237. }
  238. else{
  239. ?>
  240. <img src="<?php echo GFCommon::get_base_url() ?>/images/cross.png"/>
  241. <span class="installation_item_message"><?php _e("Gravity Forms requires PHP 5 or above.", "gravityforms"); ?></span>
  242. <?php
  243. }
  244. ?>
  245. </td>
  246. </tr>
  247. <tr valign="top">
  248. <th scope="row"><label><?php _e("MySQL Version", "gravityforms"); ?></label></th>
  249. <td class="installation_item_cell">
  250. <strong><?php echo $wpdb->db_version();?></strong>
  251. </td>
  252. <td>
  253. <?php
  254. if(version_compare($wpdb->db_version(), '5.0.0', '>')){
  255. ?>
  256. <img src="<?php echo GFCommon::get_base_url() ?>/images/tick.png"/>
  257. <?php
  258. }
  259. else{
  260. ?>
  261. <img src="<?php echo GFCommon::get_base_url() ?>/images/cross.png"/>
  262. <span class="installation_item_message"><?php _e("Gravity Forms requires MySQL 5 or above.", "gravityforms"); ?></span>
  263. <?php
  264. }
  265. ?>
  266. </td>
  267. </tr>
  268. <tr valign="top">
  269. <th scope="row"><label><?php _e("WordPress Version", "gravityforms"); ?></label></th>
  270. <td class="installation_item_cell">
  271. <strong><?php echo get_bloginfo("version"); ?></strong>
  272. </td>
  273. <td>
  274. <?php
  275. if(version_compare(get_bloginfo("version"), '3.0', '>')){
  276. ?>
  277. <img src="<?php echo GFCommon::get_base_url() ?>/images/tick.png"/>
  278. <?php
  279. }
  280. else{
  281. ?>
  282. <img src="<?php echo GFCommon::get_base_url() ?>/images/cross.png"/>
  283. <span class="installation_item_message"><?php _e("Gravity Forms requires WordPress 3.0 or above.", "gravityforms"); ?></span>
  284. <?php
  285. }
  286. ?>
  287. </td>
  288. </tr>
  289. <tr valign="top">
  290. <th scope="row"><label><?php _e("Gravity Forms Version", "gravityforms"); ?></label></th>
  291. <td class="installation_item_cell">
  292. <strong><?php echo GFCommon::$version ?></strong>
  293. </td>
  294. <td>
  295. <?php
  296. if(version_compare(GFCommon::$version, $version_info["version"], '>=')){
  297. ?>
  298. <img src="<?php echo GFCommon::get_base_url() ?>/images/tick.png"/>
  299. <?php
  300. }
  301. else{
  302. echo sprintf(__("New version %s available. Automatic upgrade available on the %splugins page%s", "gravityforms"), $version_info["version"], '<a href="plugins.php">', '</a>');
  303. }
  304. ?>
  305. </td>
  306. </tr>
  307. </table>
  308. <form action="" method="post">
  309. <?php if(GFCommon::current_user_can_any("gravityforms_uninstall") && (!function_exists("is_multisite") || !is_multisite() || is_super_admin())){ ?>
  310. <div class="hr-divider"></div>
  311. <h3><?php _e("Uninstall Gravity Forms", "gravityforms") ?></h3>
  312. <div class="delete-alert alert_red"><h3><?php _e("Warning", "gravityforms") ?></h3><p><?php _e("This operation deletes ALL Gravity Forms data. If you continue, You will not be able to retrieve or restore your forms or entries.", "gravityforms") ?></p>
  313. <?php
  314. $uninstall_button = '<input type="submit" name="uninstall" value="' . __("Uninstall Gravity Forms", "gravityforms") . '" class="button" onclick="return confirm(\'' . __("Warning! ALL Gravity Forms data, including form entries will be deleted. This cannot be undone. \'OK\' to delete, \'Cancel\' to stop", "gravityforms") . '\');"/>';
  315. echo apply_filters("gform_uninstall_button", $uninstall_button);
  316. ?>
  317. </div>
  318. <?php } ?>
  319. </form>
  320. <?php
  321. }
  322. public static function upgrade_license(){
  323. //check_ajax_referer('gf_upgrade_license','gf_upgrade_license');
  324. $key = GFCommon::get_key();
  325. $body = "key=$key";
  326. $options = array('method' => 'POST', 'timeout' => 3, 'body' => $body);
  327. $options['headers'] = array(
  328. 'Content-Type' => 'application/x-www-form-urlencoded; charset=' . get_option('blog_charset'),
  329. 'Content-Length' => strlen($body),
  330. 'User-Agent' => 'WordPress/' . get_bloginfo("version"),
  331. 'Referer' => get_bloginfo("url")
  332. );
  333. $request_url = GRAVITY_MANAGER_URL . "/api.php?op=upgrade_message&key=" . GFCommon::get_key();
  334. $raw_response = wp_remote_request($request_url, $options);
  335. if ( is_wp_error( $raw_response ) || 200 != $raw_response['response']['code'] )
  336. $message = "";
  337. else
  338. $message = $raw_response['body'];
  339. //validating that message is a valid Gravity Form message. If message is invalid, don't display anything
  340. if(substr($message, 0, 10) != "<!--GFM-->")
  341. $message = "";
  342. echo $message;
  343. exit;
  344. }
  345. }
  346. ?>