]> pere.pagekite.me Git - homepage.git/blob - blog/Lets_make_hardware_dongles_easier_to_use_in_Debian.html
Generated.
[homepage.git] / blog / Lets_make_hardware_dongles_easier_to_use_in_Debian.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: Lets make hardware dongles easier to use in Debian</title>
7 <link rel="stylesheet" type="text/css" media="screen" href="http://people.skolelinux.org/pere/blog/style.css" />
8 <link rel="stylesheet" type="text/css" media="screen" href="http://people.skolelinux.org/pere/blog/vim.css" />
9 </head>
10 <body>
11 <div class="title">
12 <h1>
13 <a href="http://people.skolelinux.org/pere/blog/">Petter Reinholdtsen</a>
14
15 </h1>
16
17 </div>
18
19
20 <div class="entry">
21 <div class="title">Lets make hardware dongles easier to use in Debian</div>
22 <div class="date"> 9th January 2013</div>
23 <div class="body"><p>One thing that annoys me with Debian and Linux distributions in
24 general, is that there is a great package management system with the
25 ability to automatically install software packages by downloading them
26 from the distribution mirrors, but no way to get it to automatically
27 install the packages I need to use the hardware I plug into my
28 machine. Even if the package to use it is easily available from the
29 Linux distribution. When I plug in a LEGO Mindstorms NXT, it could
30 suggest to automatically install the python-nxt, nbc and t2n packages
31 I need to talk to it. When I plug in a Yubikey, it could propose the
32 yubikey-personalization package. The information required to do this
33 is available, but no-one have pulled all the pieces together.</p>
34
35 <p>Some years ago, I proposed to
36 <a href="http://lists.debian.org/debian-devel/2010/05/msg01206.html">use
37 the discover subsystem to implement this</a>. The idea is fairly
38 simple:
39
40 <ul>
41
42 <li>Add a desktop entry in /usr/share/autostart/ pointing to a program
43 starting when a user log in.</li>
44
45 <li>Set this program up to listen for kernel events emitted when new
46 hardware is inserted into the computer.</li>
47
48 <li>When new hardware is inserted, look up the hardware ID in a
49 database mapping to packages, and take note of any non-installed
50 packages.</li>
51
52 <li>Show a message to the user proposing to install the discovered
53 package, and make it easy to install it.</li>
54
55 </ul>
56
57 <p>I am not sure what the best way to implement this is, but my
58 initial idea was to use dbus events to discover new hardware, the
59 discover database to find packages and
60 <a href="http://www.packagekit.org/">PackageKit</a> to install
61 packages.</p>
62
63 <p>Yesterday, I found time to try to implement this idea, and the
64 draft package is now checked into
65 <a href="http://anonscm.debian.org/viewvc/debian-edu/trunk/src/hw-support-handler/">the
66 Debian Edu subversion repository</a>. In the process, I updated the
67 <a href="http://packages.qa.debian.org/d/discover-data.html">discover-data</a>
68 package to map the USB ids of LEGO Mindstorms and Yubikey devices to
69 the relevant packages in Debian, and uploaded a new version
70 2.2013.01.09 to unstable. I also discovered that the current
71 <a href="http://packages.qa.debian.org/d/discover.html">discover</a>
72 package in Debian no longer discovered any USB devices, because
73 /proc/bus/usb/devices is no longer present. I ported it to use
74 libusb as a fall back option to get it working. The fixed package
75 version 2.1.2-6 is now in experimental (didn't upload it to unstable
76 because of the freeze).</p>
77
78 <p>With this prototype in place, I can insert my Yubikey, and get this
79 desktop notification to show up (only once, the first time it is
80 inserted):</p>
81
82 <p align="center"><img src="http://people.skolelinux.org/pere/blog/images/2013-01-09-hw-autoinstall.png"></p>
83
84 <p>For this prototype to be really useful, some way to automatically
85 install the proposed packages by pressing the "Please install
86 program(s)" button should to be implemented.</p>
87
88 <p>If this idea seem useful to you, and you want to help make it
89 happen, please help me update the discover-data database with mappings
90 from hardware to Debian packages. Check if 'discover-pkginstall -l'
91 list the package you would like to have installed when a given
92 hardware device is inserted into your computer, and report bugs using
93 reportbug if it isn't. Or, if you know of a better way to provide
94 such mapping, please let me know.</p>
95
96 <p>This prototype need more work, and there are several questions that
97 should be considered before it is ready for production use. Is dbus
98 the correct way to detect new hardware? At the moment I look for HAL
99 dbus events on the system bus, because that is the events I could see
100 on my Debian Squeeze KDE desktop. Are there better events to use?
101 How should the user be notified? Is the desktop notification
102 mechanism the best option, or should the background daemon raise a
103 popup instead? How should packages be installed? When should they
104 not be installed?</p>
105
106 <p>If you want to help getting such feature implemented in Debian,
107 please send me an email. :)</p>
108 </div>
109
110 <div class="tags">Tags: <a href="http://people.skolelinux.org/pere/blog/tags/debian">debian</a>, <a href="http://people.skolelinux.org/pere/blog/tags/english">english</a>, <a href="http://people.skolelinux.org/pere/blog/tags/isenkram">isenkram</a>.</div>
111
112
113 </div>
114
115
116
117
118 <div id="sidebar">
119
120
121
122 <h2>Archive</h2>
123 <ul>
124
125 <li>2013
126 <ul>
127
128 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/01/">January (11)</a></li>
129
130 </ul></li>
131
132 <li>2012
133 <ul>
134
135 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/01/">January (7)</a></li>
136
137 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/02/">February (10)</a></li>
138
139 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/03/">March (17)</a></li>
140
141 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/04/">April (12)</a></li>
142
143 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/05/">May (12)</a></li>
144
145 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/06/">June (20)</a></li>
146
147 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/07/">July (17)</a></li>
148
149 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/08/">August (6)</a></li>
150
151 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/09/">September (9)</a></li>
152
153 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/10/">October (17)</a></li>
154
155 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/11/">November (10)</a></li>
156
157 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/12/">December (7)</a></li>
158
159 </ul></li>
160
161 <li>2011
162 <ul>
163
164 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/01/">January (16)</a></li>
165
166 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/02/">February (6)</a></li>
167
168 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/03/">March (6)</a></li>
169
170 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/04/">April (7)</a></li>
171
172 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/05/">May (3)</a></li>
173
174 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/06/">June (2)</a></li>
175
176 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/07/">July (7)</a></li>
177
178 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/08/">August (6)</a></li>
179
180 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/09/">September (4)</a></li>
181
182 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/10/">October (2)</a></li>
183
184 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/11/">November (3)</a></li>
185
186 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/12/">December (1)</a></li>
187
188 </ul></li>
189
190 <li>2010
191 <ul>
192
193 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/01/">January (2)</a></li>
194
195 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/02/">February (1)</a></li>
196
197 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/03/">March (3)</a></li>
198
199 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/04/">April (3)</a></li>
200
201 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/05/">May (9)</a></li>
202
203 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/06/">June (14)</a></li>
204
205 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/07/">July (12)</a></li>
206
207 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/08/">August (13)</a></li>
208
209 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/09/">September (7)</a></li>
210
211 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/10/">October (9)</a></li>
212
213 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/11/">November (13)</a></li>
214
215 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/12/">December (12)</a></li>
216
217 </ul></li>
218
219 <li>2009
220 <ul>
221
222 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/01/">January (8)</a></li>
223
224 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/02/">February (8)</a></li>
225
226 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/03/">March (12)</a></li>
227
228 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/04/">April (10)</a></li>
229
230 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/05/">May (9)</a></li>
231
232 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/06/">June (3)</a></li>
233
234 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/07/">July (4)</a></li>
235
236 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/08/">August (3)</a></li>
237
238 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/09/">September (1)</a></li>
239
240 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/10/">October (2)</a></li>
241
242 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/11/">November (3)</a></li>
243
244 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/12/">December (3)</a></li>
245
246 </ul></li>
247
248 <li>2008
249 <ul>
250
251 <li><a href="http://people.skolelinux.org/pere/blog/archive/2008/11/">November (5)</a></li>
252
253 <li><a href="http://people.skolelinux.org/pere/blog/archive/2008/12/">December (7)</a></li>
254
255 </ul></li>
256
257 </ul>
258
259
260
261 <h2>Tags</h2>
262 <ul>
263
264 <li><a href="http://people.skolelinux.org/pere/blog/tags/3d-printer">3d-printer (13)</a></li>
265
266 <li><a href="http://people.skolelinux.org/pere/blog/tags/amiga">amiga (1)</a></li>
267
268 <li><a href="http://people.skolelinux.org/pere/blog/tags/aros">aros (1)</a></li>
269
270 <li><a href="http://people.skolelinux.org/pere/blog/tags/bankid">bankid (4)</a></li>
271
272 <li><a href="http://people.skolelinux.org/pere/blog/tags/bitcoin">bitcoin (5)</a></li>
273
274 <li><a href="http://people.skolelinux.org/pere/blog/tags/bootsystem">bootsystem (12)</a></li>
275
276 <li><a href="http://people.skolelinux.org/pere/blog/tags/bsa">bsa (2)</a></li>
277
278 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian">debian (69)</a></li>
279
280 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian edu">debian edu (118)</a></li>
281
282 <li><a href="http://people.skolelinux.org/pere/blog/tags/digistan">digistan (9)</a></li>
283
284 <li><a href="http://people.skolelinux.org/pere/blog/tags/docbook">docbook (7)</a></li>
285
286 <li><a href="http://people.skolelinux.org/pere/blog/tags/drivstoffpriser">drivstoffpriser (4)</a></li>
287
288 <li><a href="http://people.skolelinux.org/pere/blog/tags/english">english (175)</a></li>
289
290 <li><a href="http://people.skolelinux.org/pere/blog/tags/fiksgatami">fiksgatami (21)</a></li>
291
292 <li><a href="http://people.skolelinux.org/pere/blog/tags/fildeling">fildeling (12)</a></li>
293
294 <li><a href="http://people.skolelinux.org/pere/blog/tags/freeculture">freeculture (10)</a></li>
295
296 <li><a href="http://people.skolelinux.org/pere/blog/tags/frikanalen">frikanalen (9)</a></li>
297
298 <li><a href="http://people.skolelinux.org/pere/blog/tags/intervju">intervju (32)</a></li>
299
300 <li><a href="http://people.skolelinux.org/pere/blog/tags/isenkram">isenkram (5)</a></li>
301
302 <li><a href="http://people.skolelinux.org/pere/blog/tags/kart">kart (17)</a></li>
303
304 <li><a href="http://people.skolelinux.org/pere/blog/tags/ldap">ldap (8)</a></li>
305
306 <li><a href="http://people.skolelinux.org/pere/blog/tags/lenker">lenker (6)</a></li>
307
308 <li><a href="http://people.skolelinux.org/pere/blog/tags/ltsp">ltsp (1)</a></li>
309
310 <li><a href="http://people.skolelinux.org/pere/blog/tags/multimedia">multimedia (25)</a></li>
311
312 <li><a href="http://people.skolelinux.org/pere/blog/tags/norsk">norsk (219)</a></li>
313
314 <li><a href="http://people.skolelinux.org/pere/blog/tags/nuug">nuug (148)</a></li>
315
316 <li><a href="http://people.skolelinux.org/pere/blog/tags/offentlig innsyn">offentlig innsyn (6)</a></li>
317
318 <li><a href="http://people.skolelinux.org/pere/blog/tags/open311">open311 (2)</a></li>
319
320 <li><a href="http://people.skolelinux.org/pere/blog/tags/opphavsrett">opphavsrett (41)</a></li>
321
322 <li><a href="http://people.skolelinux.org/pere/blog/tags/personvern">personvern (61)</a></li>
323
324 <li><a href="http://people.skolelinux.org/pere/blog/tags/raid">raid (1)</a></li>
325
326 <li><a href="http://people.skolelinux.org/pere/blog/tags/reprap">reprap (11)</a></li>
327
328 <li><a href="http://people.skolelinux.org/pere/blog/tags/rfid">rfid (2)</a></li>
329
330 <li><a href="http://people.skolelinux.org/pere/blog/tags/robot">robot (6)</a></li>
331
332 <li><a href="http://people.skolelinux.org/pere/blog/tags/rss">rss (1)</a></li>
333
334 <li><a href="http://people.skolelinux.org/pere/blog/tags/ruter">ruter (4)</a></li>
335
336 <li><a href="http://people.skolelinux.org/pere/blog/tags/scraperwiki">scraperwiki (2)</a></li>
337
338 <li><a href="http://people.skolelinux.org/pere/blog/tags/sikkerhet">sikkerhet (28)</a></li>
339
340 <li><a href="http://people.skolelinux.org/pere/blog/tags/sitesummary">sitesummary (4)</a></li>
341
342 <li><a href="http://people.skolelinux.org/pere/blog/tags/skepsis">skepsis (4)</a></li>
343
344 <li><a href="http://people.skolelinux.org/pere/blog/tags/standard">standard (39)</a></li>
345
346 <li><a href="http://people.skolelinux.org/pere/blog/tags/stavekontroll">stavekontroll (3)</a></li>
347
348 <li><a href="http://people.skolelinux.org/pere/blog/tags/stortinget">stortinget (5)</a></li>
349
350 <li><a href="http://people.skolelinux.org/pere/blog/tags/surveillance">surveillance (12)</a></li>
351
352 <li><a href="http://people.skolelinux.org/pere/blog/tags/sysadmin">sysadmin (1)</a></li>
353
354 <li><a href="http://people.skolelinux.org/pere/blog/tags/valg">valg (7)</a></li>
355
356 <li><a href="http://people.skolelinux.org/pere/blog/tags/video">video (35)</a></li>
357
358 <li><a href="http://people.skolelinux.org/pere/blog/tags/vitenskap">vitenskap (4)</a></li>
359
360 <li><a href="http://people.skolelinux.org/pere/blog/tags/web">web (26)</a></li>
361
362 </ul>
363
364
365 </div>
366 <p style="text-align: right">
367 Created by <a href="http://steve.org.uk/Software/chronicle">Chronicle v4.4</a>
368 </p>
369
370 </body>
371 </html>