- DokuWikiを「2018-04-22c Greebo」 から「2020-07-29 Hogfather」にアップグレードしました。
- すると、エラーが表示されてシステムにログインできなくなってしまいました。
data:image/s3,"s3://crabby-images/ea563/ea5631862364471a56f265ceb46e967214e86212" alt="Dokuwikiをアップグレードしたら動かなくなった「Fatal error: Class ‘Doku_Handler_Quote’ not found 」(markdowkuプラグイン)"
今回は、ニッチな話ですが、dokuwikiのアップグレードについて書いてみます。
1. 表示されたエラー:Fatal error: Class ‘Doku_Handler_Quote’ not found
DokuWikiのアップグレードの通知があったので適用しました。
その後ログインすると、エラーで表示されなくなってしまいました。
Fatal error: Class ‘Doku_Handler_Quote’ not found in …/wiki/lib/plugins/markdowku/syntax/blockquotes.php on line 95
data:image/s3,"s3://crabby-images/48619/48619144bbe4b628debc7b4a91cadb577198b2ee" alt="表示されたエラー:Fatal error: Class ‘Doku_Handler_Quote’ not found"
こんなときは、とりあえずバックアップから復元です。
dokuwikiは、Softaculousで管理しているので、バックアップ復元が利用できます。
ちなみに、ちゃんとアップデートの直前にバックアップしていたので、ばっちりです。
data:image/s3,"s3://crabby-images/d113d/d113d67b6ef59b29f1765e8c82a41a782dea2c57" alt="表示されたエラー:Fatal error: Class ‘Doku_Handler_Quote’ not found"
data:image/s3,"s3://crabby-images/b5be0/b5be0c76b24b9285be43ba1a4f2071c1843b2b3c" alt="表示されたエラー:Fatal error: Class ‘Doku_Handler_Quote’ not found"
バックアップから復元すると、とりあえず動くように戻りました。
mixhostがレンタルサーバーで、
softaculousはサーバーのソフトウェア管理システムです。
softaculousは、スマホでいうApp StoreやPlayストアのようなものです
サーバ内のプログラム(「インスタレーション」といいます)をインストールしたり、アップデートしたりできます。
2. 落ち着いてエラーを読んでみる
再度、アップグレードを試すために、原因を探ります。
Fatal error: Class ‘Doku_Handler_Quote’ not found in …/wiki/lib/plugins/markdowku/syntax/blockquotes.php on line 95
もう一度スクリーンショットしてあるエラーを読んでみると、markdowkuというプラグインで呼び出している「Doku_Handler_Quote」というクラスの参照が見つからないようです。
2-1. Markdowkuプラグインとは?
Markdowkuプラグインは、MarkdownをDokuWiki構文に追加します。
構文変更ではなく追加なので、markdowkuでは、Markdown構文に加えて、Dokuwikiの構文でも表や内部リンクを利用することができます。
つまり、いいとこ取りができるんです。
data:image/s3,"s3://crabby-images/38664/38664c2dad2598ab1dea0fdfffbb16b0cf48a4f9" alt="Markdowkuプラグインとは?"
markdown構文は見出しを#で指定できるのが便利で、Dokuwikiはリンクを[[]]で指定できるのが便利だと思います
2-2. Dokuwikiのバージョン「2020-07-29 Hogfather」
そもそも、今回はDokuwikiのバージョンを「2018-04-22c Greebo」 から「2020-07-29 Hogfather」にアップグレードしました。
data:image/s3,"s3://crabby-images/bf171/bf17176d96dbdc3847cde6f8fcd43798cca88a78" alt="Dokuwikiのバージョン「2020-07-29 Hogfather」"
新しいバージョンでは「Doku_Handler_Quote」クラスは参照できなくなっているようです。
3. MarkdowkuプラグインはHogfatherに未対応
プラグインの更新がないかどうか、復元したDokuwikiの設定から見てみることにしました。
すると、Markdowkuプラグインの配布URLが変更されていることがわかりました。
data:image/s3,"s3://crabby-images/c8aeb/c8aeb06a29801d4615b9b79b5c2bd1fe3f04ebd5" alt="MarkdowkuプラグインはHogfatherに未対応"
- 旧)https://komkon2.de/markdowku/markdowku.tgz
- 新)https://github.com/Medieninformatik-Regensburg/dokuwiki-plugin-markdowku/archive/Greebo.zip
githubのレジストリからplugin.info.txtを表示してみると、pluginURLがありました。
data:image/s3,"s3://crabby-images/d3fce/d3fce6cb3723bb19b9d2a34d3e2464033e7544cf" alt="MarkdowkuプラグインはHogfatherに未対応"
こちらを確認すると、現時点(2020-08-21)では Hogfatherに対応していないことがはっきりしました。
data:image/s3,"s3://crabby-images/d31d8/d31d8b452265cd83ae312333bd7eb593578da077" alt="MarkdowkuプラグインはHogfatherに未対応"
3-1. バグ修正には2週間ほどかかるらしい
Githubのフォーラムを見てみると、さしあたりの解決方法と、バグ修正には2週間ほどかかることがわかりました。
data:image/s3,"s3://crabby-images/2a373/2a3732384be2923f42109c0b05d1751980027fa0" alt="出典:https://github.com/Medieninformatik-Regensburg/dokuwiki-plugin-markdowku/issues/2"
- lib/plugins/markdowku/syntax/blockquotes.php
- lib/plugins/markdowku/syntax/olists.php
- lib/plugins/markdowku/syntax/ulists.php
の3つのシンタックスファイルを削除することで、不完全ながらエラーは消せるようです。
他にもhttps://www.dokuwiki.org/plugin:markdowkuには以下のような、暫定版(RC2)が公開されています。
data:image/s3,"s3://crabby-images/2b54f/2b54f0ed46671bf6b29318747a13adc9170f2eb2" alt="バグ修正には2週間ほどかかるらしい"
data:image/s3,"s3://crabby-images/38664/38664c2dad2598ab1dea0fdfffbb16b0cf48a4f9" alt="バグ修正には2週間ほどかかるらしい"
ちょっとややこしいですね💦
一応プロジェクトは進行中なのでバグ修正を待ってからDokuwikiのアップグレードをしようと思います。
data:image/s3,"s3://crabby-images/9041a/9041af163a87819524e6e66a9c99586a7c656fa1" alt="DokuWikiの印刷用CSSを変更する(userprint.css)"
data:image/s3,"s3://crabby-images/ddc22/ddc227651742b74b0366a652ce2652f438c74380" alt="DokuWikiの編集画面のメッセージを直したい"