From 9813d0bf8193fc65b4fa4db56a91579549a1cfdd Mon Sep 17 00:00:00 2001 From: Akmal Date: Thu, 20 Jun 2024 08:39:49 +0700 Subject: [PATCH] Marshal data for every scrape type This fixes 7660c9312b1a8db46ba99080649912ab9e2bda62 as replace is done after marshalling, move marshalling after replacement of cdn hostname --- handlers/data/data.go | 19 +++++++++---------- 1 file changed, 9 insertions(+), 10 deletions(-) diff --git a/handlers/data/data.go b/handlers/data/data.go index 478e885..d1a54d8 100644 --- a/handlers/data/data.go +++ b/handlers/data/data.go @@ -68,7 +68,6 @@ func (i *InstaData) GetData(postID string) error { } // Scrape from remote scraper, if available - var bb []byte // marshaled data if len(RemoteScraperAddr) > 0 { req, res := fasthttp.AcquireRequest(), fasthttp.AcquireResponse() defer func() { @@ -79,8 +78,8 @@ func (i *InstaData) GetData(postID string) error { req.Header.Set("Accept-Encoding", "gzip, deflate, br") req.SetRequestURI(RemoteScraperAddr + "/scrape/" + postID) if err := client.DoTimeout(req, res, timeout); err == nil && res.StatusCode() == fasthttp.StatusOK { - bb, _ = res.BodyGunzip() - if err := binary.Unmarshal(bb, i); err == nil { + iDataGunzip, _ := res.BodyGunzip() + if err := binary.Unmarshal(iDataGunzip, i); err == nil { log.Info().Str("postID", postID).Msg("Data parsed from remote scraper") } } @@ -132,17 +131,11 @@ func (i *InstaData) GetData(postID string) error { URL: mediaURL.String(), }) } - - bb, err = binary.Marshal(i) - if err != nil { - log.Error().Str("postID", postID).Err(err).Msg("Failed to marshal data") - return err - } } // Replace all media urls cdn to scontent.cdninstagram.com for n, media := range i.Medias { - u, err := url.Parse(string(media.URL)) + u, err := url.Parse(media.URL) if err != nil { log.Error().Str("postID", postID).Err(err).Msg("Failed to parse media URL") return err @@ -151,6 +144,12 @@ func (i *InstaData) GetData(postID string) error { i.Medias[n].URL = u.String() } + bb, err := binary.Marshal(i) + if err != nil { + log.Error().Str("postID", postID).Err(err).Msg("Failed to marshal data") + return err + } + batch := DB.NewBatch() // Write cache to DB if err := batch.Set(utils.S2B(postID), bb, pebble.Sync); err != nil {