Hex Artifact Content
Not logged in

Artifact cb7dcac5a10b598b7e5b03a69eda022ece1b899f:

File src/setup.c part of check-in [dbda8d6ce9] - Initial check-in of m1 sources. by drh on 2007-07-21 14:10:57.

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 20 0a 2a 2a 20 59 6f 75 20 73 68 6f 75  .** .** You shou
0230: 6c 64 20 68 61 76 65 20 72 65 63 65 69 76 65 64  ld have received
0240: 20 61 20 63 6f 70 79 20 6f 66 20 74 68 65 20 47   a copy of the G
0250: 4e 55 20 47 65 6e 65 72 61 6c 20 50 75 62 6c 69  NU General Publi
0260: 63 0a 2a 2a 20 4c 69 63 65 6e 73 65 20 61 6c 6f  c.** License alo
0270: 6e 67 20 77 69 74 68 20 74 68 69 73 20 6c 69 62  ng with this lib
0280: 72 61 72 79 3b 20 69 66 20 6e 6f 74 2c 20 77 72  rary; if not, wr
0290: 69 74 65 20 74 6f 20 74 68 65 0a 2a 2a 20 46 72  ite to the.** Fr
02a0: 65 65 20 53 6f 66 74 77 61 72 65 20 46 6f 75 6e  ee Software Foun
02b0: 64 61 74 69 6f 6e 2c 20 49 6e 63 2e 2c 20 35 39  dation, Inc., 59
02c0: 20 54 65 6d 70 6c 65 20 50 6c 61 63 65 20 2d 20   Temple Place - 
02d0: 53 75 69 74 65 20 33 33 30 2c 0a 2a 2a 20 42 6f  Suite 330,.** Bo
02e0: 73 74 6f 6e 2c 20 4d 41 20 20 30 32 31 31 31 2d  ston, MA  02111-
02f0: 31 33 30 37 2c 20 55 53 41 2e 0a 2a 2a 0a 2a 2a  1307, USA..**.**
0300: 20 41 75 74 68 6f 72 20 63 6f 6e 74 61 63 74 20   Author contact 
0310: 69 6e 66 6f 72 6d 61 74 69 6f 6e 3a 0a 2a 2a 20  information:.** 
0320: 20 20 64 72 68 40 68 77 61 63 69 2e 63 6f 6d 0a    drh@hwaci.com.
0330: 2a 2a 20 20 20 68 74 74 70 3a 2f 2f 77 77 77 2e  **   http://www.
0340: 68 77 61 63 69 2e 63 6f 6d 2f 64 72 68 2f 0a 2a  hwaci.com/drh/.*
0350: 2a 0a 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: 2a 0a 2a 2a 0a 2a 2a 20 49 6d 70 6c 65 6d 65 6e  *.**.** Implemen
03b0: 74 61 74 69 6f 6e 20 6f 66 20 74 68 65 20 53 65  tation of the Se
03c0: 74 75 70 20 70 61 67 65 0a 2a 2f 0a 23 69 6e 63  tup page.*/.#inc
03d0: 6c 75 64 65 20 3c 61 73 73 65 72 74 2e 68 3e 0a  lude <assert.h>.
03e0: 23 69 6e 63 6c 75 64 65 20 22 63 6f 6e 66 69 67  #include "config
03f0: 2e 68 22 0a 23 69 6e 63 6c 75 64 65 20 22 73 65  .h".#include "se
0400: 74 75 70 2e 68 22 0a 0a 0a 2f 2a 0a 2a 2a 20 4f  tup.h".../*.** O
0410: 75 74 70 75 74 20 61 20 73 69 6e 67 6c 65 20 65  utput a single e
0420: 6e 74 72 79 20 66 6f 72 20 61 20 6d 65 6e 75 20  ntry for a menu 
0430: 67 65 6e 65 72 61 74 65 64 20 75 73 69 6e 67 20  generated using 
0440: 61 6e 20 48 54 4d 4c 20 74 61 62 6c 65 2e 0a 2a  an HTML table..*
0450: 2a 20 49 66 20 7a 4c 69 6e 6b 20 69 73 20 6e 6f  * If zLink is no
0460: 74 20 4e 55 4c 4c 20 6f 72 20 61 6e 20 65 6d 70  t NULL or an emp
0470: 74 79 20 73 74 72 69 6e 67 2c 20 74 68 65 6e 20  ty string, then 
0480: 69 74 20 69 73 20 74 68 65 20 70 61 67 65 20 74  it is the page t
0490: 68 61 74 0a 2a 2a 20 74 68 65 20 6d 65 6e 75 20  hat.** the menu 
04a0: 65 6e 74 72 79 20 77 69 6c 6c 20 68 79 70 65 72  entry will hyper
04b0: 6c 69 6e 6b 20 74 6f 2e 20 20 49 66 20 7a 4c 69  link to.  If zLi
04c0: 6e 6b 20 69 73 20 4e 55 4c 4c 20 6f 72 20 22 22  nk is NULL or ""
04d0: 2c 20 74 68 65 6e 0a 2a 2a 20 74 68 65 20 6d 65  , then.** the me
04e0: 6e 75 20 65 6e 74 72 79 20 68 61 73 20 6e 6f 20  nu entry has no 
04f0: 68 79 70 65 72 6c 69 6e 6b 20 2d 20 69 74 20 69  hyperlink - it i
0500: 73 20 64 69 73 61 62 6c 65 64 2e 0a 2a 2f 0a 73  s disabled..*/.s
0510: 74 61 74 69 63 20 76 6f 69 64 20 6d 65 6e 75 5f  tatic void menu_
0520: 65 6e 74 72 79 28 0a 20 20 63 6f 6e 73 74 20 63  entry(.  const c
0530: 68 61 72 20 2a 7a 54 69 74 6c 65 2c 0a 20 20 63  har *zTitle,.  c
0540: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 4c 69 6e 6b  onst char *zLink
0550: 2c 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  ,.  const char *
0560: 7a 44 65 73 63 0a 29 7b 0a 20 20 40 20 3c 64 74  zDesc.){.  @ <dt
0570: 3e 0a 20 20 69 66 28 20 7a 4c 69 6e 6b 20 26 26  >.  if( zLink &&
0580: 20 7a 4c 69 6e 6b 5b 30 5d 20 29 7b 0a 20 20 20   zLink[0] ){.   
0590: 20 40 20 3c 61 20 68 72 65 66 3d 22 25 73 28 7a   @ <a href="%s(z
05a0: 4c 69 6e 6b 29 22 3e 25 68 28 7a 54 69 74 6c 65  Link)">%h(zTitle
05b0: 29 3c 2f 61 3e 0a 20 20 7d 65 6c 73 65 7b 0a 20  )</a>.  }else{. 
05c0: 20 20 20 40 20 25 68 28 7a 54 69 74 6c 65 29 0a     @ %h(zTitle).
05d0: 20 20 7d 0a 20 20 40 20 3c 2f 64 74 3e 0a 20 20    }.  @ </dt>.  
05e0: 40 20 3c 64 64 3e 25 68 28 7a 44 65 73 63 29 3c  @ <dd>%h(zDesc)<
05f0: 2f 64 64 3e 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 57 45  /dd>.}../*.** WE
0600: 42 50 41 47 45 3a 20 2f 73 65 74 75 70 0a 2a 2f  BPAGE: /setup.*/
0610: 0a 76 6f 69 64 20 73 65 74 75 70 5f 70 61 67 65  .void setup_page
0620: 28 76 6f 69 64 29 7b 0a 20 20 6c 6f 67 69 6e 5f  (void){.  login_
0630: 63 68 65 63 6b 5f 63 72 65 64 65 6e 74 69 61 6c  check_credential
0640: 73 28 29 3b 0a 20 20 69 66 28 20 21 67 2e 6f 6b  s();.  if( !g.ok
0650: 53 65 74 75 70 20 29 7b 0a 20 20 20 20 6c 6f 67  Setup ){.    log
0660: 69 6e 5f 6e 65 65 64 65 64 28 29 3b 0a 20 20 7d  in_needed();.  }
0670: 0a 0a 20 20 73 74 79 6c 65 5f 68 65 61 64 65 72  ..  style_header
0680: 28 29 3b 0a 0a 20 20 40 20 3c 64 6c 20 69 64 3d  ();..  @ <dl id=
0690: 22 73 65 74 75 70 22 3e 0a 20 20 6d 65 6e 75 5f  "setup">.  menu_
06a0: 65 6e 74 72 79 28 22 55 73 65 72 73 22 2c 20 22  entry("Users", "
06b0: 73 65 74 75 70 5f 75 6c 69 73 74 22 2c 0a 20 20  setup_ulist",.  
06c0: 20 20 22 47 72 61 6e 74 20 70 72 69 76 69 6c 65    "Grant privile
06d0: 67 65 73 20 74 6f 20 69 6e 64 69 76 69 64 75 61  ges to individua
06e0: 6c 20 75 73 65 72 73 2e 22 29 3b 0a 20 20 6d 65  l users.");.  me
06f0: 6e 75 5f 65 6e 74 72 79 28 22 41 63 63 65 73 73  nu_entry("Access
0700: 22 2c 20 22 73 65 74 75 70 5f 61 63 63 65 73 73  ", "setup_access
0710: 22 2c 0a 20 20 20 20 22 43 6f 6e 74 72 6f 6c 20  ",.    "Control 
0720: 61 63 63 65 73 73 20 73 65 74 74 69 6e 67 73 2e  access settings.
0730: 22 29 3b 0a 20 20 40 20 3c 2f 64 6c 3e 0a 0a 20  ");.  @ </dl>.. 
0740: 20 73 74 79 6c 65 5f 66 6f 6f 74 65 72 28 29 3b   style_footer();
0750: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 57 45 42 50 41 47  .}../*.** WEBPAG
0760: 45 3a 20 73 65 74 75 70 5f 75 6c 69 73 74 0a 2a  E: setup_ulist.*
0770: 2a 0a 2a 2a 20 53 68 6f 77 20 61 20 6c 69 73 74  *.** Show a list
0780: 20 6f 66 20 75 73 65 72 73 2e 20 20 43 6c 69 63   of users.  Clic
0790: 6b 69 6e 67 20 6f 6e 20 61 6e 79 20 75 73 65 72  king on any user
07a0: 20 6a 75 6d 70 73 20 74 6f 20 74 68 65 20 65 64   jumps to the ed
07b0: 69 74 0a 2a 2a 20 73 63 72 65 65 6e 20 66 6f 72  it.** screen for
07c0: 20 74 68 61 74 20 75 73 65 72 2e 0a 2a 2f 0a 76   that user..*/.v
07d0: 6f 69 64 20 73 65 74 75 70 5f 75 6c 69 73 74 28  oid setup_ulist(
07e0: 76 6f 69 64 29 7b 0a 20 20 53 74 6d 74 20 73 3b  void){.  Stmt s;
07f0: 0a 20 20 6c 6f 67 69 6e 5f 63 68 65 63 6b 5f 63  .  login_check_c
0800: 72 65 64 65 6e 74 69 61 6c 73 28 29 3b 0a 20 20  redentials();.  
0810: 69 66 28 20 21 67 2e 6f 6b 53 65 74 75 70 20 29  if( !g.okSetup )
0820: 7b 0a 20 20 20 20 6c 6f 67 69 6e 5f 6e 65 65 64  {.    login_need
0830: 65 64 28 29 3b 0a 20 20 7d 0a 0a 20 20 73 74 79  ed();.  }..  sty
0840: 6c 65 5f 68 65 61 64 65 72 28 29 3b 0a 0a 20 20  le_header();..  
0850: 40 20 3c 74 61 62 6c 65 20 62 6f 72 64 65 72 3d  @ <table border=
0860: 22 30 22 20 63 65 6c 6c 70 61 64 64 69 6e 67 3d  "0" cellpadding=
0870: 22 30 22 20 63 65 6c 6c 73 70 61 63 69 6e 67 3d  "0" cellspacing=
0880: 22 30 22 3e 0a 20 20 64 62 5f 70 72 65 70 61 72  "0">.  db_prepar
0890: 65 28 26 73 2c 20 22 53 45 4c 45 43 54 20 75 69  e(&s, "SELECT ui
08a0: 64 2c 20 6c 6f 67 69 6e 2c 20 63 61 70 20 46 52  d, login, cap FR
08b0: 4f 4d 20 72 65 70 75 73 65 72 20 4f 52 44 45 52  OM repuser ORDER
08c0: 20 42 59 20 6c 6f 67 69 6e 22 29 3b 0a 20 20 77   BY login");.  w
08d0: 68 69 6c 65 28 20 64 62 5f 73 74 65 70 28 26 73  hile( db_step(&s
08e0: 29 3d 3d 53 51 4c 49 54 45 5f 52 4f 57 20 29 7b  )==SQLITE_ROW ){
08f0: 0a 20 20 20 20 40 20 3c 74 72 3e 3c 74 64 3e 3c  .    @ <tr><td><
0900: 61 20 68 72 65 66 3d 22 25 73 28 67 2e 7a 42 61  a href="%s(g.zBa
0910: 73 65 55 52 4c 29 2f 73 65 74 75 70 5f 75 65 64  seURL)/setup_ued
0920: 69 74 3f 75 69 64 3d 25 64 28 64 62 5f 63 6f 6c  it?uid=%d(db_col
0930: 75 6d 6e 5f 69 6e 74 28 26 73 2c 30 29 29 22 3e  umn_int(&s,0))">
0940: 0a 20 20 20 20 40 20 25 68 28 64 62 5f 63 6f 6c  .    @ %h(db_col
0950: 75 6d 6e 5f 74 65 78 74 28 26 73 2c 31 29 29 3c  umn_text(&s,1))<
0960: 2f 61 3e 3c 2f 74 64 3e 3c 74 64 20 77 69 64 74  /a></td><td widt
0970: 68 3d 22 31 30 22 3e 3c 2f 74 64 3e 0a 20 20 20  h="10"></td>.   
0980: 20 40 20 3c 74 64 3e 25 68 28 64 62 5f 63 6f 6c   @ <td>%h(db_col
0990: 75 6d 6e 5f 74 65 78 74 28 26 73 2c 32 29 29 3c  umn_text(&s,2))<
09a0: 2f 74 64 3e 3c 2f 74 72 3e 0a 20 20 7d 0a 20 20  /td></tr>.  }.  
09b0: 64 62 5f 66 69 6e 61 6c 69 7a 65 28 26 73 29 3b  db_finalize(&s);
09c0: 0a 20 20 40 20 3c 2f 74 61 62 6c 65 3e 0a 20 20  .  @ </table>.  
09d0: 0a 20 20 73 74 79 6c 65 5f 66 6f 6f 74 65 72 28  .  style_footer(
09e0: 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 57 45 42 50  );.}../*.** WEBP
09f0: 41 47 45 3a 20 73 65 74 75 70 5f 75 65 64 69 74  AGE: setup_uedit
0a00: 0a 2a 2a 0a 2a 2a 20 45 64 69 74 20 74 68 65 20  .**.** Edit the 
0a10: 75 73 65 72 20 77 69 74 68 20 52 45 50 55 53 45  user with REPUSE
0a20: 52 2e 55 49 44 20 65 71 75 61 6c 20 74 6f 20 74  R.UID equal to t
0a30: 68 65 20 22 75 22 20 71 75 65 72 79 20 70 61 72  he "u" query par
0a40: 61 6d 65 74 65 72 2e 0a 2a 2f 0a 76 6f 69 64 20  ameter..*/.void 
0a50: 73 65 74 75 70 5f 75 65 64 69 74 28 76 6f 69 64  setup_uedit(void
0a60: 29 7b 0a 20 20 69 6e 74 20 75 69 64 3b 0a 0a 20  ){.  int uid;.. 
0a70: 20 6c 6f 67 69 6e 5f 63 68 65 63 6b 5f 63 72 65   login_check_cre
0a80: 64 65 6e 74 69 61 6c 73 28 29 3b 0a 20 20 69 66  dentials();.  if
0a90: 28 20 21 67 2e 6f 6b 53 65 74 75 70 20 29 7b 0a  ( !g.okSetup ){.
0aa0: 20 20 20 20 6c 6f 67 69 6e 5f 6e 65 65 64 65 64      login_needed
0ab0: 28 29 3b 0a 20 20 7d 0a 20 20 75 69 64 20 3d 20  ();.  }.  uid = 
0ac0: 61 74 6f 69 28 50 44 28 22 75 22 2c 22 30 22 29  atoi(PD("u","0")
0ad0: 29 3b 0a 20 20 69 66 28 20 75 69 64 3c 3d 30 20  );.  if( uid<=0 
0ae0: 29 7b 0a 20 20 20 20 63 67 69 5f 72 65 64 69 72  ){.    cgi_redir
0af0: 65 63 74 28 22 73 65 74 75 70 5f 75 6c 69 73 74  ect("setup_ulist
0b00: 22 29 3b 0a 20 20 20 20 61 73 73 65 72 74 28 30  ");.    assert(0
0b10: 29 3b 0a 20 20 7d 0a 20 20 73 74 79 6c 65 5f 68  );.  }.  style_h
0b20: 65 61 64 65 72 28 29 3b 0a 20 20 73 74 79 6c 65  eader();.  style
0b30: 5f 66 6f 6f 74 65 72 28 29 3b 20 0a 7d 0a 0a 2f  _footer(); .}../
0b40: 2a 0a 2a 2a 20 47 65 6e 65 72 61 74 65 20 61 20  *.** Generate a 
0b50: 63 68 65 63 6b 62 6f 78 20 66 6f 72 20 61 6e 20  checkbox for an 
0b60: 61 74 74 72 69 62 75 74 65 2e 0a 2a 2f 0a 73 74  attribute..*/.st
0b70: 61 74 69 63 20 76 6f 69 64 20 6f 6e 6f 66 66 5f  atic void onoff_
0b80: 61 74 74 72 69 62 75 74 65 28 0a 20 20 63 6f 6e  attribute(.  con
0b90: 73 74 20 63 68 61 72 20 2a 7a 4c 61 62 65 6c 2c  st char *zLabel,
0ba0: 20 20 20 2f 2a 20 54 68 65 20 74 65 78 74 20 6c     /* The text l
0bb0: 61 62 65 6c 20 6f 6e 20 74 68 65 20 63 68 65 63  abel on the chec
0bc0: 6b 62 6f 78 20 2a 2f 0a 20 20 63 6f 6e 73 74 20  kbox */.  const 
0bd0: 63 68 61 72 20 2a 7a 56 61 72 2c 20 20 20 20 20  char *zVar,     
0be0: 2f 2a 20 54 68 65 20 63 6f 72 72 65 73 70 6f 6e  /* The correspon
0bf0: 64 69 6e 67 20 72 6f 77 20 69 6e 20 74 68 65 20  ding row in the 
0c00: 56 41 52 20 74 61 62 6c 65 20 2a 2f 0a 20 20 63  VAR table */.  c
0c10: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 51 50 61 72  onst char *zQPar
0c20: 6d 2c 20 20 20 2f 2a 20 54 68 65 20 71 75 65 72  m,   /* The quer
0c30: 79 20 70 61 72 61 6d 65 74 65 72 20 2a 2f 0a 20  y parameter */. 
0c40: 20 69 6e 74 20 64 66 6c 74 56 61 6c 20 20 20 20   int dfltVal    
0c50: 20 20 20 20 20 20 20 2f 2a 20 44 65 66 61 75 6c         /* Defaul
0c60: 74 20 76 61 6c 75 65 20 69 66 20 56 41 52 20 74  t value if VAR t
0c70: 61 62 6c 65 20 65 6e 74 72 79 20 64 6f 65 73 20  able entry does 
0c80: 6e 6f 74 20 65 78 69 73 74 20 2a 2f 0a 29 7b 0a  not exist */.){.
0c90: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 56    const char *zV
0ca0: 61 6c 20 3d 20 64 62 5f 67 65 74 28 7a 56 61 72  al = db_get(zVar
0cb0: 2c 20 30 29 3b 0a 20 20 63 6f 6e 73 74 20 63 68  , 0);.  const ch
0cc0: 61 72 20 2a 7a 51 20 3d 20 50 28 7a 51 50 61 72  ar *zQ = P(zQPar
0cd0: 6d 29 3b 0a 20 20 69 6e 74 20 69 56 61 6c 3b 0a  m);.  int iVal;.
0ce0: 20 20 69 66 28 20 7a 56 61 6c 20 29 7b 0a 20 20    if( zVal ){.  
0cf0: 20 20 69 56 61 6c 20 3d 20 61 74 6f 69 28 7a 56    iVal = atoi(zV
0d00: 61 6c 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20  al);.  }else{.  
0d10: 20 20 69 56 61 6c 20 3d 20 64 66 6c 74 56 61 6c    iVal = dfltVal
0d20: 3b 0a 20 20 7d 0a 20 20 69 66 28 20 7a 51 3d 3d  ;.  }.  if( zQ==
0d30: 30 20 26 26 20 50 28 22 73 75 62 6d 69 74 22 29  0 && P("submit")
0d40: 20 29 7b 0a 20 20 20 20 7a 51 20 3d 20 22 6f 66   ){.    zQ = "of
0d50: 66 22 3b 0a 20 20 7d 0a 20 20 69 66 28 20 7a 51  f";.  }.  if( zQ
0d60: 20 29 7b 0a 20 20 20 20 69 6e 74 20 69 51 20 3d   ){.    int iQ =
0d70: 20 73 74 72 63 6d 70 28 7a 51 2c 22 6f 6e 22 29   strcmp(zQ,"on")
0d80: 3d 3d 30 20 7c 7c 20 61 74 6f 69 28 7a 51 29 3b  ==0 || atoi(zQ);
0d90: 0a 20 20 20 20 69 66 28 20 69 51 21 3d 69 56 61  .    if( iQ!=iVa
0da0: 6c 20 29 7b 0a 20 20 20 20 20 20 64 62 5f 73 65  l ){.      db_se
0db0: 74 28 7a 56 61 72 2c 20 69 51 20 3f 20 22 31 22  t(zVar, iQ ? "1"
0dc0: 20 3a 20 22 30 22 29 3b 0a 20 20 20 20 20 20 69   : "0");.      i
0dd0: 56 61 6c 20 3d 20 69 51 3b 0a 20 20 20 20 7d 0a  Val = iQ;.    }.
0de0: 20 20 7d 0a 20 20 69 66 28 20 69 56 61 6c 20 29    }.  if( iVal )
0df0: 7b 0a 20 20 20 20 40 20 3c 69 6e 70 75 74 20 74  {.    @ <input t
0e00: 79 70 65 3d 22 63 68 65 63 6b 62 6f 78 22 20 6e  ype="checkbox" n
0e10: 61 6d 65 3d 22 25 73 28 7a 51 50 61 72 6d 29 22  ame="%s(zQParm)"
0e20: 20 63 68 65 63 6b 65 64 3e 25 73 28 7a 4c 61 62   checked>%s(zLab
0e30: 65 6c 29 3c 2f 69 6e 70 75 74 3e 0a 20 20 7d 65  el)</input>.  }e
0e40: 6c 73 65 7b 0a 20 20 20 20 40 20 3c 69 6e 70 75  lse{.    @ <inpu
0e50: 74 20 74 79 70 65 3d 22 63 68 65 63 6b 62 6f 78  t type="checkbox
0e60: 22 20 6e 61 6d 65 3d 22 25 73 28 7a 51 50 61 72  " name="%s(zQPar
0e70: 6d 29 22 3e 25 73 28 7a 4c 61 62 65 6c 29 3c 2f  m)">%s(zLabel)</
0e80: 69 6e 70 75 74 3e 0a 20 20 7d 0a 7d 0a 0a 2f 2a  input>.  }.}../*
0e90: 0a 2a 2a 20 47 65 6e 65 72 61 74 65 20 61 6e 20  .** Generate an 
0ea0: 65 6e 74 72 79 20 62 6f 78 20 66 6f 72 20 61 6e  entry box for an
0eb0: 20 61 74 74 72 69 62 75 74 65 2e 0a 2a 2f 0a 73   attribute..*/.s
0ec0: 74 61 74 69 63 20 76 6f 69 64 20 65 6e 74 72 79  tatic void entry
0ed0: 5f 61 74 74 72 69 62 75 74 65 28 0a 20 20 63 6f  _attribute(.  co
0ee0: 6e 73 74 20 63 68 61 72 20 2a 7a 4c 61 62 65 6c  nst char *zLabel
0ef0: 2c 20 20 20 2f 2a 20 54 68 65 20 74 65 78 74 20  ,   /* The text 
0f00: 6c 61 62 65 6c 20 6f 6e 20 74 68 65 20 65 6e 74  label on the ent
0f10: 72 79 20 62 6f 78 20 2a 2f 0a 20 20 69 6e 74 20  ry box */.  int 
0f20: 77 69 64 74 68 2c 20 20 20 20 20 20 20 20 20 20  width,          
0f30: 20 20 2f 2a 20 57 69 64 74 68 20 6f 66 20 74 68    /* Width of th
0f40: 65 20 65 6e 74 72 79 20 62 6f 78 20 2a 2f 0a 20  e entry box */. 
0f50: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 56 61   const char *zVa
0f60: 72 2c 20 20 20 20 20 2f 2a 20 54 68 65 20 63 6f  r,     /* The co
0f70: 72 72 65 73 70 6f 6e 64 69 6e 67 20 72 6f 77 20  rresponding row 
0f80: 69 6e 20 74 68 65 20 56 41 52 20 74 61 62 6c 65  in the VAR table
0f90: 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61 72   */.  const char
0fa0: 20 2a 7a 51 50 61 72 6d 2c 20 20 20 2f 2a 20 54   *zQParm,   /* T
0fb0: 68 65 20 71 75 65 72 79 20 70 61 72 61 6d 65 74  he query paramet
0fc0: 65 72 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 63 68  er */.  const ch
0fd0: 61 72 20 2a 7a 44 66 6c 74 20 20 20 20 20 2f 2a  ar *zDflt     /*
0fe0: 20 44 65 66 61 75 6c 74 20 76 61 6c 75 65 20 69   Default value i
0ff0: 66 20 56 41 52 20 74 61 62 6c 65 20 65 6e 74 72  f VAR table entr
1000: 79 20 64 6f 65 73 20 6e 6f 74 20 65 78 69 73 74  y does not exist
1010: 20 2a 2f 0a 29 7b 0a 20 20 63 6f 6e 73 74 20 63   */.){.  const c
1020: 68 61 72 20 2a 7a 56 61 6c 20 3d 20 64 62 5f 67  har *zVal = db_g
1030: 65 74 28 7a 56 61 72 2c 20 7a 44 66 6c 74 29 3b  et(zVar, zDflt);
1040: 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  .  const char *z
1050: 51 20 3d 20 50 28 7a 51 50 61 72 6d 29 3b 0a 20  Q = P(zQParm);. 
1060: 20 69 66 28 20 7a 51 20 26 26 20 73 74 72 63 6d   if( zQ && strcm
1070: 70 28 7a 51 2c 7a 56 61 6c 29 21 3d 30 20 29 7b  p(zQ,zVal)!=0 ){
1080: 0a 20 20 20 20 64 62 5f 73 65 74 28 7a 56 61 72  .    db_set(zVar
1090: 2c 20 7a 51 29 3b 0a 20 20 20 20 7a 56 61 6c 20  , zQ);.    zVal 
10a0: 3d 20 7a 51 3b 0a 20 20 7d 0a 20 20 40 20 3c 69  = zQ;.  }.  @ <i
10b0: 6e 70 75 74 20 74 79 70 65 3d 22 74 65 78 74 22  nput type="text"
10c0: 20 6e 61 6d 65 3d 22 25 73 28 7a 51 50 61 72 6d   name="%s(zQParm
10d0: 29 22 20 76 61 6c 75 65 3d 22 25 68 28 7a 56 61  )" value="%h(zVa
10e0: 6c 29 22 20 73 69 7a 65 3d 22 25 64 28 77 69 64  l)" size="%d(wid
10f0: 74 68 29 22 3e 0a 20 20 40 20 25 73 28 7a 4c 61  th)">.  @ %s(zLa
1100: 62 65 6c 29 0a 7d 0a 0a 0a 0a 2f 2a 0a 2a 2a 20  bel).}..../*.** 
1110: 57 45 42 50 41 47 45 3a 20 73 65 74 75 70 5f 61  WEBPAGE: setup_a
1120: 63 63 65 73 73 0a 2a 2f 0a 76 6f 69 64 20 73 65  ccess.*/.void se
1130: 74 75 70 5f 61 63 63 65 73 73 28 76 6f 69 64 29  tup_access(void)
1140: 7b 0a 20 20 6c 6f 67 69 6e 5f 63 68 65 63 6b 5f  {.  login_check_
1150: 63 72 65 64 65 6e 74 69 61 6c 73 28 29 3b 0a 20  credentials();. 
1160: 20 69 66 28 20 21 67 2e 6f 6b 53 65 74 75 70 20   if( !g.okSetup 
1170: 29 7b 0a 20 20 20 20 6c 6f 67 69 6e 5f 6e 65 65  ){.    login_nee
1180: 64 65 64 28 29 3b 0a 20 20 7d 0a 0a 20 20 73 74  ded();.  }..  st
1190: 79 6c 65 5f 68 65 61 64 65 72 28 29 3b 0a 20 20  yle_header();.  
11a0: 64 62 5f 62 65 67 69 6e 5f 74 72 61 6e 73 61 63  db_begin_transac
11b0: 74 69 6f 6e 28 29 3b 0a 20 20 40 20 3c 66 6f 72  tion();.  @ <for
11c0: 6d 20 61 63 74 69 6f 6e 3d 22 25 73 28 67 2e 7a  m action="%s(g.z
11d0: 42 61 73 65 55 52 4c 29 2f 73 65 74 75 70 5f 61  BaseURL)/setup_a
11e0: 63 63 65 73 73 22 20 6d 65 74 68 6f 64 3d 22 47  ccess" method="G
11f0: 45 54 22 3e 0a 0a 20 20 40 20 3c 68 72 3e 0a 20  ET">..  @ <hr>. 
1200: 20 6f 6e 6f 66 66 5f 61 74 74 72 69 62 75 74 65   onoff_attribute
1210: 28 22 52 65 71 75 69 72 65 20 70 61 73 73 77 6f  ("Require passwo
1220: 72 64 20 66 6f 72 20 6c 6f 63 61 6c 20 61 63 63  rd for local acc
1230: 65 73 73 22 2c 0a 20 20 20 20 20 22 61 75 74 68  ess",.     "auth
1240: 65 6e 74 69 63 61 74 65 2d 6c 6f 63 61 6c 68 6f  enticate-localho
1250: 73 74 22 2c 20 22 6c 6f 63 61 6c 61 75 74 68 22  st", "localauth"
1260: 2c 20 31 29 3b 0a 20 20 40 20 3c 70 3e 57 68 65  , 1);.  @ <p>Whe
1270: 6e 20 65 6e 61 62 6c 65 64 2c 20 74 68 65 20 70  n enabled, the p
1280: 61 73 73 77 6f 72 64 20 73 69 67 6e 2d 69 6e 20  assword sign-in 
1290: 69 73 20 72 65 71 75 69 72 65 64 20 66 6f 72 0a  is required for.
12a0: 20 20 40 20 77 65 62 20 61 63 63 65 73 73 20 63    @ web access c
12b0: 6f 6d 69 6e 67 20 66 72 6f 6d 20 31 32 37 2e 30  oming from 127.0
12c0: 2e 30 2e 31 2e 20 20 57 68 65 6e 20 64 69 73 61  .0.1.  When disa
12d0: 62 6c 65 64 2c 20 77 65 62 20 61 63 63 65 73 73  bled, web access
12e0: 0a 20 20 40 20 66 72 6f 6d 20 31 32 37 2e 30 2e  .  @ from 127.0.
12f0: 30 2e 31 20 69 73 20 61 6c 6c 6f 77 73 20 77 69  0.1 is allows wi
1300: 74 68 6f 75 74 20 61 6e 79 20 6c 6f 67 69 6e 20  thout any login 
1310: 2d 20 74 68 65 20 75 73 65 72 20 69 64 20 69 73  - the user id is
1320: 20 73 65 6c 65 63 74 65 64 0a 20 20 40 20 66 72   selected.  @ fr
1330: 6f 6d 20 74 68 65 20 7e 2f 2e 66 6f 73 73 69 6c  om the ~/.fossil
1340: 20 64 61 74 61 62 61 73 65 2e 20 50 61 73 73 77   database. Passw
1350: 6f 72 64 20 6c 6f 67 69 6e 20 69 73 20 61 6c 77  ord login is alw
1360: 61 79 73 20 72 65 71 75 69 72 65 64 0a 20 20 40  ays required.  @
1370: 20 66 6f 72 20 69 6e 63 6f 6d 69 6e 67 20 77 65   for incoming we
1380: 62 20 63 6f 6e 6e 65 63 74 69 6f 6e 73 20 6f 6e  b connections on
1390: 20 69 6e 74 65 72 6e 65 74 20 61 64 64 72 65 73   internet addres
13a0: 73 65 73 20 6f 74 68 65 72 20 74 68 61 6e 0a 20  ses other than. 
13b0: 20 40 20 31 32 37 2e 30 2e 30 2e 31 2e 3c 2f 70   @ 127.0.0.1.</p
13c0: 3e 3c 2f 6c 69 3e 0a 0a 20 20 40 20 3c 68 72 3e  ></li>..  @ <hr>
13d0: 0a 20 20 65 6e 74 72 79 5f 61 74 74 72 69 62 75  .  entry_attribu
13e0: 74 65 28 22 4c 6f 67 69 6e 20 65 78 70 69 72 61  te("Login expira
13f0: 74 69 6f 6e 20 74 69 6d 65 22 2c 20 36 2c 20 22  tion time", 6, "
1400: 63 6f 6f 6b 69 65 2d 65 78 70 69 72 65 22 2c 20  cookie-expire", 
1410: 22 63 65 78 22 2c 20 22 38 37 36 36 22 29 3b 0a  "cex", "8766");.
1420: 20 20 40 20 3c 70 3e 54 68 65 20 6e 75 6d 62 65    @ <p>The numbe
1430: 72 20 6f 66 20 68 6f 75 72 73 20 66 6f 72 20 77  r of hours for w
1440: 68 69 63 68 20 61 20 6c 6f 67 69 6e 20 69 73 20  hich a login is 
1450: 76 61 6c 69 64 2e 20 20 54 68 69 73 20 6d 75 73  valid.  This mus
1460: 74 20 62 65 20 61 0a 20 20 40 20 70 6f 73 69 74  t be a.  @ posit
1470: 69 76 65 20 6e 75 6d 62 65 72 2e 20 20 54 68 65  ive number.  The
1480: 20 64 65 66 61 75 6c 74 20 69 73 20 38 37 36 30   default is 8760
1490: 20 68 6f 75 72 73 20 77 68 69 63 68 20 69 73 20   hours which is 
14a0: 61 70 70 72 6f 78 69 6d 61 74 65 6c 79 20 65 71  approximately eq
14b0: 75 61 6c 0a 20 20 40 20 74 6f 20 61 20 79 65 61  ual.  @ to a yea
14c0: 72 2e 3c 2f 70 3e 0a 20 20 20 0a 20 20 40 20 3c  r.</p>.   .  @ <
14d0: 68 72 3e 0a 20 20 6f 6e 6f 66 66 5f 61 74 74 72  hr>.  onoff_attr
14e0: 69 62 75 74 65 28 22 41 6c 6c 6f 77 20 61 6e 6f  ibute("Allow ano
14f0: 6e 79 6d 6f 75 73 20 73 69 67 6e 75 70 22 2c 20  nymous signup", 
1500: 22 61 6e 6f 6e 2d 73 69 67 6e 75 70 22 2c 20 22  "anon-signup", "
1510: 61 73 75 22 2c 20 30 29 3b 0a 20 20 40 20 3c 70  asu", 0);.  @ <p
1520: 3e 41 6c 6c 6f 77 20 75 73 65 72 73 20 74 6f 20  >Allow users to 
1530: 63 72 65 61 74 65 20 74 68 65 69 72 20 6f 77 6e  create their own
1540: 20 61 63 63 6f 75 6e 74 73 3c 2f 70 3e 0a 20 20   accounts</p>.  
1550: 20 0a 20 20 40 20 3c 68 72 3e 0a 20 20 40 20 3c   .  @ <hr>.  @ <
1560: 70 3e 3c 69 6e 70 75 74 20 74 79 70 65 3d 22 73  p><input type="s
1570: 75 62 6d 69 74 22 20 20 6e 61 6d 65 3d 22 73 75  ubmit"  name="su
1580: 62 6d 69 74 22 20 76 61 6c 75 65 3d 22 41 70 70  bmit" value="App
1590: 6c 79 20 43 68 61 6e 67 65 73 22 3e 3c 2f 70 3e  ly Changes"></p>
15a0: 0a 20 20 40 20 3c 2f 66 6f 72 6d 3e 0a 20 20 64  .  @ </form>.  d
15b0: 62 5f 65 6e 64 5f 74 72 61 6e 73 61 63 74 69 6f  b_end_transactio
15c0: 6e 28 30 29 3b 0a 20 20 73 74 79 6c 65 5f 66 6f  n(0);.  style_fo
15d0: 6f 74 65 72 28 29 3b 0a 7d 0a                    oter();.}.