diskid 0.2.1 → 0.2.2

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.
Files changed (4) hide show
  1. data/bin/diskid +32 -23
  2. data/bin/diskid-ws +1 -1
  3. data/lib/diskid.rb +37 -5
  4. metadata +19 -19
data/bin/diskid CHANGED
@@ -7,6 +7,7 @@ require 'diskid'
7
7
 
8
8
  class DiskIDCommand < Clamp::Command
9
9
  parameter 'FILE', "Disk file", :attribute_name => 'file'
10
+ option '--local', :flag, "Try to identify the disk using a local qemu-img binary"
10
11
  option '--server-port', "PORT", "DiskID service port", :default => '80'
11
12
  option '--server-host', "HOST", "DiskID service host", :default => 'diskid.frameos.org'
12
13
  option '--format', "FORMAT", "Disk info output format (text, json, xml)", :default => 'text'
@@ -21,33 +22,41 @@ class DiskIDCommand < Clamp::Command
21
22
  puts "Supported formats: vvfat vpc vmdk vdi sheepdog raw host_cdrom host_floppy host_device file qed qcow2 qcow parallels nbd dmg tftp ftps ftp https http cow cloop bochs blkverify blkdebug"
22
23
  exit 1
23
24
  end
25
+
26
+ # Use local qemu-img to identify the disk
27
+ if local?
28
+ di = DiskID::Inspector.new(file, 'qemu-img').identify
29
+ begin
30
+ puts di.send "to_#{format}"
31
+ rescue NoMethodError
32
+ $stderr.puts "Invalid format."
33
+ end
34
+ else
35
+ begin
36
+ RestClient.get "http://#{server_host}:#{server_port}/service-check"
37
+ rescue => e
38
+ $stderr.puts "Couldn't reach http://#{server_host}."
39
+ exit 1
40
+ end
24
41
 
25
- puts "\n#{server_host}\n\n"
42
+ fsize = File.size(file).bytes.to.megabytes.to_f.round
43
+ unit = 'M'
44
+ if fsize > 1024
45
+ fsize = fsize.megabytes.to.gigabytes.to_f.round
46
+ unit = 'G'
47
+ end
26
48
 
27
- begin
28
- RestClient.get "http://#{server_host}:#{server_port}/service-check"
29
- rescue => e
30
- $stderr.puts "Couldn't reach http://#{server_host}."
31
- exit 1
32
- end
49
+ fsize = "#{fsize}#{unit}"
33
50
 
34
- fsize = File.size(file).bytes.to.megabytes.to_f.round
35
- unit = 'M'
36
- if fsize > 1024
37
- fsize = fsize.megabytes.to.gigabytes.to_f.round
38
- unit = 'G'
51
+ #out = `head -n 20 #{file}|curl -s -X POST -F client_version=#{DiskID::VERSION} -F chunk=@- -F file_size=#{fsize} -F file_name=#{File.basename(file)} http://#{server_host}:#{server_port}/?format=#{format} 2>&1`
52
+ out = RestClient.post "http://#{server_host}:#{server_port}/",
53
+ :chunk => File.read(file, 20000),
54
+ :client_version => DiskID::VERSION,
55
+ :file_size => fsize,
56
+ :file_name => File.basename(file),
57
+ :format => format
58
+ puts out
39
59
  end
40
-
41
- fsize = "#{fsize}#{unit}"
42
-
43
- #out = `head -n 20 #{file}|curl -s -X POST -F client_version=#{DiskID::VERSION} -F chunk=@- -F file_size=#{fsize} -F file_name=#{File.basename(file)} http://#{server_host}:#{server_port}/?format=#{format} 2>&1`
44
- out = RestClient.post "http://#{server_host}:#{server_port}/",
45
- :chunk => File.read(file, 20000),
46
- :client_version => DiskID::VERSION,
47
- :file_size => fsize,
48
- :file_name => File.basename(file),
49
- :format => format
50
- puts out
51
60
  end
52
61
  end
53
62
 
@@ -49,7 +49,7 @@ class DiskIDWS < Sinatra::Base
49
49
  file_size = params[:file_size] || ''
50
50
  begin
51
51
  inspector = DiskID::Inspector.new(tmpfile.path)
52
- di = inspector.inspect
52
+ di = inspector.identify
53
53
  di.file_name = file_name
