-
Notifications
You must be signed in to change notification settings - Fork 348
/
operation_utils.go
39 lines (34 loc) · 1.03 KB
/
operation_utils.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
package operations
import (
"net/http"
"time"
"github.com/treeverse/lakefs/pkg/catalog"
"github.com/treeverse/lakefs/pkg/logging"
)
func (o *PathOperation) finishUpload(req *http.Request, checksum, physicalAddress string, size int64, relative bool) error {
addressType := catalog.AddressTypeRelative
if !relative {
addressType = catalog.AddressTypeFull
}
// write metadata
writeTime := time.Now()
entry := catalog.DBEntry{
Path: o.Path,
PhysicalAddress: physicalAddress,
AddressType: addressType,
Checksum: checksum,
Metadata: nil, // TODO: Read whatever metadata came from the request headers/params and add here
Size: size,
CreationDate: writeTime,
}
err := o.Catalog.CreateEntry(req.Context(), o.Repository.Name, o.Reference, entry)
if err != nil {
o.Log(req).WithError(err).Error("could not update metadata")
return err
}
tookMeta := time.Since(writeTime)
o.Log(req).WithFields(logging.Fields{
"took": tookMeta,
}).Debug("metadata update complete")
return nil
}