queue system settings expanded. Update debug to goffee log system

This commit is contained in:
Zeni Kim 2026-05-18 22:37:26 -05:00
parent fc57baff78
commit f4476d3e89
5 changed files with 74 additions and 4 deletions

View file

@ -0,0 +1,55 @@
// Copyright (c) 2025 Zeni Kim <zenik@smarteching.com>
// Use of this source code is governed by MIT-style
// license that can be found in the LICENSE file.
package controllers
import (
"encoding/json"
"fmt"
"time"
"git.smarteching.com/goffee/core"
"git.smarteching.com/goffee/cup/workers"
"github.com/hibiken/asynq"
)
// Make samples queues
func Queuesample(c *core.Context) *core.Response {
// Get client queue asynq
client := c.GetQueueClient()
// Create a task with typename and payload.
payload, err := json.Marshal(workers.EmailTaskPayload{UserID: 42})
if err != nil {
c.GetLogger().Error(err.Error())
return c.Response.SetStatusCode(500).Json(`{"message": "internal error"}`)
}
t1 := asynq.NewTask(workers.TypeWelcomeEmail, payload)
t2 := asynq.NewTask(workers.TypeReminderEmail, payload)
// Process the task immediately.
info, err := client.Enqueue(t1)
if err != nil {
c.GetLogger().Error(err.Error())
return c.Response.SetStatusCode(500).Json(`{"message": "internal error"}`)
}
c.GetLogger().Info(fmt.Sprintf(" [*] Successfully enqueued task: %+v", info))
// Process 2 task 1 min later.
for i := 1; i < 3; i++ {
info, err = client.Enqueue(t2, asynq.ProcessIn(1*time.Minute))
if err != nil {
c.GetLogger().Error(err.Error())
return c.Response.SetStatusCode(500).Json(`{"message": "internal error"}`)
}
c.GetLogger().Info(fmt.Sprintf(" [*] Successfully enqueued task: %+v", info))
}
message := "{\"message\": \"Task queued\"}"
return c.Response.Json(message)
}