mirror of
https://git.0x0.st/mia/0x0.git
synced 2024-12-22 08:11:07 -05:00
migrations: Fix file expirations on SQLite
Well that was what we feared. I love arbitrary hardcoded limits.
This commit is contained in:
parent
f76dbef82f
commit
dcea8bffe1
1 changed files with 8 additions and 3 deletions
|
@ -58,14 +58,19 @@ def upgrade():
|
|||
return # There are no currently unexpired files
|
||||
|
||||
# Calculate an expiration date for all existing files
|
||||
files = session.scalars(
|
||||
|
||||
q = session.scalars(
|
||||
sa.select(File)
|
||||
.where(
|
||||
sa.not_(File.removed),
|
||||
File.sha256.in_(unexpired_files)
|
||||
sa.not_(File.removed)
|
||||
)
|
||||
)
|
||||
updates = [] # We coalesce updates to the database here
|
||||
|
||||
# SQLite has a hard limit on the number of variables so we
|
||||
# need to do this the slow way
|
||||
files = [f for f in q if f.sha256 in unexpired_files]
|
||||
|
||||
for file in files:
|
||||
file_path = storage / file.sha256
|
||||
stat = os.stat(file_path)
|
||||
|
|
Loading…
Reference in a new issue