Bash Cures Cancer
Learn the UNIX/Linux command line

Home     Man Pages     SpamDefeator


callback(8)		    mgetty+callback manual		  callback(8)



NAME
       callback - call a user back, presenting a login prompt

SYNOPSIS
       callback	  [-x]   [-V]  [-l]  [-m]
       [-s] [-d] [-S] [phone-number]

DESCRIPTION
       Call the given phone number (if none is given on the command line, ask
       user  for  one), and if a CONNECT is established, hand over control to
       mgetty(8) to present user with a login name prompt.

       callback is used for various purposes:

       * security: make sure your users are who they pretend to be by calling
       a well-known phone number.

       * cost savings: make your company call you back.

       callback can be called directly from the command line (but you must be
       "root" to do this, otherwise callback can't signal  mgetty),  or	 from
       mgetty's "login.config". See the login.config file shipped with mgetty
       for an example.


OPTIONS
       -x 
	      Use the given level of verbosity for logging -  0	 means
	      no logging, 5 is really noisy.

       -V     Print version number and quit.

       -d     Do  not  go  into	 the  background.  This is helpful for
	      debugging.

       -l 
	      Use the given modem lines. Multiple lines can  be	 sepa-
	      rated  by	 ":", as with sendfax(8). Example: callback -l
	      tty1a:tty2a

       -m <init sequence>
	      Set the modem initialization sequence (as usual:	expect
	      send  expect  ...).   This  can do nearly everything, as
	      long as it leaves the modem command responses  on	 (that
	      is,  no  ATQ1 here!) and switches the modem to data mode
	      (AT+FCLASS=0) if it is used in data/fax mode.

       -s 
	      This is the  bit	rate  that  should  be	used  for  the
	      machine-modem  connection.   Usually you'll set this via
	      the "speed " option in "callback.config".

       -S     Use the line where callback is started from for  dialing
	      out.  Callback can make use of multiple modem lines, and
	      with this options, you can force	it  to	use  just  one
	      modem, the one where a call comes in.


CONFIG FILE
       callback	 will  read  all  its configuration at run-time from a
       file, usually called  /etc/mgetty+sendfax/callback.config.  See
       the documentation in the mgetty.info manual for details.


DIAGNOSTICS
       In  most	 cases, callback can't print any error messages to the
       console, because it must detach	itself	immediately  from  the
       terminal,  in case someone wants to be called back on the modem
       line he called in. So, nothing to print messages to...

       Because of this, all callback errors are logged to  a  protocol
       file  (the extent of the data written is controlled by the "-x"
       option), especially including the reason why  a	call  was  not
       made, or what exactly failed.

       Just  two  messages  are printed on stdout, and those are self-
       explaining, a call from a non-root user, and an invalid option.


INTERNALS
       How does it work?

       This  is	 a  bit tricky, because of the way init(8) handles the
       utmp(5) file.  You can't just have any program ask the user for
       a  login	 name,	and  then start a "login shell", it won't work
       (this is for the same reason mgetty(8) has to be	 started  from
       /etc/inittab).

       So,  mgetty has to do the "asking for login name". But I do not
       want to have all that dialout code in mgetty, bloating it  even
       more.

       The way it works is this: callback dials out on a modem device.
       It will only take a modem device that  has  a  mgetty  watching
       over  it	 (!).  When  the  connection is established (CONNECT),
       callback will send a signal SIGUSR1 to mgetty, which, in	 turn,
       will  send  the same signal back to signal "I got your signal".
       callback then exits, and mgetty takes over the existing connec-
       tion,  prompts  the  user  for  a  login	 name,	and  forks off
       /bin/login.

       Conclusion: this will not  work	with  mgetty  versions	before
       February	 04,  1996 (no support for this signalling), and if it
       doesn't work for you, please send me BOTH the  mgetty  and  the
       callback log file, otherwise it's very hard to find the bugs.


BUGS
       callback is "alpha" code, not very stable right now.

       callback is fairly dumb concerning retries.

       callback must be run as root.

       Most of the documentation consists of "reading the source".


SEE ALSO
       mgetty(8), ct(1)

AUTHOR
       callback	  is   Copyright   (C)	 1993-1996  by	Gert  Doering,
       .



greenie				  27 Oct 93			  callback(8)


UNIX/Linux commands referenced on this page:
  1. login
  2. make
  3. users
  4. who
  5. file
  6. as
  7. init
  8. at
  9. mgetty
  10. which
  11. find