Merge branch 'api' of https://github.com/NARKOZ/gitlabhq
Conflicts: Gemfile.lock
This commit is contained in:
commit
318350e34f
9 changed files with 206 additions and 0 deletions
61
lib/api.rb
Normal file
61
lib/api.rb
Normal file
|
@ -0,0 +1,61 @@
|
|||
require 'api/entities'
|
||||
require 'api/helpers'
|
||||
|
||||
module Gitlab
|
||||
class API < Grape::API
|
||||
format :json
|
||||
helpers APIHelpers
|
||||
|
||||
# Users API
|
||||
resource :users do
|
||||
before { authenticate! }
|
||||
|
||||
# GET /users
|
||||
get do
|
||||
@users = User.all
|
||||
present @users, :with => Entities::User
|
||||
end
|
||||
|
||||
# GET /users/:id
|
||||
get ":id" do
|
||||
@user = User.find(params[:id])
|
||||
present @user, :with => Entities::User
|
||||
end
|
||||
end
|
||||
|
||||
# GET /user
|
||||
get "/user" do
|
||||
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 = current_user.projects.find_by_code(params[:id])
|
||||
present @project, :with => Entities::Project
|
||||
end
|
||||
|
||||
# GET /projects/:id/repository/branches
|
||||
get ":id/repository/branches" do
|
||||
@project = current_user.projects.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 = current_user.projects.find_by_code(params[:id])
|
||||
present @project.repo.tags.sort_by(&:name).reverse, :with => Entities::ProjectRepositoryTags
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
23
lib/api/entities.rb
Normal file
23
lib/api/entities.rb
Normal file
|
@ -0,0 +1,23 @@
|
|||
module Gitlab
|
||||
module Entities
|
||||
class User < Grape::Entity
|
||||
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
|
11
lib/api/helpers.rb
Normal file
11
lib/api/helpers.rb
Normal file
|
@ -0,0 +1,11 @@
|
|||
module Gitlab
|
||||
module APIHelpers
|
||||
def current_user
|
||||
@current_user ||= User.find_by_authentication_token(params[:private_token])
|
||||
end
|
||||
|
||||
def authenticate!
|
||||
error!('401 Unauthorized', 401) unless current_user
|
||||
end
|
||||
end
|
||||
end
|
Loading…
Add table
Add a link
Reference in a new issue