Set 30 second deadline for reading requests. See #35.
This commit is contained in:
parent
c4866d2965
commit
4b54eb6134
1 changed files with 14 additions and 3 deletions
17
handler.go
17
handler.go
|
@ -204,17 +204,28 @@ func handleGeminiRequest(conn net.Conn, sysConfig SysConfig, config UserConfig,
|
|||
}
|
||||
|
||||
func readRequest(conn net.Conn, logEntry *LogEntry) (*url.URL, error) {
|
||||
err := conn.SetReadDeadline(time.Now().Add(30 * time.Second))
|
||||
if err != nil {
|
||||
log.Println("Error setting read deadline: " + err.Error())
|
||||
return nil, err
|
||||
}
|
||||
|
||||
reader := bufio.NewReaderSize(conn, 1024)
|
||||
request, overflow, err := reader.ReadLine()
|
||||
|
||||
if overflow {
|
||||
conn.Write([]byte("59 Request too long!\r\n"))
|
||||
logEntry.Status = 59
|
||||
return nil, errors.New("Request too long")
|
||||
} else if err != nil {
|
||||
log.Println("Error reading request from " + conn.RemoteAddr().String() + ": " + err.Error())
|
||||
conn.Write([]byte("40 Unknown error reading request!\r\n"))
|
||||
if errors.Is(err, os.ErrDeadlineExceeded) {
|
||||
conn.Write([]byte("40 Request timed out!\r\n"))
|
||||
} else {
|
||||
log.Println("Error reading request from " + conn.RemoteAddr().String() + ": " + err.Error())
|
||||
conn.Write([]byte("40 Unknown error reading request!\r\n"))
|
||||
}
|
||||
logEntry.Status = 40
|
||||
return nil, errors.New("Error reading request")
|
||||
return nil, err
|
||||
}
|
||||
|
||||
// Parse request as URL
|
||||
|
|
Loading…
Add table
Reference in a new issue