require 'pathname' require 'logger' require 'awestruct/logger' require 'awestruct/cli/options' module Awestruct module CLI class Invoker attr_reader :options attr_reader :config attr_reader :profile attr_reader :success def initialize(*options) options = options.flatten if ( ( ! options.empty? ) && ( options.first === Awestruct::CLI::Options ) ) @options = options.first else @options = Awestruct::CLI::Options.parse! options end @threads = [] @profile = nil @success = true logging_path = Pathname.new '.awestruct' logging_path.mkdir unless logging_path.exist? $LOG = Logger.new(Awestruct::AwestructLoggerMultiIO.new(@options.verbose, STDOUT, File.open('.awestruct/debug.log', 'w'))) $LOG.level = @options.verbose ? Logger::DEBUG : Logger::INFO $LOG.formatter = Awestruct::AwestructLogFormatter.new # these requires are deferred until after $LOG is set require 'awestruct/cli/init' require 'awestruct/cli/generate' require 'awestruct/cli/auto' require 'awestruct/cli/server' end def invoke! load_profile() unless ( options.init ) setup_config() invoke_init() if ( options.init ) invoke_script() if ( options.script ) invoke_force() if ( options.force ) invoke_generate() if ( options.generate ) invoke_deploy() if ( options.deploy ) invoke_server() if ( options.server ) invoke_auto() if ( options.auto ) wait_for_completion() success end def load_profile() site_yaml_file = File.join( Dir.pwd, '_config', 'site.yml' ) if ( File.exist?( site_yaml_file ) ) site_yaml = YAML.load( File.read( site_yaml_file ) ) if site_yaml profiles_data = site_yaml['profiles'] || {} @profile = if profiles_data.nil? nil else if options.profile profiles_data[options.profile] || {} else # if no profile given, pick the first with deploy config options.profile, profile_data = profiles_data.select { |k,v| v && v['deploy'] }.first profile_data end end end end unless @profile $LOG.error "Unable to locate profile: #{options.profile}" if options.profile && $LOG.error? options.profile = 'NONE' @profile = {} end $LOG.info "Using profile: #{options.profile}" if $LOG.info? end def setup_config() @config = Awestruct::Config.new( @options ) @config.track_dependencies = true if ( @options.auto ) @config.verbose = true if ( @options.verbose ) end def invoke_init() Awestruct::CLI::Init.new( Dir.pwd, @options.framework, @options.scaffold ).run end def invoke_script() end def invoke_force() FileUtils.rm_rf( File.join( config.dir, '.awestruct', 'dependency-cache' ) ) FileUtils.rm_rf( config.output_dir ) end def invoke_generate() base_url = profile['base_url'] || options.base_url @success = Awestruct::CLI::Generate.new( config, options.profile, base_url, Options::DEFAULT_BASE_URL, options.force ).run end def invoke_deploy() require 'awestruct/cli/deploy' deploy_config = profile[ 'deploy' ] if ( deploy_config.nil? ) $LOG.error "No configuration for 'deploy'" if $LOG.error? return end Awestruct::CLI::Deploy.new( config, deploy_config ).run end def invoke_auto() Awestruct::CLI::Auto.new( config ).run end def invoke_server() run_in_thread( Awestruct::CLI::Server.new( options.output_dir, options.bind_addr, options.port ) ) end private def run_in_thread(command) @threads << Thread.new(command){|c| c.run} end def wait_for_completion() @threads.each do |thr| thr.join end end end end end