Added error handling for web TLVs. webPageCreate and webConfigSet* now return Result. Moved webWifiCreate/webWifiShow immediately after _webShow in web.c.

This commit is contained in:
yellows8 2019-02-26 17:55:16 -05:00
parent 904deeec10
commit 9e11dd1bd7
2 changed files with 66 additions and 60 deletions

View File

@ -135,7 +135,7 @@ Result webWifiShow(WebWifiConfig* config, WebWifiReturnValue *out);
* @param config WebCommonConfig object. * @param config WebCommonConfig object.
* @param url Initial URL navigated to by the applet. * @param url Initial URL navigated to by the applet.
*/ */
void webPageCreate(WebCommonConfig* config, const char* url); Result webPageCreate(WebCommonConfig* config, const char* url);
/** /**
* @brief Sets the CallbackUrl. * @brief Sets the CallbackUrl.
@ -143,7 +143,7 @@ void webPageCreate(WebCommonConfig* config, const char* url);
* @param config WebCommonConfig object. * @param config WebCommonConfig object.
* @param url URL * @param url URL
*/ */
void webConfigSetCallbackUrl(WebCommonConfig* config, const char* url); Result webConfigSetCallbackUrl(WebCommonConfig* config, const char* url);
/** /**
* @brief Sets the CallbackableUrl. * @brief Sets the CallbackableUrl.
@ -151,7 +151,7 @@ void webConfigSetCallbackUrl(WebCommonConfig* config, const char* url);
* @param config WebCommonConfig object. * @param config WebCommonConfig object.
* @param url URL * @param url URL
*/ */
void webConfigSetCallbackableUrl(WebCommonConfig* config, const char* url); Result webConfigSetCallbackableUrl(WebCommonConfig* config, const char* url);
/** /**
* @brief Sets the whitelist. * @brief Sets the whitelist.
@ -160,14 +160,14 @@ void webConfigSetCallbackableUrl(WebCommonConfig* config, const char* url);
* @param config WebCommonConfig object. * @param config WebCommonConfig object.
* @param whitelist Whitelist string, each line is a regex for each whitelisted URL. * @param whitelist Whitelist string, each line is a regex for each whitelisted URL.
*/ */
void webConfigSetWhitelist(WebCommonConfig* config, const char* whitelist); Result webConfigSetWhitelist(WebCommonConfig* config, const char* whitelist);
/** /**
* @brief Sets the DisplayUrlKind. * @brief Sets the DisplayUrlKind.
* @param config WebCommonConfig object. * @param config WebCommonConfig object.
* @param kind Kind * @param kind Kind
*/ */
void webConfigSetDisplayUrlKind(WebCommonConfig* config, bool kind); Result webConfigSetDisplayUrlKind(WebCommonConfig* config, bool kind);
/** /**
* @brief Sets the UserAgentAdditionalString. * @brief Sets the UserAgentAdditionalString.
@ -175,7 +175,7 @@ void webConfigSetDisplayUrlKind(WebCommonConfig* config, bool kind);
* @param config WebCommonConfig object. * @param config WebCommonConfig object.
* @param str String * @param str String
*/ */
void webConfigSetUserAgentAdditionalString(WebCommonConfig* config, const char* str); Result webConfigSetUserAgentAdditionalString(WebCommonConfig* config, const char* str);
/** /**
* @brief Launches the {web applet} with the specified config and waits for it to exit. * @brief Launches the {web applet} with the specified config and waits for it to exit.

View File

@ -56,6 +56,22 @@ static Result _webShow(AppletId id, u32 version, void* arg, size_t arg_size, voi
return rc; return rc;
} }
void webWifiCreate(WebWifiConfig* config, const char* conntest_url, const char* initial_url, u128 userID, u32 unk) {
memset(config, 0, sizeof(*config));
if (conntest_url==NULL) conntest_url = initial_url;
strncpy(config->arg.conntest_url, conntest_url, sizeof(config->arg.conntest_url)-1);
strncpy(config->arg.initial_url, initial_url, sizeof(config->arg.initial_url)-1);
config->arg.userID = userID;
config->arg.unk_x514 = unk;
}
Result webWifiShow(WebWifiConfig* config, WebWifiReturnValue *out) {
return _webShow(AppletId_wifiWebAuth, 0, &config->arg, sizeof(config->arg), out, sizeof(*out));
}
static void _webArgInitialize(WebCommonConfig* config, AppletId appletid, WebShimKind shimKind) { static void _webArgInitialize(WebCommonConfig* config, AppletId appletid, WebShimKind shimKind) {
memset(config, 0, sizeof(*config)); memset(config, 0, sizeof(*config));
@ -77,7 +93,8 @@ WebShimKind _webGetShimKind(WebCommonConfig* config) {
return hdr->shimKind; return hdr->shimKind;
} }
static void _webTLVWrite(WebCommonTLVStorage *storage, u16 type, const void* argdata, u16 argdata_size, u16 argdata_size_total) { static Result _webTLVWrite(WebCommonTLVStorage *storage, u16 type, const void* argdata, u16 argdata_size, u16 argdata_size_total) {
Result rc = MAKERESULT(Module_Libnx, LibnxError_BadInput);
size_t i, count, offset; size_t i, count, offset;
u8 *dataptr = storage->data; u8 *dataptr = storage->data;
WebArgHeader *hdr = (WebArgHeader*)dataptr; WebArgHeader *hdr = (WebArgHeader*)dataptr;
@ -85,32 +102,32 @@ static void _webTLVWrite(WebCommonTLVStorage *storage, u16 type, const void* arg
size_t size = sizeof(storage->data); size_t size = sizeof(storage->data);
offset = sizeof(WebArgHeader); offset = sizeof(WebArgHeader);
if (size < offset) return; if (size < offset) return rc;
if (argdata_size > argdata_size_total) argdata_size = argdata_size_total; if (argdata_size > argdata_size_total) argdata_size = argdata_size_total;
count = hdr->total_entries; count = hdr->total_entries;
tlv = (WebArgTLV*)&dataptr[offset]; tlv = (WebArgTLV*)&dataptr[offset];
for (i=0; i<count; i++) { for (i=0; i<count; i++) {
if (size < offset + sizeof(WebArgTLV)) return; if (size < offset + sizeof(WebArgTLV)) return rc;
tlv = (WebArgTLV*)&dataptr[offset]; tlv = (WebArgTLV*)&dataptr[offset];
if (tlv->type == type) { if (tlv->type == type) {
if (tlv->size != argdata_size_total) return; if (tlv->size != argdata_size_total) return rc;
break; break;
} }
offset+= sizeof(WebArgTLV) + tlv->size; offset+= sizeof(WebArgTLV) + tlv->size;
if (size < offset) return; if (size < offset) return rc;
} }
if (size < offset + sizeof(WebArgTLV) + argdata_size_total) return; if (size < offset + sizeof(WebArgTLV) + argdata_size_total) return rc;
tlv = (WebArgTLV*)&dataptr[offset]; tlv = (WebArgTLV*)&dataptr[offset];
if (tlv->type != type) { if (tlv->type != type) {
if (hdr->total_entries == 0xFFFF) return; if (hdr->total_entries == 0xFFFF) return rc;
tlv->type = type; tlv->type = type;
tlv->size = argdata_size_total; tlv->size = argdata_size_total;
@ -120,84 +137,73 @@ static void _webTLVWrite(WebCommonTLVStorage *storage, u16 type, const void* arg
offset+= sizeof(WebArgTLV); offset+= sizeof(WebArgTLV);
memcpy(&dataptr[offset], argdata, argdata_size); memcpy(&dataptr[offset], argdata, argdata_size);
if (argdata_size_total != argdata_size) memset(&dataptr[offset+argdata_size], 0, argdata_size_total-argdata_size); if (argdata_size_total != argdata_size) memset(&dataptr[offset+argdata_size], 0, argdata_size_total-argdata_size);
return 0;
} }
static void _webTLVSet(WebCommonTLVStorage *storage, u16 type, const void* argdata, u16 argdata_size) { static Result _webTLVSet(WebCommonTLVStorage *storage, u16 type, const void* argdata, u16 argdata_size) {
_webTLVWrite(storage, type, argdata, argdata_size, argdata_size); return _webTLVWrite(storage, type, argdata, argdata_size, argdata_size);
} }
static void _webConfigSetU8(WebCommonConfig* config, u16 type, u8 arg) { static Result _webConfigSetU8(WebCommonConfig* config, u16 type, u8 arg) {
_webTLVSet(&config->arg, type, &arg, sizeof(arg)); return _webTLVSet(&config->arg, type, &arg, sizeof(arg));
} }
static void _webConfigSetFlag(WebCommonConfig* config, u16 type, bool arg) { static Result _webConfigSetFlag(WebCommonConfig* config, u16 type, bool arg) {
_webConfigSetU8(config, type, arg!=0); return _webConfigSetU8(config, type, arg!=0);
} }
/*static void _webConfigSetU32(WebCommonConfig* config, u16 type, u32 arg) { /*static Result _webConfigSetU32(WebCommonConfig* config, u16 type, u32 arg) {
_webTLVSet(&config->arg, type, &arg, sizeof(arg)); return _webTLVSet(&config->arg, type, &arg, sizeof(arg));
}*/ }*/
static void _webConfigSetString(WebCommonConfig* config, u16 type, const char* str, u16 argdata_size_total) { static Result _webConfigSetString(WebCommonConfig* config, u16 type, const char* str, u16 argdata_size_total) {
u16 arglen = strlen(str); u16 arglen = strlen(str);
if (arglen >= argdata_size_total) arglen = argdata_size_total-1; //The string must be NUL-terminated. if (arglen >= argdata_size_total) arglen = argdata_size_total-1; //The string must be NUL-terminated.
_webTLVWrite(&config->arg, type, str, arglen, argdata_size_total); return _webTLVWrite(&config->arg, type, str, arglen, argdata_size_total);
} }
static void _webConfigSetUrl(WebCommonConfig* config, const char* url) { static Result _webConfigSetUrl(WebCommonConfig* config, const char* url) {
_webConfigSetString(config, WebArgType_Url, url, 0xc00); return _webConfigSetString(config, WebArgType_Url, url, 0xc00);
} }
void webWifiCreate(WebWifiConfig* config, const char* conntest_url, const char* initial_url, u128 userID, u32 unk) { Result webPageCreate(WebCommonConfig* config, const char* url) {
memset(config, 0, sizeof(*config)); Result rc=0;
if (conntest_url==NULL) conntest_url = initial_url;
strncpy(config->arg.conntest_url, conntest_url, sizeof(config->arg.conntest_url)-1);
strncpy(config->arg.initial_url, initial_url, sizeof(config->arg.initial_url)-1);
config->arg.userID = userID;
config->arg.unk_x514 = unk;
}
Result webWifiShow(WebWifiConfig* config, WebWifiReturnValue *out) {
return _webShow(AppletId_wifiWebAuth, 0, &config->arg, sizeof(config->arg), out, sizeof(*out));
}
void webPageCreate(WebCommonConfig* config, const char* url) {
_webArgInitialize(config, AppletId_web, WebShimKind_Web); _webArgInitialize(config, AppletId_web, WebShimKind_Web);
_webConfigSetU8(config, WebArgType_UnknownD, 1); rc = _webConfigSetU8(config, WebArgType_UnknownD, 1);
if (config->version < 0x30000) _webConfigSetU8(config, WebArgType_Unknown12, 1); // Removed from user-process init with [3.0.0+]. if (R_SUCCEEDED(rc) && config->version < 0x30000) rc = _webConfigSetU8(config, WebArgType_Unknown12, 1); // Removed from user-process init with [3.0.0+].
_webConfigSetUrl(config, url); if (R_SUCCEEDED(rc)) rc = _webConfigSetUrl(config, url);
return rc;
} }
void webConfigSetCallbackUrl(WebCommonConfig* config, const char* url) { Result webConfigSetCallbackUrl(WebCommonConfig* config, const char* url) {
WebShimKind shim = _webGetShimKind(config); WebShimKind shim = _webGetShimKind(config);
if (shim != WebShimKind_Web && shim != WebShimKind_Share) return; if (shim != WebShimKind_Web && shim != WebShimKind_Share) return MAKERESULT(Module_Libnx, LibnxError_NotInitialized);
_webConfigSetString(config, WebArgType_CallbackUrl, url, 0x400); return _webConfigSetString(config, WebArgType_CallbackUrl, url, 0x400);
} }
void webConfigSetCallbackableUrl(WebCommonConfig* config, const char* url) { Result webConfigSetCallbackableUrl(WebCommonConfig* config, const char* url) {
if (_webGetShimKind(config) != WebShimKind_Web) return; if (_webGetShimKind(config) != WebShimKind_Web) return MAKERESULT(Module_Libnx, LibnxError_NotInitialized);
_webConfigSetString(config, WebArgType_CallbackableUrl, url, 0x400); return _webConfigSetString(config, WebArgType_CallbackableUrl, url, 0x400);
} }
void webConfigSetWhitelist(WebCommonConfig* config, const char* whitelist) { Result webConfigSetWhitelist(WebCommonConfig* config, const char* whitelist) {
if (_webGetShimKind(config) != WebShimKind_Web) return; if (_webGetShimKind(config) != WebShimKind_Web) return MAKERESULT(Module_Libnx, LibnxError_NotInitialized);
_webConfigSetString(config, WebArgType_Whitelist, whitelist, 0x1000); return _webConfigSetString(config, WebArgType_Whitelist, whitelist, 0x1000);
} }
void webConfigSetDisplayUrlKind(WebCommonConfig* config, bool kind) { Result webConfigSetDisplayUrlKind(WebCommonConfig* config, bool kind) {
_webConfigSetFlag(config, WebArgType_DisplayUrlKind, kind); return _webConfigSetFlag(config, WebArgType_DisplayUrlKind, kind);
} }
void webConfigSetUserAgentAdditionalString(WebCommonConfig* config, const char* str) { Result webConfigSetUserAgentAdditionalString(WebCommonConfig* config, const char* str) {
if (_webGetShimKind(config) != WebShimKind_Web) return; if (_webGetShimKind(config) != WebShimKind_Web) return MAKERESULT(Module_Libnx, LibnxError_NotInitialized);
if (hosversionBefore(4,0,0)) return; if (hosversionBefore(4,0,0)) return MAKERESULT(Module_Libnx, LibnxError_IncompatSysVer);
_webConfigSetString(config, WebArgType_UserAgentAdditionalString, str, 0x80); return _webConfigSetString(config, WebArgType_UserAgentAdditionalString, str, 0x80);
} }
Result webConfigShow(WebCommonConfig* config, WebCommonReturnValue *out) { Result webConfigShow(WebCommonConfig* config, WebCommonReturnValue *out) {