dnsmanager/src/requests/login.cr

34 lines
1 KiB
Crystal
Raw Normal View History

class DNSManager::Request
IPC::JSON.message Login, 0 do
property token : String
def initialize(@token)
end
def handle(dnsmanagerd : DNSManager::Service, event : IPC::Event)
2023-06-15 14:11:13 +02:00
response = dnsmanagerd.decode_token token
case response
when AuthD::Response::User
dnsmanagerd.logged_users[event.fd] = response.user
# In case we want to log their last connection.
#dnsmanagerd.auth.edit_profile_content user.uid, {
# "dnsmanager-last-connection" => JSON::Any.new Time.utc.to_s
#}
user_data = dnsmanagerd.storage.ensure_user_data response.user.uid
return Response::Error.new "invalid user" unless user_data
accepted_domains = dnsmanagerd.configuration.accepted_domains.not_nil!
user_domains = user_data.domains
Response::Logged.new accepted_domains, user_domains
2023-06-15 14:11:13 +02:00
else
Response::ErrorInvalidToken.new
end
rescue e
# FIXME: Should those be logged?
2023-06-18 02:36:30 +02:00
Baguette::Log.error "Error: #{e}"
2023-05-07 18:32:32 +02:00
Response::Error.new "unauthorized"
end
end
DNSManager.requests << Login
end