mirror of
https://github.com/cgrates/cgrates.git
synced 2026-02-11 18:16:24 +05:00
278 lines
9.9 KiB
Go
278 lines
9.9 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 config
|
|
|
|
import (
|
|
"github.com/cgrates/cgrates/utils"
|
|
)
|
|
|
|
// CdrsCfg is the CDR server
|
|
type CdrsCfg struct {
|
|
Enabled bool // Enable CDR Server service
|
|
ExtraFields RSRParsers // Extra fields to store in CDRs
|
|
StoreCdrs bool // store cdrs in storDb
|
|
CompressStoredCost bool // compress cost details in cdrs
|
|
SMCostRetries int
|
|
ChargerSConns []string
|
|
RaterConns []string
|
|
AttributeSConns []string
|
|
ThresholdSConns []string
|
|
StatSConns []string
|
|
OnlineCDRExports []string // list of CDRE templates to use for real-time CDR exports
|
|
SchedulerConns []string
|
|
EEsConns []string
|
|
}
|
|
|
|
// loadFromJSONCfg loads Cdrs config from JsonCfg
|
|
func (cdrscfg *CdrsCfg) loadFromJSONCfg(jsnCdrsCfg *CdrsJsonCfg) (err error) {
|
|
if jsnCdrsCfg == nil {
|
|
return nil
|
|
}
|
|
if jsnCdrsCfg.Enabled != nil {
|
|
cdrscfg.Enabled = *jsnCdrsCfg.Enabled
|
|
}
|
|
if jsnCdrsCfg.Extra_fields != nil {
|
|
if cdrscfg.ExtraFields, err = NewRSRParsersFromSlice(*jsnCdrsCfg.Extra_fields); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if jsnCdrsCfg.Store_cdrs != nil {
|
|
cdrscfg.StoreCdrs = *jsnCdrsCfg.Store_cdrs
|
|
}
|
|
if jsnCdrsCfg.Compress_stored_cost != nil {
|
|
cdrscfg.CompressStoredCost = *jsnCdrsCfg.Compress_stored_cost
|
|
}
|
|
if jsnCdrsCfg.Session_cost_retries != nil {
|
|
cdrscfg.SMCostRetries = *jsnCdrsCfg.Session_cost_retries
|
|
}
|
|
if jsnCdrsCfg.Chargers_conns != nil {
|
|
cdrscfg.ChargerSConns = make([]string, len(*jsnCdrsCfg.Chargers_conns))
|
|
for idx, connID := range *jsnCdrsCfg.Chargers_conns {
|
|
// if we have the connection internal we change the name so we can have internal rpc for each subsystem
|
|
cdrscfg.ChargerSConns[idx] = connID
|
|
if connID == utils.MetaInternal {
|
|
cdrscfg.ChargerSConns[idx] = utils.ConcatenatedKey(utils.MetaInternal, utils.MetaChargers)
|
|
}
|
|
}
|
|
}
|
|
if jsnCdrsCfg.Rals_conns != nil {
|
|
cdrscfg.RaterConns = make([]string, len(*jsnCdrsCfg.Rals_conns))
|
|
for idx, connID := range *jsnCdrsCfg.Rals_conns {
|
|
// if we have the connection internal we change the name so we can have internal rpc for each subsystem
|
|
cdrscfg.RaterConns[idx] = connID
|
|
if connID == utils.MetaInternal {
|
|
cdrscfg.RaterConns[idx] = utils.ConcatenatedKey(utils.MetaInternal, utils.MetaResponder)
|
|
}
|
|
}
|
|
}
|
|
if jsnCdrsCfg.Attributes_conns != nil {
|
|
cdrscfg.AttributeSConns = make([]string, len(*jsnCdrsCfg.Attributes_conns))
|
|
for idx, connID := range *jsnCdrsCfg.Attributes_conns {
|
|
// if we have the connection internal we change the name so we can have internal rpc for each subsystem
|
|
cdrscfg.AttributeSConns[idx] = connID
|
|
if connID == utils.MetaInternal {
|
|
cdrscfg.AttributeSConns[idx] = utils.ConcatenatedKey(utils.MetaInternal, utils.MetaAttributes)
|
|
}
|
|
}
|
|
}
|
|
if jsnCdrsCfg.Thresholds_conns != nil {
|
|
cdrscfg.ThresholdSConns = make([]string, len(*jsnCdrsCfg.Thresholds_conns))
|
|
for idx, connID := range *jsnCdrsCfg.Thresholds_conns {
|
|
// if we have the connection internal we change the name so we can have internal rpc for each subsystem
|
|
cdrscfg.ThresholdSConns[idx] = connID
|
|
if connID == utils.MetaInternal {
|
|
cdrscfg.ThresholdSConns[idx] = utils.ConcatenatedKey(utils.MetaInternal, utils.MetaThresholds)
|
|
}
|
|
}
|
|
}
|
|
if jsnCdrsCfg.Stats_conns != nil {
|
|
cdrscfg.StatSConns = make([]string, len(*jsnCdrsCfg.Stats_conns))
|
|
for idx, connID := range *jsnCdrsCfg.Stats_conns {
|
|
// if we have the connection internal we change the name so we can have internal rpc for each subsystem
|
|
cdrscfg.StatSConns[idx] = connID
|
|
if connID == utils.MetaInternal {
|
|
cdrscfg.StatSConns[idx] = utils.ConcatenatedKey(utils.MetaInternal, utils.MetaStats)
|
|
}
|
|
}
|
|
}
|
|
if jsnCdrsCfg.Online_cdr_exports != nil {
|
|
cdrscfg.OnlineCDRExports = append(cdrscfg.OnlineCDRExports, *jsnCdrsCfg.Online_cdr_exports...)
|
|
}
|
|
if jsnCdrsCfg.Scheduler_conns != nil {
|
|
cdrscfg.SchedulerConns = make([]string, len(*jsnCdrsCfg.Scheduler_conns))
|
|
for idx, connID := range *jsnCdrsCfg.Scheduler_conns {
|
|
// if we have the connection internal we change the name so we can have internal rpc for each subsystem
|
|
cdrscfg.SchedulerConns[idx] = connID
|
|
if connID == utils.MetaInternal {
|
|
cdrscfg.SchedulerConns[idx] = utils.ConcatenatedKey(utils.MetaInternal, utils.MetaScheduler)
|
|
}
|
|
}
|
|
}
|
|
|
|
if jsnCdrsCfg.Ees_conns != nil {
|
|
cdrscfg.EEsConns = make([]string, len(*jsnCdrsCfg.Ees_conns))
|
|
for idx, connID := range *jsnCdrsCfg.Ees_conns {
|
|
// if we have the connection internal we change the name so we can have internal rpc for each subsystem
|
|
cdrscfg.EEsConns[idx] = connID
|
|
if connID == utils.MetaInternal {
|
|
cdrscfg.EEsConns[idx] = utils.ConcatenatedKey(utils.MetaInternal, utils.MetaEEs)
|
|
}
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// AsMapInterface returns the config as a map[string]any
|
|
func (cdrscfg *CdrsCfg) AsMapInterface() (initialMP map[string]any) {
|
|
initialMP = map[string]any{
|
|
utils.EnabledCfg: cdrscfg.Enabled,
|
|
utils.StoreCdrsCfg: cdrscfg.StoreCdrs,
|
|
utils.CompressStoredCostCfg: cdrscfg.CompressStoredCost,
|
|
utils.SMCostRetriesCfg: cdrscfg.SMCostRetries,
|
|
}
|
|
|
|
extraFields := make([]string, len(cdrscfg.ExtraFields))
|
|
for i, item := range cdrscfg.ExtraFields {
|
|
extraFields[i] = item.Rules
|
|
}
|
|
initialMP[utils.ExtraFieldsCfg] = extraFields
|
|
|
|
onlineCDRExports := make([]string, len(cdrscfg.OnlineCDRExports))
|
|
copy(onlineCDRExports, cdrscfg.OnlineCDRExports)
|
|
|
|
initialMP[utils.OnlineCDRExportsCfg] = onlineCDRExports
|
|
|
|
if cdrscfg.ChargerSConns != nil {
|
|
chargerSConns := make([]string, len(cdrscfg.ChargerSConns))
|
|
for i, item := range cdrscfg.ChargerSConns {
|
|
chargerSConns[i] = item
|
|
if item == utils.ConcatenatedKey(utils.MetaInternal, utils.MetaChargers) {
|
|
chargerSConns[i] = utils.MetaInternal
|
|
}
|
|
}
|
|
initialMP[utils.ChargerSConnsCfg] = chargerSConns
|
|
}
|
|
if cdrscfg.RaterConns != nil {
|
|
raterConns := make([]string, len(cdrscfg.RaterConns))
|
|
for i, item := range cdrscfg.RaterConns {
|
|
raterConns[i] = item
|
|
if item == utils.ConcatenatedKey(utils.MetaInternal, utils.MetaResponder) {
|
|
raterConns[i] = utils.MetaInternal
|
|
}
|
|
}
|
|
initialMP[utils.RALsConnsCfg] = raterConns
|
|
}
|
|
if cdrscfg.AttributeSConns != nil {
|
|
attributeSConns := make([]string, len(cdrscfg.AttributeSConns))
|
|
for i, item := range cdrscfg.AttributeSConns {
|
|
attributeSConns[i] = item
|
|
if item == utils.ConcatenatedKey(utils.MetaInternal, utils.MetaAttributes) {
|
|
attributeSConns[i] = utils.MetaInternal
|
|
}
|
|
}
|
|
initialMP[utils.AttributeSConnsCfg] = attributeSConns
|
|
}
|
|
if cdrscfg.ThresholdSConns != nil {
|
|
thresholdSConns := make([]string, len(cdrscfg.ThresholdSConns))
|
|
for i, item := range cdrscfg.ThresholdSConns {
|
|
thresholdSConns[i] = item
|
|
if item == utils.ConcatenatedKey(utils.MetaInternal, utils.MetaThresholds) {
|
|
thresholdSConns[i] = utils.MetaInternal
|
|
}
|
|
}
|
|
initialMP[utils.ThresholdSConnsCfg] = thresholdSConns
|
|
}
|
|
if cdrscfg.StatSConns != nil {
|
|
statSConns := make([]string, len(cdrscfg.StatSConns))
|
|
for i, item := range cdrscfg.StatSConns {
|
|
statSConns[i] = item
|
|
if item == utils.ConcatenatedKey(utils.MetaInternal, utils.MetaStats) {
|
|
statSConns[i] = utils.MetaInternal
|
|
}
|
|
}
|
|
initialMP[utils.StatSConnsCfg] = statSConns
|
|
}
|
|
if cdrscfg.SchedulerConns != nil {
|
|
schedulerConns := make([]string, len(cdrscfg.SchedulerConns))
|
|
for i, item := range cdrscfg.SchedulerConns {
|
|
schedulerConns[i] = item
|
|
if item == utils.ConcatenatedKey(utils.MetaInternal, utils.MetaScheduler) {
|
|
schedulerConns[i] = utils.MetaInternal
|
|
}
|
|
}
|
|
initialMP[utils.SchedulerConnsCfg] = schedulerConns
|
|
}
|
|
if cdrscfg.EEsConns != nil {
|
|
eesConns := make([]string, len(cdrscfg.EEsConns))
|
|
for i, item := range cdrscfg.EEsConns {
|
|
eesConns[i] = item
|
|
if item == utils.ConcatenatedKey(utils.MetaInternal, utils.MetaEEs) {
|
|
eesConns[i] = utils.MetaInternal
|
|
}
|
|
}
|
|
initialMP[utils.EEsConnsCfg] = eesConns
|
|
}
|
|
return
|
|
}
|
|
|
|
// Clone returns a deep copy of CdrsCfg
|
|
func (cdrscfg CdrsCfg) Clone() (cln *CdrsCfg) {
|
|
cln = &CdrsCfg{
|
|
Enabled: cdrscfg.Enabled,
|
|
ExtraFields: cdrscfg.ExtraFields.Clone(),
|
|
StoreCdrs: cdrscfg.StoreCdrs,
|
|
SMCostRetries: cdrscfg.SMCostRetries,
|
|
CompressStoredCost: cdrscfg.CompressStoredCost,
|
|
}
|
|
if cdrscfg.ChargerSConns != nil {
|
|
cln.ChargerSConns = make([]string, len(cdrscfg.ChargerSConns))
|
|
copy(cln.ChargerSConns, cdrscfg.ChargerSConns)
|
|
}
|
|
if cdrscfg.RaterConns != nil {
|
|
cln.RaterConns = make([]string, len(cdrscfg.RaterConns))
|
|
copy(cln.RaterConns, cdrscfg.RaterConns)
|
|
}
|
|
if cdrscfg.AttributeSConns != nil {
|
|
cln.AttributeSConns = make([]string, len(cdrscfg.AttributeSConns))
|
|
copy(cln.AttributeSConns, cdrscfg.AttributeSConns)
|
|
}
|
|
if cdrscfg.ThresholdSConns != nil {
|
|
cln.ThresholdSConns = make([]string, len(cdrscfg.ThresholdSConns))
|
|
copy(cln.ThresholdSConns, cdrscfg.ThresholdSConns)
|
|
}
|
|
if cdrscfg.StatSConns != nil {
|
|
cln.StatSConns = make([]string, len(cdrscfg.StatSConns))
|
|
copy(cln.StatSConns, cdrscfg.StatSConns)
|
|
}
|
|
if cdrscfg.OnlineCDRExports != nil {
|
|
cln.OnlineCDRExports = make([]string, len(cdrscfg.OnlineCDRExports))
|
|
copy(cln.OnlineCDRExports, cdrscfg.OnlineCDRExports)
|
|
}
|
|
if cdrscfg.SchedulerConns != nil {
|
|
cln.SchedulerConns = make([]string, len(cdrscfg.SchedulerConns))
|
|
copy(cln.SchedulerConns, cdrscfg.SchedulerConns)
|
|
}
|
|
if cdrscfg.EEsConns != nil {
|
|
cln.EEsConns = make([]string, len(cdrscfg.EEsConns))
|
|
copy(cln.EEsConns, cdrscfg.EEsConns)
|
|
}
|
|
|
|
return
|
|
}
|