2015-07-20 18:59:26 +03:00
|
|
|
require "providers/provider_factory"
|
|
|
|
|
require "commands/stack"
|
|
|
|
|
require "db/mongo/models/stack/stack_factory"
|
2015-07-30 02:14:45 +03:00
|
|
|
require "db/mongo/models/project"
|
2015-07-20 18:59:26 +03:00
|
|
|
require "db/mongo/models/report"
|
|
|
|
|
|
2015-07-30 13:18:55 +03:00
|
|
|
class StackBootstrapWorker < Worker
|
2015-07-20 18:59:26 +03:00
|
|
|
include StackCommands
|
|
|
|
|
|
2015-07-23 12:54:36 +03:00
|
|
|
# besides options came from JobStarter we need:
|
|
|
|
|
# :provider
|
|
|
|
|
# :stack_id
|
|
|
|
|
def perform(options)
|
2015-07-30 15:37:43 +03:00
|
|
|
call(options['config'], options['provider'], options['dir']) do |provider, out, file|
|
2015-08-14 17:48:07 +03:00
|
|
|
attrs = options['stack_attributes']
|
2015-08-12 13:32:26 +03:00
|
|
|
mongo = ::Devops::Db.connector
|
2015-08-14 17:48:07 +03:00
|
|
|
report = ::Devops::Model::Report.new(
|
|
|
|
|
"file" => file,
|
|
|
|
|
"_id" => jid,
|
|
|
|
|
"created_by" => attrs['owner'],
|
|
|
|
|
"project" => attrs["project"],
|
|
|
|
|
"deploy_env" => attrs["deploy_env"],
|
|
|
|
|
"type" => ::Devops::Model::Report::STACK_TYPE
|
|
|
|
|
)
|
|
|
|
|
mongo.save_report(report)
|
|
|
|
|
|
|
|
|
|
stack = Devops::Model::StackFactory.create(options['provider'], options['stack_attributes'], out)
|
|
|
|
|
# stack.owner = attrs['owner']
|
2015-08-12 13:32:26 +03:00
|
|
|
mongo.stack_insert(stack)
|
2015-07-20 18:59:26 +03:00
|
|
|
|
2015-08-05 15:06:18 +03:00
|
|
|
sync_bootstrap_proc.call(out, stack, mongo)
|
2015-08-18 17:41:17 +03:00
|
|
|
out << "\nStack '#{stack.name}' has been created\n"
|
2015-08-18 17:53:39 +03:00
|
|
|
out.flush
|
2015-08-12 12:24:48 +03:00
|
|
|
servers = persist_stack_servers!(stack, provider)
|
2015-08-18 18:09:09 +03:00
|
|
|
out << attrs.inspect
|
|
|
|
|
out << "\n"
|
|
|
|
|
unless attrs['without_bootstrap']
|
2015-08-14 17:48:07 +03:00
|
|
|
statuses = servers.map do |s|
|
|
|
|
|
Devops::Executor::ServerExecutor.new(s, out).two_phase_bootstrap({})
|
|
|
|
|
end
|
2015-08-12 12:24:48 +03:00
|
|
|
end
|
2015-07-20 18:59:26 +03:00
|
|
|
end
|
|
|
|
|
end
|
2015-07-30 02:14:45 +03:00
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
2015-08-05 18:26:21 +03:00
|
|
|
def persist_stack_servers!(stack, provider)
|
|
|
|
|
mongo = ::Devops::Db.connector
|
2015-07-30 02:14:45 +03:00
|
|
|
project = mongo.project(stack.project)
|
|
|
|
|
deploy_env = project.deploy_env(stack.deploy_env)
|
|
|
|
|
|
2015-08-14 17:48:07 +03:00
|
|
|
provider.stack_servers(stack).map do |extended_info |
|
2015-08-05 18:26:21 +03:00
|
|
|
server_attrs = {
|
|
|
|
|
'provider' => provider.name,
|
|
|
|
|
'project' => project.id,
|
|
|
|
|
'deploy_env' => deploy_env.identifier,
|
|
|
|
|
'remote_user' => mongo.image(deploy_env.image).remote_user,
|
|
|
|
|
'key' => extended_info.key_name || provider.ssh_key,
|
2015-08-14 17:48:07 +03:00
|
|
|
'_id' => extended_info.id,
|
2015-08-05 18:26:21 +03:00
|
|
|
'chef_node_name' => extended_info.name,
|
|
|
|
|
'private_ip' => extended_info.addresses.values.first.first['addr'],
|
|
|
|
|
'created_by' => stack.owner,
|
|
|
|
|
'run_list' => stack.run_list || [],
|
|
|
|
|
'stack' => stack.id
|
2015-07-30 02:14:45 +03:00
|
|
|
}
|
|
|
|
|
|
2015-08-05 18:26:21 +03:00
|
|
|
server = ::Devops::Model::Server.new(server_attrs)
|
|
|
|
|
mongo.server_insert(server)
|
2015-08-12 12:24:48 +03:00
|
|
|
server
|
2015-07-30 02:14:45 +03:00
|
|
|
end
|
|
|
|
|
end
|
2015-08-05 18:26:21 +03:00
|
|
|
|
2015-07-20 18:59:26 +03:00
|
|
|
end
|
2015-07-23 12:54:36 +03:00
|
|
|
|
2015-07-30 13:18:55 +03:00
|
|
|
WorkersStorage.add_worker(stack_bootstrap: StackBootstrapWorker)
|