mirror of
				https://github.com/knadh/listmonk.git
				synced 2025-10-25 06:56:03 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			66 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package main
 | |
| 
 | |
| import (
 | |
| 	"github.com/gofrs/uuid"
 | |
| 	"github.com/knadh/listmonk/models"
 | |
| 	"github.com/lib/pq"
 | |
| )
 | |
| 
 | |
| // runnerDB implements runner.DataSource over the primary
 | |
| // database.
 | |
| type runnerDB struct {
 | |
| 	queries *Queries
 | |
| }
 | |
| 
 | |
| func newManagerDB(q *Queries) *runnerDB {
 | |
| 	return &runnerDB{
 | |
| 		queries: q,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // NextCampaigns retrieves active campaigns ready to be processed.
 | |
| func (r *runnerDB) NextCampaigns(excludeIDs []int64) ([]*models.Campaign, error) {
 | |
| 	var out []*models.Campaign
 | |
| 	err := r.queries.NextCampaigns.Select(&out, pq.Int64Array(excludeIDs))
 | |
| 	return out, err
 | |
| }
 | |
| 
 | |
| // NextSubscribers retrieves a subset of subscribers of a given campaign.
 | |
| // Since batches are processed sequentially, the retrieval is ordered by ID,
 | |
| // and every batch takes the last ID of the last batch and fetches the next
 | |
| // batch above that.
 | |
| func (r *runnerDB) NextSubscribers(campID, limit int) ([]models.Subscriber, error) {
 | |
| 	var out []models.Subscriber
 | |
| 	err := r.queries.NextCampaignSubscribers.Select(&out, campID, limit)
 | |
| 	return out, err
 | |
| }
 | |
| 
 | |
| // GetCampaign fetches a campaign from the database.
 | |
| func (r *runnerDB) GetCampaign(campID int) (*models.Campaign, error) {
 | |
| 	var out = &models.Campaign{}
 | |
| 	err := r.queries.GetCampaign.Get(out, campID, nil)
 | |
| 	return out, err
 | |
| }
 | |
| 
 | |
| // UpdateCampaignStatus updates a campaign's status.
 | |
| func (r *runnerDB) UpdateCampaignStatus(campID int, status string) error {
 | |
| 	_, err := r.queries.UpdateCampaignStatus.Exec(campID, status)
 | |
| 	return err
 | |
| }
 | |
| 
 | |
| // CreateLink registers a URL with a UUID for tracking clicks and returns the UUID.
 | |
| func (r *runnerDB) CreateLink(url string) (string, error) {
 | |
| 	// Create a new UUID for the URL. If the URL already exists in the DB
 | |
| 	// the UUID in the database is returned.
 | |
| 	uu, err := uuid.NewV4()
 | |
| 	if err != nil {
 | |
| 		return "", err
 | |
| 	}
 | |
| 
 | |
| 	var out string
 | |
| 	if err := r.queries.CreateLink.Get(&out, uu, url); err != nil {
 | |
| 		return "", err
 | |
| 	}
 | |
| 
 | |
| 	return out, nil
 | |
| }
 |