fix incorrect broadcast endpoints - add correct broadcasts endpoint
This commit is contained in:
parent
bd61d1e58e
commit
1640c33517
|
@ -1,11 +1,13 @@
|
||||||
module Travis::API::V3
|
module Travis::API::V3
|
||||||
class Queries::Broadcasts < Query
|
class Queries::Broadcasts < Query
|
||||||
def for_repo(repository)
|
|
||||||
Models::Broadcast.where(recipient_id: repository.id)
|
|
||||||
end
|
|
||||||
|
|
||||||
def for_user(user)
|
def for_user(user)
|
||||||
Models::Broadcast.where(recipient_id: user.id)
|
query = %(
|
||||||
|
recipient_type IS NULL OR
|
||||||
|
recipient_type = ? AND recipient_id IN(?) OR
|
||||||
|
recipient_type = ? AND recipient_id = ? OR
|
||||||
|
recipient_type = ? AND recipient_id IN (?)
|
||||||
|
)
|
||||||
|
Models::Broadcast.where(query, 'Organization', user.organization_ids, 'User', user.id, 'Repository', user.repository_ids)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -8,6 +8,11 @@ module Travis::API::V3
|
||||||
get :for_current_user
|
get :for_current_user
|
||||||
end
|
end
|
||||||
|
|
||||||
|
resource :broadcasts do
|
||||||
|
route '/broadcasts'
|
||||||
|
get :for_current_user
|
||||||
|
end
|
||||||
|
|
||||||
resource :build do
|
resource :build do
|
||||||
capture id: :digit
|
capture id: :digit
|
||||||
route '/build/{build.id}'
|
route '/build/{build.id}'
|
||||||
|
@ -63,11 +68,6 @@ module Travis::API::V3
|
||||||
get :find
|
get :find
|
||||||
end
|
end
|
||||||
|
|
||||||
resource :broadcasts do
|
|
||||||
route '/broadcasts'
|
|
||||||
get :for_current_repo
|
|
||||||
end
|
|
||||||
|
|
||||||
resource :builds do
|
resource :builds do
|
||||||
route '/builds'
|
route '/builds'
|
||||||
get :find
|
get :find
|
||||||
|
@ -85,11 +85,6 @@ module Travis::API::V3
|
||||||
route '/user'
|
route '/user'
|
||||||
get :current
|
get :current
|
||||||
get :find, '/{user.id}'
|
get :find, '/{user.id}'
|
||||||
|
|
||||||
resource :broadcasts do
|
|
||||||
route '/broadcasts'
|
|
||||||
get :for_current_user
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,7 +0,0 @@
|
||||||
module Travis::API::V3
|
|
||||||
class Services::Broadcasts::ForCurrentRepo < Service
|
|
||||||
def run!
|
|
||||||
query.for_repo(find(:repository))
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -1,7 +1,8 @@
|
||||||
module Travis::API::V3
|
module Travis::API::V3
|
||||||
class Services::Broadcasts::ForCurrentUser < Service
|
class Services::Broadcasts::ForCurrentUser < Service
|
||||||
def run!
|
def run!
|
||||||
query.for_user(find(:user))
|
raise LoginRequired unless access_control.logged_in?
|
||||||
|
query.for_user(access_control.user)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
41
spec/v3/services/broadcasts/for_current_user_spec.rb
Normal file
41
spec/v3/services/broadcasts/for_current_user_spec.rb
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
require 'spec_helper'
|
||||||
|
|
||||||
|
describe Travis::API::V3::Services::Broadcasts::ForCurrentUser do
|
||||||
|
let(:user) { Travis::API::V3::Models::User.where(login: 'svenfuchs').first }
|
||||||
|
let(:broadcast) { Travis::API::V3::Models::Broadcast.where(recipient_id: user.id) }
|
||||||
|
|
||||||
|
let(:token) { Travis::Api::App::AccessToken.create(user: user, app_id: 1) }
|
||||||
|
let(:headers) {{ 'HTTP_AUTHORIZATION' => "token #{token}" }}
|
||||||
|
before { Travis::API::V3::Models::Permission.create(user: user, pull: true) }
|
||||||
|
# before { Travis::API::V3::Models::Broadcast.create(recipient_id: repo.id, recipient_type: "Organization", message: "This is a test!") }
|
||||||
|
# before { repo.update_attribute(:private, true) }
|
||||||
|
# after { repo.update_attribute(:private, false) }
|
||||||
|
|
||||||
|
# let(:org) { Travis::API::V3::Models::Organization.new(login: 'example-org') }
|
||||||
|
# before { org.save! }
|
||||||
|
# before { org.memberships.create(user: user.login) }
|
||||||
|
# after { org.delete }
|
||||||
|
|
||||||
|
describe "authenticated as user with access" do
|
||||||
|
before { get("/v3/broadcasts", {}, headers) }
|
||||||
|
example { expect(last_response).to be_ok }
|
||||||
|
example { expect(JSON.load(body)).to be == {
|
||||||
|
"@type" => "broadcasts",
|
||||||
|
"@href" => "/v3/broadcasts",
|
||||||
|
"@representation" => "standard",
|
||||||
|
"broadcasts" => [{
|
||||||
|
"@type" => "broadcast",
|
||||||
|
"@representation" => "standard",
|
||||||
|
"@permissions" => { "read"=>true, "sync"=>true },
|
||||||
|
"id" => broadcasts[0].id,
|
||||||
|
"recipient_id" => broadcasts[0].recipient_id,
|
||||||
|
"recipient_type" => broadcasts[0].recipient_type,
|
||||||
|
"kind" => broadcast[0].kind,
|
||||||
|
"message" => broadcast[0].message,
|
||||||
|
"expired" => nil,
|
||||||
|
"created_at" => "2015-09-10T11:05:21Z",
|
||||||
|
"updated_at" => "2015-09-10T11:05:21Z"
|
||||||
|
}]
|
||||||
|
}}
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in New Issue
Block a user