Как обеспечить соблюдение состояния, только если у минона установлен SELinux?

У меня есть код, который устанавливает собственный модуль selinux. В моем парке миньонов есть системы на базе Fedora (с установленным SELinux) и на базе Debian (без SELinux). В последнем случае не следует использовать состояние модуля/установки, и поэтому я ищу способ получить четкий ответ на вопрос «установлен ли SELinux в этой системе?» (НЕ «принудительно ли SELinux применяется к этой системе?») для использования в соответствующем предложении jinja2if.

Попытки, которые приводят меня в отчаяние:

  • похоже, в Salt нет состояния, запрашивающего, находится ли данный двоичный файл в $PATH - проверка sestatus - это то, что мне нужно здесь.
  • salt.states.selinux недоступен в системах без SELinux, поэтому его функциональность не поможет.
  • Я также не смог найти никакой функции Salt для запроса локальной доступности чего-то вроде salt.states.selinux (см. выше).
  • Что-то вроде
    - unless: - rpm -q libselinux
    
    (из этого ответа) также не работает, поскольку rpm специфично для Fedora...
  • Проверка отсутствия /etc/selinux также невозможна, поскольку в системах Debian это действительно предусмотрено.

Любой намек на то, как это сделать, приветствуется.

Вы также можете использовать зерно os для условного выполнения определенных состояний. Например. if grains['os'] == 'Fedora'.

seshadri_c 09.07.2024 11:05
Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
1
1
77
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Следуя этой подсказке, я в итоге сделал:

{% if salt['pkg.version']('libselinux') %}
...
{% endif %}

Не то, что я бы назвал аккуратным и использующим несколько запутанную логику, но, похоже, это помогает.

Ответ принят как подходящий

Если установлен selinux, то зерно доступно:

{% if 'selinux' in grains %}

# stuff that's only included if selinux is available

{% endif %}

Вы также можете использовать это зерно для нацеливания на миньонов:

base:
  'selinux:*':
    - match: grain
    - my_states.for_selinux_only

В общем, вы также можете проверить, загрузился ли модуль:

{% if 'selinux.getconfig' in salt %}

Находится ли исполняемый файл в PATH:

{% if 'sestatus' | which %}

Установлен ли пакет (что также работает в параметре onlyif):

{% if salt['pkg.version']('libselinux') %}

Бит {% if 'selinux.getconfig' in salt %} на самом деле у меня не работает. Возможно, это запрашивает настройку sal в мастере, а не minion. В любом случае. Вернемся к нацеливанию/зерну миньонов.

balin 06.07.2024 21:40

Нет, шаблоны рендерятся на миньоне. Модуль может иметь дополнительные требования для загрузки, например. соответствующий пакет Python.

OrangeDog 07.07.2024 12:03

@balin также есть фильтр which Jinja, для которого я только что добавил пример.

OrangeDog 08.07.2024 18:08

Другие вопросы по теме