54
54
  di.disk_size = file_size
55
55
  if params[:format] == 'json'
@@ -2,11 +2,12 @@ module DiskID
2
2
 
3
3
  require 'json'
4
4
 
5
- VERSION = "0.2.1"
5
+ VERSION = "0.2.2"
6
6
 
7
7
  class DiskInfo
8
8
 
9
9
  attr_accessor :file_name, :format, :virtual_size, :disk_size
10
+ attr_accessor :variant
10
11
 
11
12
  def initialize(params)
12
13
  @hash = params
@@ -14,6 +15,7 @@ module DiskID
14
15
  @format = @hash['format']
15
16
  @virtual_size = @hash['virtual_size']
16
17
  @disk_size = @hash['disk_size']
18
+ @variant = @hash['variant']
17
19
  end
18
20
 
19
21
  def to_json
@@ -25,19 +27,31 @@ module DiskID
25
27
  buf << "<disk_info>"
26
28
  buf << "<file_name>#{@file_name}</file_name>"
27
29
  buf << "<format>#{@format}</format>"
30
+ buf << "<variant>#{@variant}</variant>" if not @variant.empty?
28
31
  buf << "<virtual_size>#{@virtual_size}</virtual_size>"
29
32
  buf << "<disk_size>#{@disk_size}</disk_size>"
30
33
  buf << "</disk_info>"
31
34
  buf
32
35
  end
33
36
 
37
+ def to_text
38
+ t = ""
39
+ t << "file_name: #{@file_name}\n"
40
+ t << "format: #{@format}\n"
41
+ t << "variant: #{@variant}\n" if not @variant.empty?
42
+ t << "virtual_size: #{@virtual_size}\n"
43
+ t << "disk_size: #{@disk_size}\n"
44
+ end
45
+
34
46
  def to_hash
