3 # smbtar script - front end to smbclient
5 # Authors: Martin.Kraemer <Martin.Kraemer@mch.sni.de>
6 # and Ricky Poulten (ricky@logcam.co.uk)
8 # (May need to change shell to ksh for HPUX or OSF for better getopts)
10 # sandy nov 3 '98 added -a flag
12 # Richard Sharpe, added -c 'tarmode full' so that we back up all files to
13 # fix a bug in clitar when a patch was added to stop system and hidden files
17 # when called by absolute path, assume smbclient is in the same directory
19 SMBCLIENT
="$(dirname $0)/smbclient"
21 *) # you may need to edit this to show where your smbclient is
22 SMBCLIENT
="smbclient" ;;
25 # These are the default values. You could fill them in if you know what
26 # you're doing, but beware: better not store a plain text password!
28 service
="backup" # Default: a service called "backup"
30 username
=$LOGNAME # Default: same user name as in *nix
31 verbose
="2>/dev/null" # Default: no echo to stdout
37 clientargs
="-c 'tarmode full'"
41 tapefile
=${TAPE-tar.out}
47 echo >&2 "Usage: $(basename $0) [<options>] [<include/exclude files>]
48 Function: backup/restore a Windows PC directories to a local tape file
49 Options: (Description) (Default)
50 -r Restore from tape file to PC Save from PC to tapefile
51 -i Incremental mode Full backup mode
52 -a Reset archive bit mode Don't reset archive bit
53 -v Verbose mode: echo command Don't echo anything
54 -s <server> Specify PC Server $server
55 -p <password> Specify PC Password $password
56 -x <share> Specify PC Share $service
57 -X Exclude mode Include
58 -N <newer> File for date comparison $(
62 -b <blocksize> Specify tape's blocksize $(
66 -d <dir> Specify a directory in share $cdcmd
67 -l <log> Specify a Samba Log Level $(
71 -u <user> Specify User Name $username
72 -t <tape> Specify Tape device $tapefile
78 # echo Params count: $#
80 # DEC OSF AKA Digital UNIX does not seem to return a value in OPTIND if
81 # there are no command line params, so protect us against that ...
84 Usage
2 "Please enter a command line parameter!"
88 while getopts riavl
:b
:d
:N
:s
:p
:x
:u
:Xt
: c
; do
90 r
) # [r]estore to Windows (instead of the default "Save from Windows")
95 clientargs
="-c 'tarmode inc'"
100 l
) # specify [l]og file
105 echo >&2 "$0: Error, log level not numeric: -l $OPTARG"
110 d
) # specify [d]irectory to change to in server's share
113 N
) # compare with a file, test if [n]ewer
114 if [ -f $OPTARG ]; then
118 echo >&2 $0: Warning
, $OPTARG not found
121 X
) # Add exclude flag
124 s
) # specify [s]erver's share to connect to - this MUST be given.
127 b
) # specify [b]locksize
132 echo >&2 "$0: Error, block size not numeric: -b $OPTARG"
138 p
) # specify [p]assword to use
141 x
) # specify windows [s]hare to use
144 t
) # specify [t]apefile on local host
147 u
) # specify [u]sername for connection
150 v
) # be [v]erbose and display what's going on
154 '?') # any other switch
155 Usage
2 "Invalid switch specified - abort."
160 shift $
(expr $OPTIND - 1)
162 if [ "$server" = "" ] ||
[ "$service" = "" ]; then
163 Usage
1 "No server or no service specified - abort."
166 # if the -v switch is set, the echo the current parameters
167 if [ -z "$verbose" ]; then
168 echo "server is $server"
169 # echo "share is $service"
170 echo "share is $service\\$cdcmd"
171 echo "tar args is $tarargs"
172 # echo "password is $password" # passwords should never be sent to screen
173 echo "tape is $tapefile"
174 echo "blocksize is $blocksize"
177 tarargs
=${tarargs}${blocksizearg}${newerarg}
179 eval $SMBCLIENT "'\\\\$server\\$service'" "'$password'" -U "'$username'" \
180 -E $log -D "'$cdcmd'" ${clientargs} \
181 -T${tarcmd}${tarargs} $blocksize $newer $tapefile '${1+"$@"}' $verbose