#1.はじめに
もともと20年ほど旧サイト「らららのプログラマーズラウンジ」を運営していたのですが、XServer,WordPressのサイトへ引っ越ししました。これを機に(いまどき?になりますが)CGIの掲示板からWordPressのwpForo Forum(掲示板)へ移行しました。
(移行先は、こちらです。6万件弱の書き込みが移行されたことが確認できます)
旧サイトは約20年ほどの掲示板書き込みデータがあり、もちろんそのデータを移行する必要があるのですが
標準で移行方法が用意されておらず、自力で「wpForo Forum」を解析して移行しました。
ゆうて掲示板だし「眺めれば、なんとかなるっしょ♪」と軽いノリでやってみた。
と、そういう記事です。
ちなみに、Qiitaでちょっと「wpForo」を検索してみたところ1件もヒットしない!
WordPressはあってもwpForoは1件もないかw ということで需要はないのはわかりましたが、
私のように(あまりいない)掲示板移行したい方向け、そして自分用のメモとして記事にしておきます。
#2.移行元と移行先の掲示板について
##掲示板(移行元)
移行元の掲示板は、「[とほほのWWW入門] (http://www.tohoho-web.com/)」で配布されている「[WwwLounge - CGI質問掲示板](http://www.tohoho-web.com/wwwboard.htm)」です。
約20年ほど前に配布され、今は更新されていないCGI掲示板です。
当時は設置している方もちらほら見られて、知っている人は知っている掲示板でした。
書き込みデータは、ほんとテキストのログです。
データはこんな感じです。
Subject: WEB質問ラウンジ設置!
========================================
From: ららら
E-Mail: rararahp@cool.ne.jp
HomePage: http://rararahp.cool.ne.jp
Date: 2002/06/01(土) 02:28:34
こんにちは。らららです。
WEB用ラウンジを設置しました。
みなさん、ご活用くださいませ。m(_ _)m
========================================
From: xxx
Date: 2002/06/03(月) 12:36:42
新規ラウンジ解説、おめでとうございます。
ところで、ASPの設置予定はないのでしょうか?
========================================
From: xxx
Date: 2002/06/03(月) 17:34:41
こんにちは。ASPはHP作成に関わることなので、
このラウンジでよいんじゃないですかねぇ。
##掲示板(移行先)
移行先の掲示板は、冒頭で書いたようにWordPressのプラグイン「wpForo Forum」です。
「wpForo」はWordPressの掲示板プラグインの中でも優れている機能を持っていて実は、他の掲示板からの移行ツールが用意されています。
画像
https://wpforo.com/docs/root/migrate-to-wpforo/
しかし「phpBB」や「MyBB」等の有名どころからの移行ツールは用意されているのですが
むかーしの日本のローカルでしか使われていなかった「WwwLounge」からの移行ツールはもちろん用意されていません。
しゅーりょーである😭。。。
いや。待て待て。わいエンジニア!💪
ちょっと眺めれば、掲示板データの移行なんて楽々いけるでしょ!
ということでやってみた。
#3.wpForoの解析(完全に理解した。してない)
では、移行に向けてwpForの解析を始めます。
と言っても眺めるだけです🤣
wpForoにはドキュメント(英語)はあるのですが、
ぱっと見、移行ツール以外に有用な情報はなさげ。
フォーラムで書き込まれたテキストはどこにいくか?
WwwLoungeみたいにテキストファイルってことはなくデータベースでしょう。
ということで、MySQL管理ツールのphpmyadminからデータベースを覗くとそれっぽいものがありました。
名前が「wp_wpforo_」から続くテーブルがそうですね。
次にテーブルの定義やデータを眺めます。
(眺めるというのは、テーブル名前、項目名から意味を想定して、実際に掲示板から書き込みをしてみて、どのようなデータが生成されるかを確認する地道な作業。。。🤣)
と、すると移行にはこのあたりのテーブルをなんとかすれば良いことがわかります。
wp_wpforo_forums:各掲示板の情報
wp_wpforo_topics:投稿(ヘッダ)
wp_wpforo_posts:投稿(明細)
wp_wpforo_tags:タグ
wp_users:ユーザー (WordPressと共通)
wp_wpforo_profiles:ユーザーのプロファイル
wp_wpforo_topicsとwp_wpforo_postsが書き込みデータで
スレ主がスレッドを立てるとwp_wpforo_topics、wp_wpforo_postsがそれぞれ1件出来て、
レスをつけるとwp_wpforo_postsが1件づつ増えていく関係です。
それぞれの項目の意味はこんな感じです。
・wp_wpforo_topicsテーブル
・wp_wpforo_postsテーブル
※必要なテーブルの項目は、すべてどのような意味か、データ値はどんな形式で何が入るかを洗い出します。掲示板で使っていない機能とかがあるとデータに変化が現れずわからない事もあるのですが、大体解析しました。
#4.移行方針決定
移行方針は、事前にWordPressからサブフォーラムの作成など大まかな掲示板の設定を行い、
移行元掲示板からデータを抽出して、移行先掲示板にインポートしてあげます。これだけで動くはず!
##移行元掲示板(WwwLounge)からのデータエクスポート
上記にも書きましたが、投稿はテキストファイルなので、このテキストファイルを解析して読み込むプログラムを自作します。
SubjectやDateなど特定キーワードや規則的な順序性があるので、これに基づいて読み込みます。
##移行元→移行先へデータを変換
移行元からのエクスポートをしたデータをwpForoの形式に変換するプログラムを自作します。
(どのように変換するかは「wpForoの解析」のところで把握した構造になるように変換します)
★実際の抽出、変換プログラムはこちら
https://github.com/rararalounge/LoungeTool
##移行先掲示板(wpForo Forum)へのデータインポート
インポートには、phpmyadminにインポート機能があるのでこれを使います。
以下のようにインポートするファイルのフォーマットを指定できます。
今回は、CSVにしています。
(XMLのほうが後々良いかなと思いましたが、1回インポート出来ればいいしCSVのほうがとりあえずなら簡単かなと。安易な選択)
またCSV読み込み時にやっかいな、カラムの区切り文字や囲み記号エスケープ記号などをインポート画面から指定できます。便利!
#5.移行実行
ここまでくれば、あとはインポートして「めでたしめでたし!」のはずなんですが、実際インポートすると以下のようにエラーが出たり、インポートが成功しても想定していなかった問題が発生したりとです。
解析があまかったり、データが思うように出来ていなかったりといった事が原因ですね。トライアンドエラーを繰り返すしかねぇ!
いくつか対応したのですが、覚えているのだと以下のような問題が出ました。
(もっと問題が出た気がしますが、忘れてしまいました)
##問題1
問題1 Q&AのURLがなぜか重複する
wpForoの仕様で、質問をすると以下のようにタイトルがそのままURLに使われます。
(例)
「https://rarara.org/community/programming/コードで作成したコントロールのイベントハンドラー」
ただこのURLの長さに最大制限があって途中で切り取られます。普通に使う分には重複すると連番(ハイフンと数字)が付与される仕様なので問題ないのですが、私のように移行プログラムでインポートしようとしたところユニークチェックにひっかかって大量にエラーが出ました。
タイトルに
「コードで作成したコントロールのイベントハンドラー1」
「コードで作成したコントロールのイベントハンドラー2」
「コードで作成したコントロールのイベントハンドラー3」
というように連番をついている場合や
「コードで作成したコントロールのイベントハンドラーでエラー発生」
というようにタイトルが途中までが同じ場合です。。。
これは変換プログラムを修正して、重複したらURLに連番をつけるようにして対応しました。
##問題2
問題2 検索文字列をURLエンコードしてくれない
これはwpForoのバグなのですが、例えばサイドバーからタグ「C#」と検索しても#がURLエンコードされておらず正しく検索出来ない。
###公式サイトへの修正依頼
とりあえずwpForoはPHPで出来ているのでソースコードを眺めて、修正箇所を見つけて対応しました。ただプラグインがバージョンアップした際に自分が行った修正が消えてしまうのが面倒だなぁと思ったので、wpForoの公式にサポートがあるので以下のように修正依頼を行いました。
返答はその日のうちにありました。はやい!
回答としては、「そのバグは知っている。次のバージョンで修正する予定」とのこと。
##おまけに
移行先の掲示板では、ユーザー登録制(登録しなくても投稿と書き込みは可能)なのですが、ユーザー登録していると投稿数に応じて以下のように貢献度がわかるちょっとだけうれしい仕様です。
昔から書き込んでくれているユーザーと、移行した掲示板ログをひもづけるために以下のように直にSQLでデータをいじって対応したりしています。(ユーザー登録して頂いた方のみですが)
UPDATE `wp_wpforo_topics` SET name = "", email="", userid = ユーザーID WHERE name = "ユーザー名"
UPDATE `wp_wpforo_posts` SET name = "", email="", userid = ユーザーID WHERE name = "ユーザー名"
(上記のSQLは、過去のユーザー名(文字列)で検索して登録したユーザーへの置き換え)
※一応、解析でテーブル構造を把握しているからこそ、こんな対応もできる。
#6.さいごに
エンジニアだから、存在しないんだったら(今回は移行ツール)自分で作れば良いですね。
エンジニアとかたいそうなものじゃなくて、今回のようにどのように解決するかの思考とプログラムがちょっと書けるぐらいで大丈夫!
あと、移行先の「らららのエンジニアラウンジ」
移行前よりさらにアクセスが減っているような。。。引っ越ししたばかりで検索にヒットしにくいというのはあるかもしれませんが。
いまどき掲示板は難しい(チャットやTwitter等と比べて)のはわかっておりますが、みなさんのノウハウが参照できる形でずっと残るという意味ではとても有用だとと思っています。現に約20年分の技術Q&Aのログが本サイトには残っています。
ということで当サイトにアクセスして頂けると喜びます!🙇🙇🙇
また私としてはQiita初投稿でした。勉強になりました。そしてこのしくみ便利だぁー。