Artifact
236b7343e451d0a37eaac75914b6f405cef158c7:
0000: 3b 3b 20 43 6f 70 79 72 69 67 68 74 20 32 30 30 ;; Copyright 200
0010: 37 2d 32 30 30 38 2c 20 4d 61 74 74 68 65 77 20 7-2008, Matthew
0020: 57 65 6c 6c 61 6e 64 2e 20 6d 61 74 74 40 6b 69 Welland. matt@ki
0030: 61 74 6f 61 2e 63 6f 6d 20 41 6c 6c 20 72 69 67 atoa.com All rig
0040: 68 74 73 20 72 65 73 65 72 76 65 64 2e 0a 3b 3b hts reserved..;;
0050: 20 0a 3b 3b 20 6d 61 69 6e 74 2f 63 6f 6e 74 72 .;; maint/contr
0060: 6f 6c 2e 73 63 6d 0a 3b 3b 0a 0a 3b 3b 20 65 76 ol.scm.;;..;; ev
0070: 6f 6c 76 65 20 79 6f 75 72 20 73 63 68 65 6d 61 olve your schema
0080: 20 68 65 72 65 21 0a 3b 3b 20 41 64 64 20 65 6e here!.;; Add en
0090: 74 72 69 65 73 20 61 6e 64 20 74 68 65 6e 20 67 tries and then g
00a0: 6f 20 74 6f 20 68 74 74 70 3a 2f 79 6f 75 72 2d o to http:/your-
00b0: 75 72 6c 2f 6d 61 69 6e 74 0a 3b 3b 0a 3b 3b 20 url/maint.;;.;;
00c0: 66 69 72 73 74 20 6d 61 6b 65 20 6d 61 69 6e 74 first make maint
00d0: 3a 64 62 20 61 76 61 69 6c 61 62 6c 65 20 61 73 :db available as
00e0: 20 61 20 67 6c 6f 62 61 6c 0a 3b 3b 0a 28 64 65 a global.;;.(de
00f0: 66 69 6e 65 20 6d 61 69 6e 74 3a 64 62 20 28 73 fine maint:db (s
0100: 6c 6f 74 2d 72 65 66 20 73 3a 73 65 73 73 69 6f lot-ref s:sessio
0110: 6e 20 27 63 6f 6e 6e 29 29 0a 0a 3b 3b 20 79 6f n 'conn))..;; yo
0120: 75 20 63 61 6e 20 73 74 6f 72 65 20 6c 61 6d 62 u can store lamb
0130: 64 61 27 73 20 6f 72 20 53 51 4c 20 71 75 65 72 da's or SQL quer
0140: 69 65 73 20 74 6f 20 62 65 20 65 78 65 63 74 75 ies to be exectu
0150: 74 65 64 0a 3b 3b 20 62 65 20 65 78 74 72 65 6d ted.;; be extrem
0160: 65 6c 79 20 63 61 72 65 66 75 6c 20 2d 20 65 73 ely careful - es
0170: 70 65 63 69 61 6c 6c 79 20 77 69 74 68 20 74 68 pecially with th
0180: 65 20 6c 61 6d 62 64 61 27 73 21 21 21 0a 28 64 e lambda's!!!.(d
0190: 65 66 69 6e 65 20 6d 61 69 6e 74 3a 73 63 68 65 efine maint:sche
01a0: 6d 61 2d 75 70 64 61 74 65 73 0a 20 20 28 6c 69 ma-updates. (li
01b0: 73 74 20 28 6c 69 73 74 20 31 20 28 6c 61 6d 62 st (list 1 (lamb
01c0: 64 61 20 28 29 28 6b 65 79 73 74 6f 72 65 3a 73 da ()(keystore:s
01d0: 65 74 21 20 6d 61 69 6e 74 3a 64 62 20 22 4d 41 et! maint:db "MA
01e0: 49 4e 54 50 57 22 20 22 41 62 63 31 32 33 22 29 INTPW" "Abc123")
01f0: 29 29 0a 09 28 6c 69 73 74 20 32 20 22 43 52 45 ))..(list 2 "CRE
0200: 41 54 45 20 54 41 42 4c 45 20 70 65 6f 70 6c 65 ATE TABLE people
0210: 20 28 69 64 20 49 4e 54 45 47 45 52 20 50 52 49 (id INTEGER PRI
0220: 4d 41 52 59 20 4b 45 59 2c 6e 61 6d 65 20 54 45 MARY KEY,name TE
0230: 58 54 20 44 45 46 41 55 4c 54 20 27 27 2c 6e 69 XT DEFAULT '',ni
0240: 63 6b 20 54 45 58 54 20 44 45 46 41 55 4c 54 20 ck TEXT DEFAULT
0250: 27 27 2c 65 6d 61 69 6c 20 54 45 58 54 2c 70 61 '',email TEXT,pa
0260: 73 73 77 6f 72 64 20 54 45 58 54 2c 73 74 61 74 ssword TEXT,stat
0270: 75 73 20 49 4e 54 45 47 45 52 20 44 45 46 41 55 us INTEGER DEFAU
0280: 4c 54 20 30 2c 73 63 6f 72 65 20 49 4e 54 45 47 LT 0,score INTEG
0290: 45 52 20 44 45 46 41 55 4c 54 20 30 2c 6c 6f 63 ER DEFAULT 0,loc
02a0: 61 74 69 6f 6e 5f 69 64 20 49 4e 54 45 47 45 52 ation_id INTEGER
02b0: 20 44 45 46 41 55 4c 54 20 30 29 3b 22 29 0a 09 DEFAULT 0);")..
02c0: 28 6c 69 73 74 20 33 20 22 43 52 45 41 54 45 20 (list 3 "CREATE
02d0: 54 41 42 4c 45 20 63 61 6e 64 69 64 61 74 65 73 TABLE candidates
02e0: 20 28 69 64 20 49 4e 54 45 47 45 52 20 50 52 49 (id INTEGER PRI
02f0: 4d 41 52 59 20 4b 45 59 2c 6e 61 6d 65 20 54 45 MARY KEY,name TE
0300: 58 54 20 44 45 46 41 55 4c 54 20 27 27 2c 75 72 XT DEFAULT '',ur
0310: 6c 20 54 45 58 54 20 44 45 46 41 55 4c 54 20 27 l TEXT DEFAULT '
0320: 27 2c 70 61 72 74 79 20 54 45 58 54 20 44 45 46 ',party TEXT DEF
0330: 41 55 4c 54 20 27 27 2c 64 65 73 63 20 54 45 58 AULT '',desc TEX
0340: 54 20 44 45 46 41 55 4c 54 20 27 27 2c 73 75 70 T DEFAULT '',sup
0350: 70 6f 72 74 73 5f 61 76 20 49 4e 54 45 47 45 52 ports_av INTEGER
0360: 2c 64 61 74 65 5f 61 64 64 65 64 20 44 41 54 45 ,date_added DATE
0370: 54 49 4d 45 2c 73 63 6f 72 65 20 49 4e 54 45 47 TIME,score INTEG
0380: 45 52 20 44 45 46 41 55 4c 54 20 30 29 3b 22 29 ER DEFAULT 0);")
0390: 0a 09 28 6c 69 73 74 20 34 20 22 43 52 45 41 54 ..(list 4 "CREAT
03a0: 45 20 54 41 42 4c 45 20 76 6f 74 65 73 20 28 69 E TABLE votes (i
03b0: 64 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52 d INTEGER PRIMAR
03c0: 59 20 4b 45 59 2c 63 61 6e 64 69 64 61 74 65 5f Y KEY,candidate_
03d0: 69 64 20 49 4e 54 45 47 45 52 2c 76 6f 74 65 5f id INTEGER,vote_
03e0: 64 61 74 65 20 49 4e 54 45 47 45 52 2c 76 6f 74 date INTEGER,vot
03f0: 65 73 20 49 4e 54 45 47 45 52 2c 73 63 6f 72 65 es INTEGER,score
0400: 20 49 4e 54 45 47 45 52 2c 76 6f 74 65 5f 74 79 INTEGER,vote_ty
0410: 70 65 20 49 4e 54 45 47 45 52 29 3b 22 29 0a 09 pe INTEGER);")..
0420: 28 6c 69 73 74 20 35 20 22 43 52 45 41 54 45 20 (list 5 "CREATE
0430: 54 41 42 4c 45 20 76 6f 74 65 64 20 28 69 64 20 TABLE voted (id
0440: 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59 20 INTEGER PRIMARY
0450: 4b 45 59 2c 75 73 65 72 5f 69 64 20 49 4e 54 45 KEY,user_id INTE
0460: 47 45 52 2c 76 6f 74 65 5f 64 61 74 65 20 49 4e GER,vote_date IN
0470: 54 45 47 45 52 2c 73 63 6f 72 65 20 49 4e 54 45 TEGER,score INTE
0480: 47 45 52 29 3b 22 29 0a 09 3b 3b 20 6c 6f 63 61 GER);")..;; loca
0490: 74 69 6f 6e 5f 74 79 70 65 20 63 61 6e 20 62 65 tion_type can be
04a0: 3a 20 63 69 74 79 2c 20 74 6f 77 6e 2c 20 73 74 : city, town, st
04b0: 61 74 65 2c 20 72 65 67 69 6f 6e 2c 20 63 6f 75 ate, region, cou
04c0: 6e 74 79 20 65 74 63 0a 09 28 6c 69 73 74 20 36 nty etc..(list 6
04d0: 20 22 43 52 45 41 54 45 20 54 41 42 4c 45 20 6c "CREATE TABLE l
04e0: 6f 63 61 74 69 6f 6e 73 20 28 69 64 20 49 4e 54 ocations (id INT
04f0: 45 47 45 52 20 50 52 49 4d 41 52 59 20 4b 45 59 EGER PRIMARY KEY
0500: 2c 70 61 72 65 6e 74 5f 69 64 20 49 4e 54 45 47 ,parent_id INTEG
0510: 45 52 2c 63 6f 64 65 6e 61 6d 65 20 54 45 58 54 ER,codename TEXT
0520: 2c 6e 61 6d 65 20 54 45 58 54 2c 6c 6f 63 61 74 ,name TEXT,locat
0530: 69 6f 6e 5f 74 79 70 65 20 54 45 58 54 2c 64 65 ion_type TEXT,de
0540: 73 63 20 54 45 58 54 2c 75 72 6c 20 54 45 58 54 sc TEXT,url TEXT
0550: 29 3b 22 29 0a 09 28 6c 69 73 74 20 37 20 22 49 );")..(list 7 "I
0560: 4e 53 45 52 54 20 49 4e 54 4f 20 6c 6f 63 61 74 NSERT INTO locat
0570: 69 6f 6e 73 20 56 41 4c 55 45 53 28 30 2c 30 2c ions VALUES(0,0,
0580: 27 65 61 27 2c 27 65 61 72 74 68 27 2c 27 70 6c 'ea','earth','pl
0590: 61 6e 65 74 27 2c 27 48 6f 6d 65 20 50 6c 61 6e anet','Home Plan
05a0: 65 74 20 6f 66 20 48 75 6d 61 6e 73 27 2c 27 27 et of Humans',''
05b0: 29 3b 22 29 0a 09 28 6c 69 73 74 20 38 20 22 41 );")..(list 8 "A
05c0: 4c 54 45 52 20 54 41 42 4c 45 20 63 61 6e 64 69 LTER TABLE candi
05d0: 64 61 74 65 73 20 41 44 44 20 63 6f 6c 75 6d 6e dates ADD column
05e0: 20 70 73 63 6f 72 65 20 49 4e 54 45 47 45 52 20 pscore INTEGER
05f0: 44 45 46 41 55 4c 54 20 30 3b 22 29 0a 09 29 29 DEFAULT 0;")..))
0600: 0a 0a 28 64 65 66 69 6e 65 20 28 6d 61 69 6e 74 ..(define (maint
0610: 3a 61 6d 2d 69 2d 6d 61 69 6e 74 3f 29 0a 20 20 :am-i-maint?).
0620: 3b 3b 20 45 6e 74 65 72 20 61 20 6d 61 69 6e 74 ;; Enter a maint
0630: 20 70 61 73 73 77 6f 72 64 20 2d 20 72 65 74 75 password - retu
0640: 72 6e 20 23 74 20 69 66 20 67 6f 6f 64 0a 20 20 rn #t if good.
0650: 23 74 29 0a 0a 28 64 65 66 69 6e 65 20 28 6d 61 #t)..(define (ma
0660: 69 6e 74 3a 75 70 64 61 74 65 2d 74 61 62 6c 65 int:update-table
0670: 73 29 0a 20 20 28 6c 65 74 2a 20 28 28 64 62 20 s). (let* ((db
0680: 20 20 20 20 20 20 28 73 6c 6f 74 2d 72 65 66 20 (slot-ref
0690: 73 3a 73 65 73 73 69 6f 6e 20 27 63 6f 6e 6e 29 s:session 'conn)
06a0: 29 0a 09 20 28 63 75 72 72 2d 76 65 72 20 28 73 ).. (curr-ver (s
06b0: 3a 61 6e 79 2d 3e 6e 75 6d 62 65 72 20 28 6b 65 :any->number (ke
06c0: 79 73 74 6f 72 65 3a 67 65 74 20 64 62 20 22 53 ystore:get db "S
06d0: 43 48 45 4d 41 2d 56 45 52 53 49 4f 4e 22 29 29 CHEMA-VERSION"))
06e0: 29 29 0a 20 20 20 20 28 69 66 20 28 6e 6f 74 20 )). (if (not
06f0: 63 75 72 72 2d 76 65 72 29 0a 09 28 62 65 67 69 curr-ver)..(begi
0700: 6e 0a 09 20 20 28 6b 65 79 73 74 6f 72 65 3a 73 n.. (keystore:s
0710: 65 74 21 20 28 73 6c 6f 74 2d 72 65 66 20 73 3a et! (slot-ref s:
0720: 73 65 73 73 69 6f 6e 20 27 63 6f 6e 6e 29 20 22 session 'conn) "
0730: 53 43 48 45 4d 41 2d 56 45 52 53 49 4f 4e 22 20 SCHEMA-VERSION"
0740: 30 29 0a 09 20 20 28 73 65 74 21 20 63 75 72 72 0).. (set! curr
0750: 2d 76 65 72 20 30 29 29 29 0a 20 20 20 20 28 69 -ver 0))). (i
0760: 66 20 28 6e 75 6c 6c 3f 20 6d 61 69 6e 74 3a 73 f (null? maint:s
0770: 63 68 65 6d 61 2d 75 70 64 61 74 65 73 29 0a 09 chema-updates)..
0780: 28 6b 65 79 73 74 6f 72 65 3a 73 65 74 21 20 28 (keystore:set! (
0790: 73 6c 6f 74 2d 72 65 66 20 73 3a 73 65 73 73 69 slot-ref s:sessi
07a0: 6f 6e 20 27 63 6f 6e 6e 29 20 22 53 43 48 45 4d on 'conn) "SCHEM
07b0: 41 2d 56 45 52 53 49 4f 4e 22 20 30 29 0a 09 28 A-VERSION" 0)..(
07c0: 6c 65 74 20 6c 6f 6f 70 20 28 28 68 65 64 20 28 let loop ((hed (
07d0: 63 61 72 20 20 6d 61 69 6e 74 3a 73 63 68 65 6d car maint:schem
07e0: 61 2d 75 70 64 61 74 65 73 29 29 0a 09 09 20 20 a-updates))...
07f0: 20 28 74 61 6c 20 28 63 64 72 20 6d 61 69 6e 74 (tal (cdr maint
0800: 3a 73 63 68 65 6d 61 2d 75 70 64 61 74 65 73 29 :schema-updates)
0810: 29 0a 09 09 20 20 20 28 68 69 67 68 65 73 74 2d )... (highest-
0820: 76 65 72 20 30 29 29 0a 09 20 20 28 69 66 20 28 ver 0)).. (if (
0830: 3c 20 28 6c 65 6e 67 74 68 20 68 65 64 29 20 32 < (length hed) 2
0840: 29 0a 09 20 20 20 20 20 20 28 73 3a 6c 6f 67 20 ).. (s:log
0850: 22 4d 61 6c 66 6f 72 6d 65 64 20 6d 61 69 6e 74 "Malformed maint
0860: 3a 73 63 68 65 6d 61 2d 75 70 64 61 74 65 73 20 :schema-updates
0870: 74 61 62 6c 65 20 69 6e 20 6d 61 69 6e 74 2f 63 table in maint/c
0880: 6f 6e 74 72 6f 6c 2e 73 63 6d 22 29 0a 09 20 20 ontrol.scm")..
0890: 20 20 20 20 28 6c 65 74 20 28 28 76 65 72 20 28 (let ((ver (
08a0: 63 61 72 20 68 65 64 29 29 0a 09 09 20 20 20 20 car hed))...
08b0: 28 61 63 74 20 28 63 61 64 72 20 68 65 64 29 29 (act (cadr hed))
08c0: 29 0a 09 09 28 69 66 20 28 3e 20 76 65 72 20 63 )...(if (> ver c
08d0: 75 72 72 2d 76 65 72 29 20 3b 3b 20 6e 65 65 64 urr-ver) ;; need
08e0: 20 74 6f 20 61 70 70 6c 79 20 74 68 69 73 20 6f to apply this o
08f0: 6e 65 0a 09 09 20 20 20 20 28 62 65 67 69 6e 0a ne... (begin.
0900: 09 09 20 20 20 20 20 20 28 69 66 20 28 73 74 72 .. (if (str
0910: 69 6e 67 3f 20 61 63 74 29 0a 09 09 09 20 20 28 ing? act).... (
0920: 64 62 69 3a 65 78 65 63 20 64 62 20 61 63 74 29 dbi:exec db act)
0930: 0a 09 09 09 20 20 28 61 63 74 29 29 0a 09 09 20 .... (act))...
0940: 20 20 20 20 20 3b 3b 20 79 65 73 2c 20 64 6f 20 ;; yes, do
0950: 74 68 69 73 20 66 6f 72 20 65 61 63 68 20 6f 6e this for each on
0960: 65 2c 20 6a 75 73 74 20 69 6e 20 63 61 73 65 20 e, just in case
0970: 6f 66 20 61 20 63 72 61 73 68 0a 09 09 20 20 20 of a crash...
0980: 20 20 20 28 6b 65 79 73 74 6f 72 65 3a 73 65 74 (keystore:set
0990: 21 20 64 62 20 22 53 43 48 45 4d 41 2d 56 45 52 ! db "SCHEMA-VER
09a0: 53 49 4f 4e 22 20 76 65 72 29 29 29 0a 09 09 28 SION" ver)))...(
09b0: 69 66 20 28 6e 75 6c 6c 3f 20 74 61 6c 29 0a 09 if (null? tal)..
09c0: 09 20 20 20 20 68 69 67 68 65 73 74 2d 76 65 72 . highest-ver
09d0: 0a 09 09 20 20 20 20 28 6c 6f 6f 70 20 28 63 61 ... (loop (ca
09e0: 72 20 74 61 6c 29 28 63 64 72 20 74 61 6c 29 20 r tal)(cdr tal)
09f0: 76 65 72 29 29 29 29 29 29 29 29 0a 0a ver))))))))..