feat: get all staff

This commit is contained in:
ericprd 2025-03-25 18:01:14 +08:00
parent 3311b80943
commit 98b871a5ed
18 changed files with 89 additions and 7 deletions

View 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
}

View File

@ -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
}

View File

@ -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"

View 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)
})
}

View File

@ -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"

View File

@ -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"

View File

@ -9,5 +9,6 @@ var Module = fx.Module("auth-api",
Update,
GetProfile,
GetUsers,
GetStaffs,
),
)

View File

@ -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"

View File

@ -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"

View File

@ -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"

View File

@ -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"

View 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()
}

View File

@ -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
}