An XML framework for interactive publishing

This article describes the systems developed for publishing articles at ApacheTutor. The goal was a highly lightweight but extensible framework for interactive authoring and publication, offering full guarantees of Accessibility and Quality. We discuss reasons why existing blog and wiki software was not considered adequate, and describe the design and implementation of this application, including new modules, an XML namespace, and a DTD.

Add Comment

Introduction


The concept of ApacheTutor is one of an interactive, online book. High quality content (which is gradually being written) should be accompanied by genuine interactivity. Subject to permissions, reviewers, editors and readers should be able to attach notes to an article, and authorised editors should be able to work on the document text itself. The system is required to manage this process, including retaining a full revision history.

Coincidentally, while the site was in preparation, I was asked to do the technical review for a forthcoming book. This required me to find out about and use broadly comparable capabilities in a modern wordprocessor, which permits an editor to make changes or enter notes anywhere, while the software takes care of attaching my name and the date to my edits. But publishing on the Web opens this process up, and permits not only expert reviewers but also general readers to participate. So if anything is inaccurate or unclear, there is a readily-available builtin mechanism to ask for review and clarification.

Wearing my other hat, I am concerned about web standards and accessibility, and I am not prepared to accept sub-standard publishing 'solutions'. ApacheTutor is required to ensure that all HTML delivered over the web is both valid and fully accessible. To the best of my knowledge, this is the first and only web-based system that can offer such a guarantee while permitting editors the flexibility of working on 'raw' markup.

show annotation

Note by anonymous, Tue Aug 24 12:13:01 2004

show annotation

Note by anonymous, Tue Aug 24 15:22:03 2004

bcd

show annotation

Note by anonymous, Tue Aug 24 16:36:48 2004

asf

show annotation

Note by anonymous, Thu Jun 26 12:53:25 2008

Test Annotation

show annotation

Note by anonymous, Tue Jul 1 22:53:56 2008

KpOyYC http://putaria.dnip.net http://sexpartylog.dnip.net http://passiov.dnip.net http://sexkore.dnip.net http://352free.dnip.net http://outdoorlog.dnip.net http://buceti.dnip.net http://kamranh.dnip.net http://kamsut.dnip.net

show annotation

Note by anonymous, Wed Jul 2 03:37:16 2008

TTUltr http://putaria.dnip.net http://sexpartylog.dnip.net http://passiov.dnip.net http://sexkore.dnip.net http://352free.dnip.net http://outdoorlog.dnip.net http://buceti.dnip.net http://kamranh.dnip.net http://kamsut.dnip.net

show annotation

Note by anonymous, Sat Jul 5 11:26:55 2008

xTjhgJ sdbgh83kdf0umfn3fdhzp

show annotation

Note by anonymous, Sun Jul 13 06:06:45 2008

c967t [a] [/a]

show annotation

Note by anonymous, Sun Jul 13 06:18:44 2008

c564t [a] [/a]

show annotation

Note by anonymous, Mon Jul 14 01:14:56 2008

