7426 Commits

Author SHA1 Message Date
Richard W.M. Jones
a6b3943783 Version 1.29.4. 1.29.4 2014-10-31 17:47:18 +00:00
Richard W.M. Jones
6d6644d52d launch: libvirt: Implement drive secrets (RHBZ#1159016).
Implement the GUESTFS_ADD_DRIVE_OPTS_SECRET argument of
guestfs_add_drive_opts.  For libvirt we have to save the secret in
libvirtd first, get a UUID, and then pass the UUID back through the
domain XML.
2014-10-31 17:24:54 +00:00
Richard W.M. Jones
68dc488a44 v2v: -o libvirt: Get the <features/> right in the output XML (RHBZ#1159258).
Implement what old virt-v2v did (from
lib/Sys/VirtConvert/Connection/LibVirtTarget.pm)

Thanks: Tingting Zheng, Matthew Booth
2014-10-31 17:24:53 +00:00
Pino Toscano
7ba102dc4c fish: complete symlink properly
When an entry is a symlink, check whether it points to a directory, so
the entry for it can be completed correctly.
2014-10-31 17:49:54 +01:00
Pino Toscano
a8b95a5535 fish: fix dir completion on filesystems w/o dirent.d_type (RHBZ#1153844).
On filesystems whose dirent.d_type is DT_UNKNOWN or some unknown value,
manually check whether an entry is a directory, thus completing in the
proper way.
2014-10-31 17:49:54 +01:00
Pino Toscano
d082cd6ae5 builder: pass Sources.source objects directly
Instead of passing the (uri, key, proxy) tuple around, pass the whole
Sources.source record; this requires creating proper Sources.source also
for uri+fingerprint passed via command line.

No functional changes.
2014-10-31 17:49:46 +01:00
Pino Toscano
56bd781b76 builder: use gpgkey_type for the gpgkey field in sources 2014-10-31 17:46:14 +01:00
Pino Toscano
3987bbcd91 builder: move the gpgkey_type type from Sigchecker to Utils
No functional change, just code motion.
2014-10-31 17:46:14 +01:00
Richard W.M. Jones
1470be7f3b v2v: Add bounds check to Xml.xpathobj_node function.
I accidentally called it with an out-of-bounds index, and it caused a
core dump.  Add a bounds check to stop this from happening in
production.
2014-10-31 15:58:43 +00:00
Richard W.M. Jones
c085a0ba73 builder: Updated CentOS image to 6.6. 2014-10-31 13:57:26 +00:00
Richard W.M. Jones
847465a794 src/info.c: Remove incorrect comment. 2014-10-31 10:50:20 +00:00
Richard W.M. Jones
3e4024a1ea Version 1.29.3. 1.29.3 2014-10-30 22:21:47 +00:00
Richard W.M. Jones
65abc44203 v2v: Add --password-file parameter (RHBZ#1158526).
This allows you to send passwords to virt-v2v input modes without
being interactive.
2014-10-30 13:47:54 +00:00
Richard W.M. Jones
b35b84684c v2v: vmware: Use 'curl --config' to pass arguments securely to curl.
Instead of making up an ordinary curl command line, write a temporary
config file and use 'curl --config tmpfile' to pass the arguments.

The advantage is that it's more secure if we want to supply passwords
to curl, since a '--user username:password' parameter on the command
line could be read (eg. by 'ps ax'), but the temporary file has mode
0600 and cannot be read by other users.

This is mostly code motion, but it also passes the '-q' option to curl
to stop it from reading default configuration files.
2014-10-30 13:47:37 +00:00
Richard W.M. Jones
d82c5fb5a0 v2v: Remove useless parentheses around expression. 2014-10-30 13:47:36 +00:00
Richard W.M. Jones
8efbe49df6 p2v: kickstart: Add rpm to list of packages.
Avoids RHBZ#1089566.
2014-10-29 18:02:29 +00:00
Richard W.M. Jones
26952db56f p2v: kickstart: Remove 'install' line.
'install' is the default operation, it doesn't have to be specified.
2014-10-29 18:02:28 +00:00
Richard W.M. Jones
c48114cd24 p2v: kickstart: Add firewalld to the ISO to allow firewall to be enabled. 2014-10-29 18:02:28 +00:00
Richard W.M. Jones
439bf5e42a p2v: kickstart: Name the ISO 'virt-p2v'. 2014-10-29 18:02:28 +00:00
Richard W.M. Jones
a03bffa15a v2v: Add a support matrix to the manual page.
This explains what does and doesn't work.
2014-10-29 18:02:28 +00:00
Richard W.M. Jones
6d338ae4e6 builder: Document that --edit option can be split across lines. 2014-10-28 22:49:58 +00:00
Richard W.M. Jones
cb291d7e46 p2v: Ensure we are using virt-v2v >= 1.28.
Must NOT use:

- One of the interim versions of virt-v2v (1.27.x) that we published
  during development.

- Old virt-v2v (0.9.x).

Also use the --version option (instead of -V) since old virt-v2v
required it:

  $ virt-v2v -V
  Option v is ambiguous (version, vmtype)
  Usage:
  [...]
  $ virt-v2v --version
  0.9.1
2014-10-28 11:21:34 +00:00
Hu Tao
d0eba7f260 sysprep: remove /var/spool/mail/username
remove /var/spool/mail/username if --enable user-account.

Signed-off-by: Hu Tao <hutao@cn.fujitsu.com>
2014-10-28 11:21:33 +00:00
Richard W.M. Jones
7f7c153347 Document three (fixed) security problems in the main manual page.
Previously these were only covered in the release notes, but not in
the "SECURITY" section of guestfs(3).
2014-10-27 17:51:40 +00:00
Richard W.M. Jones
777e2175ab Add warnings about using guestfs_strings* APIs because of CVE-2014-8484 and CVE-2014-8485. 2014-10-27 17:44:54 +00:00
Richard W.M. Jones
b09b60c987 p2v: Add usb-storage module and rebuild initrd (RHBZ#1157679).
Include the usb-storage kernel module, to permit booting from USB
keys.

Rerun dracut to rebuild the initramfs.  This is complicated because by
default dracut will try to build an initramfs for the running
(ie. appliance) kernel, which is completely useless.  We need to find
the latest installed kernel and rebuild the initramfs for that
instead, which is hairy.

This also does a small refactoring of the distro-specific code,
removing the $selinux_relabel variable and replacing it with a generic
$extra_args variable.

I only added this to the virt-builder script, since one assumes that
livecd-creator/whatever should make the kickstart ISO bootable by
installing whatever drivers and modules are necessary.
2014-10-27 16:56:13 +00:00
Richard W.M. Jones
4c31cae279 Revert "p2v: Add usb-storage dracut module to allow boot from USB key (RHBZ#1157679)."
Running 'dracut -f' installs a dracut for the running kernel (of the
appliance) not the installed kernel.  Stupid stupid stupid.

This reverts commit 7a6d44ebfe.
2014-10-27 16:10:28 +00:00
Richard W.M. Jones
7a6d44ebfe p2v: Add usb-storage dracut module to allow boot from USB key (RHBZ#1157679).
I only added this to the virt-builder script, since one assumes that
livecd-creator/whatever should make the kickstart ISO bootable by
installing whatever drivers and modules are necessary.
2014-10-27 16:02:38 +00:00
Richard W.M. Jones
91788cd76f p2v: Add "Hardware Support" group to the P2V images (RHBZ#1157679).
Thanks: Chris Adams
2014-10-27 13:52:06 +00:00
Richard W.M. Jones
fab95a52bd p2v: Explain in the man page why the virt-p2v ISO is used. 2014-10-26 19:35:36 +00:00
Richard W.M. Jones
5862a4391d Version 1.29.2. 1.29.2 2014-10-25 17:56:45 +01:00
Richard W.M. Jones
09584a8bc6 sparsify: Add Utils module and use common error/warning/info functions.
This program needs quite a lot more work, in particular to make the
regular messages use 'make_message_function' instead of 'printf'.
2014-10-25 15:35:49 +01:00
Richard W.M. Jones
b01582623d resize: Tidy up messages.
Add common error/warning/info functions.

Examine every existing call to printf/eprintf and change where
necessary so that:

 - error is used instead of eprintf + exit 1

 - warning no longer needs ~prog argument (it is added by Utils module)

 - any verbose output should go to stdout, not stderr

 - info is used to print general informational messages

Also, don't indent summary of changes.
2014-10-25 15:28:58 +01:00
Richard W.M. Jones
6049fbdddb sysprep: Use common error/warning/info functions. 2014-10-25 15:13:27 +01:00
Richard W.M. Jones
7c9293fff0 v2v: Add Utils.warning and Utils.info that don't require ~prog parameter. 2014-10-25 15:06:08 +01:00
Richard W.M. Jones
f7664b7f76 customize: Add Customize_utils module and use common error/warning/info functions.
Add a Customize_utils module.  This contains common error/warning/info
functions, and also quote = Filename.quote.

Examine every existing call to printf/eprintf and change where
necessary so that:

 - error is used instead of eprintf + exit 1

 - warning no longer needs ~prog argument (it is added by Utils module)

 - any verbose output should go to stdout, not stderr

 - info is used to print general informational messages

Also, don't pass ~prog parameter around.  Instead we just get it from
the executable name.
2014-10-25 15:00:21 +01:00
Richard W.M. Jones
b99983480a builder: Add Utils module and use common error/warning/info functions.
Add a Utils module.  This contains common error/warning/info functions,
and also quote = Filename.quote.

Examine every existing call to printf/eprintf and change where
necessary so that:

 - error is used instead of eprintf + exit 1

 - warning no longer needs ~prog argument (it is added by Utils module)

 - any verbose output should go to stdout, not stderr

 - info is used to print general informational messages
2014-10-25 14:57:51 +01:00
Richard W.M. Jones
4ff6ba3550 test-tool: Handle mapping other architectures to qemu-system-* binaries. 2014-10-24 16:55:36 +01:00
Menanteau Guy
5018e00129 ppc64le: test-tool: Use correct qemu-system-ppc64 binary when creating qemu wrapper. 2014-10-24 16:51:02 +01:00
Richard W.M. Jones
a61d190ed3 ppc64le: configure: Look for qemu-system-ppc64 binary (RHBZ#1156449). 2014-10-24 14:40:57 +01:00
Richard W.M. Jones
62c84c6a55 inspector: Document that -a option can take a URI for remote storage (RHBZ#1156301). 2014-10-24 10:32:25 +01:00
Richard W.M. Jones
a5a0c2f3b0 bash-completion: Install symbolic links instead of copies of files (RHBZ#1156298). 2014-10-24 10:32:25 +01:00
Richard W.M. Jones
68ac0afc8d bash-completion: Replace 'ln -sf' commands with rm; $(LN_S). 2014-10-24 10:32:25 +01:00
Pino Toscano
46f9dd5290 configure: map also amd64 as host_cpu to x86_64 qemu 2014-10-23 19:03:12 +02:00
Pino Toscano
7fcac5f59f tests: switch from get_current_dir_name to getcwd(0, NULL)
get_current_dir_name exists on GNU libc only, so not portable.
On the other hand, while POSIX leaves a null buffer argument for getcwd
as unspecified behaviour, basically the most used/important Unix
implementations (GNU libc, FreeBSD's libc, etc) allow such value,
returning a new allocated buffer with the current directory.

In any case, the change just affects two tests, so even if it hits a
libc not implementing this behaviour for getcwd, only tests are
affected.
2014-10-23 19:03:12 +02:00
Pino Toscano
3784a42d03 customize, mllib: use the libvirt CFLAGS
uri-c.c and perl_edit-c.c end up (directly or indirectly) including
guestfs-internal-frontend.h, which in turns includes libvirt/libvirt.h;
hence, make sure to use the libvirt CFLAGS.
2014-10-23 19:03:12 +02:00
Pino Toscano
0a2534c4f1 actions: mark as IfNotCrossAppliance tests of command and command_lines
All these tests copy to the appliance a tool built on the host, and run
it.
2014-10-23 19:03:12 +02:00
Pino Toscano
349536bf70 tests/c-api: add a way to skip test when host and appliance differ
Add a IfNotCrossAppliance prereq for tests, so a test using it can only
be run when the appliance is a copy of the running host system; this can
help marking tests which run stuff (usually built in the host) inside
the appliance.
2014-10-23 19:03:12 +02:00
Pino Toscano
3de9fa7ba9 build: use $(SED) instead of sed when possible
Make use of the sed executable set at configure time.
2014-10-23 19:03:12 +02:00
Pino Toscano
ea9b225480 Include stdint.h where needed
Required for using int64_t, etc. Apparently implicitly pulled so far.
2014-10-23 19:03:12 +02:00