group.go 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284
  1. package orm
  2. import (
  3. "fmt"
  4. "net/http"
  5. "strings"
  6. "github.com/gobwas/glob"
  7. "github.com/jinzhu/gorm"
  8. "gogs.carducci-dante.gov.it/karmen/core/renderer"
  9. )
  10. type Group struct {
  11. gorm.Model
  12. Name string
  13. Query string
  14. TeacherIDs []uint `schema:"teacher_ids" gorm:"-"`
  15. Teachers []*Teacher `gorm:"many2many:group_teachers"`
  16. }
  17. type GroupForAdd struct {
  18. AllTeachers []*Teacher
  19. }
  20. type GroupForUpdate struct {
  21. Group Group
  22. AllTeachers []*Teacher
  23. SelectedTeacher map[uint]string
  24. }
  25. func (g *Group) GetID() uint { return g.ID }
  26. func GetGroups(args map[string]string) (interface{}, error) {
  27. return GetGroupsAll(args)
  28. }
  29. func GetGroupsAll(args map[string]string) (interface{}, error) {
  30. var groups []*Group
  31. if err := DB().Preload("Teachers").Order("name").Find(&groups).Error; err != nil {
  32. return nil, err
  33. }
  34. for _, group := range groups {
  35. if group.Query != "" {
  36. err := group.updateTeachersAssociation()
  37. if err != nil {
  38. return nil, err
  39. }
  40. }
  41. }
  42. return groups, nil
  43. }
  44. func GetGroupAll(args map[string]string) (interface{}, error) {
  45. var group Group
  46. id := args["id"]
  47. if err := DB().Preload("Teachers").Where("id = ?", id).Find(&group).Error; err != nil {
  48. return nil, err
  49. }
  50. if group.Query != "" {
  51. err := group.updateTeachersAssociation()
  52. if err != nil {
  53. return nil, err
  54. }
  55. }
  56. return group, nil
  57. }
  58. func GetGroupForUpdate(args map[string]string) (interface{}, error) {
  59. var data GroupForUpdate
  60. id := args["id"]
  61. if err := DB().Preload("Teachers").First(&data.Group, id).Error; err != nil {
  62. return nil, err
  63. }
  64. if err := DB().Find(&data.AllTeachers).Error; err != nil {
  65. return nil, err
  66. }
  67. data.SelectedTeacher = make(map[uint]string)
  68. for _, t := range data.Group.Teachers {
  69. data.SelectedTeacher[t.ID] = "selected"
  70. }
  71. return data, nil
  72. }
  73. func GetGroupForAdd(args map[string]string) (interface{}, error) {
  74. var data GroupForAdd
  75. if err := DB().Find(&data.AllTeachers).Error; err != nil {
  76. return nil, err
  77. }
  78. return data, nil
  79. }
  80. func GetGroup(args map[string]string) (interface{}, error) {
  81. var group Group
  82. id := args["id"]
  83. if err := DB().Preload("Teachers").Where("id = ?", id).Find(&group).Error; err != nil {
  84. return nil, err
  85. }
  86. return &group, nil
  87. }
  88. func UpdateGroup(args map[string]string, r *http.Request) (IDer, error) {
  89. group, err := GetGroup(args)
  90. if err != nil {
  91. return nil, err
  92. }
  93. err = renderer.Decode(group, r)
  94. if err != nil {
  95. return nil, err
  96. }
  97. if err := DB().Where(group.(*Group).TeacherIDs).Find(&group.(*Group).Teachers).Error; err != nil {
  98. return nil, err
  99. }
  100. teachers, err := group.(*Group).executeTeacherQuery()
  101. group.(*Group).Teachers = append(group.(*Group).Teachers, teachers...)
  102. _, err = SaveGroup(group)
  103. if err != nil {
  104. return nil, err
  105. }
  106. if err := DB().Model(group).Association("Teachers").Replace(group.(*Group).Teachers).Error; err != nil {
  107. return nil, err
  108. }
  109. group, err = GetGroup(args)
  110. if err != nil {
  111. return nil, err
  112. }
  113. return group.(*Group), nil
  114. }
  115. func SaveGroup(group interface{}) (interface{}, error) {
  116. if err := DB().Save(group).Error; err != nil {
  117. return nil, err
  118. }
  119. return group, nil
  120. }
  121. func DeleteGroup(args map[string]string, r *http.Request) (IDer, error) {
  122. group, err := GetGroup(args)
  123. if err != nil {
  124. return nil, err
  125. }
  126. if err := DB().Unscoped().Delete(group.(*Group)).Error; err != nil {
  127. return nil, err
  128. }
  129. return group.(*Group), nil
  130. }
  131. func AddGroup(args map[string]string, r *http.Request) (IDer, error) {
  132. group := new(Group)
  133. err := renderer.Decode(group, r)
  134. if err != nil {
  135. return nil, err
  136. }
  137. group, err = CreateGroup(group)
  138. if err != nil {
  139. return nil, err
  140. }
  141. return group, nil
  142. }
  143. func CreateGroup(group *Group) (*Group, error) {
  144. var groups []*Group
  145. if err := DB().Where("name=?", group.Name).Find(&groups).Error; err != nil {
  146. return nil, err
  147. }
  148. if len(groups) > 0 {
  149. return nil, fmt.Errorf("Group %s already exists!", group.Name)
  150. }
  151. if err := DB().Where(group.TeacherIDs).Find(&group.Teachers).Error; err != nil {
  152. return nil, err
  153. }
  154. teachers, err := group.executeTeacherQuery()
  155. if err != nil {
  156. return nil, err
  157. }
  158. group.Teachers = append(group.Teachers, teachers...)
  159. if err := DB().Create(group).Error; err != nil {
  160. return nil, err
  161. }
  162. return group, nil
  163. }
  164. func (group *Group) RestAPIPath() string {
  165. return "groupes"
  166. }
  167. func (group *Group) updateTeachersAssociation() error {
  168. teachers, err := group.executeTeacherQuery()
  169. if err != nil {
  170. return err
  171. }
  172. if err := DB().Model(group).Association("Teachers").Replace(teachers).Error; err != nil {
  173. return err
  174. }
  175. return nil
  176. }
  177. func (group *Group) executeTeacherQuery() ([]*Teacher, error) {
  178. var (
  179. result []*Teacher
  180. allTeachers []*Teacher
  181. )
  182. if group.Query != "" {
  183. fields := strings.Split(group.Query, " ")
  184. if err := DB().Find(&allTeachers).Error; err != nil {
  185. return nil, err
  186. }
  187. for _, field := range fields {
  188. nameValue := strings.Split(field, ":")
  189. if len(nameValue) < 2 {
  190. return nil, fmt.Errorf("Error parsing search query %s on field %s", group.Query, field)
  191. }
  192. name := nameValue[0]
  193. value := nameValue[1]
  194. switch name {
  195. case "surname":
  196. g, err := glob.Compile(value)
  197. if err != nil {
  198. return nil, err
  199. }
  200. for _, t := range allTeachers {
  201. if g.Match(t.Surname) {
  202. result = append(result, t)
  203. }
  204. }
  205. case "coordinator":
  206. for _, t := range allTeachers {
  207. c, err := t.CoordinatorClasses()
  208. if err != nil {
  209. return nil, err
  210. }
  211. if len(c) > 0 {
  212. result = append(result, t)
  213. }
  214. }
  215. }
  216. }
  217. }
  218. return result, nil
  219. }