add projects API
This commit is contained in:
parent
4ad91d3c11
commit
7b5c3cc8be
30
lib/api.rb
30
lib/api.rb
|
@ -6,6 +6,7 @@ module Gitlab
|
||||||
format :json
|
format :json
|
||||||
helpers APIHelpers
|
helpers APIHelpers
|
||||||
|
|
||||||
|
# Users API
|
||||||
resource :users do
|
resource :users do
|
||||||
before { authenticate! }
|
before { authenticate! }
|
||||||
|
|
||||||
|
@ -27,5 +28,34 @@ module Gitlab
|
||||||
authenticate!
|
authenticate!
|
||||||
present @current_user, :with => Entities::User
|
present @current_user, :with => Entities::User
|
||||||
end
|
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
|
||||||
end
|
end
|
||||||
|
|
|
@ -4,5 +4,20 @@ module Gitlab
|
||||||
expose :id, :email, :name, :bio, :skype, :linkedin, :twitter,
|
expose :id, :email, :name, :bio, :skype, :linkedin, :twitter,
|
||||||
:dark_scheme, :theme_id, :blocked, :created_at
|
:dark_scheme, :theme_id, :blocked, :created_at
|
||||||
end
|
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
|
||||||
end
|
end
|
||||||
|
|
56
spec/api/projects_spec.rb
Normal file
56
spec/api/projects_spec.rb
Normal file
|
@ -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
|
Loading…
Reference in a new issue