vagrant-subutai 7.0.2 → 7.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: aabe7e7c68d3d359655354727293c7ef9816158b
4
- data.tar.gz: 8b2e4361bda3faf126bf695e0ee38c0785033af5
3
+ metadata.gz: adb3b9b979548fbd83ff2eb4ec71ab69e1cf154f
4
+ data.tar.gz: d913fd3476e3c84745d4d30ba48b1f62c6e3316b
5
5
  SHA512:
6
- metadata.gz: a0249deec3ac761adaf330ddfbdd71ddd2f5719636b5976a01d78699bfa8caf9618acef484ac4396ac029ea887c10a2f20a1ff2d801e5d20903549c240390d01
7
- data.tar.gz: 4245cc02705bf6e94f0b7458abc2962472429983b15258a444254b77a31254d0fdb2b565785ae8cdaac8bd493b1a68990a5a3d54f565563602d649d2bab80862
6
+ metadata.gz: 1b80d1dfeddbdef2b7a2d16042843776bfa536b8c17ad4cd18de0280d9691f0ed426c6d797706679f7c333a39cd6eff1d33dd9a0b438aec632724d6aa2327554
7
+ data.tar.gz: 243f5a694326265475f05cec03a84382d03ff64e5d33b559671c22d5744052631c255188f0bac5b0f2c72ac8de9bc66ac8f860ebb875fbbbeaf4caf0962d990f
data/.gitignore CHANGED
@@ -19,4 +19,5 @@ mkmf.log
19
19
  pkg
20
20
  Gemfile.lock
21
21
  build.sh
22
- .vscode/
22
+ .vscode/
23
+ .vagrant/
data/CHANGELOG.md CHANGED
@@ -68,4 +68,10 @@ FEATURES:
68
68
  ## 7.0.2 (May 22, 2018)
69
69
 
70
70
  BUG FIXES:
