Browse Source

Add API for retrieving blocked accounts

master
Eugen Rochko 7 years ago
parent
commit
49834a6e7f
15 changed files with 50 additions and 14 deletions
  1. +1
    -0
      .rubocop.yml
  2. +21
    -0
      app/controllers/api/v1/blocks_controller.rb
  3. +0
    -2
      app/helpers/api/oembed_helper.rb
  4. +0
    -2
      app/helpers/api/v1/follow_requests_helper.rb
  5. +2
    -0
      app/helpers/authorize_follow_helper.rb
  6. +1
    -1
      app/helpers/stream_entries_helper.rb
  7. +1
    -0
      app/models/block.rb
  8. +2
    -0
      app/views/api/v1/blocks/index.rabl
  9. +1
    -1
      app/workers/processing_worker.rb
  10. +1
    -1
      app/workers/salmon_worker.rb
  11. +1
    -0
      config/routes.rb
  12. +0
    -1
      spec/controllers/api/v1/accounts_controller_spec.rb
  13. +19
    -0
      spec/controllers/api/v1/blocks_controller_spec.rb
  14. +0
    -1
      spec/controllers/api/v1/timelines_controller_spec.rb
  15. +0
    -5
      spec/helpers/api/oembed_helper_spec.rb

+ 1
- 0
.rubocop.yml View File

@@ -86,3 +86,4 @@ AllCops:
- 'config/**/*'
- 'bin/*'
- 'Rakefile'
- 'node_modules/**/*'

+ 21
- 0
app/controllers/api/v1/blocks_controller.rb View File

@@ -0,0 +1,21 @@
# frozen_string_literal: true

class Api::V1::BlocksController < ApiController
before_action -> { doorkeeper_authorize! :follow }
before_action :require_user!

respond_to :json

def index
results = Block.where(account: current_account).paginate_by_max_id(DEFAULT_ACCOUNTS_LIMIT, params[:max_id], params[:since_id])
accounts = Account.where(id: results.map(&:target_account_id)).map { |a| [a.id, a] }.to_h
@accounts = results.map { |f| accounts[f.target_account_id] }

set_account_counters_maps(@accounts)

next_path = api_v1_blocks_url(max_id: results.last.id) if results.size == DEFAULT_ACCOUNTS_LIMIT
prev_path = api_v1_blocks_url(since_id: results.first.id) unless results.empty?

set_pagination_headers(next_path, prev_path)
end
end

+ 0
- 2
app/helpers/api/oembed_helper.rb View File

@@ -1,2 +0,0 @@
module Api::OembedHelper
end

+ 0
- 2
app/helpers/api/v1/follow_requests_helper.rb View File

@@ -1,2 +0,0 @@
module Api::V1::FollowRequestsHelper
end

+ 2
- 0
app/helpers/authorize_follow_helper.rb View File

@@ -1,2 +1,4 @@
# frozen_string_literal: true

module AuthorizeFollowHelper
end

+ 1
- 1
app/helpers/stream_entries_helper.rb View File

@@ -10,7 +10,7 @@ module StreamEntriesHelper
end

def avatar_for_status_url(status)
status.reblog? ? status.reblog.account.avatar.url( :original) : status.account.avatar.url( :original)
status.reblog? ? status.reblog.account.avatar.url(:original) : status.account.avatar.url(:original)
end

def entry_classes(status, is_predecessor, is_successor, include_threads)


+ 1
- 0
app/models/block.rb View File

@@ -1,6 +1,7 @@
# frozen_string_literal: true

class Block < ApplicationRecord
include Paginable
include Streamable

belongs_to :account


+ 2
- 0
app/views/api/v1/blocks/index.rabl View File

@@ -0,0 +1,2 @@
collection @accounts
extends 'api/v1/accounts/show'

+ 1
- 1
app/workers/processing_worker.rb View File

@@ -2,7 +2,7 @@

class ProcessingWorker
include Sidekiq::Worker
sidekiq_options backtrace: true

def perform(account_id, body)


+ 1
- 1
app/workers/salmon_worker.rb View File

@@ -2,7 +2,7 @@

class SalmonWorker
include Sidekiq::Worker
sidekiq_options backtrace: true

def perform(account_id, body)


+ 1
- 0
config/routes.rb View File

@@ -100,6 +100,7 @@ Rails.application.routes.draw do
resources :follows, only: [:create]
resources :media, only: [:create]
resources :apps, only: [:create]
resources :blocks, only: [:index]

resources :follow_requests, only: [:index] do
member do


+ 0
- 1
spec/controllers/api/v1/accounts_controller_spec.rb View File

@@ -7,7 +7,6 @@ RSpec.describe Api::V1::AccountsController, type: :controller do
let(:token) { double acceptable?: true, resource_owner_id: user.id }

before do
stub_request(:post, "https://pubsubhubbub.superfeedr.com/").to_return(:status => 200, :body => "", :headers => {})
allow(controller).to receive(:doorkeeper_token) { token }
end



+ 19
- 0
spec/controllers/api/v1/blocks_controller_spec.rb View File

@@ -0,0 +1,19 @@
require 'rails_helper'

RSpec.describe Api::V1::BlocksController, type: :controller do
render_views

let(:user) { Fabricate(:user, account: Fabricate(:account, username: 'alice')) }
let(:token) { double acceptable?: true, resource_owner_id: user.id }

before do
allow(controller).to receive(:doorkeeper_token) { token }
end

describe 'GET #index' do
it 'returns http success' do
get :index
expect(response).to have_http_status(:success)
end
end
end

+ 0
- 1
spec/controllers/api/v1/timelines_controller_spec.rb View File

@@ -6,7 +6,6 @@ RSpec.describe Api::V1::TimelinesController, type: :controller do
let(:user) { Fabricate(:user, account: Fabricate(:account, username: 'alice')) }

before do
stub_request(:post, "https://pubsubhubbub.superfeedr.com/").to_return(:status => 200, :body => "", :headers => {})
allow(controller).to receive(:doorkeeper_token) { token }
end



+ 0
- 5
spec/helpers/api/oembed_helper_spec.rb View File

@@ -1,5 +0,0 @@
require 'rails_helper'

RSpec.describe Api::OembedHelper, type: :helper do

end

Loading…
Cancel
Save