mirror of
https://github.com/kremalicious/Badged.git
synced 2025-01-01 09:37:44 +01:00
236 lines
4.8 KiB
PHP
236 lines
4.8 KiB
PHP
|
<?php
|
||
|
/**
|
||
|
* Badged
|
||
|
*
|
||
|
* @package Badged
|
||
|
* @author Matthias Kretschmann <m@kretschmann.io>
|
||
|
* @license GPL-2.0+
|
||
|
* @link http://kremalicious.com/badged/
|
||
|
* @copyright 2013 Matthias Kretschmann
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* Plugin class.
|
||
|
*
|
||
|
* @package Badged
|
||
|
* @author Matthias Kretschmann <m@kretschmann.io>
|
||
|
*/
|
||
|
class Badged {
|
||
|
|
||
|
/**
|
||
|
* Plugin version, used for cache-busting of style and script file references.
|
||
|
*
|
||
|
* @since 2.0.0
|
||
|
* @var string
|
||
|
*/
|
||
|
const VERSION = '2.0.0';
|
||
|
|
||
|
/**
|
||
|
*
|
||
|
* Unique identifier.
|
||
|
*
|
||
|
* @since 2.0.0
|
||
|
* @var string
|
||
|
*/
|
||
|
protected $plugin_slug = 'badged';
|
||
|
|
||
|
/**
|
||
|
* Instance of this class.
|
||
|
*
|
||
|
* @since 2.0.0
|
||
|
* @var object
|
||
|
*/
|
||
|
protected static $instance = null;
|
||
|
|
||
|
/**
|
||
|
* Initialize the plugin by setting localization and loading public scripts
|
||
|
* and styles.
|
||
|
*
|
||
|
* @since 2.0.0
|
||
|
*/
|
||
|
private function __construct() {
|
||
|
|
||
|
// Load plugin text domain
|
||
|
add_action( 'init', array( $this, 'load_badged_textdomain' ) );
|
||
|
|
||
|
// Activate plugin when new blog is added
|
||
|
add_action( 'wpmu_new_blog', array( $this, 'activate_new_site' ) );
|
||
|
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Return the plugin slug.
|
||
|
*
|
||
|
* @since 2.0.0
|
||
|
*@return Plugin slug variable.
|
||
|
*/
|
||
|
public function get_plugin_slug() {
|
||
|
return $this->plugin_slug;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Return an instance of this class.
|
||
|
*
|
||
|
* @since 2.0.0
|
||
|
* @return object A single instance of this class.
|
||
|
*/
|
||
|
public static function get_instance() {
|
||
|
|
||
|
// If the single instance hasn't been set, set it now.
|
||
|
if ( null == self::$instance ) {
|
||
|
self::$instance = new self;
|
||
|
}
|
||
|
|
||
|
return self::$instance;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Fired when the plugin is activated.
|
||
|
*
|
||
|
* @since 2.0.0
|
||
|
* @param boolean $network_wide True if WPMU superadmin uses
|
||
|
* "Network Activate" action, false if
|
||
|
* WPMU is disabled or plugin is
|
||
|
* activated on an individual blog.
|
||
|
*/
|
||
|
public static function activate( $network_wide ) {
|
||
|
|
||
|
if ( function_exists( 'is_multisite' ) && is_multisite() ) {
|
||
|
|
||
|
if ( $network_wide ) {
|
||
|
|
||
|
// Get all blog ids
|
||
|
$blog_ids = self::get_blog_ids();
|
||
|
|
||
|
foreach ( $blog_ids as $blog_id ) {
|
||
|
|
||
|
switch_to_blog( $blog_id );
|
||
|
self::single_activate();
|
||
|
}
|
||
|
|
||
|
restore_current_blog();
|
||
|
|
||
|
} else {
|
||
|
self::single_activate();
|
||
|
}
|
||
|
|
||
|
} else {
|
||
|
self::single_activate();
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Fired when the plugin is deactivated.
|
||
|
*
|
||
|
* @since 2.0.0
|
||
|
* @param boolean $network_wide True if WPMU superadmin uses
|
||
|
* "Network Deactivate" action, false if
|
||
|
* WPMU is disabled or plugin is
|
||
|
* deactivated on an individual blog.
|
||
|
*/
|
||
|
public static function deactivate( $network_wide ) {
|
||
|
|
||
|
if ( function_exists( 'is_multisite' ) && is_multisite() ) {
|
||
|
|
||
|
if ( $network_wide ) {
|
||
|
|
||
|
// Get all blog ids
|
||
|
$blog_ids = self::get_blog_ids();
|
||
|
|
||
|
foreach ( $blog_ids as $blog_id ) {
|
||
|
|
||
|
switch_to_blog( $blog_id );
|
||
|
self::single_deactivate();
|
||
|
|
||
|
}
|
||
|
|
||
|
restore_current_blog();
|
||
|
|
||
|
} else {
|
||
|
self::single_deactivate();
|
||
|
}
|
||
|
|
||
|
} else {
|
||
|
self::single_deactivate();
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Fired when a new site is activated with a WPMU environment.
|
||
|
*
|
||
|
* @since 2.0.0
|
||
|
* @param int $blog_id ID of the new blog.
|
||
|
*/
|
||
|
public function activate_new_site( $blog_id ) {
|
||
|
|
||
|
if ( 1 !== did_action( 'wpmu_new_blog' ) ) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
switch_to_blog( $blog_id );
|
||
|
self::single_activate();
|
||
|
restore_current_blog();
|
||
|
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get all blog ids of blogs in the current network that are:
|
||
|
* - not archived
|
||
|
* - not spam
|
||
|
* - not deleted
|
||
|
*
|
||
|
* @since 2.0.0
|
||
|
* @return array|false The blog ids, false if no matches.
|
||
|
*/
|
||
|
private static function get_blog_ids() {
|
||
|
|
||
|
global $wpdb;
|
||
|
|
||
|
// get an array of blog ids
|
||
|
$sql = "SELECT blog_id FROM $wpdb->blogs
|
||
|
WHERE archived = '0' AND spam = '0'
|
||
|
AND deleted = '0'";
|
||
|
|
||
|
return $wpdb->get_col( $sql );
|
||
|
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Fired for each blog when the plugin is activated.
|
||
|
*
|
||
|
* @since 2.0.0
|
||
|
*/
|
||
|
private static function single_activate() {
|
||
|
// update_option('menu', 'yes');
|
||
|
// update_option('bar', 'no');
|
||
|
// update_option('ios6', 'yes');
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Fired for each blog when the plugin is deactivated.
|
||
|
*
|
||
|
* @since 2.0.0
|
||
|
*/
|
||
|
private static function single_deactivate() {
|
||
|
// TODO: Define deactivation functionality here
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Load the plugin text domain for translation.
|
||
|
*
|
||
|
* @since 2.0.0
|
||
|
*/
|
||
|
public function load_plugin_textdomain() {
|
||
|
|
||
|
$domain = $this->plugin_slug;
|
||
|
$locale = apply_filters( 'plugin_locale', get_locale(), $domain );
|
||
|
|
||
|
load_textdomain( $domain, trailingslashit( WP_LANG_DIR ) . $domain . '/' . $domain . '-' . $locale . '.mo' );
|
||
|
load_plugin_textdomain( $domain, FALSE, basename( plugin_dir_path( dirname( __FILE__ ) ) ) . '/languages/' );
|
||
|
|
||
|
}
|
||
|
|
||
|
}
|