2023-06-29 06:41:02 +08:00
// Copyright 2023 The Gitea Authors. All rights reserved.
// SPDX-License-Identifier: MIT
package v1_21 //nolint
import (
"fmt"
"xorm.io/xorm"
)
// AddGitSizeAndLFSSizeToRepositoryTable: add GitSize and LFSSize columns to Repository
func AddGitSizeAndLFSSizeToRepositoryTable ( x * xorm . Engine ) error {
type Repository struct {
GitSize int64 ` xorm:"NOT NULL DEFAULT 0" `
LFSSize int64 ` xorm:"NOT NULL DEFAULT 0" `
}
sess := x . NewSession ( )
defer sess . Close ( )
if err := sess . Begin ( ) ; err != nil {
return err
}
2023-08-13 21:17:21 +02:00
if err := sess . Sync ( new ( Repository ) ) ; err != nil {
return fmt . Errorf ( "Sync: %w" , err )
2023-06-29 06:41:02 +08:00
}
_ , err := sess . Exec ( ` UPDATE repository SET lfs_size=(SELECT SUM(size) FROM lfs_meta_object WHERE lfs_meta_object.repository_id=repository.ID) WHERE EXISTS (SELECT 1 FROM lfs_meta_object WHERE lfs_meta_object.repository_id=repository.ID) ` )
if err != nil {
return err
}
2023-12-05 22:51:56 +08:00
_ , err = sess . Exec ( ` UPDATE repository SET size = 0 WHERE size IS NULL ` )
if err != nil {
return err
}
_ , err = sess . Exec ( ` UPDATE repository SET git_size = size - lfs_size WHERE size > lfs_size ` )
2023-06-29 06:41:02 +08:00
if err != nil {
return err
}
return sess . Commit ( )
}