5
0
mirror of git://git.proxmox.com/git/pve-common.git synced 2025-01-10 09:17:37 +03:00
Commit Graph

899 Commits

Author SHA1 Message Date
Dietmar Maurer
732b693f14 new helper get_host_arch 2018-09-20 06:21:55 +02:00
Dominik Csapak
fbd10e04e7 fix #1914: CLIFormatter: check also for existence of 'type'
we sometimes define

result => {}

on an api call, so check that result->{type} is defined
and guess the type if not

Signed-off-by: Dominik Csapak <d.csapak@proxmox.com>
2018-09-17 10:58:35 +02:00
Dominik Csapak
9194ee0657 INotify.pm: add methods for reading/writing /etc/hosts
Signed-off-by: Dominik Csapak <d.csapak@proxmox.com>
2018-09-14 11:37:32 +02:00
Dominik Csapak
69758574a1 INotify.pm: use run_command instead of open for calling diff
Signed-off-by: Dominik Csapak <d.csapak@proxmox.com>
2018-09-14 07:09:03 +02:00
Dominik Csapak
1b505ae239 decode comments in /etc/network/interfaces as utf8
Signed-off-by: Dominik Csapak <d.csapak@proxmox.com>
2018-09-14 07:08:35 +02:00
Dietmar Maurer
d01452bdce api_dump_full: use api_clone_schema() for 'returns' schema
This  convert indexed parameters like -net\d+ to -net[n], so resulting dump
is smaller.

Signed-off-by: Dietmar Maurer <dietmar@proxmox.com>
2018-09-13 13:00:05 +02:00
Wolfgang Bumiller
8b49281929 INotify: add tests for non-defined vlan bridge ports
This tests the case covered by the previous commit

Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com>
2018-09-11 14:13:39 +02:00
Alexandre Derumier
514c2138d1 Inotify: check bridgeport: fix vlan interface not defined
We can add to a bridge a non defined vlan interface.
We only need to check that physical interface exist

example:
    auto eno1
    iface eno1 inet manual

    auto vmbr0
    iface vmbr0 inet manual
        bridge_ports eno1.1

[w.bumiller@proxmox.com: style & commit message fixup]
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com>
2018-09-11 14:13:33 +02:00
Alexandre Derumier
000e32bc4a Inotify: fix mtu check
- special check for bond, set parent mtu from slaves mtu if no defined.

- error if parent mtu is lower than child mtu (not bigger)

- return if child mtu is not defined

- fix vlan check (parent/child was inverted)
2018-09-11 10:53:58 +02:00
Thomas Lamprecht
fb6134feaa README.dev: enhance installing build-dependcy section
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
2018-09-05 10:57:49 +02:00
Thomas Lamprecht
2c2b3b55bc README.dev: note that one can start from a PVE installation
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
2018-09-05 10:26:37 +02:00
Martin Beckert
bb9d386588 Rework of the installation documentation 2018-09-05 10:24:18 +02:00
Dominik Csapak
2e353dfb5f run_fork_with_timeout: handle SIGTERM
when stopping a worker while doing a run_fork_with_timeout,
we want to handle that there and send the child the SIGTERM
so that it can clean up

for this we have to use readline_nointr,
because the read from the pipe gets interrupted by the signal

this partially fixes #1874
as we now correctly clean up the new disk, except if it is
on lvm/lvmthin (possibly other storages as well), and use the old disk
in the config

Signed-off-by: Dominik Csapak <d.csapak@proxmox.com>
2018-08-22 15:32:56 +02:00
Dominik Csapak
e03a836591 add readline_nointr to Tools
this is a wrapper to have an uninterruptible readline
so that we can read e.g. from a pipe even if interrupted by
a signal

Signed-off-by: Dominik Csapak <d.csapak@proxmox.com>
2018-08-22 15:32:56 +02:00
Dietmar Maurer
3496d4bf4d render_bytes: avoid untaint by simply change the sprintf call
There is no need to untaint if we do it this way (no idea why).
2018-08-06 13:36:23 +02:00
Dietmar Maurer
a91ee28fe5 render_bytes: check format, untaint before calling sprintf
Signed-off-by: Dietmar Maurer <dietmar@proxmox.com>
2018-08-06 13:16:44 +02:00
Dietmar Maurer
c701c5659e print_usage_short: do not group subcommands
For examply, do not group 'qm guest' usage.

