mirror of
https://github.com/lightpanda-io/browser.git
synced 2025-10-29 15:13:28 +00:00
Add cli options for server (host, port, timeout)
Signed-off-by: Francis Bouvier <francis@lightpanda.io>
This commit is contained in:
100
src/main.zig
100
src/main.zig
@@ -30,9 +30,21 @@ const apiweb = @import("apiweb.zig");
|
|||||||
pub const Types = jsruntime.reflect(apiweb.Interfaces);
|
pub const Types = jsruntime.reflect(apiweb.Interfaces);
|
||||||
pub const UserContext = apiweb.UserContext;
|
pub const UserContext = apiweb.UserContext;
|
||||||
|
|
||||||
// TODO: move to cli options
|
// Default options
|
||||||
const host = "127.0.0.1";
|
const Host = "127.0.0.1";
|
||||||
const port = 3245;
|
const Port = 3245;
|
||||||
|
const Timeout = 3; // in seconds
|
||||||
|
|
||||||
|
const usage =
|
||||||
|
\\usage: {s} [options]
|
||||||
|
\\ start Lightpanda browser in CDP server mode
|
||||||
|
\\
|
||||||
|
\\ -h, --help Print this help message and exit.
|
||||||
|
\\ --host Host of the server (default "127.0.0.1")
|
||||||
|
\\ --port Port of the server (default "3245")
|
||||||
|
\\ --timeout Timeout for incoming connections in seconds (default "3")
|
||||||
|
\\
|
||||||
|
;
|
||||||
|
|
||||||
// Inspired by std.net.StreamServer in Zig < 0.12
|
// Inspired by std.net.StreamServer in Zig < 0.12
|
||||||
pub const StreamServer = struct {
|
pub const StreamServer = struct {
|
||||||
@@ -130,18 +142,74 @@ pub const StreamServer = struct {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
fn printUsageExit(execname: []const u8, res: u8) void {
|
||||||
|
std.io.getStdErr().writer().print(usage, .{execname}) catch |err| {
|
||||||
|
std.log.err("Print usage error: {any}", .{err});
|
||||||
|
std.posix.exit(1);
|
||||||
|
};
|
||||||
|
std.posix.exit(res);
|
||||||
|
}
|
||||||
|
|
||||||
pub fn main() !void {
|
pub fn main() !void {
|
||||||
|
|
||||||
// create v8 vm
|
// allocator
|
||||||
const vm = jsruntime.VM.init();
|
|
||||||
defer vm.deinit();
|
|
||||||
|
|
||||||
// alloc
|
|
||||||
var arena = std.heap.ArenaAllocator.init(std.heap.page_allocator);
|
var arena = std.heap.ArenaAllocator.init(std.heap.page_allocator);
|
||||||
defer arena.deinit();
|
defer arena.deinit();
|
||||||
|
|
||||||
|
// args
|
||||||
|
var args = try std.process.argsWithAllocator(arena.allocator());
|
||||||
|
defer args.deinit();
|
||||||
|
|
||||||
|
const execname = args.next().?;
|
||||||
|
var host: []const u8 = Host;
|
||||||
|
var port: u16 = Port;
|
||||||
|
var addr: std.net.Address = undefined;
|
||||||
|
var timeout: u8 = undefined;
|
||||||
|
|
||||||
|
while (args.next()) |opt| {
|
||||||
|
if (std.mem.eql(u8, "-h", opt) or std.mem.eql(u8, "--help", opt)) {
|
||||||
|
printUsageExit(execname, 0);
|
||||||
|
}
|
||||||
|
if (std.mem.eql(u8, "--host", opt)) {
|
||||||
|
if (args.next()) |arg| {
|
||||||
|
host = arg;
|
||||||
|
continue;
|
||||||
|
} else {
|
||||||
|
std.log.err("--host not provided\n", .{});
|
||||||
|
return printUsageExit(execname, 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (std.mem.eql(u8, "--port", opt)) {
|
||||||
|
if (args.next()) |arg| {
|
||||||
|
port = std.fmt.parseInt(u16, arg, 10) catch |err| {
|
||||||
|
std.log.err("--port {any}\n", .{err});
|
||||||
|
return printUsageExit(execname, 1);
|
||||||
|
};
|
||||||
|
continue;
|
||||||
|
} else {
|
||||||
|
std.log.err("--port not provided\n", .{});
|
||||||
|
return printUsageExit(execname, 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (std.mem.eql(u8, "--timeout", opt)) {
|
||||||
|
if (args.next()) |arg| {
|
||||||
|
timeout = std.fmt.parseInt(u8, arg, 10) catch |err| {
|
||||||
|
std.log.err("--timeout {any}\n", .{err});
|
||||||
|
return printUsageExit(execname, 1);
|
||||||
|
};
|
||||||
|
continue;
|
||||||
|
} else {
|
||||||
|
std.log.err("--timeout not provided\n", .{});
|
||||||
|
return printUsageExit(execname, 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
addr = std.net.Address.parseIp4(host, port) catch |err| {
|
||||||
|
std.log.err("address (host:port) {any}\n", .{err});
|
||||||
|
return printUsageExit(execname, 1);
|
||||||
|
};
|
||||||
|
|
||||||
// server
|
// server
|
||||||
const addr = try std.net.Address.parseIp4(host, port);
|
|
||||||
var srv = StreamServer.init(.{
|
var srv = StreamServer.init(.{
|
||||||
.reuse_address = true,
|
.reuse_address = true,
|
||||||
.reuse_port = true,
|
.reuse_port = true,
|
||||||
@@ -149,15 +217,25 @@ pub fn main() !void {
|
|||||||
});
|
});
|
||||||
defer srv.deinit();
|
defer srv.deinit();
|
||||||
|
|
||||||
try srv.listen(addr);
|
srv.listen(addr) catch |err| {
|
||||||
|
std.log.err("address (host:port) {any}\n", .{err});
|
||||||
|
return printUsageExit(execname, 1);
|
||||||
|
};
|
||||||
defer srv.close();
|
defer srv.close();
|
||||||
std.log.info("Listening on: {s}:{d}...", .{ host, port });
|
std.log.info("Listening on: {s}:{d}...", .{ host, port });
|
||||||
|
|
||||||
|
// create v8 vm
|
||||||
|
const vm = jsruntime.VM.init();
|
||||||
|
defer vm.deinit();
|
||||||
|
|
||||||
|
// loop
|
||||||
var loop = try jsruntime.Loop.init(arena.allocator());
|
var loop = try jsruntime.Loop.init(arena.allocator());
|
||||||
defer loop.deinit();
|
defer loop.deinit();
|
||||||
|
|
||||||
|
// browser
|
||||||
var browser = try Browser.init(arena.allocator(), &loop);
|
var browser = try Browser.init(arena.allocator(), &loop);
|
||||||
defer browser.deinit();
|
defer browser.deinit();
|
||||||
|
|
||||||
try server.listen(&browser, &loop, srv.sockfd.?);
|
// listen
|
||||||
|
try server.listen(&browser, &loop, srv.sockfd.?, std.time.ns_per_s * @as(u64, timeout));
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -35,7 +35,6 @@ const IOError = AcceptError || RecvError || SendError || CloseError || TimeoutEr
|
|||||||
const Error = IOError || std.fmt.ParseIntError || cdp.Error || NoError;
|
const Error = IOError || std.fmt.ParseIntError || cdp.Error || NoError;
|
||||||
|
|
||||||
const TimeoutCheck = std.time.ns_per_ms * 100;
|
const TimeoutCheck = std.time.ns_per_ms * 100;
|
||||||
const TimeoutRead = std.time.ns_per_s * 3; // TODO: cli option
|
|
||||||
|
|
||||||
// I/O Main
|
// I/O Main
|
||||||
// --------
|
// --------
|
||||||
@@ -56,6 +55,7 @@ pub const Ctx = struct {
|
|||||||
// I/O fields
|
// I/O fields
|
||||||
conn_completion: *Completion,
|
conn_completion: *Completion,
|
||||||
timeout_completion: *Completion,
|
timeout_completion: *Completion,
|
||||||
|
timeout: u64,
|
||||||
last_active: ?std.time.Instant = null,
|
last_active: ?std.time.Instant = null,
|
||||||
|
|
||||||
// CDP
|
// CDP
|
||||||
@@ -146,7 +146,7 @@ pub const Ctx = struct {
|
|||||||
return;
|
return;
|
||||||
};
|
};
|
||||||
|
|
||||||
if (now.since(self.last_active.?) > TimeoutRead) {
|
if (now.since(self.last_active.?) > self.timeout) {
|
||||||
// closing
|
// closing
|
||||||
std.log.debug("conn timeout, closing...", .{});
|
std.log.debug("conn timeout, closing...", .{});
|
||||||
|
|
||||||
@@ -334,7 +334,12 @@ pub fn sendSync(ctx: *Ctx, msg: []const u8) !void {
|
|||||||
// Listen
|
// Listen
|
||||||
// ------
|
// ------
|
||||||
|
|
||||||
pub fn listen(browser: *Browser, loop: *public.Loop, server_socket: std.posix.socket_t) anyerror!void {
|
pub fn listen(
|
||||||
|
browser: *Browser,
|
||||||
|
loop: *public.Loop,
|
||||||
|
server_socket: std.posix.socket_t,
|
||||||
|
timeout: u64,
|
||||||
|
) anyerror!void {
|
||||||
|
|
||||||
// create buffers
|
// create buffers
|
||||||
var read_buf: [BufReadSize]u8 = undefined;
|
var read_buf: [BufReadSize]u8 = undefined;
|
||||||
@@ -354,6 +359,7 @@ pub fn listen(browser: *Browser, loop: *public.Loop, server_socket: std.posix.so
|
|||||||
.read_buf = &read_buf,
|
.read_buf = &read_buf,
|
||||||
.msg_buf = &msg_buf,
|
.msg_buf = &msg_buf,
|
||||||
.accept_socket = server_socket,
|
.accept_socket = server_socket,
|
||||||
|
.timeout = timeout,
|
||||||
.conn_completion = &conn_completion,
|
.conn_completion = &conn_completion,
|
||||||
.timeout_completion = &timeout_completion,
|
.timeout_completion = &timeout_completion,
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user