mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-05-28 00:02:28 +00:00
Add /statusz page to redbean plus other enhancements
redbean improvements: - Explicitly disable corking - Simulate Python regex API for Lua - Send warmup requests in main process on startup - Add Class-A granular IPv4 network classification - Add /statusz page so you can monitor your redbean's health - Fix regressions on OpenBSD/NetBSD caused by recent changes - Plug Authorization header into Lua GetUser and GetPass APIs - Recognize X-Forwarded-{For,Host} from local reverse proxies - Add many additional functions to redbean Lua server page API - Report resource usage of child processes on `/` listing page - Introduce `-a` flag for logging child process resource usage - Introduce `-t MILLIS` flag and `ProgramTimeout(ms)` init API - Introduce `-H "Header: value"` flag and `ProgramHeader(k,v)` API Cosmopolitan Libc improvements: - Make strerror() simpler - Make inet_pton() not depend on sscanf() - Fix OpenExecutable() which broke .data section earlier - Fix stdio in cases where it overflows kernel tty buffer - Fix bugs in crash reporting w/o .com.dbg binary present - Add polyfills for SO_LINGER, SO_RCVTIMEO, and SO_SNDTIMEO - Polyfill TCP_CORK on BSD and XNU using TCP_NOPUSH magnums New netcat clone in examples/nc.c: While testing some of the failure conditions for redbean, I noticed that BusyBox's `nc` command is pretty busted, if you use it as an interactive tool, rather than having it be part of a pipeline. Unfortunately this'll only work on UNIX since Windows doesn't let us poll on stdio and sockets at the same time because I don't think they want tools like this running on their platform. So if you want forbidden fruit, it's here so enjoy it
This commit is contained in:
parent
4effa23528
commit
b107d2709f
163 changed files with 4425 additions and 2104 deletions
|
@ -89,8 +89,41 @@ TEST(ParseIp, test) {
|
|||
EXPECT_EQ(-1, ParseIp("hello..example", -1));
|
||||
}
|
||||
|
||||
TEST(ParseForwarded, test) {
|
||||
uint32_t ip = 7;
|
||||
uint16_t port = 7;
|
||||
EXPECT_EQ(-1, ParseForwarded("", -1, &ip, &port));
|
||||
EXPECT_EQ(-1, ParseForwarded("0.0.0.0", -1, &ip, &port));
|
||||
EXPECT_EQ(-1, ParseForwarded("8.8.8.8", -1, &ip, &port));
|
||||
EXPECT_EQ(-1, ParseForwarded("[::1]:123", -1, &ip, &port));
|
||||
EXPECT_EQ(7, ip);
|
||||
EXPECT_EQ(7, port);
|
||||
EXPECT_EQ(0, ParseForwarded("0.0.0.1:123", -1, &ip, &port));
|
||||
EXPECT_EQ(0x00000001, ip);
|
||||
EXPECT_EQ(123, port);
|
||||
EXPECT_EQ(0, ParseForwarded("1.2.3.4:123", -1, &ip, &port));
|
||||
EXPECT_EQ(0x01020304, ip);
|
||||
EXPECT_EQ(123, port);
|
||||
EXPECT_EQ(0, ParseForwarded("128.2.3.4:123", -1, &ip, &port));
|
||||
EXPECT_EQ(0x80020304, ip);
|
||||
EXPECT_EQ(123, port);
|
||||
EXPECT_EQ(0, ParseForwarded("255.255.255.255:123", -1, &ip, &port));
|
||||
EXPECT_EQ(0xFFFFFFFF, ip);
|
||||
EXPECT_EQ(123, port);
|
||||
EXPECT_EQ(0, ParseForwarded("203.0.113.0:123", -1, &ip, &port));
|
||||
EXPECT_EQ(0xcb007100, ip);
|
||||
EXPECT_EQ(123, port);
|
||||
EXPECT_EQ(0, ParseForwarded("203.0.113.42:31337", -1, &ip, &port));
|
||||
EXPECT_EQ(-1, ParseForwarded("...:123", -1, &ip, &port));
|
||||
EXPECT_EQ(-1, ParseForwarded("203.0.113.0:123123123", -1, &ip, &port));
|
||||
}
|
||||
|
||||
BENCH(IsAcceptableHost, bench) {
|
||||
uint32_t ip;
|
||||
uint16_t port;
|
||||
EZBENCH2("IsAcceptableHost 127.0.0.1", donothing,
|
||||
IsAcceptableHost("127.0.0.1", 9));
|
||||
EZBENCH2("IsAcceptablePort 80", donothing, IsAcceptablePort("80", 2));
|
||||
EZBENCH2("ParseForwarded 80", donothing,
|
||||
ParseForwarded("203.0.113.42:31337", 20, &ip, &port));
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue