]> git.proxmox.com Git - pve-container.git/blame - src/lxc-pve-poststop-hook
Add 'perms' option to ct_modify_file
[pve-container.git] / src / lxc-pve-poststop-hook
CommitLineData
32e6d659
AD
1#!/usr/bin/perl
2
b056d074
DM
3package lxc_pve_poststop_hook;
4
32e6d659
AD
5use strict;
6use warnings;
4ed2b825 7
d6811d3f 8exit 0 if $ENV{LXC_NAME} && $ENV{LXC_NAME} !~ /^\d+$/;
4ed2b825 9
32e6d659
AD
10use POSIX;
11use File::Path;
12
13use PVE::SafeSyslog;
14use PVE::Tools;
15use PVE::Cluster;
16use PVE::INotify;
17use PVE::RPCEnvironment;
18use PVE::JSONSchema qw(get_standard_option);
19use PVE::CLIHandler;
20use PVE::Storage;
21use PVE::Storage::Plugin;
22use PVE::LXC;
32e6d659
AD
23use Data::Dumper;
24
25use base qw(PVE::CLIHandler);
26
32e6d659
AD
27__PACKAGE__->register_method ({
28 name => 'lxc-pve-poststop-hook',
29 path => 'lxc-pve-poststop-hook',
30 method => 'GET',
31 description => "vm_stop_cleanup.",
32 parameters => {
33 additionalProperties => 0,
34 properties => {
35 name => {
c0c77476 36 description => "The container name. This hook is only active for containers using numeric IDs, where configuration is stored on /etc/pve/lxc/<name>.conf (else it is just a NOP).",
32e6d659
AD
37 type => 'string',
38 pattern => '\S+',
39 maxLength => 64,
40 }
41 },
42 },
43 returns => { type => 'null' },
44
45 code => sub {
46 my ($param) = @_;
47
32e6d659
AD
48 return undef if $param->{name} !~ m/^\d+$/;
49
2914ad9b 50 my $vmid = $param->{name};
32e6d659 51
67afe46e 52 return undef if ! -f PVE::LXC::Config->config_file($vmid);
32e6d659 53
67afe46e 54 my $conf = PVE::LXC::Config->load_config($vmid);
32e6d659 55
2914ad9b 56 my $storage_cfg = PVE::Storage::config();
32e6d659 57
2914ad9b 58 PVE::LXC::vm_stop_cleanup($storage_cfg, $vmid, $conf);
c9a5774b
WB
59
60 my $rootfs = $ENV{LXC_ROOTFS_PATH};
61 die "Missing container root directory!\n" if !$rootfs;
62 PVE::Tools::run_command(['umount', '--recursive', $rootfs]);
32e6d659
AD
63
64 return undef;
65 }});
66
67
68push @ARGV, 'help' if !scalar(@ARGV);
69
70my $param = {};
71
b056d074 72if ((scalar(@ARGV) == 3) && ($ARGV[1] eq 'lxc') && ($ARGV[2] eq 'post-stop')) {
32e6d659
AD
73 $param->{name} = $ENV{'LXC_NAME'};
74 die "got wrong name" if $param->{name} ne $ARGV[0];
75
76 @ARGV = ();
77} else {
78 @ARGV = ('help');
79}
80
b056d074 81our $cmddef = [ __PACKAGE__, 'lxc-pve-poststop-hook', [], $param];
32e6d659 82
b056d074 83__PACKAGE__->run_cli_handler();