Hex Artifact Content

Artifact cc49ddd664b4530283481f42fd429d1e3a4ba94c:


0000: 2e 50 55 0a 2e 54 48 20 46 49 4c 45 44 20 31 20  .PU..TH FILED 1 
0010: 22 31 33 20 4f 63 74 20 31 34 22 20 22 66 69 6c  "13 Oct 14" "fil
0020: 65 64 20 31 2e 31 32 22 0a 2e 53 48 20 4e 41 4d  ed 1.12"..SH NAM
0030: 45 0a 66 69 6c 65 64 20 5c 2d 20 73 65 72 76 65  E.filed \- serve
0040: 20 66 69 6c 65 73 20 6f 76 65 72 20 48 54 54 50   files over HTTP
0050: 0a 2e 53 48 20 53 59 4e 4f 50 53 49 53 0a 2e 6c  ..SH SYNOPSIS..l
0060: 6c 20 2b 31 30 0a 2e 42 20 66 69 6c 65 64 0a 2e  l +10..B filed..
0070: 52 42 20 5b 7b 20 5c 2d 68 20 7c 20 5c 2d 5c 2d  RB [{ \-h | \-\-
0080: 68 65 6c 70 20 7d 5d 0a 2e 52 42 20 5b 7b 20 5c  help }]..RB [{ \
0090: 2d 64 20 7c 20 5c 2d 5c 2d 64 61 65 6d 6f 6e 20  -d | \-\-daemon 
00a0: 7d 5d 0a 2e 52 42 20 5b 7b 20 5c 2d 76 20 7c 20  }]..RB [{ \-v | 
00b0: 5c 2d 5c 2d 76 65 72 73 69 6f 6e 20 7d 5d 0a 2e  \-\-version }]..
00c0: 52 42 20 5b 7b 20 5c 2d 56 20 7c 20 5c 2d 5c 2d  RB [{ \-V | \-\-
00d0: 76 68 6f 73 74 20 7d 5d 0a 2e 52 42 20 5b 7b 20  vhost }]..RB [{ 
00e0: 5c 2d 62 20 7c 20 5c 2d 5c 2d 62 69 6e 64 20 7d  \-b | \-\-bind }
00f0: 0a 2e 49 52 20 61 64 64 72 65 73 73 20 5d 0a 2e  ..IR address ]..
0100: 52 42 20 5b 7b 20 5c 2d 70 20 7c 20 5c 2d 5c 2d  RB [{ \-p | \-\-
0110: 70 6f 72 74 20 7d 0a 2e 49 52 20 70 6f 72 74 20  port }..IR port 
0120: 5d 0a 2e 52 42 20 5b 7b 20 5c 2d 74 20 7c 20 5c  ]..RB [{ \-t | \
0130: 2d 5c 2d 74 68 72 65 61 64 73 20 7d 0a 2e 49 52  -\-threads }..IR
0140: 20 63 6f 75 6e 74 20 5d 0a 2e 52 42 20 5b 7b 20   count ]..RB [{ 
0150: 5c 2d 63 20 7c 20 5c 2d 5c 2d 63 61 63 68 65 20  \-c | \-\-cache 
0160: 7d 0a 2e 49 52 20 65 6e 74 72 69 65 73 20 5d 0a  }..IR entries ].
0170: 2e 52 42 20 5b 7b 20 5c 2d 6c 20 7c 20 5c 2d 5c  .RB [{ \-l | \-\
0180: 2d 6c 6f 67 20 7d 0a 2e 49 52 20 66 69 6c 65 20  -log }..IR file 
0190: 5d 0a 2e 52 42 20 5b 7b 20 5c 2d 75 20 7c 20 5c  ]..RB [{ \-u | \
01a0: 2d 5c 2d 75 73 65 72 20 7d 0a 2e 49 52 20 75 73  -\-user }..IR us
01b0: 65 72 20 5d 0a 2e 52 42 20 5b 7b 20 5c 2d 72 20  er ]..RB [{ \-r 
01c0: 7c 20 5c 2d 5c 2d 72 6f 6f 74 20 7d 0a 2e 49 52  | \-\-root }..IR
01d0: 20 64 69 72 65 63 74 6f 72 79 20 5d 0a 0a 2e 6c   directory ]...l
01e0: 6c 20 2d 31 30 0a 2e 53 48 20 44 45 53 43 52 49  l -10..SH DESCRI
01f0: 50 54 49 4f 4e 0a 2e 49 20 46 49 4c 45 44 0a 73  PTION..I FILED.s
0200: 65 72 76 65 73 20 66 69 6c 65 73 20 6f 76 65 72  erves files over
0210: 20 48 54 54 50 20 61 73 20 6d 69 6e 69 6d 61 6c   HTTP as minimal
0220: 6c 79 20 61 73 20 70 6f 73 73 69 62 6c 65 2e 20  ly as possible. 
0230: 20 4f 6e 6c 79 20 73 74 61 74 69 63 20 66 69 6c   Only static fil
0240: 65 73 20 28 69 2e 65 2e 2c 20 66 69 6c 65 73 20  es (i.e., files 
0250: 74 68 61 74 20 6e 65 76 65 72 20 63 68 61 6e 67  that never chang
0260: 65 20 6f 72 20 61 72 65 20 72 65 70 6c 61 63 65  e or are replace
0270: 64 29 20 61 72 65 20 73 75 70 70 6f 72 74 65 64  d) are supported
0280: 2e 0a 0a 2e 53 48 20 4f 50 54 49 4f 4e 53 0a 2e  ....SH OPTIONS..
0290: 54 50 0a 2e 42 20 2d 68 20 28 6f 72 20 2d 2d 68  TP..B -h (or --h
02a0: 65 6c 70 29 0a 50 72 69 6e 74 73 20 64 65 74 61  elp).Prints deta
02b0: 69 6c 65 64 20 75 73 61 67 65 20 69 6e 66 6f 72  iled usage infor
02c0: 6d 61 74 69 6f 6e 2e 0a 0a 2e 54 50 0a 2e 42 20  mation....TP..B 
02d0: 2d 64 20 28 6f 72 20 2d 2d 64 61 65 6d 6f 6e 29  -d (or --daemon)
02e0: 0a 49 6e 73 74 72 75 63 74 73 0a 2e 42 20 66 69  .Instructs..B fi
02f0: 6c 65 64 0a 74 6f 20 62 65 63 6f 6d 65 20 61 20  led.to become a 
0300: 64 61 65 6d 6f 6e 20 61 66 74 65 72 20 69 6e 69  daemon after ini
0310: 74 69 61 6c 69 7a 69 6e 67 0a 74 68 65 20 6c 69  tializing.the li
0320: 73 74 65 6e 69 6e 67 20 54 43 50 20 73 6f 63 6b  stening TCP sock
0330: 65 74 20 61 6e 64 20 6c 6f 67 20 66 69 6c 65 73  et and log files
0340: 2e 0a 0a 2e 54 50 0a 2e 42 20 2d 76 20 28 6f 72  ....TP..B -v (or
0350: 20 2d 2d 76 65 72 73 69 6f 6e 29 0a 49 6e 73 74   --version).Inst
0360: 72 75 63 74 73 0a 2e 42 20 66 69 6c 65 64 0a 74  ructs..B filed.t
0370: 6f 20 70 72 69 6e 74 20 6f 75 74 20 69 74 73 20  o print out its 
0380: 76 65 72 73 69 6f 6e 20 6e 75 6d 62 65 72 20 61  version number a
0390: 6e 64 20 74 68 65 6e 20 65 78 69 74 2e 0a 0a 2e  nd then exit....
03a0: 54 50 0a 2e 42 20 2d 56 20 28 6f 72 20 2d 2d 76  TP..B -V (or --v
03b0: 68 6f 73 74 29 0a 69 6e 73 74 72 75 63 74 73 20  host).instructs 
03c0: 66 69 6c 65 64 20 74 6f 20 70 72 65 70 65 6e 64  filed to prepend
03d0: 20 61 6c 6c 20 72 65 71 75 65 73 74 73 20 77 69   all requests wi
03e0: 74 68 20 74 68 65 69 72 20 48 54 54 50 0a 48 6f  th their HTTP.Ho
03f0: 73 74 20 68 65 61 64 65 72 2e 0a 0a 2e 54 50 0a  st header....TP.
0400: 2e 42 20 2d 62 20 28 6f 72 20 2d 2d 62 69 6e 64  .B -b (or --bind
0410: 29 0a 53 70 65 63 69 66 69 65 73 20 74 68 65 20  ).Specifies the 
0420: 61 64 64 72 65 73 73 20 74 6f 20 6c 69 73 74 65  address to liste
0430: 6e 20 66 6f 72 20 69 6e 63 6f 6d 69 6e 67 20 48  n for incoming H
0440: 54 54 50 0a 72 65 71 75 65 73 74 73 20 6f 6e 2e  TTP.requests on.
0450: 0a 0a 2e 54 50 0a 2e 42 20 2d 70 20 28 6f 72 20  ...TP..B -p (or 
0460: 2d 2d 70 6f 72 74 29 0a 53 70 65 63 69 66 69 65  --port).Specifie
0470: 73 20 74 68 65 20 54 43 50 20 70 6f 72 74 20 6e  s the TCP port n
0480: 75 6d 62 65 72 20 74 6f 20 6c 69 73 74 65 6e 20  umber to listen 
0490: 66 6f 72 20 69 6e 63 6f 6d 69 6e 67 20 48 54 54  for incoming HTT
04a0: 50 0a 72 65 71 75 65 73 74 73 20 6f 6e 2e 0a 0a  P.requests on...
04b0: 2e 54 50 0a 2e 42 20 2d 74 20 28 6f 72 20 2d 2d  .TP..B -t (or --
04c0: 74 68 72 65 61 64 73 29 0a 53 70 65 63 69 66 69  threads).Specifi
04d0: 65 73 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66  es the number of
04e0: 20 77 6f 72 6b 65 72 20 74 68 72 65 61 64 73 20   worker threads 
04f0: 74 6f 20 63 72 65 61 74 65 2e 20 45 61 63 68 0a  to create. Each.
0500: 77 6f 72 6b 65 72 20 74 68 72 65 61 64 20 63 61  worker thread ca
0510: 6e 20 73 65 72 76 69 63 65 20 6f 6e 65 20 63 6f  n service one co
0520: 6e 63 75 72 72 65 6e 74 20 48 54 54 50 20 73 65  ncurrent HTTP se
0530: 73 73 69 6f 6e 2e 0a 54 68 75 73 20 74 68 65 20  ssion..Thus the 
0540: 6e 75 6d 62 65 72 20 6f 66 20 74 68 72 65 61 64  number of thread
0550: 73 20 63 72 65 61 74 65 64 20 77 69 6c 6c 20 64  s created will d
0560: 65 74 65 72 6d 69 6e 65 20 68 6f 77 0a 6d 61 6e  etermine how.man
0570: 79 20 73 69 6d 75 6c 74 61 6e 65 6f 75 73 20 74  y simultaneous t
0580: 72 61 6e 73 66 65 72 73 20 77 69 6c 6c 20 62 65  ransfers will be
0590: 20 70 6f 73 73 69 62 6c 65 2e 0a 0a 2e 54 50 0a   possible....TP.
05a0: 2e 42 20 2d 63 20 28 6f 72 20 2d 2d 63 61 63 68  .B -c (or --cach
05b0: 65 29 0a 53 70 65 63 69 66 69 65 73 20 74 68 65  e).Specifies the
05c0: 20 6e 75 6d 62 65 72 20 6f 66 20 66 69 6c 65 20   number of file 
05d0: 69 6e 66 6f 72 6d 61 74 69 6f 6e 20 63 61 63 68  information cach
05e0: 65 20 65 6e 74 72 69 65 73 0a 74 6f 20 61 6c 6c  e entries.to all
05f0: 6f 63 61 74 65 2e 20 20 45 61 63 68 20 63 61 63  ocate.  Each cac
0600: 68 65 20 65 6e 74 72 79 20 68 6f 6c 64 73 20 66  he entry holds f
0610: 69 6c 65 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 20  ile information 
0620: 61 73 0a 77 65 6c 6c 20 61 73 20 61 6e 20 6f 70  as.well as an op
0630: 65 6e 20 66 69 6c 65 20 64 65 73 63 72 69 70 74  en file descript
0640: 6f 72 20 74 6f 20 74 68 65 20 66 69 6c 65 2c 20  or to the file, 
0650: 73 6f 20 72 65 73 6f 75 72 63 65 0a 6c 69 6d 69  so resource.limi
0660: 74 73 20 28 69 2e 65 2e 2c 20 75 6c 69 6d 69 74  ts (i.e., ulimit
0670: 29 20 73 68 6f 75 6c 64 20 62 65 20 63 6f 6e 73  ) should be cons
0680: 69 64 65 72 65 64 2e 20 20 54 68 69 73 20 73 68  idered.  This sh
0690: 6f 75 6c 64 0a 62 65 20 61 20 70 72 69 6d 65 20  ould.be a prime 
06a0: 6e 75 6d 62 65 72 20 66 6f 72 20 69 64 65 61 6c  number for ideal
06b0: 20 75 73 65 20 77 69 74 68 20 74 68 65 20 6c 6f   use with the lo
06c0: 6f 6b 75 70 20 6d 65 74 68 6f 64 2e 0a 0a 2e 54  okup method....T
06d0: 50 0a 2e 42 20 2d 6c 20 28 6f 72 20 2d 2d 6c 6f  P..B -l (or --lo
06e0: 67 29 0a 53 70 65 63 69 66 69 65 73 20 61 20 66  g).Specifies a f
06f0: 69 6c 65 6e 61 6d 65 20 74 6f 20 6f 70 65 6e 20  ilename to open 
0700: 66 6f 72 20 77 72 69 74 69 6e 67 20 6c 6f 67 20  for writing log 
0710: 65 6e 74 72 69 65 73 2e 20 20 4c 6f 67 0a 65 6e  entries.  Log.en
0720: 74 72 69 65 73 20 61 72 65 20 6d 61 64 65 20 66  tries are made f
0730: 6f 72 20 76 61 72 69 6f 75 73 20 73 74 61 67 65  or various stage
0740: 73 20 69 6e 20 74 72 61 6e 73 66 65 72 69 6e 67  s in transfering
0750: 20 66 69 6c 65 73 2e 0a 54 68 65 20 6c 6f 67 20   files..The log 
0760: 66 69 6c 65 20 69 73 20 6f 70 65 6e 65 64 20 62  file is opened b
0770: 65 66 6f 72 65 20 73 77 69 74 63 68 69 6e 67 20  efore switching 
0780: 75 73 65 72 73 20 28 73 65 65 20 22 2d 75 22 29  users (see "-u")
0790: 0a 61 6e 64 20 72 6f 6f 74 20 64 69 72 65 63 74  .and root direct
07a0: 6f 72 69 65 73 20 28 73 65 65 20 22 2d 72 22 29  ories (see "-r")
07b0: 2e 20 20 54 68 65 20 6c 6f 67 20 66 69 6c 65 20  .  The log file 
07c0: 69 73 20 6e 65 76 65 72 0a 63 6c 6f 73 65 64 20  is never.closed 
07d0: 73 6f 20 6c 6f 67 20 72 6f 74 61 74 69 6f 6e 20  so log rotation 
07e0: 77 69 74 68 6f 75 74 20 73 74 6f 70 70 69 6e 67  without stopping
07f0: 20 74 68 65 20 64 61 65 6d 6f 6e 20 69 73 20 77   the daemon is w
0800: 69 6c 6c 0a 6e 6f 74 20 77 6f 72 6b 2e 20 20 54  ill.not work.  T
0810: 68 65 20 76 61 6c 75 65 20 6f 66 20 22 2d 22 20  he value of "-" 
0820: 69 6e 64 69 63 61 74 65 73 20 74 68 61 74 20 73  indicates that s
0830: 74 61 6e 64 61 72 64 20 6f 75 74 70 75 74 0a 73  tandard output.s
0840: 68 6f 75 6c 64 20 62 65 20 75 73 65 64 20 66 6f  hould be used fo
0850: 72 20 6c 6f 67 67 69 6e 67 2e 20 20 49 66 20 74  r logging.  If t
0860: 68 65 20 66 69 6c 65 6e 61 6d 65 20 62 65 67 69  he filename begi
0870: 6e 73 20 77 69 74 68 20 61 0a 70 69 70 65 20 28  ns with a.pipe (
0880: 22 7c 22 29 20 74 68 65 6e 20 61 20 70 72 6f 63  "|") then a proc
0890: 65 73 73 20 69 73 20 73 74 61 72 74 65 64 20 61  ess is started a
08a0: 6e 64 20 75 73 65 64 20 66 6f 72 20 6c 6f 67 67  nd used for logg
08b0: 69 6e 67 0a 69 6e 73 74 65 61 64 20 6f 66 20 61  ing.instead of a
08c0: 20 66 69 6c 65 2e 0a 0a 2e 54 50 0a 2e 42 20 2d   file....TP..B -
08d0: 75 20 28 6f 72 20 2d 2d 75 73 65 72 29 0a 53 70  u (or --user).Sp
08e0: 65 63 69 66 69 65 73 20 74 68 65 20 75 73 65 72  ecifies the user
08f0: 20 74 6f 20 73 77 69 74 63 68 20 75 73 65 72 20   to switch user 
0900: 49 44 73 20 74 6f 20 62 65 66 6f 72 65 20 73 65  IDs to before se
0910: 72 76 69 63 69 6e 67 0a 72 65 71 75 65 73 74 73  rvicing.requests
0920: 2e 20 20 54 68 65 20 64 65 66 61 75 6c 74 20 69  .  The default i
0930: 73 20 6e 6f 74 20 63 68 61 6e 67 65 20 75 73 65  s not change use
0940: 72 20 49 44 73 2e 0a 0a 2e 54 50 0a 2e 42 20 2d  r IDs....TP..B -
0950: 72 20 28 6f 72 20 2d 2d 72 6f 6f 74 29 0a 53 70  r (or --root).Sp
0960: 65 63 69 66 69 65 73 20 74 68 65 20 64 69 72 65  ecifies the dire
0970: 63 74 6f 72 79 20 74 6f 20 61 63 74 20 61 73 20  ctory to act as 
0980: 74 68 65 20 72 6f 6f 74 20 64 69 72 65 63 74 6f  the root directo
0990: 72 79 20 66 6f 72 0a 74 68 65 20 66 69 6c 65 20  ry for.the file 
09a0: 73 65 72 76 65 72 2e 20 20 49 66 20 74 68 69 73  server.  If this
09b0: 20 6f 70 74 69 6f 6e 20 69 73 20 73 70 65 63 69   option is speci
09c0: 66 69 65 64 2c 20 63 68 72 6f 6f 74 28 32 29 0a  fied, chroot(2).
09d0: 69 73 20 63 61 6c 6c 65 64 2e 20 20 54 68 65 20  is called.  The 
09e0: 64 65 66 61 75 6c 74 20 69 73 20 6e 6f 74 20 63  default is not c
09f0: 68 61 6e 67 65 20 72 6f 6f 74 20 64 69 72 65 63  hange root direc
0a00: 74 6f 72 69 65 73 2c 0a 74 68 61 74 20 69 73 2c  tories,.that is,
0a10: 20 74 68 65 20 22 2f 22 20 64 69 72 65 63 74 6f   the "/" directo
0a20: 72 79 20 69 73 20 73 68 61 72 65 64 20 6f 75 74  ry is shared out
0a30: 2e 20 20 54 68 69 73 20 77 69 6c 6c 0a 6c 69 6b  .  This will.lik
0a40: 65 6c 79 20 62 65 20 61 20 73 65 63 75 72 69 74  ely be a securit
0a50: 79 20 69 73 73 75 65 2c 20 73 6f 20 74 68 69 73  y issue, so this
0a60: 20 6f 70 74 69 6f 6e 20 73 68 6f 75 6c 64 20 61   option should a
0a70: 6c 77 61 79 73 0a 62 65 20 75 73 65 64 2e 0a 0a  lways.be used...
0a80: 2e 53 48 20 41 55 54 48 4f 52 0a 2e 53 70 0a 52  .SH AUTHOR..Sp.R
0a90: 6f 79 20 4b 65 65 6e 65 0a 2e 49 20 3c 66 69 6c  oy Keene..I <fil
0aa0: 65 64 40 72 6b 65 65 6e 65 2e 6f 72 67 3e 0a     ed@rkeene.org>.