1 %bcond_with connman_openconnect
2 %bcond_with connman_wireguard
3 %bcond_without connman_openvpn
4 %bcond_without connman_ipsec
5 %bcond_without connman_vpnd
11 Summary: Connection Manager
12 Url: http://connman.net
13 Group: Network & Connectivity/Connection Management
14 Source0: %{name}-%{version}.tar.gz
15 BuildRequires: systemd-devel
16 BuildRequires: pkgconfig(dlog)
17 BuildRequires: pkgconfig(dbus-1)
18 BuildRequires: pkgconfig(glib-2.0)
19 BuildRequires: pkgconfig(gio-2.0)
20 BuildRequires: pkgconfig(libiptc)
21 BuildRequires: pkgconfig(xtables)
22 BuildRequires: pkgconfig(libsmack)
23 BuildRequires: pkgconfig(libnl-3.0)
24 BuildRequires: pkgconfig(libnl-genl-3.0)
25 BuildRequires: pkgconfig(libsystemd-daemon)
26 %if %{with connman_openconnect}
27 BuildRequires: openconnect
29 %if %{with connman_openvpn}
30 BuildRequires: openvpn
32 %if %{with connman_ipsec}
33 BuildRequires: strongswan
35 BuildRequires: readline-devel
39 Requires(post): systemd
40 Requires(preun): systemd
41 Requires(postun): systemd
43 Requires: security-config
44 Provides: %{name}-profile_common = %{version}-%{release}
45 Provides: %{name}-profile_mobile = %{version}-%{release}
46 Provides: %{name}-profile_wearable = %{version}-%{release}
49 Connection Manager provides a daemon for managing Internet connections
50 within embedded devices running the Linux operating system.
52 %if %{with connman_openconnect}
53 %package plugin-openconnect
54 Summary: Openconnect Support for Connman
55 Requires: %{name} = %{version}
58 %description plugin-openconnect
59 Openconnect Support for Connman.
62 %if %{with connman_openvpn}
63 %package plugin-openvpn
64 Summary: Openvpn Support for Connman
65 Requires: %{name} = %{version}
68 %description plugin-openvpn
69 OpenVPN support for Connman.
72 %if %{with connman_ipsec}
74 Summary: IPsec Support for Connman
75 Requires: %{name} = %{version}
78 %description plugin-ipsec
79 OpenVPN support for Connman.
82 %if %{with connman_vpnd}
84 Summary: VPN Support for Connman
85 #BuildRequires: %{name} = %{version}
86 Requires: %{name} = %{version}
88 %description connman-vpnd
89 Provides VPN support for Connman
92 %if %{with connman_wireguard}
93 %package plugin-wireguard
94 Summary: Wireguard Support for Connman
95 BuildRequires: pkgconfig(libmnl)
96 Requires: %{name} = %{version}
98 %description plugin-wireguard
99 Wireguard Support for Connman.
103 Summary: Test Scripts for Connection Manager
104 Group: Development/Tools
105 Requires: %{name} = %{version}
106 Requires: dbus-python
111 Scripts for testing Connman and its functionality
114 Summary: Development Files for connman
115 Group: Development/Tools
116 Requires: %{name} = %{version}
119 Header files and development files for connman.
121 %package extension-tv
122 Summary: Connman service script for TV profile
123 Requires: %{name} = %{version}-%{release}
124 Provides: %{name}-profile_tv = %{version}-%{release}
125 Conflicts: %{name}-extension-ivi
126 Conflicts: %{name}-extension-disable-eth
127 %description extension-tv
128 Supplies Tizen TV profile systemd service scripts instead of the default one.
129 This overwrites service script of %{name}.
131 %package extension-ivi
132 Summary: Connman configuration for IVI profile
133 Requires: %{name} = %{version}-%{release}
134 Provides: %{name}-profile_ivi = %{version}-%{release}
135 Conflicts: %{name}-extension-tv
136 Conflicts: %{name}-extension-disable-eth
137 %description extension-ivi
138 Supplies Tizen IVI profile configuration instead of the default one.
139 This overwrites conf file of %{name}.
141 %package extension-disable-eth
142 Summary: Connman configuration for testing which requires the ethernet to be disabled
143 Requires: %{name} = %{version}-%{release}
144 Conflicts: %{name}-extension-tv
145 Conflicts: %{name}-extension-ivi
146 %description extension-disable-eth
147 Connman without ethernet support
148 This overwrites conf file of %{name}.
155 %if %{with connman_vpnd}
156 VPN_CFLAGS+=" -DTIZEN_EXT -lsmack -Werror"
165 --disable-tizen-ext-ins \
166 --enable-tizen-ext-eap-on-ethernet \
168 --enable-wifi=builtin \
169 %if %{with connman_openconnect}
170 --enable-openconnect \
172 %if %{with connman_openvpn}
175 %if %{with connman_ipsec}
178 %if %{without connman_wireguard}
179 --disable-wireguard \
181 %if 0%{?enable_connman_features}
185 --enable-telephony=builtin \
189 --with-systemdunitdir=%{_unitdir} \
192 --disable-backtrace \
200 #Systemd service file
201 mkdir -p %{buildroot}%{_unitdir}
203 cp src/connman_tv.service %{buildroot}%{_unitdir}/connman.service.tv
204 cp src/connman.service %{buildroot}%{_unitdir}/connman.service
205 cp vpn/connman-vpn.service %{buildroot}%{_unitdir}/connman-vpn.service
207 mkdir -p %{buildroot}%{_unitdir}/multi-user.target.wants
208 ln -s ../connman.service %{buildroot}%{_unitdir}/multi-user.target.wants/connman.service
210 #Systemd socket file for DNS proxy
211 cp src/connman.socket %{buildroot}%{_unitdir}/connman.socket
212 mkdir -p %{buildroot}%{_unitdir}/sockets.target.wants
213 ln -s ../connman.socket %{buildroot}%{_unitdir}/sockets.target.wants/connman.socket
215 mkdir -p %{buildroot}/%{_localstatedir}/lib/connman
216 cp resources/var/lib/connman/settings %{buildroot}/%{_localstatedir}/lib/connman/settings
217 mkdir -p %{buildroot}%{_datadir}/dbus-1/system-services
218 cp resources/usr/share/dbus-1/system-services/net.connman.service %{buildroot}%{_datadir}/dbus-1/system-services/net.connman.service
219 mkdir -p %{buildroot}/etc/connman
221 cp src/main_ivi.conf %{buildroot}/etc/connman/main.conf.ivi
222 cp src/main_tv.conf %{buildroot}/etc/connman/main.conf.tv
223 cp src/main_disable_eth.conf %{buildroot}/etc/connman/main.conf.disable.eth
224 cp src/main.conf %{buildroot}/etc/connman/main.conf
226 rm %{buildroot}%{_sysconfdir}/dbus-1/system.d/*.conf
227 mkdir -p %{buildroot}%{_sysconfdir}/dbus-1/system.d/
228 cp src/connman.conf %{buildroot}%{_sysconfdir}/dbus-1/system.d/
230 %if %{with connman_vpnd}
231 cp vpn/vpn-dbus.conf %{buildroot}%{_sysconfdir}/dbus-1/system.d/connman-vpn-dbus.conf
235 #chsmack -a 'System' /%{_localstatedir}/lib/connman
236 #chsmack -a 'System' /%{_localstatedir}/lib/connman/settings
241 systemctl daemon-reload
246 %manifest connman.manifest
247 %attr(500,network_fw,network_fw) %{_bindir}/connmand
248 %attr(500,network_fw,network_fw) %{_bindir}/connmanctl
249 %attr(755,network_fw,network_fw) /%{_localstatedir}/lib/connman
250 %attr(600,network_fw,network_fw) /%{_localstatedir}/lib/connman/settings
251 %attr(644,root,root) %{_datadir}/dbus-1/system-services/net.connman.service
252 %attr(644,root,root) %{_sysconfdir}/dbus-1/system.d/*
253 %attr(644,network_fw,network_fw) %{_sysconfdir}/connman/main.conf
254 %attr(644,root,root) %{_sysconfdir}/dbus-1/system.d/*.conf
255 %attr(644,root,root) %{_unitdir}/connman.service
256 %attr(644,root,root) %{_unitdir}/multi-user.target.wants/connman.service
257 %attr(644,root,root) %{_unitdir}/connman.socket
258 %attr(644,root,root) %{_unitdir}/sockets.target.wants/connman.socket
262 %manifest connman.manifest
263 %{_libdir}/%{name}/test/*
266 %manifest connman.manifest
268 %{_libdir}/pkgconfig/*.pc
270 %if %{with connman_openconnect}
271 %files plugin-openconnect
272 %manifest %{name}.manifest
273 %{_libdir}/connman/plugins-vpn/openconnect.so
274 %{_libdir}/connman/scripts/openconnect-script
278 %if %{with connman_openvpn}
279 %files plugin-openvpn
280 %manifest %{name}.manifest
281 %{_libdir}/%{name}/plugins-vpn/openvpn.so
282 %{_libdir}/%{name}/scripts/openvpn-script
286 %if %{with connman_ipsec}
288 %manifest %{name}.manifest
289 %{_libdir}/%{name}/plugins-vpn/ipsec.so
290 %{_libdir}/%{name}/scripts/ipsec-script
294 %if %{with connman_vpnd}
296 %manifest %{name}.manifest
297 %{_bindir}/connman-vpnd
298 %dir %{_libdir}/%{name}
299 %dir %{_libdir}/%{name}/scripts
300 %dir %{_libdir}/%{name}/plugins-vpn
301 %attr(644,root,root) %config %{_sysconfdir}/dbus-1/system.d/connman-vpn-dbus.conf
302 %{_datadir}/dbus-1/system-services/net.connman.vpn.service
304 %attr(644,root,root) %{_unitdir}/connman-vpn.service
307 %if %{with connman_wireguard}
308 %files plugin-wireguard
309 %manifest %{name}.manifest
310 %{_libdir}/%{name}/plugins-vpn/wireguard.so
315 mv -f %{_unitdir}/connman.service.tv %{_unitdir}/connman.service
316 mv -f %{_sysconfdir}/connman/main.conf.tv %{_sysconfdir}/connman/main.conf
318 %attr(644,network_fw,network_fw) %{_sysconfdir}/connman/main.conf.tv
320 %attr(644,root,root) %{_unitdir}/connman.service.tv
322 mv -f %{_sysconfdir}/connman/main.conf.ivi %{_sysconfdir}/connman/main.conf
324 %attr(644,network_fw,network_fw) %{_sysconfdir}/connman/main.conf.ivi
326 %post extension-disable-eth
327 mv -f %{_sysconfdir}/connman/main.conf.disable.eth %{_sysconfdir}/connman/main.conf
328 %files extension-disable-eth
329 %attr(644,network_fw,network_fw) %{_sysconfdir}/connman/main.conf.disable.eth