Rails|Deviseのログアウトでルーティングエラー
事象
ユーザー認証にDeviseを使用しているのですが、サインアウトをしようとした際、以下のようにエラーになってしまいます。 ログインまわりのソースコード↓
<% if user_signed_in? %> <!-- current_user は現在ログインしているUserオブジェクトを返すdeviseのHelperメソッド --> <!-- *_path はUserモデルを作成したときに、 deviseにより自動で作成されてますので、rake routesで確認できます --> Logged in as <strong><%= current_user.email %></strong>. <%= link_to 'プロフィール変更', edit_user_registration_path %> | <%= link_to "ログアウト", destroy_user_session_path, method: :delete %> <% else %> <%= link_to "サインイン", new_user_registration_path %> | <%= link_to "ログイン", new_user_session_path %> <% end %>
対応方法
DeviseはデフォルトでDELETEメソッドによりサインアウトさせていますが、今回はこれをGETに変更します。
① hmtl上で送信する際のメソッドを変更
② /config/initializers/devise.rb の config.sign_out_via のメソッドをGETに変更
特定のページのみ特定のCSSを読み込ませる
やりたいこと
特定のページ(今回はサイトのTOPのWelcomeページ)のみ特定のCSSを読み込ませたい。
HOWTO
① 特定のページ用のlayoutを作成する
/app/views/layouts/welcome_layout.html.erb
② コントローラーに使用するlayoutを明記する
class WelcomeController < ApplicationController layout "welcome_layout" # ->これ def index end end
③ /config/initializers/assets.rb に以下を記述
Rails.application.config.assets.precompile += %w( welcome/creative.css ) Rails.application.config.assets.precompile += %w( welcome/creative.min.css ) Rails.application.config.assets.precompile += %w( welcome/style.css )
④ welcome_layout.html.erbに以下を記述
<%= stylesheet_link_tag 'welcome/style', media: 'all' %> <%= stylesheet_link_tag 'welcome/creative', media: 'all' %> <%= stylesheet_link_tag 'welcome/creative.min', media: 'all' %>
※ <%= stylesheet_link_tag ‘application’, media: 'all' %>
は記述しないこと
⑤ サーバー再起動
Vagrant開発環境でメールサーバを立てる
やりたいこと
普段Vagrant上でRuby on Railsのアプリを開発しています。
ユーザー認証にDeviseを使っていてサインアップの際、開発環境でアプリからメールを送りたい場面があったので、今回MailCatcherを使ってメールサーバをVagrant上に立てました。
※ 今回VagrantのIPアドレスは192.168.33.60
としています。
HOWTO
1.Gemをインストールする
※ アプリで使う他のGemと衝突する恐れがあるため、Gemfileには書かない。
$ gem install mailcatcher
2.以下をenvironment/development.rbに記述
config.action_mailer.delivery_method = :smtp config.action_mailer.smtp_settings = { :address => "localhost", :port => 1025 } config.action_mailer.default_url_options = { host: '192.168.33.60', port: 3000 }
3.MailCatcherを起動する
$ mailcatcher --http-ip 192.168.33.60 Starting MailCatcher ==> smtp://127.0.0.1:1025 ==> http://192.168.33.60:1080 *** MailCatcher runs as a daemon by default. Go to the web interface to quit.
4.ブラウザからアクセスする
5.ルート画面からサインインし、メールが送られると、コンソールに以下の文言が表示される
Sent mail to programming_girl@hoge.com (10.1ms) Date: Wed, 05 Oct 2016 09:56:34 +0900 From: please-change-me-at-config-initializers-devise@example.com Reply-To: please-change-me-at-config-initializers-devise@example.com To: programming_girl@hoge.com Message-ID: <57f44fc21f0f5_1cfc3f81bcda37ac325df@develop.mail> Subject: Confirmation instructions Mime-Version: 1.0 Content-Type: text/html; charset=UTF-8 Content-Transfer-Encoding: 7bit <p>Welcome programming_girl@hoge.com!</p> <p>You can confirm your account email through the link below:</p> <p><a href="http://192.168.33.60:3000/users/confirmation?confirmation_token=WPTMz1JQJm3gx4YxCfSt">Confirm my account</a></p> Redirected to http://192.168.33.60:3000/ Completed 302 Found in 200ms (ActiveRecord: 12.4ms)
6.ブラウザ見るとこんなかんじ
本文に確認URLがあるので、Pushする。
あるいは5の文言中のconfirmリンクをブラウザで叩く
http://192.168.33.60:1080:3000//users/confirmation?confirmation_token=79y3We4KFXSMzExiEqsx
7.ログイン画面に遷移するので、ログインする
git configの値の設定
はじめに
いつもいつも値のユーザー名やメアドの設定方法をググっている気がするので、備忘録(´・ω・`)
コミット時のユーザーを設定するよ。
設定の確認
$ git config --global --list user.name=programming_girl user.email=programming_girl@hoge.com core.excludesfile=~/.gitignore core.pager=less -R core.editor=vim color.ui=auto pull.rebase=true push.default=current include.path=~/.gitconfig.local
値の設定
$ git config --global user.name programming_girl $ git config --global user.email programming_girl@hoge.com
Vagrant Share でHTTPS通信する
1.Vagrantfile記述
2.オレオレ証明書を発行
① 証明書の発行
# On Vagrant $ yum install mod_ssl openssl $ openssl genrsa -out ca.key 2048 $ openssl req -new -key ca.key -out ca.csr
② 決められた場所に各ファイルを配置する
$ cp ca.crt /etc/pki/tls/certs/ $ cp ca.key /etc/pki/tls/private/ $ cp ca.csr /etc/pki/tls/private/
③ /etc/httpd/conf.d/ssl.confに以下を記述
SSLCertificateFile /etc/pki/tls/certs/ca.crt SSLCertificateKeyFile /etc/pki/tls/private/ca.key
④ /etc/httpd/conf/httpd.confに以下を記述
Listen 443 LoadModule ssl_module modules/mod_ssl.so NameVirtualHost *:443 # # <VirtualHost *:443> SSLEngine on SSLCertificateFile /etc/pki/tls/certs/ca.crt SSLCertificateKeyFile /etc/pki/tls/private/ca.key <Directory /home/vagrant/www/public> AllowOverride All </Directory> DocumentRoot /home/vagrant/www/public/ ServerName myfirst.test </VirtualHost>
3.Vagrant Shareする
Vagrantが立ち上がっている状態で以下を実行。
$ vagrant share --ssh --https 443
–ssh:シェアする人がSSHでVagrantに入れるようにする設定
–https {{ポート番号}}:Vagrantfile内で定義したdeveliop.vm.network 'forwarded_port', guest: 443, host: 8443
の guest の値
文字化け問題の解決
問題
開発している環境(Vagrant上)で以下の問題が発生。
① viしたときに日本語が文字化けて見える
② git diffしたときに日本語が文字化けて見える
①の解決方法
$ vi ~/.vimrc ---- .vimrc追記内容 ---- set encoding=utf-8 set fileencodings=iso-2022-jp,euc-jp,sjis,utf-8 set fileformats=unix,dos,mac ------------------------ $ source ~/.vimrc
②の解決方法
$ echo "export LESSCHARSET=utf-8" >> ~/.bashrc $ source ~/.bashrc
git の pager が less コマンドを使っていて、その文字コードが utf-8 に設定されていないことが原因。
.bashrc に LESSCHARSET の環境変数を追加。
Vagrant Shareを使ってみた
Vagrant Shareは、ローカルで立てたVagrantの環境へ誰でもアクセスできるようにしてくれます。
まぁとりあえず使ってみよう。
HOW TO
1.ATLASの無料のアカウント作成
https://atlas.hashicorp.com/account/new
2.ローカルのVagrantを立ち上げる
$ vagrant up
3.コマンドライン上からログインする
$ vagrant login You are now logged in.
4.共有できるURLを発行する
$ vagrant share ==> default: Detecting network information for machine... default: Local machine address: 192.168.33.20 default: Local HTTP port: 80 default: Local HTTPS port: disabled ==> default: Checking authentication and authorization... ==> default: Creating Vagrant Share session... default: Share will be at: slight-fox-6296 ==> default: Your Vagrant Share is running! Name: slight-fox-6296 ==> default: URL: http://slight-fox-6296.vagrantshare.com
5.共有をストップ
Ctrl + C
割り振られるURLは毎回違うようです。
Vagrant Shareがお名前解決してくれてるということかな。
すんばらしい〜!