authd/src/requests/login.cr

35 lines
830 B
Crystal
Raw Normal View History

2020-11-22 13:49:34 +01:00
class AuthD::Request
IPC::JSON.message Login, 0 do
2020-11-22 13:49:34 +01:00
property login : String
property password : String
def initialize(@login, @password)
end
def handle(authd : AuthD::Service, fd : Int32)
2020-11-22 13:49:34 +01:00
begin
user = authd.users_per_login.get @login
rescue e : DODB::MissingEntry
return Response::Error.new "invalid credentials"
end
if user.nil?
return Response::Error.new "invalid credentials"
end
if user.password_hash != authd.hash_password @password
return Response::Error.new "invalid credentials"
end
user.date_last_connection = Time.local
token = user.to_token
# change the date of the last connection
authd.users_per_uid.update user.uid.to_s, user
Response::Login.new (token.to_s authd.configuration.shared_key), user.uid
2020-11-22 13:49:34 +01:00
end
end
AuthD.requests << Login
2020-11-22 13:49:34 +01:00
end