// Includes #include "stdafx.h" #include #include #include #include #include "globals.h" #include "comp.h" #include "ib.h" #include "fstream.h" #include #include #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 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; // variables for CCK Linux build CString linuxOption; CString templinuxPath; CString nsinstPath; CString nsinstallerDir; CString xpiDir; CString templinuxDir; CString tarfile; // For use with PrefsTree CString gstrPrefFile; 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)) 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 " + ClearTextFile + " -output " + HashedFile; 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; //We have to get rid of the bin/chrome/ and hence the delete. jarname.Delete(0,11); if (findJAR(jarname, xpifile)) return TRUE; // Can use -d instead of change CWD??? CString jarArchive = tempPath + "\\bin\\chrome\\" + jarname; 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? 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: "<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) { // Only write those prefs that have been marked as "Manage." Ignore all others. BOOL bManage = ((CPrefElement*)userData)->IsManage(); if (!bManage) return; // Write the pref element to prefs file. ExtractXPIFile(gstrInstallFile, gstrPrefFile); BOOL bLocked = ((CPrefElement*)userData)->IsLocked(); // Should go into a hashed file if prefs file is .cfg. if (gstrPrefFile.Find(".cfg") > 0) { // hashed ModifyHashedPref(gstrPrefFile, ((CPrefElement*)userData)->GetPrefName(), ((CPrefElement*)userData)->GetPrefValue(), ((CPrefElement*)userData)->GetPrefType(), bLocked); } else { // not hashed if ((((CPrefElement*)userData)->GetPrefType() == "int") || (((CPrefElement*)userData)->GetPrefType() == "bool")) ModifyJS2(gstrPrefFile, ((CPrefElement*)userData)->GetPrefName(), ((CPrefElement*)userData)->GetPrefValue(), bLocked); else // string ModifyJS(gstrPrefFile, ((CPrefElement*)userData)->GetPrefName(), ((CPrefElement*)userData)->GetPrefValue(), bLocked); } } } // Converts the strPrefFile (netscp6.cfg) to a plain text file (autoconfig.jsc) in the output directory, then sets the // autoadmin.global_config_url in strPrefFile to strURL. BOOL ConvertToRemoteAdmin(CString strURL, CString strPrefFile, CString strRemoteAdminFile) { ASSERT(!strURL.IsEmpty() && !strPrefFile.IsEmpty() && !strRemoteAdminFile.IsEmpty()); if (strURL.IsEmpty() || strPrefFile.IsEmpty() || strRemoteAdminFile.IsEmpty()) return FALSE; ASSERT(strPrefFile.Find(".cfg") > 0); if (strPrefFile.Find(".cfg") <= 0) return FALSE; // Convert the strPrefFile to plain text remote admin file. CString strPlainTextFile = outputPath + "\\" + strRemoteAdminFile; if (!UnHash(strPrefFile, strPlainTextFile)) return FALSE; // Delete the original pref file and replace it with a file with only remote admin entries. DeleteFile(strPrefFile); ModifyHashedPref(strPrefFile, "autoadmin.global_config_url", strURL, "string", TRUE); CString strAppendEmail = GetGlobal("RemoteAdminAppendEmail"); ModifyHashedPref(strPrefFile, "autoadmin.append_emailaddr", strAppendEmail, "bool", TRUE); CString strFailover = GetGlobal("RemoteAdminFailover"); ModifyHashedPref(strPrefFile, "autoadmin.offline_failover", strFailover, "bool", 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, CString strPrefFile, CString strInstallFile) { gstrPrefFile = strPrefFile; gstrInstallFile = strInstallFile; 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; } WritePrivateProfileString(section, key, newvalue, 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, "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); } // Search for a locked pref variable for this pref name. // It will be a global with name: "lockpref."+prefname CString LockPrefGlobalName; LockPrefGlobalName.Format("lockpref.%s", value); CString LockedPrefCheckboxVal = GetGlobal(LockPrefGlobalName); BOOL bLockPref = (LockedPrefCheckboxVal.Compare("1") == 0); // "1" if locked 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", bLockPref); else if (strcmp(cmdname, "modifyHashedPrefInt") == 0) ModifyHashedPref(xpifile,entity,newvalue, "int", bLockPref); else if (strcmp(cmdname, "modifyHashedPrefBool") == 0) ModifyHashedPref(xpifile,entity,newvalue, "bool", bLockPref); else if (strcmp(cmdname, "modifyJS") == 0) ModifyJS(xpifile,entity,newvalue, bLockPref); else if (strcmp(cmdname, "modifyProperties") == 0) ModifyProperties(xpifile,entity,newvalue); else if (strcmp(cmdname, "modifyJS1") == 0) ModifyJS1(xpifile,entity,newvalue, bLockPref); else if (strcmp(cmdname, "modifyJS2") == 0) ModifyJS2(xpifile,entity,newvalue, bLockPref); 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, ",)"); char *installFile = strtok(NULL, ",)"); char *prefFile = strtok(NULL, ",)"); CString fileWithPath = configPath + "\\" + prefsTreeFile; ProcessPrefsTree(fileWithPath, prefFile, installFile); } else if (strcmp(cmdname, "convertToRemoteAdmin") == 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, ",)"); char *remoteAdminFile = strtok(NULL, ",)"); if (!prefFile || !remoteAdminFile) return TRUE; ConvertToRemoteAdmin(url, prefFile, remoteAdminFile); } 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; ivalue, 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; iSetPath(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; } void CreateLinuxInstaller() { char currentdir[_MAX_PATH]; _getcwd(currentdir,_MAX_PATH); 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/"); DeleteFile(tarfile); CString command = "tar -zcvf " + tarfile + " -C " +quotes+ templinuxPath + "/" + templinuxDir +quotes+ spaces + nsinstallerDir; ExecuteCommand((char *)(LPCTSTR) command, SW_HIDE, INFINITE); _chdir(currentdir); } void InsertComma(CString& requiredSpace) { int len = requiredSpace.GetLength(); int pos = len%3; if (pos == 0) pos = 3; for(int i=pos; i= 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]; componentOrder =0; rootPath = GetModulePath(); SetGlobal("Root", rootPath); configName = GetGlobal("_NewConfigName"); SetGlobal("CustomizationList", configName); CString curVersion = GetGlobal("Version"); CString curPlatform = GetGlobal("lPlatform"); CString curLanguage = GetGlobal("Language"); CString localePath = rootPath+"Version\\"+curVersion+"\\"+curPlatform+"\\"+curLanguage; configPath = rootPath + "Configs\\" + configName; outputPath = configPath + "\\Output"; cdPath = configPath + "\\Output\\Core"; cdshellPath = configPath + "\\Output\\Shell"; networkPath = configPath + "\\Network"; tempPath = configPath + "\\Temp"; iniDstPath = cdPath + "\\config.ini"; scriptPath = localePath + "\\script.ib"; workspacePath = configPath + "\\Workspace"; xpiDstPath = cdPath; // initializing variables for CCK linux build linuxOption = GetGlobal("lPlatform"); templinuxPath = tempPath + "\\templinux\\netscape-installer"; nsinstPath = "\\netscape-installer\\xpi"; nsinstallerDir = "netscape-installer"; xpiDir = "\\xpi"; templinuxDir = "tempLinux"; tarfile = GetGlobal("InstallerFilename"); // AfxMessageBox("set breakpoint",MB_OK); if (SearchPath(workspacePath, "NSCPXPI", NULL, 0, NULL, NULL)) nscpxpiPath = workspacePath + "\\NSCPXPI"; else nscpxpiPath = localePath + "\\Nscpxpi"; if (linuxOption == "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 (linuxOption != "Linux") { if ((nTotalAvailable.QuadPart) < WDISK_SPACE) { DiskSpaceAlert(WDISK_SPACE,(nTotalAvailable.QuadPart)); return FALSE; } } else { if ((nTotalAvailable.QuadPart) < LDISK_SPACE) { DiskSpaceAlert(LDISK_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) { _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 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