department.go 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. package orm
  2. import (
  3. "net/http"
  4. "github.com/jinzhu/gorm"
  5. "gogs.carduccidante.edu.it/karmen/core/renderer"
  6. )
  7. type Department struct {
  8. gorm.Model
  9. Name string
  10. CoordinatorID uint `schema:"coordinator_id"`
  11. Coordinator *Teacher
  12. Subjects []*Subject
  13. Teachers []*Teacher
  14. AllTeachers []*Teacher `gorm:"-"`
  15. SelectedCoordinator map[uint]string `gorm:"-"`
  16. }
  17. var (
  18. selectUniqueDepartmentTeachers = `
  19. SELECT DISTINCT teachers.* FROM subjects
  20. INNER JOIN activities ON activities.subject_id=subjects.id
  21. INNER JOIN teachers ON (activities.teacher_id=teachers.id OR teachers.id=activities.supply_teacher_id)
  22. WHERE department_id=?`
  23. selectUniqueDepartmentSubjects = `
  24. SELECT * FROM subjects
  25. WHERE department_id=?`
  26. )
  27. func (d *Department) GetID() uint { return d.ID }
  28. func (d *Department) String() string {
  29. return d.Name
  30. }
  31. func (d *Department) Create(args map[string]string, r *http.Request) (interface{}, error) {
  32. if r.Method == "GET" {
  33. department := new(Department)
  34. if err := DB().Find(&department.AllTeachers).Error; err != nil {
  35. return nil, err
  36. }
  37. return department, nil
  38. } else {
  39. department := new(Department)
  40. err := renderer.Decode(department, r)
  41. if err != nil {
  42. return nil, err
  43. }
  44. department, err = CreateDepartment(department)
  45. if err != nil {
  46. return nil, err
  47. }
  48. return department, nil
  49. }
  50. }
  51. func (d *Department) Read(args map[string]string, r *http.Request) (interface{}, error) {
  52. var department Department
  53. id := args["id"]
  54. if err := DB().Preload("Coordinator").Where("id = ?", id).Find(&department).Error; err != nil {
  55. return nil, err
  56. }
  57. if err := DB().Raw(selectUniqueDepartmentTeachers, id).Scan(&department.Teachers).Error; err != nil {
  58. return nil, err
  59. }
  60. if err := DB().Raw(selectUniqueDepartmentSubjects, id).Scan(&department.Subjects).Error; err != nil {
  61. return nil, err
  62. }
  63. return &department, nil
  64. }
  65. func (d *Department) ReadAll(args map[string]string, r *http.Request) (interface{}, error) {
  66. var departments []*Department
  67. if err := DB().Preload("Coordinator").Preload("Subjects").Order("name").Find(&departments).Error; err != nil {
  68. return nil, err
  69. }
  70. for _, department := range departments {
  71. department.GetTeachers()
  72. }
  73. return departments, nil
  74. }
  75. func (d *Department) Update(args map[string]string, r *http.Request) (interface{}, error) {
  76. if r.Method == "GET" {
  77. result, err := d.Read(args, r)
  78. if err != nil {
  79. return nil, err
  80. }
  81. department := result.(*Department)
  82. if err := DB().Find(&department.AllTeachers).Error; err != nil {
  83. return nil, err
  84. }
  85. department.SelectedCoordinator = make(map[uint]string)
  86. department.SelectedCoordinator[department.CoordinatorID] = "selected"
  87. return department, nil
  88. } else {
  89. department, err := d.Read(args, r)
  90. if err != nil {
  91. return nil, err
  92. }
  93. err = renderer.Decode(department, r)
  94. if err != nil {
  95. return nil, err
  96. }
  97. _, err = SaveDepartment(department)
  98. if err != nil {
  99. return nil, err
  100. }
  101. department, err = d.Read(args, r)
  102. if err != nil {
  103. return nil, err
  104. }
  105. return department.(*Department), nil
  106. }
  107. }
  108. func (d *Department) Delete(args map[string]string, r *http.Request) (interface{}, error) {
  109. department, err := d.Read(args, r)
  110. if err != nil {
  111. return nil, err
  112. }
  113. if err := DB().Unscoped().Delete(department.(*Department)).Error; err != nil {
  114. return nil, err
  115. }
  116. return department.(*Department), nil
  117. }
  118. func SaveDepartment(department interface{}) (interface{}, error) {
  119. if err := DB().Debug().Omit("Coordinator", "Teachers", "Subjects").Save(department).Error; err != nil {
  120. return nil, err
  121. }
  122. return department, nil
  123. }
  124. func AddDepartment(args map[string]string, r *http.Request) (IDer, error) {
  125. department := new(Department)
  126. err := renderer.Decode(department, r)
  127. if err != nil {
  128. return nil, err
  129. }
  130. department, err = CreateDepartment(department)
  131. if err != nil {
  132. return nil, err
  133. }
  134. return department, nil
  135. }
  136. func CreateDepartment(department *Department) (*Department, error) {
  137. if err := DB().Create(department).Error; err != nil {
  138. return nil, err
  139. }
  140. return department, nil
  141. }
  142. func (t *Department) GetTeachers() ([]*Teacher, error) {
  143. if err := DB().Raw(selectUniqueDepartmentTeachers, t.ID).Scan(&t.Teachers).Error; err != nil {
  144. return nil, err
  145. }
  146. return t.Teachers, nil
  147. }
  148. func (t *Department) GetSubjects() ([]*Subject, error) {
  149. if err := DB().Raw(selectUniqueDepartmentSubjects, t.ID).Scan(&t.Subjects).Error; err != nil {
  150. return nil, err
  151. }
  152. return t.Subjects, nil
  153. }