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 2.0 kB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  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 DoTx20[T1 any, T2 any](db *DB, do func(tx SQLContext, t1 T1, t2 T2) error, t1 T1, t2 T2) error {
  49. return db.db.Transaction(func(tx *gorm.DB) error {
  50. return do(SQLContext{tx}, t1, t2)
  51. })
  52. }
  53. 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) {
  54. var ret R
  55. err := db.db.Transaction(func(tx *gorm.DB) error {
  56. var err error
  57. ret, err = do(SQLContext{tx}, t1, t2)
  58. return err
  59. })
  60. return ret, err
  61. }
  62. 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) {
  63. var ret R
  64. err := db.db.Transaction(func(tx *gorm.DB) error {
  65. var err error
  66. ret, err = do(SQLContext{tx}, t1, t2, t3)
  67. return err
  68. })
  69. return ret, err
  70. }
  71. type SQLContext struct {
  72. *gorm.DB
  73. }
  74. func (db *DB) DefCtx() SQLContext {
  75. return SQLContext{db.db}
  76. }

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