Redmineのプラグインで「redmine_wiki_extensions 0.9.0」を使用した
ところ、Redmine4.0では正常に動作しませんでした。Rubyのバージョンが原因
でしょうか。よろしくお願い致します。
動作しないということですが、ログにはどのようなメッセージが出ているのでしょうか?
これが該当しますでしょうか。宜しくお願い致します。
/var/log/nginxの内容です。
19:39:45 [error] 70377#100108: *248 connect() to unix:/var/run/unicor n.sock failed (61: Connection refused) while connecting to upstream
やってみたこと
・mysql80からmysql57へ変更してみた。
・chown www:www redmine
・chmod -R 777 redmine/
以上、ですが改善しませんでした。rubyのバージョンは下げられませんでした。
すみません宜しくお願い致します。
また、「redmine_wiki_extensions」のかわりのプラグインはありますでしょうか。
合わせてお願いいたします。
「redmine_wiki_extensions 0.9.0」は登録出来ているようですが、タイトルとwikiページに入力した
後、「更新」をクリックすると次の画面が表示されない状態になります。WebソフトはNginxを使用して
いますが、こちらの問題でしょうか。宜しくお願い致します。
表示されないとはどのような状況でしょうか。ブラウザには白い表示しかない。とか詳細を書いていただいたほうが良いです。確かにnginx側で白い表示にする事もできなくもないような。nginxの「次の画面が表示されない」場合のログがわかると良いです。直接の解決に至るかは今のところわかりませんが。
firefoxですと白い画面のままです。
nginxのアクセスログは、以下のようです。
"POST /projects/houkoku/wiki_extensions_settings/update?partial=wiki_extensions_settings%2Fupdate&setting_id=1&tab=wiki_extensions HTTP/1.1" 400 0 "http://192.168.xxx.xxx/projects/houkoku/settings/wiki_extensions" "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:68.0) Gecko/20100101 Firefox/68.0"
redmineのproduction.logは以下の通りです。
Current user: admin (id=1)
Completed 500 Internal Server Error in 50ms (ActiveRecord: 16.1ms)
ActionController::ParameterMissing (param is missing or the value is empty: sett ing):
plugins/redmine_wiki_extensions/app/controllers/wiki_extensions_settings_control ler.rb:36:in `block in update'
plugins/redmine_wiki_extensions/app/controllers/wiki_extensions_settings_control ler.rb:29:in `update'
lib/redmine/sudo_mode.rb:63:in `sudo_mode'
・chromeですと以下の「更新時」に以下のメッセージがでます。
このページは動作していません この問題が何度も発生する場合は、サイト所有者にお問い合わせください。
HTTP ERROR 400
以上、よろしくお願いいたします。
ActionController::ParameterMissingとあるのでやはりインストールしただけでは動作しない状況かと思われます。御自身でソースを書き直しても後のプラグインのバージョンアップに伴い再度ソースコードを直す事になると思われます。解決には全部の環境をこちらで再現しなければわからない事なのでそこまではできません。インストール以外で状況をお知らせいただければ答えられる事はあるかも知れません。
もし自分がこの問題に直面したら、一応デバッガ等で状況を確認します。
plugins/redmine_wiki_extensions/app/controllers/wiki_extensions_settings_control ler.rb
の29行目あたりにpryでブレークポイントを設けてpostされた内容の確認をします。
他ソースコードの改修まで出来るかは非常に不明瞭です。
lib/redmine/sudo_mode.rb
というのも若干は気になります。
ActionController::ParameterMissing (param is missing or the value is empty: setting):
は改善されませんでした。仮想的に再現できませんでしょうか。宜しくお願い致します。
仮想的に再現ということが難しいのですが。
ちょっとした事で同一環境にならない事もあります。
rubyのところにamd64-freebsd12とある事からもOSはfreebsdですね。
freebsdのオペレーションは不慣れなものでして。
ちょっとこれ以上の対応は難しいです。
申し訳ありません。
いろいろとありがとうございます。
ActionController::ParameterMissing (param is missing or the value is empty: setting):という事で
「wiki_extensions_settings_controller.rb」の内容を記載します。ソースのことが良くわからい者です
ので、修正する箇所がわかりましたらご教授願います。
ーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーー
class WikiExtensionsSettingsController < ApplicationController
unloadable
layout 'base'
before_action :find_project, :authorize, :find_user
def update
menus = params[:menus]
setting = WikiExtensionsSetting.find_or_create @project.id
begin
29行目 setting.transaction do
menus.each_pair {|menu_no, menu|
menu_setting = WikiExtensionsMenu.find_or_create(@project.id, menu[:menu_no].to_i)
menu_setting.attributes = menu.permit(:enabled, :menu_no, :title, :page_name)
menu_setting.save!
}
#setting.auto_preview_enabled = auto_preview_enabled
36行目 setting.attributes = params.require(:setting).permit(:auto_preview_enabled, :tag_disabled)
setting.save!
end
flash[:notice] = l(:notice_successful_update)
rescue => e
flash[:error] = "Updating failed." + e.message
throw e
end
redirect_to :controller => 'projects', :action => "settings", :id => @project, :tab => 'wiki_extensions'
end
private
def find_project
# @project variable must be set before calling the authorize filter
@project = Project.find(params[:id])
end
def find_user
ソースだけあれば解決できる訳ではなく、先にも書きました通り
>29行目あたりにpryでブレークポイントを設けてpostされた内容の確認をします。
といった策を自分であれば試みます。
ソースのデバックの知識がなく、検証できませでした。いろりとありがとうございました。

回答1件
あなたの回答
tips
プレビュー