🐛 fixed the issue that third-party login sessions were missing
This commit is contained in:
100
app/core/api/common/http/responses.go
Normal file
100
app/core/api/common/http/responses.go
Normal file
@@ -0,0 +1,100 @@
|
||||
package http
|
||||
|
||||
import (
|
||||
"context"
|
||||
"encoding/xml"
|
||||
"fmt"
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
"github.com/zeromicro/go-zero/rest/httpx"
|
||||
"net/http"
|
||||
)
|
||||
|
||||
// OkXml writes v into w with 200 OK.
|
||||
func OkXml(w http.ResponseWriter, v any) {
|
||||
WriteXml(w, http.StatusOK, v)
|
||||
}
|
||||
|
||||
// OkXmlCtx writes v into w with 200 OK.
|
||||
func OkXmlCtx(ctx context.Context, w http.ResponseWriter, v any) {
|
||||
WriteXmlCtx(ctx, w, http.StatusOK, v)
|
||||
}
|
||||
|
||||
// WriteXml writes v as xml string into w with code.
|
||||
func WriteXml(w http.ResponseWriter, code int, v any) {
|
||||
if err := doWriteXml(w, code, v); err != nil {
|
||||
logx.Error(err)
|
||||
}
|
||||
}
|
||||
|
||||
// WriteXmlCtx writes v as xml string into w with code.
|
||||
func WriteXmlCtx(ctx context.Context, w http.ResponseWriter, code int, v any) {
|
||||
if err := doWriteXml(w, code, v); err != nil {
|
||||
logx.WithContext(ctx).Error(err)
|
||||
}
|
||||
}
|
||||
|
||||
func doWriteXml(w http.ResponseWriter, code int, v any) error {
|
||||
bs, err := xml.Marshal(v)
|
||||
if err != nil {
|
||||
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||
return fmt.Errorf("marshal xml failed, error: %w", err)
|
||||
}
|
||||
|
||||
w.Header().Set(httpx.ContentType, XmlContentType)
|
||||
w.WriteHeader(code)
|
||||
|
||||
if n, err := w.Write(bs); err != nil {
|
||||
// http.ErrHandlerTimeout has been handled by http.TimeoutHandler,
|
||||
// so it's ignored here.
|
||||
if err != http.ErrHandlerTimeout {
|
||||
return fmt.Errorf("write response failed, error: %w", err)
|
||||
}
|
||||
} else if n < len(bs) {
|
||||
return fmt.Errorf("actual bytes: %d, written bytes: %d", len(bs), n)
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
// OkHTML writes v into w with 200 OK.
|
||||
func OkHTML(w http.ResponseWriter, v string) {
|
||||
WriteHTML(w, http.StatusOK, v)
|
||||
}
|
||||
|
||||
// OkHTMLCtx writes v into w with 200 OK.
|
||||
func OkHTMLCtx(ctx context.Context, w http.ResponseWriter, v string) {
|
||||
WriteHTMLCtx(ctx, w, http.StatusOK, v)
|
||||
}
|
||||
|
||||
// WriteHTML writes v as HTML string into w with code.
|
||||
func WriteHTML(w http.ResponseWriter, code int, v string) {
|
||||
if err := doWriteHTML(w, code, v); err != nil {
|
||||
logx.Error(err)
|
||||
}
|
||||
}
|
||||
|
||||
// WriteHTMLCtx writes v as HTML string into w with code.
|
||||
func WriteHTMLCtx(ctx context.Context, w http.ResponseWriter, code int, v string) {
|
||||
if err := doWriteHTML(w, code, v); err != nil {
|
||||
logx.WithContext(ctx).Error(err)
|
||||
}
|
||||
}
|
||||
|
||||
func doWriteHTML(w http.ResponseWriter, code int, v string) error {
|
||||
|
||||
w.Header().Set(httpx.ContentType, HTMLContentType)
|
||||
w.WriteHeader(code)
|
||||
|
||||
bs := []byte(v)
|
||||
if n, err := w.Write(bs); err != nil {
|
||||
// http.ErrHandlerTimeout has been handled by http.TimeoutHandler,
|
||||
// so it's ignored here.
|
||||
if err != http.ErrHandlerTimeout {
|
||||
return fmt.Errorf("write response failed, error: %w", err)
|
||||
}
|
||||
} else if n < len(bs) {
|
||||
return fmt.Errorf("actual bytes: %d, written bytes: %d", len(bs), n)
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
Reference in New Issue
Block a user