71
- - Fixed validation url
71
+ - Fixed validation url
72
+
73
+ ## 7.0.3 (May 30, 2018)
74
+
75
+ BUG FIXES:
76
+ - [hyperv, vmware_desktop] fixed delete virtual disk file after destroy VM
77
+ - user configuration validation
data/LICENSE ADDED
@@ -0,0 +1,201 @@
1
+ Apache License
2
+ Version 2.0, January 2004
3
+ http://www.apache.org/licenses/
4
+
5
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
6
+
7
+ 1. Definitions.
8
+
9
+ "License" shall mean the terms and conditions for use, reproduction,
10
+ and distribution as defined by Sections 1 through 9 of this document.
11
+
12
+ "Licensor" shall mean the copyright owner or entity authorized by
13
+ the copyright owner that is granting the License.
14
+
15
+ "Legal Entity" shall mean the union of the acting entity and all
16
+ other entities that control, are controlled by, or are under common
17
+ control with that entity. For the purposes of this definition,
18
+ "control" means (i) the power, direct or indirect, to cause the
19
+ direction or management of such entity, whether by contract or
20
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
21
+ outstanding shares, or (iii) beneficial ownership of such entity.
22
+
23
+ "You" (or "Your") shall mean an individual or Legal Entity
24
+ exercising permissions granted by this License.
25
+
26
+ "Source" form shall mean the preferred form for making modifications,
27
+ including but not limited to software source code, documentation
28
+ source, and configuration files.
29
+
30
+ "Object" form shall mean any form resulting from mechanical
31
+ transformation or translation of a Source form, including but
32
+ not limited to compiled object code, generated documentation,
33
+ and conversions to other media types.
34
+
35
+ "Work" shall mean the work of authorship, whether in Source or
36
+ Object form, made available under the License, as indicated by a
37
+ copyright notice that is included in or attached to the work
38
+ (an example is provided in the Appendix below).
39
+
40
+ "Derivative Works" shall mean any work, whether in Source or Object
41
+ form, that is based on (or derived from) the Work and for which the
42
+ editorial revisions, annotations, elaborations, or other modifications
43
+ represent, as a whole, an original work of authorship. For the purposes
44
+ of this License, Derivative Works shall not include works that remain
45
+ separable from, or merely link (or bind by name) to the interfaces of,
46
+ the Work and Derivative Works thereof.
47
+
48
+ "Contribution" shall mean any work of authorship, including
49
+ the original version of the Work and any modifications or additions
50
+ to that Work or Derivative Works thereof, that is intentionally
51
+ submitted to Licensor for inclusion in the Work by the copyright owner
52
+ or by an individual or Legal Entity authorized to submit on behalf of
53
+ the copyright owner. For the purposes of this definition, "submitted"
54
+ means any form of electronic, verbal, or written communication sent
55
+ to the Licensor or its representatives, including but not limited to
56
+ communication on electronic mailing lists, source code control systems,
57
+ and issue tracking systems that are managed by, or on behalf of, the
58
+ Licensor for the purpose of discussing and improving the Work, but
59
+ excluding communication that is conspicuously marked or otherwise
60
+ designated in writing by the copyright owner as "Not a Contribution."
61
+
62
+ "Contributor" shall mean Licensor and any individual or Legal Entity
63
+ on behalf of whom a Contribution has been received by Licensor and
64
+ subsequently incorporated within the Work.
65
+
66
+ 2. Grant of Copyright License. Subject to the terms and conditions of
67
+ this License, each Contributor hereby grants to You a perpetual,
68
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
69
+ copyright license to reproduce, prepare Derivative Works of,
70
+ publicly display, publicly perform, sublicense, and distribute the
71
+ Work and such Derivative Works in Source or Object form.
72
+
73
+ 3. Grant of Patent License. Subject to the terms and conditions of
74
+ this License, each Contributor hereby grants to You a perpetual,
75
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
76
+ (except as stated in this section) patent license to make, have made,
77
+ use, offer to sell, sell, import, and otherwise transfer the Work,
78
+ where such license applies only to those patent claims licensable
79
+ by such Contributor that are necessarily infringed by their
80
+ Contribution(s) alone or by combination of their Contribution(s)
81
+ with the Work to which such Contribution(s) was submitted. If You
82
+ institute patent litigation against any entity (including a
83
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
84
+ or a Contribution incorporated within the Work constitutes direct
85
+ or contributory patent infringement, then any patent licenses
86
+ granted to You under this License for that Work shall terminate
87
+ as of the date such litigation is filed.
88
+
89
+ 4. Redistribution. You may reproduce and distribute copies of the
90
+ Work or Derivative Works thereof in any medium, with or without
91
+ modifications, and in Source or Object form, provided that You
92
+ meet the following conditions:
93
+
94
+ (a) You must give any other recipients of the Work or
95
+ Derivative Works a copy of this License; and
96
+
97
+ (b) You must cause any modified files to carry prominent notices
98
+ stating that You changed the files; and
99
+
100
+ (c) You must retain, in the Source form of any Derivative Works
101
+ that You distribute, all copyright, patent, trademark, and
102
+ attribution notices from the Source form of the Work,
103
+ excluding those notices that do not pertain to any part of
104
+ the Derivative Works; and
105
+
106
+ (d) If the Work includes a "NOTICE" text file as part of its
107
+ distribution, then any Derivative Works that You distribute must
108
+ include a readable copy of the attribution notices contained
109
+ within such NOTICE file, excluding those notices that do not
110
+ pertain to any part of the Derivative Works, in at least one
111
+ of the following places: within a NOTICE text file distributed
112
+ as part of the Derivative Works; within the Source form or
113
+ documentation, if provided along with the Derivative Works; or,
114
+ within a display generated by the Derivative Works, if and
115
+ wherever such third-party notices normally appear. The contents
116
+ of the NOTICE file are for informational purposes only and
117
+ do not modify the License. You may add Your own attribution
118
+ notices within Derivative Works that You distribute, alongside
119
+ or as an addendum to the NOTICE text from the Work, provided
120
+ that such additional attribution notices cannot be construed
121
+ as modifying the License.
122
+
123
+ You may add Your own copyright statement to Your modifications and
124
+ may provide additional or different license terms and conditions
125
+ for use, reproduction, or distribution of Your modifications, or
126
+ for any such Derivative Works as a whole, provided Your use,
127
+ reproduction, and distribution of the Work otherwise complies with
128
+ the conditions stated in this License.
129
+
130
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
131
+ any Contribution intentionally submitted for inclusion in the Work
132
+ by You to the Licensor shall be under the terms and conditions of
133
+ this License, without any additional terms or conditions.
134
+ Notwithstanding the above, nothing herein shall supersede or modify
135
+ the terms of any separate license agreement you may have executed
136
+ with Licensor regarding such Contributions.
137
+
138
+ 6. Trademarks. This License does not grant permission to use the trade
139
+ names, trademarks, service marks, or product names of the Licensor,
140
+ except as required for reasonable and customary use in describing the
141
+ origin of the Work and reproducing the content of the NOTICE file.
142
+
143
+ 7. Disclaimer of Warranty. Unless required by applicable law or
144
+ agreed to in writing, Licensor provides the Work (and each
145
+ Contributor provides its Contributions) on an "AS IS" BASIS,
146
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
147
+ implied, including, without limitation, any warranties or conditions
148
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
149
+ PARTICULAR PURPOSE. You are solely responsible for determining the
150
+ appropriateness of using or redistributing the Work and assume any
151
+ risks associated with Your exercise of permissions under this License.
152
+
153
+ 8. Limitation of Liability. In no event and under no legal theory,
154
+ whether in tort (including negligence), contract, or otherwise,
155
+ unless required by applicable law (such as deliberate and grossly
156
+ negligent acts) or agreed to in writing, shall any Contributor be
157
+ liable to You for damages, including any direct, indirect, special,
158
+ incidental, or consequential damages of any character arising as a
159
+ result of this License or out of the use or inability to use the
160
+ Work (including but not limited to damages for loss of goodwill,
161
+ work stoppage, computer failure or malfunction, or any and all
162
+ other commercial damages or losses), even if such Contributor
163
+ has been advised of the possibility of such damages.
164
+
165
+ 9. Accepting Warranty or Additional Liability. While redistributing
166
+ the Work or Derivative Works thereof, You may choose to offer,
167
+ and charge a fee for, acceptance of support, warranty, indemnity,
168
+ or other liability obligations and/or rights consistent with this
169
+ License. However, in accepting such obligations, You may act only
170
+ on Your own behalf and on Your sole responsibility, not on behalf
171
+ of any other Contributor, and only if You agree to indemnify,
172
+ defend, and hold each Contributor harmless for any liability
173
+ incurred by, or claims asserted against, such Contributor by reason
174
+ of your accepting any such warranty or additional liability.
175
+
176
+ END OF TERMS AND CONDITIONS
177
+
178
+ APPENDIX: How to apply the Apache License to your work.
179
+
180
+ To apply the Apache License to your work, attach the following
181
+ boilerplate notice, with the fields enclosed by brackets "{}"
182
+ replaced with your own identifying information. (Don't include
183
+ the brackets!) The text should be enclosed in the appropriate
184
+ comment syntax for the file format. We also recommend that a
185
+ file or class name and description of purpose be included on the
186
+ same "printed page" as the copyright notice for easier
187
+ identification within third-party archives.
188
+
189
+ Copyright 2016 Subutai Social
190
+
191
+ Licensed under the Apache License, Version 2.0 (the "License");
192
+ you may not use this file except in compliance with the License.
193
+ You may obtain a copy of the License at
194
+
195
+ http://www.apache.org/licenses/LICENSE-2.0
196
+
197
+ Unless required by applicable law or agreed to in writing, software
198
+ distributed under the License is distributed on an "AS IS" BASIS,
199
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
200
+ See the License for the specific language governing permissions and
201
+ limitations under the License.
@@ -23,6 +23,7 @@ require 'vagrant-subutai/rest/bazaar'
23
23
  require 'vagrant-subutai/rest/gorjun'
24
24
  require 'vagrant-subutai/rest/subutai_console'
25
25
 
26
+ require 'vagrant-subutai/cleanup'
26
27
  require 'vagrant-subutai/command'
27
28
  require 'vagrant-subutai/config'
28
29
  require 'vagrant-subutai/create_disk'
@@ -0,0 +1,79 @@
1
+ require_relative '../vagrant-subutai'
2
+
3
+
4
+ module VagrantSubutai
5
+ class Cleanup < Vagrant.plugin(2, :provisioner)
6
+ attr_reader :machine
7
+ attr_reader :config
8
+
9
+ # Initializes the provisioner with the machine that it will be
10
+ # provisioning along with the provisioner configuration (if there
11
+ # is any).
12
+ #
13
+ # The provisioner should _not_ do anything at this point except
14
+ # initialize internal state.
15
+ #
16
+ # @param [Machine] machine The machine that this will be provisioning.
17
+ # @param [Object] config Provisioner configuration, if one was set.
18
+ def initialize(machine, config)
19
+ @machine = machine
20
+ @config = config
21
+ end
22
+
23
+ # Called with the root configuration of the machine so the provisioner
24
+ # can add some configuration on top of the machine.
25
+ #
26
+ # During this step, and this step only, the provisioner should modify
27
+ # the root machine configuration to add any additional features it
28
+ # may need. Examples include sharing folders, networking, and so on.
29
+ # This step is guaranteed to be called before any of those steps are
30
+ # done so the provisioner may do that.
31
+ #
32
+ # No return value is expected.
33
+ def configure(root_config)
34
+ end
35
+
36
+ # This is the method called when the actual provisioning should be
37
+ # done. The communicator is guaranteed to be ready at this point,
38
+ # and any shared folders or networks are already setup.
39
+ #
40
+ # No return value is expected.
41
+ def provision
42
+ end
43
+
44
+ # This is the method called when destroying a machine that allows
45
+ # for any state related to the machine created by the provisioner
46
+ # to be cleaned up.
47
+ def cleanup
48
+ case SubutaiConfig.provider
49
+ when :hyper_v
50
+ SubutaiDisk.hyperv_remove_disk
51
+ end
52
+
53
+ # cleanup virtual disks
54
+ disks = SubutaiConfig.get(:_DISK_PATHES)
55
+ unless disks.nil?
56
+ disks.keys.each do |key|
57
+ if File.exist?(disks[key])
58
+ begin
59
+ File.delete(disks[key])
60
+ puts " ==> Deleted file: #{disks[key]}"
61
+ rescue Errno::EACCES
62
+ puts " ==> (Permission denied) Failed delete file: #{disks[key]}"
63
+ end
64
+ end
65
+ end
66
+ end
67
+
68
+ # cleanup generated files
69
+ if File.exist?(SubutaiConfig::GENERATED_FILE)
70
+ begin
71
+ File.delete SubutaiConfig::GENERATED_FILE
72
+ puts " ==> Deleted file: #{SubutaiConfig::GENERATED_FILE}"
73
+ rescue Errno::EACCES
74
+ puts " ==> (Permission denied) Failed delete file: #{SubutaiConfig::GENERATED_FILE}"
75
+ end
76
+ end
77
+ end
78
+ end
79
+ end
@@ -46,6 +46,7 @@ module VagrantSubutai
46
46
  Put.warn "Disk size is growing by #{grow_by} gb."
47
47
  if has_grow
48
48
  if SubutaiDisk.hyperv_create_disk(grow_by, file_disk)
49
+ SubutaiDisk.save_path(SubutaiDisk.port, file_disk)
49
50
  SubutaiDisk.save_conf(grow_by)
50
51
  end
51
52
  end
@@ -0,0 +1,12 @@
1
+ param (
2
+ [string]$VmId = $(throw "-VmId is required.")
3
+ )
4
+
5
+ try {
6
+ $vm = Get-VM -Id $VmId -ErrorAction "stop"
7
+ Get-VMHardDiskDrive -VMName $vm.Name -ControllerType SCSI | Remove-VMHardDiskDrive
8
+ Stop-VM -Name $vm.Name -TurnOff
9
+ }
10
+ catch {
11
+ Write-Error-Message "Failed to remove virtual disk "
12
+ }
@@ -67,6 +67,7 @@ module SubutaiConfig
67
67
  _ALT_MANAGEMENT_MD5_LAST
68
68
  _DISK_SIZE
69
69
  _DISK_PORT
70
+ _DISK_PATHES
70
71
  ].freeze
