介绍
在本教程的第一部分中,我们学习了如何安装Devise并在Rails应用程序中进行设置。 在这一部分中,我们将研究如何集成DeviseInvitable。
DeviseInvitable是与Devise一起使用的扩展。 通过在您的应用程序中使用DeviseInvitable,您的用户可以通过电子邮件邀请朋友。 如果您正在构建协作应用程序,那么这是一项很棒的功能,可以包含在您的应用程序中。
设置DeviseInvitable
打开您的Gemfile
并添加gem:
#Gemfile
...
gem 'devise_invitable'
运行命令以安装bundle install
。
运行generator命令将DeviseInvitable的配置选项添加到Devise配置文件中。
rails generate devise_invitable:install
您可以通过使用文本编辑器检出config/initializers/devise.rb
来查看新更改。
接下来,让我们将DeviseInvitable添加到我们的User
模型。
rails generate devise_invitable User
这会在您的模型中添加:invitable
标志,因此您的User模型将如下所示:
#app/models/user.rb
class User < ActiveRecord::Base
# Include default devise modules. Others available are:
# :confirmable, :lockable, :timeoutable and :omniauthable
devise :invitable, :database_authenticatable, :registerable,
:recoverable, :rememberable, :trackable, :validatable
end
运行上面的命令还会生成一个迁移文件,看起来像我下面的内容:
class DeviseInvitableAddToUsers < ActiveRecord::Migration
def up
change_table :users do |t|
t.string :invitation_token
t.datetime :invitation_created_at
t.datetime :invitation_sent_at
t.datetime :invitation_accepted_at
t.integer :invitation_limit
t.references :invited_by, polymorphic: true
t.integer :invitations_count, default: 0
t.index :invitations_count
t.index :invitation_token, unique: true # for invitable
t.index :invited_by_id
end
end
def down
change_table :users do |t|
t.remove_references :invited_by, polymorphic: true
t.remove :invitations_count, :invitation_limit, :invitation_sent_at, :invitation_accepted_at, :invitation_token, :invitation_created_at
end
end
end
现在,通过运行rake db:migrate
数据库。
为DeviseInvitable配置控制器
发送邀请时,需要DeviseInvitable传递一些参数。 为此,我们需要将要使用的必要参数列入白名单。 使用您的文本编辑器,导航到app/controllers/application_controller.rb
并使您的外观如下所示:
#app/controllers/application_controller.rb
class ApplicationController < ActionController::Base
# Prevent CSRF attacks by raising an exception.
# For APIs, you may want to use :null_session instead.
protect_from_forgery with: :exception
before_action :configure_permitted_parameters, if: :devise_controller?
protected
def configure_permitted_parameters
added_attrs = [:username, :email, :password, :password_confirmation, :remember_me]
devise_parameter_sanitizer.permit :sign_up, keys: added_attrs
devise_parameter_sanitizer.permit :account_update, keys: added_attrs
devise_parameter_sanitizer.permit :accept_invitation, keys: [:email]
end
end
从上面可以看到, :email
已被列入DeviseInvitable的白名单。
现在,让我们看看通过控制台获得的内容。 在终端上,运行rails console
并在下面输入内容。
[1] pry(main)> User.invite!(:email => "johndoe@example.com")
它应该产生的输出看起来像我下面的内容,尽管会有差异。
[2] pry(main)> User Load (78.3ms) SELECT "users".* FROM "users" WHERE "users"."email" = ? ORDER BY "users"."id" ASC LIMIT 1 [["email", "johndoe@example.com"]]
User Load (0.2ms) SELECT "users".* FROM "users" WHERE "users"."invitation_token" = ? ORDER BY "users"."id" ASC LIMIT 1 [["invitation_token", "658da470d5fcbb2275f30bc1fb66f5771b889cec2f1e56f536319d2fd1ef4a92"]]
(0.1ms) begin transaction
SQL (67.8ms) INSERT INTO "users" ("email", "encrypted_password", "invitation_token", "invitation_created_at", "invitation_sent_at", "created_at", "updated_at") VALUES (?, ?, ?, ?, ?, ?, ?) [["email", "johndoe@example.com"], ["encrypted_password", "$2a$11$0sLfqvfFDsebcmcQTUXzlOuqNIooL5z8niXeza8OUwNK3gZY/iRum"], ["invitation_token", "658da470d5fcbb2275f30bc1fb66f5771b889cec2f1e56f536319d2fd1ef4a92"], ["invitation_created_at", "2016-10-07 07:41:51.254047"], ["invitation_sent_at", "2016-10-07 07:41:51.254047"], ["created_at", "2016-10-07 07:41:51.255700"], ["updated_at", "2016-10-07 07:41:51.255700"]]
(220.5ms) commit transaction
Rendered /home/kinsomicrote/.rbenv/versions/2.3.0/lib/ruby/gems/2.3.0/gems/devise_invitable-1.7.0/app/views/devise/mailer/invitation_instructions.html.erb (2.5ms)
Rendered /home/kinsomicrote/.rbenv/versions/2.3.0/lib/ruby/gems/2.3.0/gems/devise_invitable-1.7.0/app/views/devise/mailer/invitation_instructions.text.erb (88.0ms)
Devise::Mailer#invitation_instructions: processed outbound mail in 247.1ms
Sent mail to johndoe@example.com (74.3ms)
Date: Fri, 07 Oct 2016 08:41:51 +0100
From: please-change-me-at-config-initializers-devise@example.com
Reply-To: please-change-me-at-config-initializers-devise@example.com
To: johndoe@example.com
Message-ID: <57f751bfce8d6_18022ac6c272b12840661@kinsomicrote-X553MA.mail>
Subject: Invitation instructions
Mime-Version: 1.0
Content-Type: multipart/alternative;
boundary="--==_mimepart_57f751bfcc725_18022ac6c272b12840524";
charset=UTF-8
Content-Transfer-Encoding: 7bit
----==_mimepart_57f751bfcc725_18022ac6c272b12840524
Content-Type: text/plain;
charset=UTF-8
Content-Transfer-Encoding: 7bit
Hello johndoe@example.com
Someone has invited you to https://localhost:3000/, you can accept it through the link below.
http://localhost:3000/users/invitation/accept?invitation_token=xmW9uRfyafptmeFMmFBy
If you don't want to accept the invitation, please ignore this email.
Your account won't be created until you access the link above and set your password.
----==_mimepart_57f751bfcc725_18022ac6c272b12840524
Content-Type: text/html;
charset=UTF-8
Content-Transfer-Encoding: 7bit
<p>Hello johndoe@example.com</p>
<p>Someone has invited you to http://localhost:3000/, you can accept it through the link below.</p>
<p><a href="http://localhost:3000/users/invitation/accept?invitation_token=xmW9uRfyafptmeFMmFBy">Accept invitation</a></p>
<p>If you don't want to accept the invitation, please ignore this email.<br />
Your account won't be created until you access the link above and set your password.</p>
----==_mimepart_57f751bfcc725_18022ac6c272b12840524--
=> #<User:0x00558d875fa798
id: 4,
email: "johndoe@example.com",
encrypted_password: "$2a$11$0sLfqvfFDsebcmcQTUXzlOuqNIooL5z8niXeza8OUwNK3gZY/iRum",
reset_password_token: nil,
reset_password_sent_at: nil,
remember_created_at: nil,
sign_in_count: 0,
current_sign_in_at: nil,
last_sign_in_at: nil,
current_sign_in_ip: nil,
last_sign_in_ip: nil,
created_at: Fri, 07 Oct 2016 07:41:51 UTC +00:00,
updated_at: Fri, 07 Oct 2016 07:41:51 UTC +00:00,
username: nil,
invitation_token: "658da470d5fcbb2275f30bc1fb66f5771b889cec2f1e56f536319d2fd1ef4a92",
invitation_created_at: Fri, 07 Oct 2016 07:41:51 UTC +00:00,
invitation_sent_at: Fri, 07 Oct 2016 07:41:51 UTC +00:00,
invitation_accepted_at: nil,
invitation_limit: nil,
invited_by_id: nil,
invited_by_type: nil,
invitations_count: 0>
[3] pry(main)>
这按计划进行。
您不希望我们的用户通过命令行发送邀请,因此重要的是,我们将DeviseInvitable设置为在前端工作。 这样做非常简单; 运行generator命令生成DeviseInvitable的视图。
rails generate devise_invitable:views users
您还需要在应用程序中的某个位置添加指向该页面的链接,以发送邀请( app/views/users/invitations/new.html.erb
)。
对于此应用程序,您可以继续并将链接添加到导航文件。 这是我的工作方式:
#app/views/shared/_navigation.html.erb
<nav class="navbar navbar-inverse">
<div class="container">
<div class="navbar-header">
<%= link_to 'Tutsplus Devise', root_path, class: 'navbar-brand' %>
</div>
<div id="navbar">
<ul class="nav navbar-nav">
<li><%= link_to 'Home', root_path %></li>
</ul>
<ul class="nav navbar-nav pull-right">
<% if user_signed_in? %>
<li class="dropdown">
<a class="dropdown-toggle" data-toggle="dropdown" href="#">
<%= current_user.username %>
<span class="caret"></span>
</a>
<ul class="dropdown-menu" role="menu">
<li><%= link_to 'Invite', new_user_invitation_path %></li>
<li><%= link_to 'Profile', edit_user_registration_path %></li>
<li><%= link_to 'Log out', destroy_user_session_path, method: :delete %></li>
</ul>
</li>
<% else %>
<li><%= link_to 'Log In', new_user_session_path %></li>
<li><%= link_to 'Sign Up', new_user_registration_path %></li>
<% end %>
</ul>
</div>
</div>
</nav>
要查看DeviseInvitable提供的路由,请运行命令rake routes | invit
rake routes | invit
。 这是输出的样子。
cancel_user_registration GET /users/cancel(.:format) devise_invitable/registrations#cancel
user_registration POST /users(.:format) devise_invitable/registrations#create
new_user_registration GET /users/sign_up(.:format) devise_invitable/registrations#new
edit_user_registration GET /users/edit(.:format) devise_invitable/registrations#edit
PATCH /users(.:format) devise_invitable/registrations#update
PUT /users(.:format) devise_invitable/registrations#update
DELETE /users(.:format) devise_invitable/registrations#destroy
accept_user_invitation GET /users/invitation/accept(.:format) devise/invitations#edit
remove_user_invitation GET /users/invitation/remove(.:format) devise/invitations#destroy
user_invitation POST /users/invitation(.:format) devise/invitations#create
new_user_invitation GET /users/invitation/new(.:format) devise/invitations#new
PATCH /users/invitation(.:format) devise/invitations#update
PUT /users/invitation(.:format) devise/invitations#update
让我们看看目前的状况。 运行命令以启动服务器; rails server
。
将浏览器指向http://localhost:3000/users/invitation/new
。 输入显示形式的电子邮件地址,然后单击按钮。 那应该工作! 如果转到服务器的日志,则应该看到发送邀请时创建的输出。 在输出中,您将看到一个接受邀请的链接。
您将与我同意,如果您可以查看在浏览器中发送的电子邮件,将会更好。 让我们看看如何进行这项工作。
集成Letter_Opener
Letter Opener允许您在默认浏览器中预览电子邮件。 使用它,在开发环境中工作时不必建立邮件传递系统。
打开您的Gemfile并添加以下gem:
gem 'letter_opener'
运行bundle install
。
使用文本编辑器,导航至config/environments/development.rb
并添加以下行。
#config/environments/development.rb
...
config.action_mailer.delivery_method = :letter_opener
end
重新启动Rails服务器。 现在,将浏览器指向http://localhost:3000/users/invitation/new
。 填写并提交显示的表单。 这次,将弹出一个包含邀请电子邮件的新页面。
更改默认登录和注销路线
默认情况下,使用Devise时, sign_in
和sign_out
路由如下所示:
sign_in:
http://localhost:3000/users/sign_in
sign_out:
http://localhost:3000/users/sign_out
要更改它,请转到config/routes.rb
并添加以下内容:
#config/routes.rb
as :user do
get 'signin' => 'devise/sessions#new'
post 'signin' => 'devise/sessions#create'
delete 'signout' => 'devise/sessions#destroy'
end
您可以将浏览器指向http://localhost:3000/signin
。
结论
现在您知道了如何使用DeviseInvitable。 您还了解了gem letter_opener
。 您可以使用Devise做很多事情,因此请查阅Wiki了解更多信息。 谢谢你陪我
翻译自: https://code.tutsplus.com/tutorials/exploring-devise-part-2--cms-27390