Adaptation to EricBackup.bat

I took the liberty to adapt EricBackup.bat created by Eric.
Eric graciously permitted me to post to his blog aswell.

I have almost completely rewritten the batchfile for it to meet my fancy ;)
Replaced blat with sendmail and using delage32 to cleanup previous backupfiles and logfiles.
Date and time variables are in European format, change this if you want/need to.
The first part declares a bunch of variables, read this carefully.

Hands down to Eric, he laid the foundation for me to create this.

Below the source I have created. Comments are welcome.

MyBackup.bat

@ECHO OFF
:: ====
:: PROGRAMÂ Â Â Â Â Â Â Â Â Â : MYBACKUP.BAT
:: BYÂ Â Â Â Â Â Â Â Â Â Â Â Â Â Â : M.T.D. JONKER
:: ADAPTED FROMÂ Â Â Â Â : EricBackup.bat Version 2.8, EricGreer@GMail.com, http://blog.integrii.net/?p=76
:: CREATION DATEÂ Â Â Â : 20-12-2008
:: LATEST REVISIONÂ Â : 22-02-2009
::====
::22-02-2009: REDID REMOVAL OF OLD BACKUPFILES AND LOGFILES THROUGH EXTERNAL TOOL DELAGE32
::20-01-2009: ADDED REMOVAL OF PREVIOUS LOGFILES
::20-01-2009: CREATED VARIABLE "BACKUPFILE" TO REMOVE CLUTTER
::20-01-2009: REWROTE REMOVAL OF PREVIOUS BACKUPFILES
::10-01-2009: ADDED REMOVAL OF PREVIOUS BACKUPFILES
::22-12-2008: REPLACED BLAT WITH SENDMAIL
::20-12-2008: REWROTE BATCHFILE
::====
TITLE ADVANCED NTBACKUP SCRIPT
COLOR 1F
::====SET VARIABLES.HERE====
::ADJUST VARIABLES TO MEET YOUR PREFERENCE

::BACKUP RELATED VARIABLES
::SET USERNAME (AS SHOWN IN C:\DOCUMENTS AND SETTINGS\),
SET USER=
::PATH TO PUT LOGFILES OF THIS BATCHFILE AND NTBACKUP
SET ARCHIVEPATH=C:\Backups\logs
:: ORIGINAL (DEFAULT) LOCATION OF NTBACKUP LOGFILE
SET LOGPATH="%USERPROFILE%\Local Settings\Application Data\Microsoft\Windows NT\NTBackup\data"
::SET THE DESTINATION FOLDER OF YOUR BACKUP
SET DESTINATION=C:\BACKUPS\%COMPUTERNAME%
::SET PATH TO SENDMAIL.EXE
SET MAILPATH=C:\Backups\sendmail.exe
::SET PATH TO delage32.exe
SET DAPATH=C:\Backups\delage32.exe
::SET NAME OR IP OF SMTPSERVER TO BE USED
SET SMTPSERVER=smtp.server.com
::SET THE TO ADDRESS
SET TO=name@domain.com
::SET THE FROM ADDRESS
SET FROM=name@domain.com
::SET THE SOURCE OF YOUR BACKUP (FOR EXAMPLE: D:) NOT USED IN SYSTEMSTATE BACKUP
::SET SOURCE=D:
::SET A NOTE TO DESCRIBE YOUR BACKUP (USED IN FILENAME, SO REFRAIN FROM USING NON COMPATIBLE CHARACTERS)
::SET NOTE=D-DRIVE
::====COMMAND LINE PASSING====
::THE VARIABLES NOTE AND SOURCE CAN BE PASSED FROM THE COMMAND LINE.
::EIHTER SET THEM ABOVE OR USE THE SETTING BELOW
::COMMENT/UNCOMMENT AS NEEDED
::WHEN PASSED FROM THE COMMAND LINE BOTH SOURCE AND NOTE MUST BE PROPERLY FILLED
::SO USE SHORT FILENAMES SUCH AS C:\DOCUME~1\, WITHOUT QUOTES
SET SOURCE=%2
::USED IN FILENAME, SO REFRAIN FROM USING NON COMPATIBLE CHARACTERS
SET NOTE=%3
::====DONE SETTING MANUAL VARIABLES====

