X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/10afc7ae2f95aad09937465702be7c44d07920d4..daf902070467a6a48bd0c9a8b147b8c27e0720c3:/services/keep-web/handler.go diff --git a/services/keep-web/handler.go b/services/keep-web/handler.go index 6f6ff542b5..ef61b06873 100644 --- a/services/keep-web/handler.go +++ b/services/keep-web/handler.go @@ -864,12 +864,9 @@ func (h *handler) seeOtherWithCookie(w http.ResponseWriter, r *http.Request, loc } func (h *handler) userPermittedToUploadOrDownload(method string, tokenUser *arvados.User) bool { - if tokenUser == nil { - return false - } var permitDownload bool var permitUpload bool - if tokenUser.IsAdmin { + if tokenUser != nil && tokenUser.IsAdmin { permitUpload = h.Config.cluster.Collections.WebDAVPermission.Admin.Upload permitDownload = h.Config.cluster.Collections.WebDAVPermission.Admin.Download } else { @@ -900,9 +897,13 @@ func (h *handler) logUploadOrDownload( log := ctxlog.FromContext(r.Context()) props := make(map[string]string) props["reqPath"] = r.URL.Path + var useruuid string if user != nil { log = log.WithField("user_uuid", user.UUID). WithField("user_full_name", user.FullName) + useruuid = user.UUID + } else { + useruuid = fmt.Sprintf("%s-tpzed-anonymouspublic", h.Config.cluster.ClusterID) } if collection == nil && fs != nil { collection, filepath = h.determineCollection(fs, filepath) @@ -912,13 +913,21 @@ func (h *handler) logUploadOrDownload( WithField("collection_file_path", filepath) props["collection_uuid"] = collection.UUID props["collection_file_path"] = filepath + // h.determineCollection populates the collection_uuid prop with the PDH, if + // this collection is being accessed via PDH. In that case, blank the + // collection_uuid field so that consumers of the log entries can rely on it + // being a UUID, or blank. The PDH remains available via the + // portable_data_hash property. + if props["collection_uuid"] == collection.PortableDataHash { + props["collection_uuid"] = "" + } } if r.Method == "PUT" || r.Method == "POST" { log.Info("File upload") if h.Config.cluster.Collections.WebDAVLogEvents { go func() { lr := arvadosclient.Dict{"log": arvadosclient.Dict{ - "object_uuid": user.UUID, + "object_uuid": useruuid, "event_type": "file_upload", "properties": props}} err := client.Create("logs", lr, nil) @@ -936,7 +945,7 @@ func (h *handler) logUploadOrDownload( if h.Config.cluster.Collections.WebDAVLogEvents { go func() { lr := arvadosclient.Dict{"log": arvadosclient.Dict{ - "object_uuid": user.UUID, + "object_uuid": useruuid, "event_type": "file_download", "properties": props}} err := client.Create("logs", lr, nil)