mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
net.websocket: allow timeout to be configured (#14941)
This commit is contained in:
parent
5523c11dd4
commit
a50e0f0522
@ -1,7 +1,6 @@
|
||||
module websocket
|
||||
|
||||
import net
|
||||
import time
|
||||
|
||||
// socket_read reads from socket into the provided buffer
|
||||
fn (mut ws Client) socket_read(mut buffer []u8) ?int {
|
||||
@ -13,17 +12,10 @@ fn (mut ws Client) socket_read(mut buffer []u8) ?int {
|
||||
r := ws.ssl_conn.read(mut buffer)?
|
||||
return r
|
||||
} else {
|
||||
for {
|
||||
r := ws.conn.read(mut buffer) or {
|
||||
if err.code() == net.err_timed_out_code {
|
||||
continue
|
||||
}
|
||||
return err
|
||||
}
|
||||
r := ws.conn.read(mut buffer)?
|
||||
return r
|
||||
}
|
||||
}
|
||||
}
|
||||
return none
|
||||
}
|
||||
|
||||
@ -37,17 +29,10 @@ fn (mut ws Client) socket_read_ptr(buf_ptr &u8, len int) ?int {
|
||||
r := ws.ssl_conn.socket_read_into_ptr(buf_ptr, len)?
|
||||
return r
|
||||
} else {
|
||||
for {
|
||||
r := ws.conn.read_ptr(buf_ptr, len) or {
|
||||
if err.code() == net.err_timed_out_code {
|
||||
continue
|
||||
}
|
||||
return err
|
||||
}
|
||||
r := ws.conn.read_ptr(buf_ptr, len)?
|
||||
return r
|
||||
}
|
||||
}
|
||||
}
|
||||
return none
|
||||
}
|
||||
|
||||
@ -91,8 +76,8 @@ fn (mut ws Client) dial_socket() ?&net.TcpConn {
|
||||
mut t := net.dial_tcp(tcp_address)?
|
||||
optval := int(1)
|
||||
t.sock.set_option_int(.keep_alive, optval)?
|
||||
t.set_read_timeout(30 * time.second)
|
||||
t.set_write_timeout(30 * time.second)
|
||||
t.set_read_timeout(ws.read_timeout)
|
||||
t.set_write_timeout(ws.write_timeout)
|
||||
if ws.is_ssl {
|
||||
ws.ssl_conn.connect(mut t, ws.uri.hostname)?
|
||||
}
|
||||
|
@ -30,6 +30,8 @@ pub:
|
||||
is_ssl bool // true if secure socket is used
|
||||
uri Uri // uri of current connection
|
||||
id string // unique id of client
|
||||
read_timeout i64
|
||||
write_timeout i64
|
||||
pub mut:
|
||||
header http.Header // headers that will be passed when connecting
|
||||
conn &net.TcpConn // underlying TCP socket connection
|
||||
@ -73,8 +75,14 @@ pub enum OPCode {
|
||||
pong = 0x0A
|
||||
}
|
||||
|
||||
[params]
|
||||
pub struct ClientOpt {
|
||||
read_timeout i64 = 30 * time.second
|
||||
write_timeout i64 = 30 * time.second
|
||||
}
|
||||
|
||||
// new_client instance a new websocket client
|
||||
pub fn new_client(address string) ?&Client {
|
||||
pub fn new_client(address string, opt ClientOpt) ?&Client {
|
||||
uri := parse_uri(address)?
|
||||
return &Client{
|
||||
conn: 0
|
||||
@ -88,6 +96,8 @@ pub fn new_client(address string) ?&Client {
|
||||
state: .closed
|
||||
id: rand.uuid_v4()
|
||||
header: http.new_header()
|
||||
read_timeout: opt.read_timeout
|
||||
write_timeout: opt.write_timeout
|
||||
}
|
||||
}
|
||||
|
||||
@ -97,9 +107,6 @@ pub fn (mut ws Client) connect() ? {
|
||||
ws.set_state(.connecting)
|
||||
ws.logger.info('connecting to host $ws.uri')
|
||||
ws.conn = ws.dial_socket()?
|
||||
// Todo: make setting configurable
|
||||
ws.conn.set_read_timeout(time.second * 30)
|
||||
ws.conn.set_write_timeout(time.second * 30)
|
||||
ws.handshake()?
|
||||
ws.set_state(.open)
|
||||
ws.logger.info('successfully connected to host $ws.uri')
|
||||
|
Loading…
Reference in New Issue
Block a user