mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-08-09 19:30:29 +00:00
Update fetch in redbean to initialize SSL when used with https
This commit is contained in:
parent
abac6f729c
commit
5a99c8e11c
1 changed files with 10 additions and 6 deletions
|
@ -347,6 +347,7 @@ static bool invalidated;
|
||||||
static bool logmessages;
|
static bool logmessages;
|
||||||
static bool isinitialized;
|
static bool isinitialized;
|
||||||
static bool checkedmethod;
|
static bool checkedmethod;
|
||||||
|
static bool sslinitialized;
|
||||||
static bool sslfetchverify;
|
static bool sslfetchverify;
|
||||||
static bool sslclientverify;
|
static bool sslclientverify;
|
||||||
static bool connectionclose;
|
static bool connectionclose;
|
||||||
|
@ -448,6 +449,8 @@ static char *HandleAsset(struct Asset *, const char *, size_t);
|
||||||
static char *ServeAsset(struct Asset *, const char *, size_t);
|
static char *ServeAsset(struct Asset *, const char *, size_t);
|
||||||
static char *SetStatus(unsigned, const char *);
|
static char *SetStatus(unsigned, const char *);
|
||||||
|
|
||||||
|
static void TlsInit(void);
|
||||||
|
|
||||||
static void OnChld(void) {
|
static void OnChld(void) {
|
||||||
zombied = true;
|
zombied = true;
|
||||||
}
|
}
|
||||||
|
@ -3565,12 +3568,6 @@ static int LuaFetch(lua_State *L) {
|
||||||
.ai_protocol = IPPROTO_TCP,
|
.ai_protocol = IPPROTO_TCP,
|
||||||
.ai_flags = AI_NUMERICSERV};
|
.ai_flags = AI_NUMERICSERV};
|
||||||
|
|
||||||
if (!isinitialized) {
|
|
||||||
luaL_error(L, "Fetch() can't be called from .init.lua global scope;"
|
|
||||||
" try calling it from your OnServerStart() hook");
|
|
||||||
unreachable;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Get args: url [, body | {method = "PUT", body = "..."}]
|
* Get args: url [, body | {method = "PUT", body = "..."}]
|
||||||
*/
|
*/
|
||||||
|
@ -3622,6 +3619,9 @@ static int LuaFetch(lua_State *L) {
|
||||||
unreachable;
|
unreachable;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (usessl && !sslinitialized) TlsInit();
|
||||||
|
|
||||||
if (url.host.n) {
|
if (url.host.n) {
|
||||||
host = gc(strndup(url.host.p, url.host.n));
|
host = gc(strndup(url.host.p, url.host.n));
|
||||||
if (url.port.n) {
|
if (url.port.n) {
|
||||||
|
@ -6973,6 +6973,10 @@ static void SigInit(void) {
|
||||||
static void TlsInit(void) {
|
static void TlsInit(void) {
|
||||||
#ifndef UNSECURE
|
#ifndef UNSECURE
|
||||||
int suite;
|
int suite;
|
||||||
|
|
||||||
|
if (sslinitialized) return;
|
||||||
|
sslinitialized = true;
|
||||||
|
|
||||||
InitializeRng(&rng);
|
InitializeRng(&rng);
|
||||||
InitializeRng(&rngcli);
|
InitializeRng(&rngcli);
|
||||||
cachain = GetSslRoots();
|
cachain = GetSslRoots();
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue