Exemplo n.º 1
0
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
}