class-yoast-plugin-conflict-ajax.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. <?php
  2. /**
  3. * WPSEO plugin file.
  4. *
  5. * @package WPSEO\Admin\Ajax
  6. */
  7. /**
  8. * Class Yoast_Plugin_Conflict_Ajax
  9. */
  10. class Yoast_Plugin_Conflict_Ajax {
  11. /**
  12. * @var string
  13. */
  14. private $option_name = 'wpseo_dismissed_conflicts';
  15. /**
  16. * @var array
  17. */
  18. private $dismissed_conflicts = array();
  19. /**
  20. * Initialize the hooks for the AJAX request
  21. */
  22. public function __construct() {
  23. add_action( 'wp_ajax_wpseo_dismiss_plugin_conflict', array( $this, 'dismiss_notice' ) );
  24. }
  25. /**
  26. * Handles the dismiss notice request
  27. */
  28. public function dismiss_notice() {
  29. check_ajax_referer( 'dismiss-plugin-conflict' );
  30. $conflict_data = filter_input( INPUT_POST, 'data', FILTER_DEFAULT, FILTER_REQUIRE_ARRAY );
  31. $this->dismissed_conflicts = $this->get_dismissed_conflicts( $conflict_data['section'] );
  32. $this->compare_plugins( $conflict_data['plugins'] );
  33. $this->save_dismissed_conflicts( $conflict_data['section'] );
  34. wp_die( 'true' );
  35. }
  36. /**
  37. * Getting the user option from the database
  38. *
  39. * @return bool|array
  40. */
  41. private function get_dismissed_option() {
  42. return get_user_meta( get_current_user_id(), $this->option_name, true );
  43. }
  44. /**
  45. * Getting the dismissed conflicts from the database
  46. *
  47. * @param string $plugin_section Type of conflict group (such as Open Graph or sitemap).
  48. *
  49. * @return array
  50. */
  51. private function get_dismissed_conflicts( $plugin_section ) {
  52. $dismissed_conflicts = $this->get_dismissed_option();
  53. if ( is_array( $dismissed_conflicts ) && array_key_exists( $plugin_section, $dismissed_conflicts ) ) {
  54. return $dismissed_conflicts[ $plugin_section ];
  55. }
  56. return array();
  57. }
  58. /**
  59. * Storing the conflicting plugins as an user option in the database
  60. *
  61. * @param string $plugin_section Plugin conflict type (such as Open Graph or sitemap).
  62. */
  63. private function save_dismissed_conflicts( $plugin_section ) {
  64. $dismissed_conflicts = $this->get_dismissed_option();
  65. $dismissed_conflicts[ $plugin_section ] = $this->dismissed_conflicts;
  66. update_user_meta( get_current_user_id(), $this->option_name, $dismissed_conflicts );
  67. }
  68. /**
  69. * Loop through the plugins to compare them with the already stored dismissed plugin conflicts
  70. *
  71. * @param array $posted_plugins Plugin set to check.
  72. */
  73. public function compare_plugins( array $posted_plugins ) {
  74. foreach ( $posted_plugins as $posted_plugin ) {
  75. $this->compare_plugin( $posted_plugin );
  76. }
  77. }
  78. /**
  79. * Check if plugin is already dismissed, if not store it in the array that will be saved later
  80. *
  81. * @param string $posted_plugin Plugin to check against dismissed conflicts.
  82. */
  83. private function compare_plugin( $posted_plugin ) {
  84. if ( ! in_array( $posted_plugin, $this->dismissed_conflicts, true ) ) {
  85. $this->dismissed_conflicts[] = $posted_plugin;
  86. }
  87. }
  88. }