🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

1151閲覧

activeadminの環境変数設定でのエラーで困っています:Access denied for user 'root'@'localhost' (using password: YES)

kurumin27

総合スコア3

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2021/01/03 22:53

編集2021/01/03 23:28

###前提・実現したいこと
activeadminのページへ環境変数を設定したところうまく設定できていないせいか、db:seedを実行するとエラーとなってしまいます。
activeadminの管理者のアカウントがseedファイルに記述されているのでこれが実行できないとアカウントが生成されず困っています。
これを解決できる方法はありますでしょうか?

###発生している問題・エラーメッセージ
ターミナル上で発生しているエラーは下記です。

Access denied for user 'root'@'localhost' (using password: YES)

###該当のソースコード
seed.rb

ruby

1unless AdminUser.find_by(email: ENV['KEY']) 2 AdminUser.create!(email: ENV['KEY'], password: ['SECRET_KEY'], password_confirmation: ['SECRET_KEY']) if Rails.env.development? 3end 4# この下に商品名を作成するコードを書いています

database.yml

ruby(database.yaml)

1default: &default 2 adapter: mysql2 3 encoding: utf8 4 pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> 5 username: root 6 password: 7 socket: /tmp/mysql.sock 8 9development: 10 <<: *default 11 database: reservation_system_development 12 email: <%= ENV['KEY'] %> 13 password: <%= ENV['SECRET_KEY'] %> 14 password_confirmation: <%= ENV['SECRET_KEY'] %> 15 16test: 17 <<: *default 18 database: reservation_system_test 19 20production: 21 <<: *default 22 database: reservation_system_production 23 username: reservation_system 24 password: <%= ENV['reservation_system_DATABASE_PASSWORD'] %> 25 email: <%= ENV['KEY'] %> 26 password: <%= ENV['SECRET_KEY'] %> 27 password_confirmation: <%= ENV['SECRET_KEY'] %>

gitignore

ruby

1/.env.production 2/.env.development

admin_user

ruby

1class AdminUser < ApplicationRecord 2 devise :database_authenticatable, 3 :recoverable, :rememberable, :validatable 4end

active_admin

ruby

1ActiveAdmin.setup do |config| 2 config.site_title = "Reservation System" 3 config.authentication_method = :authenticate_admin_user! 4 config.current_user_method = :current_admin_user 5 config.logout_link_path = :destroy_admin_user_session_path 6 config.root_to = 'reservations#index' 7 config.comments = false 8 config.comments_menu = false 9 config.batch_actions = true 10 config.filter_attributes = [:encrypted_password, :password, :password_confirmation] 11 config.localize_format = :long 12end 13

###試したこと
①コンソールから以下を打つと、ほしいデータが出力することができました。

  • ENV['KEY']
  • ENV['SECRET_KEY']

②試しにdatabase.ymlの以下3行をコメントアウトし、db:seedを実行すると、「バリデーションに失敗しました: Passwordは6文字以上で入力してください」となります。

email: <%= ENV['KEY'] %> password: <%= ENV['SECRET_KEY'] %> password_confirmation: <%= ENV['SECRET_KEY'] %>

###補足情報(FW/ツールのバージョンなど)
DotenvというGemを利用しております。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

databawe.ymlにemailとかpassword_confirmationがあるのが異常です。
username: password: 場合によっては host:  socket: あたり。

投稿2021/01/03 23:01

winterboum

総合スコア23567

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kurumin27

2021/01/03 23:31 編集

ご回答いただきありがとうございます! database.ymlへの記述が必要そうな記事を見つけたので、書いていました。 すべて記述は削除し、db:seedを行うと 「バリデーションに失敗しました: Passwordは6文字以上で入力してください」 というエラーがでます。 passwordについては、6文字以上になっており、バリデーションにならないはずなのですが・・・
winterboum

2021/01/03 23:40

AdminUser.create!(email: ENV['KEY'], password: ['SECRET_KEY'], password_confirmation: ['SECRET_KEY']) passwordなどでENVが書いてないです
kurumin27

2021/01/03 23:48

ありがとうございます!!!! 無事にエラーが解消できて、問題なく動いているようです!! 昨日からずっと格闘していたので、本当に助かりました。。。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問