71
72
 
72
73
  # Used for testing
@@ -75,6 +76,9 @@ module SubutaiConfig
75
76
  # Vagrant command currently being executed, must not be nil
76
77
  @cmd = nil
77
78
 
79
+ # Vagrant provider name
80
+ @provider = nil
81
+
78
82
  # Hash of generated/calculated settings preserved through commands
79
83
  @generated = {}
80
84
 
@@ -168,6 +172,10 @@ module SubutaiConfig
168
172
  @cmd
169
173
  end
170
174
 
175
+ def self.provider
176
+ @provider
177
+ end
178
+
171
179
  def self.config
172
180
  @config
173
181
  end
@@ -193,6 +201,11 @@ module SubutaiConfig
193
201
  def self.url_of_cdn
194
202
  @url_of_cdn
195
203
  end
204
+
205
+ def self.url_of_cdn=(cdn_url)
206
+ @url_of_cdn = cdn_url
207
+ end
208
+
196
209
  def self.override_conf_file(filepath)
197
210
  @conf_file_override = filepath
198
211
  end
@@ -269,7 +282,7 @@ module SubutaiConfig
269
282
  raise "Invalid key in YAML file: '#{key}'" \
270
283
  unless USER_PARAMETERS.include?(key.to_sym)
271
284
 
