Want to protect your cyber security and still get fast solutions? Ask a secure question today.Go Premium

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 1654
  • Last Modified:

Troubles with Log off script

I run a Windows 2000 Domain logoff script that backs up Outlook mailboxes from individual computers to the server.

I have two logoff scripts, basically, one logoff.vbs that calls another backup.cmd. Logoff.vbs asks for user input and if yes, it runs backup.cmd

Easy enough except that backup.cmd doesn't run. It stops at PKZIP and then exits very quickly.  I can't see what's on the screen. The script works fine when I scroll to the SYSVOL, then to my policy and click on logoff.vbs. Backup.cmd also works fine if I set it as logoff script in my domain policy and if it is not called from logoff.vbs. However, I need user input.

I spent two days trying to figure it out and I have no clue.

Logoff.vbs
========
Set wshShell = WScript.CreateObject("Wscript.Shell")

strInput = MsgBox("Do you want to backup your e-mail?", vbQuestion + vbYesNo, "Select Yes or No")

If strInput = 6 Then wshShell.Run("backup.cmd") ' They pressed Yes
If strInput = 7 Then WScript.Quit ' They pressed No
+++++++++++++++++++++++++

backup.cmd
========
@ECHO OFF

ECHO Backing up your email and address book to server
ECHO Archiving your file locally

C:
CD\
CD "Documents and Settings\%username%\Local Settings\Application Data\Microsoft\Outlook\"

PKZIP OUTLOOK.ZIP Outlook.pst

ECHO Copying file to server

COPY OUTLOOK.ZIP H:\Email\*.*

ECHO Done!

PAUSE
++++++++++++++++
0
njava
Asked:
njava
1 Solution
 
JamesDSCommented:
njava

Put a pause command before and after the PKZIP command and post the error message - if there is one
Cheers
JamesDS
0
 
oBdACommented:
You don't wait for the batch script to end, so your VB script finishes, and the logoff continues and shuts down the zipping.
Make that "wshShell.Run("backup.cmd",,true)

Windows Script Host: Run Method
http://msdn.microsoft.com/library/default.asp?url=/library/en-us/script56/html/wsmthrun.asp

Then there's an error in your batch file: The proper environment variable to get access to the user's profile folder is %UserProfile%; this folder is *NOT* necessarily "Documents and Settings\%Username%"!
CD "%UserProfile%\Local Settings\Application Data\Microsoft\Outlook\"
0
 
JamesDSCommented:
oBdA

Nice answer, I stand in awe!

Cheers

JamesDS
0
Free Tool: ZipGrep

ZipGrep is a utility that can list and search zip (.war, .ear, .jar, etc) archives for text patterns, without the need to extract the archive's contents.

One of a set of tools we're offering as a way to say thank you for being a part of the community.

 
roadhog_NZCommented:
no idea really... but is the PKZIP command in the correct order? PKZIP Outlook.pst OUTLOOK.ZIP ??
0
 
roadhog_NZCommented:
DOH! ~(8(|), gotta stop staying up so late, and gotta start reading the questions better, backup.cmd does work.
0
 
njavaAuthor Commented:
oBdA:
That was indeed the problem!!! I have a couple of notes.

1.  "wshShell.Run("backup.cmd",,true)" won't work - it will exit with error saying that you cannot use parenthesis when calling a Sub. The same line without parens should be used:

wshShell.Run "backup.cmd", 0, true

2. After I fixed wshShell.Run and attempted to run logoff.vbs I got another error
"The procedure entry point DoOpenPipeStream could not be located in the dynamic link library ScrRun.dll".

It happened because the version of scrrun.dll in %windir%\system32 was 5.0 and it should be 5.6 for the script to work.
"regsvr32 scrrun.dll" didn't fix the problem, so I downloaded Windows Scripting Machine (it's not the exact title but close) from Microsoft's website and voila, the script worked like a charm. Surprisingly though, my computer was the only one of 25 that had problems with scrrun.dll
0

Featured Post

Get expert help—faster!

Need expert help—fast? Use the Help Bell for personalized assistance getting answers to your important questions.

Tackle projects and never again get stuck behind a technical roadblock.
Join Now