From ba87801930da96fac36866b41d209dd0f84ad8db Mon Sep 17 00:00:00 2001 From: Kailash Nadh Date: Sun, 8 Mar 2020 15:10:51 +0530 Subject: [PATCH] Fix template preview sending invalid view requests --- public.go | 9 +++++++-- subscribers.go | 6 +++++- templates.go | 2 +- 3 files changed, 13 insertions(+), 4 deletions(-) diff --git a/public.go b/public.go index 6175615a..506468b1 100644 --- a/public.go +++ b/public.go @@ -255,9 +255,14 @@ func handleRegisterCampaignView(c echo.Context) error { campUUID = c.Param("campUUID") subUUID = c.Param("subUUID") ) - if _, err := app.queries.RegisterCampaignView.Exec(campUUID, subUUID); err != nil { - app.log.Printf("error registering campaign view: %s", err) + + // Exclude dummy hits from template previews. + if campUUID != dummyUUID && subUUID != dummyUUID { + if _, err := app.queries.RegisterCampaignView.Exec(campUUID, subUUID); err != nil { + app.log.Printf("error registering campaign view: %s", err) + } } + c.Response().Header().Set("Cache-Control", "no-cache") return c.Blob(http.StatusOK, "image/png", pixelPNG) } diff --git a/subscribers.go b/subscribers.go index b09656d5..de02b654 100644 --- a/subscribers.go +++ b/subscribers.go @@ -17,6 +17,10 @@ import ( "github.com/lib/pq" ) +const ( + dummyUUID = "00000000-0000-0000-0000-000000000000" +) + // subQueryReq is a "catch all" struct for reading various // subscriber related requests. type subQueryReq struct { @@ -57,7 +61,7 @@ type subOptin struct { var dummySubscriber = models.Subscriber{ Email: "dummy@listmonk.app", Name: "Dummy Subscriber", - UUID: "00000000-0000-0000-0000-000000000000", + UUID: dummyUUID, } // handleGetSubscriber handles the retrieval of a single subscriber by ID. diff --git a/templates.go b/templates.go index fc4ff919..bcf3dd78 100644 --- a/templates.go +++ b/templates.go @@ -100,7 +100,7 @@ func handlePreviewTemplate(c echo.Context) error { // Compile the template. camp := models.Campaign{ - UUID: "00000000-0000-0000-0000-000000000000", + UUID: dummyUUID, Name: "Dummy Campaign", Subject: "Dummy Campaign Subject", FromEmail: "dummy-campaign@listmonk.app",