#1079 closed defect (fixed)

upload of file into dir doesn't appear on Recent Uploads and Downloads

Reported by: zooko Owned by: Brian Warner <warner@…>
Priority: major Milestone: 1.9.0
Component: code-frontend Version: 1.7β
Keywords: upload usability statistics wui easy Cc:
Launchpad Bug:

Description

When I upload a file into a directory, such as this one: http://pubgrid.tahoe-lafs.org/uri/URI:DIR2-RO:ixqhc4kdbjxc7o65xjnveoewym:5x6lwoxghrd5rxhwunzavft2qygfkt27oj3fbxlq4c6p45z5uneq/ , which the timestamps show got linked into this directory at 2010-06-12_03:45:30.369968, the upload of the immutable file doesn't appear on the Recent Uploads and Downloads page:

21:45:38 11-Jun-2010	retrieve	up4mutkj52kcm2l7c7nvg5j2ua	No	314B	100.0%	Finished
21:45:38 11-Jun-2010	mapupdate MODE_READ	up4mutkj52kcm2l7c7nvg5j2ua	No	-NA-	100.0%	Finished
21:45:31 11-Jun-2010	retrieve	up4mutkj52kcm2l7c7nvg5j2ua	No	314B	100.0%	Finished
21:45:31 11-Jun-2010	mapupdate MODE_READ	up4mutkj52kcm2l7c7nvg5j2ua	No	-NA-	100.0%	Finished
21:45:30 11-Jun-2010	publish	up4mutkj52kcm2l7c7nvg5j2ua	No	314B	100.0%	Finished
21:45:30 11-Jun-2010	retrieve	up4mutkj52kcm2l7c7nvg5j2ua	No	624B	100.0%	Finished
21:45:30 11-Jun-2010	mapupdate MODE_WRITE	up4mutkj52kcm2l7c7nvg5j2ua	No	-NA-	100.0%	Finished
21:45:30 11-Jun-2010	publish	up4mutkj52kcm2l7c7nvg5j2ua	No	624B	100.0%	Finished
21:45:30 11-Jun-2010	retrieve	up4mutkj52kcm2l7c7nvg5j2ua	No	310B	100.0%	Finished
21:45:30 11-Jun-2010	mapupdate MODE_WRITE	up4mutkj52kcm2l7c7nvg5j2ua	No	-NA-	100.0%	Finished
21:45:30 11-Jun-2010	retrieve	up4mutkj52kcm2l7c7nvg5j2ua	No	310B	100.0%	Finished
21:45:29 11-Jun-2010	mapupdate MODE_READ	up4mutkj52kcm2l7c7nvg5j2ua	No	-NA-	100.0%	Finished
21:45:24 11-Jun-2010	retrieve	up4mutkj52kcm2l7c7nvg5j2ua	No	310B	100.0%	Finished
21:45:24 11-Jun-2010	mapupdate MODE_READ	up4mutkj52kcm2l7c7nvg5j2ua	No	-NA-	100.0%	Finished
21:45:24 11-Jun-2010	publish	up4mutkj52kcm2l7c7nvg5j2ua	No	310B	100.0%	Finished
21:45:23 11-Jun-2010	retrieve	up4mutkj52kcm2l7c7nvg5j2ua	No	620B	100.0%	Finished
21:45:23 11-Jun-2010	mapupdate MODE_WRITE	up4mutkj52kcm2l7c7nvg5j2ua	No	-NA-	100.0%	Finished
21:45:14 11-Jun-2010	retrieve	up4mutkj52kcm2l7c7nvg5j2ua	No	620B	100.0%	Finished
21:45:13 11-Jun-2010	mapupdate MODE_READ	up4mutkj52kcm2l7c7nvg5j2ua	No	-NA-	100.0%	Finished
21:32:56 11-Jun-2010	retrieve	up4mutkj52kcm2l7c7nvg5j2ua	No	620B	100.0%	Finished

Argh! These timestamps are in different timezones and neither of them have explicit timezone indicators. Grumble. Also they are of different and non-standard formatting. I just created #1077 (consistent timestamp format and timezone).

Anyway, making some educated guesses about what these timestamps mean, the upload that I completed at around 2010-06-12 03:45:30Z should have appeared in the list as "11-Jun-2010 21:45:30".

It seems like immutable file uploads into a directory never appear on Recent Uploads/Downloads, but immutable file downloads and unlinked immutable file uploads do.

Change History (7)

comment:1 Changed at 2010-07-26T07:00:52Z by zooko

  • Keywords easy added
  • Milestone changed from undecided to 1.8β

This shouldn't be hard to fix and it would be a big help with evaluating and improving Tahoe-LAFS performance if we could tell how fast uploads were.

comment:2 Changed at 2010-09-11T00:37:26Z by davidsarah

  • Milestone changed from 1.8β to 1.9.0

Out of time for 1.8.

comment:3 Changed at 2011-08-09T17:44:11Z by warner

I did some digging. The problem is that we aren't being consistent in passing the "History" object to all cases of file upload. (to get into the "Recent Uploads and Downloads" RUaD page, the Uploader must be given access to the History object, so it can call History.add_upload).

Client.upload(uploadable) does the right thing. The webapi has several different code paths that result in an immutable upload:

  • PUT /uri : hits PUTUnlinkedCHK (unlinked.py#L11) which calls client.upload, ok
  • PUT /uri/DIRCAP/childname: hits filenode.py#L37 which calls self.parentnode.add_file(), which does *not* handle history
  • POST /uri/DIRCAP/newchildname?t=upload and POST /uri/DIRCAP/oldchildname?t=upload&replace=true : both hit replace_me_with_a_formpost (filenode.py#L86), uses self.parentnode.add_file(), *no* history

The root problem is that DirectoryNode.add_file(), while convenient, doesn't have access to the History object. The best fix is probably to delete this method, and rewrite web/filenode.py to make two separate calls: client.upload and self.parentnode.set_uri.

OTOH, add_file() is used in an awful lot of unit tests, because it's so darned convenient. It'd be easier to change DirectoryNode.add_file to use client.upload, since the client knows about History, but DirectoryNode doesn't currently hold a reference to the client (just the nodemaker and the uploader). Maybe we should move client.upload over to the nodemaker?

comment:4 follow-up: Changed at 2011-08-10T06:36:32Z by davidsarah

The SFTP and FTP frontends also use add_file.

comment:5 in reply to: ↑ 4 Changed at 2011-08-10T14:51:58Z by davidsarah

Replying to davidsarah:

The SFTP and FTP frontends also use add_file.

As does the drop-upload frontend. All of these have access to the Client, so one possibility would be to add a client= argument to add_file. But since all uploads should be included in the history, I would think (without having looked in detail at the code) that the uploader should have a reference to the History.

Version 0, edited at 2011-08-10T14:51:58Z by davidsarah (next)

comment:6 Changed at 2011-08-29T06:33:11Z by Brian Warner <warner@…>

  • Owner set to Brian Warner <warner@…>
  • Resolution set to fixed
  • Status changed from new to closed

In fd676a5846fce5da:

(The changeset message doesn't reference this ticket)

comment:7 Changed at 2011-08-29T06:35:23Z by warner

excellent idea! Just landed it. I don't know why I didn't think of that before.. it might be that I've been hoping to get rid of the Uploader service (as we did with the old Downloader service), and so I didn't want to add anything extra to it. But that's a project for another day, and adding History to the Uploader is the perfect solution for this. Thanks!

Note: See TracTickets for help on using tickets.