feat: get all staff
This commit is contained in:
parent
3311b80943
commit
98b871a5ed
13
internal/accessor/staff/get_staff.go
Normal file
13
internal/accessor/staff/get_staff.go
Normal file
@ -0,0 +1,13 @@
|
||||
package staffrepository
|
||||
|
||||
import staffdomain "legalgo-BE-go/internal/domain/staff"
|
||||
|
||||
func (a *accessor) GetStaffs() ([]staffdomain.StaffProfile, error) {
|
||||
var staffs []staffdomain.StaffProfile
|
||||
|
||||
if err := a.db.Table("staffs").Find(&staffs).Error; err != nil {
|
||||
return staffs, err
|
||||
}
|
||||
|
||||
return staffs, nil
|
||||
}
|
||||
@ -14,6 +14,7 @@ type Staff interface {
|
||||
GetStaffByEmail(string) (*staffdomain.Staff, error)
|
||||
GetStaffByID(string) (*staffdomain.Staff, error)
|
||||
GetUsers() ([]userdomain.UserProfile, error)
|
||||
GetStaffs() ([]staffdomain.StaffProfile, error)
|
||||
Create(staffdomain.Staff) error
|
||||
Update(staffdomain.Staff) error
|
||||
}
|
||||
|
||||
@ -5,7 +5,7 @@ import (
|
||||
authmiddleware "legalgo-BE-go/internal/api/http/middleware/auth"
|
||||
newsdomain "legalgo-BE-go/internal/domain/news"
|
||||
newssvc "legalgo-BE-go/internal/services/news"
|
||||
staffsvc "legalgo-BE-go/internal/services/staffsvc"
|
||||
staffsvc "legalgo-BE-go/internal/services/staff"
|
||||
"legalgo-BE-go/internal/utilities/response"
|
||||
"legalgo-BE-go/internal/utilities/utils"
|
||||
"net/http"
|
||||
|
||||
59
internal/api/http/staff/get_staffs.go
Normal file
59
internal/api/http/staff/get_staffs.go
Normal file
@ -0,0 +1,59 @@
|
||||
package staffhttp
|
||||
|
||||
import (
|
||||
authmiddleware "legalgo-BE-go/internal/api/http/middleware/auth"
|
||||
staffsvc "legalgo-BE-go/internal/services/staff"
|
||||
"legalgo-BE-go/internal/utilities/response"
|
||||
"legalgo-BE-go/internal/utilities/utils"
|
||||
"net/http"
|
||||
|
||||
"github.com/go-chi/chi/v5"
|
||||
)
|
||||
|
||||
func GetStaffs(
|
||||
router chi.Router,
|
||||
staffSvc staffsvc.Auth,
|
||||
) {
|
||||
router.With(authmiddleware.Authorize()).Get("/staff/get-all", func(w http.ResponseWriter, r *http.Request) {
|
||||
ctx := r.Context()
|
||||
staffDetail, err := utils.GetTokenDetail(r)
|
||||
if err != nil {
|
||||
response.RespondJsonErrorWithCode(
|
||||
ctx,
|
||||
w,
|
||||
err,
|
||||
response.ErrBadRequest.Code,
|
||||
response.ErrBadRequest.HttpCode,
|
||||
"failed to get staff token",
|
||||
)
|
||||
return
|
||||
}
|
||||
|
||||
if staffDetail.Role != "staff" {
|
||||
response.RespondJsonErrorWithCode(
|
||||
ctx,
|
||||
w,
|
||||
err,
|
||||
response.ErrUnauthorized.Code,
|
||||
response.ErrUnauthorized.HttpCode,
|
||||
"unauthorized",
|
||||
)
|
||||
return
|
||||
}
|
||||
|
||||
staffs, err := staffSvc.GetStaffs()
|
||||
if err != nil {
|
||||
response.RespondJsonErrorWithCode(
|
||||
ctx,
|
||||
w,
|
||||
err,
|
||||
response.ErrBadRequest.Code,
|
||||
response.ErrBadRequest.HttpCode,
|
||||
err.Error(),
|
||||
)
|
||||
return
|
||||
}
|
||||
|
||||
response.RespondJsonSuccess(ctx, w, staffs)
|
||||
})
|
||||
}
|
||||
@ -2,7 +2,7 @@ package staffhttp
|
||||
|
||||
import (
|
||||
authmiddleware "legalgo-BE-go/internal/api/http/middleware/auth"
|
||||
staffsvc "legalgo-BE-go/internal/services/staffsvc"
|
||||
staffsvc "legalgo-BE-go/internal/services/staff"
|
||||
"legalgo-BE-go/internal/utilities/response"
|
||||
"legalgo-BE-go/internal/utilities/utils"
|
||||
"net/http"
|
||||
|
||||
@ -5,7 +5,7 @@ import (
|
||||
|
||||
responsedomain "legalgo-BE-go/internal/domain/reponse"
|
||||
staffdomain "legalgo-BE-go/internal/domain/staff"
|
||||
staffsvc "legalgo-BE-go/internal/services/staffsvc"
|
||||
staffsvc "legalgo-BE-go/internal/services/staff"
|
||||
"legalgo-BE-go/internal/utilities/response"
|
||||
"legalgo-BE-go/internal/utilities/utils"
|
||||
|
||||
|
||||
@ -9,5 +9,6 @@ var Module = fx.Module("auth-api",
|
||||
Update,
|
||||
GetProfile,
|
||||
GetUsers,
|
||||
GetStaffs,
|
||||
),
|
||||
)
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
package staffhttp
|
||||
|
||||
import (
|
||||
staffsvc "legalgo-BE-go/internal/services/staffsvc"
|
||||
staffsvc "legalgo-BE-go/internal/services/staff"
|
||||
"legalgo-BE-go/internal/utilities/response"
|
||||
"legalgo-BE-go/internal/utilities/utils"
|
||||
"net/http"
|
||||
|
||||
@ -4,7 +4,7 @@ import (
|
||||
"net/http"
|
||||
|
||||
staffdomain "legalgo-BE-go/internal/domain/staff"
|
||||
staffsvc "legalgo-BE-go/internal/services/staffsvc"
|
||||
staffsvc "legalgo-BE-go/internal/services/staff"
|
||||
"legalgo-BE-go/internal/utilities/response"
|
||||
"legalgo-BE-go/internal/utilities/utils"
|
||||
|
||||
|
||||
@ -2,7 +2,7 @@ package staffhttp
|
||||
|
||||
import (
|
||||
staffdomain "legalgo-BE-go/internal/domain/staff"
|
||||
staffsvc "legalgo-BE-go/internal/services/staffsvc"
|
||||
staffsvc "legalgo-BE-go/internal/services/staff"
|
||||
"legalgo-BE-go/internal/utilities/response"
|
||||
"legalgo-BE-go/internal/utilities/utils"
|
||||
"net/http"
|
||||
|
||||
@ -6,7 +6,7 @@ import (
|
||||
logssvc "legalgo-BE-go/internal/services/logs"
|
||||
newssvc "legalgo-BE-go/internal/services/news"
|
||||
"legalgo-BE-go/internal/services/oss"
|
||||
staffsvc "legalgo-BE-go/internal/services/staffsvc"
|
||||
staffsvc "legalgo-BE-go/internal/services/staff"
|
||||
subscribesvc "legalgo-BE-go/internal/services/subscribe"
|
||||
subscribeplansvc "legalgo-BE-go/internal/services/subscribe_plan"
|
||||
tagsvc "legalgo-BE-go/internal/services/tag"
|
||||
|
||||
7
internal/services/staff/get_staffs.go
Normal file
7
internal/services/staff/get_staffs.go
Normal file
@ -0,0 +1,7 @@
|
||||
package staffsvc
|
||||
|
||||
import staffdomain "legalgo-BE-go/internal/domain/staff"
|
||||
|
||||
func (i *impl) GetStaffs() ([]staffdomain.StaffProfile, error) {
|
||||
return i.staffRepo.GetStaffs()
|
||||
}
|
||||
@ -20,6 +20,7 @@ type Auth interface {
|
||||
Login(staffdomain.StaffLogin) (string, error)
|
||||
Register(staffdomain.StaffRegister) (string, error)
|
||||
GetProfile(string) (*staffdomain.StaffProfile, error)
|
||||
GetStaffs() ([]staffdomain.StaffProfile, error)
|
||||
GetUsers() ([]userdomain.UserProfile, error)
|
||||
Update(string, staffdomain.StaffUpdate) error
|
||||
}
|
||||
Loading…
x
Reference in New Issue
Block a user