gitea源码

v245.go 1.6KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. // Copyright 2023 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package v1_20
  4. import (
  5. "context"
  6. "code.gitea.io/gitea/models/migrations/base"
  7. "code.gitea.io/gitea/modules/setting"
  8. "xorm.io/xorm"
  9. )
  10. func RenameWebhookOrgToOwner(x *xorm.Engine) error {
  11. type Webhook struct {
  12. OrgID int64 `xorm:"INDEX"`
  13. }
  14. // This migration maybe rerun so that we should check if it has been run
  15. ownerExist, err := x.Dialect().IsColumnExist(x.DB(), context.Background(), "webhook", "owner_id")
  16. if err != nil {
  17. return err
  18. }
  19. if ownerExist {
  20. orgExist, err := x.Dialect().IsColumnExist(x.DB(), context.Background(), "webhook", "org_id")
  21. if err != nil {
  22. return err
  23. }
  24. if !orgExist {
  25. return nil
  26. }
  27. }
  28. sess := x.NewSession()
  29. defer sess.Close()
  30. if err := sess.Begin(); err != nil {
  31. return err
  32. }
  33. if err := sess.Sync(new(Webhook)); err != nil {
  34. return err
  35. }
  36. if ownerExist {
  37. if err := base.DropTableColumns(sess, "webhook", "owner_id"); err != nil {
  38. return err
  39. }
  40. }
  41. switch {
  42. case setting.Database.Type.IsMySQL():
  43. inferredTable, err := x.TableInfo(new(Webhook))
  44. if err != nil {
  45. return err
  46. }
  47. sqlType := x.Dialect().SQLType(inferredTable.GetColumn("org_id"))
  48. if _, err := sess.Exec("ALTER TABLE `webhook` CHANGE org_id owner_id " + sqlType); err != nil {
  49. return err
  50. }
  51. case setting.Database.Type.IsMSSQL():
  52. if _, err := sess.Exec("sp_rename 'webhook.org_id', 'owner_id', 'COLUMN'"); err != nil {
  53. return err
  54. }
  55. default:
  56. if _, err := sess.Exec("ALTER TABLE `webhook` RENAME COLUMN org_id TO owner_id"); err != nil {
  57. return err
  58. }
  59. }
  60. return sess.Commit()
  61. }