group.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. package orm
  2. import (
  3. "fmt"
  4. "log"
  5. "net/http"
  6. "github.com/jinzhu/gorm"
  7. "gogs.carducci-dante.gov.it/karmen/core/renderer"
  8. )
  9. type Group struct {
  10. gorm.Model
  11. Name string
  12. Search string
  13. TeacherIDs []uint `schema:"teacher_ids" gorm:"-"`
  14. Teachers []*Teacher `gorm:"many2many:group_teachers"`
  15. }
  16. type GroupForAdd struct {
  17. AllTeachers []*Teacher
  18. }
  19. type GroupForUpdate struct {
  20. Group Group
  21. AllTeachers []*Teacher
  22. SelectedTeacher map[uint]string
  23. }
  24. func (g *Group) GetID() uint { return g.ID }
  25. func GetGroupsAll(args map[string]string) (interface{}, error) {
  26. var groups []*Group
  27. if err := DB().Debug().Preload("Teachers").Order("name").Find(&groups).Error; err != nil {
  28. return nil, err
  29. }
  30. return groups, nil
  31. }
  32. func GetGroupAll(args map[string]string) (interface{}, error) {
  33. var group Group
  34. id := args["id"]
  35. if err := DB().Preload("Teachers").Where("id = ?", id).Find(&group).Error; err != nil {
  36. return nil, err
  37. }
  38. return group, nil
  39. }
  40. func GetGroupForUpdate(args map[string]string) (interface{}, error) {
  41. var data GroupForUpdate
  42. id := args["id"]
  43. if err := DB().Preload("Teachers").First(&data.Group, id).Error; err != nil {
  44. return nil, err
  45. }
  46. if err := DB().Find(&data.AllTeachers).Error; err != nil {
  47. return nil, err
  48. }
  49. data.SelectedTeacher = make(map[uint]string)
  50. for _, t := range data.Group.Teachers {
  51. data.SelectedTeacher[t.ID] = "selected"
  52. }
  53. return data, nil
  54. }
  55. func GetGroupForAdd(args map[string]string) (interface{}, error) {
  56. var data GroupForAdd
  57. if err := DB().Find(&data.AllTeachers).Error; err != nil {
  58. return nil, err
  59. }
  60. return data, nil
  61. }
  62. func GetGroup(args map[string]string) (interface{}, error) {
  63. var group Group
  64. id := args["id"]
  65. if err := DB().Preload("Teachers").Where("id = ?", id).Find(&group).Error; err != nil {
  66. return nil, err
  67. }
  68. return &group, nil
  69. }
  70. func UpdateGroup(args map[string]string, r *http.Request) (IDer, error) {
  71. group, err := GetGroup(args)
  72. if err != nil {
  73. return nil, err
  74. }
  75. log.Println("Before decoding...", group.(*Group).TeacherIDs)
  76. err = renderer.Decode(group, r)
  77. if err != nil {
  78. return nil, err
  79. }
  80. if err := DB().Where(group.(*Group).TeacherIDs).Find(&group.(*Group).Teachers).Error; err != nil {
  81. return nil, err
  82. }
  83. log.Println("After decoding...", group.(*Group).TeacherIDs)
  84. _, err = SaveGroup(group)
  85. if err != nil {
  86. return nil, err
  87. }
  88. group, err = GetGroup(args)
  89. if err != nil {
  90. return nil, err
  91. }
  92. return group.(*Group), nil
  93. }
  94. func SaveGroup(group interface{}) (interface{}, error) {
  95. if err := DB().Save(group).Error; err != nil {
  96. return nil, err
  97. }
  98. return group, nil
  99. }
  100. func DeleteGroup(args map[string]string, r *http.Request) (IDer, error) {
  101. return nil, nil
  102. }
  103. func AddGroup(args map[string]string, r *http.Request) (IDer, error) {
  104. group := new(Group)
  105. err := renderer.Decode(group, r)
  106. if err != nil {
  107. return nil, err
  108. }
  109. group, err = CreateGroup(group)
  110. if err != nil {
  111. return nil, err
  112. }
  113. return group, nil
  114. }
  115. func CreateGroup(group *Group) (*Group, error) {
  116. var groups []*Group
  117. if err := DB().Where("name=?", group.Name).Find(&groups).Error; err != nil {
  118. return nil, err
  119. }
  120. if len(groups) > 0 {
  121. return nil, fmt.Errorf("Group %s already exists!", group.Name)
  122. }
  123. if err := DB().Where(group.TeacherIDs).Find(&group.Teachers).Error; err != nil {
  124. return nil, err
  125. }
  126. if err := DB().Create(group).Error; err != nil {
  127. return nil, err
  128. }
  129. return group, nil
  130. }