Move template for application Smack rules to security-manager-policy
[platform/core/security/security-manager.git] / packaging / security-manager.spec
1 Name:       security-manager
2 Summary:    Security manager and utilities
3 Version:    0.2.0
4 Release:    1
5 Group:      Security/Service
6 License:    Apache-2.0
7 Source0:    %{name}-%{version}.tar.gz
8 Source1:    security-manager.manifest
9 Source3:    libsecurity-manager-client.manifest
10 Requires: security-manager-policy
11 Requires(post): smack
12 BuildRequires: cmake
13 BuildRequires: zip
14 BuildRequires: libattr-devel
15 BuildRequires: pkgconfig(libsmack)
16 BuildRequires: pkgconfig(libcap)
17 BuildRequires: pkgconfig(libsystemd-daemon)
18 BuildRequires: pkgconfig(libsystemd-journal)
19 BuildRequires: pkgconfig(libtzplatform-config)
20 BuildRequires: pkgconfig(sqlite3)
21 BuildRequires: pkgconfig(db-util)
22 BuildRequires: pkgconfig(cynara-admin)
23 BuildRequires: pkgconfig(cynara-client)
24 BuildRequires: boost-devel
25 %{?systemd_requires}
26
27 %description
28 Tizen security manager and utilities
29
30 %package -n libsecurity-manager-client
31 Summary:    Security manager (client)
32 Group:      Security/Libraries
33 Requires:   security-manager = %{version}-%{release}
34 Requires(post): /sbin/ldconfig
35 Requires(postun): /sbin/ldconfig
36
37 %description -n libsecurity-manager-client
38 Tizen Security manager client library
39
40 %package -n libsecurity-manager-client-devel
41 Summary:    Security manager (client-devel)
42 Group:      Security/Development
43 Requires:   libsecurity-manager-client = %{version}-%{release}
44
45 %description -n libsecurity-manager-client-devel
46 Development files needed for using the security manager client
47
48 %package policy
49 Summary:    Security manager policy
50 Group:      Security/Access Control
51 Requires(post): security-manager = %{version}-%{release}
52 Requires(post): cyad
53
54 %description policy
55 Set of security rules that constitute security policy in the system
56
57 %prep
58 %setup -q
59 cp %{SOURCE1} .
60 cp %{SOURCE3} .
61
62 %build
63 %if 0%{?sec_build_binary_debug_enable}
64 export CFLAGS="$CFLAGS -DTIZEN_DEBUG_ENABLE"
65 export CXXFLAGS="$CXXFLAGS -DTIZEN_DEBUG_ENABLE"
66 export FFLAGS="$FFLAGS -DTIZEN_DEBUG_ENABLE"
67 %endif
68
69 export LDFLAGS+="-Wl,--rpath=%{_libdir}"
70
71 %cmake . -DVERSION=%{version} \
72         -DBIN_INSTALL_DIR=%{_bindir} \
73         -DDB_INSTALL_DIR=%{TZ_SYS_DB} \
74         -DSYSTEMD_INSTALL_DIR=%{_unitdir} \
75         -DCMAKE_BUILD_TYPE=%{?build_type:%build_type}%{!?build_type:RELEASE} \
76         -DCMAKE_VERBOSE_MAKEFILE=ON
77 make %{?jobs:-j%jobs}
78
79 %install
80 rm -rf %{buildroot}
81 mkdir -p %{buildroot}%{_datadir}/license
82 cp LICENSE %{buildroot}%{_datadir}/license/%{name}
83 cp LICENSE %{buildroot}%{_datadir}/license/libsecurity-manager-client
84 %make_install
85
86 mkdir -p %{buildroot}/%{_unitdir}/sockets.target.wants
87 ln -s ../security-manager.socket %{buildroot}/%{_unitdir}/sockets.target.wants/security-manager.socket
88
89 %clean
90 rm -rf %{buildroot}
91
92 %post
93 /sbin/ldconfig
94 systemctl daemon-reload
95 if [ $1 = 1 ]; then
96     # installation
97     systemctl start security-manager.service
98 fi
99
100 if [ $1 = 2 ]; then
101     # update
102     systemctl restart security-manager.service
103 fi
104 chsmack -a System %{TZ_SYS_DB}/.security-manager.db
105 chsmack -a System %{TZ_SYS_DB}/.security-manager.db-journal
106
107 %preun
108 if [ $1 = 0 ]; then
109     # unistall
110     systemctl stop security-manager.service
111 fi
112
113 %postun
114 /sbin/ldconfig
115 if [ $1 = 0 ]; then
116     # unistall
117     systemctl daemon-reload
118 fi
119
120 %post -n libsecurity-manager-client -p /sbin/ldconfig
121
122 %postun -n libsecurity-manager-client -p /sbin/ldconfig
123
124 %post policy
125 %{_bindir}/security-manager-policy-reload
126
127 %files -n security-manager
128 %manifest security-manager.manifest
129 %defattr(-,root,root,-)
130 %attr(755,root,root) %{_bindir}/security-manager
131 %attr(755,root,root) %{_bindir}/security-manager-cmd
132 %attr(755,root,root) %{_sysconfdir}/gumd/useradd.d/50_security-manager-add.post
133 %attr(755,root,root) %{_sysconfdir}/gumd/userdel.d/50_security-manager-remove.pre
134
135 %{_libdir}/libsecurity-manager-commons.so.*
136 %attr(-,root,root) %{_unitdir}/security-manager.*
137 %attr(-,root,root) %{_unitdir}/sockets.target.wants/security-manager.*
138 %config(noreplace) %attr(0600,root,root) %{TZ_SYS_DB}/.security-manager.db
139 %config(noreplace) %attr(0600,root,root) %{TZ_SYS_DB}/.security-manager.db-journal
140 %{_datadir}/license/%{name}
141
142 %files -n libsecurity-manager-client
143 %manifest libsecurity-manager-client.manifest
144 %defattr(-,root,root,-)
145 %{_libdir}/libsecurity-manager-client.so.*
146 %{_datadir}/license/libsecurity-manager-client
147
148 %files -n libsecurity-manager-client-devel
149 %manifest %{name}.manifest
150 %defattr(-,root,root,-)
151 %{_libdir}/libsecurity-manager-client.so
152 %{_libdir}/libsecurity-manager-commons.so
153 %{_includedir}/security-manager/security-manager.h
154 %{_libdir}/pkgconfig/security-manager.pc
155
156 %files -n security-manager-policy
157 %manifest %{name}.manifest
158 %{_datadir}/security-manager/policy
159 %attr(755,root,root) %{_bindir}/security-manager-policy-reload