feat/sso-auth: added the handler

This commit is contained in:
2025-11-10 22:54:08 +07:00
parent 5aa45088f4
commit fe804dabb3
4 changed files with 172 additions and 22 deletions
@@ -0,0 +1,71 @@
package authpartner
import (
"net/http"
rw "github.com/karincake/risoles"
sf "github.com/karincake/semprit"
// ua "github.com/karincake/tumpeng/auth/svc"
e "simrs-vx/internal/domain/main-entities/auth-partner"
u "simrs-vx/internal/use-case/main-use-case/auth-partner"
)
type myBase struct{}
var O myBase
func (obj myBase) Create(w http.ResponseWriter, r *http.Request) {
dto := e.CreateDto{}
if res := rw.ValidateStructByIOR(w, r.Body, &dto); !res {
return
}
res, err := u.Create(dto)
rw.DataResponse(w, res, err)
}
func (obj myBase) GetList(w http.ResponseWriter, r *http.Request) {
dto := e.ReadListDto{}
sf.UrlQueryParam(&dto, *r.URL)
res, err := u.ReadList(dto)
rw.DataResponse(w, res, err)
}
func (obj myBase) GetDetail(w http.ResponseWriter, r *http.Request) {
id := uint16(rw.ValidateInt(w, "id", r.PathValue("id")))
if id <= 0 {
return
}
dto := e.ReadDetailDto{}
dto.Id = &id
res, err := u.ReadDetail(dto)
rw.DataResponse(w, res, err)
}
func (obj myBase) Update(w http.ResponseWriter, r *http.Request) {
id := uint16(rw.ValidateInt(w, "id", r.PathValue("id")))
if id <= 0 {
return
}
dto := e.UpdateDto{}
if res := rw.ValidateStructByIOR(w, r.Body, &dto); !res {
return
}
dto.Id = id
res, err := u.Update(dto)
rw.DataResponse(w, res, err)
}
func (obj myBase) Delete(w http.ResponseWriter, r *http.Request) {
id := uint16(rw.ValidateInt(w, "id", r.PathValue("id")))
if id <= 0 {
return
}
dto := e.DeleteDto{}
dto.Id = id
res, err := u.Delete(dto)
rw.DataResponse(w, res, err)
}
@@ -30,6 +30,30 @@ func Login(w http.ResponseWriter, r *http.Request) {
}
}
func LoginFes(w http.ResponseWriter, r *http.Request) {
var input mf.LoginDto
err := sp.IOReaderJson(&input, r.Body)
if err != nil {
rw.WriteJSON(w, http.StatusUnauthorized, d.II{"errors": err}, nil)
return
}
input.AuthPartner_Code = r.Header.Get("X-AuthPartner-Code")
input.AuthPartner_SecretKey = r.Header.Get("X-AuthPartner-SecretKey")
if err = sr.Validate(input); err != nil {
rw.WriteJSON(w, http.StatusUnauthorized, d.II{"errors": err}, nil)
return
}
// input.Position = Position
res, err := s.GenTokenFes(input)
if err != nil {
rw.WriteJSON(w, http.StatusUnauthorized, d.II{"errors": err}, nil)
} else {
rw.DataResponse(w, res, err)
}
}
func Logout(w http.ResponseWriter, r *http.Request) {
ctxVal := r.Context().Value(pa.AuthKey{})
if ctxVal == nil {
@@ -52,25 +76,3 @@ func GuardMW(next http.Handler) http.Handler {
next.ServeHTTP(w, r.WithContext(ctx))
})
}
func LoginFes(w http.ResponseWriter, r *http.Request) {
var input mf.LoginDto
err := sp.IOReaderJson(input, r.Body)
if err != nil {
rw.WriteJSON(w, http.StatusUnauthorized, d.II{"errors": err}, nil)
}
input.AuthPartner_Code = r.Header.Get("X-AuthPartner-Code")
input.AuthPartner_SecretKey = r.Header.Get("X-AuthPartner-SecretKey")
if err = (sr.Validate(input)); err != nil {
rw.WriteJSON(w, http.StatusUnauthorized, d.II{"errors": err}, nil)
}
// input.Position = Position
res, err := s.GenTokenFes(input)
if err != nil {
rw.WriteJSON(w, http.StatusUnauthorized, d.II{"errors": err}, nil)
} else {
rw.DataResponse(w, res, err)
}
}
@@ -36,6 +36,7 @@ import (
/******************** actor ********************/
authpartner "simrs-vx/internal/interface/main-handler/auth-partner"
doctor "simrs-vx/internal/interface/main-handler/doctor"
employee "simrs-vx/internal/interface/main-handler/employee"
nurse "simrs-vx/internal/interface/main-handler/nurse"
@@ -47,6 +48,7 @@ import (
personinsurance "simrs-vx/internal/interface/main-handler/person-insurance"
pharmacist "simrs-vx/internal/interface/main-handler/pharmacist"
user "simrs-vx/internal/interface/main-handler/user"
userfes "simrs-vx/internal/interface/main-handler/user-fes"
/******************** external ********************/
a "github.com/karincake/apem"
@@ -132,7 +134,9 @@ func SetRoutes() http.Handler {
r.HandleFunc("/", home.Home)
r.HandleFunc("POST /v1/authentication/login", auth.Login)
r.HandleFunc("POST /v1/authentication/login-fes", auth.LoginFes)
hk.Route("POST /v1/authentication/logout", r, auth.GuardMW, auth.Logout)
hc.RegCrud(r, "/v1/auth-partner", authpartner.O)
hc.RegCrud(r, "/v1/practice-schedule", practiceschedule.O)
hc.RegCrud(r, "/v1/counter", counter.O)
hc.RegCrud(r, "/v1/medicine-mix", medicicinemix.O)
@@ -284,6 +288,8 @@ func SetRoutes() http.Handler {
"PATCH /{id}/block": user.O.Block,
"PATCH /{id}/active": user.O.Active,
})
hc.RegCrud(r, "/v1/user-fes", userfes.O)
hk.GroupRoutes("/v1/patient", r, hk.MapHandlerFunc{
"GET /": patient.O.GetList,
"GET /{id}": patient.O.GetDetail,
@@ -0,0 +1,71 @@
package userfes
import (
"net/http"
rw "github.com/karincake/risoles"
sf "github.com/karincake/semprit"
// ua "github.com/karincake/tumpeng/auth/svc"
e "simrs-vx/internal/domain/main-entities/user-fes"
u "simrs-vx/internal/use-case/main-use-case/user-fes"
)
type myBase struct{}
var O myBase
func (obj myBase) Create(w http.ResponseWriter, r *http.Request) {
dto := e.CreateDto{}
if res := rw.ValidateStructByIOR(w, r.Body, &dto); !res {
return
}
res, err := u.Create(dto)
rw.DataResponse(w, res, err)
}
func (obj myBase) GetList(w http.ResponseWriter, r *http.Request) {
dto := e.ReadListDto{}
sf.UrlQueryParam(&dto, *r.URL)
res, err := u.ReadList(dto)
rw.DataResponse(w, res, err)
}
func (obj myBase) GetDetail(w http.ResponseWriter, r *http.Request) {
id := rw.ValidateInt(w, "id", r.PathValue("id"))
if id <= 0 {
return
}
dto := e.ReadDetailDto{}
dto.Id = uint(id)
res, err := u.ReadDetail(dto)
rw.DataResponse(w, res, err)
}
func (obj myBase) Update(w http.ResponseWriter, r *http.Request) {
id := uint16(rw.ValidateInt(w, "id", r.PathValue("id")))
if id <= 0 {
return
}
dto := e.UpdateDto{}
if res := rw.ValidateStructByIOR(w, r.Body, &dto); !res {
return
}
dto.Id = uint(id)
res, err := u.Update(dto)
rw.DataResponse(w, res, err)
}
func (obj myBase) Delete(w http.ResponseWriter, r *http.Request) {
id := rw.ValidateInt(w, "id", r.PathValue("id"))
if id <= 0 {
return
}
dto := e.DeleteDto{}
dto.Id = uint(id)
res, err := u.Delete(dto)
rw.DataResponse(w, res, err)
}