| 
									
										
										
										
											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-09-21 15:54:33 +03:00
										 |  |  | class StackCreatingError < StandardError; end | 
					
						
							|  |  |  | class BootstrapingStackServerError < StandardError; end | 
					
						
							|  |  |  | class DeployingStackServerError < StandardError; end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  |   def perform(options) | 
					
						
							| 
									
										
										
										
											2015-09-01 16:31:31 +03:00
										 |  |  |     provider_name = options.fetch('provider_name') | 
					
						
							|  |  |  |     stack_attrs = options.fetch('stack_attributes') | 
					
						
							| 
									
										
										
										
											2015-08-14 17:48:07 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-01 16:31:31 +03:00
										 |  |  |     call(provider_name) do |provider, out, file| | 
					
						
							| 
									
										
										
										
											2015-09-21 15:54:33 +03:00
										 |  |  |       @out = out | 
					
						
							| 
									
										
										
										
											2015-09-01 16:31:31 +03:00
										 |  |  |       without_bootstrap = stack_attrs.delete('without_bootstrap') | 
					
						
							| 
									
										
										
										
											2015-09-24 15:06:02 +03:00
										 |  |  |       @out.puts "Received 'without_bootstrap' option" if without_bootstrap | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-17 11:50:35 +03:00
										 |  |  |       report = save_report(file, stack_attrs) | 
					
						
							| 
									
										
										
										
											2015-09-01 16:31:31 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-21 15:54:33 +03:00
										 |  |  |       begin | 
					
						
							|  |  |  |         stack = create_stack(provider_name, stack_attrs) | 
					
						
							|  |  |  |       rescue StackCreatingError | 
					
						
							|  |  |  |         return 1
 | 
					
						
							|  |  |  |       end | 
					
						
							| 
									
										
										
										
											2015-07-20 18:59:26 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-21 15:54:33 +03:00
										 |  |  |       begin | 
					
						
							| 
									
										
										
										
											2015-08-20 21:55:44 +03:00
										 |  |  |         servers = persist_stack_servers!(stack, provider) | 
					
						
							| 
									
										
										
										
											2015-09-21 15:54:33 +03:00
										 |  |  |         bootstrap_servers!(servers, report) unless without_bootstrap | 
					
						
							|  |  |  |       rescue BootstrapingStackServerError | 
					
						
							| 
									
										
										
										
											2015-09-22 15:07:56 +03:00
										 |  |  |         @out.puts "\nAn error occured during bootstraping stack servers. Initiating stack rollback." | 
					
						
							| 
									
										
										
										
											2015-09-21 15:54:33 +03:00
										 |  |  |         rollback_stack!(stack) | 
					
						
							|  |  |  |         1
 | 
					
						
							|  |  |  |       rescue DeployingStackServerError => e | 
					
						
							| 
									
										
										
										
											2015-09-22 15:07:56 +03:00
										 |  |  |         @out.puts "\nStack was launched, but an error occured during deploying stack servers." | 
					
						
							|  |  |  |         @out.puts "You can redeploy stack after fixing the error." | 
					
						
							| 
									
										
										
										
											2015-09-21 15:54:33 +03:00
										 |  |  |         1
 | 
					
						
							|  |  |  |       rescue StandardError => e | 
					
						
							| 
									
										
										
										
											2015-09-22 15:07:56 +03:00
										 |  |  |         @out.puts "\nAn error occured. Initiating stack rollback." | 
					
						
							| 
									
										
										
										
											2015-09-21 15:54:33 +03:00
										 |  |  |         rollback_stack!(stack) | 
					
						
							|  |  |  |         raise e | 
					
						
							| 
									
										
										
										
											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-09-21 15:54:33 +03:00
										 |  |  |   def rollback_stack!(stack) | 
					
						
							|  |  |  |     @out.puts "\nStart rollback of a stack" | 
					
						
							|  |  |  |     stack.delete_stack_in_cloud! | 
					
						
							|  |  |  |     Devops::Db.connector.stack_servers_delete(stack.name) | 
					
						
							|  |  |  |     Devops::Db.connector.stack_delete(stack.id) | 
					
						
							| 
									
										
										
										
											2015-09-22 15:07:56 +03:00
										 |  |  |     @out.puts "Rollback has been completed" | 
					
						
							| 
									
										
										
										
											2015-09-21 15:54:33 +03:00
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def create_stack(provider_name, stack_attrs) | 
					
						
							|  |  |  |     stack = Devops::Model::StackFactory.create(provider_name, stack_attrs, @out) | 
					
						
							|  |  |  |     mongo.stack_insert(stack) | 
					
						
							|  |  |  |     operation_result = sync_stack_proc.call(@out, stack, mongo) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if operation_result == 0
 | 
					
						
							|  |  |  |       @out.puts "\nStack '#{stack.name}' has been created" | 
					
						
							|  |  |  |       @out.flush | 
					
						
							|  |  |  |       stack | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |       human_readable_code = StackCommands.result_codes.key(operation_result) | 
					
						
							|  |  |  |       @out.puts "An error ocurred during stack creating" | 
					
						
							|  |  |  |       @out.puts "Stack creating operation result was #{human_readable_code}" | 
					
						
							|  |  |  |       raise StackCreatingError | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def bootstrap_servers!(servers, report) | 
					
						
							|  |  |  |     @out << "\nStart bootstraping stack servers\n" | 
					
						
							|  |  |  |     bootstraping_results = {} | 
					
						
							|  |  |  |     servers.each do |server| | 
					
						
							|  |  |  |       executor = Devops::Executor::ServerExecutor.new(server, @out) | 
					
						
							| 
									
										
										
										
											2015-09-17 11:50:35 +03:00
										 |  |  |       executor.report = report | 
					
						
							| 
									
										
										
										
											2015-09-21 15:54:33 +03:00
										 |  |  |       bootstraping_results[server.chef_node_name] = executor.two_phase_bootstrap({}) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |     check_bootstrap_results!(bootstraping_results) | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def check_bootstrap_results!(results) | 
					
						
							|  |  |  |     if results.values.all?(&:zero?) | 
					
						
							|  |  |  |       # everything is OK | 
					
						
							|  |  |  |       @out.puts "Stack servers have been bootstraped" | 
					
						
							|  |  |  |       @out.flush | 
					
						
							|  |  |  |       return 0
 | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-22 15:07:56 +03:00
										 |  |  |     @out.puts | 
					
						
							| 
									
										
										
										
											2015-09-21 15:54:33 +03:00
										 |  |  |     results.each do |chef_node_name, code| | 
					
						
							| 
									
										
										
										
											2015-09-22 15:07:56 +03:00
										 |  |  |       human_readable_code = Devops::Executor::ServerExecutor.symbolic_result_code(code) | 
					
						
							| 
									
										
										
										
											2015-09-21 15:54:33 +03:00
										 |  |  |       @out.puts "Operation result for #{chef_node_name}: #{human_readable_code}" | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if errors_in_bootstrapping_present?(results) | 
					
						
							| 
									
										
										
										
											2015-09-22 15:07:56 +03:00
										 |  |  |       raise BootstrapingStackServerError # will cause rollback of a stack | 
					
						
							| 
									
										
										
										
											2015-09-21 15:54:33 +03:00
										 |  |  |     else | 
					
						
							| 
									
										
										
										
											2015-09-22 15:07:56 +03:00
										 |  |  |       raise DeployingStackServerError #will not cause rollback of a stack | 
					
						
							| 
									
										
										
										
											2015-09-21 15:54:33 +03:00
										 |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def errors_in_bootstrapping_present?(results) | 
					
						
							|  |  |  |     results.values.any? do |result| | 
					
						
							|  |  |  |       result == Devops::Executor::ServerExecutor.result_code(:server_bootstrap_fail) | 
					
						
							| 
									
										
										
										
											2015-09-01 16:31:31 +03:00
										 |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def save_report(file, stack_attrs) | 
					
						
							|  |  |  |     report = ::Devops::Model::Report.new( | 
					
						
							|  |  |  |       "file" => file, | 
					
						
							|  |  |  |       "_id" => jid, | 
					
						
							|  |  |  |       "created_by" => stack_attrs['owner'], | 
					
						
							|  |  |  |       "project" => stack_attrs["project"], | 
					
						
							|  |  |  |       "deploy_env" => stack_attrs["deploy_env"], | 
					
						
							|  |  |  |       "type" => ::Devops::Model::Report::STACK_TYPE | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     mongo.save_report(report) | 
					
						
							| 
									
										
										
										
											2015-09-17 11:50:35 +03:00
										 |  |  |     report | 
					
						
							| 
									
										
										
										
											2015-09-01 16:31:31 +03:00
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-05 18:26:21 +03:00
										 |  |  |   def persist_stack_servers!(stack, provider) | 
					
						
							| 
									
										
										
										
											2015-09-21 15:54:33 +03:00
										 |  |  |     @out.puts "Start syncing stack servers with CID" | 
					
						
							|  |  |  |     @out.flush | 
					
						
							| 
									
										
										
										
											2015-07-30 02:14:45 +03:00
										 |  |  |     project = mongo.project(stack.project) | 
					
						
							|  |  |  |     deploy_env = project.deploy_env(stack.deploy_env) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-21 15:54:33 +03:00
										 |  |  |     servers = 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, | 
					
						
							| 
									
										
										
										
											2015-08-18 20:01:17 +03:00
										 |  |  |         'key' => extended_info["key_name"] || provider.ssh_key, | 
					
						
							|  |  |  |         '_id' => extended_info["id"], | 
					
						
							|  |  |  |         'chef_node_name' => extended_info["name"], | 
					
						
							|  |  |  |         'private_ip' => extended_info["private_ip"], | 
					
						
							|  |  |  |         'public_ip' => extended_info["public_ip"], | 
					
						
							| 
									
										
										
										
											2015-08-05 18:26:21 +03:00
										 |  |  |         'created_by' => stack.owner, | 
					
						
							|  |  |  |         'run_list' => stack.run_list || [], | 
					
						
							| 
									
										
										
										
											2015-08-20 22:42:21 +03:00
										 |  |  |         'stack' => stack.name | 
					
						
							| 
									
										
										
										
											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-31 14:26:16 +03:00
										 |  |  |       # server.chef_node_name =  provider.create_default_chef_node_name(server) | 
					
						
							| 
									
										
										
										
											2015-08-12 12:24:48 +03:00
										 |  |  |       server | 
					
						
							| 
									
										
										
										
											2015-07-30 02:14:45 +03:00
										 |  |  |     end | 
					
						
							| 
									
										
										
										
											2015-09-21 15:54:33 +03:00
										 |  |  |     @out.puts "Stack servers have been synced with CID" | 
					
						
							|  |  |  |     @out.flush | 
					
						
							|  |  |  |     servers | 
					
						
							| 
									
										
										
										
											2015-07-30 02:14:45 +03:00
										 |  |  |   end | 
					
						
							| 
									
										
										
										
											2015-08-05 18:26:21 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-20 18:59:26 +03:00
										 |  |  | end |