mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-21 10:51:29 +00:00
Currently, there are some unit tests that are failing on Windows due to various reasons: - paths not properly joined (filepath.Join should be used). - Proxy Mode IPVS not supported on Windows. - DeadlineExceeded can occur when trying to read data from an UDP socket. This can be used to detect whether the port was closed or not. - In Windows, with long file name support enabled, file names can have up to 32,767 characters. In this case, the error windows.ERROR_FILENAME_EXCED_RANGE will be encountered instead. - files not closed, which means that they cannot be removed / renamed. - time.Now() is not as precise on Windows, which means that 2 consecutive calls may return the same timestamp. - path.Base() will return the same path. filepath.Base() should be used instead. - path.Join() will always join the paths with a / instead of the OS specific separator. filepath.Join() should be used instead.
71 lines
2.2 KiB
Go
71 lines
2.2 KiB
Go
/*
|
|
Copyright 2014 The Kubernetes Authors.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package routes
|
|
|
|
import (
|
|
"net/http"
|
|
"os"
|
|
"path"
|
|
|
|
"github.com/emicklei/go-restful/v3"
|
|
)
|
|
|
|
// Logs adds handlers for the /logs path serving log files from /var/log.
|
|
type Logs struct{}
|
|
|
|
// Install func registers the logs handler.
|
|
func (l Logs) Install(c *restful.Container) {
|
|
// use restful: ws.Route(ws.GET("/logs/{logpath:*}").To(fileHandler))
|
|
// See github.com/emicklei/go-restful/blob/master/examples/static/restful-serve-static.go
|
|
ws := new(restful.WebService)
|
|
ws.Path("/logs")
|
|
ws.Doc("get log files")
|
|
ws.Route(ws.GET("/{logpath:*}").To(logFileHandler).Param(ws.PathParameter("logpath", "path to the log").DataType("string")))
|
|
ws.Route(ws.GET("/").To(logFileListHandler))
|
|
|
|
c.Add(ws)
|
|
}
|
|
|
|
func logFileHandler(req *restful.Request, resp *restful.Response) {
|
|
logdir := "/var/log"
|
|
actual := path.Join(logdir, req.PathParameter("logpath"))
|
|
|
|
// check filename length first, return 404 if it's oversize.
|
|
if logFileNameIsTooLong(actual) {
|
|
http.Error(resp, "file not found", http.StatusNotFound)
|
|
return
|
|
}
|
|
http.ServeFile(resp.ResponseWriter, req.Request, actual)
|
|
}
|
|
|
|
func logFileListHandler(req *restful.Request, resp *restful.Response) {
|
|
logdir := "/var/log"
|
|
http.ServeFile(resp.ResponseWriter, req.Request, logdir)
|
|
}
|
|
|
|
// logFileNameIsTooLong checks filename length, returns true if it's longer than 255.
|
|
// cause http.ServeFile returns default error code 500 except for NotExist and Forbidden, but we need to separate the real 500 from oversize filename here.
|
|
func logFileNameIsTooLong(filePath string) bool {
|
|
_, err := os.Stat(filePath)
|
|
if err != nil {
|
|
if e, ok := err.(*os.PathError); ok && e.Err == fileNameTooLong {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|