mirror of
https://github.com/rclone/rclone.git
synced 2025-01-08 12:34:53 +02:00
rcserver: set ModTime
for dirs and files served by --rc-serve
This commit is contained in:
parent
08bf5228a7
commit
92368f6d2b
1
.gitignore
vendored
1
.gitignore
vendored
@ -7,6 +7,7 @@ docs/public
|
||||
rclone.iml
|
||||
.idea
|
||||
.history
|
||||
.vscode
|
||||
*.test
|
||||
*.iml
|
||||
fuzz-build.zip
|
||||
|
@ -281,6 +281,7 @@ Flags to control the Remote Control API.
|
||||
--rc-realm string Realm for authentication
|
||||
--rc-salt string Password hashing salt (default "dlPL2MqE")
|
||||
--rc-serve Enable the serving of remote objects
|
||||
--rc-serve-no-modtime Don't read the modification time (can speed things up)
|
||||
--rc-server-read-timeout Duration Timeout for server reading data (default 1h0m0s)
|
||||
--rc-server-write-timeout Duration Timeout for server writing data (default 1h0m0s)
|
||||
--rc-template string User-specified template
|
||||
|
@ -77,6 +77,12 @@ remotes using this syntax http://127.0.0.1:5572/[remote:path]/path/to/object
|
||||
|
||||
Default Off.
|
||||
|
||||
### --rc-serve-no-modtime
|
||||
|
||||
Set this flag to skip reading the modification time (can speed things up).
|
||||
|
||||
Default Off.
|
||||
|
||||
### --rc-files /path/to/directory
|
||||
|
||||
Path to local files to serve on the HTTP server.
|
||||
|
@ -23,6 +23,7 @@ type Options struct {
|
||||
Template libhttp.TemplateConfig
|
||||
Enabled bool // set to enable the server
|
||||
Serve bool // set to serve files from remotes
|
||||
ServeNoModTime bool // don't read the modification time
|
||||
Files string // set to enable serving files locally
|
||||
NoAuth bool // set to disable auth checks on AuthRequired methods
|
||||
WebUI bool // set to launch the web ui
|
||||
|
@ -21,6 +21,7 @@ func AddFlags(flagSet *pflag.FlagSet) {
|
||||
flags.BoolVarP(flagSet, &Opt.Enabled, "rc", "", false, "Enable the remote control server", "RC")
|
||||
flags.StringVarP(flagSet, &Opt.Files, "rc-files", "", "", "Path to local files to serve on the HTTP server", "RC")
|
||||
flags.BoolVarP(flagSet, &Opt.Serve, "rc-serve", "", false, "Enable the serving of remote objects", "RC")
|
||||
flags.BoolVarP(flagSet, &Opt.ServeNoModTime, "rc-serve-no-modtime", "", false, "Don't read the modification time (can speed things up)", "RC")
|
||||
flags.BoolVarP(flagSet, &Opt.NoAuth, "rc-no-auth", "", false, "Don't require auth for certain methods", "RC")
|
||||
flags.BoolVarP(flagSet, &Opt.WebUI, "rc-web-gui", "", false, "Launch WebGUI on localhost", "RC")
|
||||
flags.BoolVarP(flagSet, &Opt.WebGUIUpdate, "rc-web-gui-update", "", false, "Check and update to latest version of web gui", "RC")
|
||||
|
@ -340,8 +340,11 @@ func (s *Server) serveRemote(w http.ResponseWriter, r *http.Request, path string
|
||||
directory := serve.NewDirectory(path, s.server.HTMLTemplate())
|
||||
for _, entry := range entries {
|
||||
_, isDir := entry.(fs.Directory)
|
||||
//directory.AddHTMLEntry(entry.Remote(), isDir, entry.Size(), entry.ModTime(r.Context()))
|
||||
directory.AddHTMLEntry(entry.Remote(), isDir, entry.Size(), time.Time{})
|
||||
var modTime time.Time
|
||||
if !s.opt.ServeNoModTime {
|
||||
modTime = entry.ModTime(r.Context())
|
||||
}
|
||||
directory.AddHTMLEntry(entry.Remote(), isDir, entry.Size(), modTime)
|
||||
}
|
||||
sortParm := r.URL.Query().Get("sort")
|
||||
orderParm := r.URL.Query().Get("order")
|
||||
|
@ -8,6 +8,7 @@ import (
|
||||
"net/http"
|
||||
"net/http/httptest"
|
||||
"os"
|
||||
"path/filepath"
|
||||
"regexp"
|
||||
"strings"
|
||||
"testing"
|
||||
@ -23,10 +24,10 @@ import (
|
||||
)
|
||||
|
||||
const (
|
||||
testBindAddress = "localhost:0"
|
||||
testTemplate = "testdata/golden/testindex.html"
|
||||
testFs = "testdata/files"
|
||||
remoteURL = "[" + testFs + "]/" // initial URL path to fetch from that remote
|
||||
testBindAddress = "localhost:0"
|
||||
defaultTestTemplate = "testdata/golden/testindex.html"
|
||||
testFs = "testdata/files"
|
||||
remoteURL = "[" + testFs + "]/" // initial URL path to fetch from that remote
|
||||
)
|
||||
|
||||
func TestMain(m *testing.M) {
|
||||
@ -49,7 +50,7 @@ func TestMain(m *testing.M) {
|
||||
func TestRcServer(t *testing.T) {
|
||||
opt := rc.DefaultOpt
|
||||
opt.HTTP.ListenAddr = []string{testBindAddress}
|
||||
opt.Template.Path = testTemplate
|
||||
opt.Template.Path = defaultTestTemplate
|
||||
opt.Enabled = true
|
||||
opt.Serve = true
|
||||
opt.Files = testFs
|
||||
@ -102,15 +103,21 @@ type testRun struct {
|
||||
|
||||
// Run a suite of tests
|
||||
func testServer(t *testing.T, tests []testRun, opt *rc.Options) {
|
||||
t.Helper()
|
||||
|
||||
ctx := context.Background()
|
||||
configfile.Install()
|
||||
opt.Template.Path = testTemplate
|
||||
if opt.Template.Path == "" {
|
||||
opt.Template.Path = defaultTestTemplate
|
||||
}
|
||||
rcServer, err := newServer(ctx, opt, http.DefaultServeMux)
|
||||
require.NoError(t, err)
|
||||
testURL := rcServer.server.URLs()[0]
|
||||
mux := rcServer.server.Router()
|
||||
for _, test := range tests {
|
||||
t.Run(test.Name, func(t *testing.T) {
|
||||
t.Helper()
|
||||
|
||||
method := test.Method
|
||||
if method == "" {
|
||||
method = "GET"
|
||||
@ -172,6 +179,7 @@ func TestFileServing(t *testing.T) {
|
||||
Expected: `<pre>
|
||||
<a href="dir/">dir/</a>
|
||||
<a href="file.txt">file.txt</a>
|
||||
<a href="modtime/">modtime/</a>
|
||||
</pre>
|
||||
`,
|
||||
}, {
|
||||
@ -243,6 +251,7 @@ func TestRemoteServing(t *testing.T) {
|
||||
<body>
|
||||
<h1>Directory listing of /</h1>
|
||||
<a href="dir/">dir/</a><br />
|
||||
<a href="modtime/">modtime/</a><br />
|
||||
<a href="file.txt">file.txt</a><br />
|
||||
</body>
|
||||
</html>
|
||||
@ -804,3 +813,37 @@ func TestRCDebug(t *testing.T) {
|
||||
opt.Files = ""
|
||||
testServer(t, tests, &opt)
|
||||
}
|
||||
|
||||
func TestServeModTime(t *testing.T) {
|
||||
for file, mtime := range map[string]time.Time{
|
||||
"dir": time.Date(2023, 4, 12, 21, 15, 17, 0, time.UTC),
|
||||
"modtime.txt": time.Date(2021, 1, 18, 5, 2, 28, 0, time.UTC),
|
||||
} {
|
||||
path := filepath.Join(testFs, "modtime", file)
|
||||
err := os.Chtimes(path, mtime, mtime)
|
||||
require.NoError(t, err)
|
||||
}
|
||||
|
||||
opt := newTestOpt()
|
||||
opt.Serve = true
|
||||
opt.Template.Path = "testdata/golden/testmodtime.html"
|
||||
|
||||
tests := []testRun{{
|
||||
Name: "modtime",
|
||||
Method: "GET",
|
||||
URL: remoteURL + "modtime/",
|
||||
Status: http.StatusOK,
|
||||
Expected: "* dir/ - 2023-04-12T21:15:17Z\n* modtime.txt - 2021-01-18T05:02:28Z\n",
|
||||
}}
|
||||
testServer(t, tests, &opt)
|
||||
|
||||
opt.ServeNoModTime = true
|
||||
tests = []testRun{{
|
||||
Name: "no modtime",
|
||||
Method: "GET",
|
||||
URL: remoteURL + "modtime/",
|
||||
Status: http.StatusOK,
|
||||
Expected: "* dir/ - 0001-01-01T00:00:00Z\n* modtime.txt - 0001-01-01T00:00:00Z\n",
|
||||
}}
|
||||
testServer(t, tests, &opt)
|
||||
}
|
||||
|
0
fs/rc/rcserver/testdata/files/modtime/dir/.gitkeep
vendored
Normal file
0
fs/rc/rcserver/testdata/files/modtime/dir/.gitkeep
vendored
Normal file
0
fs/rc/rcserver/testdata/files/modtime/modtime.txt
vendored
Normal file
0
fs/rc/rcserver/testdata/files/modtime/modtime.txt
vendored
Normal file
2
fs/rc/rcserver/testdata/golden/testmodtime.html
vendored
Normal file
2
fs/rc/rcserver/testdata/golden/testmodtime.html
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
{{ range .Entries }}* {{ .Leaf }} - {{ .ModTime.UTC.Format "2006-01-02T15:04:05Z07:00" }}
|
||||
{{ end }}
|
Loading…
Reference in New Issue
Block a user