]> git.proxmox.com Git - pve-ha-manager.git/blame - src/PVE/HA/Config.pm
adapt test output for better readability
[pve-ha-manager.git] / src / PVE / HA / Config.pm
CommitLineData
cc32b737
DM
1package PVE::HA::Config;
2
3use strict;
4use warnings;
139a9b90 5use JSON;
cc32b737 6
139a9b90 7use PVE::HA::Tools;
cc32b737 8use PVE::HA::Groups;
139a9b90 9use PVE::Cluster qw(cfs_register_file cfs_read_file cfs_write_file cfs_lock_file);
d6edb3ea 10use PVE::HA::Resources;
cc32b737
DM
11
12PVE::HA::Groups->register();
13
14PVE::HA::Groups->init();
15
139a9b90
DM
16my $manager_status_filename = "ha/manager_status";
17my $ha_groups_config = "ha/groups.cfg";
18my $ha_resources_config = "ha/resources.cfg";
19my $crm_commands_filename = "ha/crm_commands";
f83e7e6e 20my $ha_fence_config = "ha/fence.cfg";
139a9b90
DM
21
22cfs_register_file($crm_commands_filename,
23 sub { my ($fn, $raw) = @_; return defined($raw) ? $raw : ''; },
24 sub { my ($fn, $raw) = @_; return $raw; });
25cfs_register_file($ha_groups_config,
26 sub { PVE::HA::Groups->parse_config(@_); },
27 sub { PVE::HA::Groups->write_config(@_); });
28cfs_register_file($ha_resources_config,
29 sub { PVE::HA::Resources->parse_config(@_); },
30 sub { PVE::HA::Resources->write_config(@_); });
31cfs_register_file($manager_status_filename,
32 \&json_reader,
33 \&json_writer);
f83e7e6e
TL
34cfs_register_file($ha_fence_config,
35 \&PVE::HA::FenceConfig::parse_config,
36 \&PVE::HA::FenceConfig::write_config);
139a9b90
DM
37
38sub json_reader {
39 my ($filename, $data) = @_;
40
b96c37ec 41 return defined($data) ? decode_json($data) : {};
139a9b90
DM
42}
43
44sub json_writer {
45 my ($filename, $data) = @_;
46
47 return encode_json($data);
48}
49
50sub read_lrm_status {
51 my ($node) = @_;
52
53 die "undefined node" if !defined($node);
54
55 my $filename = "/etc/pve/nodes/$node/lrm_status";
56
57 return PVE::HA::Tools::read_json_from_file($filename, {});
58}
59
60sub write_lrm_status {
61 my ($node, $status_obj) = @_;
62
63 die "undefined node" if !defined($node);
64
65 my $filename = "/etc/pve/nodes/$node/lrm_status";
66
67 PVE::HA::Tools::write_json_to_file($filename, $status_obj);
68}
69
cc32b737
DM
70sub parse_groups_config {
71 my ($filename, $raw) = @_;
72
139a9b90 73 return PVE::HA::Groups->parse_config($filename, $raw);
cc32b737
DM
74}
75
ce216792 76sub parse_resources_config {
cc32b737
DM
77 my ($filename, $raw) = @_;
78
79 return PVE::HA::Resources->parse_config($filename, $raw);
80}
81
139a9b90
DM
82sub read_resources_config {
83
84 return cfs_read_file($ha_resources_config);
85}
86
87sub read_group_config {
139a9b90
DM
88
89 return cfs_read_file($ha_groups_config);
90}
91
9eb0f126
DM
92sub write_group_config {
93 my ($cfg) = @_;
94
95 cfs_write_file($ha_groups_config, $cfg);
96}
97
139a9b90
DM
98sub write_resources_config {
99 my ($cfg) = @_;
100
101 cfs_write_file($ha_resources_config, $cfg);
102}
103
104sub read_manager_status {
105 my () = @_;
106
107 return cfs_read_file($manager_status_filename);
108}
109
110sub write_manager_status {
111 my ($status_obj) = @_;
f83e7e6e 112
139a9b90
DM
113 cfs_write_file($manager_status_filename, $status_obj);
114}
115
f83e7e6e
TL
116sub read_fence_config {
117 my () = @_;
118
119 cfs_read_file($ha_fence_config);
120}
121
66c7e7ef 122sub lock_ha_domain {
139a9b90
DM
123 my ($code, $errmsg) = @_;
124
66c7e7ef 125 my $res = PVE::Cluster::cfs_lock_domain("ha", undef, $code);
139a9b90
DM
126 my $err = $@;
127 if ($err) {
128 $errmsg ? die "$errmsg: $err" : die $err;
129 }
130 return $res;
131}
132
133sub queue_crm_commands {
134 my ($cmd) = @_;
135
136 chomp $cmd;
137
138 my $code = sub {
139 my $data = cfs_read_file($crm_commands_filename);
140 $data .= "$cmd\n";
141 cfs_write_file($crm_commands_filename, $data);
142 };
143
66c7e7ef 144 return lock_ha_domain($code);
139a9b90
DM
145}
146
147sub read_crm_commands {
148
149 my $code = sub {
150 my $data = cfs_read_file($crm_commands_filename);
151 cfs_write_file($crm_commands_filename, '');
152 return $data;
153 };
154
66c7e7ef 155 return lock_ha_domain($code);
139a9b90
DM
156}
157
0e703a14 158my $service_check_ha_state = sub {
e709d3d0
DM
159 my ($conf, $sid, $has_state) = @_;
160
161 if (my $d = $conf->{ids}->{$sid}) {
162 return 1 if !defined($has_state);
163
164 $d->{state} = 'enabled' if !defined($d->{state});
165 return 1 if $d->{state} eq $has_state;
166 }
167
168 return undef;
169};
170
139a9b90 171sub vm_is_ha_managed {
55c82a65 172 my ($vmid, $has_state) = @_;
139a9b90
DM
173
174 my $conf = cfs_read_file($ha_resources_config);
175
8facb786 176 my $types = PVE::HA::Resources->lookup_types();
e709d3d0 177 foreach my $type ('vm', 'ct') {
0e703a14 178 return 1 if &$service_check_ha_state($conf, "$type:$vmid", $has_state);
e709d3d0 179 }
8facb786
TL
180
181 return undef;
139a9b90
DM
182}
183
9e03f787
TL
184sub service_is_ha_managed {
185 my ($sid, $has_state, $noerr) = @_;
186
187 my $conf = cfs_read_file($ha_resources_config);
188
0e703a14 189 return 1 if &$service_check_ha_state($conf, $sid, $has_state);
9e03f787
TL
190
191 die "resource '$sid' is not HA managed\n" if !$noerr;
192
193 return undef;
194}
917ea00c
TL
195
196sub get_service_status {
197 my ($sid) = @_;
198
199 my $status = { managed => 0 };
200
201 my $conf = cfs_read_file($ha_resources_config);
202
0e703a14 203 if (&$service_check_ha_state($conf, $sid)) {
917ea00c
TL
204 my $manager_status = cfs_read_file($manager_status_filename);
205
206 $status->{managed} = 1;
207 $status->{group} = $conf->{ids}->{$sid}->{group};
208 $status->{state} = $manager_status->{service_status}->{$sid}->{state};
209 }
210
211 return $status;
212}
213
cc32b737 2141;