プラグインをマルチサイト互換にする


9

プラグインを各ブログにインストールして、ブログごとにデータベーステーブルを作成します。私はこのコードを持っています:

register_activation_hook( __FILE__, 'install1' );
function install1() {
    global $wpdb;

    if (function_exists('is_multisite') && is_multisite()) {
        // check if it is a network activation - if so, run the activation function for each blog id
        if (isset($_GET['networkwide']) && ($_GET['networkwide'] == 1)) {
                    $old_blog = $wpdb->blogid;
            // Get all blog ids
            $blogids = $wpdb->get_col($wpdb->prepare("SELECT blog_id FROM $wpdb->blogs"));
            foreach ($blogids as $blog_id) {
                switch_to_blog($blog_id);
                _install2();
            }
            switch_to_blog($old_blog);
            return;
        }   
    } 
    _install2();        
}

function _install2()
{
    require_once WP_PLUGIN_DIR . '/pluginfolder/functions/database.php';
    require_once WP_PLUGIN_DIR . '/pluginfolder/functions/general.php';
    $db_error = false;

    $sql_file = WP_PLUGIN_DIR . '/pluginfolder/ossq.sql';
    os_db_connect(DB_HOST, DB_USER, DB_PASSWORD);
    os_set_time_limit(0);
    os_db_install(DB_NAME, $sql_file);
    if ($db_error != false) {

        //  echo 'instalation successfull';
    } else {


    }

コードはこのブログ投稿[http://shibashake.com/wordpress-theme/write-a-plugin-for-wordpress-multi-site]から発想を得ています

SQLファイルは次のもので構成されます。

DROP TABLE IF EXISTS address_book;
CREATE TABLE address_book (
   address_book_id int NOT NULL auto_increment,
   customers_id int NOT NULL,
   entry_gender char(1),
   entry_company varchar(255),
   entry_firstname varchar(255) NOT NULL,
   entry_lastname varchar(255) NOT NULL,
   entry_street_address varchar(255) NOT NULL,
   entry_suburb varchar(255),
   entry_postcode varchar(255) NOT NULL,
   entry_city varchar(255) NOT NULL,
   entry_state varchar(255),
   entry_country_id int DEFAULT '0' NOT NULL,
   entry_zone_id int DEFAULT '0' NOT NULL,
   PRIMARY KEY (address_book_id),
   KEY idx_address_book_customers_id (customers_id)
);

ただし、機能していないため、プラグインは通常のワードプレスと同じようにテーブルを作成しますが、マルチサイト環境の各ブログには作成しません。

助けてください!


ossq.sqlファイルのwhatsと$ wpdbオブジェクトを使用しない理由
Bainternet

ブログのインストールごとに新しいテーブルを作成する代わりに、1つのテーブルだけを使用してblog_idの列を追加する方が理にかなっていますか?こうすると、ブログが1つしかない場合、ブログIDは常に1になります。マルチサイトの場合、ブログIDはサイトIDに従って設定されます...
Scott

やりたかったのですが、どうすればいいのかわかりません。ブログIDの列を作成できますが、そのための関数を作成する方法はありません。
ケン

これはうまく機能し、最近コードに追加しました。newzealandgoonline.co.nz/...
NZGO

回答:


12

適切なネットワークアクティベーションメタプラグインは、まさにこのような場合のために書かれました。


素敵なプラグイン。あなたは著者だと思います。今日は30票を使ってcosに投票できませんでした:(
Giri

プラグインは私の問題を解決しません。プラグインをネットワークでアクティブ化した2つのサイトには、まだ1つのデータベーステーブルがあります。私が必要なのは、彼らがそれぞれ別々のデータベーステーブルを持つことです。
ケン

3
つまり、それらの名前に$ wpdb-> prefixを追加していません。
scribu
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.