6
7
8
9
10
11
12
13
14
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
40
41
42
|
# File 'lib/iptables_web/cli/command/update.rb', line 6
def update_command
command :update do |c|
c.syntax = 'iptables-web update'
c.description = 'Display bar with optional prefix and suffix'
c.option '--config STRING', String, 'Path to config file'
c.option '--print', 'Show rules without restoring'
c.option '--force', 'Set rules omit checksum check'
c.action do |_, options|
begin
IptablesWeb.configuration.load(options.config) if options.config
logged_say "Use iptables server #{IptablesWeb.api_base_url}"
IptablesWeb.pid_file do
IptablesWeb::Model::Node.handshake do
rules = IptablesWeb::Model::AccessRule.all
iptables = IptablesWeb::Iptables.new
last_checksum = rules.response.[:etag].first
if options.print
logged_say 'Nothing changed.' if IptablesWeb.checksum?(last_checksum)
say iptables.render(rules)
else
if IptablesWeb.checksum?(rules.response.[:etag].first) && !options.force
logged_say 'Skip iptables update. Nothing changed.'
else
logged_say '*** Iptables updated! ***'
iptables.restore(rules)
IptablesWeb.checksum = last_checksum
end
end
end
end
rescue Exception => e
logged_say(e.message)
logged_say(e.backtrace.join("\n"))
end
end
end
end
|