]> pere.pagekite.me Git - homepage.git/blob - blog/UsingQR____Electronic__paper_invoices_using_JSON_and_QR_codes.html
Generated.
[homepage.git] / blog / UsingQR____Electronic__paper_invoices_using_JSON_and_QR_codes.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: UsingQR - "Electronic" paper invoices using JSON and QR codes</title>
7 <link rel="stylesheet" type="text/css" media="screen" href="http://people.skolelinux.org/pere/blog/style.css" />
8 <link rel="stylesheet" type="text/css" media="screen" href="http://people.skolelinux.org/pere/blog/vim.css" />
9
10
11 </head>
12 <body>
13 <div class="title">
14 <h1>
15 <a href="http://people.skolelinux.org/pere/blog/">Petter Reinholdtsen</a>
16
17 </h1>
18
19 </div>
20
21
22 <div class="entry">
23 <div class="title">UsingQR - "Electronic" paper invoices using JSON and QR codes</div>
24 <div class="date">19th March 2016</div>
25 <div class="body"><p>Back in 2013 I proposed
26 <a href="http://people.skolelinux.org/pere/blog/_Electronic__paper_invoices___using_vCard_in_a_QR_code.html">a
27 way to make paper and PDF invoices easier to process electronically by
28 adding a QR code with the key information about the invoice</a>. I
29 suggested using vCard field definition, to get some standard format
30 for name and address, but any format would work. I did not do
31 anything about the proposal, but hoped someone one day would make
32 something like it. It would make it possible to efficiently send
33 machine readable invoices directly between seller and buyer.</p>
34
35 <p>This was the background when I came across a proposal and
36 specification from the web based accounting and invoicing supplier
37 <a href="http://www.visma.com/">Visma</a> in Sweden called
38 <a href="http://usingqr.com/">UsingQR</a>. Their PDF invoices contain
39 a QR code with the key information of the invoice in JSON format.
40 This is the typical content of a QR code following the UsingQR
41 specification (based on a real world example, some numbers replaced to
42 get a more bogus entry). I've reformatted the JSON to make it easier
43 to read. Normally this is all on one long line:
44
45 <p><img src="http://people.skolelinux.org/pere/blog/images/2016-03-19-qr-invoice.png" align="right"><pre>
46 {
47 "vh":500.00,
48 "vm":0,
49 "vl":0,
50 "uqr":1,
51 "tp":1,
52 "nme":"Din Leverandør",
53 "cc":"NO",
54 "cid":"997912345 MVA",
55 "iref":"12300001",
56 "idt":"20151022",
57 "ddt":"20151105",
58 "due":2500.0000,
59 "cur":"NOK",
60 "pt":"BBAN",
61 "acc":"17202612345",
62 "bc":"BIENNOK1",
63 "adr":"0313 OSLO"
64 }
65 </pre></p>
66
67 </p>The interpretation of the fields can be found in the
68 <a href="http://usingqr.com/wp-content/uploads/2014/06/UsingQR_specification1.pdf">format
69 specification</a> (revision 2 from june 2014). The format seem to
70 have most of the information needed to handle accounting and payment
71 of invoices, at least the fields I have needed so far here in
72 Norway.</p>
73
74 <p>Unfortunately, the site and document do not mention anything about
75 the patent, trademark and copyright status of the format and the
76 specification. Because of this, I asked the people behind it back in
77 November to clarify. Ann-Christine Savlid (ann-christine.savlid (at)
78 visma.com) replied that Visma had not applied for patent or trademark
79 protection for this format, and that there were no copyright based
80 usage limitations for the format. I urged her to make sure this was
81 explicitly written on the web pages and in the specification, but
82 unfortunately this has not happened yet. So I guess if there is
83 submarine patents, hidden trademarks or a will to sue for copyright
84 infringements, those starting to use the UsingQR format might be at
85 risk, but if this happen there is some legal defense in the fact that
86 the people behind the format claimed it was safe to do so. At least
87 with patents, there is always
88 <a href="http://www.paperspecs.com/paper-news/beware-the-qr-code-patent-trap/">a
89 chance of getting sued...</a>
90
91 <p>I also asked if they planned to maintain the format in an
92 independent standard organization to give others more confidence that
93 they would participate in the standardization process on equal terms
94 with Visma, but they had no immediate plans for this. Their plan was
95 to work with banks to try to get more users of the format, and
96 evaluate the way forward if the format proved to be popular. I hope
97 they conclude that using an open standard organisation like
98 <a href="http://www.ietf.org/">IETF</a> is the correct place to
99 maintain such specification.</p>
100 </div>
101
102 <div class="tags">Tags: <a href="http://people.skolelinux.org/pere/blog/tags/english">english</a>, <a href="http://people.skolelinux.org/pere/blog/tags/standard">standard</a>.</div>
103
104
105 </div>
106
107
108
109
110 <div id="sidebar">
111
112
113
114 <h2>Archive</h2>
115 <ul>
116
117 <li>2016
118 <ul>
119
120 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/01/">January (3)</a></li>
121
122 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/02/">February (2)</a></li>
123
124 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/03/">March (2)</a></li>
125
126 </ul></li>
127
128 <li>2015
129 <ul>
130
131 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/01/">January (7)</a></li>
132
133 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/02/">February (6)</a></li>
134
135 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/03/">March (1)</a></li>
136
137 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/04/">April (4)</a></li>
138
139 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/05/">May (3)</a></li>
140
141 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/06/">June (4)</a></li>
142
143 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/07/">July (6)</a></li>
144
145 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/08/">August (2)</a></li>
146
147 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/09/">September (2)</a></li>
148
149 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/10/">October (9)</a></li>
150
151 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/11/">November (6)</a></li>
152
153 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/12/">December (3)</a></li>
154
155 </ul></li>
156
157 <li>2014
158 <ul>
159
160 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/01/">January (2)</a></li>
161
162 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/02/">February (3)</a></li>
163
164 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/03/">March (8)</a></li>
165
166 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/04/">April (7)</a></li>
167
168 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/05/">May (1)</a></li>
169
170 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/06/">June (2)</a></li>
171
172 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/07/">July (2)</a></li>
173
174 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/08/">August (2)</a></li>
175
176 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/09/">September (5)</a></li>
177
178 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/10/">October (6)</a></li>
179
180 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/11/">November (3)</a></li>
181
182 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/12/">December (5)</a></li>
183
184 </ul></li>
185
186 <li>2013
187 <ul>
188
189 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/01/">January (11)</a></li>
190
191 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/02/">February (9)</a></li>
192
193 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/03/">March (9)</a></li>
194
195 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/04/">April (6)</a></li>
196
197 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/05/">May (9)</a></li>
198
199 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/06/">June (10)</a></li>
200
201 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/07/">July (7)</a></li>
202
203 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/08/">August (3)</a></li>
204
205 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/09/">September (5)</a></li>
206
207 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/10/">October (7)</a></li>
208
209 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/11/">November (9)</a></li>
210
211 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/12/">December (3)</a></li>
212
213 </ul></li>
214
215 <li>2012
216 <ul>
217
218 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/01/">January (7)</a></li>
219
220 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/02/">February (10)</a></li>
221
222 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/03/">March (17)</a></li>
223
224 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/04/">April (12)</a></li>
225
226 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/05/">May (12)</a></li>
227
228 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/06/">June (20)</a></li>
229
230 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/07/">July (17)</a></li>
231
232 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/08/">August (6)</a></li>
233
234 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/09/">September (9)</a></li>
235
236 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/10/">October (17)</a></li>
237
238 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/11/">November (10)</a></li>
239
240 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/12/">December (7)</a></li>
241
242 </ul></li>
243
244 <li>2011
245 <ul>
246
247 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/01/">January (16)</a></li>
248
249 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/02/">February (6)</a></li>
250
251 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/03/">March (6)</a></li>
252
253 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/04/">April (7)</a></li>
254
255 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/05/">May (3)</a></li>
256
257 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/06/">June (2)</a></li>
258
259 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/07/">July (7)</a></li>
260
261 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/08/">August (6)</a></li>
262
263 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/09/">September (4)</a></li>
264
265 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/10/">October (2)</a></li>
266
267 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/11/">November (3)</a></li>
268
269 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/12/">December (1)</a></li>
270
271 </ul></li>
272
273 <li>2010
274 <ul>
275
276 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/01/">January (2)</a></li>
277
278 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/02/">February (1)</a></li>
279
280 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/03/">March (3)</a></li>
281
282 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/04/">April (3)</a></li>
283
284 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/05/">May (9)</a></li>
285
286 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/06/">June (14)</a></li>
287
288 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/07/">July (12)</a></li>
289
290 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/08/">August (13)</a></li>
291
292 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/09/">September (7)</a></li>
293
294 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/10/">October (9)</a></li>
295
296 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/11/">November (13)</a></li>
297
298 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/12/">December (12)</a></li>
299
300 </ul></li>
301
302 <li>2009
303 <ul>
304
305 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/01/">January (8)</a></li>
306
307 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/02/">February (8)</a></li>
308
309 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/03/">March (12)</a></li>
310
311 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/04/">April (10)</a></li>
312
313 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/05/">May (9)</a></li>
314
315 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/06/">June (3)</a></li>
316
317 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/07/">July (4)</a></li>
318
319 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/08/">August (3)</a></li>
320
321 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/09/">September (1)</a></li>
322
323 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/10/">October (2)</a></li>
324
325 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/11/">November (3)</a></li>
326
327 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/12/">December (3)</a></li>
328
329 </ul></li>
330
331 <li>2008
332 <ul>
333
334 <li><a href="http://people.skolelinux.org/pere/blog/archive/2008/11/">November (5)</a></li>
335
336 <li><a href="http://people.skolelinux.org/pere/blog/archive/2008/12/">December (7)</a></li>
337
338 </ul></li>
339
340 </ul>
341
342
343
344 <h2>Tags</h2>
345 <ul>
346
347 <li><a href="http://people.skolelinux.org/pere/blog/tags/3d-printer">3d-printer (13)</a></li>
348
349 <li><a href="http://people.skolelinux.org/pere/blog/tags/amiga">amiga (1)</a></li>
350
351 <li><a href="http://people.skolelinux.org/pere/blog/tags/aros">aros (1)</a></li>
352
353 <li><a href="http://people.skolelinux.org/pere/blog/tags/bankid">bankid (4)</a></li>
354
355 <li><a href="http://people.skolelinux.org/pere/blog/tags/bitcoin">bitcoin (9)</a></li>
356
357 <li><a href="http://people.skolelinux.org/pere/blog/tags/bootsystem">bootsystem (15)</a></li>
358
359 <li><a href="http://people.skolelinux.org/pere/blog/tags/bsa">bsa (2)</a></li>
360
361 <li><a href="http://people.skolelinux.org/pere/blog/tags/chrpath">chrpath (2)</a></li>
362
363 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian">debian (121)</a></li>
364
365 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian edu">debian edu (154)</a></li>
366
367 <li><a href="http://people.skolelinux.org/pere/blog/tags/digistan">digistan (10)</a></li>
368
369 <li><a href="http://people.skolelinux.org/pere/blog/tags/dld">dld (15)</a></li>
370
371 <li><a href="http://people.skolelinux.org/pere/blog/tags/docbook">docbook (20)</a></li>
372
373 <li><a href="http://people.skolelinux.org/pere/blog/tags/drivstoffpriser">drivstoffpriser (4)</a></li>
374
375 <li><a href="http://people.skolelinux.org/pere/blog/tags/english">english (304)</a></li>
376
377 <li><a href="http://people.skolelinux.org/pere/blog/tags/fiksgatami">fiksgatami (23)</a></li>
378
379 <li><a href="http://people.skolelinux.org/pere/blog/tags/fildeling">fildeling (12)</a></li>
380
381 <li><a href="http://people.skolelinux.org/pere/blog/tags/freeculture">freeculture (25)</a></li>
382
383 <li><a href="http://people.skolelinux.org/pere/blog/tags/freedombox">freedombox (9)</a></li>
384
385 <li><a href="http://people.skolelinux.org/pere/blog/tags/frikanalen">frikanalen (16)</a></li>
386
387 <li><a href="http://people.skolelinux.org/pere/blog/tags/h264">h264 (20)</a></li>
388
389 <li><a href="http://people.skolelinux.org/pere/blog/tags/intervju">intervju (42)</a></li>
390
391 <li><a href="http://people.skolelinux.org/pere/blog/tags/isenkram">isenkram (11)</a></li>
392
393 <li><a href="http://people.skolelinux.org/pere/blog/tags/kart">kart (19)</a></li>
394
395 <li><a href="http://people.skolelinux.org/pere/blog/tags/ldap">ldap (9)</a></li>
396
397 <li><a href="http://people.skolelinux.org/pere/blog/tags/lenker">lenker (8)</a></li>
398
399 <li><a href="http://people.skolelinux.org/pere/blog/tags/lsdvd">lsdvd (2)</a></li>
400
401 <li><a href="http://people.skolelinux.org/pere/blog/tags/ltsp">ltsp (1)</a></li>
402
403 <li><a href="http://people.skolelinux.org/pere/blog/tags/mesh network">mesh network (8)</a></li>
404
405 <li><a href="http://people.skolelinux.org/pere/blog/tags/multimedia">multimedia (37)</a></li>
406
407 <li><a href="http://people.skolelinux.org/pere/blog/tags/nice free software">nice free software (7)</a></li>
408
409 <li><a href="http://people.skolelinux.org/pere/blog/tags/norsk">norsk (273)</a></li>
410
411 <li><a href="http://people.skolelinux.org/pere/blog/tags/nuug">nuug (177)</a></li>
412
413 <li><a href="http://people.skolelinux.org/pere/blog/tags/offentlig innsyn">offentlig innsyn (22)</a></li>
414
415 <li><a href="http://people.skolelinux.org/pere/blog/tags/open311">open311 (2)</a></li>
416
417 <li><a href="http://people.skolelinux.org/pere/blog/tags/opphavsrett">opphavsrett (58)</a></li>
418
419 <li><a href="http://people.skolelinux.org/pere/blog/tags/personvern">personvern (92)</a></li>
420
421 <li><a href="http://people.skolelinux.org/pere/blog/tags/raid">raid (1)</a></li>
422
423 <li><a href="http://people.skolelinux.org/pere/blog/tags/reactos">reactos (1)</a></li>
424
425 <li><a href="http://people.skolelinux.org/pere/blog/tags/reprap">reprap (11)</a></li>
426
427 <li><a href="http://people.skolelinux.org/pere/blog/tags/rfid">rfid (3)</a></li>
428
429 <li><a href="http://people.skolelinux.org/pere/blog/tags/robot">robot (9)</a></li>
430
431 <li><a href="http://people.skolelinux.org/pere/blog/tags/rss">rss (1)</a></li>
432
433 <li><a href="http://people.skolelinux.org/pere/blog/tags/ruter">ruter (4)</a></li>
434
435 <li><a href="http://people.skolelinux.org/pere/blog/tags/scraperwiki">scraperwiki (2)</a></li>
436
437 <li><a href="http://people.skolelinux.org/pere/blog/tags/sikkerhet">sikkerhet (45)</a></li>
438
439 <li><a href="http://people.skolelinux.org/pere/blog/tags/sitesummary">sitesummary (4)</a></li>
440
441 <li><a href="http://people.skolelinux.org/pere/blog/tags/skepsis">skepsis (4)</a></li>
442
443 <li><a href="http://people.skolelinux.org/pere/blog/tags/standard">standard (49)</a></li>
444
445 <li><a href="http://people.skolelinux.org/pere/blog/tags/stavekontroll">stavekontroll (3)</a></li>
446
447 <li><a href="http://people.skolelinux.org/pere/blog/tags/stortinget">stortinget (10)</a></li>
448
449 <li><a href="http://people.skolelinux.org/pere/blog/tags/surveillance">surveillance (36)</a></li>
450
451 <li><a href="http://people.skolelinux.org/pere/blog/tags/sysadmin">sysadmin (2)</a></li>
452
453 <li><a href="http://people.skolelinux.org/pere/blog/tags/usenix">usenix (2)</a></li>
454
455 <li><a href="http://people.skolelinux.org/pere/blog/tags/valg">valg (8)</a></li>
456
457 <li><a href="http://people.skolelinux.org/pere/blog/tags/video">video (55)</a></li>
458
459 <li><a href="http://people.skolelinux.org/pere/blog/tags/vitenskap">vitenskap (4)</a></li>
460
461 <li><a href="http://people.skolelinux.org/pere/blog/tags/web">web (38)</a></li>
462
463 </ul>
464
465
466 </div>
467 <p style="text-align: right">
468 Created by <a href="http://steve.org.uk/Software/chronicle">Chronicle v4.6</a>
469 </p>
470
471 </body>
472 </html>