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