require 'json'
require 'base64'
require 'commands/add-env'
require 'plan-step-class'
require 'yaml'
require 'canzea/config'
require 'commands/remote-run'

class PreparePlan
    def initialize ()
        @log = Logger.new(Canzea::config[:logging_root] + '/plans.log')
        @basePath = "#{Pathname.new(Canzea::config[:catalog_location]).realpath}"
    end

    def doPatch (params, test, privateKey, serverBase, serverNumber)

        publicIp = File.read("#{Canzea::config[:pwd]}/vps-#{serverBase}-#{serverNumber}.json")
        publicIp.strip!

        patches = Base64.decode64(params['patches'])
        params['patches'] = JSON.parse(patches)

        params['patches'].each do | patch |
            RemoteRun.new.doCommand publicIp, privateKey, patch.command
        end
    end

    # Read the blueprint instructions and prepare plan for a particular segment
    def do (blueprint, segment, step, task, test, privateKey, serverBase, serverNumber)
        planStep = PlanStep.new

        log "Processing configure.json for #{segment} in #{blueprint} from #{@basePath}"

        instructions = YAML.load_file("#{@basePath}/blueprints/#{blueprint}/instruction.yml")
        segment = instructions['instructions']['segments'][segment]

        log segment['abbreviation']

        index = 1
        segment['image'].each { |item|
            if item.start_with?("step:")
                parts = item.split(':')

                if (index < Integer(step))
                    log "[#{index.to_s.rjust(2, "0")}] #{item} SKIPPING"
                else
                    log "[#{index.to_s.rjust(2, "0")}] #{item}"
                    publicIp = File.read("#{Canzea::config[:pwd]}/vps-#{serverBase}-#{serverNumber}.json")
                    publicIp.strip!
                    if (test == false)
                        if (task == nil)
                            RemoteRun.new.do publicIp, privateKey, parts[1], parts[2], index.to_s.rjust(2, "0")
                        else
                            RemoteRun.new.doTask publicIp, privateKey, parts[1], parts[2], task, index.to_s.rjust(2, "0")
                        end
                        # Keep track of what we have done; parsing the response and looking at the JSON
                    else
                        RemoteRun.new.test publicIp, privateKey, parts[1], parts[2], index.to_s.rjust(2, "0")
                    end
                end
                index = index + 1
            end
        }
    end

    def log (msg)
        puts "-- #{msg}"
        @log.info(msg)
    end
end