.circleci
.github
app
chewy
controllers
activitypub
admin
api
auth
concerns
account_controller_concern.rb
account_owned_concern.rb
accountable_concern.rb
authorization.rb
cache_concern.rb
challengable_concern.rb
export_controller_concern.rb
localized.rb
rate_limit_headers.rb
registration_spam_concern.rb
session_tracking_concern.rb
sign_in_token_authentication_concern.rb
signature_authentication.rb
signature_verification.rb
status_controller_concern.rb
two_factor_authentication_concern.rb
user_tracking_concern.rb
oauth
settings
well_known
about_controller.rb
account_follow_controller.rb
account_unfollow_controller.rb
accounts_controller.rb
application_controller.rb
authorize_interactions_controller.rb
custom_css_controller.rb
directories_controller.rb
emojis_controller.rb
filters_controller.rb
follower_accounts_controller.rb
following_accounts_controller.rb
home_controller.rb
instance_actors_controller.rb
intents_controller.rb
invites_controller.rb
manifests_controller.rb
media_controller.rb
media_proxy_controller.rb
public_timelines_controller.rb
relationships_controller.rb
remote_follow_controller.rb
remote_interaction_controller.rb
shares_controller.rb
statuses_controller.rb
tags_controller.rb
helpers
javascript
lib
mailers
models
policies
presenters
serializers
services
validators
views
workers
bin
chart
config
db
dist
lib
log
nanobox
public
spec
streaming
vendor
.buildpacks
.codeclimate.yml
.dockerignore
.editorconfig
.env.nanobox
.env.production.sample
.env.test
.env.vagrant
.eslintignore
.eslintrc.js
.foreman
.gitattributes
.gitignore
.haml-lint.yml
.nanoignore
.nvmrc
.profile
.rspec
.rubocop.yml
.ruby-version
.sass-lint.yml
.slugignore
.yarnclean
AUTHORS.md
Aptfile
CHANGELOG.md
CODE_OF_CONDUCT.md
CONTRIBUTING.md
Capfile
Dockerfile
Gemfile
Gemfile.lock
LICENSE
Procfile
Procfile.dev
README.md
Rakefile
SECURITY.md
Vagrantfile
app.json
babel.config.js
boxfile.yml
config.ru
crowdin.yml
docker-compose.yml
ide-helper.js
package.json
postcss.config.js
priv-config
scalingo.json
yarn.lock
* Add HTTP signature requirement for served ActivityPub resources * Change `SECURE_MODE` to `AUTHORIZED_FETCH` * Add 'Signature' to 'Vary' header and improve code style * Improve code style by adding `public_fetch_mode?` method
50 lines
962 B
Ruby
50 lines
962 B
Ruby
# frozen_string_literal: true
|
|
|
|
module AccountControllerConcern
|
|
extend ActiveSupport::Concern
|
|
|
|
include AccountOwnedConcern
|
|
|
|
FOLLOW_PER_PAGE = 12
|
|
|
|
included do
|
|
layout 'public'
|
|
|
|
before_action :set_instance_presenter
|
|
before_action :set_link_headers, if: -> { request.format.nil? || request.format == :html }
|
|
end
|
|
|
|
private
|
|
|
|
def set_instance_presenter
|
|
@instance_presenter = InstancePresenter.new
|
|
end
|
|
|
|
def set_link_headers
|
|
response.headers['Link'] = LinkHeader.new(
|
|
[
|
|
webfinger_account_link,
|
|
actor_url_link,
|
|
]
|
|
)
|
|
end
|
|
|
|
def webfinger_account_link
|
|
[
|
|
webfinger_account_url,
|
|
[%w(rel lrdd), %w(type application/jrd+json)],
|
|
]
|
|
end
|
|
|
|
def actor_url_link
|
|
[
|
|
ActivityPub::TagManager.instance.uri_for(@account),
|
|
[%w(rel alternate), %w(type application/activity+json)],
|
|
]
|
|
end
|
|
|
|
def webfinger_account_url
|
|
webfinger_url(resource: @account.to_webfinger_s)
|
|
end
|
|
end
|