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">
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" />
14 <a href=
"https://people.skolelinux.org/pere/blog/">Petter Reinholdtsen
</a>
23 <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>
24 <div class=
"date">14th May
2023</div>
25 <div class=
"body"><p>The LinuxCNC project is making headway these days. A lot of
26 patches and issues have seen activity on
27 <a href=
"https://github.com/LinuxCNC/linuxcnc/">the project github
28 pages
</a> recently. A few weeks ago there was a developer gathering
29 over at the
<a href=
"https://tormach.com/">Tormach
</a> headquarter in
30 Wisconsin, and now we are planning a new gathering in Norway. If you
31 wonder what LinuxCNC is, lets quote Wikipedia:
</p>
34 "LinuxCNC is a software system for numerical control of
35 machines such as milling machines, lathes, plasma cutters, routers,
36 cutting machines, robots and hexapods. It can control up to
9 axes or
37 joints of a CNC machine using G-code (RS-
274NGC) as input. It has
38 several GUIs suited to specific kinds of usage (touch screen,
39 interactive development)."
42 <p>The Norwegian developer gathering take place the weekend June
16th
43 to
18th this year, and is open for everyone interested in contributing
44 to LinuxCNC. Up to date information about the gathering can be found
46 <a href=
"https://sourceforge.net/p/emc/mailman/emc-developers/thread/sa64jp06nob.fsf%40hjemme.reinholdtsen.name/#msg37837251">the
47 developer mailing list thread
</a> where the gathering was announced.
48 Thanks to the good people at
49 <a href=
"https://www.debian.org/">Debian
</a>,
50 <a href=
"https://www.redpill-linpro.com/">Redpill-Linpro
</a> and
51 <a href=
"https://www.nuugfoundation.no/no/">NUUG Foundation
</a>, we
52 have enough sponsor funds to pay for food, and shelter for the people
53 traveling from afar to join us. If you would like to join the
54 gathering, get in touch.
</p>
56 <p>As usual, if you use Bitcoin and want to show your support of my
57 activities, please send Bitcoin donations to my address
58 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
63 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>.
68 <div class=
"padding"></div>
71 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/OpenSnitch_in_Debian_ready_for_prime_time.html">OpenSnitch in Debian ready for prime time
</a></div>
72 <div class=
"date">13th May
2023</div>
73 <div class=
"body"><p>A bit delayed,
74 <a href=
"https://tracker.debian.org/pkg/opensnitch">the interactive
75 application firewall OpenSnitch
</a> package in Debian now got the
76 latest fixes ready for Debian Bookworm. Because it depend on a
77 package missing on some architectures, the autopkgtest check of the
78 testing migration script did not understand that the tests were
79 actually working, so the migration was delayed. A bug in the package
80 dependencies is also fixed, so those installing the firewall package
81 (opensnitch) now also get the GUI admin tool (python3-opensnitch-ui)
82 installed by default. I am very grateful to Gustavo IƱiguez Goya for
83 his work on getting the package ready for Debian Bookworm.
</p>
85 <p>Armed with this package I have discovered some surprising
86 connections from programs I believed were able to work completly
87 offline, and it has already proven its worth, at least to me. If you
88 too want to get more familiar with the kind of programs using
89 Internett connections on your machine, I recommend testing
<tt>apt
90 install opensnitch
</tt> in Bookworm and see what you think.
</p>
92 <p>The package is still not able to build its eBPF module within
93 Debian. Not sure how much work it would be to get it working, but
94 suspect some kernel related packages need to be extended with more
95 header files to get it working.
</p>
97 <p>As usual, if you use Bitcoin and want to show your support of my
98 activities, please send Bitcoin donations to my address
99 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
104 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>.
109 <div class=
"padding"></div>
112 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/Speech_to_text__she_APTly_whispered__how_hard_can_it_be_.html">Speech to text, she APTly whispered, how hard can it be?
</a></div>
113 <div class=
"date">23rd April
2023</div>
114 <div class=
"body"><p>While visiting a convention during Easter, it occurred to me that
115 it would be great if I could have a digital Dictaphone with
116 transcribing capabilities, providing me with texts to cut-n-paste into
117 stuff I need to write. The background is that long drives often bring
118 up the urge to write on texts I am working on, which of course is out
119 of the question while driving. With the release of
120 <a href=
"https://github.com/openai/whisper/">OpenAI Whisper
</a>, this
121 seem to be within reach with Free Software, so I decided to give it a
122 go. OpenAI Whisper is a Linux based neural network system to read in
123 audio files and provide text representation of the speech in that
124 audio recording. It handle multiple languages and according to its
125 creators even can translate into a different language than the spoken
126 one. I have not tested the latter feature. It can either use the CPU
127 or a GPU with CUDA support. As far as I can tell, CUDA in practice
128 limit that feature to NVidia graphics cards. I have few of those, as
129 they do not work great with free software drivers, and have not tested
130 the GPU option. While looking into the matter, I did discover some
131 work to provide CUDA support on non-NVidia GPUs, and some work with
132 the library used by Whisper to port it to other GPUs, but have not
133 spent much time looking into GPU support yet. I've so far used an old
134 X220 laptop as my test machine, and only transcribed using its
137 <p>As it from a privacy standpoint is unthinkable to use computers
138 under control of someone else (aka a "cloud" service) to transcribe
139 ones thoughts and personal notes, I want to run the transcribing
140 system locally on my own computers. The only sensible approach to me
141 is to make the effort I put into this available for any Linux user and
142 to upload the needed packages into Debian. Looking at Debian Bookworm, I
143 discovered that only three packages were missing,
144 <a href=
"https://bugs.debian.org/1034307">tiktoken
</a>,
145 <a href=
"https://bugs.debian.org/1034144">triton
</a>, and
146 <a href=
"https://bugs.debian.org/1034091">openai-whisper
</a>. For a while
148 <a href=
"https://bugs.debian.org/1034286">ffmpeg-python
</a> was
150 <a href=
"https://github.com/kkroening/ffmpeg-python/issues/760">upstream
151 seem to have vanished
</a> I found it safer
152 <a href=
"https://github.com/openai/whisper/pull/1242">to rewrite
153 whisper
</a> to stop depending on in than to introduce ffmpeg-python
154 into Debian. I decided to place these packages under the umbrella of
155 <a href=
"https://salsa.debian.org/deeplearning-team">the Debian Deep
156 Learning Team
</a>, which seem like the best team to look after such
157 packages. Discussing the topic within the group also made me aware
158 that the triton package was already a future dependency of newer
159 versions of the torch package being planned, and would be needed after
160 Bookworm is released.
</p>
162 <p>All required code packages have been now waiting in
163 <a href=
"https://ftp-master.debian.org/new.html">the Debian NEW
164 queue
</a> since Wednesday, heading for Debian Experimental until
165 Bookworm is released. An unsolved issue is how to handle the neural
166 network models used by Whisper. The default behaviour of Whisper is
167 to require Internet connectivity and download the model requested to
168 <tt>~/.cache/whisper/
</tt> on first invocation. This obviously would
169 fail
<a href=
"https://people.debian.org/~bap/dfsg-faq.html">the
170 deserted island test of free software
</a> as the Debian packages would
171 be unusable for someone stranded with only the Debian archive and solar
172 powered computer on a deserted island.
</p>
174 <p>Because of this, I would love to include the models in the Debian
175 mirror system. This is problematic, as the models are very large
176 files, which would put a heavy strain on the Debian mirror
177 infrastructure around the globe. The strain would be even higher if
178 the models change often, which luckily as far as I can tell they do
179 not. The small model, which according to its creator is most useful
180 for English and in my experience is not doing a great job there
181 either, is
462 MiB (deb is
414 MiB). The medium model, which to me
182 seem to handle English speech fairly well is
1.5 GiB (deb is
1.3 GiB)
183 and the large model is
2.9 GiB (deb is
2.6 GiB). I would assume
184 everyone with enough resources would prefer to use the large model for
185 highest quality. I believe the models themselves would have to go
186 into the non-free part of the Debian archive, as they are not really
187 including any useful source code for updating the models. The
188 "source", aka the model training set, according to the creators
189 consist of "
680,
000 hours of multilingual and multitask supervised
190 data collected from the web", which to me reads material with both
191 unknown copyright terms, unavailable to the general public. In other
192 words, the source is not available according to the Debian Free
193 Software Guidelines and the model should be considered non-free.
</p>
195 <p>I asked the Debian FTP masters for advice regarding uploading a
196 model package on their IRC channel, and based on the feedback there it
197 is still unclear to me if such package would be accepted into the
198 archive. In any case I wrote build rules for a
199 <a href=
"https://salsa.debian.org/deeplearning-team/openai-whisper-model">OpenAI
200 Whisper model package
</a> and
201 <a href=
"https://github.com/openai/whisper/pull/1257">modified the
202 Whisper code base
</a> to prefer shared files under
<tt>/usr/
</tt> and
203 <tt>/var/
</tt> over user specific files in
<tt>~/.cache/whisper/
</tt>
204 to be able to use these model packages, to prepare for such
205 possibility. One solution might be to include only one of the models
206 (small or medium, I guess) in the Debian archive, and ask people to
207 download the others from the Internet. Not quite sure what to do
208 here, and advice is most welcome (use the debian-ai mailing list).
</p>
210 <p>To make it easier to test the new packages while I wait for them to
211 clear the NEW queue, I created an APT source targeting bookworm. I
212 selected Bookworm instead of Bullseye, even though I know the latter
213 would reach more users, is that some of the required dependencies are
214 missing from Bullseye and I during this phase of testing did not want
215 to backport a lot of packages just to get up and running.
</p>
217 <p>Here is a recipe to run as user root if you want to test OpenAI
218 Whisper using Debian packages on your Debian Bookworm installation,
219 first adding the APT repository GPG key to the list of trusted keys,
220 then setting up the APT repository and finally installing the packages
221 and one of the models:
</p>
224 curl https://geekbay.nuug.no/~pere/openai-whisper/D78F5C4796F353D211B119E28200D9B589641240.asc \
225 -o /etc/apt/trusted.gpg.d/pere-whisper.asc
226 mkdir -p /etc/apt/sources.list.d
227 cat
> /etc/apt/sources.list.d/pere-whisper.list
<<EOF
228 deb https://geekbay.nuug.no/~pere/openai-whisper/ bookworm main
229 deb-src https://geekbay.nuug.no/~pere/openai-whisper/ bookworm main
232 apt install openai-whisper
235 <p>The package work for me, but have not yet been tested on any other
236 computer than my own. With it, I have been able to (badly) transcribe
237 a
2 minute
40 second Norwegian audio clip to test using the small
238 model. This took
11 minutes and around
2.2 GiB of RAM. Transcribing
239 the same file with the medium model gave a accurate text in
77 minutes
240 using around
5.2 GiB of RAM. My test machine had too little memory to
241 test the large model, which I believe require
11 GiB of RAM. In
242 short, this now work for me using Debian packages, and I hope it will
243 for you and everyone else once the packages enter Debian.
</p>
245 <p>Now I can start on the audio recording part of this project.
</p>
247 <p>As usual, if you use Bitcoin and want to show your support of my
248 activities, please send Bitcoin donations to my address
249 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
254 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/multimedia">multimedia
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/video">video
</a>.
259 <div class=
"padding"></div>
262 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/rtlsdr_scanner__software_defined_radio_frequency_scanner_for_Linux____nice_free_software.html">rtlsdr-scanner, software defined radio frequency scanner for Linux - nice free software
</a></div>
263 <div class=
"date"> 7th April
2023</div>
264 <div class=
"body"><p>Today I finally found time to track down a useful radio frequency
265 scanner for my software defined radio. Just for fun I tried to locate
266 the radios used in the areas, and a good start would be to scan all
267 the frequencies to see what is in use. I've tried to find a useful
268 program earlier, but ran out of time before I managed to find a useful
269 tool. This time I was more successful, and after a few false leads I
270 found a description of
271 <a href=
"https://www.kali.org/tools/rtlsdr-scanner/">rtlsdr-scanner
272 over at the Kali site
</a>, and was able to track down
273 <a href=
"https://gitlab.com/kalilinux/packages/rtlsdr-scanner.git">the
274 Kali package git repository
</a> to build a deb package for the
275 scanner. Sadly the package is missing from the Debian project itself,
276 at least in Debian Bullseye. Two runtime dependencies,
277 <a href=
"https://gitlab.com/kalilinux/packages/python-visvis.git">python-visvis
</a>
279 <a href=
"https://gitlab.com/kalilinux/packages/python-rtlsdr.git">python-rtlsdr
</a>
280 had to be built and installed separately. Luckily '
<tt>gbp
281 buildpackage
</tt>' handled them just fine and no further packages had
282 to be manually built. The end result worked out of the box after
285 <p>My initial scans for FM channels worked just fine, so I knew the
286 scanner was functioning. But when I tried to scan every frequency
287 from
100 to
1000 MHz, the program stopped unexpectedly near the
288 completion. After some debugging I discovered USB software radio I
289 used rejected frequencies above
948 MHz, triggering a unreported
290 exception breaking the scan. Changing the scan to end at
957 worked
291 better. I similarly found the lower limit to be around
15, and ended
292 up with the following full scan:
</p>
294 <p><a href=
"https://people.skolelinux.org/pere/blog/images/2023-04-07-radio-freq-scanning.png"><img src=
"https://people.skolelinux.org/pere/blog/images/2023-04-07-radio-freq-scanning.png" width=
"100%"></a></p>
296 <p>Saving the scan did not work, but exporting it as a CSV file worked
297 just fine. I ended up with around
477k CVS lines with dB level for
298 the given frequency.
</p>
300 <p>The save failure seem to be a missing UTF-
8 encoding issue in the
301 python code. Will see if I can find time to send a patch
302 <a href=
"https://github.com/CdeMills/RTLSDR-Scanner/">upstream
</a>
303 later to fix this exception:
</p>
306 Traceback (most recent call last):
307 File "/usr/lib/python3/dist-packages/rtlsdr_scanner/main_window.py", line
485, in __on_save
308 save_plot(fullName, self.scanInfo, self.spectrum, self.locations)
309 File "/usr/lib/python3/dist-packages/rtlsdr_scanner/file.py", line
408, in save_plot
310 handle.write(json.dumps(data, indent=
4))
311 TypeError: a bytes-like object is required, not 'str'
312 Traceback (most recent call last):
313 File "/usr/lib/python3/dist-packages/rtlsdr_scanner/main_window.py", line
485, in __on_save
314 save_plot(fullName, self.scanInfo, self.spectrum, self.locations)
315 File "/usr/lib/python3/dist-packages/rtlsdr_scanner/file.py", line
408, in save_plot
316 handle.write(json.dumps(data, indent=
4))
317 TypeError: a bytes-like object is required, not 'str'
320 <p>As usual, if you use Bitcoin and want to show your support of my
321 activities, please send Bitcoin donations to my address
322 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
327 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>.
332 <div class=
"padding"></div>
335 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/OpenSnitch_available_in_Debian_Sid_and_Bookworm.html">OpenSnitch available in Debian Sid and Bookworm
</a></div>
336 <div class=
"date">25th February
2023</div>
337 <div class=
"body"><p>Thanks to the efforts of the OpenSnitch lead developer Gustavo
338 IƱiguez Goya allowing me to sponsor the upload,
339 <a href=
"https://tracker.debian.org/pkg/opensnitch">the interactive
340 application firewall OpenSnitch
</a> is now available in Debian
341 Testing, soon to become the next stable release of Debian.
</p>
343 <p>This is a package which set up a network firewall on one or more
344 machines, which is controlled by a graphical user interface that will
345 ask the user if a program should be allowed to connect to the local
346 network or the Internet. If some background daemon is trying to dial
347 home, it can be blocked from doing so with a simple mouse click, or by
348 default simply by not doing anything when the GUI question dialog pop
349 up. A list of all programs discovered using the network is provided
350 in the GUI, giving the user an overview of how the machine(s) programs
353 <p>OpenSnitch was uploaded for NEW processing about a month ago, and I
354 had little hope of it getting accepted and shaping up in time for the
355 package freeze, but the Debian ftpmasters proved to be amazingly quick
356 at checking out the package and it was accepted into the archive about
357 week after the first upload. It is now team maintained under the Go
358 language team umbrella. A few fixes to the default setup is only in
359 Sid, and should migrate to Testing/Bookworm in a week.
</p>
361 <p>During testing I ran into an
362 <a href=
"https://github.com/evilsocket/opensnitch/issues/813">issue
363 with Minecraft server broadcasts disappearing
</a>, which was quickly
364 resolved by the developer with a patch and a proposed configuration
365 change. I've been told this was caused by the Debian packages default
366 use if /proc/ information to track down kernel status, instead of the
367 newer eBPF module that can be used. The reason is simply that
368 upstream and I have failed to find a way to build the eBPF modules for
369 OpenSnitch without a complete configured Linux kernel source tree,
370 which as far as we can tell is unavailable as a build dependency in
371 Debian. We tried unsuccessfully so far to use the kernel-headers
372 package. It would be great if someone could provide some clues how to
373 build eBPF modules on build daemons in Debian, possibly without the full
376 <p>As usual, if you use Bitcoin and want to show your support of my
377 activities, please send Bitcoin donations to my address
378 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
383 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>.
388 <div class=
"padding"></div>
391 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/Is_the_desktop_recommending_your_program_for_opening_its_files_.html">Is the desktop recommending your program for opening its files?
</a></div>
392 <div class=
"date">29th January
2023</div>
393 <div class=
"body"><p>Linux desktop systems
394 <a href=
"https://specifications.freedesktop.org/basedir-spec/basedir-spec-latest.html">have
395 standardized
</a> how programs present themselves to the desktop
396 system. If a package include a .desktop file in
397 /usr/share/applications/, Gnome, KDE, LXDE, Xfce and the other desktop
398 environments will pick up the file and use its content to generate the
399 menu of available programs in the system. A lesser known fact is that
400 a package can also explain to the desktop system how to recognize the
401 files created by the program in question, and use it to open these
402 files on request, for example via a GUI file browser.
</p>
404 <p>A while back I ran into a package that did not tell the desktop
405 system how to recognize its files and was not used to open its files
406 in the file browser and fixed it. In the process I wrote a simple
407 debian/tests/ script to ensure the setup keep working. It might be
408 useful for other packages too, to ensure any future version of the
409 package keep handling its own files.
</p>
411 <p>For this to work the file format need a useful MIME type that can
412 be used to identify the format. If the file format do not yet have a
413 MIME type, it should define one and preferably also
414 <a href=
"https://www.iana.org/assignments/media-types/media-types.xhtml">register
415 it with IANA
</a> to ensure the MIME type string is reserved.
</p>
417 <p>The script uses the
<tt>xdg-mime
</tt> program from xdg-utils to
418 query the database of standardized package information and ensure it
419 return sensible values. It also need the location of an example file
420 for xdg-mime to guess the format of.
</p>
425 # Author: Petter Reinholdtsen
426 # License: GPL v2 or later at your choice.
428 # Validate the MIME setup, making sure motor types have
429 # application/vnd.openmotor+yaml associated with them and is connected
430 # to the openmotor desktop file.
434 mimetype="application/vnd.openmotor+yaml"
435 testfile="test/data/real/o3100/motor.ric"
436 mydesktopfile="openmotor.desktop"
438 filemime="$(xdg-mime query filetype "$testfile")"
440 if [ "$mimetype" != "$filemime" ] ; then
442 echo "error: xdg-mime claim motor file MIME type is $filemine, not $mimetype"
444 echo "success: xdg-mime report correct mime type $mimetype for motor file"
447 desktop=$(xdg-mime query default "$mimetype")
449 if [ "$mydesktopfile" != "$desktop" ]; then
451 echo "error: xdg-mime claim motor file should be handled by $desktop, not $mydesktopfile"
453 echo "success: xdg-mime agree motor file should be handled by $mydesktopfile"
459 <p>It is a simple way to ensure your users are not very surprised when
460 they try to open one of your file formats in their file browser.
</p>
462 <p>As usual, if you use Bitcoin and want to show your support of my
463 activities, please send Bitcoin donations to my address
464 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
469 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>.
474 <div class=
"padding"></div>
477 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/Opensnitch__the_application_level_interactive_firewall__heading_into_the_Debian_archive.html">Opensnitch, the application level interactive firewall, heading into the Debian archive
</a></div>
478 <div class=
"date">22nd January
2023</div>
479 <div class=
"body"><p>While reading a
480 <a href=
"https://sneak.berlin/20230115/macos-scans-your-local-files-now/">blog
481 post claiming MacOS X recently started scanning local files and
482 reporting information about them to Apple
</a>, even on a machine where
483 all such callback features had been disabled, I came across a
484 description of the Little Snitch application for MacOS X. It seemed
485 like a very nice tool to have in the tool box, and I decided to see if
486 something similar was available for Linux.
</p>
488 <p>It did not take long to find
489 <a href=
"https://github.com/evilsocket/opensnitch">the OpenSnitch
490 package
</a>, which has been in development since
2017, and now is in
491 version
1.5.0. It has had a
492 <a href=
"https://bugs.debian.org/909567">request for Debian
493 packaging
</a> since
2018, but no-one completed the job so far. Just
494 for fun, I decided to see if I could help, and I was very happy to
496 <a href=
"https://github.com/evilsocket/opensnitch/issues/304">upstream
497 want a Debian package too
</a>.
</p>
499 <p>After struggling a bit with getting the program to run, figuring
500 out building Go programs (and a little failed detour to look at eBPF
501 builds too - help needed), I am very happy to report that I am
502 sponsoring upstream to maintain the package in Debian, and it has
503 since this morning been waiting in NEW for the ftpmasters to have a
504 look. Perhaps it can get into the archive in time for the Bookworm
507 <p>As usual, if you use Bitcoin and want to show your support of my
508 activities, please send Bitcoin donations to my address
509 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
514 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>.
519 <div class=
"padding"></div>
522 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/LinuxCNC_MQTT_publisher_component.html">LinuxCNC MQTT publisher component
</a></div>
523 <div class=
"date"> 8th January
2023</div>
524 <div class=
"body"><p>I watched
<a href=
"https://yewtu.be/watch?v=jmKUV3aNLjk">a
2015
525 video from Andreas Schiffler
</a> the other day, where he set up
526 <a href=
"https://linuxcnc.org/">LinuxCNC
</a> to send status
527 information to the MQTT broker IBM Bluemix. As I also use MQTT for
528 graphing, it occured to me that a generic MQTT LinuxCNC component
529 would be useful and I set out to implement it. Today I got the first
530 draft limping along and submitted as
531 <a href=
"https://github.com/LinuxCNC/linuxcnc/pull/2253">a patch to the
532 LinuxCNC project
</a>.
</p>
534 <p>The simple part was setting up the MQTT publishing code in Python.
535 I already have set up other parts submitting data to my Mosquito MQTT
536 broker, so I could reuse that code. Writing a LinuxCNC component in
537 Python as new to me, but using existing examples in the code
538 repository and the extensive documentation, this was fairly straight
539 forward. The hardest part was creating a automated test for the
540 component to ensure it was working. Testing it in a simulated
541 LinuxCNC machine proved very useful, as I discovered features I needed
542 that I had not thought of yet, and adjusted the code quite a bit to
543 make it easier to test without a operational MQTT broker
546 <p>The draft is ready and working, but I am unsure which LinuxCNC HAL
547 pins I should collect and publish by default (in other words, the
548 default set of information pieces published), and how to get the
549 machine name from the LinuxCNC INI file. The latter is a minor
550 detail, but I expect it would be useful in a setup with several
551 machines available. I am hoping for feedback from the experienced
552 LinuxCNC developers and users, to make the component even better
553 before it can go into the mainland LinuxCNC code base.
</p>
555 <p>Since I started on the MQTT component, I came across
556 <a href=
"https://yewtu.be/watch?v=Bqa2grG0XtA">another video from Kent
557 VanderVelden
</a> where he combine LinuxCNC with a set of screen glasses
558 controlled by a Raspberry Pi, and it occured to me that it would
559 be useful for such use cases if LinuxCNC also provided a REST API for
560 querying its status. I hope to start on such component once the MQTT
561 component is working well.
</p>
563 <p>As usual, if you use Bitcoin and want to show your support of my
564 activities, please send Bitcoin donations to my address
565 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
570 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>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/robot">robot
</a>.
575 <div class=
"padding"></div>
578 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/ONVIF_IP_camera_management_tool_finally_in_Debian.html">ONVIF IP camera management tool finally in Debian
</a></div>
579 <div class=
"date">24th December
2022</div>
580 <div class=
"body"><p>Merry Christmas to you all. Here is a small gift to all those with
581 IP cameras following the
<a href=
"https://www.onvif.org/">ONVIF
582 specification
</a>. There is finally a nice command line and GUI tool
583 in Debian to manage ONVIF IP cameras. After working with upstream for
584 a few months and sponsoring the upload, I am very happy to report that
585 the
<a href=
"https://tracker.debian.org/libonvif">libonvif package
</a>
586 entered Debian Sid last night.
</p>
588 <p>The package provide a C library to communicate with such cameras, a
589 command line tool to locate and update settings of (like password) the
590 cameras and a GUI tool to configure and control the units as well as
591 preview the video from the camera. Libonvif is available on Both
592 Linux and Windows and the GUI tool uses the Qt library. The main
593 competitors are non-free software, while libonvif is GNU GPL licensed.
594 I am very glad Debian users in the future can control their cameras
595 using a free software system provided by Debian. But the ONVIF world
596 is full of slightly broken firmware, where the cameras pretend to
597 follow the ONVIF specification but fail to set some configuration
598 values or refuse to provide video to more than one recipient at the
599 time, and the onvif project is quite young and might take a while
600 before it completely work with your camera. Upstream seem eager to
601 improve the library, so handling any broken camera might be just
<a
602 href=
"https://github.com/sr99622/libonvif/">a bug report away
</a>.
</p>
604 <p>The package just cleared NEW, and need a new source only upload
605 before it can enter testing. This will happen in the next few
608 <p>As usual, if you use Bitcoin and want to show your support of my
609 activities, please send Bitcoin donations to my address
610 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
615 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/multimedia">multimedia
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/standard">standard
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/surveillance">surveillance
</a>.
620 <div class=
"padding"></div>
623 <div class=
"title"><a href=
"https://people.skolelinux.org/pere/blog/Managing_and_using_ONVIF_IP_cameras_with_Linux.html">Managing and using ONVIF IP cameras with Linux
</a></div>
624 <div class=
"date">19th October
2022</div>
625 <div class=
"body"><p>Recently I have been looking at how to control and collect data
626 from a handful IP cameras using Linux. I both wanted to change their
627 settings and to make their imagery available via a free software
628 service under my control. Here is a summary of the tools I found.
</p>
630 <p>First I had to identify the cameras and their protocols. As far as
631 I could tell, they were using some SOAP looking protocol and their
632 internal web server seem to only work with Microsoft Internet Explorer
633 with some proprietary binary plugin, which in these days of course is
634 a security disaster and also made it impossible for me to use the
635 camera web interface. Luckily I discovered that the SOAP looking
636 protocol is actually following
<a href=
"https://www.onvif.org/">the
637 ONVIF specification
</a>, which seem to be supported by a lot of IP
638 cameras these days.
</p>
640 <p>Once the protocol was identified, I was able to find what appear to
641 be the most popular way to configure ONVIF cameras, the free software
643 <a href=
"https://sourceforge.net/projects/onvifdm/">ONVIF Device
644 Manager
</a>. Lacking any other options at the time, I tried
645 unsuccessfully to get it running using Wine, but was missing a dotnet
646 40 library and I found no way around it to run it on Linux.
</p>
648 <p>The next tool I found to configure the cameras were a non-free Linux Qt
649 client
<a href=
"https://www.lingodigit.com/onvif_nvcdemo.html">ONVIF
650 Device Tool
</a>. I did not like its terms of use, so did not spend
653 <p>To collect the video and make it available in a web interface, I
654 found the Zoneminder tool in Debian. A recent version was able to
655 automatically detect and configure ONVIF devices, so I could use it to
656 set up motion detection in and collection of the camera output. I had
657 initial problems getting the ONVIF autodetection to work, as both
658 Firefox and Chromium
<a href=
"https://bugs.debian.org/1001188">refused
659 the inter-tab communication
</a> being used by the Zoneminder web
660 pages, but managed to get konqueror to work. Apparently the "Enhanced
661 Tracking Protection" in Firefox cause the problem. I ended up
662 upgrading to the Bookworm edition of Zoneminder in the process to try
663 to fix the issue, and believe the problem might be solved now.
</p>
665 <p>In the process I came across the nice Linux GUI tool
666 <a href=
"https://gitlab.com/caspermeijn/onvifviewer/">ONVIF Viewer
</a>
667 allowing me to preview the camera output and validate the login
668 passwords required. Sadly its author has grown tired of maintaining
669 the software, so it might not see any future updates. Which is sad,
670 as the viewer is sightly unstable and the picture tend to lock up.
671 Note, this lockup might be due to limitations in the cameras and not
672 the viewer implementation. I suspect the camera is only able to
673 provide pictures to one client at the time, and the Zoneminder feed
674 might interfere with the GUI viewer. I have
675 <a href=
"https://bugs.debian.org/1000820">asked for the tool to be
676 included in Debian
</a>.
</p>
678 <p>Finally, I found what appear to be very nice Linux free software
679 replacement for the Windows tool, named
680 <a href=
"https://github.com/sr99622/libonvif/">libonvif
</a>. It
681 provide a C library to talk to ONVIF devices as well as a command line
682 and GUI tool using the library. Using the GUI tool I was able to change
683 the admin passwords and update other settings of the cameras. I have
684 <a href=
"https://bugs.debian.org/1021980">asked for the package to be
685 included in Debian
</a>.
</p>
687 <p>As usual, if you use Bitcoin and want to show your support of my
688 activities, please send Bitcoin donations to my address
689 <b><a href=
"bitcoin:15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b">15oWEoG9dUPovwmUL9KWAnYRtNJEkP1u1b
</a></b>.
</p>
691 <p><strong>Update
2022-
10-
20</strong>: Since my initial publication of
692 this text, I got several suggestions for more free software Linux
693 tools. There is
<a href=
"https://github.com/quatanium/python-onvif">a
694 ONVIF python library
</a> (already
695 <a href=
"https://bugs.debian.org/824240">requested into Debian
</a>) and
696 <a href=
"https://github.com/FalkTannhaeuser/python-onvif-zeep">a python
3
697 fork
</a> using a different SOAP dependency. There is also
698 <a href=
"https://www.home-assistant.io/integrations/onvif/">support for
699 ONVIF in Home Assistant
</a>, and there is an alternative to Zoneminder
700 called
<a href=
"https://www.shinobi.video/">Shinobi
</a>. The latter
701 two are not included in Debian either. I have not tested any of these
707 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/multimedia">multimedia
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/standard">standard
</a>,
<a href=
"https://people.skolelinux.org/pere/blog/tags/surveillance">surveillance
</a>.
712 <div class=
"padding"></div>
714 <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>
725 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2023/01/">January (
3)
</a></li>
727 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2023/02/">February (
1)
</a></li>
729 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2023/04/">April (
2)
</a></li>
731 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2023/05/">May (
2)
</a></li>
738 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2022/02/">February (
1)
</a></li>
740 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2022/03/">March (
3)
</a></li>
742 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2022/04/">April (
2)
</a></li>
744 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2022/06/">June (
2)
</a></li>
746 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2022/07/">July (
1)
</a></li>
748 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2022/09/">September (
1)
</a></li>
750 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2022/10/">October (
1)
</a></li>
752 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2022/12/">December (
1)
</a></li>
759 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2021/01/">January (
2)
</a></li>
761 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2021/02/">February (
1)
</a></li>
763 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2021/05/">May (
1)
</a></li>
765 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2021/06/">June (
1)
</a></li>
767 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2021/07/">July (
3)
</a></li>
769 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2021/08/">August (
1)
</a></li>
771 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2021/09/">September (
1)
</a></li>
773 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2021/10/">October (
1)
</a></li>
775 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2021/12/">December (
1)
</a></li>
782 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2020/02/">February (
2)
</a></li>
784 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2020/03/">March (
2)
</a></li>
786 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2020/04/">April (
2)
</a></li>
788 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2020/05/">May (
3)
</a></li>
790 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2020/06/">June (
2)
</a></li>
792 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2020/07/">July (
1)
</a></li>
794 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2020/09/">September (
1)
</a></li>
796 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2020/10/">October (
1)
</a></li>
798 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2020/11/">November (
1)
</a></li>
805 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/01/">January (
4)
</a></li>
807 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/02/">February (
3)
</a></li>
809 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/03/">March (
3)
</a></li>
811 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/05/">May (
2)
</a></li>
813 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/06/">June (
5)
</a></li>
815 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/07/">July (
2)
</a></li>
817 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/08/">August (
1)
</a></li>
819 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/09/">September (
1)
</a></li>
821 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/11/">November (
1)
</a></li>
823 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2019/12/">December (
4)
</a></li>
830 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/01/">January (
1)
</a></li>
832 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/02/">February (
5)
</a></li>
834 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/03/">March (
5)
</a></li>
836 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/04/">April (
3)
</a></li>
838 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/06/">June (
2)
</a></li>
840 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/07/">July (
5)
</a></li>
842 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/08/">August (
3)
</a></li>
844 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/09/">September (
3)
</a></li>
846 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/10/">October (
5)
</a></li>
848 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/11/">November (
2)
</a></li>
850 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2018/12/">December (
4)
</a></li>
857 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/01/">January (
4)
</a></li>
859 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/02/">February (
3)
</a></li>
861 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/03/">March (
5)
</a></li>
863 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/04/">April (
2)
</a></li>
865 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/06/">June (
5)
</a></li>
867 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/07/">July (
1)
</a></li>
869 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/08/">August (
1)
</a></li>
871 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/09/">September (
3)
</a></li>
873 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/10/">October (
5)
</a></li>
875 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/11/">November (
3)
</a></li>
877 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2017/12/">December (
4)
</a></li>
884 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/01/">January (
3)
</a></li>
886 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/02/">February (
2)
</a></li>
888 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/03/">March (
3)
</a></li>
890 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/04/">April (
8)
</a></li>
892 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/05/">May (
8)
</a></li>
894 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/06/">June (
2)
</a></li>
896 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/07/">July (
2)
</a></li>
898 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/08/">August (
5)
</a></li>
900 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/09/">September (
2)
</a></li>
902 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/10/">October (
3)
</a></li>
904 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/11/">November (
8)
</a></li>
906 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2016/12/">December (
5)
</a></li>
913 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/01/">January (
7)
</a></li>
915 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/02/">February (
6)
</a></li>
917 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/03/">March (
1)
</a></li>
919 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/04/">April (
4)
</a></li>
921 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/05/">May (
3)
</a></li>
923 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/06/">June (
4)
</a></li>
925 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/07/">July (
6)
</a></li>
927 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/08/">August (
2)
</a></li>
929 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/09/">September (
2)
</a></li>
931 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/10/">October (
9)
</a></li>
933 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/11/">November (
6)
</a></li>
935 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2015/12/">December (
3)
</a></li>
942 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/01/">January (
2)
</a></li>
944 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/02/">February (
3)
</a></li>
946 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/03/">March (
8)
</a></li>
948 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/04/">April (
7)
</a></li>
950 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/05/">May (
1)
</a></li>
952 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/06/">June (
2)
</a></li>
954 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/07/">July (
2)
</a></li>
956 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/08/">August (
2)
</a></li>
958 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/09/">September (
5)
</a></li>
960 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/10/">October (
6)
</a></li>
962 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/11/">November (
3)
</a></li>
964 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2014/12/">December (
5)
</a></li>
971 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/01/">January (
11)
</a></li>
973 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/02/">February (
9)
</a></li>
975 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/03/">March (
9)
</a></li>
977 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/04/">April (
6)
</a></li>
979 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/05/">May (
9)
</a></li>
981 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/06/">June (
10)
</a></li>
983 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/07/">July (
7)
</a></li>
985 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/08/">August (
3)
</a></li>
987 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/09/">September (
5)
</a></li>
989 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/10/">October (
7)
</a></li>
991 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/11/">November (
9)
</a></li>
993 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2013/12/">December (
3)
</a></li>
1000 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/01/">January (
7)
</a></li>
1002 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/02/">February (
10)
</a></li>
1004 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/03/">March (
17)
</a></li>
1006 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/04/">April (
12)
</a></li>
1008 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/05/">May (
12)
</a></li>
1010 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/06/">June (
20)
</a></li>
1012 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/07/">July (
17)
</a></li>
1014 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/08/">August (
6)
</a></li>
1016 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/09/">September (
9)
</a></li>
1018 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/10/">October (
17)
</a></li>
1020 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/11/">November (
10)
</a></li>
1022 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2012/12/">December (
7)
</a></li>
1029 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/01/">January (
16)
</a></li>
1031 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/02/">February (
6)
</a></li>
1033 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/03/">March (
6)
</a></li>
1035 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/04/">April (
7)
</a></li>
1037 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/05/">May (
3)
</a></li>
1039 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/06/">June (
2)
</a></li>
1041 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/07/">July (
7)
</a></li>
1043 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/08/">August (
6)
</a></li>
1045 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/09/">September (
4)
</a></li>
1047 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/10/">October (
2)
</a></li>
1049 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/11/">November (
3)
</a></li>
1051 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2011/12/">December (
1)
</a></li>
1058 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/01/">January (
2)
</a></li>
1060 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/02/">February (
1)
</a></li>
1062 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/03/">March (
3)
</a></li>
1064 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/04/">April (
3)
</a></li>
1066 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/05/">May (
9)
</a></li>
1068 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/06/">June (
14)
</a></li>
1070 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/07/">July (
12)
</a></li>
1072 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/08/">August (
13)
</a></li>
1074 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/09/">September (
7)
</a></li>
1076 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/10/">October (
9)
</a></li>
1078 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/11/">November (
13)
</a></li>
1080 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2010/12/">December (
12)
</a></li>
1087 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/01/">January (
8)
</a></li>
1089 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/02/">February (
8)
</a></li>
1091 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/03/">March (
12)
</a></li>
1093 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/04/">April (
10)
</a></li>
1095 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/05/">May (
9)
</a></li>
1097 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/06/">June (
3)
</a></li>
1099 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/07/">July (
4)
</a></li>
1101 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/08/">August (
3)
</a></li>
1103 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/09/">September (
1)
</a></li>
1105 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/10/">October (
2)
</a></li>
1107 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/11/">November (
3)
</a></li>
1109 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2009/12/">December (
3)
</a></li>
1116 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2008/11/">November (
5)
</a></li>
1118 <li><a href=
"https://people.skolelinux.org/pere/blog/archive/2008/12/">December (
7)
</a></li>
1129 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/3d-printer">3d-printer (
19)
</a></li>
1131 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/amiga">amiga (
1)
</a></li>
1133 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/aros">aros (
1)
</a></li>
1135 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/bankid">bankid (
4)
</a></li>
1137 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/betalkontant">betalkontant (
9)
</a></li>
1139 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/bitcoin">bitcoin (
12)
</a></li>
1141 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/bootsystem">bootsystem (
17)
</a></li>
1143 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/bsa">bsa (
2)
</a></li>
1145 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/chrpath">chrpath (
2)
</a></li>
1147 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/debian">debian (
192)
</a></li>
1149 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/debian edu">debian edu (
159)
</a></li>
1151 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/debian-handbook">debian-handbook (
9)
</a></li>
1153 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/digistan">digistan (
11)
</a></li>
1155 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/dld">dld (
18)
</a></li>
1157 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/docbook">docbook (
30)
</a></li>
1159 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/drivstoffpriser">drivstoffpriser (
4)
</a></li>
1161 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/english">english (
448)
</a></li>
1163 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/fiksgatami">fiksgatami (
23)
</a></li>
1165 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/fildeling">fildeling (
14)
</a></li>
1167 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/freeculture">freeculture (
34)
</a></li>
1169 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/freedombox">freedombox (
9)
</a></li>
1171 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/frikanalen">frikanalen (
20)
</a></li>
1173 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/h264">h264 (
20)
</a></li>
1175 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/intervju">intervju (
43)
</a></li>
1177 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/isenkram">isenkram (
16)
</a></li>
1179 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/kart">kart (
23)
</a></li>
1181 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/kodi">kodi (
4)
</a></li>
1183 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/ldap">ldap (
9)
</a></li>
1185 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/lego">lego (
5)
</a></li>
1187 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/lenker">lenker (
8)
</a></li>
1189 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/linuxcnc">linuxcnc (
5)
</a></li>
1191 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/lsdvd">lsdvd (
2)
</a></li>
1193 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/ltsp">ltsp (
1)
</a></li>
1195 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/madewithcc">madewithcc (
3)
</a></li>
1197 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/mesh network">mesh network (
8)
</a></li>
1199 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/multimedia">multimedia (
45)
</a></li>
1201 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/nice free software">nice free software (
14)
</a></li>
1203 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/noark5">noark5 (
23)
</a></li>
1205 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/norsk">norsk (
320)
</a></li>
1207 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/nuug">nuug (
198)
</a></li>
1209 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/offentlig innsyn">offentlig innsyn (
40)
</a></li>
1211 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/open311">open311 (
2)
</a></li>
1213 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/opensnitch">opensnitch (
3)
</a></li>
1215 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/opphavsrett">opphavsrett (
75)
</a></li>
1217 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/personvern">personvern (
114)
</a></li>
1219 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/raid">raid (
2)
</a></li>
1221 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/reactos">reactos (
1)
</a></li>
1223 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/reprap">reprap (
11)
</a></li>
1225 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/rfid">rfid (
3)
</a></li>
1227 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/robot">robot (
17)
</a></li>
1229 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/rss">rss (
1)
</a></li>
1231 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/ruter">ruter (
7)
</a></li>
1233 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/scraperwiki">scraperwiki (
2)
</a></li>
1235 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/sikkerhet">sikkerhet (
59)
</a></li>
1237 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/sitesummary">sitesummary (
4)
</a></li>
1239 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/skepsis">skepsis (
5)
</a></li>
1241 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/standard">standard (
74)
</a></li>
1243 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/stavekontroll">stavekontroll (
7)
</a></li>
1245 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/stortinget">stortinget (
14)
</a></li>
1247 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/surveillance">surveillance (
64)
</a></li>
1249 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/sysadmin">sysadmin (
5)
</a></li>
1251 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/usenix">usenix (
2)
</a></li>
1253 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/valg">valg (
9)
</a></li>
1255 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/verkidetfri">verkidetfri (
20)
</a></li>
1257 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/video">video (
78)
</a></li>
1259 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/vitenskap">vitenskap (
4)
</a></li>
1261 <li><a href=
"https://people.skolelinux.org/pere/blog/tags/web">web (
42)
</a></li>
1267 <p style=
"text-align: right">
1268 Created by
<a href=
"http://steve.org.uk/Software/chronicle">Chronicle v4.6
</a>