| Server IP : 127.0.1.1 / Your IP : 216.73.216.152 Web Server : Apache/2.4.52 (Ubuntu) System : Linux bahcrestlinepropertiesllc 5.15.0-113-generic #123-Ubuntu SMP Mon Jun 10 08:16:17 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.33 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /proc/thread-self/root/lib/python3/dist-packages/sos/collector/clusters/ |
Upload File : |
# Copyright Red Hat 2022, Trevor Benson <trevor.benson@gmail.com>
# This file is part of the sos project: https://github.com/sosreport/sos
#
# This copyrighted material is made available to anyone wishing to use,
# modify, copy, or redistribute it subject to the terms and conditions of
# version 2 of the GNU General Public License.
#
# See the LICENSE file in the source distribution for further information.
import json
from shlex import quote
from sos.collector.clusters import Cluster
class saltstack(Cluster):
"""
The saltstack cluster profile is intended to be used on saltstack
clusters (Salt Project).
"""
cluster_name = "Saltstack"
packages = ("salt-master",)
sos_plugins = ["saltmaster"]
strict_node_list = True
option_list = [
("compound", "", "Filter node list to those matching compound"),
("glob", "", "Filter node list to those matching glob pattern"),
("grain", "", "Filter node list to those with matching grain"),
("minion_id_unresolvable", False, "Returns the FQDN grain of each"
" minion in the node list when the minion ID is not a hostname."),
("nodegroup", "", "Filter node list to those matching nodegroup"),
("pillar", "", "Filter node list to those with matching pillar"),
("subnet", "", "Filter node list to those in subnet"),
]
targeted = False
node_cmd = "salt-run --out=pprint manage.status"
def _parse_manage_status(self, output: str) -> list:
nodes = []
salt_json_output = json.loads(output.replace("'", '"'))
for _, value in salt_json_output.items():
nodes.extend(value)
return nodes
def _get_hostnames_from_grain(self, manage_status: dict) -> list:
hostnames = []
for status, minions in manage_status.items():
if status == "down":
self.log_warn(f"Node(s) {minions} are status down.")
hostnames.extend(minions)
else:
for minion in minions:
node_cmd = (
f"salt --out=newline_values_only {minion} "
f"grains.get fqdn"
)
hostnames.append(
self.exec_primary_cmd(node_cmd)["output"].strip()
)
return hostnames
def _get_nodes(self) -> list:
res = self.exec_primary_cmd(self.node_cmd)
if res["status"] != 0:
raise Exception("Node enumeration did not return usable output")
if self.get_option("minion_id_unresolvable"):
status = json.loads(res["output"].replace("'", '"'))
return self._get_hostnames_from_grain(status)
return self._parse_manage_status(res["output"])
def get_nodes(self):
# Default to all online nodes
for option in self.option_list:
if option[0] != "minion_id_unresolvable":
opt = self.get_option(option[0])
if opt:
self.node_cmd += f" tgt={quote(opt)} tgt_type={option[0]}"
break
return self._get_nodes()
# vim: set et ts=4 sw=4 :