api to rpc

This commit is contained in:
withchao
2023-02-27 14:44:14 +08:00
parent 03ccd0131a
commit 0411a5045b
9 changed files with 173 additions and 16 deletions
+28
View File
@@ -0,0 +1,28 @@
package a2r
import (
"context"
"github.com/gin-gonic/gin"
"google.golang.org/grpc"
)
// Call TEST
func Call[A, B, C, D, E any](
apiReq *A,
apiResp *B,
rpc func(client E, ctx context.Context, req C, options ...grpc.CallOption) (D, error),
client func() (E, error),
c *gin.Context,
before func(apiReq *A, rpcReq *C, bind func() error) error,
after func(rpcResp *D, apiResp *B, bind func() error) error,
) {
}
func Call1[C, D, E any](
rpc func(client E, ctx context.Context, req C, options ...grpc.CallOption) (D, error),
client func() (E, error),
c *gin.Context,
) {
}
+8 -11
View File
@@ -1,14 +1,19 @@
package group
import (
"OpenIM/internal/api2rpc"
"OpenIM/internal/a2r"
"OpenIM/pkg/apistruct"
"OpenIM/pkg/common/config"
"OpenIM/pkg/proto/group"
"context"
"github.com/OpenIMSDK/openKeeper"
"github.com/gin-gonic/gin"
)
func _() {
context.Background()
}
type Group struct {
zk *openKeeper.ZkClient
}
@@ -22,17 +27,9 @@ func (g *Group) getGroupClient() (group.GroupClient, error) {
}
func (g *Group) KickGroupMember(c *gin.Context) {
api2rpc.New(&apistruct.KickGroupMemberReq{}, &apistruct.KickGroupMemberResp{}, group.GroupClient.KickGroupMember).Call(c, g.getGroupClient)
a2r.Call(&apistruct.KickGroupMemberReq{}, &apistruct.KickGroupMemberResp{}, group.GroupClient.KickGroupMember, g.getGroupClient, c, nil, nil)
}
func (g *Group) GetGroupMembersInfo(c *gin.Context) {
api2rpc.New(&apistruct.GetGroupMembersInfoReq{}, &apistruct.GetGroupMembersInfoResp{}, group.GroupClient.GetGroupMembersInfo).Call(c, g.getGroupClient)
a2r.Call1(group.GroupClient.GetGroupMembersInfo, g.getGroupClient, c)
}
//func GetGroupMembersInfo(c *gin.Context) {
// api2rpc.New(&apistruct.GetGroupMembersInfoReq{}, &apistruct.GetGroupMembersInfoResp{}, group.GroupClient.GetGroupMembersInfo).Call(c, g.getGroupClient)
//}
//func New[A, B, C, D any, E any](apiReq *A, apiResp *B, rpc func(client E, ctx context.Context, req *C, options ...grpc.CallOption) (*D, error)) {
//
//}
+1
View File
@@ -82,6 +82,7 @@ func NewGinRouter() *gin.Engine {
c.Next()
})
{
groupRouterGroup.POST("/create_group", group.NewCreateGroup) //1
groupRouterGroup.POST("/set_group_info", group.NewSetGroupInfo) //1
groupRouterGroup.POST("/join_group", group.JoinGroup) //1
+49
View File
@@ -0,0 +1,49 @@
package api2rpc
import (
"context"
"github.com/gin-gonic/gin"
"google.golang.org/grpc"
)
type FUNC[E, C, D any] func(client E, ctx context.Context, req *C, options ...grpc.CallOption) (*D, error)
// Call1 TEST
func Call1[A, B, C, D, E any](
apiReq *A,
apiResp *B,
rpc FUNC[E, C, D],
//client func() (E, error),
c *gin.Context,
before func(apiReq *A, rpcReq *C, bind func() error) error,
after func(rpcResp *D, apiResp *B, bind func() error) error,
) {
}
func Call2[C, D, E any](
rpc func(client E, ctx context.Context, req *C, options ...grpc.CallOption) (*D, error),
client func() (E, error),
c *gin.Context,
) {
}
func Call3[C, D, E any](
rpc func(client E, ctx context.Context, req *C, options ...grpc.CallOption) (*D, error),
//client func() (E, error),
c *gin.Context,
) {
}
func Call4[C, D, E any](
rpc func(client E, ctx context.Context, req *C, options ...grpc.CallOption) (*D, error),
c *gin.Context,
) {
}
func Call10[A, B, C, D, E any](apiReq A, apiResp B, client func() (E, error), call func(client E, rpcReq C) (D, error)) {
}
+1 -1
View File
@@ -9,7 +9,7 @@ import (
type rpcFunc[E, C, D any] func(client E, ctx context.Context, req *C, options ...grpc.CallOption) (*D, error)
func New[A, B, C, D any, E any](apiReq *A, apiResp *B, rpc func(client E, ctx context.Context, req *C, options ...grpc.CallOption) (*D, error)) RpcCall[A, B, C, D, E] {
func New[A, B, C, D, E any](apiReq *A, apiResp *B, rpc func(client E, ctx context.Context, req *C, options ...grpc.CallOption) (*D, error)) RpcCall[A, B, C, D, E] {
return &rpcCall[A, B, C, D, E]{
apiReq: apiReq,
apiResp: apiResp,