manageiq-smartstate 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +15 -0
- data/.rspec +4 -0
- data/.rspec_ci +4 -0
- data/.travis.yml +15 -0
- data/Gemfile +9 -0
- data/LICENSE.txt +202 -0
- data/README.md +45 -0
- data/Rakefile +23 -0
- data/bin/console +14 -0
- data/bin/setup +8 -0
- data/lib/MiqContainerGroup/MiqContainerGroup.rb +31 -0
- data/lib/MiqVm/MiqLocalVm.rb +50 -0
- data/lib/MiqVm/MiqRhevmVm.rb +179 -0
- data/lib/MiqVm/MiqVm.rb +355 -0
- data/lib/MiqVm/miq_azure_vm.rb +96 -0
- data/lib/MiqVm/miq_scvmm_vm.rb +38 -0
- data/lib/MiqVm/test/camcorder_fleece_test.rb +60 -0
- data/lib/MiqVm/test/localVm.rb +45 -0
- data/lib/MiqVm/test/partitionAlignmentCheck.rb +76 -0
- data/lib/MiqVm/test/remoteVm.rb +65 -0
- data/lib/MiqVm/test/rhevmNfsTest.rb +62 -0
- data/lib/MiqVm/test/rhevmNfsTest2.rb +66 -0
- data/lib/MiqVm/test/rhevmTest.rb +70 -0
- data/lib/OpenStackExtract/MiqOpenStackVm/MiqOpenStackCommon.rb +107 -0
- data/lib/OpenStackExtract/MiqOpenStackVm/MiqOpenStackImage.rb +67 -0
- data/lib/OpenStackExtract/MiqOpenStackVm/MiqOpenStackInstance.rb +182 -0
- data/lib/Scvmm/miq_hyperv_disk.rb +273 -0
- data/lib/Scvmm/miq_scvmm_parse_powershell.rb +75 -0
- data/lib/Scvmm/miq_scvmm_vm_ssa_info.rb +135 -0
- data/lib/Scvmm/test/miq_hyperv_disk_test.rb +33 -0
- data/lib/Scvmm/test/miq_scvmm_vm_ssa_info_test.rb +41 -0
- data/lib/VmLocalDiskAccess/test/localCfg.rb +97 -0
- data/lib/VolumeManager/LVM/logical_volume.rb +75 -0
- data/lib/VolumeManager/LVM/lv_segment.rb +43 -0
- data/lib/VolumeManager/LVM/lvm2disk.rb +158 -0
- data/lib/VolumeManager/LVM/parser.rb +138 -0
- data/lib/VolumeManager/LVM/physical_volume.rb +19 -0
- data/lib/VolumeManager/LVM/scanner.rb +156 -0
- data/lib/VolumeManager/LVM/thin/btree.rb +83 -0
- data/lib/VolumeManager/LVM/thin/constants.rb +86 -0
- data/lib/VolumeManager/LVM/thin/data_map.rb +44 -0
- data/lib/VolumeManager/LVM/thin/mapping_tree.rb +19 -0
- data/lib/VolumeManager/LVM/thin/space_maps.rb +58 -0
- data/lib/VolumeManager/LVM/thin/superblock.rb +136 -0
- data/lib/VolumeManager/LVM/thin.rb +6 -0
- data/lib/VolumeManager/LVM/volume_group.rb +97 -0
- data/lib/VolumeManager/LVM.rb +8 -0
- data/lib/VolumeManager/MiqLdm.rb +546 -0
- data/lib/VolumeManager/MiqLvm.rb +17 -0
- data/lib/VolumeManager/MiqNativeVolumeManager.rb +150 -0
- data/lib/VolumeManager/MiqVolumeManager.rb +277 -0
- data/lib/VolumeManager/VolMgrPlatformSupport.rb +18 -0
- data/lib/VolumeManager/VolMgrPlatformSupportLinux.rb +77 -0
- data/lib/VolumeManager/VolMgrPlatformSupportWin.rb +17 -0
- data/lib/VolumeManager/test/blockDevTest.rb +40 -0
- data/lib/VolumeManager/test/ldm.rb +97 -0
- data/lib/blackbox/VmBlackBox.rb +103 -0
- data/lib/blackbox/xmlStorage.rb +180 -0
- data/lib/db/MiqBdb/MiqBdb.rb +309 -0
- data/lib/db/MiqBdb/MiqBdbBtree.rb +219 -0
- data/lib/db/MiqBdb/MiqBdbHash.rb +199 -0
- data/lib/db/MiqBdb/MiqBdbPage.rb +159 -0
- data/lib/db/MiqBdb/MiqBdbUtil.rb +18 -0
- data/lib/db/MiqSqlite/MiqSqlite3.rb +330 -0
- data/lib/db/MiqSqlite/MiqSqlite3Cell.rb +167 -0
- data/lib/db/MiqSqlite/MiqSqlite3Page.rb +151 -0
- data/lib/db/MiqSqlite/MiqSqlite3Table.rb +124 -0
- data/lib/db/MiqSqlite/MiqSqlite3Util.rb +32 -0
- data/lib/disk/DiskProbe.rb +68 -0
- data/lib/disk/MiqDisk.rb +317 -0
- data/lib/disk/camcorder_test.rb +90 -0
- data/lib/disk/dos_mbr.img +0 -0
- data/lib/disk/modules/AzureBlobDisk.rb +101 -0
- data/lib/disk/modules/LocalDevMod.rb +47 -0
- data/lib/disk/modules/LocalDevProbe.rb +6 -0
- data/lib/disk/modules/MSCommon.rb +352 -0
- data/lib/disk/modules/MSVSDiffDisk.rb +91 -0
- data/lib/disk/modules/MSVSDiskProbe.rb +61 -0
- data/lib/disk/modules/MSVSDynamicDisk.rb +42 -0
- data/lib/disk/modules/MSVSFixedDisk.rb +45 -0
- data/lib/disk/modules/MiqLargeFile.rb +63 -0
- data/lib/disk/modules/MiqLargeFileWin32.rb +107 -0
- data/lib/disk/modules/QcowDisk.rb +692 -0
- data/lib/disk/modules/QcowDiskProbe.rb +34 -0
- data/lib/disk/modules/RawBlockIO.rb +116 -0
- data/lib/disk/modules/RawDisk.rb +45 -0
- data/lib/disk/modules/RawDiskProbe.rb +7 -0
- data/lib/disk/modules/RhevmDescriptor.rb +167 -0
- data/lib/disk/modules/RhevmDiskProbe.rb +52 -0
- data/lib/disk/modules/VMWareCowdDisk.rb +207 -0
- data/lib/disk/modules/VMWareDescriptor.rb +214 -0
- data/lib/disk/modules/VMWareDiskProbe.rb +74 -0
- data/lib/disk/modules/VMWareSparseDisk.rb +189 -0
- data/lib/disk/modules/VhdxDisk.rb +625 -0
- data/lib/disk/modules/VhdxDiskProbe.rb +46 -0
- data/lib/disk/modules/VixDiskMod.rb +54 -0
- data/lib/disk/modules/VixDiskProbe.rb +6 -0
- data/lib/disk/modules/miq_disk_cache.rb +135 -0
- data/lib/disk/modules/miq_dummy_disk.rb +41 -0
- data/lib/disk/modules/vhdx_bat_entry.rb +10 -0
- data/lib/disk/test.rb +66 -0
- data/lib/fs/MetakitFS/MetakitFS.rb +530 -0
- data/lib/fs/MetakitFS/test/Makefile +14 -0
- data/lib/fs/MetakitFS/test/MkCollectFiles.rb +165 -0
- data/lib/fs/MetakitFS/test/MkSelectFiles.rb +30 -0
- data/lib/fs/MetakitFS/test/collect_files.yaml +70 -0
- data/lib/fs/MetakitFS/test/init.rb +3 -0
- data/lib/fs/MetakitFS/test/mk2vmdk.rb +64 -0
- data/lib/fs/MetakitFS/test/mk4test.c +92 -0
- data/lib/fs/MetakitFS/test/mkFsTest.rb +113 -0
- data/lib/fs/MetakitFS/test/proto.rb +97 -0
- data/lib/fs/MiqFS/FsProbe.rb +39 -0
- data/lib/fs/MiqFS/MiqFS.rb +515 -0
- data/lib/fs/MiqFS/modules/AUFSProbe.rb +26 -0
- data/lib/fs/MiqFS/modules/Ext3.rb +305 -0
- data/lib/fs/MiqFS/modules/Ext3Probe.rb +25 -0
- data/lib/fs/MiqFS/modules/Ext4.rb +304 -0
- data/lib/fs/MiqFS/modules/Ext4Probe.rb +25 -0
- data/lib/fs/MiqFS/modules/Fat32.rb +318 -0
- data/lib/fs/MiqFS/modules/Fat32Probe.rb +30 -0
- data/lib/fs/MiqFS/modules/HFSProbe.rb +18 -0
- data/lib/fs/MiqFS/modules/Iso9660.rb +293 -0
- data/lib/fs/MiqFS/modules/Iso9660Probe.rb +18 -0
- data/lib/fs/MiqFS/modules/LocalFS.rb +105 -0
- data/lib/fs/MiqFS/modules/NTFS.rb +287 -0
- data/lib/fs/MiqFS/modules/NTFSProbe.rb +21 -0
- data/lib/fs/MiqFS/modules/NativeFS.rb +155 -0
- data/lib/fs/MiqFS/modules/ReFSProbe.rb +17 -0
- data/lib/fs/MiqFS/modules/RealFS.rb +79 -0
- data/lib/fs/MiqFS/modules/RealFSProbe.rb +6 -0
- data/lib/fs/MiqFS/modules/Reiser4Probe.rb +18 -0
- data/lib/fs/MiqFS/modules/ReiserFS.rb +315 -0
- data/lib/fs/MiqFS/modules/ReiserFSProbe.rb +42 -0
- data/lib/fs/MiqFS/modules/UnionFSProbe.rb +18 -0
- data/lib/fs/MiqFS/modules/WebDAV.rb +127 -0
- data/lib/fs/MiqFS/modules/WebDAVFile.rb +68 -0
- data/lib/fs/MiqFS/modules/XFS.rb +300 -0
- data/lib/fs/MiqFS/modules/XFSProbe.rb +26 -0
- data/lib/fs/MiqFS/modules/ZFSProbe.rb +18 -0
- data/lib/fs/MiqFS/test.rb +59 -0
- data/lib/fs/MiqFsUtil.rb +383 -0
- data/lib/fs/MiqMountManager.rb +209 -0
- data/lib/fs/MiqNativeMountManager.rb +101 -0
- data/lib/fs/MountManagerProbe.rb +29 -0
- data/lib/fs/ReiserFS/block.rb +209 -0
- data/lib/fs/ReiserFS/directory.rb +136 -0
- data/lib/fs/ReiserFS/directory_entry.rb +140 -0
- data/lib/fs/ReiserFS/file_data.rb +111 -0
- data/lib/fs/ReiserFS/superblock.rb +140 -0
- data/lib/fs/ReiserFS/utils.rb +95 -0
- data/lib/fs/VimDatastoreFS/VimDatastoreFS.rb +192 -0
- data/lib/fs/ext3/alloc_bitmap.rb +38 -0
- data/lib/fs/ext3/block_pointers_path.rb +130 -0
- data/lib/fs/ext3/directory.rb +51 -0
- data/lib/fs/ext3/directory_entry.rb +67 -0
- data/lib/fs/ext3/ex_attrib_header.rb +14 -0
- data/lib/fs/ext3/ex_attrib_name.rb +23 -0
- data/lib/fs/ext3/file_data.rb +130 -0
- data/lib/fs/ext3/group_descriptor_entry.rb +65 -0
- data/lib/fs/ext3/group_descriptor_table.rb +54 -0
- data/lib/fs/ext3/hash_tree_entry.rb +18 -0
- data/lib/fs/ext3/hash_tree_header.rb +15 -0
- data/lib/fs/ext3/inode.rb +228 -0
- data/lib/fs/ext3/posix_acl_entry.rb +29 -0
- data/lib/fs/ext3/posix_acl_header.rb +11 -0
- data/lib/fs/ext3/superblock.rb +406 -0
- data/lib/fs/ext3/test/tc_Ext3BlockPointersPath.rb +74 -0
- data/lib/fs/ext4/alloc_bitmap.rb +38 -0
- data/lib/fs/ext4/directory.rb +87 -0
- data/lib/fs/ext4/directory_entry.rb +77 -0
- data/lib/fs/ext4/ex_attrib_header.rb +14 -0
- data/lib/fs/ext4/ex_attrib_name.rb +23 -0
- data/lib/fs/ext4/extent.rb +35 -0
- data/lib/fs/ext4/extent_header.rb +40 -0
- data/lib/fs/ext4/extent_index.rb +33 -0
- data/lib/fs/ext4/group_descriptor_entry.rb +69 -0
- data/lib/fs/ext4/group_descriptor_table.rb +54 -0
- data/lib/fs/ext4/hash_tree_entry.rb +58 -0
- data/lib/fs/ext4/hash_tree_header.rb +35 -0
- data/lib/fs/ext4/inode.rb +465 -0
- data/lib/fs/ext4/posix_acl_entry.rb +29 -0
- data/lib/fs/ext4/posix_acl_header.rb +11 -0
- data/lib/fs/ext4/superblock.rb +412 -0
- data/lib/fs/fat32/boot_sect.rb +379 -0
- data/lib/fs/fat32/directory.rb +222 -0
- data/lib/fs/fat32/directory_entry.rb +540 -0
- data/lib/fs/fat32/file_data.rb +128 -0
- data/lib/fs/iso9660/boot_sector.rb +170 -0
- data/lib/fs/iso9660/directory.rb +90 -0
- data/lib/fs/iso9660/directory_entry.rb +147 -0
- data/lib/fs/iso9660/file_data.rb +78 -0
- data/lib/fs/iso9660/rock_ridge.rb +329 -0
- data/lib/fs/iso9660/util.rb +57 -0
- data/lib/fs/modules/LinuxMount.rb +300 -0
- data/lib/fs/modules/LinuxMountProbe.rb +29 -0
- data/lib/fs/modules/WinMount.rb +97 -0
- data/lib/fs/modules/WinMountProbe.rb +24 -0
- data/lib/fs/ntfs/attrib_attribute_list.rb +131 -0
- data/lib/fs/ntfs/attrib_bitmap.rb +26 -0
- data/lib/fs/ntfs/attrib_data.rb +74 -0
- data/lib/fs/ntfs/attrib_file_name.rb +110 -0
- data/lib/fs/ntfs/attrib_header.rb +194 -0
- data/lib/fs/ntfs/attrib_index_allocation.rb +19 -0
- data/lib/fs/ntfs/attrib_index_root.rb +247 -0
- data/lib/fs/ntfs/attrib_object_id.rb +40 -0
- data/lib/fs/ntfs/attrib_standard_information.rb +107 -0
- data/lib/fs/ntfs/attrib_type.rb +49 -0
- data/lib/fs/ntfs/attrib_volume_information.rb +53 -0
- data/lib/fs/ntfs/attrib_volume_name.rb +31 -0
- data/lib/fs/ntfs/boot_sect.rb +253 -0
- data/lib/fs/ntfs/data_run.rb +358 -0
- data/lib/fs/ntfs/directory_index_node.rb +114 -0
- data/lib/fs/ntfs/index_node_header.rb +69 -0
- data/lib/fs/ntfs/index_record_header.rb +85 -0
- data/lib/fs/ntfs/mft_entry.rb +288 -0
- data/lib/fs/ntfs/utils.rb +43 -0
- data/lib/fs/test/camcorder_fs_test.rb +108 -0
- data/lib/fs/test/collect_files_direct.yaml +22 -0
- data/lib/fs/test/collect_files_in.yaml +24 -0
- data/lib/fs/test/collect_files_in_nc.yaml +22 -0
- data/lib/fs/test/collect_files_out.yaml +6 -0
- data/lib/fs/test/collect_files_rm.yaml +6 -0
- data/lib/fs/test/copyTest.rb +126 -0
- data/lib/fs/test/fsTest.rb +87 -0
- data/lib/fs/test/updateTest.rb +184 -0
- data/lib/fs/xfs/allocation_group.rb +160 -0
- data/lib/fs/xfs/bmap_btree_block.rb +125 -0
- data/lib/fs/xfs/bmap_btree_record.rb +80 -0
- data/lib/fs/xfs/bmap_btree_root_node.rb +72 -0
- data/lib/fs/xfs/directory.rb +133 -0
- data/lib/fs/xfs/directory2_data_header.rb +27 -0
- data/lib/fs/xfs/directory3_data_header.rb +34 -0
- data/lib/fs/xfs/directory_block_tail.rb +22 -0
- data/lib/fs/xfs/directory_data_header.rb +46 -0
- data/lib/fs/xfs/directory_entry.rb +106 -0
- data/lib/fs/xfs/inode.rb +532 -0
- data/lib/fs/xfs/inode_map.rb +100 -0
- data/lib/fs/xfs/short_form_directory_entry.rb +91 -0
- data/lib/fs/xfs/short_form_header.rb +44 -0
- data/lib/fs/xfs/superblock.rb +556 -0
- data/lib/lib/tasks/azure.rake +52 -0
- data/lib/manageiq/smartstate/version.rb +5 -0
- data/lib/manageiq/smartstate.rb +7 -0
- data/lib/manageiq-smartstate.rb +1 -0
- data/lib/metadata/MIQExtract/MIQExtract.rb +297 -0
- data/lib/metadata/MIQExtract/test/extractTest.rb +41 -0
- data/lib/metadata/MIQExtract/test/full_extract_test.rb +68 -0
- data/lib/metadata/ScanProfile/HostScanItem.rb +4 -0
- data/lib/metadata/ScanProfile/HostScanProfile.rb +4 -0
- data/lib/metadata/ScanProfile/HostScanProfiles.rb +41 -0
- data/lib/metadata/ScanProfile/ScanItemBase.rb +63 -0
- data/lib/metadata/ScanProfile/ScanProfileBase.rb +51 -0
- data/lib/metadata/ScanProfile/ScanProfilesBase.rb +60 -0
- data/lib/metadata/ScanProfile/VmScanItem.rb +4 -0
- data/lib/metadata/ScanProfile/VmScanProfile.rb +4 -0
- data/lib/metadata/ScanProfile/VmScanProfiles.rb +38 -0
- data/lib/metadata/ScanProfile/modules/HostScanItemFile.rb +51 -0
- data/lib/metadata/ScanProfile/modules/HostScanItemNteventlog.rb +84 -0
- data/lib/metadata/ScanProfile/modules/VmScanItemFile.rb +39 -0
- data/lib/metadata/ScanProfile/modules/VmScanItemNteventlog.rb +34 -0
- data/lib/metadata/ScanProfile/modules/VmScanItemRegistry.rb +64 -0
- data/lib/metadata/VMMount/VMMount.rb +81 -0
- data/lib/metadata/VMMount/VMPlatformMount.rb +18 -0
- data/lib/metadata/VMMount/VMPlatformMountLinux.rb +75 -0
- data/lib/metadata/VMMount/VMPlatformMountWin.rb +13 -0
- data/lib/metadata/VmConfig/GetNativeCfg.rb +45 -0
- data/lib/metadata/VmConfig/VmConfig.rb +947 -0
- data/lib/metadata/VmConfig/cfgConfig.rb +45 -0
- data/lib/metadata/VmConfig/ovfConfig.rb +99 -0
- data/lib/metadata/VmConfig/test/GetVMwareCfgTest.rb +40 -0
- data/lib/metadata/VmConfig/vmcConfig.rb +116 -0
- data/lib/metadata/VmConfig/vmtxConfig.rb +4 -0
- data/lib/metadata/VmConfig/vmxConfig.rb +162 -0
- data/lib/metadata/VmConfig/xmlConfig.rb +79 -0
- data/lib/metadata/VmConfig/xmlMsHyperVConfig.rb +41 -0
- data/lib/metadata/linux/InitProcHash.rb +632 -0
- data/lib/metadata/linux/LinuxInitProcs.rb +142 -0
- data/lib/metadata/linux/LinuxOSInfo.rb +237 -0
- data/lib/metadata/linux/LinuxPackages.rb +209 -0
- data/lib/metadata/linux/LinuxSystemd.rb +130 -0
- data/lib/metadata/linux/LinuxUsers.rb +289 -0
- data/lib/metadata/linux/LinuxUtils.rb +197 -0
- data/lib/metadata/linux/MiqConaryPackages.rb +41 -0
- data/lib/metadata/linux/MiqRpmPackages.rb +160 -0
- data/lib/metadata/linux/test/Name +0 -0
- data/lib/metadata/linux/test/Packages +0 -0
- data/lib/metadata/linux/test/rpoTest.rb +5 -0
- data/lib/metadata/linux/test/tc_LinuxUtils.rb +4157 -0
- data/lib/metadata/util/event_log_filter.rb +61 -0
- data/lib/metadata/util/md5deep.rb +280 -0
- data/lib/metadata/util/win32/Win32Accounts.rb +764 -0
- data/lib/metadata/util/win32/Win32EventLog.rb +743 -0
- data/lib/metadata/util/win32/Win32Services.rb +86 -0
- data/lib/metadata/util/win32/Win32Software.rb +326 -0
- data/lib/metadata/util/win32/Win32System.rb +333 -0
- data/lib/metadata/util/win32/boot_info_win.rb +59 -0
- data/lib/metadata/util/win32/fleece_hives.rb +220 -0
- data/lib/metadata/util/win32/ms-registry.rb +650 -0
- data/lib/metadata/util/win32/peheader.rb +868 -0
- data/lib/metadata/util/win32/remote-registry.rb +142 -0
- data/lib/metadata/util/win32/system_path_win.rb +103 -0
- data/lib/metadata/util/win32/versioninfo.rb +17 -0
- data/manageiq-smartstate.gemspec +35 -0
- metadata +486 -0
@@ -0,0 +1,51 @@
|
|
1
|
+
require 'metadata/linux/LinuxUtils'
|
2
|
+
|
3
|
+
module HostScanItemFile
|
4
|
+
def parse_data(ssu, data, &_blk)
|
5
|
+
if data.nil?
|
6
|
+
d = scan_definition
|
7
|
+
|
8
|
+
st = Time.now
|
9
|
+
$log.info "Scanning [Profile-Files] information."
|
10
|
+
yield({:msg => 'Scanning Profile-File'}) if block_given?
|
11
|
+
|
12
|
+
fs_files = d["stats"].collect { |s| s["target"] }.uniq
|
13
|
+
|
14
|
+
$log.info "Retrieving file metadata for targets."
|
15
|
+
files = ssu.shell_exec("ls -lLd --full-time #{fs_files.join(' ')} 2>/dev/null; true").split("\n")
|
16
|
+
files = MiqLinux::Utils.parse_ls_l_fulltime(files)
|
17
|
+
files.each do |f|
|
18
|
+
f.delete(:hard_links)
|
19
|
+
f[:rsc_type] = f.delete(:ftype)
|
20
|
+
f[:contents] = nil
|
21
|
+
end
|
22
|
+
|
23
|
+
md5_files = files.collect { |f| f[:name] if f[:rsc_type] == 'file' }.compact
|
24
|
+
$log.info "Retrieving md5 values for targets."
|
25
|
+
md5_files = ssu.shell_exec("md5sum #{md5_files.join(' ')} 2>/dev/null; true").split("\n")
|
26
|
+
md5_files.each do |line|
|
27
|
+
parts = line.chomp.split(' ')
|
28
|
+
md5, fname = parts[0], parts[1..-1].join(' ')
|
29
|
+
file = files.find { |f| f[:name] == fname }
|
30
|
+
file[:md5] = md5 unless file.nil?
|
31
|
+
end
|
32
|
+
|
33
|
+
cat_files = d["stats"].collect { |s| s["target"] if s["content"] }.compact.uniq
|
34
|
+
unless cat_files.empty?
|
35
|
+
$log.info "Retrieving content for specified targets."
|
36
|
+
cat_files = ssu.shell_exec("ls -1d #{cat_files.join(' ')} 2>/dev/null; true").split("\n")
|
37
|
+
cat_files.each do |fname|
|
38
|
+
fname = fname.chomp
|
39
|
+
next if fname.empty?
|
40
|
+
file = files.find { |f| f[:name] == fname }
|
41
|
+
$log.debug "Retrieving content for #{fname}."
|
42
|
+
file[:contents] = ssu.shell_exec("cat #{fname} 2>/dev/null; true")
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
d[:data] = files
|
47
|
+
|
48
|
+
$log.info "Scanning [Profile-Files] information ran for [#{Time.now - st}] seconds."
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
@@ -0,0 +1,84 @@
|
|
1
|
+
require 'metadata/util/event_log_filter'
|
2
|
+
|
3
|
+
require 'digest/md5'
|
4
|
+
|
5
|
+
module HostScanItemNteventlog
|
6
|
+
def parse_data(vim, data, &_blk)
|
7
|
+
d = scan_definition
|
8
|
+
filter = d["content"][0][:filter]
|
9
|
+
if filter.nil?
|
10
|
+
$log.warn("MIQ(#{self.class.name}.parse_data) Unable to find hostd filter in scan profile [host default]")
|
11
|
+
return
|
12
|
+
end
|
13
|
+
|
14
|
+
data = vim.browseDiagnosticLogEx('hostd') if data.nil?
|
15
|
+
d[:data] = hostd_log_to_hashes(data, filter)
|
16
|
+
end
|
17
|
+
|
18
|
+
#
|
19
|
+
# Diagnostic Log Parsing
|
20
|
+
#
|
21
|
+
|
22
|
+
def hostd_log_to_hashes(log, filter = nil)
|
23
|
+
filter ||= {}
|
24
|
+
EventLogFilter.prepare_filter!(filter)
|
25
|
+
|
26
|
+
ret = []
|
27
|
+
rec_count = 0
|
28
|
+
|
29
|
+
log['lineText'].each do |line|
|
30
|
+
next unless line[0, 1] == '['
|
31
|
+
next unless i = line.index(']')
|
32
|
+
header, message = line[1..i - 1], line[i + 1..-1]
|
33
|
+
|
34
|
+
# Process the header parts
|
35
|
+
parts = header.split(' ')
|
36
|
+
next unless parts.length >= 5
|
37
|
+
|
38
|
+
# Different versions of ESX hosts order the log messages differently
|
39
|
+
# old: date, time, quoted source, hash, level
|
40
|
+
# new: date, time, hash, level, quoted source
|
41
|
+
# Check that the last character of the last part is a quote to determine
|
42
|
+
# the versions
|
43
|
+
if parts[-1][-1, 1] != "'"
|
44
|
+
level = -1
|
45
|
+
source_start = 2
|
46
|
+
source_end = -3
|
47
|
+
else
|
48
|
+
level = 3
|
49
|
+
source_start = 4
|
50
|
+
source_end = -1
|
51
|
+
end
|
52
|
+
|
53
|
+
level = parts[level]
|
54
|
+
level = "warn" if level == "warning"
|
55
|
+
next if EventLogFilter.filter_by_level?(level, filter)
|
56
|
+
|
57
|
+
source = parts[source_start..source_end].join(' ')
|
58
|
+
source = source[1..-2] # Remove the surrounding quotes
|
59
|
+
next if EventLogFilter.filter_by_source?(source, filter)
|
60
|
+
|
61
|
+
generated = Time.parse(parts[0..1].join(' ')).utc.iso8601
|
62
|
+
next if EventLogFilter.filter_by_generated?(generated, filter)
|
63
|
+
|
64
|
+
message.strip!
|
65
|
+
next if EventLogFilter.filter_by_message?(message, filter)
|
66
|
+
|
67
|
+
name = 'hostd'
|
68
|
+
|
69
|
+
ret << {
|
70
|
+
:generated => generated,
|
71
|
+
:name => name,
|
72
|
+
:level => level,
|
73
|
+
:source => source,
|
74
|
+
:message => message,
|
75
|
+
:uid => Digest::MD5.hexdigest("#{generated} #{name} #{level} #{source} #{message}")
|
76
|
+
}
|
77
|
+
|
78
|
+
rec_count += 1
|
79
|
+
break if EventLogFilter.filter_by_rec_count?(rec_count, filter)
|
80
|
+
end
|
81
|
+
|
82
|
+
ret
|
83
|
+
end
|
84
|
+
end
|
@@ -0,0 +1,39 @@
|
|
1
|
+
module VmScanItemFile
|
2
|
+
def to_xml
|
3
|
+
xml = @xml_class.newNode("scan_item")
|
4
|
+
xml.add_attributes("guid" => @params["guid"], "name" => @params["name"], "item_type" => @params["item_type"])
|
5
|
+
|
6
|
+
scan_definition['stats'].each do |d|
|
7
|
+
if d["data"]
|
8
|
+
xml_partial = xml.root.add_element("filesystem")
|
9
|
+
xml_partial.add_attributes(d["data"].root.attributes)
|
10
|
+
xml_partial.add_attribute("id", d["target"])
|
11
|
+
e = d["data"].root.elements[1]
|
12
|
+
until e.blank?
|
13
|
+
xml_partial << e
|
14
|
+
e = d["data"].root.elements[1]
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
xml
|
20
|
+
end
|
21
|
+
|
22
|
+
def parse_data(vm, data, &_blk)
|
23
|
+
if data.nil?
|
24
|
+
st = Time.now
|
25
|
+
$log.info "Scanning [Profile-Files] information."
|
26
|
+
yield({:msg => 'Scanning Profile-File'}) if block_given?
|
27
|
+
scan_definition["stats"].each do |d|
|
28
|
+
# MD5deep scanning will raise an error if the path does not exist.
|
29
|
+
begin
|
30
|
+
# Skip if we already have data for this element
|
31
|
+
options = {'contents' => d['content']}
|
32
|
+
d["data"] = MD5deep.scan_glob(vm.rootTrees[0], d["target"], options) if d["data"].nil?
|
33
|
+
rescue
|
34
|
+
end
|
35
|
+
end
|
36
|
+
$log.info "Scanning [Profile-Files] information ran for [#{Time.now - st}] seconds."
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
@@ -0,0 +1,34 @@
|
|
1
|
+
module VmScanItemNteventlog
|
2
|
+
def to_xml
|
3
|
+
xml = @xml_class.newNode('scan_item')
|
4
|
+
xml.add_attributes('guid' => @params['guid'], 'name' => @params['name'], 'item_type' => @params['item_type'])
|
5
|
+
d = scan_definition
|
6
|
+
xml.root << d[:data] if d[:data]
|
7
|
+
xml
|
8
|
+
end
|
9
|
+
|
10
|
+
def parse_data(vm, data, &_blk)
|
11
|
+
if data.nil?
|
12
|
+
d = scan_definition
|
13
|
+
if d[:data].nil?
|
14
|
+
if vm.rootTrees[0].guestOS == "Windows"
|
15
|
+
begin
|
16
|
+
st = Time.now
|
17
|
+
$log.info "Scanning [Profile-EventLogs] information."
|
18
|
+
yield({:msg => 'Scanning Profile-EventLogs'}) if block_given?
|
19
|
+
ntevent = Win32EventLog.new(vm.rootTrees[0])
|
20
|
+
ntevent.readAllLogs(d['content'])
|
21
|
+
rescue MiqException::NtEventLogFormat
|
22
|
+
$log.warn $!.to_s
|
23
|
+
rescue => err
|
24
|
+
$log.error "Win32EventLog: #{err}"
|
25
|
+
$log.error err.backtrace.join("\n")
|
26
|
+
ensure
|
27
|
+
d[:data] = ntevent.xmlDoc
|
28
|
+
$log.info "Scanning [Profile-EventLogs] information ran for [#{Time.now - st}] seconds."
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
@@ -0,0 +1,64 @@
|
|
1
|
+
module VmScanItemRegistry
|
2
|
+
def to_xml
|
3
|
+
xml = @xml_class.newNode("scan_item")
|
4
|
+
xml.add_attributes("guid" => @params["guid"], "name" => @params["name"], "item_type" => @params["item_type"])
|
5
|
+
|
6
|
+
scan_definition["content"].each do |d|
|
7
|
+
if d[:data]
|
8
|
+
xml_partial = xml.root.add_element("registry")
|
9
|
+
xml_partial.add_attributes("base_path" => base_reg_path(d), "id" => build_reg_path(d))
|
10
|
+
xml_partial << d[:data]
|
11
|
+
end
|
12
|
+
end
|
13
|
+
xml
|
14
|
+
end
|
15
|
+
|
16
|
+
def parse_data(_vm, data)
|
17
|
+
if data
|
18
|
+
scan_definition["content"].each do |d|
|
19
|
+
d[:data] = MIQRexml.findRegElement(build_reg_path(d), data.root) if d[:data].nil?
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
def build_reg_path(scanHash)
|
25
|
+
path = get_long_hive_name(scanHash["hive"]) + "\\" + scanHash["key"]
|
26
|
+
|
27
|
+
# Include the value as part of the search if we have a valid value
|
28
|
+
path += "\\" + scanHash["value"] if include_value?(scanHash)
|
29
|
+
|
30
|
+
path
|
31
|
+
end
|
32
|
+
|
33
|
+
def base_reg_path(scanHash)
|
34
|
+
path = File.join(scanHash["hive"], scanHash["key"])
|
35
|
+
path.tr!("/", "\\")
|
36
|
+
# If we are not processing the value the base path is the hive + key, minus the last path element
|
37
|
+
path = path.split("\\")[0..-2].join("\\") unless include_value?(scanHash)
|
38
|
+
path
|
39
|
+
end
|
40
|
+
|
41
|
+
def include_value?(scanHash)
|
42
|
+
# Include the value as part of the search if we have a valid value
|
43
|
+
value = scanHash["value"].to_s.strip
|
44
|
+
value = "" if value.length == 1 && value[0, 1] == "*"
|
45
|
+
if !value.blank?
|
46
|
+
return true
|
47
|
+
else
|
48
|
+
return false
|
49
|
+
end
|
50
|
+
end
|
51
|
+
|
52
|
+
def get_long_hive_name(hive)
|
53
|
+
case hive
|
54
|
+
when "HKLM"
|
55
|
+
"HKEY_LOCAL_MACHINE"
|
56
|
+
when "HKCU"
|
57
|
+
"HKEY_CURRENT_USER"
|
58
|
+
when "HKCR"
|
59
|
+
"HKEY_CLASSES_ROOT"
|
60
|
+
else
|
61
|
+
hive
|
62
|
+
end
|
63
|
+
end
|
64
|
+
end
|
@@ -0,0 +1,81 @@
|
|
1
|
+
require 'ostruct'
|
2
|
+
require 'disk/MiqDisk'
|
3
|
+
require 'fs/MiqFS/MiqFS'
|
4
|
+
require 'metadata/VMMount/VMPlatformMount'
|
5
|
+
require 'metadata/util/win32/system_path_win' # Used to check for Windows system partition
|
6
|
+
|
7
|
+
class VMMount
|
8
|
+
attr_reader :disk
|
9
|
+
|
10
|
+
def initialize(filename, ost = nil)
|
11
|
+
$log.debug "Initializing VMMount, filename: #{filename}" if $log
|
12
|
+
@mountDrive = nil
|
13
|
+
@diskInfo = OpenStruct.new
|
14
|
+
@ost = OpenStruct.new unless ost
|
15
|
+
@disk = nil
|
16
|
+
@fs = nil
|
17
|
+
|
18
|
+
# Use the MIQ functions to load virtual disk image
|
19
|
+
# Check if there is a flat file and redirect to the proper name
|
20
|
+
# TODO: This function should be improved to open the current file and check for the
|
21
|
+
# redirection. Right now it just looks for the expected flat filename.
|
22
|
+
$log.debug "vmmount called for disk image: [#{filename}]"
|
23
|
+
@diskInfo.fileName = getMountFile(filename)
|
24
|
+
|
25
|
+
@platMount = VMPlatformMount.new(@diskInfo, @ost)
|
26
|
+
@platMount.preMount
|
27
|
+
begin
|
28
|
+
@disk = MiqDisk.getDisk(@diskInfo)
|
29
|
+
raise "Failed to open disk: #{@diskInfo.fileName}" if @disk.nil?
|
30
|
+
|
31
|
+
@parts = @disk.getPartitions
|
32
|
+
raise "No Partitions found on disk: #{@diskInfo.fileName}" if @parts.nil?
|
33
|
+
|
34
|
+
$log.debug "VMMount mounting partitions of #{filename}" if $log
|
35
|
+
@parts.each do |p|
|
36
|
+
fsPartitions = MiqFS.getFS(p)
|
37
|
+
unless fsPartitions.nil?
|
38
|
+
# Always set the fs pointer to the first partition so we return something.
|
39
|
+
@fs = fsPartitions if @fs.nil?
|
40
|
+
|
41
|
+
# If the systemRoot does not throw an error then we found it
|
42
|
+
# and should return this fs. Otherwise, continue looking.
|
43
|
+
begin
|
44
|
+
Win32::SystemPath.systemRoot(fsPartitions)
|
45
|
+
@fs = fsPartitions
|
46
|
+
break
|
47
|
+
rescue
|
48
|
+
# $log.warn "No Windows partition here."
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
52
|
+
$log.debug "vmmount complete for: [#{filename}]"
|
53
|
+
rescue => err
|
54
|
+
@platMount.postMount
|
55
|
+
raise err
|
56
|
+
end
|
57
|
+
end
|
58
|
+
|
59
|
+
def getMountFile(fn)
|
60
|
+
file_miq = File.join(File.dirname(fn), File.basename(fn, ".*") + ".miq")
|
61
|
+
return file_miq if File.exist?(file_miq)
|
62
|
+
fn
|
63
|
+
end
|
64
|
+
|
65
|
+
def unMountImage
|
66
|
+
if @disk
|
67
|
+
@disk.close
|
68
|
+
@platMount.postMount
|
69
|
+
end
|
70
|
+
end
|
71
|
+
|
72
|
+
def getMountDrive
|
73
|
+
return @fs if @fs
|
74
|
+
@mountDrive
|
75
|
+
end
|
76
|
+
|
77
|
+
def mounted?
|
78
|
+
return true unless getMountDrive.nil?
|
79
|
+
false
|
80
|
+
end
|
81
|
+
end
|
@@ -0,0 +1,18 @@
|
|
1
|
+
require 'sys-uname'
|
2
|
+
|
3
|
+
class VMPlatformMount
|
4
|
+
def initialize(dInfo, ost)
|
5
|
+
$log.debug "Initializing VMPlatformMount" if $log
|
6
|
+
@dInfo = dInfo
|
7
|
+
@ost = ost
|
8
|
+
|
9
|
+
if Sys::Platform::OS == :windows
|
10
|
+
require "metadata/VMMount/VMPlatformMountWin"
|
11
|
+
extend VMPlatformMountWin
|
12
|
+
else
|
13
|
+
require "metadata/VMMount/VMPlatformMountLinux"
|
14
|
+
extend VMPlatformMountLinux
|
15
|
+
end
|
16
|
+
init
|
17
|
+
end # def initialize
|
18
|
+
end # class VMPlatformMount
|
@@ -0,0 +1,75 @@
|
|
1
|
+
require 'util/miq-password'
|
2
|
+
|
3
|
+
module VMPlatformMountLinux
|
4
|
+
VCBNAME = '/usr/sbin/vcbVmName'
|
5
|
+
VCBSNAPSHOT = '/usr/sbin/vcbSnapshot'
|
6
|
+
|
7
|
+
def init
|
8
|
+
$log.debug "Initializing VMPlatformMountLinux: #{@dInfo.fileName}" if $log
|
9
|
+
@ems = nil
|
10
|
+
@snapSsId = nil
|
11
|
+
|
12
|
+
unless @ost.force
|
13
|
+
$log.debug "Initializing VMPlatformMountLinux: force flag = false" if $log
|
14
|
+
return
|
15
|
+
end
|
16
|
+
|
17
|
+
return unless $miqHostCfg
|
18
|
+
return unless $miqHostCfg.emsLocal
|
19
|
+
return unless File.exist? VCBNAME
|
20
|
+
return unless File.exist? VCBSNAPSHOT
|
21
|
+
return unless File.extname(@dInfo.fileName) == ".vmdk"
|
22
|
+
|
23
|
+
$log.debug "VMPlatformMountLinux::init: emsLocal = #{$miqHostCfg.emsLocal}" if $log
|
24
|
+
@ems = $miqHostCfg.ems[$miqHostCfg.emsLocal]
|
25
|
+
#
|
26
|
+
# TODO: This won't always yield the VM name.
|
27
|
+
# While it works most of the time, we need to find a better way to do this.
|
28
|
+
#
|
29
|
+
@vmName = File.basename(File.dirname(@dInfo.fileName))
|
30
|
+
$log.debug "VMPlatformMountLinux::init: vmName = \"" # {@vmName}\"" if $log
|
31
|
+
#
|
32
|
+
# TODO: passing the user name and password on the command line is BAD.
|
33
|
+
# Change this to use web-services.
|
34
|
+
#
|
35
|
+
@cs = MiqPassword::Key.new
|
36
|
+
cmd = "#{VCBNAME} -h #{@ems['host']} -u #{@ems['user']} -p #{@cs.decrypt64(@ems['password'])} -s \"Name:#{@vmName}\" | grep \"moref:\""
|
37
|
+
#
|
38
|
+
# XXX Don't forget to remove this. We're logging the username and password, not good.
|
39
|
+
#
|
40
|
+
$log.debug "VMPlatformMountLinux::init: cmd = #{cmd}" if $log
|
41
|
+
@vmMoref = `#{cmd}`.chomp
|
42
|
+
$log.debug "VMPlatformMountLinux::init: vmMoref = \"#{@vmMoref}\"" if $log
|
43
|
+
end
|
44
|
+
|
45
|
+
def preMount
|
46
|
+
return unless @ost.force
|
47
|
+
return unless @ems
|
48
|
+
cmd = "#{VCBSNAPSHOT} -h #{@ems['host']} -u #{@ems['user']} -p #{@cs.decrypt64(@ems['password'])} -c \"#{@vmMoref}\" \"miq#{@vmName}snap\" | grep \"SsId:\""
|
49
|
+
#
|
50
|
+
# XXX Don't forget to remove this. We're logging the username and password, not good.
|
51
|
+
#
|
52
|
+
$log.debug "VMPlatformMountLinux::preMount: cmd = #{cmd}" if $log
|
53
|
+
@snapSsId = `#{cmd}`.chomp
|
54
|
+
$log.debug "VMPlatformMountLinux::preMount: snapSsId = \"#{@snapSsId}\"" if $log
|
55
|
+
# The VMMount code selects the disk file before the snapshot is taken.
|
56
|
+
# The file it selects should be the parent of the snapshot, so we should be OK.
|
57
|
+
# This may not be the case fot other types of VMs.
|
58
|
+
# @dInfo.baseOnly = true
|
59
|
+
end
|
60
|
+
|
61
|
+
def postMount
|
62
|
+
return unless @ost.force
|
63
|
+
#
|
64
|
+
# TODO: Ensure the snapshot gets removed in the event something happens between the preMount and postMount.
|
65
|
+
#
|
66
|
+
return unless @snapSsId
|
67
|
+
cmd = "#{VCBSNAPSHOT} -h #{@ems['host']} -u #{@ems['user']} -p #{@cs.decrypt64(@ems['password'])} -d \"#{@vmMoref}\" \"#{@snapSsId}\""
|
68
|
+
#
|
69
|
+
# XXX Don't forget to remove this. We're logging the username and password, not good.
|
70
|
+
#
|
71
|
+
$log.debug "VMPlatformMountLinux::postMount: cmd = #{cmd}" if $log
|
72
|
+
result = `#{cmd}`.chomp
|
73
|
+
$log.debug "VMPlatformMountLinux::postMount: result = #{result}" if $log
|
74
|
+
end
|
75
|
+
end # module VMPlatformMountLinux
|
@@ -0,0 +1,45 @@
|
|
1
|
+
require 'util/miq-xml'
|
2
|
+
require 'util/runcmd'
|
3
|
+
require 'metadata/VmConfig/VmConfig'
|
4
|
+
|
5
|
+
class GetNativeCfg
|
6
|
+
LSHW = "lshw"
|
7
|
+
|
8
|
+
def self.new
|
9
|
+
lshwXml = MiqUtil.runcmd("#{LSHW} -xml")
|
10
|
+
nodeHash = Hash.new { |h, k| h[k] = [] }
|
11
|
+
doc = MiqXml.load(lshwXml)
|
12
|
+
doc.find_match("//node").each { |n| nodeHash[n.attributes["id"].split(':', 2)[0]] << n }
|
13
|
+
|
14
|
+
hardware = ""
|
15
|
+
|
16
|
+
nodeHash["disk"].each do |d|
|
17
|
+
diskid = d.find_first('businfo').get_text.to_s
|
18
|
+
next unless diskid
|
19
|
+
sn = d.find_first('size')
|
20
|
+
# If there's no size node, assume it's a removable drive.
|
21
|
+
next unless sn
|
22
|
+
busType, busAddr = diskid.split('@', 2)
|
23
|
+
if busType == "scsi"
|
24
|
+
f1, f2 = busAddr.split(':', 2)
|
25
|
+
f2 = f2.split('.')[1]
|
26
|
+
busAddr = "#{f1}:#{f2}"
|
27
|
+
else
|
28
|
+
busAddr['.'] = ':'
|
29
|
+
end
|
30
|
+
diskid = busType + busAddr
|
31
|
+
filename = d.find_first('logicalname').get_text.to_s
|
32
|
+
hardware += "#{diskid}.present = \"TRUE\"\n"
|
33
|
+
hardware += "#{diskid}.filename = \"#{filename}\"\n"
|
34
|
+
end
|
35
|
+
|
36
|
+
VmConfig.new(hardware)
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
if __FILE__ == $0
|
41
|
+
|
42
|
+
cfg = GetNativeCfg.new
|
43
|
+
cfg.getDiskFileHash.each { |dtag, df| puts "#{dtag}\t=> #{df}" }
|
44
|
+
|
45
|
+
end
|