-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathinstall_swtpm.sh
More file actions
executable file
·108 lines (90 loc) · 3.34 KB
/
install_swtpm.sh
File metadata and controls
executable file
·108 lines (90 loc) · 3.34 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
#!/bin/bash
pushd ~/Downloads > /dev/null
# https://gist.github.com/Jacobboogiebear/2af9a49f8e9fdc2641ae019be58c4acd
# sudo apt install -y git build-essential autotools-dev libssl-dev libtasn1-6-dev libjson-glib-dev expect socat libseccomp-dev libgmp3-dev
# Prepare package for distro
packages=()
if [[ -z "`apt list 2> /dev/null | grep git | grep installed`" ]]; then
packages=(git)
fi
if [[ -z "`apt list 2> /dev/null | grep build-essential | grep installed`" ]]; then
packages=(build-essential)
fi
if [[ -z "`apt list 2> /dev/null | grep autotools-dev | grep installed`" ]]; then
packages=(autotools-dev)
fi
if [[ -z "`apt list 2> /dev/null | grep libssl-dev | grep installed`" ]]; then
packages=(libssl-dev)
fi
if [[ -z "`apt list 2> /dev/null | grep libtasn1-6-dev | grep installed`" ]]; then
packages=(libtasn1-6-dev)
fi
if [[ -z "`apt list 2> /dev/null | grep libjson-glib-dev | grep installed`" ]]; then
packages=(libjson-glib-dev)
fi
if [[ -z "`apt list 2> /dev/null | grep expect | grep installed`" ]]; then
packages=(expect)
fi
if [[ -z "`apt list 2> /dev/null | grep socat | grep installed`" ]]; then
packages=(socat)
fi
if [[ -z "`apt list 2> /dev/null | grep libseccomp-dev | grep installed`" ]]; then
packages=(libseccomp-dev)
fi
if [[ -z "`apt list 2> /dev/null | grep libgmp3-dev | grep installed`" ]]; then
packages=(libgmp3-dev)
fi
# Install if there are missing packages
if [ ${#packages[@]} -gt 0 ]; then
sudo apt install -y ${packages[@]}
fi
if [[ -z "`ldconfig -p | grep libtpms`" ]]; then
if [[ ! -d libtpms ]]; then
git clone https://github.com/stefanberger/libtpms.git
fi
fi
if ! command -v swtpm &> /dev/null; then
if [[ ! -d swtpm ]]; then
git clone https://github.com/stefanberger/swtpm.git
fi
fi
if [[ -z "`ldconfig -p | grep libtpms`" ]]; then
pushd libtpms > /dev/null
# Build and install
./autogen.sh --prefix=/usr --with-tpm2 --with-openssl
make -j`nproc`
sudo make install
# update ld cache
sudo ldconfig
popd > /dev/null
rm -rf libtpms
fi
if ! command -v swtpm &> /dev/null; then
pushd swtpm > /dev/null
# Build and install
./autogen.sh --prefix=/usr
make -j`nproc`
sudo make install
# @TODO: Consider making a real deb package
# Get PACKAGE_VERSION from configure script (cannot be sourced), so replace "=" and "'"
VERSION=(`grep "PACKAGE_VERSION=" configure | sed "s/=/ /g" | sed "s/'/ /g"`)
# Make a fake dpkg entry to be visible for apt
PACKAGE_NAME=swtpm_${VERSION[1]}
mkdir -p ${PACKAGE_NAME}/DEBIAN
mkdir -p ${PACKAGE_NAME}/usr/bin
# cp src/swtpm/.libs/swtpm ${PACKAGE_NAME}/usr/bin
echo "Package: swtpm" > ${PACKAGE_NAME}/DEBIAN/control
echo "Version: ${VERSION[1]}" >> ${PACKAGE_NAME}/DEBIAN/control
echo "Priority: optional" >> ${PACKAGE_NAME}/DEBIAN/control
echo "Architecture: amd64" >> ${PACKAGE_NAME}/DEBIAN/control
echo "Essential: no" >> ${PACKAGE_NAME}/DEBIAN/control
echo "Maintainer: Fake <fake@fake.com>" >> ${PACKAGE_NAME}/DEBIAN/control
echo "Description: Software TPM (swtpm)" >> ${PACKAGE_NAME}/DEBIAN/control
# Build the fake swtpm package
dpkg-deb --build --root-owner-group ${PACKAGE_NAME}
# Install the fake swtpm to add to dpkg entry
sudo gdebi -n ${PACKAGE_NAME}.deb
popd > /dev/null
rm -rf swtpm
fi
popd > /dev/null