summaryrefslogtreecommitdiff
path: root/lib/api/helpers.rb
diff options
context:
space:
mode:
authorFatih Acet <acetfatih@gmail.com>2017-01-09 21:11:17 +0000
committerFatih Acet <acetfatih@gmail.com>2017-01-09 21:11:17 +0000
commit2f1701c56a7ce6ee2870bd6a280cf5bf788bd607 (patch)
tree8a8949e61094c9d4385315bf6685332ce32fe210 /lib/api/helpers.rb
parent6524ec5deead306773e34a11152cb87e613a9273 (diff)
parent1d02d5b148f3d30ceb7dc1cc08385ee5c43b6cc4 (diff)
downloadgitlab-ce-2f1701c56a7ce6ee2870bd6a280cf5bf788bd607.tar.gz
Merge branch 'auto-pipelines-vue' into 'master'
Pipelines Vue See merge request !7196
Diffstat (limited to 'lib/api/helpers.rb')
-rw-r--r--lib/api/helpers.rb39
1 files changed, 1 insertions, 38 deletions
diff --git a/lib/api/helpers.rb b/lib/api/helpers.rb
index ee9247ee240..20b5bc1502a 100644
--- a/lib/api/helpers.rb
+++ b/lib/api/helpers.rb
@@ -1,6 +1,7 @@
module API
module Helpers
include Gitlab::Utils
+ include Helpers::Pagination
SUDO_HEADER = "HTTP_SUDO"
SUDO_PARAM = :sudo
@@ -85,12 +86,6 @@ module API
IssuesFinder.new(current_user, project_id: user_project.id).find(id)
end
- def paginate(relation)
- relation.page(params[:page]).per(params[:per_page].to_i).tap do |data|
- add_pagination_headers(data)
- end
- end
-
def authenticate!
unauthorized! unless current_user
end
@@ -361,38 +356,6 @@ module API
@sudo_identifier ||= params[SUDO_PARAM] || env[SUDO_HEADER]
end
- def add_pagination_headers(paginated_data)
- header 'X-Total', paginated_data.total_count.to_s
- header 'X-Total-Pages', paginated_data.total_pages.to_s
- header 'X-Per-Page', paginated_data.limit_value.to_s
- header 'X-Page', paginated_data.current_page.to_s
- header 'X-Next-Page', paginated_data.next_page.to_s
- header 'X-Prev-Page', paginated_data.prev_page.to_s
- header 'Link', pagination_links(paginated_data)
- end
-
- def pagination_links(paginated_data)
- request_url = request.url.split('?').first
- request_params = params.clone
- request_params[:per_page] = paginated_data.limit_value
-
- links = []
-
- request_params[:page] = paginated_data.current_page - 1
- links << %(<#{request_url}?#{request_params.to_query}>; rel="prev") unless paginated_data.first_page?
-
- request_params[:page] = paginated_data.current_page + 1
- links << %(<#{request_url}?#{request_params.to_query}>; rel="next") unless paginated_data.last_page?
-
- request_params[:page] = 1
- links << %(<#{request_url}?#{request_params.to_query}>; rel="first")
-
- request_params[:page] = paginated_data.total_pages
- links << %(<#{request_url}?#{request_params.to_query}>; rel="last")
-
- links.join(', ')
- end
-
def secret_token
Gitlab::Shell.secret_token
end