::DETERMINE BACKUPMODE
SET BACKUPMODE=NONE
IF "%1" == "systemstate" SET BACKUPMODE=SYSTEMSTATE
IF "%1" == "normal" SET BACKUPMODE=NORMAL
IF "%1" == "differential" SET BACKUPMODE=DIFFERENTIAL
IF %BACKUPMODE% == NONE GOTO NOPARAMS

::SET TIME AND DATE VARIABLES, (EUROPEAN FORMAT)Â DO NOT TOUCH (UNLESS OTHER FORMAT)
FOR /F "TOKENS=1,2 DELIMS=:" %%A IN ('TIME /T') DO (
SET HR=%%A
SET MIN=%%B
SET TM=%%A%%B
SET TME=%%A:%%B
)
FOR /F "TOKENS=2,3,4 DELIMS=- " %%A IN ('DATE /T') DO (
SET D=%%A
SET M=%%B
SET Y=%%C
SET DT=%%A-%%B-%%C
SET DTE=%%C%%B%%A
)
::====!!!OTHER VARIABLES, DO NOT CHANGE!!!====
:: NAME OF SYSTEM TO BE BACKED UP
SET SYS=%COMPUTERNAME%
::NAME OF BACKUPFILE (THIS IS LATER USED IN REMOVING PREVIOUS BACKUPFILES)
SET BACKUPFILE=%SYS%_%BACKUPMODE%_%NOTE%_%DT%.bkf
::LOGFILE OF THIS BATCHFILE
SET BATCHLOG=%ARCHIVEPATH%\%BACKUPMODE%_%NOTE%_%DT%_%TM%.txt
::NAME OF NTBACKUP LOGFILE TO BE ARCHIVED
SET NTBARCLOG=%BACKUPMODE%_%NOTE%_%DT%_%TM%.log
::====DONE SETTING VARIABLES====
::====

::CREATE ARCHIVE AND DESTINATION PATHS IF THEY DO NOT EXIST
IF NOT EXIST "%ARCHIVEPATH%" MD "%ARCHIVEPATH%" & ECHO "ARCHIVE PATH DID NOT EXIST, SO IT WAS CREATED." & ECHO.>> %BATCHLOG%
IF NOT EXIST "%DESTINATION%" MD "%DESTINATION%" & ECHO "DESTINATION PATH DID NOT EXIST, SO IT WAS CREATED." & ECHO.>> %BATCHLOG%

::BACKUP SELECTION, LOG TO CMD WINDOW
ECHO.
ECHO *********************************************************
ECHO * JOB %NOTE% STARTED
ECHO *********************************************************
ECHO *
IF %BACKUPMODE% NEQ SYSTEMSTATE ECHO * JOB SOURCE: %SOURCE%

IF %BACKUPMODE% == SYSTEMSTATE ECHO * %SYS% %BACKUPMODE% BACKUP STARTED AT %TME% ON %DT% & ECHO * TO %DESTINATION%\%BACKUPFILE% & ECHO %SYS% %BACKUPMODE% BACKUP STARTED AT %TME% ON %DT% TO %DESTINATION%\%BACKUPFILE% >> %BATCHLOG%
IF %BACKUPMODE% == DIFFERENTIAL ECHO * %SYS% %BACKUPMODE% BACKUP OF %SOURCE% STARTED AT %TME% ON %DT% & ECHO * TO %DESTINATION%\%BACKUPFILE% & ECHO %SYS% %BACKUPMODE% BACKUP OF %SOURCE% STARTED AT %TME% ON %DT% TO %DESTINATION%\%BACKUPFILE% >> %BATCHLOG%
IF %BACKUPMODE% == NORMAL ECHO * %SYS% %BACKUPMODE% BACKUP OF %SOURCE% STARTED AT %TME% ON %DT% & ECHO * TO %DESTINATION%\%BACKUPFILE% & ECHO %SYS% %BACKUPMODE% BACKUP OF %SOURCE% STARTED AT %TME% ON %DT% TO %DESTINATION%\%BACKUPFILE% >> %BATCHLOG%

