wp-cw/content-warning-v2.php
2016-11-04 09:45:36 -04:00

390 lines
8.8 KiB
PHP

<?php
/*
Plugin Name: Content Warning v2
Plugin URI: http://plugish.com/plugins/content-warning-v2
Description: A WordPress Plugin to allow site owners to display an acceptance dialog. Used mainly for NSFW websites, this plugin provides a dialog popup to warn viewers of it's possible content.
Author: Jerry Wood Jr.
Version: 3.7.2
Author URI: http://plugish.com
Text Domain: content-warning-v2
Domain Path: /lang
*/
require_once 'includes/api.php';
function cwv2_autoload_classes( $class_name ) {
if ( 0 != strpos( $class_name, 'CWV2_' ) ) {
return false;
}
$filename = strtolower( str_ireplace(
array( 'CWV2_', '_' ),
array( '', '-' ),
$class_name
) );
ContentWarning_v2::include_file( $filename );
return true;
}
spl_autoload_register( 'cwv2_autoload_classes' );
/**
* Class ContentWarning_v2
*
* @property string $version The current plugin version
*
* @author JayWood
*/
class ContentWarning_v2 {
/**
* Instance of ContentWarning_v2
* @var ContentWarning_v2
*/
public static $instance = null;
const VERSION = '3.7.2';
/**
* Rather or not scripts should be minified
* @var string
*/
public $min = '';
/**
* @var CWV2_Admin
*/
public $admin;
/**
* @var CWV2_Settings
*/
public $settings;
private function __construct() {
$this->min = defined( 'SCRIPT_DEBUG' ) && SCRIPT_DEBUG ? '' : '.min';
}
public static function init() {
if ( null == self::$instance ) {
self::$instance = new self();
}
return self::$instance;
}
/**
* Gotta get them hooks yo!
*
* @author JayWood
*/
public function hooks() {
add_action( 'init', array( $this, 'register_frontend_data' ) );
add_action( 'wp_enqueue_scripts', array( $this, 'load_deps' ) );
add_action( 'wp_footer', array( $this, 'render_dialog' ) );
add_action( 'wp_head', array( $this, 'override_css' ) );
if ( ! is_admin() ) {
}
$this->plugin_classes();
}
/**
* Get Cookie Name
*
* If the cookie is to be shown, this function will return the ID, and the javascript
* will handle the rest of it. If this function returns false, the javascript will not show a popup.
*
* @author JayWood
*
* @since 3.6.3
* @return string|int String if special page like homepage, or post_id otherwise.
*/
public function get_cookie_name() {
global $post;
$site_wide = get_option( 'cwv3_sitewide' );
$homepage = get_option( 'cwv3_homepage' );
$misc = get_option( 'cwv3_misc' );
$should_gate = apply_filters( 'cwv3_should_gate', true, $post );
if ( false === $should_gate ) {
return false;
}
if ( 'enabled' == ! empty( $site_wide ) ) {
return 'sitewide';
}
if ( 'enabled' == ! empty( $homepage ) && is_front_page() ) {
return 'homepage';
}
if ( 'enabled' == ! empty( $misc ) && ( is_search() || is_archive() ) ) {
return 'misc';
}
if ( is_attachment() && isset( $post->post_parent ) ) {
// Special consideration needs to be taken to check if the post parent is in-fact
// gated in any way.
$cat_gated = $this->is_cat_gated( $post->post_parent );
if ( $cat_gated ) {
// Return the category cookie name like _cat_###
return '_cat_' . $cat_gated;
} elseif ( $this->is_gated( $post->post_parent ) ) {
return $post->post_parent;
}
}
if ( is_singular() && isset( $post->ID ) ) {
$cat_gated = $this->is_cat_gated( $post->ID );
if ( $cat_gated ) {
// Return the category cookie name like _cat_###
return '_cat_' . $cat_gated;
} elseif ( $this->is_gated( $post->ID ) ) {
return $post->ID;
}
}
return false;
}
/**
* Is Gated
*
* Checks a post ID to see if it's supposed to be
* gated in any way, either by metabox, or category from the
* regular category taxonomy.
*
* @author JayWood
* @since 3.6.3
*
* @param int $post_id Post ID
*
* @return bool TRUE | FALSE
*/
public function is_gated( $post_id ) {
$meta = get_post_meta( $post_id, 'cwv3_auth', true );
if ( ! empty( $meta ) ) {
return true;
}
return false;
}
/**
* Is Cat Gated
*
* Determines if a post is within a gated category, if so, will
* return the category id for use in cookie names like so '_cat_###'
*
* @author JayWood
* @since 3.6.3
*
* @param int $post_id Post ID
*
* @return boolean|string False on failure, cookie string otherwise
*/
public function is_cat_gated( $post_id ) {
$cat_settings = get_option( 'cwv3_cat_list', array() );
if ( ! empty( $cat_settings ) ) {
$post_categories = get_the_category( $post_id );
return $this->in_cat( $cat_settings, $post_categories );
}
return false;
}
/**
* In Cat
*
* Checks to see if the current post is within the set
* categories in the options panel, if so, returns the ID of the
* category that it resides in.
*
* @author JayWood
* @since 3.6.3
*
* @param array $cat_settings Array of categories from settings page
* @param array $post_categories Array of categories from get_the_category()
*
* @return boolean|int False on failure, category ID on success
*/
public function in_cat( $cat_settings, $post_categories ) {
if ( ! is_array( $cat_settings ) ) {
$cat_settings = array(); // Empty
}
foreach ( $post_categories as $post_category ) {
if ( in_array( $post_category->term_id, $cat_settings ) ) {
return $post_category->term_id;
} else {
continue;
}
}
return false;
}
/**
* Load Dependancies
*
* Pretty self-explanatory, loads all the data that needs to be loaded beforehand.
*
* @author JayWood
* @since 3.6.3
* @return null
*/
public function load_deps() {
if ( current_user_can( 'manage_options' ) ) {
return;
}
wp_enqueue_style( 'cwv3_css' );
wp_enqueue_script( 'cwv3_js' );
$cookie_death = get_option( 'cwv3_death', 1 );
$de = get_option( 'cwv3_denial', 'enabled' );
$localized_data = array(
'opacity' => get_option( 'cwv3_bg_opacity', 0.85 ),
'cookie_path' => COOKIEPATH,
'cookie_name' => $this->get_cookie_name(),
'cookie_time' => intval( $cookie_death ) > 365 ? 365 : intval( $cookie_death ),
// Max at one year if it's over 365 days.
'denial_enabled' => is_array( $de ) && ! empty( $de ) ? true : false,
'denial_method' => get_option( 'cwv3_method', 'redirect' ),
'redirect_url' => esc_js( get_option( 'cwv3_exit_link', '#' ) ),
);
wp_localize_script( 'cwv3_js', 'cwv3_params', $localized_data );
}
/**
* Override CSS
* Placeholder method that uses the new API in inc/api.php
*
* @author JayWood
* @since 3.6.3
* @see cwv3_the_css()
*/
public function override_css() {
if ( ! is_admin() ) {
cwv3_the_css();
}
}
/**
* Register Frontend Data
*
* @author JayWood
* @since 3.6.3
* @return null
*/
public function register_frontend_data() {
load_plugin_textdomain( 'content-warning-v2', false, dirname( plugin_basename( __FILE__ ) ) . '/lang/' );
// Jquery Cookie
wp_register_script( 'jquery_cookie', $this->url( "js/jquery_cookie{$this->min}.js" ), array( 'jquery' ), '1.4.1', true );
// Main data
wp_register_script( 'cwv3_js', $this->url( "js/cwv3{$this->min}.js" ), array( 'jquery_cookie' ), '3.6.0', true );
wp_register_style( 'cwv3_css', $this->url( "css/cwv3{$this->min}.css" ), '', '1.0' );
}
/**
* Render Dialog
*
* Redirect method to use the API.php that was created
*
* @author JayWood
* @since 3.6.3
* @see cwv3_js_dialog()
*/
public function render_dialog() {
cwv3_js_dialog();
}
/**
* Uses autoloader for plugin classes
*
* @author JayWood
*/
private function plugin_classes() {
$this->settings = new CWV2_Settings( $this );
$this->admin = new CWV2_Admin( $this );
}
/**
* This plugin's directory
*
* @since 3.7
*
* @param string $path (optional) appended path
*
* @return string Directory and path
*/
public static function dir( $path = '' ) {
static $dir;
$dir = $dir ? $dir : trailingslashit( dirname( __FILE__ ) );
return $dir . $path;
}
/**
* This plugin's url
*
* @since 3.7
*
* @param string $path (optional) appended path
*
* @return string URL and path
*/
public static function url( $path = '' ) {
static $url;
$url = $url ? $url : trailingslashit( plugin_dir_url( __FILE__ ) );
return $url . $path;
}
/**
* Include a file from the includes directory
*
* @since 3.7
*
* @param string $filename Name of the file to be included
*
* @return bool Result of include call.
*/
public static function include_file( $filename ) {
$file = self::dir( 'includes/' . $filename . '.php' );
if ( file_exists( $file ) ) {
return include_once( $file );
}
return false;
}
public function __get( $field ) {
if ( $field == 'version' ) {
return self::VERSION;
}
return $this->$field;
}
}
function content_warning_v2() {
return ContentWarning_v2::init();
}
add_action( 'plugins_loaded', array( content_warning_v2(), 'hooks' ) );