Skip to content

Commit

Permalink
Adding application/jrd+json webfinger resource
Browse files Browse the repository at this point in the history
  • Loading branch information
Gargron committed Oct 18, 2016
1 parent 7bb72ff commit d5e086a
Show file tree
Hide file tree
Showing 6 changed files with 54 additions and 10 deletions.
18 changes: 10 additions & 8 deletions app/controllers/xrd_controller.rb
Original file line number Diff line number Diff line change
@@ -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)
Expand Down
16 changes: 16 additions & 0 deletions app/views/xrd/webfinger.json.rabl
Original file line number Diff line number Diff line change
@@ -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
4 changes: 2 additions & 2 deletions config/initializers/mime_types.rb
Original file line number Diff line number Diff line change
@@ -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 )
19 changes: 19 additions & 0 deletions spec/javascript/components/display_name.test.jsx
Original file line number Diff line number Diff line change
@@ -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('<DisplayName />', () => {
const account = Immutable.fromJS({
username: 'bar',
acct: 'bar@baz',
display_name: 'Foo'
});

const wrapper = render(<DisplayName account={account} />);

it('renders display name', () => {
expect(wrapper.text()).to.match(/Foo @bar@baz/);
});
});
1 change: 1 addition & 0 deletions storybook/config.js
Original file line number Diff line number Diff line change
Expand Up @@ -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);
6 changes: 6 additions & 0 deletions storybook/stories/tabs_bar.story.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
import TabsBar from '../../app/assets/javascripts/components/features/ui/components/tabs_bar.jsx'

storiesOf('TabsBar', module)
.add('default state', () => (
<TabsBar />
));

0 comments on commit d5e086a

Please sign in to comment.