/* 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" ) type CdrcCfg struct { ID string // free-form text identifying this CDRC instance Enabled bool // Enable/Disable the profile DryRun bool // Do not post CDRs to the server CdrsConns []string // The address where CDRs can be reached CdrFormat string // The type of CDR file to process <*csv|*opensips_flatstore> FieldSeparator rune // The separator to use when reading csvs Timezone string // timezone for timestamps where not specified <""|UTC|Local|$IANA_TZ_DB> RunDelay time.Duration // Delay between runs, 0 for inotify driven requests MaxOpenFiles int // Maximum number of files opened simultaneously CDRInPath string // Folder to process CDRs from CDROutPath string // Folder to move processed CDRs to FailedCallsPrefix string // Used in case of flatstore CDRs to avoid searching for BYE records CDRRootPath utils.HierarchyPath // used for XML CDRs to specify the path towards CDR elements CdrSourceId string // Source identifier for the processed CDRs Filters []string Tenant RSRParsers ContinueOnSuccess bool // Continue after execution PartialRecordCache time.Duration // Duration to cache partial records when not pairing PartialCacheExpiryAction string HeaderFields []*FCTemplate ContentFields []*FCTemplate TrailerFields []*FCTemplate CacheDumpFields []*FCTemplate } func (self *CdrcCfg) loadFromJsonCfg(jsnCfg *CdrcJsonCfg, separator string) error { if jsnCfg == nil { return nil } var err error if jsnCfg.Id != nil { self.ID = *jsnCfg.Id } if jsnCfg.Enabled != nil { self.Enabled = *jsnCfg.Enabled } if jsnCfg.Dry_run != nil { self.DryRun = *jsnCfg.Dry_run } if jsnCfg.Cdrs_conns != nil { self.CdrsConns = make([]string, len(*jsnCfg.Cdrs_conns)) for idx, connID := range *jsnCfg.Cdrs_conns { // if we have the connection internal we change the name so we can have internal rpc for each subsystem if connID == utils.MetaInternal { self.CdrsConns[idx] = utils.ConcatenatedKey(utils.MetaInternal, utils.MetaCDRs) } else { self.CdrsConns[idx] = connID } } } if jsnCfg.Cdr_format != nil { self.CdrFormat = *jsnCfg.Cdr_format } if jsnCfg.Field_separator != nil && len(*jsnCfg.Field_separator) > 0 { sepStr := *jsnCfg.Field_separator self.FieldSeparator = rune(sepStr[0]) } if jsnCfg.Timezone != nil { self.Timezone = *jsnCfg.Timezone } if jsnCfg.Run_delay != nil { self.RunDelay = time.Duration(*jsnCfg.Run_delay) * time.Second } if jsnCfg.Max_open_files != nil { self.MaxOpenFiles = *jsnCfg.Max_open_files } if jsnCfg.Cdr_in_path != nil { self.CDRInPath = *jsnCfg.Cdr_in_path } if jsnCfg.Cdr_out_path != nil { self.CDROutPath = *jsnCfg.Cdr_out_path } if jsnCfg.Failed_calls_prefix != nil { self.FailedCallsPrefix = *jsnCfg.Failed_calls_prefix } if jsnCfg.Cdr_root_path != nil { self.CDRRootPath = utils.ParseHierarchyPath(*jsnCfg.Cdr_root_path, "") } if jsnCfg.Cdr_source_id != nil { self.CdrSourceId = *jsnCfg.Cdr_source_id } if jsnCfg.Filters != nil { self.Filters = make([]string, len(*jsnCfg.Filters)) for i, fltr := range *jsnCfg.Filters { self.Filters[i] = fltr } } if jsnCfg.Tenant != nil { if self.Tenant, err = NewRSRParsers(*jsnCfg.Tenant, true, separator); err != nil { return err } } if jsnCfg.Continue_on_success != nil { self.ContinueOnSuccess = *jsnCfg.Continue_on_success } if jsnCfg.Partial_record_cache != nil { if self.PartialRecordCache, err = utils.ParseDurationWithNanosecs(*jsnCfg.Partial_record_cache); err != nil { return err } } if jsnCfg.Partial_cache_expiry_action != nil { self.PartialCacheExpiryAction = *jsnCfg.Partial_cache_expiry_action } if jsnCfg.Header_fields != nil { if self.HeaderFields, err = FCTemplatesFromFCTemplatesJsonCfg(*jsnCfg.Header_fields, separator); err != nil { return err } } if jsnCfg.Content_fields != nil { if self.ContentFields, err = FCTemplatesFromFCTemplatesJsonCfg(*jsnCfg.Content_fields, separator); err != nil { return err } } if jsnCfg.Trailer_fields != nil { if self.TrailerFields, err = FCTemplatesFromFCTemplatesJsonCfg(*jsnCfg.Trailer_fields, separator); err != nil { return err } } if jsnCfg.Cache_dump_fields != nil { if self.CacheDumpFields, err = FCTemplatesFromFCTemplatesJsonCfg(*jsnCfg.Cache_dump_fields, separator); err != nil { return err } } return nil } // Clone itself into a new CdrcCfg func (self *CdrcCfg) Clone() *CdrcCfg { clnCdrc := new(CdrcCfg) clnCdrc.ID = self.ID clnCdrc.Enabled = self.Enabled clnCdrc.DryRun = self.DryRun clnCdrc.CdrsConns = make([]string, len(self.CdrsConns)) for idx, connID := range self.CdrsConns { clnCdrc.CdrsConns[idx] = connID } clnCdrc.CdrFormat = self.CdrFormat clnCdrc.FieldSeparator = self.FieldSeparator clnCdrc.Timezone = self.Timezone clnCdrc.RunDelay = self.RunDelay clnCdrc.MaxOpenFiles = self.MaxOpenFiles clnCdrc.CDRInPath = self.CDRInPath clnCdrc.CDROutPath = self.CDROutPath clnCdrc.CDRRootPath = make(utils.HierarchyPath, len(self.CDRRootPath)) for i, path := range self.CDRRootPath { clnCdrc.CDRRootPath[i] = path } clnCdrc.FailedCallsPrefix = self.FailedCallsPrefix clnCdrc.Filters = make([]string, len(self.Filters)) for i, fltr := range self.Filters { clnCdrc.Filters[i] = fltr } clnCdrc.Tenant = self.Tenant clnCdrc.CdrSourceId = self.CdrSourceId clnCdrc.ContinueOnSuccess = self.ContinueOnSuccess clnCdrc.PartialRecordCache = self.PartialRecordCache clnCdrc.PartialCacheExpiryAction = self.PartialCacheExpiryAction clnCdrc.HeaderFields = make([]*FCTemplate, len(self.HeaderFields)) clnCdrc.ContentFields = make([]*FCTemplate, len(self.ContentFields)) clnCdrc.TrailerFields = make([]*FCTemplate, len(self.TrailerFields)) clnCdrc.CacheDumpFields = make([]*FCTemplate, len(self.CacheDumpFields)) for idx, fld := range self.HeaderFields { clnCdrc.HeaderFields[idx] = fld.Clone() } for idx, fld := range self.ContentFields { clnCdrc.ContentFields[idx] = fld.Clone() } for idx, fld := range self.TrailerFields { clnCdrc.TrailerFields[idx] = fld.Clone() } for idx, fld := range self.CacheDumpFields { clnCdrc.CacheDumpFields[idx] = fld.Clone() } return clnCdrc }