-
Notifications
You must be signed in to change notification settings - Fork 16
109 lines (94 loc) · 3.62 KB
/
main.yml
File metadata and controls
109 lines (94 loc) · 3.62 KB
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
name: php-pkcs11 using SoftHSM2 CI
on:
# Triggers the workflow on push or pull requests events for any branch
push:
pull_request:
# Everey night of from Monday to Friday
schedule:
- cron: "0 2 * * 1-5"
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
env:
SOFTHSM2_TOKENDIR: /tmp/php-pkcs11-softhsm
SOFTHSM2_CONF: /tmp/php-pkcs11-softhsm2.conf
PHP11_PIN: 123456
PHP11_SOPIN: 12345678
jobs:
test-with-php-8_1:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Installing packages
run: |
sudo add-apt-repository ppa:ondrej/php
sudo apt-get update
sudo apt-get install php8.1-dev softhsm2 pkcs11-dump opensc
- name: Setup Ubuntu SoftHSM2
run: |
export PHP11_MODULE=/usr/lib/softhsm/libsofthsm2.so
mkdir -p $SOFTHSM2_TOKENDIR
cat <<EOFCONF >> $SOFTHSM2_CONF
directories.tokendir = $SOFTHSM2_TOKENDIR
objectstore.backend = file
log.level = INFO
slots.removable = false
slots.mechanisms = ALL
EOFCONF
softhsm2-util --init-token --slot 0 --label "Test Token" --pin $PHP11_PIN --so-pin $PHP11_SOPIN
pkcs11-dump info $PHP11_MODULE
pkcs11-dump slotlist $PHP11_MODULE
- name: Compile
run: |
phpize
./configure
make -j $(nproc)
- name: Tests using SoftHSM2
run: |
export PHP11_MODULE=/usr/lib/softhsm/libsofthsm2.so
echo "PHP11_MODULE $PHP11_MODULE"
export PHP11_SLOT=$(pkcs11-dump slotlist $PHP11_MODULE 2>/dev/null | grep SoftHSM | head -1 | cut -f 1)
echo "PHP11_SLOT $PHP11_SLOT"
export NO_INTERACTION=1
export REPORT_EXIT_STATUS=1
pkcs11-tool --module $PHP11_MODULE --login --slot $PHP11_SLOT --pin $PHP11_PIN --keypairgen --key-type rsa:2048
pkcs11-tool --module $PHP11_MODULE --login --slot $PHP11_SLOT --pin $PHP11_PIN --keygen --key-type aes:32
make test
test-with-php-8_2:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Installing packages
run: |
sudo add-apt-repository ppa:ondrej/php
sudo apt-get update
sudo apt-get install php8.2-dev softhsm2 pkcs11-dump opensc
- name: Setup Ubuntu SoftHSM2
run: |
export PHP11_MODULE=/usr/lib/softhsm/libsofthsm2.so
mkdir -p $SOFTHSM2_TOKENDIR
cat <<EOFCONF >> $SOFTHSM2_CONF
directories.tokendir = $SOFTHSM2_TOKENDIR
objectstore.backend = file
log.level = INFO
slots.removable = false
slots.mechanisms = ALL
EOFCONF
softhsm2-util --init-token --slot 0 --label "Test Token" --pin $PHP11_PIN --so-pin $PHP11_SOPIN
pkcs11-dump info $PHP11_MODULE
pkcs11-dump slotlist $PHP11_MODULE
- name: Compile
run: |
phpize
./configure
make -j $(nproc)
- name: Tests using SoftHSM2
run: |
export PHP11_MODULE=/usr/lib/softhsm/libsofthsm2.so
echo "PHP11_MODULE $PHP11_MODULE"
export PHP11_SLOT=$(pkcs11-dump slotlist $PHP11_MODULE 2>/dev/null | grep SoftHSM | head -1 | cut -f 1)
echo "PHP11_SLOT $PHP11_SLOT"
export NO_INTERACTION=1
export REPORT_EXIT_STATUS=1
pkcs11-tool --module $PHP11_MODULE --login --slot $PHP11_SLOT --pin $PHP11_PIN --keypairgen --key-type rsa:2048
pkcs11-tool --module $PHP11_MODULE --login --slot $PHP11_SLOT --pin $PHP11_PIN --keygen --key-type aes:32
make test