mirror of
https://github.com/discourse/discourse.git
synced 2025-01-18 20:22:45 +08:00
FIX: Check if invite has expired before showing it (#10581)
This commit is contained in:
parent
38c9c87128
commit
ef68e11137
|
@ -19,7 +19,7 @@ class InvitesController < ApplicationController
|
||||||
|
|
||||||
invite = Invite.find_by(invite_key: params[:id])
|
invite = Invite.find_by(invite_key: params[:id])
|
||||||
|
|
||||||
if invite.present?
|
if invite.present? && !invite.expired?
|
||||||
if !invite.redeemed?
|
if !invite.redeemed?
|
||||||
store_preloaded("invite_info", MultiJson.dump(
|
store_preloaded("invite_info", MultiJson.dump(
|
||||||
invited_by: UserNameSerializer.new(invite.invited_by, scope: guardian, root: false),
|
invited_by: UserNameSerializer.new(invite.invited_by, scope: guardian, root: false),
|
||||||
|
|
|
@ -20,6 +20,18 @@ describe InvitesController do
|
||||||
expect(CGI.unescapeHTML(body)).to include(I18n.t('invite.not_found', base_url: Discourse.base_url))
|
expect(CGI.unescapeHTML(body)).to include(I18n.t('invite.not_found', base_url: Discourse.base_url))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it "returns error if invite expired" do
|
||||||
|
invite.update(expires_at: 1.day.ago)
|
||||||
|
|
||||||
|
get "/invites/#{invite.invite_key}"
|
||||||
|
|
||||||
|
expect(response.status).to eq(200)
|
||||||
|
|
||||||
|
body = response.body
|
||||||
|
expect(body).to_not have_tag(:script, with: { src: '/assets/application.js' })
|
||||||
|
expect(CGI.unescapeHTML(body)).to include(I18n.t('invite.not_found', base_url: Discourse.base_url))
|
||||||
|
end
|
||||||
|
|
||||||
it "renders the accept invite page if invite exists" do
|
it "renders the accept invite page if invite exists" do
|
||||||
get "/invites/#{invite.invite_key}"
|
get "/invites/#{invite.invite_key}"
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user