gecko-dev/cck/ib/ib.cpp

2356 lines
64 KiB
C++

// Includes
#include "stdafx.h"
#include <Winbase.h>
#include <direct.h>
#include <stdio.h>
#include <stdlib.h>
#include "globals.h"
#include "comp.h"
#include "ib.h"
#include "fstream.h"
#include <afxtempl.h>
#include <afxdisp.h>
#include "resource.h"
#include "NewDialog.h"
#define MAX_SIZE 1024
#define CRVALUE 0x0D
#define BUF_SIZE 4096
// for the xml parser used for PrefsTree
#include "xmlparse.h"
#include "prefselement.h"
// Required disk space for Win build
#define WDISK_SPACE 27577549
// Required disk space for Linux build
#define LDISK_SPACE 84934656
// Required disk space for Mac OS build
#define MDISK_SPACE 5976884
int interpret(char *cmd);
CString rootPath;
CString configName;
CString configPath;
CString workspacePath;
CString cdPath;
CString networkPath;
CString tempPath;
CString iniDstPath;
CString iniSrcPath;
CString scriptPath;
CString nscpxpiPath;
CString cdshellPath;
CString outputPath;
CString xpiDstPath;
CString remoteAdminFile;
// variables for CCK Linux build
CString curPlatform;
CString platformPath;
CString templinuxPath;
CString nsinstPath;
CString nsinstallerDir;
CString xpiDir;
CString templinuxDir;
CString tarfile;
// For use with PrefsTree
CString gstrCFGPrefFile;
CString gstrPlainPrefFile;
CString gstrInstallFile;
WIDGET *tempWidget;
char buffer[50000];
XPI xpiList[100];
int xpiLen = -1;
JAR jarList[100];
int jarLen = -1;
// Setup Sections for config.ini
CString Setup0Short = "R&ecommended";
CString Setup1Short = "C&ustom";
CString quotes = "\"";
CString spaces = " ";
BOOL prefDoesntExist = TRUE;
COMPONENT Components[100];
int numComponents;
int componentOrder;
CString componentstr;
char tempcomponentstr[MAX_SIZE];
int findXPI(CString xpiname, CString filename)
{
int found = FALSE;
for (int i=0; !found && i<=xpiLen; i++)
//xpiList is an array of structures where each structure contains
//the name of the xpi file and the subpath of the file within.
if (xpiList[i].xpiname == xpiname && xpiList[i].filename == filename)
found = TRUE;
if (!found)
{
xpiLen++;
xpiList[xpiLen].xpiname = xpiname;
xpiList[xpiLen].filename = filename;
}
return found;
}
int ExtractXPIFile(CString xpiname, CString xpifile)
{
CString command;
// AfxMessageBox("The xpiname is "+xpiname+" and the file is "+xpifile,MB_OK);
if (findXPI(xpiname, xpifile))
return TRUE;
// Can use -d instead of change CWD???
CString xpiArchive = nscpxpiPath + "\\" + xpiname; //xpiArchive = CCKTool\NSCPXPI
command = quotes +rootPath + "unzip.exe"+ quotes + "-o" + spaces + quotes + xpiArchive + quotes + spaces + quotes + xpifile + quotes;
ExecuteCommand((char *)(LPCTSTR) command, SW_HIDE, INFINITE);
return TRUE;
}
int ReplaceXPIFiles()
{
CString command;
CString xpiArchive;
CString xpiArcDest;
// Go through the whole list putting them into the archives
for (int i=0; i<=xpiLen; i++)
{
// This copy preserves the existing archive if it exists - do we
// need to delete it the first time through?
xpiArchive = nscpxpiPath + "\\" + xpiList[i].xpiname;//nscpxpiPath=CCKTool\NSCPXPI
xpiArcDest = xpiDstPath + "\\" + xpiList[i].xpiname; //xpiDstPath=CCKTool\Configs\ configName\Output\Core
if (!CopyFile(xpiArchive, xpiArcDest, TRUE))
DWORD e = GetLastError();
// if ((strcmp(xpiList[i].filename,"bin/defaults/isp/US") == 0) || (strcmp(xpiList[i].filename,"bin/defaults/isp") == 0))
if (((xpiList[i].filename).Find("isp")) != -1)
command = quotes + rootPath + "zip.exe" + quotes + "-m " + spaces + quotes +xpiArcDest + quotes + spaces + quotes + xpiList[i].filename + "/*.*" + quotes;
else
command = quotes + rootPath + "zip.exe" + quotes + "-m " + spaces + quotes +xpiArcDest + quotes + spaces + quotes + xpiList[i].filename + quotes;
ExecuteCommand((char *)(LPCTSTR) command, SW_HIDE, INFINITE);
}
return TRUE;
}
int findJAR(CString jarname, CString filename)
{
int found = FALSE;
for (int i=0; !found && i<=jarLen; i++)
if (jarList[i].jarname == jarname &&
jarList[i].filename == filename)
found = TRUE;
if (!found)
{
jarLen++;
jarList[jarLen].jarname = jarname;
jarList[jarLen].filename = filename;
}
return found;
}
// Decrypt a file to another file.
int UnHash(CString HashedFile, CString ClearTextFile)
{
CString command = quotes + rootPath + "parse_cfg.exe" + quotes + " -Y -input " + HashedFile + " -output " + ClearTextFile;
ExecuteCommand((char *)(LPCTSTR) command, SW_HIDE, INFINITE);
return TRUE;
}
// Encrypt a file to another file.
int Hash(CString ClearTextFile, CString HashedFile)
{
CString command = quotes + rootPath + "make_cfg.exe" + quotes +
" -Y -input " + quotes + ClearTextFile + quotes +" -output " +
quotes + HashedFile + quotes;
ExecuteCommand((char *)(LPCTSTR) command, SW_HIDE, INFINITE);
return TRUE;
}
int ExtractJARFile(CString xpiname, CString jarname, CString xpifile)
{
// AfxMessageBox("The xpiname is "+xpiname+" and the jar name is "+jarname+" and the file is "+xpifile,MB_OK);
ExtractXPIFile(xpiname, jarname);
CString command;
CString jarArchive;
if (curPlatform == "Mac OS")
{
jarname.Replace("/","\\");
jarname.Insert(0,"\\");
jarArchive = tempPath + jarname;
}
else
{
//We have to get rid of the bin/chrome/ and hence the delete.
jarname.Delete(0,11);
jarArchive = tempPath + "\\bin\\chrome\\" + jarname;
}
if (findJAR(jarname, xpifile))
return TRUE;
// Can use -d instead of change CWD???
command = quotes +rootPath + "unzip.exe"+ quotes + "-o" + spaces + quotes + jarArchive + quotes + spaces + quotes + xpifile + quotes;
ExecuteCommand((char *)(LPCTSTR) command, SW_HIDE, INFINITE);
return TRUE;
}
int ReplaceJARFiles()
{
CString command;
CString jarArchive;
// Go through the whole list putting them into the archives
for (int i=0; i<=jarLen; i++)
{
// This copy preserves the existing archive if it exists - do we
// need to delete it the first time through?
if (curPlatform == "Mac OS")
jarArchive = tempPath + jarList[i].jarname;
else
jarArchive = tempPath + "\\bin\\chrome\\" + jarList[i].jarname;
command = quotes + rootPath + "zip.exe" + quotes + "-m " + spaces + quotes +jarArchive + quotes + spaces + quotes + jarList[i].filename + quotes;
ExecuteCommand((char *)(LPCTSTR) command, SW_HIDE, INFINITE);
}
return TRUE;
}
int ReplaceINIFile()
{
CString command1,command2,commandReadme;
CString zipName("N6Setup.zip");
CString exeName("N6Setup.exe");
CString copyb = "copy /b ";
char olddir[1024];
GetCurrentDirectory(sizeof(olddir), olddir);
if(SetCurrentDirectory((char *)(LPCTSTR) xpiDstPath) == FALSE)
return FALSE;
CString Src = nscpxpiPath + "\\" +zipName;
CString Dst = xpiDstPath + "\\" + zipName;
if (!CopyFile(Src, Dst, FALSE))
DWORD e = GetLastError();
// command = quotes + rootPath + "nszip.exe " + quotes + spaces + exeName + spaces + "config.ini";
command1 = quotes + rootPath + "zip.exe" + quotes + "-m " + spaces + zipName + spaces + "config.ini";
ExecuteCommand((char *)(LPCTSTR) command1, SW_HIDE, INFINITE);
// Copy the Readme file to the core directory and insert it inside the N6Setup.zip**********
CString readmePath = GetGlobal("ReadMeFile");
CString replaceReadme = xpiDstPath + "\\Readme.txt";
if (!CopyFile(readmePath, replaceReadme, FALSE))
DWORD e = GetLastError();
commandReadme = quotes + rootPath + "zip.exe" + quotes + "-m " + spaces + zipName + spaces + "Readme.txt";
ExecuteCommand((char *)(LPCTSTR) commandReadme, SW_HIDE, INFINITE);
// Finished copying readme and inserting into the zip**********
command2 = copyb + quotes + rootPath + "unzipsfx.exe" + quotes + " + N6Setup.zip N6Setup.exe";
// copy /b unzipsfx.exe+letters.zip letters.exe
///////////////////////////////////////////////////////
CString copycat = "copycat.bat";
ofstream cc(copycat);
cc << command2 <<"\necho off \ncls\n";
cc.close();
CString command3 ="copycat.bat";
///////////////////////////////////////////////////////
ExecuteCommand((char *)(LPCTSTR) command3, SW_HIDE, INFINITE);
DeleteFile("copycat.bat");
CString unzipN6 = quotes +rootPath + "unzip.exe"+ quotes + "-o" + spaces + quotes + zipName + quotes;
ExecuteCommand((char *)(LPCTSTR) unzipN6, SW_HIDE, INFINITE);
DeleteFile(zipName);
SetCurrentDirectory(olddir);
return TRUE;
}
void ModifyPref(char *buffer, CString entity, CString newvalue, BOOL bLockPref)
{
CString buf(buffer);
int i = buf.Find(entity);
if (i == -1) return;
i = buf.Find('"', i+1);
if (i == -1) return;
i++;
i = buf.Find('"', i+1);
if (i == -1) return;
i++;
int j = buf.Find('"', i);
if (j == -1) return;
j--;
buf.Delete(i, j-i+1);
buf.Insert(i, newvalue);
if (bLockPref)
{
// If it's not lockPref( already.
if (buf.Find("lockPref(") < 0)
buf.Replace("pref(", "lockPref(");
}
strcpy(buffer, (char *)(LPCTSTR) buf);
prefDoesntExist = FALSE;
}
int ModifyProperties(CString xpifile, CString entity, CString newvalue)
{
int rv = TRUE;
CString propFile = xpifile;
CString tempFile = xpifile + ".temp";
char properties[400];
ofstream tf(tempFile);
if(!tf)
{
rv = FALSE;
cout <<"Cannot open: "<<tempFile<<"\n";
return rv;
}
tf<< entity <<"="<<newvalue <<"\n";
ifstream pf(propFile);
if (!pf)
{
rv = FALSE;
cout <<"Cannot open: "<<propFile<<"\n";
return rv;
}
while (!pf.eof())
{
pf.getline(properties,400);
tf <<properties<<"\n";
}
pf.close();
tf.close();
remove(xpifile);
rename(tempFile, xpifile);
return rv;
}
void AddPref(CString xpifile, CString entity, CString newvalue, BOOL bUseQuotes, BOOL bLockPref)
{
int rv = TRUE;
CString prefFile = xpifile;
CString tempFile = xpifile + ".temp";
char properties[400];
ofstream tf(tempFile);
if(!tf)
{
rv = FALSE;
cout <<"Cannot open: "<<tempFile<<"\n";
return;
}
ifstream pf(prefFile);
if (!pf)
{
rv = FALSE;
cout <<"Cannot open: "<<prefFile<<"\n";
return;
}
while (!pf.eof())
{
pf.getline(properties,400);
tf <<properties<<"\n";
}
CString Quote = bUseQuotes? quotes : "";
CString FuncName = bLockPref? "lockPref(" : "pref(";
tf<< FuncName << entity << ", " << Quote << newvalue << Quote << ");\n";
pf.close();
tf.close();
remove(xpifile);
rename(tempFile, xpifile);
return;
}
int ModifyJS(CString xpifile, CString entity, CString newvalue, BOOL bLockPref)
{
int rv = TRUE;
CString newfile = xpifile + ".new";
char *fgetsrv;
// Read in DTD file and make substitutions
FILE *srcf = fopen(xpifile, "r");
FILE *dstf = fopen(newfile, "w");
CString apost = '"';
entity.Insert(0,apost);
entity.Insert(1000,apost);
if (!srcf)
rv = FALSE;
else
{
prefDoesntExist = TRUE;
while (!feof(srcf))
{
fgetsrv = fgets(buffer, sizeof(buffer), srcf);
if (!fgetsrv || ferror(srcf))
{
rv = FALSE;
break;
}
ModifyPref(buffer, entity, newvalue, bLockPref);
fputs(buffer, dstf);
}
fclose(srcf);
fclose(dstf);
}
remove(xpifile);
rename(newfile, xpifile);
if (prefDoesntExist)
AddPref(xpifile,entity,newvalue, TRUE, bLockPref);
return TRUE;
}
void ModifyEntity(char *buffer, CString entity, CString newvalue)
{
CString buf(buffer);
entity = entity + " "; // Ensure we don't get false matches
int i = buf.Find(entity);
if (i == -1) return;
i = buf.Find('"', i+1);
if (i == -1) return;
i++;
int j = buf.Find('"', i);
if (j == -1) return;
j--;
buf.Delete(i, j-i+1);
buf.Insert(i, newvalue);
strcpy(buffer, (char *)(LPCTSTR) buf);
}
int ModifyDTD(CString xpifile, CString entity, CString newvalue)
{
CString newfile = xpifile + ".new";
int rv = TRUE;
char *fgetsrv;
// Read in DTD file and make substitutions
FILE *srcf = fopen(xpifile, "r");
FILE *dstf = fopen(newfile, "w");
if (!srcf)
rv = FALSE;
else
{
while (!feof(srcf))
{
fgetsrv = fgets(buffer, sizeof(buffer), srcf);
if (!fgetsrv || ferror(srcf))
{
rv = FALSE;
break;
}
ModifyEntity(buffer, entity, newvalue);
fputs(buffer, dstf);
}
fclose(srcf);
fclose(dstf);
}
remove(xpifile);
rename(newfile, xpifile);
return TRUE;
}
void ModifyEntity1(char *buffer, CString entity, CString newvalue, BOOL bLockPref)
{
CString buf(buffer);
entity = entity + "\"";
int i = buf.Find(entity);
if (i == -1) return;
i = buf.ReverseFind('"');
if (i == -1) return;
CString tempbuf = buf;
tempbuf.Left(i);
int j = tempbuf.ReverseFind('"');
if (j == -1) return;
buf.Delete(j, i-j);
buf.Insert(j, newvalue);
if (bLockPref)
{
// If it's not LockPref( already, change Pref( to LockPref(.
if (buf.Find("lockPref(") < 0)
buf.Replace("pref(", "lockPref(");
}
strcpy(buffer, (char *)(LPCTSTR) buf);
}
int ModifyJS1(CString xpifile, CString entity, CString newvalue, BOOL bLockPref)
{
CString newfile = xpifile + ".new";
int rv = TRUE;
char *fgetsrv;
// Read in all.js file and make substitutions
FILE *srcf = fopen(xpifile, "r");
FILE *dstf = fopen(newfile, "w");
if (!srcf)
rv = FALSE;
else
{
while (!feof(srcf))
{
fgetsrv = fgets(buffer, sizeof(buffer), srcf);
if (!fgetsrv || ferror(srcf))
{
rv = FALSE;
break;
}
ModifyEntity1(buffer, entity, newvalue, bLockPref);
fputs(buffer, dstf);
}
fclose(srcf);
fclose(dstf);
}
remove(xpifile);
rename(newfile, xpifile);
return TRUE;
}
void ModifyEntity2(char *buffer, CString entity, CString newvalue, BOOL bLockPref)
{
CString buf(buffer);
newvalue = " " + newvalue;
int i = buf.Find(entity);
if (i == -1) return;
i = buf.ReverseFind(')');
if (i == -1) return;
CString tempbuf = buf;
tempbuf.Left(i);
int j = tempbuf.ReverseFind(',');
if (j == -1) return;
buf.Delete(j+1, i-j-1);
buf.Insert(j+1, newvalue);
if (bLockPref)
{
// If it's not LockPref( already.
if (buf.Find("lockPref(") < 0)
buf.Replace("pref(", "lockPref(");
}
strcpy(buffer, (char *)(LPCTSTR) buf);
prefDoesntExist = FALSE;
}
int ModifyJS2(CString xpifile, CString entity, CString newvalue, BOOL bLockPref)
{
CString newfile = xpifile + ".new";
int rv = TRUE;
char *fgetsrv;
// Read in all.js file and make substitutions
FILE *srcf = fopen(xpifile, "r");
FILE *dstf = fopen(newfile, "w");
if (!srcf)
rv = FALSE;
else
{
prefDoesntExist = TRUE;
while (!feof(srcf))
{
fgetsrv = fgets(buffer, sizeof(buffer), srcf);
if (!fgetsrv || ferror(srcf))
{
rv = FALSE;
break;
}
ModifyEntity2(buffer, entity, newvalue, bLockPref);
fputs(buffer, dstf);
}
fclose(srcf);
fclose(dstf);
}
remove(xpifile);
rename(newfile, xpifile);
if (prefDoesntExist)
{
// AddPref expects pref name to be surrounded in quotes.
CString prefName = "\"" + entity + "\"";
AddPref(xpifile, prefName, newvalue, FALSE, bLockPref);
}
return TRUE;
}
BOOL FileExists(CString file)
{
WIN32_FIND_DATA data;
HANDLE d = FindFirstFile((const char *) file, &data);
return (d != INVALID_HANDLE_VALUE);
}
BOOL CreateNewFile(CString& Filename, CString Contents)
{
FILE *f = fopen(Filename, "w");
if (!f)
return FALSE;
fprintf(f,Contents);
fclose(f);
return TRUE;
}
// Modifies a preference in a hashed prefs file.
// Specify whether the pref value should be "string", "bool", or "int".
// Adds the pref if it is missing.
// Creates the file if missing.
// Returns TRUE if OK, or FALSE on error.
int ModifyHashedPref(CString HashedPrefsFile, CString PrefName, CString NewPrefValue, CString PrefType, BOOL bLockPref)
{
// Unhash the prefs file to a plain text file. If there is no hashed file yet,
// create a plaintext file with only a comment.
CString PlainTextPrefsFile = HashedPrefsFile + ".js";
if (FileExists(HashedPrefsFile))
{
if (!UnHash(HashedPrefsFile, PlainTextPrefsFile))
return FALSE;
}
else
{
// Create a plain text prefs with only a comment.
CreateNewFile(PlainTextPrefsFile, "/* prefs configured in NCADM */\n");
}
// Modify the pref.
if (PrefType.CompareNoCase("string") == 0)
{
if (!ModifyJS(PlainTextPrefsFile, PrefName, NewPrefValue, bLockPref))
return FALSE;
}
else if (PrefType.CompareNoCase("int") == 0)
{
if (NewPrefValue.IsEmpty())
NewPrefValue = "0";
if (!ModifyJS2(PlainTextPrefsFile, PrefName, NewPrefValue, bLockPref))
return FALSE;
}
else if (PrefType.CompareNoCase("bool") == 0)
{
if (NewPrefValue.IsEmpty() || NewPrefValue == "0" || (NewPrefValue.CompareNoCase("false") == 0))
NewPrefValue = "false";
else
NewPrefValue = "true";
if (!ModifyJS2(PlainTextPrefsFile, PrefName, NewPrefValue, bLockPref))
return FALSE;
}
// And rehash it.
if (!Hash(PlainTextPrefsFile, HashedPrefsFile))
return FALSE;
return TRUE;
}
// This processes a prefs tree XML file, adding preferences to install files
// as specified in the prefs tree XML file. See PrefsTree.html for file
// format details.
//
// Called by the XML parser when a new element is read.
void startElement(void *userData, const char *name, const char **atts)
{
ASSERT(userData);
((CPrefElement*)userData)->startElement(name, atts);
}
void characterData(void *userData, const XML_Char *s, int len)
{
ASSERT(userData);
((CPrefElement*)userData)->characterData(s, len);
}
// Called by the XML parser when an element close tag is read.
void endElement(void *userData, const char *name)
{
ASSERT(userData);
((CPrefElement*)userData)->endElement(name);
if (stricmp(name, "PREF") == 0)
{
// If locked, write to the .cfg file. Don't care if it's default or not.
BOOL bLocked = ((CPrefElement*)userData)->IsLocked();
BOOL bRemoteAdmin = ((CPrefElement*)userData)->IsRemoteAdmin();
BOOL bDefault = ((CPrefElement*)userData)->IsDefault();
if (bLocked && !bRemoteAdmin)
{
// Write the pref element to prefs file.
ExtractXPIFile(gstrInstallFile, gstrCFGPrefFile);
ModifyHashedPref(gstrCFGPrefFile, ((CPrefElement*)userData)->GetPrefName(), ((CPrefElement*)userData)->GetPrefValue(), ((CPrefElement*)userData)->GetPrefType(), TRUE);
}
// If not locked, and not NS default, write to the .js file.
else if (!bDefault)
{
ExtractXPIFile(gstrInstallFile, gstrPlainPrefFile);
if ((((CPrefElement*)userData)->GetPrefType() == "int") || (((CPrefElement*)userData)->GetPrefType() == "bool"))
ModifyJS2(gstrPlainPrefFile, ((CPrefElement*)userData)->GetPrefName(), ((CPrefElement*)userData)->GetPrefValue(), FALSE);
else // string
ModifyJS(gstrPlainPrefFile, ((CPrefElement*)userData)->GetPrefName(), ((CPrefElement*)userData)->GetPrefValue(), FALSE);
}
// If remote admin, write to the .jsc file.
if (bRemoteAdmin)
{
if (!FileExists(remoteAdminFile))
{
CString strURL = GetGlobal("RemoteAdminURL");
CString strComment;
strComment.Format("/* This Remote Admin file should be placed at %s */\n", strURL);
CreateNewFile(remoteAdminFile, strComment);
}
if ((((CPrefElement*)userData)->GetPrefType() == "int") || (((CPrefElement*)userData)->GetPrefType() == "bool"))
ModifyJS2(remoteAdminFile, ((CPrefElement*)userData)->GetPrefName(), ((CPrefElement*)userData)->GetPrefValue(), TRUE);
else // string
ModifyJS(remoteAdminFile, ((CPrefElement*)userData)->GetPrefName(), ((CPrefElement*)userData)->GetPrefValue(), TRUE);
}
}
}
// special case for homepage URL: if locked or remote admin, do the right thing.
// otherwise, call the originally called ModifyProperties method
BOOL ModifyHomepageURL(CString xpifile, CString entity, CString newvalue)
{
bool bLocked = GetGlobal("HomePageURLLocked") == "1";
bool bRemoteAdmin = GetGlobal("HomePageURLRemoteAdmin") == "1";
CString strPref = "browser.startup.homepage";
CString strURL = GetGlobal("HomePageURL");
if (bLocked && !bRemoteAdmin)
{
// Write the pref element to prefs file.
ExtractXPIFile(gstrInstallFile, gstrCFGPrefFile);
ModifyHashedPref(gstrCFGPrefFile, strPref, strURL, "string", TRUE);
}
// If remote admin, write to the .jsc file.
else if (bRemoteAdmin)
{
if (!FileExists(remoteAdminFile))
{
CString strComment;
strComment.Format("/* The Homepage URL should be %s */\n", strURL);
CreateNewFile(remoteAdminFile, strComment);
}
ModifyJS(remoteAdminFile, strPref, strURL, TRUE);
}
// not locked, or remote, just modify the property
else
ModifyProperties(xpifile, entity, newvalue);
return TRUE;
}
// Sets the autoadmin.global_config_url in strPrefFile to strURL.
BOOL ConfigureRemoteAdmin(CString strURL, CString strPrefFile)
{
ASSERT(!strURL.IsEmpty() && !strPrefFile.IsEmpty());
if (strURL.IsEmpty() || strPrefFile.IsEmpty())
return FALSE;
ASSERT(strPrefFile.Find(".cfg") > 0);
if (strPrefFile.Find(".cfg") <= 0)
return FALSE;
ModifyHashedPref(strPrefFile, "autoadmin.global_config_url", strURL, "string", TRUE);
CString strFailoverCached = GetGlobal("RemoteAdminFailoverToCached");
ModifyHashedPref(strPrefFile, "autoadmin.failover_to_cached", strFailoverCached, "bool", TRUE);
CString strFailover = GetGlobal("RemoteAdminFailover");
ModifyHashedPref(strPrefFile, "autoadmin.offline_failover", strFailover, "bool", TRUE);
CString strPoll = GetGlobal("RemoteAdminPoll");
if (strPoll == "1")
{
CString strPollFreq = GetGlobal("RemoteAdminPollFreq");
ModifyHashedPref(strPrefFile, "autoadmin.refresh_interval", strPollFreq, "int", TRUE);
}
return TRUE;
}
// This function can easily be rewriten to parse the XML file by hand if it
// needs to be ported to a non-MS OS. The XML is pretty simple.
BOOL ProcessPrefsTree(CString strPrefsTreeFile)
{
//AfxMessageBox("Pause", MB_OK);
XML_Parser parser = XML_ParserCreate(NULL);
XML_SetElementHandler(parser, startElement, endElement);
XML_SetCharacterDataHandler(parser, characterData);
// Used by the XML parser. The data object passed to the handlers.
static CPrefElement element;
XML_SetUserData(parser, &element);
// Load the XML from the file.
CString strPrefsXML;
FILE* pFile = fopen(strPrefsTreeFile, "r");
if (!pFile)
{
fprintf(stderr, "Can't open the file %s.", strPrefsTreeFile);
return FALSE;
}
// obtain file size.
fseek(pFile , 0 , SEEK_END);
long lSize = ftell(pFile);
rewind(pFile);
// allocate memory to contain the whole file.
char* buffer = (char*) malloc (lSize + 1);
if (buffer == NULL)
{
fprintf(stderr, "Memory allocation error.");
return FALSE;
}
buffer[lSize] = '\0';
// copy the file into the buffer.
size_t len = fread(buffer,1,lSize,pFile);
// the whole file is loaded in the buffer.
int done = 0;
if (!XML_Parse(parser, buffer, len, done))
{
fprintf(stderr,
"%s at line %d\n",
XML_ErrorString(XML_GetErrorCode(parser)),
XML_GetCurrentLineNumber(parser));
return FALSE;
}
XML_ParserFree(parser);
free(buffer);
return TRUE;
}
BOOL ModifyUserJS(CString HashedPrefsFile, CString jsSourceFile)
{
// Unhash the prefs file to a plain text file. If there is no hashed file yet,
// create a plaintext file with only a comment.
CString PlainTextPrefsFile = HashedPrefsFile + ".js";
if (FileExists(HashedPrefsFile))
{
if (!UnHash(HashedPrefsFile, PlainTextPrefsFile))
return FALSE;
}
else
{
// Create a plain text prefs with only a comment.
CreateNewFile(PlainTextPrefsFile, "/* prefs configured in NCADM */\n");
}
// find the block and replace it with the contents of the source file
CString newPrefsFile = PlainTextPrefsFile + ".new";
// Read in all.js file and make substitutions
CStdioFile srcJSC;
FILE* destJSC = fopen(newPrefsFile, "w");
if (srcJSC.Open(PlainTextPrefsFile,CFile::modeRead | CFile::typeText) && destJSC)
{
CString strLine;
bool bInJSBlock = FALSE;
bool bInsertUserJSNow = FALSE;
bool bDroppedPayload = FALSE;
int iBraceLevel = 0; // these are in case cfg file has braces
bool bPastFirstBrace = FALSE;
while (srcJSC.ReadString(strLine))
{
strLine += "\n";
// count braces
/*
char buffer[4096];
strcpy(buffer,strLine);
char *token = strtok( buffer, "{");
while( token != NULL )
{
bPastFirstBrace = TRUE;
iBraceLevel++;
token = strtok(NULL,"{");
}
strcpy(buffer,strLine);
token = strtok( buffer, "}");
while( token != NULL )
{
iBraceLevel--;
token = strtok(NULL,"}");
}
if (bPastFirstBrace && iBraceLevel < 1)
bInsertUserJSNow = TRUE;
*/
// looking for //ADMJS_BEG (ADM JavaScript Begin)
// or //ADMJS_END (ADM JavaScript End) which must be on a line by themselves
int len = strLine.GetLength();
if ( strLine.GetLength() > 10
&& strLine[0] == '/'
&& strLine[1] == '/')
{
CString str = strLine.Left(6);
if (str.CompareNoCase("\n\n//ADMJS_BEG\n") == 0)
{
bInsertUserJSNow = TRUE;
bInJSBlock = TRUE;
}
else if (str.CompareNoCase("//ADMJS_END\n") == 0)
bInJSBlock = FALSE;
}
// drop our payload
//
if (bInsertUserJSNow)
{
CStdioFile srcJS;
CString strJSLine;
fputs(strLine,destJSC); // write out "//ADMJS_BEG"
if (srcJS.Open(jsSourceFile,CFile::modeRead | CFile::typeText))
{
while (srcJS.ReadString(strJSLine))
{
strJSLine += "\n";
fputs(strJSLine, destJSC);
}
srcJS.Close();
}
bInsertUserJSNow = FALSE;
bDroppedPayload = TRUE;
}
else
{
fputs(strLine,destJSC); // drop whatever line we have
}
} // while source lines
if (!bDroppedPayload)
{
CStdioFile srcJS;
CString strJSLine;
strJSLine = "\n\n//ADMJS_BEG\n";
fputs(strJSLine,destJSC);
if (srcJS.Open(jsSourceFile,CFile::modeRead | CFile::typeText))
{
while (srcJS.ReadString(strJSLine))
{
strJSLine += "\n";
fputs(strJSLine, destJSC);
}
srcJS.Close();
}
strJSLine = "//ADMJS_END\n";
fputs(strJSLine,destJSC);
}
srcJSC.Close();
fclose(destJSC);
} // if can open source file
// delete orig and rename new file to correct name
remove(PlainTextPrefsFile);
rename(newPrefsFile, PlainTextPrefsFile);
// And rehash it.
if (!Hash(PlainTextPrefsFile, HashedPrefsFile))
return FALSE;
return TRUE;
}
BOOL MarkCFGVersion(CString HashedPrefsFile, CString versionTxt)
{
// Unhash the prefs file to a plain text file. If there is no hashed file yet,
// create a plaintext file with only a comment.
CString PlainTextPrefsFile = HashedPrefsFile + ".js";
if (FileExists(HashedPrefsFile))
{
if (!UnHash(HashedPrefsFile, PlainTextPrefsFile))
return FALSE;
}
else
{
// Create a plain text prefs with only a comment.
CreateNewFile(PlainTextPrefsFile, "/* prefs configured in NCADM */\n");
}
// find the block and replace it with the contents of the source file
CString newPrefsFile = PlainTextPrefsFile + ".new";
// Read in all.js file and make substitutions
CStdioFile srcJSC;
FILE* destJSC = fopen(newPrefsFile, "w");
if (srcJSC.Open(PlainTextPrefsFile,CFile::modeRead | CFile::typeText) && destJSC)
{
CString strLine;
strLine = "//ADMVERSION:" + versionTxt + "\n";
fputs(strLine,destJSC);
while (srcJSC.ReadString(strLine))
{
strLine += "\n";
CString str = strLine.Left(8);
if (str.Compare("//ADMVER") == 0) // throw away any previous //ADMVERSION tags
continue;
fputs(strLine,destJSC); // drop whatever line we have
}
srcJSC.Close();
fclose(destJSC);
} // if can open source file
// delete orig and rename new file to correct name
remove(PlainTextPrefsFile);
rename(newPrefsFile, PlainTextPrefsFile);
// And rehash it.
if (!Hash(PlainTextPrefsFile, HashedPrefsFile))
return FALSE;
return TRUE;
}
int interpret(char *cmd)
{
char *cmdname = strtok(cmd, "(");
if (strcmp(cmdname, "configure") == 0)
{
char temp[1024];
char *section = strtok(NULL, ",)");
char *key = strtok(NULL, ",)");
char *value = strtok(NULL, ",)");
char *newvalue = value;
if (value[0] == '%')
{
value++;
char *t = strchr(value, '%');
//Post Beta - we have to figure a way to handle these cases - right now returning FALSE
//causes the other commands to not be carried through- changing return FALSE to TRUE
if (!t)
return TRUE;//*** Changed FALSE to TRUE
*t = '\0';
newvalue = (char *)(LPCTSTR) GetGlobal(value);
}
if (!section || !key || !newvalue)
return TRUE;//***Changed FALSE to TRUE
if (!CopyFile(iniSrcPath, iniDstPath, TRUE))
DWORD e = GetLastError();
if (strcmp(key, "Program Folder Name") == 0)
{
if (strcmp(newvalue, "") == 0)
strcpy(temp, "Netscape 6");
else
strcpy(temp, "Netscape 6 by ");
strcat(temp, newvalue);
newvalue = temp;
}
CString encodedValue = newvalue;
WritePrivateProfileString(section, key, ConvertUTF8toANSI(encodedValue),
iniDstPath);
}
else if (strcmp(cmdname, "replaceXPI") == 0)
{
char *xpiname = strtok(NULL, ",)");
char *jname = strtok(NULL, ",)");
char *xpifile = strtok(NULL, ",)");
char *value = strtok(NULL, ",)");
char *newvalue = value;
CString jarname = jname;
if (value[0] == '%')
{
value++;
char *t = strchr(value, '%');
if (!t)
return TRUE;//*** Changed FALSE to TRUE
*t = '\0';
newvalue = (char *)(LPCTSTR) GetGlobal(value);
}
if (!xpiname || !xpifile || !newvalue)
return TRUE;//*** Changed FALSE to TRUE
/*Post Beta -This is a hack to prevent the last page from staying up there endlessly;
We check to see if the filename is null and if it is so we return true
so that the return value isnt made FALSE */
CString filename = newvalue;
if (filename.IsEmpty())
return TRUE;
////////////////////////////////
//check to see if it is a jar and then do accordingly
if (jarname.CompareNoCase("no.jar")==0)
ExtractXPIFile(xpiname, xpifile);
else
ExtractJARFile(xpiname, jarname, xpifile);
if (!CopyFile(newvalue, xpifile, FALSE))
{
DWORD e = GetLastError();
return TRUE;//*** Changed FALSE to TRUE
}
}
// If the string in script.ib matches "addrdfFile" perform this code
// This code decompresses the xpi files to which the rdf files must be
// added and copies the rdf files (mailaccount.rdf and newsaccount.rdf)
// from the Temp directory to the resulting directory after decompression
else if (strcmp(cmdname, "addrdfFile") == 0)
{
char *xpiname = strtok(NULL, ",)"); // xpi file name
char *jname = strtok(NULL, ",)"); // jar name within xpi file
char *xpifile = strtok(NULL, ",)"); // directory path within jar file
char *value2 = strtok(NULL, ",)"); // name of rdf file to be added
char *value = strtok(NULL, ",)"); // variable which specifies the path of the Temp dir
char *newvalue = value;
CString jarname = jname;
if (value[0] == '%')
{
value++;
char *t = strchr(value, '%');
if (!t)
return TRUE;//*** Changed FALSE to TRUE
*t = '\0';
newvalue = (char *)(LPCTSTR) GetGlobal(value);
}
if (!xpiname || !xpifile || !newvalue)
return TRUE;//*** Changed FALSE to TRUE
CString command;
if (strcmp(value2,"newsaccount.rdf") != 0)
{
if (findXPI(xpiname, xpifile))
return TRUE;
}
// nscpxpipath = \CCKTool\NSCPXPI
CString xpiArchive = nscpxpiPath + "\\" + xpiname;
// decompressing the directory path within the XPI file
command = quotes +rootPath + "unzip.exe"+ quotes + "-o" + spaces + quotes + xpiArchive + quotes + spaces + quotes + xpifile + "/*.*" + quotes;
ExecuteCommand((char *)(LPCTSTR) command, SW_HIDE, INFINITE);
CString xpifile1 = xpifile;
CString tempval=value2;
CString newxpifile = xpifile1 + "/" + tempval;
// copy rdf file from Temp directory
if (!CopyFile(newvalue, newxpifile, FALSE))
{
DWORD e = GetLastError();
return TRUE;//*** Changed FALSE to TRUE
}
}
else if ((strcmp(cmdname, "modifyDTD") == 0) ||
(strcmp(cmdname, "modifyJS") == 0) ||
(strcmp(cmdname, "modifyJS1") == 0) ||
(strcmp(cmdname, "modifyJS2") == 0) ||
(strcmp(cmdname, "modifyHomepageURL") == 0) ||
(strcmp(cmdname, "modifyProperties") == 0) ||
(strcmp(cmdname, "modifyHashedPrefString") == 0) ||
(strcmp(cmdname, "modifyHashedPrefInt") == 0) ||
(strcmp(cmdname, "modifyHashedPrefBool") == 0))
{
char *xpiname = strtok(NULL, ",)");
char *jname = strtok(NULL, ",)");
char *xpifile = strtok(NULL, ",)");
char *entity = strtok(NULL, ",)");
char *value = strtok(NULL, ",)");
char *newvalue = value;
CString jarname = jname;
if (value[0] == '%')
{
value++;
char *t = strchr(value, '%');
if (!t)
return TRUE;//*** Changed FALSE to TRUE
*t = '\0';
newvalue = (char *)(LPCTSTR) GetGlobal(value);
}
if (!xpiname || !xpifile || !entity || !newvalue)
return TRUE;//*** Changed FALSE to TRUE
//check to see if it is a jar and then do accordingly
if (jarname.CompareNoCase("no.jar")==0)
ExtractXPIFile(xpiname, xpifile);
else
ExtractJARFile(xpiname, jarname, xpifile);
if (strcmp(cmdname, "modifyHashedPrefString") == 0)
ModifyHashedPref(xpifile,entity,newvalue, "string", TRUE);
else if (strcmp(cmdname, "modifyHashedPrefInt") == 0)
ModifyHashedPref(xpifile,entity,newvalue, "int", TRUE);
else if (strcmp(cmdname, "modifyHashedPrefBool") == 0)
ModifyHashedPref(xpifile,entity,newvalue, "bool", TRUE);
else if (strcmp(cmdname, "modifyHomepageURL") == 0)
ModifyHomepageURL(xpifile,entity,newvalue);
else if (strcmp(cmdname, "modifyJS") == 0)
ModifyJS(xpifile,entity,newvalue, FALSE);
else if (strcmp(cmdname, "modifyProperties") == 0)
ModifyProperties(xpifile,entity,newvalue);
else if (strcmp(cmdname, "modifyJS1") == 0)
ModifyJS1(xpifile,entity,newvalue, FALSE);
else if (strcmp(cmdname, "modifyJS2") == 0)
ModifyJS2(xpifile,entity,newvalue, FALSE);
else
{
// If the browser window's title bar text field is empty,
// the default browser value is displayed
if ((strcmp(entity,"mainWindow.titlemodifier") == 0) &&
(strcmp(newvalue,"") == 0))
newvalue = "&brandShortName;";
ModifyDTD(xpifile, entity, newvalue);
}
}
else if (strcmp(cmdname, "wrapXPI") == 0)
{
}
else if (strcmp(cmdname, "processPrefsTree") == 0)
{
char *prefsTreeFile = strtok(NULL, ",)");
CString fileWithPath = configPath + "\\" + prefsTreeFile;
char *installFile = strtok(NULL, ",)");
gstrInstallFile = installFile;
char *cfgPrefFile = strtok(NULL, ",)");
gstrCFGPrefFile = cfgPrefFile;
char *plainPrefFile = strtok(NULL, ",)");
gstrPlainPrefFile = plainPrefFile;
ProcessPrefsTree(fileWithPath);
}
else if (strcmp(cmdname, "configureRemoteAdmin") == 0)
{
char *vConvert = strtok(NULL, ",)"); // if set, then do the convert to remote admin
if (vConvert[0] == '%')
{
vConvert++;
char *t = strchr(vConvert, '%');
if (!t)
return TRUE;
*t = '\0';
char *bConvert = (char *)(LPCTSTR) GetGlobal(vConvert);
// The convert checkbox was not checked. No need to continue.
if (strcmp(bConvert, "1") != 0)
return TRUE;
}
char *url = strtok(NULL, ",)");
if (url[0] == '%')
{
url++;
char *t = strchr(url, '%');
if (!t)
return TRUE;
*t = '\0';
url = (char *)(LPCTSTR) GetGlobal(url);
if (!url)
return TRUE;
}
char *prefFile = strtok(NULL, ",)");
if (!prefFile)
return TRUE;
ConfigureRemoteAdmin(url, prefFile);
}
else if (strcmp(cmdname, "modifyUserJS") == 0)
{
// modifyUserJS(XPIname, fileWithinXPI, JSsourcefile) // within XPI
// modifyUserJS(browser.xpi, bin, jsedit.jsc) // example
// modifyUserJS(none, pathAndFilename, JSsourcefile) // normal file
// modifyUserJS(none, \autoadmin\test.jsc, jsedit.jsc) // example
char *xpiname = strtok(NULL, ",)");
char *filename = strtok(NULL, ",)");
char *jssource = strtok(NULL, ",)");
CString jsSourceFile = configPath + "\\" + jssource;
// pull the cfg file out of the XPI
//
ExtractXPIFile(xpiname, filename);
// replace the appropriate block of javascript
//
ModifyUserJS(filename, jsSourceFile);
// cfg file gets repackaged with call to ReplaceXPIFiles in StartIB after all the interpret calls,
// so no need to repacked it ourself.
}
else if (strcmp(cmdname, "markcfgversion") == 0)
{
char *xpiname = strtok(NULL, ",)");
char *filename = strtok(NULL, ",)");
char *versiontxt = strtok(NULL, ",)");
// pull the cfg file out of the XPI
//
ExtractXPIFile(xpiname, filename);
// replace the appropriate block of javascript
//
MarkCFGVersion(filename, versiontxt);
// cfg file gets repackaged with call to ReplaceXPIFiles in StartIB after all the interpret calls,
// so no need to repacked it ourself.
}
else
return FALSE;//*** We have to handle this condition better.
return TRUE;
}
void init_components()
{
int i;
WIDGET *w = findWidget("SelectedComponents");
BuildComponentList(Components, &numComponents, iniSrcPath,0);
// Turn off components that aren't selected
for (i=0; i<numComponents; i++)
{
if ((strstr(ConvertUTF8toANSI(w->value), Components[i].name) == NULL))
{
if (!(Components[i].selected && Components[i].invisible))
Components[i].selected = FALSE;
}
else
if ((Components[i].additional) || !(Components[i].empty))
Components[i].selected = TRUE;
}
}
/*Post Beta - we will use the DISABLED key.
Now this is implemented the round about way here.
We have to take only the components that are chosen and mark the rest as disabled
Disabled doesnt work now - so what we are doing is re writing every key in the sections
besides that we are also deleting the keys in the setup types 2&3 so that we have only two
as per request of mktg.
*/
void invisible()
{
CString Setup0Long = "Program will be installed with the most common options";
CString Setup1Long = "You may choose the options you want to install. Recommended for advanced users.";
WritePrivateProfileString("Setup Type0", NULL, "", iniDstPath);
WritePrivateProfileString("Setup Type1", NULL, "", iniDstPath);
WritePrivateProfileString("Setup Type0","Description Short",(LPCTSTR)Setup0Short,iniDstPath);
WritePrivateProfileString("Setup Type0","Description Long", (LPCTSTR)Setup0Long,iniDstPath);
WritePrivateProfileString("Setup Type1","Description Short",(LPCTSTR)Setup1Short,iniDstPath);
WritePrivateProfileString("Setup Type1","Description Long", (LPCTSTR)Setup1Long,iniDstPath);
WritePrivateProfileString("Setup Type2",NULL," ",iniDstPath);
WritePrivateProfileString("Setup Type3",NULL," ",iniDstPath);
CString Cee;
tempWidget = findWidget("SelectedComponents");
CString component;
for (int i=0; i<numComponents; i++)
{
if (Components[i].selected)
{
component = Components[i].compname;
Cee.Format("C%d", componentOrder);
WritePrivateProfileString("Setup Type0",(LPCTSTR)Cee,(LPCTSTR)component, iniDstPath);
WritePrivateProfileString("Setup Type1",(LPCTSTR)Cee,(LPCTSTR)component, iniDstPath);
if (Components[i].additional && !(Components[i].launchapp) &&
!Components[i].forceupgrade && !(Components[i].invisible))
WritePrivateProfileString(Components[i].compname, "Attributes",
"SELECTED|ADDITIONAL", iniDstPath);
else if (Components[i].additional && !(Components[i].launchapp) &&
Components[i].forceupgrade && !(Components[i].unselected) &&
!(Components[i].invisible))
WritePrivateProfileString(Components[i].compname, "Attributes",
"SELECTED|ADDITIONAL|FORCE_UPGRADE", iniDstPath);
else if (Components[i].additional && !(Components[i].launchapp) &&
Components[i].forceupgrade && Components[i].unselected &&
!(Components[i].invisible))
WritePrivateProfileString(Components[i].compname, "Attributes",
"UNSELECTED|ADDITIONAL|FORCE_UPGRADE", iniDstPath);
else if (!(Components[i].disabled) && !(Components[i].additional) &&
Components[i].forceupgrade && !(Components[i].invisible))
WritePrivateProfileString(Components[i].compname, "Attributes",
"SELECTED|FORCE_UPGRADE", iniDstPath);
else if (Components[i].additional && Components[i].launchapp &&
Components[i].uncompress && !(Components[i].invisible))
WritePrivateProfileString(Components[i].compname, "Attributes",
"SELECTED|UNCOMPRESS|LAUNCHAPP|ADDITIONAL", iniDstPath);
else if (!(Components[i].additional) &&
!(Components[i].forceupgrade) && !(Components[i].invisible))
WritePrivateProfileString(Components[i].compname, "Attributes",
"SELECTED|INVISIBLE", iniDstPath);
componentOrder++;
}
else
WritePrivateProfileString(Components[i].compname, "Attributes", "INVISIBLE", iniDstPath);
}
}
void LinuxInvisible()
{
Setup0Short = "Recommended";
Setup1Short = "Custom";
CString Setup0Long = "Installs the most common options. Quickest to download; recommended for most users. Java not included.";
CString Setup1Long = "Recommended for advanced users or users with specific international language package requirements. (Navigator will be installed by default.)";
WritePrivateProfileString("Setup Type0", NULL, "", iniDstPath);
WritePrivateProfileString("Setup Type1", NULL, "", iniDstPath);
WritePrivateProfileString("Setup Type0","Description Short",
(LPCTSTR)Setup0Short,iniDstPath);
WritePrivateProfileString("Setup Type0","Description Long",
(LPCTSTR)Setup0Long,iniDstPath);
WritePrivateProfileString("Setup Type1","Description Short",
(LPCTSTR)Setup1Short,iniDstPath);
WritePrivateProfileString("Setup Type1","Description Long",
(LPCTSTR)Setup1Long,iniDstPath);
WritePrivateProfileString("Setup Type2",NULL," ",iniDstPath);
WritePrivateProfileString("Setup Type3",NULL," ",iniDstPath);
CString Cee;
tempWidget = findWidget("SelectedComponents");
CString component;
for (int i=0; i<numComponents; i++)
{
if (Components[i].selected)
{
component = Components[i].compname;
Cee.Format("C%d", componentOrder);
WritePrivateProfileString("Setup Type0",(LPCTSTR)Cee,
(LPCTSTR)component,iniDstPath);
WritePrivateProfileString("Setup Type1",(LPCTSTR)Cee,
(LPCTSTR)component,iniDstPath);
if ((Components[i].invisible) && (Components[i].downloadonly))
WritePrivateProfileString(Components[i].compname,"Attributes",
"SELECTED|INVISIBLE|DOWNLOAD_ONLY",iniDstPath);
else if ((Components[i].invisible) && !(Components[i].downloadonly))
WritePrivateProfileString(Components[i].compname,"Attributes",
"SELECTED|INVISIBLE",iniDstPath);
else if (!Components[i].empty)
WritePrivateProfileString(Components[i].compname,"Attributes",
"",iniDstPath);
else
WritePrivateProfileString(Components[i].compname,"Attributes",
"SELECTED",iniDstPath);
componentOrder++;
}
else
WritePrivateProfileString(Components[i].compname,"Attributes",
"INVISIBLE",iniDstPath);
}
}
void AddThirdParty()
{
CString tpCompPath1 = GetGlobal("CustomComponentPath1");
CString tpCompPath2 = GetGlobal("CustomComponentPath2");
CString tpComp1 = ConvertUTF8toANSI(GetGlobal("CustomComponentDesc1"));
CString tpComp2 = ConvertUTF8toANSI(GetGlobal("CustomComponentDesc2"));
CString tpCompSize1 = GetGlobal("CustomComponentSize1");
CString tpCompSize2 = GetGlobal("CustomComponentSize2");
CString componentName;
CString cName;
CString compSDesc = "Description Short=";
CString compLDesc = "Description Long=";
CString compArchive = "Archive=";
CString compISize = "Install Size Archive=";
CString compAttrib = "Attributes=SELECTED|LAUNCHAPP";
int archiveLen = tpCompPath1.GetLength();
int findLen = tpCompPath1.ReverseFind('\\');
CString Archive1 = tpCompPath1.Right(archiveLen - findLen -1);
archiveLen = tpCompPath2.GetLength();
findLen = tpCompPath2.ReverseFind('\\');
CString Archive2 = tpCompPath2.Right(archiveLen - findLen -1);
CString tempstr;
char *cBuffer1 = new char [MAX_SIZE];
char *p = cBuffer1;
strcpy(p,LPCTSTR(compSDesc + tpComp1));
tempstr = compSDesc + tpComp1;
p += (tempstr.GetLength() +1);
strcpy(p,LPCTSTR(compLDesc + tpComp1));
tempstr = compLDesc + tpComp1;
p += (tempstr.GetLength() +1);
strcpy(p,LPCTSTR(compArchive + Archive1));
tempstr = compArchive + Archive1;
p += (tempstr.GetLength() +1);
strcpy(p,LPCTSTR(compISize + tpCompSize1));
tempstr = compISize + tpCompSize1;
p += (tempstr.GetLength() +1);
strcpy(p,LPCTSTR(compAttrib));
p += (compAttrib.GetLength() +1);
*p = 0;
char *cBuffer2 = new char [MAX_SIZE];
char *q = cBuffer2;
strcpy(q,LPCTSTR(compSDesc + tpComp2));
tempstr = compSDesc + tpComp2;
q += (tempstr.GetLength() +1);
strcpy(q,LPCTSTR(compLDesc + tpComp2));
tempstr = compLDesc + tpComp2;
q += (tempstr.GetLength() +1);
strcpy(q,LPCTSTR(compArchive + Archive2));
tempstr = compArchive + Archive2;
q += (tempstr.GetLength() +1);
strcpy(q,LPCTSTR(compISize + tpCompSize2));
tempstr = compISize + tpCompSize2;
q += (tempstr.GetLength() +1);
strcpy(q,LPCTSTR(compAttrib));
q += (compAttrib.GetLength() +1);
*q = 0;
/*
char cBuffer1[MAX_SIZE][MAX_SIZE]={LPCTSTR(compSDesc + tpComp1),LPCTSTR(compLDesc + tpComp1),
LPCTSTR(compArchive + Archive1),LPCTSTR(compISize + tpCompSize1),
LPCTSTR(compAttrib)};
char *cBuffer2[]={LPCTSTR(compSDesc + tpComp2),LPCTSTR(compLDesc + tpComp2),
LPCTSTR(compArchive + Archive2),LPCTSTR(compISize + tpCompSize2),
LPCTSTR(compAttrib)};
*/
CString firstSix = tpCompPath1.Left(6);
if ((firstSix.CompareNoCase("Please") != 0) && !(tpCompPath1.IsEmpty()))
{
componentName.Format("C%d", (numComponents));
cName.Format("C%d", componentOrder);
componentOrder++;
WritePrivateProfileString("Setup Type0", cName, componentName, iniDstPath);
WritePrivateProfileString("Setup Type1", cName, componentName, iniDstPath);
WritePrivateProfileSection(componentName, cBuffer1, iniDstPath);
numComponents++;
CopyFile(tpCompPath1, xpiDstPath + "\\" + Archive1, FALSE);
DWORD e1 = GetLastError();
}
firstSix = tpCompPath2.Left(6);
if ((firstSix.CompareNoCase("Please") != 0) && !(tpCompPath2.IsEmpty()))
{
componentName.Format("C%d", (numComponents));
cName.Format("C%d", componentOrder);
WritePrivateProfileString("Setup Type0", cName, componentName, iniDstPath);
WritePrivateProfileString("Setup Type1", cName, componentName, iniDstPath);
WritePrivateProfileSection(componentName, cBuffer2, iniDstPath);
CopyFile(tpCompPath2, xpiDstPath + "\\" + Archive2, FALSE);
DWORD e2 = GetLastError();
}
delete [] cBuffer1;
delete [] cBuffer2;
}
HRESULT CreateShortcut(const CString Target, const CString Arguments, const CString
LinkFileName, const CString WorkingDir, bool IsFolder)
{
// Initialize OLE libraries
if (!AfxOleInit())
return FALSE;
HRESULT hres;
CString Desktop=getenv("USERPROFILE");
Desktop += "\\Desktop\\";
CString Link = Desktop + LinkFileName;
if (!IsFolder)
{
IShellLink* psl;
hres = CoCreateInstance(CLSID_ShellLink, NULL, CLSCTX_INPROC_SERVER, IID_IShellLink,
(LPVOID*) &psl);
if (SUCCEEDED(hres))
{
IPersistFile* ppf;
psl->SetPath(Target);
psl->SetArguments(Arguments);
psl->SetWorkingDirectory(WorkingDir);
hres = psl->QueryInterface( IID_IPersistFile, (LPVOID *) &ppf);
if (SUCCEEDED(hres))
{
CString Temp = Link;
Temp.MakeLower();
if (Temp.Find(".lnk")==-1)
Link += ".lnk"; // Important !!!
WORD wsz[MAX_PATH];
MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, Link, -1, wsz,MAX_PATH);
hres = ppf->Save(wsz, TRUE);
ppf->Release();
}
psl->Release();
}
}
else
{
hres = _mkdir(Link);
}
return hres;
}
BOOL GetRegistryKey( HKEY key, char *subkey, char *retdata )
{
long retval;
HKEY hkey;
retval = RegOpenKeyEx(key, subkey, 0, KEY_QUERY_VALUE, &hkey);
if(retval == ERROR_SUCCESS)
{
long datasize = MAX_SIZE;
char data[MAX_SIZE];
RegQueryValue(hkey,NULL,(LPSTR)data,&datasize);
lstrcpy(retdata,data);
RegCloseKey(hkey);
}
return retval;
}
CString GetBrowser(void)
{
char key[MAX_SIZE + MAX_SIZE];
CString retflag = "";
/* get the .htm regkey and lookup the program */
if(GetRegistryKey(HKEY_CLASSES_ROOT,".htm",key) == ERROR_SUCCESS)
{
lstrcat(key,"\\shell\\open\\command");
if(GetRegistryKey(HKEY_CLASSES_ROOT,key,key) == ERROR_SUCCESS)
{
char *pos;
pos = strstr(key,"\"%1\"");
if(pos == NULL) /* if no quotes */
{
/* now check for %1, without the quotes */
pos = strstr(key,"%1");
if(pos == NULL) /* if no parameter */
pos = key+lstrlen(key)-1;
else
*pos = '\0'; /* remove the parameter */
}
else
*pos = '\0'; /* remove the parameter */
retflag = key;
}
}
return retflag;
}
CString SubstituteValues(CString inLine)
// Replace tokens in script template with appropriate locale values
{
CString newValue, oldValue, strTemp;
int tokenStartPos, tokenEndPos,
searchPos=0, count=0;
int inLineLength = inLine.GetLength();
while (count < inLineLength)
{
tokenStartPos = inLine.Find('%', searchPos);
if (tokenStartPos != -1)
{
tokenEndPos = inLine.Find('%', tokenStartPos+1);
tokenEndPos += 1;
strTemp = inLine.Left(tokenEndPos);
oldValue = strTemp.Right(tokenEndPos-tokenStartPos);
WIDGET *w = findWidget(oldValue);
if (w)
{
newValue = GetGlobal(oldValue);
searchPos = 0;
}
else
{
newValue = oldValue;
searchPos = tokenEndPos;
}
inLine.Replace(oldValue, newValue);
count = tokenEndPos;
}
else
count = inLineLength;
}
return inLine;
}
void CreateLinuxInstaller()
{
char currentdir[_MAX_PATH];
_getcwd(currentdir,_MAX_PATH);
if (FileExists(xpiDstPath+"\\"+tarfile))
DeleteFile(xpiDstPath+"\\"+tarfile);
CopyDirectory(xpiDstPath, templinuxPath + xpiDir, TRUE);
CopyFile(xpiDstPath+"\\Config.ini", templinuxPath+"\\Config.ini",FALSE);
DeleteFile(templinuxPath + xpiDir + "\\Config.ini");
FILE *fout = fopen(templinuxPath+"\\config.tmp", "wb");
if (!fout)
{
AfxMessageBox("Cannot open output file", MB_OK);
exit(3);
}
FILE *fin = fopen(templinuxPath+"\\Config.ini", "rb");
if (!fin)
{
AfxMessageBox("Cannot open Config.ini file", MB_OK);
exit(3);
}
else
{
char inbuf[BUF_SIZE], outbuf[BUF_SIZE];
int cnt2=0;
while(!feof(fin))
{
int count = fread(&inbuf, sizeof(char), sizeof(inbuf), fin);
if (ferror(fin))
{
AfxMessageBox("Error in reading Config.ini file", MB_OK);
exit(3);
}
char *cpin = inbuf;
char *cpout = outbuf;
while (count-- > 0)
{
if (*cpin == CRVALUE)
cpin++;
else
{
*cpout++ = *cpin++;
cnt2++;
}
}
fwrite(&outbuf, sizeof(char), cnt2, fout);
if (ferror(fout))
{
AfxMessageBox("Error in writing Config.ini file", MB_OK);
exit(3);
}
cnt2=0;
}
fclose(fin);
}
fclose(fout);
DeleteFile(templinuxPath+"\\Config.ini");
rename(templinuxPath+"\\config.tmp",templinuxPath+"\\config.ini");
_chdir(outputPath);
templinuxPath = tempPath;
templinuxPath.Replace("\\", "/");
templinuxPath.Replace(":","");
templinuxPath.Insert(0,"/cygdrive/");
CString command = "tar -zcvf " + tarfile + " -C " +quotes+ templinuxPath + "/" + templinuxDir +quotes+ spaces + nsinstallerDir;
ExecuteCommand((char *)(LPCTSTR) command, SW_HIDE, INFINITE);
_chdir(currentdir);
}
void CreateMacZipFile()
// Creating a single customized Mac zip file which contains mac scripts
// and customized mac files
{
CString customizedZipFile = "CustomizedMacFiles.zip";
if (FileExists(customizedZipFile))
DeleteFile(customizedZipFile);
// Adding Mac scripts shipped with the tool to the final Mac zip file
CString command = quotes + rootPath + "zip.exe" + quotes + spaces + "-j" +
spaces + quotes + xpiDstPath + "\\" + customizedZipFile + quotes +
spaces + quotes + platformPath + "\\*.*" + quotes;
ExecuteCommand((char *)(LPCTSTR) command, SW_HIDE, INFINITE);
// Adding customized mac files created in output directory to the
// final Mac zip file
command = quotes + rootPath + "zip.exe" + quotes + spaces + "-jm" +
spaces + quotes + xpiDstPath + "\\" + customizedZipFile + quotes +
spaces + quotes + xpiDstPath + "\\*.*" + quotes;
ExecuteCommand((char *)(LPCTSTR) command, SW_HIDE, INFINITE);
}
void InsertComma(CString& requiredSpace)
{
int len = requiredSpace.GetLength();
int pos = len%3;
if (pos == 0)
pos = 3;
for(int i=pos; i<len; i+=3)
{
requiredSpace.Insert(i,',');
i++;
}
}
void DiskSpaceAlert(ULONGLONG required, ULONGLONG available)
{
char tempavailspace[20], tempreqspace[20];
CString availableSpace, requiredSpace;
_ui64toa(available, tempavailspace, 10);
availableSpace = tempavailspace;
InsertComma(availableSpace);
_ui64toa(required, tempreqspace, 10);
requiredSpace = tempreqspace;
InsertComma(requiredSpace);
AfxMessageBox("Not enough disk space. Required: "+requiredSpace+" bytes. Available: "+availableSpace+" bytes.", MB_OK);
}
BOOL FillGlobalWidgetArray(CString file)
{
char buffer[MAX_SIZE] = {'\0'};
CString name = "";
CString value = "";
FILE *globs = fopen(file, "r");
if (!globs)
return FALSE;
while(!feof(globs))
{
while(fgets(buffer, MAX_SIZE, globs))
{
if (strstr(buffer, "="))
{
name = CString(strtok(buffer,"="));
value = CString(strtok(NULL,"="));
value.TrimRight();
if (value.Find("%") >= 0) {
//We should never enter this condition via wizardmachine.exe
AfxMessageBox("The current .che file called: "+file+" contains some unfilled parameters."
"These parameters will appear between two percent (%) signs such as %Root%"
"Please replace these parameters with their appropriate values and restart"
"the program", MB_OK);
// value=theInterpreter->replaceVars((char *) (LPCSTR) value,NULL);
}
WIDGET* w = SetGlobal(name, value);
if (w)
w->cached = TRUE;
}
}
}
fclose(globs);
return TRUE;
}
int StartIB(/*CString parms, WIDGET *curWidget*/)
{
char *fgetsrv;
int rv = TRUE;
char olddir[1024];
CString curVersion, curLanguage, localePath,
strLang, strRegion, strREGION;
componentOrder = 0;
rootPath = GetModulePath();
SetGlobal("Root", rootPath);
configName = GetGlobal("_NewConfigName");
SetGlobal("CustomizationList", configName);
curVersion = GetGlobal("Version");
curPlatform = GetGlobal("lPlatform");
platformPath = rootPath+"Version\\"+curVersion+"\\"+curPlatform;
curLanguage = GetGlobal("Language");
localePath = rootPath+"Version\\"+curVersion+"\\"+curPlatform+"\\"+curLanguage;
configPath = rootPath + "Configs\\" + configName;
outputPath = configPath + "\\Output";
cdPath = configPath + "\\Output\\Core";
cdshellPath = configPath + "\\Output\\Shell";
remoteAdminFile = outputPath + "\\autoconfig.jsc";
networkPath = configPath + "\\Network";
tempPath = configPath + "\\Temp";
iniDstPath = cdPath + "\\config.ini";
scriptPath = rootPath + "script_" + curPlatform + ".ib";
workspacePath = configPath + "\\Workspace";
xpiDstPath = cdPath;
// variables for language-region information
strLang = curLanguage.Left(2);
strRegion = curLanguage.Right(2);
strREGION = strRegion;
strREGION.MakeUpper();
SetGlobal("%lang%", strLang);
SetGlobal("%region%", strRegion);
SetGlobal("%REGION%", strREGION);
// initializing variables for CCK linux build
templinuxPath = tempPath + "\\templinux\\netscape-installer";
nsinstPath = "\\netscape-installer\\xpi";
nsinstallerDir = "netscape-installer";
xpiDir = "\\xpi";
templinuxDir = "tempLinux";
tarfile = "netscape-i686-pc-linux-gnu-sea.tar.gz";
// AfxMessageBox("set breakpoint",MB_OK);
if (SearchPath(workspacePath, "NSCPXPI", NULL, 0, NULL, NULL))
nscpxpiPath = workspacePath + "\\NSCPXPI";
else
nscpxpiPath = localePath + "\\Nscpxpi";
if (curPlatform == "Linux")
{
_mkdir(tempPath);
_chdir(tempPath);
_mkdir(templinuxDir);
_chdir(templinuxDir);
_mkdir(nsinstallerDir);
CopyDirectory(nscpxpiPath+"\\"+nsinstallerDir, templinuxPath, TRUE);
// get rid of this ugly code when bugzilla bug 105351 is fixed
CopyFile(nscpxpiPath+"\\full.start",
templinuxPath+"\\xpi\\full.start", FALSE);
CopyFile(nscpxpiPath+"\\full.end",
templinuxPath+"\\xpi\\full.end", FALSE);
CopyFile(nscpxpiPath+"\\recommended.start",
templinuxPath+"\\xpi\\recommended.start", FALSE);
CopyFile(nscpxpiPath+"\\recommended.end",
templinuxPath+"\\xpi\\recommended.end", FALSE);
}
iniSrcPath = nscpxpiPath + "\\config.ini";
//Check for disk space before continuing
ULARGE_INTEGER nTotalBytes, nTotalFreeBytes, nTotalAvailable;
GetDiskFreeSpaceEx(NULL,&nTotalAvailable, &nTotalBytes, &nTotalFreeBytes);
// Checking for 26.3MB disk space
if (curPlatform == "Windows")
{
if ((nTotalAvailable.QuadPart) < WDISK_SPACE)
{
DiskSpaceAlert(WDISK_SPACE,(nTotalAvailable.QuadPart));
return FALSE;
}
}
else if (curPlatform == "Linux")
{
if ((nTotalAvailable.QuadPart) < LDISK_SPACE)
{
DiskSpaceAlert(LDISK_SPACE,(nTotalAvailable.QuadPart));
return FALSE;
}
}
else if (curPlatform == "Mac OS")
{
if ((nTotalAvailable.QuadPart) < MDISK_SPACE)
{
DiskSpaceAlert(MDISK_SPACE,(nTotalAvailable.QuadPart));
return FALSE;
}
}
//Check for Disk space over
init_components();
//checking for the autorun CD shell - inorder to create a Core dir or not
CString cdDir= GetGlobal("CD image");
CString networkDir = GetGlobal("Network");
CString ftpLocation = GetGlobal("FTPLocation");
//checking to see if the AnimatedLogoURL has a http:// appended in front of it
//if not then we have to append it;
//Check to see if the User Agent string exists and if so then prefix with -CK
//(-CK can be replaced with a string UserAgentPrefix global.)
CString userAgentPrefix = GetGlobal("UserAgentPrefix");
if (userAgentPrefix.IsEmpty())
userAgentPrefix = "CK-";
CString userAgent = GetGlobal("OrganizationName");
if (userAgent)
{
CString templeft = userAgent.Left(3);
if ((templeft.CompareNoCase(userAgentPrefix)) != 0)
userAgent = userAgentPrefix + userAgent;
}
SetGlobal("OrganizationName",userAgent);
// check to see if the bmp for rshell background is bigger than 302KB;
HANDLE hFile;
DWORD dwFileSize;
CString Rshellbmp = GetGlobal("ShellBgBitmap");
hFile = CreateFile ((LPCTSTR)Rshellbmp,GENERIC_READ,FILE_SHARE_READ,NULL,
OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL,(HANDLE)NULL);
dwFileSize = GetFileSize (hFile, NULL);
int returnValue;
if (dwFileSize < 300000)
returnValue = AfxMessageBox("You have chosen a background BitMap that is too small for the customized RShell-If you want to proceed anyway choose Cancel or click on Retry and go back and make your changes",MB_RETRYCANCEL);
if (returnValue == IDRETRY)
return FALSE;
//end of filesize check;
// Check to see if the animatedlogourl has the http before it or not- else the browser
// looks only in the chrome directory.
CString animLogoUrl = GetGlobal("AnimatedLogoURL");
CString leftvalue = animLogoUrl.Left(7);
CString httpvalue = "http://";
if (leftvalue.CompareNoCase("http://") != 0)
{
httpvalue = httpvalue + animLogoUrl;
SetGlobal("AnimatedLogoURL",httpvalue);
}
CString HelpUrl = GetGlobal("HelpMenuCommandURL");
leftvalue = HelpUrl.Left(7);
httpvalue = "http://";
if (leftvalue.CompareNoCase("http://") != 0)
{
httpvalue = httpvalue + HelpUrl;
SetGlobal("HelpMenuCommandURL",httpvalue);
}
// Create the HelpMenu.xul in the beginning so that it can be called from the script.ib
CString setHlpRDF = tempPath +"\\helpMenu.rdf";
SetGlobal("HlpRDF",setHlpRDF);
CreateHelpMenu();
CString setIspRDF = tempPath +"\\mailaccount.rdf";
SetGlobal("IspRDF",setIspRDF);
CreateIspMenu();
CString setnewsRDF = tempPath +"\\newsaccount.rdf";
SetGlobal("NewsRDF",setnewsRDF);
CreateNewsMenu();
// Determine which proxy configuration is chosen
CString proxyConfigoption = GetGlobal("radioGroup2");
if (proxyConfigoption == "3")
SetGlobal("ProxyConfig","2");
else if (proxyConfigoption == "2")
SetGlobal("ProxyConfig","1");
else
SetGlobal("ProxyConfig","0");
// Determine which SOCKS version is chosen
CString socksVer = GetGlobal("socksv");
if (socksVer == "SOCKS v4")
SetGlobal("SocksVersion","4");
else
SetGlobal("SocksVersion","5");
if ((cdDir.Compare("1")==0) && (curPlatform.Compare("Windows")==0))
{
_mkdir((char *)(LPCTSTR) cdPath);
}
else
{
iniDstPath = outputPath + "\\config.ini";
xpiDstPath = outputPath;
}
/////////////////////////////
_mkdir((char *)(LPCTSTR) tempPath);
_mkdir((char *)(LPCTSTR) workspacePath);
// Copying config.ini file to the output directory
if (!CopyFile(iniSrcPath, iniDstPath, TRUE))
DWORD e = GetLastError();
// _mkdir((char *)(LPCTSTR) cdshellPath);
GetCurrentDirectory(sizeof(olddir), olddir);
if(SetCurrentDirectory((char *)(LPCTSTR) tempPath) == FALSE)
{
AfxMessageBox("Windows System Error:Unable to change directory",MB_OK);
return TRUE;
}
//PostBeta - We have to inform the user that he has not set any value
//and that it will default.Returning TRUE so that it doesnt stay in the last
//screen forever.
// Read in script file and interpret commands from it
FILE *f = fopen(scriptPath, "r");
if (!f)
rv = FALSE;
else
{
int done = FALSE;
while (!done)
{
fgetsrv = fgets(buffer, sizeof(buffer), f);
done = feof(f);
if (!done)
{
if (!fgetsrv || ferror(f))
{
rv = FALSE;
break;
}
buffer[strlen(buffer)] = '\0'; // Eliminate the trailing newline
CString strTempBuffer = buffer;
strcpy(buffer, SubstituteValues(strTempBuffer));
if (!interpret(buffer))
{
rv = FALSE;
break;
}
}
}
fclose(f);
}
// Put all the extracted files back into their new XPI homes
ReplaceJARFiles();
ReplaceXPIFiles();
// Copy remaining default installer files into config
// preserving any existing files that we created already
// in previous steps
/* -- Need to be more selective than this
CopyDir(nscpxpiPath, cdPath, NULL, FALSE);
*/
for (int i=0; i<numComponents; i++)
{
if (Components[i].selected)
CopyFile(nscpxpiPath + "\\" + Components[i].archive,
xpiDstPath + "\\" + Components[i].archive, TRUE);
}
if (curPlatform == "Windows")
{
if (cdDir.Compare("1") ==0)
{
CString shellPath = workspacePath + "\\Autorun\\";
CopyDir(shellPath, outputPath, NULL, TRUE);
CreateRshell ();
WritePrivateProfileString("Message Stream", "Status", "Disabled", iniDstPath);
}
else
{
FILE *infout;
CString infFile = outputPath + "\\autorun.inf";
infout = fopen(infFile, "w");
if (!infout)
exit( 3 );
fprintf(infout,"[autorun]\nopen = setup.exe");
}
CString component;
CString configiniPath = xpiDstPath +"\\config.ini";
if (ftpLocation.Compare("ftp://") !=0)
{
// Change the ftp section to accomodate changes from PR3 to RTM
// for (int i=0; i<numComponents; i++)
// {
// if (Components[i].selected)
// CopyFile(nscpxpiPath + "\\" + Components[i].archive,
// networkPath + "\\" + Components[i].archive, TRUE);
WritePrivateProfileString("General", "url", ftpLocation, configiniPath);
WritePrivateProfileString("Redirect", "Status", "Disabled", configiniPath);
WritePrivateProfileString("Site Selector", NULL, "", configiniPath);
WritePrivateProfileString("Site Selector", "Identifier0", "Site0", configiniPath);
WritePrivateProfileString("Site Selector", "Description0", "Default", configiniPath);
WritePrivateProfileString("Site Selector", "Domain0", ftpLocation, configiniPath);
// HTTP support for network installer
CString httpstr = ftpLocation.Left(7);
if (httpstr.Compare("http://") == 0)
WritePrivateProfileString("Dialog Advanced Settings",
"Use Protocol", "HTTP", configiniPath);
else
WritePrivateProfileString("Dialog Advanced Settings",
"Use Protocol", "FTP", configiniPath);
// }
}
invisible();
AddThirdParty();
ReplaceINIFile();
}
else if (curPlatform == "Linux")
{
LinuxInvisible();
AddThirdParty();
CreateLinuxInstaller();
}
else if (curPlatform == "Mac OS")
{
CreateMacZipFile();
}
SetCurrentDirectory(olddir);
CString TargetDir = GetGlobal("Root");
CString TargetFile = TargetDir + "wizardmachine.ini";
CString MozBrowser = GetBrowser();
// CreateShortcut(MozBrowser, TargetFile, "HelpLink", TargetDir, FALSE);
SetCurrentDirectory(configPath);
EraseDirectory(tempPath);
RemoveDirectory(tempPath);
return TRUE;
}