Skip to content
Snippets Groups Projects
Select Git revision
  • 8190f92a5f6eb416f138574dc3c42f15dcc54d4c
  • main default protected
  • v1.298.0
  • v1.297.0
  • v1.296.0
  • v1.295.0
  • v1.294.0
  • v1.293.0
  • v1.292.0
  • v1.291.0
  • v1.290.0
  • v1.289.0
  • v1.288.0
  • v1.287.0
  • v1.286.0
  • v1.285.0
  • v1.284.0
  • v1.283.0
  • v1.282.0
  • v1.281.0
  • v1.280.0
  • v1.279.0
22 results

consumer.go

Blame
  • consumer.go 4.54 KiB
    package mem
    
    import (
    	"encoding/json"
    	"fmt"
    	"math/rand"
    	"os"
    	"reflect"
    	"sync"
    	"time"
    
    	"github.com/google/uuid"
    	"gitlab.com/uafrica/go-utils/audit"
    	"gitlab.com/uafrica/go-utils/errors"
    	"gitlab.com/uafrica/go-utils/queues"
    	"gitlab.com/uafrica/go-utils/service"
    )
    
    func NewConsumer(routes map[string]interface{}) *consumer {
    	router, err := queues.NewRouter(routes)
    	if err != nil {
    		panic(fmt.Sprintf("cannot create router: %+v", err))
    	}
    	//l := logger.New().WithFields(map[string]interface{}{"env": "dev"})
    	//l.IFormatter = l.IFormatter.NextColor()
    	return &consumer{
    		Service: service.New(),
    		//Logger:  l,
    		router: router,
    		queues: map[string]*queue{},
    	}
    }
    
    type consumer struct {
    	sync.Mutex
    	service.Service
    	//logger.Logger
    	router queues.Router
    	queues map[string]*queue
    }
    
    //wrap Service.WithStarter to return cron, else cannot be chained
    func (consumer *consumer) WithStarter(name string, starter service.IStarter) queues.Consumer {
    	consumer.Service = consumer.Service.WithStarter(name, starter)
    	return consumer
    }
    
    //wrap Service.WithErrorReporter to return api, else cannot be chained
    func (consumer *consumer) WithErrorReporter(reporter service.IErrorReporter) queues.Consumer {
    	consumer.Service = consumer.Service.WithErrorReporter(reporter)
    	return consumer
    }
    
    //wrap else cannot be chained
    func (consumer *consumer) WithAuditor(auditor audit.Auditor) queues.Consumer {
    	consumer.Service = consumer.Service.WithAuditor(auditor)
    	return consumer
    }
    
    func (consumer *consumer) Queue(name string) (*queue, error) {
    	consumer.Lock()
    	defer consumer.Unlock()
    	q, ok := consumer.queues[name]
    	if !ok {
    		q = &queue{
    			consumer: consumer,
    			name:     name,
    			ch:       make(chan service.Event),
    		}
    		go q.run()