diff options
author | Eugen Rochko <eugen@zeonfederated.com> | 2016-10-18 02:54:49 +0200 |
---|---|---|
committer | Eugen Rochko <eugen@zeonfederated.com> | 2016-10-18 02:54:49 +0200 |
commit | d5e086a47bedc93a1ab2d197e0400ef5bc2d0e3d (patch) | |
tree | a667b5b71c02419c03121004a08719c33b290408 /app/controllers | |
parent | 7bb72ff198d9fb0747f8ded25140be35943484a0 (diff) |
Adding application/jrd+json webfinger resource
Diffstat (limited to 'app/controllers')
-rw-r--r-- | app/controllers/xrd_controller.rb | 18 |
1 files changed, 10 insertions, 8 deletions
diff --git a/app/controllers/xrd_controller.rb b/app/controllers/xrd_controller.rb index 9201eb6c1..e00485f5e 100644 --- a/app/controllers/xrd_controller.rb +++ b/app/controllers/xrd_controller.rb @@ -1,27 +1,29 @@ class XrdController < ApplicationController - before_action :set_format - def host_meta @webfinger_template = "#{webfinger_url}?resource={uri}" + + respond_to do |format| + format.xml { render content_type: 'application/xrd+xml' } + end end def webfinger @account = Account.find_local!(username_from_resource) @canonical_account_uri = "acct:#{@account.username}@#{Rails.configuration.x.local_domain}" @magic_key = pem_to_magic_key(@account.keypair.public_key) + + respond_to do |format| + format.xml { render content_type: 'application/xrd+xml' } + format.json { render content_type: 'application/jrd+json' } + end rescue ActiveRecord::RecordNotFound head 404 end private - def set_format - request.format = 'xml' - response.headers['Content-Type'] = 'application/xrd+xml' - end - def username_from_resource - if resource_param.start_with?('acct:') + if resource_param.start_with?('acct:') || resource_param.include?('@') resource_param.split('@').first.gsub('acct:', '') else url = Addressable::URI.parse(resource_param) |