summaryrefslogtreecommitdiff
path: root/lib/api/files.rb
diff options
context:
space:
mode:
authorFelipe Artur <felipefac@gmail.com>2017-03-07 21:14:33 -0300
committerFelipe Artur <felipefac@gmail.com>2017-03-07 22:20:38 -0300
commita61bb7cda3f31e2b32b53a26187079a6d6302845 (patch)
tree18cc3407c2252cc1578d29a0c898a1033120ea61 /lib/api/files.rb
parent9053d78e7451d5358b0ec66788916a488ce66a00 (diff)
downloadgitlab-ce-a61bb7cda3f31e2b32b53a26187079a6d6302845.tar.gz
Remove unecessary endpoint from repository, add compatibility endpoints for v3 and several improvementsissue_16834
Diffstat (limited to 'lib/api/files.rb')
-rw-r--r--lib/api/files.rb32
1 files changed, 13 insertions, 19 deletions
diff --git a/lib/api/files.rb b/lib/api/files.rb
index 5983845d007..bb8f5c3076d 100644
--- a/lib/api/files.rb
+++ b/lib/api/files.rb
@@ -15,13 +15,13 @@ module API
end
def assign_file_vars!
+ authorize! :download_code, user_project
+
@commit = user_project.commit(params[:ref])
not_found!('Commit') unless @commit
- @repo = user_project.repository
- @file_path = params[:file_path]
- @file_path = [params[:file_path], params[:format]].join('.') if params[:format].present?
- @blob = @repo.blob_at(@commit.sha, @file_path)
+ @repo = user_project.repository
+ @blob = @repo.blob_at(@commit.sha, params[:file_path])
not_found!('File') unless @blob
@blob.load_all_data!(@repo)
@@ -35,7 +35,7 @@ module API
end
params :simple_file_params do
- requires :file_path, type: String, desc: 'The path to the file. Ex. lib/class.rb'
+ requires :file_path, type: String, desc: 'The url encoded path to the file. Ex. lib%2Fclass%2Erb'
requires :branch, type: String, desc: 'The name of branch'
requires :commit_message, type: String, desc: 'Commit Message'
optional :author_email, type: String, desc: 'The email of the author'
@@ -53,31 +53,25 @@ module API
requires :id, type: String, desc: 'The project ID'
end
resource :projects do
- desc 'Get a file from repository in raw format'
+ desc 'Get raw file contents from the repository'
params do
- requires :ref, type: String, desc: 'The name of branch, tag, or commit'
+ requires :file_path, type: String, desc: 'The url encoded path to the file. Ex. lib%2Fclass%2Erb'
+ requires :ref, type: String, desc: 'The name of branch, tag commit'
end
get ":id/repository/files/:file_path/raw" do
- authorize! :download_code, user_project
-
assign_file_vars!
- status(200)
-
send_git_blob @repo, @blob
end
- desc 'Get a file from repository in base64 format'
+ desc 'Get a file from the repository'
params do
- requires :ref, type: String, desc: 'The name of branch, tag, or commit'
+ requires :file_path, type: String, desc: 'The url encoded path to the file. Ex. lib%2Fclass%2Erb'
+ requires :ref, type: String, desc: 'The name of branch, tag or commit'
end
- get ":id/repository/files/:file_path" do
- authorize! :download_code, user_project
-
+ get ":id/repository/files/:file_path", requirements: { file_path: /.+/ } do
assign_file_vars!
- status(200)
-
{
file_name: @blob.name,
file_path: @blob.path,
@@ -87,7 +81,7 @@ module API
ref: params[:ref],
blob_id: @blob.id,
commit_id: @commit.id,
- last_commit_id: @repo.last_commit_id_for_path(@commit.sha, @file_path)
+ last_commit_id: @repo.last_commit_id_for_path(@commit.sha, params[:file_path])
}
end