]> pere.pagekite.me Git - homepage.git/blob - blog/Initial_notes_on_adding_Open311_server_API_on_FixMyStreet.html
5599a2176f31b6ec2ac1720e1eedc1106bdd1748
[homepage.git] / blog / Initial_notes_on_adding_Open311_server_API_on_FixMyStreet.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: Initial notes on adding Open311 server API on FixMyStreet</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">Initial notes on adding Open311 server API on FixMyStreet</div>
24 <div class="date">29th April 2011</div>
25 <div class="body"><p>The last few days I have spent some time trying to add support for
26 the <a href="http://www.open311.org/">Open311 API</a> in the
27 <a href="http://www.fiksgatami.no/">Norwegian FixMyStreet service</a>.
28 Earlier I believed Open311 would be a useful API to use to submit
29 reports to the municipalities, but when I noticed that the
30 <a href="http://fixmystreet.org.nz/">New Zealand version</a> of
31 FixMyStreet had implemented Open311 on the server side, it occurred to
32 me that this was a nice way to allow the public, press and
33 municipalities to do data mining directly in the FixMyStreet service.
34 Thus I went to work implementing the Open311 specification for
35 FixMyStreet. The implementation is not yet ready, but I am starting
36 to get a draft limping along. In the process, I have discovered a few
37 issues with the Open311 specification.</p>
38
39 <p>One obvious missing feature is the lack of natural language
40 handling in the specification. The specification seem to assume all
41 reports will be written in English, and do not provide a way for the
42 receiving end to specify which languages are understood there. To be
43 able to use the same client and submit to several Open311 receivers,
44 it would be useful to know which language to use when writing reports.
45 I believe the specification should be extended to allow the receivers
46 of problem reports to specify which language they accept, and the
47 submitter to specify which language the report is written in.
48 Language of a text can also be automatically guessed using statistical
49 methods, but for multi-lingual persons like myself, it is useful to
50 know which language to use when writing a problem report. I suspect
51 some lang=nb,nn kind of attribute would solve it.</p>
52
53 <p>A key part of the Open311 API is the list of services provided,
54 which is similar to the categories used by FixMyStreet. One issue I
55 run into is the need to specify both name and unique identifier for
56 each category. The specification do not state that the identifier
57 should be numeric, but all example implementations have used numbers
58 here. In FixMyStreet, there is no number associated with each
59 category. As the specification do not forbid it, I will use the name
60 as the unique identifier for now and see how open311 clients handle
61 it.</p>
62
63 <p>The report format in open311 and the report format in FixMyStreet
64 differ in a key part. FixMyStreet have a title and a description,
65 while Open311 only have a description and lack the title. I'm not
66 quite sure how to best handle this yet. When asking for a FixMyStreet
67 report in Open311 format, I just merge title an description into the
68 open311 description, but this is not going to work if the open311 API
69 should be used for submitting new reports to FixMyStreet.</p>
70
71 <p>The search feature in Open311 is missing a way to ask for problems
72 near a geographic location. I believe this is important if one is to
73 use Open311 as the query language for mobile units. The specification
74 should be extended to handle this, probably using some new lat=, lon=
75 and range= options.</p>
76
77 <p>The final challenge I see is that the FixMyStreet code handle
78 several administrations in one interface, while the Open311 API seem
79 to assume only one administration. For FixMyStreet, this mean a
80 report can be sent to several administrations, and the categories
81 available depend on the location of the problem. Not quite sure how
82 to best handle this. I've noticed
83 <a href="http://seeclickfix.com/open311/">SeeClickFix</a> added
84 latitude and longitude options to the services request, but it do not
85 solve the problem of what to return when no location is specified.
86 Will have to investigate this a bit more.</p>
87
88 <p>My distaste for web forums have kept me from bringing these issues
89 up with the open311 developer group. I really wish they had a email
90 list available via <a href="http://www.gmane.org/">Gmane</a> to use for
91 discussions instead of only
92 <a href="http://lists.open311.org/groups/discuss">a forum<a/>. Oh,
93 well. That will probably resolve itself, one way or another. I've
94 also tried visiting the IRC channel #open311 on FreeNode, but no-one
95 seem to reply to my questions there. This make me wonder if I just
96 fail to understand how the open311 community work. It sure do not
97 work like the free software project communities I am used to.</p>
98 </div>
99
100 <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/fiksgatami">fiksgatami</a>, <a href="http://people.skolelinux.org/pere/blog/tags/open311">open311</a>.</div>
101
102
103 </div>
104
105
106
107
108 <div id="sidebar">
109
110
111
112 <h2>Archive</h2>
113 <ul>
114
115 <li>2017
116 <ul>
117
118 <li><a href="http://people.skolelinux.org/pere/blog/archive/2017/01/">January (4)</a></li>
119
120 <li><a href="http://people.skolelinux.org/pere/blog/archive/2017/02/">February (3)</a></li>
121
122 <li><a href="http://people.skolelinux.org/pere/blog/archive/2017/03/">March (4)</a></li>
123
124 </ul></li>
125
126 <li>2016
127 <ul>
128
129 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/01/">January (3)</a></li>
130
131 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/02/">February (2)</a></li>
132
133 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/03/">March (3)</a></li>
134
135 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/04/">April (8)</a></li>
136
137 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/05/">May (8)</a></li>
138
139 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/06/">June (2)</a></li>
140
141 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/07/">July (2)</a></li>
142
143 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/08/">August (5)</a></li>
144
145 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/09/">September (2)</a></li>
146
147 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/10/">October (3)</a></li>
148
149 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/11/">November (8)</a></li>
150
151 <li><a href="http://people.skolelinux.org/pere/blog/archive/2016/12/">December (5)</a></li>
152
153 </ul></li>
154
155 <li>2015
156 <ul>
157
158 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/01/">January (7)</a></li>
159
160 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/02/">February (6)</a></li>
161
162 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/03/">March (1)</a></li>
163
164 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/04/">April (4)</a></li>
165
166 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/05/">May (3)</a></li>
167
168 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/06/">June (4)</a></li>
169
170 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/07/">July (6)</a></li>
171
172 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/08/">August (2)</a></li>
173
174 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/09/">September (2)</a></li>
175
176 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/10/">October (9)</a></li>
177
178 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/11/">November (6)</a></li>
179
180 <li><a href="http://people.skolelinux.org/pere/blog/archive/2015/12/">December (3)</a></li>
181
182 </ul></li>
183
184 <li>2014
185 <ul>
186
187 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/01/">January (2)</a></li>
188
189 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/02/">February (3)</a></li>
190
191 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/03/">March (8)</a></li>
192
193 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/04/">April (7)</a></li>
194
195 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/05/">May (1)</a></li>
196
197 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/06/">June (2)</a></li>
198
199 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/07/">July (2)</a></li>
200
201 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/08/">August (2)</a></li>
202
203 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/09/">September (5)</a></li>
204
205 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/10/">October (6)</a></li>
206
207 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/11/">November (3)</a></li>
208
209 <li><a href="http://people.skolelinux.org/pere/blog/archive/2014/12/">December (5)</a></li>
210
211 </ul></li>
212
213 <li>2013
214 <ul>
215
216 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/01/">January (11)</a></li>
217
218 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/02/">February (9)</a></li>
219
220 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/03/">March (9)</a></li>
221
222 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/04/">April (6)</a></li>
223
224 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/05/">May (9)</a></li>
225
226 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/06/">June (10)</a></li>
227
228 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/07/">July (7)</a></li>
229
230 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/08/">August (3)</a></li>
231
232 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/09/">September (5)</a></li>
233
234 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/10/">October (7)</a></li>
235
236 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/11/">November (9)</a></li>
237
238 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/12/">December (3)</a></li>
239
240 </ul></li>
241
242 <li>2012
243 <ul>
244
245 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/01/">January (7)</a></li>
246
247 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/02/">February (10)</a></li>
248
249 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/03/">March (17)</a></li>
250
251 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/04/">April (12)</a></li>
252
253 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/05/">May (12)</a></li>
254
255 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/06/">June (20)</a></li>
256
257 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/07/">July (17)</a></li>
258
259 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/08/">August (6)</a></li>
260
261 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/09/">September (9)</a></li>
262
263 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/10/">October (17)</a></li>
264
265 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/11/">November (10)</a></li>
266
267 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/12/">December (7)</a></li>
268
269 </ul></li>
270
271 <li>2011
272 <ul>
273
274 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/01/">January (16)</a></li>
275
276 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/02/">February (6)</a></li>
277
278 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/03/">March (6)</a></li>
279
280 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/04/">April (7)</a></li>
281
282 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/05/">May (3)</a></li>
283
284 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/06/">June (2)</a></li>
285
286 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/07/">July (7)</a></li>
287
288 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/08/">August (6)</a></li>
289
290 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/09/">September (4)</a></li>
291
292 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/10/">October (2)</a></li>
293
294 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/11/">November (3)</a></li>
295
296 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/12/">December (1)</a></li>
297
298 </ul></li>
299
300 <li>2010
301 <ul>
302
303 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/01/">January (2)</a></li>
304
305 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/02/">February (1)</a></li>
306
307 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/03/">March (3)</a></li>
308
309 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/04/">April (3)</a></li>
310
311 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/05/">May (9)</a></li>
312
313 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/06/">June (14)</a></li>
314
315 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/07/">July (12)</a></li>
316
317 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/08/">August (13)</a></li>
318
319 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/09/">September (7)</a></li>
320
321 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/10/">October (9)</a></li>
322
323 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/11/">November (13)</a></li>
324
325 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/12/">December (12)</a></li>
326
327 </ul></li>
328
329 <li>2009
330 <ul>
331
332 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/01/">January (8)</a></li>
333
334 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/02/">February (8)</a></li>
335
336 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/03/">March (12)</a></li>
337
338 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/04/">April (10)</a></li>
339
340 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/05/">May (9)</a></li>
341
342 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/06/">June (3)</a></li>
343
344 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/07/">July (4)</a></li>
345
346 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/08/">August (3)</a></li>
347
348 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/09/">September (1)</a></li>
349
350 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/10/">October (2)</a></li>
351
352 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/11/">November (3)</a></li>
353
354 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/12/">December (3)</a></li>
355
356 </ul></li>
357
358 <li>2008
359 <ul>
360
361 <li><a href="http://people.skolelinux.org/pere/blog/archive/2008/11/">November (5)</a></li>
362
363 <li><a href="http://people.skolelinux.org/pere/blog/archive/2008/12/">December (7)</a></li>
364
365 </ul></li>
366
367 </ul>
368
369
370
371 <h2>Tags</h2>
372 <ul>
373
374 <li><a href="http://people.skolelinux.org/pere/blog/tags/3d-printer">3d-printer (13)</a></li>
375
376 <li><a href="http://people.skolelinux.org/pere/blog/tags/amiga">amiga (1)</a></li>
377
378 <li><a href="http://people.skolelinux.org/pere/blog/tags/aros">aros (1)</a></li>
379
380 <li><a href="http://people.skolelinux.org/pere/blog/tags/bankid">bankid (4)</a></li>
381
382 <li><a href="http://people.skolelinux.org/pere/blog/tags/bitcoin">bitcoin (9)</a></li>
383
384 <li><a href="http://people.skolelinux.org/pere/blog/tags/bootsystem">bootsystem (16)</a></li>
385
386 <li><a href="http://people.skolelinux.org/pere/blog/tags/bsa">bsa (2)</a></li>
387
388 <li><a href="http://people.skolelinux.org/pere/blog/tags/chrpath">chrpath (2)</a></li>
389
390 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian">debian (148)</a></li>
391
392 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian edu">debian edu (158)</a></li>
393
394 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian-handbook">debian-handbook (3)</a></li>
395
396 <li><a href="http://people.skolelinux.org/pere/blog/tags/digistan">digistan (10)</a></li>
397
398 <li><a href="http://people.skolelinux.org/pere/blog/tags/dld">dld (16)</a></li>
399
400 <li><a href="http://people.skolelinux.org/pere/blog/tags/docbook">docbook (23)</a></li>
401
402 <li><a href="http://people.skolelinux.org/pere/blog/tags/drivstoffpriser">drivstoffpriser (4)</a></li>
403
404 <li><a href="http://people.skolelinux.org/pere/blog/tags/english">english (345)</a></li>
405
406 <li><a href="http://people.skolelinux.org/pere/blog/tags/fiksgatami">fiksgatami (23)</a></li>
407
408 <li><a href="http://people.skolelinux.org/pere/blog/tags/fildeling">fildeling (12)</a></li>
409
410 <li><a href="http://people.skolelinux.org/pere/blog/tags/freeculture">freeculture (29)</a></li>
411
412 <li><a href="http://people.skolelinux.org/pere/blog/tags/freedombox">freedombox (9)</a></li>
413
414 <li><a href="http://people.skolelinux.org/pere/blog/tags/frikanalen">frikanalen (18)</a></li>
415
416 <li><a href="http://people.skolelinux.org/pere/blog/tags/h264">h264 (20)</a></li>
417
418 <li><a href="http://people.skolelinux.org/pere/blog/tags/intervju">intervju (42)</a></li>
419
420 <li><a href="http://people.skolelinux.org/pere/blog/tags/isenkram">isenkram (15)</a></li>
421
422 <li><a href="http://people.skolelinux.org/pere/blog/tags/kart">kart (20)</a></li>
423
424 <li><a href="http://people.skolelinux.org/pere/blog/tags/ldap">ldap (9)</a></li>
425
426 <li><a href="http://people.skolelinux.org/pere/blog/tags/lenker">lenker (8)</a></li>
427
428 <li><a href="http://people.skolelinux.org/pere/blog/tags/lsdvd">lsdvd (2)</a></li>
429
430 <li><a href="http://people.skolelinux.org/pere/blog/tags/ltsp">ltsp (1)</a></li>
431
432 <li><a href="http://people.skolelinux.org/pere/blog/tags/mesh network">mesh network (8)</a></li>
433
434 <li><a href="http://people.skolelinux.org/pere/blog/tags/multimedia">multimedia (39)</a></li>
435
436 <li><a href="http://people.skolelinux.org/pere/blog/tags/nice free software">nice free software (9)</a></li>
437
438 <li><a href="http://people.skolelinux.org/pere/blog/tags/norsk">norsk (287)</a></li>
439
440 <li><a href="http://people.skolelinux.org/pere/blog/tags/nuug">nuug (187)</a></li>
441
442 <li><a href="http://people.skolelinux.org/pere/blog/tags/offentlig innsyn">offentlig innsyn (28)</a></li>
443
444 <li><a href="http://people.skolelinux.org/pere/blog/tags/open311">open311 (2)</a></li>
445
446 <li><a href="http://people.skolelinux.org/pere/blog/tags/opphavsrett">opphavsrett (64)</a></li>
447
448 <li><a href="http://people.skolelinux.org/pere/blog/tags/personvern">personvern (99)</a></li>
449
450 <li><a href="http://people.skolelinux.org/pere/blog/tags/raid">raid (1)</a></li>
451
452 <li><a href="http://people.skolelinux.org/pere/blog/tags/reactos">reactos (1)</a></li>
453
454 <li><a href="http://people.skolelinux.org/pere/blog/tags/reprap">reprap (11)</a></li>
455
456 <li><a href="http://people.skolelinux.org/pere/blog/tags/rfid">rfid (3)</a></li>
457
458 <li><a href="http://people.skolelinux.org/pere/blog/tags/robot">robot (10)</a></li>
459
460 <li><a href="http://people.skolelinux.org/pere/blog/tags/rss">rss (1)</a></li>
461
462 <li><a href="http://people.skolelinux.org/pere/blog/tags/ruter">ruter (5)</a></li>
463
464 <li><a href="http://people.skolelinux.org/pere/blog/tags/scraperwiki">scraperwiki (2)</a></li>
465
466 <li><a href="http://people.skolelinux.org/pere/blog/tags/sikkerhet">sikkerhet (52)</a></li>
467
468 <li><a href="http://people.skolelinux.org/pere/blog/tags/sitesummary">sitesummary (4)</a></li>
469
470 <li><a href="http://people.skolelinux.org/pere/blog/tags/skepsis">skepsis (5)</a></li>
471
472 <li><a href="http://people.skolelinux.org/pere/blog/tags/standard">standard (51)</a></li>
473
474 <li><a href="http://people.skolelinux.org/pere/blog/tags/stavekontroll">stavekontroll (5)</a></li>
475
476 <li><a href="http://people.skolelinux.org/pere/blog/tags/stortinget">stortinget (11)</a></li>
477
478 <li><a href="http://people.skolelinux.org/pere/blog/tags/surveillance">surveillance (48)</a></li>
479
480 <li><a href="http://people.skolelinux.org/pere/blog/tags/sysadmin">sysadmin (3)</a></li>
481
482 <li><a href="http://people.skolelinux.org/pere/blog/tags/usenix">usenix (2)</a></li>
483
484 <li><a href="http://people.skolelinux.org/pere/blog/tags/valg">valg (8)</a></li>
485
486 <li><a href="http://people.skolelinux.org/pere/blog/tags/video">video (59)</a></li>
487
488 <li><a href="http://people.skolelinux.org/pere/blog/tags/vitenskap">vitenskap (4)</a></li>
489
490 <li><a href="http://people.skolelinux.org/pere/blog/tags/web">web (40)</a></li>
491
492 </ul>
493
494
495 </div>
496 <p style="text-align: right">
497 Created by <a href="http://steve.org.uk/Software/chronicle">Chronicle v4.6</a>
498 </p>
499
500 </body>
501 </html>