Files
cgrates/migrator/migrator_utils.go

123 lines
4.0 KiB
Go

/*
Real-time Online/Offline Charging System (OCS) for Telecom & ISP environments
Copyright (C) ITsysCOM GmbH
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>
*/
package migrator
import (
"errors"
"fmt"
"strings"
"github.com/cgrates/cgrates/config"
"github.com/cgrates/cgrates/engine"
"github.com/cgrates/cgrates/utils"
)
func NewMigratorDataDB(db_type, host, port, name, user, pass,
marshaler string, cacheCfg *config.CacheCfg, sentinelName string,
itemsCacheCfg map[string]*config.ItemOpt) (db MigratorDataDB, err error) {
dbCon, err := engine.NewDataDBConn(db_type,
host, port, name, user, pass, marshaler,
sentinelName, itemsCacheCfg)
if err != nil {
return nil, err
}
dm := engine.NewDataManager(dbCon, cacheCfg, nil)
var d MigratorDataDB
switch db_type {
case utils.REDIS:
d = newRedisMigrator(dm)
case utils.MONGO:
d = newMongoMigrator(dm)
db = d.(MigratorDataDB)
case utils.INTERNAL:
d = newInternalMigrator(dm)
db = d.(MigratorDataDB)
default:
err = errors.New(fmt.Sprintf("Unknown db '%s' valid options are '%s' or '%s or '%s'",
db_type, utils.REDIS, utils.MONGO, utils.INTERNAL))
}
return d, nil
}
func NewMigratorStorDB(db_type, host, port, name, user, pass, marshaler, sslmode string,
maxConn, maxIdleConn, connMaxLifetime int, stringIndexedFields, prefixIndexedFields []string,
itemsCacheCfg map[string]*config.ItemOpt) (db MigratorStorDB, err error) {
var d MigratorStorDB
storDb, err := engine.NewStorDBConn(db_type, host, port, name, user,
pass, marshaler, sslmode, maxConn, maxIdleConn, connMaxLifetime,
stringIndexedFields, prefixIndexedFields, itemsCacheCfg)
if err != nil {
return nil, err
}
switch db_type {
case utils.MONGO:
d = newMongoStorDBMigrator(storDb)
db = d.(MigratorStorDB)
case utils.MYSQL:
d = newMigratorSQL(storDb)
db = d.(MigratorStorDB)
case utils.POSTGRES:
d = newMigratorSQL(storDb)
db = d.(MigratorStorDB)
case utils.INTERNAL:
d = newInternalStorDBMigrator(storDb)
db = d.(MigratorStorDB)
default:
err = errors.New(fmt.Sprintf("Unknown db '%s' valid options are [%s, %s, %s, %s]",
db_type, utils.MYSQL, utils.MONGO, utils.POSTGRES, utils.INTERNAL))
}
return d, nil
}
func (m *Migrator) getVersions(str string) (vrs engine.Versions, err error) {
if str == utils.CDRs || str == utils.SessionSCosts || strings.HasPrefix(str, "Tp") {
vrs, err = m.storDBIn.StorDB().GetVersions(utils.EmptyString)
} else {
vrs, err = m.dmIN.DataManager().DataDB().GetVersions(utils.EmptyString)
}
if err != nil {
return nil, utils.NewCGRError(utils.Migrator,
utils.ServerErrorCaps,
err.Error(),
fmt.Sprintf("error: <%s> when querying oldDataDB for versions", err.Error()))
} else if len(vrs) == 0 {
return nil, utils.NewCGRError(utils.Migrator,
utils.MandatoryIEMissingCaps,
utils.UndefinedVersion,
"version number is not defined for "+str)
}
return
}
func (m *Migrator) setVersions(str string) (err error) {
if str == utils.CDRs || str == utils.SessionSCosts || strings.HasPrefix(str, "Tp") {
vrs := engine.Versions{str: engine.CurrentStorDBVersions()[str]}
err = m.storDBOut.StorDB().SetVersions(vrs, false)
} else {
vrs := engine.Versions{str: engine.CurrentDataDBVersions()[str]}
err = m.dmOut.DataManager().DataDB().SetVersions(vrs, false)
}
if err != nil {
err = utils.NewCGRError(utils.Migrator,
utils.ServerErrorCaps,
err.Error(),
fmt.Sprintf("error: <%s> when updating %s version into StorDB", err.Error(), str))
}
return
}