func (self *ApierV1) DebitUsage(usageRecord engine.UsageRecord, reply *string) error { if missing := utils.MissingStructFields(&usageRecord, []string{"Account", "Destination", "Usage"}); len(missing) != 0 { return utils.NewErrMandatoryIeMissing(missing...) } out, err := engine.LoadUserProfile(usageRecord, "") if err != nil { *reply = err.Error() return err } usageRecord = out.(engine.UsageRecord) if usageRecord.TOR == "" { usageRecord.TOR = utils.VOICE } if usageRecord.ReqType == "" { usageRecord.ReqType = self.Config.DefaultReqType } if usageRecord.Direction == "" { usageRecord.Direction = utils.OUT } if usageRecord.Tenant == "" { usageRecord.Tenant = self.Config.DefaultTenant } if usageRecord.Category == "" { usageRecord.Category = self.Config.DefaultCategory } if usageRecord.Subject == "" { usageRecord.Subject = usageRecord.Account } if usageRecord.AnswerTime == "" { usageRecord.AnswerTime = utils.META_NOW } cd, err := usageRecord.AsCallDescriptor(self.Config.DefaultTimezone) if err != nil { return utils.NewErrServerError(err) } var cc engine.CallCost if err := self.Responder.Debit(cd, &cc); err != nil { return utils.NewErrServerError(err) } *reply = OK return nil }