| 
									
										
										
										
											2008-04-15 07:35:06 -04:00
										 |  |  | ! Copyright (c) 2008 Slava Pestov | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2015-10-03 19:25:11 -04:00
										 |  |  | USING: accessors kernel sequences namespaces db db.types db.tuples validators | 
					
						
							|  |  |  | hashtables urls html.forms html.components html.templates.chloe http.server | 
					
						
							|  |  |  | http.server.dispatchers furnace furnace.boilerplate furnace.auth | 
					
						
							|  |  |  | furnace.actions furnace.redirection furnace.db furnace.auth.login | 
					
						
							| 
									
										
										
										
											2015-10-03 21:41:32 -04:00
										 |  |  | webapps.utils ;
 | 
					
						
							| 
									
										
										
										
											2008-04-15 08:09:01 -04:00
										 |  |  | IN: webapps.todo | 
					
						
							| 
									
										
										
										
											2008-04-15 07:35:06 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-02 16:00:03 -04:00
										 |  |  | TUPLE: todo-list < dispatcher ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-15 07:35:06 -04:00
										 |  |  | TUPLE: todo uid id priority summary description ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | todo "TODO" | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     { "uid" "UID" { VARCHAR 256 } +not-null+ } | 
					
						
							| 
									
										
										
										
											2008-04-28 18:38:12 -04:00
										 |  |  |     { "id" "ID" +db-assigned-id+ } | 
					
						
							| 
									
										
										
										
											2008-04-15 07:35:06 -04:00
										 |  |  |     { "priority" "PRIORITY" INTEGER +not-null+ } | 
					
						
							|  |  |  |     { "summary" "SUMMARY" { VARCHAR 256 } +not-null+ } | 
					
						
							|  |  |  |     { "description" "DESCRIPTION" { VARCHAR 256 } } | 
					
						
							|  |  |  | } define-persistent | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : <todo> ( id -- todo )
 | 
					
						
							|  |  |  |     todo new
 | 
					
						
							|  |  |  |         swap >>id | 
					
						
							| 
									
										
										
										
											2008-07-09 18:04:20 -04:00
										 |  |  |         username >>uid ;
 | 
					
						
							| 
									
										
										
										
											2008-04-15 07:35:06 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-26 01:47:27 -04:00
										 |  |  | : <view-action> ( -- action )
 | 
					
						
							|  |  |  |     <page-action> | 
					
						
							|  |  |  |         [ | 
					
						
							|  |  |  |             validate-integer-id | 
					
						
							| 
									
										
										
										
											2008-06-01 18:22:39 -04:00
										 |  |  |             "id" value <todo> select-tuple from-object | 
					
						
							| 
									
										
										
										
											2008-05-26 01:47:27 -04:00
										 |  |  |         ] >>init | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-02 16:00:03 -04:00
										 |  |  |         { todo-list "view-todo" } >>template ;
 | 
					
						
							| 
									
										
										
										
											2008-05-26 01:47:27 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : validate-todo ( -- )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         { "summary" [ v-one-line ] } | 
					
						
							|  |  |  |         { "priority" [ v-integer 0 v-min-value 10 v-max-value ] } | 
					
						
							|  |  |  |         { "description" [ v-required ] } | 
					
						
							|  |  |  |     } validate-params ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-06 19:18:05 -04:00
										 |  |  | : view-todo-url ( id -- url )
 | 
					
						
							|  |  |  |     <url> "$todo-list/view" >>path swap "id" set-query-param ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-26 01:47:27 -04:00
										 |  |  | : <new-action> ( -- action )
 | 
					
						
							|  |  |  |     <page-action> | 
					
						
							|  |  |  |         [ 0 "priority" set-value ] >>init | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-02 16:00:03 -04:00
										 |  |  |         { todo-list "new-todo" } >>template | 
					
						
							| 
									
										
										
										
											2008-05-26 01:47:27 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         [ validate-todo ] >>validate | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         [ | 
					
						
							|  |  |  |             f <todo> | 
					
						
							| 
									
										
										
										
											2008-06-15 03:38:12 -04:00
										 |  |  |                 dup { "summary" "priority" "description" } to-object | 
					
						
							| 
									
										
										
										
											2008-06-06 19:18:05 -04:00
										 |  |  |             [ insert-tuple ] [ id>> view-todo-url <redirect> ] bi
 | 
					
						
							| 
									
										
										
										
											2008-05-26 01:47:27 -04:00
										 |  |  |         ] >>submit ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : <edit-action> ( -- action )
 | 
					
						
							|  |  |  |     <page-action> | 
					
						
							|  |  |  |         [ | 
					
						
							|  |  |  |             validate-integer-id | 
					
						
							| 
									
										
										
										
											2008-06-01 18:22:39 -04:00
										 |  |  |             "id" value <todo> select-tuple from-object | 
					
						
							| 
									
										
										
										
											2008-05-26 01:47:27 -04:00
										 |  |  |         ] >>init | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-02 16:00:03 -04:00
										 |  |  |         { todo-list "edit-todo" } >>template | 
					
						
							| 
									
										
										
										
											2008-05-26 01:47:27 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         [ | 
					
						
							|  |  |  |             validate-integer-id | 
					
						
							|  |  |  |             validate-todo | 
					
						
							|  |  |  |         ] >>validate | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         [ | 
					
						
							|  |  |  |             f <todo> | 
					
						
							| 
									
										
										
										
											2008-06-15 03:38:12 -04:00
										 |  |  |                 dup { "id" "summary" "priority" "description" } to-object | 
					
						
							| 
									
										
										
										
											2008-06-06 19:18:05 -04:00
										 |  |  |             [ update-tuple ] [ id>> view-todo-url <redirect> ] bi
 | 
					
						
							| 
									
										
										
										
											2008-05-26 01:47:27 -04:00
										 |  |  |         ] >>submit ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-06 19:18:05 -04:00
										 |  |  | : todo-list-url ( -- url )
 | 
					
						
							|  |  |  |     URL" $todo-list/list" ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-26 01:47:27 -04:00
										 |  |  | : <delete-action> ( -- action )
 | 
					
						
							|  |  |  |     <action> | 
					
						
							|  |  |  |         [ validate-integer-id ] >>validate | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         [ | 
					
						
							|  |  |  |             "id" get <todo> delete-tuples | 
					
						
							| 
									
										
										
										
											2008-06-06 19:18:05 -04:00
										 |  |  |             todo-list-url <redirect> | 
					
						
							| 
									
										
										
										
											2008-05-26 01:47:27 -04:00
										 |  |  |         ] >>submit ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : <list-action> ( -- action )
 | 
					
						
							|  |  |  |     <page-action> | 
					
						
							|  |  |  |         [ f <todo> select-tuples "items" set-value ] >>init | 
					
						
							| 
									
										
										
										
											2008-06-02 16:00:03 -04:00
										 |  |  |         { todo-list "todo-list" } >>template ;
 | 
					
						
							| 
									
										
										
										
											2008-04-15 07:35:06 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-26 01:47:27 -04:00
										 |  |  | : <todo-list> ( -- responder )
 | 
					
						
							|  |  |  |     todo-list new-dispatcher | 
					
						
							| 
									
										
										
										
											2009-02-10 20:05:08 -05:00
										 |  |  |         <list-action>   "list"       add-responder | 
					
						
							|  |  |  |         URL" /list" <redirect-responder> "" add-responder | 
					
						
							| 
									
										
										
										
											2008-05-26 01:47:27 -04:00
										 |  |  |         <view-action>   "view"   add-responder | 
					
						
							|  |  |  |         <new-action>    "new"    add-responder | 
					
						
							|  |  |  |         <edit-action>   "edit"   add-responder | 
					
						
							|  |  |  |         <delete-action> "delete" add-responder | 
					
						
							|  |  |  |     <boilerplate> | 
					
						
							| 
									
										
										
										
											2008-06-02 16:00:03 -04:00
										 |  |  |         { todo-list "todo" } >>template | 
					
						
							| 
									
										
										
										
											2008-06-04 20:54:05 -04:00
										 |  |  |     <protected> | 
					
						
							|  |  |  |         "view your todo list" >>description ;
 | 
					
						
							| 
									
										
										
										
											2009-02-10 20:05:08 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | USING: furnace.auth.features.registration | 
					
						
							|  |  |  | furnace.auth.features.edit-profile | 
					
						
							|  |  |  | furnace.auth.features.deactivate-user | 
					
						
							| 
									
										
										
										
											2015-10-03 21:41:32 -04:00
										 |  |  | furnace.alloy ;
 | 
					
						
							| 
									
										
										
										
											2009-02-10 20:05:08 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : <login-config> ( responder -- responder' )
 | 
					
						
							|  |  |  |     "Todo list" <login-realm> | 
					
						
							|  |  |  |         allow-registration | 
					
						
							|  |  |  |         allow-edit-profile | 
					
						
							|  |  |  |         allow-deactivation ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-03 21:41:32 -04:00
										 |  |  | : todo-db ( -- db )
 | 
					
						
							|  |  |  |     "todo.db" <temp-sqlite-db> ;
 | 
					
						
							| 
									
										
										
										
											2009-02-10 20:05:08 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : init-todo-db ( -- )
 | 
					
						
							|  |  |  |     todo-db [ | 
					
						
							|  |  |  |         init-furnace-tables | 
					
						
							|  |  |  |         todo ensure-table | 
					
						
							|  |  |  |     ] with-db ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : <todo-app> ( -- responder )
 | 
					
						
							|  |  |  |     init-todo-db | 
					
						
							|  |  |  |     <todo-list> | 
					
						
							|  |  |  |         <login-config> | 
					
						
							|  |  |  |         todo-db <alloy> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : run-todo ( -- )
 | 
					
						
							|  |  |  |     <todo-app> main-responder set-global
 | 
					
						
							|  |  |  |     todo-db start-expiring | 
					
						
							| 
									
										
										
										
											2015-10-03 21:41:32 -04:00
										 |  |  |     run-test-httpd ;
 | 
					
						
							| 
									
										
										
										
											2009-02-10 20:05:08 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | MAIN: run-todo |