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))))))))..