::START BACKUP DEPENDING ON BACKUPMODE
IF %BACKUPMODE% == SYSTEMSTATE ntbackup.exe backup systemstate /n "%sys%-Backup" /d "%sys%-Backup" /v:no /r:no /rs:no /hc:off /j "%sys%-Backup" /l:s /f "%destination%\%BACKUPFILE%" >> %BATCHLOG%
IF %BACKUPMODE% == DIFFERENTIAL ntbackup.exe backup "%source%" /n "%sys%-Backup" /d "%sys%-Backup" /v:no /r:no /rs:no /hc:off /m differential /j "%sys%-Backup" /l:s /f "%destination%\%BACKUPFILE%" >> %BATCHLOG%
IF %BACKUPMODE% == NORMAL ntbackup.exe backup "%source%" /n "%sys%-Backup" /d "%sys%-Backup" /v:no /r:no /rs:no /hc:off /m normal /j "%sys%-Backup" /l:s /f "%destination%\%BACKUPFILE%" >> %BATCHLOG%

::ARCHIVE LOGFILES
::CLEAR TIME VARIABLES AND SET ANEW
SET HR=
SET MIN=
SET TM=
SET TME=
FOR /F "TOKENS=1,2 DELIMS=:" %%A IN ('TIME /T') DO (
SET HR=%%A
SET MIN=%%B
SET TM=%%A%%B
SET TME=%%A:%%B
)
::GET NTBACKUP LOGFILE NAME
FOR /F "TOKENS=1,2,4 DELIMS= " %%A IN ('dir %LOGPATH% *.log ^| find "%dt%" ^| find "%tme%"') DO SET NTBLOG=%%C >NUL
ECHO NTBACKUP LOGFILE FOT THIS JOB: %LOGPATH%\%NTBLOG% >> %BATCHLOG%
::COPY AND RENAME THE NTBACKUP LOGFILE
IF EXIST %LOGPATH%\%NTBLOG% copy %LOGPATH%\%NTBLOG% %ARCHIVEPATH% /Y >NUL
IF EXIST %ARCHIVEPATH%\%NTBLOG% ren %ARCHIVEPATH%\%NTBLOG% "%NTBARCLOG%"
::CHECK LOGFILE FOR BACKUP SUCCESS
SET ERRORLEVEL=
find /I "BACKUP COMPLETED" "%ARCHIVEPATH%\%NTBARCLOG%" >NUL
GOTO %ERRORLEVEL%
:0
SET SUCCESS=1
ECHO * BACKUP COMPLETED SUCCESSFULLY & ECHO BACKUP COMPLETED SUCCESSFULLY >> %BATCHLOG%
GOTO SUCCESSBACKUP
:1
SET SUCCESS=0
ECHO * BACKUP FAILED & ECHO BACKUP FAILED >> %BATCHLOG%
GOTO FAILBACKUP

:SUCCESSBACKUP
::SEND EMAIL WITH NTBACKUP LOGFILE ATTACHED
IF %SUCCESS% == 1 %MAILPATH% /smtpserver %SMTPSERVER% /to %TO% /from %FROM% /subject %BACKUPMODE% Backup %NOTE% Successful /body %BACKUPMODE% Backup %NOTE% Successful /attachment %ARCHIVEPATH%\%NTBARCLOG% >> %BATCHLOG%

::CLEANUP PREVIOUS BACKUPFILES
::IF NO PREVIOUS BACKUPFILE EXISTS, SKIP TO CLEANIN LOGFILES
IF NOT EXIST %DESTINATION%\*%BACKUPMODE%_%NOTE%* ECHO NO PREVIOUS BACKUPFILE(S) FOR %BACKUPMODE%_%NOTE% EXIST >> %BATCHLOG% & GOTO CLLOG
::IF PREVIOUS BACKUPFILE(S) EXIST, DELETE ALL PREVIOUS BACKUPFILES. FILTERED BY VARIABLES %BACKUPMODE% & %NOTE%
::THE FOLLOWING STATEMENT IS COMPLETELY DEPENDEND ON THE MAKEUP OF THE VARIABLE %BACKUPFILE%
IF %NOTE% == note %DAPATH% %DESTINATION%\*%BACKUPMODE%_%NOTE%* 60 >> %BATCHLOG% & GOTO CLLOG
IF %BACKUPMODE% == SYSTEMSTATE %DAPATH% %DESTINATION%\*%BACKUPMODE%_%NOTE%* 60 >> %BATCHLOG% & GOTO CLLOG
::FOR /F "TOKENS=1-7 DELIMS=_-." %%A IN ('DIR %DESTINATION%\*%BACKUPMODE%_%NOTE%* /B') DO IF "%%F%%E%%D" LSS "%DTE%" SET BF=%%A_%%B_%%C_%%D-%%E-%%F.%%G & DEL %DESTINATION%\%BF% & IF ERROLEVEL NEQ 0 ECHO PREVIOUS BACKUPFILE %DESTINATION%\%BF% DELETED >> %BATCHLOG% & GOTO CLLOG
ECHO NO (PREVIOUS) BACKUPFILE(S) DELETED >> %BATCHLOG%

