You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tailscale/taildrop
Joe Tsai 6ada33db77
taildrop: fix theoretical race condition in fileDeleter.Init (#9876)
It is possible that upon a cold-start, we enqueue a partial file
for deletion that is resumed shortly after startup.

If the file transfer happens to last longer than deleteDelay,
we will delete the partial file, which is unfortunate.
The client spent a long time uploading a file,
only for it to be accidentally deleted.
It's a very rare race, but also a frustrating one
if it happens to manifest.

Fix the code to only delete partial files that
do not have an active puts against it.

We also fix a minor bug in ResumeReader
where we read b[:blockSize] instead of b[:cs.Size].
The former is the fixed size of 64KiB,
while the latter is usually 64KiB,
but may be less for the last block.

Updates tailscale/corp#14772

Signed-off-by: Joe Tsai <joetsai@digital-static.net>
8 months ago
..
delete.go taildrop: fix theoretical race condition in fileDeleter.Init (#9876) 8 months ago
delete_test.go taildrop: fix theoretical race condition in fileDeleter.Init (#9876) 8 months ago
resume.go taildrop: fix theoretical race condition in fileDeleter.Init (#9876) 8 months ago
resume_test.go taildrop: fix TestResume (#9874) 8 months ago
retrieve.go taildrop: fix theoretical race condition in fileDeleter.Init (#9876) 8 months ago
send.go taildrop: implement asynchronous file deletion (#9844) 8 months ago
taildrop.go taildrop: fix theoretical race condition in fileDeleter.Init (#9876) 8 months ago
taildrop_test.go taildrop: implement asynchronous file deletion (#9844) 8 months ago