summaryrefslogtreecommitdiff
path: root/lib/api/projects.rb
diff options
context:
space:
mode:
authorDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2013-03-06 07:43:45 -0800
committerDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2013-03-06 07:43:45 -0800
commitafee5303ff3a31d4b3eca82e19c7a326f2c86659 (patch)
tree7ae515b3f1bbbdcad5fcb30898466b712fda4349 /lib/api/projects.rb
parent65d78253cb289091a4eb389bada11828849d434c (diff)
parentf411772e3395f569da893dd1fc0fd666dcbb5caa (diff)
downloadgitlab-ce-afee5303ff3a31d4b3eca82e19c7a326f2c86659.tar.gz
Merge pull request #3149 from m4tthumphrey/api-deploy-keys
Added methods to manage project deploy keys via API
Diffstat (limited to 'lib/api/projects.rb')
-rw-r--r--lib/api/projects.rb43
1 files changed, 43 insertions, 0 deletions
diff --git a/lib/api/projects.rb b/lib/api/projects.rb
index 8f57e5ac79f..763f90015dd 100644
--- a/lib/api/projects.rb
+++ b/lib/api/projects.rb
@@ -424,6 +424,49 @@ module Gitlab
present tree.data
end
+ # Get a specific project's keys
+ #
+ # Example Request:
+ # GET /projects/:id/keys
+ get ":id/keys" do
+ present user_project.deploy_keys, with: Entities::SSHKey
+ end
+
+ # Get single key owned by currently authenticated user
+ #
+ # Example Request:
+ # GET /projects/:id/keys/:id
+ get ":id/keys/:key_id" do
+ key = user_project.deploy_keys.find params[:key_id]
+ present key, with: Entities::SSHKey
+ end
+
+ # Add new ssh key to currently authenticated user
+ #
+ # Parameters:
+ # key (required) - New SSH Key
+ # title (required) - New SSH Key's title
+ # Example Request:
+ # POST /projects/:id/keys
+ post ":id/keys" do
+ attrs = attributes_for_keys [:title, :key]
+ key = user_project.deploy_keys.new attrs
+ if key.save
+ present key, with: Entities::SSHKey
+ else
+ not_found!
+ end
+ end
+
+ # Delete existed ssh key of currently authenticated user
+ #
+ # Example Request:
+ # DELETE /projects/:id/keys/:id
+ delete ":id/keys/:key_id" do
+ key = user_project.deploy_keys.find params[:key_id]
+ key.delete
+ end
+
end
end
end