diff options
author | Robert Schilling <rschilling@student.tugraz.at> | 2017-10-24 13:28:06 +0300 |
---|---|---|
committer | Robert Schilling <rschilling@student.tugraz.at> | 2017-10-24 13:28:06 +0300 |
commit | 58617553e66b4492eee84d320fdc3d65f93d069e (patch) | |
tree | 0c84d50d034f26811c1a9bbcce4d45bdb915fcce | |
parent | 82446a2bd009e7d7481c35a142063a3973be77ce (diff) | |
download | gitlab-ce-api-refs-for-commit.tar.gz |
Basic ref fetching for commitsapi-refs-for-commit
-rw-r--r-- | lib/api/commits.rb | 25 | ||||
-rw-r--r-- | lib/api/entities.rb | 10 |
2 files changed, 32 insertions, 3 deletions
diff --git a/lib/api/commits.rb b/lib/api/commits.rb index 2685dc27252..14d9a3ee985 100644 --- a/lib/api/commits.rb +++ b/lib/api/commits.rb @@ -155,6 +155,31 @@ module API end end + desc 'Get all reference a commit is pushed to' do + detail 'This feature was introduced in GitLab 10.2' + success Entities::Ref + end + params do + requires :sha, type: String, desc: 'A commit sha' + optional :type, type: String, values: %w(branches tags all), default: 'all', desc: 'Scope' + end + get ':id/repository/commits/:sha/refs', requirements: API::COMMIT_ENDPOINT_REQUIREMENTS do + commit = user_project.commit(params[:sha]) + not_found!('Commit') unless commit + + case params[:type] + when 'branches' + refs = user_project.repository.branch_names_contains(commit.id) + when 'tags' + refs = user_project.repository.tag_names_contains(commit.id) + else + refs = user_project.repository.branch_names_contains(commit.id) + refs << user_project.repository.branch_names_contains(commit.id) + end + + present refs, with: Entities::BasicRef + end + desc 'Post comment to commit' do success Entities::CommitNote end diff --git a/lib/api/entities.rb b/lib/api/entities.rb index 5f0bad14839..ad3ca18db3c 100644 --- a/lib/api/entities.rb +++ b/lib/api/entities.rb @@ -238,7 +238,11 @@ module API expose :last_pipeline, using: 'API::Entities::PipelineBasic' end - class Branch < Grape::Entity + class BasicRef < Grape::Entity + expose :name + end + + class Branch < BasicRef expose :name expose :commit, using: Entities::Commit do |repo_branch, options| @@ -774,8 +778,8 @@ module API expose :description end - class Tag < Grape::Entity - expose :name, :message + class Tag < BasicRef + expose :message expose :commit, using: Entities::Commit do |repo_tag, options| options[:project].repository.commit(repo_tag.dereferenced_target) |