// Code generated by protoc-gen-go-http. DO NOT EDIT.
// versions:
// - protoc-gen-go-http v2.7.3
// - protoc             v5.27.1
// source: matchmaking/v1/virtually/second.proto

package v1

import (
	context "context"
	http "github.com/go-kratos/kratos/v2/transport/http"
	binding "github.com/go-kratos/kratos/v2/transport/http/binding"
)

// This is a compile-time assertion to ensure that this generated file
// is compatible with the kratos package it is being compiled against.
var _ = new(context.Context)
var _ = binding.EncodeURL

const _ = http.SupportPackageIsVersion1

const OperationSecondSecondGetBotContractTrade = "/matchmaking.v1.Second/SecondGetBotContractTrade"
const OperationSecondSecondOrder = "/matchmaking.v1.Second/SecondOrder"

type SecondHTTPServer interface {
	// SecondGetBotContractTrade SecondGetBotContractTrade 合约列表查询
	SecondGetBotContractTrade(context.Context, *GetBotSecondTradeRequest) (*GetBotSecondTradeReply, error)
	// SecondOrder SecondOrder 秒合约下单
	SecondOrder(context.Context, *SecondOrderRequest) (*SecondOrderReply, error)
}

func RegisterSecondHTTPServer(s *http.Server, srv SecondHTTPServer) {
	r := s.Route("/")
	r.POST("/order_second/second_list", _Second_SecondGetBotContractTrade0_HTTP_Handler(srv))
	r.POST("/order_second/contract_second_order", _Second_SecondOrder0_HTTP_Handler(srv))
}

func _Second_SecondGetBotContractTrade0_HTTP_Handler(srv SecondHTTPServer) func(ctx http.Context) error {
	return func(ctx http.Context) error {
		var in GetBotSecondTradeRequest
		if err := ctx.Bind(&in); err != nil {
			return err
		}
		if err := ctx.BindQuery(&in); err != nil {
			return err
		}
		http.SetOperation(ctx, OperationSecondSecondGetBotContractTrade)
		h := ctx.Middleware(func(ctx context.Context, req interface{}) (interface{}, error) {
			return srv.SecondGetBotContractTrade(ctx, req.(*GetBotSecondTradeRequest))
		})
		out, err := h(ctx, &in)
		if err != nil {
			return err
		}
		reply := out.(*GetBotSecondTradeReply)
		return ctx.Result(200, reply)
	}
}

func _Second_SecondOrder0_HTTP_Handler(srv SecondHTTPServer) func(ctx http.Context) error {
	return func(ctx http.Context) error {
		var in SecondOrderRequest
		if err := ctx.Bind(&in); err != nil {
			return err
		}
		if err := ctx.BindQuery(&in); err != nil {
			return err
		}
		http.SetOperation(ctx, OperationSecondSecondOrder)
		h := ctx.Middleware(func(ctx context.Context, req interface{}) (interface{}, error) {
			return srv.SecondOrder(ctx, req.(*SecondOrderRequest))
		})
		out, err := h(ctx, &in)
		if err != nil {
			return err
		}
		reply := out.(*SecondOrderReply)
		return ctx.Result(200, reply)
	}
}

type SecondHTTPClient interface {
	SecondGetBotContractTrade(ctx context.Context, req *GetBotSecondTradeRequest, opts ...http.CallOption) (rsp *GetBotSecondTradeReply, err error)
	SecondOrder(ctx context.Context, req *SecondOrderRequest, opts ...http.CallOption) (rsp *SecondOrderReply, err error)
}

type SecondHTTPClientImpl struct {
	cc *http.Client
}

func NewSecondHTTPClient(client *http.Client) SecondHTTPClient {
	return &SecondHTTPClientImpl{client}
}

func (c *SecondHTTPClientImpl) SecondGetBotContractTrade(ctx context.Context, in *GetBotSecondTradeRequest, opts ...http.CallOption) (*GetBotSecondTradeReply, error) {
	var out GetBotSecondTradeReply
	pattern := "/order_second/second_list"
	path := binding.EncodeURL(pattern, in, false)
	opts = append(opts, http.Operation(OperationSecondSecondGetBotContractTrade))
	opts = append(opts, http.PathTemplate(pattern))
	err := c.cc.Invoke(ctx, "POST", path, in, &out, opts...)
	if err != nil {
		return nil, err
	}
	return &out, nil
}

func (c *SecondHTTPClientImpl) SecondOrder(ctx context.Context, in *SecondOrderRequest, opts ...http.CallOption) (*SecondOrderReply, error) {
	var out SecondOrderReply
	pattern := "/order_second/contract_second_order"
	path := binding.EncodeURL(pattern, in, false)
	opts = append(opts, http.Operation(OperationSecondSecondOrder))
	opts = append(opts, http.PathTemplate(pattern))
	err := c.cc.Invoke(ctx, "POST", path, in, &out, opts...)
	if err != nil {
		return nil, err
	}
	return &out, nil
}