mirror of
https://github.com/Security-Onion-Solutions/securityonion.git
synced 2025-12-06 17:22:49 +01:00
246 lines
6.2 KiB
Plaintext
246 lines
6.2 KiB
Plaintext
# Copyright Security Onion Solutions LLC and/or licensed to Security Onion Solutions LLC under one
|
|
# or more contributor license agreements. Licensed under the Elastic License 2.0 as shown at
|
|
# https://securityonion.net/license; you may not use this file except in compliance with the
|
|
# Elastic License 2.0.
|
|
|
|
{% from 'allowed_states.map.jinja' import allowed_states %}
|
|
{% if sls.split('.')[0] in allowed_states %}
|
|
|
|
include:
|
|
- ssl
|
|
- elasticsearch.ca
|
|
|
|
{% from 'vars/globals.map.jinja' import GLOBALS %}
|
|
{% from 'elasticsearch/config.map.jinja' import ELASTICSEARCHMERGED %}
|
|
|
|
vm.max_map_count:
|
|
sysctl.present:
|
|
- value: 262144
|
|
|
|
# Add ES Group
|
|
elasticsearchgroup:
|
|
group.present:
|
|
- name: elasticsearch
|
|
- gid: 930
|
|
|
|
esconfdir:
|
|
file.directory:
|
|
- name: /opt/so/conf/elasticsearch
|
|
- user: 930
|
|
- group: 939
|
|
- makedirs: True
|
|
|
|
# Add ES user
|
|
elasticsearch:
|
|
user.present:
|
|
- uid: 930
|
|
- gid: 930
|
|
- home: /opt/so/conf/elasticsearch
|
|
- createhome: False
|
|
|
|
elasticsearch_sbin:
|
|
file.recurse:
|
|
- name: /usr/sbin
|
|
- source: salt://elasticsearch/tools/sbin
|
|
- user: 930
|
|
- group: 939
|
|
- file_mode: 755
|
|
- exclude_pat:
|
|
- so-elasticsearch-pipelines # exclude this because we need to watch it for changes, we sync it in another state
|
|
- show_changes: False
|
|
|
|
elasticsearch_sbin_jinja:
|
|
file.recurse:
|
|
- name: /usr/sbin
|
|
- source: salt://elasticsearch/tools/sbin_jinja
|
|
- user: 939
|
|
- group: 939
|
|
- file_mode: 755
|
|
- template: jinja
|
|
- exclude_pat:
|
|
- so-elasticsearch-ilm-policy-load # exclude this because we need to watch it for changes, we sync it in another state
|
|
- defaults:
|
|
GLOBALS: {{ GLOBALS }}
|
|
- show_changes: False
|
|
|
|
so-elasticsearch-ilm-policy-load-script:
|
|
file.managed:
|
|
- name: /usr/sbin/so-elasticsearch-ilm-policy-load
|
|
- source: salt://elasticsearch/tools/sbin_jinja/so-elasticsearch-ilm-policy-load
|
|
- user: 930
|
|
- group: 939
|
|
- mode: 754
|
|
- template: jinja
|
|
- show_changes: False
|
|
|
|
so-elasticsearch-pipelines-script:
|
|
file.managed:
|
|
- name: /usr/sbin/so-elasticsearch-pipelines
|
|
- source: salt://elasticsearch/tools/sbin/so-elasticsearch-pipelines
|
|
- user: 930
|
|
- group: 939
|
|
- mode: 754
|
|
- show_changes: False
|
|
|
|
esingestdir:
|
|
file.directory:
|
|
- name: /opt/so/conf/elasticsearch/ingest
|
|
- user: 930
|
|
- group: 939
|
|
- makedirs: True
|
|
|
|
estemplatedir:
|
|
file.directory:
|
|
- name: /opt/so/conf/elasticsearch/templates/index
|
|
- user: 930
|
|
- group: 939
|
|
- makedirs: True
|
|
|
|
esrolesdir:
|
|
file.directory:
|
|
- name: /opt/so/conf/elasticsearch/roles
|
|
- user: 930
|
|
- group: 939
|
|
- makedirs: True
|
|
|
|
eslibdir:
|
|
file.absent:
|
|
- name: /opt/so/conf/elasticsearch/lib
|
|
|
|
esingestdynamicconf:
|
|
file.recurse:
|
|
- name: /opt/so/conf/elasticsearch/ingest
|
|
- source: salt://elasticsearch/files/ingest-dynamic
|
|
- user: 930
|
|
- group: 939
|
|
- template: jinja
|
|
- show_changes: False
|
|
|
|
esingestconf:
|
|
file.recurse:
|
|
- name: /opt/so/conf/elasticsearch/ingest
|
|
- source: salt://elasticsearch/files/ingest
|
|
- user: 930
|
|
- group: 939
|
|
- show_changes: False
|
|
|
|
# Remove .fleet_final_pipeline-1 because we are using global@custom now
|
|
so-fleet-final-pipeline-remove:
|
|
file.absent:
|
|
- name: /opt/so/conf/elasticsearch/ingest/.fleet_final_pipeline-1
|
|
|
|
# Auto-generate Elasticsearch ingest node pipelines from pillar
|
|
{% for pipeline, config in ELASTICSEARCHMERGED.pipelines.items() %}
|
|
es_ingest_conf_{{pipeline}}:
|
|
file.managed:
|
|
- name: /opt/so/conf/elasticsearch/ingest/{{ pipeline }}
|
|
- source: salt://elasticsearch/base-template.json.jinja
|
|
- defaults:
|
|
TEMPLATE_CONFIG: {{ config }}
|
|
- template: jinja
|
|
- onchanges_in:
|
|
- file: so-pipelines-reload
|
|
{% endfor %}
|
|
|
|
eslog4jfile:
|
|
file.managed:
|
|
- name: /opt/so/conf/elasticsearch/log4j2.properties
|
|
- source: salt://elasticsearch/files/log4j2.properties
|
|
- user: 930
|
|
- group: 939
|
|
- template: jinja
|
|
|
|
esyml:
|
|
file.managed:
|
|
- name: /opt/so/conf/elasticsearch/elasticsearch.yml
|
|
- source: salt://elasticsearch/files/elasticsearch.yaml.jinja
|
|
- user: 930
|
|
- group: 939
|
|
- defaults:
|
|
ESCONFIG: {{ ELASTICSEARCHMERGED.config }}
|
|
- template: jinja
|
|
- show_changes: False
|
|
|
|
esroles:
|
|
file.recurse:
|
|
- source: salt://elasticsearch/roles/
|
|
- name: /opt/so/conf/elasticsearch/roles/
|
|
- clean: True
|
|
- template: jinja
|
|
- user: 930
|
|
- group: 939
|
|
- show_changes: False
|
|
|
|
nsmesdir:
|
|
file.directory:
|
|
- name: /nsm/elasticsearch
|
|
- user: 930
|
|
- group: 939
|
|
- makedirs: True
|
|
|
|
eslogdir:
|
|
file.directory:
|
|
- name: /opt/so/log/elasticsearch
|
|
- user: 930
|
|
- group: 939
|
|
- makedirs: True
|
|
|
|
es_repo_dir:
|
|
file.directory:
|
|
- name: /nsm/elasticsearch/repo/
|
|
- user: 930
|
|
- group: 930
|
|
- require:
|
|
- file: nsmesdir
|
|
|
|
so-pipelines-reload:
|
|
file.absent:
|
|
- name: /opt/so/state/espipelines.txt
|
|
- onchanges:
|
|
- file: esingestconf
|
|
- file: esingestdynamicconf
|
|
- file: esyml
|
|
- file: so-elasticsearch-pipelines-script
|
|
|
|
auth_users:
|
|
file.managed:
|
|
- name: /opt/so/conf/elasticsearch/users.tmp
|
|
- source: salt://elasticsearch/files/users
|
|
- user: 930
|
|
- group: 930
|
|
- mode: 600
|
|
- show_changes: False
|
|
|
|
auth_users_roles:
|
|
file.managed:
|
|
- name: /opt/so/conf/elasticsearch/users_roles.tmp
|
|
- source: salt://elasticsearch/files/users_roles
|
|
- user: 930
|
|
- group: 930
|
|
- mode: 600
|
|
- show_changes: False
|
|
|
|
auth_users_inode:
|
|
require:
|
|
- file: auth_users
|
|
cmd.run:
|
|
- name: cat /opt/so/conf/elasticsearch/users.tmp > /opt/so/conf/elasticsearch/users && chown 930:939 /opt/so/conf/elasticsearch/users && chmod 660 /opt/so/conf/elasticsearch/users
|
|
- onchanges:
|
|
- file: /opt/so/conf/elasticsearch/users.tmp
|
|
|
|
auth_users_roles_inode:
|
|
require:
|
|
- file: auth_users_roles
|
|
cmd.run:
|
|
- name: cat /opt/so/conf/elasticsearch/users_roles.tmp > /opt/so/conf/elasticsearch/users_roles && chown 930:939 /opt/so/conf/elasticsearch/users_roles && chmod 660 /opt/so/conf/elasticsearch/users_roles
|
|
- onchanges:
|
|
- file: /opt/so/conf/elasticsearch/users_roles.tmp
|
|
|
|
{% else %}
|
|
|
|
{{sls}}_state_not_allowed:
|
|
test.fail_without_changes:
|
|
- name: {{sls}}_state_not_allowed
|
|
|
|
{% endif %}
|