iisconfig 0.4.0 → 0.4.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -13
- data/VERSION +1 -1
- data/bin/iisconfig +7 -7
- data/lib/iisconfig.rb +42 -42
- data/lib/iisconfig/app_pool.rb +118 -110
- data/lib/iisconfig/application.rb +46 -46
- data/lib/iisconfig/configuration.rb +101 -101
- data/lib/iisconfig/ftp_site.rb +91 -91
- data/lib/iisconfig/iis_object.rb +34 -34
- data/lib/iisconfig/iisconfig.rb +2 -2
- data/lib/iisconfig/process_model.rb +77 -77
- data/lib/iisconfig/runner.rb +25 -25
- data/lib/iisconfig/site.rb +84 -84
- data/lib/iisconfig/version.rb +4 -4
- data/lib/iisconfig/virtual_directory.rb +29 -29
- data/test/example.rb +53 -52
- metadata +8 -8
@@ -1,101 +1,101 @@
|
|
1
|
-
$:.push File.expand_path(File.dirname(__FILE__))
|
2
|
-
|
3
|
-
require 'rexml/document'
|
4
|
-
require 'app_pool'
|
5
|
-
require 'ftp_site'
|
6
|
-
require 'site'
|
7
|
-
|
8
|
-
module IISConfig
|
9
|
-
|
10
|
-
class IISConfiguration
|
11
|
-
@@dry_run = false
|
12
|
-
|
13
|
-
def initialize(options = {})
|
14
|
-
@options = {recycle_apppools: false}.merge(options)
|
15
|
-
@app_pools = []
|
16
|
-
@sites = []
|
17
|
-
@ftp_sites = []
|
18
|
-
@before = []
|
19
|
-
@after = []
|
20
|
-
end
|
21
|
-
|
22
|
-
def self.dry_run=dry_run
|
23
|
-
@@dry_run = dry_run
|
24
|
-
end
|
25
|
-
|
26
|
-
def self.dry_run?
|
27
|
-
@@dry_run
|
28
|
-
end
|
29
|
-
|
30
|
-
def app_pool(&block)
|
31
|
-
add_instance @app_pools, IISConfig::AppPool, block
|
32
|
-
end
|
33
|
-
|
34
|
-
def site(&block)
|
35
|
-
add_instance @sites, IISConfig::Site, block
|
36
|
-
end
|
37
|
-
|
38
|
-
def ftp_site(&block)
|
39
|
-
add_instance @ftp_sites, IISConfig::FtpSite, block
|
40
|
-
end
|
41
|
-
|
42
|
-
def before(&block)
|
43
|
-
@before << block
|
44
|
-
end
|
45
|
-
|
46
|
-
def after(&block)
|
47
|
-
@after << block
|
48
|
-
end
|
49
|
-
|
50
|
-
def load(path)
|
51
|
-
instance_eval IO.read(path), path
|
52
|
-
end
|
53
|
-
|
54
|
-
def run
|
55
|
-
@before.each { |a| a.call }
|
56
|
-
|
57
|
-
if @options[:recycle_apppools]
|
58
|
-
recycle_application_pools
|
59
|
-
else
|
60
|
-
rebuild_all
|
61
|
-
end
|
62
|
-
|
63
|
-
@after.each { |a| a.call }
|
64
|
-
end
|
65
|
-
|
66
|
-
private
|
67
|
-
|
68
|
-
def rebuild_all
|
69
|
-
execute @app_pools
|
70
|
-
execute @sites
|
71
|
-
execute @ftp_sites
|
72
|
-
end
|
73
|
-
|
74
|
-
def recycle_application_pools
|
75
|
-
@app_pools.each do |p|
|
76
|
-
commands = p.recycle
|
77
|
-
Runner.run_commands [commands] unless commands.empty?
|
78
|
-
end
|
79
|
-
end
|
80
|
-
|
81
|
-
def execute(objects)
|
82
|
-
objects.each do |p|
|
83
|
-
commands = p.build_commands
|
84
|
-
Runner.run_commands commands
|
85
|
-
|
86
|
-
p.required_paths.each do |path|
|
87
|
-
FileUtils.mkdir_p path unless Dir.exist? path
|
88
|
-
end
|
89
|
-
end
|
90
|
-
end
|
91
|
-
|
92
|
-
def add_instance(collection, type, block)
|
93
|
-
instance = type.new
|
94
|
-
collection << instance
|
95
|
-
block.call instance if block
|
96
|
-
end
|
97
|
-
|
98
|
-
end
|
99
|
-
|
100
|
-
end
|
101
|
-
|
1
|
+
$:.push File.expand_path(File.dirname(__FILE__))
|
2
|
+
|
3
|
+
require 'rexml/document'
|
4
|
+
require 'app_pool'
|
5
|
+
require 'ftp_site'
|
6
|
+
require 'site'
|
7
|
+
|
8
|
+
module IISConfig
|
9
|
+
|
10
|
+
class IISConfiguration
|
11
|
+
@@dry_run = false
|
12
|
+
|
13
|
+
def initialize(options = {})
|
14
|
+
@options = {recycle_apppools: false}.merge(options)
|
15
|
+
@app_pools = []
|
16
|
+
@sites = []
|
17
|
+
@ftp_sites = []
|
18
|
+
@before = []
|
19
|
+
@after = []
|
20
|
+
end
|
21
|
+
|
22
|
+
def self.dry_run=dry_run
|
23
|
+
@@dry_run = dry_run
|
24
|
+
end
|
25
|
+
|
26
|
+
def self.dry_run?
|
27
|
+
@@dry_run
|
28
|
+
end
|
29
|
+
|
30
|
+
def app_pool(&block)
|
31
|
+
add_instance @app_pools, IISConfig::AppPool, block
|
32
|
+
end
|
33
|
+
|
34
|
+
def site(&block)
|
35
|
+
add_instance @sites, IISConfig::Site, block
|
36
|
+
end
|
37
|
+
|
38
|
+
def ftp_site(&block)
|
39
|
+
add_instance @ftp_sites, IISConfig::FtpSite, block
|
40
|
+
end
|
41
|
+
|
42
|
+
def before(&block)
|
43
|
+
@before << block
|
44
|
+
end
|
45
|
+
|
46
|
+
def after(&block)
|
47
|
+
@after << block
|
48
|
+
end
|
49
|
+
|
50
|
+
def load(path)
|
51
|
+
instance_eval IO.read(path), path
|
52
|
+
end
|
53
|
+
|
54
|
+
def run
|
55
|
+
@before.each { |a| a.call }
|
56
|
+
|
57
|
+
if @options[:recycle_apppools]
|
58
|
+
recycle_application_pools
|
59
|
+
else
|
60
|
+
rebuild_all
|
61
|
+
end
|
62
|
+
|
63
|
+
@after.each { |a| a.call }
|
64
|
+
end
|
65
|
+
|
66
|
+
private
|
67
|
+
|
68
|
+
def rebuild_all
|
69
|
+
execute @app_pools
|
70
|
+
execute @sites
|
71
|
+
execute @ftp_sites
|
72
|
+
end
|
73
|
+
|
74
|
+
def recycle_application_pools
|
75
|
+
@app_pools.each do |p|
|
76
|
+
commands = p.recycle
|
77
|
+
Runner.run_commands [commands] unless commands.empty?
|
78
|
+
end
|
79
|
+
end
|
80
|
+
|
81
|
+
def execute(objects)
|
82
|
+
objects.each do |p|
|
83
|
+
commands = p.build_commands
|
84
|
+
Runner.run_commands commands
|
85
|
+
|
86
|
+
p.required_paths.each do |path|
|
87
|
+
FileUtils.mkdir_p path unless Dir.exist? path
|
88
|
+
end
|
89
|
+
end
|
90
|
+
end
|
91
|
+
|
92
|
+
def add_instance(collection, type, block)
|
93
|
+
instance = type.new
|
94
|
+
collection << instance
|
95
|
+
block.call instance if block
|
96
|
+
end
|
97
|
+
|
98
|
+
end
|
99
|
+
|
100
|
+
end
|
101
|
+
|
data/lib/iisconfig/ftp_site.rb
CHANGED
@@ -1,92 +1,92 @@
|
|
1
|
-
require 'iis_object'
|
2
|
-
require 'application'
|
3
|
-
|
4
|
-
module IISConfig
|
5
|
-
|
6
|
-
class FtpSite < IISObject
|
7
|
-
|
8
|
-
def initialize
|
9
|
-
@bindings = []
|
10
|
-
@authentication = []
|
11
|
-
@allow_authorization = []
|
12
|
-
end
|
13
|
-
|
14
|
-
def name(name = nil)
|
15
|
-
@name = name unless name.nil?
|
16
|
-
@name
|
17
|
-
end
|
18
|
-
|
19
|
-
def binding(binding)
|
20
|
-
@bindings << binding
|
21
|
-
end
|
22
|
-
|
23
|
-
def app_pool(pool)
|
24
|
-
@app_pool = pool
|
25
|
-
end
|
26
|
-
|
27
|
-
def physical_path(path)
|
28
|
-
@physical_path = path
|
29
|
-
end
|
30
|
-
|
31
|
-
def enable_authentication(*authentication)
|
32
|
-
@authentication += authentication
|
33
|
-
end
|
34
|
-
|
35
|
-
def allow_authorization(permissions, access)
|
36
|
-
@allow_authorization << { :permissions => permissions, :access => access }
|
37
|
-
end
|
38
|
-
|
39
|
-
def allow_ssl
|
40
|
-
@ssl = :allow
|
41
|
-
end
|
42
|
-
|
43
|
-
def delete
|
44
|
-
%W{DELETE SITE #{@name}}
|
45
|
-
end
|
46
|
-
|
47
|
-
def add
|
48
|
-
args = []
|
49
|
-
args << 'ADD'
|
50
|
-
args << 'SITE'
|
51
|
-
args << "/name:#{@name}"
|
52
|
-
args << "/bindings:\"#{@bindings.join('","')}\""
|
53
|
-
args << "/physicalPath:#{@physical_path.gsub(/\//, '\\')}"
|
54
|
-
|
55
|
-
args
|
56
|
-
end
|
57
|
-
|
58
|
-
def required_paths
|
59
|
-
paths = []
|
60
|
-
paths << @physical_path
|
61
|
-
paths
|
62
|
-
end
|
63
|
-
|
64
|
-
def build_commands()
|
65
|
-
commands = []
|
66
|
-
commands << delete if exist? :site, @name
|
67
|
-
commands << add
|
68
|
-
|
69
|
-
commands << %W{SET SITE /site.name:#{@name} /[path='/'].applicationPool:#{@app_pool}} unless @app_pool.nil?
|
70
|
-
|
71
|
-
@allow_authorization.each do |a|
|
72
|
-
permissions = a[:permissions].map { |p| p.capitalize }.join(',')
|
73
|
-
roles = a[:access][:roles]
|
74
|
-
users = a[:access][:users]
|
75
|
-
commands << %W{SET CONFIG #{@name} /section:system.ftpserver/security/authorization /+[accessType='Allow',permissions='#{permissions}',roles='#{roles}',users='#{users}'] /commit:apphost}
|
76
|
-
end
|
77
|
-
|
78
|
-
@authentication.each do |a|
|
79
|
-
commands << %W{SET CONFIG -section:system.applicationHost/sites /[name='#{@name}'].ftpServer.security.authentication.#{a}Authentication.enabled:true}
|
80
|
-
end
|
81
|
-
|
82
|
-
unless @ssl.nil?
|
83
|
-
commands << %W{SET CONFIG -section:system.applicationHost/sites /[name='#{@name}'].ftpServer.security.ssl.controlChannelPolicy:"Ssl#{@ssl.capitalize}"}
|
84
|
-
commands << %W{SET CONFIG -section:system.applicationHost/sites /[name='#{@name}'].ftpServer.security.ssl.dataChannelPolicy:"Ssl#{@ssl.capitalize}"}
|
85
|
-
end
|
86
|
-
|
87
|
-
commands
|
88
|
-
end
|
89
|
-
|
90
|
-
end
|
91
|
-
|
1
|
+
require 'iis_object'
|
2
|
+
require 'application'
|
3
|
+
|
4
|
+
module IISConfig
|
5
|
+
|
6
|
+
class FtpSite < IISObject
|
7
|
+
|
8
|
+
def initialize
|
9
|
+
@bindings = []
|
10
|
+
@authentication = []
|
11
|
+
@allow_authorization = []
|
12
|
+
end
|
13
|
+
|
14
|
+
def name(name = nil)
|
15
|
+
@name = name unless name.nil?
|
16
|
+
@name
|
17
|
+
end
|
18
|
+
|
19
|
+
def binding(binding)
|
20
|
+
@bindings << binding
|
21
|
+
end
|
22
|
+
|
23
|
+
def app_pool(pool)
|
24
|
+
@app_pool = pool
|
25
|
+
end
|
26
|
+
|
27
|
+
def physical_path(path)
|
28
|
+
@physical_path = path
|
29
|
+
end
|
30
|
+
|
31
|
+
def enable_authentication(*authentication)
|
32
|
+
@authentication += authentication
|
33
|
+
end
|
34
|
+
|
35
|
+
def allow_authorization(permissions, access)
|
36
|
+
@allow_authorization << { :permissions => permissions, :access => access }
|
37
|
+
end
|
38
|
+
|
39
|
+
def allow_ssl
|
40
|
+
@ssl = :allow
|
41
|
+
end
|
42
|
+
|
43
|
+
def delete
|
44
|
+
%W{DELETE SITE #{@name}}
|
45
|
+
end
|
46
|
+
|
47
|
+
def add
|
48
|
+
args = []
|
49
|
+
args << 'ADD'
|
50
|
+
args << 'SITE'
|
51
|
+
args << "/name:#{@name}"
|
52
|
+
args << "/bindings:\"#{@bindings.join('","')}\""
|
53
|
+
args << "/physicalPath:#{@physical_path.gsub(/\//, '\\')}"
|
54
|
+
|
55
|
+
args
|
56
|
+
end
|
57
|
+
|
58
|
+
def required_paths
|
59
|
+
paths = []
|
60
|
+
paths << @physical_path
|
61
|
+
paths
|
62
|
+
end
|
63
|
+
|
64
|
+
def build_commands()
|
65
|
+
commands = []
|
66
|
+
commands << delete if exist? :site, @name
|
67
|
+
commands << add
|
68
|
+
|
69
|
+
commands << %W{SET SITE /site.name:#{@name} /[path='/'].applicationPool:#{@app_pool}} unless @app_pool.nil?
|
70
|
+
|
71
|
+
@allow_authorization.each do |a|
|
72
|
+
permissions = a[:permissions].map { |p| p.capitalize }.join(',')
|
73
|
+
roles = a[:access][:roles]
|
74
|
+
users = a[:access][:users]
|
75
|
+
commands << %W{SET CONFIG #{@name} /section:system.ftpserver/security/authorization /+[accessType='Allow',permissions='#{permissions}',roles='#{roles}',users='#{users}'] /commit:apphost}
|
76
|
+
end
|
77
|
+
|
78
|
+
@authentication.each do |a|
|
79
|
+
commands << %W{SET CONFIG -section:system.applicationHost/sites /[name='#{@name}'].ftpServer.security.authentication.#{a}Authentication.enabled:true}
|
80
|
+
end
|
81
|
+
|
82
|
+
unless @ssl.nil?
|
83
|
+
commands << %W{SET CONFIG -section:system.applicationHost/sites /[name='#{@name}'].ftpServer.security.ssl.controlChannelPolicy:"Ssl#{@ssl.capitalize}"}
|
84
|
+
commands << %W{SET CONFIG -section:system.applicationHost/sites /[name='#{@name}'].ftpServer.security.ssl.dataChannelPolicy:"Ssl#{@ssl.capitalize}"}
|
85
|
+
end
|
86
|
+
|
87
|
+
commands
|
88
|
+
end
|
89
|
+
|
90
|
+
end
|
91
|
+
|
92
92
|
end
|
data/lib/iisconfig/iis_object.rb
CHANGED
@@ -1,35 +1,35 @@
|
|
1
|
-
require 'runner'
|
2
|
-
|
3
|
-
module IISConfig
|
4
|
-
|
5
|
-
class IISObject
|
6
|
-
|
7
|
-
def exist?(type, name)
|
8
|
-
args = []
|
9
|
-
args << 'LIST'
|
10
|
-
args << type.to_s.upcase
|
11
|
-
args << '/xml'
|
12
|
-
result = Runner.execute_command args
|
13
|
-
|
14
|
-
exists = false
|
15
|
-
doc = REXML::Document.new(result)
|
16
|
-
|
17
|
-
doc.elements.each("appcmd/#{type.to_s.upcase}[@#{type.to_s.upcase}.NAME='#{name}']") do
|
18
|
-
exists = true
|
19
|
-
break
|
20
|
-
end
|
21
|
-
|
22
|
-
exists
|
23
|
-
end
|
24
|
-
|
25
|
-
protected
|
26
|
-
|
27
|
-
def add_instance(collection, type, block)
|
28
|
-
instance = type.new
|
29
|
-
collection << instance
|
30
|
-
block.call instance if block
|
31
|
-
end
|
32
|
-
|
33
|
-
end
|
34
|
-
|
1
|
+
require 'runner'
|
2
|
+
|
3
|
+
module IISConfig
|
4
|
+
|
5
|
+
class IISObject
|
6
|
+
|
7
|
+
def exist?(type, name)
|
8
|
+
args = []
|
9
|
+
args << 'LIST'
|
10
|
+
args << type.to_s.upcase
|
11
|
+
args << '/xml'
|
12
|
+
result = Runner.execute_command args
|
13
|
+
|
14
|
+
exists = false
|
15
|
+
doc = REXML::Document.new(result)
|
16
|
+
|
17
|
+
doc.elements.each("appcmd/#{type.to_s.upcase}[@#{type.to_s.upcase}.NAME='#{name}']") do
|
18
|
+
exists = true
|
19
|
+
break
|
20
|
+
end
|
21
|
+
|
22
|
+
exists
|
23
|
+
end
|
24
|
+
|
25
|
+
protected
|
26
|
+
|
27
|
+
def add_instance(collection, type, block)
|
28
|
+
instance = type.new
|
29
|
+
collection << instance
|
30
|
+
block.call instance if block
|
31
|
+
end
|
32
|
+
|
33
|
+
end
|
34
|
+
|
35
35
|
end
|