Very nice site! [url=http://c.1asphost.com/topfarm7/419.html]cheap cialis[/url]

show annotation

Note by anonymous, Mon Jul 14 01:15:00 2008

Very nice site! [LINK http://c.1asphost.com/topfarm7/557.html]cheap tramadol[/LINK]

show annotation

Note by anonymous, Mon Jul 14 01:18:36 2008

Very nice site! http://c.1asphost.com/topfarm7/0.html

show annotation

Note by anonymous, Mon Jul 14 01:18:40 2008

Very nice site!

show annotation

Note by anonymous, Tue Jul 15 00:30:59 2008

c351t [a] [/a]

show annotation

Note by anonymous, Tue Jul 15 00:42:04 2008

c818t [a] [/a]

show annotation

Note by anonymous, Tue Jul 15 00:53:37 2008

c15t [a] [/a]

show annotation

Note by anonymous, Tue Jul 15 01:05:29 2008

c377t [a] [/a]

show annotation

Note by anonymous, Tue Jul 15 01:28:18 2008

c819t [a] [/a]

show annotation

Note by anonymous, Tue Jul 15 01:39:16 2008

c294t [a] [/a]

show annotation

Note by anonymous, Tue Jul 15 01:50:03 2008

c459t [a] [/a]

show annotation

Note by anonymous, Tue Jul 15 02:00:43 2008

c427t [a] [/a]

show annotation

Note by anonymous, Tue Jul 15 02:11:31 2008

c589t [a] [/a]

show annotation

Note by anonymous, Tue Jul 15 02:19:02 2008

c386t [a] http://www.imeem.com/people/mP2N-B7/blogs/2008/07/14/KGWlLkO6/garth_brooks_rington [/a] [a] http://www.imeem.com/people/bqXrM1v/blogs/2008/07/14/AIlCFiIF/get_ringtones_co [/a] [a] http://www.imeem.com/people/7xshDja/blogs/2008/07/14/rcmg266F/gospel_ringtones_fre [/a] Garth Brooks Rington - http://www.imeem.com/people/mP2N-B7/blogs/2008/07/14/KGWlLkO6/garth_brooks_rington

show annotation

Note by anonymous, Tue Jul 15 02:31:49 2008

c681t [a] [/a]

show annotation

Note by anonymous, Tue Jul 15 02:34:38 2008

c45t [a] [/a]

show annotation

Note by anonymous, Tue Jul 15 02:42:49 2008

c547t [a] [/a]

show annotation

Note by anonymous, Tue Jul 15 02:56:24 2008

c185t [a] [/a]

show annotation

Note by anonymous, Tue Jul 15 03:03:49 2008

c983t [a] [/a]

show annotation

Note by anonymous, Tue Jul 15 03:04:59 2008

c297t [a] [/a]

show annotation

Note by anonymous, Tue Jul 15 03:07:38 2008

c93t [a] [/a]

show annotation

Note by anonymous, Fri Jul 18 04:26:26 2008

c671t [a] [/a]

show annotation

Note by anonymous, Fri Jul 18 04:34:01 2008

c35t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 11:50:10 2008

c281t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 12:03:31 2008

c625t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 12:16:18 2008

c555t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 12:29:32 2008

c657t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 12:42:26 2008

c844t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 12:55:40 2008

c967t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 13:20:18 2008

c446t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 13:32:30 2008

c230t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 13:44:14 2008

c774t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 13:56:05 2008

c220t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 14:07:52 2008

c991t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 14:20:03 2008

c170t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 14:31:43 2008

c426t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 14:40:39 2008

c866t [a] http://groups.yahoo.com/group/Paris-Cheep-Viagra-vs [/a]

show annotation

Note by anonymous, Sun Jul 20 14:43:11 2008

c326t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 14:53:17 2008

c547t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 14:54:55 2008

c224t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 15:05:55 2008

c521t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 15:06:38 2008

c706t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 15:18:35 2008

c888t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 15:18:39 2008

c455t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 15:19:00 2008

c636t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 15:30:50 2008

c174t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 15:31:53 2008

c660t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 15:43:00 2008

c642t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 15:44:08 2008

c351t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 15:54:53 2008

c943t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 15:56:06 2008

c955t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 16:06:52 2008

c86t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 16:08:07 2008

c344t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 16:18:52 2008

c18t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 16:20:15 2008

c696t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 16:30:43 2008

c890t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 16:32:39 2008

c800t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 16:41:55 2008

c933t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 16:44:20 2008

c590t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 16:53:20 2008

c380t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 16:55:56 2008

c81t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 17:05:08 2008

c1000t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 17:07:38 2008

c530t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 17:17:07 2008

c22t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 17:19:35 2008

c41t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 17:31:41 2008

c99t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 17:40:32 2008

c449t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 17:43:34 2008

c471t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 17:52:24 2008

c950t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 17:55:40 2008

c216t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 18:04:14 2008

c302t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 18:08:03 2008

c99t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 18:16:37 2008

c27t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 18:19:57 2008

c546t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 18:28:40 2008

c270t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 18:32:32 2008

c51t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 18:40:45 2008

c682t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 18:44:32 2008

c798t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 18:52:39 2008

c560t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 18:56:01 2008

c561t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 19:08:20 2008

c32t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 19:16:46 2008

c908t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 19:19:44 2008

c509t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 19:28:03 2008

c243t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 19:39:26 2008

c859t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 19:44:10 2008

c854t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 19:56:33 2008

c130t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 20:02:33 2008

c655t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 20:07:33 2008

c728t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 20:08:35 2008

c604t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 20:20:59 2008

c790t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 20:25:47 2008

c874t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 20:31:55 2008

c163t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 20:33:16 2008

c252t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 20:48:33 2008

c317t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 20:55:34 2008

c659t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 21:00:06 2008

c393t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 21:07:46 2008

c292t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 21:08:02 2008

c607t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 21:23:07 2008

c508t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 21:31:38 2008

c994t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 21:34:28 2008

c611t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 21:35:48 2008

c40t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 21:47:59 2008

c994t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 21:54:59 2008

c882t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 21:57:23 2008

c603t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 22:00:57 2008

c418t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 22:08:52 2008

c376t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 22:19:20 2008

c648t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 22:20:25 2008

c490t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 22:25:12 2008

c740t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 22:31:51 2008

c58t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 22:43:48 2008

c940t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 22:43:48 2008

c90t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 22:49:30 2008

c241t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 23:01:47 2008

c82t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 23:07:32 2008

c338t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 23:08:10 2008

c281t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 23:14:26 2008

c506t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 23:19:47 2008

c388t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 23:20:56 2008

c225t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 23:25:58 2008

c139t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 23:33:15 2008

c590t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 23:43:37 2008

c927t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 23:45:27 2008

c143t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 23:50:20 2008

c979t [a] [/a]

show annotation

Note by anonymous, Sun Jul 20 23:57:16 2008

c506t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 00:08:15 2008

c605t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 00:09:24 2008

c747t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 00:14:53 2008

c603t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 00:26:54 2008

c149t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 00:32:11 2008

c675t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 00:33:10 2008

c104t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 00:38:48 2008

c310t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 00:54:45 2008

c813t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 00:56:25 2008

c500t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 01:02:42 2008

c436t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 01:17:57 2008

c589t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 01:20:09 2008

c578t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 01:29:34 2008

c722t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 01:31:14 2008

c367t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 01:43:51 2008

c107t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 01:52:49 2008

c519t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 01:56:16 2008

c891t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 01:56:34 2008

c896t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 02:08:56 2008

c257t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 02:17:04 2008

c296t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 02:20:23 2008

c937t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 02:21:12 2008

c403t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 02:32:54 2008

c127t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 02:41:07 2008

c193t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 02:44:30 2008

c923t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 02:45:05 2008

c883t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 02:53:19 2008

c918t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 02:56:37 2008

c490t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 02:56:47 2008

c879t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 03:08:47 2008

c183t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 03:18:00 2008

c953t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 03:21:02 2008

c506t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 03:21:27 2008

c963t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 03:33:29 2008

c467t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 03:41:20 2008

c110t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 03:45:39 2008

c311t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 03:47:49 2008

c372t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 03:57:52 2008

c59t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 04:05:03 2008

c584t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 04:10:06 2008

c210t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 04:14:30 2008

c23t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 04:30:43 2008

c148t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 04:36:29 2008

c790t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 04:40:26 2008

c968t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 04:55:17 2008

c912t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 05:02:05 2008

c173t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 05:07:43 2008

c28t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 05:15:37 2008

c349t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 05:20:12 2008

c851t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 05:28:30 2008

c729t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 05:32:22 2008

c755t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 05:35:10 2008

c298t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 05:40:39 2008

c578t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 05:44:13 2008

c266t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 05:46:46 2008

c363t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 05:58:47 2008

c153t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 06:05:35 2008

c312t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 06:08:37 2008

c935t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 06:10:22 2008

c292t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 06:22:22 2008

c215t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 06:30:29 2008

c900t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 06:32:09 2008

c891t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 06:33:58 2008

c296t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 06:45:56 2008

c379t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 06:55:06 2008

c684t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 06:55:10 2008

c460t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 06:57:30 2008

c420t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 06:57:51 2008

c512t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 07:10:07 2008

c66t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 07:18:52 2008

c309t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 07:19:37 2008

c452t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 07:22:19 2008

c741t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 07:33:54 2008

c193t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 07:42:53 2008

c840t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 07:43:47 2008

c981t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 07:46:17 2008

c153t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 07:54:20 2008

c790t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 08:07:58 2008

c713t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 08:17:53 2008

c563t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 08:20:09 2008

c229t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 08:29:30 2008

c800t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 08:40:48 2008

c490t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 08:43:22 2008

c608t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 08:52:45 2008

c406t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 08:54:53 2008

c397t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 09:04:21 2008

c99t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 09:06:27 2008

c974t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 09:16:04 2008

c1000t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 09:27:38 2008

c201t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 09:29:59 2008

c316t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 09:39:04 2008

c604t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 09:41:29 2008

c798t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 09:50:34 2008

c379t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 09:53:09 2008

c323t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 10:02:30 2008

c288t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 10:04:51 2008

c515t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 10:14:10 2008

c154t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 10:16:34 2008

c133t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 10:21:15 2008

c213t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 10:37:30 2008

c198t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 10:38:02 2008

c150t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 10:52:58 2008

c999t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 11:01:57 2008

c443t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 11:03:01 2008

c227t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 11:14:11 2008

c367t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 11:28:23 2008

c210t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 11:32:49 2008

c275t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 11:38:24 2008

c382t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 11:47:18 2008

c179t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 11:56:10 2008

c598t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 12:01:48 2008

c895t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 12:10:07 2008

c391t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 12:16:07 2008

c790t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 12:25:05 2008

c702t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 12:32:13 2008

c227t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 12:39:12 2008

c235t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 12:46:22 2008

c533t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 13:01:51 2008

c691t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 13:08:23 2008

c776t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 13:18:00 2008

c263t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 13:24:25 2008

c348t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 13:34:09 2008

c21t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 13:39:01 2008

c228t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 13:49:25 2008

c689t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 13:54:08 2008

c404t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 14:07:20 2008

c992t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 14:11:21 2008

c206t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 14:23:48 2008

c778t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 14:26:50 2008

c154t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 14:37:38 2008

c38t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 14:39:20 2008

c249t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 14:50:37 2008

c139t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 14:51:36 2008

c544t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 15:03:09 2008

c758t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 15:03:59 2008

c90t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 15:18:22 2008

c350t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 15:18:46 2008

c219t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 15:35:02 2008

c149t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 15:35:37 2008

c521t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 15:53:46 2008

c191t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 16:11:20 2008

c233t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 16:29:29 2008

c842t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 16:42:39 2008

c582t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 16:45:05 2008

c772t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 17:00:18 2008

c364t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 17:14:30 2008

c435t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 17:15:50 2008

c730t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 17:26:26 2008

c431t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 17:27:37 2008

c509t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 17:38:11 2008

c327t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 17:39:35 2008

c731t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 17:49:18 2008

c332t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 17:50:54 2008

c287t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 18:00:41 2008

c997t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 18:03:00 2008

c455t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 18:11:47 2008

c118t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 18:13:49 2008

c533t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 18:24:50 2008

c280t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 18:35:08 2008

c760t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 18:46:53 2008

c558t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 18:48:40 2008

c879t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 18:57:44 2008

c742t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 19:08:49 2008

c679t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 19:10:25 2008

c67t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 19:19:55 2008

c887t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 19:21:56 2008

c901t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 19:31:00 2008

c603t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 19:33:03 2008

c343t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 19:42:03 2008

c754t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 19:43:59 2008

c858t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 19:53:43 2008

c107t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 19:55:39 2008

c996t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 20:05:35 2008

c812t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 20:07:42 2008

c694t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 20:17:17 2008

c61t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 20:18:45 2008

c862t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 20:28:27 2008

c196t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 20:30:06 2008

c454t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 20:39:50 2008

c115t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 20:41:16 2008

c413t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 20:51:03 2008

c171t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 20:51:04 2008

c853t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 20:52:24 2008

c448t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 21:02:48 2008

c105t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 21:04:08 2008

c941t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 21:14:34 2008

c769t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 21:16:08 2008

c155t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 21:26:28 2008

c312t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 21:27:43 2008

c897t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 21:38:12 2008

c287t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 21:38:56 2008

c444t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 21:49:50 2008

c162t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 21:50:19 2008

c227t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 22:01:25 2008

c505t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 22:01:49 2008

c181t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 22:13:09 2008

c910t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 22:13:09 2008

c65t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 22:24:58 2008

c323t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 22:24:59 2008

c267t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 22:37:21 2008

c15t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 22:37:29 2008

c754t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 22:49:58 2008

c794t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 22:49:58 2008

c238t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 23:02:28 2008

c242t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 23:02:28 2008

c628t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 23:14:10 2008

c431t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 23:14:13 2008

c948t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 23:25:57 2008

c441t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 23:38:11 2008

c125t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 23:38:19 2008

c50t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 23:50:33 2008

c66t [a] [/a]

show annotation

Note by anonymous, Mon Jul 21 23:50:43 2008

c628t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 00:02:21 2008

c807t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 00:02:22 2008

c782t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 00:03:42 2008

c246t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 00:16:26 2008

c39t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 00:16:26 2008

c563t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 00:16:27 2008

c390t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 00:28:39 2008

c730t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 00:28:49 2008

c69t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 00:40:44 2008

c882t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 00:52:40 2008

c944t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 00:52:43 2008

c453t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 01:04:38 2008

c850t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 01:05:12 2008

c147t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 01:16:42 2008

c851t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 01:17:25 2008

c352t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 01:28:14 2008

c851t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 01:29:49 2008

c510t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 05:18:48 2008

c889t [a] http://www.imeem.com/people/6O19nuG/blogs/2008/07/18/1-8NtCMu/blackberry_free_ringtones [/a] [a] http://www.imeem.com/people/hXk79vS/blogs/2008/07/18/XzARknPQ/blackberry_mp3_ringtones [/a] blackberry free ringtones - http://www.imeem.com/people/6O19nuG/blogs/2008/07/18/1-8NtCMu/blackberry_free_ringtones

show annotation

Note by anonymous, Tue Jul 22 05:31:52 2008

c264t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 05:39:37 2008

c334t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 05:44:41 2008

c893t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 05:51:53 2008

c313t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 05:56:17 2008

c442t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 06:04:54 2008

c946t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 06:08:23 2008

c817t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 06:20:53 2008

c520t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 06:32:32 2008

c760t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 06:34:32 2008

c935t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 06:46:32 2008

c749t [a] [/a]

show annotation

Note by anonymous, Tue Jul 22 06:47:49 2008

c316t [a] [/a]

show annotation

Note by anonymous, Wed Jul 23 05:08:03 2008

c128t [a] [/a]

show annotation

Note by anonymous, Wed Jul 23 05:19:55 2008

c555t [a] [/a]

show annotation

Note by anonymous, Thu Jul 24 08:08:34 2008

c317t [a] http://groups.yahoo.com/group/Ballysac-b [/a] [a] http://groups.yahoo.com/group/Oblivion-Lock-Picks-b [/a] [a] http://groups.yahoo.com/group/Manual-Retractable-Awning-b [/a] [a] http://groups.yahoo.com/group/Abercrombie-Fitch-A-f-b [/a] [a] http://groups.yahoo.com/group/Continental-Air-Line-En-Espanol-b [/a] [a] http://groups.yahoo.com/group/Redcross-Csplans-b [/a] [a] http://groups.yahoo.com/group/Chapter-13-Bankruptcy-Alternatives-b [/a] [a] http://groups.yahoo.com/group/Uhaul-Rental-Trucks-Boxes-b [/a] [a] http://groups.yahoo.com/group/Basspro-Shops-Toronto-b [/a] ballysac - http://groups.yahoo.com/group/Ballysac-b oblivion lock picks - http://groups.yahoo.com/group/Oblivion-Lock-Picks-b manual retractable awning - http://groups.yahoo.com/group/Manual-Retractable-Awning-b abercrombie fitch a

show annotation

Note by anonymous, Thu Jul 24 10:39:18 2008

c844t [a] http://groups.yahoo.com/group/Bed-Bath-Beyond-Bridal-Registry-b [/a] [a] http://groups.yahoo.com/group/Ariel-Steam-Shower-b [/a] [a] http://groups.yahoo.com/group/Dellcomputers-Tv-b [/a] [a] http://groups.yahoo.com/group/Galveston-Cruises-Carnival-b [/a] [a] http://groups.yahoo.com/group/Newegg-Promotional-Code-b [/a] [a] http://groups.yahoo.com/group/Shinhan-Bank-America-b [/a] [a] http://groups.yahoo.com/group/Gas-Price-Watch-b [/a] [a] http://groups.yahoo.com/group/Zoom-Teeth-Whitening-Cost-b [/a] [a] http://groups.yahoo.com/group/Circus-Circus-Reno-Hotels-b [/a] [a] http://groups.yahoo.com/group/Odds-Of-Winning-The-Powerball-b [/a] bed bath

show annotation

Note by anonymous, Fri Jul 25 06:55:08 2008

c42t [a] http://groups.yahoo.com/group/At-t-Corded-Telephones-b [/a] [a] http://groups.yahoo.com/group/Electric-Mopeds-b [/a] [a] http://groups.yahoo.com/group/Eczema-Pictures-Baby-b [/a] [a] http://groups.yahoo.com/group/Pottery-Barns-Outlet-b [/a] [a] http://groups.yahoo.com/group/The-Hot-Tubs-Sf-b [/a] [a] http://groups.yahoo.com/group/Pay-A-Pal-Storm-Machine-b [/a] [a] http://groups.yahoo.com/group/Accounts-Receivable-Factoring-b [/a] [a] http://groups.yahoo.com/group/My-Puppies-Nose-Is-Dry-b [/a] [a] http://groups.yahoo.com/group/Nutrisystems-b [/a] at

Add Comment

Design Goals


Our design goals fall into three categories: functional (required capabilities), System (few dependencies, high performance) and Web Standards Compliance. To meet these requirements, we can also consider non-requirements. The system should offer strong support for technical and scholarly publishing to support authors, editors and readers. But there is no expectation that it will be used in high-volume discussions.

Add Comment

Interactive Features


Permissions Framework
The system should permit or deny privilege to annotate or edit it, and should different levels of access to different users, including anonymous users where appropriate. It should be possible for each document to have its own permissions.
Editing facilities
Subject to permissions, it should be possible to edit the markup of a section and to add an annotation (margin-note) to a section.
Granular comment framework
It should be possible to edit or annotate sections individually, and to attach annotations to the section to which they apply. Structurally each section is an independent unit.
Concurrency Management
It is essential that concurrency is properly managed. In addition to locking a document for updates, any change or annotation to a section must be coordinated to avoid the risk of conflicting changes. Changes to different sections of a document are not considered to be in conflict, even if made simultaneously.
Versioning
Strong versioning (such as provided by CVS) is not a requirement, but it should at least be possible for a document owner and/or system administrator to restore an older version if required. It should mark annotations as old once the section has been updated to reflect the comments.
Add Comment

General


Simplicity
This should not require the addition of any substantial new software that might prove problematic to introduce on an operational server or risk compromising performance on older hardware.
Lightweight application
Reading a document should be a very low overhead on the server, preferably avoiding any such overheads as a database query or multiple filesystem accesses. Write operations should also be fast but are considered less critical.
Extensibility
Many planned capabilities are not yet implemented, but the design must accommodate introducing them at a later date without disrupting the existing site.
Add Comment

Web Standards


Guaranteed Valid Markup
A system that permits an editor to enter markup risks collecting garbage, whether through ignorance or simple typos. The system must prevent that happening.
Accessibility and Graceful Degredation
Although the system may take advantage of graphics, stylesheets and clientside scripting to deliver a complete presentation, all contents must be available and clearly presented even in a text-only rendering such as Lynx.
Add Comment

The Solution


The basic solution adopted is to make each article a single XML file, containing all the data and metadata relevant to the article (except history information). The XML format adopted contains three types of data:

  • XHTML (namespace http://www.w3.org/1999/xhtml) for display
  • DublinCore (namespace http://purl.org/dc/elements/1.1/) for metadata
  • Annot (namespace http://apache.webthing.com/annot) for annotation and document management information. This is the only new markup introduced by this system.

Documents are presented using Apache's namespace support (mod_xmlns), based on a SAX parser that dispatches to different namespace handlers. A new namespace module mod_annot_view was developed to handle the annotations namespace. A second module mod_annot was developed to edit the articles. Other elements of the site development are a DTD used to validate document edits, and site design elements including CSS and Javascript.

The core of the system is therefore the design of the annotations namespace and document structure, and the implementation of the editor.

Add Comment

The Document Structure


The XML source is delivered on the Web as XHTML, which is required to be valid and accessible. To implement this with a fast SAX parser requires that the XML be ordered as it will be served, and that document-level metadata appear at the top of the file.

The structure of the XHTML served is constrained by accessibility to follow the logical order of the material presented. Apart from that, it needs hooks for CSS and Javascript to enhance the presentation.

The document root element is html. It is followed by annotation metadata describing ownership and access control. The data that will be served on the Web comprise the article's title, an Abstract, and one or more Section. Each section comprises a section title, section contents (html), and annotations, in that order.

All interactive features are at the level of the Section, which contains relevant metadata including in particular a last-modified timestamp and editor (this information is updated only by edits, not by annotations).

show annotation

Note by anonymous, Sat Jul 19 14:06:14 2008

test

Add Comment

The Annotations Namespace


The annotations namespace http://apache.webthing.com/annot is introduced by this application, and comprises application-specific metadata and structure:

editor
element listing a named editor, and noting owner
protection
sets protection for annot or edit to No (not allowed), Yes (allowed for anyone), or Auth (allow only identified/authorised users)
lock
Sets a temporary lock against any edits or annotations
article
container for all article content, with title and hooks for templated header and footer. Contains abstract and one or more section.
abstract
Document abstract (html markup)
section
container for a section, with title, editor and timestamp information, containing content element and zero or more annots.
content
Contents of the section. (Editable HTML markup).
annot
An annotation (margin note), with identifier of who made it and when. Plain text.
show annotation

Note by anonymous, Fri Jul 25 03:25:46 2008

varaccdom

Add Comment

Displaying an Article


Articles are served using the generic namespace processor mod_xmlns, together with the mod_xhtml XHTML namespace implementation and a new module mod_annot_view, implementing the annotations namespace. The document is displayed in order: title, abstract, sections, within a page template incorporating a sitewide header and footer, and document information. Each section is displayed in order: section title, content, annotations, together with Annotate and Edit buttons if the user has the relevant permissions.

On the browser side (and subject to browser support for CSS and javascript), annotations are transformed into margin notes and collapsed to icons. Selecting an icon will display the annotation, while a simple mouseover will show who made the annotation and when.

Add Comment

The Editor


The editor supports two handlers: editing or annotating a section. Each operation has two parts: displaying a Form, and submitting the Form to commit the update.

This is not considered so performance-critical ad displaying an article, as it is likely to be a relatively infrequent (and non-cacheable) operation. Nevertheless, it is implemented as a module mod_annot. But mod_annot does allow itself the overhead of parsing the document to a DOM and using XPATH expressions to check document metadata and extract the section we are working on. If a document is not well-formed, the parse will fail and an HTTP Error 500 will be returned.

On all requests, mod_annot first checks that the user is authorised for the attempted operation and that the document is not locked against any update. If this check fails an HTTP 401 or 503 error response will be returned as appropriate.

After these checks, one of two things happen. If the request was an HTTP GET, it will display an editor form. If the request was a POST, it will submit the form, making the update.

In either case, the next operation is to extract the section we are working on from the DOM. This relies on the user submitting valid inputs to the editor: if the inputs are not acceptable to the system (i.e. if someone is trying to tamper with it), it will return an HTTP 400 error. If the section cannot be extracted despite well-formed inputs, it will return an HTTP 500 error: this could happen either on a tamper attempt or because the section was updated between loading a page and selecting the editor operation.

Either the annotation or edit forms are displayed within a general page template. The annotation form displays the section with an empty text box to enter the user's comment, while the edit form displays the section title and the section contents (markup) in form fields to be edited.

Submitting either of the forms causes an update to the document. So in the case of a POST operation, the editor will take an exclusive lock to prevent a race condition. It will also check the section timestamp to ensure that the section is still the same as what the user is working on, and hasn't been updated by someone else in the meantime, returning an HTTP 409 error on failure.

An Annotation operation will insert a new annot node in the section, escaping any markup to plain text.

An Edit operation will first validate the markup, returning an HTTP 422 error on failure (if no section DTD is supplied, it would merely check well-formedness). If successful, it will replace the section title and contents in the DOM with the new values entered, together with the timestamp and editor id.

The DOM will then be saved to a new file, and moved atomically to the filename used to display the document. Finally, an internal redirect returns the updated document to the user.

Add Comment

Appendix: httpd.conf



LoadModule	xmlns_module		modules/mod_xmlns.so
LoadModule	xhtml_module		modules/mod_xhtml.so
LoadModule	annotate_module		modules/mod_annot.so
LoadModule	annot_view_module	modules/mod_annot_view.so
LoadModule	dublincore_module	modules/mod_dublincore.so

<VirtualHost 195.224.39.74>
ServerName	www.apachetutor.org
DocumentRoot	/usr/www/atutor

AnnotSectionDTD file:///usr/www/atutor/section.dtd
AliasMatch	/([a-z]+)\/$	/usr/www/atutor/$1.html
AliasMatch	/auth/([a-z]+)\/$ /usr/www/atutor/$1.html
Alias /auth	/usr/www/atutor

<Directory /usr/www/atutor>
	AddType text/html;charset=utf-8 .edit .annot
	AddHandler	annot-edit	.edit
	AddHandler	annot-annot	.annot
	AnnotHeader	/path/to/header
	AnnotFooter	/path/to/footer
	<FilesMatch "^[a-z-]+$">
		SetOutputFilter	 xmlns
		ForceType		text/html;charset=utf-8
		XMLNSUseNamespace	http://apache.webthing.com/annot on view
		XMLNSUseNamespace	http://www.w3.org/1999/xhtml on 1.0
		XMLNSUseNamespace	http://purl.org/dc/elements/1.1/ on hide
	</FilesMatch>
</Directory>

<Location /auth>
	AuthType	Basic
	AuthName	"Apache Tutorials"
	Require		valid-user
	#(details chopped)
</Location>

</VirtualHost>