]> pere.pagekite.me Git - homepage.git/blob - blog/No_hardcoded_config_on_Debian_Edu_clients.html
Generated.
[homepage.git] / blog / No_hardcoded_config_on_Debian_Edu_clients.html
1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
2 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
3 <html xmlns="http://www.w3.org/1999/xhtml" dir="ltr">
4 <head>
5 <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
6 <title>Petter Reinholdtsen: No hardcoded config on Debian Edu clients</title>
7 <link rel="stylesheet" type="text/css" media="screen" href="http://people.skolelinux.org/pere/blog/style.css" />
8 <link rel="stylesheet" type="text/css" media="screen" href="http://people.skolelinux.org/pere/blog/vim.css" />
9
10
11 </head>
12 <body>
13 <div class="title">
14 <h1>
15 <a href="http://people.skolelinux.org/pere/blog/">Petter Reinholdtsen</a>
16
17 </h1>
18
19 </div>
20
21
22 <div class="entry">
23 <div class="title">No hardcoded config on Debian Edu clients</div>
24 <div class="date"> 9th August 2010</div>
25 <div class="body"><p>As reported earlier, the last few days I have looked at how Debian
26 Edu clients are configured, and tried to get rid of all hardcoded
27 configuration settings on the clients. I believe the work to be
28 mostly done, and the clients seem to work just fine with dynamically
29 generated configuration.</p>
30
31 <p>What is the point, you might ask? The point is to allow a Debian
32 Edu desktop to integrate into an existing network infrastructure
33 without any manual configuration.</p>
34
35 <p>This is what happens when installing a Debian Edu client here at
36 the University of Oslo using PXE. With the PXE installation, I am
37 asked for language (Norwegian Bokmål), locality (Norway) and keyboard
38 layout (no-latin1), Debian Edu profile (Roaming Workstation), if I
39 accept to reformat the hard drive (yes), if I want to submit info to
40 popcon.debian.org (no) and root password (secret). After answering
41 these questions, the installer goes ahead and does its thing, and
42 after around 50 minutes it is done. I press enter to finish the
43 installation, and the machine reboots into KDE. When the machine is
44 ready and kdm asks for login information, I enter my university
45 username and password, am told by kdm that a local home directory has
46 been created and that I must log in again, and finally log in with the
47 same username and password to the KDE 4.4 desktop. At no point during
48 this process did it ask for university specific settings, and all the
49 required configuration was dynamically detected using information
50 fetched via DHCP and DNS. The roaming workstation is now ready for
51 use.</p>
52
53 <p>How was this done, you might wonder? First of all, here is the
54 list of things that need to be configured on the client to get it
55 working properly out of the box:</p>
56
57 <ul>
58 <li>IP address/netmask and DNS server.</li>
59 <li>Web proxy URL.</li>
60 <li>LDAP server for NSS directory information (user, group, etc).</li>
61 <li>Kerberos server for PAM password checking.</li>
62 <li>SMB mount point to access the network home directory. (*)</li>
63 <li>Central syslog server to send syslog messages to. (*)</li>
64 <li>Sitesummary collector URL to submit info to central server. (*)</li>
65 </ul>
66
67 <p>(Hm, did I forget anything? Let me knew if I did.)</p>
68
69 <p>The points marked (*) are not required to be able to use the
70 machine, but needed to provide central storage and allowing system
71 administrators to track their machines. Since yesterday, everything
72 but the sitesummary collector URL is dynamically discovered at boot
73 and installation time in the svn version of Debian Edu.</p>
74
75 <p>The IP and DNS setup is fetched during boot using DHCP as usual.
76 When a DHCP update arrives, the proxy setup is updated by looking for
77 http://wpat/wpad.dat and using the content of this WPAD file to
78 configure the http and ftp proxy in /etc/environment and
79 /etc/apt/apt.conf. I decided to update the proxy setup using a DHCP
80 hook to ensure that the client stops using the Debian Edu proxy when
81 it is moved outside the Debian Edu network, and instead uses any local
82 proxy present on the new network when it moves around.</p>
83
84 <p>The DNS names of the LDAP, Kerberos and syslog server and related
85 configuration are generated using DNS information at boot. First the
86 installer looks for a host named ldap in the current DNS domain. If
87 not found, it looks for _ldap._tcp SRV records in DNS instead. If an
88 LDAP server is found, its root DSE entry is requested and the
89 attributes namingContexts and defaultNamingContext are used to
90 determine which LDAP base to use for NSS. If there are several
91 namingContexts attibutes and the defaultNamingContext is present, that
92 LDAP subtree is used as the base. If defaultNamingContext is missing,
93 the subtrees listed as namingContexts are searched in sequence for any
94 object with class posixAccount or posixGroup, and the first one with
95 such an object is used as the LDAP base. For Kerberos, a similar
96 search is done by first looking for a host named kerberos, and then
97 for the _kerberos._tcp SRV record. I've been unable to find a way to
98 look up the Kerberos realm, so for this the upper case string of the
99 current DNS domain is used.</p>
100
101 <p>For the syslog server, the hosts syslog and loghost are searched
102 for, and the _syslog._udp SRV record is consulted if no such host is
103 found. This algorithm works for both Debian Edu and the University of
104 Oslo. A similar strategy would work for locating the sitesummary
105 server, but have not been implemented yet. I decided to fetch and
106 save these settings during installation, to make sure moving to a
107 different network does not change the set of users being allowed to
108 log in nor the passwords required to log in. Usernames and passwords
109 will be cached by sssd when the user logs in on the Debian Edu
110 network, and will not change as the laptop move around. For a
111 non-roaming machine, there is no caching, but given that it is
112 supposed to stay in place it should not matter much. Perhaps we
113 should switch those to use sssd too?</p>
114
115 <p>The user's SMB mount point for the network home directory is
116 located when the user logs in for the first time. The LDAP server is
117 consulted to look for the user's LDAP object and the sambaHomePath
118 attribute is used if found. If it isn't found, the home directory
119 path fetched from NSS is used instead. Assuming the path is of the
120 form /site/server/directory/username, the second part is looked up in
121 DNS and used to generate a SMB URL of the form
122 smb://server.domain/username. This algorithm works for both Debian
123 edu and the University of Oslo. Perhaps there are better attributes
124 to use or a better algorithm that works for more sites, but this will
125 do for now. :)</p>
126
127 <p>This work should make it easier to integrate the Debian Edu clients
128 into any LDAP/Kerberos infrastructure, and make the current setup even
129 more flexible than before. I suspect it will also work for thin
130 client servers, allowing one to easily set up LTSP and hook it into a
131 existing network infrastructure, but I have not had time to test this
132 yet.</p>
133
134 <p>If you want to help out with implementing these things for Debian
135 Edu, please contact us on debian-edu@lists.debian.org.</p>
136
137 <p>Update 2010-08-09: Simon Farnsworth gave me a heads-up on how to
138 detect Kerberos realm from DNS, by looking for _kerberos TXT entries
139 before falling back to the upper case DNS domain name. Will have to
140 implement it for Debian Edu. :)</p>
141 </div>
142
143 <div class="tags">Tags: <a href="http://people.skolelinux.org/pere/blog/tags/debian edu">debian edu</a>, <a href="http://people.skolelinux.org/pere/blog/tags/english">english</a>, <a href="http://people.skolelinux.org/pere/blog/tags/nuug">nuug</a>.</div>
144
145
146 </div>
147
148
149
150
151 <div id="sidebar">
152
153
154
155 <h2>Archive</h2>
156 <ul>
157
158 <li>2019
159 <ul>
160
161 <li><a href="http://people.skolelinux.org/pere/blog/archive/2019/01/">January (4)</a></li>
162
163 <li><a href="http://people.skolelinux.org/pere/blog/archive/2019/02/">February (3)</a></li>
164
165 <li><a href="http://people.skolelinux.org/pere/blog/archive/2019/03/">March (3)</a></li>
166
167 <li><a href="http://people.skolelinux.org/pere/blog/archive/2019/05/">May (2)</a></li>
168
169 <li><a href="http://people.skolelinux.org/pere/blog/archive/2019/06/">June (5)</a></li>
170
171 <li><a href="http://people.skolelinux.org/pere/blog/archive/2019/07/">July (2)</a></li>
172
173 <li><a href="http://people.skolelinux.org/pere/blog/archive/2019/08/">August (1)</a></li>
174
175 <li><a href="http://people.skolelinux.org/pere/blog/archive/2019/09/">September (1)</a></li>
176
177 </ul></li>
178
179 <li>2018
180 <ul>
181
182 <li><a href="http://people.skolelinux.org/pere/blog/archive/2018/01/">January (1)</a></li>
183
184 <li><a href="http://people.skolelinux.org/pere/blog/archive/2018/02/">February (5)</a></li>
185
186 <li><a href="http://people.skolelinux.org/pere/blog/archive/2018/03/">March (5)</a></li>
187
188 <li><a href="http://people.skolelinux.org/pere/blog/archive/2018/04/">April (3)</a></li>
189
190 <li><a href="http://people.skolelinux.org/pere/blog/archive/2018/06/">June (2)</a></li>
191
192 <li><a href="http://people.skolelinux.org/pere/blog/archive/2018/07/">July (5)</a></li>
193
194 <li><a href="http://people.skolelinux.org/pere/blog/archive/2018/08/">August (3)</a></li>
195
196 <li><a href="http://people.skolelinux.org/pere/blog/archive/2018/09/">September (3)</a></li>
197
198 <li><a href="http://people.skolelinux.org/pere/blog/archive/2018/10/">October (5)</a></li>
199
200 <li><a href="http://people.skolelinux.org/pere/blog/archive/2018/11/">November (2)</a></li>
201
202 <li><a href="http://people.skolelinux.org/pere/blog/archive/2018/12/">December (4)</a></li>
203
204 </ul></li>
205
206 <li>2017
207 <ul>
208
209 <li><a href="http://people.skolelinux.org/pere/blog/archive/2017/01/">January (4)</a></li>
210
211 <li><a href="http://people.skolelinux.org/pere/blog/archive/2017/02/">February (3)</a></li>
212
213 <li><a href="http://people.skolelinux.org/pere/blog/archive/2017/03/">March (5)</a></li>
214
215 <li><a href="http://people.skolelinux.org/pere/blog/archive/2017/04/">April (2)</a></li>
216
217 <li><a href="http://people.skolelinux.org/pere/blog/archive/2017/06/">June (5)</a></li>
218
219 <li><a href="http://people.skolelinux.org/pere/blog/archive/2017/07/">July (1)</a></li>
220
221 <li><a href="http://people.skolelinux.org/pere/blog/archive/2017/08/">August (1)</a></li>
222
223 <li><a href="http://people.skolelinux.org/pere/blog/archive/2017/09/">September (3)</a></li>
224
225 <li><a href="http://people.skolelinux.org/pere/blog/archive/2017/10/">October (5)</a></li>
226
227 <li><a href="http://people.skolelinux.org/pere/blog/archive/2017/11/">November (3)</a></li>
228
229 <li><a href="http://people.skolelinux.org/pere/blog/archive/2017/12/">December (4)</a></li>
230
231 </ul></li>
232
233 <li>2016
234 <ul>
235
236 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/01/">January (3)</a></li>
237
238 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/02/">February (2)</a></li>
239
240 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/03/">March (3)</a></li>
241
242 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/04/">April (8)</a></li>
243
244 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/05/">May (8)</a></li>
245
246 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/06/">June (2)</a></li>
247
248 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/07/">July (2)</a></li>
249
250 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/08/">August (5)</a></li>
251
252 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/09/">September (2)</a></li>
253
254 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/10/">October (3)</a></li>
255
256 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/11/">November (8)</a></li>
257
258 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/12/">December (5)</a></li>
259
260 </ul></li>
261
262 <li>2015
263 <ul>
264
265 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/01/">January (7)</a></li>
266
267 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/02/">February (6)</a></li>
268
269 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/03/">March (1)</a></li>
270
271 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/04/">April (4)</a></li>
272
273 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/05/">May (3)</a></li>
274
275 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/06/">June (4)</a></li>
276
277 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/07/">July (6)</a></li>
278
279 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/08/">August (2)</a></li>
280
281 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/09/">September (2)</a></li>
282
283 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/10/">October (9)</a></li>
284
285 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/11/">November (6)</a></li>
286
287 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/12/">December (3)</a></li>
288
289 </ul></li>
290
291 <li>2014
292 <ul>
293
294 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/01/">January (2)</a></li>
295
296 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/02/">February (3)</a></li>
297
298 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/03/">March (8)</a></li>
299
300 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/04/">April (7)</a></li>
301
302 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/05/">May (1)</a></li>
303
304 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/06/">June (2)</a></li>
305
306 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/07/">July (2)</a></li>
307
308 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/08/">August (2)</a></li>
309
310 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/09/">September (5)</a></li>
311
312 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/10/">October (6)</a></li>
313
314 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/11/">November (3)</a></li>
315
316 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/12/">December (5)</a></li>
317
318 </ul></li>
319
320 <li>2013
321 <ul>
322
323 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/01/">January (11)</a></li>
324
325 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/02/">February (9)</a></li>
326
327 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/03/">March (9)</a></li>
328
329 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/04/">April (6)</a></li>
330
331 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/05/">May (9)</a></li>
332
333 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/06/">June (10)</a></li>
334
335 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/07/">July (7)</a></li>
336
337 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/08/">August (3)</a></li>
338
339 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/09/">September (5)</a></li>
340
341 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/10/">October (7)</a></li>
342
343 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/11/">November (9)</a></li>
344
345 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/12/">December (3)</a></li>
346
347 </ul></li>
348
349 <li>2012
350 <ul>
351
352 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/01/">January (7)</a></li>
353
354 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/02/">February (10)</a></li>
355
356 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/03/">March (17)</a></li>
357
358 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/04/">April (12)</a></li>
359
360 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/05/">May (12)</a></li>
361
362 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/06/">June (20)</a></li>
363
364 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/07/">July (17)</a></li>
365
366 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/08/">August (6)</a></li>
367
368 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/09/">September (9)</a></li>
369
370 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/10/">October (17)</a></li>
371
372 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/11/">November (10)</a></li>
373
374 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/12/">December (7)</a></li>
375
376 </ul></li>
377
378 <li>2011
379 <ul>
380
381 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/01/">January (16)</a></li>
382
383 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/02/">February (6)</a></li>
384
385 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/03/">March (6)</a></li>
386
387 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/04/">April (7)</a></li>
388
389 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/05/">May (3)</a></li>
390
391 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/06/">June (2)</a></li>
392
393 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/07/">July (7)</a></li>
394
395 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/08/">August (6)</a></li>
396
397 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/09/">September (4)</a></li>
398
399 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/10/">October (2)</a></li>
400
401 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/11/">November (3)</a></li>
402
403 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/12/">December (1)</a></li>
404
405 </ul></li>
406
407 <li>2010
408 <ul>
409
410 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/01/">January (2)</a></li>
411
412 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/02/">February (1)</a></li>
413
414 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/03/">March (3)</a></li>
415
416 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/04/">April (3)</a></li>
417
418 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/05/">May (9)</a></li>
419
420 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/06/">June (14)</a></li>
421
422 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/07/">July (12)</a></li>
423
424 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/08/">August (13)</a></li>
425
426 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/09/">September (7)</a></li>
427
428 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/10/">October (9)</a></li>
429
430 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/11/">November (13)</a></li>
431
432 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/12/">December (12)</a></li>
433
434 </ul></li>
435
436 <li>2009
437 <ul>
438
439 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/01/">January (8)</a></li>
440
441 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/02/">February (8)</a></li>
442
443 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/03/">March (12)</a></li>
444
445 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/04/">April (10)</a></li>
446
447 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/05/">May (9)</a></li>
448
449 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/06/">June (3)</a></li>
450
451 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/07/">July (4)</a></li>
452
453 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/08/">August (3)</a></li>
454
455 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/09/">September (1)</a></li>
456
457 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/10/">October (2)</a></li>
458
459 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/11/">November (3)</a></li>
460
461 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/12/">December (3)</a></li>
462
463 </ul></li>
464
465 <li>2008
466 <ul>
467
468 <li><a href="http://people.skolelinux.org/pere/blog/archive/2008/11/">November (5)</a></li>
469
470 <li><a href="http://people.skolelinux.org/pere/blog/archive/2008/12/">December (7)</a></li>
471
472 </ul></li>
473
474 </ul>
475
476
477
478 <h2>Tags</h2>
479 <ul>
480
481 <li><a href="http://people.skolelinux.org/pere/blog/tags/3d-printer">3d-printer (16)</a></li>
482
483 <li><a href="http://people.skolelinux.org/pere/blog/tags/amiga">amiga (1)</a></li>
484
485 <li><a href="http://people.skolelinux.org/pere/blog/tags/aros">aros (1)</a></li>
486
487 <li><a href="http://people.skolelinux.org/pere/blog/tags/bankid">bankid (4)</a></li>
488
489 <li><a href="http://people.skolelinux.org/pere/blog/tags/betalkontant">betalkontant (8)</a></li>
490
491 <li><a href="http://people.skolelinux.org/pere/blog/tags/bitcoin">bitcoin (11)</a></li>
492
493 <li><a href="http://people.skolelinux.org/pere/blog/tags/bootsystem">bootsystem (17)</a></li>
494
495 <li><a href="http://people.skolelinux.org/pere/blog/tags/bsa">bsa (2)</a></li>
496
497 <li><a href="http://people.skolelinux.org/pere/blog/tags/chrpath">chrpath (2)</a></li>
498
499 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian">debian (168)</a></li>
500
501 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian edu">debian edu (158)</a></li>
502
503 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian-handbook">debian-handbook (4)</a></li>
504
505 <li><a href="http://people.skolelinux.org/pere/blog/tags/digistan">digistan (11)</a></li>
506
507 <li><a href="http://people.skolelinux.org/pere/blog/tags/dld">dld (17)</a></li>
508
509 <li><a href="http://people.skolelinux.org/pere/blog/tags/docbook">docbook (26)</a></li>
510
511 <li><a href="http://people.skolelinux.org/pere/blog/tags/drivstoffpriser">drivstoffpriser (4)</a></li>
512
513 <li><a href="http://people.skolelinux.org/pere/blog/tags/english">english (409)</a></li>
514
515 <li><a href="http://people.skolelinux.org/pere/blog/tags/fiksgatami">fiksgatami (23)</a></li>
516
517 <li><a href="http://people.skolelinux.org/pere/blog/tags/fildeling">fildeling (14)</a></li>
518
519 <li><a href="http://people.skolelinux.org/pere/blog/tags/freeculture">freeculture (34)</a></li>
520
521 <li><a href="http://people.skolelinux.org/pere/blog/tags/freedombox">freedombox (9)</a></li>
522
523 <li><a href="http://people.skolelinux.org/pere/blog/tags/frikanalen">frikanalen (20)</a></li>
524
525 <li><a href="http://people.skolelinux.org/pere/blog/tags/h264">h264 (20)</a></li>
526
527 <li><a href="http://people.skolelinux.org/pere/blog/tags/intervju">intervju (42)</a></li>
528
529 <li><a href="http://people.skolelinux.org/pere/blog/tags/isenkram">isenkram (16)</a></li>
530
531 <li><a href="http://people.skolelinux.org/pere/blog/tags/kart">kart (22)</a></li>
532
533 <li><a href="http://people.skolelinux.org/pere/blog/tags/kodi">kodi (4)</a></li>
534
535 <li><a href="http://people.skolelinux.org/pere/blog/tags/ldap">ldap (9)</a></li>
536
537 <li><a href="http://people.skolelinux.org/pere/blog/tags/lego">lego (4)</a></li>
538
539 <li><a href="http://people.skolelinux.org/pere/blog/tags/lenker">lenker (8)</a></li>
540
541 <li><a href="http://people.skolelinux.org/pere/blog/tags/lsdvd">lsdvd (2)</a></li>
542
543 <li><a href="http://people.skolelinux.org/pere/blog/tags/ltsp">ltsp (1)</a></li>
544
545 <li><a href="http://people.skolelinux.org/pere/blog/tags/mesh network">mesh network (8)</a></li>
546
547 <li><a href="http://people.skolelinux.org/pere/blog/tags/multimedia">multimedia (42)</a></li>
548
549 <li><a href="http://people.skolelinux.org/pere/blog/tags/nice free software">nice free software (12)</a></li>
550
551 <li><a href="http://people.skolelinux.org/pere/blog/tags/noark5">noark5 (17)</a></li>
552
553 <li><a href="http://people.skolelinux.org/pere/blog/tags/norsk">norsk (307)</a></li>
554
555 <li><a href="http://people.skolelinux.org/pere/blog/tags/nuug">nuug (196)</a></li>
556
557 <li><a href="http://people.skolelinux.org/pere/blog/tags/offentlig innsyn">offentlig innsyn (37)</a></li>
558
559 <li><a href="http://people.skolelinux.org/pere/blog/tags/open311">open311 (2)</a></li>
560
561 <li><a href="http://people.skolelinux.org/pere/blog/tags/opphavsrett">opphavsrett (75)</a></li>
562
563 <li><a href="http://people.skolelinux.org/pere/blog/tags/personvern">personvern (109)</a></li>
564
565 <li><a href="http://people.skolelinux.org/pere/blog/tags/raid">raid (2)</a></li>
566
567 <li><a href="http://people.skolelinux.org/pere/blog/tags/reactos">reactos (1)</a></li>
568
569 <li><a href="http://people.skolelinux.org/pere/blog/tags/reprap">reprap (11)</a></li>
570
571 <li><a href="http://people.skolelinux.org/pere/blog/tags/rfid">rfid (3)</a></li>
572
573 <li><a href="http://people.skolelinux.org/pere/blog/tags/robot">robot (12)</a></li>
574
575 <li><a href="http://people.skolelinux.org/pere/blog/tags/rss">rss (1)</a></li>
576
577 <li><a href="http://people.skolelinux.org/pere/blog/tags/ruter">ruter (7)</a></li>
578
579 <li><a href="http://people.skolelinux.org/pere/blog/tags/scraperwiki">scraperwiki (2)</a></li>
580
581 <li><a href="http://people.skolelinux.org/pere/blog/tags/sikkerhet">sikkerhet (56)</a></li>
582
583 <li><a href="http://people.skolelinux.org/pere/blog/tags/sitesummary">sitesummary (4)</a></li>
584
585 <li><a href="http://people.skolelinux.org/pere/blog/tags/skepsis">skepsis (5)</a></li>
586
587 <li><a href="http://people.skolelinux.org/pere/blog/tags/standard">standard (66)</a></li>
588
589 <li><a href="http://people.skolelinux.org/pere/blog/tags/stavekontroll">stavekontroll (6)</a></li>
590
591 <li><a href="http://people.skolelinux.org/pere/blog/tags/stortinget">stortinget (12)</a></li>
592
593 <li><a href="http://people.skolelinux.org/pere/blog/tags/surveillance">surveillance (56)</a></li>
594
595 <li><a href="http://people.skolelinux.org/pere/blog/tags/sysadmin">sysadmin (4)</a></li>
596
597 <li><a href="http://people.skolelinux.org/pere/blog/tags/usenix">usenix (2)</a></li>
598
599 <li><a href="http://people.skolelinux.org/pere/blog/tags/valg">valg (9)</a></li>
600
601 <li><a href="http://people.skolelinux.org/pere/blog/tags/verkidetfri">verkidetfri (17)</a></li>
602
603 <li><a href="http://people.skolelinux.org/pere/blog/tags/video">video (73)</a></li>
604
605 <li><a href="http://people.skolelinux.org/pere/blog/tags/vitenskap">vitenskap (4)</a></li>
606
607 <li><a href="http://people.skolelinux.org/pere/blog/tags/web">web (42)</a></li>
608
609 </ul>
610
611
612 </div>
613 <p style="text-align: right">
614 Created by <a href="http://steve.org.uk/Software/chronicle">Chronicle v4.6</a>
615 </p>
616
617 </body>
618 </html>