fluke/devops-service/routes/v2.0/key.rb

114 lines
3.6 KiB
Ruby
Raw Normal View History

2014-05-08 15:34:26 +04:00
require "json"
require "db/exceptions/invalid_record"
require "db/mongo/models/key"
require "fileutils"
2014-12-15 14:26:54 +03:00
module Devops
module Version2_0
module Core
module KeyRoutes
2014-05-08 15:34:26 +04:00
2014-12-15 14:26:54 +03:00
def self.registered(app)
app.before %r{\A/key(/[\w]+)?\z} do
if request.delete?
check_headers :accept
else
check_headers :accept, :content_type
end
check_privileges("key", "w")
end
2014-05-08 15:34:26 +04:00
2014-12-15 14:26:54 +03:00
app.after %r{\A/key(/[\w]+)?\z} do
statistic
end
2014-05-08 15:34:26 +04:00
2014-12-15 14:26:54 +03:00
# Get list of available ssh keys
#
# * *Request*
# - method : GET
# - headers :
# - Accept: application/json
#
# * *Returns* : array of strings
# [
# {
# "scope": "system", -> 'system' - key was added by server, 'user' - key was added by user
# "id": "devops"
# }
# ]
app.get "/keys" do
check_headers :accept
check_privileges("key", "r")
keys = settings.mongo.keys.map {|i| i.to_hash}
keys.each {|k| k.delete("path")} # We should not return path to the key
json keys
end
2014-05-08 15:34:26 +04:00
2014-12-15 14:26:54 +03:00
# Create ssh key on devops server
#
# * *Request*
# - method : POST
# - headers :
# - Accept: application/json
# - Content-Type: application/json
# - body :
# {
# "file_name": "key file name",
# "key_name": "key name",
# "content": "key content"
# }
#
# * *Returns* :
# 201 - Created
app.post "/key" do
key = create_object_from_json_body
fname = check_filename(key["file_name"], "Parameter 'file_name' must be a not empty string")
kname = check_string(key["key_name"], "Parameter 'key_name' should be a not empty string")
content = check_string(key["content"], "Parameter 'content' should be a not empty string")
file_name = File.join(DevopsService.config[:keys_dir], fname)
halt(400, "File '#{fname}' already exist") if File.exists?(file_name)
File.open(file_name, "w") do |f|
f.write(content)
f.chmod(0400)
end
2014-05-08 15:34:26 +04:00
2014-12-15 14:26:54 +03:00
key = Key.new({"path" => file_name, "id" => kname})
settings.mongo.key_insert key
create_response("Created", nil, 201)
end
2014-05-08 15:34:26 +04:00
2014-12-15 14:26:54 +03:00
# Delete ssh key from devops server
#
# * *Request*
# - method : DELETE
# - headers :
# - Accept: application/json
#
# * *Returns* :
# 200 - Deleted
app.delete "/key/:key" do
servers = settings.mongo.servers_by_key params[:key]
unless servers.empty?
s_str = servers.map{|s| s.id}.join(", ")
raise DependencyError.new "Deleting is forbidden: Key is used in servers: #{s_str}"
end
2014-05-08 15:34:26 +04:00
2014-12-15 14:26:54 +03:00
k = settings.mongo.key params[:key]
begin
FileUtils.rm(k.path)
rescue
logger.error "Missing key file for #{params[:key]} - #{k.filename}"
end
r = settings.mongo.key_delete params[:key]
return [500, r["err"].inspect] unless r["err"].nil?
create_response("Key '#{params[:key]}' removed")
end
puts "Key routes initialized"
end
2014-05-08 15:34:26 +04:00
end
end
end
end