Files
cgrates/apier/v1/cdrs.go

125 lines
3.8 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 v1
import (
"github.com/cgrates/cgrates/engine"
"github.com/cgrates/cgrates/utils"
)
// Retrieves the callCost out of CGR logDb
func (apier *ApierV1) GetEventCost(attrs utils.AttrGetCallCost, reply *engine.EventCost) error {
if attrs.CgrId == "" {
return utils.NewErrMandatoryIeMissing("CgrId")
}
if attrs.RunId == "" {
attrs.RunId = utils.META_DEFAULT
}
cdrFltr := &utils.CDRsFilter{
CGRIDs: []string{attrs.CgrId},
RunIDs: []string{attrs.RunId},
}
if cdrs, _, err := apier.CdrDb.GetCDRs(cdrFltr, false); err != nil {
if err != utils.ErrNotFound {
err = utils.NewErrServerError(err)
}
return err
} else if len(cdrs) == 0 ||
cdrs[0].CostDetails == nil { // to avoid nil pointer dereference
return utils.ErrNotFound
} else {
*reply = *cdrs[0].CostDetails
}
return nil
}
// Retrieves CDRs based on the filters
func (apier *ApierV1) GetCDRs(attrs utils.AttrGetCdrs, reply *[]*engine.ExternalCDR) error {
cdrsFltr, err := attrs.AsCDRsFilter(apier.Config.GeneralCfg().DefaultTimezone)
if err != nil {
return utils.NewErrServerError(err)
}
if cdrs, _, err := apier.CdrDb.GetCDRs(cdrsFltr, false); err != nil {
return err
} else if len(cdrs) == 0 {
*reply = make([]*engine.ExternalCDR, 0)
} else {
for _, cdr := range cdrs {
*reply = append(*reply, cdr.AsExternalCDR())
}
}
return nil
}
// New way of removing CDRs
func (apier *ApierV1) RemoveCDRs(attrs utils.RPCCDRsFilter, reply *string) error {
cdrsFilter, err := attrs.AsCDRsFilter(apier.Config.GeneralCfg().DefaultTimezone)
if err != nil {
return utils.NewErrServerError(err)
}
if _, _, err := apier.CdrDb.GetCDRs(cdrsFilter, true); err != nil {
return utils.NewErrServerError(err)
}
*reply = utils.OK
return nil
}
// Receive CDRs via RPC methods
type CDRsV1 struct {
CDRs *engine.CDRServer
}
// ProcessCDR will process a CDR in CGRateS internal format
func (cdrSv1 *CDRsV1) ProcessCDR(cdr *engine.CDRWithArgDispatcher, reply *string) error {
return cdrSv1.CDRs.V1ProcessCDR(cdr, reply)
}
// ProcessCDR will process a CDR in CGRateS internal format
func (cdrSv1 *CDRsV1) ProcessEvent(arg *engine.ArgV1ProcessEvent, reply *string) error {
return cdrSv1.CDRs.V1ProcessEvent(arg, reply)
}
// ProcessExternalCDR will process a CDR in external format
func (cdrSv1 *CDRsV1) ProcessExternalCDR(cdr *engine.ExternalCDRWithArgDispatcher, reply *string) error {
return cdrSv1.CDRs.V1ProcessExternalCDR(cdr, reply)
}
// RateCDRs can re-/rate remotely CDRs
func (cdrSv1 *CDRsV1) RateCDRs(arg *engine.ArgRateCDRs, reply *string) error {
return cdrSv1.CDRs.V1RateCDRs(arg, reply)
}
// StoreSMCost will store
func (cdrSv1 *CDRsV1) StoreSessionCost(attr *engine.AttrCDRSStoreSMCost, reply *string) error {
return cdrSv1.CDRs.V1StoreSessionCost(attr, reply)
}
func (cdrSv1 *CDRsV1) CountCDRs(args *utils.RPCCDRsFilterWithArgDispatcher, reply *int64) error {
return cdrSv1.CDRs.V1CountCDRs(args, reply)
}
func (cdrSv1 *CDRsV1) GetCDRs(args utils.RPCCDRsFilterWithArgDispatcher, reply *[]*engine.CDR) error {
return cdrSv1.CDRs.V1GetCDRs(args, reply)
}
func (cdrSv1 *CDRsV1) Ping(ign *utils.CGREventWithArgDispatcher, reply *string) error {
*reply = utils.Pong
return nil
}