Signed-off-by: Dietmar Maurer <dietmar@proxmox.com>
2018-08-01 08:54:35 +02:00
Dietmar Maurer
7b2ba123b4 generate_usage_str: do not group sub-commands
Usually, sub commands already form a logical group, so further grouping
just adds confusion (see 'qm' as example)

Signed-off-by: Dietmar Maurer <dietmar@proxmox.com>
2018-07-31 10:57:15 +02:00
Dietmar Maurer
90851cec3c print_api_result: fix test for undefined $result_schema 2018-07-31 08:29:45 +02:00
Dietmar Maurer
b51b930d2b print_api_result: allow to pass undefined schema
This is useful if we do not have a fixed schema, for example to
print results from qemu agent commands.

Signed-off-by: Dietmar Maurer <dietmar@proxmox.com>
2018-07-30 15:53:06 +02:00
Dietmar Maurer
6bc094934b print_api_result_plain: new helper
Usefull to print result without borders an headers.

Signed-off-by: Dietmar Maurer <dietmar@proxmox.com>
2018-07-30 15:52:53 +02:00
Dietmar Maurer
2ec79c0f95 print_text_table: align numbers to the right side
Signed-off-by: Dietmar Maurer <dietmar@proxmox.com>
2018-07-30 15:51:59 +02:00
Dietmar Maurer
b9474c9682 print_text_table: untaint $width
The value of $width depends on possible untainted $data (for example
task logs read from external files).

Signed-off-by: Dietmar Maurer <dietmar@proxmox.com>
2018-07-30 15:51:23 +02:00
Dietmar Maurer
6c7fee81f2 bump version to 5.0-38 2018-07-27 10:56:13 +02:00
Dietmar Maurer
5c59d8f99c getopt_usage: always remove $standard_output_options
Tools like pvesh and pveclient pass them as normal arguments. We use
a simply heuristic to test if there is an 'output_format' parameter.
If so, we remove all $standard_output_options and display [FORMAT_OPTIONS]
instead.
2018-07-27 07:48:44 +02:00
Dietmar Maurer
62c66c47fb getopt_usage: do not display $standard_output_options
Instead, simply add [FORMAT_OPTIONS] to the usage string.
2018-07-26 13:58:50 +02:00
Dietmar Maurer
ac6c61bf13 introcude new output format 'yaml' 2018-07-26 12:02:45 +02:00
Dietmar Maurer
b01a09e73f PVE::CLIFormatter - pass terminal option as separate parameter
This simplifies usage, because we can simple omit the $terminal_opts
parameter in most cases (automatically call query_terminal_option) while
still setting $options.
2018-07-26 11:57:15 +02:00
Dietmar Maurer
b99c04ada5 PVE::Certificate - set renderers for unix epoch and 'san' 2018-07-26 11:57:15 +02:00
Dietmar Maurer
ba752c8062 PVE::CLIFormatter - new 'yaml' renderer
Generates nice and readable output for list of string and simple objects.
2018-07-26 11:57:15 +02:00
Dietmar Maurer
2e2a450272 cli: print_text_table: correctly handle sort_key 0 2018-07-26 11:08:52 +02:00
Dietmar Maurer
9da2722861 PVE::CLIHandler - allow to define additional parameters for output formatter
Best shown with a example:

my $test_formatter = sub {
    my ($res, $result_schema, $fmt_param) = @_;
    PVE::CLIFormatter::print_api_result($res, $result_schema, undef, $fmt_param);
};

$cmddef = [ __PACKAGE__, 'test', [], undef, $test_formatter, $PVE::RESTHandler::standard_output_options],
2018-07-26 11:08:52 +02:00
Dietmar Maurer
4cbcd1386f cli: remove all output formatter magic from CLIHandler
- and rename format to 'output-format'

- provide a method to add properties to schema:
	PVE::RESTHandler::add_standard_output_properties

- provide methods to extract output properties:
	PVE::RESTHandler::extract_standard_output_properties()
2018-07-26 11:08:52 +02:00
Dietmar Maurer
bf5e9f8440 PVE::ACME - untaint saved account data
Signed-off-by: Dietmar Maurer <dietmar@proxmox.com>
2018-07-26 10:54:17 +02:00
Dominik Csapak
34d8999638 api dump: do not skip indexed params with only one index
We transform indexed parameters (like scsi0 scsi1 ...) to a single
scsi[n]. The check if we should transform did not handle the case
where a parameter was indexed but (currently) only index 0 existed.
Such definitions where simply skipped and seemed then to miss from
places using the API dump, like the api-viewer.

