group.go 5.5 KB

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