ref: master
plugins/stoa/lib/stoa_plugin/auth.rb
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
require 'sinatra' require 'stoa_plugin/person_fields' class StoaPlugin::Auth < Sinatra::Base include StoaPlugin::PersonFields post '/' do headers['Content-Type'] = 'application/json' if params[:login].blank? person = Person.find_by usp_id: params[:usp_id] login = person ? person.user.login : nil else login = params[:login] end domain = Domain.by_name(request.host) environment = domain && domain.environment environment ||= Environment.default user = User.authenticate(login, params[:password], environment) if user result = StoaPlugin::PersonApi.new(user.person, self).fields(selected_fields(params[:fields], user)) result.merge!(:ok => true) else result = { :error => _('Incorrect user/password pair.'), :ok => false } end result.to_json end get '/' do headers['Content-Type'] = 'application/json' { :error => _('Conection requires post method.'), :ok => false }.to_json end end |