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

171 lines
5.5 KiB
Ruby
Raw Normal View History

2014-05-08 15:34:26 +04:00
require "db/exceptions/invalid_record"
require "db/mongo/models/user"
2014-12-12 17:00:06 +03:00
module Sinatra
module Version2_0
module Core
module UserRoutes
2014-05-08 15:34:26 +04:00
2014-12-12 17:00:06 +03:00
def self.registered(app)
puts "User routes initialized"
2014-05-08 15:34:26 +04:00
2014-12-12 17:00:06 +03:00
app.after %r{\A/user(/[\w]+(/password)?)?\z} do
statistic
end
2014-05-08 15:34:26 +04:00
2014-12-12 17:00:06 +03:00
# Get users list
#
# * *Request*
# - method : GET
# - headers :
# - Accept: application/json
#
# * *Returns* :
# [
# {
# "email": "test@test.test",
# "privileges": {
# "flavor": "r",
# "group": "r",
# "image": "r",
# "project": "r",
# "server": "r",
# "key": "r",
# "user": "",
# "filter": "r",
# "network": "r",
# "provider": "r",
# "script": "r",
# "templates": "r"
# },
# "id": "test"
# }
# ]
app.get "/users" do
check_headers :accept
check_privileges("user", "r")
users = settings.mongo.users.map {|i| i.to_hash}
users.each {|u| u.delete("password")}
json users
end
2014-05-08 15:34:26 +04:00
2014-12-12 17:00:06 +03:00
# Create user
#
# * *Request*
# - method : POST
# - headers :
# - Accept: application/json
# - Content-Type: application/json
# - body :
# {
# "username": "user name",
# "email": "user email",
# "password": "user password"
# }
#
# * *Returns* :
# 201 - Created
app.post "/user" do
check_headers :accept, :content_type
check_privileges("user", "w")
user = create_object_from_json_body
["username", "password", "email"].each do |p|
check_string(user[p], "Parameter '#{p}' must be a not empty string")
end
#BaseRoutes.mongo.user_insert User.new(user)
settings.mongo.user_insert User.new(user)
create_response("Created", nil, 201)
end
# Delete user
#
# * *Request*
# - method : DELETE
# - headers :
# - Accept: application/json
#
# * *Returns* :
# 200 - Deleted
app.delete "/user/:user" do
check_headers :accept
check_privileges("user", "w")
projects = settings.mongo.projects_by_user params[:user]
if !projects.empty?
str = ""
projects.each do |p|
p.deploy_envs.each do |e|
str+="#{p.id}.#{e.identifier} " if e.users.include? params[:user]
end
end
logger.info projects
raise DependencyError.new "Deleting is forbidden: User is included in #{str}"
#return [400, "Deleting is forbidden: User is included in #{str}"]
end
2014-05-08 15:34:26 +04:00
2014-12-12 17:00:06 +03:00
r = settings.mongo.user_delete params[:user]
create_response("User '#{params[:user]}' removed")
2014-05-08 15:34:26 +04:00
end
2014-12-12 17:00:06 +03:00
# Change user privileges
#
# * *Request*
# - method : PUT
# - headers :
# - Accept: application/json
# - Content-Type: application/json
# - body :
# {
# "cmd": "command or all", -> if empty, set default privileges
# "privileges": "priv" -> 'rwx' or ''
# }
#
# * *Returns* :
# 200 - Updated
app.put "/user/:user" do
check_headers :accept, :content_type
check_privileges("user", "w")
data = create_object_from_json_body
user = settings.mongo.user params[:user]
cmd = check_string(data["cmd"], "Parameter 'cmd' should be a not empty string", true) || ""
privileges = check_string(data["privileges"], "Parameter 'privileges' should be a not empty string", true) || ""
user.grant(cmd, privileges)
settings.mongo.user_update user
create_response("Updated")
end
2014-05-08 15:34:26 +04:00
2014-12-12 17:00:06 +03:00
# Change user email/password
#
# * *Request*
# - method : PUT
# - headers :
# - Accept: application/json
# - Content-Type: application/json
# - body :
# {
# "email/password": "new user email/password",
# }
#
# * *Returns* :
# 200 - Updated
app.put %r{\A/user/[\w]+/(email|password)\z} do
check_headers :accept, :content_type
action = File.basename(request.path)
u = File.basename(File.dirname(request.path))
raise InvalidPrivileges.new("Access denied for '#{request.env['REMOTE_USER']}'") if u == User::ROOT_USER_NAME and request.env['REMOTE_USER'] != User::ROOT_USER_NAME
2014-05-08 15:34:26 +04:00
2014-12-12 17:00:06 +03:00
check_privileges("user", "w") unless request.env['REMOTE_USER'] == u
2014-05-08 15:34:26 +04:00
2014-12-12 17:00:06 +03:00
body = create_object_from_json_body
p = check_string(body[action], "Parameter '#{action}' must be a not empty string")
user = settings.mongo.user u
user.send("#{action}=", p)
settings.mongo.user_update user
create_response("Updated")
end
end
2014-05-08 15:34:26 +04:00
2014-12-12 17:00:06 +03:00
end
2014-05-08 15:34:26 +04:00
end
end
end