/* Copyright 2020 The Qmgo Authors. Licensed 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 qmgo import ( "context" opts "github.com/qiniu/qmgo/options" "go.mongodb.org/mongo-driver/bson/bsoncodec" "go.mongodb.org/mongo-driver/mongo" "go.mongodb.org/mongo-driver/mongo/options" ) // Database is a handle to a MongoDB database type Database struct { database *mongo.Database registry *bsoncodec.Registry } // Collection gets collection from database func (d *Database) Collection(name string) *Collection { var cp *mongo.Collection cp = d.database.Collection(name) return &Collection{ collection: cp, registry: d.registry, } } // GetDatabaseName returns the name of database func (d *Database) GetDatabaseName() string { return d.database.Name() } // DropDatabase drops database func (d *Database) DropDatabase(ctx context.Context) error { return d.database.Drop(ctx) } // RunCommand executes the given command against the database. // // The runCommand parameter must be a document for the command to be executed. It cannot be nil. // This must be an order-preserving type such as bson.D. Map types such as bson.M are not valid. // If the command document contains a session ID or any transaction-specific fields, the behavior is undefined. // // The opts parameter can be used to specify options for this operation (see the options.RunCmdOptions documentation). func (d *Database) RunCommand(ctx context.Context, runCommand interface{}, opts ...opts.RunCommandOptions) *mongo.SingleResult { option := options.RunCmd() if len(opts) > 0 && opts[0].RunCmdOptions != nil { option = opts[0].RunCmdOptions } return d.database.RunCommand(ctx, runCommand, option) } // CreateCollection executes a create command to explicitly create a new collection with the specified name on the // server. If the collection being created already exists, this method will return a mongo.CommandError. This method // requires driver version 1.4.0 or higher. // // The opts parameter can be used to specify options for the operation (see the options.CreateCollectionOptions // documentation). func (db *Database) CreateCollection(ctx context.Context, name string, opts ...opts.CreateCollectionOptions) error { var option = make([]*options.CreateCollectionOptions,0,len(opts)) for _,opt := range opts{ if opt.CreateCollectionOptions != nil{ option = append(option,opt.CreateCollectionOptions) } } return db.database.CreateCollection(ctx,name,option...) }