summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorNihad Abbasov <narkoz.2008@gmail.com>2012-06-29 03:46:01 -0700
committerNihad Abbasov <narkoz.2008@gmail.com>2012-06-29 03:46:01 -0700
commit0d67f209fcbabed5831d90561350a8e094c150c4 (patch)
tree12aadf636dde8f626fd1cfd53f13aaf8cf7a47c8 /lib
parent84a3f8fca4e57422267bdd7e07d4f1b90717fbcc (diff)
downloadgitlab-ce-0d67f209fcbabed5831d90561350a8e094c150c4.tar.gz
refactor API and improve docs
Diffstat (limited to 'lib')
-rw-r--r--lib/api.rb56
-rw-r--r--lib/api/projects.rb50
-rw-r--r--lib/api/users.rb36
3 files changed, 89 insertions, 53 deletions
diff --git a/lib/api.rb b/lib/api.rb
index 4fdc3273a0e..5cc78e52850 100644
--- a/lib/api.rb
+++ b/lib/api.rb
@@ -1,61 +1,11 @@
-require 'api/entities'
-require 'api/helpers'
+Dir["#{Rails.root}/lib/api/*.rb"].each {|file| require file}
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
+ mount Users
+ mount Projects
end
end
diff --git a/lib/api/projects.rb b/lib/api/projects.rb
new file mode 100644
index 00000000000..670d3d97acc
--- /dev/null
+++ b/lib/api/projects.rb
@@ -0,0 +1,50 @@
+module Gitlab
+ # Projects API
+ class Projects < Grape::API
+ before { authenticate! }
+
+ resource :projects do
+ # Get a projects list for authenticated user
+ #
+ # Example Request:
+ # GET /projects
+ get do
+ @projects = current_user.projects
+ present @projects, :with => Entities::Project
+ end
+
+ # Get a single project
+ #
+ # Parameters:
+ # id (required) - The code of a project
+ # Example Request:
+ # GET /projects/:id
+ get ":id" do
+ @project = current_user.projects.find_by_code(params[:id])
+ present @project, :with => Entities::Project
+ end
+
+ # Get a project repository branches
+ #
+ # Parameters:
+ # id (required) - The code of a project
+ # Example Request:
+ # 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 a project repository tags
+ #
+ # Parameters:
+ # id (required) - The code of a project
+ # Example Request:
+ # 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
diff --git a/lib/api/users.rb b/lib/api/users.rb
new file mode 100644
index 00000000000..ef3762f30fc
--- /dev/null
+++ b/lib/api/users.rb
@@ -0,0 +1,36 @@
+module Gitlab
+ # Users API
+ class Users < Grape::API
+ before { authenticate! }
+
+ resource :users do
+ # Get a users list
+ #
+ # Example Request:
+ # GET /users
+ get do
+ @users = User.all
+ present @users, :with => Entities::User
+ end
+
+ # Get a single user
+ #
+ # Parameters:
+ # id (required) - The ID of a user
+ # Example Request:
+ # GET /users/:id
+ get ":id" do
+ @user = User.find(params[:id])
+ present @user, :with => Entities::User
+ end
+ end
+
+ # Get currently authenticated user
+ #
+ # Example Request:
+ # GET /user
+ get "/user" do
+ present @current_user, :with => Entities::User
+ end
+ end
+end