fix incorrect broadcast endpoints - add correct broadcasts endpoint

This commit is contained in:
carlad 2015-09-10 17:36:13 +02:00
parent bd61d1e58e
commit 1640c33517
5 changed files with 55 additions and 23 deletions

View File

@ -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

View File

@ -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

View File

@ -1,7 +0,0 @@
module Travis::API::V3
class Services::Broadcasts::ForCurrentRepo < Service
def run!
query.for_repo(find(:repository))
end
end
end

View File

@ -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

View 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