You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

db.go 1.8 kB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. package db
  2. import (
  3. _ "github.com/go-sql-driver/mysql"
  4. "github.com/sirupsen/logrus"
  5. "gorm.io/driver/mysql"
  6. "gorm.io/gorm"
  7. )
  8. type DB struct {
  9. db *gorm.DB
  10. }
  11. func NewDB(cfg *Config) (*DB, error) {
  12. mydb, err := gorm.Open(mysql.Open(cfg.MakeSourceString()), &gorm.Config{})
  13. if err != nil {
  14. logrus.Fatalf("failed to connect to database: %v", err)
  15. }
  16. return &DB{
  17. db: mydb,
  18. }, nil
  19. }
  20. func (db *DB) DoTx(do func(tx SQLContext) error) error {
  21. return db.db.Transaction(func(tx *gorm.DB) error {
  22. return do(SQLContext{tx})
  23. })
  24. }
  25. func DoTx10[T any](db *DB, do func(tx SQLContext, t T) error, t T) error {
  26. return db.db.Transaction(func(tx *gorm.DB) error {
  27. return do(SQLContext{tx}, t)
  28. })
  29. }
  30. func DoTx01[R any](db *DB, do func(tx SQLContext) (R, error)) (R, error) {
  31. var ret R
  32. err := db.db.Transaction(func(tx *gorm.DB) error {
  33. var err error
  34. ret, err = do(SQLContext{tx})
  35. return err
  36. })
  37. return ret, err
  38. }
  39. func DoTx11[T any, R any](db *DB, do func(tx SQLContext, t T) (R, error), t T) (R, error) {
  40. var ret R
  41. err := db.db.Transaction(func(tx *gorm.DB) error {
  42. var err error
  43. ret, err = do(SQLContext{tx}, t)
  44. return err
  45. })
  46. return ret, err
  47. }
  48. func DoTx21[T1 any, T2 any, R any](db *DB, do func(tx SQLContext, t1 T1, t2 T2) (R, error), t1 T1, t2 T2) (R, error) {
  49. var ret R
  50. err := db.db.Transaction(func(tx *gorm.DB) error {
  51. var err error
  52. ret, err = do(SQLContext{tx}, t1, t2)
  53. return err
  54. })
  55. return ret, err
  56. }
  57. func DoTx31[T1 any, T2 any, T3 any, R any](db *DB, do func(tx SQLContext, t1 T1, t2 T2, t3 T3) (R, error), t1 T1, t2 T2, t3 T3) (R, error) {
  58. var ret R
  59. err := db.db.Transaction(func(tx *gorm.DB) error {
  60. var err error
  61. ret, err = do(SQLContext{tx}, t1, t2, t3)
  62. return err
  63. })
  64. return ret, err
  65. }
  66. type SQLContext struct {
  67. *gorm.DB
  68. }
  69. func (db *DB) DefCtx() SQLContext {
  70. return SQLContext{db.db}
  71. }

本项目旨在将云际存储公共基础设施化,使个人及企业可低门槛使用高效的云际存储服务(安装开箱即用云际存储客户端即可,无需关注其他组件的部署),同时支持用户灵活便捷定制云际存储的功能细节。