0

私は現在、簡単な小さなシナトラ アプリを開発しており、認証を非常に簡単に克服することができました。しかし、私は一生、パスワードの変更を機能させることができません。以下のコードを Datamapper で使用しており、リダイレクトに到達するもののパスワードが変化しません。

user = User.first(:token => session[:user])
if params[:newpassword] == params[:newpasswordconfirm]
    if BCrypt::Engine.hash_secret(params[:oldpassword], user.salt) == user.password_hash
        user.password_hash = BCrypt::Engine.hash_secret(params[:newpassword], user.salt)
        user.save
        redirect '/'

私も試してみました

user = User.first(:token => session[:user])
if params[:newpassword] == params[:newpasswordconfirm]
    if BCrypt::Engine.hash_secret(params[:oldpassword], user.salt) == user.password_hash
        user.update(:password_hash = BCrypt::Engine.hash_secret(params[:newpassword], user.salt)
        redirect '/'

ただし、これも値の更新に失敗します。私が間違ったことをしたかわからない。

class User 
include DataMapper::Resource

attr_accessor :password, :password_confirmation

property :id, Serial
property :username, String, :required => true, :unique => true
property :password_hash, Text  
property :salt, Text
property :token, String

validates_presence_of           :password
validates_confirmation_of       :password
validates_length_of             :password, :min => 6
end
4

0 に答える 0