forked from wazuh/wazuh-puppet
-
Notifications
You must be signed in to change notification settings - Fork 0
125 lines (102 loc) · 3.84 KB
/
main.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
name: Kitchen tests for Wazuh Puppet
on: [pull_request, workflow_dispatch, release]
jobs:
validate-and-build:
runs-on: ubuntu-latest
steps:
- uses: actions/[email protected]
- name: Create enviroment variables
run: |
cat VERSION >> $GITHUB_ENV
VER=`curl -s https://api.github.com/repos/wazuh/wazuh/releases/latest | grep '\"tag_name\":' | sed -E 's/.*\"([^\"]+)\".*/\1/' | cut -c 2-`
WAZUH_VERSION=$VER >> $GITHUB_ENV
- name: Install Puppet
uses: ./.github/debian_install
- name: Download and Install pdk
run: |
wget https://apt.puppet.com/puppet-tools-release-focal.deb
sudo dpkg -i puppet-tools-release-focal.deb
sudo apt-get update
sudo apt-get install pdk
- name: Compare versions
run: |
function compare_versions() {
operator="${2}"
echo $operator
if [ $operator == "-gt" ]; then
test "$(echo "$1" "$3" | tr " " "\n" | sort -V | head -n 1)" != "$1";
elif [ $operator == "-le" ]; then
test "$(echo "$1" "$3" | tr " " "\n" | sort -V | head -n 1)" == "$1";
elif [ $operator == "-lt" ]; then
test "$(echo "$1" "$3" | tr " " "\n" | sort -rV | head -n 1)" != "$1";
elif [ $operator == "-ge" ]; then
test "$(echo "$1" "$3" | tr " " "\n" | sort -rV | head -n 1)" == "$1";
else
echo "Operator not supported"
exit 1
fi
}
if compare_versions "{{ env.VERSION }}" -gt "{{ env.WAZUH_VERSION }}"; then
sed -i 's/packages.wazuh.com/packages-dev.wazuh.com/' manifests/repo.pp
sed -i 's/4.x/pre-release/' manifests/repo.pp
sed -i "s/'stable'/'unstable'/" manifests/repo.pp
fi
- name: Create Puppet module
run: pdk build
- name: Create artifact
uses: actions/upload-artifact@v2
with:
name: wazuh-module
path: ./pkg/wazuh-wazuh-${{ env.VERSION }}.tar.gz
#-------------------------------------------------------------------------------
ubuntu20:
runs-on: ubuntu-20.04
needs: validate-and-build
steps:
- uses: actions/checkout@v2
- name: Create enviroment variables
run: |
cat VERSION >> $GITHUB_ENV
VER=`curl -s https://api.github.com/repos/wazuh/wazuh/releases/latest | grep '\"tag_name\":' | sed -E 's/.*\"([^\"]+)\".*/\1/' | cut -c 2-`
WAZUH_VERSION=$VER >> $GITHUB_ENV
- name: Install Puppet
uses: ./.github/debian_install
- name: Configure Puppet server
uses: ./.github/configure
- name: Retrieve saved Wazuh module
uses: actions/download-artifact@v3
with:
name: wazuh-module
- name: Install Wazuh Module
run: |
sudo puppet module install ./wazuh-wazuh-${{ env.VERSION }}.tar.gz
- name: Install Wazuh Stack
uses: ./.github/install_stack
- name: Test stack
uses: ./.github/tests
#-------------------------------------------------------------------------------
ubuntu22:
runs-on: ubuntu-22.04
needs: validate-and-build
steps:
- uses: actions/checkout@v2
- name: Create enviroment variables
run: |
cat VERSION >> $GITHUB_ENV
VER=`curl -s https://api.github.com/repos/wazuh/wazuh/releases/latest | grep '\"tag_name\":' | sed -E 's/.*\"([^\"]+)\".*/\1/' | cut -c 2-`
WAZUH_VERSION=$VER >> $GITHUB_ENV
- name: Install Puppet
uses: ./.github/debian_install
- name: Configure Puppet server
uses: ./.github/configure
- name: Retrieve saved Wazuh module
uses: actions/download-artifact@v3
with:
name: wazuh-module
- name: Install Wazuh Module
run: |
sudo puppet module install ./wazuh-wazuh-${{ env.VERSION }}.tar.gz
- name: Install Wazuh Stack
uses: ./.github/install_stack
- name: Test stack
uses: ./.github/tests