/* Real-time Online/Offline Charging System (OCS) for Telecom & ISP environments Copyright (C) ITsysCOM GmbH This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see */ package config import ( "time" "github.com/cgrates/cgrates/utils" ) // StatSCfg the stats config section type StatSCfg struct { Enabled bool IndexedSelects bool StoreInterval time.Duration // Dump regularly from cache into dataDB StoreUncompressedLimit int ThresholdSConns []string StringIndexedFields *[]string PrefixIndexedFields *[]string SuffixIndexedFields *[]string NestedFields bool } func (st *StatSCfg) loadFromJSONCfg(jsnCfg *StatServJsonCfg) (err error) { if jsnCfg == nil { return nil } if jsnCfg.Enabled != nil { st.Enabled = *jsnCfg.Enabled } if jsnCfg.Indexed_selects != nil { st.IndexedSelects = *jsnCfg.Indexed_selects } if jsnCfg.Store_interval != nil { if st.StoreInterval, err = utils.ParseDurationWithNanosecs(*jsnCfg.Store_interval); err != nil { return err } } if jsnCfg.Store_uncompressed_limit != nil { st.StoreUncompressedLimit = *jsnCfg.Store_uncompressed_limit } if jsnCfg.Thresholds_conns != nil { st.ThresholdSConns = make([]string, len(*jsnCfg.Thresholds_conns)) for idx, conn := range *jsnCfg.Thresholds_conns { // if we have the connection internal we change the name so we can have internal rpc for each subsystem st.ThresholdSConns[idx] = conn if conn == utils.MetaInternal { st.ThresholdSConns[idx] = utils.ConcatenatedKey(utils.MetaInternal, utils.MetaThresholds) } } } if jsnCfg.String_indexed_fields != nil { sif := make([]string, len(*jsnCfg.String_indexed_fields)) for i, fID := range *jsnCfg.String_indexed_fields { sif[i] = fID } st.StringIndexedFields = &sif } if jsnCfg.Prefix_indexed_fields != nil { pif := make([]string, len(*jsnCfg.Prefix_indexed_fields)) for i, fID := range *jsnCfg.Prefix_indexed_fields { pif[i] = fID } st.PrefixIndexedFields = &pif } if jsnCfg.Suffix_indexed_fields != nil { sif := make([]string, len(*jsnCfg.Suffix_indexed_fields)) for i, fID := range *jsnCfg.Suffix_indexed_fields { sif[i] = fID } st.SuffixIndexedFields = &sif } if jsnCfg.Nested_fields != nil { st.NestedFields = *jsnCfg.Nested_fields } return nil } // AsMapInterface returns the config as a map[string]interface{} func (st *StatSCfg) AsMapInterface() (initialMP map[string]interface{}) { initialMP = map[string]interface{}{ utils.EnabledCfg: st.Enabled, utils.IndexedSelectsCfg: st.IndexedSelects, utils.StoreUncompressedLimitCfg: st.StoreUncompressedLimit, utils.NestedFieldsCfg: st.NestedFields, utils.StoreIntervalCfg: utils.EmptyString, } if st.StoreInterval != 0 { initialMP[utils.StoreIntervalCfg] = st.StoreInterval.String() } if st.StringIndexedFields != nil { stringIndexedFields := make([]string, len(*st.StringIndexedFields)) for i, item := range *st.StringIndexedFields { stringIndexedFields[i] = item } initialMP[utils.StringIndexedFieldsCfg] = stringIndexedFields } if st.PrefixIndexedFields != nil { prefixIndexedFields := make([]string, len(*st.PrefixIndexedFields)) for i, item := range *st.PrefixIndexedFields { prefixIndexedFields[i] = item } initialMP[utils.PrefixIndexedFieldsCfg] = prefixIndexedFields } if st.SuffixIndexedFields != nil { suffixIndexedFields := make([]string, len(*st.SuffixIndexedFields)) for i, item := range *st.SuffixIndexedFields { suffixIndexedFields[i] = item } initialMP[utils.SuffixIndexedFieldsCfg] = suffixIndexedFields } if st.ThresholdSConns != nil { thresholdSConns := make([]string, len(st.ThresholdSConns)) for i, item := range st.ThresholdSConns { thresholdSConns[i] = item if item == utils.ConcatenatedKey(utils.MetaInternal, utils.MetaThresholds) { thresholdSConns[i] = utils.MetaInternal } } initialMP[utils.ThresholdSConnsCfg] = thresholdSConns } return } // Clone returns a deep copy of StatSCfg func (st StatSCfg) Clone() (cln *StatSCfg) { cln = &StatSCfg{ Enabled: st.Enabled, IndexedSelects: st.IndexedSelects, StoreInterval: st.StoreInterval, StoreUncompressedLimit: st.StoreUncompressedLimit, NestedFields: st.NestedFields, } if st.ThresholdSConns != nil { cln.ThresholdSConns = make([]string, len(st.ThresholdSConns)) for i, con := range st.ThresholdSConns { cln.ThresholdSConns[i] = con } } if st.StringIndexedFields != nil { idx := make([]string, len(*st.StringIndexedFields)) for i, dx := range *st.StringIndexedFields { idx[i] = dx } cln.StringIndexedFields = &idx } if st.PrefixIndexedFields != nil { idx := make([]string, len(*st.PrefixIndexedFields)) for i, dx := range *st.PrefixIndexedFields { idx[i] = dx } cln.PrefixIndexedFields = &idx } if st.SuffixIndexedFields != nil { idx := make([]string, len(*st.SuffixIndexedFields)) for i, dx := range *st.SuffixIndexedFields { idx[i] = dx } cln.SuffixIndexedFields = &idx } return }