#前提
deviseをインストールし、ログイン機能を実装済み
#バージョン
rubyのバージョン ruby-2.6.5
Railsのバージョン Rails:6.0.0
#できること
・管理者のみが閲覧でき、特定の操作を行うことができる管理画面の作成(日本語版)
・管理画面にBasic認証をつける
⇨管理者機能とBasic認証の2重ロック
#実装の全体像
①gemのインストール
・gem 'rails_admin', '~> 2.0.0.beta'
・gem 'cancancan'
②生成されたファイルにコードを記述
③管理者(admin)カラムをuserモデルに追加
④管理者画面の日本語化
⑤BASIC認証をかける
#実装手順
##①gemのインストール
(rails_admin編)
gem 'rails_admin', '~> 2.0.0.beta'
上記をGemfileの一番下に記述する。
$ bundle install
$ rails g rails_admin:install
ターミナルでbundle installを行い、rails g rails_admin:installを実行する。
※rails g rails_admin:install後に、ターミナル上で以下の質問をされた場合は、Enterを押す。
? Where do you want to mount rails_admin? Press <enter> for [admin]>
(cancancan編)
rails_admin編と同様の手順。
gem 'cancancan'
$ bundle install
##②生成されたファイルにコードを記述
指定ファイルにコードを記述する。
class Ability
include CanCan::Ability
def initialize(user)
if user.try(:admin?)
can :access, :rails_admin
can :manage, :all
end
end
end
RailsAdmin.config do |config|
### Popular gems integration
## == Devise ==
config.authenticate_with do
warden.authenticate! scope: :user
end
config.current_user_method(&:current_user)
## == Cancan ==
config.authorize_with :cancan
## == Pundit ==
サーバーを再起動させる。
$ rails s
##③管理者(admin)カラムをuserモデルに追加
$ rails g migration add_column_to_users
class ADddAdminToUsers < ActiveRecord::Migration[6.0]
def change
add_column :users, :admin, :boolean, default: false
end
end
rails db:migrateを実行
$ rails db:migrate
##④管理者画面の日本語化
管理画面の日本語化を行うために以下を指定のファイルに記述する。
config.i18n.default_locale = :j
ja:
admin:
js:
true: True
false: False
is_present: 存在する
is_blank: 空白
date: 日付 ...
between_and_: ... から ...
today: 今日
yesterday: 昨日
this_week: 今週
last_week: 先週
number: 数字 ...
contains: 含む
is_exactly: 完全に一致
starts_with: で始まる
ends_with: で終わる
too_many_objects: "対象が多すぎます、上の検索ボックスを使用してください"
no_objects: "対象が見つかりません"
loading: "読み込み中..."
toggle_navigation: ナビゲーション切り替え
home:
name: "ホーム"
pagination:
previous: "« 前"
next: "次 »"
truncate: "…"
misc:
search: "検索"
filter: "検索"
refresh: "更新"
show_all: "すべて表示"
add_filter: "絞り込む..."
bulk_menu_title: "選択項目を..."
remove: "削除"
add_new: "新規作成"
chosen: "選択された%{name}"
chose_all: "すべて選択"
clear_all: "選択解除"
up: "上"
down: "下"
navigation: "ナビゲーション"
root_navigation: "アクション"
navigation_static_label: "リンク"
log_out: "ログアウト"
time_ago: "%{time}前"
ago: "前"
more: "さらに %{count} 個以上の %{models_name}"
flash:
successful: "%{name}の%{action}に成功しました"
error: "%{name}の%{action}に失敗しました"
noaction: "操作を取り消しました"
model_not_found: "モデル'%{model}'はありません"
object_not_found: "'ID:%{id}'の%{model}はありません"
table_headers:
model_name: "モデル名"
last_used: "最終アクセス日"
records: "レコード数"
username: "ユーザ"
changes: "変更"
created_at: "日時"
item: "アイテム"
message: "メッセージ"
actions:
dashboard:
title: "サイト管理"
menu: "ダッシュボード"
breadcrumb: "ダッシュボード"
index:
title: "%{model_label_plural}の一覧"
menu: "一覧"
breadcrumb: "%{model_label_plural}"
show:
title: "%{model_label} '%{object_label}'の詳細"
menu: "詳細"
breadcrumb: "%{object_label}"
show_in_app:
menu: "表示"
new:
title: "新規%{model_label}"
menu: "新規作成"
breadcrumb: "新規"
link: "新規%{model_label}追加"
done: "作成"
edit:
title: "%{model_label} '%{object_label}'を編集"
menu: "編集"
breadcrumb: "編集"
link: "この%{model_label}を編集"
done: "更新"
delete:
title: "%{model_label} '%{object_label}'を削除"
menu: "削除"
breadcrumb: "削除"
link: "'%{object_label}'削除"
done: "削除"
bulk_delete:
title: "%{model_label_plural}を一括削除"
menu: "一括削除"
breadcrumb: "一括削除"
bulk_link: "選択した%{model_label_plural}を削除"
export:
title: "%{model_label}をエクスポート"
menu: "エクスポート"
breadcrumb: "エクスポート"
link: "%{model_label_plural}をエクスポート"
bulk_link: "選択した%{model_label_plural}をエクスポート"
done: "エクスポート"
history_index:
title: "%{model_label_plural}の更新履歴"
menu: "履歴"
breadcrumb: "履歴"
history_show:
title: "%{model_label} '%{object_label}'の履歴"
menu: "履歴"
breadcrumb: "履歴"
form:
cancel: "キャンセル"
basic_info: "基本情報"
required: "必須"
optional: "オプション"
one_char: "文字"
char_length_up_to: "最大文字数:"
char_length_of: "文字数:"
save: "保存"
save_and_add_another: "保存して次へ"
save_and_edit: "保存して編集"
all_of_the_following_related_items_will_be_deleted: "を削除してよろしいですか? 以下の項目が削除され、もしくは関係を失います:"
are_you_sure_you_want_to_delete_the_object: "%{model_name}の項目"
confirmation: "実行する"
bulk_delete: "以下の項目が削除され、それによって関連する項目が削除され、もしくは関係を失います:"
new_model: "%{name} (新規)"
export:
confirmation: "%{name}としてエクスポート"
select: "エクスポートするフィールドを選択してください"
select_all_fields: "全フィールドを選択"
fields_from: "%{name}のフィールド"
fields_from_associated: "関連する%{name}のフィールド"
display: "カラム:%{name} 型:%{type}"
options_for: "%{name}の出力オプション"
empty_value_for_associated_objects: "<empty>"
click_to_reverse_selection: 'クリックで選択を反転します'
csv:
header_for_root_methods: "%{name}" # 'model' is available
header_for_association_methods: "%{name} [%{association}]"
encoding_to: "文字コード"
encoding_to_help: "空白の場合は%{name}になります"
skip_header: "ヘッダなし"
skip_header_help: "チェックすると出力にヘッダ行を含めません"
default_col_sep: ","
col_sep: "区切り文字"
col_sep_help: "空白の場合は'%{value}'区切りです" # value is default_col_sep
⑤BASIC認証をかける
# 一番上に追加
config.authenticate_with do
authenticate_or_request_with_http_basic('Site Message') do |username, password|
username == 'admin' && password == 'admin'
end
end
サーバーを再起動させ、"http://localhost:3000/admin" にアクセスすると認証ダイアログが表示される。
$ rails s
ロックを解除すると、以下の管理者画面となる。
管理者画面で挙動確認をし問題なければ完成。