We now only skip those parameters with an index > 0 where the same
parameter with index 0 is defined.

This fixes a missing efidisk0 entry in an API dump[0].

[0]: https://forum.proxmox.com/threads/efidisk0-creation-missing-from-api.45624/

Signed-off-by: Dominik Csapak <d.csapak@proxmox.com>
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
2018-07-23 16:11:21 +02:00
Thomas Lamprecht
f4265f248f bump version to 5.0-37
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
2018-07-18 10:48:05 +02:00
Wolfgang Bumiller
afd4f9966a fixup: parameters vs properties typo
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com>
2018-07-18 10:42:24 +02:00
Thomas Lamprecht
11b30ba490 cli_handler: make standard options opt-in
The new standard options overwrite some already existing options in
already existing CLI tools, which is surely no good, e.g. vzdump
already has an quiet option which now gets overwritten, thus any
backup triggered by CRON always sents out an (additional) email.

Further, they may even only have an effect if the respective CLI
command uses an CLIFormatter print* method to output things.

And for some commands, like 'pvecm status' they may even never make
sense, as they exec an external program which doesn't honors nor gets
those std options...
Also some internal commands, like 'qm mtunnel' will never use it, as
probably even "normal" commands, as it may simply not make sense for
every command..

So make it opt-in for now, any CLI command can set std-output-opts to
get them.

Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
2018-07-18 09:26:53 +02:00
Thomas Lamprecht
7c7bc4623d bump version to 5.0-36
Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
2018-07-10 14:06:33 +02:00
Dietmar Maurer
a05db8b5dd print_api_result: skip undefined object values
We use objects to return VM configurations, so we uónly want to display
defined values.

Signed-off-by: Dietmar Maurer <dietmar@proxmox.com>
2018-07-10 13:52:20 +02:00
Dietmar Maurer
cd6591d38b output format options: remove 'plain', add 'json-pretty'
Signed-off-by: Dietmar Maurer <dietmar@proxmox.com>
2018-07-10 13:52:20 +02:00
Dietmar Maurer
f0bcf4d4c6 PVE::CLIFormatter::print_api_result - remove parameter $format
Instead, we pass it within $options.

Signed-off-by: Dietmar Maurer <dietmar@proxmox.com>
2018-07-10 13:52:20 +02:00
Dietmar Maurer
0adee98536 cli_handler: pass common output options as separate parameter
Signed-off-by: Dietmar Maurer <dietmar@proxmox.com>
2018-07-10 13:52:20 +02:00
Dietmar Maurer
352b7a14c8 PVE::CLIFormatter - implement new output options
quiet: dont print anything
noheader: supres headers
noborder: no borders
human-readable: use renderers
Signed-off-by: Dietmar Maurer <dietmar@proxmox.com>
2018-07-10 13:52:20 +02:00
Wolfgang Bumiller
ec0f515131 tests: test newly added interfaces individually
And add eth2/3 to /proc/net/dev, that way we don't need to
create them "virtually" (which we shouldn't, for physical
interfaces).

Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com>
2018-07-10 12:34:10 +02:00
Wolfgang Bumiller
fc158d0d9c fixup: don't use exists boolean
The previous condition didn't fail tests because it was
always false. The 'exists' property is not actually usable
when writing the interface file. It is merely a hint that
the interface existed in /proc/net/dev while parsing the
interfaces file and is otherwise actually unused here.

Simply check for the existence of the interface in $ifaces.

Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com>
2018-07-10 12:08:04 +02:00
Wolfgang Bumiller
c27ef07ff5 fixup: compare MTUs numerically
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com>
2018-07-10 11:55:39 +02:00
Wolfgang Bumiller
cebd1c85f0 whitespace fixup
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com>
2018-07-10 11:55:21 +02:00
Wolfgang Bumiller
94d786b393 cleanup: whitespace and error message consistency
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com>
2018-07-10 11:53:18 +02:00
Alexandre Derumier
9b053d70de Inotify : add mtu option
also check if mtu value is lower than parent interface

fixme: vxlan interface should be 50bytes lower than outgoing interface
       we need to find which interface is used (unicast/multicast/frr)
2018-07-10 11:38:54 +02:00