|
|
|
@@ -0,0 +1,61 @@ |
|
|
|
package cmdline |
|
|
|
|
|
|
|
import ( |
|
|
|
"fmt" |
|
|
|
"os" |
|
|
|
|
|
|
|
"github.com/spf13/cobra" |
|
|
|
"gitlink.org.cn/cloudream/storage2/client/internal/config" |
|
|
|
clitypes "gitlink.org.cn/cloudream/storage2/client/types" |
|
|
|
"gorm.io/driver/mysql" |
|
|
|
"gorm.io/gorm" |
|
|
|
) |
|
|
|
|
|
|
|
func init() { |
|
|
|
var configPath string |
|
|
|
cmd := cobra.Command{ |
|
|
|
Use: "migrate", |
|
|
|
Short: "Run database migrations", |
|
|
|
Run: func(cmd *cobra.Command, args []string) { |
|
|
|
migrate(configPath) |
|
|
|
}, |
|
|
|
} |
|
|
|
cmd.Flags().StringVarP(&configPath, "config", "c", "", "Path to config file") |
|
|
|
RootCmd.AddCommand(&cmd) |
|
|
|
} |
|
|
|
|
|
|
|
func migrate(configPath string) { |
|
|
|
// TODO 将create_database.sql的内容逐渐移动到这里来 |
|
|
|
|
|
|
|
err := config.Init(configPath) |
|
|
|
if err != nil { |
|
|
|
fmt.Println(err) |
|
|
|
os.Exit(1) |
|
|
|
} |
|
|
|
|
|
|
|
db, err := gorm.Open(mysql.Open(config.Cfg().DB.MakeSourceString())) |
|
|
|
if err != nil { |
|
|
|
fmt.Println(err) |
|
|
|
os.Exit(1) |
|
|
|
} |
|
|
|
db = db.Set("gorm:table_options", "CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci") |
|
|
|
|
|
|
|
migrateOne(db, clitypes.Bucket{}) |
|
|
|
migrateOne(db, clitypes.ObjectAccessStat{}) |
|
|
|
migrateOne(db, clitypes.ObjectBlock{}) |
|
|
|
migrateOne(db, clitypes.Object{}) |
|
|
|
migrateOne(db, clitypes.PackageAccessStat{}) |
|
|
|
migrateOne(db, clitypes.Package{}) |
|
|
|
migrateOne(db, clitypes.PinnedObject{}) |
|
|
|
migrateOne(db, clitypes.UserSpace{}) |
|
|
|
|
|
|
|
fmt.Println("migrate success") |
|
|
|
} |
|
|
|
|
|
|
|
func migrateOne[T any](db *gorm.DB, model T) { |
|
|
|
err := db.AutoMigrate(model) |
|
|
|
if err != nil { |
|
|
|
fmt.Printf("migratting model %T: %v\n", model, err) |
|
|
|
os.Exit(1) |
|
|
|
} |
|
|
|
} |