diff options
author | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2014-07-03 07:28:02 +0000 |
---|---|---|
committer | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2014-07-03 07:28:02 +0000 |
commit | 8031be73fede0718b81c1b9d038be8a7c81a946a (patch) | |
tree | 839e439cbe911df2991d2d772cfcf90ff03f0ef5 | |
parent | efc6baf782951ea2150b45f524c103d0904dbdc1 (diff) | |
parent | dacf9f9f863dcb67a3dcb8dcfc4c151b10bca5e3 (diff) | |
download | gitlab-ce-8031be73fede0718b81c1b9d038be8a7c81a946a.tar.gz |
Merge branch 'contributors-api' into 'master'
Contributors api
Fixes #1266
See merge request !934
-rw-r--r-- | app/models/repository.rb | 21 | ||||
-rw-r--r-- | doc/api/repositories.md | 29 | ||||
-rw-r--r-- | lib/api/entities.rb | 4 | ||||
-rw-r--r-- | lib/api/repositories.rb | 12 | ||||
-rw-r--r-- | lib/gitlab/contributors.rb | 9 | ||||
-rw-r--r-- | spec/requests/api/repositories_spec.rb | 16 |
6 files changed, 90 insertions, 1 deletions
diff --git a/app/models/repository.rb b/app/models/repository.rb index 22c16abe480..89bf12ce9ef 100644 --- a/app/models/repository.rb +++ b/app/models/repository.rb @@ -242,4 +242,25 @@ class Repository branches end end + + def contributors + log = graph_log.group_by { |i| i[:author_email] } + + log.map do |email, contributions| + contributor = Gitlab::Contributor.new + contributor.email = email + + contributions.each do |contribution| + if contributor.name.blank? + contributor.name = contribution[:author_name] + end + + contributor.commits += 1 + contributor.additions += contribution[:additions] || 0 + contributor.deletions += contribution[:deletions] || 0 + end + + contributor + end + end end diff --git a/doc/api/repositories.md b/doc/api/repositories.md index 26ae3e87232..2539e3edbf9 100644 --- a/doc/api/repositories.md +++ b/doc/api/repositories.md @@ -220,3 +220,32 @@ Response: "compare_same_ref": false } ``` + +## Contributors + +Get repository contributors list + +``` +GET /projects/:id/repository/contributors +``` + +Parameters: ++ `id` (required) - The ID of a project + +Response: + +``` +[{ + "name": "Dmitriy Zaporozhets", + "email": "dmitriy.zaporozhets@gmail.com", + "commits": 117, + "additions": 2097, + "deletions": 517 +}, { + "name": "Jacob Vosmaer", + "email": "contact@jacobvosmaer.nl", + "commits": 33, + "additions": 338, + "deletions": 244 +}] +``` diff --git a/lib/api/entities.rb b/lib/api/entities.rb index b190646a1e3..09fb97abf29 100644 --- a/lib/api/entities.rb +++ b/lib/api/entities.rb @@ -218,5 +218,9 @@ module API expose :same, as: :compare_same_ref end + + class Contributor < Grape::Entity + expose :name, :email, :commits, :additions, :deletions + end end end diff --git a/lib/api/repositories.rb b/lib/api/repositories.rb index 03806d9343b..d091fa4f035 100644 --- a/lib/api/repositories.rb +++ b/lib/api/repositories.rb @@ -150,6 +150,18 @@ module API compare = Gitlab::Git::Compare.new(user_project.repository.raw_repository, params[:from], params[:to], MergeRequestDiff::COMMITS_SAFE_SIZE) present compare, with: Entities::Compare end + + # Get repository contributors + # + # Parameters: + # id (required) - The ID of a project + # Example Request: + # GET /projects/:id/repository/contributors + get ':id/repository/contributors' do + authorize! :download_code, user_project + + present user_project.repository.contributors, with: Entities::Contributor + end end end end diff --git a/lib/gitlab/contributors.rb b/lib/gitlab/contributors.rb new file mode 100644 index 00000000000..c41e92b620f --- /dev/null +++ b/lib/gitlab/contributors.rb @@ -0,0 +1,9 @@ +module Gitlab + class Contributor + attr_accessor :email, :name, :commits, :additions, :deletions + + def initialize + @commits, @additions, @deletions = 0, 0, 0 + end + end +end diff --git a/spec/requests/api/repositories_spec.rb b/spec/requests/api/repositories_spec.rb index 94850d0f1ae..a02231a5bba 100644 --- a/spec/requests/api/repositories_spec.rb +++ b/spec/requests/api/repositories_spec.rb @@ -128,7 +128,7 @@ describe API::API, api: true do end end - describe 'GET /GET /projects/:id/repository/compare' do + describe 'GET /projects/:id/repository/compare' do it "should compare branches" do get api("/projects/#{project.id}/repository/compare", user), from: 'master', to: 'simple_merge_request' response.status.should == 200 @@ -166,4 +166,18 @@ describe API::API, api: true do json_response['compare_same_ref'].should be_true end end + + describe 'GET /projects/:id/repository/contributors' do + it 'should return valid data' do + get api("/projects/#{project.id}/repository/contributors", user) + response.status.should == 200 + json_response.should be_an Array + contributor = json_response.first + contributor['email'].should == 'dmitriy.zaporozhets@gmail.com' + contributor['name'].should == 'Dmitriy Zaporozhets' + contributor['commits'].should == 185 + contributor['additions'].should == 66072 + contributor['deletions'].should == 63013 + end + end end |