:CLLOG
::CLEANUP ARCHIVED LOGFILES
::IF NO PREVIOUS LOGFILE EXISTS, SKIP TO NEXT
IF NOT EXIST %DESTINATION%\*%BACKUPMODE%_%NOTE%* ECHO NO PREVIOUS LOGFILE(S) FOR %BACKUPMODE%_%NOTE% EXIST >> %BATCHLOG% & GOTO NEXT
::IF PREVIOUS LOGFILE(S) EXIST, DELETE ALL PREVIOUS LOGFILES. FILTERED BY VARIABLES %BACKUPMODE% & %NOTE%
::THE FOLLOWING STATEMENT IS DEPENDEND ON THE MAKEUP OF THE VARIABLE %BATCHLOG% & %NTBARCLOG%
IF %NOTE% == note %DAPATH% %ARCHIVEPATH%\*%BACKUPMODE%_%NOTE%* 60 >> %BATCHLOG% & GOTO NEXT
::FOR /F "TOKENS=1-5 DELIMS=_-." %%A IN ('DIR %ARCHIVEPATH%\*%BACKUPMODE%_%NOTE%* /B') DO IF "%%F%%E%%D" LSS "%DTE%" SET LF=%%A_%%B_%%C-%%D-%%E_*.* & DEL %ARCHIVEPATH%\%LF% & IF ERROLEVEL NEQ 0 ECHO PREVIOUS LOGFILE(S) %ARCHIVEPATH%\%LF% DELETED >> %BATCHLOG% & GOTO NEXT
ECHO NO (PREVIOUS) LOGFILE(S) DELETED >> %BATCHLOG% & GOTO NEXT

:FAILBACKUP
IF %SUCCESS% == 0 %MAILPATH% /smtpserver %SMTPSERVER% /to %TO% /from %FROM% /subject %BACKUPMODE% Backup %NOTE% Failed /body %BACKUPMODE% Backup %NOTE% Failed /attachment %ARCHIVEPATH%\%NTBARCLOG% >> "%BATCHLOG%"

:NEXT
IF EXIST "%ARCHIVEPATH%\%NTBARCLOG%" ECHO NTBACKUP.EXE .LOG FILE ARCHIVED AT "%ARCHIVEPATH%\%NTBARCLOG%" >> %BATCHLOG%
ECHO BATCHLOG .TXT FILE ARCHIVED AT "%BATCHLOG%" >> %BATCHLOG%

GOTO END

:NOPARAMS
ECHO ********************************************************
ECHO THIS FILE MUST BE CONFIGURED BY OPENING IT IN NOTEPAD.
ECHO SETTING THE VARIABLES IN THE VARIABLES SECTION.
ECHO TO RUN THE FILE AFTER YOU CONFIGURE IT,
ECHO YOU MUST SPECIFY A BACKUP TYPE AS THE FIRST PARAMETER.
ECHO THE FIRST PARAMETER SHOULD BE IN lowercase.
ECHO SOURCE AND NOTE CAN BE PASSED FROM THE COMMAND LINE,
ECHO READ THE VARIABLES SECTION OF THIS FILE
ECHO.
ECHO EXAMPLE 1:
ECHO MYBACKUP systemstate [source] [note]
ECHO.
ECHO EXAMPLE 2:
ECHO MYBACKUP normal [source] [note]
ECHO.
ECHO EXAMPLE 3:
ECHO MYBACKUP differential [source] [note]
ECHO.
ECHO ********************************************************
PAUSE

:END
CLS
EXIT
Source and support files can be downloaded here