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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
|
%bcond_with connman_openconnect
%bcond_without connman_wireguard
%bcond_without connman_openvpn
%bcond_without connman_ipsec
%bcond_without connman_vpnd
Name: connman
Version: 1.41
Release: 2
License: GPL-2.0+
Summary: Connection Manager
Url: http://connman.net
Group: Network & Connectivity/Connection Management
Source0: %{name}-%{version}.tar.gz
BuildRequires: systemd-devel
BuildRequires: pkgconfig(dlog)
BuildRequires: pkgconfig(dbus-1)
BuildRequires: pkgconfig(glib-2.0)
BuildRequires: pkgconfig(gio-2.0)
BuildRequires: pkgconfig(libiptc)
BuildRequires: pkgconfig(xtables)
BuildRequires: pkgconfig(libsmack)
BuildRequires: pkgconfig(libnl-3.0)
BuildRequires: pkgconfig(libnl-genl-3.0)
BuildRequires: pkgconfig(libsystemd)
%if %{with connman_openconnect}
BuildRequires: openconnect
%endif
%if %{with connman_openvpn}
BuildRequires: openvpn
%endif
%if %{with connman_ipsec}
BuildRequires: strongswan
%endif
BuildRequires: readline-devel
#%systemd_requires
Requires: iptables
Requires: systemd
Requires(post): systemd
Requires(preun): systemd
Requires(postun): systemd
Requires: security-config
Provides: %{name}-profile_common = %{version}-%{release}
Provides: %{name}-profile_mobile = %{version}-%{release}
Provides: %{name}-profile_wearable = %{version}-%{release}
Provides: %{name}-profile_robot = %{version}-%{release}
%description
Connection Manager provides a daemon for managing Internet connections
within embedded devices running the Linux operating system.
%if %{with connman_openconnect}
%package plugin-openconnect
Summary: Openconnect Support for Connman
Requires: %{name} = %{version}
Requires: openconnect
%description plugin-openconnect
Openconnect Support for Connman.
%endif
%if %{with connman_openvpn}
%package plugin-openvpn
Summary: Openvpn Support for Connman
Requires: %{name} = %{version}
Requires: openvpn
%description plugin-openvpn
OpenVPN support for Connman.
%endif
%if %{with connman_ipsec}
%package plugin-ipsec
Summary: IPsec Support for Connman
Requires: %{name} = %{version}
Requires: strongswan
%description plugin-ipsec
OpenVPN support for Connman.
%endif
%if %{with connman_vpnd}
%package connman-vpnd
Summary: VPN Support for Connman
#BuildRequires: %{name} = %{version}
Requires: %{name} = %{version}
%description connman-vpnd
Provides VPN support for Connman
%endif
%if %{with connman_wireguard}
%package plugin-wireguard
Summary: Wireguard Support for Connman
BuildRequires: pkgconfig(libmnl)
Requires: %{name} = %{version}
%description plugin-wireguard
Wireguard Support for Connman.
%endif
%package test
Summary: Test Scripts for Connection Manager
Group: Development/Tools
Requires: %{name} = %{version}
Requires: dbus-python
Requires: pygobject
Requires: python-xml
%description test
Scripts for testing Connman and its functionality
%package devel
Summary: Development files for connman
Group: Development/Tools
Requires: %{name} = %{version}
%description devel
Header files and development files for connman.
%package extension-tv
Summary: Connman service script for TV profile
Requires: %{name} = %{version}-%{release}
Provides: %{name}-profile_tv = %{version}-%{release}
Conflicts: %{name}-extension-ivi
Conflicts: %{name}-extension-disable-eth
%description extension-tv
Supplies Tizen TV profile systemd service scripts instead of the default one.
This overwrites service script of %{name}.
%package extension-ivi
Summary: Connman configuration for IVI profile
Requires: %{name} = %{version}-%{release}
Provides: %{name}-profile_ivi = %{version}-%{release}
Conflicts: %{name}-extension-tv
Conflicts: %{name}-extension-disable-eth
%description extension-ivi
Supplies Tizen IVI profile configuration instead of the default one.
This overwrites conf file of %{name}.
%package extension-disable-eth
Summary: Connman configuration for testing which requires the ethernet to be disabled
Requires: %{name} = %{version}-%{release}
Conflicts: %{name}-extension-tv
Conflicts: %{name}-extension-ivi
%description extension-disable-eth
Connman without ethernet support
This overwrites conf file of %{name}.
%package profile_robot
Summary: connman extension for robot profile
Requires: %{name} = %{version}-%{release}
%description profile_robot
connman extension for Tizen robot profile
%package isu
Summary: connman ISU pacakge
Group: Network & Connectivity/Connection Management
%description isu
Configuration files to generate the ISU (Individual Service Upgrade) package
%prep
%setup -q
%build
%if %{with connman_vpnd}
VPN_CFLAGS+=" -DTIZEN_EXT -lsmack -Werror"
%endif
chmod +x bootstrap
./bootstrap
%configure \
--sysconfdir=/etc \
--enable-client \
--enable-tizen-ext \
--disable-tizen-ext-ins \
--enable-tizen-ext-eap-on-ethernet \
--enable-pacrunner \
--enable-wifi=builtin \
%if %{with connman_openconnect}
--enable-openconnect \
%endif
%if %{with connman_openvpn}
--enable-openvpn \
%endif
%if %{with connman_ipsec}
--enable-ipsec \
%endif
%if %{without connman_wireguard}
--disable-wireguard \
%endif
%if 0%{?enable_connman_features}
%connman_features \
%endif
--disable-ofono \
--enable-telephony=builtin \
--enable-test \
--enable-loopback \
--enable-ethernet \
--with-systemdunitdir=%{_unitdir} \
--enable-pie \
--disable-wispr \
--disable-backtrace \
--disable-tools
make %{?_smp_mflags}
%install
%make_install
#Systemd service file
mkdir -p %{buildroot}%{_unitdir}
cp src/connman_tv.service %{buildroot}%{_unitdir}/connman.service.tv
cp src/connman.service %{buildroot}%{_unitdir}/connman.service
cp vpn/connman-vpn.service %{buildroot}%{_unitdir}/connman-vpn.service
mkdir -p %{buildroot}%{_unitdir}/multi-user.target.wants
ln -s ../connman.service %{buildroot}%{_unitdir}/multi-user.target.wants/connman.service
#Systemd socket file for DNS proxy
cp src/connman.socket %{buildroot}%{_unitdir}/connman.socket
mkdir -p %{buildroot}%{_unitdir}/sockets.target.wants
ln -s ../connman.socket %{buildroot}%{_unitdir}/sockets.target.wants/connman.socket
mkdir -p %{buildroot}/%{_localstatedir}/lib/connman
cp resources/var/lib/connman/settings %{buildroot}/%{_localstatedir}/lib/connman/settings
mkdir -p %{buildroot}%{_datadir}/dbus-1/system-services
cp resources/usr/share/dbus-1/system-services/net.connman.service %{buildroot}%{_datadir}/dbus-1/system-services/net.connman.service
mkdir -p %{buildroot}/etc/connman
cp src/main_ivi.conf %{buildroot}/etc/connman/main.conf.ivi
cp src/main_tv.conf %{buildroot}/etc/connman/main.conf.tv
cp src/main_disable_eth.conf %{buildroot}/etc/connman/main.conf.disable.eth
cp src/main_robot.conf %{buildroot}/etc/connman/main.conf.robot
cp src/main.conf %{buildroot}/etc/connman/main.conf
rm %{buildroot}%{_sysconfdir}/dbus-1/system.d/*.conf
mkdir -p %{buildroot}%{_sysconfdir}/dbus-1/system.d/
cp src/connman.conf %{buildroot}%{_sysconfdir}/dbus-1/system.d/
cp src/connman-robot.conf %{buildroot}%{_sysconfdir}/dbus-1/system.d/
%if %{with connman_vpnd}
cp vpn/vpn-dbus.conf %{buildroot}%{_sysconfdir}/dbus-1/system.d/connman-vpn-dbus.conf
%endif
%post
#chsmack -a 'System' /%{_localstatedir}/lib/connman
#chsmack -a 'System' /%{_localstatedir}/lib/connman/settings
%preun
%postun
systemctl daemon-reload
%docs_package
%files
%manifest connman.manifest
%attr(500,network_fw,network_fw) %{_bindir}/connmand
%attr(500,network_fw,network_fw) %{_bindir}/connmanctl
%attr(600,network_fw,network_fw) /%{_localstatedir}/lib/connman/settings
%attr(644,root,root) %{_datadir}/dbus-1/system-services/net.connman.service
%attr(644,root,root) %{_sysconfdir}/dbus-1/system.d/*
%exclude %{_sysconfdir}/dbus-1/system.d/connman-robot.conf
%attr(644,network_fw,network_fw) %{_sysconfdir}/connman/main.conf
%attr(644,root,root) %{_sysconfdir}/dbus-1/system.d/*.conf
%attr(644,root,root) %{_unitdir}/connman.service
%attr(644,root,root) %{_unitdir}/multi-user.target.wants/connman.service
%attr(644,root,root) %{_unitdir}/connman.socket
%attr(644,root,root) %{_unitdir}/sockets.target.wants/connman.socket
%license COPYING
%files test
%manifest connman.manifest
%{_libdir}/%{name}/test/*
%files devel
%manifest connman.manifest
%{_includedir}/*
%{_libdir}/pkgconfig/*.pc
%if %{with connman_openconnect}
%files plugin-openconnect
%manifest %{name}.manifest
%{_libdir}/connman/plugins-vpn/openconnect.so
%{_libdir}/connman/scripts/openconnect-script
%license COPYING
%endif
%if %{with connman_openvpn}
%files plugin-openvpn
%manifest %{name}.manifest
%{_libdir}/%{name}/plugins-vpn/openvpn.so
%{_libdir}/%{name}/scripts/openvpn-script
%license COPYING
%endif
%if %{with connman_ipsec}
%files plugin-ipsec
%manifest %{name}.manifest
%{_libdir}/%{name}/plugins-vpn/ipsec.so
%{_libdir}/%{name}/scripts/ipsec-script
%license COPYING
%endif
%if %{with connman_vpnd}
%files connman-vpnd
%manifest %{name}.manifest
%{_bindir}/connman-vpnd
%dir %{_libdir}/%{name}
%dir %{_libdir}/%{name}/scripts
%dir %{_libdir}/%{name}/plugins-vpn
%attr(644,root,root) %config %{_sysconfdir}/dbus-1/system.d/connman-vpn-dbus.conf
%{_datadir}/dbus-1/system-services/net.connman.vpn.service
%license COPYING
%attr(644,root,root) %{_unitdir}/connman-vpn.service
%endif
%if %{with connman_wireguard}
%files plugin-wireguard
%manifest %{name}.manifest
%{_libdir}/%{name}/plugins-vpn/wireguard.so
%license COPYING
%endif
%post extension-tv
mv -f %{_unitdir}/connman.service.tv %{_unitdir}/connman.service
mv -f %{_sysconfdir}/connman/main.conf.tv %{_sysconfdir}/connman/main.conf
%files extension-tv
%attr(644,network_fw,network_fw) %{_sysconfdir}/connman/main.conf.tv
%license COPYING
%attr(644,root,root) %{_unitdir}/connman.service.tv
%post extension-ivi
mv -f %{_sysconfdir}/connman/main.conf.ivi %{_sysconfdir}/connman/main.conf
%files extension-ivi
%attr(644,network_fw,network_fw) %{_sysconfdir}/connman/main.conf.ivi
%license COPYING
%post extension-disable-eth
mv -f %{_sysconfdir}/connman/main.conf.disable.eth %{_sysconfdir}/connman/main.conf
%files extension-disable-eth
%attr(644,network_fw,network_fw) %{_sysconfdir}/connman/main.conf.disable.eth
%license COPYING
%post profile_robot
mv %{_sysconfdir}/dbus-1/system.d/connman-robot.conf %{_sysconfdir}/dbus-1/system.d/connman.conf
mv -f %{_sysconfdir}/connman/main.conf.robot %{_sysconfdir}/connman/main.conf
%files profile_robot
%manifest %{name}.manifest
%attr(644,root,root) %{_sysconfdir}/dbus-1/system.d/connman-robot.conf
%attr(644,network_fw,network_fw) %{_sysconfdir}/connman/main.conf.robot
%files isu
/etc/isu/connman/isu.cfg
/etc/isu/connman/system-services/connman.service
|