Class: UpdateChecker

Inherits:
Object
  • Object
show all
Includes:
Thor::Shell
Defined in:
lib/docker-sync/update_check.rb

Instance Method Summary collapse

Constructor Details

#initializeUpdateChecker

Returns a new instance of UpdateChecker.



10
11
12
13
# File 'lib/docker-sync/update_check.rb', line 10

def initialize
  @config = DockerSync::GlobalConfig.load
  @newer_image_found = false
end

Instance Method Details

#check_and_warn(update_enforced = true) ⇒ Object



87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
# File 'lib/docker-sync/update_check.rb', line 87

def check_and_warn(update_enforced = true)
  return if ENV['DOCKER_SYNC_SKIP_UPDATE']
  # update the timestamp
  @config.update! 'update_last_check' => DateTime.now.iso8601(9)

  check = docker_sync_update_check
  if check.update_available
    say_status 'warning',"There is an update (#{check.latest_version}) available (current version #{check.current_version}). Please update before you continue",:yellow
    if yes?("Shall I update docker-sync to #{check.latest_version} for you?")
      system('gem update docker-sync')
      say_status 'success','Successfully updated, please restart docker-sync and check the changelog at https://github.com/EugenMayer/docker-sync/wiki/5.-Changelog',:green
      exit 0
    else
      exit 1 if update_enforced
    end
  end
end

#check_rsync_imageObject



60
61
62
63
64
65
66
67
68
69
70
71
# File 'lib/docker-sync/update_check.rb', line 60

def check_rsync_image
  return if ENV['DOCKER_SYNC_SKIP_UPDATE']
  say_status 'ok','Checking if a newer rsync image is available'

  if system("docker pull eugenmayer/rsync | grep 'Downloaded newer image for'")
    say_status 'ok', 'Downloaded newer image for rsync', :green
    @newer_image_found = true
  else
    say_status 'ok', 'No newer image found - current image is up to date.'
  end

end

#docker_sync_update_checkObject



80
81
82
83
84
85
# File 'lib/docker-sync/update_check.rb', line 80

def docker_sync_update_check
  gem_name = 'docker-sync'
  current_version = get_current_version
  checker = GemUpdateChecker::Client.new(gem_name, current_version)
  return checker
end

#get_current_versionObject



73
74
75
76
77
78
# File 'lib/docker-sync/update_check.rb', line 73

def get_current_version
  path = File.expand_path('../../../', __FILE__)
  version = File.read("#{path}/VERSION")
  version.strip
  version
end

#has_internet?Boolean

Returns:

  • (Boolean)


41
42
43
44
# File 'lib/docker-sync/update_check.rb', line 41

def has_internet?
  `ping -c1 -t 1 8.8.8.8 > /dev/null 2>&1`
  return $?.success?
end

#runObject



15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
# File 'lib/docker-sync/update_check.rb', line 15

def run
  return if ENV['DOCKER_SYNC_SKIP_UPDATE']
  unless @config['update_check']
    say_status 'hint','Skipping up-to-date check since it has been disabled in your ~/.docker-sync-global.yml configuration',:yellow
    return
  end
  unless should_run
    return
  end

  # do not check the image if its the first run - since this it will be downloaded anyway
  unless @config.first_run?
    unless has_internet?
      check_unison_image
      check_rsync_image
      # stop if there was an update
      if @newer_image_found
        say_status 'warning', 'One or more images have been updated. Please use "docker-sync clean" before you start docker-sync again', :red
        exit 0
      end
    end
  end

  check_and_warn(@config['update_enforce'])
end

#should_runObject



46
47
48
49
50
51
52
53
54
55
56
57
58
# File 'lib/docker-sync/update_check.rb', line 46

def should_run
  return false unless has_internet?
  now = DateTime.now
  return true if @config['update_last_check'].nil?

  last_check = DateTime.iso8601(@config['update_last_check'])
  check_after_days = 2
  if now - last_check > check_after_days
    return true
  end

  return false
end