@@ -2,6 +2,7 @@ package main
2
2
3
3
import (
4
4
"context"
5
+ "crypto/tls"
5
6
"database/sql"
6
7
"fmt"
7
8
"log"
@@ -68,12 +69,34 @@ func (app *App) CloseDB() {
68
69
}
69
70
70
71
func (app * App ) InitServer () {
72
+ tlsConfig := & tls.Config {
73
+ PreferServerCipherSuites : true ,
74
+ CurvePreferences : []tls.CurveID {tls .X25519 , tls .CurveP256 },
75
+ CipherSuites : []uint16 {
76
+ tls .TLS_ECDHE_ECDSA_WITH_CHACHA20_POLY1305 ,
77
+ tls .TLS_ECDHE_RSA_WITH_CHACHA20_POLY1305 ,
78
+ tls .TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256 ,
79
+ tls .TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256 ,
80
+ tls .TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384 ,
81
+ tls .TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 ,
82
+ tls .TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256 ,
83
+ tls .TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256 ,
84
+ tls .TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA ,
85
+ tls .TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA ,
86
+ tls .TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA ,
87
+ tls .TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA ,
88
+ },
89
+ MinVersion : tls .VersionTLS12 ,
90
+ MaxVersion : tls .VersionTLS12 ,
91
+ }
92
+
71
93
app .server = & http.Server {
72
94
Addr : app .addr ,
73
95
Handler : app .Routes (),
74
96
WriteTimeout : 15 * time .Second ,
75
97
ReadTimeout : 15 * time .Second ,
76
98
IdleTimeout : 60 * time .Second ,
99
+ TLSConfig : tlsConfig ,
77
100
}
78
101
}
79
102
0 commit comments