/* 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 Affero 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 Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program. If not, see */ package migrator import ( "errors" "fmt" "strings" "github.com/cgrates/cgrates/engine" "github.com/cgrates/cgrates/utils" ) func (m *Migrator) migrateCurrentDispatcher() (err error) { var ids []string ids, err = m.dmIN.DataManager().DataDB().GetKeysForPrefix(utils.DispatcherProfilePrefix, utils.EmptyString) if err != nil { return } for _, id := range ids { tntID := strings.SplitN(strings.TrimPrefix(id, utils.DispatcherProfilePrefix), utils.InInFieldSep, 2) if len(tntID) < 2 { return fmt.Errorf("Invalid key <%s> when migrating dispatcher profiles", id) } dpp, err := m.dmIN.DataManager().GetDispatcherProfile(tntID[0], tntID[1], false, false, utils.NonTransactional) if err != nil { return err } if dpp == nil || m.dryRun { continue } if err := m.dmOut.DataManager().SetDispatcherProfile(dpp, true); err != nil { return err } if err := m.dmIN.DataManager().RemoveDispatcherProfile(tntID[0], tntID[1], false); err != nil { return err } m.stats[utils.Dispatchers]++ } return } func (m *Migrator) migrateCurrentDispatcherHost() (err error) { var ids []string ids, err = m.dmIN.DataManager().DataDB().GetKeysForPrefix(utils.DispatcherHostPrefix, utils.EmptyString) if err != nil { return err } for _, id := range ids { tntID := strings.SplitN(strings.TrimPrefix(id, utils.DispatcherHostPrefix), utils.InInFieldSep, 2) if len(tntID) < 2 { return fmt.Errorf("Invalid key <%s> when migrating dispatcher hosts", id) } dpp, err := m.dmIN.DataManager().GetDispatcherHost(tntID[0], tntID[1], false, false, utils.NonTransactional) if err != nil { return err } if dpp == nil || m.dryRun { continue } if err := m.dmOut.DataManager().SetDispatcherHost(dpp); err != nil { return err } if err := m.dmIN.DataManager().RemoveDispatcherHost(tntID[0], tntID[1]); err != nil { return err } } return } func (m *Migrator) migrateDispatchers() (err error) { var vrs engine.Versions current := engine.CurrentDataDBVersions() if vrs, err = m.getVersions(utils.Dispatchers); err != nil { return } migrated := true var v2 *engine.DispatcherProfile for { version := vrs[utils.Dispatchers] for { switch version { default: return fmt.Errorf("Unsupported version %v", version) case current[utils.Dispatchers]: migrated = false if m.sameDataDB { break } if err = m.migrateCurrentDispatcher(); err != nil { return } if err = m.migrateCurrentDispatcherHost(); err != nil { return } case 1: if v2, err = m.migrateV1ToV2Dispatchers(); err != nil && err != utils.ErrNoMoreData { return } else if err == utils.ErrNoMoreData { break } version = 2 } if version == current[utils.Dispatchers] || err == utils.ErrNoMoreData { break } } if err == utils.ErrNoMoreData || !migrated { break } if !m.dryRun { //set action plan if err = m.dmOut.DataManager().SetDispatcherProfile(v2, true); err != nil { return } } m.stats[utils.Dispatchers]++ } // All done, update version wtih current one if err = m.setVersions(utils.Dispatchers); err != nil { return } return m.ensureIndexesDataDB(engine.ColDpp, engine.ColDph) } func (m *Migrator) migrateV1ToV2Dispatchers() (v4Cpp *engine.DispatcherProfile, err error) { v4Cpp, err = m.dmIN.getV1DispatcherProfile() if err != nil { return nil, err } else if v4Cpp == nil { return nil, errors.New("Dispatcher NIL") } if v4Cpp.FilterIDs, err = migrateInlineFilterV4(v4Cpp.FilterIDs); err != nil { return nil, err } return }