mirror of
https://github.com/cgrates/cgrates.git
synced 2026-02-12 18:46:24 +05:00
170 lines
6.5 KiB
Go
170 lines
6.5 KiB
Go
/*
|
|
Rating system designed to be used in VoIP Carriers World
|
|
Copyright (C) 2013 ITsysCOM
|
|
|
|
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 (
|
|
"encoding/gob"
|
|
"flag"
|
|
"fmt"
|
|
"github.com/cgrates/cgrates/config"
|
|
"github.com/cgrates/cgrates/engine"
|
|
"github.com/cgrates/cgrates/history"
|
|
"github.com/cgrates/cgrates/utils"
|
|
"log"
|
|
"path"
|
|
)
|
|
|
|
var (
|
|
//separator = flag.String("separator", ",", "Default field separator")
|
|
cgrConfig, _ = config.NewDefaultCGRConfig()
|
|
data_db_type = flag.String("datadb_type", cgrConfig.DataDBType, "The type of the dataDb database (redis|mongo|postgres|mysql)")
|
|
data_db_host = flag.String("datadb_host", cgrConfig.DataDBHost, "The dataDb host to connect to.")
|
|
data_db_port = flag.String("datadb_port", cgrConfig.DataDBPort, "The dataDb port to bind to.")
|
|
data_db_name = flag.String("datadb_name", cgrConfig.DataDBName, "The name/number of the dataDb to connect to.")
|
|
data_db_user = flag.String("datadb_user", cgrConfig.DataDBUser, "The dataDb user to sign in as.")
|
|
data_db_pass = flag.String("datadb_passwd", cgrConfig.DataDBPass, "The dataDb user's password.")
|
|
|
|
stor_db_type = flag.String("stordb_type", cgrConfig.StorDBType, "The type of the storDb database (redis|mongo|postgres|mysql)")
|
|
stor_db_host = flag.String("stordb_host", cgrConfig.StorDBHost, "The storDb host to connect to.")
|
|
stor_db_port = flag.String("stordb_port", cgrConfig.StorDBPort, "The storDb port to bind to.")
|
|
stor_db_name = flag.String("stordb_name", cgrConfig.StorDBName, "The name/number of the storDb to connect to.")
|
|
stor_db_user = flag.String("stordb_user", cgrConfig.StorDBUser, "The storDb user to sign in as.")
|
|
stor_db_pass = flag.String("stordb_passwd", cgrConfig.StorDBPass, "The storDb user's password.")
|
|
|
|
flush = flag.Bool("flush", false, "Flush the database before importing")
|
|
tpid = flag.String("tpid", "", "The tariff plan id from the database")
|
|
dataPath = flag.String("path", ".", "The path containing the data files")
|
|
version = flag.Bool("version", false, "Prints the application version.")
|
|
verbose = flag.Bool("verbose", false, "Enable detailed verbose logging output")
|
|
fromStorDb = flag.Bool("from-stordb", false, "Load the tariff plan from storDb to dataDb")
|
|
toStorDb = flag.Bool("to-stordb", false, "Import the tariff plan from files to storDb")
|
|
historyServer = flag.String("history-server", "", "The history server address:port")
|
|
rpcEncoding = flag.String("rpc-encoding", "json", "The history server rpc encoding json|gob")
|
|
runId = flag.String("runid", "", "Uniquely identify an import/load, postpended to some automatic fields")
|
|
)
|
|
|
|
func main() {
|
|
flag.Parse()
|
|
if *version {
|
|
fmt.Println("CGRateS " + utils.VERSION)
|
|
return
|
|
}
|
|
var errDataDb, errStorDb, err error
|
|
var dataDb, storDb engine.DataStorage
|
|
// Init necessary db connections
|
|
if *fromStorDb {
|
|
dataDb, errDataDb = engine.ConfigureDatabase(*data_db_type, *data_db_host, *data_db_port, *data_db_name, *data_db_user, *data_db_pass)
|
|
storDb, errStorDb = engine.ConfigureDatabase(*stor_db_type, *stor_db_host, *stor_db_port, *stor_db_name, *stor_db_user, *stor_db_pass)
|
|
} else if *toStorDb { // Import from csv files to storDb
|
|
storDb, errStorDb = engine.ConfigureDatabase(*stor_db_type, *stor_db_host, *stor_db_port, *stor_db_name, *stor_db_user, *stor_db_pass)
|
|
} else { // Default load from csv files to dataDb
|
|
dataDb, errDataDb = engine.ConfigureDatabase(*data_db_type, *data_db_host, *data_db_port, *data_db_name, *data_db_user, *data_db_pass)
|
|
}
|
|
// Defer databases opened to be closed when we are done
|
|
for _, db := range []engine.DataStorage{dataDb, storDb} {
|
|
if db != nil {
|
|
defer db.Close()
|
|
}
|
|
}
|
|
// Stop on db errors
|
|
for _, err = range []error{errDataDb, errStorDb} {
|
|
if err != nil {
|
|
log.Fatalf("Could not open database connection: %v", err)
|
|
}
|
|
}
|
|
var loader engine.TPLoader
|
|
if *fromStorDb { // Load Tariff Plan from storDb into dataDb
|
|
loader = engine.NewDbReader(storDb, dataDb, *tpid)
|
|
} else if *toStorDb { // Import files from a directory into storDb
|
|
if *tpid == "" {
|
|
log.Fatal("TPid required, please define it via *-tpid* command argument.")
|
|
}
|
|
csvImporter := engine.TPCSVImporter{*tpid, storDb, *dataPath, ',', *verbose, *runId}
|
|
if errImport := csvImporter.Run(); errImport != nil {
|
|
log.Fatal(errImport)
|
|
}
|
|
return
|
|
} else { // Default load from csv files to dataDb
|
|
for fn, v := range engine.FileValidators {
|
|
err := engine.ValidateCSVData(path.Join(*dataPath, fn), v.Rule)
|
|
if err != nil {
|
|
log.Fatal(err, "\n\t", v.Message)
|
|
}
|
|
}
|
|
loader = engine.NewFileCSVReader(dataDb, ',', utils.DESTINATIONS_CSV, utils.TIMINGS_CSV, utils.RATES_CSV, utils.DESTINATION_RATES_CSV, utils.DESTRATE_TIMINGS_CSV, utils.RATE_PROFILES_CSV, utils.ACTIONS_CSV, utils.ACTION_TIMINGS_CSV, utils.ACTION_TRIGGERS_CSV, utils.ACCOUNT_ACTIONS_CSV)
|
|
}
|
|
|
|
if *historyServer != "" {
|
|
if scribeAgent, err := history.NewProxyScribe(*historyServer, *rpcEncoding); err != nil {
|
|
log.Fatal("Could not connect to history server:" + err.Error())
|
|
return
|
|
} else {
|
|
engine.SetHistoryScribe(scribeAgent)
|
|
gob.Register(&engine.Destination{})
|
|
defer scribeAgent.Client.Close()
|
|
}
|
|
}
|
|
|
|
err = loader.LoadDestinations()
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
err = loader.LoadTimings()
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
err = loader.LoadRates()
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
err = loader.LoadDestinationRates()
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
err = loader.LoadDestinationRateTimings()
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
err = loader.LoadRatingProfiles()
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
err = loader.LoadActions()
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
err = loader.LoadActionTimings()
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
err = loader.LoadActionTriggers()
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
err = loader.LoadAccountActions()
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
|
|
// write maps to database
|
|
if err := loader.WriteToDatabase(*flush, *verbose); err != nil {
|
|
log.Fatal("Could not write to database: ", err)
|
|
}
|
|
}
|