summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2014-07-03 07:28:02 +0000
committerDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2014-07-03 07:28:02 +0000
commit8031be73fede0718b81c1b9d038be8a7c81a946a (patch)
tree839e439cbe911df2991d2d772cfcf90ff03f0ef5
parentefc6baf782951ea2150b45f524c103d0904dbdc1 (diff)
parentdacf9f9f863dcb67a3dcb8dcfc4c151b10bca5e3 (diff)
downloadgitlab-ce-8031be73fede0718b81c1b9d038be8a7c81a946a.tar.gz
Merge branch 'contributors-api' into 'master'
Contributors api Fixes #1266 See merge request !934
-rw-r--r--app/models/repository.rb21
-rw-r--r--doc/api/repositories.md29
-rw-r--r--lib/api/entities.rb4
-rw-r--r--lib/api/repositories.rb12
-rw-r--r--lib/gitlab/contributors.rb9
-rw-r--r--spec/requests/api/repositories_spec.rb16
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