]> pere.pagekite.me Git - homepage.git/blob - blog/index.html
Generated.
[homepage.git] / blog / index.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</title>
7 <link rel="stylesheet" type="text/css" media="screen" href="https://people.skolelinux.org/pere/blog/style.css" />
8 <link rel="stylesheet" type="text/css" media="screen" href="https://people.skolelinux.org/pere/blog/vim.css" />
9 <link rel="alternate" title="RSS Feed" href="https://people.skolelinux.org/pere/blog/index.rss" type="application/rss+xml" />
10 </head>
11 <body>
12 <div class="title">
13 <h1>
14 <a href="https://people.skolelinux.org/pere/blog/">Petter Reinholdtsen</a>
15
16 </h1>
17
18 </div>
19
20
21
22 <div class="entry">
23 <div class="title"><a href="https://people.skolelinux.org/pere/blog/VLC_bittorrent_plugin_still_going_strong__new_upload_2_14_4.html">VLC bittorrent plugin still going strong, new upload 2.14-4</a></div>
24 <div class="date">31st December 2023</div>
25 <div class="body"><p>The other day I uploaded a new version of
26 <a href="https://tracker.debian.org/pkg/vlc-plugin-bittorrent">the VLC
27 bittorrent plugin</a> to Debian, version 2.14-4, to fix a few
28 packaging issues. This plugin extend VLC allowing it to stream videos
29 directly from a bittorrent source using both torrent files and magnet
30 links, as easy as using a HTTP or local file source. I believe such
31 protocol support is a vital feature in VLC, allowing efficient
32 streaming from sources such at the 11 million movies in
33 <a href="https://archive.org/">the Internet Archive</a>. Bittorrent is
34 one of the most efficient content distribution protocols on the
35 Internet, without centralised control, and should be used more.</p>
36
37 <p>The new version is now both in Debian Unstable and Testing, as well
38 as Ubuntu. While looking after the package, I decided to ask the VLC
39 upstream community if there was any hope to get Bittorrent support
40 into the official VLC program, and was very happy to learn that
41 someone is already working on it. I hope we can see some fruits of
42 that labour next year, but do not hold my breath. In the mean time we
43 can use the plugin, which is already
44 <a href="https://qa.debian.org/popcon.php?package=vlc-plugin-bittorrent">installed
45 by 0.23 percent of the Debian population</a> according to
46 popularity-contest. It could use a new upstream release, and I hope
47 the upstream developer soon find time to polish it even more.</p>
48
49 <p>It is worth noting that the plugin store the downloaded files in
50 <tt>~/Downloads/vlc-bittorrent/</tt>, which can quickly fill up the
51 user home directory during use. Users of the plugin should keep an
52 eye with disk usage when streaming a bittorrent source.</p>
53
54 <p>As usual, if you use Bitcoin and want to show your support of my
55 activities, please send Bitcoin donations to my address
56 <b><a href="bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b</a></b>.</p>
57 </div>
58 <div class="tags">
59
60
61 Tags: <a href="https://people.skolelinux.org/pere/blog/tags/english">english</a>, <a href="https://people.skolelinux.org/pere/blog/tags/verkidetfri">verkidetfri</a>, <a href="https://people.skolelinux.org/pere/blog/tags/video">video</a>.
62
63
64 </div>
65 </div>
66 <div class="padding"></div>
67
68 <div class="entry">
69 <div class="title"><a href="https://people.skolelinux.org/pere/blog/_N_r__p___blir__p_____Et_reservoar_av_tegn_sett_fra_depotet__i_tidsskriftet_Aksess.html">«Når «på» blir «pÃ¥»: Et reservoar av tegn sett fra depotet» i tidsskriftet Aksess</a></div>
70 <div class="date">15th November 2023</div>
71 <div class="body"><p>For noen uker siden skrev en kamerat og meg
72 <a href="https://www.aksess-tidsskrift.no/fordypning/175530">en
73 artikkel om tegnsett</a> i
74 <a href="https://www.aksess-tidsskrift.no/">arkivtidsskriftet
75 Aksess</a> både på web og i papirutgave nr. 3 2023. Her er det som
76 nettopp ble publisert.</p>
77
78 <blockquote>
79
80 <p><strong>Når «på» blir «pÃ¥»: Et reservoar av tegn sett fra
81 depotet</strong></p>
82
83 <p>av Thomas Sødring og Petter Reinholdtsen</p>
84
85 <p>De færreste av oss tenker over hva som skjer dypere i datamaskinen
86 mens vi sitter der og skriver noe på tastaturet. Når du trykker på
87 tasten «Å», så vises bokstaven Å. Men noen ganger blir det
88 feil. Hvorfor det – og hva er viktig å være klar over i
89 arkivsammenheng?</p>
90
91 <p>Dersom bokstaver tolkes forskjellig mellom systemer, blir det fort
92 rot, dette kalles mojibake blant kjennere, etter det japanske
93 uttrykket for tegnomforming. Det er en lang historie her som tidvis
94 har vært preget av rot. Noen husker kanskje tilbake til en tid der
95 bokstavene æ, ø og å ofte var ødelagt i e-poster – et klassisk
96 eksempel på tegnsettproblemstilling.</p>
97
98 <p id="tegnsett_access_nå_og_før"><strong>«Nå» og «før»</strong></p>
99
100 <p>Tid er et skjult problem for depot fordi vi danner dokumentasjon i
101 en kontekst som er preget av å være «nå». Vår forståelse av verden og
102 bruken av teknologi er utgangspunktet for denne konteksten. Tenk selv
103 hvordan verden har utviklet seg de siste 20 årene, hva samfunnet er
104 opptatt av, og hvordan vi bruker teknologi i hverdagen. Tid er et
105 skjult problem fordi når vi trekker dokumentasjon ut av systemer og
106 deponerer for langtidsbevaring, er konteksten til materialet «nå», men
107 verden går videre. Ettersom teknologien og måten vi bruker den på,
108 utvikler seg, blir «nå» til «før», og dokumentasjonen befinner seg
109 snart i en «før»-kontekst.</p>
110
111 <p>Dette med «før» og «nå» i forhold til dokumentasjonens kontekst er
112 noe vi er veldig lite bevisste på, men det er en problemstilling
113 depotarkivene eier og forvalter. En av disse utfordringene er hvorfor
114 «Ø» ikke nødvendigvis er det samme som «Ø», og hvorfor det i det hele
115 tatt gir mening å si noe sånt. Vi snakker her om noe som heter
116 tegnsett, som er en avtalt måte å representere bokstaver, tall og
117 andre symboler på slik at vi på en feilfri måte kan utveksle tekst
118 mellom datasystemer.</p>
119
120 <p>Tegnsettproblemstillingen er satt sammen av fire fasetter;
121 repertoar, representasjon, koding og uttegning.</p>
122
123 <p id="tegnsett_access_repertoarer"><strong>Repertoarer</strong></p>
124
125 <p>Repertoar er en samling med tegn og symboler som kan
126 representeres. Tenk norsk alfabet eller japanske piktogrammer, men
127 også matematiske og elektroniske symboler. Bokstaven «stor a» kan være
128 en oppføring i et slikt repertoar. For å kunne brukes i en datamaskin
129 trenger hver oppføring i et slikt repertoar en representasjon, hvilket
130 i datamaskinsammenheng betyr at det tilordnes et tall. Tallet kan
131 lagres på ulike vis i en eller flere kodingsformater. For eksempel kan
132 en skrive tallet ti som både 10, X og A, i henholdsvis
133 titallssystemet, romertallssystemet og sekstentallssystemet.</p>
134
135 <p>Hvis en skal kunne lese inn filer og vite hvilket tall og hvilken
136 representasjon og instans i et repertoar det er snakk om, så må en
137 vite hvordan tallet er kodet. Sist, men ikke minst, for å kunne bruke
138 symbolet til noe må det kunne være kjent hvordan det skal se ut eller
139 tegnes på ark. Det finnes utallige skrifttyper med norske bokstaver,
140 alle litt forskjellige, og skal en kunne tegne en stor A på skjermen,
141 så må datamaskinen vite hva den skal tegne. Skrifttyper inneholder
142 informasjon om hvordan ulike tall skal tegnes. De inneholder ikke
143 alltid alle symbolene som er brukt i en tekst, hvilket gjør at ikke
144 alle forståtte tegn vil kunne vises på skjerm eller ark.</p>
145
146 <p>Hver av disse fasettene må være avklart for å kunne ta vare på og vise
147 frem tekst med en datamaskin. Kombinasjon av repertoar, representasjon
148 og koding er det en kaller et tegnsett. Kombinasjonen av
149 representasjon og uttegning kalles en skrifttype. De fleste
150 skrifttyper har også informasjon om repertoar, men det finnes
151 skrifttyper som kun kobler mellom tallkode og uttegning, uten å
152 fortelle noe om hvordan tallkodene egentlig skal tolkes.</p>
153
154 <p id="tegnsett_access_fra_ascii_til_iso_8859"><strong>Fra ASCII til ISO-8859</strong></p>
155
156 <p>Vi begynner historien med ASCII (American Standard Code for
157 Information Interchange) som har en historie som spores tilbake til
158 1963. Utgangspunktet til ASCII var at det kunne kode opp til 128
159 forskjellige symboler i vanlig bruk i USA. De visuelle symbolene i
160 ASCII er de små og store bokstavene (a til z og A til Z), tall (0 til
161 9) og tegnsettingssymboler (for eksempel semikolon, komma og
162 punktum). ASCII har også noen usynlige symboler som ble brukt for
163 bl.a. kommunikasjon. Før ASCII var det for eksempel teleks-tegnsett
164 med plass til bare 32 tegn og EBCDIC med plass til 256 tegn, alle med
165 en helt annen rekkefølge på symbolene enn ASCII, men de har vært lite
166 brukt de siste femti årene. Et eksempel på noen utvalgte symboler i
167 repertoaret til ASCII vises i tabell 1.</p>
168
169 <table align="center" width="50%">
170
171 <caption>Tabell 1. Eksempel på utvalgte symboler hentet fra
172 ASCII-tegnsettet. Kolonnen «Binær» viser symbolets verdi i
173 totallssystemet (1 og 0 tall), mens kolonnen «Desimal» viser symbolets
174 verdi i titallssystemet.</caption>
175
176 <tbody>
177 <tr>
178 <th>Grafisk</th>
179 <th>Binær</th>
180 <th>Desimal</th>
181 </tr>
182 <tr>
183 <td>A</td>
184 <td>1000001</td>
185 <td align="right">65</td>
186 </tr>
187 <tr>
188 <td>M</td>
189 <td>1001101</td>
190 <td align="right">77</td>
191 </tr>
192 <tr>
193 <td>Z</td>
194 <td>1011010</td>
195 <td align="right">90</td>
196 </tr>
197 <tr>
198 <td>a</td>
199 <td>1100001</td>
200 <td align="right">97</td>
201 </tr>
202 <tr>
203 <td>m</td>
204 <td>1101101</td>
205 <td align="right">109</td>
206 </tr>
207 <tr>
208 <td>z</td>
209 <td>1111010</td>
210 <td align="right">122</td>
211 </tr>
212 <tr>
213 <td>0</td>
214 <td>0110000</td>
215 <td align="right">48</td>
216 </tr>
217 <tr>
218 <td>9</td>
219 <td>0111001</td>
220 <td align="right">58</td>
221 </tr>
222 <tr>
223 <td>;</td>
224 <td>0111011</td>
225 <td align="right">59</td>
226 </tr>
227 </tbody>
228 </table>
229
230 <p>Det opprinnelige ASCII-tegnsettet ble også omtalt som ASCII-7 og
231 brukte 7 bits (0 og 1) for å representere symboler. Datamaskiner er
232 ofte konfigurert til å jobbe med enheter der bits er gruppert som 4
233 eller 8 bits . Det lå en mulighet i å ta i bruk bit åtte. En slik
234 endring ville gjøre det mulig for datamaskiner å øke antall symboler
235 de kunne representere, noe som ga en økning fra 128 forskjellige
236 symboler til 256 forskjellige symboler. Det ble åpnet for å innlemme
237 de nordiske bokstavene sammen med ASCII, og dette ble etter hvert
238 standardisert som ISO-8859-1. Tabell 2 viser deler av ISO-8859-1 som
239 støtter de norske bokstavene.</p>
240
241 <p>Det sier seg selv at muligheten til å representere inntil 256 symboler
242 ikke holder når vi snakker om en global verden, og det ble gjort et
243 standardiseringsløp som tok utgangspunkt i ASCII-7 med en utvidelse
244 til å bruke den åttende biten for ulike språkgrupper. Denne standarden
245 heter ISO-8859 og er inndelt i opptil 16 varianter, altså fra
246 ISO-8859-1 til ISO-8859-16.</p>
247
248 <table align="center" width="50%">
249
250 <caption>Tabell 2. Koding av de norske symbolene slik de er definert i
251 ISO-8859-1 tegnsettet.</caption>
252
253 <tbody>
254 <tr>
255 <th>Grafisk</th>
256 <th>Binær</th>
257 <th>Desimal</th>
258 </tr>
259 <tr>
260 <td>Æ</td>
261 <td>11000110</td>
262 <td align="right">198</td>
263 </tr>
264 <tr>
265 <td>Ø</td>
266 <td>11011000</td>
267 <td align="right">216</td>
268 </tr>
269 <tr>
270 <td>Å</td>
271 <td>11000101</td>
272 <td align="right">197</td>
273 </tr>
274 <tr>
275 <td>æ</td>
276 <td>11100110</td>
277 <td align="right">230</td>
278 </tr>
279 <tr>
280 <td>ø</td>
281 <td>11111000</td>
282 <td align="right">248</td>
283 </tr>
284 <tr>
285 <td>å</td>
286 <td>11100101</td>
287 <td align="right">229</td>
288 </tr>
289 </tbody>
290 </table>
291
292 <p>Norske tegn er definert i ISO-8859-1, som også omtales som Latin 1, de
293 fleste samiske tegn er definert i ISO-8859-4 (Latin 4) mens tilgang
294 til €-symbolet kom med ISO-8859-15 (Latin 9). ISO-8859-15 er en
295 revisjon av ISO-8859-1 som fjerner noen lite brukte symboler og
296 erstatter bokstaver som er mer brukt, og introduserer €-symbolet. Det
297 er viktig å merke at alle ISO-8859-variantene har overlapp med
298 ASCII-7, noe som ga samvirke med de engelskspråklige landene som ikke
299 trengte å gjøre noe. Det innebærer også at de første 128 verdiene i
300 ISO-8859-variantene representerer de samme symbolene. Det er først når
301 du kommer til tolkningen av de resterende 128 verdiene med nummer 128
302 til 255, at det oppsto tolkningsutfordringer mellom
303 ISO-8859-variantene.</p>
304
305 <p>ISO-8859-verdenen fungerte godt så lenge tegnsettet som ble brukt når
306 innhold ble skapt, også ble brukt når innhold ble gjengitt og du ikke
307 trengte å kombinere innhold fra forskjellige tegnsett i samme
308 dokument. Utfordringen med bruken av ISO-8859-variantene ble raskt
309 tydelig i en mer globalisert verden med utveksling av tekst på tvers
310 av landegrenser der tekstlig innhold i dokumenter, e-poster og
311 websider kunne bli skrevet med ett tegnsett og gjengitt med et annet
312 tegnsett.</p>
313
314 <table align="center" width="60%">
315
316 <caption>Tabell 3. Viser tolkning av verdiene som er tilegnet de
317 norske symbolene i ISO-8859-1 i de andre ISO 8859-variatene. Merk
318 ISO-8859-12 ikke finnes da arbeidet ble avsluttet.<sup>[<a id="tegnsett_access_footnoteref_1" href="#tegnsett_access_footnotedef_1" title="View footnote.">1</a>]</sup></caption>
319
320 <tbody>
321 <tr>
322 <th>Binærverdi</th>
323 <th>1</th>
324 <th>2</th>
325 <th>3</th>
326 <th>4</th>
327 <th>5</th>
328 <th>6</th>
329 <th>7</th>
330 <th>8</th>
331 <th>9</th>
332 <th>10</th>
333 <th>11</th>
334 <th>13</th>
335 <th>14</th>
336 <th>15</th>
337 <th>16</th>
338 </tr>
339 <tr>
340 <td>11000110</td>
341 <td>Æ</td>
342 <td>Ć</td>
343 <td>Ĉ</td>
344 <td>Æ</td>
345 <td>Ц</td>
346 <td>ئ</td>
347 <td>Ζ</td>
348 <td></td>
349 <td>Æ</td>
350 <td>Æ</td>
351 <td></td>
352 <td>Ę</td>
353 <td>Æ</td>
354 <td>Æ</td>
355 <td>Æ</td>
356 </tr>
357 <tr>
358 <td>11011000</td>
359 <td>Ø</td>
360 <td>Ř</td>
361 <td>Ĝ</td>
362 <td>Ø</td>
363 <td>и</td>
364 <td>ظ</td>
365 <td>Ψ</td>
366 <td></td>
367 <td>Ø</td>
368 <td>Ø</td>
369 <td></td>
370 <td>Ų</td>
371 <td>Ø</td>
372 <td>Ø</td>
373 <td>Ű</td>
374 </tr>
375 <tr>
376 <td>11000101</td>
377 <td>Å</td>
378 <td>Ĺ</td>
379 <td>Ċ</td>
380 <td>Å</td>
381 <td>Х</td>
382 <td>إ</td>
383 <td>Ε</td>
384 <td></td>
385 <td>Å</td>
386 <td>Å</td>
387 <td></td>
388 <td>Å</td>
389 <td>Å</td>
390 <td>Å</td>
391 <td>Ć</td>
392 </tr>
393 <tr>
394 <td>11100110</td>
395 <td>æ</td>
396 <td>ć</td>
397 <td>ĉ</td>
398 <td>æ</td>
399 <td>ц</td>
400 <td>ن</td>
401 <td>ζ</td>
402 <td>ז</td>
403 <td>æ</td>
404 <td>æ</td>
405 <td></td>
406 <td>ę</td>
407 <td>æ</td>
408 <td>æ</td>
409 <td>v</td>
410 </tr>
411 <tr>
412 <td>11111000</td>
413 <td>ø</td>
414 <td>ř</td>
415 <td>ĝ</td>
416 <td>ø</td>
417 <td>ј</td>
418 <td></td>
419 <td>ψ</td>
420 <td>ר</td>
421 <td>ø</td>
422 <td>ø</td>
423 <td></td>
424 <td>ų</td>
425 <td>ø</td>
426 <td>ø</td>
427 <td>ű</td>
428 </tr>
429 <tr>
430 <td>11100101</td>
431 <td>å</td>
432 <td>ĺ</td>
433 <td>ċ</td>
434 <td>å</td>
435 <td>х</td>
436 <td>م</td>
437 <td>ε</td>
438 <td>ו</td>
439 <td>å</td>
440 <td>å</td>
441 <td></td>
442 <td>å</td>
443 <td>å</td>
444 <td>å</td>
445 <td>ć</td>
446 </tr>
447 </tbody>
448 </table>
449
450 <p>Denne problemstillingen er illustrert i tabell 3, der vi ser verdiene
451 tilegnet de norske symbolene i ISO-8859-1 i kolonne «1». I de øvrige
452 kolonnene ser vi hvilket symbol verdien får i de andre
453 ISO-8859-variantene. Tar vi utgangspunkt i tabell 3, kan vi se at
454 ordet lærlingspørsmål gjengitt med ISO-8859-2 (kolonne 2) blir
455 lćrlingspřrsmĺl, mens det blir lζrlingspψrsmεl med ISO- 8859-7
456 (kolonne 7). Med ISO-8859-2 blir «æ» til «ć», «ø» til «ř» og «å» til
457 «ĺ». I ISO-8859-7 blir «æ» til «ζ», «ø» til «ψ», mens «å» blir «ε».</p>
458
459 <p>Det er egentlig ingen utfordring med dette så lenge du vet hvilket
460 tegnsett innholdet ditt er representert med, og det ikke har skjedd
461 omforminger som du ikke er klar over. Det er det siste som er
462 problematisk, spesielt de datasystemene som har vært i bruk de siste
463 20 årene, som ikke har noe innebygd funksjonalitet for å forvalte
464 tegnsettproblematikken. Et godt eksempel på dette er
465 Microsoft-tegnsettet Windows-1252, som ble forvekslet som 100 %
466 kompatibel med ISO-8859-1, men hadde byttet ut plassene fra 127 til
467 159. Historisk vil det finnes en del variasjon i hvilket tegnsett som
468 har vært i bruk, og hvor vellykket konvertering mellom tegnsett har
469 vært.</p>
470
471 <p id="tegnsett_access_unicode_som_løsning"><strong>Unicode som løsning</strong></p>
472
473 <p>Tegnsettforvirring ble etter hvert et irritasjonsmoment og
474 samvirkeproblem. Ofte fikk man en e-post der æøå var erstattet av rare
475 symboler fordi e-posten hadde vært innom et eller annet datasystem som
476 ikke brukte samme tegnsett.</p>
477
478 <p>For å løse dette samvirkeproblemet for tegnsett ble det startet et
479 arbeid og en ny standard så dagens lys etter hvert. Denne standarden
480 fikk navnet Unicode (ISO/ IEC 10646) og skulle resultere i et tegnsett
481 som alle skulle være enige om. Unicode er et repertoar og en
482 representasjon, dvs. navngivning og tilordning av tallverdi til alle
483 symboler i bruk i verden i dag. Oppføringer i Unicode skrives gjerne
484 U+XXXX der XXXX er tallkoden i sekstentallssystemet som oppføringen
485 har i Unicode-katalogen. Her finner vi tegn brukt av både levende og
486 døde språk, konstruerte språk, tekniske symboler, morsomme tegninger
487 (såkalte emojier) og tegn ingen vet hva betyr eller skal brukes
488 til. Et morsomt eksempel er i nettartikkelen: U+237C ⍼ RIGHT ANGLE
489 WITH DOWNWARDS ZIGZAG ARROW, av Jonathan Chan.<sup>[<a id="tegnsett_access_footnoteref_2" href="#tegnsett_access_footnotedef_2" title="View footnote.">2</a>]</sup></p>
490
491 <p>Sammen med Unicode kom det tre måter å kode disse tallene på; UTF-8,
492 UTF-16 og UTF-32. Av datatekniske årsaker er UTF-8 mye brukt, spesielt
493 når det gjelder utveksling av tekst over Internett, mens UTF-16 er
494 brukt en del til tekstfiler lagret på Windows. En utfordring med
495 Unicode og UTF-variantene er at disse gir flere måter å kode samme
496 symbol på med en kombinasjonsmekanisme. Dette kan gi utfordringer ved
497 søk, hvis en skal søke etter et ord som har ett eller flere symboler
498 som kan skrives på ulikt vis, så er det ikke sikkert at søkesystemet
499 vil finne alle forekomster. For eksempel kan bokstaven U+00F8 «Latin
500 Small Letter O with Stroke» kodes som den tradisjonelle norske tegnet
501 ø, men også som o kombinert med skråstrek U+0338. Begge deler er
502 gyldig bruk av Unicode, selv om det er tradisjon for å foretrekke å
503 «normalisere» kombinasjoner som enkelttegn der det er mulig, nettopp
504 for å forenkle søk.</p>
505
506 <p id="tegnsett_access_bare_unicode_fremover"><strong>Bare Unicode fremover</strong></p>
507
508 <p>Forvaltningens bruk av tegnsett er regulert i Forskrift om
509 IT-standarder i offentlig forvaltning<sup>[<a id="tegnsett_access_footnoteref_3" href="#tegnsett_access_footnotedef_3" title="View footnote.">3</a>]</sup>. Her står det: «Ved all
510 utveksling av informasjon mellom forvaltningsorganer og fra
511 forvaltningsorgan til innbyggere og næringsliv skal tegnsettstandarden
512 ISO/IEC 10646 representert ved UTF8 benyttes.» Det er forskjellige
513 bruksområder til UTF-8, UTF-16 og UTF-32, men UTF-8 er kodingen vi
514 kjenner mest til. Det er flere grunner at UTF-8 «vant» konkurransen
515 til å bli den utvalgte. Den kanskje viktigste er at UTF-8 er fullt
516 samvirkende med ASCII-7, slik at den engelskspråklige delen av verden
517 kunne rulle ut UTF-8 uten å merke noe forskjell. En tekstfil med kun
518 ASCII-tekst vil være identisk på disken hvis den lagres som UTF-8 og
519 ASCII. UTF-16 og UTF-32 byr på noen optimaliseringer som gjør dem
520 relevant for spesifikke problemområder, men for det meste vil vi aldri
521 oppleve disse standardene på nært hold i hverdagen. Det er uansett kun
522 bruken av UTF-8 som er lovregulert i Norge.</p>
523
524 <p>Det er ikke slik at hele verden bruker ISO/IEC 10646 og UTF-8. Kina
525 har egne standarder for tegnsett, mye brukt er GB 18030, som er
526 Unicode med en annen koding enn UTF-8, mens Taiwan og andre asiatiske
527 land gjerne bruker Big5 eller andre tegnsett.</p>
528
529 <p>UTF-8 er dominerende i Norge, men det er tidsperioder der forskjellige
530 datasystemer utvekslet data i henhold til ISO-8859-1, ISO-8859-15,
531 Windows-1252, Codepage 865 og ISO-646-60 / Codepage 1016 mens
532 overgangen til UTF-8 pågikk. Det er ikke slik at et datasystem enkelt
533 kan tvinges til å bruke et tegnsett, da det er flere lag i et
534 datasystem som må settes opp til å bruke riktig tegnsett, og
535 tegnsettproblemet fort oppstår når det er et eller annet i
536 datasystemet som bruker feil tegnsett.</p>
537
538 <p>Et klassisk eksempel på problemet er en utveksling av tekst mellom to
539 systemer der teksten i utgangspunktet er kodet i UTF-8, men går
540 gjennom noe som er ISO-8859-1 underveis. Dette kan vises med at ordet
541 «på» i et slik scenario ender opp som «pÃ¥». Det er mulig å spore
542 dette tilbake til verdiene symbolene er tilordnet i tegnsettene. «på»
543 blir til «pÃ¥» fordi «å» i UTF-8 er representert med U+C3AF, og dersom
544 vi ser på hva disse verdiene representerer, ser vi at
545 sekstentallssystemverdien C3 er 1100 0011 i totallssystemet og
546 symbolet med dette tallet i ISO-8859-1 er Ã.</p>
547
548 <p>Vi ser det samme med sekstentallssystemverdien A5, som er 1010 0101 i
549 totallssystemet, og tilsvarende symbol i ISO-8859-1 er ¥. Slik
550 mojibake kan lett skje hvis «på» i utgangspunktet var representert med
551 UTF-8, men ble behandlet med et system som bruker ISO-8859-1. Det er
552 ingen automatikk i å fange opp slike ødeleggelser mens tekstlig
553 innhold utveksles mellom datasystemer.</p>
554
555 <p>En utfordring for depotarkivene er at bruken av tegnsett ikke alltid
556 har vært regulert, og at det kan finnes flere dokumentasjonssamlinger
557 som er opprettet med varierende tegnsett før gjeldende forskrift
558 inntraff – uten at det er mulig å avlede fra filene hvilket tegnsett
559 som ble brukt. Et eksempel på dette er €-symbolet, som kom først etter
560 at ISO-8859-1 var tatt i bruk. Det kan bli en utfordring for et
561 depotarkiv, men så lenge det er kjent hvilket tegnsett var i bruk, så
562 bør det gå bra. Riksarkivarens
563 forskrift<sup>[<a id="tegnsett_access_footnoteref_4" href="#tegnsett_access_footnotedef_4" title="View footnote.">4</a>]</sup>
564 formaliserer dette ved å kreve følgende:</p>
565
566 <blockquote>
567 <p>§ 5-11. Tegnsett i arkivuttrekk</p>
568
569 <ol>
570 <li>Arkivuttrekk og medfølgende struktur- og innholdsbeskrivelser skal
571 overføres som ren tekst i ukryptert form, og benytte godkjent
572 tegnsett.</li>
573
574 <li>Godkjente tegnsett er:
575 <ol>
576 <li>Unicode UTF-8<br>
577 (ISO/IEC 10646-1:2000 Annex D)</li>
578 <li>ISO 8859-1:1998, Latin 1</li>
579 <li>ISO 8859-4:1998, Latin 4 for samiske tegn.</li>
580 </ol></li>
581
582 <li>Andre tegnsett aksepteres bare etter avtale med Arkivverket.</li>
583 </ol>
584 </blockquote>
585
586 <p id="tegnsett_access_ditt_ansvar"><strong>Ditt ansvar</strong></p>
587
588 <p>På mange måter burde ikke tegnsett være et problem i 2023, men sånn er
589 det nok ikke. Land som har oppgradert til UTF-8 som primærtegnsett for
590 utveksling av tekstlig innhold, begrenser problematikken betraktelig,
591 men globalt sett så er tegnsettutfordringen ikke løst fordi ikke alle
592 er enige om å bruke samme tegnsett. Det kan være geopolitiske eller
593 kulturelle hensyn som ligger til grunn for dette.</p>
594
595 <p>Det er uansett verdt å merke at selv om bruken av UTF-8 skulle bli
596 100% utbredt, så er det et historisk perspektiv (ASCII-7,
597 ISO-8859-variantene, UTF-8) her som gjør tegnsett til et problemområde
598 arkivarene må forstå og håndtere. Som danningsarkivar har du et
599 ansvar for å vite hvilket tegnsett systemene og databasene dere
600 forvalter, er i samsvar med. Det er noe IT-avdelingen din eller
601 programvareleverandørene enkelt skal kunne svare på, og svaret skal
602 være UTF-8 for alle nye systemer.</p>
603
604 <hr>
605
606 <p id="tegnsett_access_footnotedef_1"><a href="#tegnsett_access_footnoteref_1">1</a>. Tegnsettkilde <a href="https://en.wikipedia.org/wiki/ISO/IEC_8859">https://en.wikipedia.org/wiki/ISO/IEC_8859</a></p>
607
608 <p id="tegnsett_access_footnotedef_2"><a href="#tegnsett_access_footnoteref_2">2</a>. <a href="https://ionathan.ch/2022/04/09/angzarr.html">https://ionathan.ch/2022/04/09/angzarr.html</a></p>
609
610 <p id="tegnsett_access_footnotedef_3"><a href="#tegnsett_access_footnoteref_3">3</a>. <a href="https://lovdata.no/dokument/SF/forskrift/2013-04-05-959/%C2%A78#%C2%A78">https://lovdata.no/dokument/SF/forskrift/2013-04-05-959/%C2%A78#%C2%A78</a></p>
611
612 <p id="tegnsett_access_footnotedef_4"><a href="#tegnsett_access_footnoteref_4">4</a>. <a href="https://lovdata.no/forskrift/2017-12-19-2286/§5-11">https://lovdata.no/forskrift/2017-12-19-22865-11</a></p>
613
614 </blockquote>
615
616 <p>For øvrig burde varsleren Edward Snowden få politisk asyl i Norge.</p>
617
618 <p>Som vanlig, hvis du bruker Bitcoin og ønsker å vise din støtte til
619 det jeg driver med, setter jeg pris på om du sender Bitcoin-donasjoner
620 til min adresse
621 <b><a href="bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b</a></b>. Merk,
622 betaling med bitcoin er ikke anonymt. :)</p>
623 </div>
624 <div class="tags">
625
626
627 Tags: <a href="https://people.skolelinux.org/pere/blog/tags/noark5">noark5</a>, <a href="https://people.skolelinux.org/pere/blog/tags/norsk">norsk</a>, <a href="https://people.skolelinux.org/pere/blog/tags/standard">standard</a>.
628
629
630 </div>
631 </div>
632 <div class="padding"></div>
633
634 <div class="entry">
635 <div class="title"><a href="https://people.skolelinux.org/pere/blog/New_and_improved_sqlcipher_in_Debian_for_accessing_Signal_database.html">New and improved sqlcipher in Debian for accessing Signal database</a></div>
636 <div class="date">12th November 2023</div>
637 <div class="body"><p>For a while now I wanted to have direct access to the
638 <a href="https://signal.org/">Signal</a> database of messages and
639 channels of my Desktop edition of Signal. I prefer the enforced end
640 to end encryption of Signal these days for my communication with
641 friends and family, to increase the level of safety and privacy as
642 well as raising the cost of the mass surveillance government and
643 non-government entities practice these days. In August I came across
644 a nice
645 <a href="https://www.yoranbrondsema.com/post/the-guide-to-extracting-statistics-from-your-signal-conversations/">recipe
646 on how to use sqlcipher to extract statistics from the Signal
647 database</a> explaining how to do this. Unfortunately this did not
648 work with the version of sqlcipher in Debian. The
649 <a href="http://tracker.debian.org/sqlcipher/">sqlcipher</a>
650 package is a "fork" of the sqlite package with added support for
651 encrypted databases. Sadly the current Debian maintainer
652 <a href="https://bugs.debian.org/961598">announced more than three
653 years ago that he did not have time to maintain sqlcipher</a>, so it
654 seemed unlikely to be upgraded by the maintainer. I was reluctant to
655 take on the job myself, as I have very limited experience maintaining
656 shared libraries in Debian. After waiting and hoping for a few
657 months, I gave up the last week, and set out to update the package. In
658 the process I orphaned it to make it more obvious for the next person
659 looking at it that the package need proper maintenance.</p>
660
661 <p>The version in Debian was around five years old, and quite a lot of
662 changes had taken place upstream into the Debian maintenance git
663 repository. After spending a few days importing the new upstream
664 versions, realising that upstream did not care much for SONAME
665 versioning as I saw library symbols being both added and removed with
666 minor version number changes to the project, I concluded that I had to
667 do a SONAME bump of the library package to avoid surprising the
668 reverse dependencies. I even added a simple
669 autopkgtest script to ensure the package work as intended. Dug deep
670 into the hole of learning shared library maintenance, I set out a few
671 days ago to upload the new version to Debian experimental to see what
672 the quality assurance framework in Debian had to say about the result.
673 The feedback told me the pacakge was not too shabby, and yesterday I
674 uploaded the latest version to Debian unstable. It should enter
675 testing today or tomorrow, perhaps delayed by
676 <a href="https://bugs.debian.org/1055812">a small library
677 transition</a>.</p>
678
679 <p>Armed with a new version of sqlcipher, I can now have a look at the
680 SQL database in ~/.config/Signal/sql/db.sqlite. First, one need to
681 fetch the encryption key from the Signal configuration using this
682 simple JSON extraction command:</p>
683
684 <pre>/usr/bin/jq -r '."key"' ~/.config/Signal/config.json</pre>
685
686 <p>Assuming the result from that command is 'secretkey', which is a
687 hexadecimal number representing the key used to encrypt the database.
688 Next, one can now connect to the database and inject the encryption
689 key for access via SQL to fetch information from the database. Here
690 is an example dumping the database structure:</p>
691
692 <pre>
693 % sqlcipher ~/.config/Signal/sql/db.sqlite
694 sqlite> PRAGMA key = "x'secretkey'";
695 sqlite> .schema
696 CREATE TABLE sqlite_stat1(tbl,idx,stat);
697 CREATE TABLE conversations(
698 id STRING PRIMARY KEY ASC,
699 json TEXT,
700
701 active_at INTEGER,
702 type STRING,
703 members TEXT,
704 name TEXT,
705 profileName TEXT
706 , profileFamilyName TEXT, profileFullName TEXT, e164 TEXT, serviceId TEXT, groupId TEXT, profileLastFetchedAt INTEGER);
707 CREATE TABLE identityKeys(
708 id STRING PRIMARY KEY ASC,
709 json TEXT
710 );
711 CREATE TABLE items(
712 id STRING PRIMARY KEY ASC,
713 json TEXT
714 );
715 CREATE TABLE sessions(
716 id TEXT PRIMARY KEY,
717 conversationId TEXT,
718 json TEXT
719 , ourServiceId STRING, serviceId STRING);
720 CREATE TABLE attachment_downloads(
721 id STRING primary key,
722 timestamp INTEGER,
723 pending INTEGER,
724 json TEXT
725 );
726 CREATE TABLE sticker_packs(
727 id TEXT PRIMARY KEY,
728 key TEXT NOT NULL,
729
730 author STRING,
731 coverStickerId INTEGER,
732 createdAt INTEGER,
733 downloadAttempts INTEGER,
734 installedAt INTEGER,
735 lastUsed INTEGER,
736 status STRING,
737 stickerCount INTEGER,
738 title STRING
739 , attemptedStatus STRING, position INTEGER DEFAULT 0 NOT NULL, storageID STRING, storageVersion INTEGER, storageUnknownFields BLOB, storageNeedsSync
740 INTEGER DEFAULT 0 NOT NULL);
741 CREATE TABLE stickers(
742 id INTEGER NOT NULL,
743 packId TEXT NOT NULL,
744
745 emoji STRING,
746 height INTEGER,
747 isCoverOnly INTEGER,
748 lastUsed INTEGER,
749 path STRING,
750 width INTEGER,
751
752 PRIMARY KEY (id, packId),
753 CONSTRAINT stickers_fk
754 FOREIGN KEY (packId)
755 REFERENCES sticker_packs(id)
756 ON DELETE CASCADE
757 );
758 CREATE TABLE sticker_references(
759 messageId STRING,
760 packId TEXT,
761 CONSTRAINT sticker_references_fk
762 FOREIGN KEY(packId)
763 REFERENCES sticker_packs(id)
764 ON DELETE CASCADE
765 );
766 CREATE TABLE emojis(
767 shortName TEXT PRIMARY KEY,
768 lastUsage INTEGER
769 );
770 CREATE TABLE messages(
771 rowid INTEGER PRIMARY KEY ASC,
772 id STRING UNIQUE,
773 json TEXT,
774 readStatus INTEGER,
775 expires_at INTEGER,
776 sent_at INTEGER,
777 schemaVersion INTEGER,
778 conversationId STRING,
779 received_at INTEGER,
780 source STRING,
781 hasAttachments INTEGER,
782 hasFileAttachments INTEGER,
783 hasVisualMediaAttachments INTEGER,
784 expireTimer INTEGER,
785 expirationStartTimestamp INTEGER,
786 type STRING,
787 body TEXT,
788 messageTimer INTEGER,
789 messageTimerStart INTEGER,
790 messageTimerExpiresAt INTEGER,
791 isErased INTEGER,
792 isViewOnce INTEGER,
793 sourceServiceId TEXT, serverGuid STRING NULL, sourceDevice INTEGER, storyId STRING, isStory INTEGER
794 GENERATED ALWAYS AS (type IS 'story'), isChangeCreatedByUs INTEGER NOT NULL DEFAULT 0, isTimerChangeFromSync INTEGER
795 GENERATED ALWAYS AS (
796 json_extract(json, '$.expirationTimerUpdate.fromSync') IS 1
797 ), seenStatus NUMBER default 0, storyDistributionListId STRING, expiresAt INT
798 GENERATED ALWAYS
799 AS (ifnull(
800 expirationStartTimestamp + (expireTimer * 1000),
801 9007199254740991
802 )), shouldAffectActivity INTEGER
803 GENERATED ALWAYS AS (
804 type IS NULL
805 OR
806 type NOT IN (
807 'change-number-notification',
808 'contact-removed-notification',
809 'conversation-merge',
810 'group-v1-migration',
811 'keychange',
812 'message-history-unsynced',
813 'profile-change',
814 'story',
815 'universal-timer-notification',
816 'verified-change'
817 )
818 ), shouldAffectPreview INTEGER
819 GENERATED ALWAYS AS (
820 type IS NULL
821 OR
822 type NOT IN (
823 'change-number-notification',
824 'contact-removed-notification',
825 'conversation-merge',
826 'group-v1-migration',
827 'keychange',
828 'message-history-unsynced',
829 'profile-change',
830 'story',
831 'universal-timer-notification',
832 'verified-change'
833 )
834 ), isUserInitiatedMessage INTEGER
835 GENERATED ALWAYS AS (
836 type IS NULL
837 OR
838 type NOT IN (
839 'change-number-notification',
840 'contact-removed-notification',
841 'conversation-merge',
842 'group-v1-migration',
843 'group-v2-change',
844 'keychange',
845 'message-history-unsynced',
846 'profile-change',
847 'story',
848 'universal-timer-notification',
849 'verified-change'
850 )
851 ), mentionsMe INTEGER NOT NULL DEFAULT 0, isGroupLeaveEvent INTEGER
852 GENERATED ALWAYS AS (
853 type IS 'group-v2-change' AND
854 json_array_length(json_extract(json, '$.groupV2Change.details')) IS 1 AND
855 json_extract(json, '$.groupV2Change.details[0].type') IS 'member-remove' AND
856 json_extract(json, '$.groupV2Change.from') IS NOT NULL AND
857 json_extract(json, '$.groupV2Change.from') IS json_extract(json, '$.groupV2Change.details[0].aci')
858 ), isGroupLeaveEventFromOther INTEGER
859 GENERATED ALWAYS AS (
860 isGroupLeaveEvent IS 1
861 AND
862 isChangeCreatedByUs IS 0
863 ), callId TEXT
864 GENERATED ALWAYS AS (
865 json_extract(json, '$.callId')
866 ));
867 CREATE TABLE sqlite_stat4(tbl,idx,neq,nlt,ndlt,sample);
868 CREATE TABLE jobs(
869 id TEXT PRIMARY KEY,
870 queueType TEXT STRING NOT NULL,
871 timestamp INTEGER NOT NULL,
872 data STRING TEXT
873 );
874 CREATE TABLE reactions(
875 conversationId STRING,
876 emoji STRING,
877 fromId STRING,
878 messageReceivedAt INTEGER,
879 targetAuthorAci STRING,
880 targetTimestamp INTEGER,
881 unread INTEGER
882 , messageId STRING);
883 CREATE TABLE senderKeys(
884 id TEXT PRIMARY KEY NOT NULL,
885 senderId TEXT NOT NULL,
886 distributionId TEXT NOT NULL,
887 data BLOB NOT NULL,
888 lastUpdatedDate NUMBER NOT NULL
889 );
890 CREATE TABLE unprocessed(
891 id STRING PRIMARY KEY ASC,
892 timestamp INTEGER,
893 version INTEGER,
894 attempts INTEGER,
895 envelope TEXT,
896 decrypted TEXT,
897 source TEXT,
898 serverTimestamp INTEGER,
899 sourceServiceId STRING
900 , serverGuid STRING NULL, sourceDevice INTEGER, receivedAtCounter INTEGER, urgent INTEGER, story INTEGER);
901 CREATE TABLE sendLogPayloads(
902 id INTEGER PRIMARY KEY ASC,
903
904 timestamp INTEGER NOT NULL,
905 contentHint INTEGER NOT NULL,
906 proto BLOB NOT NULL
907 , urgent INTEGER, hasPniSignatureMessage INTEGER DEFAULT 0 NOT NULL);
908 CREATE TABLE sendLogRecipients(
909 payloadId INTEGER NOT NULL,
910
911 recipientServiceId STRING NOT NULL,
912 deviceId INTEGER NOT NULL,
913
914 PRIMARY KEY (payloadId, recipientServiceId, deviceId),
915
916 CONSTRAINT sendLogRecipientsForeignKey
917 FOREIGN KEY (payloadId)
918 REFERENCES sendLogPayloads(id)
919 ON DELETE CASCADE
920 );
921 CREATE TABLE sendLogMessageIds(
922 payloadId INTEGER NOT NULL,
923
924 messageId STRING NOT NULL,
925
926 PRIMARY KEY (payloadId, messageId),
927
928 CONSTRAINT sendLogMessageIdsForeignKey
929 FOREIGN KEY (payloadId)
930 REFERENCES sendLogPayloads(id)
931 ON DELETE CASCADE
932 );
933 CREATE TABLE preKeys(
934 id STRING PRIMARY KEY ASC,
935 json TEXT
936 , ourServiceId NUMBER
937 GENERATED ALWAYS AS (json_extract(json, '$.ourServiceId')));
938 CREATE TABLE signedPreKeys(
939 id STRING PRIMARY KEY ASC,
940 json TEXT
941 , ourServiceId NUMBER
942 GENERATED ALWAYS AS (json_extract(json, '$.ourServiceId')));
943 CREATE TABLE badges(
944 id TEXT PRIMARY KEY,
945 category TEXT NOT NULL,
946 name TEXT NOT NULL,
947 descriptionTemplate TEXT NOT NULL
948 );
949 CREATE TABLE badgeImageFiles(
950 badgeId TEXT REFERENCES badges(id)
951 ON DELETE CASCADE
952 ON UPDATE CASCADE,
953 'order' INTEGER NOT NULL,
954 url TEXT NOT NULL,
955 localPath TEXT,
956 theme TEXT NOT NULL
957 );
958 CREATE TABLE storyReads (
959 authorId STRING NOT NULL,
960 conversationId STRING NOT NULL,
961 storyId STRING NOT NULL,
962 storyReadDate NUMBER NOT NULL,
963
964 PRIMARY KEY (authorId, storyId)
965 );
966 CREATE TABLE storyDistributions(
967 id STRING PRIMARY KEY NOT NULL,
968 name TEXT,
969
970 senderKeyInfoJson STRING
971 , deletedAtTimestamp INTEGER, allowsReplies INTEGER, isBlockList INTEGER, storageID STRING, storageVersion INTEGER, storageUnknownFields BLOB, storageNeedsSync INTEGER);
972 CREATE TABLE storyDistributionMembers(
973 listId STRING NOT NULL REFERENCES storyDistributions(id)
974 ON DELETE CASCADE
975 ON UPDATE CASCADE,
976 serviceId STRING NOT NULL,
977
978 PRIMARY KEY (listId, serviceId)
979 );
980 CREATE TABLE uninstalled_sticker_packs (
981 id STRING NOT NULL PRIMARY KEY,
982 uninstalledAt NUMBER NOT NULL,
983 storageID STRING,
984 storageVersion NUMBER,
985 storageUnknownFields BLOB,
986 storageNeedsSync INTEGER NOT NULL
987 );
988 CREATE TABLE groupCallRingCancellations(
989 ringId INTEGER PRIMARY KEY,
990 createdAt INTEGER NOT NULL
991 );
992 CREATE TABLE IF NOT EXISTS 'messages_fts_data'(id INTEGER PRIMARY KEY, block BLOB);
993 CREATE TABLE IF NOT EXISTS 'messages_fts_idx'(segid, term, pgno, PRIMARY KEY(segid, term)) WITHOUT ROWID;
994 CREATE TABLE IF NOT EXISTS 'messages_fts_content'(id INTEGER PRIMARY KEY, c0);
995 CREATE TABLE IF NOT EXISTS 'messages_fts_docsize'(id INTEGER PRIMARY KEY, sz BLOB);
996 CREATE TABLE IF NOT EXISTS 'messages_fts_config'(k PRIMARY KEY, v) WITHOUT ROWID;
997 CREATE TABLE edited_messages(
998 messageId STRING REFERENCES messages(id)
999 ON DELETE CASCADE,
1000 sentAt INTEGER,
1001 readStatus INTEGER
1002 , conversationId STRING);
1003 CREATE TABLE mentions (
1004 messageId REFERENCES messages(id) ON DELETE CASCADE,
1005 mentionAci STRING,
1006 start INTEGER,
1007 length INTEGER
1008 );
1009 CREATE TABLE kyberPreKeys(
1010 id STRING PRIMARY KEY NOT NULL,
1011 json TEXT NOT NULL, ourServiceId NUMBER
1012 GENERATED ALWAYS AS (json_extract(json, '$.ourServiceId')));
1013 CREATE TABLE callsHistory (
1014 callId TEXT PRIMARY KEY,
1015 peerId TEXT NOT NULL, -- conversation id (legacy) | uuid | groupId | roomId
1016 ringerId TEXT DEFAULT NULL, -- ringer uuid
1017 mode TEXT NOT NULL, -- enum "Direct" | "Group"
1018 type TEXT NOT NULL, -- enum "Audio" | "Video" | "Group"
1019 direction TEXT NOT NULL, -- enum "Incoming" | "Outgoing
1020 -- Direct: enum "Pending" | "Missed" | "Accepted" | "Deleted"
1021 -- Group: enum "GenericGroupCall" | "OutgoingRing" | "Ringing" | "Joined" | "Missed" | "Declined" | "Accepted" | "Deleted"
1022 status TEXT NOT NULL,
1023 timestamp INTEGER NOT NULL,
1024 UNIQUE (callId, peerId) ON CONFLICT FAIL
1025 );
1026 [ dropped all indexes to save space in this blog post ]
1027 CREATE TRIGGER messages_on_view_once_update AFTER UPDATE ON messages
1028 WHEN
1029 new.body IS NOT NULL AND new.isViewOnce = 1
1030 BEGIN
1031 DELETE FROM messages_fts WHERE rowid = old.rowid;
1032 END;
1033 CREATE TRIGGER messages_on_insert AFTER INSERT ON messages
1034 WHEN new.isViewOnce IS NOT 1 AND new.storyId IS NULL
1035 BEGIN
1036 INSERT INTO messages_fts
1037 (rowid, body)
1038 VALUES
1039 (new.rowid, new.body);
1040 END;
1041 CREATE TRIGGER messages_on_delete AFTER DELETE ON messages BEGIN
1042 DELETE FROM messages_fts WHERE rowid = old.rowid;
1043 DELETE FROM sendLogPayloads WHERE id IN (
1044 SELECT payloadId FROM sendLogMessageIds
1045 WHERE messageId = old.id
1046 );
1047 DELETE FROM reactions WHERE rowid IN (
1048 SELECT rowid FROM reactions
1049 WHERE messageId = old.id
1050 );
1051 DELETE FROM storyReads WHERE storyId = old.storyId;
1052 END;
1053 CREATE VIRTUAL TABLE messages_fts USING fts5(
1054 body,
1055 tokenize = 'signal_tokenizer'
1056 );
1057 CREATE TRIGGER messages_on_update AFTER UPDATE ON messages
1058 WHEN
1059 (new.body IS NULL OR old.body IS NOT new.body) AND
1060 new.isViewOnce IS NOT 1 AND new.storyId IS NULL
1061 BEGIN
1062 DELETE FROM messages_fts WHERE rowid = old.rowid;
1063 INSERT INTO messages_fts
1064 (rowid, body)
1065 VALUES
1066 (new.rowid, new.body);
1067 END;
1068 CREATE TRIGGER messages_on_insert_insert_mentions AFTER INSERT ON messages
1069 BEGIN
1070 INSERT INTO mentions (messageId, mentionAci, start, length)
1071
1072 SELECT messages.id, bodyRanges.value ->> 'mentionAci' as mentionAci,
1073 bodyRanges.value ->> 'start' as start,
1074 bodyRanges.value ->> 'length' as length
1075 FROM messages, json_each(messages.json ->> 'bodyRanges') as bodyRanges
1076 WHERE bodyRanges.value ->> 'mentionAci' IS NOT NULL
1077
1078 AND messages.id = new.id;
1079 END;
1080 CREATE TRIGGER messages_on_update_update_mentions AFTER UPDATE ON messages
1081 BEGIN
1082 DELETE FROM mentions WHERE messageId = new.id;
1083 INSERT INTO mentions (messageId, mentionAci, start, length)
1084
1085 SELECT messages.id, bodyRanges.value ->> 'mentionAci' as mentionAci,
1086 bodyRanges.value ->> 'start' as start,
1087 bodyRanges.value ->> 'length' as length
1088 FROM messages, json_each(messages.json ->> 'bodyRanges') as bodyRanges
1089 WHERE bodyRanges.value ->> 'mentionAci' IS NOT NULL
1090
1091 AND messages.id = new.id;
1092 END;
1093 sqlite>
1094 </pre>
1095
1096 <p>Finally I have the tool needed to inspect and process Signal
1097 messages that I need, without using the vendor provided client. Now
1098 on to transforming it to a more useful format.</p>
1099
1100 <p>As usual, if you use Bitcoin and want to show your support of my
1101 activities, please send Bitcoin donations to my address
1102 <b><a href="bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b</a></b>.</p>
1103 </div>
1104 <div class="tags">
1105
1106
1107 Tags: <a href="https://people.skolelinux.org/pere/blog/tags/debian">debian</a>, <a href="https://people.skolelinux.org/pere/blog/tags/english">english</a>, <a href="https://people.skolelinux.org/pere/blog/tags/sikkerhet">sikkerhet</a>, <a href="https://people.skolelinux.org/pere/blog/tags/surveillance">surveillance</a>.
1108
1109
1110 </div>
1111 </div>
1112 <div class="padding"></div>
1113
1114 <div class="entry">
1115 <div class="title"><a href="https://people.skolelinux.org/pere/blog/New_chrpath_release_0_17.html">New chrpath release 0.17</a></div>
1116 <div class="date">10th November 2023</div>
1117 <div class="body"><p>The chrpath package provide a simple command line tool to remove or
1118 modify the rpath or runpath of compiled ELF program. It is almost 10
1119 years since I updated the code base, but I stumbled over the tool
1120 today, and decided it was time to move the code base from Subversion
1121 to git and find a new home for it, as the previous one (Debian Alioth)
1122 has been shut down. I decided to go with
1123 <a href="https://codeberg.org/">Codeberg</a> this time, as it is my git
1124 service of choice these days, did a quick and dirty migration to git
1125 and updated the code with a few patches I found in the Debian bug
1126 tracker. These are the release notes:</p>
1127
1128 <p>New in 0.17 released 2023-11-10:</p>
1129
1130 <ul>
1131 <li>Moved project to Codeberg, as Alioth is shut down.</li>
1132 <li>Add Solaris support (use &lt;sys/byteorder.h> instead of &lt;byteswap.h>).
1133 Patch from Rainer Orth.</li>
1134 <li>Added missing newline from printf() line. Patch from Frank Dana.</li>
1135 <li>Corrected handling of multiple ELF sections. Patch from Frank Dana.</li>
1136 <li>Updated build rules for .deb. Partly based on patch from djcj.</li>
1137 </ul>
1138
1139 <p>The latest edition is tagged and available from
1140 <a href="https://codeberg.org/pere/chrpath">https://codeberg.org/pere/chrpath</a>.
1141
1142 <p>As usual, if you use Bitcoin and want to show your support of my
1143 activities, please send Bitcoin donations to my address
1144 <b><a href="bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b</a></b>.</p>
1145 </div>
1146 <div class="tags">
1147
1148
1149 Tags: <a href="https://people.skolelinux.org/pere/blog/tags/chrpath">chrpath</a>, <a href="https://people.skolelinux.org/pere/blog/tags/debian">debian</a>, <a href="https://people.skolelinux.org/pere/blog/tags/english">english</a>.
1150
1151
1152 </div>
1153 </div>
1154 <div class="padding"></div>
1155
1156 <div class="entry">
1157 <div class="title"><a href="https://people.skolelinux.org/pere/blog/Test_framework_for_DocBook_processors___formatters.html">Test framework for DocBook processors / formatters</a></div>
1158 <div class="date"> 5th November 2023</div>
1159 <div class="body"><p>All the books I have published so far has been using
1160 <a href="https://docbook.org/">DocBook</a> somewhere in the process.
1161 For the first book, the source format was DocBook, while for every
1162 later book it was an intermediate format used as the stepping stone to
1163 be able to present the same manuscript in several formats, on paper,
1164 as ebook in ePub format, as a HTML page and as a PDF file either for
1165 paper production or for Internet consumption. This is made possible
1166 with a wide variety of free software tools with DocBook support in
1167 Debian. The source format of later books have been docx via rst,
1168 Markdown, Filemaker and Asciidoc, and for all of these I was able to
1169 generate a suitable DocBook file for further processing using
1170 <a href="https://tracker.debian.org/pkg/pandoc">pandoc</a>,
1171 <a href="https://tracker.debian.org/pkg/asciidoc">a2x</a> and
1172 <a href="https://tracker.debian.org/pkg/asciidoctor">asciidoctor</a>,
1173 as well as rendering using
1174 <a href="https://tracker.debian.org/pkg/xmlto">xmlto</a>,
1175 <a href="https://tracker.debian.org/pkg/dbtoepub">dbtoepub</a>,
1176 <a href="https://tracker.debian.org/pkg/dblatex">dblatex</a>,
1177 <a href="https://tracker.debian.org/pkg/docbook-xsl">docbook-xsl</a> and
1178 <a href="https://tracker.debian.org/pkg/fop">fop</a>.</p>
1179
1180 <p>Most of the <a href="http://www.hungry.com/~pere/publisher/">books I
1181 have published</a> are translated books, with English as the source
1182 language. The use of
1183 <a href="https://tracker.debian.org/pkg/po4a">po4a</a> to
1184 handle translations using the gettext PO format has been a blessing,
1185 but publishing translated books had triggered the need to ensure the
1186 DocBook tools handle relevant languages correctly. For every new
1187 language I have published, I had to submit patches dblatex, dbtoepub
1188 and docbook-xsl fixing incorrect language and country specific issues
1189 in the framework themselves. Typically this has been missing keywords
1190 like 'figure' or sort ordering of index entries. After a while it
1191 became tiresome to only discover issues like this by accident, and I
1192 decided to write a DocBook "test framework" exercising various
1193 features of DocBook and allowing me to see all features exercised for
1194 a given language. It consist of a set of DocBook files, a version 4
1195 book, a version 5 book, a v4 book set, a v4 selection of problematic
1196 tables, one v4 testing sidefloat and finally one v4 testing a book of
1197 articles. The DocBook files are accompanied with a set of build rules
1198 for building PDF using dblatex and docbook-xsl/fop, HTML using xmlto
1199 or docbook-xsl and epub using dbtoepub. The result is a set of files
1200 visualizing footnotes, indexes, table of content list, figures,
1201 formulas and other DocBook features, allowing for a quick review on
1202 the completeness of the given locale settings. To build with a
1203 different language setting, all one need to do is edit the lang= value
1204 in the .xml file to pick a different ISO 639 code value and run
1205 'make'.</p>
1206
1207 <p>The <a href="https://codeberg.org/pere/docbook-example/">test framework
1208 source code</a> is available from Codeberg, and a generated set of
1209 presentations of the various examples is available as Codeberg static
1210 web pages at
1211 <a href="https://pere.codeberg.page/docbook-example/">https://pere.codeberg.page/docbook-example/</a>.
1212 Using this test framework I have been able to discover and report
1213 several bugs and missing features in various tools, and got a lot of
1214 them fixed. For example I got Northern Sami keywords added to both
1215 docbook-xsl and dblatex, fixed several typos in Norwegian bokmål and
1216 Norwegian Nynorsk, support for non-ascii title IDs added to pandoc,
1217 Norwegian index sorting support fixed in xindy and initial Norwegian
1218 Bokmål support added to dblatex. Some issues still remains, though.
1219 Default index sorting rules are still broken in several tools, so the
1220 Norwegian letters æ, ø and å are more often than not sorted properly
1221 in the book index.</p>
1222
1223 <p>The test framework recently received some more polish, as part of
1224 publishing my latest book. This book contained a lot of fairly
1225 complex tables, which exposed bugs in some of the tools. This made me
1226 add a new test file with various tables, as well as spend some time to
1227 brush up the build rules. My goal is for the test framework to
1228 exercise all DocBook features to make it easier to see which features
1229 work with different processors, and hopefully get them all to support
1230 the full set of DocBook features. Feel free to send patches to extend
1231 the test set, and test it with your favorite DocBook processor.
1232 Please visit these two URLs to learn more:</p>
1233
1234 <ul>
1235 <li><a href="https://codeberg.org/pere/docbook-example/">https://codeberg.org/pere/docbook-example/</a></li>
1236 <li><a href="https://pere.codeberg.page/docbook-example/">https://pere.codeberg.page/docbook-example/</a></li>
1237 </ul>
1238
1239 <p>If you want to learn more on Docbook and translations, I recommend
1240 having a look at the <a href="https://docbook.org/">the DocBook
1241 web site</a>,
1242 <a href="https://doccookbook.sourceforge.net/html/en/">the DoCookBook
1243 site<a/> and my earlier blog post on
1244 <a href="https://people.skolelinux.org/pere/blog/From_English_wiki_to_translated_PDF_and_epub_via_Docbook.html">how
1245 the Skolelinux project process and translate documentation</a>, a talk I gave earlier this year on
1246 <a href="https://www.nuug.no/aktiviteter/20230314-oversetting-og-publisering-av-b%c3%b8ker-med-fri-programvare/">how
1247 to translate and publish books using free software</a> (Norwegian
1248 only).</p>
1249
1250 <!--
1251
1252 https://github.com/docbook/xslt10-stylesheets/issues/205 (docbook-xsl: sme support)
1253 https://bugs.debian.org/968437 (xindy: index sorting rules for nb/nn)
1254 https://bugs.debian.org/856123 (pandoc: markdown to docbook with non-english titles)
1255 https://bugs.debian.org/864813 (dblatex: missing nb words)
1256 https://bugs.debian.org/756386 (dblatex: index sorting rules for nb/nn)
1257 https://bugs.debian.org/796871 (dbtoepub: index sorting rules for nb/nn)
1258 https://bugs.debian.org/792616 (dblatex: PDF metadata)
1259 https://bugs.debian.org/686908 (docbook-xsl: index sorting rules for nb/nn)
1260 https://sourceforge.net/tracker/?func=detail&atid=373747&aid=3556630&group_id=21935 (docbook-xsl: nb/nn support)
1261 https://bugs.debian.org/684391 (dblatex: initial nb support)
1262
1263 -->
1264
1265 <p>As usual, if you use Bitcoin and want to show your support of my
1266 activities, please send Bitcoin donations to my address
1267 <b><a href="bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b</a></b>.</p>
1268 </div>
1269 <div class="tags">
1270
1271
1272 Tags: <a href="https://people.skolelinux.org/pere/blog/tags/debian">debian</a>, <a href="https://people.skolelinux.org/pere/blog/tags/docbook">docbook</a>, <a href="https://people.skolelinux.org/pere/blog/tags/english">english</a>.
1273
1274
1275 </div>
1276 </div>
1277 <div class="padding"></div>
1278
1279 <div class="entry">
1280 <div class="title"><a href="https://people.skolelinux.org/pere/blog/_Virkninger_av_angrefristloven___hovedfagsoppgaven_som_fikk_endret_en_lov.html">«Virkninger av angrefristloven», hovedfagsoppgaven som fikk endret en lov</a></div>
1281 <div class="date">29th October 2023</div>
1282 <div class="body"><img src="http://people.skolelinux.org/pere/blog/images/2023-10-29-bok-angrefrist.svg" width="20%" align="center"></a>
1283
1284 <p>I 1979 leverte Ole-Erik Yrvin en hovedfagsoppgave for Cand. Scient.
1285 ved Institutt for sosiologi på Universitetet i Oslo på oppdrag fra
1286 Forbruker- og administrasjonsdepartementet. Oppgaven evaluerte
1287 Angrefristloven fra 1972, og det han oppdaget førte til at loven ble
1288 endret fire år senere.</p>
1289
1290 <p>Jeg har kjent Ole-Erik en stund, og synes det var trist at hans
1291 oppgave ikke lenger er tilgjengelig, hverken fra oppdragsgiver
1292 eller fra universitetet. Hans forsøk på å få den avbildet og lagt
1293 ut på Internett har vist seg fånyttes, så derfor tilbød jeg meg for
1294 en stund tilbake å publisere den og gjøre den tilgjengelig med
1295 fribruksvilkår på Internett. Det er nå klart, og hovedfagsoppgaven
1296 er tilgjengelig blant annet via <a
1297 href="http://www.hungry.com/~pere/publisher/">min liste over
1298 publiserte bøker</a>, både som nettside,
1299 <a href="https://www.lulu.com/search?contributor=Ole-Erik+Yrvin">digital
1300 bok i ePub-format og på papir fra lulu.com</a>. Jeg regner med at
1301 den også vil dukke opp på nettbokhandlere i løpet av en måned eller
1302 to.</p>
1303
1304 <p>Alle tabeller og figurer er gjenskapt for bedre lesbarhet, noen
1305 skrivefeil rettet opp og mange referanser har fått flere detaljer
1306 som ISBN-nummer og DOI-referanse. Selv om jeg ikke regner med at
1307 dette blir en kioskvelter, så håper jeg denne nye utgaven kan komme
1308 fremtiden til glede.</p>
1309
1310 <p>Som vanlig, hvis du bruker Bitcoin og ønsker å vise din støtte til
1311 det jeg driver med, setter jeg pris på om du sender Bitcoin-donasjoner
1312 til min adresse
1313 <b><a href="bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b</a></b>. Merk,
1314 betaling med bitcoin er ikke anonymt. :)</p>
1315 </div>
1316 <div class="tags">
1317
1318
1319 Tags: <a href="https://people.skolelinux.org/pere/blog/tags/docbook">docbook</a>, <a href="https://people.skolelinux.org/pere/blog/tags/norsk">norsk</a>.
1320
1321
1322 </div>
1323 </div>
1324 <div class="padding"></div>
1325
1326 <div class="entry">
1327 <div class="title"><a href="https://people.skolelinux.org/pere/blog/_underordnet_tjenestemann_blir_inhabil_fordi_en_overordnet_er_inhabil__.html">«underordnet tjenestemann blir inhabil fordi en overordnet er inhabil».</a></div>
1328 <div class="date"> 7th September 2023</div>
1329 <div class="body"><p>Medlemmene av Norges regjering har demonstert de siste månedene at
1330 habilitetsvureringer ikke er deres sterke side og det gjelder både
1331 Arbeiderpartiets og Senterpartiers representater. Det er heldigvis
1332 enklere i det private, da inhabilitetsreglene kun gjelder de som
1333 jobber for folket, ikke seg selv. Sist ut er utenriksminister
1334 Huitfeldt. I går kom nyheten om at
1335 <a href="https://www.nrk.no/nyheter/riksadvokaten_-okokrim-nestsjef-kan-behandle-huitfeldt-saken-1.16545162">Riksadvokaten
1336 har konkludert med at nestsjefen i Økokrim kan behandle sak om
1337 habilitet og innsidekunnskap</a> for Huitfeldt, på tross av at hans
1338 overordnede, sjefen for Økokrim, har meldt seg inhabil i saken. Dette
1339 er litt rart. I veilednigen
1340 «<a href="https://www.regjeringen.no/globalassets/upload/krd/vedlegg/komm/veiledere/habilitet_i_kommuner_og_fylkeskommuner.pdf">Habilitet
1341 i kommuner og fylkeskommuner</a>» av Kommunal- og regionaldepartementet
1342 forteller de hva som gjelder, riktig nok gjelder veiledningen ikke for
1343 Økokrim som jo ikke er kommune eller fylkeskommune, men jeg får ikke
1344 inntrykk av at dette er regler som kun gjelder for kommune og
1345 fylkeskommune:
1346
1347 <blockquote>
1348 <p>«<strong>2.1 Oversikt over inhabilitetsgrunnlagene</strong>
1349
1350 <p>De alminnelige reglene om inhabilitet for den offentlige
1351 forvaltningen er gitt i
1352 <a href="https://lovdata.no/dokument/NL/lov/1967-02-10/KAPITTEL_2#KAPITTEL_2">forvaltningsloven
1353 §§ 6 til 10</a>. Forvaltningslovens hovedregel om inhabilitet framgår
1354 av § 6. Her er det gitt tre ulike grunnlag som kan føre til at en
1355 tjenestemann eller folkevalgt blir inhabil. I § 6 første ledd
1356 bokstavene a til e er det oppstilt konkrete tilknytningsforhold mellom
1357 tjenestemannen og saken eller sakens parter som automatisk fører til
1358 inhabilitet. Annet ledd oppstiller en skjønnsmessig regel om at
1359 tjenestemannen også kan bli inhabil etter en konkret vurdering av
1360 inhabilitetsspørsmålet, der en lang rekke momenter kan være
1361 relevante. I tredje ledd er det regler om såkalt avledet
1362 inhabilitet. Det vil si at en underordnet tjenestemann blir inhabil
1363 fordi en overordnet er inhabil.»</p>
1364 </blockquote>
1365
1366 <p>Loven sier ganske enkelt «Er den overordnede tjenestemann ugild,
1367 kan avgjørelse i saken heller ikke treffes av en direkte underordnet
1368 tjenestemann i samme forvaltningsorgan.» Jeg antar tanken er at en
1369 underordnet vil stå i fare for å tilpasse sine konklusjoner til det
1370 overordnet vil ha fordel av, for å fortsatt ha et godt forhold til sin
1371 overordnede. Men jeg er ikke jurist og forstår nok ikke kompliserte
1372 juridiske vurderinger. For å sitere «Kamerat Napoleon» av George
1373 Orwell: «Alle dyr er like, men noen dyr er likere enn andre».
1374 </div>
1375 <div class="tags">
1376
1377
1378 Tags: <a href="https://people.skolelinux.org/pere/blog/tags/norsk">norsk</a>.
1379
1380
1381 </div>
1382 </div>
1383 <div class="padding"></div>
1384
1385 <div class="entry">
1386 <div class="title"><a href="https://people.skolelinux.org/pere/blog/Invidious_add_on_for_Kodi_20.html">Invidious add-on for Kodi 20</a></div>
1387 <div class="date">10th August 2023</div>
1388 <div class="body"><p>I still enjoy <a href="https://kodi.tv/">Kodi</a> and
1389 <a href="https://libreelec.tv/">LibreELEC</a> as my multimedia center
1390 at home. Sadly two of the services I really would like to use from
1391 within Kodi are not easily available. The most wanted add-on would be
1392 one making <a href="https://archive.org/">The Internet Archive</a>
1393 available, and it has
1394 <a href="https://kodi.wiki/view/Add-on:Internet_Archive">not been
1395 working</a> for many years. The second most wanted add-on is one
1396 using <a href="https://invidious.io/">the Invidious privacy enhanced
1397 Youtube frontent</a>. A plugin for this has been partly working, but
1398 not been kept up to date in the Kodi add-on repository, and its
1399 upstream seem to have given it up in April this year, when the git
1400 repository was closed. A few days ago I got tired of this sad state
1401 of affairs and decided to
1402 <a href="https://github.com/petterreinholdtsen/kodi-invidious-plugin">have
1403 a go at improving the Invidious add-on</a>. As
1404 <a href="https://github.com/iv-org/invidious/issues/3872">Google has
1405 already attacked</a> the Invidious concept, so it need all the support
1406 if can get. My small contribution here is to improve the service
1407 status on Kodi.</p>
1408
1409 <p>I added support to the Invidious add-on for automatically picking a
1410 working Invidious instance, instead of requiring the user to specify
1411 the URL to a specific instance after installation. I also had a look
1412 at the set of patches floating around in the various forks on github,
1413 and decided to clean up at least some of the features I liked and
1414 integrate them into my new release branch. Now the plugin can handle
1415 channel and short video items in search results. Earlier it could
1416 only handle single video instances in the search response. I also
1417 brushed up the set of metadata displayed a bit, but hope I can figure
1418 out how to get more relevant metadata displayed.</p>
1419
1420 <p>Because I only use Kodi 20 myself, I only test on version 20 and am
1421 only motivated to ensure version 20 is working. Because of API changes
1422 between version 19 and 20, I suspect it will fail with earlier Kodi
1423 versions.</p>
1424
1425 <p>I already
1426 <a href="https://github.com/xbmc/repo-plugins/pull/4363">asked to have
1427 the add-on added</a> to the official Kodi 20 repository, and is
1428 waiting to heard back from the repo maintainers.</p>
1429
1430 <p>As usual, if you use Bitcoin and want to show your support of my
1431 activities, please send Bitcoin donations to my address
1432 <b><a href="bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b</a></b>.</p>
1433 </div>
1434 <div class="tags">
1435
1436
1437 Tags: <a href="https://people.skolelinux.org/pere/blog/tags/english">english</a>, <a href="https://people.skolelinux.org/pere/blog/tags/kodi">kodi</a>, <a href="https://people.skolelinux.org/pere/blog/tags/multimedia">multimedia</a>, <a href="https://people.skolelinux.org/pere/blog/tags/video">video</a>.
1438
1439
1440 </div>
1441 </div>
1442 <div class="padding"></div>
1443
1444 <div class="entry">
1445 <div class="title"><a href="https://people.skolelinux.org/pere/blog/What_did_I_learn_from_OpenSnitch_this_summer_.html">What did I learn from OpenSnitch this summer?</a></div>
1446 <div class="date">11th June 2023</div>
1447 <div class="body"><p>With yesterdays
1448 <a href="https://www.debian.org/News/2023/20230610">release of Debian
1449 12 Bookworm</a>, I am happy to know the
1450 <a href="https://tracker.debian.org/pkg/opensnitch">the interactive
1451 application firewall OpenSnitch</a> is available for a wider audience.
1452 I have been running it for a few weeks now, and have been surprised
1453 about some of the programs connecting to the Internet. Some programs
1454 are obviously calling out from my machine, like the NTP network based
1455 clock adjusting system and Tor to reach other Tor clients, but others
1456 were more dubious. For example, the KDE Window manager try to look up
1457 the host name in DNS, for no apparent reason, but if this lookup is
1458 blocked the KDE desktop get periodically stuck when I use it. Another
1459 surprise was how much Firefox call home directly to mozilla.com,
1460 mozilla.net and googleapis.com, to mention a few, when I visit other
1461 web pages. This direct connection happen even if I told Firefox to
1462 always use a proxy, and the proxy setting is ignored for this traffic.
1463 Other surprising connections come from audacity and dirmngr (I do not
1464 use Gnome). It took some trial and error to get a good default set of
1465 permissions. Without it, I would get popups asking for permissions at
1466 any time, also the most inconvenient ones where I am in the middle of
1467 a time sensitive gaming session.</p>
1468
1469 <p>I suspect some application developers should rethink when then need
1470 to use network connections or DNS lookups, and recommend testing
1471 OpenSnitch (only <tt>apt install opensnitch</tt> away in Debian
1472 Bookworm) to locate and report any surprising Internet connections on
1473 your desktop machine.</p>
1474
1475 <p>At the moment the upstream developer and Debian package maintainer
1476 is working on making the system more reliable in Debian, by enabling
1477 the eBPF kernel module to track processes and connections instead of
1478 depending in content in /proc/. This should enter unstable fairly
1479 soon.</p>
1480
1481 <p>As usual, if you use Bitcoin and want to show your support of my
1482 activities, please send Bitcoin donations to my address
1483 <b><a href="bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b</a></b>.</p>
1484
1485 <p><strong>Update 2023-06-12</strong>: I got a tip about
1486 <a href="https://wiki.debian.org/PrivacyIssues">a list of privacy
1487 issues in Free Software</a> and the
1488 <a href="irc://irc.debian.org/%23debian-privacy">#debian-privacy IRC
1489 channel</a> discussing these topics.</p>
1490
1491 </div>
1492 <div class="tags">
1493
1494
1495 Tags: <a href="https://people.skolelinux.org/pere/blog/tags/debian">debian</a>, <a href="https://people.skolelinux.org/pere/blog/tags/english">english</a>, <a href="https://people.skolelinux.org/pere/blog/tags/opensnitch">opensnitch</a>.
1496
1497
1498 </div>
1499 </div>
1500 <div class="padding"></div>
1501
1502 <div class="entry">
1503 <div class="title"><a href="https://people.skolelinux.org/pere/blog/wmbusmeters__parse_data_from_your_utility_meter___nice_free_software.html">wmbusmeters, parse data from your utility meter - nice free software</a></div>
1504 <div class="date">19th May 2023</div>
1505 <div class="body"><p>There is a European standard for reading utility meters like water,
1506 gas, electricity or heat distribution meters. The
1507 <a href="https://en.wikipedia.org/wiki/Meter-Bus">Meter-Bus standard
1508 (EN 13757-2, EN 13757-3 and EN 137574)</a> provide a cross vendor way
1509 to talk to and collect meter data. I ran into this standard when I
1510 wanted to monitor some heat distribution meters, and managed to find
1511 free software that could do the job. The meters in question broadcast
1512 encrypted messages with meter information via radio, and the hardest
1513 part was to track down the encryption keys from the vendor. With this
1514 in place I could set up a MQTT gateway to submit the meter data for
1515 graphing.</p>
1516
1517 <p>The free software systems in question,
1518 <a href="https://tracker.debian.org/pkg/rtl-wmbus">rtl-wmbus</a> to
1519 read the messages from a software defined radio, and
1520 <a href="https://tracker.debian.org/pkg/wmbusmeters">wmbusmeters</a> to
1521 decrypt and decode the content of the messages, is working very well
1522 and allowe me to get frequent updates from my meters. I got in touch
1523 with upstream last year to see if there was any interest in publishing
1524 the packages via Debian. I was very happy to learn that Fredrik
1525 Öhrström volunteered to maintain the packages, and I have since
1526 assisted him in getting Debian package build rules in place as well as
1527 sponsoring the packages into the Debian archive. Sadly we completed
1528 it too late for them to become part of the next stable Debian release
1529 (Bookworm). The wmbusmeters package just cleared the NEW queue. It
1530 will need some work to fix a built problem, but I expect Fredrik will
1531 find a solution soon.</p>
1532
1533 <p>If you got a infrastructure meter supporting the Meter Bus
1534 standard, I strongly recommend having a look at these nice
1535 packages.</p>
1536
1537 <p>As usual, if you use Bitcoin and want to show your support of my
1538 activities, please send Bitcoin donations to my address
1539 <b><a href="bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b</a></b>.</p>
1540 </div>
1541 <div class="tags">
1542
1543
1544 Tags: <a href="https://people.skolelinux.org/pere/blog/tags/debian">debian</a>, <a href="https://people.skolelinux.org/pere/blog/tags/english">english</a>, <a href="https://people.skolelinux.org/pere/blog/tags/nice free software">nice free software</a>.
1545
1546
1547 </div>
1548 </div>
1549 <div class="padding"></div>
1550
1551 <p style="text-align: right;"><a href="index.rss"><img src="https://people.skolelinux.org/pere/blog/xml.gif" alt="RSS feed" width="36" height="14" /></a></p>
1552 <div id="sidebar">
1553
1554
1555
1556 <h2>Archive</h2>
1557 <ul>
1558
1559 <li>2023
1560 <ul>
1561
1562 <li><a href="https://people.skolelinux.org/pere/blog/archive/2023/01/">January (3)</a></li>
1563
1564 <li><a href="https://people.skolelinux.org/pere/blog/archive/2023/02/">February (1)</a></li>
1565
1566 <li><a href="https://people.skolelinux.org/pere/blog/archive/2023/04/">April (2)</a></li>
1567
1568 <li><a href="https://people.skolelinux.org/pere/blog/archive/2023/05/">May (3)</a></li>
1569
1570 <li><a href="https://people.skolelinux.org/pere/blog/archive/2023/06/">June (1)</a></li>
1571
1572 <li><a href="https://people.skolelinux.org/pere/blog/archive/2023/08/">August (1)</a></li>
1573
1574 <li><a href="https://people.skolelinux.org/pere/blog/archive/2023/09/">September (1)</a></li>
1575
1576 <li><a href="https://people.skolelinux.org/pere/blog/archive/2023/10/">October (1)</a></li>
1577
1578 <li><a href="https://people.skolelinux.org/pere/blog/archive/2023/11/">November (4)</a></li>
1579
1580 <li><a href="https://people.skolelinux.org/pere/blog/archive/2023/12/">December (1)</a></li>
1581
1582 </ul></li>
1583
1584 <li>2022
1585 <ul>
1586
1587 <li><a href="https://people.skolelinux.org/pere/blog/archive/2022/02/">February (1)</a></li>
1588
1589 <li><a href="https://people.skolelinux.org/pere/blog/archive/2022/03/">March (3)</a></li>
1590
1591 <li><a href="https://people.skolelinux.org/pere/blog/archive/2022/04/">April (2)</a></li>
1592
1593 <li><a href="https://people.skolelinux.org/pere/blog/archive/2022/06/">June (2)</a></li>
1594
1595 <li><a href="https://people.skolelinux.org/pere/blog/archive/2022/07/">July (1)</a></li>
1596
1597 <li><a href="https://people.skolelinux.org/pere/blog/archive/2022/09/">September (1)</a></li>
1598
1599 <li><a href="https://people.skolelinux.org/pere/blog/archive/2022/10/">October (1)</a></li>
1600
1601 <li><a href="https://people.skolelinux.org/pere/blog/archive/2022/12/">December (1)</a></li>
1602
1603 </ul></li>
1604
1605 <li>2021
1606 <ul>
1607
1608 <li><a href="https://people.skolelinux.org/pere/blog/archive/2021/01/">January (2)</a></li>
1609
1610 <li><a href="https://people.skolelinux.org/pere/blog/archive/2021/02/">February (1)</a></li>
1611
1612 <li><a href="https://people.skolelinux.org/pere/blog/archive/2021/05/">May (1)</a></li>
1613
1614 <li><a href="https://people.skolelinux.org/pere/blog/archive/2021/06/">June (1)</a></li>
1615
1616 <li><a href="https://people.skolelinux.org/pere/blog/archive/2021/07/">July (3)</a></li>
1617
1618 <li><a href="https://people.skolelinux.org/pere/blog/archive/2021/08/">August (1)</a></li>
1619
1620 <li><a href="https://people.skolelinux.org/pere/blog/archive/2021/09/">September (1)</a></li>
1621
1622 <li><a href="https://people.skolelinux.org/pere/blog/archive/2021/10/">October (1)</a></li>
1623
1624 <li><a href="https://people.skolelinux.org/pere/blog/archive/2021/12/">December (1)</a></li>
1625
1626 </ul></li>
1627
1628 <li>2020
1629 <ul>
1630
1631 <li><a href="https://people.skolelinux.org/pere/blog/archive/2020/02/">February (2)</a></li>
1632
1633 <li><a href="https://people.skolelinux.org/pere/blog/archive/2020/03/">March (2)</a></li>
1634
1635 <li><a href="https://people.skolelinux.org/pere/blog/archive/2020/04/">April (2)</a></li>
1636
1637 <li><a href="https://people.skolelinux.org/pere/blog/archive/2020/05/">May (3)</a></li>
1638
1639 <li><a href="https://people.skolelinux.org/pere/blog/archive/2020/06/">June (2)</a></li>
1640
1641 <li><a href="https://people.skolelinux.org/pere/blog/archive/2020/07/">July (1)</a></li>
1642
1643 <li><a href="https://people.skolelinux.org/pere/blog/archive/2020/09/">September (1)</a></li>
1644
1645 <li><a href="https://people.skolelinux.org/pere/blog/archive/2020/10/">October (1)</a></li>
1646
1647 <li><a href="https://people.skolelinux.org/pere/blog/archive/2020/11/">November (1)</a></li>
1648
1649 </ul></li>
1650
1651 <li>2019
1652 <ul>
1653
1654 <li><a href="https://people.skolelinux.org/pere/blog/archive/2019/01/">January (4)</a></li>
1655
1656 <li><a href="https://people.skolelinux.org/pere/blog/archive/2019/02/">February (3)</a></li>
1657
1658 <li><a href="https://people.skolelinux.org/pere/blog/archive/2019/03/">March (3)</a></li>
1659
1660 <li><a href="https://people.skolelinux.org/pere/blog/archive/2019/05/">May (2)</a></li>
1661
1662 <li><a href="https://people.skolelinux.org/pere/blog/archive/2019/06/">June (5)</a></li>
1663
1664 <li><a href="https://people.skolelinux.org/pere/blog/archive/2019/07/">July (2)</a></li>
1665
1666 <li><a href="https://people.skolelinux.org/pere/blog/archive/2019/08/">August (1)</a></li>
1667
1668 <li><a href="https://people.skolelinux.org/pere/blog/archive/2019/09/">September (1)</a></li>
1669
1670 <li><a href="https://people.skolelinux.org/pere/blog/archive/2019/11/">November (1)</a></li>
1671
1672 <li><a href="https://people.skolelinux.org/pere/blog/archive/2019/12/">December (4)</a></li>
1673
1674 </ul></li>
1675
1676 <li>2018
1677 <ul>
1678
1679 <li><a href="https://people.skolelinux.org/pere/blog/archive/2018/01/">January (1)</a></li>
1680
1681 <li><a href="https://people.skolelinux.org/pere/blog/archive/2018/02/">February (5)</a></li>
1682
1683 <li><a href="https://people.skolelinux.org/pere/blog/archive/2018/03/">March (5)</a></li>
1684
1685 <li><a href="https://people.skolelinux.org/pere/blog/archive/2018/04/">April (3)</a></li>
1686
1687 <li><a href="https://people.skolelinux.org/pere/blog/archive/2018/06/">June (2)</a></li>
1688
1689 <li><a href="https://people.skolelinux.org/pere/blog/archive/2018/07/">July (5)</a></li>
1690
1691 <li><a href="https://people.skolelinux.org/pere/blog/archive/2018/08/">August (3)</a></li>
1692
1693 <li><a href="https://people.skolelinux.org/pere/blog/archive/2018/09/">September (3)</a></li>
1694
1695 <li><a href="https://people.skolelinux.org/pere/blog/archive/2018/10/">October (5)</a></li>
1696
1697 <li><a href="https://people.skolelinux.org/pere/blog/archive/2018/11/">November (2)</a></li>
1698
1699 <li><a href="https://people.skolelinux.org/pere/blog/archive/2018/12/">December (4)</a></li>
1700
1701 </ul></li>
1702
1703 <li>2017
1704 <ul>
1705
1706 <li><a href="https://people.skolelinux.org/pere/blog/archive/2017/01/">January (4)</a></li>
1707
1708 <li><a href="https://people.skolelinux.org/pere/blog/archive/2017/02/">February (3)</a></li>
1709
1710 <li><a href="https://people.skolelinux.org/pere/blog/archive/2017/03/">March (5)</a></li>
1711
1712 <li><a href="https://people.skolelinux.org/pere/blog/archive/2017/04/">April (2)</a></li>
1713
1714 <li><a href="https://people.skolelinux.org/pere/blog/archive/2017/06/">June (5)</a></li>
1715
1716 <li><a href="https://people.skolelinux.org/pere/blog/archive/2017/07/">July (1)</a></li>
1717
1718 <li><a href="https://people.skolelinux.org/pere/blog/archive/2017/08/">August (1)</a></li>
1719
1720 <li><a href="https://people.skolelinux.org/pere/blog/archive/2017/09/">September (3)</a></li>
1721
1722 <li><a href="https://people.skolelinux.org/pere/blog/archive/2017/10/">October (5)</a></li>
1723
1724 <li><a href="https://people.skolelinux.org/pere/blog/archive/2017/11/">November (3)</a></li>
1725
1726 <li><a href="https://people.skolelinux.org/pere/blog/archive/2017/12/">December (4)</a></li>
1727
1728 </ul></li>
1729
1730 <li>2016
1731 <ul>
1732
1733 <li><a href="https://people.skolelinux.org/pere/blog/archive/2016/01/">January (3)</a></li>
1734
1735 <li><a href="https://people.skolelinux.org/pere/blog/archive/2016/02/">February (2)</a></li>
1736
1737 <li><a href="https://people.skolelinux.org/pere/blog/archive/2016/03/">March (3)</a></li>
1738
1739 <li><a href="https://people.skolelinux.org/pere/blog/archive/2016/04/">April (8)</a></li>
1740
1741 <li><a href="https://people.skolelinux.org/pere/blog/archive/2016/05/">May (8)</a></li>
1742
1743 <li><a href="https://people.skolelinux.org/pere/blog/archive/2016/06/">June (2)</a></li>
1744
1745 <li><a href="https://people.skolelinux.org/pere/blog/archive/2016/07/">July (2)</a></li>
1746
1747 <li><a href="https://people.skolelinux.org/pere/blog/archive/2016/08/">August (5)</a></li>
1748
1749 <li><a href="https://people.skolelinux.org/pere/blog/archive/2016/09/">September (2)</a></li>
1750
1751 <li><a href="https://people.skolelinux.org/pere/blog/archive/2016/10/">October (3)</a></li>
1752
1753 <li><a href="https://people.skolelinux.org/pere/blog/archive/2016/11/">November (8)</a></li>
1754
1755 <li><a href="https://people.skolelinux.org/pere/blog/archive/2016/12/">December (5)</a></li>
1756
1757 </ul></li>
1758
1759 <li>2015
1760 <ul>
1761
1762 <li><a href="https://people.skolelinux.org/pere/blog/archive/2015/01/">January (7)</a></li>
1763
1764 <li><a href="https://people.skolelinux.org/pere/blog/archive/2015/02/">February (6)</a></li>
1765
1766 <li><a href="https://people.skolelinux.org/pere/blog/archive/2015/03/">March (1)</a></li>
1767
1768 <li><a href="https://people.skolelinux.org/pere/blog/archive/2015/04/">April (4)</a></li>
1769
1770 <li><a href="https://people.skolelinux.org/pere/blog/archive/2015/05/">May (3)</a></li>
1771
1772 <li><a href="https://people.skolelinux.org/pere/blog/archive/2015/06/">June (4)</a></li>
1773
1774 <li><a href="https://people.skolelinux.org/pere/blog/archive/2015/07/">July (6)</a></li>
1775
1776 <li><a href="https://people.skolelinux.org/pere/blog/archive/2015/08/">August (2)</a></li>
1777
1778 <li><a href="https://people.skolelinux.org/pere/blog/archive/2015/09/">September (2)</a></li>
1779
1780 <li><a href="https://people.skolelinux.org/pere/blog/archive/2015/10/">October (9)</a></li>
1781
1782 <li><a href="https://people.skolelinux.org/pere/blog/archive/2015/11/">November (6)</a></li>
1783
1784 <li><a href="https://people.skolelinux.org/pere/blog/archive/2015/12/">December (3)</a></li>
1785
1786 </ul></li>
1787
1788 <li>2014
1789 <ul>
1790
1791 <li><a href="https://people.skolelinux.org/pere/blog/archive/2014/01/">January (2)</a></li>
1792
1793 <li><a href="https://people.skolelinux.org/pere/blog/archive/2014/02/">February (3)</a></li>
1794
1795 <li><a href="https://people.skolelinux.org/pere/blog/archive/2014/03/">March (8)</a></li>
1796
1797 <li><a href="https://people.skolelinux.org/pere/blog/archive/2014/04/">April (7)</a></li>
1798
1799 <li><a href="https://people.skolelinux.org/pere/blog/archive/2014/05/">May (1)</a></li>
1800
1801 <li><a href="https://people.skolelinux.org/pere/blog/archive/2014/06/">June (2)</a></li>
1802
1803 <li><a href="https://people.skolelinux.org/pere/blog/archive/2014/07/">July (2)</a></li>
1804
1805 <li><a href="https://people.skolelinux.org/pere/blog/archive/2014/08/">August (2)</a></li>
1806
1807 <li><a href="https://people.skolelinux.org/pere/blog/archive/2014/09/">September (5)</a></li>
1808
1809 <li><a href="https://people.skolelinux.org/pere/blog/archive/2014/10/">October (6)</a></li>
1810
1811 <li><a href="https://people.skolelinux.org/pere/blog/archive/2014/11/">November (3)</a></li>
1812
1813 <li><a href="https://people.skolelinux.org/pere/blog/archive/2014/12/">December (5)</a></li>
1814
1815 </ul></li>
1816
1817 <li>2013
1818 <ul>
1819
1820 <li><a href="https://people.skolelinux.org/pere/blog/archive/2013/01/">January (11)</a></li>
1821
1822 <li><a href="https://people.skolelinux.org/pere/blog/archive/2013/02/">February (9)</a></li>
1823
1824 <li><a href="https://people.skolelinux.org/pere/blog/archive/2013/03/">March (9)</a></li>
1825
1826 <li><a href="https://people.skolelinux.org/pere/blog/archive/2013/04/">April (6)</a></li>
1827
1828 <li><a href="https://people.skolelinux.org/pere/blog/archive/2013/05/">May (9)</a></li>
1829
1830 <li><a href="https://people.skolelinux.org/pere/blog/archive/2013/06/">June (10)</a></li>
1831
1832 <li><a href="https://people.skolelinux.org/pere/blog/archive/2013/07/">July (7)</a></li>
1833
1834 <li><a href="https://people.skolelinux.org/pere/blog/archive/2013/08/">August (3)</a></li>
1835
1836 <li><a href="https://people.skolelinux.org/pere/blog/archive/2013/09/">September (5)</a></li>
1837
1838 <li><a href="https://people.skolelinux.org/pere/blog/archive/2013/10/">October (7)</a></li>
1839
1840 <li><a href="https://people.skolelinux.org/pere/blog/archive/2013/11/">November (9)</a></li>
1841
1842 <li><a href="https://people.skolelinux.org/pere/blog/archive/2013/12/">December (3)</a></li>
1843
1844 </ul></li>
1845
1846 <li>2012
1847 <ul>
1848
1849 <li><a href="https://people.skolelinux.org/pere/blog/archive/2012/01/">January (7)</a></li>
1850
1851 <li><a href="https://people.skolelinux.org/pere/blog/archive/2012/02/">February (10)</a></li>
1852
1853 <li><a href="https://people.skolelinux.org/pere/blog/archive/2012/03/">March (17)</a></li>
1854
1855 <li><a href="https://people.skolelinux.org/pere/blog/archive/2012/04/">April (12)</a></li>
1856
1857 <li><a href="https://people.skolelinux.org/pere/blog/archive/2012/05/">May (12)</a></li>
1858
1859 <li><a href="https://people.skolelinux.org/pere/blog/archive/2012/06/">June (20)</a></li>
1860
1861 <li><a href="https://people.skolelinux.org/pere/blog/archive/2012/07/">July (17)</a></li>
1862
1863 <li><a href="https://people.skolelinux.org/pere/blog/archive/2012/08/">August (6)</a></li>
1864
1865 <li><a href="https://people.skolelinux.org/pere/blog/archive/2012/09/">September (9)</a></li>
1866
1867 <li><a href="https://people.skolelinux.org/pere/blog/archive/2012/10/">October (17)</a></li>
1868
1869 <li><a href="https://people.skolelinux.org/pere/blog/archive/2012/11/">November (10)</a></li>
1870
1871 <li><a href="https://people.skolelinux.org/pere/blog/archive/2012/12/">December (7)</a></li>
1872
1873 </ul></li>
1874
1875 <li>2011
1876 <ul>
1877
1878 <li><a href="https://people.skolelinux.org/pere/blog/archive/2011/01/">January (16)</a></li>
1879
1880 <li><a href="https://people.skolelinux.org/pere/blog/archive/2011/02/">February (6)</a></li>
1881
1882 <li><a href="https://people.skolelinux.org/pere/blog/archive/2011/03/">March (6)</a></li>
1883
1884 <li><a href="https://people.skolelinux.org/pere/blog/archive/2011/04/">April (7)</a></li>
1885
1886 <li><a href="https://people.skolelinux.org/pere/blog/archive/2011/05/">May (3)</a></li>
1887
1888 <li><a href="https://people.skolelinux.org/pere/blog/archive/2011/06/">June (2)</a></li>
1889
1890 <li><a href="https://people.skolelinux.org/pere/blog/archive/2011/07/">July (7)</a></li>
1891
1892 <li><a href="https://people.skolelinux.org/pere/blog/archive/2011/08/">August (6)</a></li>
1893
1894 <li><a href="https://people.skolelinux.org/pere/blog/archive/2011/09/">September (4)</a></li>
1895
1896 <li><a href="https://people.skolelinux.org/pere/blog/archive/2011/10/">October (2)</a></li>
1897
1898 <li><a href="https://people.skolelinux.org/pere/blog/archive/2011/11/">November (3)</a></li>
1899
1900 <li><a href="https://people.skolelinux.org/pere/blog/archive/2011/12/">December (1)</a></li>
1901
1902 </ul></li>
1903
1904 <li>2010
1905 <ul>
1906
1907 <li><a href="https://people.skolelinux.org/pere/blog/archive/2010/01/">January (2)</a></li>
1908
1909 <li><a href="https://people.skolelinux.org/pere/blog/archive/2010/02/">February (1)</a></li>
1910
1911 <li><a href="https://people.skolelinux.org/pere/blog/archive/2010/03/">March (3)</a></li>
1912
1913 <li><a href="https://people.skolelinux.org/pere/blog/archive/2010/04/">April (3)</a></li>
1914
1915 <li><a href="https://people.skolelinux.org/pere/blog/archive/2010/05/">May (9)</a></li>
1916
1917 <li><a href="https://people.skolelinux.org/pere/blog/archive/2010/06/">June (14)</a></li>
1918
1919 <li><a href="https://people.skolelinux.org/pere/blog/archive/2010/07/">July (12)</a></li>
1920
1921 <li><a href="https://people.skolelinux.org/pere/blog/archive/2010/08/">August (13)</a></li>
1922
1923 <li><a href="https://people.skolelinux.org/pere/blog/archive/2010/09/">September (7)</a></li>
1924
1925 <li><a href="https://people.skolelinux.org/pere/blog/archive/2010/10/">October (9)</a></li>
1926
1927 <li><a href="https://people.skolelinux.org/pere/blog/archive/2010/11/">November (13)</a></li>
1928
1929 <li><a href="https://people.skolelinux.org/pere/blog/archive/2010/12/">December (12)</a></li>
1930
1931 </ul></li>
1932
1933 <li>2009
1934 <ul>
1935
1936 <li><a href="https://people.skolelinux.org/pere/blog/archive/2009/01/">January (8)</a></li>
1937
1938 <li><a href="https://people.skolelinux.org/pere/blog/archive/2009/02/">February (8)</a></li>
1939
1940 <li><a href="https://people.skolelinux.org/pere/blog/archive/2009/03/">March (12)</a></li>
1941
1942 <li><a href="https://people.skolelinux.org/pere/blog/archive/2009/04/">April (10)</a></li>
1943
1944 <li><a href="https://people.skolelinux.org/pere/blog/archive/2009/05/">May (9)</a></li>
1945
1946 <li><a href="https://people.skolelinux.org/pere/blog/archive/2009/06/">June (3)</a></li>
1947
1948 <li><a href="https://people.skolelinux.org/pere/blog/archive/2009/07/">July (4)</a></li>
1949
1950 <li><a href="https://people.skolelinux.org/pere/blog/archive/2009/08/">August (3)</a></li>
1951
1952 <li><a href="https://people.skolelinux.org/pere/blog/archive/2009/09/">September (1)</a></li>
1953
1954 <li><a href="https://people.skolelinux.org/pere/blog/archive/2009/10/">October (2)</a></li>
1955
1956 <li><a href="https://people.skolelinux.org/pere/blog/archive/2009/11/">November (3)</a></li>
1957
1958 <li><a href="https://people.skolelinux.org/pere/blog/archive/2009/12/">December (3)</a></li>
1959
1960 </ul></li>
1961
1962 <li>2008
1963 <ul>
1964
1965 <li><a href="https://people.skolelinux.org/pere/blog/archive/2008/11/">November (5)</a></li>
1966
1967 <li><a href="https://people.skolelinux.org/pere/blog/archive/2008/12/">December (7)</a></li>
1968
1969 </ul></li>
1970
1971 </ul>
1972
1973
1974
1975 <h2>Tags</h2>
1976 <ul>
1977
1978 <li><a href="https://people.skolelinux.org/pere/blog/tags/3d-printer">3d-printer (19)</a></li>
1979
1980 <li><a href="https://people.skolelinux.org/pere/blog/tags/amiga">amiga (1)</a></li>
1981
1982 <li><a href="https://people.skolelinux.org/pere/blog/tags/aros">aros (1)</a></li>
1983
1984 <li><a href="https://people.skolelinux.org/pere/blog/tags/bankid">bankid (4)</a></li>
1985
1986 <li><a href="https://people.skolelinux.org/pere/blog/tags/betalkontant">betalkontant (9)</a></li>
1987
1988 <li><a href="https://people.skolelinux.org/pere/blog/tags/bitcoin">bitcoin (12)</a></li>
1989
1990 <li><a href="https://people.skolelinux.org/pere/blog/tags/bootsystem">bootsystem (17)</a></li>
1991
1992 <li><a href="https://people.skolelinux.org/pere/blog/tags/bsa">bsa (2)</a></li>
1993
1994 <li><a href="https://people.skolelinux.org/pere/blog/tags/chrpath">chrpath (3)</a></li>
1995
1996 <li><a href="https://people.skolelinux.org/pere/blog/tags/debian">debian (197)</a></li>
1997
1998 <li><a href="https://people.skolelinux.org/pere/blog/tags/debian edu">debian edu (159)</a></li>
1999
2000 <li><a href="https://people.skolelinux.org/pere/blog/tags/debian-handbook">debian-handbook (9)</a></li>
2001
2002 <li><a href="https://people.skolelinux.org/pere/blog/tags/digistan">digistan (11)</a></li>
2003
2004 <li><a href="https://people.skolelinux.org/pere/blog/tags/dld">dld (18)</a></li>
2005
2006 <li><a href="https://people.skolelinux.org/pere/blog/tags/docbook">docbook (32)</a></li>
2007
2008 <li><a href="https://people.skolelinux.org/pere/blog/tags/drivstoffpriser">drivstoffpriser (4)</a></li>
2009
2010 <li><a href="https://people.skolelinux.org/pere/blog/tags/english">english (455)</a></li>
2011
2012 <li><a href="https://people.skolelinux.org/pere/blog/tags/fiksgatami">fiksgatami (23)</a></li>
2013
2014 <li><a href="https://people.skolelinux.org/pere/blog/tags/fildeling">fildeling (14)</a></li>
2015
2016 <li><a href="https://people.skolelinux.org/pere/blog/tags/freeculture">freeculture (34)</a></li>
2017
2018 <li><a href="https://people.skolelinux.org/pere/blog/tags/freedombox">freedombox (9)</a></li>
2019
2020 <li><a href="https://people.skolelinux.org/pere/blog/tags/frikanalen">frikanalen (20)</a></li>
2021
2022 <li><a href="https://people.skolelinux.org/pere/blog/tags/h264">h264 (20)</a></li>
2023
2024 <li><a href="https://people.skolelinux.org/pere/blog/tags/intervju">intervju (43)</a></li>
2025
2026 <li><a href="https://people.skolelinux.org/pere/blog/tags/isenkram">isenkram (16)</a></li>
2027
2028 <li><a href="https://people.skolelinux.org/pere/blog/tags/kart">kart (23)</a></li>
2029
2030 <li><a href="https://people.skolelinux.org/pere/blog/tags/kodi">kodi (6)</a></li>
2031
2032 <li><a href="https://people.skolelinux.org/pere/blog/tags/ldap">ldap (9)</a></li>
2033
2034 <li><a href="https://people.skolelinux.org/pere/blog/tags/lego">lego (5)</a></li>
2035
2036 <li><a href="https://people.skolelinux.org/pere/blog/tags/lenker">lenker (8)</a></li>
2037
2038 <li><a href="https://people.skolelinux.org/pere/blog/tags/linuxcnc">linuxcnc (5)</a></li>
2039
2040 <li><a href="https://people.skolelinux.org/pere/blog/tags/lsdvd">lsdvd (2)</a></li>
2041
2042 <li><a href="https://people.skolelinux.org/pere/blog/tags/ltsp">ltsp (1)</a></li>
2043
2044 <li><a href="https://people.skolelinux.org/pere/blog/tags/madewithcc">madewithcc (3)</a></li>
2045
2046 <li><a href="https://people.skolelinux.org/pere/blog/tags/mesh network">mesh network (8)</a></li>
2047
2048 <li><a href="https://people.skolelinux.org/pere/blog/tags/multimedia">multimedia (46)</a></li>
2049
2050 <li><a href="https://people.skolelinux.org/pere/blog/tags/nice free software">nice free software (15)</a></li>
2051
2052 <li><a href="https://people.skolelinux.org/pere/blog/tags/noark5">noark5 (24)</a></li>
2053
2054 <li><a href="https://people.skolelinux.org/pere/blog/tags/norsk">norsk (323)</a></li>
2055
2056 <li><a href="https://people.skolelinux.org/pere/blog/tags/nuug">nuug (198)</a></li>
2057
2058 <li><a href="https://people.skolelinux.org/pere/blog/tags/offentlig innsyn">offentlig innsyn (40)</a></li>
2059
2060 <li><a href="https://people.skolelinux.org/pere/blog/tags/open311">open311 (2)</a></li>
2061
2062 <li><a href="https://people.skolelinux.org/pere/blog/tags/opensnitch">opensnitch (4)</a></li>
2063
2064 <li><a href="https://people.skolelinux.org/pere/blog/tags/opphavsrett">opphavsrett (75)</a></li>
2065
2066 <li><a href="https://people.skolelinux.org/pere/blog/tags/personvern">personvern (114)</a></li>
2067
2068 <li><a href="https://people.skolelinux.org/pere/blog/tags/raid">raid (2)</a></li>
2069
2070 <li><a href="https://people.skolelinux.org/pere/blog/tags/reactos">reactos (1)</a></li>
2071
2072 <li><a href="https://people.skolelinux.org/pere/blog/tags/reprap">reprap (11)</a></li>
2073
2074 <li><a href="https://people.skolelinux.org/pere/blog/tags/rfid">rfid (3)</a></li>
2075
2076 <li><a href="https://people.skolelinux.org/pere/blog/tags/robot">robot (17)</a></li>
2077
2078 <li><a href="https://people.skolelinux.org/pere/blog/tags/rss">rss (1)</a></li>
2079
2080 <li><a href="https://people.skolelinux.org/pere/blog/tags/ruter">ruter (7)</a></li>
2081
2082 <li><a href="https://people.skolelinux.org/pere/blog/tags/scraperwiki">scraperwiki (2)</a></li>
2083
2084 <li><a href="https://people.skolelinux.org/pere/blog/tags/sikkerhet">sikkerhet (60)</a></li>
2085
2086 <li><a href="https://people.skolelinux.org/pere/blog/tags/sitesummary">sitesummary (4)</a></li>
2087
2088 <li><a href="https://people.skolelinux.org/pere/blog/tags/skepsis">skepsis (5)</a></li>
2089
2090 <li><a href="https://people.skolelinux.org/pere/blog/tags/standard">standard (75)</a></li>
2091
2092 <li><a href="https://people.skolelinux.org/pere/blog/tags/stavekontroll">stavekontroll (7)</a></li>
2093
2094 <li><a href="https://people.skolelinux.org/pere/blog/tags/stortinget">stortinget (14)</a></li>
2095
2096 <li><a href="https://people.skolelinux.org/pere/blog/tags/surveillance">surveillance (65)</a></li>
2097
2098 <li><a href="https://people.skolelinux.org/pere/blog/tags/sysadmin">sysadmin (5)</a></li>
2099
2100 <li><a href="https://people.skolelinux.org/pere/blog/tags/usenix">usenix (2)</a></li>
2101
2102 <li><a href="https://people.skolelinux.org/pere/blog/tags/valg">valg (9)</a></li>
2103
2104 <li><a href="https://people.skolelinux.org/pere/blog/tags/verkidetfri">verkidetfri (21)</a></li>
2105
2106 <li><a href="https://people.skolelinux.org/pere/blog/tags/video">video (80)</a></li>
2107
2108 <li><a href="https://people.skolelinux.org/pere/blog/tags/vitenskap">vitenskap (4)</a></li>
2109
2110 <li><a href="https://people.skolelinux.org/pere/blog/tags/web">web (42)</a></li>
2111
2112 </ul>
2113
2114
2115 </div>
2116 <p style="text-align: right">
2117 Created by <a href="http://steve.org.uk/Software/chronicle">Chronicle v4.6</a>
2118 </p>
2119
2120 </body>
2121 </html>