ユーザー認証にdeviseを採用しているRailsアプリのメール送信サービスをMailgunからAWS SESに変更したところ、送られてきたメールのリンクからアカウントの有効化ができないという問題に遭遇しています。
ご助言いただけると幸いです。
開発環境
- ruby 3.0.1
- Rails 6.1.4.4
- docker 20.10.12
- docker-compos 1.29.2
前提事項
- メールの送信にはAWS SESを使用
- Mailgunを使用していたときには正常に認証ができていた
起きている問題
アカウント登録時の認証メール内有効化リンクをクリックしても、アカウントが有効になりません。
アカウント新規登録画面からメールアドレス等の必要事項を入力して「認証メールを送信」ボタンを押すと正常にメールが送られて来ます。しかし、メール内のurlをクリックすると「アカウント有効化リンクの再送信」ページに飛んでしまい、当該ユーザーでのログインにも失敗します(「認証が必要です」とメッセージが出ます)。
# Railsログ(抜粋) [1m[36mUser Create (0.8ms)[0m [1m[32mINSERT INTO `users` (`name`, `email`, `encrypted_password`, `confirmation_token`, `confirmation_sent_at`, `created_at`, `updated_at`) VALUES ('t_kyab', 'example@gmail.com', '$2a$12$Aak*********************************cHPoO7KKwq', 'wMB***************r1sA', '2022-05-31 21:32:41', '2022-05-31 21:32:41.975876', '2022-05-31 21:32:41.975876') # メール内urlの内容 https://myapp.com/users/confirmation?confirmation_token=wMB***************r1sA
root@515826d65af1:/var/www/hangartalk# rails c Warning: the running version of Bundler (2.2.15) is older than the version that created the lockfile (2.3.4). We suggest you to upgrade to the version that created the lockfile by running `gem install bundler:2.3.4`. Running via Spring preloader in process 830 Loading development environment (Rails 6.1.6) [1] pry(main)> User.find_by(email: 'hajsu00@gmail.com') User Load (1.1ms) SELECT `users`.* FROM `users` WHERE `users`.`email` = 'hajsu00@gmail.com' LIMIT 1 => #<User id: 51, name: "t_kyab", admin: false, introduction: "", location: "", email: "hajsu00@gmail.com", created_at: "2022-06-01 06:32:41.975876000 +0900", updated_at: "2022-06-01 06:32:41.975876000 +0900">
ログ全文
bash
Started POST "/users" for 172.19.0.1 at 2022-05-31 21:32:41 +0000 [1m[35m (0.9ms)[0m [1m[34mSELECT `schema_migrations`.`version` FROM `schema_migrations` ORDER BY `schema_migrations`.`version` ASC[0m Processing by Users::RegistrationsController#create as HTML Parameters: {"authenticity_token"=>"[FILTERED]", "user"=>{"name"=>"t_kyab", "email"=>"example@gmail.com", "password"=>"[FILTERED]", "password_confirmation"=>"[FILTERED]"}, "commit"=>"認証メールを送信する"} [1m[36mTRANSACTION (0.6ms)[0m [1m[35mBEGIN[0m [1m[36mUser Exists? (0.9ms)[0m [1m[34mSELECT 1 AS one FROM `users` WHERE `users`.`email` = BINARY 'example@gmail.com' LIMIT 1[0m [1m[36mUser Create (0.8ms)[0m [1m[32mINSERT INTO `users` (`name`, `email`, `encrypted_password`, `confirmation_token`, `confirmation_sent_at`, `created_at`, `updated_at`) VALUES ('t_kyab', 'example@gmail.com', '$2a$12$Aak*********************************cHPoO7KKwq', 'wMB***************r1sA', '2022-05-31 21:32:41', '2022-05-31 21:32:41.975876', '2022-05-31 21:32:41.975876')[0m [1m[36mTRANSACTION (4.1ms)[0m [1m[35mCOMMIT[0m Rendering users/mailer/confirmation_instructions.html.erb Rendered users/mailer/confirmation_instructions.html.erb (Duration: 3.6ms | Allocations: 947) Devise::Mailer#confirmation_instructions: processed outbound mail in 392.9ms [Aws::SES::Client 200 0.452997 0 retries] send_raw_email(raw_message:{data:#<String "Date: Tue, 31 May 2022 21:32:42 +0000\r\nFrom: My App Talk <info@myapp.com>\r\nReply-To: My App <info@myapp.com>\r\nTo: example@gmail.com\r\nMessage-ID: <6296897a603b2_17698c6823e@515826d65af1.mail>\r\nSubject: =?UTF-8?Q?=E3=83=A1=E3=83=BC=E3=83=AB=E3=82=A2=E3=83=89=E3=83=AC=E3=82=B9=E7=A2=BA=E8=AA=8D=E3=83=A1=E3=83=BC=E3=83=AB?=\r\nMime-Version: 1.0\r\nContent-Type: text/html;\r\n charset=UTF-8\r\nContent-Transfer-Encoding: base64\r\n\r\nPHA+aGFqc3UwMEBnbWFpbC5jb20g44GV44KTPC9wPg0KDQo8cD7ku6XkuIvj\r\nga7jg6rjg7Pjgq/jgpLjgq/jg6rjg4Pjgq/jgZfjgabjgIHjg6Hjg7zjg6vj\r\ngqLjg4njg6zjgrnjga7oqo3oqLzjgpLlrozkuobjgZfjgabjgY/jgaDjgZXj\r\ngYTjgII8L3A+DQoNCjxwPjxhIGhyZWY9Imh0dHBzOi8vaGFuZ2FydGFsay1h\r\ncHAuY29tL3VzZXJzL2NvbmZpcm1hdGlvbj9jb25maXJtYXRpb25fdG9rZW49\r\nd01CR1lLelRHaGVFTmZaLXIxc0EiPuODoeODvOODq+OCouODieODrOOCueOC\r\nkuiqjeiovOOBmeOCizwvYT48L3A+DQoNCjxwPuKAu+acieWKueacn+mZkOOB\r\nr+acrOODoeODvOODq+OBrueZuuihjOOBi+OCie+8ku+8lOaZgumWk+S7peWG\r\nheOBp+OBmeOAgjwvcD4NCjxwPuKAu+OBk+OBruODoeODvOODq+OBr+mAgeS/" ... (1396 bytes)>},destinations:["example@gmail.com"]) Delivered mail 6296897a603b2_17698c6823e@515826d65af1.mail (461.6ms) Date: Tue, 31 May 2022 21:32:42 +0000 From: My App <info@myapp.com> Reply-To: My App<info@myapp.com> To: example@gmail.com Message-ID: <6296897a603b2_17698c6823e@515826d65af1.mail> Subject: =?UTF-8?Q?=E3=83=A1=E3=83=BC=E3=83=AB=E3=82=A2=E3=83=89=E3=83=AC=E3=82=B9=E7=A2=BA=E8=AA=8D=E3=83=A1=E3=83=BC=E3=83=AB?= Mime-Version: 1.0 Content-Type: text/html; charset=UTF-8 Content-Transfer-Encoding: base64 PHA+aGFqc3UwMEBnbWFpbC5jb20g44GV44KTPC9wPg0KDQo8cD7ku6XkuIvj ga7jg6rjg7Pjgq/jgpLjgq/jg6rjg4Pjgq/jgZfjgabjgIHjg6Hjg7zjg6vj gqLjg4njg6zjgrnjga7oqo3oqLzjgpLlrozkuobjgZfjgabjgY/jgaDjgZXj gYTjgII8L3A+DQoNCjxwPjxhIGhyZWY9Imh0dHBzOi8vaGFuZ2FydGFsay1h cHAuY29tL3VzZXJzL2NvbmZpcm1hdGlvbj9jb25maXJtYXRpb25fdG9rZW49 d01CR1lLelRHaGVFTmZaLXIxc0EiPuODoeODvOODq+OCouODieODrOOCueOC (省略) PHA+LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LS0tLS0tLS08L3A+IA0K Redirected to http://localhost/users/sign_in Completed 302 Found in 1219ms (ActiveRecord: 10.8ms | Allocations: 503206) Started GET "/users/sign_in" for 172.19.0.1 at 2022-05-31 21:32:42 +0000 Processing by Users::SessionsController#new as HTML Rendering layout layouts/application.html.erb Rendering users/sessions/new.html.erb within layouts/application Rendered /usr/local/bundle/gems/devise-i18n-1.10.2/app/views/devise/shared/_error_messages.html.erb (Duration: 0.1ms | Allocations: 13) Rendered users/sessions/new.html.erb within layouts/application (Duration: 7.9ms | Allocations: 2054) [Webpacker] Everything's up-to-date. Nothing to do Rendered layouts/_shim.html.erb (Duration: 0.1ms | Allocations: 7) Rendered layouts/_header.html.erb (Duration: 10.4ms | Allocations: 782) Rendered layouts/_message.html.erb (Duration: 2.4ms | Allocations: 138) Rendered layouts/_notification.html.erb (Duration: 6.8ms | Allocations: 579) Rendered layouts/_footer.html.erb (Duration: 6.7ms | Allocations: 372) Rendered layout layouts/application.html.erb (Duration: 168.2ms | Allocations: 13821) Completed 200 OK in 176ms (Views: 174.1ms | ActiveRecord: 0.0ms | Allocations: 16344)
関連コード
ruby
# myapp/app/controllers/users/registrations_controller.rb ... # POST /resource def create super user = User.find_by(email: params[:user][:email]) if !user.nil? user.avatar.attach(io: File.open(Rails.root.join('app/assets/images/default_avatar.png')), filename: 'default_avatar.png') user.user_cover.attach(io: File.open(Rails.root.join('app/assets/images/default_cover.png')), filename: 'default_cover.png') user.create_glider_initial_log!(at_present: Date.today, total_time: 0, total_number: 0, pic_winch_time: 0, (省略) number_of_stall_recovery: 0) end end ...
ruby
# myapp/app/mailers/application_mailer.rb class ApplicationMailer < ActionMailer::Base default from: 'Myapp <info@myapp.com>' layout 'mailer' end
html.erb
# myapp/app/views/users/mailer/confirmation_instructions.html.erb <p><%= @resource.email %> さん</p> <p>以下のリンクをクリックして、メールアドレスの認証を完了してください。</p> <p><%= link_to 'メールアドレスを認証する', confirmation_url(@resource, confirmation_token: @token) %></p> <p>※有効期限は本メールの発行から24時間以内です。</p> <p>※このメールは送信専用です。ご返信をいただいてもご連絡できかねますのでご了承ください。<br></p>
ruby
# myapp/config/environments/development.rb config.action_mailer.raise_delivery_errors = false config.action_mailer.default_url_options = { host: 'myapp.com', protocol: 'https' } config.action_mailer.delivery_method = :ses config.action_mailer.perform_caching = false
確認したこと
$ rails c
で、データベースに保存された情報を確認しました
##### 今回ユーザー認証に失敗したユーザー 1] pry(main)> User.find_by(email: 'example@gmail.com') User Load (1.1ms) SELECT `users`.* FROM `users` WHERE `users`.`email` = 'example@gmail.com' LIMIT 1 => #<User id: 51, name: "t_kyab", admin: false, introduction: "", location: "", email: "hajsu00@gmail.com", created_at: "2022-06-01 06:32:41.975876000 +0900", updated_at: "2022-06-01 06:32:41.975876000 +0900">
'seed'で保存した、認証済みのユーザー
[2] pry(main)> User.find(1) User Load (1.4ms) SELECT `users`.* FROM `users` WHERE `users`.`id` = 1 LIMIT 1 => #<User id: 1, name: "Example User", admin: true, introduction: "ここはユーザーのプロフィール文です。入力可能な文字数は160字にする予定です。ここはユーザーのプロフ...", location: "東京", email: "example@railstutorial.org", created_at: "2022-06-01 06:31:01.286221000 +0900", updated_at: "2022-06-01 06:31:01.469712000 +0900">
もしかしてconfirmation_tokenは発行はされているが、データベースに保存されていない?
そうだとしても以前のメールサービスでは正常に動いていた点が気になります。
"devise-i18n-views"がインストールされていないことを確認
以下の記事を参考に、devise-i18n-viewsがgemfileに存在しないことを確認し、bundle update
とbundle clean
を実行しましたが、症状は改善しませんでした。
お力を貸していただけると幸いです。
まだ回答がついていません
会員登録して回答してみよう