From 06ccafb5fd73099f952d6f553dbd1ca467be014a Mon Sep 17 00:00:00 2001 From: gezimbll Date: Wed, 22 Jan 2025 13:14:09 +0100 Subject: [PATCH] added tests for opts with dynamic values --- apis/config_it_test.go | 66 +- config/attributescfg.go | 7 +- config/config.go | 2 +- config/config_it_test.go | 215 ++- config/config_test.go | 10 +- config/libdynamics.go | 4 +- config/routescfg.go | 2 +- config/routescfg_test.go | 6 +- config/sessionscfg_test.go | 2 +- engine/libdynopts.go | 4 +- engine/libdynopts_test.go | 1479 +++++++++++------- general_tests/config_reload_rates_it_test.go | 2 +- 12 files changed, 1062 insertions(+), 737 deletions(-) diff --git a/apis/config_it_test.go b/apis/config_it_test.go index f966b1e2c..6a8d9eb34 100644 --- a/apis/config_it_test.go +++ b/apis/config_it_test.go @@ -153,9 +153,9 @@ func testCfgGetConfig(t *testing.T) { "notexists_indexed_fields": []string{}, utils.OptsCfg: map[string]any{ utils.MetaProfileIDs: []*config.DynamicStringSliceOpt{}, - utils.MetaProcessRunsCfg: []*config.DynamicIntOpt{}, - utils.MetaProfileRunsCfg: []*config.DynamicIntOpt{}, - utils.MetaProfileIgnoreFilters: []*config.DynamicBoolOpt{}, + utils.MetaProcessRunsCfg: []*config.DynamicIntOpt{config.NewDynamicIntOpt(nil, "", config.AttributesProcessRunsDftOpt, nil)}, + utils.MetaProfileRunsCfg: []*config.DynamicIntOpt{config.NewDynamicIntOpt(nil, "", config.AttributesProfileRunsDftOpt, nil)}, + utils.MetaProfileIgnoreFilters: []*config.DynamicBoolOpt{config.NewDynamicBoolOpt(nil, "", config.AttributesProfileIgnoreFiltersDftOpt, nil)}, }, }, } @@ -223,12 +223,26 @@ func testCfgSetGetConfig(t *testing.T) { utils.MetaProfileIDs: []any{}, utils.MetaProcessRunsCfg: []any{ map[string]any{ - "Value": 2., - "Tenant": utils.EmptyString, + "Tenant": utils.EmptyString, + "FilterIDs": nil, + }, + map[string]any{ + "Tenant": utils.EmptyString, + "FilterIDs": nil, + }, + }, + utils.MetaProfileRunsCfg: []any{ + map[string]any{ + "Tenant": utils.EmptyString, + "FilterIDs": nil, + }, + }, + utils.MetaProfileIgnoreFilters: []any{ + map[string]any{ + "Tenant": utils.EmptyString, + "FilterIDs": nil, }, }, - utils.MetaProfileRunsCfg: []any{}, - utils.MetaProfileIgnoreFilters: []any{}, }, }, } @@ -306,10 +320,10 @@ func testCfgSetEmptyReload(t *testing.T) { "verbosity": 1000, utils.OptsCfg: map[string]any{ utils.MetaProfileIDs: []*config.DynamicStringSliceOpt{}, - utils.MetaStartTime: []*config.DynamicStringOpt{}, - utils.MetaUsage: []*config.DynamicDecimalOpt{}, - utils.MetaIntervalStartCfg: []*config.DynamicDecimalOpt{}, - utils.MetaProfileIgnoreFilters: []*config.DynamicBoolOpt{}, + utils.MetaStartTime: []*config.DynamicStringOpt{config.NewDynamicStringOpt(nil, "", config.RatesStartTimeDftOpt, nil)}, + utils.MetaUsage: []*config.DynamicDecimalOpt{config.NewDynamicDecimalOpt(nil, "", config.RatesUsageDftOpt, nil)}, + utils.MetaIntervalStartCfg: []*config.DynamicDecimalOpt{config.NewDynamicDecimalOpt(nil, "", config.RatesIntervalStartDftOpt, nil)}, + utils.MetaProfileIgnoreFilters: []*config.DynamicBoolOpt{config.NewDynamicBoolOpt(nil, "", config.RatesProfileIgnoreFiltersDftOpt, nil)}, }, }, } @@ -362,7 +376,7 @@ func testCfgSetJSONGetJSONConfig(t *testing.T) { if !reflect.DeepEqual(`"OK"`, utils.ToJSON(reply)) { t.Errorf("\nExpected <%+v>, \nReceived <%+v>", "OK", utils.ToJSON(reply)) } - expectedGet := `{"attributes":{"accounts_conns":["*internal"],"enabled":true,"exists_indexed_fields":[],"indexed_selects":false,"nested_fields":false,"notexists_indexed_fields":[],"opts":{"*processRuns":[{"Tenant":"","Value":2},{"Tenant":"","Value":"2"}],"*profileIDs":[],"*profileIgnoreFilters":[],"*profileRuns":[]},"prefix_indexed_fields":[],"resources_conns":["*internal"],"stats_conns":["*localhost"],"suffix_indexed_fields":[]}}` + expectedGet := `{"attributes":{"accounts_conns":["*internal"],"enabled":true,"exists_indexed_fields":[],"indexed_selects":false,"nested_fields":false,"notexists_indexed_fields":[],"opts":{"*processRuns":[{"FilterIDs":null,"Tenant":""},{"FilterIDs":null,"Tenant":""},{"FilterIDs":null,"Tenant":""}],"*profileIDs":[],"*profileIgnoreFilters":[{"FilterIDs":null,"Tenant":""}],"*profileRuns":[{"FilterIDs":null,"Tenant":""}]},"prefix_indexed_fields":[],"resources_conns":["*internal"],"stats_conns":["*localhost"],"suffix_indexed_fields":[]}}` var replyGet string if err := cfgRPC.Call(context.Background(), utils.ConfigSv1GetConfigAsJSON, &config.SectionWithAPIOpts{ @@ -529,9 +543,9 @@ func testCfgSetGetConfigStore(t *testing.T) { "notexists_indexed_fields": []string{}, utils.OptsCfg: map[string]any{ utils.MetaProfileIDs: []*config.DynamicStringSliceOpt{}, - utils.MetaProcessRunsCfg: []*config.DynamicIntOpt{}, - utils.MetaProfileRunsCfg: []*config.DynamicIntOpt{}, - utils.MetaProfileIgnoreFilters: []*config.DynamicBoolOpt{}, + utils.MetaProcessRunsCfg: []*config.DynamicIntOpt{config.NewDynamicIntOpt(nil, "", config.AttributesProcessRunsDftOpt, nil)}, + utils.MetaProfileRunsCfg: []*config.DynamicIntOpt{config.NewDynamicIntOpt(nil, "", config.AttributesProfileRunsDftOpt, nil)}, + utils.MetaProfileIgnoreFilters: []*config.DynamicBoolOpt{config.NewDynamicBoolOpt(nil, "", config.AttributesProfileIgnoreFiltersDftOpt, nil)}, }, }, } @@ -632,12 +646,26 @@ func testCfgGetAfterReloadStore(t *testing.T) { utils.MetaProfileIDs: []any{}, utils.MetaProcessRunsCfg: []any{ map[string]any{ - "Tenant": utils.EmptyString, - "Value": 2., + "Tenant": utils.EmptyString, + "FilterIDs": nil, + }, + map[string]any{ + "Tenant": utils.EmptyString, + "FilterIDs": nil, + }, + }, + utils.MetaProfileRunsCfg: []any{ + map[string]any{ + "Tenant": utils.EmptyString, + "FilterIDs": nil, + }, + }, + utils.MetaProfileIgnoreFilters: []any{ + map[string]any{ + "Tenant": utils.EmptyString, + "FilterIDs": nil, }, }, - utils.MetaProfileRunsCfg: []any{}, - utils.MetaProfileIgnoreFilters: []any{}, }, }, } diff --git a/config/attributescfg.go b/config/attributescfg.go index 0cbafd125..c80757952 100644 --- a/config/attributescfg.go +++ b/config/attributescfg.go @@ -75,8 +75,7 @@ func (attrOpts *AttributesOpts) loadFromJSONCfg(jsnCfg *AttributesOptsJson) (err if jsnCfg.ProcessRuns != nil { var procRuns []*DynamicIntOpt procRuns, err = IfaceToIntDynamicOpts(jsnCfg.ProcessRuns) - procRuns = append(procRuns, attrOpts.ProcessRuns...) - attrOpts.ProcessRuns = procRuns + attrOpts.ProcessRuns = append(procRuns, attrOpts.ProcessRuns...) } if jsnCfg.ProfileRuns != nil { var profRuns []*DynamicIntOpt @@ -84,8 +83,8 @@ func (attrOpts *AttributesOpts) loadFromJSONCfg(jsnCfg *AttributesOptsJson) (err if err != nil { return } - profRuns = append(profRuns, attrOpts.ProfileRuns...) - attrOpts.ProfileRuns = profRuns + attrOpts.ProfileRuns = append(profRuns, attrOpts.ProfileRuns...) + } if jsnCfg.ProfileIgnoreFilters != nil { var profIgnFltrs []*DynamicBoolOpt diff --git a/config/config.go b/config/config.go index d54a48018..781a41b4c 100644 --- a/config/config.go +++ b/config/config.go @@ -213,7 +213,7 @@ func newCGRConfig(config []byte) (cfg *CGRConfig, err error) { routeSCfg: &RouteSCfg{Opts: &RoutesOpts{ Context: []*DynamicStringOpt{{value: RoutesContextDftOpt}}, IgnoreErrors: []*DynamicBoolOpt{{value: RatesProfileIgnoreFiltersDftOpt}}, - MaxCost: []*DynamicInterfaceOpt{}, + MaxCost: []*DynamicInterfaceOpt{{Value: RoutesMaxCostDftOpt}}, ProfileCount: []*DynamicIntPointerOpt{{value: RoutesProfileCountDftOpt}}, Limit: []*DynamicIntPointerOpt{}, Offset: []*DynamicIntPointerOpt{}, diff --git a/config/config_it_test.go b/config/config_it_test.go index 7c1caa92d..02727218c 100644 --- a/config/config_it_test.go +++ b/config/config_it_test.go @@ -158,11 +158,10 @@ func testCGRConfigReloadAttributeS(t *testing.T) { IndexedSelects: true, Opts: &AttributesOpts{ ProfileIDs: []*DynamicStringSliceOpt{}, - ProcessRuns: []*DynamicIntOpt{}, - ProfileRuns: []*DynamicIntOpt{}, - ProfileIgnoreFilters: []*DynamicBoolOpt{}, - }, - } + ProcessRuns: []*DynamicIntOpt{{value: AttributesProcessRunsDftOpt}}, + ProfileRuns: []*DynamicIntOpt{{value: AttributesProfileRunsDftOpt}}, + ProfileIgnoreFilters: []*DynamicBoolOpt{{value: AttributesProfileIgnoreFiltersDftOpt}}, + }} if !reflect.DeepEqual(expAttr, cfg.AttributeSCfg()) { t.Errorf("Expected %s , received: %s ", utils.ToJSON(expAttr), utils.ToJSON(cfg.AttributeSCfg())) } @@ -199,9 +198,9 @@ func testCGRConfigReloadAttributeSWithDB(t *testing.T) { IndexedSelects: true, Opts: &AttributesOpts{ ProfileIDs: []*DynamicStringSliceOpt{}, - ProcessRuns: []*DynamicIntOpt{}, - ProfileRuns: []*DynamicIntOpt{}, - ProfileIgnoreFilters: []*DynamicBoolOpt{}, + ProcessRuns: []*DynamicIntOpt{{value: AttributesProcessRunsDftOpt}}, + ProfileRuns: []*DynamicIntOpt{{value: AttributesProfileRunsDftOpt}}, + ProfileIgnoreFilters: []*DynamicBoolOpt{{value: AccountsProfileIgnoreFiltersDftOpt}}, }, } if !reflect.DeepEqual(expAttr, cfg.AttributeSCfg()) { @@ -277,9 +276,8 @@ func testCGRConfigReloadThresholdS(t *testing.T) { IndexedSelects: true, Opts: &ThresholdsOpts{ ProfileIDs: []*DynamicStringSliceOpt{}, - ProfileIgnoreFilters: []*DynamicBoolOpt{}, - }, - } + ProfileIgnoreFilters: []*DynamicBoolOpt{{value: ThresholdsProfileIgnoreFiltersDftOpt}}, + }} if !reflect.DeepEqual(expAttr, cfg.ThresholdSCfg()) { t.Errorf("Expected %s , received: %s ", utils.ToJSON(expAttr), utils.ToJSON(cfg.ThresholdSCfg())) } @@ -308,7 +306,7 @@ func testCGRConfigReloadStatS(t *testing.T) { ThresholdSConns: []string{utils.MetaLocalHost}, Opts: &StatsOpts{ ProfileIDs: []*DynamicStringSliceOpt{}, - ProfileIgnoreFilters: []*DynamicBoolOpt{}, + ProfileIgnoreFilters: []*DynamicBoolOpt{{value: StatsProfileIgnoreFilters}}, RoundingDecimals: []*DynamicIntOpt{}, PrometheusStatIDs: []*DynamicStringSliceOpt{}, }, @@ -341,9 +339,9 @@ func testCGRConfigReloadResourceS(t *testing.T) { IndexedSelects: true, ThresholdSConns: []string{utils.MetaLocalHost}, Opts: &ResourcesOpts{ - UsageID: []*DynamicStringOpt{}, - UsageTTL: []*DynamicDurationOpt{}, - Units: []*DynamicFloat64Opt{}, + UsageID: []*DynamicStringOpt{{value: ResourcesUsageIDDftOpt}}, + UsageTTL: []*DynamicDurationOpt{{value: ResourcesUsageTTLDftOpt}}, + Units: []*DynamicFloat64Opt{{value: ResourcesUnitsDftOpt}}, }, } if !reflect.DeepEqual(expAttr, cfg.ResourceSCfg()) { @@ -378,13 +376,13 @@ func testCGRConfigReloadSupplierS(t *testing.T) { IndexedSelects: true, DefaultRatio: 1, Opts: &RoutesOpts{ - Context: []*DynamicStringOpt{}, - ProfileCount: []*DynamicIntPointerOpt{}, - IgnoreErrors: []*DynamicBoolOpt{}, - MaxCost: []*DynamicInterfaceOpt{}, + Context: []*DynamicStringOpt{{value: RoutesContextDftOpt}}, + ProfileCount: []*DynamicIntPointerOpt{{value: RoutesProfileCountDftOpt}}, + IgnoreErrors: []*DynamicBoolOpt{{value: RoutesIgnoreErrorsDftOpt}}, + MaxCost: []*DynamicInterfaceOpt{{Value: RoutesMaxCostDftOpt}}, Limit: []*DynamicIntPointerOpt{}, Offset: []*DynamicIntPointerOpt{}, - Usage: []*DynamicDecimalOpt{}, + Usage: []*DynamicDecimalOpt{{value: RatesUsageDftOpt}}, MaxItems: []*DynamicIntPointerOpt{}, }, } @@ -826,41 +824,41 @@ func testCGRConfigReloadConfigFromJSONSessionS(t *testing.T) { utils.MetaSMS: 1, }, Opts: &SessionsOpts{ - Accounts: []*DynamicBoolOpt{}, - Attributes: []*DynamicBoolOpt{}, - CDRs: []*DynamicBoolOpt{}, - Chargers: []*DynamicBoolOpt{}, - Resources: []*DynamicBoolOpt{}, - Routes: []*DynamicBoolOpt{}, - Stats: []*DynamicBoolOpt{}, - Thresholds: []*DynamicBoolOpt{}, - Initiate: []*DynamicBoolOpt{}, - Update: []*DynamicBoolOpt{}, - Terminate: []*DynamicBoolOpt{}, - Message: []*DynamicBoolOpt{}, - AttributesDerivedReply: []*DynamicBoolOpt{}, - BlockerError: []*DynamicBoolOpt{}, - CDRsDerivedReply: []*DynamicBoolOpt{}, - ResourcesAuthorize: []*DynamicBoolOpt{}, - ResourcesAllocate: []*DynamicBoolOpt{}, - ResourcesRelease: []*DynamicBoolOpt{}, - ResourcesDerivedReply: []*DynamicBoolOpt{}, - RoutesDerivedReply: []*DynamicBoolOpt{}, - StatsDerivedReply: []*DynamicBoolOpt{}, - ThresholdsDerivedReply: []*DynamicBoolOpt{}, - MaxUsage: []*DynamicBoolOpt{}, + Accounts: []*DynamicBoolOpt{{}}, + Attributes: []*DynamicBoolOpt{{}}, + CDRs: []*DynamicBoolOpt{{}}, + Chargers: []*DynamicBoolOpt{{}}, + Resources: []*DynamicBoolOpt{{}}, + Routes: []*DynamicBoolOpt{{}}, + Stats: []*DynamicBoolOpt{{}}, + Thresholds: []*DynamicBoolOpt{{}}, + Initiate: []*DynamicBoolOpt{{}}, + Update: []*DynamicBoolOpt{{}}, + Terminate: []*DynamicBoolOpt{{}}, + Message: []*DynamicBoolOpt{{}}, + AttributesDerivedReply: []*DynamicBoolOpt{{}}, + BlockerError: []*DynamicBoolOpt{{}}, + CDRsDerivedReply: []*DynamicBoolOpt{{}}, + ResourcesAuthorize: []*DynamicBoolOpt{{}}, + ResourcesAllocate: []*DynamicBoolOpt{{}}, + ResourcesRelease: []*DynamicBoolOpt{{}}, + ResourcesDerivedReply: []*DynamicBoolOpt{{}}, + RoutesDerivedReply: []*DynamicBoolOpt{{}}, + StatsDerivedReply: []*DynamicBoolOpt{{}}, + ThresholdsDerivedReply: []*DynamicBoolOpt{{}}, + MaxUsage: []*DynamicBoolOpt{{}}, ForceUsage: []*DynamicBoolOpt{}, - TTL: []*DynamicDurationOpt{}, - Chargeable: []*DynamicBoolOpt{}, + TTL: []*DynamicDurationOpt{{value: SessionsTTLDftOpt}}, + Chargeable: []*DynamicBoolOpt{{value: SessionsChargeableDftOpt}}, TTLLastUsage: []*DynamicDurationPointerOpt{}, TTLLastUsed: []*DynamicDurationPointerOpt{}, - DebitInterval: []*DynamicDurationOpt{}, - TTLMaxDelay: []*DynamicDurationOpt{}, + DebitInterval: []*DynamicDurationOpt{{value: SessionsDebitIntervalDftOpt}}, + TTLMaxDelay: []*DynamicDurationOpt{{value: SessionsTTLMaxDelayDftOpt}}, TTLUsage: []*DynamicDurationPointerOpt{}, }, } if !reflect.DeepEqual(expAttr, cfg.SessionSCfg()) { - t.Errorf("Expected %s , received: %s ", utils.ToJSON(expAttr), utils.ToJSON(cfg.SessionSCfg())) + t.Errorf("Expected %s ,\n received: %s ", utils.ToJSON(expAttr), utils.ToJSON(cfg.SessionSCfg())) } } @@ -914,45 +912,45 @@ func testCGRConfigReloadConfigFromStringSessionS(t *testing.T) { utils.MetaSMS: 1, }, Opts: &SessionsOpts{ - Accounts: []*DynamicBoolOpt{}, - Attributes: []*DynamicBoolOpt{}, - CDRs: []*DynamicBoolOpt{}, - Chargers: []*DynamicBoolOpt{}, - Resources: []*DynamicBoolOpt{}, - Routes: []*DynamicBoolOpt{}, - Stats: []*DynamicBoolOpt{}, - Thresholds: []*DynamicBoolOpt{}, - Initiate: []*DynamicBoolOpt{}, - Update: []*DynamicBoolOpt{}, - Terminate: []*DynamicBoolOpt{}, - Message: []*DynamicBoolOpt{}, - AttributesDerivedReply: []*DynamicBoolOpt{}, - BlockerError: []*DynamicBoolOpt{}, - CDRsDerivedReply: []*DynamicBoolOpt{}, - ResourcesAuthorize: []*DynamicBoolOpt{}, - ResourcesAllocate: []*DynamicBoolOpt{}, - ResourcesRelease: []*DynamicBoolOpt{}, - ResourcesDerivedReply: []*DynamicBoolOpt{}, - RoutesDerivedReply: []*DynamicBoolOpt{}, - StatsDerivedReply: []*DynamicBoolOpt{}, - ThresholdsDerivedReply: []*DynamicBoolOpt{}, - MaxUsage: []*DynamicBoolOpt{}, + Accounts: []*DynamicBoolOpt{{}}, + Attributes: []*DynamicBoolOpt{{}}, + CDRs: []*DynamicBoolOpt{{}}, + Chargers: []*DynamicBoolOpt{{}}, + Resources: []*DynamicBoolOpt{{}}, + Routes: []*DynamicBoolOpt{{}}, + Stats: []*DynamicBoolOpt{{}}, + Thresholds: []*DynamicBoolOpt{{}}, + Initiate: []*DynamicBoolOpt{{}}, + Update: []*DynamicBoolOpt{{}}, + Terminate: []*DynamicBoolOpt{{}}, + Message: []*DynamicBoolOpt{{}}, + AttributesDerivedReply: []*DynamicBoolOpt{{}}, + BlockerError: []*DynamicBoolOpt{{}}, + CDRsDerivedReply: []*DynamicBoolOpt{{}}, + ResourcesAuthorize: []*DynamicBoolOpt{{}}, + ResourcesAllocate: []*DynamicBoolOpt{{}}, + ResourcesRelease: []*DynamicBoolOpt{{}}, + ResourcesDerivedReply: []*DynamicBoolOpt{{}}, + RoutesDerivedReply: []*DynamicBoolOpt{{}}, + StatsDerivedReply: []*DynamicBoolOpt{{}}, + ThresholdsDerivedReply: []*DynamicBoolOpt{{}}, + MaxUsage: []*DynamicBoolOpt{{}}, ForceUsage: []*DynamicBoolOpt{}, - TTL: []*DynamicDurationOpt{}, - Chargeable: []*DynamicBoolOpt{}, + TTL: []*DynamicDurationOpt{{value: SessionsTTLDftOpt}}, + Chargeable: []*DynamicBoolOpt{{value: SessionsChargeableDftOpt}}, TTLLastUsage: []*DynamicDurationPointerOpt{}, TTLLastUsed: []*DynamicDurationPointerOpt{}, - DebitInterval: []*DynamicDurationOpt{}, - TTLMaxDelay: []*DynamicDurationOpt{}, + DebitInterval: []*DynamicDurationOpt{{value: SessionsDebitIntervalDftOpt}}, + TTLMaxDelay: []*DynamicDurationOpt{{value: SessionsTTLMaxDelayDftOpt}}, TTLUsage: []*DynamicDurationPointerOpt{}, }, } if !reflect.DeepEqual(expAttr, cfg.SessionSCfg()) { - t.Errorf("Expected %s , received: %s ", utils.ToJSON(expAttr), utils.ToJSON(cfg.SessionSCfg())) + t.Errorf("Expected %s ,\n received: %s ", utils.ToJSON(expAttr), utils.ToJSON(cfg.SessionSCfg())) } var rcv string - expected := `{"sessions":{"accounts_conns":[],"actions_conns":[],"alterable_fields":[],"attributes_conns":["*localhost"],"cdrs_conns":["*internal"],"channel_sync_interval":"0","chargers_conns":["*localhost"],"client_protocol":1,"default_usage":{"*any":"3h0m0s","*data":"1048576","*sms":"1","*voice":"3h0m0s"},"enabled":true,"listen_bigob":"","listen_bijson":"127.0.0.1:2014","min_dur_low_balance":"0","opts":{"*accounts":[],"*attributes":[],"*attributesDerivedReply":[],"*blockerError":[],"*cdrs":[],"*cdrsDerivedReply":[],"*chargeable":[],"*chargers":[],"*debitInterval":[],"*forceUsage":[],"*initiate":[],"*maxUsage":[],"*message":[],"*resources":[],"*resourcesAllocate":[],"*resourcesAuthorize":[],"*resourcesDerivedReply":[],"*resourcesRelease":[],"*routes":[],"*routesDerivedReply":[],"*stats":[],"*statsDerivedReply":[],"*terminate":[],"*thresholds":[],"*thresholdsDerivedReply":[],"*ttl":[],"*ttlLastUsage":[],"*ttlLastUsed":[],"*ttlMaxDelay":[],"*ttlUsage":[],"*update":[]},"rates_conns":[],"replication_conns":[],"resources_conns":["*localhost"],"routes_conns":["*localhost"],"session_indexes":[],"stats_conns":[],"stir":{"allowed_attest":["*any"],"default_attest":"A","payload_maxduration":"-1","privatekey_path":"","publickey_path":""},"store_session_costs":false,"terminate_attempts":5,"thresholds_conns":[]}}` + expected := `{"sessions":{"accounts_conns":[],"actions_conns":[],"alterable_fields":[],"attributes_conns":["*localhost"],"cdrs_conns":["*internal"],"channel_sync_interval":"0","chargers_conns":["*localhost"],"client_protocol":1,"default_usage":{"*any":"3h0m0s","*data":"1048576","*sms":"1","*voice":"3h0m0s"},"enabled":true,"listen_bigob":"","listen_bijson":"127.0.0.1:2014","min_dur_low_balance":"0","opts":{"*accounts":[{"FilterIDs":null,"Tenant":""}],"*attributes":[{"FilterIDs":null,"Tenant":""}],"*attributesDerivedReply":[{"FilterIDs":null,"Tenant":""}],"*blockerError":[{"FilterIDs":null,"Tenant":""}],"*cdrs":[{"FilterIDs":null,"Tenant":""}],"*cdrsDerivedReply":[{"FilterIDs":null,"Tenant":""}],"*chargeable":[{"FilterIDs":null,"Tenant":""}],"*chargers":[{"FilterIDs":null,"Tenant":""}],"*debitInterval":[{"FilterIDs":null,"Tenant":""}],"*forceUsage":[],"*initiate":[{"FilterIDs":null,"Tenant":""}],"*maxUsage":[{"FilterIDs":null,"Tenant":""}],"*message":[{"FilterIDs":null,"Tenant":""}],"*resources":[{"FilterIDs":null,"Tenant":""}],"*resourcesAllocate":[{"FilterIDs":null,"Tenant":""}],"*resourcesAuthorize":[{"FilterIDs":null,"Tenant":""}],"*resourcesDerivedReply":[{"FilterIDs":null,"Tenant":""}],"*resourcesRelease":[{"FilterIDs":null,"Tenant":""}],"*routes":[{"FilterIDs":null,"Tenant":""}],"*routesDerivedReply":[{"FilterIDs":null,"Tenant":""}],"*stats":[{"FilterIDs":null,"Tenant":""}],"*statsDerivedReply":[{"FilterIDs":null,"Tenant":""}],"*terminate":[{"FilterIDs":null,"Tenant":""}],"*thresholds":[{"FilterIDs":null,"Tenant":""}],"*thresholdsDerivedReply":[{"FilterIDs":null,"Tenant":""}],"*ttl":[{"FilterIDs":null,"Tenant":""}],"*ttlLastUsage":[],"*ttlLastUsed":[],"*ttlMaxDelay":[{"FilterIDs":null,"Tenant":""}],"*ttlUsage":[],"*update":[{"FilterIDs":null,"Tenant":""}]},"rates_conns":[],"replication_conns":[],"resources_conns":["*localhost"],"routes_conns":["*localhost"],"session_indexes":[],"stats_conns":[],"stir":{"allowed_attest":["*any"],"default_attest":"A","payload_maxduration":"-1","privatekey_path":"","publickey_path":""},"store_session_costs":false,"terminate_attempts":5,"thresholds_conns":[]}}` if err := cfg.V1GetConfigAsJSON(context.Background(), &SectionWithAPIOpts{Sections: []string{SessionSJSON}}, &rcv); err != nil { t.Error(err) } else if expected != rcv { @@ -1005,41 +1003,41 @@ func testCGRConfigReloadAll(t *testing.T) { utils.MetaSMS: 1, }, Opts: &SessionsOpts{ - Accounts: []*DynamicBoolOpt{}, - Attributes: []*DynamicBoolOpt{}, - CDRs: []*DynamicBoolOpt{}, - Chargers: []*DynamicBoolOpt{}, - Resources: []*DynamicBoolOpt{}, - Routes: []*DynamicBoolOpt{}, - Stats: []*DynamicBoolOpt{}, - Thresholds: []*DynamicBoolOpt{}, - Initiate: []*DynamicBoolOpt{}, - Update: []*DynamicBoolOpt{}, - Terminate: []*DynamicBoolOpt{}, - Message: []*DynamicBoolOpt{}, - AttributesDerivedReply: []*DynamicBoolOpt{}, - BlockerError: []*DynamicBoolOpt{}, - CDRsDerivedReply: []*DynamicBoolOpt{}, - ResourcesAuthorize: []*DynamicBoolOpt{}, - ResourcesAllocate: []*DynamicBoolOpt{}, - ResourcesRelease: []*DynamicBoolOpt{}, - ResourcesDerivedReply: []*DynamicBoolOpt{}, - RoutesDerivedReply: []*DynamicBoolOpt{}, - StatsDerivedReply: []*DynamicBoolOpt{}, - ThresholdsDerivedReply: []*DynamicBoolOpt{}, - MaxUsage: []*DynamicBoolOpt{}, + Accounts: []*DynamicBoolOpt{{}}, + Attributes: []*DynamicBoolOpt{{}}, + CDRs: []*DynamicBoolOpt{{}}, + Chargers: []*DynamicBoolOpt{{}}, + Resources: []*DynamicBoolOpt{{}}, + Routes: []*DynamicBoolOpt{{}}, + Stats: []*DynamicBoolOpt{{}}, + Thresholds: []*DynamicBoolOpt{{}}, + Initiate: []*DynamicBoolOpt{{}}, + Update: []*DynamicBoolOpt{{}}, + Terminate: []*DynamicBoolOpt{{}}, + Message: []*DynamicBoolOpt{{}}, + AttributesDerivedReply: []*DynamicBoolOpt{{}}, + BlockerError: []*DynamicBoolOpt{{}}, + CDRsDerivedReply: []*DynamicBoolOpt{{}}, + ResourcesAuthorize: []*DynamicBoolOpt{{}}, + ResourcesAllocate: []*DynamicBoolOpt{{}}, + ResourcesRelease: []*DynamicBoolOpt{{}}, + ResourcesDerivedReply: []*DynamicBoolOpt{{}}, + RoutesDerivedReply: []*DynamicBoolOpt{{}}, + StatsDerivedReply: []*DynamicBoolOpt{{}}, + ThresholdsDerivedReply: []*DynamicBoolOpt{{}}, + MaxUsage: []*DynamicBoolOpt{{}}, ForceUsage: []*DynamicBoolOpt{}, - TTL: []*DynamicDurationOpt{}, - Chargeable: []*DynamicBoolOpt{}, + TTL: []*DynamicDurationOpt{{value: SessionsTTLDftOpt}}, + Chargeable: []*DynamicBoolOpt{{value: SessionsChargeableDftOpt}}, TTLLastUsage: []*DynamicDurationPointerOpt{}, TTLLastUsed: []*DynamicDurationPointerOpt{}, - DebitInterval: []*DynamicDurationOpt{}, - TTLMaxDelay: []*DynamicDurationOpt{}, + DebitInterval: []*DynamicDurationOpt{{value: SessionsDebitIntervalDftOpt}}, + TTLMaxDelay: []*DynamicDurationOpt{{value: SessionsTTLMaxDelayDftOpt}}, TTLUsage: []*DynamicDurationPointerOpt{}, }, } if !reflect.DeepEqual(expAttr, cfg.SessionSCfg()) { - t.Errorf("Expected %s , received: %s ", utils.ToJSON(expAttr), utils.ToJSON(cfg.SessionSCfg())) + t.Errorf("Expected %s ,\n received: %s ", utils.ToJSON(expAttr), utils.ToJSON(cfg.SessionSCfg())) } } @@ -1567,11 +1565,12 @@ func TestReloadCfgInDb(t *testing.T) { Opts: &AttributesOpts{ ProcessRuns: []*DynamicIntOpt{ { - FilterIDs: []string{}, - value: 2, + FilterIDs: nil, + value: 3, }, { - value: 3, + FilterIDs: []string{}, + value: 2, }, }, }, diff --git a/config/config_test.go b/config/config_test.go index 333ce7b72..97a024bfa 100644 --- a/config/config_test.go +++ b/config/config_test.go @@ -671,7 +671,7 @@ func TestCgrCfgJSONDefaultRouteSCfg(t *testing.T) { Context: []*DynamicStringOpt{{value: RoutesContextDftOpt}}, ProfileCount: []*DynamicIntPointerOpt{{value: RoutesProfileCountDftOpt}}, IgnoreErrors: []*DynamicBoolOpt{{value: RoutesIgnoreErrorsDftOpt}}, - MaxCost: []*DynamicInterfaceOpt{}, + MaxCost: []*DynamicInterfaceOpt{{Value: RoutesMaxCostDftOpt}}, Limit: []*DynamicIntPointerOpt{}, Offset: []*DynamicIntPointerOpt{}, MaxItems: []*DynamicIntPointerOpt{}, @@ -1673,7 +1673,7 @@ func TestRouteSConfig(t *testing.T) { Context: []*DynamicStringOpt{{value: RoutesContextDftOpt}}, ProfileCount: []*DynamicIntPointerOpt{{value: RoutesProfileCountDftOpt}}, IgnoreErrors: []*DynamicBoolOpt{{value: RoutesIgnoreErrorsDftOpt}}, - MaxCost: []*DynamicInterfaceOpt{}, + MaxCost: []*DynamicInterfaceOpt{{Value: RoutesMaxCostDftOpt}}, Limit: []*DynamicIntPointerOpt{}, Offset: []*DynamicIntPointerOpt{}, MaxItems: []*DynamicIntPointerOpt{}, @@ -4076,7 +4076,7 @@ func TestV1GetConfigRoutes(t *testing.T) { utils.OptsContext: []*DynamicStringOpt{{value: RoutesContextDftOpt}}, utils.MetaProfileCountCfg: []*DynamicIntPointerOpt{{value: RoutesProfileCountDftOpt}}, utils.MetaIgnoreErrorsCfg: []*DynamicBoolOpt{{value: RoutesIgnoreErrorsDftOpt}}, - utils.MetaMaxCostCfg: []*DynamicInterfaceOpt{}, + utils.MetaMaxCostCfg: []*DynamicInterfaceOpt{{Value: RoutesMaxCostDftOpt}}, utils.MetaLimitCfg: []*DynamicIntPointerOpt{}, utils.MetaOffsetCfg: []*DynamicIntPointerOpt{}, utils.MetaMaxItemsCfg: []*DynamicIntPointerOpt{}, @@ -4828,7 +4828,7 @@ func TestV1GetConfigAsJSONThresholdS(t *testing.T) { func TestV1GetConfigAsJSONRouteS(t *testing.T) { var reply string - expected := `{"routes":{"accounts_conns":[],"attributes_conns":[],"default_ratio":1,"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"nested_fields":false,"notexists_indexed_fields":[],"opts":{"*context":[{"FilterIDs":null,"Tenant":""}],"*ignoreErrors":[{"FilterIDs":null,"Tenant":""}],"*limit":[],"*maxCost":[],"*maxItems":[],"*offset":[],"*profileCount":[{"FilterIDs":null,"Tenant":""}],"*usage":[{"FilterIDs":null,"Tenant":""}]},"prefix_indexed_fields":[],"rates_conns":[],"resources_conns":[],"stats_conns":[],"suffix_indexed_fields":[]}}` + expected := `{"routes":{"accounts_conns":[],"attributes_conns":[],"default_ratio":1,"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"nested_fields":false,"notexists_indexed_fields":[],"opts":{"*context":[{"FilterIDs":null,"Tenant":""}],"*ignoreErrors":[{"FilterIDs":null,"Tenant":""}],"*limit":[],"*maxCost":[{"Tenant":"","Value":""}],"*maxItems":[],"*offset":[],"*profileCount":[{"FilterIDs":null,"Tenant":""}],"*usage":[{"FilterIDs":null,"Tenant":""}]},"prefix_indexed_fields":[],"rates_conns":[],"resources_conns":[],"stats_conns":[],"suffix_indexed_fields":[]}}` cgrCfg := NewDefaultCGRConfig() if err := cgrCfg.V1GetConfigAsJSON(context.Background(), &SectionWithAPIOpts{Sections: []string{RouteSJSON}}, &reply); err != nil { t.Error(err) @@ -5069,7 +5069,7 @@ func TestV1GetConfigAsJSONAllConfig(t *testing.T) { } }` var reply string - expected := `{"accounts":{"attributes_conns":[],"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"max_iterations":1000,"max_usage":"259200000000000","nested_fields":false,"notexists_indexed_fields":[],"opts":{"*profileIDs":[],"*profileIgnoreFilters":[{"FilterIDs":null,"Tenant":""}],"*usage":[{"FilterIDs":null,"Tenant":""}]},"prefix_indexed_fields":[],"rates_conns":[],"suffix_indexed_fields":[],"thresholds_conns":[]},"actions":{"accounts_conns":[],"cdrs_conns":[],"dynaprepaid_actionprofile":[],"ees_conns":[],"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"nested_fields":false,"notexists_indexed_fields":[],"opts":{"*posterAttempts":[{"FilterIDs":null,"Tenant":""}],"*profileIDs":[],"*profileIgnoreFilters":[{"FilterIDs":null,"Tenant":""}]},"prefix_indexed_fields":[],"stats_conns":[],"suffix_indexed_fields":[],"tenants":[],"thresholds_conns":[]},"admins":{"actions_conns":[],"attributes_conns":[],"caches_conns":["*internal"],"ees_conns":[],"enabled":false},"analyzers":{"cleanup_interval":"1h0m0s","db_path":"/var/spool/cgrates/analyzers","ees_conns":[],"enabled":false,"index_type":"*scorch","opts":{"*exporterIDs":[]},"ttl":"24h0m0s"},"apiban":{"enabled":false,"keys":[]},"asterisk_agent":{"asterisk_conns":[{"address":"127.0.0.1:8088","alias":"","connect_attempts":3,"max_reconnect_interval":"0s","password":"CGRateS.org","reconnects":5,"user":"cgrates"}],"create_cdr":false,"enabled":false,"sessions_conns":["*birpc_internal"]},"attributes":{"accounts_conns":[],"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"nested_fields":false,"notexists_indexed_fields":[],"opts":{"*processRuns":[{"FilterIDs":null,"Tenant":""}],"*profileIDs":[],"*profileIgnoreFilters":[{"FilterIDs":null,"Tenant":""}],"*profileRuns":[{"FilterIDs":null,"Tenant":""}]},"prefix_indexed_fields":[],"resources_conns":[],"stats_conns":[],"suffix_indexed_fields":[]},"caches":{"partitions":{"*account_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*accounts":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*action_profile_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*action_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*apiban":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"2m0s"},"*attribute_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*attribute_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*caps_events":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*cdr_ids":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"10m0s"},"*charger_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*charger_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*closed_sessions":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"10s"},"*diameter_messages":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"3h0m0s"},"*event_charges":{"limit":0,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"10s"},"*event_resources":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*filters":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*load_ids":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*ranking_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*rankings":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*rate_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*rate_profile_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*rate_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*replication_hosts":{"limit":0,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*resource_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*resource_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*resources":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*reverse_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*route_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*route_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*rpc_connections":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*rpc_responses":{"limit":0,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"2s"},"*sentrypeer":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":true,"ttl":"24h0m0s"},"*stat_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*statqueue_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*statqueues":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*stir":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"3h0m0s"},"*threshold_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*threshold_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*thresholds":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*trend_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*trends":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*uch":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"3h0m0s"}},"remote_conns":[],"replication_conns":[]},"cdrs":{"accounts_conns":[],"actions_conns":[],"attributes_conns":[],"chargers_conns":[],"ees_conns":[],"enabled":false,"extra_fields":[],"online_cdr_exports":null,"opts":{"*accounts":[{"FilterIDs":null,"Tenant":""}],"*attributes":[{"FilterIDs":null,"Tenant":""}],"*chargers":[{"FilterIDs":null,"Tenant":""}],"*ees":[{"FilterIDs":null,"Tenant":""}],"*rates":[{"FilterIDs":null,"Tenant":""}],"*refund":[{"FilterIDs":null,"Tenant":""}],"*rerate":[{"FilterIDs":null,"Tenant":""}],"*stats":[{"FilterIDs":null,"Tenant":""}],"*store":[{"FilterIDs":null,"Tenant":""}],"*thresholds":[{"FilterIDs":null,"Tenant":""}]},"rates_conns":[],"session_cost_retries":5,"stats_conns":[],"thresholds_conns":[]},"chargers":{"attributes_conns":[],"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"nested_fields":false,"notexists_indexed_fields":[],"prefix_indexed_fields":[],"suffix_indexed_fields":[]},"config_db":{"db_host":"","db_name":"","db_password":"","db_port":0,"db_type":"*internal","db_user":"","opts":{"mongoConnScheme":"mongodb","mongoQueryTimeout":"10s","redisCACertificate":"","redisClientCertificate":"","redisClientKey":"","redisCluster":false,"redisClusterOndownDelay":"0s","redisClusterSync":"5s","redisConnectAttempts":20,"redisConnectTimeout":"0s","redisMaxConns":10,"redisReadTimeout":"0s","redisSentinel":"","redisTLS":false,"redisWriteTimeout":"0s"}},"configs":{"enabled":false,"root_dir":"/var/spool/cgrates/configs","url":"/configs/"},"cores":{"caps":0,"caps_stats_interval":"0","caps_strategy":"*busy","ees_conns":[],"shutdown_timeout":"1s"},"data_db":{"db_host":"127.0.0.1","db_name":"10","db_password":"","db_port":6379,"db_type":"*redis","db_user":"cgrates","items":{"*account_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*accounts":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*action_profile_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*action_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*actions":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*attribute_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*attribute_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*charger_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*charger_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*filters":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*load_ids":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*ranking_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*rankings":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*rate_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*rate_profile_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*rate_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*resource_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*resource_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*resources":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*reverse_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*route_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*route_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*stat_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*statqueue_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*statqueues":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*threshold_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*threshold_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*thresholds":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*trend_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*trends":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*versions":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false}},"opts":{"mongoConnScheme":"mongodb","mongoQueryTimeout":"10s","redisCACertificate":"","redisClientCertificate":"","redisClientKey":"","redisCluster":false,"redisClusterOndownDelay":"0s","redisClusterSync":"5s","redisConnectAttempts":20,"redisConnectTimeout":"0s","redisMaxConns":10,"redisPoolPipelineLimit":0,"redisPoolPipelineWindow":"150µs","redisReadTimeout":"0s","redisSentinel":"","redisTLS":false,"redisWriteTimeout":"0s"},"remote_conn_id":"","remote_conns":[],"replication_cache":"","replication_conns":[],"replication_filtered":false},"diameter_agent":{"asr_template":"","dictionaries_path":"/usr/share/cgrates/diameter/dict/","enabled":false,"forced_disconnect":"*none","listen":"127.0.0.1:3868","listen_net":"tcp","origin_host":"CGR-DA","origin_realm":"cgrates.org","product_name":"CGRateS","rar_template":"","request_processors":[],"sessions_conns":["*birpc_internal"],"synced_conn_requests":false,"vendor_id":0},"dns_agent":{"enabled":false,"listeners":[{"address":"127.0.0.1:53","network":"udp"}],"request_processors":[],"sessions_conns":["*internal"],"timezone":""},"ees":{"attributes_conns":[],"cache":{"*fileCSV":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"}},"enabled":false,"exporters":[{"attempts":1,"attribute_context":"","attribute_ids":[],"blocker":false,"concurrent_requests":0,"efs_conns":["*internal"],"export_path":"/var/spool/cgrates/ees","failed_posts_dir":"/var/spool/cgrates/failed_posts","fields":[],"filters":[],"flags":[],"id":"*default","opts":{},"synchronous":false,"timezone":"","type":"*none"}]},"efs":{"enabled":false,"failed_posts_dir":"/var/spool/cgrates/failed_posts","failed_posts_ttl":"5s","poster_attempts":3},"ers":{"enabled":false,"partial_cache_ttl":"1s","readers":[{"cache_dump_fields":[],"concurrent_requests":1024,"fields":[{"mandatory":true,"path":"*cgreq.ToR","tag":"ToR","type":"*variable","value":"~*req.2"},{"mandatory":true,"path":"*cgreq.OriginID","tag":"OriginID","type":"*variable","value":"~*req.3"},{"mandatory":true,"path":"*cgreq.RequestType","tag":"RequestType","type":"*variable","value":"~*req.4"},{"mandatory":true,"path":"*cgreq.Tenant","tag":"Tenant","type":"*variable","value":"~*req.6"},{"mandatory":true,"path":"*cgreq.Category","tag":"Category","type":"*variable","value":"~*req.7"},{"mandatory":true,"path":"*cgreq.Account","tag":"Account","type":"*variable","value":"~*req.8"},{"mandatory":true,"path":"*cgreq.Subject","tag":"Subject","type":"*variable","value":"~*req.9"},{"mandatory":true,"path":"*cgreq.Destination","tag":"Destination","type":"*variable","value":"~*req.10"},{"mandatory":true,"path":"*cgreq.SetupTime","tag":"SetupTime","type":"*variable","value":"~*req.11"},{"mandatory":true,"path":"*cgreq.AnswerTime","tag":"AnswerTime","type":"*variable","value":"~*req.12"},{"mandatory":true,"path":"*cgreq.Usage","tag":"Usage","type":"*variable","value":"~*req.13"}],"filters":[],"flags":[],"id":"*default","max_reconnect_interval":"5m0s","opts":{"csvFieldSeparator":",","csvHeaderDefineChar":":","csvRowLength":0,"natsSubject":"cgrates_cdrs","partialCacheAction":"*none","partialOrderField":"~*req.AnswerTime"},"partial_commit_fields":[],"processed_path":"/var/spool/cgrates/ers/out","reconnects":-1,"run_delay":"0","source_path":"/var/spool/cgrates/ers/in","tenant":"","timezone":"","type":"*none"}],"sessions_conns":["*internal"]},"filters":{"accounts_conns":[],"rankings_conns":[],"resources_conns":[],"stats_conns":[],"trends_conns":[]},"freeswitch_agent":{"active_session_delimiter":",","create_cdr":false,"empty_balance_ann_file":"","empty_balance_context":"","enabled":false,"event_socket_conns":[{"address":"127.0.0.1:8021","alias":"127.0.0.1:8021","max_reconnect_interval":"0s","password":"ClueCon","reconnects":5,"reply_timeout":"1m0s"}],"extra_fields":[],"low_balance_ann_file":"","max_wait_connection":"2s","sessions_conns":["*birpc_internal"],"subscribe_park":true},"general":{"caching_delay":"0","connect_attempts":5,"connect_timeout":"1s","dbdata_encoding":"*msgpack","decimal_max_scale":0,"decimal_min_scale":0,"decimal_precision":0,"decimal_rounding_mode":"*toNearestEven","default_caching":"*reload","default_category":"call","default_request_type":"*rated","default_tenant":"cgrates.org","default_timezone":"Local","digest_equal":":","digest_separator":",","locking_timeout":"0","max_parallel_conns":100,"max_reconnect_interval":"0","node_id":"ENGINE1","opts":{"*exporterIDs":[]},"reconnects":-1,"reply_timeout":"2s","rounding_decimals":5,"rsr_separator":";","tpexport_dir":"/var/spool/cgrates/tpe"},"http":{"auth_users":{},"client_opts":{"dialFallbackDelay":"300ms","dialKeepAlive":"30s","dialTimeout":"30s","disableCompression":false,"disableKeepAlives":false,"expectContinueTimeout":"0s","forceAttemptHttp2":true,"idleConnTimeout":"1m30s","maxConnsPerHost":0,"maxIdleConns":100,"maxIdleConnsPerHost":2,"responseHeaderTimeout":"0s","skipTLSVerification":false,"tlsHandshakeTimeout":"10s"},"freeswitch_cdrs_url":"/freeswitch_json","http_cdrs":"/cdr_http","json_rpc_url":"/jsonrpc","pprof_path":"/debug/pprof/","prometheus_url":"/prometheus","registrars_url":"/registrar","use_basic_auth":false,"ws_url":"/ws"},"http_agent":[],"janus_agent":{"enabled":false,"janus_conns":[{"address":"127.0.0.1:8088","admin_address":"localhost:7188","admin_password":"","type":"*ws"}],"request_processors":[],"sessions_conns":["*internal"],"url":"/janus"},"kamailio_agent":{"create_cdr":false,"enabled":false,"evapi_conns":[{"address":"127.0.0.1:8448","alias":"","max_reconnect_interval":"0s","reconnects":5}],"sessions_conns":["*birpc_internal"],"timezone":""},"listen":{"http":"127.0.0.1:2080","http_tls":"127.0.0.1:2280","rpc_gob":"127.0.0.1:2013","rpc_gob_tls":"127.0.0.1:2023","rpc_json":"127.0.0.1:2012","rpc_json_tls":"127.0.0.1:2022"},"loader":{"actions_conns":["*localhost"],"caches_conns":["*localhost"],"data_path":"./","disable_reverse":false,"field_separator":",","gapi_credentials":".gapi/credentials.json","gapi_token":".gapi/token.json","tpid":""},"loaders":[{"action":"*store","cache":{"*accounts":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*action_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*attributes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*chargers":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*filters":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*rankings":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*rate_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*resources":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*routes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*stats":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*thresholds":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*trends":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"}},"caches_conns":["*internal"],"data":[{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"new_branch":true,"path":"Rules.Type","tag":"Type","type":"*variable","value":"~*req.2"},{"path":"Rules.Element","tag":"Element","type":"*variable","value":"~*req.3"},{"path":"Rules.Values","tag":"Values","type":"*variable","value":"~*req.4"}],"file_name":"Filters.csv","flags":null,"type":"*filters"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"TenantID","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ProfileID","type":"*variable","value":"~*req.1"},{"path":"FilterIDs","tag":"FilterIDs","type":"*variable","value":"~*req.2"},{"path":"Weights","tag":"Weights","type":"*variable","value":"~*req.3"},{"path":"Blockers","tag":"Blockers","type":"*variable","value":"~*req.4"},{"new_branch":true,"path":"Attributes.FilterIDs","tag":"AttributeFilterIDs","type":"*variable","value":"~*req.5"},{"path":"Attributes.Blockers","tag":"AttributeBlockers","type":"*variable","value":"~*req.6"},{"path":"Attributes.Path","tag":"Path","type":"*variable","value":"~*req.7"},{"path":"Attributes.Type","tag":"Type","type":"*variable","value":"~*req.8"},{"path":"Attributes.Value","tag":"Value","type":"*variable","value":"~*req.9"}],"file_name":"Attributes.csv","flags":null,"type":"*attributes"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"FilterIDs","tag":"FilterIDs","type":"*variable","value":"~*req.2"},{"path":"Weights","tag":"Weights","type":"*variable","value":"~*req.3"},{"path":"UsageTTL","tag":"TTL","type":"*variable","value":"~*req.4"},{"path":"Limit","tag":"Limit","type":"*variable","value":"~*req.5"},{"path":"AllocationMessage","tag":"AllocationMessage","type":"*variable","value":"~*req.6"},{"path":"Blocker","tag":"Blocker","type":"*variable","value":"~*req.7"},{"path":"Stored","tag":"Stored","type":"*variable","value":"~*req.8"},{"path":"ThresholdIDs","tag":"ThresholdIDs","type":"*variable","value":"~*req.9"}],"file_name":"Resources.csv","flags":null,"type":"*resources"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"FilterIDs","tag":"FilterIDs","type":"*variable","value":"~*req.2"},{"path":"Weights","tag":"Weights","type":"*variable","value":"~*req.3"},{"path":"Blockers","tag":"Blockers","type":"*variable","value":"~*req.4"},{"path":"QueueLength","tag":"QueueLength","type":"*variable","value":"~*req.5"},{"path":"TTL","tag":"TTL","type":"*variable","value":"~*req.6"},{"path":"MinItems","tag":"MinItems","type":"*variable","value":"~*req.7"},{"path":"Stored","tag":"Stored","type":"*variable","value":"~*req.8"},{"path":"ThresholdIDs","tag":"ThresholdIDs","type":"*variable","value":"~*req.9"},{"new_branch":true,"path":"Metrics.MetricID","tag":"MetricIDs","type":"*variable","value":"~*req.10"},{"path":"Metrics.FilterIDs","tag":"MetricFilterIDs","type":"*variable","value":"~*req.11"},{"path":"Metrics.Blockers","tag":"MetricBlockers","type":"*variable","value":"~*req.12"}],"file_name":"Stats.csv","flags":null,"type":"*stats"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"FilterIDs","tag":"FilterIDs","type":"*variable","value":"~*req.2"},{"path":"Weights","tag":"Weights","type":"*variable","value":"~*req.3"},{"path":"MaxHits","tag":"MaxHits","type":"*variable","value":"~*req.4"},{"path":"MinHits","tag":"MinHits","type":"*variable","value":"~*req.5"},{"path":"MinSleep","tag":"MinSleep","type":"*variable","value":"~*req.6"},{"path":"Blocker","tag":"Blocker","type":"*variable","value":"~*req.7"},{"path":"ActionProfileIDs","tag":"ActionProfileIDs","type":"*variable","value":"~*req.8"},{"path":"Async","tag":"Async","type":"*variable","value":"~*req.9"}],"file_name":"Thresholds.csv","flags":null,"type":"*thresholds"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"Schedule","tag":"Schedule","type":"*variable","value":"~*req.2"},{"path":"StatID","tag":"StatID","type":"*variable","value":"~*req.3"},{"path":"Metrics","tag":"Metrics","type":"*variable","value":"~*req.4"},{"path":"TTL","tag":"TTL","type":"*variable","value":"~*req.5"},{"path":"QueueLength","tag":"QueueLength","type":"*variable","value":"~*req.6"},{"path":"MinItems","tag":"MinItems","type":"*variable","value":"~*req.7"},{"path":"CorrelationType","tag":"CorrelationType","type":"*variable","value":"~*req.8"},{"path":"Tolerance","tag":"Tolerance","type":"*variable","value":"~*req.9"},{"path":"Stored","tag":"Stored","type":"*variable","value":"~*req.10"},{"path":"ThresholdIDs","tag":"ThresholdIDs","type":"*variable","value":"~*req.11"}],"file_name":"Trends.csv","flags":null,"type":"*trends"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"Schedule","tag":"Schedule","type":"*variable","value":"~*req.2"},{"path":"StatIDs","tag":"StatIDs","type":"*variable","value":"~*req.3"},{"path":"MetricIDs","tag":"MetricIDs","type":"*variable","value":"~*req.4"},{"path":"Sorting","tag":"Sorting","type":"*variable","value":"~*req.5"},{"path":"SortingParameters","tag":"SortingParameters","type":"*variable","value":"~*req.6"},{"path":"Stored","tag":"Stored","type":"*variable","value":"~*req.7"},{"path":"ThresholdIDs","tag":"ThresholdIDs","type":"*variable","value":"~*req.8"}],"file_name":"Rankings.csv","flags":null,"type":"*rankings"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"FilterIDs","tag":"FilterIDs","type":"*variable","value":"~*req.2"},{"path":"Weights","tag":"Weights","type":"*variable","value":"~*req.3"},{"path":"Blockers","tag":"Blockers","type":"*variable","value":"~*req.4"},{"path":"Sorting","tag":"Sorting","type":"*variable","value":"~*req.5"},{"path":"SortingParameters","tag":"SortingParameters","type":"*variable","value":"~*req.6"},{"new_branch":true,"path":"Routes.ID","tag":"RouteID","type":"*variable","value":"~*req.7"},{"path":"Routes.FilterIDs","tag":"RouteFilterIDs","type":"*variable","value":"~*req.8"},{"path":"Routes.AccountIDs","tag":"RouteAccountIDs","type":"*variable","value":"~*req.9"},{"path":"Routes.RateProfileIDs","tag":"RouteRateProfileIDs","type":"*variable","value":"~*req.10"},{"path":"Routes.ResourceIDs","tag":"RouteResourceIDs","type":"*variable","value":"~*req.11"},{"path":"Routes.StatIDs","tag":"RouteStatIDs","type":"*variable","value":"~*req.12"},{"path":"Routes.Weights","tag":"RouteWeights","type":"*variable","value":"~*req.13"},{"path":"Routes.Blockers","tag":"RouteBlockers","type":"*variable","value":"~*req.14"},{"path":"Routes.RouteParameters","tag":"RouteParameters","type":"*variable","value":"~*req.15"}],"file_name":"Routes.csv","flags":null,"type":"*routes"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"FilterIDs","tag":"FilterIDs","type":"*variable","value":"~*req.2"},{"path":"Weights","tag":"Weights","type":"*variable","value":"~*req.3"},{"path":"Blockers","tag":"Blockers","type":"*variable","value":"~*req.4"},{"path":"RunID","tag":"RunID","type":"*variable","value":"~*req.5"},{"path":"AttributeIDs","tag":"AttributeIDs","type":"*variable","value":"~*req.6"}],"file_name":"Chargers.csv","flags":null,"type":"*chargers"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"FilterIDs","tag":"FilterIDs","type":"*variable","value":"~*req.2"},{"path":"Weights","tag":"Weights","type":"*variable","value":"~*req.3"},{"path":"MinCost","tag":"MinCost","type":"*variable","value":"~*req.4"},{"path":"MaxCost","tag":"MaxCost","type":"*variable","value":"~*req.5"},{"path":"MaxCostStrategy","tag":"MaxCostStrategy","type":"*variable","value":"~*req.6"},{"filters":["*notempty:~*req.7:"],"path":"Rates[\u003c~*req.7\u003e].FilterIDs","tag":"RateFilterIDs","type":"*variable","value":"~*req.8"},{"filters":["*notempty:~*req.7:"],"path":"Rates[\u003c~*req.7\u003e].ActivationTimes","tag":"RateActivationTimes","type":"*variable","value":"~*req.9"},{"filters":["*notempty:~*req.7:"],"path":"Rates[\u003c~*req.7\u003e].Weights","tag":"RateWeights","type":"*variable","value":"~*req.10"},{"filters":["*notempty:~*req.7:"],"path":"Rates[\u003c~*req.7\u003e].Blocker","tag":"RateBlocker","type":"*variable","value":"~*req.11"},{"filters":["*notempty:~*req.7:"],"new_branch":true,"path":"Rates[\u003c~*req.7\u003e].IntervalRates.IntervalStart","tag":"RateIntervalStart","type":"*variable","value":"~*req.12"},{"filters":["*notempty:~*req.7:"],"path":"Rates[\u003c~*req.7\u003e].IntervalRates.FixedFee","tag":"RateFixedFee","type":"*variable","value":"~*req.13"},{"filters":["*notempty:~*req.7:"],"path":"Rates[\u003c~*req.7\u003e].IntervalRates.RecurrentFee","tag":"RateRecurrentFee","type":"*variable","value":"~*req.14"},{"filters":["*notempty:~*req.7:"],"path":"Rates[\u003c~*req.7\u003e].IntervalRates.Unit","tag":"RateUnit","type":"*variable","value":"~*req.15"},{"filters":["*notempty:~*req.7:"],"path":"Rates[\u003c~*req.7\u003e].IntervalRates.Increment","tag":"RateIncrement","type":"*variable","value":"~*req.16"}],"file_name":"Rates.csv","flags":null,"type":"*rate_profiles"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"FilterIDs","tag":"FilterIDs","type":"*variable","value":"~*req.2"},{"path":"Weights","tag":"Weights","type":"*variable","value":"~*req.3"},{"path":"Blockers","tag":"Blockers","type":"*variable","value":"~*req.4"},{"path":"Schedule","tag":"Schedule","type":"*variable","value":"~*req.5"},{"path":"Targets[\u003c~*req.6\u003e]","tag":"TargetIDs","type":"*variable","value":"~*req.7"},{"filters":["*notempty:~*req.8:"],"path":"Actions[\u003c~*req.8\u003e].FilterIDs","tag":"ActionFilterIDs","type":"*variable","value":"~*req.9"},{"filters":["*notempty:~*req.8:"],"path":"Actions[\u003c~*req.8\u003e].TTL","tag":"ActionTTL","type":"*variable","value":"~*req.10"},{"filters":["*notempty:~*req.8:"],"path":"Actions[\u003c~*req.8\u003e].Type","tag":"ActionType","type":"*variable","value":"~*req.11"},{"filters":["*notempty:~*req.8:"],"path":"Actions[\u003c~*req.8\u003e].Opts","tag":"ActionOpts","type":"*variable","value":"~*req.12"},{"filters":["*notempty:~*req.8:"],"new_branch":true,"path":"Actions[\u003c~*req.8\u003e].Diktats.Path","tag":"ActionPath","type":"*variable","value":"~*req.13"},{"filters":["*notempty:~*req.8:"],"path":"Actions[\u003c~*req.8\u003e].Diktats.Value","tag":"ActionValue","type":"*variable","value":"~*req.14"}],"file_name":"Actions.csv","flags":null,"type":"*action_profiles"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"FilterIDs","tag":"FilterIDs","type":"*variable","value":"~*req.2"},{"path":"Weights","tag":"Weights","type":"*variable","value":"~*req.3"},{"path":"Blockers","tag":"Blockers","type":"*variable","value":"~*req.4"},{"path":"Opts","tag":"Opts","type":"*variable","value":"~*req.5"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].FilterIDs","tag":"BalanceFilterIDs","type":"*variable","value":"~*req.7"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].Weights","tag":"BalanceWeights","type":"*variable","value":"~*req.8"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].Blockers","tag":"BalanceBlockers","type":"*variable","value":"~*req.9"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].Type","tag":"BalanceType","type":"*variable","value":"~*req.10"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].Units","tag":"BalanceUnits","type":"*variable","value":"~*req.11"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].UnitFactors","tag":"BalanceUnitFactors","type":"*variable","value":"~*req.12"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].Opts","tag":"BalanceOpts","type":"*variable","value":"~*req.13"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].CostIncrements","tag":"BalanceCostIncrements","type":"*variable","value":"~*req.14"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].AttributeIDs","tag":"BalanceAttributeIDs","type":"*variable","value":"~*req.15"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].RateProfileIDs","tag":"BalanceRateProfileIDs","type":"*variable","value":"~*req.16"},{"path":"ThresholdIDs","tag":"ThresholdIDs","type":"*variable","value":"~*req.17"}],"file_name":"Accounts.csv","flags":null,"type":"*accounts"}],"enabled":false,"field_separator":",","id":"*default","lockfile_path":".cgr.lck","opts":{"*cache":"","*forceLock":false,"*stopOnError":false,"*withIndex":true},"run_delay":"0","tenant":"","tp_in_dir":"/var/spool/cgrates/loader/in","tp_out_dir":"/var/spool/cgrates/loader/out"}],"logger":{"efs_conns":["*internal"],"level":6,"opts":{"failed_posts_dir":"/var/spool/cgrates/failed_posts","kafka_attempts":1,"kafka_conn":"","kafka_topic":""},"type":"*syslog"},"migrator":{"out_datadb_encoding":"msgpack","out_datadb_host":"127.0.0.1","out_datadb_name":"10","out_datadb_opts":{"mongoConnScheme":"mongodb","mongoQueryTimeout":"10s","redisCACertificate":"","redisClientCertificate":"","redisClientKey":"","redisCluster":false,"redisClusterOndownDelay":"0s","redisClusterSync":"5s","redisConnectAttempts":20,"redisConnectTimeout":"0s","redisMaxConns":10,"redisPoolPipelineLimit":0,"redisPoolPipelineWindow":"150µs","redisReadTimeout":"0s","redisSentinel":"","redisTLS":false,"redisWriteTimeout":"0s"},"out_datadb_password":"","out_datadb_port":"6379","out_datadb_type":"*redis","out_datadb_user":"cgrates","users_filters":null},"radius_agent":{"client_dictionaries":{"*default":"/usr/share/cgrates/radius/dict/"},"client_secrets":{"*default":"CGRateS.org"},"enabled":false,"listen_acct":"127.0.0.1:1813","listen_auth":"127.0.0.1:1812","listen_net":"udp","request_processors":[],"sessions_conns":["*internal"]},"rankings":{"ees_conns":[],"ees_exporter_ids":null,"enabled":false,"scheduled_ids":{},"stats_conns":[],"store_interval":"","thresholds_conns":[]},"rates":{"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"nested_fields":false,"notexists_indexed_fields":[],"opts":{"*intervalStart":[{"FilterIDs":null,"Tenant":""}],"*profileIDs":[],"*profileIgnoreFilters":[{"FilterIDs":null,"Tenant":""}],"*startTime":[{"FilterIDs":null,"Tenant":""}],"*usage":[{"FilterIDs":null,"Tenant":""}]},"prefix_indexed_fields":[],"rate_exists_indexed_fields":[],"rate_indexed_selects":true,"rate_nested_fields":false,"rate_notexists_indexed_fields":[],"rate_prefix_indexed_fields":[],"rate_suffix_indexed_fields":[],"suffix_indexed_fields":[],"verbosity":1000},"registrarc":{"rpc":{"hosts":[],"refresh_interval":"5m0s","registrars_conns":[]}},"resources":{"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"nested_fields":false,"notexists_indexed_fields":[],"opts":{"*units":[{"FilterIDs":null,"Tenant":""}],"*usageID":[{"FilterIDs":null,"Tenant":""}],"*usageTTL":[{"FilterIDs":null,"Tenant":""}]},"prefix_indexed_fields":[],"store_interval":"","suffix_indexed_fields":[],"thresholds_conns":[]},"routes":{"accounts_conns":[],"attributes_conns":[],"default_ratio":1,"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"nested_fields":false,"notexists_indexed_fields":[],"opts":{"*context":[{"FilterIDs":null,"Tenant":""}],"*ignoreErrors":[{"FilterIDs":null,"Tenant":""}],"*limit":[],"*maxCost":[],"*maxItems":[],"*offset":[],"*profileCount":[{"FilterIDs":null,"Tenant":""}],"*usage":[{"FilterIDs":null,"Tenant":""}]},"prefix_indexed_fields":[],"rates_conns":[],"resources_conns":[],"stats_conns":[],"suffix_indexed_fields":[]},"rpc_conns":{"*bijson_localhost":{"conns":[{"address":"127.0.0.1:2014","transport":"*birpc_json"}],"poolSize":0,"strategy":"*first"},"*birpc_internal":{"conns":[{"address":"*birpc_internal","transport":""}],"poolSize":0,"strategy":"*first"},"*internal":{"conns":[{"address":"*internal","transport":""}],"poolSize":0,"strategy":"*first"},"*localhost":{"conns":[{"address":"127.0.0.1:2012","transport":"*json"}],"poolSize":0,"strategy":"*first"}},"sentrypeer":{"audience":"https://sentrypeer.com/api","client_id":"","client_secret":"","grant_type":"client_credentials","ips_url":"https://sentrypeer.com/api/ip-addresses","numbers_url":"https://sentrypeer.com/api/phone-numbers","token_url":"https://authz.sentrypeer.com/oauth/token"},"sessions":{"accounts_conns":[],"actions_conns":[],"alterable_fields":[],"attributes_conns":[],"cdrs_conns":[],"channel_sync_interval":"0","chargers_conns":[],"client_protocol":1,"default_usage":{"*any":"3h0m0s","*data":"1048576","*sms":"1","*voice":"3h0m0s"},"enabled":false,"listen_bigob":"","listen_bijson":"127.0.0.1:2014","min_dur_low_balance":"0","opts":{"*accounts":[{"FilterIDs":null,"Tenant":""}],"*attributes":[{"FilterIDs":null,"Tenant":""}],"*attributesDerivedReply":[{"FilterIDs":null,"Tenant":""}],"*blockerError":[{"FilterIDs":null,"Tenant":""}],"*cdrs":[{"FilterIDs":null,"Tenant":""}],"*cdrsDerivedReply":[{"FilterIDs":null,"Tenant":""}],"*chargeable":[{"FilterIDs":null,"Tenant":""}],"*chargers":[{"FilterIDs":null,"Tenant":""}],"*debitInterval":[{"FilterIDs":null,"Tenant":""}],"*forceUsage":[],"*initiate":[{"FilterIDs":null,"Tenant":""}],"*maxUsage":[{"FilterIDs":null,"Tenant":""}],"*message":[{"FilterIDs":null,"Tenant":""}],"*resources":[{"FilterIDs":null,"Tenant":""}],"*resourcesAllocate":[{"FilterIDs":null,"Tenant":""}],"*resourcesAuthorize":[{"FilterIDs":null,"Tenant":""}],"*resourcesDerivedReply":[{"FilterIDs":null,"Tenant":""}],"*resourcesRelease":[{"FilterIDs":null,"Tenant":""}],"*routes":[{"FilterIDs":null,"Tenant":""}],"*routesDerivedReply":[{"FilterIDs":null,"Tenant":""}],"*stats":[{"FilterIDs":null,"Tenant":""}],"*statsDerivedReply":[{"FilterIDs":null,"Tenant":""}],"*terminate":[{"FilterIDs":null,"Tenant":""}],"*thresholds":[{"FilterIDs":null,"Tenant":""}],"*thresholdsDerivedReply":[{"FilterIDs":null,"Tenant":""}],"*ttl":[{"FilterIDs":null,"Tenant":""}],"*ttlLastUsage":[],"*ttlLastUsed":[],"*ttlMaxDelay":[{"FilterIDs":null,"Tenant":""}],"*ttlUsage":[],"*update":[{"FilterIDs":null,"Tenant":""}]},"rates_conns":[],"replication_conns":[],"resources_conns":[],"routes_conns":[],"session_indexes":[],"stats_conns":[],"stir":{"allowed_attest":["*any"],"default_attest":"A","payload_maxduration":"-1","privatekey_path":"","publickey_path":""},"store_session_costs":false,"terminate_attempts":5,"thresholds_conns":[]},"sip_agent":{"enabled":false,"listen":"127.0.0.1:5060","listen_net":"udp","request_processors":[],"retransmission_timer":"1s","sessions_conns":["*internal"],"timezone":""},"stats":{"ees_conns":[],"ees_exporter_ids":null,"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"nested_fields":false,"notexists_indexed_fields":[],"opts":{"*profileIDs":[],"*profileIgnoreFilters":[{"FilterIDs":null,"Tenant":""}],"*prometheusStatIDs":[],"*roundingDecimals":[]},"prefix_indexed_fields":[],"store_interval":"","store_uncompressed_limit":0,"suffix_indexed_fields":[],"thresholds_conns":[]},"stor_db":{"db_host":"127.0.0.1","db_name":"cgrates","db_password":"CGRateS.org","db_port":3306,"db_type":"**mysql","db_user":"cgrates","items":{"*cdrs":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false}},"opts":{"mongoConnScheme":"mongodb","mongoQueryTimeout":"10s","mysqlDSNParams":{},"mysqlLocation":"Local","pgSSLMode":"disable","sqlConnMaxLifetime":"0s","sqlMaxIdleConns":10,"sqlMaxOpenConns":100},"prefix_indexed_fields":[],"remote_conns":null,"replication_conns":null,"string_indexed_fields":[]},"suretax":{"bill_to_number":"","business_unit":"","client_number":"","client_tracking":"~*opts.*originID","customer_number":"~*req.Subject","include_local_cost":false,"orig_number":"~*req.Subject","p2pplus4":"","p2pzipcode":"","plus4":"","regulatory_code":"03","response_group":"03","response_type":"D4","return_file_code":"0","sales_type_code":"R","tax_exemption_code_list":"","tax_included":"0","tax_situs_rule":"04","term_number":"~*req.Destination","timezone":"UTC","trans_type_code":"010101","unit_type":"00","units":"1","url":"","validation_key":"","zipcode":""},"templates":{"*asr":[{"mandatory":true,"path":"*diamreq.Session-Id","tag":"SessionId","type":"*variable","value":"~*req.Session-Id"},{"mandatory":true,"path":"*diamreq.Origin-Host","tag":"OriginHost","type":"*variable","value":"~*req.Destination-Host"},{"mandatory":true,"path":"*diamreq.Origin-Realm","tag":"OriginRealm","type":"*variable","value":"~*req.Destination-Realm"},{"mandatory":true,"path":"*diamreq.Destination-Realm","tag":"DestinationRealm","type":"*variable","value":"~*req.Origin-Realm"},{"mandatory":true,"path":"*diamreq.Destination-Host","tag":"DestinationHost","type":"*variable","value":"~*req.Origin-Host"},{"mandatory":true,"path":"*diamreq.Auth-Application-Id","tag":"AuthApplicationId","type":"*variable","value":"~*vars.*appid"}],"*cca":[{"mandatory":true,"path":"*rep.Session-Id","tag":"SessionId","type":"*variable","value":"~*req.Session-Id"},{"path":"*rep.Result-Code","tag":"ResultCode","type":"*constant","value":"2001"},{"mandatory":true,"path":"*rep.Origin-Host","tag":"OriginHost","type":"*variable","value":"~*vars.OriginHost"},{"mandatory":true,"path":"*rep.Origin-Realm","tag":"OriginRealm","type":"*variable","value":"~*vars.OriginRealm"},{"mandatory":true,"path":"*rep.Auth-Application-Id","tag":"AuthApplicationId","type":"*variable","value":"~*vars.*appid"},{"mandatory":true,"path":"*rep.CC-Request-Type","tag":"CCRequestType","type":"*variable","value":"~*req.CC-Request-Type"},{"mandatory":true,"path":"*rep.CC-Request-Number","tag":"CCRequestNumber","type":"*variable","value":"~*req.CC-Request-Number"}],"*cdrLog":[{"mandatory":true,"path":"*cdr.ToR","tag":"ToR","type":"*variable","value":"~*req.BalanceType"},{"mandatory":true,"path":"*cdr.OriginHost","tag":"OriginHost","type":"*constant","value":"127.0.0.1"},{"mandatory":true,"path":"*cdr.RequestType","tag":"RequestType","type":"*constant","value":"*none"},{"mandatory":true,"path":"*cdr.Tenant","tag":"Tenant","type":"*variable","value":"~*req.Tenant"},{"mandatory":true,"path":"*cdr.Account","tag":"Account","type":"*variable","value":"~*req.Account"},{"mandatory":true,"path":"*cdr.Subject","tag":"Subject","type":"*variable","value":"~*req.Account"},{"mandatory":true,"path":"*cdr.Cost","tag":"Cost","type":"*variable","value":"~*req.Cost"},{"mandatory":true,"path":"*cdr.Source","tag":"Source","type":"*constant","value":"*cdrLog"},{"mandatory":true,"path":"*cdr.Usage","tag":"Usage","type":"*constant","value":"1"},{"mandatory":true,"path":"*cdr.RunID","tag":"RunID","type":"*variable","value":"~*req.ActionType"},{"mandatory":true,"path":"*cdr.SetupTime","tag":"SetupTime","type":"*constant","value":"*now"},{"mandatory":true,"path":"*cdr.AnswerTime","tag":"AnswerTime","type":"*constant","value":"*now"},{"mandatory":true,"path":"*cdr.PreRated","tag":"PreRated","type":"*constant","value":"true"}],"*err":[{"mandatory":true,"path":"*rep.Session-Id","tag":"SessionId","type":"*variable","value":"~*req.Session-Id"},{"mandatory":true,"path":"*rep.Origin-Host","tag":"OriginHost","type":"*variable","value":"~*vars.OriginHost"},{"mandatory":true,"path":"*rep.Origin-Realm","tag":"OriginRealm","type":"*variable","value":"~*vars.OriginRealm"}],"*errSip":[{"mandatory":true,"path":"*rep.Request","tag":"Request","type":"*constant","value":"SIP/2.0 500 Internal Server Error"}],"*rar":[{"mandatory":true,"path":"*diamreq.Session-Id","tag":"SessionId","type":"*variable","value":"~*req.Session-Id"},{"mandatory":true,"path":"*diamreq.Origin-Host","tag":"OriginHost","type":"*variable","value":"~*req.Destination-Host"},{"mandatory":true,"path":"*diamreq.Origin-Realm","tag":"OriginRealm","type":"*variable","value":"~*req.Destination-Realm"},{"mandatory":true,"path":"*diamreq.Destination-Realm","tag":"DestinationRealm","type":"*variable","value":"~*req.Origin-Realm"},{"mandatory":true,"path":"*diamreq.Destination-Host","tag":"DestinationHost","type":"*variable","value":"~*req.Origin-Host"},{"mandatory":true,"path":"*diamreq.Auth-Application-Id","tag":"AuthApplicationId","type":"*variable","value":"~*vars.*appid"},{"path":"*diamreq.Re-Auth-Request-Type","tag":"ReAuthRequestType","type":"*constant","value":"0"}]},"thresholds":{"actions_conns":[],"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"nested_fields":false,"notexists_indexed_fields":[],"opts":{"*profileIDs":[],"*profileIgnoreFilters":[{"FilterIDs":null,"Tenant":""}]},"prefix_indexed_fields":[],"store_interval":"","suffix_indexed_fields":[]},"tls":{"ca_certificate":"","client_certificate":"","client_key":"","server_certificate":"","server_key":"","server_name":"","server_policy":4},"tpes":{"enabled":false},"trends":{"ees_conns":[],"ees_exporter_ids":null,"enabled":false,"scheduled_ids":{},"stats_conns":[],"store_interval":"","store_uncompressed_limit":0,"thresholds_conns":[]}}` + expected := `{"accounts":{"attributes_conns":[],"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"max_iterations":1000,"max_usage":"259200000000000","nested_fields":false,"notexists_indexed_fields":[],"opts":{"*profileIDs":[],"*profileIgnoreFilters":[{"FilterIDs":null,"Tenant":""}],"*usage":[{"FilterIDs":null,"Tenant":""}]},"prefix_indexed_fields":[],"rates_conns":[],"suffix_indexed_fields":[],"thresholds_conns":[]},"actions":{"accounts_conns":[],"cdrs_conns":[],"dynaprepaid_actionprofile":[],"ees_conns":[],"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"nested_fields":false,"notexists_indexed_fields":[],"opts":{"*posterAttempts":[{"FilterIDs":null,"Tenant":""}],"*profileIDs":[],"*profileIgnoreFilters":[{"FilterIDs":null,"Tenant":""}]},"prefix_indexed_fields":[],"stats_conns":[],"suffix_indexed_fields":[],"tenants":[],"thresholds_conns":[]},"admins":{"actions_conns":[],"attributes_conns":[],"caches_conns":["*internal"],"ees_conns":[],"enabled":false},"analyzers":{"cleanup_interval":"1h0m0s","db_path":"/var/spool/cgrates/analyzers","ees_conns":[],"enabled":false,"index_type":"*scorch","opts":{"*exporterIDs":[]},"ttl":"24h0m0s"},"apiban":{"enabled":false,"keys":[]},"asterisk_agent":{"asterisk_conns":[{"address":"127.0.0.1:8088","alias":"","connect_attempts":3,"max_reconnect_interval":"0s","password":"CGRateS.org","reconnects":5,"user":"cgrates"}],"create_cdr":false,"enabled":false,"sessions_conns":["*birpc_internal"]},"attributes":{"accounts_conns":[],"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"nested_fields":false,"notexists_indexed_fields":[],"opts":{"*processRuns":[{"FilterIDs":null,"Tenant":""}],"*profileIDs":[],"*profileIgnoreFilters":[{"FilterIDs":null,"Tenant":""}],"*profileRuns":[{"FilterIDs":null,"Tenant":""}]},"prefix_indexed_fields":[],"resources_conns":[],"stats_conns":[],"suffix_indexed_fields":[]},"caches":{"partitions":{"*account_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*accounts":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*action_profile_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*action_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*apiban":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"2m0s"},"*attribute_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*attribute_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*caps_events":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*cdr_ids":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"10m0s"},"*charger_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*charger_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*closed_sessions":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"10s"},"*diameter_messages":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"3h0m0s"},"*event_charges":{"limit":0,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"10s"},"*event_resources":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*filters":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*load_ids":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*ranking_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*rankings":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*rate_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*rate_profile_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*rate_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*replication_hosts":{"limit":0,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*resource_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*resource_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*resources":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*reverse_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*route_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*route_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*rpc_connections":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*rpc_responses":{"limit":0,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"2s"},"*sentrypeer":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":true,"ttl":"24h0m0s"},"*stat_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*statqueue_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*statqueues":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*stir":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"3h0m0s"},"*threshold_filter_indexes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*threshold_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*thresholds":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*trend_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*trends":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false},"*uch":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"3h0m0s"}},"remote_conns":[],"replication_conns":[]},"cdrs":{"accounts_conns":[],"actions_conns":[],"attributes_conns":[],"chargers_conns":[],"ees_conns":[],"enabled":false,"extra_fields":[],"online_cdr_exports":null,"opts":{"*accounts":[{"FilterIDs":null,"Tenant":""}],"*attributes":[{"FilterIDs":null,"Tenant":""}],"*chargers":[{"FilterIDs":null,"Tenant":""}],"*ees":[{"FilterIDs":null,"Tenant":""}],"*rates":[{"FilterIDs":null,"Tenant":""}],"*refund":[{"FilterIDs":null,"Tenant":""}],"*rerate":[{"FilterIDs":null,"Tenant":""}],"*stats":[{"FilterIDs":null,"Tenant":""}],"*store":[{"FilterIDs":null,"Tenant":""}],"*thresholds":[{"FilterIDs":null,"Tenant":""}]},"rates_conns":[],"session_cost_retries":5,"stats_conns":[],"thresholds_conns":[]},"chargers":{"attributes_conns":[],"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"nested_fields":false,"notexists_indexed_fields":[],"prefix_indexed_fields":[],"suffix_indexed_fields":[]},"config_db":{"db_host":"","db_name":"","db_password":"","db_port":0,"db_type":"*internal","db_user":"","opts":{"mongoConnScheme":"mongodb","mongoQueryTimeout":"10s","redisCACertificate":"","redisClientCertificate":"","redisClientKey":"","redisCluster":false,"redisClusterOndownDelay":"0s","redisClusterSync":"5s","redisConnectAttempts":20,"redisConnectTimeout":"0s","redisMaxConns":10,"redisReadTimeout":"0s","redisSentinel":"","redisTLS":false,"redisWriteTimeout":"0s"}},"configs":{"enabled":false,"root_dir":"/var/spool/cgrates/configs","url":"/configs/"},"cores":{"caps":0,"caps_stats_interval":"0","caps_strategy":"*busy","ees_conns":[],"shutdown_timeout":"1s"},"data_db":{"db_host":"127.0.0.1","db_name":"10","db_password":"","db_port":6379,"db_type":"*redis","db_user":"cgrates","items":{"*account_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*accounts":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*action_profile_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*action_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*actions":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*attribute_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*attribute_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*charger_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*charger_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*filters":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*load_ids":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*ranking_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*rankings":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*rate_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*rate_profile_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*rate_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*resource_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*resource_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*resources":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*reverse_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*route_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*route_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*stat_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*statqueue_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*statqueues":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*threshold_filter_indexes":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*threshold_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*thresholds":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*trend_profiles":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*trends":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false},"*versions":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false}},"opts":{"mongoConnScheme":"mongodb","mongoQueryTimeout":"10s","redisCACertificate":"","redisClientCertificate":"","redisClientKey":"","redisCluster":false,"redisClusterOndownDelay":"0s","redisClusterSync":"5s","redisConnectAttempts":20,"redisConnectTimeout":"0s","redisMaxConns":10,"redisPoolPipelineLimit":0,"redisPoolPipelineWindow":"150µs","redisReadTimeout":"0s","redisSentinel":"","redisTLS":false,"redisWriteTimeout":"0s"},"remote_conn_id":"","remote_conns":[],"replication_cache":"","replication_conns":[],"replication_filtered":false},"diameter_agent":{"asr_template":"","dictionaries_path":"/usr/share/cgrates/diameter/dict/","enabled":false,"forced_disconnect":"*none","listen":"127.0.0.1:3868","listen_net":"tcp","origin_host":"CGR-DA","origin_realm":"cgrates.org","product_name":"CGRateS","rar_template":"","request_processors":[],"sessions_conns":["*birpc_internal"],"synced_conn_requests":false,"vendor_id":0},"dns_agent":{"enabled":false,"listeners":[{"address":"127.0.0.1:53","network":"udp"}],"request_processors":[],"sessions_conns":["*internal"],"timezone":""},"ees":{"attributes_conns":[],"cache":{"*fileCSV":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"}},"enabled":false,"exporters":[{"attempts":1,"attribute_context":"","attribute_ids":[],"blocker":false,"concurrent_requests":0,"efs_conns":["*internal"],"export_path":"/var/spool/cgrates/ees","failed_posts_dir":"/var/spool/cgrates/failed_posts","fields":[],"filters":[],"flags":[],"id":"*default","opts":{},"synchronous":false,"timezone":"","type":"*none"}]},"efs":{"enabled":false,"failed_posts_dir":"/var/spool/cgrates/failed_posts","failed_posts_ttl":"5s","poster_attempts":3},"ers":{"enabled":false,"partial_cache_ttl":"1s","readers":[{"cache_dump_fields":[],"concurrent_requests":1024,"fields":[{"mandatory":true,"path":"*cgreq.ToR","tag":"ToR","type":"*variable","value":"~*req.2"},{"mandatory":true,"path":"*cgreq.OriginID","tag":"OriginID","type":"*variable","value":"~*req.3"},{"mandatory":true,"path":"*cgreq.RequestType","tag":"RequestType","type":"*variable","value":"~*req.4"},{"mandatory":true,"path":"*cgreq.Tenant","tag":"Tenant","type":"*variable","value":"~*req.6"},{"mandatory":true,"path":"*cgreq.Category","tag":"Category","type":"*variable","value":"~*req.7"},{"mandatory":true,"path":"*cgreq.Account","tag":"Account","type":"*variable","value":"~*req.8"},{"mandatory":true,"path":"*cgreq.Subject","tag":"Subject","type":"*variable","value":"~*req.9"},{"mandatory":true,"path":"*cgreq.Destination","tag":"Destination","type":"*variable","value":"~*req.10"},{"mandatory":true,"path":"*cgreq.SetupTime","tag":"SetupTime","type":"*variable","value":"~*req.11"},{"mandatory":true,"path":"*cgreq.AnswerTime","tag":"AnswerTime","type":"*variable","value":"~*req.12"},{"mandatory":true,"path":"*cgreq.Usage","tag":"Usage","type":"*variable","value":"~*req.13"}],"filters":[],"flags":[],"id":"*default","max_reconnect_interval":"5m0s","opts":{"csvFieldSeparator":",","csvHeaderDefineChar":":","csvRowLength":0,"natsSubject":"cgrates_cdrs","partialCacheAction":"*none","partialOrderField":"~*req.AnswerTime"},"partial_commit_fields":[],"processed_path":"/var/spool/cgrates/ers/out","reconnects":-1,"run_delay":"0","source_path":"/var/spool/cgrates/ers/in","tenant":"","timezone":"","type":"*none"}],"sessions_conns":["*internal"]},"filters":{"accounts_conns":[],"rankings_conns":[],"resources_conns":[],"stats_conns":[],"trends_conns":[]},"freeswitch_agent":{"active_session_delimiter":",","create_cdr":false,"empty_balance_ann_file":"","empty_balance_context":"","enabled":false,"event_socket_conns":[{"address":"127.0.0.1:8021","alias":"127.0.0.1:8021","max_reconnect_interval":"0s","password":"ClueCon","reconnects":5,"reply_timeout":"1m0s"}],"extra_fields":[],"low_balance_ann_file":"","max_wait_connection":"2s","sessions_conns":["*birpc_internal"],"subscribe_park":true},"general":{"caching_delay":"0","connect_attempts":5,"connect_timeout":"1s","dbdata_encoding":"*msgpack","decimal_max_scale":0,"decimal_min_scale":0,"decimal_precision":0,"decimal_rounding_mode":"*toNearestEven","default_caching":"*reload","default_category":"call","default_request_type":"*rated","default_tenant":"cgrates.org","default_timezone":"Local","digest_equal":":","digest_separator":",","locking_timeout":"0","max_parallel_conns":100,"max_reconnect_interval":"0","node_id":"ENGINE1","opts":{"*exporterIDs":[]},"reconnects":-1,"reply_timeout":"2s","rounding_decimals":5,"rsr_separator":";","tpexport_dir":"/var/spool/cgrates/tpe"},"http":{"auth_users":{},"client_opts":{"dialFallbackDelay":"300ms","dialKeepAlive":"30s","dialTimeout":"30s","disableCompression":false,"disableKeepAlives":false,"expectContinueTimeout":"0s","forceAttemptHttp2":true,"idleConnTimeout":"1m30s","maxConnsPerHost":0,"maxIdleConns":100,"maxIdleConnsPerHost":2,"responseHeaderTimeout":"0s","skipTLSVerification":false,"tlsHandshakeTimeout":"10s"},"freeswitch_cdrs_url":"/freeswitch_json","http_cdrs":"/cdr_http","json_rpc_url":"/jsonrpc","pprof_path":"/debug/pprof/","prometheus_url":"/prometheus","registrars_url":"/registrar","use_basic_auth":false,"ws_url":"/ws"},"http_agent":[],"janus_agent":{"enabled":false,"janus_conns":[{"address":"127.0.0.1:8088","admin_address":"localhost:7188","admin_password":"","type":"*ws"}],"request_processors":[],"sessions_conns":["*internal"],"url":"/janus"},"kamailio_agent":{"create_cdr":false,"enabled":false,"evapi_conns":[{"address":"127.0.0.1:8448","alias":"","max_reconnect_interval":"0s","reconnects":5}],"sessions_conns":["*birpc_internal"],"timezone":""},"listen":{"http":"127.0.0.1:2080","http_tls":"127.0.0.1:2280","rpc_gob":"127.0.0.1:2013","rpc_gob_tls":"127.0.0.1:2023","rpc_json":"127.0.0.1:2012","rpc_json_tls":"127.0.0.1:2022"},"loader":{"actions_conns":["*localhost"],"caches_conns":["*localhost"],"data_path":"./","disable_reverse":false,"field_separator":",","gapi_credentials":".gapi/credentials.json","gapi_token":".gapi/token.json","tpid":""},"loaders":[{"action":"*store","cache":{"*accounts":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*action_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*attributes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*chargers":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*filters":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*rankings":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*rate_profiles":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*resources":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*routes":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*stats":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*thresholds":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"},"*trends":{"limit":-1,"precache":false,"remote":false,"replicate":false,"static_ttl":false,"ttl":"5s"}},"caches_conns":["*internal"],"data":[{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"new_branch":true,"path":"Rules.Type","tag":"Type","type":"*variable","value":"~*req.2"},{"path":"Rules.Element","tag":"Element","type":"*variable","value":"~*req.3"},{"path":"Rules.Values","tag":"Values","type":"*variable","value":"~*req.4"}],"file_name":"Filters.csv","flags":null,"type":"*filters"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"TenantID","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ProfileID","type":"*variable","value":"~*req.1"},{"path":"FilterIDs","tag":"FilterIDs","type":"*variable","value":"~*req.2"},{"path":"Weights","tag":"Weights","type":"*variable","value":"~*req.3"},{"path":"Blockers","tag":"Blockers","type":"*variable","value":"~*req.4"},{"new_branch":true,"path":"Attributes.FilterIDs","tag":"AttributeFilterIDs","type":"*variable","value":"~*req.5"},{"path":"Attributes.Blockers","tag":"AttributeBlockers","type":"*variable","value":"~*req.6"},{"path":"Attributes.Path","tag":"Path","type":"*variable","value":"~*req.7"},{"path":"Attributes.Type","tag":"Type","type":"*variable","value":"~*req.8"},{"path":"Attributes.Value","tag":"Value","type":"*variable","value":"~*req.9"}],"file_name":"Attributes.csv","flags":null,"type":"*attributes"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"FilterIDs","tag":"FilterIDs","type":"*variable","value":"~*req.2"},{"path":"Weights","tag":"Weights","type":"*variable","value":"~*req.3"},{"path":"UsageTTL","tag":"TTL","type":"*variable","value":"~*req.4"},{"path":"Limit","tag":"Limit","type":"*variable","value":"~*req.5"},{"path":"AllocationMessage","tag":"AllocationMessage","type":"*variable","value":"~*req.6"},{"path":"Blocker","tag":"Blocker","type":"*variable","value":"~*req.7"},{"path":"Stored","tag":"Stored","type":"*variable","value":"~*req.8"},{"path":"ThresholdIDs","tag":"ThresholdIDs","type":"*variable","value":"~*req.9"}],"file_name":"Resources.csv","flags":null,"type":"*resources"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"FilterIDs","tag":"FilterIDs","type":"*variable","value":"~*req.2"},{"path":"Weights","tag":"Weights","type":"*variable","value":"~*req.3"},{"path":"Blockers","tag":"Blockers","type":"*variable","value":"~*req.4"},{"path":"QueueLength","tag":"QueueLength","type":"*variable","value":"~*req.5"},{"path":"TTL","tag":"TTL","type":"*variable","value":"~*req.6"},{"path":"MinItems","tag":"MinItems","type":"*variable","value":"~*req.7"},{"path":"Stored","tag":"Stored","type":"*variable","value":"~*req.8"},{"path":"ThresholdIDs","tag":"ThresholdIDs","type":"*variable","value":"~*req.9"},{"new_branch":true,"path":"Metrics.MetricID","tag":"MetricIDs","type":"*variable","value":"~*req.10"},{"path":"Metrics.FilterIDs","tag":"MetricFilterIDs","type":"*variable","value":"~*req.11"},{"path":"Metrics.Blockers","tag":"MetricBlockers","type":"*variable","value":"~*req.12"}],"file_name":"Stats.csv","flags":null,"type":"*stats"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"FilterIDs","tag":"FilterIDs","type":"*variable","value":"~*req.2"},{"path":"Weights","tag":"Weights","type":"*variable","value":"~*req.3"},{"path":"MaxHits","tag":"MaxHits","type":"*variable","value":"~*req.4"},{"path":"MinHits","tag":"MinHits","type":"*variable","value":"~*req.5"},{"path":"MinSleep","tag":"MinSleep","type":"*variable","value":"~*req.6"},{"path":"Blocker","tag":"Blocker","type":"*variable","value":"~*req.7"},{"path":"ActionProfileIDs","tag":"ActionProfileIDs","type":"*variable","value":"~*req.8"},{"path":"Async","tag":"Async","type":"*variable","value":"~*req.9"}],"file_name":"Thresholds.csv","flags":null,"type":"*thresholds"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"Schedule","tag":"Schedule","type":"*variable","value":"~*req.2"},{"path":"StatID","tag":"StatID","type":"*variable","value":"~*req.3"},{"path":"Metrics","tag":"Metrics","type":"*variable","value":"~*req.4"},{"path":"TTL","tag":"TTL","type":"*variable","value":"~*req.5"},{"path":"QueueLength","tag":"QueueLength","type":"*variable","value":"~*req.6"},{"path":"MinItems","tag":"MinItems","type":"*variable","value":"~*req.7"},{"path":"CorrelationType","tag":"CorrelationType","type":"*variable","value":"~*req.8"},{"path":"Tolerance","tag":"Tolerance","type":"*variable","value":"~*req.9"},{"path":"Stored","tag":"Stored","type":"*variable","value":"~*req.10"},{"path":"ThresholdIDs","tag":"ThresholdIDs","type":"*variable","value":"~*req.11"}],"file_name":"Trends.csv","flags":null,"type":"*trends"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"Schedule","tag":"Schedule","type":"*variable","value":"~*req.2"},{"path":"StatIDs","tag":"StatIDs","type":"*variable","value":"~*req.3"},{"path":"MetricIDs","tag":"MetricIDs","type":"*variable","value":"~*req.4"},{"path":"Sorting","tag":"Sorting","type":"*variable","value":"~*req.5"},{"path":"SortingParameters","tag":"SortingParameters","type":"*variable","value":"~*req.6"},{"path":"Stored","tag":"Stored","type":"*variable","value":"~*req.7"},{"path":"ThresholdIDs","tag":"ThresholdIDs","type":"*variable","value":"~*req.8"}],"file_name":"Rankings.csv","flags":null,"type":"*rankings"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"FilterIDs","tag":"FilterIDs","type":"*variable","value":"~*req.2"},{"path":"Weights","tag":"Weights","type":"*variable","value":"~*req.3"},{"path":"Blockers","tag":"Blockers","type":"*variable","value":"~*req.4"},{"path":"Sorting","tag":"Sorting","type":"*variable","value":"~*req.5"},{"path":"SortingParameters","tag":"SortingParameters","type":"*variable","value":"~*req.6"},{"new_branch":true,"path":"Routes.ID","tag":"RouteID","type":"*variable","value":"~*req.7"},{"path":"Routes.FilterIDs","tag":"RouteFilterIDs","type":"*variable","value":"~*req.8"},{"path":"Routes.AccountIDs","tag":"RouteAccountIDs","type":"*variable","value":"~*req.9"},{"path":"Routes.RateProfileIDs","tag":"RouteRateProfileIDs","type":"*variable","value":"~*req.10"},{"path":"Routes.ResourceIDs","tag":"RouteResourceIDs","type":"*variable","value":"~*req.11"},{"path":"Routes.StatIDs","tag":"RouteStatIDs","type":"*variable","value":"~*req.12"},{"path":"Routes.Weights","tag":"RouteWeights","type":"*variable","value":"~*req.13"},{"path":"Routes.Blockers","tag":"RouteBlockers","type":"*variable","value":"~*req.14"},{"path":"Routes.RouteParameters","tag":"RouteParameters","type":"*variable","value":"~*req.15"}],"file_name":"Routes.csv","flags":null,"type":"*routes"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"FilterIDs","tag":"FilterIDs","type":"*variable","value":"~*req.2"},{"path":"Weights","tag":"Weights","type":"*variable","value":"~*req.3"},{"path":"Blockers","tag":"Blockers","type":"*variable","value":"~*req.4"},{"path":"RunID","tag":"RunID","type":"*variable","value":"~*req.5"},{"path":"AttributeIDs","tag":"AttributeIDs","type":"*variable","value":"~*req.6"}],"file_name":"Chargers.csv","flags":null,"type":"*chargers"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"FilterIDs","tag":"FilterIDs","type":"*variable","value":"~*req.2"},{"path":"Weights","tag":"Weights","type":"*variable","value":"~*req.3"},{"path":"MinCost","tag":"MinCost","type":"*variable","value":"~*req.4"},{"path":"MaxCost","tag":"MaxCost","type":"*variable","value":"~*req.5"},{"path":"MaxCostStrategy","tag":"MaxCostStrategy","type":"*variable","value":"~*req.6"},{"filters":["*notempty:~*req.7:"],"path":"Rates[\u003c~*req.7\u003e].FilterIDs","tag":"RateFilterIDs","type":"*variable","value":"~*req.8"},{"filters":["*notempty:~*req.7:"],"path":"Rates[\u003c~*req.7\u003e].ActivationTimes","tag":"RateActivationTimes","type":"*variable","value":"~*req.9"},{"filters":["*notempty:~*req.7:"],"path":"Rates[\u003c~*req.7\u003e].Weights","tag":"RateWeights","type":"*variable","value":"~*req.10"},{"filters":["*notempty:~*req.7:"],"path":"Rates[\u003c~*req.7\u003e].Blocker","tag":"RateBlocker","type":"*variable","value":"~*req.11"},{"filters":["*notempty:~*req.7:"],"new_branch":true,"path":"Rates[\u003c~*req.7\u003e].IntervalRates.IntervalStart","tag":"RateIntervalStart","type":"*variable","value":"~*req.12"},{"filters":["*notempty:~*req.7:"],"path":"Rates[\u003c~*req.7\u003e].IntervalRates.FixedFee","tag":"RateFixedFee","type":"*variable","value":"~*req.13"},{"filters":["*notempty:~*req.7:"],"path":"Rates[\u003c~*req.7\u003e].IntervalRates.RecurrentFee","tag":"RateRecurrentFee","type":"*variable","value":"~*req.14"},{"filters":["*notempty:~*req.7:"],"path":"Rates[\u003c~*req.7\u003e].IntervalRates.Unit","tag":"RateUnit","type":"*variable","value":"~*req.15"},{"filters":["*notempty:~*req.7:"],"path":"Rates[\u003c~*req.7\u003e].IntervalRates.Increment","tag":"RateIncrement","type":"*variable","value":"~*req.16"}],"file_name":"Rates.csv","flags":null,"type":"*rate_profiles"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"FilterIDs","tag":"FilterIDs","type":"*variable","value":"~*req.2"},{"path":"Weights","tag":"Weights","type":"*variable","value":"~*req.3"},{"path":"Blockers","tag":"Blockers","type":"*variable","value":"~*req.4"},{"path":"Schedule","tag":"Schedule","type":"*variable","value":"~*req.5"},{"path":"Targets[\u003c~*req.6\u003e]","tag":"TargetIDs","type":"*variable","value":"~*req.7"},{"filters":["*notempty:~*req.8:"],"path":"Actions[\u003c~*req.8\u003e].FilterIDs","tag":"ActionFilterIDs","type":"*variable","value":"~*req.9"},{"filters":["*notempty:~*req.8:"],"path":"Actions[\u003c~*req.8\u003e].TTL","tag":"ActionTTL","type":"*variable","value":"~*req.10"},{"filters":["*notempty:~*req.8:"],"path":"Actions[\u003c~*req.8\u003e].Type","tag":"ActionType","type":"*variable","value":"~*req.11"},{"filters":["*notempty:~*req.8:"],"path":"Actions[\u003c~*req.8\u003e].Opts","tag":"ActionOpts","type":"*variable","value":"~*req.12"},{"filters":["*notempty:~*req.8:"],"new_branch":true,"path":"Actions[\u003c~*req.8\u003e].Diktats.Path","tag":"ActionPath","type":"*variable","value":"~*req.13"},{"filters":["*notempty:~*req.8:"],"path":"Actions[\u003c~*req.8\u003e].Diktats.Value","tag":"ActionValue","type":"*variable","value":"~*req.14"}],"file_name":"Actions.csv","flags":null,"type":"*action_profiles"},{"fields":[{"mandatory":true,"path":"Tenant","tag":"Tenant","type":"*variable","value":"~*req.0"},{"mandatory":true,"path":"ID","tag":"ID","type":"*variable","value":"~*req.1"},{"path":"FilterIDs","tag":"FilterIDs","type":"*variable","value":"~*req.2"},{"path":"Weights","tag":"Weights","type":"*variable","value":"~*req.3"},{"path":"Blockers","tag":"Blockers","type":"*variable","value":"~*req.4"},{"path":"Opts","tag":"Opts","type":"*variable","value":"~*req.5"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].FilterIDs","tag":"BalanceFilterIDs","type":"*variable","value":"~*req.7"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].Weights","tag":"BalanceWeights","type":"*variable","value":"~*req.8"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].Blockers","tag":"BalanceBlockers","type":"*variable","value":"~*req.9"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].Type","tag":"BalanceType","type":"*variable","value":"~*req.10"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].Units","tag":"BalanceUnits","type":"*variable","value":"~*req.11"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].UnitFactors","tag":"BalanceUnitFactors","type":"*variable","value":"~*req.12"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].Opts","tag":"BalanceOpts","type":"*variable","value":"~*req.13"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].CostIncrements","tag":"BalanceCostIncrements","type":"*variable","value":"~*req.14"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].AttributeIDs","tag":"BalanceAttributeIDs","type":"*variable","value":"~*req.15"},{"filters":["*notempty:~*req.6:"],"path":"Balances[\u003c~*req.6\u003e].RateProfileIDs","tag":"BalanceRateProfileIDs","type":"*variable","value":"~*req.16"},{"path":"ThresholdIDs","tag":"ThresholdIDs","type":"*variable","value":"~*req.17"}],"file_name":"Accounts.csv","flags":null,"type":"*accounts"}],"enabled":false,"field_separator":",","id":"*default","lockfile_path":".cgr.lck","opts":{"*cache":"","*forceLock":false,"*stopOnError":false,"*withIndex":true},"run_delay":"0","tenant":"","tp_in_dir":"/var/spool/cgrates/loader/in","tp_out_dir":"/var/spool/cgrates/loader/out"}],"logger":{"efs_conns":["*internal"],"level":6,"opts":{"failed_posts_dir":"/var/spool/cgrates/failed_posts","kafka_attempts":1,"kafka_conn":"","kafka_topic":""},"type":"*syslog"},"migrator":{"out_datadb_encoding":"msgpack","out_datadb_host":"127.0.0.1","out_datadb_name":"10","out_datadb_opts":{"mongoConnScheme":"mongodb","mongoQueryTimeout":"10s","redisCACertificate":"","redisClientCertificate":"","redisClientKey":"","redisCluster":false,"redisClusterOndownDelay":"0s","redisClusterSync":"5s","redisConnectAttempts":20,"redisConnectTimeout":"0s","redisMaxConns":10,"redisPoolPipelineLimit":0,"redisPoolPipelineWindow":"150µs","redisReadTimeout":"0s","redisSentinel":"","redisTLS":false,"redisWriteTimeout":"0s"},"out_datadb_password":"","out_datadb_port":"6379","out_datadb_type":"*redis","out_datadb_user":"cgrates","users_filters":null},"radius_agent":{"client_dictionaries":{"*default":"/usr/share/cgrates/radius/dict/"},"client_secrets":{"*default":"CGRateS.org"},"enabled":false,"listen_acct":"127.0.0.1:1813","listen_auth":"127.0.0.1:1812","listen_net":"udp","request_processors":[],"sessions_conns":["*internal"]},"rankings":{"ees_conns":[],"ees_exporter_ids":null,"enabled":false,"scheduled_ids":{},"stats_conns":[],"store_interval":"","thresholds_conns":[]},"rates":{"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"nested_fields":false,"notexists_indexed_fields":[],"opts":{"*intervalStart":[{"FilterIDs":null,"Tenant":""}],"*profileIDs":[],"*profileIgnoreFilters":[{"FilterIDs":null,"Tenant":""}],"*startTime":[{"FilterIDs":null,"Tenant":""}],"*usage":[{"FilterIDs":null,"Tenant":""}]},"prefix_indexed_fields":[],"rate_exists_indexed_fields":[],"rate_indexed_selects":true,"rate_nested_fields":false,"rate_notexists_indexed_fields":[],"rate_prefix_indexed_fields":[],"rate_suffix_indexed_fields":[],"suffix_indexed_fields":[],"verbosity":1000},"registrarc":{"rpc":{"hosts":[],"refresh_interval":"5m0s","registrars_conns":[]}},"resources":{"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"nested_fields":false,"notexists_indexed_fields":[],"opts":{"*units":[{"FilterIDs":null,"Tenant":""}],"*usageID":[{"FilterIDs":null,"Tenant":""}],"*usageTTL":[{"FilterIDs":null,"Tenant":""}]},"prefix_indexed_fields":[],"store_interval":"","suffix_indexed_fields":[],"thresholds_conns":[]},"routes":{"accounts_conns":[],"attributes_conns":[],"default_ratio":1,"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"nested_fields":false,"notexists_indexed_fields":[],"opts":{"*context":[{"FilterIDs":null,"Tenant":""}],"*ignoreErrors":[{"FilterIDs":null,"Tenant":""}],"*limit":[],"*maxCost":[{"Tenant":"","Value":""}],"*maxItems":[],"*offset":[],"*profileCount":[{"FilterIDs":null,"Tenant":""}],"*usage":[{"FilterIDs":null,"Tenant":""}]},"prefix_indexed_fields":[],"rates_conns":[],"resources_conns":[],"stats_conns":[],"suffix_indexed_fields":[]},"rpc_conns":{"*bijson_localhost":{"conns":[{"address":"127.0.0.1:2014","transport":"*birpc_json"}],"poolSize":0,"strategy":"*first"},"*birpc_internal":{"conns":[{"address":"*birpc_internal","transport":""}],"poolSize":0,"strategy":"*first"},"*internal":{"conns":[{"address":"*internal","transport":""}],"poolSize":0,"strategy":"*first"},"*localhost":{"conns":[{"address":"127.0.0.1:2012","transport":"*json"}],"poolSize":0,"strategy":"*first"}},"sentrypeer":{"audience":"https://sentrypeer.com/api","client_id":"","client_secret":"","grant_type":"client_credentials","ips_url":"https://sentrypeer.com/api/ip-addresses","numbers_url":"https://sentrypeer.com/api/phone-numbers","token_url":"https://authz.sentrypeer.com/oauth/token"},"sessions":{"accounts_conns":[],"actions_conns":[],"alterable_fields":[],"attributes_conns":[],"cdrs_conns":[],"channel_sync_interval":"0","chargers_conns":[],"client_protocol":1,"default_usage":{"*any":"3h0m0s","*data":"1048576","*sms":"1","*voice":"3h0m0s"},"enabled":false,"listen_bigob":"","listen_bijson":"127.0.0.1:2014","min_dur_low_balance":"0","opts":{"*accounts":[{"FilterIDs":null,"Tenant":""}],"*attributes":[{"FilterIDs":null,"Tenant":""}],"*attributesDerivedReply":[{"FilterIDs":null,"Tenant":""}],"*blockerError":[{"FilterIDs":null,"Tenant":""}],"*cdrs":[{"FilterIDs":null,"Tenant":""}],"*cdrsDerivedReply":[{"FilterIDs":null,"Tenant":""}],"*chargeable":[{"FilterIDs":null,"Tenant":""}],"*chargers":[{"FilterIDs":null,"Tenant":""}],"*debitInterval":[{"FilterIDs":null,"Tenant":""}],"*forceUsage":[],"*initiate":[{"FilterIDs":null,"Tenant":""}],"*maxUsage":[{"FilterIDs":null,"Tenant":""}],"*message":[{"FilterIDs":null,"Tenant":""}],"*resources":[{"FilterIDs":null,"Tenant":""}],"*resourcesAllocate":[{"FilterIDs":null,"Tenant":""}],"*resourcesAuthorize":[{"FilterIDs":null,"Tenant":""}],"*resourcesDerivedReply":[{"FilterIDs":null,"Tenant":""}],"*resourcesRelease":[{"FilterIDs":null,"Tenant":""}],"*routes":[{"FilterIDs":null,"Tenant":""}],"*routesDerivedReply":[{"FilterIDs":null,"Tenant":""}],"*stats":[{"FilterIDs":null,"Tenant":""}],"*statsDerivedReply":[{"FilterIDs":null,"Tenant":""}],"*terminate":[{"FilterIDs":null,"Tenant":""}],"*thresholds":[{"FilterIDs":null,"Tenant":""}],"*thresholdsDerivedReply":[{"FilterIDs":null,"Tenant":""}],"*ttl":[{"FilterIDs":null,"Tenant":""}],"*ttlLastUsage":[],"*ttlLastUsed":[],"*ttlMaxDelay":[{"FilterIDs":null,"Tenant":""}],"*ttlUsage":[],"*update":[{"FilterIDs":null,"Tenant":""}]},"rates_conns":[],"replication_conns":[],"resources_conns":[],"routes_conns":[],"session_indexes":[],"stats_conns":[],"stir":{"allowed_attest":["*any"],"default_attest":"A","payload_maxduration":"-1","privatekey_path":"","publickey_path":""},"store_session_costs":false,"terminate_attempts":5,"thresholds_conns":[]},"sip_agent":{"enabled":false,"listen":"127.0.0.1:5060","listen_net":"udp","request_processors":[],"retransmission_timer":"1s","sessions_conns":["*internal"],"timezone":""},"stats":{"ees_conns":[],"ees_exporter_ids":null,"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"nested_fields":false,"notexists_indexed_fields":[],"opts":{"*profileIDs":[],"*profileIgnoreFilters":[{"FilterIDs":null,"Tenant":""}],"*prometheusStatIDs":[],"*roundingDecimals":[]},"prefix_indexed_fields":[],"store_interval":"","store_uncompressed_limit":0,"suffix_indexed_fields":[],"thresholds_conns":[]},"stor_db":{"db_host":"127.0.0.1","db_name":"cgrates","db_password":"CGRateS.org","db_port":3306,"db_type":"**mysql","db_user":"cgrates","items":{"*cdrs":{"limit":-1,"remote":false,"replicate":false,"static_ttl":false}},"opts":{"mongoConnScheme":"mongodb","mongoQueryTimeout":"10s","mysqlDSNParams":{},"mysqlLocation":"Local","pgSSLMode":"disable","sqlConnMaxLifetime":"0s","sqlMaxIdleConns":10,"sqlMaxOpenConns":100},"prefix_indexed_fields":[],"remote_conns":null,"replication_conns":null,"string_indexed_fields":[]},"suretax":{"bill_to_number":"","business_unit":"","client_number":"","client_tracking":"~*opts.*originID","customer_number":"~*req.Subject","include_local_cost":false,"orig_number":"~*req.Subject","p2pplus4":"","p2pzipcode":"","plus4":"","regulatory_code":"03","response_group":"03","response_type":"D4","return_file_code":"0","sales_type_code":"R","tax_exemption_code_list":"","tax_included":"0","tax_situs_rule":"04","term_number":"~*req.Destination","timezone":"UTC","trans_type_code":"010101","unit_type":"00","units":"1","url":"","validation_key":"","zipcode":""},"templates":{"*asr":[{"mandatory":true,"path":"*diamreq.Session-Id","tag":"SessionId","type":"*variable","value":"~*req.Session-Id"},{"mandatory":true,"path":"*diamreq.Origin-Host","tag":"OriginHost","type":"*variable","value":"~*req.Destination-Host"},{"mandatory":true,"path":"*diamreq.Origin-Realm","tag":"OriginRealm","type":"*variable","value":"~*req.Destination-Realm"},{"mandatory":true,"path":"*diamreq.Destination-Realm","tag":"DestinationRealm","type":"*variable","value":"~*req.Origin-Realm"},{"mandatory":true,"path":"*diamreq.Destination-Host","tag":"DestinationHost","type":"*variable","value":"~*req.Origin-Host"},{"mandatory":true,"path":"*diamreq.Auth-Application-Id","tag":"AuthApplicationId","type":"*variable","value":"~*vars.*appid"}],"*cca":[{"mandatory":true,"path":"*rep.Session-Id","tag":"SessionId","type":"*variable","value":"~*req.Session-Id"},{"path":"*rep.Result-Code","tag":"ResultCode","type":"*constant","value":"2001"},{"mandatory":true,"path":"*rep.Origin-Host","tag":"OriginHost","type":"*variable","value":"~*vars.OriginHost"},{"mandatory":true,"path":"*rep.Origin-Realm","tag":"OriginRealm","type":"*variable","value":"~*vars.OriginRealm"},{"mandatory":true,"path":"*rep.Auth-Application-Id","tag":"AuthApplicationId","type":"*variable","value":"~*vars.*appid"},{"mandatory":true,"path":"*rep.CC-Request-Type","tag":"CCRequestType","type":"*variable","value":"~*req.CC-Request-Type"},{"mandatory":true,"path":"*rep.CC-Request-Number","tag":"CCRequestNumber","type":"*variable","value":"~*req.CC-Request-Number"}],"*cdrLog":[{"mandatory":true,"path":"*cdr.ToR","tag":"ToR","type":"*variable","value":"~*req.BalanceType"},{"mandatory":true,"path":"*cdr.OriginHost","tag":"OriginHost","type":"*constant","value":"127.0.0.1"},{"mandatory":true,"path":"*cdr.RequestType","tag":"RequestType","type":"*constant","value":"*none"},{"mandatory":true,"path":"*cdr.Tenant","tag":"Tenant","type":"*variable","value":"~*req.Tenant"},{"mandatory":true,"path":"*cdr.Account","tag":"Account","type":"*variable","value":"~*req.Account"},{"mandatory":true,"path":"*cdr.Subject","tag":"Subject","type":"*variable","value":"~*req.Account"},{"mandatory":true,"path":"*cdr.Cost","tag":"Cost","type":"*variable","value":"~*req.Cost"},{"mandatory":true,"path":"*cdr.Source","tag":"Source","type":"*constant","value":"*cdrLog"},{"mandatory":true,"path":"*cdr.Usage","tag":"Usage","type":"*constant","value":"1"},{"mandatory":true,"path":"*cdr.RunID","tag":"RunID","type":"*variable","value":"~*req.ActionType"},{"mandatory":true,"path":"*cdr.SetupTime","tag":"SetupTime","type":"*constant","value":"*now"},{"mandatory":true,"path":"*cdr.AnswerTime","tag":"AnswerTime","type":"*constant","value":"*now"},{"mandatory":true,"path":"*cdr.PreRated","tag":"PreRated","type":"*constant","value":"true"}],"*err":[{"mandatory":true,"path":"*rep.Session-Id","tag":"SessionId","type":"*variable","value":"~*req.Session-Id"},{"mandatory":true,"path":"*rep.Origin-Host","tag":"OriginHost","type":"*variable","value":"~*vars.OriginHost"},{"mandatory":true,"path":"*rep.Origin-Realm","tag":"OriginRealm","type":"*variable","value":"~*vars.OriginRealm"}],"*errSip":[{"mandatory":true,"path":"*rep.Request","tag":"Request","type":"*constant","value":"SIP/2.0 500 Internal Server Error"}],"*rar":[{"mandatory":true,"path":"*diamreq.Session-Id","tag":"SessionId","type":"*variable","value":"~*req.Session-Id"},{"mandatory":true,"path":"*diamreq.Origin-Host","tag":"OriginHost","type":"*variable","value":"~*req.Destination-Host"},{"mandatory":true,"path":"*diamreq.Origin-Realm","tag":"OriginRealm","type":"*variable","value":"~*req.Destination-Realm"},{"mandatory":true,"path":"*diamreq.Destination-Realm","tag":"DestinationRealm","type":"*variable","value":"~*req.Origin-Realm"},{"mandatory":true,"path":"*diamreq.Destination-Host","tag":"DestinationHost","type":"*variable","value":"~*req.Origin-Host"},{"mandatory":true,"path":"*diamreq.Auth-Application-Id","tag":"AuthApplicationId","type":"*variable","value":"~*vars.*appid"},{"path":"*diamreq.Re-Auth-Request-Type","tag":"ReAuthRequestType","type":"*constant","value":"0"}]},"thresholds":{"actions_conns":[],"enabled":false,"exists_indexed_fields":[],"indexed_selects":true,"nested_fields":false,"notexists_indexed_fields":[],"opts":{"*profileIDs":[],"*profileIgnoreFilters":[{"FilterIDs":null,"Tenant":""}]},"prefix_indexed_fields":[],"store_interval":"","suffix_indexed_fields":[]},"tls":{"ca_certificate":"","client_certificate":"","client_key":"","server_certificate":"","server_key":"","server_name":"","server_policy":4},"tpes":{"enabled":false},"trends":{"ees_conns":[],"ees_exporter_ids":null,"enabled":false,"scheduled_ids":{},"stats_conns":[],"store_interval":"","store_uncompressed_limit":0,"thresholds_conns":[]}}` cgrCfg, err := NewCGRConfigFromJSONStringWithDefaults(cfgJSON) if err != nil { diff --git a/config/libdynamics.go b/config/libdynamics.go index e7e2287fa..c37c3fd33 100644 --- a/config/libdynamics.go +++ b/config/libdynamics.go @@ -838,11 +838,11 @@ func (dynFlt *DynamicBoolOpt) Value(dP utils.DataProvider) (bool, error) { func (dynDec *DynamicDecimalOpt) Value(dP utils.DataProvider) (*decimal.Big, error) { if dynDec.rsVal != nil { - out, err := dynDec.rsVal.ParseDataProvider(dP) + out, err := dynDec.rsVal.ParseDataProviderWithInterfaces2(dP) if err != nil { return nil, err } - return utils.StringAsBig(out) + return utils.IfaceAsBig(out) } return dynDec.value, nil } diff --git a/config/routescfg.go b/config/routescfg.go index dcc57563b..c557f7a0c 100644 --- a/config/routescfg.go +++ b/config/routescfg.go @@ -98,7 +98,7 @@ func (rtsOpts *RoutesOpts) loadFromJSONCfg(jsnCfg *RoutesOptsJson) (err error) { rtsOpts.IgnoreErrors = append(ignoreErrs, rtsOpts.IgnoreErrors...) } if jsnCfg.MaxCost != nil { - rtsOpts.MaxCost = append(rtsOpts.MaxCost, jsnCfg.MaxCost...) + rtsOpts.MaxCost = append(jsnCfg.MaxCost, rtsOpts.MaxCost...) } if jsnCfg.Limit != nil { var limit []*DynamicIntPointerOpt diff --git a/config/routescfg_test.go b/config/routescfg_test.go index c1c9f5237..41949a047 100644 --- a/config/routescfg_test.go +++ b/config/routescfg_test.go @@ -62,7 +62,7 @@ func TestRouteSCfgloadFromJsonCfg(t *testing.T) { Context: []*DynamicStringOpt{{value: RoutesContextDftOpt}}, ProfileCount: []*DynamicIntPointerOpt{{value: RoutesProfileCountDftOpt}}, IgnoreErrors: []*DynamicBoolOpt{{value: RoutesIgnoreErrorsDftOpt}}, - MaxCost: []*DynamicInterfaceOpt{}, + MaxCost: []*DynamicInterfaceOpt{{Value: RoutesMaxCostDftOpt}}, Limit: []*DynamicIntPointerOpt{}, Offset: []*DynamicIntPointerOpt{}, MaxItems: []*DynamicIntPointerOpt{}, @@ -125,7 +125,7 @@ func TestRouteSCfgAsMapInterface(t *testing.T) { utils.MetaMaxItemsCfg: []*DynamicIntPointerOpt{}, utils.MetaProfileCountCfg: []*DynamicIntPointerOpt{{value: RoutesProfileCountDftOpt}}, utils.MetaIgnoreErrorsCfg: []*DynamicBoolOpt{{value: RoutesIgnoreErrorsDftOpt}}, - utils.MetaMaxCostCfg: []*DynamicInterfaceOpt{}, + utils.MetaMaxCostCfg: []*DynamicInterfaceOpt{{Value: RoutesMaxCostDftOpt}}, utils.MetaUsage: []*DynamicDecimalOpt{{value: RoutesUsageDftOpt}}, }, } @@ -177,7 +177,7 @@ func TestRouteSCfgAsMapInterface1(t *testing.T) { utils.MetaMaxItemsCfg: []*DynamicIntPointerOpt{}, utils.MetaProfileCountCfg: []*DynamicIntPointerOpt{{value: RoutesProfileCountDftOpt}}, utils.MetaIgnoreErrorsCfg: []*DynamicBoolOpt{{value: RoutesIgnoreErrorsDftOpt}}, - utils.MetaMaxCostCfg: []*DynamicInterfaceOpt{}, + utils.MetaMaxCostCfg: []*DynamicInterfaceOpt{{Value: RoutesMaxCostDftOpt}}, utils.MetaUsage: []*DynamicDecimalOpt{{value: RoutesUsageDftOpt}}, }, } diff --git a/config/sessionscfg_test.go b/config/sessionscfg_test.go index bae580a8a..0c14c3397 100644 --- a/config/sessionscfg_test.go +++ b/config/sessionscfg_test.go @@ -593,7 +593,7 @@ func TestSessionSCfgAsMapInterfaceCase2(t *testing.T) { "opts": { "*ttl": [ { - "value": "1s", + "Value": "1s", }, ], "*debitInterval": [ diff --git a/engine/libdynopts.go b/engine/libdynopts.go index 26c5486e6..9e58afd20 100644 --- a/engine/libdynopts.go +++ b/engine/libdynopts.go @@ -233,7 +233,7 @@ func GetDecimalBigOpts(ctx *context.Context, tnt string, ev *utils.CGREvent, fS // GetInterfaceOpts checks the specified option names in order among the keys in APIOpts returning the first value it finds as any, otherwise it // returns the config option if at least one filter passes or the default value if none of them do func GetInterfaceOpts(ctx *context.Context, tnt string, ev *utils.CGREvent, fS *FilterS, dynOpts []*config.DynamicInterfaceOpt, - dftOpt any, optNames ...string) (cfgOpt any, err error) { + optNames ...string) (cfgOpt any, err error) { for _, optName := range optNames { if opt, has := ev.APIOpts[optName]; has { return opt, nil @@ -250,7 +250,7 @@ func GetInterfaceOpts(ctx *context.Context, tnt string, ev *utils.CGREvent, fS * return opt.Value, nil } } - return dftOpt, nil // return the default value if there are no options and none of the filters pass + return } // GetIntPointerOpts checks the specified option names in order among the keys in APIOpts returning the first value it finds as *int, otherwise it diff --git a/engine/libdynopts_test.go b/engine/libdynopts_test.go index 2fe174628..b04773cad 100644 --- a/engine/libdynopts_test.go +++ b/engine/libdynopts_test.go @@ -838,13 +838,16 @@ func TestLibFiltersGetInterfaceOptsReturnDefaultOpt(t *testing.T) { Tenant: "cgrates.org", Value: 2, }, + { + Value: config.RoutesMaxCostDftOpt, + }, } if rcv, err := GetInterfaceOpts(context.Background(), "cgrates.org", ev, fS, dynOpts, - config.RoutesMaxCostDftOpt, utils.OptsRoutesMaxCost); err != nil { + utils.OptsRoutesMaxCost); err != nil { t.Error(err) } else if rcv != config.RoutesMaxCostDftOpt { - t.Errorf("expected: <%+v>,\nreceived: <%+v>", config.RoutesMaxCostDftOpt, rcv) + t.Errorf("expected: <%+v>,\nreceived: <%+v>", utils.ToJSON(config.RoutesMaxCostDftOpt), rcv) } } @@ -1639,6 +1642,410 @@ func TestDynamicStringOptsDynVal(t *testing.T) { } } +func TestAttrDynamicOptsFromJson(t *testing.T) { + cfgJSONStr := `{ + "attributes": { + "enabled": true, + "stats_conns": ["*internal"], + "resources_conns": ["*internal"], + "accounts_conns": ["*internal"], + "prefix_indexed_fields": ["*req.index1","*req.index2"], + "string_indexed_fields": ["*req.index1"], + "exists_indexed_fields": ["*req.index1","*req.index2"], + "notexists_indexed_fields": ["*req.index1"], + "opts": { + "*processRuns": [ + { + "Value": "~*req.ProcessRuns", + "FilterIDs": ["*string:~*req.Account:1001"] + }, + { + "Value": 11, + "FilterIDs": ["*string:~*req.Account:1003"] + }, + ], + "*profileRuns": [ + { + "FilterIDs": ["*string:~*req.Account:1001"], + "Value": "~*opts.ProfileRuns" + } + ], + "*profileIgnoreFilters": [ + { + "FilterIDs": ["*string:~*req.Account:1001"], + "Value": "~*req.IgnoreFilters" + } + ] + }, + }, + }` + + cgrCfg, err := config.NewCGRConfigFromJSONStringWithDefaults(cfgJSONStr) + if err != nil { + t.Error(err) + } + ev := &utils.CGREvent{ + Tenant: utils.CGRateSorg, + ID: "testIDEvent", + Event: map[string]any{ + utils.AccountField: "1001", + "ProcessRuns": 4, + "IgnoreFilters": true, + }, + APIOpts: map[string]any{ + "ProfileRuns": 5, + }, + } + ev2 := &utils.CGREvent{ + Tenant: utils.CGRateSorg, + ID: "testIDEvent", + Event: map[string]any{ + utils.AccountField: "1002", + "ProcessRuns": 4, + "IgnoreFilters": true, + }, + APIOpts: map[string]any{ + "ProfileRuns": 5, + }, + } + ev3 := &utils.CGREvent{ + Tenant: utils.CGRateSorg, + ID: "testIDEvent", + Event: map[string]any{ + utils.AccountField: "1003", + }, + APIOpts: map[string]any{}, + } + fltrs := NewFilterS(cgrCfg, nil, nil) + if rcv, err := GetIntOpts(context.Background(), "cgrates.org", ev, fltrs, cgrCfg.AttributeSCfg().Opts.ProcessRuns); err != nil { + t.Error(err) + } else if rcv != 4 { + t.Errorf("expected %d,received %d", 4, rcv) + } + if rcv, err := GetIntOpts(context.Background(), "cgrates.org", ev3, fltrs, cgrCfg.AttributeSCfg().Opts.ProcessRuns); err != nil { + t.Error(err) + } else if rcv != 11 { + t.Errorf("expected %d,received %d", 11, rcv) + } + if rcv, err := GetIntOpts(context.Background(), "cgrates.org", ev2, fltrs, cgrCfg.AttributeSCfg().Opts.ProcessRuns); err != nil { + t.Error(err) + } else if rcv != config.AttributesProcessRunsDftOpt { + t.Errorf("expected %d,received %d", config.AttributesProcessRunsDftOpt, rcv) + } + + if rcv, err := GetIntOpts(context.Background(), "cgrates.org", ev, fltrs, cgrCfg.AttributeSCfg().Opts.ProfileRuns); err != nil { + t.Error(err) + } else if rcv != 5 { + t.Errorf("expected %d,received %d", 5, rcv) + } + if rcv, err := GetIntOpts(context.Background(), "cgrates.org", ev2, fltrs, cgrCfg.AttributeSCfg().Opts.ProfileRuns); err != nil { + t.Error(err) + } else if rcv != config.AttributesProfileRunsDftOpt { + t.Errorf("expected %d,received %d", config.AttributesProcessRunsDftOpt, rcv) + } + + if rcv, err := GetBoolOpts(context.Background(), "cgrates.org", ev.AsDataProvider(), fltrs, cgrCfg.AttributeSCfg().Opts.ProfileIgnoreFilters); err != nil { + t.Error(err) + } else if !rcv { + t.Errorf("expected true,received %v", rcv) + } + if rcv, err := GetBoolOpts(context.Background(), "cgrates.org", ev2.AsDataProvider(), fltrs, cgrCfg.AttributeSCfg().Opts.ProfileIgnoreFilters); err != nil { + t.Error(err) + } else if rcv != config.AttributesProfileIgnoreFiltersDftOpt { + t.Errorf("expected %v,received %v", config.AttributesProcessRunsDftOpt, rcv) + } +} + +func TestSessionDynamicOptsFromJson(t *testing.T) { + cfgJSONStr := `{ + "sessions": { + "enabled": true, + "listen_bijson": "127.0.0.1:2018", + "replication_conns": ["*localhost"], + "store_session_costs": true, + "min_dur_low_balance": "1s", + "client_protocol": 2.0, + "terminate_attempts": 10, + "opts": { + "*accounts": [ + { + "FilterIDs": ["*string:~*req.Account:1001"], + "Value": "~*opts.*accounts" + } + ], + "*attributes": [ + { + "FilterIDs": ["*string:~*req.Account:1001"], + "Value": "~*opts.*attributes" + } + ], + "*ttl": [ + { + "FilterIDs": ["*string:~*req.Account:1001"], + "Value": "~*req.TTL", + }, + ], + "*debitInterval": [ + { + "FilterIDs": ["*string:~*req.Account:1001"], + "Value": "~*req.Usage", + }, + ], + }, + }, + }` + + cgrCfg, err := config.NewCGRConfigFromJSONStringWithDefaults(cfgJSONStr) + if err != nil { + t.Error(err) + } + ev := &utils.CGREvent{ + Tenant: utils.CGRateSorg, + ID: "testIDEvent", + Event: map[string]any{ + utils.AccountField: "1001", + utils.Usage: 8 * time.Second, + utils.TTL: "1s", + }, + APIOpts: map[string]any{ + utils.MetaAttributes: true, + utils.MetaAccounts: true, + }, + } + ev2 := &utils.CGREvent{ + Tenant: utils.CGRateSorg, + ID: "testIDEvent", + Event: map[string]any{ + utils.AccountField: "1002", + utils.Usage: 8 * time.Second, + utils.TTL: "1s", + }, + APIOpts: map[string]any{ + utils.MetaAttributes: true, + utils.MetaAccounts: true, + }, + } + fltrs := NewFilterS(cgrCfg, nil, nil) + if rcv, err := GetBoolOpts(context.Background(), "cgrates.org", ev.AsDataProvider(), fltrs, cgrCfg.SessionSCfg().Opts.Accounts); err != nil { + t.Error(err) + } else if !rcv { + t.Errorf("expected true,received %v", rcv) + } + if rcv, err := GetBoolOpts(context.Background(), "cgrates.org", ev2.AsDataProvider(), fltrs, cgrCfg.SessionSCfg().Opts.Accounts); err != nil { + t.Error(err) + } else if rcv != config.SessionsAccountsDftOpt { + t.Errorf("expected %v,received %v", config.SessionsAccountsDftOpt, rcv) + } + + if rcv, err := GetBoolOpts(context.Background(), "cgrates.org", ev.AsDataProvider(), fltrs, cgrCfg.SessionSCfg().Opts.Attributes); err != nil { + t.Error(err) + } else if !rcv { + t.Errorf("expected true,received %v", rcv) + } + if rcv, err := GetBoolOpts(context.Background(), "cgrates.org", ev2.AsDataProvider(), fltrs, cgrCfg.SessionSCfg().Opts.Attributes); err != nil { + t.Error(err) + } else if rcv != config.SessionsAttributesDftOpt { + t.Errorf("expected %v,received %v", config.SessionsAttributesDftOpt, rcv) + } + + if rcv, err := GetDurationOpts(context.Background(), "cgrates.org", ev, fltrs, cgrCfg.SessionSCfg().Opts.TTL); err != nil { + t.Error(err) + } else if rcv != time.Second { + t.Errorf("expected %v,received %v", time.Second, rcv) + } + if rcv, err := GetDurationOpts(context.Background(), "cgrates.org", ev2, fltrs, cgrCfg.SessionSCfg().Opts.TTL); err != nil { + t.Error(err) + } else if rcv != config.SessionsTTLDftOpt { + t.Errorf("expected %v,received %v", config.SessionsTTLDftOpt, rcv) + } + + if rcv, err := GetDurationOpts(context.Background(), "cgrates.org", ev, fltrs, cgrCfg.SessionSCfg().Opts.DebitInterval); err != nil { + t.Error(err) + } else if rcv != (8 * time.Second) { + t.Errorf("expected %v,received %v", 8*time.Second, rcv) + } + if rcv, err := GetDurationOpts(context.Background(), "cgrates.org", ev2, fltrs, cgrCfg.SessionSCfg().Opts.DebitInterval); err != nil { + t.Error(err) + } else if rcv != config.SessionsDebitIntervalDftOpt { + t.Errorf("expected %v,received %v", config.SessionsDebitIntervalDftOpt, rcv) + } +} + +func TestResDynamicOptsFromJson(t *testing.T) { + cfgJSONStr := `{ + "resources": { + "enabled": true, + "store_interval": "7m", + "thresholds_conns": ["*internal:*thresholds", "*conn1"], + "indexed_selects":true, + "nested_fields": true, + "opts":{ + "*usageID": [ + { + "FilterIDs": ["*string:~*req.Account:1001"], + "Value": "~*req.UsageID" + } + ], + "*usageTTL": [ + { + "FilterIDs": ["*string:~*req.Account:1001"], + "Value": "~*req.UsageTTL" + } + ], + "*units": [ + { + "FilterIDs": ["*string:~*req.Account:1001"], + "Value": "~*opts.*units" + } + ] + } + }, + }` + + cgrCfg, err := config.NewCGRConfigFromJSONStringWithDefaults(cfgJSONStr) + if err != nil { + t.Error(err) + } + ev := &utils.CGREvent{ + Tenant: utils.CGRateSorg, + ID: "testIDEvent", + Event: map[string]any{ + utils.AccountField: "1001", + "UsageID": "UsgID3232", + "UsageTTL": 3 * time.Second, + }, + APIOpts: map[string]any{ + "*units": 23.22, + }, + } + ev2 := &utils.CGREvent{ + Tenant: utils.CGRateSorg, + ID: "testIDEvent", + Event: map[string]any{ + utils.AccountField: "1002", + "UsageID": "UsgID3232", + "UsageTTL": 3 * time.Second, + }, + APIOpts: map[string]any{ + "*units": 23.22, + }, + } + fltrs := NewFilterS(cgrCfg, nil, nil) + if rcv, err := GetStringOpts(context.Background(), "cgrates.org", ev, fltrs, cgrCfg.ResourceSCfg().Opts.UsageID); err != nil { + t.Error(err) + } else if rcv != "UsgID3232" { + t.Errorf("expected %s,received %s", "UsgID3232", rcv) + } + if rcv, err := GetStringOpts(context.Background(), "cgrates.org", ev2, fltrs, cgrCfg.ResourceSCfg().Opts.UsageID); err != nil { + t.Error(err) + } else if rcv != config.ResourcesUsageIDDftOpt { + t.Errorf("expected %s,received %s", config.ResourcesUsageTTLDftOpt, rcv) + } + + if rcv, err := GetDurationOpts(context.Background(), "cgrates.org", ev, fltrs, cgrCfg.ResourceSCfg().Opts.UsageTTL); err != nil { + t.Error(err) + } else if rcv != 3*time.Second { + t.Errorf("expected %v,received %d", 3*time.Second, rcv) + } + if rcv, err := GetDurationOpts(context.Background(), "cgrates.org", ev2, fltrs, cgrCfg.ResourceSCfg().Opts.UsageTTL); err != nil { + t.Error(err) + } else if rcv != config.ResourcesUsageTTLDftOpt { + t.Errorf("expected %d,received %d", config.ResourcesUsageTTLDftOpt, rcv) + } + + if rcv, err := GetFloat64Opts(context.Background(), "cgrates.org", ev, fltrs, cgrCfg.ResourceSCfg().Opts.Units); err != nil { + t.Error(err) + } else if rcv != 23.22 { + t.Errorf("expected %f,received %f", 23.22, rcv) + } + if rcv, err := GetFloat64Opts(context.Background(), "cgrates.org", ev2, fltrs, cgrCfg.ResourceSCfg().Opts.Units); err != nil { + t.Error(err) + } else if rcv != config.ResourcesUnitsDftOpt { + t.Errorf("expected %v,received %v", config.ResourcesUnitsDftOpt, rcv) + } +} + +func TestRoutesDynamicOptsFromJson(t *testing.T) { + routeJsnStr := `{ + "routes": { + "enabled": true, + "indexed_selects":false, + "opts":{ + "*usage": [ + { + "FilterIDs": ["*string:~*req.Account:1001"], + "Value": "~*req.Usage" + }, + { + "FilterIDs": ["*string:~*req.Account:1002"], + "Value": 15555 + }, + { + "FilterIDs": ["*string:~*req.Account:1003"], + "Value": "5m" + }, + { + "FilterIDs": ["*string:~*req.Account:1004"], + "Value": "~*opts.*usage" + }, + ] + } + } + }` + + cgrCfg, err := config.NewCGRConfigFromJSONStringWithDefaults(routeJsnStr) + if err != nil { + t.Error(err) + } + ev := &utils.CGREvent{ + Tenant: utils.CGRateSorg, + ID: "testIDEvent", + Event: map[string]any{ + utils.AccountField: "1001", + utils.Usage: 43364.4, + }, + APIOpts: map[string]any{ + "*usage": "12m", + }, + } + var dec decimal.Big + dec.SetFloat64(43364.4) + + fltrs := NewFilterS(cgrCfg, nil, nil) + if rcv, err := GetDecimalBigOpts(context.Background(), "cgrates.org", ev, fltrs, cgrCfg.RouteSCfg().Opts.Usage); err != nil { + t.Error(err) + } else if rcv.Cmp(&dec) != 0 { + t.Errorf("expected %v,received %v", dec.String(), rcv.String()) + } + ev.Event[utils.AccountField] = 1002 + dec.SetUint64(15555) + if rcv, err := GetDecimalBigOpts(context.Background(), "cgrates.org", ev, fltrs, cgrCfg.RouteSCfg().Opts.Usage); err != nil { + t.Error(err) + } else if rcv.Cmp(&dec) != 0 { + t.Errorf("expected %v,received %v", dec.String(), rcv.String()) + } + ev.Event[utils.AccountField] = 1003 + dec = *decimal.New(int64(5*time.Minute), 0) + if rcv, err := GetDecimalBigOpts(context.Background(), "cgrates.org", ev, fltrs, cgrCfg.RouteSCfg().Opts.Usage); err != nil { + t.Error(err) + } else if rcv.Cmp(&dec) != 0 { + t.Errorf("expected %v,received %v", dec.String(), rcv.String()) + } + ev.Event[utils.AccountField] = 1004 + dec = *decimal.New(int64(12*time.Minute), 0) + if rcv, err := GetDecimalBigOpts(context.Background(), "cgrates.org", ev, fltrs, cgrCfg.RouteSCfg().Opts.Usage); err != nil { + t.Error(err) + } else if rcv.Cmp(&dec) != 0 { + t.Errorf("expected %v,received %v", dec.String(), rcv.String()) + } + ev.Event[utils.AccountField] = 1005 + if rcv, err := GetDecimalBigOpts(context.Background(), "cgrates.org", ev, fltrs, cgrCfg.RouteSCfg().Opts.Usage); err != nil { + t.Error(err) + } else if rcv.Cmp(config.RatesUsageDftOpt) != 0 { + t.Errorf("expected %v,received %v", config.RatesUsageDftOpt.String(), rcv.String()) + } +} + func TestLibFiltersGetDecimalBigOptsFilterCheckErr(t *testing.T) { cfg := config.NewDefaultCGRConfig() dataDB := NewInternalDB(nil, nil, nil) @@ -1738,634 +2145,526 @@ func TestLibFiltersGetDecimalBigOptsReturnOptFromAPIOpts(t *testing.T) { } } -// func TestLibFiltersGetIntPointerOptsReturnConfigOpt(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// ev := &utils.CGREvent{ -// Tenant: "cgrates.org", -// ID: "TestEvent", -// Event: map[string]any{ -// utils.AccountField: 1001, -// }, -// APIOpts: map[string]any{}, -// } -// dynOpts := []*config.DynamicIntPointerOpt{ -// // tenant will not be recognized, will ignore this opt -// { -// FilterIDs: []string{"*string:~*req.Account:1001"}, -// Tenant: "cgrates.net", -// Value: utils.IntPointer(3), -// }, -// // filter will not pass, will ignore this opt -// { -// FilterIDs: []string{"*string:~*req.Account:1002"}, -// Tenant: "cgrates.org", -// Value: utils.IntPointer(4), -// }, -// { -// FilterIDs: []string{"*string:~*req.Account:1001"}, -// Tenant: "cgrates.org", -// Value: utils.IntPointer(5), -// }, -// } +func TestLibFiltersGetIntPointerOptsReturnConfigOpt(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + ev := &utils.CGREvent{ + Tenant: "cgrates.org", + ID: "TestEvent", + Event: map[string]any{ + utils.AccountField: 1001, + }, + APIOpts: map[string]any{}, + } + dynOpts := []*config.DynamicIntPointerOpt{ + // tenant will not be recognized, will ignore this opt + config.NewDynamicIntPointerOpt([]string{"*string:~*req.Account:1001"}, "cgrates.net", utils.IntPointer(3), nil), + // filter will not pass, will ignore this opt + config.NewDynamicIntPointerOpt([]string{"*string:~*req.Account:1002"}, "cgrates.org", utils.IntPointer(4), nil), + config.NewDynamicIntPointerOpt([]string{"*string:~*req.Account:1001"}, "cgrates.org", utils.IntPointer(5), nil), + } -// expected := 5 -// if rcv, err := GetIntPointerOpts(context.Background(), "cgrates.org", ev, fS, dynOpts, -// utils.OptsRoutesProfilesCount); err != nil { -// t.Error(err) -// } else if *rcv != expected { -// t.Errorf("expected: <%+v>,\nreceived: <%+v>", expected, *rcv) -// } -// } + expected := 5 + if rcv, err := GetIntPointerOpts(context.Background(), "cgrates.org", ev, fS, dynOpts, + utils.OptsRoutesProfilesCount); err != nil { + t.Error(err) + } else if *rcv != expected { + t.Errorf("expected: <%+v>,\nreceived: <%+v>", expected, *rcv) + } +} -// func TestLibFiltersGetIntPointerOptsFilterCheckErr(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// ev := &utils.CGREvent{ -// Tenant: "cgrates.org", -// ID: "TestEvent", -// Event: map[string]any{ -// utils.AccountField: 1001, -// }, -// APIOpts: map[string]any{}, -// } -// dynOpts := []*config.DynamicIntPointerOpt{ -// // function will return error after trying to parse the filter -// { -// FilterIDs: []string{"*string.invalid:filter"}, -// Tenant: "cgrates.org", -// Value: utils.IntPointer(4), -// }, -// } +func TestLibFiltersGetIntPointerOptsFilterCheckErr(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + ev := &utils.CGREvent{ + Tenant: "cgrates.org", + ID: "TestEvent", + Event: map[string]any{ + utils.AccountField: 1001, + }, + APIOpts: map[string]any{}, + } + dynOpts := []*config.DynamicIntPointerOpt{ + // function will return error after trying to parse the filter + config.NewDynamicIntPointerOpt([]string{"*string.invalid:filter"}, "cgrates.org", utils.IntPointer(4), nil), + } -// experr := `inline parse error for string: <*string.invalid:filter>` -// if _, err := GetIntPointerOpts(context.Background(), "cgrates.org", ev, fS, dynOpts, -// utils.OptsRoutesProfilesCount); err == nil || -// err.Error() != experr { -// t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err) -// } -// } + experr := `inline parse error for string: <*string.invalid:filter>` + if _, err := GetIntPointerOpts(context.Background(), "cgrates.org", ev, fS, dynOpts, + utils.OptsRoutesProfilesCount); err == nil || + err.Error() != experr { + t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err) + } +} -// func TestLibFiltersGetIntPointerOptsReturnDft(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// ev := &utils.CGREvent{ -// Tenant: "cgrates.org", -// ID: "TestEvent", -// Event: map[string]any{ -// utils.AccountField: 1001, -// }, -// APIOpts: map[string]any{}, -// } -// dynOpts := []*config.DynamicIntPointerOpt{ -// // filter will not pass, will ignore this opt -// { -// FilterIDs: []string{"*string:~*req.Account:1002"}, -// Tenant: "cgrates.org", -// Value: utils.IntPointer(4), -// }, -// } +func TestLibFiltersGetIntPointerOptsReturnDft(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + ev := &utils.CGREvent{ + Tenant: "cgrates.org", + ID: "TestEvent", + Event: map[string]any{ + utils.AccountField: 1001, + }, + APIOpts: map[string]any{}, + } + dynOpts := []*config.DynamicIntPointerOpt{ + // filter will not pass, will ignore this opt + config.NewDynamicIntPointerOpt([]string{"*string:~*req.Account:1002"}, "cgrates.org", utils.IntPointer(4), nil), + } -// if rcv, err := GetIntPointerOpts(context.Background(), "cgrates.org", ev, fS, dynOpts, -// utils.OptsRoutesProfilesCount); err != nil { -// t.Error(err) -// } else if rcv != nil { -// t.Errorf("expected: <%+v>,\nreceived: <%+v>", nil, rcv) -// } -// } + if rcv, err := GetIntPointerOpts(context.Background(), "cgrates.org", ev, fS, dynOpts, + utils.OptsRoutesProfilesCount); err != nil { + t.Error(err) + } else if rcv != nil { + t.Errorf("expected: <%+v>,\nreceived: <%+v>", nil, rcv) + } +} -// func TestLibFiltersGetIntPointerOptsReturnOptFromAPIOptsOK(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// ev := &utils.CGREvent{ -// Tenant: "cgrates.org", -// ID: "TestEvent", -// Event: map[string]any{ -// utils.AccountField: 1001, -// }, -// APIOpts: map[string]any{ -// utils.OptsRoutesProfilesCount: 6, -// }, -// } -// dynOpts := []*config.DynamicIntPointerOpt{ -// // will never get to this opt because it will return once it -// // finds the one set in APIOpts -// { -// FilterIDs: []string{"*string:~*req.Account:1001"}, -// Tenant: "cgrates.org", -// Value: utils.IntPointer(5), -// }, -// } +func TestLibFiltersGetIntPointerOptsReturnOptFromAPIOptsOK(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + ev := &utils.CGREvent{ + Tenant: "cgrates.org", + ID: "TestEvent", + Event: map[string]any{ + utils.AccountField: 1001, + }, + APIOpts: map[string]any{ + utils.OptsRoutesProfilesCount: 6, + }, + } + dynOpts := []*config.DynamicIntPointerOpt{ + // will never get to this opt because it will return once it + // finds the one set in APIOpts + config.NewDynamicIntPointerOpt([]string{"*string:~*req.Account:1001"}, "cgrates.org", utils.IntPointer(5), nil), + } -// expected := 6 -// if rcv, err := GetIntPointerOpts(context.Background(), "cgrates.org", ev, fS, dynOpts, -// "nonExistingAPIOpt", utils.OptsRoutesProfilesCount); err != nil { -// t.Error(err) -// } else if *rcv != expected { -// t.Errorf("expected: <%+v>,\nreceived: <%+v>", expected, rcv) -// } -// } + expected := 6 + if rcv, err := GetIntPointerOpts(context.Background(), "cgrates.org", ev, fS, dynOpts, + "nonExistingAPIOpt", utils.OptsRoutesProfilesCount); err != nil { + t.Error(err) + } else if *rcv != expected { + t.Errorf("expected: <%+v>,\nreceived: <%+v>", expected, rcv) + } +} -// func TestLibFiltersGetIntPointerOptsReturnOptFromAPIOptsErr(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// ev := &utils.CGREvent{ -// Tenant: "cgrates.org", -// ID: "TestEvent", -// Event: map[string]any{ -// utils.AccountField: 1001, -// }, -// APIOpts: map[string]any{ -// utils.OptsRoutesProfilesCount: true, -// }, -// } -// dynOpts := []*config.DynamicIntPointerOpt{ -// // will never get to this opt because it will return once it -// // finds the one set in APIOpts -// { -// FilterIDs: []string{"*string:~*req.Account:1001"}, -// Tenant: "cgrates.org", -// Value: utils.IntPointer(5), -// }, -// } +func TestLibFiltersGetIntPointerOptsReturnOptFromAPIOptsErr(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + ev := &utils.CGREvent{ + Tenant: "cgrates.org", + ID: "TestEvent", + Event: map[string]any{ + utils.AccountField: 1001, + }, + APIOpts: map[string]any{ + utils.OptsRoutesProfilesCount: true, + }, + } + dynOpts := []*config.DynamicIntPointerOpt{ + // will never get to this opt because it will return once it + // finds the one set in APIOpts + config.NewDynamicIntPointerOpt([]string{"*string:~*req.Account:1001"}, "cgrates.org", utils.IntPointer(5), nil), + } -// experr := `cannot convert field: true to int` -// if _, err := GetIntPointerOpts(context.Background(), "cgrates.org", ev, fS, dynOpts, -// "nonExistingAPIOpt", utils.OptsRoutesProfilesCount); err == nil || err.Error() != experr { -// t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err) -// } -// } + experr := `cannot convert field: true to int` + if _, err := GetIntPointerOpts(context.Background(), "cgrates.org", ev, fS, dynOpts, + "nonExistingAPIOpt", utils.OptsRoutesProfilesCount); err == nil || err.Error() != experr { + t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err) + } +} -// func TestLibFiltersGetDurationOptsFromMultipleMapsReturnConfigOpt(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// eventStart := map[string]any{ -// utils.AccountField: 1001, -// } -// apiOpts := map[string]any{} -// startOpts := map[string]any{} -// dynOpts := []*config.DynamicDurationOpt{ -// // tenant will not be recognized, will ignore this opt -// { -// FilterIDs: []string{"*string:~*req.Account:1001"}, -// Tenant: "cgrates.net", -// Value: time.Millisecond, -// }, -// // filter will not pass, will ignore this opt -// { -// FilterIDs: []string{"*string:~*req.Account:1002"}, -// Tenant: "cgrates.org", -// Value: time.Second, -// }, -// { -// FilterIDs: []string{"*string:~*req.Account:1001"}, -// Tenant: "cgrates.org", -// Value: time.Minute, -// }, -// } +func TestLibFiltersGetDurationOptsFromMultipleMapsReturnConfigOpt(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + eventStart := map[string]any{ + utils.AccountField: 1001, + } + apiOpts := map[string]any{} + startOpts := map[string]any{} + dynOpts := []*config.DynamicDurationOpt{ + // tenant will not be recognized, will ignore this opt + config.NewDynamicDurationOpt([]string{"*string:~*req.Account:1001"}, "cgrates.net", time.Millisecond, nil), + // filter will not pass, will ignore this opt + config.NewDynamicDurationOpt([]string{"*string:~*req.Account:1002"}, "cgrates.net", time.Second, nil), + config.NewDynamicDurationOpt([]string{"*string:~*req.Account:1001"}, "cgrates.org", time.Minute, nil), + } -// expected := time.Minute -// if rcv, err := GetDurationOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, -// config.SessionsTTLDftOpt, utils.OptsSesTTL); err != nil { -// t.Error(err) -// } else if rcv != expected { -// t.Errorf("expected: <%+v>,\nreceived: <%+v>", expected, rcv) -// } -// } + expected := time.Minute + if rcv, err := GetDurationOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, + config.SessionsTTLDftOpt, utils.OptsSesTTL); err != nil { + t.Error(err) + } else if rcv != expected { + t.Errorf("expected: <%+v>,\nreceived: <%+v>", expected, rcv) + } +} -// func TestLibFiltersGetDurationOptsFromMultipleMapsFilterCheckErr(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// eventStart := map[string]any{ -// utils.AccountField: 1001, -// } -// apiOpts := map[string]any{} -// startOpts := map[string]any{} -// dynOpts := []*config.DynamicDurationOpt{ -// // function will return error after trying to parse the filter -// { -// FilterIDs: []string{"*string.invalid:filter"}, -// Tenant: "cgrates.org", -// Value: time.Second, -// }, -// } +func TestLibFiltersGetDurationOptsFromMultipleMapsFilterCheckErr(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + eventStart := map[string]any{ + utils.AccountField: 1001, + } + apiOpts := map[string]any{} + startOpts := map[string]any{} + dynOpts := []*config.DynamicDurationOpt{ + // function will return error after trying to parse the filter + config.NewDynamicDurationOpt([]string{"*string.invalid:filter"}, "cgrates.org", time.Second, nil), + } -// experr := `inline parse error for string: <*string.invalid:filter>` -// if _, err := GetDurationOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, -// config.SessionsTTLDftOpt, utils.OptsSesTTL); err == nil || -// err.Error() != experr { -// t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err) -// } -// } + experr := `inline parse error for string: <*string.invalid:filter>` + if _, err := GetDurationOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, + config.SessionsTTLDftOpt, utils.OptsSesTTL); err == nil || + err.Error() != experr { + t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err) + } +} -// func TestLibFiltersGetDurationOptsFromMultipleMapsErrNotFound(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// eventStart := map[string]any{ -// utils.AccountField: 1001, -// } -// apiOpts := map[string]any{} -// startOpts := map[string]any{} -// dynOpts := []*config.DynamicDurationOpt{ -// // filter will not pass, will ignore this opt -// { -// FilterIDs: []string{"*string:~*req.Account:1002"}, -// Tenant: "cgrates.org", -// Value: time.Second, -// }, -// } +func TestLibFiltersGetDurationOptsFromMultipleMapsErrNotFound(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + eventStart := map[string]any{ + utils.AccountField: 1001, + } + apiOpts := map[string]any{} + startOpts := map[string]any{} + dynOpts := []*config.DynamicDurationOpt{ + // filter will not pass, will ignore this opt + config.NewDynamicDurationOpt([]string{"*string:~*req.Account:1002"}, "cgrates.org", time.Second, nil), + } -// if rcv, err := GetDurationOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, -// config.SessionsTTLDftOpt, utils.OptsSesTTL); err != nil { -// t.Error(err) -// } else if rcv != config.SessionsTTLDftOpt { -// t.Errorf("expected: <%+v>,\nreceived: <%+v>", config.SessionsTTLDftOpt, rcv) -// } -// } + if rcv, err := GetDurationOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, + config.SessionsTTLDftOpt, utils.OptsSesTTL); err != nil { + t.Error(err) + } else if rcv != config.SessionsTTLDftOpt { + t.Errorf("expected: <%+v>,\nreceived: <%+v>", config.SessionsTTLDftOpt, rcv) + } +} -// func TestLibFiltersGetDurationOptsFromMultipleMapsReturnOptFromAPIOptsOK(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// eventStart := map[string]any{ -// utils.AccountField: 1001, -// } -// apiOpts := map[string]any{ -// utils.OptsSesTTL: time.Hour, -// } -// startOpts := map[string]any{} -// dynOpts := []*config.DynamicDurationOpt{ -// // will never get to this opt because it will return once it -// // finds the one set in APIOpts -// { -// FilterIDs: []string{"*string:~*req.Account:1001"}, -// Tenant: "cgrates.org", -// Value: time.Minute, -// }, -// } +func TestLibFiltersGetDurationOptsFromMultipleMapsReturnOptFromAPIOptsOK(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + eventStart := map[string]any{ + utils.AccountField: 1001, + } + apiOpts := map[string]any{ + utils.OptsSesTTL: time.Hour, + } + startOpts := map[string]any{} + dynOpts := []*config.DynamicDurationOpt{ + // will never get to this opt because it will return once it + // finds the one set in APIOpts + config.NewDynamicDurationOpt([]string{"*string:~*req.Account:1001"}, "cgrates.org", time.Minute, nil), + } -// expected := time.Hour -// if rcv, err := GetDurationOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, -// config.SessionsTTLDftOpt, utils.OptsSesTTL); err != nil { -// t.Error(err) -// } else if rcv != expected { -// t.Errorf("expected: <%+v>,\nreceived: <%+v>", expected, rcv) -// } -// } + expected := time.Hour + if rcv, err := GetDurationOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, + config.SessionsTTLDftOpt, utils.OptsSesTTL); err != nil { + t.Error(err) + } else if rcv != expected { + t.Errorf("expected: <%+v>,\nreceived: <%+v>", expected, rcv) + } +} -// func TestLibFiltersGetDurationOptsFromMultipleMapsReturnOptFromAPIOptsErr(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// eventStart := map[string]any{ -// utils.AccountField: 1001, -// } -// apiOpts := map[string]any{ -// utils.OptsSesTTL: true, -// } -// startOpts := map[string]any{} -// dynOpts := []*config.DynamicDurationOpt{ -// // will never get to this opt because it will return once it -// // finds the one set in APIOpts -// { -// FilterIDs: []string{"*string:~*req.Account:1001"}, -// Tenant: "cgrates.org", -// Value: time.Minute, -// }, -// } +func TestLibFiltersGetDurationOptsFromMultipleMapsReturnOptFromAPIOptsErr(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + eventStart := map[string]any{ + utils.AccountField: 1001, + } + apiOpts := map[string]any{ + utils.OptsSesTTL: true, + } + startOpts := map[string]any{} + dynOpts := []*config.DynamicDurationOpt{ + // will never get to this opt because it will return once it + // finds the one set in APIOpts + config.NewDynamicDurationOpt([]string{"*string:~*req.Account:1001"}, "cgrates.org", time.Minute, nil), + } -// experr := `cannot convert field: true to time.Duration` -// if _, err := GetDurationOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, -// config.SessionsTTLDftOpt, utils.OptsSesTTL); err == nil || err.Error() != experr { -// t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err) -// } -// } + experr := `cannot convert field: true to time.Duration` + if _, err := GetDurationOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, + config.SessionsTTLDftOpt, utils.OptsSesTTL); err == nil || err.Error() != experr { + t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err) + } +} -// func TestLibFiltersGetDurationOptsFromMultipleMapsReturnOptFromStartOptsOK(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// eventStart := map[string]any{ -// utils.AccountField: 1001, -// } -// apiOpts := map[string]any{} -// startOpts := map[string]any{ -// utils.OptsSesTTL: time.Hour, -// } -// dynOpts := []*config.DynamicDurationOpt{ -// // will never get to this opt because it will return once it -// // finds the one set in APIOpts -// { -// FilterIDs: []string{"*string:~*req.Account:1001"}, -// Tenant: "cgrates.org", -// Value: time.Minute, -// }, -// } +func TestLibFiltersGetDurationOptsFromMultipleMapsReturnOptFromStartOptsOK(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + eventStart := map[string]any{ + utils.AccountField: 1001, + } + apiOpts := map[string]any{} + startOpts := map[string]any{ + utils.OptsSesTTL: time.Hour, + } + dynOpts := []*config.DynamicDurationOpt{ + // will never get to this opt because it will return once it + // finds the one set in APIOpts + config.NewDynamicDurationOpt([]string{"*string:~*req.Account:1001"}, "cgrates.org", time.Minute, nil), + } -// expected := time.Hour -// if rcv, err := GetDurationOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, -// config.SessionsTTLDftOpt, utils.OptsSesTTL); err != nil { -// t.Error(err) -// } else if rcv != expected { -// t.Errorf("expected: <%+v>,\nreceived: <%+v>", expected, rcv) -// } -// } + expected := time.Hour + if rcv, err := GetDurationOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, + config.SessionsTTLDftOpt, utils.OptsSesTTL); err != nil { + t.Error(err) + } else if rcv != expected { + t.Errorf("expected: <%+v>,\nreceived: <%+v>", expected, rcv) + } +} -// func TestLibFiltersGetDurationOptsFromMultipleMapsReturnOptFromStartOptsErr(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// eventStart := map[string]any{ -// utils.AccountField: 1001, -// } -// apiOpts := map[string]any{} -// startOpts := map[string]any{ -// utils.OptsSesTTL: true, -// } -// dynOpts := []*config.DynamicDurationOpt{ -// // will never get to this opt because it will return once it -// // finds the one set in APIOpts -// { -// FilterIDs: []string{"*string:~*req.Account:1001"}, -// Tenant: "cgrates.org", -// Value: time.Minute, -// }, -// } +func TestLibFiltersGetDurationOptsFromMultipleMapsReturnOptFromStartOptsErr(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + eventStart := map[string]any{ + utils.AccountField: 1001, + } + apiOpts := map[string]any{} + startOpts := map[string]any{ + utils.OptsSesTTL: true, + } + dynOpts := []*config.DynamicDurationOpt{ + // will never get to this opt because it will return once it + // finds the one set in APIOpts + config.NewDynamicDurationOpt([]string{"*string:~*req.Account:1001"}, "cgrates.org", time.Minute, nil), + } -// experr := `cannot convert field: true to time.Duration` -// if _, err := GetDurationOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, -// config.SessionsTTLDftOpt, utils.OptsSesTTL); err == nil || err.Error() != experr { -// t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err) -// } -// } + experr := `cannot convert field: true to time.Duration` + if _, err := GetDurationOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, + config.SessionsTTLDftOpt, utils.OptsSesTTL); err == nil || err.Error() != experr { + t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err) + } +} -// func TestLibFiltersGetDurationPointerOptsFromMultipleMapsReturnConfigOpt(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// eventStart := map[string]any{ -// utils.AccountField: 1001, -// } -// apiOpts := map[string]any{} -// startOpts := map[string]any{} -// dynOpts := []*config.DynamicDurationPointerOpt{ -// // tenant will not be recognized, will ignore this opt -// { -// FilterIDs: []string{"*string:~*req.Account:1001"}, -// Tenant: "cgrates.net", -// Value: utils.DurationPointer(time.Millisecond), -// }, -// // filter will not pass, will ignore this opt -// { -// FilterIDs: []string{"*string:~*req.Account:1002"}, -// Tenant: "cgrates.org", -// Value: utils.DurationPointer(time.Second), -// }, -// { -// FilterIDs: []string{"*string:~*req.Account:1001"}, -// Tenant: "cgrates.org", -// Value: utils.DurationPointer(time.Minute), -// }, -// } +func TestLibFiltersGetDurationPointerOptsFromMultipleMapsReturnConfigOpt(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + eventStart := map[string]any{ + utils.AccountField: 1001, + } + apiOpts := map[string]any{} + startOpts := map[string]any{} + dynOpts := []*config.DynamicDurationPointerOpt{ + // tenant will not be recognized, will ignore this opt + config.NewDynamicDurationPointerOpt([]string{"*string:~*req.Account:1001"}, "cgrates.net", utils.DurationPointer(time.Millisecond), nil), + // filter will not pass, will ignore this opt + config.NewDynamicDurationPointerOpt([]string{"*string:~*req.Account:1002"}, "cgrates.org", utils.DurationPointer(time.Second), nil), + config.NewDynamicDurationPointerOpt([]string{"*string:~*req.Account:1001"}, "cgrates.org", utils.DurationPointer(time.Minute), nil), + } -// expected := time.Minute -// if rcv, err := GetDurationPointerOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, -// utils.OptsSesTTLUsage); err != nil { -// t.Error(err) -// } else if *rcv != expected { -// t.Errorf("expected: <%+v>,\nreceived: <%+v>", expected, rcv) -// } -// } + expected := time.Minute + if rcv, err := GetDurationPointerOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, + utils.OptsSesTTLUsage); err != nil { + t.Error(err) + } else if *rcv != expected { + t.Errorf("expected: <%+v>,\nreceived: <%+v>", expected, rcv) + } +} -// func TestLibFiltersGetDurationPointerOptsFromMultipleMapsFilterCheckErr(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// eventStart := map[string]any{ -// utils.AccountField: 1001, -// } -// apiOpts := map[string]any{} -// startOpts := map[string]any{} -// dynOpts := []*config.DynamicDurationPointerOpt{ -// // function will return error after trying to parse the filter -// { -// FilterIDs: []string{"*string.invalid:filter"}, -// Tenant: "cgrates.org", -// Value: utils.DurationPointer(time.Second), -// }, -// } +func TestLibFiltersGetDurationPointerOptsFromMultipleMapsFilterCheckErr(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + eventStart := map[string]any{ + utils.AccountField: 1001, + } + apiOpts := map[string]any{} + startOpts := map[string]any{} + dynOpts := []*config.DynamicDurationPointerOpt{ + // function will return error after trying to parse the filter + config.NewDynamicDurationPointerOpt([]string{"*string.invalid:filter"}, "cgrates.org", utils.DurationPointer(time.Second), nil), + } -// experr := `inline parse error for string: <*string.invalid:filter>` -// if _, err := GetDurationPointerOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, -// utils.OptsSesTTLUsage); err == nil || -// err.Error() != experr { -// t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err) -// } -// } + experr := `inline parse error for string: <*string.invalid:filter>` + if _, err := GetDurationPointerOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, + utils.OptsSesTTLUsage); err == nil || + err.Error() != experr { + t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err) + } +} -// func TestLibFiltersGetDurationPointerOptsFromMultipleMapsReturnDft(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// eventStart := map[string]any{ -// utils.AccountField: 1001, -// } -// apiOpts := map[string]any{} -// startOpts := map[string]any{} -// dynOpts := []*config.DynamicDurationPointerOpt{ -// // filter will not pass, will ignore this opt -// { -// FilterIDs: []string{"*string:~*req.Account:1002"}, -// Tenant: "cgrates.org", -// Value: utils.DurationPointer(time.Second), -// }, -// } +func TestLibFiltersGetDurationPointerOptsFromMultipleMapsReturnDft(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + eventStart := map[string]any{ + utils.AccountField: 1001, + } + apiOpts := map[string]any{} + startOpts := map[string]any{} + dynOpts := []*config.DynamicDurationPointerOpt{ + // filter will not pass, will ignore this opt + config.NewDynamicDurationPointerOpt([]string{"*string:~*req.Account:1002"}, "cgrates.org", utils.DurationPointer(time.Second), nil), + } -// if _, err := GetDurationPointerOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, -// utils.OptsSesTTLUsage); err != nil { -// t.Error(err) -// } -// } + if _, err := GetDurationPointerOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, + utils.OptsSesTTLUsage); err != nil { + t.Error(err) + } +} -// func TestLibFiltersGetDurationPointerOptsFromMultipleMapsReturnOptFromAPIOptsOK(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// eventStart := map[string]any{ -// utils.AccountField: 1001, -// } -// apiOpts := map[string]any{ -// utils.OptsSesTTLUsage: time.Hour, -// } -// startOpts := map[string]any{} -// dynOpts := []*config.DynamicDurationPointerOpt{ -// // will never get to this opt because it will return once it -// // finds the one set in APIOpts -// { -// FilterIDs: []string{"*string:~*req.Account:1001"}, -// Tenant: "cgrates.org", -// Value: utils.DurationPointer(time.Minute), -// }, -// } +func TestLibFiltersGetDurationPointerOptsFromMultipleMapsReturnOptFromAPIOptsOK(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + eventStart := map[string]any{ + utils.AccountField: 1001, + } + apiOpts := map[string]any{ + utils.OptsSesTTLUsage: time.Hour, + } + startOpts := map[string]any{} + dynOpts := []*config.DynamicDurationPointerOpt{ + // will never get to this opt because it will return once it + // finds the one set in APIOpts + config.NewDynamicDurationPointerOpt([]string{"*string:~*req.Account:1001"}, "cgrates.org", utils.DurationPointer(time.Minute), nil), + } -// expected := time.Hour -// if rcv, err := GetDurationPointerOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, -// utils.OptsSesTTLUsage); err != nil { -// t.Error(err) -// } else if *rcv != expected { -// t.Errorf("expected: <%+v>,\nreceived: <%+v>", expected, rcv) -// } -// } + expected := time.Hour + if rcv, err := GetDurationPointerOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, + utils.OptsSesTTLUsage); err != nil { + t.Error(err) + } else if *rcv != expected { + t.Errorf("expected: <%+v>,\nreceived: <%+v>", expected, rcv) + } +} -// func TestLibFiltersGetDurationPointerOptsFromMultipleMapsReturnOptFromAPIOptsErr(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// eventStart := map[string]any{ -// utils.AccountField: 1001, -// } -// apiOpts := map[string]any{ -// utils.OptsSesTTLUsage: true, -// } -// startOpts := map[string]any{} -// dynOpts := []*config.DynamicDurationPointerOpt{ -// // will never get to this opt because it will return once it -// // finds the one set in APIOpts -// { -// FilterIDs: []string{"*string:~*req.Account:1001"}, -// Tenant: "cgrates.org", -// Value: utils.DurationPointer(time.Minute), -// }, -// } +func TestLibFiltersGetDurationPointerOptsFromMultipleMapsReturnOptFromAPIOptsErr(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + eventStart := map[string]any{ + utils.AccountField: 1001, + } + apiOpts := map[string]any{ + utils.OptsSesTTLUsage: true, + } + startOpts := map[string]any{} + dynOpts := []*config.DynamicDurationPointerOpt{ + // will never get to this opt because it will return once it + // finds the one set in APIOpts + config.NewDynamicDurationPointerOpt([]string{"*string:~*req.Account:1001"}, "cgrates.org", utils.DurationPointer(time.Minute), nil), + } -// experr := `cannot convert field: true to time.Duration` -// if _, err := GetDurationPointerOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, -// utils.OptsSesTTLUsage); err == nil || err.Error() != experr { -// t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err) -// } -// } + experr := `cannot convert field: true to time.Duration` + if _, err := GetDurationPointerOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, + utils.OptsSesTTLUsage); err == nil || err.Error() != experr { + t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err) + } +} -// func TestLibFiltersGetDurationPointerOptsFromMultipleMapsReturnOptFromStartOptsOK(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// eventStart := map[string]any{ -// utils.AccountField: 1001, -// } -// apiOpts := map[string]any{} -// startOpts := map[string]any{ -// utils.OptsSesTTLUsage: time.Hour, -// } -// dynOpts := []*config.DynamicDurationPointerOpt{ -// // will never get to this opt because it will return once it -// // finds the one set in APIOpts -// { -// FilterIDs: []string{"*string:~*req.Account:1001"}, -// Tenant: "cgrates.org", -// Value: utils.DurationPointer(time.Minute), -// }, -// } +func TestLibFiltersGetDurationPointerOptsFromMultipleMapsReturnOptFromStartOptsOK(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + eventStart := map[string]any{ + utils.AccountField: 1001, + } + apiOpts := map[string]any{} + startOpts := map[string]any{ + utils.OptsSesTTLUsage: time.Hour, + } + dynOpts := []*config.DynamicDurationPointerOpt{ + // will never get to this opt because it will return once it + // finds the one set in APIOpts + config.NewDynamicDurationPointerOpt([]string{"*string:~*req.Account:1001"}, "cgrates.org", utils.DurationPointer(time.Minute), nil), + } -// expected := time.Hour -// if rcv, err := GetDurationPointerOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, -// utils.OptsSesTTLUsage); err != nil { -// t.Error(err) -// } else if *rcv != expected { -// t.Errorf("expected: <%+v>,\nreceived: <%+v>", expected, rcv) -// } -// } + expected := time.Hour + if rcv, err := GetDurationPointerOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, + utils.OptsSesTTLUsage); err != nil { + t.Error(err) + } else if *rcv != expected { + t.Errorf("expected: <%+v>,\nreceived: <%+v>", expected, rcv) + } +} -// func TestLibFiltersGetDurationPointerOptsFromMultipleMapsReturnOptFromStartOptsErr(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// eventStart := map[string]any{ -// utils.AccountField: 1001, -// } -// apiOpts := map[string]any{} -// startOpts := map[string]any{ -// utils.OptsSesTTLUsage: true, -// } -// dynOpts := []*config.DynamicDurationPointerOpt{ -// // will never get to this opt because it will return once it -// // finds the one set in APIOpts -// { -// FilterIDs: []string{"*string:~*req.Account:1001"}, -// Tenant: "cgrates.org", -// Value: utils.DurationPointer(time.Minute), -// }, -// } +func TestLibFiltersGetDurationPointerOptsFromMultipleMapsReturnOptFromStartOptsErr(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + eventStart := map[string]any{ + utils.AccountField: 1001, + } + apiOpts := map[string]any{} + startOpts := map[string]any{ + utils.OptsSesTTLUsage: true, + } + dynOpts := []*config.DynamicDurationPointerOpt{ + // will never get to this opt because it will return once it + // finds the one set in APIOpts + config.NewDynamicDurationPointerOpt([]string{"*string:~*req.Account:1001"}, "cgrates.org", utils.DurationPointer(time.Minute), nil), + } -// experr := `cannot convert field: true to time.Duration` -// if _, err := GetDurationPointerOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, -// utils.OptsSesTTLUsage); err == nil || err.Error() != experr { -// t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err) -// } -// } + experr := `cannot convert field: true to time.Duration` + if _, err := GetDurationPointerOptsFromMultipleMaps(context.Background(), "cgrates.org", eventStart, apiOpts, startOpts, fS, dynOpts, + utils.OptsSesTTLUsage); err == nil || err.Error() != experr { + t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err) + } +} -// func TestGetBoolOptsFieldAsInterfaceErr(t *testing.T) { +func TestGetBoolOptsFieldAsInterfaceErr(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// dynOpts := []*config.DynamicBoolOpt{ -// { -// FilterIDs: []string{"*string:~*req.Account:1001"}, -// Tenant: "cgrates.org", -// Value: false, -// }, -// } + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + dynOpts := []*config.DynamicBoolOpt{ + config.NewDynamicBoolOpt([]string{"*string:~*req.Account:1"}, "cgrates.org", false, nil), + } -// if _, err := GetBoolOpts(context.Background(), "cgrates.org", new(mockDP), fS, dynOpts, -// config.ThresholdsProfileIgnoreFiltersDftOpt, "nonExistingAPIOpt", utils.MetaProfileIgnoreFilters); err != utils.ErrAccountNotFound { -// t.Errorf("Expecting error <%+v>,\n Recevied error <%+v>", utils.ErrAccountNotFound, err) -// } + if _, err := GetBoolOpts(context.Background(), "cgrates.org", new(mockDP), fS, dynOpts, + "nonExistingAPIOpt", utils.MetaProfileIgnoreFilters); err != utils.ErrAccountNotFound { + t.Errorf("Expecting error <%+v>,\n Recevied error <%+v>", utils.ErrAccountNotFound, err) + } -// } +} -// func TestGetBoolOptsCantCastErr(t *testing.T) { -// cfg := config.NewDefaultCGRConfig() -// dataDB := NewInternalDB(nil, nil, nil) -// dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) -// fS := NewFilterS(cfg, nil, dm) -// dynOpts := []*config.DynamicBoolOpt{ -// { -// FilterIDs: []string{"*string:~*req.Account:1001"}, -// Tenant: "cgrates.org", -// Value: false, -// }, -// } -// if _, err := GetBoolOpts(context.Background(), "cgrates.org", utils.StringSet{utils.MetaOpts: {}}, fS, dynOpts, -// config.ThresholdsProfileIgnoreFiltersDftOpt, "nonExistingAPIOpt", utils.MetaProfileIgnoreFilters); err.Error() != "cannot convert to map[string]any" { -// t.Errorf("Expecting error <%+v>,\n Recevied error <%+v>", utils.ErrCastFailed, err) -// } +func TestGetBoolOptsCantCastErr(t *testing.T) { + cfg := config.NewDefaultCGRConfig() + dataDB := NewInternalDB(nil, nil, nil) + dm := NewDataManager(dataDB, cfg.CacheCfg(), nil) + fS := NewFilterS(cfg, nil, dm) + dynOpts := []*config.DynamicBoolOpt{ + config.NewDynamicBoolOpt([]string{"*string:~*req.Account:1001"}, "cgrates.org", false, nil), + } + if _, err := GetBoolOpts(context.Background(), "cgrates.org", utils.StringSet{utils.MetaOpts: {}}, fS, dynOpts, + "nonExistingAPIOpt", utils.MetaProfileIgnoreFilters); err.Error() != "cannot convert to map[string]any" { + t.Errorf("Expecting error <%+v>,\n Recevied error <%+v>", utils.ErrCastFailed, err) + } -// } +} diff --git a/general_tests/config_reload_rates_it_test.go b/general_tests/config_reload_rates_it_test.go index 52ed5a6f3..4a22d131b 100644 --- a/general_tests/config_reload_rates_it_test.go +++ b/general_tests/config_reload_rates_it_test.go @@ -103,7 +103,7 @@ func testRateConfigSReloadRates(t *testing.T) { } else if reply != utils.OK { t.Errorf("Expected OK received: %+v", reply) } - cfgStr := "{\"rates\":{\"enabled\":true,\"exists_indexed_fields\":[],\"indexed_selects\":true,\"nested_fields\":false,\"notexists_indexed_fields\":[],\"opts\":{\"*intervalStart\":[],\"*profileIDs\":[],\"*profileIgnoreFilters\":[],\"*startTime\":[],\"*usage\":[]},\"prefix_indexed_fields\":[],\"rate_exists_indexed_fields\":[],\"rate_indexed_selects\":true,\"rate_nested_fields\":false,\"rate_notexists_indexed_fields\":[],\"rate_prefix_indexed_fields\":[],\"rate_suffix_indexed_fields\":[],\"suffix_indexed_fields\":[],\"verbosity\":1000}}" + cfgStr := "{\"rates\":{\"enabled\":true,\"exists_indexed_fields\":[],\"indexed_selects\":true,\"nested_fields\":false,\"notexists_indexed_fields\":[],\"opts\":{\"*intervalStart\":[{\"FilterIDs\":null,\"Tenant\":\"\"}],\"*profileIDs\":[],\"*profileIgnoreFilters\":[{\"FilterIDs\":null,\"Tenant\":\"\"}],\"*startTime\":[{\"FilterIDs\":null,\"Tenant\":\"\"}],\"*usage\":[{\"FilterIDs\":null,\"Tenant\":\"\"}]},\"prefix_indexed_fields\":[],\"rate_exists_indexed_fields\":[],\"rate_indexed_selects\":true,\"rate_nested_fields\":false,\"rate_notexists_indexed_fields\":[],\"rate_prefix_indexed_fields\":[],\"rate_suffix_indexed_fields\":[],\"suffix_indexed_fields\":[],\"verbosity\":1000}}" var rpl string if err := testRateRPC.Call(context.Background(), utils.ConfigSv1GetConfigAsJSON, &config.SectionWithAPIOpts{ Tenant: "cgrates.org",