272
- SubutaiValidation.validate(key.to_sym, temp[key])
285
+ SubutaiValidation.validate(key.to_sym, temp[key]) unless delete?
273
286
  @config.store(key.to_sym, temp[key]) unless temp[key].nil?
274
287
  end
275
288
  end
@@ -324,10 +337,11 @@ module SubutaiConfig
324
337
  def self.load_config(cmd, provider)
325
338
  raise 'SubutaiConfig.cmd not set' if cmd.nil?
326
339
  @cmd = cmd
340
+ @provider = provider
327
341
 
328
342
  # Load YAML based user and local configuration if they exist
329
343
  load_config_file(USER_CONF_FILE) if File.exist?(USER_CONF_FILE)
330
- load_config_file(CONF_FILE) if File.exist?(CONF_FILE)
344
+ load_config_file(conf_file) if File.exist?(conf_file)
331
345
  load_generated
332
346
 
333
347
  # Load overrides from the environment, and generated configurations
@@ -340,14 +354,14 @@ module SubutaiConfig
340
354
 
341
355
  def self.reset
342
356
  @cmd = nil
357
+ @provider = nil
343
358
  @config = @defaults.clone
344
359
  @generated = {}
345
360
  @conf_file_override = nil
346
361
  end
347
362
 
348
- # Destroys the generated file if vagrant destroy is used
363
+
349
364
  def self.cleanup
