mirror of
https://github.com/Ylianst/MeshAgent
synced 2025-12-06 00:13:33 +00:00
1. Fixed bug with Authenticode URI parsing
2. Fixed bug with Http Uri parsing
This commit is contained in:
@@ -3913,7 +3913,7 @@ duk_ret_t ILibDuktape_httpStream_parseUri(duk_context *ctx)
|
||||
|
||||
char *path, *addr;
|
||||
unsigned short port;
|
||||
int protocolIndex;
|
||||
int protocolIndex, i;
|
||||
|
||||
char *username = NULL;
|
||||
char *password = NULL;
|
||||
@@ -3980,6 +3980,16 @@ duk_ret_t ILibDuktape_httpStream_parseUri(duk_context *ctx)
|
||||
duk_push_null(ctx);
|
||||
}
|
||||
password = NULL;
|
||||
// [options]
|
||||
uri = Duktape_GetStringPropertyValueEx(ctx, -1, "host", NULL, &uriLen);
|
||||
if ((i = ILibString_IndexOf(uri, uriLen, "?", 1)) >= 0)
|
||||
{
|
||||
duk_push_sprintf(ctx, "/%s", uri + i); // [options][newpath]
|
||||
duk_put_prop_string(ctx, -2, "path"); // [options]
|
||||
duk_push_lstring(ctx, uri, i); // [options][newhost]
|
||||
duk_put_prop_string(ctx, -2, "host"); // [options]
|
||||
}
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
File diff suppressed because one or more lines are too long
@@ -114,7 +114,17 @@ function locked(uri)
|
||||
function checkMSH()
|
||||
{
|
||||
var value = module.exports(process.execPath);
|
||||
if (value != null) { value = module.exports.locked(value.url); }
|
||||
if (value != null)
|
||||
{
|
||||
if (value.url != null)
|
||||
{
|
||||
value = module.exports.locked(value.url);
|
||||
}
|
||||
else
|
||||
{
|
||||
value = null;
|
||||
}
|
||||
}
|
||||
if(value!=null)
|
||||
{
|
||||
var msh = _MSH();
|
||||
@@ -125,9 +135,13 @@ function checkMSH()
|
||||
var res1 = require('http').parseUri(msh.MeshServer);
|
||||
if(res1!=null)
|
||||
{
|
||||
if(res1.host.toLowerCase() != value.dns.toLowerCase() || msh.ServerID.toLowerCase() != value.id.toLowerCase())
|
||||
if(res1.host.toLowerCase() != value.dns.toLowerCase())
|
||||
{
|
||||
throw ('Server Configuration MISMATCH');
|
||||
throw ('DNS MISMATCH in Configuration, LOCKED to: ' + value.dns);
|
||||
}
|
||||
if(msh.ServerID.toLowerCase() != value.id.toLowerCase())
|
||||
{
|
||||
throw ('ServerID MISMATCH in Configuration, LOCKED to: ' + value.id);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user