Arquivo em lotes> Javascript> WinSCP> Verificar se o arquivo existe

Eu tenho um arquivo em lotes que irá lançar um arquivo .js que, via WinSCP, verifica se existe um arquivo e retorna para o arquivo em lotes, se isso acontecer ou não.

O problema é: ele sempre retorna não encontrado, e não consigo descobrir o porquê. Não tenho certeza de como usar um curinga nesse cenário.

O arquivo de lote é assim:

cscript /nologo file.js
if errorlevel 1 goto notfound
exit
:notfound
(another script to copy a file over)

Apenas um arquivo pode existir no servidor de uma só vez. Assim, a cada dez minutos, esse arquivo em lote será executado, verifique se há um arquivo, se não, copie um.

O arquivo.js:

// Configuration

// Remote file search for
var FILEPATH = "../filepath/TSS*";

// Session to connect to
var SESSION = "[email protected]";

// Path to winscp.com
var WINSCP = "c:\\program files (x86)\\winscp\\winscp.com";

var filesys = WScript.CreateObject("Scripting.FileSystemObject");
var shell = WScript.CreateObject("WScript.Shell");

var logfilepath = filesys.GetSpecialFolder(2) + "\\" + filesys.GetTempName() + ".xml";

var p = FILEPATH.lastIndexOf('/');
var path = FILEPATH.substring(0, p);
var filename = FILEPATH.substring(p + 1);

var exec;

// run winscp to check for file existence
exec = shell.Exec("\"" + WINSCP + "\" /log=\"" + logfilepath + "\"");
exec.StdIn.Write(
"option batch abort\n" +
"open \"" + SESSION + "\"\n" +
"ls \"" + path + "\"\n" +
"exit\n");

// wait until the script finishes
while (exec.Status == 0)
{
WScript.Sleep(100);
WScript.Echo(exec.StdOut.ReadAll());
}

if (exec.ExitCode != 0)
{
WScript.Echo("Error checking for file existence");
WScript.Quit(1);
}

// look for log file
var logfile = filesys.GetFile(logfilepath);

if (logfile == null)
{
WScript.Echo("Cannot find log file");
WScript.Quit(1);
}

// parse XML log file
var doc = new ActiveXObject("MSXML2.DOMDocument");
doc.async = false;
doc.load(logfilepath);

doc.setProperty("SelectionNamespaces", 
"xmlns:w='http://winscp.net/schema/session/1.0'");

var nodes = doc.selectNodes("//w:file/w:filename[@value='" + filename + "']");

if (nodes.length > 0)
{
WScript.Echo("File found");
// signalize file existence to calling process;
// you can also continue with processing (e.g. downloading the file)
// directly from the script here
WScript.Quit(0);
}
else
{
WScript.Echo("File not found");
WScript.Quit(1);
}

Na linha 4, diz:

var FILEPATH = "../filepath/TSS*";

Essa estrela é o que está me dando problemas, eu acho. Preciso procurar um arquivo que INICIE COM O TSS, mas tenha um carimbo de data e hora no final. Então eu preciso apenas usar um curinga após o TSS.

Então, o que eu preciso de ajuda é: Fazer este processo retornar true se houver algum arquivo com o TSS *

Qualquer ajuda seria muito apreciada.

EDITAR:

var nodes = doc.selectNodes("//w:file/w:filename[starts-with(@value, 'TSS')]");

Este código parece não funcionar. Se esse código funcionasse, parece que resolveria todos os meus problemas.

questionAnswers(2)

yourAnswerToTheQuestion