35
- {
47
+ h = {
36
48
  'file_name' => @file_name,
37
49
  'format' => @format,
38
50
  'virtual_size' => @virtual_size,
39
51
  'disk_size' => @disk_size
40
52
  }
53
+ h['variant'] = @variant if not @variant.empty?
54
+ h
41
55
  end
42
56
 
43
57
  end
@@ -46,25 +60,43 @@ module DiskID
46
60
 
47
61
 
48
62
  def initialize(file, qemu_img_bin='qemu-img-bleeding')
49
- @qemu_img_bin = qemu_img_bin
63
+ @qemu_img_bin = (qemu_img_bin || '').strip.chomp
64
+ if not @qemu_img_bin =~ /^\//
65
+ @qemu_img_bin = `sh -c 'command -v #{@qemu_img_bin}'`.strip.chomp
66
+ end
67
+ raise ArgumentError.new("qemu-img command not found: #{@qemu_img_bin}") if @qemu_img_bin.empty?
68
+
50
69
  @file = file
51
70
  end
52
71
 
53
- def inspect
72
+ def identify
54
73
  out = `#{@qemu_img_bin} info #{@file}`
55
74
  raise Exception.new("Error getting info from #{@file}") if $? != 0
56
75
 
57
76
  md = /image:(.*)$\nfile format:(.*)$\nvirtual size:(.*)$\ndisk size:(.*)\n/.match out
58
77
  @file_name,@format,@virtual_size,@disk_size = [md[1], md[2], md[3], md[4]].map { |e| e.strip.chomp }
59
78
  @virtual_size = @virtual_size.split()[0]
79
+ variant = ''
80
+ if @format == 'vmdk'
81
+ variant = read_variant @file
82
+ end
60
83
  DiskInfo.new({
61
84
  'file_name' => @file_name,
62
85
  'format' => @format,
63
86
  'virtual_size' => @virtual_size,
64
- 'disk_size' => @disk_size
87
+ 'disk_size' => @disk_size,
88
+ 'variant' => variant
65
89
  })
66
90
  end
67
91
 
92
+ private
93
+ def read_variant(file)
94
+ IO.read(file, 20000).each_line do |l|
95
+ return $1 if l =~ /createType="(.*?)"/
96
+ end
97
+ ''
98
+ end
68
99
 
69
100
  end
101
+
70
102
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: diskid
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.2.1
4
+ version: 0.2.2
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -13,7 +13,7 @@ date: 2011-10-31 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: shoulda
16
- requirement: &9209720 !ruby/object:Gem::Requirement
16
+ requirement: &24178460 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ! '>='
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: '0'
22
22
  type: :development
23
23
  prerelease: false
24
- version_requirements: *9209720
24
+ version_requirements: *24178460
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: bundler
27
- requirement: &9209020 !ruby/object:Gem::Requirement
27
+ requirement: &24177980 !ruby/object:Gem::Requirement
28
28
  none: false
29
29
  requirements:
30
30
  - - ~>
@@ -32,10 +32,10 @@ dependencies:
32
32
  version: 1.0.0
33
33
  type: :development
34
34
  prerelease: false
35
- version_requirements: *9209020
35
+ version_requirements: *24177980
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: jeweler
38
- requirement: &9208280 !ruby/object:Gem::Requirement
38
+ requirement: &24177440 !ruby/object:Gem::Requirement
39
39
  none: false
40
40
  requirements:
41
41
  - - ~>
@@ -43,10 +43,10 @@ dependencies:
43
43
  version: 1.6.4
44
44
  type: :development
45
45
  prerelease: false
46
- version_requirements: *9208280
46
+ version_requirements: *24177440
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: rcov
49
- requirement: &9207580 !ruby/object:Gem::Requirement
49
+ requirement: &24176940 !ruby/object:Gem::Requirement
50
50
  none: false
51
51
  requirements:
52
52
  - - ! '>='
@@ -54,10 +54,10 @@ dependencies:
54
54
  version: '0'
55
55
  type: :development
56
56
  prerelease: false
57
- version_requirements: *9207580
57
+ version_requirements: *24176940
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: sinatra
60
- requirement: &9206800 !ruby/object:Gem::Requirement
60
+ requirement: &24176380 !ruby/object:Gem::Requirement
61
61
  none: false
62
62
  requirements:
63
63
  - - ! '>='
@@ -65,10 +65,10 @@ dependencies:
65
65
  version: '0'
66
66
  type: :runtime
67
67
  prerelease: false
68
- version_requirements: *9206800
68
+ version_requirements: *24176380
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: clamp
71
- requirement: &9206260 !ruby/object:Gem::Requirement
71
+ requirement: &23667400 !ruby/object:Gem::Requirement
72
72
  none: false
73
73
  requirements:
74
74
  - - ! '>='
@@ -76,10 +76,10 @@ dependencies:
76
76
  version: '0'
77
77
  type: :runtime
78
78
  prerelease: false
79
- version_requirements: *9206260
79
+ version_requirements: *23667400
80
80
  - !ruby/object:Gem::Dependency
81
81
  name: alchemist
82
- requirement: &9205780 !ruby/object:Gem::Requirement
82
+ requirement: &23666820 !ruby/object:Gem::Requirement
83
83
  none: false
84
84
  requirements:
85
85
  - - ! '>='
@@ -87,10 +87,10 @@ dependencies:
87
87
  version: '0'
88
88
  type: :runtime
89
89
  prerelease: false
90
- version_requirements: *9205780
90
+ version_requirements: *23666820
91
91
  - !ruby/object:Gem::Dependency
92
92
  name: rest-client
93
- requirement: &9205280 !ruby/object:Gem::Requirement
93
+ requirement: &23666320 !ruby/object:Gem::Requirement
94
94
  none: false
95
95
  requirements:
96
96
  - - ! '>='
@@ -98,10 +98,10 @@ dependencies:
98
98
  version: '0'
99
99
  type: :runtime
100
100
  prerelease: false
101
- version_requirements: *9205280
101
+ version_requirements: *23666320
102
102
  - !ruby/object:Gem::Dependency
103
103
  name: json
104
- requirement: &9204800 !ruby/object:Gem::Requirement
104
+ requirement: &23665840 !ruby/object:Gem::Requirement
105
105
  none: false
106
106
  requirements:
107
107
  - - ! '>='
@@ -109,7 +109,7 @@ dependencies:
109
109
  version: '0'
110
110
  type: :runtime
111
111
  prerelease: false
112
- version_requirements: *9204800
112
+ version_requirements: *23665840
113
113
  description: Virtual Disk Identification Service
114
114
  email: rubiojr@frameos.org
115
115
  executables: