// Licensed to the LF AI & Data foundation under one // or more contributor license agreements. See the NOTICE file // distributed with this work for additional information // regarding copyright ownership. The ASF licenses this file // to you under the Apache License, Version 2.0 (the // "License"); you may not use this file except in compliance // with the License. You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package rootcoord import ( "fmt" "golang.org/x/exp/maps" "github.com/milvus-io/milvus/pkg/util" "github.com/milvus-io/milvus/pkg/util/typeutil" ) type nameDb struct { db2Name2ID map[string]map[string]UniqueID // database -> collection name -> collection id totalCollectionNum int totalPartitionNum int } func (n *nameDb) exist(dbName string) bool { _, ok := n.db2Name2ID[dbName] return ok } func (n *nameDb) empty(dbName string) bool { db, ok := n.db2Name2ID[dbName] return ok && len(db) == 0 } func (n *nameDb) createDbIfNotExist(dbName string) { if !n.exist(dbName) { n.db2Name2ID[dbName] = make(map[string]UniqueID) } } func (n *nameDb) dropDb(dbName string) { delete(n.db2Name2ID, dbName) } func (n *nameDb) insert(dbName string, collectionName string, collectionID UniqueID) { if dbName == "" { dbName = util.DefaultDBName } n.createDbIfNotExist(dbName) n.db2Name2ID[dbName][collectionName] = collectionID } func (n *nameDb) get(dbName string, collectionName string) (collectionID UniqueID, ok bool) { if !n.exist(dbName) { return 0, false } collectionID, ok = n.db2Name2ID[dbName][collectionName] return collectionID, ok } func (n *nameDb) listDB() []string { dbs := make([]string, 0, len(n.db2Name2ID)) for db := range n.db2Name2ID { dbs = append(dbs, db) } return dbs } func (n *nameDb) listCollections(dbName string) map[string]UniqueID { res, ok := n.db2Name2ID[dbName] if ok { return res } return map[string]UniqueID{} } func (n *nameDb) listCollectionID(dbName string) ([]typeutil.UniqueID, error) { name2ID, ok := n.db2Name2ID[dbName] if !ok { return nil, fmt.Errorf("database not exist: %s", dbName) } return maps.Values(name2ID), nil } func (n *nameDb) removeIf(selector func(db string, collection string, id UniqueID) bool) { type union struct { db string collection string id UniqueID } matches := make([]union, 0, len(n.db2Name2ID)) for dbName, db := range n.db2Name2ID { for collection, id := range db { if selector(dbName, collection, id) { matches = append(matches, union{ db: dbName, collection: collection, id: id, }) } } } for _, match := range matches { delete(n.db2Name2ID[match.db], match.collection) } } func (n *nameDb) remove(db, collection string) { if n.exist(db) { delete(n.db2Name2ID[db], collection) } } func (n *nameDb) iterate(exitOnFalse func(db string, collection string, id UniqueID) bool) { for dbName, db := range n.db2Name2ID { for collection, id := range db { if !exitOnFalse(dbName, collection, id) { return } } } } func newNameDb() *nameDb { return &nameDb{ db2Name2ID: make(map[string]map[string]typeutil.UniqueID), } }