mirror of
https://github.com/cgrates/cgrates.git
synced 2026-02-20 14:48:43 +05:00
193 lines
9.2 KiB
Go
Executable File
193 lines
9.2 KiB
Go
Executable File
/*
|
|
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 main
|
|
|
|
import (
|
|
"flag"
|
|
"fmt"
|
|
"log"
|
|
"strings"
|
|
|
|
"github.com/cgrates/cgrates/config"
|
|
"github.com/cgrates/cgrates/engine"
|
|
"github.com/cgrates/cgrates/migrator"
|
|
"github.com/cgrates/cgrates/utils"
|
|
)
|
|
|
|
var (
|
|
sameDataDB = true
|
|
sameStorDB = true
|
|
outDataDB migrator.MigratorDataDB
|
|
storDB engine.Storage
|
|
oDBDataEncoding string
|
|
migrate = flag.String("migrate", "", "Fire up automatic migration "+
|
|
"\n <*set_versions|*cost_details|*accounts|*actions|*action_triggers|*action_plans|*shared_groups|*stordb|*datadb> ")
|
|
version = flag.Bool("version", false, "Prints the application version.")
|
|
|
|
inDataDBType = flag.String("datadb_type", config.CgrConfig().DataDbType, "The type of the DataDb Database <*redis>")
|
|
inDataDBHost = flag.String("datadb_host", utils.MetaDynamic, "The DataDb host to connect to.")
|
|
inDataDBPort = flag.String("datadb_port", utils.MetaDynamic, "The DataDb port to bind to.")
|
|
inDataDBName = flag.String("datadb_name", utils.MetaDynamic, "The name/number of the DataDb to connect to.")
|
|
inDataDBUser = flag.String("datadb_user", utils.MetaDynamic, "The DataDb user to sign in as.")
|
|
inDataDBPass = flag.String("datadb_passwd", utils.MetaDynamic, "The DataDb user's password.")
|
|
|
|
inStorDBType = flag.String("stordb_type", config.CgrConfig().StorDBType, "The type of the StorDB Database <*mysql|*postgres>")
|
|
inStorDBHost = flag.String("stordb_host", utils.MetaDynamic, "The StorDB host to connect to.")
|
|
inStorDBPort = flag.String("stordb_port", utils.MetaDynamic, "The StorDB port to bind to.")
|
|
inStorDBName = flag.String("stordb_name", utils.MetaDynamic, "The name/number of the StorDB to connect to.")
|
|
inStorDBUser = flag.String("stordb_user", utils.MetaDynamic, "The StorDB user to sign in as.")
|
|
inStorDBPass = flag.String("stordb_passwd", utils.MetaDynamic, "The StorDB user's password.")
|
|
|
|
outDataDBType = flag.String("out_datadb_type", utils.MetaDynamic, "The type of the DataDb Database <*redis|*mongo>")
|
|
outDataDBHost = flag.String("out_datadb_host", utils.MetaDynamic, "The DataDb host to connect to.")
|
|
outDataDBPort = flag.String("out_datadb_port", utils.MetaDynamic, "The DataDb port to bind to.")
|
|
outDataDBName = flag.String("out_datadb_name", utils.MetaDynamic, "The name/number of the DataDb to connect to.")
|
|
outDataDBUser = flag.String("out_datadb_user", utils.MetaDynamic, "The DataDb user to sign in as.")
|
|
outDataDBPass = flag.String("out_datadb_passwd", utils.MetaDynamic, "The DataDb user's password.")
|
|
|
|
outStorDBType = flag.String("out_stordb_type", utils.MetaDynamic, "The type of the StorDB Database <*mysql|*postgres|*mongo>")
|
|
outStorDBHost = flag.String("out_stordb_host", utils.MetaDynamic, "The StorDB host to connect to.")
|
|
outStorDBPort = flag.String("out_stordb_port", utils.MetaDynamic, "The StorDB port to bind to.")
|
|
outStorDBName = flag.String("out_stordb_name", utils.MetaDynamic, "The name/number of the StorDB to connect to.")
|
|
outStorDBUser = flag.String("out_stordb_user", utils.MetaDynamic, "The StorDB user to sign in as.")
|
|
outStorDBPass = flag.String("out_stordb_passwd", utils.MetaDynamic, "The StorDB user's password.")
|
|
|
|
loadHistorySize = flag.Int("load_history_size", config.CgrConfig().LoadHistorySize, "Limit the number of records in the load history")
|
|
|
|
datadb_versions = flag.Bool("datadb_versions", false, "Print DataDB versions")
|
|
stordb_versions = flag.Bool("stordb_versions", false, "Print StorDB versions")
|
|
|
|
dbDataEncoding = flag.String("dbData_encoding", config.CgrConfig().DBDataEncoding, "The encoding used to store object Data in strings")
|
|
inDBDataEncoding = flag.String("in_dbData_encoding", "", "The encoding used to store object Data in strings")
|
|
dryRun = flag.Bool("dry_run", false, "When true will not save loaded Data to DataDb but just parse it for consistency and errors.")
|
|
verbose = flag.Bool("verbose", false, "Enable detailed verbose logging output")
|
|
)
|
|
|
|
func main() {
|
|
flag.Parse()
|
|
if *version {
|
|
fmt.Println(utils.GetCGRVersion())
|
|
return
|
|
}
|
|
*inDataDBType = strings.TrimPrefix(*inDataDBType, "*")
|
|
*inDataDBHost = config.DBDefaults.DBHost(*inDataDBType, *inDataDBHost)
|
|
*inDataDBPort = config.DBDefaults.DBPort(*inDataDBType, *inDataDBPort)
|
|
*inDataDBName = config.DBDefaults.DBName(*inDataDBType, *inDataDBName)
|
|
*inDataDBUser = config.DBDefaults.DBUser(*inDataDBType, *inDataDBUser)
|
|
*inDataDBPass = config.DBDefaults.DBPass(*inDataDBType, *inDataDBPass)
|
|
|
|
*inStorDBType = strings.TrimPrefix(*inStorDBType, "*")
|
|
*inStorDBHost = config.DBDefaults.DBHost(*inStorDBType, *inStorDBHost)
|
|
*inStorDBPort = config.DBDefaults.DBPort(*inStorDBType, *inStorDBPort)
|
|
*inStorDBName = config.DBDefaults.DBName(*inStorDBType, *inStorDBName)
|
|
*inStorDBUser = config.DBDefaults.DBUser(*inStorDBType, *inStorDBUser)
|
|
*inStorDBPass = config.DBDefaults.DBPass(*inStorDBType, *inStorDBPass)
|
|
|
|
if *outDataDBType == utils.MetaDynamic {
|
|
*outDataDBType = *inDataDBType
|
|
*outDataDBHost = *inDataDBHost
|
|
*outDataDBPort = *inDataDBPort
|
|
*outDataDBName = *inDataDBName
|
|
*outDataDBUser = *inDataDBUser
|
|
*outDataDBPass = *inDataDBPass
|
|
} else {
|
|
*outDataDBType = strings.TrimPrefix(*outDataDBType, "*")
|
|
*outDataDBHost = config.DBDefaults.DBHost(*outDataDBType, *outDataDBHost)
|
|
*outDataDBPort = config.DBDefaults.DBPort(*outDataDBType, *outDataDBPort)
|
|
*outDataDBName = config.DBDefaults.DBName(*outDataDBType, *outDataDBName)
|
|
*outDataDBUser = config.DBDefaults.DBUser(*outDataDBType, *outDataDBUser)
|
|
*outDataDBPass = config.DBDefaults.DBPass(*outDataDBType, *outDataDBPass)
|
|
}
|
|
|
|
if *outStorDBType != utils.MetaDynamic {
|
|
*outStorDBType = strings.TrimPrefix(*outStorDBType, "*")
|
|
*outStorDBHost = config.DBDefaults.DBHost(*outStorDBType, *outStorDBHost)
|
|
*outStorDBPort = config.DBDefaults.DBPort(*outStorDBType, *outStorDBPort)
|
|
*outStorDBName = config.DBDefaults.DBName(*outStorDBType, *outStorDBName)
|
|
*outStorDBUser = config.DBDefaults.DBUser(*outStorDBType, *outStorDBUser)
|
|
*outStorDBPass = config.DBDefaults.DBPass(*outStorDBType, *outStorDBPass)
|
|
}
|
|
|
|
var dmIN *engine.DataManager
|
|
dmIN, _ = engine.ConfigureDataStorage(*inDataDBType, *inDataDBHost, *inDataDBPort,
|
|
*inDataDBName, *inDataDBUser, *inDataDBPass, *dbDataEncoding, config.CgrConfig().CacheCfg(), *loadHistorySize)
|
|
instorDB, err := engine.ConfigureStorStorage(*inStorDBType, *inStorDBHost, *inStorDBPort, *inStorDBName, *inStorDBUser, *inStorDBPass, *inDBDataEncoding,
|
|
config.CgrConfig().StorDBMaxOpenConns, config.CgrConfig().StorDBMaxIdleConns, config.CgrConfig().StorDBConnMaxLifetime, config.CgrConfig().StorDBCDRSIndexes)
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
var dmOUT *engine.DataManager
|
|
dmOUT, _ = engine.ConfigureDataStorage(*outDataDBType, *outDataDBHost, *outDataDBPort,
|
|
*outDataDBName, *outDataDBUser, *outDataDBPass, *dbDataEncoding, config.CgrConfig().CacheCfg(), *loadHistorySize)
|
|
outDataDB, err := migrator.ConfigureV1DataStorage(*outDataDBType, *outDataDBHost, *outDataDBPort, *outDataDBName, *outDataDBUser, *outDataDBPass, *dbDataEncoding)
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
|
|
if *outStorDBType == utils.MetaDynamic {
|
|
storDB = instorDB
|
|
} else {
|
|
storDB, err = engine.ConfigureStorStorage(*outStorDBType, *outStorDBHost, *outStorDBPort, *outStorDBName, *outStorDBUser, *outStorDBPass, *dbDataEncoding,
|
|
config.CgrConfig().StorDBMaxOpenConns, config.CgrConfig().StorDBMaxIdleConns, config.CgrConfig().StorDBConnMaxLifetime, config.CgrConfig().StorDBCDRSIndexes)
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
}
|
|
if *inDataDBName != *outDataDBName || *inDataDBType != *outDataDBType || *inDataDBHost != *outDataDBHost {
|
|
sameDataDB = false
|
|
}
|
|
if *inStorDBName != *outStorDBName || *inStorDBType != *outStorDBName || *inStorDBHost != *outStorDBHost {
|
|
sameStorDB = false
|
|
}
|
|
m, err := migrator.NewMigrator(dmIN, dmOUT, *inDataDBType, *dbDataEncoding, storDB, *inStorDBType, outDataDB,
|
|
*outDataDBType, *inDBDataEncoding, instorDB, *outStorDBType, *dryRun, sameDataDB, sameStorDB, *datadb_versions, *stordb_versions)
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
if *datadb_versions {
|
|
vrs, _ := dmOUT.DataDB().GetVersions(utils.TBLVersions)
|
|
if len(vrs) != 0 {
|
|
log.Printf("DataDB versions : %+v\n", vrs)
|
|
} else {
|
|
log.Printf("DataDB versions not_found")
|
|
}
|
|
}
|
|
if *stordb_versions {
|
|
vrs, _ := storDB.GetVersions(utils.TBLVersions)
|
|
if len(vrs) != 0 {
|
|
log.Printf("StorDB versions : %+v\n", vrs)
|
|
} else {
|
|
log.Printf("StorDB versions not_found")
|
|
}
|
|
}
|
|
if migrate != nil && *migrate != "" { // Run migrator
|
|
migrstats := make(map[string]int)
|
|
mig := strings.Split(*migrate, ",")
|
|
err, migrstats = m.Migrate(mig)
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
if *verbose != false {
|
|
log.Printf("Data migrated: %+v", migrstats)
|
|
}
|
|
return
|
|
}
|
|
|
|
}
|