2022-12-15 20:44:16 +00:00
// Copyright 2022 The Gitea Authors. All rights reserved.
// SPDX-License-Identifier: MIT
package doctor
import (
"context"
"fmt"
2023-01-16 19:50:53 +00:00
"time"
2022-12-15 20:44:16 +00:00
"code.gitea.io/gitea/modules/log"
"code.gitea.io/gitea/modules/setting"
"code.gitea.io/gitea/services/repository"
)
func init ( ) {
Register ( & Check {
Title : "Garbage collect LFS" ,
Name : "gc-lfs" ,
IsDefault : false ,
Run : garbageCollectLFSCheck ,
AbortIfFailed : false ,
SkipDatabaseInitialization : false ,
Priority : 1 ,
} )
}
func garbageCollectLFSCheck ( ctx context . Context , logger log . Logger , autofix bool ) error {
if ! setting . LFS . StartServer {
return fmt . Errorf ( "LFS support is disabled" )
}
2023-01-16 19:50:53 +00:00
if err := repository . GarbageCollectLFSMetaObjects ( ctx , repository . GarbageCollectLFSMetaObjectsOptions {
2023-07-07 00:52:41 +08:00
LogDetail : logger . Info ,
AutoFix : autofix ,
2023-01-16 19:50:53 +00:00
// Only attempt to garbage collect lfs meta objects older than a week as the order of git lfs upload
// and git object upload is not necessarily guaranteed. It's possible to imagine a situation whereby
// an LFS object is uploaded but the git branch is not uploaded immediately, or there are some rapid
// changes in new branches that might lead to lfs objects becoming temporarily unassociated with git
// objects.
//
// It is likely that a week is potentially excessive but it should definitely be enough that any
// unassociated LFS object is genuinely unassociated.
OlderThan : time . Now ( ) . Add ( - 24 * time . Hour * 7 ) ,
// We don't set the UpdatedLessRecentlyThan because we want to do a full GC
} ) ; err != nil {
2024-04-05 11:48:03 +02:00
logger . Error ( "Couldn't garabage collect LFS objects: %v" , err )
2022-12-15 20:44:16 +00:00
return err
}
return checkStorage ( & checkStorageOptions { LFS : true } ) ( ctx , logger , autofix )
}