Files
cgrates/migrator/migrator_utils.go
2025-10-19 13:15:57 +02:00

111 lines
3.5 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 Affero 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 Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>
*/
package migrator
import (
"fmt"
"github.com/cgrates/cgrates/config"
"github.com/cgrates/cgrates/engine"
"github.com/cgrates/cgrates/utils"
)
var (
SUPPLIER = "Supplier"
)
func NewMigratorDataDBs(dbConnIDList []string, marshaler string,
cfg *config.CGRConfig) (db map[string]MigratorDataDB, err error) {
dataDBs := make(map[string]engine.DataDB, len(dbConnIDList))
for _, dbConnID := range dbConnIDList {
dbCon, err := engine.NewDataDBConn(cfg.DbCfg().DBConns[dbConnID].Type,
cfg.DbCfg().DBConns[dbConnID].Host, cfg.DbCfg().DBConns[dbConnID].Port,
cfg.DbCfg().DBConns[dbConnID].Name, cfg.DbCfg().DBConns[dbConnID].User,
cfg.DbCfg().DBConns[dbConnID].Password, marshaler,
cfg.DbCfg().DBConns[dbConnID].StringIndexedFields,
cfg.DbCfg().DBConns[dbConnID].PrefixIndexedFields,
cfg.MigratorCgrCfg().OutDBOpts, cfg.DbCfg().Items)
if err != nil {
return nil, err
}
dataDBs[dbConnID] = dbCon
}
dbcManager := engine.NewDBConnManager(dataDBs, cfg.DbCfg())
dm := engine.NewDataManager(dbcManager, cfg, nil)
d := make(map[string]MigratorDataDB, len(dbConnIDList))
for _, dbConnID := range dbConnIDList {
switch cfg.DbCfg().DBConns[dbConnID].Type {
case utils.MetaRedis:
d[dbConnID] = newRedisMigrator(dm)
case utils.MetaMongo:
d[dbConnID] = newMongoMigrator(dm)
case utils.MetaInternal:
d[dbConnID] = newInternalMigrator(dm)
default:
err = fmt.Errorf("unknown db '%s' valid options are '%s' or '%s or '%s'",
cfg.DbCfg().DBConns[dbConnID].Type, utils.MetaRedis, utils.MetaMongo, utils.MetaInternal)
}
}
return d, nil
}
func (m *Migrator) getVersions(str string) (vrs engine.Versions, err error) {
mInDB, err := m.GetINConn(utils.CacheVersions)
if err != nil {
return nil, err
}
dataDB, _, err := mInDB.DataManager().DBConns().GetConn(utils.CacheVersions)
if err != nil {
return nil, err
}
vrs, err = 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) {
mOutDB, err := m.GetOUTConn(utils.CacheVersions)
if err != nil {
return err
}
dataDB, _, err := mOutDB.DataManager().DBConns().GetConn(utils.CacheVersions)
if err != nil {
return err
}
vrs := engine.Versions{str: engine.CurrentDataDBVersions()[str]}
err = 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 DataDB", err.Error(), str))
}
return
}