# frozen_string_literal: true
module BitBucket
module Result
include BitBucket::Constants
# TODO: Add result counts method to check total items looking at result links
def ratelimit_limit
loaded? ? @env[:response_headers][RATELIMIT_LIMIT] : nil
end
def ratelimit_remaining
loaded? ? @env[:response_headers][RATELIMIT_REMAINING] : nil
end
def cache_control
loaded? ? @env[:response_headers][CACHE_CONTROL] : nil
end
def content_type
loaded? ? @env[:response_headers][CONTENT_TYPE] : nil
end
def content_length
loaded? ? @env[:response_headers][CONTENT_LENGTH] : nil
end
def etag
loaded? ? @env[:response_headers][ETAG] : nil
end
def date
loaded? ? @env[:response_headers][DATE] : nil
end
def location
loaded? ? @env[:response_headers][LOCATION] : nil
end
def server
loaded? ? @env[:response_headers][SERVER] : nil
end
def status
loaded? ? @env[:status] : nil
end
def success?
(200..299).include? status
end
# Returns raw body
def body
loaded? ? @env[:body] : nil
end
def loaded?
!!@env
end
# Return page links
def links
@@links = BitBucket::PageLinks.new(@env[:response_headers])
end
# Iterator like each for response pages. If there are no pages to
# iterate over this method will return nothing.
def each_page
yield body
yield next_page while page_iterator.has_next?
end
# Retrives the result of the first page. Returns nil if there is
# no first page - either because you are already on the first page
# or there are no pages at all in the result.
def first_page
first_request = page_iterator.first
instance_eval { @env = first_request.env } if first_request
body
end
# Retrives the result of the next page. Returns nil if there is
# no next page or no pages at all.
def next_page
next_request = page_iterator.next
instance_eval { @env = next_request.env } if next_request
body
end
# Retrives the result of the previous page. Returns nil if there is
# no previous page or no pages at all.
def prev_page
prev_request = page_iterator.prev
instance_eval { @env = prev_request.env } if prev_request
body
end
alias previous_page prev_page
# Retrives the result of the last page. Returns nil if there is
# no last page - either because you are already on the last page,
# there is only one page or there are no pages at all in the result.
def last_page
last_request = page_iterator.last
instance_eval { @env = last_request.env } if last_request
body
end
# Retrives a specific result for a page given page number.
# The page_number parameter is not validate, hitting a page
# that does not exist will return BitBucket API error. Consequently, if
# there is only one page, this method returns nil
def page(page_number)
request = page_iterator.get_page(page_number)
instance_eval { @env = request.env } if request
body
end
# Returns true if there is another page in the result set,
# otherwise false
def has_next_page?
page_iterator.has_next?
end
# Repopulates objects for new values
def reset
nil
end
private
# Internally used page iterator
def page_iterator # :nodoc:
@@page_iterator = BitBucket::PageIterator.new(@env)
end
end # Result
end # BitBucket