[comp.sys.att] Using FTP from cron with .netrc

kmeek@cti1.UUCP (Kevin Meek) (01/09/91)

I am trying to send files from a central machine to 
another file on the remote host.

What I've done is create a .netrc directory in my home directory
with the machine name and password.

then I run the following shell script

# ---- shell script ----------
#
# Shell script to send files to remote machine
#  .netrc should take care of login etc.
#
ftp machinename <<!
binary 
send file1 junk1
send file2 junk2
quit
!
# ---- End of shell script ----------


This script works fine when I execute it from the prompt 
but when I try to run it from my cron I get the following
errors.  

 Name (sea06u:): Password (sea06u:binary): Login disallowed for binary.
 Login failed.
 ?Invalid command
 Please login with USER and supply the password when the prompt appears.
 Please login with USER and supply the password when the prompt appears.

It isn't using the .netrc??  

I tried setting the $HOME variable and even running an
su -c username "shellscript" in the cron so my .profile
would be run but still no dice!.

Any suggestions  -- why won't ftp work from cron.

I am working on an AT&T 3B2600G running system V ver 3.2.2

Kevin Meek

-- 
Kevin Meek 
kmeek@cti.com

thad@cup.portal.com (Thad P Floryan) (01/10/91)

kmeek@cti1.UUCP (Kevin Meek) in <366@cti1.UUCP> writes:

	I am trying to send files from a central machine to 
	another file on the remote host.

	What I've done is create a .netrc directory in my home directory
	with the machine name and password.

	then I run the following shell script
	[...]
	This script works fine when I execute it from the prompt 
	but when I try to run it from my cron I get the following
	errors.  
	[...]
	It isn't using the .netrc??  
	I tried setting the $HOME variable and even running an
	su -c username "shellscript" in the cron so my .profile
	would be run but still no dice!.

	Any suggestions  -- why won't ftp work from cron.

	I am working on an AT&T 3B2600G running system V ver 3.2.2

At first I received the same errors and non-performance that you did on my
3B1 systems.  Then I tried some experiments and got it to work fine!

The trick is in both the shell script and in the crontab entry.

Running it as my normal login, thad, it all worked fine.

Running it as another user, even su'd to thad, my "doit" script didn't work,
so I added the "echo" of $HOME and $PWD and that provided the clue to set
HOME in the shell script itself since that's what ftp apparently needs, and the
use of "/bin/sh" is important in the crontab entry to prevent a "Nonstandard
shell" error message.

Kevin's posting of his problem highlighted a potentially neato application
I needed to do, so I had more than a passing interest to get this to work.
Thanks for the idea, and accept this fix as my way of saying "Thanks!".

To avoid cluttering the net with example of some stupid errors (:-) I'll just
show the final script, crontab entry, and log of a successful run.

First:
	total 14
	-rw-r--r--  1 thad    users       865 Jan 10 07:22 #ftp-with-cron
	-rw-r--r--  1 thad    users       785 Jan 10 07:17 crontab
	-rw-r--r--  1 thad    users       916 Jan 10 07:16 crontab~
	-rw-r--r--  1 thad    users        61 Jan  9 04:53 doit
	-rwxr-xr-x  1 thad    users       220 Jan 10 07:11 doit2
	-rwxr-xr-x  1 thad    users       218 Jan 10 06:57 doit2~
	-rw-r--r--  1 thad    users      1648 Jan  9 03:19 ftp-with-cron
	-rw-r--r--  1 thad    users        91 Jan  9 04:23 toget

Crontab entry (the first produces no log, the second does):

	#13    7  *  *  *  /bin/sh         -c "/u/thad/test/doit2  >/dev/null"
	15    7  *  *  *  /bin/sh         -c "/u/thad/test/doit2"

The shell script (doit2):

	uname -a
	#who am i			# had to patch out for use with cron
	echo $HOME "   " $PWD
	#
	HOME=/u/thad;export HOME
	#who am i			# had to patch out for use with cron
	echo $HOME "   " $PWD
	#
	cd /u/thad/test
	echo $HOME "   " $PWD
	#
	ftp <<!
	open tlabs3
	binary
	verbose
	get xfr/hdhelp.tar hdhelp.tar
	bye
	!
	exit 0

The results from the cronlog, and note that whomever is actually running cron
does NOT have a $HOME or $PWD:

Thu Jan 10 07:12:00 1991
crontab read
/bin/sh         -c "/u/thad/test/doit2 > /dev/null"

Thu Jan 10 07:14:00 1991
crontab read
/bin/sh         -c "/u/thad/test/doit2"
UNIX thadlabs SYSTEM5 3.51a mc68k
   
/u/thad    
/u/thad    
Verbose mode on.
200 PORT command okay.
150 Opening data connection for xfr/hdhelp.tar (128.15.22.2,1206) (15360 bytes)
.
226 Transfer complete.
15360 bytes received in 0.28 seconds (53 Kbytes/s)
221 Goodbye.
/bin/su uucpadm -c "/usr/lib/uucp/uudemon.poll    >/dev/null"

Thu Jan 10 07:18:00 1991
crontab read
/bin/su uucpadm -c "/usr/lib/uucp/uudemon.hour    >/dev/null"