diskimage-builder/diskimage_builder/elements/hwdiscovery
Jesse Keating 84d10dce57 Remove use of 'which'.
Instead, either use the bash built-in of type to ensure it exists. Since
which is an external dep, things can fail oddly in a constrained
environment.

Also add a dib-lint test for this.

Change-Id: I645029f5b5bfe1198c89ce10fd3246be8636e8af
Signed-off-by: Jesse Keating <omgjlk@us.ibm.com>
2017-05-19 12:43:36 -07:00
..
binary-deps.d Move elements & lib relative to diskimage_builder package 2016-11-01 17:27:41 -07:00
init.d Remove use of 'which'. 2017-05-19 12:43:36 -07:00
element-deps Move elements & lib relative to diskimage_builder package 2016-11-01 17:27:41 -07:00
package-installs.yaml Move elements & lib relative to diskimage_builder package 2016-11-01 17:27:41 -07:00
README.rst Move elements & lib relative to diskimage_builder package 2016-11-01 17:27:41 -07:00

===========
hwdiscovery
===========
A ramdisk to report the hardware of a machine to an inventory service.

This will collect up some basic information about the hardware it 
boots on:

 * CPU cores
 * RAM
 * Disk
 * NIC mac address

This information will then be collated into a JSON document, base64 
encoded and passed, via HTTP POST, to a URL that you must specify on 
the kernel commandline, thus:

HW_DISCOVERY_URL=http://1.2.3.4:56/hw_script.asp


This is currently fairly fragile as there can be a huge variability in 
the number of disks/NICs in servers and how they are configured.

If other elements wish to inject data into the hardware discovery data, 
they can - they should be specified before hwdiscovery to the image 
building script, and they should contain something like this in their 
init fragment:

_vendor_hwdiscovery_data="$_vendor_hwdiscovery_data
 \"some vendor key\" : \"some data you care about\",
 \"some other vendor key\" : \"some other data you care about\","

Note that you are essentially feeding JSON into the main hwdiscovery 
JSON.

This will allow any number of vendor specific hwdiscovery elements to 
chain together their JSON fragments and maintain consistency.