2022-02-23 06:37:52 +00:00
|
|
|
package httpserver
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/gin-gonic/gin"
|
2022-06-02 09:40:04 +00:00
|
|
|
"github.com/golang/protobuf/proto"
|
|
|
|
"github.com/milvus-io/milvus/internal/proto/commonpb"
|
2022-02-23 06:37:52 +00:00
|
|
|
"github.com/milvus-io/milvus/internal/proto/milvuspb"
|
2022-06-02 09:40:04 +00:00
|
|
|
"github.com/milvus-io/milvus/internal/proto/schemapb"
|
2022-02-23 06:37:52 +00:00
|
|
|
"github.com/milvus-io/milvus/internal/types"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Handlers handles http requests
|
|
|
|
type Handlers struct {
|
|
|
|
proxy types.ProxyComponent
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewHandlers creates a new Handlers
|
|
|
|
func NewHandlers(proxy types.ProxyComponent) *Handlers {
|
|
|
|
return &Handlers{
|
|
|
|
proxy: proxy,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// RegisterRouters registers routes to given router
|
|
|
|
func (h *Handlers) RegisterRoutesTo(router gin.IRouter) {
|
|
|
|
router.GET("/health", wrapHandler(h.handleGetHealth))
|
2022-04-29 07:15:47 +00:00
|
|
|
router.POST("/dummy", wrapHandler(h.handleDummy))
|
|
|
|
|
|
|
|
router.POST("/collection", wrapHandler(h.handleCreateCollection))
|
|
|
|
router.DELETE("/collection", wrapHandler(h.handleDropCollection))
|
|
|
|
router.GET("/collection/existence", wrapHandler(h.handleHasCollection))
|
|
|
|
router.GET("/collection", wrapHandler(h.handleDescribeCollection))
|
|
|
|
router.POST("/collection/load", wrapHandler(h.handleLoadCollection))
|
|
|
|
router.DELETE("/collection/load", wrapHandler(h.handleReleaseCollection))
|
|
|
|
router.GET("/collection/statistics", wrapHandler(h.handleGetCollectionStatistics))
|
|
|
|
router.GET("/collections", wrapHandler(h.handleShowCollections))
|
|
|
|
|
|
|
|
router.POST("/partition", wrapHandler(h.handleCreatePartition))
|
|
|
|
router.DELETE("/partition", wrapHandler(h.handleDropPartition))
|
|
|
|
router.GET("/partition/existence", wrapHandler(h.handleHasPartition))
|
|
|
|
router.POST("/partitions/load", wrapHandler(h.handleLoadPartitions))
|
|
|
|
router.DELETE("/partitions/load", wrapHandler(h.handleReleasePartitions))
|
|
|
|
router.GET("/partition/statistics", wrapHandler(h.handleGetPartitionStatistics))
|
|
|
|
router.GET("/partitions", wrapHandler(h.handleShowPartitions))
|
|
|
|
|
|
|
|
router.POST("/alias", wrapHandler(h.handleCreateAlias))
|
|
|
|
router.DELETE("/alias", wrapHandler(h.handleDropAlias))
|
|
|
|
router.PATCH("/alias", wrapHandler(h.handleAlterAlias))
|
|
|
|
|
|
|
|
router.POST("/index", wrapHandler(h.handleCreateIndex))
|
|
|
|
router.GET("/index", wrapHandler(h.handleDescribeIndex))
|
|
|
|
router.GET("/index/state", wrapHandler(h.handleGetIndexState))
|
|
|
|
router.GET("/index/progress", wrapHandler(h.handleGetIndexBuildProgress))
|
|
|
|
router.DELETE("/index", wrapHandler(h.handleDropIndex))
|
2022-03-21 03:21:23 +00:00
|
|
|
|
|
|
|
router.POST("/entities", wrapHandler(h.handleInsert))
|
|
|
|
router.DELETE("/entities", wrapHandler(h.handleDelete))
|
|
|
|
router.POST("/search", wrapHandler(h.handleSearch))
|
|
|
|
router.POST("/query", wrapHandler(h.handleQuery))
|
|
|
|
|
|
|
|
router.POST("/persist", wrapHandler(h.handleFlush))
|
|
|
|
router.GET("/distance", wrapHandler(h.handleCalcDistance))
|
2022-04-29 07:15:47 +00:00
|
|
|
router.GET("/persist/state", wrapHandler(h.handleGetFlushState))
|
|
|
|
router.GET("/persist/segment-info", wrapHandler(h.handleGetPersistentSegmentInfo))
|
|
|
|
router.GET("/query-segment-info", wrapHandler(h.handleGetQuerySegmentInfo))
|
2022-06-02 09:40:04 +00:00
|
|
|
router.GET("/replicas", wrapHandler(h.handleGetReplicas))
|
2022-04-29 07:15:47 +00:00
|
|
|
|
|
|
|
router.GET("/metrics", wrapHandler(h.handleGetMetrics))
|
|
|
|
router.POST("/load-balance", wrapHandler(h.handleLoadBalance))
|
|
|
|
router.GET("/compaction/state", wrapHandler(h.handleGetCompactionState))
|
|
|
|
router.GET("/compaction/plans", wrapHandler(h.handleGetCompactionStateWithPlans))
|
|
|
|
router.POST("/compaction", wrapHandler(h.handleManualCompaction))
|
|
|
|
|
|
|
|
router.POST("/import", wrapHandler(h.handleImport))
|
|
|
|
router.GET("/import/state", wrapHandler(h.handleGetImportState))
|
2022-06-02 09:40:04 +00:00
|
|
|
router.GET("/import/tasks", wrapHandler(h.handleListImportTasks))
|
|
|
|
|
|
|
|
router.POST("/credential", wrapHandler(h.handleCreateCredential))
|
|
|
|
router.PATCH("/credential", wrapHandler(h.handleUpdateCredential))
|
|
|
|
router.DELETE("/credential", wrapHandler(h.handleDeleteCredential))
|
|
|
|
router.GET("/credential/users", wrapHandler(h.handleListCredUsers))
|
|
|
|
|
2022-02-23 06:37:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleGetHealth(c *gin.Context) (interface{}, error) {
|
|
|
|
return gin.H{"status": "ok"}, nil
|
|
|
|
}
|
|
|
|
|
2022-04-29 07:15:47 +00:00
|
|
|
func (h *Handlers) handleDummy(c *gin.Context) (interface{}, error) {
|
2022-02-23 06:37:52 +00:00
|
|
|
req := milvuspb.DummyRequest{}
|
|
|
|
// use ShouldBind to supports binding JSON, XML, YAML, and protobuf.
|
2022-03-21 03:21:23 +00:00
|
|
|
err := shouldBind(c, &req)
|
2022-02-23 06:37:52 +00:00
|
|
|
if err != nil {
|
2022-03-21 03:21:23 +00:00
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
2022-02-23 06:37:52 +00:00
|
|
|
}
|
|
|
|
return h.proxy.Dummy(c, &req)
|
|
|
|
}
|
2022-03-21 03:21:23 +00:00
|
|
|
|
2022-06-02 09:40:04 +00:00
|
|
|
type WrappedCreateCollectionRequest struct {
|
|
|
|
// Not useful for now
|
|
|
|
Base *commonpb.MsgBase `protobuf:"bytes,1,opt,name=base,proto3" json:"base,omitempty"`
|
|
|
|
// Not useful for now
|
|
|
|
DbName string `protobuf:"bytes,2,opt,name=db_name,json=dbName,proto3" json:"db_name,omitempty"`
|
|
|
|
// The unique collection name in milvus.(Required)
|
|
|
|
CollectionName string `protobuf:"bytes,3,opt,name=collection_name,json=collectionName,proto3" json:"collection_name,omitempty"`
|
|
|
|
// The serialized `schema.CollectionSchema`(Required)
|
|
|
|
Schema schemapb.CollectionSchema `protobuf:"bytes,4,opt,name=schema,proto3" json:"schema,omitempty"`
|
|
|
|
// Once set, no modification is allowed (Optional)
|
|
|
|
// https://github.com/milvus-io/milvus/issues/6690
|
|
|
|
ShardsNum int32 `protobuf:"varint,5,opt,name=shards_num,json=shardsNum,proto3" json:"shards_num,omitempty"`
|
|
|
|
// The consistency level that the collection used, modification is not supported now.
|
|
|
|
ConsistencyLevel commonpb.ConsistencyLevel `protobuf:"varint,6,opt,name=consistency_level,json=consistencyLevel,proto3,enum=milvus.proto.common.ConsistencyLevel" json:"consistency_level,omitempty"`
|
|
|
|
}
|
|
|
|
|
2022-04-29 07:15:47 +00:00
|
|
|
func (h *Handlers) handleCreateCollection(c *gin.Context) (interface{}, error) {
|
2022-06-02 09:40:04 +00:00
|
|
|
// About why we uses WrappedCreateCollectionRequest:
|
|
|
|
// Milvus uses `bytes` as the type of `schema` field,
|
|
|
|
// while the bytes has to be serialized by proto.Marshal.
|
|
|
|
// It's very inconvenient for an HTTP clien to do this,
|
|
|
|
// so we change the type to a struct,
|
|
|
|
// and does the conversion for user.
|
|
|
|
wrappedReq := WrappedCreateCollectionRequest{}
|
|
|
|
err := shouldBind(c, &wrappedReq)
|
2022-04-29 07:15:47 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
2022-06-02 09:40:04 +00:00
|
|
|
schemaProto, err := proto.Marshal(&wrappedReq.Schema)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: marshal schema failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
req := &milvuspb.CreateCollectionRequest{
|
|
|
|
Base: wrappedReq.Base,
|
|
|
|
DbName: wrappedReq.DbName,
|
|
|
|
CollectionName: wrappedReq.CollectionName,
|
|
|
|
Schema: schemaProto,
|
|
|
|
ShardsNum: wrappedReq.ShardsNum,
|
|
|
|
ConsistencyLevel: wrappedReq.ConsistencyLevel,
|
|
|
|
}
|
|
|
|
return h.proxy.CreateCollection(c, req)
|
2022-04-29 07:15:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleDropCollection(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.DropCollectionRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.DropCollection(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleHasCollection(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.HasCollectionRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.HasCollection(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleDescribeCollection(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.DescribeCollectionRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.DescribeCollection(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleLoadCollection(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.LoadCollectionRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.LoadCollection(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleReleaseCollection(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.ReleaseCollectionRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.ReleaseCollection(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleGetCollectionStatistics(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.GetCollectionStatisticsRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.GetCollectionStatistics(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleShowCollections(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.ShowCollectionsRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.ShowCollections(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleCreatePartition(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.CreatePartitionRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.CreatePartition(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleDropPartition(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.DropPartitionRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.DropPartition(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleHasPartition(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.HasPartitionRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.HasPartition(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleLoadPartitions(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.LoadPartitionsRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.LoadPartitions(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleReleasePartitions(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.ReleasePartitionsRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.ReleasePartitions(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleGetPartitionStatistics(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.GetPartitionStatisticsRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.GetPartitionStatistics(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleShowPartitions(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.ShowPartitionsRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.ShowPartitions(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleCreateAlias(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.CreateAliasRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.CreateAlias(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleDropAlias(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.DropAliasRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.DropAlias(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleAlterAlias(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.AlterAliasRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.AlterAlias(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleCreateIndex(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.CreateIndexRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.CreateIndex(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleDescribeIndex(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.DescribeIndexRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.DescribeIndex(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleGetIndexState(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.GetIndexStateRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.GetIndexState(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleGetIndexBuildProgress(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.GetIndexBuildProgressRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.GetIndexBuildProgress(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleDropIndex(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.DropIndexRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.DropIndex(c, &req)
|
|
|
|
}
|
|
|
|
|
2022-03-21 03:21:23 +00:00
|
|
|
func (h *Handlers) handleInsert(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.InsertRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.Insert(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleDelete(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.DeleteRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.Delete(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleSearch(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.SearchRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.Search(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleQuery(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.QueryRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.Query(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleFlush(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.FlushRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.Flush(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleCalcDistance(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.CalcDistanceRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.CalcDistance(c, &req)
|
|
|
|
}
|
2022-04-29 07:15:47 +00:00
|
|
|
|
|
|
|
func (h *Handlers) handleGetFlushState(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.GetFlushStateRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.GetFlushState(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleGetPersistentSegmentInfo(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.GetPersistentSegmentInfoRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.GetPersistentSegmentInfo(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleGetQuerySegmentInfo(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.GetQuerySegmentInfoRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.GetQuerySegmentInfo(c, &req)
|
|
|
|
}
|
|
|
|
|
2022-06-02 09:40:04 +00:00
|
|
|
func (h *Handlers) handleGetReplicas(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.GetReplicasRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.GetReplicas(c, &req)
|
|
|
|
}
|
|
|
|
|
2022-04-29 07:15:47 +00:00
|
|
|
func (h *Handlers) handleGetMetrics(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.GetMetricsRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.GetMetrics(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleLoadBalance(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.LoadBalanceRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.LoadBalance(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleGetCompactionState(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.GetCompactionStateRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.GetCompactionState(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleGetCompactionStateWithPlans(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.GetCompactionPlansRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.GetCompactionStateWithPlans(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleManualCompaction(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.ManualCompactionRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.ManualCompaction(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleImport(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.ImportRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.Import(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleGetImportState(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.GetImportStateRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.GetImportState(c, &req)
|
|
|
|
}
|
2022-06-02 09:40:04 +00:00
|
|
|
|
|
|
|
func (h *Handlers) handleListImportTasks(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.ListImportTasksRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.ListImportTasks(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleCreateCredential(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.CreateCredentialRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.CreateCredential(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleUpdateCredential(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.UpdateCredentialRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.UpdateCredential(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleDeleteCredential(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.DeleteCredentialRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.DeleteCredential(c, &req)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) handleListCredUsers(c *gin.Context) (interface{}, error) {
|
|
|
|
req := milvuspb.ListCredUsersRequest{}
|
|
|
|
err := shouldBind(c, &req)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("%w: parse body failed: %v", errBadRequest, err)
|
|
|
|
}
|
|
|
|
return h.proxy.ListCredUsers(c, &req)
|
|
|
|
}
|