aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorolgeni <olgeni@FreeBSD.org>2010-08-08 23:00:54 +0800
committerolgeni <olgeni@FreeBSD.org>2010-08-08 23:00:54 +0800
commit9528874a12774dc1618017d2d7fbeff3299e0393 (patch)
tree0bae91847b1a1af839de47edc1c6b60fa15b508f
parentc59a4ee74b543dc36796fde379e2ad68958e7a1d (diff)
downloadfreebsd-ports-gnome-9528874a12774dc1618017d2d7fbeff3299e0393.tar.gz
freebsd-ports-gnome-9528874a12774dc1618017d2d7fbeff3299e0393.tar.zst
freebsd-ports-gnome-9528874a12774dc1618017d2d7fbeff3299e0393.zip
Remove pkg-install, which is now replaced by mgettycfg with the same code.
In mgettycfg: - Suggest cuau1 (uart driver) as the default device, rather than cuad1 (sio) - Use Perl from LOCALBASE - Fix a few spelling/whitespace nits
-rw-r--r--comms/mgetty+sendfax/Makefile8
-rw-r--r--comms/mgetty+sendfax/files/mgettycfg.in56
-rw-r--r--comms/mgetty+sendfax/files/pkg-message.in7
-rw-r--r--comms/mgetty+sendfax/pkg-install635
-rw-r--r--comms/mgetty+sendfax/pkg-plist1
5 files changed, 40 insertions, 667 deletions
diff --git a/comms/mgetty+sendfax/Makefile b/comms/mgetty+sendfax/Makefile
index fd65bbd206b5..877261c8a45f 100644
--- a/comms/mgetty+sendfax/Makefile
+++ b/comms/mgetty+sendfax/Makefile
@@ -7,7 +7,7 @@
PORTNAME= mgetty
PORTVERSION= 1.1.35
-PORTREVISION= 3
+PORTREVISION= 4
CATEGORIES= comms
MASTER_SITES= ftp://mgetty.greenie.net/pub/mgetty/source/1.1/
DISTNAME= ${PORTNAME}${PORTVERSION}-Feb22
@@ -19,6 +19,7 @@ USE_PERL5= yes
CONFLICTS= netpbm-[0-9]*
+SUB_FILES= pkg-message mgettycfg
WRKSRC= ${WRKDIR}/${PORTNAME}-${PORTVERSION}
MAKE_FLAGS= CFLAGS="${CFLAGS}" prefix=${PREFIX} -f
ALL_TARGET= noident all
@@ -102,8 +103,7 @@ post-install:
${INSTALL_DATA} -m 600 ${WRKSRC}/voice/voice.conf-dist \
${PREFIX}/etc/mgetty+sendfax/voice.conf.dist
@${TAR} -cf - -C ${WRKSRC} samples | ${TAR} -xf - -C ${PREFIX}/lib/mgetty+sendfax/
-.if !defined(BATCH)
- @(cd ${PKGDIR}; export PKG_PREFIX=${PREFIX}; ${PERL5} ${PKGINSTALL} _ POST-INSTALL)
-.endif
+ @${INSTALL_SCRIPT} ${WRKDIR}/mgettycfg ${PREFIX}/bin
+ @${CAT} ${PKGMESSAGE}
.include <bsd.port.post.mk>
diff --git a/comms/mgetty+sendfax/files/mgettycfg.in b/comms/mgetty+sendfax/files/mgettycfg.in
index 9b76b5a1efcd..0a10770a4349 100644
--- a/comms/mgetty+sendfax/files/mgettycfg.in
+++ b/comms/mgetty+sendfax/files/mgettycfg.in
@@ -1,11 +1,9 @@
-#!/usr/bin/perl
+#!%%LOCALBASE%%/bin/perl
-exit 0 if $ARGV[1] ne "POST-INSTALL";
-exit 0 if $ENV{'BATCH'};
exit 0 if ! -t;
-print STDERR "\n\n\n =========== mgetty+sendfax configuration ===========\n\n";
-$prefix = $ENV{'PKG_PREFIX'};
+print STDERR "\n=========== mgetty+sendfax configuration ===========\n";
+$prefix = "%%PREFIX%%";
$sep = "~";
&read_config ("$prefix/etc/mgetty+sendfax/mgetty.config");
@@ -19,7 +17,7 @@ foreach (keys(%var)) {
}
$a = 1;
-$devices = $var{'ports'} ? $var{'ports'} : "cuad1";
+$devices = $var{'ports'} ? $var{'ports'} : "cuau1";
while ($a) {
$devices = &ask ("list of devices", $devices);
@@ -156,7 +154,7 @@ sub inq_m {
$def{'debug'} = 4 if !$def{'debug'};
$def{'debug'} = &ask (" - `debug (mgetty)'
This sets the amount of logging `mgetty' will do. A good value is
- 4, more details are seen with `5', and `9' is really noisy. Try
+ 4, more details are seen with `5', and `9' is really noisy. Try
it! The log data is written to the file `/tmp/log_mg.cuaxx'.",
$def{'debug'});
@@ -180,7 +178,7 @@ sub inq_m {
$def{'switchbd'} = &ask (" - `switchbd'
Some modems, mainly Rockwell chipsets, switch to 19200 bps when
entering fax mode. Others may need other speed switches (but I
- know none). If your modem is Rockwell based, try `switchbd 19200'
+ know none). If your modem is Rockwell based, try `switchbd 19200'
if fax reception doesn't work. (*Warning:* if this is set wrongly,
fax reception will definitely fail. For most sane modems, you do
*not need* this.). Set speed or `0'", $def{'switchbd'});
@@ -193,7 +191,7 @@ sub inq_m {
to initialize any modem, nor will it wait for `RING'. It will just
wait for any character, and then output the issue file and login
prompt. This option is used if you want to connect to machines via
- nullmodem cable.", $def{'direct'});
+ null modem cable.", $def{'direct'});
$settings .= " blocking";
$def{'blocking'} = "NO" if !$def{'blocking'};
@@ -205,12 +203,12 @@ sub inq_m {
$settings .= " port-owner";
$def{'port-owner'} = "uucp" if !$def{'port-owner'};
- $def{'port-owner'} = &ask (" - `port-owner'
+ $def{'port-owner'} = &ask (" - `port-owner'
If set, mgetty will `chown' the tty line to the given username (you
can specify a string or an integer uid, but the integer must be
- valid). This is highly recommended for security purposes: only
+ valid). This is highly recommended for security purposes: only
give port access to those users you trust not to misuse your modem
- lines!", $def{'port-owner'});
+ lines!", $def{'port-owner'});
$settings .= " port-group";
$def{'port-group'} = "uucp" if !$def{'port-group'};
@@ -322,13 +320,12 @@ sub inq_m {
$def{'rings'} = 1 if !$def{'rings'};
$def{'rings'} = &ask (" - `rings'
Sets the number of `RING' messages to wait for, before mgetty
- picks up the phone. *Warning:* if your modem auto-answers, for
- whatever reason, set this to something *different* than the
- value set with `ATS0=mmm', otherwise the modems autoanswer and
- mgettys manual answer will collide (most modems hang up if a
+ picks up the phone. *Warning:* if your modem auto-answers, for
+ whatever reason, set this to something *different* than the
+ value set with `ATS0=mmm', otherwise the modem's autoanswer and
+ mgetty's manual answer will collide (most modems hang up if a
command is received during auto-answer)", $def{'rings'});
-
$settings .= " answer-chat";
$def{'answer-chat'} = '"" ATA CONNECT \c \r' if !$def{'answer-chat'};
$def{'answer-chat'} =&ask (" - `answer-chat'
@@ -407,7 +404,7 @@ sub inq_m {
$settings .= " login-prompt";
$def{'login-prompt'} = "@!login: " if !$def{'login-prompt'} ;
- $def{'login-prompt'} = &ask(" - `login-prompt'
+ $def{'login-prompt'} = &ask(" - `login-prompt'
This specifies the login prompt that mgetty will output. Some
special characters in this string (and in the issue file, btw) are
recognized and replaced by something else:
@@ -427,14 +424,14 @@ sub inq_m {
* \\T current time in hh:mm:ss format
* \\DIGIT character with the specified octal code
- The maximum lenght of the login prompt is limited to 140
+ The maximum length of the login prompt is limited to 140
characters (after expansion).", $def{'login-prompt'});
$settings .= " login-time";
$def{'login-time'} = 240 if !$def{'login-time'};
$def{'login-time'} = &ask (" - `login-time'
This specifies the maximum time the user can take to log in. If no
- login has occured after that time, `mgetty' will hang up.",
+ login has occurred after that time, `mgetty' will hang up.",
$def{'login-time'});
$settings .= " fax-server-file";
@@ -468,16 +465,16 @@ sub inq_m {
$settings .= " fax-owner";
$def{'fax-owner'} = "uucp" if !$def{'fax-owner'};
- $def{'fax-owner'} = &ask (" - `fax-owner'
+ $def{'fax-owner'} = &ask (" - `fax-owner'
If set, mgetty will `chown' the received files to the given username
(you can specify a string or an integer uid, but the integer must be
- valid).", $def{'fax-owner'});
+ valid).", $def{'fax-owner'});
$settings .= " fax-group";
$def{'fax-group'} = "modem" if !$def{'fax-group'};
$def{'fax-group'} = &ask (" - `fax-group'
If set, mgetty will `chgrp' the received files to this group id
- (which can be given as group name, or as integer gid).", $def{'fax-group'});
+ (which can be given as group name, or as integer gid).", $def{'fax-group'});
$settings .= " fax-mode";
$def{'fax-mode'} = "0660" if !$def{'fax-mode'};
@@ -489,7 +486,7 @@ sub inq_f {
$def_f{'debug'} = 4 if !$def_f{'debug'};
$def_f{'debug'} = &ask (" - `debug (sendfax)'
controls the amount of information written into the fax log file.
- `0' means \"totally silent\" (not even errors are written), `9'
+ `0' means \"totally silent\" (not even errors are written), `9'
is really noisy. I usually use `3' or `4' in normal use, and `6'
for debugging.", $def_f{'debug'});
@@ -516,7 +513,7 @@ sub inq_f {
successfully transmit a page, `sendfax' will give up or simply go
on, depending on the setting of `max-tries-continue' (see below).
If this is set to `0', `sendfax' will ignore retransmission
- requests and simply go on.", $def_f{'max-tries'});
+ requests and simply go on.", $def_f{'max-tries'});
$settings .= " max-tries-continue";
$def_f{'max-tries-continue'} = "YES" if !$def_f{'max-tries-continue'};
@@ -534,9 +531,9 @@ sub inq_f {
$def_f{'speed'} = &ask (" - `speed'
Set the port speed to use for fax send operations. Usually,
`38400' is a good choice, but a few dumb modems (for example, some
- based on rockwell chipsets) need `19200' or even `9600'. A few
+ based on Rockwell chipsets) need `19200' or even `9600'. A few
modems can go higher, but `sendfax' may not support it, and it may
- not always work.", $def_f{'speed'});
+ not always work.", $def_f{'speed'});
$settings .= " dial-prefix";
$def_f{'dial-prefix'} = "ATD" if !$def_f{'dial-prefix'};
@@ -552,7 +549,7 @@ sub inq_f {
$settings .= " poll-dir";
$def_f{'poll-dir'} = "./" if !$def_f{'poll-dir'};
$def_f{'poll-dir'} = &ask (" - `poll-dir'
- This is used to specify a directory where polled faxes (wheather
+ This is used to specify a directory where polled faxes (weather
maps and such) are to be saved into. Default is the current
directory.", $def_f{'poll-dir'});
@@ -571,6 +568,7 @@ sub inq_f {
on stdout, if set to `no', `sendfax' will only print error and
warning messages.", $def_f{'verbose'});
}
+
sub setdef {
local ($p, $l);
$p = shift;
@@ -588,6 +586,7 @@ sub setdef {
$def_f{$_} = substr ($var_f{$_}, 1) if (!$def_f{$_} && $var_f{$_} =~ /^$sep/);
}
}
+
sub ask {
($info, $default, $x) = @_;
print STDERR "\n$info: ";
@@ -600,6 +599,7 @@ sub ask {
}
return $_;
}
+
sub read_config {
local ($conf, $port, $a, $b);
diff --git a/comms/mgetty+sendfax/files/pkg-message.in b/comms/mgetty+sendfax/files/pkg-message.in
new file mode 100644
index 000000000000..74e43d05ebe8
--- /dev/null
+++ b/comms/mgetty+sendfax/files/pkg-message.in
@@ -0,0 +1,7 @@
+=================================================
+
+To use the interactive configuration script, run:
+
+ %%LOCALBASE%%/bin/mgettycfg
+
+=================================================
diff --git a/comms/mgetty+sendfax/pkg-install b/comms/mgetty+sendfax/pkg-install
deleted file mode 100644
index 9b76b5a1efcd..000000000000
--- a/comms/mgetty+sendfax/pkg-install
+++ /dev/null
@@ -1,635 +0,0 @@
-#!/usr/bin/perl
-
-exit 0 if $ARGV[1] ne "POST-INSTALL";
-exit 0 if $ENV{'BATCH'};
-exit 0 if ! -t;
-
-print STDERR "\n\n\n =========== mgetty+sendfax configuration ===========\n\n";
-$prefix = $ENV{'PKG_PREFIX'};
-$sep = "~";
-
-&read_config ("$prefix/etc/mgetty+sendfax/mgetty.config");
-foreach (keys(%var)) {
- $var_m{$_} = $var{$_};
- delete $var{$_};
-}
-&read_config ("$prefix/etc/mgetty+sendfax/sendfax.config");
-foreach (keys(%var)) {
- $var_f{$_} = $var{$_};
-}
-
-$a = 1;
-$devices = $var{'ports'} ? $var{'ports'} : "cuad1";
-while ($a) {
- $devices = &ask ("list of devices", $devices);
-
- $_ = $devices;
- $w = 0;
- foreach (split) {
- if (! -c "/dev/$_" ) {
- print STDERR "warning: device file /dev/$_ does not exist!\n";
- $w++;
- }
- }
- if ($w) {
- $a = 0 if (&yesno ("are you sure?" , "n") eq "y");
- } else {
- $a = 0;
- }
-}
-
-open (TMP1, ">/tmp/mgetty.config.$$") || die "$!\n";
-open (TMP2, ">/tmp/sendfax.config.$$") || die "$!\n";
-$_ = join (":", $devices);
-print TMP2 "fax-devices $_\n\n";
-
-$_ = $devices;
-
-foreach $port (split) {
- print STDERR "\n\n *** Configuring for port $port ***\n\n";
- print TMP1 "\nport $port\n";
- print TMP2 "\nport $port\n";
- &setdef ($port);
-again:
- &inq_m;
- $settings_m = $settings;
- &inq_f;
- $settings_f = "fax-id modem-type switchbd $settings";
- goto again if (&confirm ($port) ne "y");
- &write_tmp;
-}
-
-close (TMP1);
-close (TMP2);
-if ( -e "$prefix/etc/mgetty+sendfax/mgetty.config") {
- system ("mv -f $prefix/etc/mgetty+sendfax/mgetty.config $prefix/etc/mgetty+sendfax/mgetty.config.old");
- system ("rm -f $prefix/etc/mgetty+sendfax/mgetty.config");
-}
-if ( -e "$prefix/etc/mgetty+sendfax/sendfax.config") {
- system ("mv -f $prefix/etc/mgetty+sendfax/sendfax.config $prefix/etc/mgetty+sendfax/sendfax.config.old");
- system ("rm -f $prefix/etc/mgetty+sendfax/sendfax.config");
-}
-system ("mv -f /tmp/mgetty.config.$$ $prefix/etc/mgetty+sendfax/mgetty.config");
-system ("mv -f /tmp/sendfax.config.$$ $prefix/etc/mgetty+sendfax/sendfax.config");
-
-open (F, ">$prefix/etc/mgetty+sendfax/faxheader");
-print F "\n FAX FROM: **not configured** $def{fax-id} TO: \@T\@ PAGE: \@P\@ OF \@M\@ \n";
-close (F);
-
-
-print STDERR "\n\nediting /etc/ttys...\n";
-
-open (F, "/etc/ttys");
-@ttys = <F>;
-close (F);
-
-foreach $tty (@ttys) {
- $_ = $devices;
- foreach $port (split) {
- if ($tty =~ /^\s*$port/) {
- print STDERR "replacing line $tty";
- $tty = "$port\t\"$prefix/sbin/mgetty\"\tunknown on insecure\n";
- $replaced{$port} = 1;
- }
- }
-}
-$_ = $devices;
-foreach $port (split) {
- if (!$replaced{$port}) {
- print STDERR "adding port $port\n";
- push (@ttys, "$port\t\"$prefix/sbin/mgetty\"\tunknown on insecure\n");
- }
-}
-system ("mv -f /etc/ttys /etc/ttys.old");
-open (F, ">/etc/ttys");
-print F @ttys;
-close (F);
-
-# install new_fax
-if (-e "$prefix/lib/mgetty+sendfax/lib/new_fax") {
- print STDERR "$prefix/lib/mgetty+sendfax/lib/new_fax already exists - not changed\n";
-} else {
- print STDERR "installing $prefix/lib/mgetty+sendfax/lib/samples/new_fax.mail as new_fax\n";
- open (F, "$prefix/lib/mgetty+sendfax/lib/samples/new_fax.mail");
- open (G, "$prefix/lib/mgetty+sendfax/lib/new_fax");
- while (<F>) {
- s:/usr/local/bin/:$prefix:;
- s:/usr/lib/sendmail:/usr/sbin/sendmail:;
- s/^MAILTO=.*/$def{'notify'}\n/;
- print G "$_";
- }
- close F;
- close G;
- chmod 0755, "$prefix/lib/mgetty+sendfax/lib/new_fax";
-}
-print STDERR "\n\n*** WARNING the directory /var/spool/fax/outgoing/ is world writable.\n*** This is potentially insecure\n";
-
-exit 0;
-
-sub confirm {
- $_ = shift;
- print STDERR "\n\n\tSettings for port $_\n\t------------------------\n";
- $_ = $settings_m;
- foreach (split) {
- print STDERR "\t$_ $def{$_}\n" if ($def{$_});
- }
- $_ = $settings_f;
- foreach (split) {
- print STDERR "\t$_ $def_f{$_}\n" if ($def_f{$_});
- }
- return &yesno ("OK?", "y");
-}
-
-sub write_tmp {
- $_ = $settings_m;
- foreach (split) {
- print TMP1 "$_ $def{$_}\n" if ($def{$_});
- }
- $_ = $settings_f;
- foreach (split) {
- print TMP2 "$_ $def_f{$_}\n" if ($def_f{$_});
- }
-}
-
-sub inq_m {
- $settings = "debug";
- $def{'debug'} = 4 if !$def{'debug'};
- $def{'debug'} = &ask (" - `debug (mgetty)'
- This sets the amount of logging `mgetty' will do. A good value is
- 4, more details are seen with `5', and `9' is really noisy. Try
- it! The log data is written to the file `/tmp/log_mg.cuaxx'.",
- $def{'debug'});
-
- $settings .= " fax-id";
- $def{'fax-id'} = "00 00 000000" if ! $def{'fax-id'};
- $def{'fax-id'} = &ask (" - `fax-id'
- This sets the fax station ID used in fax mode to identify your
- site to the caller (usually this is simply your fax phone number).
- ", $def{'fax-id'}) ;
- $def_f{'fax-id'} = $def{'fax-id'} ;
-
- $settings .= " speed";
- $def{'speed'} = 38400 if !$def{'speed'};
- $def{'speed'} = &ask (" - `speed'
- Specify, as integer value, the port speed to use. Default is
- 38400. If the given speed is not valid, `mgetty' complains loudly
- and exits.", $def{'speed'});
-
- $settings .= " switchbd";
- $def{'switchbd'} = 0 if !$def{'switchbd'};
- $def{'switchbd'} = &ask (" - `switchbd'
- Some modems, mainly Rockwell chipsets, switch to 19200 bps when
- entering fax mode. Others may need other speed switches (but I
- know none). If your modem is Rockwell based, try `switchbd 19200'
- if fax reception doesn't work. (*Warning:* if this is set wrongly,
- fax reception will definitely fail. For most sane modems, you do
- *not need* this.). Set speed or `0'", $def{'switchbd'});
- $def_f{'switchbd'} = $def{'switchbd'};
-
- $settings .= " direct";
- $def{'direct'} = "NO" if !$def{'direct'};
- $def{'direct'} = &ask (" - `direct'
- Tells mgetty that it is running on a direct line. Mgetty won't try
- to initialize any modem, nor will it wait for `RING'. It will just
- wait for any character, and then output the issue file and login
- prompt. This option is used if you want to connect to machines via
- nullmodem cable.", $def{'direct'});
-
- $settings .= " blocking";
- $def{'blocking'} = "NO" if !$def{'blocking'};
- $def{'blocking'} = &ask (" - `blocking'
- Tells mgetty to open the device in `blocking' mode, that is, the
- `open()' system call won't succeed until carrier detect is set.
- This is set if `mgetty' is called as `getty'. I'm not sure whether
- it's very useful, but I include it for completeness", $def{'blocking'});
-
- $settings .= " port-owner";
- $def{'port-owner'} = "uucp" if !$def{'port-owner'};
- $def{'port-owner'} = &ask (" - `port-owner'
- If set, mgetty will `chown' the tty line to the given username (you
- can specify a string or an integer uid, but the integer must be
- valid). This is highly recommended for security purposes: only
- give port access to those users you trust not to misuse your modem
- lines!", $def{'port-owner'});
-
- $settings .= " port-group";
- $def{'port-group'} = "uucp" if !$def{'port-group'};
- $def{'port-group'} = &ask (" - `port-group'
- If set, mgetty will `chgrp' the tty line to this group id (which
- can be given as group name, or as integer gid). If it's not given,
- or not valid, the primary group id of `port-owner'
- will be used.", $def{'port-group'});
-
- $settings .= " port-mode";
- $def{'port-mode'} = "0660" if !$def{'port-mode'};
- $def{'port-mode'} = &ask (" - `port-mode'
- Specifies the permissions to `chmod' the device to.
- *Never* make a modem device world-accessible, better use `0660'
- or even `0600'.", $def{'port-mode'} );
-
- $settings .= " toggle-dtr";
- $def{'toggle-dtr'} = "YES" if !$def{'toggle-dtr'};
- $def{'toggle-dtr'} = &ask (" - `toggle-dtr'
- Tells mgetty whether it should lower the DTR line upon startup to
- reset modem. Default is `yes', but some (few) modems react
- allergic to that and crash.", $def{'toggle-dtr'});
-
- $settings .= " toggle-dtr-waittime";
- $def{'toggle-dtr-waittime'} = 500 if !$def{'toggle-dtr-waittime'};
- $def{'toggle-dtr-waittime'} = &ask (" - `toggle-dtr-waittime'
- Specifies the time (in ms) to hold the DTR line low.", $def{'toggle-dtr-waittime'} );
-
- $settings .= " data-only";
- $def{'data-only'} = "NO" if !$def{'data-only'};
- $def{'data-only'} =&ask (" - `data-only'
- Tells `mgetty' to forget about faxing and only use the data part of
- the modem. Default is `false'. You need this if your modem can't
- distinguish incoming fax and data calls.", $def{'data-only'} );
-
- $settings .= " fax-only";
- $def{'fax-only'} = "NO" if !$def{'fax-only'};
- $def{'fax-only'} = &ask (" - `fax-only'
- Tells `mgetty' to put the modem in fax-only mode. You need this if
- your modem can't distinguish incoming fax and data calls, but you
- need fax more important than data; and you need it if you want to
- disable data calls for security reasons (this could be achieved
- via `login.config' as well)", $def{'fax-only'});
-
- $settings .= " modem-type";
- $def{'modem-type'} = "auto" if ! $def{'modem-type'};
- $def{'modem-type'} = &ask (" - `modem-type'
- Specifies the kind of modem connected to the port. Valid options are:
- * auto
- Mgetty will detect the modem type itself (which may occasionally
- be not desirable, or it may fail on old modem equipment).
- * c2.0
- Modem is a CLASS 2.0 fax mode. Works better than class 2, if
- both are available, because its better standardized. Known to
- work with USR and ZyXEL.
- * cls2
- Modem is a CLASS 2 fax modem, mgetty will not try class 2.0.
- * data
- Do not try fax initialization
- There is no way (yet) to tell mgetty to use *only* fax mode and
- refuse data calls with this option, use the `fax-only true'
- statement for that.", $def{'modem-type'});
- $def_f{'modem-type'} = $def{'modem-type'};
-
- $settings .= " init-chat";
- $def{'init-chat'} = '"" ATS0=0Q0&D3&C1 OK' if ! $def{'init-chat'};
- $def{'init-chat'} = &ask (" - `init-chat'
- Tells mgetty the chat sequence to use for initializing the modem.
- *Warning*: the sequence starts with *expect*, which will in most
- cases be `\"\"' (nothing). This ordering was chosen because UUCP
- does it this way, and I wanted to avoid confusion here.
-
- Example:
-
- \"\" \\d\\d\\d+++\\d\\d\\dATQ0E1V1H0 OK ATL0M0S0=0 OK AT&K3 OK
- init sequence", $def{'init-chat'});
-
- $settings .= " force-init-chat";
- $def{'force-init-chat'} = "" if !$def{'force-init-chat'};
- $def{'force-init-chat'} = &ask (" - `force-init-chat'
- In some cases, the modem can get stuck in a mode where it won't
- react to a simple `AT' command. Usually this happens because the
- modem is set to ignore a DTR drop and still has a data connection
- to the other side. If you use a voice modem, it could be stuck in
- voice mode.
-
- In these situations, the normal `init-chat' will time out, because
- the modem won't send the proper responses back.
-
- To get the modem back into a sane state, you can use the
- `force-init-chat' chat sequence. The default setup will send the
- DLE ETX characters, to get voice modems back to life, and then the
- `(pause)+++(pause)ATH0' sequence to get the modem back from data
- mode to command mode.
-
- You could prepend this sequence to `init-chat' (it wouldn't harm),
- but especially the pauses around the +++ sequence makes this
- undesirable slow.", $def{'force-init-chat'});
-
- $settings .= " modem-check-time";
- $def{'modem-check-time'} = 3600 if ! $def{'modem-check-time'};
- $def{'modem-check-time'} = &ask (" - `modem-check-time'
- Some modems have the nasty tendency to crash silently. With this
- option, you tell `mgetty' to check every SECONDS seconds with a
- simple `AT...OK' sequence whether the modem still reacts. If not,
- `mgetty' will restart itself and do a full modem reset.", $def{'modem-check-time'});
-
- $settings .= " rings";
- $def{'rings'} = 1 if !$def{'rings'};
- $def{'rings'} = &ask (" - `rings'
- Sets the number of `RING' messages to wait for, before mgetty
- picks up the phone. *Warning:* if your modem auto-answers, for
- whatever reason, set this to something *different* than the
- value set with `ATS0=mmm', otherwise the modems autoanswer and
- mgettys manual answer will collide (most modems hang up if a
- command is received during auto-answer)", $def{'rings'});
-
-
- $settings .= " answer-chat";
- $def{'answer-chat'} = '"" ATA CONNECT \c \r' if !$def{'answer-chat'};
- $def{'answer-chat'} =&ask (" - `answer-chat'
- This is the command sequence that is used to answer a phone call.
- Usually you can leave it at the default ` \"\" ATA CONNECT \\c \\r ',
- but for some modems you need `ATS0=1' in place of `ATA' (ATA not
- allowed). The extra `\\r' expect string is needed that the code can
- grab the full CONNECT XYZ\\R string. It will work without the \\r,
- but then the logging information will be less detailed. *Right now,
- \\r won't work at all, it's not implemented yet. Don't use it.*
- ", $def{'answer-chat'} );
-
- $settings .= " answer-chat-timeout";
- $def{'answer-chat-timeout'} = 80 if !$def{'answer-chat-timeout'};
- $def{'answer-chat-timeout'} = &ask (" - `answer-chat-timeout'
- During the ANSWER-CHAT, each \"expect\" string must be seen in the
- time specified here. Default is 80 seconds. This time should be at
- least some 5 seconds longer than the time set with the `ATS7=...'
- modem setup command.", $def{'answer-chat-timeout'});
-
- $settings .= " autobauding";
- $def{'autobauding'} = "NO" if !$def{'autobauding'};
- $def{'autobauding'} = &ask (" - `autobauding'
- Some modems switch their DTE line speed to the communication line
- speed after connecting, e.g., after sending `CONNECT 2400', the
- modem switches to 2400 bps. Newer modems usually have a switch to
- \"lock\" a DTE baud rate, which is strongly recommended. If your
- modem insists on doing this speed switch, setting `autobauding' to
- YES will make mgetty behave accordingly.", $def{'autobauding'});
-
- $settings .= " ringback";
- $def{'ringback'} = "NO" if !$def{'ringback'} ;
- $def{'ringback'} = &ask (" - `ringback'
- If you have to put your modem and your telephone on the same phone
- line, you can switch on \"ringback\" or \"ring-twice\". This means,
- mgetty won't answer the phone on the first call, but remember the
- call, and pick up on the second call (if it comes in the time
- specified by `ringback-time').", $def{'ringback'} );
-
- $settings .= " ringback-time";
- $def{'ringback-time'} = "30" if !$def{'ringback-time'} ;
- $def{'ringback-time'} = &ask (" - `ringback-time'
- This setting specifies how much time may pass between the first
- and the second call if \"ringback\" is active.", $def{'ringback-time'});
-
- $settings .= " ignore-carrier";
- $def{'ignore-carrier'} = "false" if !$def{'ignore-carrier'} ;
- $def{'ignore-carrier'} = &ask (" - `ignore-carrier'
-
- If your Modem does not assert the DCD (carrier detect) line, or the
- serial port or cable or serial driver is broken, it is possible
- that `mgetty' or `login' will block after a successful CONNECT
- (that means: everything seems to work, but suddenly nothing is sent
- to the port anymore. Depending on the operating system used, this
- can be before printing the `/etc/issue' file or not before printing
- the `password:' prompt.
-
- To work around this, you can switch off the carrier detection in
- software: set `ignore-carrier true'. Default is `false'.
-
- *WARNING:* If you use this, your system won't be able to detect
- when a caller just hangs up instead of cleanly logging out. This
- may result in hanging modems, etc.", $def{'ignore-carrier'});
-
- $settings .= " issue-file";
- $def{'issue-file'} = "/etc/issue" if !$def{'issue-file'} ;
- $def{'issue-file'} = &ask (" - `issue-file'
- This is the file printed before the login prompt.", $def{'issue-file'});
-
- $settings .= " prompt-waittime";
- $def{'prompt-waittime'} = "500" if !$def{'prompt-waittime'} ;
- $def{'prompt-waittime'} = &ask (" - `prompt-waittime'
- This specifies how long `mgetty' will wait for modem and line to
- settle down (in ms) before printing issue file and login prompt",
- $def{'prompt-waittime'});
-
- $settings .= " login-prompt";
- $def{'login-prompt'} = "@!login: " if !$def{'login-prompt'} ;
- $def{'login-prompt'} = &ask(" - `login-prompt'
- This specifies the login prompt that mgetty will output. Some
- special characters in this string (and in the issue file, btw) are
- recognized and replaced by something else:
- * @ system name
- * \\n newline
- * \\r carriage return
- * \\g bell
- * \\b backspace (ascii 010)
- * \\f form feed (ascii 013)
- * \\t TAB
- * \\P (and \\L) port name (e.g. ttyS0)
- * \\C date and time, in \"ctime()\" format
- * \\I Connection string (e.g. 2400/REL)
- * \\N (and \\U) number of users currently logged in
- * \\S Port speed (e.g. 38400)
- * \\D current date in dd/mm/yy format
- * \\T current time in hh:mm:ss format
- * \\DIGIT character with the specified octal code
-
- The maximum lenght of the login prompt is limited to 140
- characters (after expansion).", $def{'login-prompt'});
-
- $settings .= " login-time";
- $def{'login-time'} = 240 if !$def{'login-time'};
- $def{'login-time'} = &ask (" - `login-time'
- This specifies the maximum time the user can take to log in. If no
- login has occured after that time, `mgetty' will hang up.",
- $def{'login-time'});
-
- $settings .= " fax-server-file";
- $def{'fax-server-file'} = &ask (" - `fax-server-file'
- Specifies the fax file(s) that is to be sent if someone else calls
- your modem in *fax polling mode*, that is, the caller *receives* a
- document.
-
- Normally, the file given is a text file, containing the list of G3
- files to send to the calling machine, one file per line. Comment
- lines (starting with \"#\") are ignored. For backward compatibility,
- `mgetty' does check whether the named file is a G3 file itself, in
- which case this file is sent directly (but then, you can only send
- one page).
-
- Not all modems support fax poll *server* mode, I know that the
- ZyXEL and MultiTech do.", $def{'fax-server-file'});
-
- $settings .= " diskspace";
- $def{'diskspace'} = 1024 if !$def{'diskspace'};
- $def{'diskspace'} = &ask (" - `diskspace'
- This setting tells mgetty the minimum amount of disk space (in KB) that
- has to be available in the fax spool directory for fax reception
- to be allowed.", $def{'diskspace'});
-
- $settings .= " notify";
- $def{'notify'} = "faxadmin" if !$def{'notify'};
- $def{'notify'} = &ask (" - `notify'
- This is the address that will get mails if a fax is received. Not
- fully tested.", $def{'notify'});
-
- $settings .= " fax-owner";
- $def{'fax-owner'} = "uucp" if !$def{'fax-owner'};
- $def{'fax-owner'} = &ask (" - `fax-owner'
- If set, mgetty will `chown' the received files to the given username
- (you can specify a string or an integer uid, but the integer must be
- valid).", $def{'fax-owner'});
-
- $settings .= " fax-group";
- $def{'fax-group'} = "modem" if !$def{'fax-group'};
- $def{'fax-group'} = &ask (" - `fax-group'
- If set, mgetty will `chgrp' the received files to this group id
- (which can be given as group name, or as integer gid).", $def{'fax-group'});
-
- $settings .= " fax-mode";
- $def{'fax-mode'} = "0660" if !$def{'fax-mode'};
- $def{'fax-mode'} = &ask (" - `fax-mode'
- Specifies the permissions to `chmod' the received files.", $def{'fax-mode'});
-}
-sub inq_f {
- $settings = "debug";
- $def_f{'debug'} = 4 if !$def_f{'debug'};
- $def_f{'debug'} = &ask (" - `debug (sendfax)'
- controls the amount of information written into the fax log file.
- `0' means \"totally silent\" (not even errors are written), `9'
- is really noisy. I usually use `3' or `4' in normal use, and `6'
- for debugging.", $def_f{'debug'});
-
- $settings .= " modem-init";
- $def{'modem-init'} = &ask (" - `modem-init'
- Specifies an `AT...' command that is to be sent to the modem right
- at the *beginning* of all modem talk (even before setting the modem
- into fax mode, so this could be an `ATZ' if you want to reset the
- modem).", "");
-
- $settings .= " modem-handshake";
- $def_f{'modem-handshake'} = "AT&H3" if !$def_f{'modem-handshake'};
- $def_f{'modem-handshake'} = &ask (" - `modem-handshake'
- Specifies an `AT...' command that will be sent to the modem at the
- *end* of the modem initialization, right before dialing. *Do not
- use ATZ or such here*, since resetting the modem will switch off
- fax mode.", $def_f{'modem-handshake'});
-
- $settings .= " max-tries";
- $def_f{'max-tries'} = 3 if !$def_f{'max-tries'};
- $def_f{'max-tries'} = &ask (" - `max-tries'
- Specify the maximum number of tries per page if the receiving end
- reports reception errors. If NNN tries do not suffice to
- successfully transmit a page, `sendfax' will give up or simply go
- on, depending on the setting of `max-tries-continue' (see below).
- If this is set to `0', `sendfax' will ignore retransmission
- requests and simply go on.", $def_f{'max-tries'});
-
- $settings .= " max-tries-continue";
- $def_f{'max-tries-continue'} = "YES" if !$def_f{'max-tries-continue'};
- $def_f{'max-tries-continue'} = &ask (" - `max-tries-continue'
- After the maximum number of tries for one page are reached,
- `sendfax' can report an error and abort (`max-tries-continue NO'),
- or go on with the next page (YES).
-
- For \"mission critical\" faxes, I'd set it to NO, but since the page
- quality is most often quite good even if reported as \"page bad\",
- the default is YES.", $def_f{'max-tries-continue'});
-
- $settings .= " speed (fax)";
- $def_f{'speed'} = 38400 if ! $def_f{'speed'};
- $def_f{'speed'} = &ask (" - `speed'
- Set the port speed to use for fax send operations. Usually,
- `38400' is a good choice, but a few dumb modems (for example, some
- based on rockwell chipsets) need `19200' or even `9600'. A few
- modems can go higher, but `sendfax' may not support it, and it may
- not always work.", $def_f{'speed'});
-
- $settings .= " dial-prefix";
- $def_f{'dial-prefix'} = "ATD" if !$def_f{'dial-prefix'};
- $def_f{'dial-prefix'} = &ask (" - `dial-prefix'
- This is the command used for dialing out. Usually this will be
- something simple, as `ATD' or `ATDP', but if you have an unusual
- setup, it could also be something like `ATX0DP0;X4DT' (meaning:
- switch off dial-tone detection, pulse-dial `0', back to command
- mode, switch on dial-tone detection, and go ahead dialing with
- touch tones). The phone number will be sent right after the
- `dial-prefix'.", $def_f{'dial-prefix'});
-
- $settings .= " poll-dir";
- $def_f{'poll-dir'} = "./" if !$def_f{'poll-dir'};
- $def_f{'poll-dir'} = &ask (" - `poll-dir'
- This is used to specify a directory where polled faxes (wheather
- maps and such) are to be saved into. Default is the current
- directory.", $def_f{'poll-dir'});
-
- $settings .= " normal-res";
- $def_f{'normal-res'} = "NO" if !$def_f{'normal-res'};
- $def_f{'normal-res'} = &ask (" - `normal-res'
- If set to `yes' or `true' (boolean), `sendfax' won't attempt to
- make a fax connection in \"fine resolution\" mode. Normally you
- won't need to use that option, since `faxrunq' will set the `-n'
- switch if needed.", $def_f{'normal-res'});
-
- $settings .= " verbose";
- $def_f{'verbose'} = "NO" if !$def_f{'verbose'};
- $def_f{'verbose'} = &ask (" - `verbose'
- If set to `yes' or `true', `sendfax' will output progress reports
- on stdout, if set to `no', `sendfax' will only print error and
- warning messages.", $def_f{'verbose'});
-}
-sub setdef {
- local ($p, $l);
- $p = shift;
- $l = length ($p) + 1;
- foreach (keys(%var_m)) {
- $def{$_} = substr ($var_m{$_}, $l) if ($var_m{$_} =~ /^$p/);
- }
- foreach (keys(%var_m)) {
- $def{$_} = substr ($var_m{$_}, 1) if (!$def{$_} && $var_m{$_} =~ /^$sep/);
- }
- foreach (keys(%var_f)) {
- $def_f{$_} = substr ($var_f{$_}, $l) if ($var_f{$_} =~ /^$p/);
- }
- foreach (keys(%var_m)) {
- $def_f{$_} = substr ($var_f{$_}, 1) if (!$def_f{$_} && $var_f{$_} =~ /^$sep/);
- }
-}
-sub ask {
- ($info, $default, $x) = @_;
- print STDERR "\n$info: ";
- print STDERR "[$default] " if ($default);
- $_ = <STDIN>;
- s/^\s*//;
- chop;
- if ($_ eq "") {
- return $default;
- }
- return $_;
-}
-sub read_config {
- local ($conf, $port, $a, $b);
-
- $conf = shift;
- $port = $sep;
- if ( -f $conf) {
- open (F, $conf) || die "$!\n";
- while (<F>) {
- chop;
- s/^\s*//;
- next if /^#/;
- next if /^$/;
- ($a, $b) = split (/[ \t\n]+/, $_, 2);
- if ($a eq "port") {
- $port = $b;
- $var{'ports'} .= "$port ";
- } else {
- $var{$a} = "$port $b";
- }
- }
- close F;
- }
-}
-
-sub yesno {
- print STDERR "$_[0]: ";
- print STDERR "[$_[1]] " if ($_[1]);
- $_ = <STDIN>;
- chop;
- $_ = $_[1] if ! $_;
- return "y" if /^[Yy].*/;
- return "n";
-}
diff --git a/comms/mgetty+sendfax/pkg-plist b/comms/mgetty+sendfax/pkg-plist
index 8a0642bf5157..19b26c18729b 100644
--- a/comms/mgetty+sendfax/pkg-plist
+++ b/comms/mgetty+sendfax/pkg-plist
@@ -9,6 +9,7 @@ bin/g3cat
bin/g3topbm
bin/lintopvf
bin/mg.echo
+bin/mgettycfg
bin/newslock
bin/pbm2g3
bin/pvfamp