v3: add @warnings

This commit is contained in:
Konstantin Haase 2015-08-21 19:50:37 +02:00
parent b4a3bdeb0e
commit 09df061268
4 changed files with 43 additions and 13 deletions

View File

@ -37,4 +37,3 @@ module Travis
end
end
end

View File

@ -1,8 +1,9 @@
module Travis::API::V3
class Result
attr_accessor :access_control, :type, :resource, :status, :href, :meta_data
attr_accessor :access_control, :type, :resource, :status, :href, :meta_data, :warnings
def initialize(access_control, type, resource = [], status: 200, **meta_data)
@warnings = []
@access_control, @type, @resource, @status, @meta_data = access_control, type, resource, status, meta_data
end
@ -10,6 +11,15 @@ module Travis::API::V3
super or method.to_sym == type.to_sym
end
def warn(message, **info)
warnings << { :@type => 'warning'.freeze, :message => message, **info }
end
def ignored_param(param, reason: nil, **info)
message = reason ? "query parameter #{param} #{reason}, ignored" : "query parameter #{param} ignored"
warn(message, warning_type: :ignored_parameter, parameter: param, **info)
end
def <<(value)
resource << value
self
@ -19,7 +29,7 @@ module Travis::API::V3
href = self.href
href = V3.location(env) if href.nil? and env['REQUEST_METHOD'.freeze] == 'GET'.freeze
include = params['include'.freeze].to_s.split(?,.freeze)
Renderer[type].render(resource,
add_info Renderer[type].render(resource,
href: href,
script_name: env['SCRIPT_NAME'.freeze],
include: include,
@ -27,6 +37,14 @@ module Travis::API::V3
meta_data: meta_data)
end
def add_info(payload)
if warnings.any?
payload = { :@warnings => [] }.merge!(payload) unless payload.include? :@warnings
payload[:@warnings].concat(warnings)
end
payload
end
def method_missing(method, *args)
return super unless method.to_sym == type.to_sym
raise ArgumentError, 'wrong number of arguments (1 for 0)'.freeze if args.any?

View File

@ -16,8 +16,11 @@ module Travis::API::V3
raise NotFound unless factory
service = factory.new(access_control, factory.filter_params(env_params).merge(params))
filtered = factory.filter_params(env_params)
service = factory.new(access_control, filtered.merge(params))
result = service.run
env_params.each_key { |key| result.ignored_param(key, reason: "not whitelisted".freeze) unless filtered.include?(key) }
render(result, env_params, env)
rescue Error => error
result = Result.new(access_control, :error, error)

View File

@ -130,14 +130,19 @@ describe Travis::API::V3::Services::Owner::Find do
before { get("/v3/owner/example-org?organization.id=#{other.id}") }
example { expect(last_response).to be_ok }
example { expect(JSON.load(body)).to be == {
"@type" => "organization",
"@href" => "/v3/org/#{org.id}",
"@permissions" => { "read"=>true, "sync"=>false },
"id" => org.id,
"login" => "example-org",
"name" => nil,
"github_id" => nil,
"avatar_url" => nil
"@type" => "organization",
"@href" => "/v3/org/#{org.id}",
"@permissions" => { "read"=>true, "sync"=>false },
"id" => org.id,
"login" => "example-org",
"name" => nil,
"github_id" => nil,
"avatar_url" => nil,
"@warnings" => [{
"@type" => "warning",
"message" => "query parameter organization.id not whitelisted, ignored",
"warning_type" => "ignored_parameter",
"parameter" => "organization.id"}]
}}
end
end
@ -198,7 +203,12 @@ describe Travis::API::V3::Services::Owner::Find do
"github_id" => nil,
"avatar_url" => nil,
"is_syncing" => nil,
"synced_at" => nil
"synced_at" => nil,
"@warnings" => [{
"@type" => "warning",
"message" => "query parameter user.id not whitelisted, ignored",
"warning_type" => "ignored_parameter",
"parameter" => "user.id"}]
}}
end
end