-
Notifications
You must be signed in to change notification settings - Fork 112
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
quota querying and tree accounting #1405
Conversation
Thanks for opening this pull request! The maintainers of this repository would appreciate it if you would create a changelog item based on your changes. |
This pull request fixes 4 alerts when merging 99864e4 into d919d59 - view on LGTM.com fixed alerts:
|
the only api that end users can use to access the free and used space of a storage is through webdav rfc 4331 |
This pull request fixes 4 alerts when merging 60e4c47 into ab3be6b - view on LGTM.com fixed alerts:
|
71c6a47
to
48f10db
Compare
This pull request fixes 4 alerts when merging 790a8c7 into ffb0fb4 - view on LGTM.com fixed alerts:
|
This pull request fixes 4 alerts when merging bb1c3f9 into 82be569 - view on LGTM.com fixed alerts:
|
This pull request fixes 4 alerts when merging 6f484a8 into 6f07395 - view on LGTM.com fixed alerts:
|
This pull request fixes 4 alerts when merging 0336464 into 6f07395 - view on LGTM.com fixed alerts:
|
This pull request fixes 4 alerts when merging 9326e3b into 6f07395 - view on LGTM.com fixed alerts:
|
This pull request fixes 4 alerts when merging 0c6c3d4 into 6f07395 - view on LGTM.com fixed alerts:
|
To test this using ocis
Now test fetching the quota using ocs:
or using propfinds:
|
For the sake of completeness, the command for setting the quota on a mac is: |
I can confirm the results with the instructions from above.
|
pkg/storage/fs/ocis/ocis.go
Outdated
return 0, 0, err | ||
} | ||
|
||
total := stat.Blocks * uint64(stat.Bsize) // Total data blocks in filesystem |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Shouldn't total
be the available disk space? 🤔 at least from a user perspective it's misleading that with unlimited quota the response will tell that (on my machine) 495GB are free, while my actual free disk space is at 195GB.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
uh ... that is weird. maybe the total is calculated differently on mac? what does this look like on mac:
> stat .
File: .
Size: 4096 Blocks: 8 IO Block: 4096 directory
Device: 820h/2080d Inode: 420580 Links: 29
Access: (0755/drwxr-xr-x) Uid: ( 1000/ vscode) Gid: ( 1000/ vscode)
Access: 2021-02-09 20:43:26.250000000 +0000
Modify: 2021-02-09 20:43:26.100000000 +0000
Change: 2021-02-09 20:43:26.100000000 +0000
Birth: -
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
macOS is weird for stat
... being in the ocis user home dir of einstein:
> stat -x .
File: "."
Size: 128 FileType: Directory
Mode: (0700/drwx------) Uid: ( 501/ bene) Gid: ( 0/ wheel)
Device: 1,5 Inode: 62850061 Links: 4
Access: Wed Feb 10 07:33:06 2021
Modify: Wed Feb 10 07:33:06 2021
Change: Wed Feb 10 09:56:26 2021
> stat .
16777221 62850061 drwx------ 4 bene wheel 0 128 "Feb 10 07:33:06 2021" "Feb 10 07:33:06 2021" "Feb 10 09:56:26 2021" "Feb 10 07:23:36 2021" 4096 0 0 .
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ok, what about filesystem stat and df:
> stat -f .
File: "."
ID: fedc9aa3bd65bc57 Namelen: 255 Type: ext2/ext3
Block size: 4096 Fundamental block size: 4096
Blocks: Total: 65793553 Free: 58593039 Available: 55233500
Inodes: Total: 16777216 Free: 16011441
> df -B4K
Filesystem 4K-blocks Used Available Use% Mounted on
overlay 65793553 7200514 55233500 12% /
tmpfs 16384 0 16384 0% /dev
tmpfs 2046465 0 2046465 0% /sys/fs/cgroup
shm 16384 0 16384 0% /dev/shm
/dev/sdc 65793553 7200514 55233500 12% /etc/hosts
drvfs 31096934 19848635 11248299 64% /home/vscode/.ssh
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
macOS doesn't have stat
for the entire filesystem AFAICT.
> BLOCKSIZE=4K df
Filesystem 4K-blocks Used Available Capacity iused ifree %iused Mounted on
/dev/disk1s5s1 122061322 4756743 34314966 13% 568975 4881883905 0% /
devfs 47 47 0 100% 658 0 100% /dev
/dev/disk1s4 122061322 524298 34314966 2% 2 4882452878 0% /System/Volumes/VM
/dev/disk1s2 122061322 80331 34314966 1% 792 4882452088 0% /System/Volumes/Preboot
/dev/disk1s6 122061322 27269 34314966 1% 396 4882452484 0% /System/Volumes/Update
/dev/disk1s1 122061322 82168442 34314966 71% 4246575 4878206305 0% /System/Volumes/Data
map auto_home 0 0 0 100% 0 0 100% /System/Volumes/Data/home
/dev/disk1s5 122061322 4756743 34314966 13% 568977 4881883903 0% /System/Volumes/Update/mnt1
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ah now I get it ... the switch case in https://github.com/cs3org/reva/pull/1405/files#diff-62fe53c34a46cf0bf6e8f27409f0ba1ba6b0687387b8c9cde985299ba10b839fR229-R240 should limit the total to the quota if the latter is set. the free space is then calculated in the ocs / ocdav handler by calculating free = total-used
. The problem is that we currently cannot return 'unlimited' quota. It would be a dedicated flag because currently quota is an unsigned int...
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
actually, if no quote is set we should return free+used as the total, because other users files also count against the total.
This pull request fixes 4 alerts when merging d080ab3 into 7a9a5ef - view on LGTM.com fixed alerts:
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
👍
@ishank011 can you test on eos? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@butonic Looks good, a few minor nits. And works for EOS, nice!
Signed-off-by: Jörn Friedrich Dreyer <jfd@butonic.de>
Signed-off-by: Jörn Friedrich Dreyer <jfd@butonic.de>
Signed-off-by: Jörn Friedrich Dreyer <jfd@butonic.de>
Signed-off-by: Jörn Friedrich Dreyer <jfd@butonic.de>
Signed-off-by: Jörn Friedrich Dreyer <jfd@butonic.de>
Signed-off-by: Jörn Friedrich Dreyer <jfd@butonic.de>
Signed-off-by: Jörn Friedrich Dreyer <jfd@butonic.de>
Signed-off-by: Jörn Friedrich Dreyer <jfd@butonic.de>
Signed-off-by: Jörn Friedrich Dreyer <jfd@butonic.de>
This pull request fixes 4 alerts when merging 3f69dc2 into 8a29177 - view on LGTM.com fixed alerts:
|
The ocs api now returns the user quota for the users home storage. Furthermore, the ocis storage driver now reads the quota from the extended attributes of the user home or root node and implements tree size accounting. Finally, ocdav PROPFINDS now handle the
DAV:quota-used-bytes
andDAV:quote-available-bytes
properties.check uploads against the quotain a different PR, we need add delete home to the storage provider cs3apis#95 before continuing with anything quota related.relvated: owncloud/ocis#1313