80 lines
1.7 KiB
Go
80 lines
1.7 KiB
Go
package main
|
|
|
|
import (
|
|
"context"
|
|
"database/sql"
|
|
"log"
|
|
"os"
|
|
"screenmark/screenmark/agents"
|
|
"screenmark/screenmark/models"
|
|
"time"
|
|
|
|
"github.com/google/uuid"
|
|
"github.com/lib/pq"
|
|
)
|
|
|
|
func ListenNewImageEvents(db *sql.DB) {
|
|
listener := pq.NewListener(os.Getenv("DB_CONNECTION"), time.Second, time.Second, func(event pq.ListenerEventType, err error) {
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
})
|
|
defer listener.Close()
|
|
|
|
locationModel := models.NewLocationModel(db)
|
|
eventModel := models.NewEventModel(db)
|
|
noteModel := models.NewNoteModel(db)
|
|
imageModel := models.NewImageModel(db)
|
|
contactModel := models.NewContactModel(db)
|
|
|
|
err := listener.Listen("new_image")
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
for {
|
|
select {
|
|
case parameters := <-listener.Notify:
|
|
imageId := uuid.MustParse(parameters.Extra)
|
|
|
|
ctx := context.Background()
|
|
|
|
go func() {
|
|
locationAgent, err := agents.NewLocationEventAgent(locationModel, eventModel, contactModel)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
noteAgent, err := agents.NewNoteAgent(noteModel)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
image, err := imageModel.GetToProcessWithData(ctx, imageId)
|
|
if err != nil {
|
|
log.Println("Failed to GetToProcessWithData")
|
|
log.Println(err)
|
|
return
|
|
}
|
|
|
|
_, err = imageModel.FinishProcessing(ctx, image.ID)
|
|
if err != nil {
|
|
log.Println("Failed to FinishProcessing")
|
|
log.Println(err)
|
|
return
|
|
}
|
|
|
|
orchestrator, err := agents.NewOrchestratorAgent(locationAgent, noteAgent, image.Image.ImageName, image.Image.Image)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
err = orchestrator.Orchestrate(image.UserID, image.ImageID, image.Image.ImageName, image.Image.Image)
|
|
if err != nil {
|
|
log.Println(err)
|
|
}
|
|
}()
|
|
}
|
|
}
|
|
}
|