350
- cleanup! if delete?
351
365
  end
352
366
 
353
367
  def self.cleanup!
@@ -411,13 +425,17 @@ module SubutaiConfig
411
425
  response[0]['id']
412
426
  when Net::HTTPNotFound
413
427
  Put.error "#{response.body} template name #{name}, owner #{owner}"
428
+ "" # send empty id. DON'T REMOVE
414
429
  end
415
430
  rescue Errno::ECONNREFUSED
416
431
  Put.error "cdn.subutai.io:8338 connection refused"
432
+ "" # send empty id. DON'T REMOVE
417
433
  rescue Errno::EHOSTUNREACH
418
434
  Put.error "cdn.subutai.io:8338 unreachable"
435
+ "" # send empty id. DON'T REMOVE
419
436
  rescue => e
420
437
  Put.error e
438
+ "" # send empty id. DON'T REMOVE
421
439
  end
422
440
  else
423
441
  "" # send empty id. DON'T REMOVE
@@ -5,11 +5,18 @@ require_relative '../../../lib/vagrant-subutai/util/powershell'
5
5
  module SubutaiDisk
6
6
  DISK_NAME = "SubutaiDisk".freeze
7
7
  DISK_FORMAT = "vdi".freeze
8
+
8
9
  DISK_FORMAT_VIRTUALBOX = "vdi".freeze
