| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | ! Copyright (C) 2008 Slava Pestov | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2008-07-08 17:15:51 -04:00
										 |  |  | USING: accessors kernel hashtables calendar random assocs | 
					
						
							| 
									
										
										
										
											2008-09-10 23:11:40 -04:00
										 |  |  | namespaces make splitting sequences sorting math.order present | 
					
						
							| 
									
										
										
										
											2008-12-15 02:13:35 -05:00
										 |  |  | io.files io.directories io.encodings.ascii | 
					
						
							| 
									
										
										
										
											2008-09-08 02:11:27 -04:00
										 |  |  | syndication farkup | 
					
						
							| 
									
										
										
										
											2008-06-15 04:25:36 -04:00
										 |  |  | html.components html.forms | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | http.server | 
					
						
							| 
									
										
										
										
											2008-06-02 16:00:03 -04:00
										 |  |  | http.server.dispatchers | 
					
						
							| 
									
										
										
										
											2008-06-01 18:22:39 -04:00
										 |  |  | furnace.actions | 
					
						
							| 
									
										
										
										
											2008-11-24 21:26:11 -05:00
										 |  |  | furnace.utilities | 
					
						
							| 
									
										
										
										
											2011-05-06 22:47:32 -04:00
										 |  |  | furnace.recaptcha | 
					
						
							| 
									
										
										
										
											2008-06-17 01:10:46 -04:00
										 |  |  | furnace.redirection | 
					
						
							| 
									
										
										
										
											2008-06-01 18:22:39 -04:00
										 |  |  | furnace.auth | 
					
						
							|  |  |  | furnace.auth.login | 
					
						
							|  |  |  | furnace.boilerplate | 
					
						
							| 
									
										
										
										
											2008-06-05 02:56:06 -04:00
										 |  |  | furnace.syndication | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | validators | 
					
						
							| 
									
										
										
										
											2009-05-15 00:23:06 -04:00
										 |  |  | db.types db.tuples lcs urls ;
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | IN: webapps.wiki | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-12 19:54:50 -04:00
										 |  |  | : wiki-url ( rest path -- url )
 | 
					
						
							| 
									
										
										
										
											2008-09-23 00:45:16 -04:00
										 |  |  |     [ "$wiki/" % % "/" % present % ] "" make | 
					
						
							| 
									
										
										
										
											2008-06-12 19:54:50 -04:00
										 |  |  |     <url> swap >>path ;
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-12 19:54:50 -04:00
										 |  |  | : view-url ( title -- url ) "view" wiki-url ;
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-12 19:54:50 -04:00
										 |  |  | : edit-url ( title -- url ) "edit" wiki-url ;
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-12 19:54:50 -04:00
										 |  |  | : revisions-url ( title -- url ) "revisions" wiki-url ;
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-12 19:54:50 -04:00
										 |  |  | : revision-url ( id -- url ) "revision" wiki-url ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : user-edits-url ( author -- url ) "user-edits" wiki-url ;
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-02 16:00:03 -04:00
										 |  |  | TUPLE: wiki < dispatcher ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | SYMBOL: can-delete-wiki-articles? | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | can-delete-wiki-articles? define-capability | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | TUPLE: article title revision ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | article "ARTICLES" { | 
					
						
							|  |  |  |     { "title" "TITLE" { VARCHAR 256 } +not-null+ +user-assigned-id+ } | 
					
						
							|  |  |  |     { "revision" "REVISION" INTEGER +not-null+ } ! revision id | 
					
						
							|  |  |  | } define-persistent | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : <article> ( title -- article ) article new swap >>title ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-16 04:29:29 -04:00
										 |  |  | TUPLE: revision id title author date content description ;
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | revision "REVISIONS" { | 
					
						
							|  |  |  |     { "id" "ID" INTEGER +db-assigned-id+ } | 
					
						
							|  |  |  |     { "title" "TITLE" { VARCHAR 256 } +not-null+ } ! article id | 
					
						
							|  |  |  |     { "author" "AUTHOR" { VARCHAR 256 } +not-null+ } ! uid | 
					
						
							|  |  |  |     { "date" "DATE" TIMESTAMP +not-null+ } | 
					
						
							|  |  |  |     { "content" "CONTENT" TEXT +not-null+ } | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |     { "description" "DESCRIPTION" TEXT } | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | } define-persistent | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  | M: revision feed-entry-title | 
					
						
							|  |  |  |     [ title>> ] [ drop " by " ] [ author>> ] tri 3append ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: revision feed-entry-date date>> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: revision feed-entry-url id>> revision-url ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : reverse-chronological-order ( seq -- sorted )
 | 
					
						
							| 
									
										
										
										
											2009-08-02 21:10:58 -04:00
										 |  |  |     [ date>> ] inv-sort-with ;
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | : <revision> ( id -- revision )
 | 
					
						
							|  |  |  |     revision new swap >>id ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : validate-title ( -- )
 | 
					
						
							|  |  |  |     { { "title" [ v-one-line ] } } validate-params ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  | : validate-author ( -- )
 | 
					
						
							|  |  |  |     { { "author" [ v-username ] } } validate-params ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  | : <article-boilerplate> ( responder -- responder' )
 | 
					
						
							|  |  |  |     <boilerplate> | 
					
						
							|  |  |  |         { wiki "page-common" } >>template ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | : <main-article-action> ( -- action )
 | 
					
						
							|  |  |  |     <action> | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  |         [ "Front Page" view-url <redirect> ] >>display ;
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-15 05:56:35 -04:00
										 |  |  | : latest-revision ( title -- revision/f )
 | 
					
						
							|  |  |  |     <article> select-tuple | 
					
						
							|  |  |  |     dup [ revision>> <revision> select-tuple ] when ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | : <view-article-action> ( -- action )
 | 
					
						
							|  |  |  |     <action> | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  |         "title" >>rest | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-10 21:07:00 -04:00
										 |  |  |         [ validate-title ] >>init | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |         [ | 
					
						
							| 
									
										
										
										
											2008-06-15 05:56:35 -04:00
										 |  |  |             "title" value dup latest-revision [ | 
					
						
							|  |  |  |                 from-object | 
					
						
							| 
									
										
										
										
											2008-06-02 16:00:03 -04:00
										 |  |  |                 { wiki "view" } <chloe-content> | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |             ] [ | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  |                 edit-url <redirect> | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |             ] ?if
 | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |         ] >>display | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     <article-boilerplate> ;
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : <view-revision-action> ( -- action )
 | 
					
						
							|  |  |  |     <page-action> | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-12 19:54:50 -04:00
										 |  |  |         "id" >>rest | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |         [ | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  |             validate-integer-id | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |             "id" value <revision> | 
					
						
							| 
									
										
										
										
											2008-06-01 18:22:39 -04:00
										 |  |  |             select-tuple from-object | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |         ] >>init | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |         { wiki "view" } >>template | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |     <article-boilerplate> ;
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-08 17:15:51 -04:00
										 |  |  | : <random-article-action> ( -- action )
 | 
					
						
							|  |  |  |     <action> | 
					
						
							|  |  |  |         [ | 
					
						
							|  |  |  |             article new select-tuples random | 
					
						
							|  |  |  |             [ title>> ] [ "Front Page" ] if*
 | 
					
						
							|  |  |  |             view-url <redirect> | 
					
						
							|  |  |  |         ] >>display ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-13 23:05:41 -04:00
										 |  |  | : amend-article ( revision article -- )
 | 
					
						
							|  |  |  |     swap id>> >>revision update-tuple ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : add-article ( revision -- )
 | 
					
						
							|  |  |  |     [ title>> ] [ id>> ] bi article boa insert-tuple ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | : add-revision ( revision -- )
 | 
					
						
							|  |  |  |     [ insert-tuple ] | 
					
						
							|  |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-06-13 23:05:41 -04:00
										 |  |  |         dup title>> <article> select-tuple | 
					
						
							|  |  |  |         [ amend-article ] [ add-article ] if*
 | 
					
						
							| 
									
										
										
										
											2008-09-08 02:11:27 -04:00
										 |  |  |     ] | 
					
						
							| 
									
										
										
										
											2009-03-16 04:29:29 -04:00
										 |  |  |     bi ;
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : <edit-article-action> ( -- action )
 | 
					
						
							|  |  |  |     <page-action> | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-12 19:54:50 -04:00
										 |  |  |         "title" >>rest | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |         [ | 
					
						
							|  |  |  |             validate-title | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |             "title" value <article> select-tuple | 
					
						
							|  |  |  |             [ revision>> <revision> select-tuple ] | 
					
						
							|  |  |  |             [ f <revision> "title" value >>title ] | 
					
						
							|  |  |  |             if*
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             [ title>> "title" set-value ] | 
					
						
							|  |  |  |             [ content>> "content" set-value ] | 
					
						
							|  |  |  |             bi
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |         ] >>init | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-02 16:00:03 -04:00
										 |  |  |         { wiki "edit" } >>template | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |     <article-boilerplate> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : <submit-article-action> ( -- action )
 | 
					
						
							|  |  |  |     <action> | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |         [ | 
					
						
							| 
									
										
										
										
											2011-05-06 22:47:32 -04:00
										 |  |  |             validate-recaptcha | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |             validate-title | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 { "content" [ v-required ] } | 
					
						
							|  |  |  |                 { "description" [ [ v-one-line ] v-optional ] } | 
					
						
							|  |  |  |             } validate-params | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |             f <revision> | 
					
						
							|  |  |  |                 "title" value >>title | 
					
						
							|  |  |  |                 now >>date | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |                 username >>author | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |                 "content" value >>content | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |                 "description" value >>description | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  |             [ add-revision ] [ title>> view-url <redirect> ] bi
 | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  |         ] >>submit | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     <protected> | 
					
						
							|  |  |  |         "edit wiki articles" >>description ;
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  | : <revisions-boilerplate> ( responder -- responder )
 | 
					
						
							|  |  |  |     <boilerplate> | 
					
						
							|  |  |  |         { wiki "revisions-common" } >>template ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  | : list-revisions ( -- seq )
 | 
					
						
							|  |  |  |     f <revision> "title" value >>title select-tuples | 
					
						
							|  |  |  |     reverse-chronological-order ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | : <list-revisions-action> ( -- action )
 | 
					
						
							|  |  |  |     <page-action> | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-12 19:54:50 -04:00
										 |  |  |         "title" >>rest | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |         [ | 
					
						
							|  |  |  |             validate-title | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  |             list-revisions "revisions" set-value | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |         ] >>init | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |         { wiki "revisions" } >>template | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     <revisions-boilerplate> | 
					
						
							|  |  |  |     <article-boilerplate> ;
 | 
					
						
							| 
									
										
										
										
											2008-06-01 18:22:39 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  | : <list-revisions-feed-action> ( -- action )
 | 
					
						
							|  |  |  |     <feed-action> | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-12 19:54:50 -04:00
										 |  |  |         "title" >>rest | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  |         [ validate-title ] >>init | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  |         [ "Revisions of " "title" value append ] >>title | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  |         [ "title" value revisions-url ] >>url | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  |         [ list-revisions ] >>entries ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  | : rollback-description ( description -- description' )
 | 
					
						
							| 
									
										
										
										
											2010-08-23 00:58:13 -04:00
										 |  |  |     [ "Rollback to '" "'" surround ] [ "Rollback" ] if* ;
 | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-01 18:22:39 -04:00
										 |  |  | : <rollback-action> ( -- action )
 | 
					
						
							|  |  |  |     <action> | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  |         [ validate-integer-id ] >>validate | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-01 18:22:39 -04:00
										 |  |  |         [ | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |             "id" value <revision> select-tuple | 
					
						
							|  |  |  |                 f >>id | 
					
						
							|  |  |  |                 now >>date | 
					
						
							|  |  |  |                 username >>author | 
					
						
							|  |  |  |                 [ rollback-description ] change-description | 
					
						
							|  |  |  |             [ add-revision ] | 
					
						
							|  |  |  |             [ title>> revisions-url <redirect> ] bi
 | 
					
						
							|  |  |  |         ] >>submit | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |     <protected> | 
					
						
							|  |  |  |         "rollback wiki articles" >>description ;
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  | : list-changes ( -- seq )
 | 
					
						
							| 
									
										
										
										
											2008-06-12 19:54:50 -04:00
										 |  |  |     f <revision> select-tuples | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  |     reverse-chronological-order ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 03:42:21 -04:00
										 |  |  | : <list-changes-action> ( -- action )
 | 
					
						
							|  |  |  |     <page-action> | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |         [ list-changes "revisions" set-value ] >>init | 
					
						
							|  |  |  |         { wiki "changes" } >>template | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     <revisions-boilerplate> ;
 | 
					
						
							| 
									
										
										
										
											2008-05-27 03:42:21 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  | : <list-changes-feed-action> ( -- action )
 | 
					
						
							|  |  |  |     <feed-action> | 
					
						
							|  |  |  |         [ URL" $wiki/changes" ] >>url | 
					
						
							|  |  |  |         [ "All changes" ] >>title | 
					
						
							|  |  |  |         [ list-changes ] >>entries ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | : <delete-action> ( -- action )
 | 
					
						
							|  |  |  |     <action> | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |         [ validate-title ] >>validate | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |         [ | 
					
						
							|  |  |  |             "title" value <article> delete-tuples | 
					
						
							|  |  |  |             f <revision> "title" value >>title delete-tuples | 
					
						
							| 
									
										
										
										
											2008-06-01 18:22:39 -04:00
										 |  |  |             URL" $wiki" <redirect> | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  |         ] >>submit | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      <protected> | 
					
						
							|  |  |  |         "delete wiki articles" >>description | 
					
						
							|  |  |  |         { can-delete-wiki-articles? } >>capabilities ;
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : <diff-action> ( -- action )
 | 
					
						
							|  |  |  |     <page-action> | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |         [ | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 { "old-id" [ v-integer ] } | 
					
						
							|  |  |  |                 { "new-id" [ v-integer ] } | 
					
						
							|  |  |  |             } validate-params | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             "old-id" "new-id" | 
					
						
							|  |  |  |             [ value <revision> select-tuple ] bi@
 | 
					
						
							| 
									
										
										
										
											2008-06-02 16:33:33 -04:00
										 |  |  |             [ | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |                 over title>> "title" set-value | 
					
						
							|  |  |  |                 [ "old" [ from-object ] nest-form ] | 
					
						
							|  |  |  |                 [ "new" [ from-object ] nest-form ] | 
					
						
							|  |  |  |                 bi*
 | 
					
						
							| 
									
										
										
										
											2008-06-02 16:33:33 -04:00
										 |  |  |             ] | 
					
						
							| 
									
										
										
										
											2015-06-08 20:51:11 -04:00
										 |  |  |             [ [ content>> string-lines ] bi@ lcs-diff "diff" set-value ] | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |             2bi
 | 
					
						
							|  |  |  |         ] >>init | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |         { wiki "diff" } >>template | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     <article-boilerplate> ;
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : <list-articles-action> ( -- action )
 | 
					
						
							|  |  |  |     <page-action> | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 03:42:21 -04:00
										 |  |  |         [ | 
					
						
							|  |  |  |             f <article> select-tuples | 
					
						
							| 
									
										
										
										
											2009-08-02 21:09:23 -04:00
										 |  |  |             [ title>> ] sort-with | 
					
						
							| 
									
										
										
										
											2008-05-27 03:42:21 -04:00
										 |  |  |             "articles" set-value | 
					
						
							|  |  |  |         ] >>init | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-02 16:00:03 -04:00
										 |  |  |         { wiki "articles" } >>template ;
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  | : list-user-edits ( -- seq )
 | 
					
						
							|  |  |  |     f <revision> "author" value >>author select-tuples | 
					
						
							|  |  |  |     reverse-chronological-order ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 03:42:21 -04:00
										 |  |  | : <user-edits-action> ( -- action )
 | 
					
						
							|  |  |  |     <page-action> | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-12 19:54:50 -04:00
										 |  |  |         "author" >>rest | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 03:42:21 -04:00
										 |  |  |         [ | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  |             validate-author | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |             list-user-edits "revisions" set-value | 
					
						
							| 
									
										
										
										
											2008-05-27 03:42:21 -04:00
										 |  |  |         ] >>init | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |         { wiki "user-edits" } >>template | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     <revisions-boilerplate> ;
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  | : <user-edits-feed-action> ( -- action )
 | 
					
						
							|  |  |  |     <feed-action> | 
					
						
							| 
									
										
										
										
											2008-06-12 19:54:50 -04:00
										 |  |  |         "author" >>rest | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  |         [ validate-author ] >>init | 
					
						
							|  |  |  |         [ "Edits by " "author" value append ] >>title | 
					
						
							|  |  |  |         [ "author" value user-edits-url ] >>url | 
					
						
							|  |  |  |         [ list-user-edits ] >>entries ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-21 20:45:28 -04:00
										 |  |  | : init-sidebars ( -- )
 | 
					
						
							|  |  |  |     "Contents" latest-revision [ "contents" [ from-object ] nest-form ] when*
 | 
					
						
							| 
									
										
										
										
											2008-07-08 17:15:51 -04:00
										 |  |  |     "Footer" latest-revision [ "footer" [ from-object ] nest-form ] when* ;
 | 
					
						
							| 
									
										
										
										
											2008-06-16 06:16:51 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-22 01:36:07 -04:00
										 |  |  | : init-relative-link-prefix ( -- )
 | 
					
						
							|  |  |  |     URL" $wiki/view/" adjust-url present relative-link-prefix set ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  | : <wiki> ( -- dispatcher )
 | 
					
						
							|  |  |  |     wiki new-dispatcher | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |         <main-article-action> "" add-responder | 
					
						
							|  |  |  |         <view-article-action> "view" add-responder | 
					
						
							|  |  |  |         <view-revision-action> "revision" add-responder | 
					
						
							| 
									
										
										
										
											2008-07-08 17:15:51 -04:00
										 |  |  |         <random-article-action> "random" add-responder | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |         <list-revisions-action> "revisions" add-responder | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  |         <list-revisions-feed-action> "revisions.atom" add-responder | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |         <diff-action> "diff" add-responder | 
					
						
							|  |  |  |         <edit-article-action> "edit" add-responder | 
					
						
							|  |  |  |         <submit-article-action> "submit" add-responder | 
					
						
							| 
									
										
										
										
											2008-06-01 18:22:39 -04:00
										 |  |  |         <rollback-action> "rollback" add-responder | 
					
						
							| 
									
										
										
										
											2008-05-27 03:42:21 -04:00
										 |  |  |         <user-edits-action> "user-edits" add-responder | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |         <list-articles-action> "articles" add-responder | 
					
						
							| 
									
										
										
										
											2008-05-27 03:42:21 -04:00
										 |  |  |         <list-changes-action> "changes" add-responder | 
					
						
							| 
									
										
										
										
											2008-06-05 02:50:59 -04:00
										 |  |  |         <user-edits-feed-action> "user-edits.atom" add-responder | 
					
						
							|  |  |  |         <list-changes-feed-action> "changes.atom" add-responder | 
					
						
							| 
									
										
										
										
											2008-06-13 01:47:47 -04:00
										 |  |  |         <delete-action> "delete" add-responder | 
					
						
							| 
									
										
										
										
											2008-05-27 01:02:16 -04:00
										 |  |  |     <boilerplate> | 
					
						
							| 
									
										
										
										
											2008-09-22 01:36:07 -04:00
										 |  |  |         [ init-sidebars init-relative-link-prefix ] >>init | 
					
						
							| 
									
										
										
										
											2008-06-02 16:00:03 -04:00
										 |  |  |         { wiki "wiki-common" } >>template ;
 | 
					
						
							| 
									
										
										
										
											2008-07-08 17:15:51 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : init-wiki ( -- )
 | 
					
						
							| 
									
										
										
										
											2008-10-19 14:09:48 -04:00
										 |  |  |     "resource:extra/webapps/wiki/initial-content" [ | 
					
						
							|  |  |  |         [ | 
					
						
							|  |  |  |             dup ".txt" ?tail [ | 
					
						
							|  |  |  |                 swap ascii file-contents | 
					
						
							|  |  |  |                 f <revision> | 
					
						
							|  |  |  |                     swap >>content | 
					
						
							|  |  |  |                     swap >>title | 
					
						
							|  |  |  |                     "slava" >>author | 
					
						
							|  |  |  |                     now >>date | 
					
						
							|  |  |  |                 add-revision | 
					
						
							|  |  |  |             ] [ 2drop ] if
 | 
					
						
							|  |  |  |         ] each
 | 
					
						
							|  |  |  |     ] with-directory-files ;
 |