fceugx/source/networkop.cpp

302 lines
6.8 KiB
C++
Raw Normal View History

2008-12-24 07:58:23 +00:00
/****************************************************************************
2009-07-22 02:05:49 +00:00
* FCE Ultra
2008-12-24 07:58:23 +00:00
* Nintendo Wii/Gamecube Port
*
* Tantric December 2008
*
* networkop.cpp
*
* Network and SMB support routines
****************************************************************************/
2009-10-02 03:14:04 +00:00
#ifdef HW_DOL
bool
ConnectShare (bool silent)
{
return false;
}
#else
2009-03-31 07:13:20 +00:00
2008-12-24 07:58:23 +00:00
#include <network.h>
#include <smb.h>
#include <mxml.h>
2009-02-07 00:57:39 +00:00
#include <malloc.h>
2008-12-24 07:58:23 +00:00
#include "fceugx.h"
2009-03-28 17:23:08 +00:00
#include "menu.h"
2008-12-24 07:58:23 +00:00
#include "fileop.h"
2009-06-12 07:48:27 +00:00
#include "filebrowser.h"
2010-03-21 23:49:24 +00:00
#include "utils/http.h"
#include "utils/unzip/unzip.h"
#include "utils/unzip/miniunz.h"
2008-12-24 07:58:23 +00:00
bool inNetworkInit = false;
static bool networkInit = false;
static bool autoNetworkInit = true;
static bool networkShareInit = false;
static bool updateChecked = false; // true if checked for app update
2008-12-24 07:58:23 +00:00
static char updateURL[128]; // URL of app update
bool updateFound = false; // true if an app update was found
/****************************************************************************
* UpdateCheck
* Checks for an update for the application
***************************************************************************/
void UpdateCheck()
{
// we can only check for the update if we have internet + SD
if(!updateChecked && networkInit && (isMounted[DEVICE_SD] || isMounted[DEVICE_USB]))
2008-12-24 07:58:23 +00:00
{
static char url[128];
int retval;
updateChecked = true;
snprintf(url, 128, "http://fceugc.googlecode.com/svn/trunk/update.xml");
2009-02-07 00:57:39 +00:00
u8 * tmpbuffer = (u8 *)memalign(32,32768);
memset(tmpbuffer, 0, 32768);
retval = http_request(url, NULL, tmpbuffer, 32768);
2008-12-24 07:58:23 +00:00
memset(url, 0, 128);
if (retval)
{
mxml_node_t *xml;
mxml_node_t *item;
xml = mxmlLoadString(NULL, (char *)tmpbuffer, MXML_TEXT_CALLBACK);
2008-12-24 07:58:23 +00:00
if(xml)
2008-12-24 07:58:23 +00:00
{
// check settings version
item = mxmlFindElement(xml, xml, "app", "version", NULL, MXML_DESCEND);
if(item) // a version entry exists
2008-12-24 07:58:23 +00:00
{
2009-03-31 07:13:20 +00:00
const char * version = mxmlElementGetAttr(item, "version");
if(version && strlen(version) == 5)
2008-12-24 07:58:23 +00:00
{
2009-03-31 07:13:20 +00:00
int verMajor = version[0] - '0';
int verMinor = version[2] - '0';
int verPoint = version[4] - '0';
int curMajor = APPVERSION[0] - '0';
int curMinor = APPVERSION[2] - '0';
int curPoint = APPVERSION[4] - '0';
// check that the versioning is valid and is a newer version
if((verMajor >= 0 && verMajor <= 9 &&
verMinor >= 0 && verMinor <= 9 &&
verPoint >= 0 && verPoint <= 9) &&
(verMajor > curMajor ||
2009-04-01 05:48:01 +00:00
(verMajor == curMajor && verMinor > curMinor) ||
(verMajor == curMajor && verMinor == curMinor && verPoint > curPoint)))
{
2009-03-31 07:13:20 +00:00
item = mxmlFindElement(xml, xml, "file", NULL, NULL, MXML_DESCEND);
if(item)
{
2009-03-31 07:13:20 +00:00
const char * tmp = mxmlElementGetAttr(item, "url");
if(tmp)
{
snprintf(updateURL, 128, "%s", tmp);
updateFound = true;
}
}
}
2008-12-24 07:58:23 +00:00
}
}
mxmlDelete(xml);
2008-12-24 07:58:23 +00:00
}
}
free(tmpbuffer);
2008-12-24 07:58:23 +00:00
}
}
static bool unzipArchive(char * zipfilepath, char * unzipfolderpath)
2008-12-24 07:58:23 +00:00
{
unzFile uf = unzOpen(zipfilepath);
if (uf==NULL)
return false;
if(chdir(unzipfolderpath)) // can't access dir
{
makedir(unzipfolderpath); // attempt to make dir
if(chdir(unzipfolderpath)) // still can't access dir
return false;
}
extractZip(uf,0,1,0);
unzCloseCurrentFile(uf);
return true;
}
bool DownloadUpdate()
{
bool result = false;
if(strlen(updateURL) == 0 || strlen(appPath) == 0)
goto done;
if(!ChangeInterface(appPath, NOTSILENT))
goto done;
// stop checking if devices were removed/inserted
// since we're saving a file
HaltDeviceThread();
2009-12-23 00:36:42 +00:00
int device;
FindDevice(appPath, &device);
2008-12-24 07:58:23 +00:00
FILE * hfile;
char updateFile[50];
2009-12-23 00:36:42 +00:00
sprintf(updateFile, "%s%s Update.zip", pathPrefix[device], APPNAME);
hfile = fopen (updateFile, "wb");
2008-12-24 07:58:23 +00:00
if (hfile > 0)
{
int retval;
2010-03-31 02:47:52 +00:00
retval = http_request(updateURL, hfile, NULL, (1024*1024*10));
fclose (hfile);
}
2008-12-24 07:58:23 +00:00
2009-12-23 00:36:42 +00:00
result = unzipArchive(updateFile, (char *)pathPrefix[device]);
remove(updateFile); // delete update file
2008-12-24 07:58:23 +00:00
// go back to checking if devices were inserted/removed
ResumeDeviceThread();
done:
if(result)
InfoPrompt("Update successful!");
else
ErrorPrompt("Update failed!");
2008-12-24 07:58:23 +00:00
updateFound = false; // updating is finished (successful or not!)
2008-12-24 07:58:23 +00:00
return result;
}
/****************************************************************************
* InitializeNetwork
* Initializes the Wii/GameCube network interface
***************************************************************************/
void InitializeNetwork(bool silent)
{
// stop if we're already initialized, or if auto-init has failed before
// in which case, manual initialization is required
2009-10-06 06:38:32 +00:00
if(networkInit || (silent && !autoNetworkInit))
2008-12-24 07:58:23 +00:00
return;
2009-10-06 06:38:32 +00:00
int retry = 1;
char ip[16];
s32 initResult;
2008-12-24 07:58:23 +00:00
if(!silent)
ShowAction ("Initializing network...");
2009-03-31 07:13:20 +00:00
while(inNetworkInit) // a network init is already in progress!
usleep(50);
if(!networkInit) // check again if the network was inited
2008-12-24 07:58:23 +00:00
{
inNetworkInit = true;
2008-12-24 07:58:23 +00:00
2009-10-06 06:38:32 +00:00
while(retry)
{
if(!silent)
2009-10-06 06:38:32 +00:00
ShowAction ("Initializing network...");
initResult = if_config(ip, NULL, NULL, true);
if(initResult == 0)
networkInit = true;
if(networkInit || silent)
break;
2010-03-17 23:20:00 +00:00
retry = ErrorPromptRetry("Unable to initialize network!");
2008-12-24 07:58:23 +00:00
}
2009-10-06 06:38:32 +00:00
// do not automatically attempt a reconnection
autoNetworkInit = false;
inNetworkInit = false;
2008-12-24 07:58:23 +00:00
}
if(!silent)
CancelAction();
2008-12-24 07:58:23 +00:00
}
void CloseShare()
{
if(networkShareInit)
2009-03-28 17:23:08 +00:00
smbClose("smb");
2008-12-24 07:58:23 +00:00
networkShareInit = false;
2010-03-15 07:43:20 +00:00
isMounted[DEVICE_SMB] = false;
2008-12-24 07:58:23 +00:00
}
/****************************************************************************
* Mount SMB Share
****************************************************************************/
bool
ConnectShare (bool silent)
{
// Crashes or stalls system in GameCube mode - so disable
#ifndef HW_RVL
return false;
#endif
2009-10-06 06:38:32 +00:00
int retry = 1;
2008-12-24 07:58:23 +00:00
int chkS = (strlen(GCSettings.smbshare) > 0) ? 0:1;
int chkI = (strlen(GCSettings.smbip) > 0) ? 0:1;
// check that all parameters have been set
2009-10-04 19:28:23 +00:00
if(chkS + chkI > 0)
2008-12-24 07:58:23 +00:00
{
if(!silent)
{
char msg[50];
char msg2[100];
2009-10-04 19:28:23 +00:00
if(chkS + chkI > 1) // more than one thing is wrong
2008-12-24 07:58:23 +00:00
sprintf(msg, "Check settings.xml.");
else if(chkS)
sprintf(msg, "Share name is blank.");
else if(chkI)
sprintf(msg, "Share IP is blank.");
sprintf(msg2, "Invalid network settings - %s", msg);
2009-03-28 17:23:08 +00:00
ErrorPrompt(msg2);
2008-12-24 07:58:23 +00:00
}
return false;
}
if(!networkInit)
InitializeNetwork(silent);
2009-10-06 06:38:32 +00:00
if(!networkInit)
return false;
2008-12-24 07:58:23 +00:00
2009-10-06 06:38:32 +00:00
while(retry)
{
if(!silent)
ShowAction ("Connecting to network share...");
if(smbInit(GCSettings.smbuser, GCSettings.smbpwd, GCSettings.smbshare, GCSettings.smbip))
networkShareInit = true;
2009-10-06 06:38:32 +00:00
if(networkShareInit || silent)
break;
2008-12-24 07:58:23 +00:00
2009-10-06 06:38:32 +00:00
retry = ErrorPromptRetry("Failed to connect to network share.");
2008-12-24 07:58:23 +00:00
}
2009-10-06 06:38:32 +00:00
if(!silent)
CancelAction();
2008-12-24 07:58:23 +00:00
return networkShareInit;
}
2009-03-31 07:13:20 +00:00
#endif