Files
cgrates/migrator/filters.go
2019-03-06 16:05:01 +01:00

359 lines
10 KiB
Go

/*
Real-time Online/Offline Charging System (OCS) for Telecom & ISP environments
Copyright (C) ITsysCOM GmbH
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>
*/
package migrator
import (
"fmt"
"strings"
"github.com/cgrates/cgrates/config"
"github.com/cgrates/cgrates/engine"
"github.com/cgrates/cgrates/utils"
)
func (m *Migrator) migrateCurrentRequestFilter() (err error) {
var ids []string
tenant := config.CgrConfig().GeneralCfg().DefaultTenant
ids, err = m.dmIN.DataManager().DataDB().GetKeysForPrefix(utils.FilterPrefix)
if err != nil {
return err
}
for _, id := range ids {
idg := strings.TrimPrefix(id, utils.FilterPrefix+tenant+":")
fl, err := m.dmIN.DataManager().GetFilter(tenant, idg, false, false, utils.NonTransactional)
if err != nil {
return err
}
if m.dryRun || fl == nil {
continue
}
if err := m.dmIN.DataManager().RemoveFilter(tenant, idg, utils.NonTransactional); err != nil {
return err
}
if err := m.dmOut.DataManager().SetFilter(fl); err != nil {
return err
}
m.stats[utils.RQF] += 1
}
return
}
func migrateFilterV1(fl *engine.Filter) *engine.Filter {
for i, rule := range fl.Rules {
if rule.FieldName == "" ||
utils.IsSliceMember([]string{engine.MetaRSR, engine.MetaStatS, engine.MetaResources,
engine.MetaNotRSR, engine.MetaNotStatS, engine.MetaNotResources}, rule.Type) ||
strings.HasPrefix(rule.FieldName, utils.DynamicDataPrefix) {
continue
}
fl.Rules[i].FieldName = utils.DynamicDataPrefix + rule.FieldName
}
return fl
}
func migrateInlineFilter(fl string) string {
if fl == "" || !strings.HasPrefix(fl, utils.Meta) {
return fl
}
ruleSplt := strings.Split(fl, utils.InInFieldSep)
if len(ruleSplt) < 3 {
return fl
}
if utils.IsSliceMember([]string{engine.MetaRSR, engine.MetaStatS, engine.MetaResources,
engine.MetaNotRSR, engine.MetaNotStatS, engine.MetaNotResources}, ruleSplt[0]) ||
strings.HasPrefix(ruleSplt[1], utils.DynamicDataPrefix) {
return fl
}
return fmt.Sprintf("%s:~%s:%s", ruleSplt[0], ruleSplt[1], strings.Join(ruleSplt[2:], utils.InInFieldSep))
}
func (m *Migrator) migrateRequestFilterV1() (err error) {
var ids []string
tenant := config.CgrConfig().GeneralCfg().DefaultTenant
ids, err = m.dmIN.DataManager().DataDB().GetKeysForPrefix(utils.FilterPrefix)
if err != nil {
return err
}
for _, id := range ids {
idg := strings.TrimPrefix(id, utils.FilterPrefix+tenant+":")
fl, err := m.dmIN.DataManager().GetFilter(tenant, idg, false, false, utils.NonTransactional)
if err != nil {
return err
}
if m.dryRun || fl == nil {
continue
}
if err := m.dmOut.DataManager().SetFilter(migrateFilterV1(fl)); err != nil {
return err
}
m.stats[utils.RQF] += 1
}
if err = m.migrateResourceProfileFiltersV1(); err != nil {
return err
}
if err = m.migrateStatQueueProfileFiltersV1(); err != nil {
return err
}
if err = m.migrateThresholdsProfileFiltersV1(); err != nil {
return err
}
if err = m.migrateSupplierProfileFiltersV1(); err != nil {
return err
}
if err = m.migrateAttributeProfileFiltersV1(); err != nil {
return err
}
if err = m.migrateChargerProfileFiltersV1(); err != nil {
return err
}
if err = m.migrateDispatcherProfileFiltersV1(); err != nil {
return err
}
vrs := engine.Versions{utils.RQF: engine.CurrentDataDBVersions()[utils.RQF]}
if err = m.dmOut.DataManager().DataDB().SetVersions(vrs, false); err != nil {
return utils.NewCGRError(utils.Migrator,
utils.ServerErrorCaps,
err.Error(),
fmt.Sprintf("error: <%s> when updating Filters version into dataDB", err.Error()))
}
return
}
func (m *Migrator) migrateRequestFilter() (err error) {
var vrs engine.Versions
current := engine.CurrentDataDBVersions()
vrs, err = m.dmIN.DataManager().DataDB().GetVersions("")
if err != nil {
return utils.NewCGRError(utils.Migrator,
utils.ServerErrorCaps,
err.Error(),
fmt.Sprintf("error: <%s> when querying oldDataDB for versions", err.Error()))
} else if len(vrs) == 0 {
return utils.NewCGRError(utils.Migrator,
utils.MandatoryIEMissingCaps,
utils.UndefinedVersion,
"version number is not defined for ActionTriggers model")
}
switch vrs[utils.RQF] {
case 1:
return m.migrateRequestFilterV1()
case current[utils.RQF]:
if m.sameDataDB {
return
}
return m.migrateCurrentRequestFilter()
}
return
}
func (m *Migrator) migrateResourceProfileFiltersV1() (err error) {
var ids []string
tenant := config.CgrConfig().GeneralCfg().DefaultTenant
ids, err = m.dmIN.DataManager().DataDB().GetKeysForPrefix(utils.ResourceProfilesPrefix)
if err != nil {
return err
}
for _, id := range ids {
idg := strings.TrimPrefix(id, utils.ResourceProfilesPrefix+tenant+":")
res, err := m.dmIN.DataManager().GetResourceProfile(tenant, idg, false, false, utils.NonTransactional)
if err != nil {
return err
}
if m.dryRun || res == nil {
continue
}
for i, fl := range res.FilterIDs {
res.FilterIDs[i] = migrateInlineFilter(fl)
}
if err := m.dmOut.DataManager().SetResourceProfile(res, true); err != nil {
return err
}
m.stats[utils.RQF] += 1
}
return
}
func (m *Migrator) migrateStatQueueProfileFiltersV1() (err error) {
var ids []string
tenant := config.CgrConfig().GeneralCfg().DefaultTenant
ids, err = m.dmIN.DataManager().DataDB().GetKeysForPrefix(utils.StatQueueProfilePrefix)
if err != nil {
return err
}
for _, id := range ids {
idg := strings.TrimPrefix(id, utils.StatQueueProfilePrefix+tenant+":")
sgs, err := m.dmIN.DataManager().GetStatQueueProfile(tenant, idg, false, false, utils.NonTransactional)
if err != nil {
return err
}
if sgs == nil || m.dryRun {
continue
}
for i, fl := range sgs.FilterIDs {
sgs.FilterIDs[i] = migrateInlineFilter(fl)
}
if err = m.dmOut.DataManager().SetStatQueueProfile(sgs, true); err != nil {
return err
}
m.stats[utils.RQF] += 1
}
return
}
func (m *Migrator) migrateThresholdsProfileFiltersV1() (err error) {
var ids []string
tenant := config.CgrConfig().GeneralCfg().DefaultTenant
ids, err = m.dmIN.DataManager().DataDB().GetKeysForPrefix(utils.ThresholdProfilePrefix)
if err != nil {
return err
}
for _, id := range ids {
idg := strings.TrimPrefix(id, utils.ThresholdProfilePrefix+tenant+":")
ths, err := m.dmIN.DataManager().GetThresholdProfile(tenant, idg, false, false, utils.NonTransactional)
if err != nil {
return err
}
if ths == nil || m.dryRun {
continue
}
for i, fl := range ths.FilterIDs {
ths.FilterIDs[i] = migrateInlineFilter(fl)
}
if err := m.dmOut.DataManager().SetThresholdProfile(ths, true); err != nil {
return err
}
m.stats[utils.RQF] += 1
}
return
}
func (m *Migrator) migrateSupplierProfileFiltersV1() (err error) {
var ids []string
tenant := config.CgrConfig().GeneralCfg().DefaultTenant
ids, err = m.dmIN.DataManager().DataDB().GetKeysForPrefix(utils.SupplierProfilePrefix)
if err != nil {
return err
}
for _, id := range ids {
idg := strings.TrimPrefix(id, utils.SupplierProfilePrefix)
splp, err := m.dmIN.DataManager().GetSupplierProfile(tenant, idg, false, false, utils.NonTransactional)
if err != nil {
return err
}
if splp == nil || m.dryRun {
continue
}
for i, fl := range splp.FilterIDs {
splp.FilterIDs[i] = migrateInlineFilter(fl)
}
if err := m.dmOut.DataManager().SetSupplierProfile(splp, true); err != nil {
return err
}
m.stats[utils.RQF] += 1
}
return
}
func (m *Migrator) migrateAttributeProfileFiltersV1() (err error) {
var ids []string
tenant := config.CgrConfig().GeneralCfg().DefaultTenant
ids, err = m.dmIN.DataManager().DataDB().GetKeysForPrefix(utils.AttributeProfilePrefix)
if err != nil {
return err
}
for _, id := range ids {
idg := strings.TrimPrefix(id, utils.AttributeProfilePrefix+tenant+":")
attrPrf, err := m.dmIN.DataManager().GetAttributeProfile(tenant, idg, false, false, utils.NonTransactional)
if err != nil {
return err
}
if attrPrf == nil || m.dryRun {
continue
}
for i, fl := range attrPrf.FilterIDs {
attrPrf.FilterIDs[i] = migrateInlineFilter(fl)
}
for i, attr := range attrPrf.Attributes {
for j, fl := range attr.FilterIDs {
attrPrf.Attributes[i].FilterIDs[j] = migrateInlineFilter(fl)
}
}
if err := m.dmOut.DataManager().SetAttributeProfile(attrPrf, true); err != nil {
return err
}
m.stats[utils.RQF] += 1
}
return
}
func (m *Migrator) migrateChargerProfileFiltersV1() (err error) {
var ids []string
tenant := config.CgrConfig().GeneralCfg().DefaultTenant
ids, err = m.dmIN.DataManager().DataDB().GetKeysForPrefix(utils.ChargerProfilePrefix)
if err != nil {
return err
}
for _, id := range ids {
idg := strings.TrimPrefix(id, utils.ChargerProfilePrefix+tenant+":")
cpp, err := m.dmIN.DataManager().GetChargerProfile(tenant, idg, false, false, utils.NonTransactional)
if err != nil {
return err
}
if cpp == nil || m.dryRun {
continue
}
for i, fl := range cpp.FilterIDs {
cpp.FilterIDs[i] = migrateInlineFilter(fl)
}
if err := m.dmOut.DataManager().SetChargerProfile(cpp, true); err != nil {
return err
}
m.stats[utils.RQF] += 1
}
return
}
func (m *Migrator) migrateDispatcherProfileFiltersV1() (err error) {
var ids []string
tenant := config.CgrConfig().GeneralCfg().DefaultTenant
ids, err = m.dmIN.DataManager().DataDB().GetKeysForPrefix(utils.DispatcherProfilePrefix)
if err != nil {
return err
}
for _, id := range ids {
idg := strings.TrimPrefix(id, utils.DispatcherProfilePrefix+tenant+":")
dpp, err := m.dmIN.DataManager().GetDispatcherProfile(tenant, idg, false, false, utils.NonTransactional)
if err != nil {
return err
}
if dpp == nil || m.dryRun {
continue
}
for i, fl := range dpp.FilterIDs {
dpp.FilterIDs[i] = migrateInlineFilter(fl)
}
if err := m.dmOut.DataManager().SetDispatcherProfile(dpp, true); err != nil {
return err
}
m.stats[utils.RQF] += 1
}
return
}