9
10
  DISK_FORMAT_VMWARE = "vmdk".freeze
10
11
  DISK_FORMAT_HYPERV = "vhdx".freeze
12
+ DISK_FORMAT_LIBVIRT = "qcow2".freeze
13
+
11
14
  PROVIDER_VMWARE = "vmware".freeze
12
15
  PROVIDER_HYPERV = "hyper_v".freeze
16
+ PROVIDER_LIBVIRT = "libvirt".freeze
17
+
18
+ SCRIPT_HYPERV_DISK_CREATE_PATH = 'script/create_disk_and_attach.ps1'.freeze
19
+ SCRIPT_HYPERV_DISK_REMOVE_PATH = 'script/remove_virtual_disk.ps1'.freeze
13
20
 
14
21
  # Checks disk size for adding new VM disks
15
22
  def self.has_grow
@@ -24,6 +31,21 @@ module SubutaiDisk
24
31
  end
25
32
  end
26
33
 
34
+ # Save disk pathes. We saves for cleanup while destroying peer
35
+ def self.save_path(port, file_path)
36
+ if SubutaiConfig.get(:_DISK_PATHES).nil?
37
+ hash = {}
38
+ hash[port] = file_path
39
+ SubutaiConfig.put(:_DISK_PATHES, hash, true)
40
+ true
41
+ else
42
+ hash = SubutaiConfig.get(:_DISK_PATHES)
43
+ hash[port] = file_path
44
+ SubutaiConfig.put(:_DISK_PATHES, hash, true)
45
+ true
46
+ end
47
+ end
48
+
27
49
  # Gives disk port
28
50
  def self.port
29
51
  port = SubutaiConfig.get(:_DISK_PORT)
@@ -60,16 +82,29 @@ module SubutaiDisk
60
82
  end
61
83
 
62
84
  def self.hyperv_create_disk(grow_by, file_disk)
63
- script = File.join(File.expand_path(File.dirname(__FILE__)), 'script/create_disk_and_attach.ps1')
85
+ script = File.join(File.expand_path(File.dirname(__FILE__)), SCRIPT_HYPERV_DISK_CREATE_PATH)
64
86
  id = SubutaiConfig.machine_id(:hyper_v)
65
87
 
66
88
  if id.nil?
67
- Put.error("Not found machine id")
89
+ Put.error(" => [FAILED] Disk Creation. Not found machine id")
90
+ false
68
91
  else
69
92
  VagrantSubutai::Util::Powershell.execute(script, "-VmId", id, "-DiskPath", file_disk, "-DiskSize", "#{vmware_size(grow_by)}")
70
93
  end
71
94
  end
72
95
 
96
+ def self.hyperv_remove_disk
97
+ script = File.join(File.expand_path(File.dirname(__FILE__)), SCRIPT_HYPERV_DISK_REMOVE_PATH)
98
+ id = SubutaiConfig.machine_id(:hyper_v)
99
+
100
+ if id.nil?
101
+ Put.error(" => [FAILED] Remove virtual disk. Not found machine id")
102
+ false
103
+ else
104
+ VagrantSubutai::Util::Powershell.execute(script, "-VmId", id)
105
+ end
106
+ end
107
+
73
108
  # Save disk size and port to generated.yml
74
109
  def self.save_conf(grow_by)
75
110
  SubutaiConfig.put(:_DISK_PORT, port, true)
@@ -77,8 +112,10 @@ module SubutaiDisk
77
112
  generated_disk = SubutaiConfig.get(:_DISK_SIZE)
78
113
  if generated_disk.nil?
79
114
  SubutaiConfig.put(:_DISK_SIZE, grow_by, true) # we set all size of virtual disks to _DISK_SIZE in unit gb
115
+ true
80
116
  else
81
117
  SubutaiConfig.put(:_DISK_SIZE, grow_by + generated_disk.to_i, true) # we set all size of virtual disks to _DISK_SIZE in unit gb
118
+ true
82
119
  end
83
120
  end
84
121
 
@@ -92,19 +129,7 @@ module SubutaiDisk
92
129
  if SubutaiConfig.get(:SUBUTAI_DISK_PATH).nil?
