mirror of
https://github.com/go-gitea/gitea.git
synced 2026-04-01 13:22:15 +00:00
Replace webpack with Vite 8 as the frontend bundler. Frontend build is around 3-4 times faster than before. Will work on all platforms including riscv64 (via wasm). `iife.js` is a classic render-blocking script in `<head>` (handles web components/early DOM setup). `index.js` is loaded as a `type="module"` script in the footer. All other JS chunks are also module scripts (supported in all browsers since 2018). Entry filenames are content-hashed (e.g. `index.C6Z2MRVQ.js`) and resolved at runtime via the Vite manifest, eliminating the `?v=` cache busting (which was unreliable in some scenarios like vscode dev build). Replaces: https://github.com/go-gitea/gitea/pull/36896 Fixes: https://github.com/go-gitea/gitea/issues/17793 Signed-off-by: silverwind <me@silverwind.io> Signed-off-by: wxiaoguang <wxiaoguang@gmail.com> Co-authored-by: Claude (Opus 4.6) <noreply@anthropic.com> Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com> Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
43 lines
1.7 KiB
Go
43 lines
1.7 KiB
Go
// Copyright 2019 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package graceful
|
|
|
|
import (
|
|
"context"
|
|
"crypto/tls"
|
|
"net"
|
|
"net/http"
|
|
)
|
|
|
|
func newHTTPServer(network, address, name string, handler http.Handler) (*Server, ServeFunction) {
|
|
server := NewServer(network, address, name)
|
|
protocols := http.Protocols{}
|
|
protocols.SetHTTP1(true)
|
|
protocols.SetHTTP2(true) // HTTP/2 can only be used when Gitea is configured to use TLS
|
|
protocols.SetUnencryptedHTTP2(true) // Allow HTTP/2 without TLS, in case Gitea is behind a reverse proxy
|
|
httpServer := http.Server{
|
|
Protocols: &protocols,
|
|
Handler: handler,
|
|
BaseContext: func(net.Listener) context.Context { return GetManager().HammerContext() },
|
|
}
|
|
server.OnShutdown = func() {
|
|
httpServer.SetKeepAlivesEnabled(false)
|
|
}
|
|
return server, httpServer.Serve
|
|
}
|
|
|
|
// HTTPListenAndServe listens on the provided network address and then calls Serve
|
|
// to handle requests on incoming connections.
|
|
func HTTPListenAndServe(network, address, name string, handler http.Handler, useProxyProtocol bool) error {
|
|
server, lHandler := newHTTPServer(network, address, name, handler)
|
|
return server.ListenAndServe(lHandler, useProxyProtocol)
|
|
}
|
|
|
|
// HTTPListenAndServeTLSConfig listens on the provided network address and then calls Serve
|
|
// to handle requests on incoming connections.
|
|
func HTTPListenAndServeTLSConfig(network, address, name string, tlsConfig *tls.Config, handler http.Handler, useProxyProtocol, proxyProtocolTLSBridging bool) error {
|
|
server, lHandler := newHTTPServer(network, address, name, handler)
|
|
return server.ListenAndServeTLSConfig(tlsConfig, lHandler, useProxyProtocol, proxyProtocolTLSBridging)
|
|
}
|