Hex Artifact Content
Not logged in

Artifact ecaf658269c2bcbd844938ee1418c307e5a025bb:

File src/setup.c part of check-in [5f3ddcc1b8] - Add ticket configuration editing capability. by drh on 2007-11-25 21:11:33.

0000: 2f 2a 0a 2a 2a 20 43 6f 70 79 72 69 67 68 74 20  /*.** Copyright 
0010: 28 63 29 20 32 30 30 37 20 44 2e 20 52 69 63 68  (c) 2007 D. Rich
0020: 61 72 64 20 48 69 70 70 0a 2a 2a 0a 2a 2a 20 54  ard Hipp.**.** T
0030: 68 69 73 20 70 72 6f 67 72 61 6d 20 69 73 20 66  his program is f
0040: 72 65 65 20 73 6f 66 74 77 61 72 65 3b 20 79 6f  ree software; yo
0050: 75 20 63 61 6e 20 72 65 64 69 73 74 72 69 62 75  u can redistribu
0060: 74 65 20 69 74 20 61 6e 64 2f 6f 72 0a 2a 2a 20  te it and/or.** 
0070: 6d 6f 64 69 66 79 20 69 74 20 75 6e 64 65 72 20  modify it under 
0080: 74 68 65 20 74 65 72 6d 73 20 6f 66 20 74 68 65  the terms of the
0090: 20 47 4e 55 20 47 65 6e 65 72 61 6c 20 50 75 62   GNU General Pub
00a0: 6c 69 63 0a 2a 2a 20 4c 69 63 65 6e 73 65 20 61  lic.** License a
00b0: 73 20 70 75 62 6c 69 73 68 65 64 20 62 79 20 74  s published by t
00c0: 68 65 20 46 72 65 65 20 53 6f 66 74 77 61 72 65  he Free Software
00d0: 20 46 6f 75 6e 64 61 74 69 6f 6e 3b 20 65 69 74   Foundation; eit
00e0: 68 65 72 0a 2a 2a 20 76 65 72 73 69 6f 6e 20 32  her.** version 2
00f0: 20 6f 66 20 74 68 65 20 4c 69 63 65 6e 73 65 2c   of the License,
0100: 20 6f 72 20 28 61 74 20 79 6f 75 72 20 6f 70 74   or (at your opt
0110: 69 6f 6e 29 20 61 6e 79 20 6c 61 74 65 72 20 76  ion) any later v
0120: 65 72 73 69 6f 6e 2e 0a 2a 2a 0a 2a 2a 20 54 68  ersion..**.** Th
0130: 69 73 20 70 72 6f 67 72 61 6d 20 69 73 20 64 69  is program is di
0140: 73 74 72 69 62 75 74 65 64 20 69 6e 20 74 68 65  stributed in the
0150: 20 68 6f 70 65 20 74 68 61 74 20 69 74 20 77 69   hope that it wi
0160: 6c 6c 20 62 65 20 75 73 65 66 75 6c 2c 0a 2a 2a  ll be useful,.**
0170: 20 62 75 74 20 57 49 54 48 4f 55 54 20 41 4e 59   but WITHOUT ANY
0180: 20 57 41 52 52 41 4e 54 59 3b 20 77 69 74 68 6f   WARRANTY; witho
0190: 75 74 20 65 76 65 6e 20 74 68 65 20 69 6d 70 6c  ut even the impl
01a0: 69 65 64 20 77 61 72 72 61 6e 74 79 20 6f 66 0a  ied warranty of.
01b0: 2a 2a 20 4d 45 52 43 48 41 4e 54 41 42 49 4c 49  ** MERCHANTABILI
01c0: 54 59 20 6f 72 20 46 49 54 4e 45 53 53 20 46 4f  TY or FITNESS FO
01d0: 52 20 41 20 50 41 52 54 49 43 55 4c 41 52 20 50  R A PARTICULAR P
01e0: 55 52 50 4f 53 45 2e 20 20 53 65 65 20 74 68 65  URPOSE.  See the
01f0: 20 47 4e 55 0a 2a 2a 20 47 65 6e 65 72 61 6c 20   GNU.** General 
0200: 50 75 62 6c 69 63 20 4c 69 63 65 6e 73 65 20 66  Public License f
0210: 6f 72 20 6d 6f 72 65 20 64 65 74 61 69 6c 73 2e  or more details.
0220: 0a 2a 2a 0a 2a 2a 20 59 6f 75 20 73 68 6f 75 6c  .**.** You shoul
0230: 64 20 68 61 76 65 20 72 65 63 65 69 76 65 64 20  d have received 
0240: 61 20 63 6f 70 79 20 6f 66 20 74 68 65 20 47 4e  a copy of the GN
0250: 55 20 47 65 6e 65 72 61 6c 20 50 75 62 6c 69 63  U General Public
0260: 0a 2a 2a 20 4c 69 63 65 6e 73 65 20 61 6c 6f 6e  .** License alon
0270: 67 20 77 69 74 68 20 74 68 69 73 20 6c 69 62 72  g with this libr
0280: 61 72 79 3b 20 69 66 20 6e 6f 74 2c 20 77 72 69  ary; if not, wri
0290: 74 65 20 74 6f 20 74 68 65 0a 2a 2a 20 46 72 65  te to the.** Fre
02a0: 65 20 53 6f 66 74 77 61 72 65 20 46 6f 75 6e 64  e Software Found
02b0: 61 74 69 6f 6e 2c 20 49 6e 63 2e 2c 20 35 39 20  ation, Inc., 59 
02c0: 54 65 6d 70 6c 65 20 50 6c 61 63 65 20 2d 20 53  Temple Place - S
02d0: 75 69 74 65 20 33 33 30 2c 0a 2a 2a 20 42 6f 73  uite 330,.** Bos
02e0: 74 6f 6e 2c 20 4d 41 20 20 30 32 31 31 31 2d 31  ton, MA  02111-1
02f0: 33 30 37 2c 20 55 53 41 2e 0a 2a 2a 0a 2a 2a 20  307, USA..**.** 
0300: 41 75 74 68 6f 72 20 63 6f 6e 74 61 63 74 20 69  Author contact i
0310: 6e 66 6f 72 6d 61 74 69 6f 6e 3a 0a 2a 2a 20 20  nformation:.**  
0320: 20 64 72 68 40 68 77 61 63 69 2e 63 6f 6d 0a 2a   drh@hwaci.com.*
0330: 2a 20 20 20 68 74 74 70 3a 2f 2f 77 77 77 2e 68  *   http://www.h
0340: 77 61 63 69 2e 63 6f 6d 2f 64 72 68 2f 0a 2a 2a  waci.com/drh/.**
0350: 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  .***************
0360: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0370: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0380: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0390: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
03a0: 0a 2a 2a 0a 2a 2a 20 49 6d 70 6c 65 6d 65 6e 74  .**.** Implement
03b0: 61 74 69 6f 6e 20 6f 66 20 74 68 65 20 53 65 74  ation of the Set
03c0: 75 70 20 70 61 67 65 0a 2a 2f 0a 23 69 6e 63 6c  up page.*/.#incl
03d0: 75 64 65 20 3c 61 73 73 65 72 74 2e 68 3e 0a 23  ude <assert.h>.#
03e0: 69 6e 63 6c 75 64 65 20 22 63 6f 6e 66 69 67 2e  include "config.
03f0: 68 22 0a 23 69 6e 63 6c 75 64 65 20 22 73 65 74  h".#include "set
0400: 75 70 2e 68 22 0a 0a 0a 2f 2a 0a 2a 2a 20 4f 75  up.h".../*.** Ou
0410: 74 70 75 74 20 61 20 73 69 6e 67 6c 65 20 65 6e  tput a single en
0420: 74 72 79 20 66 6f 72 20 61 20 6d 65 6e 75 20 67  try for a menu g
0430: 65 6e 65 72 61 74 65 64 20 75 73 69 6e 67 20 61  enerated using a
0440: 6e 20 48 54 4d 4c 20 74 61 62 6c 65 2e 0a 2a 2a  n HTML table..**
0450: 20 49 66 20 7a 4c 69 6e 6b 20 69 73 20 6e 6f 74   If zLink is not
0460: 20 4e 55 4c 4c 20 6f 72 20 61 6e 20 65 6d 70 74   NULL or an empt
0470: 79 20 73 74 72 69 6e 67 2c 20 74 68 65 6e 20 69  y string, then i
0480: 74 20 69 73 20 74 68 65 20 70 61 67 65 20 74 68  t is the page th
0490: 61 74 0a 2a 2a 20 74 68 65 20 6d 65 6e 75 20 65  at.** the menu e
04a0: 6e 74 72 79 20 77 69 6c 6c 20 68 79 70 65 72 6c  ntry will hyperl
04b0: 69 6e 6b 20 74 6f 2e 20 20 49 66 20 7a 4c 69 6e  ink to.  If zLin
04c0: 6b 20 69 73 20 4e 55 4c 4c 20 6f 72 20 22 22 2c  k is NULL or "",
04d0: 20 74 68 65 6e 0a 2a 2a 20 74 68 65 20 6d 65 6e   then.** the men
04e0: 75 20 65 6e 74 72 79 20 68 61 73 20 6e 6f 20 68  u entry has no h
04f0: 79 70 65 72 6c 69 6e 6b 20 2d 20 69 74 20 69 73  yperlink - it is
0500: 20 64 69 73 61 62 6c 65 64 2e 0a 2a 2f 0a 76 6f   disabled..*/.vo
0510: 69 64 20 73 65 74 75 70 5f 6d 65 6e 75 5f 65 6e  id setup_menu_en
0520: 74 72 79 28 0a 20 20 63 6f 6e 73 74 20 63 68 61  try(.  const cha
0530: 72 20 2a 7a 54 69 74 6c 65 2c 0a 20 20 63 6f 6e  r *zTitle,.  con
0540: 73 74 20 63 68 61 72 20 2a 7a 4c 69 6e 6b 2c 0a  st char *zLink,.
0550: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 44    const char *zD
0560: 65 73 63 0a 29 7b 0a 20 20 40 20 3c 74 72 3e 3c  esc.){.  @ <tr><
0570: 74 64 20 76 61 6c 69 67 6e 3d 22 74 6f 70 22 20  td valign="top" 
0580: 61 6c 69 67 6e 3d 22 72 69 67 68 74 22 3e 0a 20  align="right">. 
0590: 20 69 66 28 20 7a 4c 69 6e 6b 20 26 26 20 7a 4c   if( zLink && zL
05a0: 69 6e 6b 5b 30 5d 20 29 7b 0a 20 20 20 20 40 20  ink[0] ){.    @ 
05b0: 3c 61 20 68 72 65 66 3d 22 25 73 28 7a 4c 69 6e  <a href="%s(zLin
05c0: 6b 29 22 3e 25 68 28 7a 54 69 74 6c 65 29 3c 2f  k)">%h(zTitle)</
05d0: 61 3e 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20  a>.  }else{.    
05e0: 40 20 25 68 28 7a 54 69 74 6c 65 29 0a 20 20 7d  @ %h(zTitle).  }
05f0: 0a 20 20 40 20 3c 2f 74 64 3e 3c 74 64 20 76 61  .  @ </td><td va
0600: 6c 69 67 6e 3d 22 74 6f 70 22 3e 25 68 28 7a 44  lign="top">%h(zD
0610: 65 73 63 29 3c 2f 74 64 3e 3c 2f 74 72 3e 0a 7d  esc)</td></tr>.}
0620: 0a 0a 2f 2a 0a 2a 2a 20 57 45 42 50 41 47 45 3a  ../*.** WEBPAGE:
0630: 20 2f 73 65 74 75 70 0a 2a 2f 0a 76 6f 69 64 20   /setup.*/.void 
0640: 73 65 74 75 70 5f 70 61 67 65 28 76 6f 69 64 29  setup_page(void)
0650: 7b 0a 20 20 6c 6f 67 69 6e 5f 63 68 65 63 6b 5f  {.  login_check_
0660: 63 72 65 64 65 6e 74 69 61 6c 73 28 29 3b 0a 20  credentials();. 
0670: 20 69 66 28 20 21 67 2e 6f 6b 53 65 74 75 70 20   if( !g.okSetup 
0680: 29 7b 0a 20 20 20 20 6c 6f 67 69 6e 5f 6e 65 65  ){.    login_nee
0690: 64 65 64 28 29 3b 0a 20 20 7d 0a 0a 20 20 73 74  ded();.  }..  st
06a0: 79 6c 65 5f 68 65 61 64 65 72 28 22 53 65 74 75  yle_header("Setu
06b0: 70 22 29 3b 0a 20 20 40 20 3c 74 61 62 6c 65 20  p");.  @ <table 
06c0: 62 6f 72 64 65 72 3d 22 30 22 20 63 65 6c 6c 73  border="0" cells
06d0: 70 61 63 69 6e 67 3d 22 32 30 22 3e 0a 20 20 73  pacing="20">.  s
06e0: 65 74 75 70 5f 6d 65 6e 75 5f 65 6e 74 72 79 28  etup_menu_entry(
06f0: 22 55 73 65 72 73 22 2c 20 22 73 65 74 75 70 5f  "Users", "setup_
0700: 75 6c 69 73 74 22 2c 0a 20 20 20 20 22 47 72 61  ulist",.    "Gra
0710: 6e 74 20 70 72 69 76 69 6c 65 67 65 73 20 74 6f  nt privileges to
0720: 20 69 6e 64 69 76 69 64 75 61 6c 20 75 73 65 72   individual user
0730: 73 2e 22 29 3b 0a 20 20 73 65 74 75 70 5f 6d 65  s.");.  setup_me
0740: 6e 75 5f 65 6e 74 72 79 28 22 41 63 63 65 73 73  nu_entry("Access
0750: 22 2c 20 22 73 65 74 75 70 5f 61 63 63 65 73 73  ", "setup_access
0760: 22 2c 0a 20 20 20 20 22 43 6f 6e 74 72 6f 6c 20  ",.    "Control 
0770: 61 63 63 65 73 73 20 73 65 74 74 69 6e 67 73 2e  access settings.
0780: 22 29 3b 0a 20 20 73 65 74 75 70 5f 6d 65 6e 75  ");.  setup_menu
0790: 5f 65 6e 74 72 79 28 22 43 6f 6e 66 69 67 75 72  _entry("Configur
07a0: 61 74 69 6f 6e 22 2c 20 22 73 65 74 75 70 5f 63  ation", "setup_c
07b0: 6f 6e 66 69 67 22 2c 0a 20 20 20 20 22 43 6f 6e  onfig",.    "Con
07c0: 66 69 67 75 72 65 20 74 68 65 20 57 57 57 20 63  figure the WWW c
07d0: 6f 6d 70 6f 6e 65 6e 74 73 20 6f 66 20 74 68 65  omponents of the
07e0: 20 72 65 70 6f 73 69 74 6f 72 79 22 29 3b 0a 20   repository");. 
07f0: 20 73 65 74 75 70 5f 6d 65 6e 75 5f 65 6e 74 72   setup_menu_entr
0800: 79 28 22 54 69 63 6b 65 74 73 22 2c 20 22 73 65  y("Tickets", "se
0810: 74 75 70 5f 74 69 63 6b 65 74 22 2c 0a 20 20 20  tup_ticket",.   
0820: 20 22 43 6f 6e 66 69 67 75 72 65 20 74 68 65 20   "Configure the 
0830: 74 72 6f 75 62 6c 65 2d 74 69 63 6b 65 74 69 6e  trouble-ticketin
0840: 67 20 73 79 73 74 65 6d 20 66 6f 72 20 74 68 69  g system for thi
0850: 73 20 72 65 70 6f 73 69 74 6f 72 79 22 29 3b 0a  s repository");.
0860: 20 20 73 65 74 75 70 5f 6d 65 6e 75 5f 65 6e 74    setup_menu_ent
0870: 72 79 28 22 43 53 53 22 2c 20 22 73 65 74 75 70  ry("CSS", "setup
0880: 5f 65 64 69 74 63 73 73 22 2c 0a 20 20 20 20 22  _editcss",.    "
0890: 45 64 69 74 20 74 68 65 20 43 61 73 63 61 64 69  Edit the Cascadi
08a0: 6e 67 20 53 74 79 6c 65 20 53 68 65 65 74 20 75  ng Style Sheet u
08b0: 73 65 64 20 62 79 20 61 6c 6c 20 70 61 67 65 73  sed by all pages
08c0: 20 6f 66 20 74 68 69 73 20 72 65 70 6f 73 69 74   of this reposit
08d0: 6f 72 79 22 29 3b 0a 20 20 73 65 74 75 70 5f 6d  ory");.  setup_m
08e0: 65 6e 75 5f 65 6e 74 72 79 28 22 48 65 61 64 65  enu_entry("Heade
08f0: 72 22 2c 20 22 73 65 74 75 70 5f 68 65 61 64 65  r", "setup_heade
0900: 72 22 2c 0a 20 20 20 20 22 45 64 69 74 20 48 54  r",.    "Edit HT
0910: 4d 4c 20 74 65 78 74 20 69 6e 73 65 72 74 65 64  ML text inserted
0920: 20 61 74 20 74 68 65 20 74 6f 70 20 6f 66 20 65   at the top of e
0930: 76 65 72 79 20 70 61 67 65 22 29 3b 0a 20 20 73  very page");.  s
0940: 65 74 75 70 5f 6d 65 6e 75 5f 65 6e 74 72 79 28  etup_menu_entry(
0950: 22 46 6f 6f 74 65 72 22 2c 20 22 73 65 74 75 70  "Footer", "setup
0960: 5f 66 6f 6f 74 65 72 22 2c 0a 20 20 20 20 22 45  _footer",.    "E
0970: 64 69 74 20 48 54 4d 4c 20 74 65 78 74 20 69 6e  dit HTML text in
0980: 73 65 72 74 65 64 20 61 74 20 74 68 65 20 62 6f  serted at the bo
0990: 74 74 6f 6d 20 6f 66 20 65 76 65 72 79 20 70 61  ttom of every pa
09a0: 67 65 22 29 3b 0a 20 20 40 20 3c 2f 74 61 62 6c  ge");.  @ </tabl
09b0: 65 3e 0a 0a 20 20 73 74 79 6c 65 5f 66 6f 6f 74  e>..  style_foot
09c0: 65 72 28 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 57  er();.}../*.** W
09d0: 45 42 50 41 47 45 3a 20 73 65 74 75 70 5f 75 6c  EBPAGE: setup_ul
09e0: 69 73 74 0a 2a 2a 0a 2a 2a 20 53 68 6f 77 20 61  ist.**.** Show a
09f0: 20 6c 69 73 74 20 6f 66 20 75 73 65 72 73 2e 20   list of users. 
0a00: 20 43 6c 69 63 6b 69 6e 67 20 6f 6e 20 61 6e 79   Clicking on any
0a10: 20 75 73 65 72 20 6a 75 6d 70 73 20 74 6f 20 74   user jumps to t
0a20: 68 65 20 65 64 69 74 0a 2a 2a 20 73 63 72 65 65  he edit.** scree
0a30: 6e 20 66 6f 72 20 74 68 61 74 20 75 73 65 72 2e  n for that user.
0a40: 0a 2a 2f 0a 76 6f 69 64 20 73 65 74 75 70 5f 75  .*/.void setup_u
0a50: 6c 69 73 74 28 76 6f 69 64 29 7b 0a 20 20 53 74  list(void){.  St
0a60: 6d 74 20 73 3b 0a 0a 20 20 6c 6f 67 69 6e 5f 63  mt s;..  login_c
0a70: 68 65 63 6b 5f 63 72 65 64 65 6e 74 69 61 6c 73  heck_credentials
0a80: 28 29 3b 0a 20 20 69 66 28 20 21 67 2e 6f 6b 53  ();.  if( !g.okS
0a90: 65 74 75 70 20 29 7b 0a 20 20 20 20 6c 6f 67 69  etup ){.    logi
0aa0: 6e 5f 6e 65 65 64 65 64 28 29 3b 0a 20 20 20 20  n_needed();.    
0ab0: 72 65 74 75 72 6e 3b 0a 20 20 7d 0a 0a 20 20 73  return;.  }..  s
0ac0: 74 79 6c 65 5f 73 75 62 6d 65 6e 75 5f 65 6c 65  tyle_submenu_ele
0ad0: 6d 65 6e 74 28 22 41 64 64 22 2c 20 22 41 64 64  ment("Add", "Add
0ae0: 20 55 73 65 72 22 2c 20 22 73 65 74 75 70 5f 75   User", "setup_u
0af0: 65 64 69 74 22 29 3b 0a 20 20 73 74 79 6c 65 5f  edit");.  style_
0b00: 68 65 61 64 65 72 28 22 55 73 65 72 20 4c 69 73  header("User Lis
0b10: 74 22 29 3b 0a 20 20 40 20 3c 74 61 62 6c 65 20  t");.  @ <table 
0b20: 62 6f 72 64 65 72 3d 22 30 22 20 63 65 6c 6c 70  border="0" cellp
0b30: 61 64 64 69 6e 67 3d 22 30 22 20 63 65 6c 6c 73  adding="0" cells
0b40: 70 61 63 69 6e 67 3d 22 32 35 22 3e 0a 20 20 40  pacing="25">.  @
0b50: 20 3c 74 72 3e 3c 74 64 20 76 61 6c 69 67 6e 3d   <tr><td valign=
0b60: 22 74 6f 70 22 3e 0a 20 20 40 20 3c 62 3e 55 73  "top">.  @ <b>Us
0b70: 65 72 73 3a 3c 2f 62 3e 0a 20 20 40 20 3c 74 61  ers:</b>.  @ <ta
0b80: 62 6c 65 20 62 6f 72 64 65 72 3d 22 31 22 20 63  ble border="1" c
0b90: 65 6c 6c 70 61 64 64 69 6e 67 3d 22 31 30 22 3e  ellpadding="10">
0ba0: 3c 74 72 3e 3c 74 64 3e 0a 20 20 40 20 3c 74 61  <tr><td>.  @ <ta
0bb0: 62 6c 65 20 63 65 6c 6c 73 70 61 63 69 6e 67 3d  ble cellspacing=
0bc0: 30 20 63 65 6c 6c 70 61 64 64 69 6e 67 3d 30 20  0 cellpadding=0 
0bd0: 62 6f 72 64 65 72 3d 30 3e 0a 20 20 40 20 3c 74  border=0>.  @ <t
0be0: 72 3e 0a 20 20 40 20 20 20 3c 74 68 20 61 6c 69  r>.  @   <th ali
0bf0: 67 6e 3d 22 72 69 67 68 74 22 3e 55 73 65 72 26  gn="right">User&
0c00: 6e 62 73 70 3b 49 44 3c 2f 74 68 3e 3c 74 68 20  nbsp;ID</th><th 
0c10: 77 69 64 74 68 3d 22 31 35 22 3e 3c 2f 74 64 3e  width="15"></td>
0c20: 0a 20 20 40 20 20 20 3c 74 68 3e 43 61 70 61 62  .  @   <th>Capab
0c30: 69 6c 69 74 69 65 73 3c 2f 74 68 3e 3c 74 68 20  ilities</th><th 
0c40: 77 69 64 74 68 3d 22 31 35 22 3e 3c 2f 74 64 3e  width="15"></td>
0c50: 0a 20 20 40 20 20 20 3c 74 68 3e 43 6f 6e 74 61  .  @   <th>Conta
0c60: 63 74 26 6e 62 73 70 3b 49 6e 66 6f 3c 2f 74 68  ct&nbsp;Info</th
0c70: 3e 0a 20 20 40 20 3c 2f 74 72 3e 0a 20 20 64 62  >.  @ </tr>.  db
0c80: 5f 70 72 65 70 61 72 65 28 26 73 2c 20 22 53 45  _prepare(&s, "SE
0c90: 4c 45 43 54 20 75 69 64 2c 20 6c 6f 67 69 6e 2c  LECT uid, login,
0ca0: 20 63 61 70 2c 20 69 6e 66 6f 20 46 52 4f 4d 20   cap, info FROM 
0cb0: 75 73 65 72 20 4f 52 44 45 52 20 42 59 20 6c 6f  user ORDER BY lo
0cc0: 67 69 6e 22 29 3b 0a 20 20 77 68 69 6c 65 28 20  gin");.  while( 
0cd0: 64 62 5f 73 74 65 70 28 26 73 29 3d 3d 53 51 4c  db_step(&s)==SQL
0ce0: 49 54 45 5f 52 4f 57 20 29 7b 0a 20 20 20 20 40  ITE_ROW ){.    @
0cf0: 20 3c 74 72 3e 0a 20 20 20 20 40 20 3c 74 64 20   <tr>.    @ <td 
0d00: 61 6c 69 67 6e 3d 22 72 69 67 68 74 22 3e 0a 20  align="right">. 
0d10: 20 20 20 69 66 28 20 67 2e 6f 6b 41 64 6d 69 6e     if( g.okAdmin
0d20: 20 29 7b 0a 20 20 20 20 20 20 40 20 3c 61 20 68   ){.      @ <a h
0d30: 72 65 66 3d 22 73 65 74 75 70 5f 75 65 64 69 74  ref="setup_uedit
0d40: 3f 69 64 3d 25 64 28 64 62 5f 63 6f 6c 75 6d 6e  ?id=%d(db_column
0d50: 5f 69 6e 74 28 26 73 2c 30 29 29 22 3e 0a 20 20  _int(&s,0))">.  
0d60: 20 20 7d 0a 20 20 20 20 40 20 3c 6e 6f 62 72 3e    }.    @ <nobr>
0d70: 25 68 28 64 62 5f 63 6f 6c 75 6d 6e 5f 74 65 78  %h(db_column_tex
0d80: 74 28 26 73 2c 31 29 29 3c 2f 6e 6f 62 72 3e 0a  t(&s,1))</nobr>.
0d90: 20 20 20 20 69 66 28 20 67 2e 6f 6b 41 64 6d 69      if( g.okAdmi
0da0: 6e 20 29 7b 0a 20 20 20 20 20 20 40 20 3c 2f 61  n ){.      @ </a
0db0: 3e 0a 20 20 20 20 7d 0a 20 20 20 20 40 20 3c 2f  >.    }.    @ </
0dc0: 74 64 3e 3c 74 64 3e 3c 2f 74 64 3e 0a 20 20 20  td><td></td>.   
0dd0: 20 40 20 3c 74 64 20 61 6c 69 67 6e 3d 22 63 65   @ <td align="ce
0de0: 6e 74 65 72 22 3e 25 73 28 64 62 5f 63 6f 6c 75  nter">%s(db_colu
0df0: 6d 6e 5f 74 65 78 74 28 26 73 2c 32 29 29 3c 2f  mn_text(&s,2))</
0e00: 74 64 3e 3c 74 64 3e 3c 2f 74 64 3e 0a 20 20 20  td><td></td>.   
0e10: 20 40 20 3c 74 64 20 61 6c 69 67 6e 3d 22 6c 65   @ <td align="le
0e20: 66 74 22 3e 25 73 28 64 62 5f 63 6f 6c 75 6d 6e  ft">%s(db_column
0e30: 5f 74 65 78 74 28 26 73 2c 33 29 29 3c 2f 74 64  _text(&s,3))</td
0e40: 3e 0a 20 20 20 20 40 20 3c 2f 74 72 3e 0a 20 20  >.    @ </tr>.  
0e50: 7d 0a 20 20 40 20 3c 2f 74 61 62 6c 65 3e 3c 2f  }.  @ </table></
0e60: 74 64 3e 3c 2f 74 72 3e 3c 2f 74 61 62 6c 65 3e  td></tr></table>
0e70: 0a 20 20 40 20 3c 74 64 20 76 61 6c 69 67 6e 3d  .  @ <td valign=
0e80: 22 74 6f 70 22 3e 0a 20 20 40 20 3c 62 3e 4e 6f  "top">.  @ <b>No
0e90: 74 65 73 3a 3c 2f 62 3e 0a 20 20 40 20 3c 6f 6c  tes:</b>.  @ <ol
0ea0: 3e 0a 20 20 40 20 3c 6c 69 3e 3c 70 3e 54 68 65  >.  @ <li><p>The
0eb0: 20 70 65 72 6d 69 73 73 69 6f 6e 20 66 6c 61 67   permission flag
0ec0: 73 20 61 72 65 20 61 73 20 66 6f 6c 6c 6f 77 73  s are as follows
0ed0: 3a 3c 2f 70 3e 0a 20 20 40 20 3c 6f 6c 20 74 79  :</p>.  @ <ol ty
0ee0: 70 65 3d 22 61 22 3e 0a 20 20 40 20 3c 6c 69 20  pe="a">.  @ <li 
0ef0: 76 61 6c 75 65 3d 22 31 22 3e 3c 62 3e 41 64 6d  value="1"><b>Adm
0f00: 69 6e 3c 2f 62 3e 3a 20 43 72 65 61 74 65 20 61  in</b>: Create a
0f10: 6e 64 20 64 65 6c 65 74 65 20 75 73 65 72 73 3c  nd delete users<
0f20: 2f 6c 69 3e 0a 20 20 40 20 3c 6c 69 20 76 61 6c  /li>.  @ <li val
0f30: 75 65 3d 22 33 22 3e 3c 62 3e 41 70 70 65 6e 64  ue="3"><b>Append
0f40: 2d 54 6b 74 3c 2f 62 3e 3a 20 41 70 70 65 6e 64  -Tkt</b>: Append
0f50: 20 74 6f 20 74 69 63 6b 65 74 73 3c 2f 6c 69 3e   to tickets</li>
0f60: 0a 20 20 40 20 3c 6c 69 20 76 61 6c 75 65 3d 22  .  @ <li value="
0f70: 34 22 3e 3c 62 3e 44 65 6c 65 74 65 3c 2f 62 3e  4"><b>Delete</b>
0f80: 3a 20 44 65 6c 65 74 65 20 77 69 6b 69 20 61 6e  : Delete wiki an
0f90: 64 20 74 69 63 6b 65 74 73 3c 2f 6c 69 3e 0a 20  d tickets</li>. 
0fa0: 20 40 20 3c 6c 69 20 76 61 6c 75 65 3d 22 35 22   @ <li value="5"
0fb0: 3e 3c 62 3e 45 6d 61 69 6c 3c 2f 62 3e 3a 20 56  ><b>Email</b>: V
0fc0: 69 65 77 20 45 4d 61 69 6c 20 61 64 64 72 65 73  iew EMail addres
0fd0: 73 65 73 20 6f 6e 20 74 69 63 6b 65 74 73 3c 2f  ses on tickets</
0fe0: 6c 69 3e 0a 20 20 40 20 3c 6c 69 20 76 61 6c 75  li>.  @ <li valu
0ff0: 65 3d 22 36 22 3e 3c 62 3e 4e 65 77 2d 57 69 6b  e="6"><b>New-Wik
1000: 69 3c 2f 62 3e 3a 20 43 72 65 61 74 65 20 6e 65  i</b>: Create ne
1010: 77 20 77 69 6b 69 20 70 61 67 65 73 3c 2f 6c 69  w wiki pages</li
1020: 3e 0a 20 20 40 20 3c 6c 69 20 76 61 6c 75 65 3d  >.  @ <li value=
1030: 22 37 22 3e 3c 62 3e 43 6c 6f 6e 65 3c 2f 62 3e  "7"><b>Clone</b>
1040: 3a 20 43 6c 6f 6e 65 20 74 68 65 20 72 65 70 6f  : Clone the repo
1050: 73 69 74 6f 72 79 3c 2f 6c 69 3e 0a 20 20 40 20  sitory</li>.  @ 
1060: 3c 6c 69 20 76 61 6c 75 65 3d 22 38 22 3e 3c 62  <li value="8"><b
1070: 3e 48 69 73 74 6f 72 79 3c 2f 62 3e 3a 20 56 69  >History</b>: Vi
1080: 65 77 20 64 65 74 61 69 6c 20 72 65 70 6f 73 69  ew detail reposi
1090: 74 6f 72 79 20 68 69 73 74 6f 72 79 3c 2f 6c 69  tory history</li
10a0: 3e 0a 20 20 40 20 3c 6c 69 20 76 61 6c 75 65 3d  >.  @ <li value=
10b0: 22 39 22 3e 3c 62 3e 43 68 65 63 6b 2d 49 6e 3c  "9"><b>Check-In<
10c0: 2f 62 3e 3a 20 43 6f 6d 6d 69 74 20 6e 65 77 20  /b>: Commit new 
10d0: 76 65 72 73 69 6f 6e 73 20 69 6e 20 74 68 65 20  versions in the 
10e0: 72 65 70 6f 73 69 74 6f 72 79 3c 2f 6c 69 3e 0a  repository</li>.
10f0: 20 20 40 20 3c 6c 69 20 76 61 6c 75 65 3d 22 31    @ <li value="1
1100: 30 22 3e 3c 62 3e 52 65 61 64 2d 57 69 6b 69 3c  0"><b>Read-Wiki<
1110: 2f 62 3e 3a 20 56 69 65 77 20 77 69 6b 69 20 70  /b>: View wiki p
1120: 61 67 65 73 3c 2f 6c 69 3e 0a 20 20 40 20 3c 6c  ages</li>.  @ <l
1130: 69 20 76 61 6c 75 65 3d 22 31 31 22 3e 3c 62 3e  i value="11"><b>
1140: 57 72 69 74 65 2d 57 69 6b 69 3c 2f 62 3e 3a 20  Write-Wiki</b>: 
1150: 45 64 69 74 20 77 69 6b 69 20 70 61 67 65 73 3c  Edit wiki pages<
1160: 2f 6c 69 3e 0a 20 20 40 20 3c 6c 69 20 76 61 6c  /li>.  @ <li val
1170: 75 65 3d 22 31 33 22 3e 3c 62 3e 41 70 70 65 6e  ue="13"><b>Appen
1180: 64 2d 57 69 6b 69 3c 2f 62 3e 3a 20 41 70 70 65  d-Wiki</b>: Appe
1190: 6e 64 20 74 6f 20 77 69 6b 69 20 70 61 67 65 73  nd to wiki pages
11a0: 3c 2f 6c 69 3e 0a 20 20 40 20 3c 6c 69 20 76 61  </li>.  @ <li va
11b0: 6c 75 65 3d 22 31 34 22 3e 3c 62 3e 4e 65 77 2d  lue="14"><b>New-
11c0: 54 6b 74 3c 2f 62 3e 3a 20 43 72 65 61 74 65 20  Tkt</b>: Create 
11d0: 6e 65 77 20 74 69 63 6b 65 74 73 3c 2f 6c 69 3e  new tickets</li>
11e0: 0a 20 20 40 20 3c 6c 69 20 76 61 6c 75 65 3d 22  .  @ <li value="
11f0: 31 35 22 3e 3c 62 3e 43 68 65 63 6b 2d 4f 75 74  15"><b>Check-Out
1200: 3c 2f 62 3e 3a 20 43 68 65 63 6b 20 6f 75 74 20  </b>: Check out 
1210: 76 65 72 73 69 6f 6e 73 3c 2f 6c 69 3e 0a 20 20  versions</li>.  
1220: 40 20 3c 6c 69 20 76 61 6c 75 65 3d 22 31 36 22  @ <li value="16"
1230: 3e 3c 62 3e 50 61 73 73 77 6f 72 64 3c 2f 62 3e  ><b>Password</b>
1240: 3a 20 43 68 61 6e 67 65 20 79 6f 75 72 20 6f 77  : Change your ow
1250: 6e 20 70 61 73 73 77 6f 72 64 3c 2f 6c 69 3e 0a  n password</li>.
1260: 20 20 40 20 3c 6c 69 20 76 61 6c 75 65 3d 22 31    @ <li value="1
1270: 37 22 3e 3c 62 3e 51 75 65 72 79 3c 2f 62 3e 3a  7"><b>Query</b>:
1280: 20 43 72 65 61 74 65 20 6e 65 77 20 71 75 65 72   Create new quer
1290: 69 65 73 20 61 67 61 69 6e 73 74 20 74 69 63 6b  ies against tick
12a0: 65 74 73 3c 2f 6c 69 3e 0a 20 20 40 20 3c 6c 69  ets</li>.  @ <li
12b0: 20 76 61 6c 75 65 3d 22 31 38 22 3e 3c 62 3e 52   value="18"><b>R
12c0: 65 61 64 2d 54 6b 74 3c 2f 62 3e 3a 20 56 69 65  ead-Tkt</b>: Vie
12d0: 77 20 74 69 63 6b 65 74 73 3c 2f 6c 69 3e 0a 20  w tickets</li>. 
12e0: 20 40 20 3c 6c 69 20 76 61 6c 75 65 3d 22 31 39   @ <li value="19
12f0: 22 3e 3c 62 3e 53 65 74 75 70 3a 3c 2f 62 3e 20  "><b>Setup:</b> 
1300: 53 65 74 75 70 20 61 6e 64 20 63 6f 6e 66 69 67  Setup and config
1310: 75 72 65 20 74 68 69 73 20 77 65 62 73 69 74 65  ure this website
1320: 3c 2f 6c 69 3e 0a 20 20 40 20 3c 6c 69 20 76 61  </li>.  @ <li va
1330: 6c 75 65 3d 22 32 33 22 3e 3c 62 3e 57 72 69 74  lue="23"><b>Writ
1340: 65 2d 54 6b 74 3c 2f 62 3e 3a 20 45 64 69 74 20  e-Tkt</b>: Edit 
1350: 74 69 63 6b 65 74 73 3c 2f 6c 69 3e 0a 20 20 40  tickets</li>.  @
1360: 20 3c 2f 6f 6c 3e 0a 20 20 40 20 3c 2f 70 3e 3c   </ol>.  @ </p><
1370: 2f 6c 69 3e 0a 20 20 40 0a 20 20 40 20 3c 6c 69  /li>.  @.  @ <li
1380: 3e 3c 70 3e 0a 20 20 40 20 45 76 65 72 79 20 75  ><p>.  @ Every u
1390: 73 65 72 2c 20 6c 6f 67 67 65 64 20 69 6e 20 6f  ser, logged in o
13a0: 72 20 6e 6f 74 2c 20 68 61 73 20 74 68 65 20 70  r not, has the p
13b0: 72 69 76 69 6c 65 67 65 73 20 6f 66 20 3c 62 3e  rivileges of <b>
13c0: 6e 6f 62 6f 64 79 3c 2f 62 3e 2e 0a 20 20 40 20  nobody</b>..  @ 
13d0: 41 6e 79 20 68 75 6d 61 6e 20 63 61 6e 20 6c 6f  Any human can lo
13e0: 67 69 6e 20 61 73 20 3c 62 3e 61 6e 6f 6e 79 6d  gin as <b>anonym
13f0: 6f 75 73 3c 2f 62 3e 20 73 69 6e 63 65 20 74 68  ous</b> since th
1400: 65 20 70 61 73 73 77 6f 72 64 20 69 73 0a 20 20  e password is.  
1410: 40 20 63 6c 65 61 72 6c 79 20 64 69 73 70 6c 61  @ clearly displa
1420: 79 65 64 20 6f 6e 20 74 68 65 20 6c 6f 67 69 6e  yed on the login
1430: 20 70 61 67 65 20 66 6f 72 20 74 68 65 6d 20 74   page for them t
1440: 6f 20 74 79 70 65 2e 20 20 54 68 65 20 70 75 72  o type.  The pur
1450: 70 6f 73 65 0a 20 20 40 20 6f 66 20 72 65 71 75  pose.  @ of requ
1460: 69 72 69 6e 67 20 61 6e 6f 6e 79 6d 6f 75 73 20  iring anonymous 
1470: 74 6f 20 6c 6f 67 20 69 6e 20 69 73 20 74 6f 20  to log in is to 
1480: 70 72 65 76 65 6e 74 20 61 63 63 65 73 73 20 62  prevent access b
1490: 79 20 73 70 69 64 65 72 73 2e 0a 20 20 40 20 3c  y spiders..  @ <
14a0: 2f 70 3e 3c 2f 6c 69 3e 0a 20 20 40 0a 20 20 40  /p></li>.  @.  @
14b0: 20 3c 2f 6f 6c 3e 0a 20 20 40 20 3c 2f 74 64 3e   </ol>.  @ </td>
14c0: 3c 2f 74 72 3e 3c 2f 74 61 62 6c 65 3e 0a 20 20  </tr></table>.  
14d0: 73 74 79 6c 65 5f 66 6f 6f 74 65 72 28 29 3b 0a  style_footer();.
14e0: 7d 0a 0a 2f 2a 0a 2a 2a 20 57 45 42 50 41 47 45  }../*.** WEBPAGE
14f0: 3a 20 2f 73 65 74 75 70 5f 75 65 64 69 74 0a 2a  : /setup_uedit.*
1500: 2f 0a 76 6f 69 64 20 75 73 65 72 5f 65 64 69 74  /.void user_edit
1510: 28 76 6f 69 64 29 7b 0a 20 20 63 6f 6e 73 74 20  (void){.  const 
1520: 63 68 61 72 20 2a 7a 49 64 2c 20 2a 7a 4c 6f 67  char *zId, *zLog
1530: 69 6e 2c 20 2a 7a 49 6e 66 6f 2c 20 2a 7a 43 61  in, *zInfo, *zCa
1540: 70 3b 0a 20 20 63 68 61 72 20 2a 6f 61 61 2c 20  p;.  char *oaa, 
1550: 2a 6f 61 73 2c 20 2a 6f 61 72 2c 20 2a 6f 61 77  *oas, *oar, *oaw
1560: 2c 20 2a 6f 61 6e 2c 20 2a 6f 61 69 2c 20 2a 6f  , *oan, *oai, *o
1570: 61 6a 2c 20 2a 6f 61 6f 2c 20 2a 6f 61 70 3b 0a  aj, *oao, *oap;.
1580: 20 20 63 68 61 72 20 2a 6f 61 6b 2c 20 2a 6f 61    char *oak, *oa
1590: 64 2c 20 2a 6f 61 71 2c 20 2a 6f 61 63 2c 20 2a  d, *oaq, *oac, *
15a0: 6f 61 66 2c 20 2a 6f 61 6d 2c 20 2a 6f 61 68 2c  oaf, *oam, *oah,
15b0: 20 2a 6f 61 67 2c 20 2a 6f 61 65 3b 0a 20 20 69   *oag, *oae;.  i
15c0: 6e 74 20 64 6f 57 72 69 74 65 3b 0a 20 20 69 6e  nt doWrite;.  in
15d0: 74 20 75 69 64 3b 0a 20 20 69 6e 74 20 68 69 67  t uid;.  int hig
15e0: 68 65 72 55 73 65 72 20 3d 20 30 3b 20 20 2f 2a  herUser = 0;  /*
15f0: 20 54 72 75 65 20 69 66 20 75 73 65 72 20 62 65   True if user be
1600: 69 6e 67 20 65 64 69 74 65 64 20 69 73 20 53 45  ing edited is SE
1610: 54 55 50 20 61 6e 64 20 74 68 65 20 2a 2f 0a 20  TUP and the */. 
1620: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1630: 20 20 20 20 20 20 2f 2a 20 75 73 65 72 20 64 6f        /* user do
1640: 69 6e 67 20 74 68 65 20 65 64 69 74 69 6e 67 20  ing the editing 
1650: 69 73 20 41 44 4d 49 4e 2e 20 20 44 69 73 61 6c  is ADMIN.  Disal
1660: 6c 6f 77 20 65 64 69 74 69 6e 67 20 2a 2f 0a 0a  low editing */..
1670: 20 20 2f 2a 20 4d 75 73 74 20 68 61 76 65 20 41    /* Must have A
1680: 44 4d 49 4e 20 70 72 69 76 6c 65 67 65 73 20 74  DMIN privleges t
1690: 6f 20 61 63 63 65 73 73 20 74 68 69 73 20 70 61  o access this pa
16a0: 67 65 0a 20 20 2a 2f 0a 20 20 6c 6f 67 69 6e 5f  ge.  */.  login_
16b0: 63 68 65 63 6b 5f 63 72 65 64 65 6e 74 69 61 6c  check_credential
16c0: 73 28 29 3b 0a 20 20 69 66 28 20 21 67 2e 6f 6b  s();.  if( !g.ok
16d0: 41 64 6d 69 6e 20 29 7b 20 6c 6f 67 69 6e 5f 6e  Admin ){ login_n
16e0: 65 65 64 65 64 28 29 3b 20 72 65 74 75 72 6e 3b  eeded(); return;
16f0: 20 7d 0a 0a 20 20 2f 2a 20 43 68 65 63 6b 20 74   }..  /* Check t
1700: 6f 20 73 65 65 20 69 66 20 61 6e 20 41 44 4d 49  o see if an ADMI
1710: 4e 20 75 73 65 72 20 69 73 20 74 72 79 69 6e 67  N user is trying
1720: 20 74 6f 20 65 64 69 74 20 61 20 53 45 54 55 50   to edit a SETUP
1730: 20 61 63 63 6f 75 6e 74 2e 0a 20 20 2a 2a 20 44   account..  ** D
1740: 6f 6e 27 74 20 61 6c 6c 6f 77 20 74 68 61 74 2e  on't allow that.
1750: 0a 20 20 2a 2f 0a 20 20 7a 49 64 20 3d 20 50 44  .  */.  zId = PD
1760: 28 22 69 64 22 2c 20 22 30 22 29 3b 0a 20 20 75  ("id", "0");.  u
1770: 69 64 20 3d 20 61 74 6f 69 28 7a 49 64 29 3b 0a  id = atoi(zId);.
1780: 20 20 69 66 28 20 7a 49 64 20 26 26 20 21 67 2e    if( zId && !g.
1790: 6f 6b 53 65 74 75 70 20 26 26 20 75 69 64 3e 30  okSetup && uid>0
17a0: 20 29 7b 0a 20 20 20 20 63 68 61 72 20 2a 7a 4f   ){.    char *zO
17b0: 6c 64 43 61 70 73 3b 0a 20 20 20 20 7a 4f 6c 64  ldCaps;.    zOld
17c0: 43 61 70 73 20 3d 20 64 62 5f 74 65 78 74 28 30  Caps = db_text(0
17d0: 2c 20 22 53 45 4c 45 43 54 20 63 61 70 73 20 46  , "SELECT caps F
17e0: 52 4f 4d 20 75 73 65 72 20 57 48 45 52 45 20 75  ROM user WHERE u
17f0: 69 64 3d 25 64 22 2c 75 69 64 29 3b 0a 20 20 20  id=%d",uid);.   
1800: 20 68 69 67 68 65 72 55 73 65 72 20 3d 20 7a 4f   higherUser = zO
1810: 6c 64 43 61 70 73 20 26 26 20 73 74 72 63 68 72  ldCaps && strchr
1820: 28 7a 4f 6c 64 43 61 70 73 2c 27 73 27 29 3b 0a  (zOldCaps,'s');.
1830: 20 20 7d 0a 0a 20 20 69 66 28 20 50 28 22 63 61    }..  if( P("ca
1840: 6e 22 29 20 29 7b 0a 20 20 20 20 63 67 69 5f 72  n") ){.    cgi_r
1850: 65 64 69 72 65 63 74 28 22 73 65 74 75 70 5f 75  edirect("setup_u
1860: 6c 69 73 74 22 29 3b 0a 20 20 20 20 72 65 74 75  list");.    retu
1870: 72 6e 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 49 66  rn;.  }..  /* If
1880: 20 77 65 20 68 61 76 65 20 61 6c 6c 20 74 68 65   we have all the
1890: 20 6e 65 63 65 73 73 61 72 79 20 69 6e 66 6f 72   necessary infor
18a0: 6d 61 74 69 6f 6e 2c 20 77 72 69 74 65 20 74 68  mation, write th
18b0: 65 20 6e 65 77 20 6f 72 0a 20 20 2a 2a 20 6d 6f  e new or.  ** mo
18c0: 64 69 66 69 65 64 20 75 73 65 72 20 72 65 63 6f  dified user reco
18d0: 72 64 2e 20 20 41 66 74 65 72 20 77 72 69 74 69  rd.  After writi
18e0: 6e 67 20 74 68 65 20 75 73 65 72 20 72 65 63 6f  ng the user reco
18f0: 72 64 2c 20 72 65 64 69 72 65 63 74 0a 20 20 2a  rd, redirect.  *
1900: 2a 20 74 6f 20 74 68 65 20 70 61 67 65 20 74 68  * to the page th
1910: 61 74 20 64 69 73 70 6c 61 79 73 20 61 20 6c 69  at displays a li
1920: 73 74 20 6f 66 20 75 73 65 72 73 2e 0a 20 20 2a  st of users..  *
1930: 2f 0a 20 20 64 6f 57 72 69 74 65 20 3d 20 63 67  /.  doWrite = cg
1940: 69 5f 61 6c 6c 28 22 6c 6f 67 69 6e 22 2c 22 69  i_all("login","i
1950: 6e 66 6f 22 2c 22 70 77 22 29 20 26 26 20 21 68  nfo","pw") && !h
1960: 69 67 68 65 72 55 73 65 72 3b 0a 20 20 69 66 28  igherUser;.  if(
1970: 20 64 6f 57 72 69 74 65 20 29 7b 0a 20 20 20 20   doWrite ){.    
1980: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 50 77 3b  const char *zPw;
1990: 0a 20 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20  .    const char 
19a0: 2a 7a 4c 6f 67 69 6e 3b 0a 20 20 20 20 63 68 61  *zLogin;.    cha
19b0: 72 20 7a 43 61 70 5b 33 30 5d 3b 0a 20 20 20 20  r zCap[30];.    
19c0: 69 6e 74 20 69 20 3d 20 30 3b 0a 20 20 20 20 69  int i = 0;.    i
19d0: 6e 74 20 61 61 20 3d 20 50 28 22 61 61 22 29 21  nt aa = P("aa")!
19e0: 3d 30 3b 0a 20 20 20 20 69 6e 74 20 61 64 20 3d  =0;.    int ad =
19f0: 20 50 28 22 61 64 22 29 21 3d 30 3b 0a 20 20 20   P("ad")!=0;.   
1a00: 20 69 6e 74 20 61 65 20 3d 20 50 28 22 61 65 22   int ae = P("ae"
1a10: 29 21 3d 30 3b 0a 20 20 20 20 69 6e 74 20 61 69  )!=0;.    int ai
1a20: 20 3d 20 50 28 22 61 69 22 29 21 3d 30 3b 0a 20   = P("ai")!=0;. 
1a30: 20 20 20 69 6e 74 20 61 6a 20 3d 20 50 28 22 61     int aj = P("a
1a40: 6a 22 29 21 3d 30 3b 0a 20 20 20 20 69 6e 74 20  j")!=0;.    int 
1a50: 61 6b 20 3d 20 50 28 22 61 6b 22 29 21 3d 30 3b  ak = P("ak")!=0;
1a60: 0a 20 20 20 20 69 6e 74 20 61 6e 20 3d 20 50 28  .    int an = P(
1a70: 22 61 6e 22 29 21 3d 30 3b 0a 20 20 20 20 69 6e  "an")!=0;.    in
1a80: 74 20 61 6f 20 3d 20 50 28 22 61 6f 22 29 21 3d  t ao = P("ao")!=
1a90: 30 3b 0a 20 20 20 20 69 6e 74 20 61 70 20 3d 20  0;.    int ap = 
1aa0: 50 28 22 61 70 22 29 21 3d 30 3b 0a 20 20 20 20  P("ap")!=0;.    
1ab0: 69 6e 74 20 61 71 20 3d 20 50 28 22 61 71 22 29  int aq = P("aq")
1ac0: 21 3d 30 3b 0a 20 20 20 20 69 6e 74 20 61 72 20  !=0;.    int ar 
1ad0: 3d 20 50 28 22 61 72 22 29 21 3d 30 3b 0a 20 20  = P("ar")!=0;.  
1ae0: 20 20 69 6e 74 20 61 73 20 3d 20 67 2e 6f 6b 53    int as = g.okS
1af0: 65 74 75 70 20 26 26 20 50 28 22 61 73 22 29 21  etup && P("as")!
1b00: 3d 30 3b 0a 20 20 20 20 69 6e 74 20 61 77 20 3d  =0;.    int aw =
1b10: 20 50 28 22 61 77 22 29 21 3d 30 3b 0a 20 20 20   P("aw")!=0;.   
1b20: 20 69 6e 74 20 61 63 20 3d 20 50 28 22 61 63 22   int ac = P("ac"
1b30: 29 21 3d 30 3b 0a 20 20 20 20 69 6e 74 20 61 66  )!=0;.    int af
1b40: 20 3d 20 50 28 22 61 66 22 29 21 3d 30 3b 0a 20   = P("af")!=0;. 
1b50: 20 20 20 69 6e 74 20 61 6d 20 3d 20 50 28 22 61     int am = P("a
1b60: 6d 22 29 21 3d 30 3b 0a 20 20 20 20 69 6e 74 20  m")!=0;.    int 
1b70: 61 68 20 3d 20 50 28 22 61 68 22 29 21 3d 30 3b  ah = P("ah")!=0;
1b80: 0a 20 20 20 20 69 6e 74 20 61 67 20 3d 20 50 28  .    int ag = P(
1b90: 22 61 67 22 29 21 3d 30 3b 0a 20 20 20 20 69 66  "ag")!=0;.    if
1ba0: 28 20 61 61 20 29 7b 20 7a 43 61 70 5b 69 2b 2b  ( aa ){ zCap[i++
1bb0: 5d 20 3d 20 27 61 27 3b 20 7d 0a 20 20 20 20 69  ] = 'a'; }.    i
1bc0: 66 28 20 61 63 20 29 7b 20 7a 43 61 70 5b 69 2b  f( ac ){ zCap[i+
1bd0: 2b 5d 20 3d 20 27 63 27 3b 20 7d 0a 20 20 20 20  +] = 'c'; }.    
1be0: 69 66 28 20 61 64 20 29 7b 20 7a 43 61 70 5b 69  if( ad ){ zCap[i
1bf0: 2b 2b 5d 20 3d 20 27 64 27 3b 20 7d 0a 20 20 20  ++] = 'd'; }.   
1c00: 20 69 66 28 20 61 65 20 29 7b 20 7a 43 61 70 5b   if( ae ){ zCap[
1c10: 69 2b 2b 5d 20 3d 20 27 65 27 3b 20 7d 0a 20 20  i++] = 'e'; }.  
1c20: 20 20 69 66 28 20 61 66 20 29 7b 20 7a 43 61 70    if( af ){ zCap
1c30: 5b 69 2b 2b 5d 20 3d 20 27 66 27 3b 20 7d 0a 20  [i++] = 'f'; }. 
1c40: 20 20 20 69 66 28 20 61 68 20 29 7b 20 7a 43 61     if( ah ){ zCa
1c50: 70 5b 69 2b 2b 5d 20 3d 20 27 68 27 3b 20 7d 0a  p[i++] = 'h'; }.
1c60: 20 20 20 20 69 66 28 20 61 67 20 29 7b 20 7a 43      if( ag ){ zC
1c70: 61 70 5b 69 2b 2b 5d 20 3d 20 27 67 27 3b 20 7d  ap[i++] = 'g'; }
1c80: 0a 20 20 20 20 69 66 28 20 61 69 20 29 7b 20 7a  .    if( ai ){ z
1c90: 43 61 70 5b 69 2b 2b 5d 20 3d 20 27 69 27 3b 20  Cap[i++] = 'i'; 
1ca0: 7d 0a 20 20 20 20 69 66 28 20 61 6a 20 29 7b 20  }.    if( aj ){ 
1cb0: 7a 43 61 70 5b 69 2b 2b 5d 20 3d 20 27 6a 27 3b  zCap[i++] = 'j';
1cc0: 20 7d 0a 20 20 20 20 69 66 28 20 61 6b 20 29 7b   }.    if( ak ){
1cd0: 20 7a 43 61 70 5b 69 2b 2b 5d 20 3d 20 27 6b 27   zCap[i++] = 'k'
1ce0: 3b 20 7d 0a 20 20 20 20 69 66 28 20 61 6d 20 29  ; }.    if( am )
1cf0: 7b 20 7a 43 61 70 5b 69 2b 2b 5d 20 3d 20 27 6d  { zCap[i++] = 'm
1d00: 27 3b 20 7d 0a 20 20 20 20 69 66 28 20 61 6e 20  '; }.    if( an 
1d10: 29 7b 20 7a 43 61 70 5b 69 2b 2b 5d 20 3d 20 27  ){ zCap[i++] = '
1d20: 6e 27 3b 20 7d 0a 20 20 20 20 69 66 28 20 61 6f  n'; }.    if( ao
1d30: 20 29 7b 20 7a 43 61 70 5b 69 2b 2b 5d 20 3d 20   ){ zCap[i++] = 
1d40: 27 6f 27 3b 20 7d 0a 20 20 20 20 69 66 28 20 61  'o'; }.    if( a
1d50: 70 20 29 7b 20 7a 43 61 70 5b 69 2b 2b 5d 20 3d  p ){ zCap[i++] =
1d60: 20 27 70 27 3b 20 7d 0a 20 20 20 20 69 66 28 20   'p'; }.    if( 
1d70: 61 71 20 29 7b 20 7a 43 61 70 5b 69 2b 2b 5d 20  aq ){ zCap[i++] 
1d80: 3d 20 27 71 27 3b 20 7d 0a 20 20 20 20 69 66 28  = 'q'; }.    if(
1d90: 20 61 72 20 29 7b 20 7a 43 61 70 5b 69 2b 2b 5d   ar ){ zCap[i++]
1da0: 20 3d 20 27 72 27 3b 20 7d 0a 20 20 20 20 69 66   = 'r'; }.    if
1db0: 28 20 61 73 20 29 7b 20 7a 43 61 70 5b 69 2b 2b  ( as ){ zCap[i++
1dc0: 5d 20 3d 20 27 73 27 3b 20 7d 0a 20 20 20 20 69  ] = 's'; }.    i
1dd0: 66 28 20 61 77 20 29 7b 20 7a 43 61 70 5b 69 2b  f( aw ){ zCap[i+
1de0: 2b 5d 20 3d 20 27 77 27 3b 20 7d 0a 0a 20 20 20  +] = 'w'; }..   
1df0: 20 7a 43 61 70 5b 69 5d 20 3d 20 30 3b 0a 20 20   zCap[i] = 0;.  
1e00: 20 20 7a 50 77 20 3d 20 50 28 22 70 77 22 29 3b    zPw = P("pw");
1e10: 0a 20 20 20 20 69 66 28 20 7a 50 77 3d 3d 30 20  .    if( zPw==0 
1e20: 7c 7c 20 7a 50 77 5b 30 5d 3d 3d 30 20 29 7b 0a  || zPw[0]==0 ){.
1e30: 20 20 20 20 20 20 7a 50 77 20 3d 20 64 62 5f 74        zPw = db_t
1e40: 65 78 74 28 30 2c 20 22 53 45 4c 45 43 54 20 70  ext(0, "SELECT p
1e50: 77 20 46 52 4f 4d 20 75 73 65 72 20 57 48 45 52  w FROM user WHER
1e60: 45 20 75 69 64 3d 25 64 22 2c 20 75 69 64 29 3b  E uid=%d", uid);
1e70: 0a 20 20 20 20 7d 0a 20 20 20 20 7a 4c 6f 67 69  .    }.    zLogi
1e80: 6e 20 3d 20 50 28 22 6c 6f 67 69 6e 22 29 3b 0a  n = P("login");.
1e90: 20 20 20 20 69 66 28 20 75 69 64 3e 30 20 26 26      if( uid>0 &&
1ea0: 0a 20 20 20 20 20 20 20 20 64 62 5f 65 78 69 73  .        db_exis
1eb0: 74 73 28 22 53 45 4c 45 43 54 20 31 20 46 52 4f  ts("SELECT 1 FRO
1ec0: 4d 20 75 73 65 72 20 57 48 45 52 45 20 6c 6f 67  M user WHERE log
1ed0: 69 6e 3d 25 51 20 41 4e 44 20 75 69 64 21 3d 25  in=%Q AND uid!=%
1ee0: 64 22 2c 20 7a 4c 6f 67 69 6e 2c 20 75 69 64 29  d", zLogin, uid)
1ef0: 0a 20 20 20 20 29 7b 0a 20 20 20 20 20 20 73 74  .    ){.      st
1f00: 79 6c 65 5f 68 65 61 64 65 72 28 22 55 73 65 72  yle_header("User
1f10: 20 43 72 65 61 74 69 6f 6e 20 45 72 72 6f 72 22   Creation Error"
1f20: 29 3b 0a 20 20 20 20 20 20 40 20 3c 66 6f 6e 74  );.      @ <font
1f30: 20 63 6f 6c 6f 72 3d 22 72 65 64 22 3e 4c 6f 67   color="red">Log
1f40: 69 6e 20 22 25 68 28 7a 4c 6f 67 69 6e 29 22 20  in "%h(zLogin)" 
1f50: 69 73 20 61 6c 72 65 61 64 79 20 75 73 65 64 20  is already used 
1f60: 62 79 20 61 20 64 69 66 66 65 72 65 6e 74 0a 20  by a different. 
1f70: 20 20 20 20 20 40 20 75 73 65 72 2e 3c 2f 66 6f       @ user.</fo
1f80: 6e 74 3e 0a 20 20 20 20 20 20 40 0a 20 20 20 20  nt>.      @.    
1f90: 20 20 40 20 3c 70 3e 3c 61 20 68 72 65 66 3d 22    @ <p><a href="
1fa0: 73 65 74 75 70 5f 75 65 64 69 74 3f 69 64 3d 25  setup_uedit?id=%
1fb0: 64 28 75 69 64 29 29 3e 5b 42 75 6d 6d 65 72 5d  d(uid))>[Bummer]
1fc0: 3c 2f 61 3e 3c 2f 70 3e 0a 20 20 20 20 20 20 73  </a></p>.      s
1fd0: 74 79 6c 65 5f 66 6f 6f 74 65 72 28 29 3b 0a 20  tyle_footer();. 
1fe0: 20 20 20 20 20 72 65 74 75 72 6e 3b 0a 20 20 20       return;.   
1ff0: 20 7d 0a 20 20 20 20 64 62 5f 6d 75 6c 74 69 5f   }.    db_multi_
2000: 65 78 65 63 28 0a 20 20 20 20 20 20 20 22 52 45  exec(.       "RE
2010: 50 4c 41 43 45 20 49 4e 54 4f 20 75 73 65 72 28  PLACE INTO user(
2020: 75 69 64 2c 6c 6f 67 69 6e 2c 69 6e 66 6f 2c 70  uid,login,info,p
2030: 77 2c 63 61 70 29 20 22 0a 20 20 20 20 20 20 20  w,cap) ".       
2040: 22 56 41 4c 55 45 53 28 6e 75 6c 6c 69 66 28 25  "VALUES(nullif(%
2050: 64 2c 30 29 2c 25 51 2c 25 51 2c 25 51 2c 27 25  d,0),%Q,%Q,%Q,'%
2060: 73 27 29 22 2c 0a 20 20 20 20 20 20 75 69 64 2c  s')",.      uid,
2070: 20 50 28 22 6c 6f 67 69 6e 22 29 2c 20 50 28 22   P("login"), P("
2080: 69 6e 66 6f 22 29 2c 20 7a 50 77 2c 20 7a 43 61  info"), zPw, zCa
2090: 70 0a 20 20 20 20 29 3b 0a 20 20 20 20 63 67 69  p.    );.    cgi
20a0: 5f 72 65 64 69 72 65 63 74 28 22 73 65 74 75 70  _redirect("setup
20b0: 5f 75 6c 69 73 74 22 29 3b 0a 20 20 20 20 72 65  _ulist");.    re
20c0: 74 75 72 6e 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20  turn;.  }..  /* 
20d0: 4c 6f 61 64 20 74 68 65 20 65 78 69 73 74 69 6e  Load the existin
20e0: 67 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 20 61 62  g information ab
20f0: 6f 75 74 20 74 68 65 20 75 73 65 72 2c 20 69 66  out the user, if
2100: 20 61 6e 79 0a 20 20 2a 2f 0a 20 20 7a 4c 6f 67   any.  */.  zLog
2110: 69 6e 20 3d 20 22 22 3b 0a 20 20 7a 49 6e 66 6f  in = "";.  zInfo
2120: 20 3d 20 22 22 3b 0a 20 20 7a 43 61 70 20 3d 20   = "";.  zCap = 
2130: 22 22 3b 0a 20 20 6f 61 61 20 3d 20 6f 61 63 20  "";.  oaa = oac 
2140: 3d 20 6f 61 64 20 3d 20 6f 61 65 20 3d 20 6f 61  = oad = oae = oa
2150: 66 20 3d 20 6f 61 67 20 3d 20 6f 61 68 20 3d 20  f = oag = oah = 
2160: 6f 61 69 20 3d 20 6f 61 6a 20 3d 20 6f 61 6b 20  oai = oaj = oak 
2170: 3d 20 6f 61 6d 20 3d 0a 20 20 20 20 20 20 20 20  = oam =.        
2180: 6f 61 6e 20 3d 20 6f 61 6f 20 3d 20 6f 61 70 20  oan = oao = oap 
2190: 3d 20 6f 61 71 20 3d 20 6f 61 72 20 3d 20 6f 61  = oaq = oar = oa
21a0: 73 20 3d 20 6f 61 77 20 3d 20 22 22 3b 0a 20 20  s = oaw = "";.  
21b0: 69 66 28 20 75 69 64 20 29 7b 0a 20 20 20 20 7a  if( uid ){.    z
21c0: 4c 6f 67 69 6e 20 3d 20 64 62 5f 74 65 78 74 28  Login = db_text(
21d0: 22 22 2c 20 22 53 45 4c 45 43 54 20 6c 6f 67 69  "", "SELECT logi
21e0: 6e 20 46 52 4f 4d 20 75 73 65 72 20 57 48 45 52  n FROM user WHER
21f0: 45 20 75 69 64 3d 25 64 22 2c 20 75 69 64 29 3b  E uid=%d", uid);
2200: 0a 20 20 20 20 7a 49 6e 66 6f 20 3d 20 64 62 5f  .    zInfo = db_
2210: 74 65 78 74 28 22 22 2c 20 22 53 45 4c 45 43 54  text("", "SELECT
2220: 20 69 6e 66 6f 20 46 52 4f 4d 20 75 73 65 72 20   info FROM user 
2230: 57 48 45 52 45 20 75 69 64 3d 25 64 22 2c 20 75  WHERE uid=%d", u
2240: 69 64 29 3b 0a 20 20 20 20 7a 43 61 70 20 3d 20  id);.    zCap = 
2250: 64 62 5f 74 65 78 74 28 22 22 2c 20 22 53 45 4c  db_text("", "SEL
2260: 45 43 54 20 63 61 70 20 46 52 4f 4d 20 75 73 65  ECT cap FROM use
2270: 72 20 57 48 45 52 45 20 75 69 64 3d 25 64 22 2c  r WHERE uid=%d",
2280: 20 75 69 64 29 3b 0a 20 20 20 20 69 66 28 20 73   uid);.    if( s
2290: 74 72 63 68 72 28 7a 43 61 70 2c 20 27 61 27 29  trchr(zCap, 'a')
22a0: 20 29 20 6f 61 61 20 3d 20 22 20 63 68 65 63 6b   ) oaa = " check
22b0: 65 64 22 3b 0a 20 20 20 20 69 66 28 20 73 74 72  ed";.    if( str
22c0: 63 68 72 28 7a 43 61 70 2c 20 27 63 27 29 20 29  chr(zCap, 'c') )
22d0: 20 6f 61 63 20 3d 20 22 20 63 68 65 63 6b 65 64   oac = " checked
22e0: 22 3b 0a 20 20 20 20 69 66 28 20 73 74 72 63 68  ";.    if( strch
22f0: 72 28 7a 43 61 70 2c 20 27 64 27 29 20 29 20 6f  r(zCap, 'd') ) o
2300: 61 64 20 3d 20 22 20 63 68 65 63 6b 65 64 22 3b  ad = " checked";
2310: 0a 20 20 20 20 69 66 28 20 73 74 72 63 68 72 28  .    if( strchr(
2320: 7a 43 61 70 2c 20 27 65 27 29 20 29 20 6f 61 65  zCap, 'e') ) oae
2330: 20 3d 20 22 20 63 68 65 63 6b 65 64 22 3b 0a 20   = " checked";. 
2340: 20 20 20 69 66 28 20 73 74 72 63 68 72 28 7a 43     if( strchr(zC
2350: 61 70 2c 20 27 66 27 29 20 29 20 6f 61 66 20 3d  ap, 'f') ) oaf =
2360: 20 22 20 63 68 65 63 6b 65 64 22 3b 0a 20 20 20   " checked";.   
2370: 20 69 66 28 20 73 74 72 63 68 72 28 7a 43 61 70   if( strchr(zCap
2380: 2c 20 27 67 27 29 20 29 20 6f 61 67 20 3d 20 22  , 'g') ) oag = "
2390: 20 63 68 65 63 6b 65 64 22 3b 0a 20 20 20 20 69   checked";.    i
23a0: 66 28 20 73 74 72 63 68 72 28 7a 43 61 70 2c 20  f( strchr(zCap, 
23b0: 27 68 27 29 20 29 20 6f 61 68 20 3d 20 22 20 63  'h') ) oah = " c
23c0: 68 65 63 6b 65 64 22 3b 0a 20 20 20 20 69 66 28  hecked";.    if(
23d0: 20 73 74 72 63 68 72 28 7a 43 61 70 2c 20 27 69   strchr(zCap, 'i
23e0: 27 29 20 29 20 6f 61 69 20 3d 20 22 20 63 68 65  ') ) oai = " che
23f0: 63 6b 65 64 22 3b 0a 20 20 20 20 69 66 28 20 73  cked";.    if( s
2400: 74 72 63 68 72 28 7a 43 61 70 2c 20 27 6a 27 29  trchr(zCap, 'j')
2410: 20 29 20 6f 61 6a 20 3d 20 22 20 63 68 65 63 6b   ) oaj = " check
2420: 65 64 22 3b 0a 20 20 20 20 69 66 28 20 73 74 72  ed";.    if( str
2430: 63 68 72 28 7a 43 61 70 2c 20 27 6b 27 29 20 29  chr(zCap, 'k') )
2440: 20 6f 61 6b 20 3d 20 22 20 63 68 65 63 6b 65 64   oak = " checked
2450: 22 3b 0a 20 20 20 20 69 66 28 20 73 74 72 63 68  ";.    if( strch
2460: 72 28 7a 43 61 70 2c 20 27 6d 27 29 20 29 20 6f  r(zCap, 'm') ) o
2470: 61 6d 20 3d 20 22 20 63 68 65 63 6b 65 64 22 3b  am = " checked";
2480: 0a 20 20 20 20 69 66 28 20 73 74 72 63 68 72 28  .    if( strchr(
2490: 7a 43 61 70 2c 20 27 6e 27 29 20 29 20 6f 61 6e  zCap, 'n') ) oan
24a0: 20 3d 20 22 20 63 68 65 63 6b 65 64 22 3b 0a 20   = " checked";. 
24b0: 20 20 20 69 66 28 20 73 74 72 63 68 72 28 7a 43     if( strchr(zC
24c0: 61 70 2c 20 27 6f 27 29 20 29 20 6f 61 6f 20 3d  ap, 'o') ) oao =
24d0: 20 22 20 63 68 65 63 6b 65 64 22 3b 0a 20 20 20   " checked";.   
24e0: 20 69 66 28 20 73 74 72 63 68 72 28 7a 43 61 70   if( strchr(zCap
24f0: 2c 20 27 70 27 29 20 29 20 6f 61 70 20 3d 20 22  , 'p') ) oap = "
2500: 20 63 68 65 63 6b 65 64 22 3b 0a 20 20 20 20 69   checked";.    i
2510: 66 28 20 73 74 72 63 68 72 28 7a 43 61 70 2c 20  f( strchr(zCap, 
2520: 27 71 27 29 20 29 20 6f 61 71 20 3d 20 22 20 63  'q') ) oaq = " c
2530: 68 65 63 6b 65 64 22 3b 0a 20 20 20 20 69 66 28  hecked";.    if(
2540: 20 73 74 72 63 68 72 28 7a 43 61 70 2c 20 27 72   strchr(zCap, 'r
2550: 27 29 20 29 20 6f 61 72 20 3d 20 22 20 63 68 65  ') ) oar = " che
2560: 63 6b 65 64 22 3b 0a 20 20 20 20 69 66 28 20 73  cked";.    if( s
2570: 74 72 63 68 72 28 7a 43 61 70 2c 20 27 73 27 29  trchr(zCap, 's')
2580: 20 29 20 6f 61 73 20 3d 20 22 20 63 68 65 63 6b   ) oas = " check
2590: 65 64 22 3b 0a 20 20 20 20 69 66 28 20 73 74 72  ed";.    if( str
25a0: 63 68 72 28 7a 43 61 70 2c 20 27 77 27 29 20 29  chr(zCap, 'w') )
25b0: 20 6f 61 77 20 3d 20 22 20 63 68 65 63 6b 65 64   oaw = " checked
25c0: 22 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 42 65 67  ";.  }..  /* Beg
25d0: 69 6e 20 67 65 6e 65 72 61 74 69 6e 67 20 74 68  in generating th
25e0: 65 20 70 61 67 65 0a 20 20 2a 2f 0a 20 20 73 74  e page.  */.  st
25f0: 79 6c 65 5f 73 75 62 6d 65 6e 75 5f 65 6c 65 6d  yle_submenu_elem
2600: 65 6e 74 28 22 43 61 6e 63 65 6c 22 2c 20 22 43  ent("Cancel", "C
2610: 61 6e 63 65 6c 22 2c 20 22 73 65 74 75 70 5f 75  ancel", "setup_u
2620: 6c 69 73 74 22 29 3b 0a 20 20 69 66 28 20 75 69  list");.  if( ui
2630: 64 20 29 7b 0a 20 20 20 20 73 74 79 6c 65 5f 68  d ){.    style_h
2640: 65 61 64 65 72 28 6d 70 72 69 6e 74 66 28 22 45  eader(mprintf("E
2650: 64 69 74 20 55 73 65 72 20 25 68 22 2c 20 7a 4c  dit User %h", zL
2660: 6f 67 69 6e 29 29 3b 0a 20 20 7d 65 6c 73 65 7b  ogin));.  }else{
2670: 0a 20 20 20 20 73 74 79 6c 65 5f 68 65 61 64 65  .    style_heade
2680: 72 28 22 41 64 64 20 41 20 4e 65 77 20 55 73 65  r("Add A New Use
2690: 72 22 29 3b 0a 20 20 7d 0a 20 20 40 20 3c 74 61  r");.  }.  @ <ta
26a0: 62 6c 65 20 61 6c 69 67 6e 3d 22 6c 65 66 74 22  ble align="left"
26b0: 20 68 73 70 61 63 65 3d 22 32 30 22 20 76 73 70   hspace="20" vsp
26c0: 61 63 65 3d 22 31 30 22 3e 3c 74 72 3e 3c 74 64  ace="10"><tr><td
26d0: 3e 0a 20 20 40 20 3c 66 6f 72 6d 20 61 63 74 69  >.  @ <form acti
26e0: 6f 6e 3d 22 25 73 28 67 2e 7a 50 61 74 68 29 22  on="%s(g.zPath)"
26f0: 20 6d 65 74 68 6f 64 3d 22 50 4f 53 54 22 3e 0a   method="POST">.
2700: 20 20 40 20 3c 74 61 62 6c 65 3e 0a 20 20 40 20    @ <table>.  @ 
2710: 3c 74 72 3e 0a 20 20 40 20 20 20 3c 74 64 20 61  <tr>.  @   <td a
2720: 6c 69 67 6e 3d 22 72 69 67 68 74 22 3e 3c 6e 6f  lign="right"><no
2730: 62 72 3e 55 73 65 72 20 49 44 3a 3c 2f 6e 6f 62  br>User ID:</nob
2740: 72 3e 3c 2f 74 64 3e 0a 20 20 69 66 28 20 75 69  r></td>.  if( ui
2750: 64 20 29 7b 0a 20 20 20 20 40 20 20 20 3c 74 64  d ){.    @   <td
2760: 3e 25 64 28 75 69 64 29 20 3c 69 6e 70 75 74 20  >%d(uid) <input 
2770: 74 79 70 65 3d 22 68 69 64 64 65 6e 22 20 6e 61  type="hidden" na
2780: 6d 65 3d 22 69 64 22 20 76 61 6c 75 65 3d 22 25  me="id" value="%
2790: 64 28 75 69 64 29 22 3e 3c 2f 74 64 3e 0a 20 20  d(uid)"></td>.  
27a0: 7d 65 6c 73 65 7b 0a 20 20 20 20 40 20 20 20 3c  }else{.    @   <
27b0: 74 64 3e 28 6e 65 77 20 75 73 65 72 29 3c 69 6e  td>(new user)<in
27c0: 70 75 74 20 74 79 70 65 3d 22 68 69 64 64 65 6e  put type="hidden
27d0: 22 20 6e 61 6d 65 3d 22 69 64 22 20 76 61 6c 75  " name="id" valu
27e0: 65 3d 30 3e 3c 2f 74 64 3e 0a 20 20 7d 0a 20 20  e=0></td>.  }.  
27f0: 40 20 3c 2f 74 72 3e 0a 20 20 40 20 3c 74 72 3e  @ </tr>.  @ <tr>
2800: 0a 20 20 40 20 20 20 3c 74 64 20 61 6c 69 67 6e  .  @   <td align
2810: 3d 22 72 69 67 68 74 22 3e 3c 6e 6f 62 72 3e 4c  ="right"><nobr>L
2820: 6f 67 69 6e 3a 3c 2f 6e 6f 62 72 3e 3c 2f 74 64  ogin:</nobr></td
2830: 3e 0a 20 20 40 20 20 20 3c 74 64 3e 3c 69 6e 70  >.  @   <td><inp
2840: 75 74 20 74 79 70 65 3d 22 74 65 78 74 22 20 6e  ut type="text" n
2850: 61 6d 65 3d 22 6c 6f 67 69 6e 22 20 76 61 6c 75  ame="login" valu
2860: 65 3d 22 25 68 28 7a 4c 6f 67 69 6e 29 22 3e 3c  e="%h(zLogin)"><
2870: 2f 74 64 3e 0a 20 20 40 20 3c 2f 74 72 3e 0a 20  /td>.  @ </tr>. 
2880: 20 40 20 3c 74 72 3e 0a 20 20 40 20 20 20 3c 74   @ <tr>.  @   <t
2890: 64 20 61 6c 69 67 6e 3d 22 72 69 67 68 74 22 3e  d align="right">
28a0: 3c 6e 6f 62 72 3e 43 6f 6e 74 61 63 74 26 6e 62  <nobr>Contact&nb
28b0: 73 70 3b 49 6e 66 6f 3a 3c 2f 6e 6f 62 72 3e 3c  sp;Info:</nobr><
28c0: 2f 74 64 3e 0a 20 20 40 20 20 20 3c 74 64 3e 3c  /td>.  @   <td><
28d0: 69 6e 70 75 74 20 74 79 70 65 3d 22 74 65 78 74  input type="text
28e0: 22 20 6e 61 6d 65 3d 22 69 6e 66 6f 22 20 73 69  " name="info" si
28f0: 7a 65 3d 34 30 20 76 61 6c 75 65 3d 22 25 68 28  ze=40 value="%h(
2900: 7a 49 6e 66 6f 29 22 3e 3c 2f 74 64 3e 0a 20 20  zInfo)"></td>.  
2910: 40 20 3c 2f 74 72 3e 0a 20 20 40 20 3c 74 72 3e  @ </tr>.  @ <tr>
2920: 0a 20 20 40 20 20 20 3c 74 64 20 61 6c 69 67 6e  .  @   <td align
2930: 3d 22 72 69 67 68 74 22 20 76 61 6c 69 67 6e 3d  ="right" valign=
2940: 22 74 6f 70 22 3e 43 61 70 61 62 69 6c 69 74 69  "top">Capabiliti
2950: 65 73 3a 3c 2f 74 64 3e 0a 20 20 40 20 20 20 3c  es:</td>.  @   <
2960: 74 64 3e 0a 20 20 69 66 28 20 67 2e 6f 6b 53 65  td>.  if( g.okSe
2970: 74 75 70 20 29 7b 0a 20 20 20 20 40 20 20 20 20  tup ){.    @    
2980: 20 3c 69 6e 70 75 74 20 74 79 70 65 3d 22 63 68   <input type="ch
2990: 65 63 6b 62 6f 78 22 20 6e 61 6d 65 3d 22 61 73  eckbox" name="as
29a0: 22 25 73 28 6f 61 73 29 3e 53 65 74 75 70 3c 2f  "%s(oas)>Setup</
29b0: 69 6e 70 75 74 3e 3c 62 72 3e 0a 20 20 7d 0a 20  input><br>.  }. 
29c0: 20 40 20 20 20 20 20 3c 69 6e 70 75 74 20 74 79   @     <input ty
29d0: 70 65 3d 22 63 68 65 63 6b 62 6f 78 22 20 6e 61  pe="checkbox" na
29e0: 6d 65 3d 22 61 61 22 25 73 28 6f 61 61 29 3e 41  me="aa"%s(oaa)>A
29f0: 64 6d 69 6e 3c 2f 69 6e 70 75 74 3e 3c 62 72 3e  dmin</input><br>
2a00: 0a 20 20 40 20 20 20 20 20 3c 69 6e 70 75 74 20  .  @     <input 
2a10: 74 79 70 65 3d 22 63 68 65 63 6b 62 6f 78 22 20  type="checkbox" 
2a20: 6e 61 6d 65 3d 22 61 64 22 25 73 28 6f 61 64 29  name="ad"%s(oad)
2a30: 3e 44 65 6c 65 74 65 3c 2f 69 6e 70 75 74 3e 3c  >Delete</input><
2a40: 62 72 3e 0a 20 20 40 20 20 20 20 20 3c 69 6e 70  br>.  @     <inp
2a50: 75 74 20 74 79 70 65 3d 22 63 68 65 63 6b 62 6f  ut type="checkbo
2a60: 78 22 20 6e 61 6d 65 3d 22 61 65 22 25 73 28 6f  x" name="ae"%s(o
2a70: 61 64 29 3e 45 6d 61 69 6c 3c 2f 69 6e 70 75 74  ad)>Email</input
2a80: 3e 3c 62 72 3e 0a 20 20 40 20 20 20 20 20 3c 69  ><br>.  @     <i
2a90: 6e 70 75 74 20 74 79 70 65 3d 22 63 68 65 63 6b  nput type="check
2aa0: 62 6f 78 22 20 6e 61 6d 65 3d 22 61 70 22 25 73  box" name="ap"%s
2ab0: 28 6f 61 70 29 3e 50 61 73 73 77 6f 72 64 3c 2f  (oap)>Password</
2ac0: 69 6e 70 75 74 3e 3c 62 72 3e 0a 20 20 40 20 20  input><br>.  @  
2ad0: 20 20 20 3c 69 6e 70 75 74 20 74 79 70 65 3d 22     <input type="
2ae0: 63 68 65 63 6b 62 6f 78 22 20 6e 61 6d 65 3d 22  checkbox" name="
2af0: 61 71 22 25 73 28 6f 61 71 29 3e 51 75 65 72 79  aq"%s(oaq)>Query
2b00: 3c 2f 69 6e 70 75 74 3e 3c 62 72 3e 0a 20 20 40  </input><br>.  @
2b10: 20 20 20 20 20 3c 69 6e 70 75 74 20 74 79 70 65       <input type
2b20: 3d 22 63 68 65 63 6b 62 6f 78 22 20 6e 61 6d 65  ="checkbox" name
2b30: 3d 22 61 69 22 25 73 28 6f 61 69 29 3e 43 68 65  ="ai"%s(oai)>Che
2b40: 63 6b 2d 49 6e 3c 2f 69 6e 70 75 74 3e 3c 62 72  ck-In</input><br
2b50: 3e 0a 20 20 40 20 20 20 20 20 3c 69 6e 70 75 74  >.  @     <input
2b60: 20 74 79 70 65 3d 22 63 68 65 63 6b 62 6f 78 22   type="checkbox"
2b70: 20 6e 61 6d 65 3d 22 61 6f 22 25 73 28 6f 61 6f   name="ao"%s(oao
2b80: 29 3e 43 68 65 63 6b 2d 4f 75 74 3c 2f 69 6e 70  )>Check-Out</inp
2b90: 75 74 3e 3c 62 72 3e 0a 20 20 40 20 20 20 20 20  ut><br>.  @     
2ba0: 3c 69 6e 70 75 74 20 74 79 70 65 3d 22 63 68 65  <input type="che
2bb0: 63 6b 62 6f 78 22 20 6e 61 6d 65 3d 22 61 68 22  ckbox" name="ah"
2bc0: 25 73 28 6f 61 68 29 3e 48 69 73 74 6f 72 79 3c  %s(oah)>History<
2bd0: 2f 69 6e 70 75 74 3e 3c 62 72 3e 0a 20 20 40 20  /input><br>.  @ 
2be0: 20 20 20 20 3c 69 6e 70 75 74 20 74 79 70 65 3d      <input type=
2bf0: 22 63 68 65 63 6b 62 6f 78 22 20 6e 61 6d 65 3d  "checkbox" name=
2c00: 22 61 67 22 25 73 28 6f 61 67 29 3e 43 6c 6f 6e  "ag"%s(oag)>Clon
2c10: 65 3c 2f 69 6e 70 75 74 3e 3c 62 72 3e 0a 20 20  e</input><br>.  
2c20: 40 20 20 20 20 20 3c 69 6e 70 75 74 20 74 79 70  @     <input typ
2c30: 65 3d 22 63 68 65 63 6b 62 6f 78 22 20 6e 61 6d  e="checkbox" nam
2c40: 65 3d 22 61 6a 22 25 73 28 6f 61 6a 29 3e 52 65  e="aj"%s(oaj)>Re
2c50: 61 64 20 57 69 6b 69 3c 2f 69 6e 70 75 74 3e 3c  ad Wiki</input><
2c60: 62 72 3e 0a 20 20 40 20 20 20 20 20 3c 69 6e 70  br>.  @     <inp
2c70: 75 74 20 74 79 70 65 3d 22 63 68 65 63 6b 62 6f  ut type="checkbo
2c80: 78 22 20 6e 61 6d 65 3d 22 61 66 22 25 73 28 6f  x" name="af"%s(o
2c90: 61 66 29 3e 4e 65 77 20 57 69 6b 69 3c 2f 69 6e  af)>New Wiki</in
2ca0: 70 75 74 3e 3c 62 72 3e 0a 20 20 40 20 20 20 20  put><br>.  @    
2cb0: 20 3c 69 6e 70 75 74 20 74 79 70 65 3d 22 63 68   <input type="ch
2cc0: 65 63 6b 62 6f 78 22 20 6e 61 6d 65 3d 22 61 6d  eckbox" name="am
2cd0: 22 25 73 28 6f 61 6d 29 3e 41 70 70 65 6e 64 20  "%s(oam)>Append 
2ce0: 57 69 6b 69 3c 2f 69 6e 70 75 74 3e 3c 62 72 3e  Wiki</input><br>
2cf0: 0a 20 20 40 20 20 20 20 20 3c 69 6e 70 75 74 20  .  @     <input 
2d00: 74 79 70 65 3d 22 63 68 65 63 6b 62 6f 78 22 20  type="checkbox" 
2d10: 6e 61 6d 65 3d 22 61 6b 22 25 73 28 6f 61 6b 29  name="ak"%s(oak)
2d20: 3e 57 72 69 74 65 20 57 69 6b 69 3c 2f 69 6e 70  >Write Wiki</inp
2d30: 75 74 3e 3c 62 72 3e 0a 20 20 40 20 20 20 20 20  ut><br>.  @     
2d40: 3c 69 6e 70 75 74 20 74 79 70 65 3d 22 63 68 65  <input type="che
2d50: 63 6b 62 6f 78 22 20 6e 61 6d 65 3d 22 61 72 22  ckbox" name="ar"
2d60: 25 73 28 6f 61 72 29 3e 52 65 61 64 20 54 6b 74  %s(oar)>Read Tkt
2d70: 3c 2f 69 6e 70 75 74 3e 3c 62 72 3e 0a 20 20 40  </input><br>.  @
2d80: 20 20 20 20 20 3c 69 6e 70 75 74 20 74 79 70 65       <input type
2d90: 3d 22 63 68 65 63 6b 62 6f 78 22 20 6e 61 6d 65  ="checkbox" name
2da0: 3d 22 61 6e 22 25 73 28 6f 61 6e 29 3e 4e 65 77  ="an"%s(oan)>New
2db0: 20 54 6b 74 3c 2f 69 6e 70 75 74 3e 3c 62 72 3e   Tkt</input><br>
2dc0: 0a 20 20 40 20 20 20 20 20 3c 69 6e 70 75 74 20  .  @     <input 
2dd0: 74 79 70 65 3d 22 63 68 65 63 6b 62 6f 78 22 20  type="checkbox" 
2de0: 6e 61 6d 65 3d 22 61 63 22 25 73 28 6f 61 63 29  name="ac"%s(oac)
2df0: 3e 41 70 70 65 6e 64 20 54 6b 74 3c 2f 69 6e 70  >Append Tkt</inp
2e00: 75 74 3e 3c 62 72 3e 0a 20 20 40 20 20 20 20 20  ut><br>.  @     
2e10: 3c 69 6e 70 75 74 20 74 79 70 65 3d 22 63 68 65  <input type="che
2e20: 63 6b 62 6f 78 22 20 6e 61 6d 65 3d 22 61 77 22  ckbox" name="aw"
2e30: 25 73 28 6f 61 77 29 3e 57 72 69 74 65 20 54 6b  %s(oaw)>Write Tk
2e40: 74 3c 2f 69 6e 70 75 74 3e 0a 20 20 40 20 20 20  t</input>.  @   
2e50: 3c 2f 74 64 3e 0a 20 20 40 20 3c 2f 74 72 3e 0a  </td>.  @ </tr>.
2e60: 20 20 40 20 3c 74 72 3e 0a 20 20 40 20 20 20 3c    @ <tr>.  @   <
2e70: 74 64 20 61 6c 69 67 6e 3d 22 72 69 67 68 74 22  td align="right"
2e80: 3e 50 61 73 73 77 6f 72 64 3a 3c 2f 74 64 3e 0a  >Password:</td>.
2e90: 20 20 40 20 20 20 3c 74 64 3e 3c 69 6e 70 75 74    @   <td><input
2ea0: 20 74 79 70 65 3d 22 70 61 73 73 77 6f 72 64 22   type="password"
2eb0: 20 6e 61 6d 65 3d 22 70 77 22 20 76 61 6c 75 65   name="pw" value
2ec0: 3d 22 22 3e 3c 2f 74 64 3e 0a 20 20 40 20 3c 2f  =""></td>.  @ </
2ed0: 74 72 3e 0a 20 20 69 66 28 20 21 68 69 67 68 65  tr>.  if( !highe
2ee0: 72 55 73 65 72 20 29 7b 0a 20 20 20 20 40 20 3c  rUser ){.    @ <
2ef0: 74 72 3e 0a 20 20 20 20 40 20 20 20 3c 74 64 3e  tr>.    @   <td>
2f00: 26 6e 62 73 70 3c 2f 74 64 3e 0a 20 20 20 20 40  &nbsp</td>.    @
2f10: 20 20 20 3c 74 64 3e 3c 69 6e 70 75 74 20 74 79     <td><input ty
2f20: 70 65 3d 22 73 75 62 6d 69 74 22 20 6e 61 6d 65  pe="submit" name
2f30: 3d 22 73 75 62 6d 69 74 22 20 76 61 6c 75 65 3d  ="submit" value=
2f40: 22 41 70 70 6c 79 20 43 68 61 6e 67 65 73 22 3e  "Apply Changes">
2f50: 0a 20 20 20 20 40 20 3c 2f 74 72 3e 0a 20 20 7d  .    @ </tr>.  }
2f60: 0a 20 20 40 20 3c 2f 74 61 62 6c 65 3e 3c 2f 74  .  @ </table></t
2f70: 64 3e 3c 2f 74 72 3e 3c 2f 74 61 62 6c 65 3e 0a  d></tr></table>.
2f80: 20 20 40 20 3c 70 3e 3c 62 3e 4e 6f 74 65 73 3a    @ <p><b>Notes:
2f90: 3c 2f 62 3e 3c 2f 70 3e 0a 20 20 40 20 3c 6f 6c  </b></p>.  @ <ol
2fa0: 3e 0a 20 20 69 66 28 20 68 69 67 68 65 72 55 73  >.  if( higherUs
2fb0: 65 72 20 29 7b 0a 20 20 20 20 40 20 3c 6c 69 3e  er ){.    @ <li>
2fc0: 3c 70 3e 0a 20 20 20 20 40 20 55 73 65 72 20 25  <p>.    @ User %
2fd0: 68 28 7a 49 64 29 20 68 61 73 20 53 65 74 75 70  h(zId) has Setup
2fe0: 20 70 72 69 76 69 6c 65 67 65 73 20 61 6e 64 20   privileges and 
2ff0: 79 6f 75 20 6f 6e 6c 79 20 68 61 76 65 20 41 64  you only have Ad
3000: 6d 69 6e 20 70 72 69 76 69 6c 65 67 65 73 0a 20  min privileges. 
3010: 20 20 20 40 20 73 6f 20 79 6f 75 20 61 72 65 20     @ so you are 
3020: 6e 6f 74 20 70 65 72 6d 69 74 74 65 64 20 74 6f  not permitted to
3030: 20 6d 61 6b 65 20 63 68 61 6e 67 65 73 20 74 6f   make changes to
3040: 20 25 68 28 7a 49 64 29 2e 0a 20 20 20 20 40 20   %h(zId)..    @ 
3050: 3c 2f 70 3e 3c 2f 6c 69 3e 0a 20 20 20 20 40 0a  </p></li>.    @.
3060: 20 20 7d 0a 20 20 40 0a 20 20 40 20 3c 6c 69 3e    }.  @.  @ <li>
3070: 3c 70 3e 0a 20 20 40 20 54 68 65 20 3c 62 3e 44  <p>.  @ The <b>D
3080: 65 6c 65 74 65 3c 2f 62 3e 20 70 72 69 76 69 6c  elete</b> privil
3090: 65 67 65 20 67 69 76 65 20 74 68 65 20 75 73 65  ege give the use
30a0: 72 20 74 68 65 20 61 62 69 6c 69 74 79 20 74 6f  r the ability to
30b0: 20 65 72 61 73 65 0a 20 20 40 20 77 69 6b 69 2c   erase.  @ wiki,
30c0: 20 74 69 63 6b 65 74 73 2c 20 61 6e 64 20 61 74   tickets, and at
30d0: 74 74 61 63 68 6d 65 6e 74 73 20 74 68 61 74 20  ttachments that 
30e0: 68 61 76 65 20 62 65 65 6e 20 61 64 64 65 64 20  have been added 
30f0: 62 79 20 61 6e 6f 6e 79 6d 6f 75 73 0a 20 20 40  by anonymous.  @
3100: 20 75 73 65 72 73 2e 20 20 54 68 69 73 20 63 61   users.  This ca
3110: 70 61 62 69 6c 69 74 79 20 69 73 20 69 6e 74 65  pability is inte
3120: 6e 64 65 64 20 66 6f 72 20 64 65 6c 65 74 69 6f  nded for deletio
3130: 6e 20 6f 66 20 73 70 61 6d 2e 20 20 54 68 65 0a  n of spam.  The.
3140: 20 20 40 20 64 65 6c 65 74 65 20 63 61 70 61 62    @ delete capab
3150: 69 6c 69 74 79 20 69 73 20 6f 6e 6c 79 20 69 6e  ility is only in
3160: 20 65 66 66 65 63 74 20 66 6f 72 20 32 34 20 68   effect for 24 h
3170: 6f 75 72 73 20 61 66 74 65 72 20 74 68 65 20 69  ours after the i
3180: 74 65 6d 0a 20 20 40 20 69 73 20 66 69 72 73 74  tem.  @ is first
3190: 20 70 6f 73 74 65 64 2e 20 20 54 68 65 20 53 65   posted.  The Se
31a0: 74 75 70 20 75 73 65 72 20 63 61 6e 20 64 65 6c  tup user can del
31b0: 65 74 65 20 61 6e 79 74 68 69 6e 67 20 61 74 20  ete anything at 
31c0: 61 6e 79 20 74 69 6d 65 2e 0a 20 20 40 20 3c 2f  any time..  @ </
31d0: 70 3e 3c 2f 6c 69 3e 0a 20 20 40 0a 20 20 40 20  p></li>.  @.  @ 
31e0: 3c 6c 69 3e 3c 70 3e 0a 20 20 40 20 54 68 65 20  <li><p>.  @ The 
31f0: 3c 62 3e 51 75 65 72 79 3c 2f 62 3e 20 70 72 69  <b>Query</b> pri
3200: 76 69 6c 65 67 65 20 61 6c 6c 6f 77 73 20 74 68  vilege allows th
3210: 65 20 75 73 65 72 20 74 6f 20 63 72 65 61 74 65  e user to create
3220: 20 6f 72 20 65 64 69 74 0a 20 20 40 20 72 65 70   or edit.  @ rep
3230: 6f 72 74 20 66 6f 72 6d 61 74 73 20 62 79 20 73  ort formats by s
3240: 70 65 63 69 66 79 69 6e 67 20 61 70 70 72 6f 70  pecifying approp
3250: 72 69 61 74 65 20 53 51 4c 2e 20 20 55 73 65 72  riate SQL.  User
3260: 73 20 63 61 6e 20 72 75 6e 0a 20 20 40 20 65 78  s can run.  @ ex
3270: 69 73 74 69 6e 67 20 72 65 70 6f 72 74 73 20 77  isting reports w
3280: 69 74 68 6f 75 74 20 74 68 65 20 51 75 65 72 79  ithout the Query
3290: 20 70 72 69 76 69 6c 65 67 65 2e 0a 20 20 40 20   privilege..  @ 
32a0: 3c 2f 70 3e 3c 2f 6c 69 3e 0a 20 20 40 0a 20 20  </p></li>.  @.  
32b0: 40 20 3c 6c 69 3e 3c 70 3e 0a 20 20 40 20 41 6e  @ <li><p>.  @ An
32c0: 20 3c 62 3e 41 64 6d 69 6e 3c 2f 62 3e 20 75 73   <b>Admin</b> us
32d0: 65 72 20 63 61 6e 20 61 64 64 20 6f 74 68 65 72  er can add other
32e0: 20 75 73 65 72 73 2c 20 63 72 65 61 74 65 20 6e   users, create n
32f0: 65 77 20 74 69 63 6b 65 74 20 72 65 70 6f 72 74  ew ticket report
3300: 0a 20 20 40 20 66 6f 72 6d 61 74 73 2c 20 61 6e  .  @ formats, an
3310: 64 20 63 68 61 6e 67 65 20 73 79 73 74 65 6d 20  d change system 
3320: 64 65 66 61 75 6c 74 73 2e 20 20 42 75 74 20 6f  defaults.  But o
3330: 6e 6c 79 20 74 68 65 20 3c 62 3e 53 65 74 75 70  nly the <b>Setup
3340: 3c 2f 62 3e 20 75 73 65 72 0a 20 20 40 20 69 73  </b> user.  @ is
3350: 20 61 62 6c 65 20 74 6f 20 63 68 61 6e 67 65 20   able to change 
3360: 74 68 65 20 72 65 70 6f 73 69 74 6f 72 79 20 74  the repository t
3370: 6f 0a 20 20 40 20 77 68 69 63 68 20 74 68 69 73  o.  @ which this
3380: 20 70 72 6f 67 72 61 6d 20 69 73 20 6c 69 6e 6b   program is link
3390: 65 64 2e 0a 20 20 40 20 3c 2f 70 3e 3c 2f 6c 69  ed..  @ </p></li
33a0: 3e 0a 20 20 40 0a 20 20 40 20 3c 6c 69 3e 3c 70  >.  @.  @ <li><p
33b0: 3e 0a 20 20 40 20 54 68 65 20 3c 62 3e 48 69 73  >.  @ The <b>His
33c0: 74 6f 72 79 3c 2f 62 3e 20 70 72 69 76 69 6c 65  tory</b> privile
33d0: 67 65 20 61 6c 6c 6f 77 73 20 61 20 75 73 65 72  ge allows a user
33e0: 20 74 6f 20 73 65 65 20 61 20 74 69 6d 65 6c 69   to see a timeli
33f0: 6e 65 0a 20 20 40 20 77 69 74 68 20 68 79 70 65  ne.  @ with hype
3400: 72 6c 69 6e 6b 73 20 74 6f 20 76 65 72 73 69 6f  rlinks to versio
3410: 6e 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 2c 20 74  n information, t
3420: 6f 20 64 6f 77 6e 6c 6f 61 64 20 5a 49 50 20 61  o download ZIP a
3430: 72 63 68 69 76 65 73 0a 20 20 40 20 6f 66 20 69  rchives.  @ of i
3440: 6e 64 69 76 69 64 75 61 6c 20 76 65 72 73 69 6f  ndividual versio
3450: 6e 73 2e 0a 20 20 40 20 3c 2f 70 3e 3c 2f 6c 69  ns..  @ </p></li
3460: 3e 0a 20 20 40 0a 20 20 40 20 3c 6c 69 3e 3c 70  >.  @.  @ <li><p
3470: 3e 0a 20 20 40 20 4e 6f 20 6c 6f 67 69 6e 20 69  >.  @ No login i
3480: 73 20 72 65 71 75 69 72 65 64 20 66 6f 72 20 75  s required for u
3490: 73 65 72 20 22 3c 62 3e 6e 6f 62 6f 64 79 3c 2f  ser "<b>nobody</
34a0: 62 3e 22 2e 20 20 54 68 65 20 63 61 70 61 62 69  b>".  The capabi
34b0: 6c 69 74 69 65 73 0a 20 20 40 20 6f 66 20 74 68  lities.  @ of th
34c0: 69 73 20 75 73 65 72 20 61 72 65 20 61 76 61 69  is user are avai
34d0: 6c 61 62 6c 65 20 74 6f 20 61 6e 79 6f 6e 65 20  lable to anyone 
34e0: 77 69 74 68 6f 75 74 20 73 75 70 70 6c 79 69 6e  without supplyin
34f0: 67 20 61 20 75 73 65 72 6e 61 6d 65 20 6f 72 0a  g a username or.
3500: 20 20 40 20 70 61 73 73 77 6f 72 64 2e 20 20 54    @ password.  T
3510: 6f 20 64 69 73 61 62 6c 65 20 6e 6f 62 6f 64 79  o disable nobody
3520: 20 61 63 63 65 73 73 2c 20 6d 61 6b 65 20 73 75   access, make su
3530: 72 65 20 74 68 65 72 65 20 69 73 20 6e 6f 20 75  re there is no u
3540: 73 65 72 0a 20 20 40 20 77 69 74 68 20 61 6e 20  ser.  @ with an 
3550: 49 44 20 6f 66 20 3c 62 3e 6e 6f 62 6f 64 79 3c  ID of <b>nobody<
3560: 2f 62 3e 20 6f 72 20 74 68 61 74 20 74 68 65 20  /b> or that the 
3570: 6e 6f 62 6f 64 79 20 75 73 65 72 20 68 61 73 20  nobody user has 
3580: 6e 6f 0a 20 20 40 20 63 61 70 61 62 69 6c 69 74  no.  @ capabilit
3590: 69 65 73 20 65 6e 61 62 6c 65 64 2e 20 20 54 68  ies enabled.  Th
35a0: 65 20 70 61 73 73 77 6f 72 64 20 66 6f 72 20 6e  e password for n
35b0: 6f 62 6f 64 79 20 69 73 20 69 67 6e 6f 72 65 2e  obody is ignore.
35c0: 20 20 54 6f 0a 20 20 40 20 61 76 6f 69 64 20 70    To.  @ avoid p
35d0: 72 6f 62 6c 65 6d 73 20 77 69 74 68 20 73 70 69  roblems with spi
35e0: 64 65 72 73 20 6f 76 65 72 6c 6f 61 64 69 6e 67  ders overloading
35f0: 20 74 68 65 20 73 65 72 76 65 72 2c 20 69 74 20   the server, it 
3600: 69 73 20 73 75 67 67 65 73 74 65 64 0a 20 20 40  is suggested.  @
3610: 20 74 68 61 74 20 74 68 65 20 27 68 27 20 28 48   that the 'h' (H
3620: 69 73 74 6f 72 79 29 20 63 61 70 61 62 69 6c 69  istory) capabili
3630: 74 79 20 62 65 20 74 75 72 6e 65 64 20 6f 66 66  ty be turned off
3640: 20 66 6f 72 20 75 73 65 72 20 6e 6f 62 6f 64 79   for user nobody
3650: 2e 0a 20 20 40 20 3c 2f 70 3e 3c 2f 6c 69 3e 0a  ..  @ </p></li>.
3660: 20 20 40 0a 20 20 40 20 3c 6c 69 3e 3c 70 3e 0a    @.  @ <li><p>.
3670: 20 20 40 20 4c 6f 67 69 6e 20 69 73 20 72 65 71    @ Login is req
3680: 75 69 72 65 64 20 66 6f 72 20 75 73 65 72 20 22  uired for user "
3690: 3c 62 3e 61 6e 6f 6e 79 6d 6f 75 73 3c 2f 62 3e  <b>anonymous</b>
36a0: 22 20 62 75 74 20 74 68 65 20 70 61 73 73 77 6f  " but the passwo
36b0: 72 64 0a 20 20 40 20 69 73 20 64 69 73 70 6c 61  rd.  @ is displa
36c0: 79 65 64 20 6f 6e 20 74 68 65 20 6c 6f 67 69 6e  yed on the login
36d0: 20 73 63 72 65 65 6e 20 62 65 73 69 64 65 20 74   screen beside t
36e0: 68 65 20 70 61 73 73 77 6f 72 64 20 65 6e 74 72  he password entr
36f0: 79 20 62 6f 78 0a 20 20 40 20 73 6f 20 61 6e 79  y box.  @ so any
3700: 62 6f 64 79 20 77 68 6f 20 63 61 6e 20 72 65 61  body who can rea
3710: 64 20 73 68 6f 75 6c 64 20 62 65 20 61 62 6c 65  d should be able
3720: 20 74 6f 20 6c 6f 67 69 6e 20 61 73 20 61 6e 6f   to login as ano
3730: 6e 79 6d 6f 75 73 2e 0a 20 20 40 20 4f 6e 20 74  nymous..  @ On t
3740: 68 65 20 6f 74 68 65 72 20 68 61 6e 64 2c 20 73  he other hand, s
3750: 70 69 64 65 72 73 20 61 6e 64 20 77 65 62 2d 63  piders and web-c
3760: 72 61 77 6c 65 72 73 20 77 69 6c 6c 20 74 79 70  rawlers will typ
3770: 69 63 61 6c 6c 79 20 6e 6f 74 0a 20 20 40 20 62  ically not.  @ b
3780: 65 20 61 62 6c 65 20 74 6f 20 6c 6f 67 69 6e 2e  e able to login.
3790: 20 20 53 65 74 20 74 68 65 20 63 61 70 61 62 69    Set the capabi
37a0: 6c 69 74 69 65 73 20 6f 66 20 74 68 65 20 61 6e  lities of the an
37b0: 6f 6e 79 6d 6f 75 73 20 75 73 65 72 0a 20 20 40  onymous user.  @
37c0: 20 74 6f 20 74 68 69 6e 67 73 20 74 68 61 74 20   to things that 
37d0: 79 6f 75 20 77 61 6e 74 20 61 6e 79 20 68 75 6d  you want any hum
37e0: 61 6e 20 74 6f 20 62 65 20 61 62 6c 65 20 74 6f  an to be able to
37f0: 20 64 6f 2c 20 62 75 74 20 6e 6f 20 61 6e 79 0a   do, but no any.
3800: 20 20 40 20 73 70 69 64 65 72 2e 0a 20 20 40 20    @ spider..  @ 
3810: 3c 2f 70 3e 3c 2f 6c 69 3e 0a 20 20 40 20 3c 2f  </p></li>.  @ </
3820: 66 6f 72 6d 3e 0a 20 20 73 74 79 6c 65 5f 66 6f  form>.  style_fo
3830: 6f 74 65 72 28 29 3b 0a 7d 0a 0a 0a 2f 2a 0a 2a  oter();.}.../*.*
3840: 2a 20 47 65 6e 65 72 61 74 65 20 61 20 63 68 65  * Generate a che
3850: 63 6b 62 6f 78 20 66 6f 72 20 61 6e 20 61 74 74  ckbox for an att
3860: 72 69 62 75 74 65 2e 0a 2a 2f 0a 73 74 61 74 69  ribute..*/.stati
3870: 63 20 76 6f 69 64 20 6f 6e 6f 66 66 5f 61 74 74  c void onoff_att
3880: 72 69 62 75 74 65 28 0a 20 20 63 6f 6e 73 74 20  ribute(.  const 
3890: 63 68 61 72 20 2a 7a 4c 61 62 65 6c 2c 20 20 20  char *zLabel,   
38a0: 2f 2a 20 54 68 65 20 74 65 78 74 20 6c 61 62 65  /* The text labe
38b0: 6c 20 6f 6e 20 74 68 65 20 63 68 65 63 6b 62 6f  l on the checkbo
38c0: 78 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61  x */.  const cha
38d0: 72 20 2a 7a 56 61 72 2c 20 20 20 20 20 2f 2a 20  r *zVar,     /* 
38e0: 54 68 65 20 63 6f 72 72 65 73 70 6f 6e 64 69 6e  The correspondin
38f0: 67 20 72 6f 77 20 69 6e 20 74 68 65 20 56 41 52  g row in the VAR
3900: 20 74 61 62 6c 65 20 2a 2f 0a 20 20 63 6f 6e 73   table */.  cons
3910: 74 20 63 68 61 72 20 2a 7a 51 50 61 72 6d 2c 20  t char *zQParm, 
3920: 20 20 2f 2a 20 54 68 65 20 71 75 65 72 79 20 70    /* The query p
3930: 61 72 61 6d 65 74 65 72 20 2a 2f 0a 20 20 69 6e  arameter */.  in
3940: 74 20 64 66 6c 74 56 61 6c 20 20 20 20 20 20 20  t dfltVal       
3950: 20 20 20 20 2f 2a 20 44 65 66 61 75 6c 74 20 76      /* Default v
3960: 61 6c 75 65 20 69 66 20 56 41 52 20 74 61 62 6c  alue if VAR tabl
3970: 65 20 65 6e 74 72 79 20 64 6f 65 73 20 6e 6f 74  e entry does not
3980: 20 65 78 69 73 74 20 2a 2f 0a 29 7b 0a 20 20 63   exist */.){.  c
3990: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 56 61 6c 20  onst char *zVal 
39a0: 3d 20 64 62 5f 67 65 74 28 7a 56 61 72 2c 20 30  = db_get(zVar, 0
39b0: 29 3b 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20  );.  const char 
39c0: 2a 7a 51 20 3d 20 50 28 7a 51 50 61 72 6d 29 3b  *zQ = P(zQParm);
39d0: 0a 20 20 69 6e 74 20 69 56 61 6c 3b 0a 20 20 69  .  int iVal;.  i
39e0: 66 28 20 7a 56 61 6c 20 29 7b 0a 20 20 20 20 69  f( zVal ){.    i
39f0: 56 61 6c 20 3d 20 61 74 6f 69 28 7a 56 61 6c 29  Val = atoi(zVal)
3a00: 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 69  ;.  }else{.    i
3a10: 56 61 6c 20 3d 20 64 66 6c 74 56 61 6c 3b 0a 20  Val = dfltVal;. 
3a20: 20 7d 0a 20 20 69 66 28 20 7a 51 3d 3d 30 20 26   }.  if( zQ==0 &
3a30: 26 20 50 28 22 73 75 62 6d 69 74 22 29 20 29 7b  & P("submit") ){
3a40: 0a 20 20 20 20 7a 51 20 3d 20 22 6f 66 66 22 3b  .    zQ = "off";
3a50: 0a 20 20 7d 0a 20 20 69 66 28 20 7a 51 20 29 7b  .  }.  if( zQ ){
3a60: 0a 20 20 20 20 69 6e 74 20 69 51 20 3d 20 73 74  .    int iQ = st
3a70: 72 63 6d 70 28 7a 51 2c 22 6f 6e 22 29 3d 3d 30  rcmp(zQ,"on")==0
3a80: 20 7c 7c 20 61 74 6f 69 28 7a 51 29 3b 0a 20 20   || atoi(zQ);.  
3a90: 20 20 69 66 28 20 69 51 21 3d 69 56 61 6c 20 29    if( iQ!=iVal )
3aa0: 7b 0a 20 20 20 20 20 20 64 62 5f 73 65 74 28 7a  {.      db_set(z
3ab0: 56 61 72 2c 20 69 51 20 3f 20 22 31 22 20 3a 20  Var, iQ ? "1" : 
3ac0: 22 30 22 2c 20 30 29 3b 0a 20 20 20 20 20 20 69  "0", 0);.      i
3ad0: 56 61 6c 20 3d 20 69 51 3b 0a 20 20 20 20 7d 0a  Val = iQ;.    }.
3ae0: 20 20 7d 0a 20 20 69 66 28 20 69 56 61 6c 20 29    }.  if( iVal )
3af0: 7b 0a 20 20 20 20 40 20 3c 69 6e 70 75 74 20 74  {.    @ <input t
3b00: 79 70 65 3d 22 63 68 65 63 6b 62 6f 78 22 20 6e  ype="checkbox" n
3b10: 61 6d 65 3d 22 25 73 28 7a 51 50 61 72 6d 29 22  ame="%s(zQParm)"
3b20: 20 63 68 65 63 6b 65 64 3e 25 73 28 7a 4c 61 62   checked>%s(zLab
3b30: 65 6c 29 3c 2f 69 6e 70 75 74 3e 0a 20 20 7d 65  el)</input>.  }e
3b40: 6c 73 65 7b 0a 20 20 20 20 40 20 3c 69 6e 70 75  lse{.    @ <inpu
3b50: 74 20 74 79 70 65 3d 22 63 68 65 63 6b 62 6f 78  t type="checkbox
3b60: 22 20 6e 61 6d 65 3d 22 25 73 28 7a 51 50 61 72  " name="%s(zQPar
3b70: 6d 29 22 3e 25 73 28 7a 4c 61 62 65 6c 29 3c 2f  m)">%s(zLabel)</
3b80: 69 6e 70 75 74 3e 0a 20 20 7d 0a 7d 0a 0a 2f 2a  input>.  }.}../*
3b90: 0a 2a 2a 20 47 65 6e 65 72 61 74 65 20 61 6e 20  .** Generate an 
3ba0: 65 6e 74 72 79 20 62 6f 78 20 66 6f 72 20 61 6e  entry box for an
3bb0: 20 61 74 74 72 69 62 75 74 65 2e 0a 2a 2f 0a 73   attribute..*/.s
3bc0: 74 61 74 69 63 20 76 6f 69 64 20 65 6e 74 72 79  tatic void entry
3bd0: 5f 61 74 74 72 69 62 75 74 65 28 0a 20 20 63 6f  _attribute(.  co
3be0: 6e 73 74 20 63 68 61 72 20 2a 7a 4c 61 62 65 6c  nst char *zLabel
3bf0: 2c 20 20 20 2f 2a 20 54 68 65 20 74 65 78 74 20  ,   /* The text 
3c00: 6c 61 62 65 6c 20 6f 6e 20 74 68 65 20 65 6e 74  label on the ent
3c10: 72 79 20 62 6f 78 20 2a 2f 0a 20 20 69 6e 74 20  ry box */.  int 
3c20: 77 69 64 74 68 2c 20 20 20 20 20 20 20 20 20 20  width,          
3c30: 20 20 2f 2a 20 57 69 64 74 68 20 6f 66 20 74 68    /* Width of th
3c40: 65 20 65 6e 74 72 79 20 62 6f 78 20 2a 2f 0a 20  e entry box */. 
3c50: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 56 61   const char *zVa
3c60: 72 2c 20 20 20 20 20 2f 2a 20 54 68 65 20 63 6f  r,     /* The co
3c70: 72 72 65 73 70 6f 6e 64 69 6e 67 20 72 6f 77 20  rresponding row 
3c80: 69 6e 20 74 68 65 20 56 41 52 20 74 61 62 6c 65  in the VAR table
3c90: 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61 72   */.  const char
3ca0: 20 2a 7a 51 50 61 72 6d 2c 20 20 20 2f 2a 20 54   *zQParm,   /* T
3cb0: 68 65 20 71 75 65 72 79 20 70 61 72 61 6d 65 74  he query paramet
3cc0: 65 72 20 2a 2f 0a 20 20 63 68 61 72 20 2a 7a 44  er */.  char *zD
3cd0: 66 6c 74 20 20 20 20 20 2f 2a 20 44 65 66 61 75  flt     /* Defau
3ce0: 6c 74 20 76 61 6c 75 65 20 69 66 20 56 41 52 20  lt value if VAR 
3cf0: 74 61 62 6c 65 20 65 6e 74 72 79 20 64 6f 65 73  table entry does
3d00: 20 6e 6f 74 20 65 78 69 73 74 20 2a 2f 0a 29 7b   not exist */.){
3d10: 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  .  const char *z
3d20: 56 61 6c 20 3d 20 64 62 5f 67 65 74 28 7a 56 61  Val = db_get(zVa
3d30: 72 2c 20 7a 44 66 6c 74 29 3b 0a 20 20 63 6f 6e  r, zDflt);.  con
3d40: 73 74 20 63 68 61 72 20 2a 7a 51 20 3d 20 50 28  st char *zQ = P(
3d50: 7a 51 50 61 72 6d 29 3b 0a 20 20 69 66 28 20 7a  zQParm);.  if( z
3d60: 51 20 26 26 20 73 74 72 63 6d 70 28 7a 51 2c 7a  Q && strcmp(zQ,z
3d70: 56 61 6c 29 21 3d 30 20 29 7b 0a 20 20 20 20 64  Val)!=0 ){.    d
3d80: 62 5f 73 65 74 28 7a 56 61 72 2c 20 7a 51 2c 20  b_set(zVar, zQ, 
3d90: 30 29 3b 0a 20 20 20 20 7a 56 61 6c 20 3d 20 7a  0);.    zVal = z
3da0: 51 3b 0a 20 20 7d 0a 20 20 40 20 3c 69 6e 70 75  Q;.  }.  @ <inpu
3db0: 74 20 74 79 70 65 3d 22 74 65 78 74 22 20 6e 61  t type="text" na
3dc0: 6d 65 3d 22 25 73 28 7a 51 50 61 72 6d 29 22 20  me="%s(zQParm)" 
3dd0: 76 61 6c 75 65 3d 22 25 68 28 7a 56 61 6c 29 22  value="%h(zVal)"
3de0: 20 73 69 7a 65 3d 22 25 64 28 77 69 64 74 68 29   size="%d(width)
3df0: 22 3e 0a 20 20 40 20 25 73 28 7a 4c 61 62 65 6c  ">.  @ %s(zLabel
3e00: 29 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 47 65 6e 65 72  ).}../*.** Gener
3e10: 61 74 65 20 61 20 74 65 78 74 20 62 6f 78 20 66  ate a text box f
3e20: 6f 72 20 61 6e 20 61 74 74 72 69 62 75 74 65 2e  or an attribute.
3e30: 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20  .*/.static void 
3e40: 74 65 78 74 61 72 65 61 5f 61 74 74 72 69 62 75  textarea_attribu
3e50: 74 65 28 0a 20 20 63 6f 6e 73 74 20 63 68 61 72  te(.  const char
3e60: 20 2a 7a 4c 61 62 65 6c 2c 20 20 20 2f 2a 20 54   *zLabel,   /* T
3e70: 68 65 20 74 65 78 74 20 6c 61 62 65 6c 20 6f 6e  he text label on
3e80: 20 74 68 65 20 74 65 78 74 61 72 65 61 20 2a 2f   the textarea */
3e90: 0a 20 20 69 6e 74 20 72 6f 77 73 2c 20 20 20 20  .  int rows,    
3ea0: 20 20 20 20 20 20 20 20 20 2f 2a 20 52 6f 77 73           /* Rows
3eb0: 20 69 6e 20 74 68 65 20 74 65 78 74 61 72 65 61   in the textarea
3ec0: 20 2a 2f 0a 20 20 69 6e 74 20 63 6f 6c 73 2c 20   */.  int cols, 
3ed0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 43              /* C
3ee0: 6f 6c 75 6d 6e 73 20 69 6e 20 74 68 65 20 74 65  olumns in the te
3ef0: 78 74 61 72 65 61 20 2a 2f 0a 20 20 63 6f 6e 73  xtarea */.  cons
3f00: 74 20 63 68 61 72 20 2a 7a 56 61 72 2c 20 20 20  t char *zVar,   
3f10: 20 20 2f 2a 20 54 68 65 20 63 6f 72 72 65 73 70    /* The corresp
3f20: 6f 6e 64 69 6e 67 20 72 6f 77 20 69 6e 20 74 68  onding row in th
3f30: 65 20 56 41 52 20 74 61 62 6c 65 20 2a 2f 0a 20  e VAR table */. 
3f40: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 51 50   const char *zQP
3f50: 2c 20 20 20 20 20 20 2f 2a 20 54 68 65 20 71 75  ,      /* The qu
3f60: 65 72 79 20 70 61 72 61 6d 65 74 65 72 20 2a 2f  ery parameter */
3f70: 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  .  const char *z
3f80: 44 66 6c 74 20 20 20 20 20 2f 2a 20 44 65 66 61  Dflt     /* Defa
3f90: 75 6c 74 20 76 61 6c 75 65 20 69 66 20 56 41 52  ult value if VAR
3fa0: 20 74 61 62 6c 65 20 65 6e 74 72 79 20 64 6f 65   table entry doe
3fb0: 73 20 6e 6f 74 20 65 78 69 73 74 20 2a 2f 0a 29  s not exist */.)
3fc0: 7b 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  {.  const char *
3fd0: 7a 20 3d 20 64 62 5f 67 65 74 28 7a 56 61 72 2c  z = db_get(zVar,
3fe0: 20 28 63 68 61 72 2a 29 7a 44 66 6c 74 29 3b 0a   (char*)zDflt);.
3ff0: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 51    const char *zQ
4000: 20 3d 20 50 28 7a 51 50 29 3b 0a 20 20 69 66 28   = P(zQP);.  if(
4010: 20 7a 51 20 26 26 20 73 74 72 63 6d 70 28 7a 51   zQ && strcmp(zQ
4020: 2c 7a 29 21 3d 30 20 29 7b 0a 20 20 20 20 64 62  ,z)!=0 ){.    db
4030: 5f 73 65 74 28 7a 56 61 72 2c 20 7a 51 2c 20 30  _set(zVar, zQ, 0
4040: 29 3b 0a 20 20 20 20 7a 20 3d 20 7a 51 3b 0a 20  );.    z = zQ;. 
4050: 20 7d 0a 20 20 69 66 28 20 72 6f 77 73 3e 30 20   }.  if( rows>0 
4060: 26 26 20 63 6f 6c 73 3e 30 20 29 7b 0a 20 20 20  && cols>0 ){.   
4070: 20 40 20 3c 74 65 78 74 61 72 65 61 20 6e 61 6d   @ <textarea nam
4080: 65 3d 22 25 73 28 7a 51 50 29 22 20 72 6f 77 73  e="%s(zQP)" rows
4090: 3d 22 25 64 28 72 6f 77 73 29 22 20 63 6f 6c 73  ="%d(rows)" cols
40a0: 3d 22 25 64 28 63 6f 6c 73 29 22 3e 25 68 28 7a  ="%d(cols)">%h(z
40b0: 29 3c 2f 74 65 78 74 61 72 65 61 3e 0a 20 20 20  )</textarea>.   
40c0: 20 40 20 25 73 28 7a 4c 61 62 65 6c 29 0a 20 20   @ %s(zLabel).  
40d0: 7d 0a 7d 0a 0a 0a 2f 2a 0a 2a 2a 20 57 45 42 50  }.}.../*.** WEBP
40e0: 41 47 45 3a 20 73 65 74 75 70 5f 61 63 63 65 73  AGE: setup_acces
40f0: 73 0a 2a 2f 0a 76 6f 69 64 20 73 65 74 75 70 5f  s.*/.void setup_
4100: 61 63 63 65 73 73 28 76 6f 69 64 29 7b 0a 20 20  access(void){.  
4110: 6c 6f 67 69 6e 5f 63 68 65 63 6b 5f 63 72 65 64  login_check_cred
4120: 65 6e 74 69 61 6c 73 28 29 3b 0a 20 20 69 66 28  entials();.  if(
4130: 20 21 67 2e 6f 6b 53 65 74 75 70 20 29 7b 0a 20   !g.okSetup ){. 
4140: 20 20 20 6c 6f 67 69 6e 5f 6e 65 65 64 65 64 28     login_needed(
4150: 29 3b 0a 20 20 7d 0a 0a 20 20 73 74 79 6c 65 5f  );.  }..  style_
4160: 68 65 61 64 65 72 28 22 41 63 63 65 73 73 20 43  header("Access C
4170: 6f 6e 74 72 6f 6c 20 53 65 74 74 69 6e 67 73 22  ontrol Settings"
4180: 29 3b 0a 20 20 64 62 5f 62 65 67 69 6e 5f 74 72  );.  db_begin_tr
4190: 61 6e 73 61 63 74 69 6f 6e 28 29 3b 0a 20 20 40  ansaction();.  @
41a0: 20 3c 66 6f 72 6d 20 61 63 74 69 6f 6e 3d 22 25   <form action="%
41b0: 73 28 67 2e 7a 42 61 73 65 55 52 4c 29 2f 73 65  s(g.zBaseURL)/se
41c0: 74 75 70 5f 61 63 63 65 73 73 22 20 6d 65 74 68  tup_access" meth
41d0: 6f 64 3d 22 50 4f 53 54 22 3e 0a 0a 20 20 40 20  od="POST">..  @ 
41e0: 3c 68 72 3e 0a 20 20 6f 6e 6f 66 66 5f 61 74 74  <hr>.  onoff_att
41f0: 72 69 62 75 74 65 28 22 52 65 71 75 69 72 65 20  ribute("Require 
4200: 70 61 73 73 77 6f 72 64 20 66 6f 72 20 6c 6f 63  password for loc
4210: 61 6c 20 61 63 63 65 73 73 22 2c 0a 20 20 20 20  al access",.    
4220: 20 22 6c 6f 63 61 6c 61 75 74 68 22 2c 20 22 6c   "localauth", "l
4230: 6f 63 61 6c 61 75 74 68 22 2c 20 31 29 3b 0a 20  ocalauth", 1);. 
4240: 20 40 20 3c 70 3e 57 68 65 6e 20 65 6e 61 62 6c   @ <p>When enabl
4250: 65 64 2c 20 74 68 65 20 70 61 73 73 77 6f 72 64  ed, the password
4260: 20 73 69 67 6e 2d 69 6e 20 69 73 20 72 65 71 75   sign-in is requ
4270: 69 72 65 64 20 66 6f 72 0a 20 20 40 20 77 65 62  ired for.  @ web
4280: 20 61 63 63 65 73 73 20 63 6f 6d 69 6e 67 20 66   access coming f
4290: 72 6f 6d 20 31 32 37 2e 30 2e 30 2e 31 2e 20 20  rom 127.0.0.1.  
42a0: 57 68 65 6e 20 64 69 73 61 62 6c 65 64 2c 20 77  When disabled, w
42b0: 65 62 20 61 63 63 65 73 73 0a 20 20 40 20 66 72  eb access.  @ fr
42c0: 6f 6d 20 31 32 37 2e 30 2e 30 2e 31 20 69 73 20  om 127.0.0.1 is 
42d0: 61 6c 6c 6f 77 73 20 77 69 74 68 6f 75 74 20 61  allows without a
42e0: 6e 79 20 6c 6f 67 69 6e 20 2d 20 74 68 65 20 75  ny login - the u
42f0: 73 65 72 20 69 64 20 69 73 20 73 65 6c 65 63 74  ser id is select
4300: 65 64 0a 20 20 40 20 66 72 6f 6d 20 74 68 65 20  ed.  @ from the 
4310: 7e 2f 2e 66 6f 73 73 69 6c 20 64 61 74 61 62 61  ~/.fossil databa
4320: 73 65 2e 20 50 61 73 73 77 6f 72 64 20 6c 6f 67  se. Password log
4330: 69 6e 20 69 73 20 61 6c 77 61 79 73 20 72 65 71  in is always req
4340: 75 69 72 65 64 0a 20 20 40 20 66 6f 72 20 69 6e  uired.  @ for in
4350: 63 6f 6d 69 6e 67 20 77 65 62 20 63 6f 6e 6e 65  coming web conne
4360: 63 74 69 6f 6e 73 20 6f 6e 20 69 6e 74 65 72 6e  ctions on intern
4370: 65 74 20 61 64 64 72 65 73 73 65 73 20 6f 74 68  et addresses oth
4380: 65 72 20 74 68 61 6e 0a 20 20 40 20 31 32 37 2e  er than.  @ 127.
4390: 30 2e 30 2e 31 2e 3c 2f 70 3e 3c 2f 6c 69 3e 0a  0.0.1.</p></li>.
43a0: 0a 20 20 40 20 3c 68 72 3e 0a 20 20 65 6e 74 72  .  @ <hr>.  entr
43b0: 79 5f 61 74 74 72 69 62 75 74 65 28 22 4c 6f 67  y_attribute("Log
43c0: 69 6e 20 65 78 70 69 72 61 74 69 6f 6e 20 74 69  in expiration ti
43d0: 6d 65 22 2c 20 36 2c 20 22 63 6f 6f 6b 69 65 2d  me", 6, "cookie-
43e0: 65 78 70 69 72 65 22 2c 20 22 63 65 78 22 2c 20  expire", "cex", 
43f0: 22 38 37 36 36 22 29 3b 0a 20 20 40 20 3c 70 3e  "8766");.  @ <p>
4400: 54 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 68 6f  The number of ho
4410: 75 72 73 20 66 6f 72 20 77 68 69 63 68 20 61 20  urs for which a 
4420: 6c 6f 67 69 6e 20 69 73 20 76 61 6c 69 64 2e 20  login is valid. 
4430: 20 54 68 69 73 20 6d 75 73 74 20 62 65 20 61 0a   This must be a.
4440: 20 20 40 20 70 6f 73 69 74 69 76 65 20 6e 75 6d    @ positive num
4450: 62 65 72 2e 20 20 54 68 65 20 64 65 66 61 75 6c  ber.  The defaul
4460: 74 20 69 73 20 38 37 36 30 20 68 6f 75 72 73 20  t is 8760 hours 
4470: 77 68 69 63 68 20 69 73 20 61 70 70 72 6f 78 69  which is approxi
4480: 6d 61 74 65 6c 79 20 65 71 75 61 6c 0a 20 20 40  mately equal.  @
4490: 20 74 6f 20 61 20 79 65 61 72 2e 3c 2f 70 3e 0a   to a year.</p>.
44a0: 0a 20 20 40 20 3c 68 72 3e 0a 20 20 6f 6e 6f 66  .  @ <hr>.  onof
44b0: 66 5f 61 74 74 72 69 62 75 74 65 28 22 41 6c 6c  f_attribute("All
44c0: 6f 77 20 61 6e 6f 6e 79 6d 6f 75 73 20 73 69 67  ow anonymous sig
44d0: 6e 75 70 22 2c 20 22 61 6e 6f 6e 2d 73 69 67 6e  nup", "anon-sign
44e0: 75 70 22 2c 20 22 61 73 75 22 2c 20 30 29 3b 0a  up", "asu", 0);.
44f0: 20 20 40 20 3c 70 3e 41 6c 6c 6f 77 20 75 73 65    @ <p>Allow use
4500: 72 73 20 74 6f 20 63 72 65 61 74 65 20 74 68 65  rs to create the
4510: 69 72 20 6f 77 6e 20 61 63 63 6f 75 6e 74 73 3c  ir own accounts<
4520: 2f 70 3e 0a 0a 20 20 40 20 3c 68 72 3e 0a 20 20  /p>..  @ <hr>.  
4530: 40 20 3c 70 3e 3c 69 6e 70 75 74 20 74 79 70 65  @ <p><input type
4540: 3d 22 73 75 62 6d 69 74 22 20 20 6e 61 6d 65 3d  ="submit"  name=
4550: 22 73 75 62 6d 69 74 22 20 76 61 6c 75 65 3d 22  "submit" value="
4560: 41 70 70 6c 79 20 43 68 61 6e 67 65 73 22 3e 3c  Apply Changes"><
4570: 2f 70 3e 0a 20 20 40 20 3c 2f 66 6f 72 6d 3e 0a  /p>.  @ </form>.
4580: 20 20 64 62 5f 65 6e 64 5f 74 72 61 6e 73 61 63    db_end_transac
4590: 74 69 6f 6e 28 30 29 3b 0a 20 20 73 74 79 6c 65  tion(0);.  style
45a0: 5f 66 6f 6f 74 65 72 28 29 3b 0a 7d 0a 0a 2f 2a  _footer();.}../*
45b0: 0a 2a 2a 20 57 45 42 50 41 47 45 3a 20 73 65 74  .** WEBPAGE: set
45c0: 75 70 5f 63 6f 6e 66 69 67 0a 2a 2f 0a 76 6f 69  up_config.*/.voi
45d0: 64 20 73 65 74 75 70 5f 63 6f 6e 66 69 67 28 76  d setup_config(v
45e0: 6f 69 64 29 7b 0a 20 20 6c 6f 67 69 6e 5f 63 68  oid){.  login_ch
45f0: 65 63 6b 5f 63 72 65 64 65 6e 74 69 61 6c 73 28  eck_credentials(
4600: 29 3b 0a 20 20 69 66 28 20 21 67 2e 6f 6b 53 65  );.  if( !g.okSe
4610: 74 75 70 20 29 7b 0a 20 20 20 20 6c 6f 67 69 6e  tup ){.    login
4620: 5f 6e 65 65 64 65 64 28 29 3b 0a 20 20 7d 0a 0a  _needed();.  }..
4630: 20 20 73 74 79 6c 65 5f 68 65 61 64 65 72 28 22    style_header("
4640: 57 57 57 20 43 6f 6e 66 69 67 75 72 61 74 69 6f  WWW Configuratio
4650: 6e 22 29 3b 0a 20 20 64 62 5f 62 65 67 69 6e 5f  n");.  db_begin_
4660: 74 72 61 6e 73 61 63 74 69 6f 6e 28 29 3b 0a 20  transaction();. 
4670: 20 40 20 3c 66 6f 72 6d 20 61 63 74 69 6f 6e 3d   @ <form action=
4680: 22 25 73 28 67 2e 7a 42 61 73 65 55 52 4c 29 2f  "%s(g.zBaseURL)/
4690: 73 65 74 75 70 5f 63 6f 6e 66 69 67 22 20 6d 65  setup_config" me
46a0: 74 68 6f 64 3d 22 50 4f 53 54 22 3e 0a 20 20 40  thod="POST">.  @
46b0: 20 3c 68 72 20 2f 3e 0a 20 20 65 6e 74 72 79 5f   <hr />.  entry_
46c0: 61 74 74 72 69 62 75 74 65 28 22 50 72 6f 6a 65  attribute("Proje
46d0: 63 74 20 4e 61 6d 65 22 2c 20 36 30 2c 20 22 70  ct Name", 60, "p
46e0: 72 6f 6a 65 63 74 2d 6e 61 6d 65 22 2c 20 22 70  roject-name", "p
46f0: 6e 22 2c 20 22 22 29 3b 0a 20 20 40 20 3c 70 3e  n", "");.  @ <p>
4700: 47 69 76 65 20 79 6f 75 72 20 70 72 6f 6a 65 63  Give your projec
4710: 74 20 61 20 6e 61 6d 65 20 73 6f 20 76 69 73 69  t a name so visi
4720: 74 6f 72 73 20 6b 6e 6f 77 20 77 68 61 74 20 74  tors know what t
4730: 68 69 73 20 73 69 74 65 20 69 73 20 61 62 6f 75  his site is abou
4740: 74 2e 0a 20 20 40 20 54 68 65 20 70 72 6f 6a 65  t..  @ The proje
4750: 63 74 20 6e 61 6d 65 20 77 69 6c 6c 20 61 6c 73  ct name will als
4760: 6f 20 62 65 20 75 73 65 64 20 61 73 20 74 68 65  o be used as the
4770: 20 52 53 53 20 66 65 65 64 20 74 69 74 6c 65 2e   RSS feed title.
4780: 3c 2f 70 3e 0a 20 20 40 20 3c 68 72 20 2f 3e 0a  </p>.  @ <hr />.
4790: 20 20 74 65 78 74 61 72 65 61 5f 61 74 74 72 69    textarea_attri
47a0: 62 75 74 65 28 22 50 72 6f 6a 65 63 74 20 44 65  bute("Project De
47b0: 73 63 72 69 70 74 69 6f 6e 22 2c 20 35 2c 20 36  scription", 5, 6
47c0: 30 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  0,.             
47d0: 20 20 20 20 20 20 20 20 22 70 72 6f 6a 65 63 74          "project
47e0: 2d 64 65 73 63 72 69 70 74 69 6f 6e 22 2c 20 22  -description", "
47f0: 70 64 22 2c 20 22 22 29 3b 0a 20 20 40 20 3c 70  pd", "");.  @ <p
4800: 3e 44 65 73 63 72 69 62 65 20 79 6f 75 72 20 70  >Describe your p
4810: 72 6f 6a 65 63 74 2e 20 54 68 69 73 20 77 69 6c  roject. This wil
4820: 6c 20 62 65 20 75 73 65 64 20 69 6e 20 70 61 67  l be used in pag
4830: 65 20 68 65 61 64 65 72 73 20 66 6f 72 20 73 65  e headers for se
4840: 61 72 63 68 0a 20 20 40 20 65 6e 67 69 6e 65 73  arch.  @ engines
4850: 20 61 73 20 77 65 6c 6c 20 61 73 20 61 20 73 68   as well as a sh
4860: 6f 72 74 20 52 53 53 20 64 65 73 63 72 69 70 74  ort RSS descript
4870: 69 6f 6e 2e 3c 2f 70 3e 0a 20 20 40 20 3c 68 72  ion.</p>.  @ <hr
4880: 20 2f 3e 0a 20 20 40 20 3c 70 3e 3c 69 6e 70 75   />.  @ <p><inpu
4890: 74 20 74 79 70 65 3d 22 73 75 62 6d 69 74 22 20  t type="submit" 
48a0: 20 6e 61 6d 65 3d 22 73 75 62 6d 69 74 22 20 76   name="submit" v
48b0: 61 6c 75 65 3d 22 41 70 70 6c 79 20 43 68 61 6e  alue="Apply Chan
48c0: 67 65 73 22 3e 3c 2f 70 3e 0a 20 20 40 20 3c 2f  ges"></p>.  @ </
48d0: 66 6f 72 6d 3e 0a 20 20 64 62 5f 65 6e 64 5f 74  form>.  db_end_t
48e0: 72 61 6e 73 61 63 74 69 6f 6e 28 30 29 3b 0a 20  ransaction(0);. 
48f0: 20 73 74 79 6c 65 5f 66 6f 6f 74 65 72 28 29 3b   style_footer();
4900: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 57 45 42 50 41 47  .}../*.** WEBPAG
4910: 45 3a 20 73 65 74 75 70 5f 65 64 69 74 63 73 73  E: setup_editcss
4920: 0a 2a 2f 0a 76 6f 69 64 20 73 65 74 75 70 5f 65  .*/.void setup_e
4930: 64 69 74 63 73 73 28 76 6f 69 64 29 7b 0a 20 20  ditcss(void){.  
4940: 6c 6f 67 69 6e 5f 63 68 65 63 6b 5f 63 72 65 64  login_check_cred
4950: 65 6e 74 69 61 6c 73 28 29 3b 0a 20 20 69 66 28  entials();.  if(
4960: 20 21 67 2e 6f 6b 53 65 74 75 70 20 29 7b 0a 20   !g.okSetup ){. 
4970: 20 20 20 6c 6f 67 69 6e 5f 6e 65 65 64 65 64 28     login_needed(
4980: 29 3b 0a 20 20 7d 0a 20 20 73 74 79 6c 65 5f 68  );.  }.  style_h
4990: 65 61 64 65 72 28 22 45 64 69 74 20 43 53 53 22  eader("Edit CSS"
49a0: 29 3b 0a 20 20 40 20 3c 66 6f 72 6d 20 61 63 74  );.  @ <form act
49b0: 69 6f 6e 3d 22 25 73 28 67 2e 7a 42 61 73 65 55  ion="%s(g.zBaseU
49c0: 52 4c 29 2f 73 65 74 75 70 5f 65 64 69 74 63 73  RL)/setup_editcs
49d0: 73 22 20 6d 65 74 68 6f 64 3d 22 50 4f 53 54 22  s" method="POST"
49e0: 3e 0a 20 20 40 20 45 64 69 74 20 74 68 65 20 43  >.  @ Edit the C
49f0: 53 53 3a 3c 62 72 20 2f 3e 0a 20 20 74 65 78 74  SS:<br />.  text
4a00: 61 72 65 61 5f 61 74 74 72 69 62 75 74 65 28 22  area_attribute("
4a10: 22 2c 20 34 30 2c 20 38 30 2c 20 22 63 73 73 22  ", 40, 80, "css"
4a20: 2c 20 22 63 73 73 22 2c 20 7a 44 65 66 61 75 6c  , "css", zDefaul
4a30: 74 43 53 53 29 3b 0a 20 20 40 20 3c 62 72 20 2f  tCSS);.  @ <br /
4a40: 3e 0a 20 20 40 20 3c 69 6e 70 75 74 20 74 79 70  >.  @ <input typ
4a50: 65 3d 22 73 75 62 6d 69 74 22 20 6e 61 6d 65 3d  e="submit" name=
4a60: 22 73 75 62 6d 69 74 22 20 76 61 6c 75 65 3d 22  "submit" value="
4a70: 41 70 70 6c 79 20 43 68 61 6e 67 65 73 22 3e 0a  Apply Changes">.
4a80: 20 20 40 20 3c 2f 66 6f 72 6d 3e 0a 20 20 40 20    @ </form>.  @ 
4a90: 3c 68 72 3e 0a 20 20 40 20 48 65 72 65 20 69 73  <hr>.  @ Here is
4aa0: 20 74 68 65 20 64 65 66 61 75 6c 74 20 43 53 53   the default CSS
4ab0: 3a 0a 20 20 40 20 3c 62 6c 6f 63 6b 71 75 6f 74  :.  @ <blockquot
4ac0: 65 3e 3c 70 72 65 3e 0a 20 20 40 20 25 68 28 7a  e><pre>.  @ %h(z
4ad0: 44 65 66 61 75 6c 74 43 53 53 29 0a 20 20 40 20  DefaultCSS).  @ 
4ae0: 3c 2f 70 72 65 3e 3c 2f 62 6c 6f 63 6b 71 75 6f  </pre></blockquo
4af0: 74 65 3e 0a 20 20 73 74 79 6c 65 5f 66 6f 6f 74  te>.  style_foot
4b00: 65 72 28 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 57  er();.}../*.** W
4b10: 45 42 50 41 47 45 3a 20 73 65 74 75 70 5f 68 65  EBPAGE: setup_he
4b20: 61 64 65 72 0a 2a 2f 0a 76 6f 69 64 20 73 65 74  ader.*/.void set
4b30: 75 70 5f 68 65 61 64 65 72 28 76 6f 69 64 29 7b  up_header(void){
4b40: 0a 20 20 6c 6f 67 69 6e 5f 63 68 65 63 6b 5f 63  .  login_check_c
4b50: 72 65 64 65 6e 74 69 61 6c 73 28 29 3b 0a 20 20  redentials();.  
4b60: 69 66 28 20 21 67 2e 6f 6b 53 65 74 75 70 20 29  if( !g.okSetup )
4b70: 7b 0a 20 20 20 20 6c 6f 67 69 6e 5f 6e 65 65 64  {.    login_need
4b80: 65 64 28 29 3b 0a 20 20 7d 0a 20 20 64 62 5f 62  ed();.  }.  db_b
4b90: 65 67 69 6e 5f 74 72 61 6e 73 61 63 74 69 6f 6e  egin_transaction
4ba0: 28 29 3b 0a 20 20 69 66 28 20 50 28 22 63 6c 65  ();.  if( P("cle
4bb0: 61 72 22 29 21 3d 30 20 29 7b 0a 20 20 20 20 64  ar")!=0 ){.    d
4bc0: 62 5f 6d 75 6c 74 69 5f 65 78 65 63 28 22 44 45  b_multi_exec("DE
4bd0: 4c 45 54 45 20 46 52 4f 4d 20 63 6f 6e 66 69 67  LETE FROM config
4be0: 20 57 48 45 52 45 20 6e 61 6d 65 3d 27 68 65 61   WHERE name='hea
4bf0: 64 65 72 27 22 29 3b 0a 20 20 20 20 63 67 69 5f  der'");.    cgi_
4c00: 72 65 70 6c 61 63 65 5f 70 61 72 61 6d 65 74 65  replace_paramete
4c10: 72 28 22 68 65 61 64 65 72 22 2c 20 7a 44 65 66  r("header", zDef
4c20: 61 75 6c 74 48 65 61 64 65 72 29 3b 0a 20 20 7d  aultHeader);.  }
4c30: 65 6c 73 65 7b 0a 20 20 20 20 74 65 78 74 61 72  else{.    textar
4c40: 65 61 5f 61 74 74 72 69 62 75 74 65 28 30 2c 20  ea_attribute(0, 
4c50: 30 2c 20 30 2c 20 22 68 65 61 64 65 72 22 2c 20  0, 0, "header", 
4c60: 22 68 65 61 64 65 72 22 2c 20 7a 44 65 66 61 75  "header", zDefau
4c70: 6c 74 48 65 61 64 65 72 29 3b 0a 20 20 7d 0a 20  ltHeader);.  }. 
4c80: 20 73 74 79 6c 65 5f 68 65 61 64 65 72 28 22 45   style_header("E
4c90: 64 69 74 20 50 61 67 65 20 48 65 61 64 65 72 22  dit Page Header"
4ca0: 29 3b 0a 20 20 40 20 3c 66 6f 72 6d 20 61 63 74  );.  @ <form act
4cb0: 69 6f 6e 3d 22 25 73 28 67 2e 7a 42 61 73 65 55  ion="%s(g.zBaseU
4cc0: 52 4c 29 2f 73 65 74 75 70 5f 68 65 61 64 65 72  RL)/setup_header
4cd0: 22 20 6d 65 74 68 6f 64 3d 22 50 4f 53 54 22 3e  " method="POST">
4ce0: 0a 20 20 40 20 3c 70 3e 45 64 69 74 20 48 54 4d  .  @ <p>Edit HTM
4cf0: 4c 20 74 65 78 74 20 77 69 74 68 20 65 6d 62 65  L text with embe
4d00: 64 64 65 64 20 73 75 62 73 63 72 69 70 74 20 74  dded subscript t
4d10: 68 61 74 20 77 69 6c 6c 20 62 65 20 75 73 65 64  hat will be used
4d20: 20 74 6f 0a 20 20 40 20 67 65 6e 65 72 61 74 65   to.  @ generate
4d30: 20 74 68 65 20 62 65 67 69 6e 6e 69 6e 67 20 6f   the beginning o
4d40: 66 20 65 76 65 72 79 20 70 61 67 65 20 74 68 72  f every page thr
4d50: 6f 75 67 68 20 73 74 61 72 74 20 6f 66 20 74 68  ough start of th
4d60: 65 20 6d 61 69 6e 0a 20 20 40 20 6d 65 6e 75 2e  e main.  @ menu.
4d70: 3c 2f 70 3e 0a 20 20 74 65 78 74 61 72 65 61 5f  </p>.  textarea_
4d80: 61 74 74 72 69 62 75 74 65 28 22 22 2c 20 34 30  attribute("", 40
4d90: 2c 20 38 30 2c 20 22 68 65 61 64 65 72 22 2c 20  , 80, "header", 
4da0: 22 68 65 61 64 65 72 22 2c 20 7a 44 65 66 61 75  "header", zDefau
4db0: 6c 74 48 65 61 64 65 72 29 3b 0a 20 20 40 20 3c  ltHeader);.  @ <
4dc0: 62 72 20 2f 3e 0a 20 20 40 20 3c 69 6e 70 75 74  br />.  @ <input
4dd0: 20 74 79 70 65 3d 22 73 75 62 6d 69 74 22 20 6e   type="submit" n
4de0: 61 6d 65 3d 22 73 75 62 6d 69 74 22 20 76 61 6c  ame="submit" val
4df0: 75 65 3d 22 41 70 70 6c 79 20 43 68 61 6e 67 65  ue="Apply Change
4e00: 73 22 3e 0a 20 20 40 20 3c 69 6e 70 75 74 20 74  s">.  @ <input t
4e10: 79 70 65 3d 22 73 75 62 6d 69 74 22 20 6e 61 6d  ype="submit" nam
4e20: 65 3d 22 63 6c 65 61 72 22 20 76 61 6c 75 65 3d  e="clear" value=
4e30: 22 52 65 76 65 72 74 20 54 6f 20 44 65 66 61 75  "Revert To Defau
4e40: 6c 74 22 3e 0a 20 20 40 20 3c 2f 66 6f 72 6d 3e  lt">.  @ </form>
4e50: 0a 20 20 40 20 3c 68 72 3e 0a 20 20 40 20 48 65  .  @ <hr>.  @ He
4e60: 72 65 20 69 73 20 74 68 65 20 64 65 66 61 75 6c  re is the defaul
4e70: 74 20 70 61 67 65 20 68 65 61 64 65 72 3a 0a 20  t page header:. 
4e80: 20 40 20 3c 62 6c 6f 63 6b 71 75 6f 74 65 3e 3c   @ <blockquote><
4e90: 70 72 65 3e 0a 20 20 40 20 25 68 28 7a 44 65 66  pre>.  @ %h(zDef
4ea0: 61 75 6c 74 48 65 61 64 65 72 29 0a 20 20 40 20  aultHeader).  @ 
4eb0: 3c 2f 70 72 65 3e 3c 2f 62 6c 6f 63 6b 71 75 6f  </pre></blockquo
4ec0: 74 65 3e 0a 20 20 64 62 5f 65 6e 64 5f 74 72 61  te>.  db_end_tra
4ed0: 6e 73 61 63 74 69 6f 6e 28 30 29 3b 0a 7d 0a 0a  nsaction(0);.}..
4ee0: 2f 2a 0a 2a 2a 20 57 45 42 50 41 47 45 3a 20 73  /*.** WEBPAGE: s
4ef0: 65 74 75 70 5f 66 6f 6f 74 65 72 0a 2a 2f 0a 76  etup_footer.*/.v
4f00: 6f 69 64 20 73 65 74 75 70 5f 66 6f 6f 74 65 72  oid setup_footer
4f10: 28 76 6f 69 64 29 7b 0a 20 20 6c 6f 67 69 6e 5f  (void){.  login_
4f20: 63 68 65 63 6b 5f 63 72 65 64 65 6e 74 69 61 6c  check_credential
4f30: 73 28 29 3b 0a 20 20 69 66 28 20 21 67 2e 6f 6b  s();.  if( !g.ok
4f40: 53 65 74 75 70 20 29 7b 0a 20 20 20 20 6c 6f 67  Setup ){.    log
4f50: 69 6e 5f 6e 65 65 64 65 64 28 29 3b 0a 20 20 7d  in_needed();.  }
4f60: 0a 20 20 64 62 5f 62 65 67 69 6e 5f 74 72 61 6e  .  db_begin_tran
4f70: 73 61 63 74 69 6f 6e 28 29 3b 0a 20 20 69 66 28  saction();.  if(
4f80: 20 50 28 22 63 6c 65 61 72 22 29 21 3d 30 20 29   P("clear")!=0 )
4f90: 7b 0a 20 20 20 20 64 62 5f 6d 75 6c 74 69 5f 65  {.    db_multi_e
4fa0: 78 65 63 28 22 44 45 4c 45 54 45 20 46 52 4f 4d  xec("DELETE FROM
4fb0: 20 63 6f 6e 66 69 67 20 57 48 45 52 45 20 6e 61   config WHERE na
4fc0: 6d 65 3d 27 66 6f 6f 74 65 72 27 22 29 3b 0a 20  me='footer'");. 
4fd0: 20 20 20 63 67 69 5f 72 65 70 6c 61 63 65 5f 70     cgi_replace_p
4fe0: 61 72 61 6d 65 74 65 72 28 22 66 6f 6f 74 65 72  arameter("footer
4ff0: 22 2c 20 7a 44 65 66 61 75 6c 74 46 6f 6f 74 65  ", zDefaultFoote
5000: 72 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20  r);.  }else{.   
5010: 20 74 65 78 74 61 72 65 61 5f 61 74 74 72 69 62   textarea_attrib
5020: 75 74 65 28 30 2c 20 30 2c 20 30 2c 20 22 66 6f  ute(0, 0, 0, "fo
5030: 6f 74 65 72 22 2c 20 22 66 6f 6f 74 65 72 22 2c  oter", "footer",
5040: 20 7a 44 65 66 61 75 6c 74 46 6f 6f 74 65 72 29   zDefaultFooter)
5050: 3b 0a 20 20 7d 0a 20 20 73 74 79 6c 65 5f 68 65  ;.  }.  style_he
5060: 61 64 65 72 28 22 45 64 69 74 20 50 61 67 65 20  ader("Edit Page 
5070: 46 6f 6f 74 65 72 22 29 3b 0a 20 20 40 20 3c 66  Footer");.  @ <f
5080: 6f 72 6d 20 61 63 74 69 6f 6e 3d 22 25 73 28 67  orm action="%s(g
5090: 2e 7a 42 61 73 65 55 52 4c 29 2f 73 65 74 75 70  .zBaseURL)/setup
50a0: 5f 66 6f 6f 74 65 72 22 20 6d 65 74 68 6f 64 3d  _footer" method=
50b0: 22 50 4f 53 54 22 3e 0a 20 20 40 20 3c 70 3e 45  "POST">.  @ <p>E
50c0: 64 69 74 20 48 54 4d 4c 20 74 65 78 74 20 77 69  dit HTML text wi
50d0: 74 68 20 65 6d 62 65 64 64 65 64 20 73 75 62 73  th embedded subs
50e0: 63 72 69 70 74 20 74 68 61 74 20 77 69 6c 6c 20  cript that will 
50f0: 62 65 20 75 73 65 64 20 74 6f 0a 20 20 40 20 67  be used to.  @ g
5100: 65 6e 65 72 61 74 65 20 74 68 65 20 65 6e 64 20  enerate the end 
5110: 6f 66 20 65 76 65 72 79 20 70 61 67 65 2e 3c 2f  of every page.</
5120: 70 3e 0a 20 20 74 65 78 74 61 72 65 61 5f 61 74  p>.  textarea_at
5130: 74 72 69 62 75 74 65 28 22 22 2c 20 32 30 2c 20  tribute("", 20, 
5140: 38 30 2c 20 22 66 6f 6f 74 65 72 22 2c 20 22 66  80, "footer", "f
5150: 6f 6f 74 65 72 22 2c 20 7a 44 65 66 61 75 6c 74  ooter", zDefault
5160: 46 6f 6f 74 65 72 29 3b 0a 20 20 40 20 3c 62 72  Footer);.  @ <br
5170: 20 2f 3e 0a 20 20 40 20 3c 69 6e 70 75 74 20 74   />.  @ <input t
5180: 79 70 65 3d 22 73 75 62 6d 69 74 22 20 6e 61 6d  ype="submit" nam
5190: 65 3d 22 73 75 62 6d 69 74 22 20 76 61 6c 75 65  e="submit" value
51a0: 3d 22 41 70 70 6c 79 20 43 68 61 6e 67 65 73 22  ="Apply Changes"
51b0: 3e 0a 20 20 40 20 3c 69 6e 70 75 74 20 74 79 70  >.  @ <input typ
51c0: 65 3d 22 73 75 62 6d 69 74 22 20 6e 61 6d 65 3d  e="submit" name=
51d0: 22 63 6c 65 61 72 22 20 76 61 6c 75 65 3d 22 52  "clear" value="R
51e0: 65 76 65 72 74 20 54 6f 20 44 65 66 61 75 6c 74  evert To Default
51f0: 22 3e 0a 20 20 40 20 3c 2f 66 6f 72 6d 3e 0a 20  ">.  @ </form>. 
5200: 20 40 20 3c 68 72 3e 0a 20 20 40 20 48 65 72 65   @ <hr>.  @ Here
5210: 20 69 73 20 74 68 65 20 64 65 66 61 75 6c 74 20   is the default 
5220: 70 61 67 65 20 66 6f 6f 74 65 72 3a 0a 20 20 40  page footer:.  @
5230: 20 3c 62 6c 6f 63 6b 71 75 6f 74 65 3e 3c 70 72   <blockquote><pr
5240: 65 3e 0a 20 20 40 20 25 68 28 7a 44 65 66 61 75  e>.  @ %h(zDefau
5250: 6c 74 46 6f 6f 74 65 72 29 0a 20 20 40 20 3c 2f  ltFooter).  @ </
5260: 70 72 65 3e 3c 2f 62 6c 6f 63 6b 71 75 6f 74 65  pre></blockquote
5270: 3e 0a 20 20 64 62 5f 65 6e 64 5f 74 72 61 6e 73  >.  db_end_trans
5280: 61 63 74 69 6f 6e 28 30 29 3b 0a 7d 0a 0a 2f 2a  action(0);.}../*
5290: 0a 2a 2a 20 57 45 42 50 41 47 45 3a 20 73 65 74  .** WEBPAGE: set
52a0: 75 70 5f 74 69 63 6b 65 74 0a 2a 2f 0a 76 6f 69  up_ticket.*/.voi
52b0: 64 20 73 65 74 75 70 5f 74 69 63 6b 65 74 28 76  d setup_ticket(v
52c0: 6f 69 64 29 7b 0a 20 20 63 6f 6e 73 74 20 63 68  oid){.  const ch
52d0: 61 72 20 2a 7a 43 6f 6e 66 69 67 3b 0a 20 20 69  ar *zConfig;.  i
52e0: 6e 74 20 69 73 53 75 62 6d 69 74 3b 0a 20 20 0a  nt isSubmit;.  .
52f0: 20 20 6c 6f 67 69 6e 5f 63 68 65 63 6b 5f 63 72    login_check_cr
5300: 65 64 65 6e 74 69 61 6c 73 28 29 3b 0a 20 20 69  edentials();.  i
5310: 66 28 20 21 67 2e 6f 6b 53 65 74 75 70 20 29 7b  f( !g.okSetup ){
5320: 0a 20 20 20 20 6c 6f 67 69 6e 5f 6e 65 65 64 65  .    login_neede
5330: 64 28 29 3b 0a 20 20 7d 0a 20 20 69 73 53 75 62  d();.  }.  isSub
5340: 6d 69 74 20 3d 20 50 28 22 73 75 62 6d 69 74 22  mit = P("submit"
5350: 29 21 3d 30 3b 0a 20 20 64 62 5f 62 65 67 69 6e  )!=0;.  db_begin
5360: 5f 74 72 61 6e 73 61 63 74 69 6f 6e 28 29 3b 0a  _transaction();.
5370: 20 20 7a 43 6f 6e 66 69 67 20 3d 20 50 28 22 63    zConfig = P("c
5380: 66 67 22 29 3b 0a 20 20 69 66 28 20 7a 43 6f 6e  fg");.  if( zCon
5390: 66 69 67 3d 3d 30 20 29 7b 0a 20 20 20 20 7a 43  fig==0 ){.    zC
53a0: 6f 6e 66 69 67 20 3d 20 64 62 5f 74 65 78 74 28  onfig = db_text(
53b0: 28 63 68 61 72 2a 29 7a 44 65 66 61 75 6c 74 54  (char*)zDefaultT
53c0: 69 63 6b 65 74 43 6f 6e 66 69 67 2c 0a 20 20 20  icketConfig,.   
53d0: 20 20 20 20 20 20 20 20 20 20 20 20 22 53 45 4c              "SEL
53e0: 45 43 54 20 76 61 6c 75 65 20 46 52 4f 4d 20 63  ECT value FROM c
53f0: 6f 6e 66 69 67 20 57 48 45 52 45 20 6e 61 6d 65  onfig WHERE name
5400: 3d 27 74 69 63 6b 65 74 2d 63 6f 6e 66 69 67 75  ='ticket-configu
5410: 72 61 74 69 6f 6e 27 22 29 3b 0a 20 20 7d 0a 20  ration'");.  }. 
5420: 20 73 74 79 6c 65 5f 68 65 61 64 65 72 28 22 45   style_header("E
5430: 64 69 74 20 54 69 63 6b 65 74 20 43 6f 6e 66 69  dit Ticket Confi
5440: 67 75 72 61 74 69 6f 6e 22 29 3b 0a 20 20 69 66  guration");.  if
5450: 28 20 50 28 22 63 6c 65 61 72 22 29 21 3d 30 20  ( P("clear")!=0 
5460: 29 7b 0a 20 20 20 20 64 62 5f 6d 75 6c 74 69 5f  ){.    db_multi_
5470: 65 78 65 63 28 22 44 45 4c 45 54 45 20 46 52 4f  exec("DELETE FRO
5480: 4d 20 63 6f 6e 66 69 67 20 57 48 45 52 45 20 6e  M config WHERE n
5490: 61 6d 65 3d 27 74 69 63 6b 65 74 2d 63 6f 6e 66  ame='ticket-conf
54a0: 69 67 75 72 61 74 69 6f 6e 27 22 29 3b 0a 20 20  iguration'");.  
54b0: 20 20 7a 43 6f 6e 66 69 67 20 3d 20 7a 44 65 66    zConfig = zDef
54c0: 61 75 6c 74 54 69 63 6b 65 74 43 6f 6e 66 69 67  aultTicketConfig
54d0: 3b 0a 20 20 7d 65 6c 73 65 20 69 66 28 20 69 73  ;.  }else if( is
54e0: 53 75 62 6d 69 74 20 29 7b 0a 20 20 20 20 63 68  Submit ){.    ch
54f0: 61 72 20 2a 7a 45 72 72 20 3d 20 74 69 63 6b 65  ar *zErr = ticke
5500: 74 5f 63 6f 6e 66 69 67 5f 63 68 65 63 6b 28 7a  t_config_check(z
5510: 43 6f 6e 66 69 67 29 3b 0a 20 20 20 20 69 66 28  Config);.    if(
5520: 20 7a 45 72 72 3d 3d 30 20 29 7b 0a 20 20 20 20   zErr==0 ){.    
5530: 20 20 64 62 5f 6d 75 6c 74 69 5f 65 78 65 63 28    db_multi_exec(
5540: 0a 20 20 20 20 20 20 20 20 20 22 52 45 50 4c 41  .         "REPLA
5550: 43 45 20 49 4e 54 4f 20 63 6f 6e 66 69 67 28 6e  CE INTO config(n
5560: 61 6d 65 2c 76 61 6c 75 65 29 20 56 41 4c 55 45  ame,value) VALUE
5570: 53 28 27 74 69 63 6b 65 74 2d 63 6f 6e 66 69 67  S('ticket-config
5580: 75 72 61 74 69 6f 6e 27 2c 22 0a 20 20 20 20 20  uration',".     
5590: 20 20 20 20 22 25 51 29 22 2c 20 7a 43 6f 6e 66      "%Q)", zConf
55a0: 69 67 0a 20 20 20 20 20 20 29 3b 0a 20 20 20 20  ig.      );.    
55b0: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 40 20 3c  }else{.      @ <
55c0: 70 3e 3c 66 6f 6e 74 20 63 6f 6c 6f 72 3d 22 72  p><font color="r
55d0: 65 64 22 3e 3c 62 3e 0a 20 20 20 20 20 20 40 20  ed"><b>.      @ 
55e0: 53 43 52 49 50 54 20 45 52 52 4f 52 3a 20 25 68  SCRIPT ERROR: %h
55f0: 28 7a 45 72 72 29 0a 20 20 20 20 20 20 40 20 3c  (zErr).      @ <
5600: 2f 62 3e 3c 2f 66 6f 6e 74 3e 3c 2f 70 3e 0a 20  /b></font></p>. 
5610: 20 20 20 7d 0a 20 20 7d 0a 20 20 40 20 3c 66 6f     }.  }.  @ <fo
5620: 72 6d 20 61 63 74 69 6f 6e 3d 22 25 73 28 67 2e  rm action="%s(g.
5630: 7a 42 61 73 65 55 52 4c 29 2f 73 65 74 75 70 5f  zBaseURL)/setup_
5640: 74 69 63 6b 65 74 22 20 6d 65 74 68 6f 64 3d 22  ticket" method="
5650: 50 4f 53 54 22 3e 0a 20 20 40 20 3c 70 3e 45 64  POST">.  @ <p>Ed
5660: 69 74 20 74 68 65 20 22 73 75 62 73 63 72 69 70  it the "subscrip
5670: 74 22 20 73 63 72 69 70 74 20 74 68 61 74 20 64  t" script that d
5680: 65 66 69 6e 65 73 20 74 68 65 20 74 69 63 6b 65  efines the ticke
5690: 74 69 6e 67 0a 20 20 40 20 73 79 73 74 65 6d 20  ting.  @ system 
56a0: 73 65 74 75 70 20 66 6f 72 20 74 68 69 73 20 73  setup for this s
56b0: 65 72 76 65 72 2e 3c 2f 70 3e 0a 20 20 40 20 3c  erver.</p>.  @ <
56c0: 74 65 78 74 61 72 65 61 20 6e 61 6d 65 3d 22 63  textarea name="c
56d0: 66 67 22 20 72 6f 77 73 3d 22 34 30 22 20 63 6f  fg" rows="40" co
56e0: 6c 73 3d 22 38 30 22 3e 25 68 28 7a 43 6f 6e 66  ls="80">%h(zConf
56f0: 69 67 29 3c 2f 74 65 78 74 61 72 65 61 3e 0a 20  ig)</textarea>. 
5700: 20 40 20 3c 62 72 20 2f 3e 0a 20 20 40 20 3c 69   @ <br />.  @ <i
5710: 6e 70 75 74 20 74 79 70 65 3d 22 73 75 62 6d 69  nput type="submi
5720: 74 22 20 6e 61 6d 65 3d 22 73 75 62 6d 69 74 22  t" name="submit"
5730: 20 76 61 6c 75 65 3d 22 41 70 70 6c 79 20 43 68   value="Apply Ch
5740: 61 6e 67 65 73 22 3e 0a 20 20 40 20 3c 69 6e 70  anges">.  @ <inp
5750: 75 74 20 74 79 70 65 3d 22 73 75 62 6d 69 74 22  ut type="submit"
5760: 20 6e 61 6d 65 3d 22 63 6c 65 61 72 22 20 76 61   name="clear" va
5770: 6c 75 65 3d 22 52 65 76 65 72 74 20 54 6f 20 44  lue="Revert To D
5780: 65 66 61 75 6c 74 22 3e 0a 20 20 40 20 3c 2f 66  efault">.  @ </f
5790: 6f 72 6d 3e 0a 20 20 40 20 3c 68 72 3e 0a 20 20  orm>.  @ <hr>.  
57a0: 40 20 48 65 72 65 20 69 73 20 74 68 65 20 64 65  @ Here is the de
57b0: 66 61 75 6c 74 20 70 61 67 65 20 68 65 61 64 65  fault page heade
57c0: 72 3a 0a 20 20 40 20 3c 62 6c 6f 63 6b 71 75 6f  r:.  @ <blockquo
57d0: 74 65 3e 3c 70 72 65 3e 0a 20 20 40 20 25 68 28  te><pre>.  @ %h(
57e0: 7a 44 65 66 61 75 6c 74 54 69 63 6b 65 74 43 6f  zDefaultTicketCo
57f0: 6e 66 69 67 29 0a 20 20 40 20 3c 2f 70 72 65 3e  nfig).  @ </pre>
5800: 3c 2f 62 6c 6f 63 6b 71 75 6f 74 65 3e 0a 20 20  </blockquote>.  
5810: 64 62 5f 65 6e 64 5f 74 72 61 6e 73 61 63 74 69  db_end_transacti
5820: 6f 6e 28 30 29 3b 0a 7d 0a                       on(0);.}.