feat: Implement Steam login initialization logic
Some checks failed
CI - Build and Push / Build and Push Docker Image (push) Failing after 32s
Some checks failed
CI - Build and Push / Build and Push Docker Image (push) Failing after 32s
- Added SteamLoginInitLogic to handle the initiation of Steam login. - Created service context for managing configuration and Redis connection. - Defined types for Steam login requests and callbacks. - Implemented utility functions for building OpenID query strings and validating responses from Steam. - Updated go.mod and go.sum to include necessary dependencies. - Modified GenApi.ps1 script to generate code in the correct directory.
This commit is contained in:
29
app/internal/handler/pinghandler.go
Normal file
29
app/internal/handler/pinghandler.go
Normal file
@@ -0,0 +1,29 @@
|
||||
package handler
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
|
||||
"git.cialloo.com/CiallooWeb/Authenticator/app/internal/logic"
|
||||
"git.cialloo.com/CiallooWeb/Authenticator/app/internal/svc"
|
||||
"git.cialloo.com/CiallooWeb/Authenticator/app/internal/types"
|
||||
"github.com/zeromicro/go-zero/rest/httpx"
|
||||
)
|
||||
|
||||
// Ping the server to check if it's alive
|
||||
func pingHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
|
||||
return func(w http.ResponseWriter, r *http.Request) {
|
||||
var req types.PingReq
|
||||
if err := httpx.Parse(r, &req); err != nil {
|
||||
httpx.ErrorCtx(r.Context(), w, err)
|
||||
return
|
||||
}
|
||||
|
||||
l := logic.NewPingLogic(r.Context(), svcCtx)
|
||||
resp, err := l.Ping(&req)
|
||||
if err != nil {
|
||||
httpx.ErrorCtx(r.Context(), w, err)
|
||||
} else {
|
||||
httpx.OkJsonCtx(r.Context(), w, resp)
|
||||
}
|
||||
}
|
||||
}
|
||||
38
app/internal/handler/routes.go
Normal file
38
app/internal/handler/routes.go
Normal file
@@ -0,0 +1,38 @@
|
||||
// Code generated by goctl. DO NOT EDIT.
|
||||
// goctl 1.8.4
|
||||
|
||||
package handler
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
|
||||
"git.cialloo.com/CiallooWeb/Authenticator/app/internal/svc"
|
||||
|
||||
"github.com/zeromicro/go-zero/rest"
|
||||
)
|
||||
|
||||
func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) {
|
||||
server.AddRoutes(
|
||||
[]rest.Route{
|
||||
{
|
||||
// Ping the server to check if it's alive
|
||||
Method: http.MethodGet,
|
||||
Path: "/ping",
|
||||
Handler: pingHandler(serverCtx),
|
||||
},
|
||||
{
|
||||
// Steam login callback
|
||||
Method: http.MethodGet,
|
||||
Path: "/steam/callback",
|
||||
Handler: steamLoginCallbackHandler(serverCtx),
|
||||
},
|
||||
{
|
||||
// Initiate Steam login
|
||||
Method: http.MethodGet,
|
||||
Path: "/steam/login",
|
||||
Handler: steamLoginInitHandler(serverCtx),
|
||||
},
|
||||
},
|
||||
rest.WithPrefix("/api/authenticator"),
|
||||
)
|
||||
}
|
||||
29
app/internal/handler/steamlogincallbackhandler.go
Normal file
29
app/internal/handler/steamlogincallbackhandler.go
Normal file
@@ -0,0 +1,29 @@
|
||||
package handler
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
|
||||
"git.cialloo.com/CiallooWeb/Authenticator/app/internal/logic"
|
||||
"git.cialloo.com/CiallooWeb/Authenticator/app/internal/svc"
|
||||
"git.cialloo.com/CiallooWeb/Authenticator/app/internal/types"
|
||||
|
||||
"github.com/zeromicro/go-zero/rest/httpx"
|
||||
)
|
||||
|
||||
// Steam login callback
|
||||
func steamLoginCallbackHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
|
||||
return func(w http.ResponseWriter, r *http.Request) {
|
||||
var req types.SteamLoginCallbackReq
|
||||
if err := httpx.Parse(r, &req); err != nil {
|
||||
httpx.ErrorCtx(r.Context(), w, err)
|
||||
return
|
||||
}
|
||||
|
||||
l := logic.NewSteamLoginCallbackLogic(r.Context(), svcCtx)
|
||||
err := l.SteamLoginCallback(&req, w, r)
|
||||
if err != nil {
|
||||
httpx.ErrorCtx(r.Context(), w, err)
|
||||
}
|
||||
// No response needed - redirect is handled in logic
|
||||
}
|
||||
}
|
||||
29
app/internal/handler/steamlogininithandler.go
Normal file
29
app/internal/handler/steamlogininithandler.go
Normal file
@@ -0,0 +1,29 @@
|
||||
package handler
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
|
||||
"git.cialloo.com/CiallooWeb/Authenticator/app/internal/logic"
|
||||
"git.cialloo.com/CiallooWeb/Authenticator/app/internal/svc"
|
||||
"git.cialloo.com/CiallooWeb/Authenticator/app/internal/types"
|
||||
|
||||
"github.com/zeromicro/go-zero/rest/httpx"
|
||||
)
|
||||
|
||||
// Initiate Steam login
|
||||
func steamLoginInitHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
|
||||
return func(w http.ResponseWriter, r *http.Request) {
|
||||
var req types.SteamLoginInitReq
|
||||
if err := httpx.Parse(r, &req); err != nil {
|
||||
httpx.ErrorCtx(r.Context(), w, err)
|
||||
return
|
||||
}
|
||||
|
||||
l := logic.NewSteamLoginInitLogic(r.Context(), svcCtx)
|
||||
err := l.SteamLoginInit(&req, w, r)
|
||||
if err != nil {
|
||||
httpx.ErrorCtx(r.Context(), w, err)
|
||||
}
|
||||
// No response needed - redirect is handled in logic
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user