summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNihad Abbasov <narkoz.2008@gmail.com>2012-06-27 05:51:39 -0700
committerNihad Abbasov <narkoz.2008@gmail.com>2012-06-28 03:44:20 -0700
commit7b5c3cc8be40ee161ae89a06bba6229da1032a0c (patch)
tree46e82de44b1061621357f24c05515327f2795a95
parent4ad91d3c1144c406e50c7b33bae684bd6837faf8 (diff)
downloadgitlab-ce-7b5c3cc8be40ee161ae89a06bba6229da1032a0c.tar.gz
add projects API
-rw-r--r--lib/api.rb30
-rw-r--r--lib/api/entities.rb15
-rw-r--r--spec/api/projects_spec.rb56
3 files changed, 101 insertions, 0 deletions
diff --git a/lib/api.rb b/lib/api.rb
index 9e38bc496fe..ab5b02e0556 100644
--- a/lib/api.rb
+++ b/lib/api.rb
@@ -6,6 +6,7 @@ module Gitlab
format :json
helpers APIHelpers
+ # Users API
resource :users do
before { authenticate! }
@@ -27,5 +28,34 @@ module Gitlab
authenticate!
present @current_user, :with => Entities::User
end
+
+ # Projects API
+ resource :projects do
+ before { authenticate! }
+
+ # GET /projects
+ get do
+ @projects = current_user.projects
+ present @projects, :with => Entities::Project
+ end
+
+ # GET /projects/:id
+ get ":id" do
+ @project = Project.find_by_code(params[:id])
+ present @project, :with => Entities::Project
+ end
+
+ # GET /projects/:id/repository/branches
+ get ":id/repository/branches" do
+ @project = Project.find_by_code(params[:id])
+ present @project.repo.heads.sort_by(&:name), :with => Entities::ProjectRepositoryBranches
+ end
+
+ # GET /projects/:id/repository/tags
+ get ":id/repository/tags" do
+ @project = Project.find_by_code(params[:id])
+ present @project.repo.tags.sort_by(&:name).reverse, :with => Entities::ProjectRepositoryTags
+ end
+ end
end
end
diff --git a/lib/api/entities.rb b/lib/api/entities.rb
index 3548e8cc5a9..44a43985602 100644
--- a/lib/api/entities.rb
+++ b/lib/api/entities.rb
@@ -4,5 +4,20 @@ module Gitlab
expose :id, :email, :name, :bio, :skype, :linkedin, :twitter,
:dark_scheme, :theme_id, :blocked, :created_at
end
+
+ class Project < Grape::Entity
+ expose :id, :code, :name, :description, :path, :default_branch
+ expose :owner, :using => Entities::User
+ expose :private_flag, :as => :private
+ expose :issues_enabled, :merge_requests_enabled, :wall_enabled, :wiki_enabled, :created_at
+ end
+
+ class ProjectRepositoryBranches < Grape::Entity
+ expose :name, :commit
+ end
+
+ class ProjectRepositoryTags < Grape::Entity
+ expose :name, :commit
+ end
end
end
diff --git a/spec/api/projects_spec.rb b/spec/api/projects_spec.rb
new file mode 100644
index 00000000000..2d1043f961e
--- /dev/null
+++ b/spec/api/projects_spec.rb
@@ -0,0 +1,56 @@
+require 'spec_helper'
+
+describe Gitlab::API do
+ let(:user) { Factory :user }
+ let!(:project) { Factory :project, :owner => user }
+
+ describe "GET /projects" do
+ before { project.add_access(user, :read) }
+
+ it "should return authentication error" do
+ get "/api/projects"
+ response.status.should == 401
+ end
+
+ describe "authenticated GET /projects" do
+ it "should return an array of projects" do
+ get "/api/projects?private_token=#{user.private_token}"
+ response.status.should == 200
+ json = JSON.parse(response.body)
+ json.should be_an Array
+ json.first['name'].should == project.name
+ json.first['owner']['email'].should == user.email
+ end
+ end
+ end
+
+ describe "GET /projects/:id" do
+ it "should return a project by id" do
+ get "/api/projects/#{project.code}?private_token=#{user.private_token}"
+ response.status.should == 200
+ json = JSON.parse(response.body)
+ json['name'].should == project.name
+ json['owner']['email'].should == user.email
+ end
+ end
+
+ describe "GET /projects/:id/repository/branches" do
+ it "should return an array of project branches" do
+ get "/api/projects/#{project.code}/repository/branches?private_token=#{user.private_token}"
+ response.status.should == 200
+ json = JSON.parse(response.body)
+ json.should be_an Array
+ json.first['name'].should == project.repo.heads.sort_by(&:name).first.name
+ end
+ end
+
+ describe "GET /projects/:id/repository/tags" do
+ it "should return an array of project tags" do
+ get "/api/projects/#{project.code}/repository/tags?private_token=#{user.private_token}"
+ response.status.should == 200
+ json = JSON.parse(response.body)
+ json.should be_an Array
+ json.first['name'].should == project.repo.tags.sort_by(&:name).reverse.first.name
+ end
+ end
+end