Remove cert-checker dependency
[platform/core/security/cert-svc.git] / packaging / cert-svc.spec
1 %define certsvc_test_build 0
2
3 Name:    cert-svc
4 Summary: Certification service
5 Version: 2.1.6
6 Release: 0
7 Group:   Security/Certificate Management
8 License: Apache-2.0 and OpenSSL
9 Source0: %{name}-%{version}.tar.gz
10 BuildRequires: cmake
11 BuildRequires: coreutils
12 BuildRequires: findutils
13 BuildRequires: openssl
14 BuildRequires: pkgconfig(dlog)
15 BuildRequires: pkgconfig(openssl)
16 BuildRequires: pkgconfig(libpcrecpp)
17 BuildRequires: pkgconfig(xmlsec1)
18 BuildRequires: pkgconfig(libxml-2.0)
19 BuildRequires: pkgconfig(libxslt)
20 BuildRequires: pkgconfig(db-util)
21 BuildRequires: pkgconfig(libsystemd-daemon)
22 BuildRequires: pkgconfig(key-manager)
23 BuildRequires: pkgconfig(libtzplatform-config)
24 BuildRequires: pkgconfig(libsystemd-journal)
25 BuildRequires: pkgconfig(sqlite3)
26 BuildRequires: ca-certificates
27 BuildRequires: ca-certificates-devel
28 BuildRequires: ca-certificates-tizen-devel
29 Requires: ca-certificates
30 Requires: ca-certificates-tizen
31 Requires: security-config
32 Requires: openssl
33
34 %global user_name security_fw
35 %global group_name security_fw
36 %global server_stream /tmp/.cert-server.socket
37 %global smack_domain_name System
38
39 %global bin_dir                 %{?TZ_SYS_BIN:%TZ_SYS_BIN}%{!?TZ_SYS_BIN:%_bindir}
40 %global etc_dir                 %{?TZ_SYS_ETC:%TZ_SYS_ETC}%{!?TZ_SYS_ETC:/opt/etc}
41 %global rw_data_dir             %{?TZ_SYS_SHARE:%TZ_SYS_SHARE}%{!?TZ_SYS_SHARE:/opt/share}
42 %global ro_data_dir             %{?TZ_SYS_RO_SHARE:%TZ_SYS_RO_SHARE}%{!?TZ_SYS_RO_SHARE:%_datadir}
43 %global rw_app_dir              %{?TZ_SYS_RW_APP:%TZ_SYS_RW_APP}%{!?TZ_SYS_RW_APP:/opt/usr/apps}
44
45 %global cert_svc_path           %rw_data_dir/cert-svc
46 %global cert_svc_ro_path        %ro_data_dir/cert-svc
47 %global cert_svc_db_path        %cert_svc_path/dbspace
48 %global cert_svc_pkcs12         %cert_svc_path/pkcs12
49 %global cert_svc_ca_bundle      %cert_svc_path/ca-certificate.crt
50 %global cert_svc_tests          %rw_app_dir/cert-svc-tests
51
52 %global cert_svc_old_db_path    /opt/share/cert-svc/dbspace
53 %global upgrade_script_path     %ro_data_dir/upgrade/scripts
54 %global upgrade_data_path       %ro_data_dir/upgrade/data
55
56 %description
57 Certification service
58
59 %package devel
60 Summary:    Certification service (development files)
61 Group:      Development/Libraries
62 Requires:   %{name} = %{version}-%{release}
63
64 %description devel
65 Certification service (development files)
66
67 %if 0%{?certsvc_test_build}
68 %package test
69 Summary:  Certification service (tests)
70 Group:    Security/Testing
71 Requires: ca-certificates-tizen
72 Requires: %{name} = %{version}-%{release}
73
74 %description test
75 Certification service (tests)
76 %endif
77
78 %prep
79 %setup -q
80
81 %build
82 export CFLAGS="$CFLAGS -DTIZEN_DEBUG_ENABLE"
83 export CXXFLAGS="$CXXFLAGS -DTIZEN_DEBUG_ENABLE"
84 export FFLAGS="$FFLAGS -DTIZEN_DEBUG_ENABLE"
85
86 export CFLAGS="$CFLAGS -DTIZEN_ENGINEER_MODE"
87 export CXXFLAGS="$CXXFLAGS -DTIZEN_ENGINEER_MODE"
88 export FFLAGS="$FFLAGS -DTIZEN_ENGINEER_MODE"
89
90 %ifarch %{ix86}
91 export CFLAGS="$CFLAGS -DTIZEN_EMULATOR_MODE"
92 export CXXFLAGS="$CXXFLAGS -DTIZEN_EMULATOR_MODE"
93 export FFLAGS="$FFLAGS -DTIZEN_EMULATOR_MODE"
94 %endif
95
96 %{!?build_type:%define build_type "Release"}
97 %cmake . -DVERSION=%version \
98          -DINCLUDEDIR=%_includedir \
99          -DUSER_NAME=%user_name \
100          -DGROUP_NAME=%group_name \
101          -DSERVER_STREAM=%server_stream \
102          -DSMACK_DOMAIN_NAME=%smack_domain_name \
103          -DRO_DATA_DIR=%ro_data_dir \
104          -DBIN_DIR=%bin_dir \
105          -DTZ_SYS_CA_CERTS=%TZ_SYS_CA_CERTS \
106          -DTZ_SYS_CA_CERTS_ORIG=%TZ_SYS_CA_CERTS_ORIG \
107          -DTZ_SYS_CA_BUNDLE=%TZ_SYS_CA_BUNDLE \
108          -DCERT_SVC_CA_BUNDLE=%cert_svc_ca_bundle \
109          -DFINGERPRINT_LIST_RW_PATH=%TZ_SYS_REVOKED_CERTS_FINGERPRINTS_RUNTIME \
110          -DCERT_SVC_PATH=%cert_svc_path \
111          -DCERT_SVC_RO_PATH=%cert_svc_ro_path \
112          -DCERT_SVC_PKCS12=%cert_svc_pkcs12 \
113          -DCERT_SVC_DB_PATH=%cert_svc_db_path \
114          -DCERT_SVC_OLD_DB_PATH=%cert_svc_old_db_path \
115          -DUPGRADE_SCRIPT_PATH=%upgrade_script_path \
116          -DUPGRADE_DATA_PATH=%upgrade_data_path \
117 %if 0%{?certsvc_test_build}
118          -DCERTSVC_TEST_BUILD=1 \
119          -DCERT_SVC_TESTS=%cert_svc_tests \
120 %endif
121          -DCMAKE_BUILD_TYPE=%build_type \
122          -DSYSTEMD_UNIT_DIR=%_unitdir
123
124 make %{?_smp_mflags}
125
126 %install
127 %make_install
128 %install_service sockets.target.wants cert-server.socket
129
130 mkdir -p %buildroot%cert_svc_pkcs12
131
132 touch %buildroot%cert_svc_db_path/certs-meta.db-journal
133
134 ln -sf %TZ_SYS_CA_BUNDLE %buildroot%cert_svc_ca_bundle
135
136 %preun
137 # erase
138 if [ $1 = 0 ]; then
139     systemctl stop cert-server.service
140 fi
141
142 %post
143 /sbin/ldconfig
144 systemctl daemon-reload
145 # install
146 if [ $1 = 1 ]; then
147     systemctl start cert-server.socket
148 fi
149 # upgrade / reinstall
150 if [ $1 = 2 ]; then
151     systemctl restart cert-server.socket
152 fi
153
154 %postun -p /sbin/ldconfig
155
156 %files
157 %manifest %name.manifest
158 %license LICENSE
159 %license LICENSE.OpenSSL
160 %_unitdir/cert-server.service
161 %_unitdir/cert-server.socket
162 %_unitdir/sockets.target.wants/cert-server.socket
163 %_libdir/libcert-svc-vcore.so.*
164 %bin_dir/cert-server
165 %dir %attr(-, %{user_name}, %{group_name}) %cert_svc_path
166 %dir %attr(-, %{user_name}, %{group_name}) %cert_svc_pkcs12
167 %dir %attr(-, %{user_name}, %{group_name}) %cert_svc_db_path
168 %attr(-, %{user_name}, %{group_name}) %cert_svc_ca_bundle
169 %attr(-, %{user_name}, %{group_name}) %cert_svc_db_path/certs-meta.db
170 %attr(-, %{user_name}, %{group_name}) %cert_svc_db_path/certs-meta.db-journal
171 %attr(-, %{user_name}, %{group_name}) %cert_svc_ro_path
172
173 %attr(755, root, root) %upgrade_script_path/202.cert-svc-db-upgrade.sh
174 %attr(755, root, root) %upgrade_script_path/203.cert-svc-disabled-certs-upgrade.sh
175 %upgrade_data_path/certs-meta.db
176
177 %files devel
178 %_includedir/*
179 %_libdir/pkgconfig/*
180 %_libdir/libcert-svc-vcore.so
181
182 %if 0%{?certsvc_test_build}
183 %files test
184 %bin_dir/cert-svc-test*
185 %cert_svc_tests
186 %_libdir/libcert-svc-validator-plugin.so
187 %attr(755, root, root) %upgrade_script_path/cert-svc-test-upgrade.sh
188 %upgrade_data_path/certs-meta-old.db
189 %endif