mirror of
https://github.com/neocities/neocities.git
synced 2025-04-25 01:32:36 +02:00
undelete site on password reset if deleted
This commit is contained in:
parent
c57f636e13
commit
d2f977635c
3 changed files with 40 additions and 1 deletions
|
@ -70,6 +70,13 @@ get '/password_reset_confirm' do
|
|||
redirect '/'
|
||||
end
|
||||
|
||||
if reset_site.is_deleted
|
||||
unless reset_site.undelete!
|
||||
flash[:error] = "Sorry, we cannot restore this account."
|
||||
redirect '/'
|
||||
end
|
||||
end
|
||||
|
||||
reset_site.password_reset_confirmed = true
|
||||
reset_site.save_changes
|
||||
|
||||
|
|
|
@ -91,6 +91,38 @@ describe '/password_reset' do
|
|||
_(@site.password_reset_confirmed).must_equal false
|
||||
end
|
||||
|
||||
it 'works for deleted site' do
|
||||
@site = Fabricate :site
|
||||
@site.destroy
|
||||
visit '/password_reset'
|
||||
fill_in 'email', with: @site.email
|
||||
click_button 'Send Reset Token'
|
||||
|
||||
_(body).must_match /We sent an e-mail with password reset instructions/
|
||||
_(@site.reload.password_reset_token.blank?).must_equal false
|
||||
_(EmailWorker.jobs.first['args'].first['body']).must_match /#{Rack::Utils.build_query(username: @site.username, token: @site.password_reset_token)}/
|
||||
|
||||
visit "/password_reset_confirm?#{Rack::Utils.build_query username: @site.username, token: @site.reload.password_reset_token}"
|
||||
|
||||
_(@site.reload.password_reset_token).wont_be_nil
|
||||
_(@site.password_reset_confirmed).must_equal true
|
||||
|
||||
_(page.current_url).must_match /.+\/settings#password/
|
||||
|
||||
fill_in 'new_password', with: 'n3wp4s$'
|
||||
fill_in 'new_password_confirm', with: 'n3wp4s$'
|
||||
click_button 'Change Password'
|
||||
|
||||
_(page.current_url).must_match /.+\/settings#password/
|
||||
_(page).must_have_content 'Successfully changed password'
|
||||
_(Site.valid_login?(@site.username, 'n3wp4s$')).must_equal true
|
||||
_(page.get_rack_session['id']).must_equal @site.id
|
||||
_(@site.reload.password_reset_token).must_be_nil
|
||||
_(@site.password_reset_confirmed).must_equal false
|
||||
end
|
||||
|
||||
|
||||
|
||||
it 'fails if timestamp is too old' do
|
||||
@site = Fabricate :site
|
||||
visit '/password_reset'
|
||||
|
|
|
@ -13,5 +13,5 @@
|
|||
<p>Confirm New Password:</p>
|
||||
<input class="input-Area" name="new_password_confirm" type="password">
|
||||
|
||||
<input class="btn-Action" type="submit" value="Change Password">
|
||||
<p><input class="btn-Action" type="submit" value="Change Password"></p>
|
||||
</form>
|
||||
|
|
Loading…
Add table
Reference in a new issue