代码拉取完成,页面将自动刷新
package api
import (
"crypto/tls"
"net/http"
"os"
"gitee.com/fast_api/api/def"
"gitee.com/fast_api/api/dwarf"
ihttp "gitee.com/fast_api/api/http"
"gitee.com/fast_api/api/log"
)
type Optional func(conf *ServerConfig)
var (
_ http.Handler = (*ServerMain)(nil)
defaultConf = ServerConfig{
dwarf: dwarf.NewDwarfMaker(),
listen: "0.0.0.0:8080",
}
)
func loadTls(s *ServerConfig) (tconf *tls.Config, err error) {
certs := make([]tls.Certificate, 1)
certs[0], err = tls.X509KeyPair(defaultConf.certPEMBlock, defaultConf.keyPEMBlock)
if err != nil {
log.Error(err)
return nil, err
}
return &tls.Config{
Certificates: certs,
}, err
}
type ServerMain struct {
maker *dwarf.DwarfMaker
pool *def.MethodsPools
}
func (ad *ServerMain) Maker() *dwarf.DwarfMaker {
return ad.maker
}
func NewServer(pool *def.MethodsPools) *ServerMain {
return &ServerMain{pool: pool}
}
func (ad *ServerMain) ServeHTTP(rw http.ResponseWriter, req *http.Request) {
ihttp.DoHttp(rw, req)
}
func WithListen(s string) Optional {
return func(conf *ServerConfig) {
conf.listen = s
}
}
func WithTLS(certPEMBlock, keyPEMBlock []byte) Optional {
return func(conf *ServerConfig) {
conf.certPEMBlock = certPEMBlock
conf.keyPEMBlock = keyPEMBlock
}
}
func WithTLSFile(certFile, keyFile string) Optional {
return func(conf *ServerConfig) {
certPEMBlock, err := os.ReadFile(certFile)
if err != nil {
log.Error(err)
return
}
keyPEMBlock, err := os.ReadFile(keyFile)
if err != nil {
log.Error(err)
return
}
conf.certPEMBlock = certPEMBlock
conf.keyPEMBlock = keyPEMBlock
}
}
func WithCa(caPEMBlock []byte) Optional {
return func(conf *ServerConfig) {
conf.caPEMBlock = caPEMBlock
}
}
func apply(s *ServerConfig, ops ...Optional) {
if ops == nil {
return
}
for i := 0; i < len(ops); i++ {
if ops[i] != nil {
ops[i](s)
}
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。