mongo

package
v0.3.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 23, 2021 License: MIT Imports: 19 Imported by: 0

Documentation

Index

Constants

View Source
const DefaultProviderName = "mongo"

Variables

View Source
var (
	ErrFailedReadInputFile = errors.New("could not read the input file")
)

Functions

func ErrWriteFileToDatabase

func ErrWriteFileToDatabase(fileName string) error

Types

type Config

type Config struct {
	// DSN is a connection string in form of DSN. Example:
	// mongodb://user:password@host:port/dbname.
	// Default: "mongodb://db:db@localhost:27017/db"
	DSN string `envconfig:"optional"`
	// Options is a string with additional options that will be passed
	// to connection. Default: "maxPoolSize=30&minPoolSize=10&maxIdleTimeMS=5000&ssl=false".
	Options string `envconfig:"optional"`
	// StartWatcher indicates to connection controller that it should
	// also start asynchronous connection watcher.
	StartWatcher bool `envconfig:"optional"`
	// Timeout is a timeout in seconds for connection checking. Every
	// this count of seconds database connection will be checked for
	// aliveness and, if it dies, attempt to reestablish connection
	// will be made. Default timeout is 10 seconds.
	Timeout time.Duration `envconfig:"optional"`
}

Config represents configuration structure for every connection.

func (*Config) ComposeDSN

func (c *Config) ComposeDSN() string

ComposeDSN compose DSN

func (*Config) GetDBName

func (c *Config) GetDBName() string

GetDBName return database name from DSN

func (*Config) SetDefault

func (c *Config) SetDefault() *Config

SetDefault checks connection config. If required field is empty - it will be filled with some default value. Returns a copy of config.

type Enity

type Enity struct {
	// Metrics
	stats.Service

	// Connection to database
	Conn *mongo.Client
	// contains filtered or unexported fields
}

Enity is a connection controlling structure. It controls connection, asynchronous queue and everything that related to specified connection.

func NewEnity

func NewEnity(ctx context.Context, name string, cfg interface{}) (*Enity, error)

NewEnity create new enity.

func (*Enity) GetFile

func (c *Enity) GetFile(databasename, fileName, fileprefix string) (*bytes.Buffer, int64, error)

func (*Enity) GetMetrics

func (c *Enity) GetMetrics(prefix string) stats.MapMetricsOptions

GetMetrics return map of the metrics from database connection

func (*Enity) GetReadyHandlers

func (c *Enity) GetReadyHandlers(prefix string) stats.MapCheckFunc

GetReadyHandlers return array of the readyHandlers from database connection

func (*Enity) Shutdown

func (c *Enity) Shutdown() error

Shutdown shutdowns queue worker and connection watcher. Later will also close connection to database. This is a blocking call.

func (*Enity) Start

func (c *Enity) Start() error

Start starts connection workers and connection procedure itself.

func (*Enity) WaitForEstablishing

func (c *Enity) WaitForEstablishing()

WaitForEstablishing will block execution until connection will be successfully established and database migrations will be applied (or rolled back).

func (*Enity) WriteMultipart

func (c *Enity) WriteMultipart(databasename, fileprefix string, multipartForm *multipart.Form) error

type Provider

type Provider struct {
	*providerwithmetrics.Provider
}

Provider for database mongo

func NewProvider

func NewProvider(ctx context.Context) *Provider

NewProvider creates new provider.

func (*Provider) CreateEnity

func (p *Provider) CreateEnity(enityName string, options interface{}) error

CreateEnity should create enity using passed parameters.

func (*Provider) GetEnity

func (p *Provider) GetEnity(connectionName string) (interface{}, error)

GetEnity should return pointer to connection structure to caller.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL