no titles handler

This commit is contained in:
Erik Winter 2024-01-20 11:19:15 +01:00
parent 2d85edecad
commit 1557a9a16e
3 changed files with 47 additions and 0 deletions

View File

@ -33,6 +33,8 @@ func (reviewAPI *ReviewAPI) ServeHTTP(w http.ResponseWriter, r *http.Request) {
reviewAPI.ListUnrated(w, r) reviewAPI.ListUnrated(w, r)
case r.Method == http.MethodGet && subPath == "unrated" && subSubPath == "next": case r.Method == http.MethodGet && subPath == "unrated" && subSubPath == "next":
reviewAPI.NextUnrated(w, r) reviewAPI.NextUnrated(w, r)
case r.Method == http.MethodGet && subPath == "no_titles" && subSubPath == "":
reviewAPI.ListNoTitles(w, r)
case r.Method == http.MethodGet && subPath != "": case r.Method == http.MethodGet && subPath != "":
reviewAPI.Get(w, r, subPath) reviewAPI.Get(w, r, subPath)
case r.Method == http.MethodPut && subPath != "": case r.Method == http.MethodPut && subPath != "":
@ -102,6 +104,21 @@ func (reviewAPI *ReviewAPI) NextUnrated(w http.ResponseWriter, r *http.Request)
} }
} }
func (reviewAPI *ReviewAPI) ListNoTitles(w http.ResponseWriter, r *http.Request) {
logger := reviewAPI.logger.With("method", "listNoTitles")
reviews, err := reviewAPI.repo.FindNoTitles()
if err != nil {
Error(w, http.StatusInternalServerError, "could not get reviews", err, logger)
return
}
if err := json.NewEncoder(w).Encode(reviews); err != nil {
Error(w, http.StatusInternalServerError, "could not encode reviews", err, logger)
return
}
}
func (reviewAPI *ReviewAPI) Store(w http.ResponseWriter, r *http.Request, id string) { func (reviewAPI *ReviewAPI) Store(w http.ResponseWriter, r *http.Request, id string) {
logger := reviewAPI.logger.With("method", "store") logger := reviewAPI.logger.With("method", "store")

View File

@ -135,6 +135,29 @@ func (rr *ReviewRepository) FindUnrated() ([]Review, error) {
return reviews, nil return reviews, nil
} }
func (rr *ReviewRepository) FindNoTitles() ([]Review, error) {
rows, err := rr.db.Query(`SELECT id, movie_id, source, url, review, movie_rating, quality, mentioned_titles FROM review WHERE mentioned_titles='{}'`)
if err != nil {
return nil, err
}
reviews := make([]Review, 0)
var titles string
for rows.Next() {
r := Review{}
if err := rows.Scan(&r.ID, &r.MovieID, &r.Source, &r.URL, &r.Review, &r.MovieRating, &r.Quality, &titles); err != nil {
return nil, err
}
if err := json.Unmarshal([]byte(titles), &r.Titles); err != nil {
return []Review{}, err
}
reviews = append(reviews, r)
}
rows.Close()
return reviews, nil
}
func (rr *ReviewRepository) FindAll() ([]Review, error) { func (rr *ReviewRepository) FindAll() ([]Review, error) {
rows, err := rr.db.Query(`SELECT id, movie_id, source, url, review, movie_rating, quality, mentioned_titles FROM review`) rows, err := rr.db.Query(`SELECT id, movie_id, source, url, review, movie_rating, quality, mentioned_titles FROM review`)
if err != nil { if err != nil {

View File

@ -93,5 +93,12 @@ func main() {
fmt.Printf("Movies: %v\n", resp.Movies) fmt.Printf("Movies: %v\n", resp.Movies)
review.Titles = resp
if err := emdb.UpdateReview(review); err != nil {
fmt.Printf("could not update review: %s\n", err)
continue
}
} }
} }