93
130
  "./#{DISK_NAME}-#{disk_port.to_i}-#{grow_by}.#{DISK_FORMAT}"
94
131
  else
95
- # Check is directory exist
96
- if File.directory?(SubutaiConfig.get(:SUBUTAI_DISK_PATH).to_s)
97
- # check permission
98
- if File.writable?(SubutaiConfig.get(:SUBUTAI_DISK_PATH).to_s)
99
- File.join(SubutaiConfig.get(:SUBUTAI_DISK_PATH).to_s, "#{DISK_NAME}-#{disk_port.to_i}-#{grow_by}.#{DISK_FORMAT}")
100
- else
101
- Put.warn "No write permission: #{SubutaiConfig.get(:SUBUTAI_DISK_PATH)}"
102
- "./#{DISK_NAME}-#{disk_port.to_i}-#{grow_by}.#{DISK_FORMAT}"
103
- end
104
- else
105
- Put.warn "Invalid path: #{SubutaiConfig.get(:SUBUTAI_DISK_PATH)}"
106
- "./#{DISK_NAME}-#{disk_port.to_i}-#{grow_by}.#{DISK_FORMAT}"
107
- end
132
+ File.join(SubutaiConfig.get(:SUBUTAI_DISK_PATH).to_s, "#{DISK_NAME}-#{disk_port.to_i}-#{grow_by}.#{DISK_FORMAT}")
108
133
  end
109
134
  end
110
135
 
@@ -117,39 +142,15 @@ module SubutaiDisk
117
142
  disk_format = DISK_FORMAT_VMWARE
118
143
  when PROVIDER_HYPERV
119
144
  disk_format = DISK_FORMAT_HYPERV
145
+ when PROVIDER_LIBVIRT
146
+ disk_format = DISK_FORMAT_LIBVIRT
120
147
  end
121
148
 
122
149
  # get disk path from conf file
123
150
  if SubutaiConfig.get(:SUBUTAI_DISK_PATH).nil?
124
- File.join(Dir.pwd, "#{DISK_NAME}-#{disk_port.to_i}-#{grow_by}.#{disk_format}")
125
- else
126
- # Check is directory exist
127
- if File.directory?(SubutaiConfig.get(:SUBUTAI_DISK_PATH).to_s)
128
- # check permission
129
- if File.writable?(SubutaiConfig.get(:SUBUTAI_DISK_PATH).to_s)
130
- File.join(SubutaiConfig.get(:SUBUTAI_DISK_PATH).to_s, "#{DISK_NAME}-#{disk_port.to_i}-#{grow_by}.#{disk_format}")
131
- else
132
- Put.warn "No write permission: #{SubutaiConfig.get(:SUBUTAI_DISK_PATH)}"
133
- File.join(Dir.pwd, "#{DISK_NAME}-#{disk_port.to_i}-#{grow_by}.#{disk_format}")
134
- end
135
- else
136
- Put.warn "Invalid path: #{SubutaiConfig.get(:SUBUTAI_DISK_PATH)}"
137
- File.join(Dir.pwd, "#{DISK_NAME}-#{disk_port.to_i}-#{grow_by}.#{disk_format}")
138
- end
139
- end
140
- end
141
-
142
- def self.path
143
- if File.directory?(SubutaiConfig.get(:SUBUTAI_DISK_PATH).to_s)
144
- # check permission
145
- if File.writable?(SubutaiConfig.get(:SUBUTAI_DISK_PATH).to_s)
146
- File.join(SubutaiConfig.get(:SUBUTAI_DISK_PATH).to_s)
147
- else
148
- Put.warn "No write permission: #{SubutaiConfig.get(:SUBUTAI_DISK_PATH)}"
149
- nil
150
- end
151
+ File.expand_path "#{DISK_NAME}-#{disk_port.to_i}-#{grow_by}.#{disk_format}"
151
152
  else
152
- nil
153
+ File.join(SubutaiConfig.get(:SUBUTAI_DISK_PATH).to_s, "#{DISK_NAME}-#{disk_port.to_i}-#{grow_by}.#{disk_format}")
153
154
  end
154
155
  end
155
156
  end