From d5e086a47bedc93a1ab2d197e0400ef5bc2d0e3d Mon Sep 17 00:00:00 2001 From: Eugen Rochko Date: Tue, 18 Oct 2016 02:54:49 +0200 Subject: [PATCH] Adding application/jrd+json webfinger resource --- app/controllers/xrd_controller.rb | 18 ++++++++++-------- app/views/xrd/webfinger.json.rabl | 16 ++++++++++++++++ config/initializers/mime_types.rb | 4 ++-- .../components/display_name.test.jsx | 19 +++++++++++++++++++ storybook/config.js | 1 + storybook/stories/tabs_bar.story.jsx | 6 ++++++ 6 files changed, 54 insertions(+), 10 deletions(-) create mode 100644 app/views/xrd/webfinger.json.rabl create mode 100644 spec/javascript/components/display_name.test.jsx create mode 100644 storybook/stories/tabs_bar.story.jsx diff --git a/app/controllers/xrd_controller.rb b/app/controllers/xrd_controller.rb index 9201eb6c..e00485f5 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) diff --git a/app/views/xrd/webfinger.json.rabl b/app/views/xrd/webfinger.json.rabl new file mode 100644 index 00000000..0de17ac1 --- /dev/null +++ b/app/views/xrd/webfinger.json.rabl @@ -0,0 +1,16 @@ +object @account + +node(:subject) { @canonical_account_uri } + +node(:aliases) do + [TagManager.instance.url_for(@account)] +end + +node(:links) do + [ + { rel: 'http://webfinger.net/rel/profile-page', type: 'text/html', href: TagManager.instance.url_for(@account) }, + { rel: 'http://schemas.google.com/g/2010#updates-from', type: 'application/atom+xml', href: account_url(@account, format: 'atom') }, + { rel: 'salmon', href: api_salmon_url(@account.id) }, + { rel: 'magic-public-key', href: "data:application/magic-public-key,#{@magic_key}" } + ] +end diff --git a/config/initializers/mime_types.rb b/config/initializers/mime_types.rb index dc189968..5a16a14e 100644 --- a/config/initializers/mime_types.rb +++ b/config/initializers/mime_types.rb @@ -1,4 +1,4 @@ # Be sure to restart your server when you modify this file. -# Add new mime types for use in respond_to blocks: -# Mime::Type.register "text/richtext", :rtf +Mime::Type.register "application/json", :json, %w( text/x-json application/jsonrequest application/jrd+json ) +Mime::Type.register "text/xml", :xml, %w( application/xml application/atom+xml application/xrd+xml ) diff --git a/spec/javascript/components/display_name.test.jsx b/spec/javascript/components/display_name.test.jsx new file mode 100644 index 00000000..c25eb853 --- /dev/null +++ b/spec/javascript/components/display_name.test.jsx @@ -0,0 +1,19 @@ +import { expect } from 'chai'; +import { render } from 'enzyme'; +import Immutable from 'immutable'; + +import DisplayName from '../../../app/assets/javascripts/components/components/display_name' + +describe('', () => { + const account = Immutable.fromJS({ + username: 'bar', + acct: 'bar@baz', + display_name: 'Foo' + }); + + const wrapper = render(); + + it('renders display name', () => { + expect(wrapper.text()).to.match(/Foo @bar@baz/); + }); +}); diff --git a/storybook/config.js b/storybook/config.js index 98dde07d..d9fde833 100644 --- a/storybook/config.js +++ b/storybook/config.js @@ -11,6 +11,7 @@ window.React = React; function loadStories () { require('./stories/loading_indicator.story.jsx'); require('./stories/button.story.jsx'); + require('./stories/tabs_bar.story.jsx'); } configure(loadStories, module); diff --git a/storybook/stories/tabs_bar.story.jsx b/storybook/stories/tabs_bar.story.jsx new file mode 100644 index 00000000..daaedca5 --- /dev/null +++ b/storybook/stories/tabs_bar.story.jsx @@ -0,0 +1,6 @@ +import TabsBar from '../../app/assets/javascripts/components/features/ui/components/tabs_bar.jsx' + +storiesOf('TabsBar', module) + .add('default state', () => ( + + ));