From 3386de40c74740b2577e5344e9f6456e9ba50502 Mon Sep 17 00:00:00 2001 From: Kailash Nadh Date: Mon, 29 Nov 2021 20:38:57 +0530 Subject: [PATCH] Fix GET `/subscribers` calls not accepting multiple `list_id`s. Closes #585 --- cmd/subscribers.go | 43 +++++++++++++++++++----------- frontend/src/views/Subscribers.vue | 5 +++- queries.sql | 4 +-- 3 files changed, 33 insertions(+), 19 deletions(-) diff --git a/cmd/subscribers.go b/cmd/subscribers.go index 57780831f..ccb95b97d 100644 --- a/cmd/subscribers.go +++ b/cmd/subscribers.go @@ -106,9 +106,6 @@ func handleQuerySubscribers(c echo.Context) error { app = c.Get("app").(*App) pg = getPagination(c.QueryParams(), 30) - // Limit the subscribers to a particular list? - listID, _ = strconv.Atoi(c.FormValue("list_id")) - // The "WHERE ?" bit. query = sanitizeSQLExp(c.FormValue("query")) orderBy = c.FormValue("order_by") @@ -116,11 +113,10 @@ func handleQuerySubscribers(c echo.Context) error { out = subsWrap{Results: make([]models.Subscriber, 0, 1)} ) - listIDs := pq.Int64Array{} - if listID < 0 { - return echo.NewHTTPError(http.StatusBadRequest, app.i18n.T("globals.messages.errorID")) - } else if listID > 0 { - listIDs = append(listIDs, int64(listID)) + // Limit the subscribers to sepcific lists? + listIDs, err := getQueryListIDs(c.QueryParams()) + if err != nil { + return echo.NewHTTPError(http.StatusBadRequest, app.i18n.T("globals.messages.invalidID")) } // There's an arbitrary query condition. @@ -196,18 +192,14 @@ func handleExportSubscribers(c echo.Context) error { var ( app = c.Get("app").(*App) - // Limit the subscribers to a particular list? - listID, _ = strconv.Atoi(c.FormValue("list_id")) - // The "WHERE ?" bit. query = sanitizeSQLExp(c.FormValue("query")) ) - listIDs := pq.Int64Array{} - if listID < 0 { - return echo.NewHTTPError(http.StatusBadRequest, app.i18n.T("globals.messages.errorID")) - } else if listID > 0 { - listIDs = append(listIDs, int64(listID)) + // Limit the subscribers to sepcific lists? + listIDs, err := getQueryListIDs(c.QueryParams()) + if err != nil { + return echo.NewHTTPError(http.StatusBadRequest, app.i18n.T("globals.messages.invalidID")) } // There's an arbitrary query condition. @@ -866,3 +858,22 @@ func sanitizeSQLExp(q string) string { } return q } + +func getQueryListIDs(qp url.Values) (pq.Int64Array, error) { + out := pq.Int64Array{} + if vals, ok := qp["list_id"]; ok { + for _, v := range vals { + if v == "" { + continue + } + + listID, err := strconv.Atoi(v) + if err != nil { + return nil, err + } + out = append(out, int64(listID)) + } + } + + return out, nil +} diff --git a/frontend/src/views/Subscribers.vue b/frontend/src/views/Subscribers.vue index 0f24b9225..3d76e7992 100644 --- a/frontend/src/views/Subscribers.vue +++ b/frontend/src/views/Subscribers.vue @@ -399,7 +399,10 @@ export default Vue.extend({ this.$utils.confirm(this.$t('subscribers.confirmExport', { num: this.subscribers.total }), () => { const q = new URLSearchParams(); q.append('query', this.queryParams.queryExp); - q.append('list_id', this.queryParams.listID); + + if (this.queryParams.listID) { + q.append('list_id', this.queryParams.listID); + } document.location.href = `${uris.exportSubscribers}?${q.toString()}`; }); }, diff --git a/queries.sql b/queries.sql index 108abf6da..9160cd297 100644 --- a/queries.sql +++ b/queries.sql @@ -241,7 +241,7 @@ SELECT subscribers.* FROM subscribers (CASE WHEN CARDINALITY($1::INT[]) > 0 THEN true ELSE false END) AND subscriber_lists.subscriber_id = subscribers.id ) - WHERE subscriber_lists.list_id = ALL($1::INT[]) + WHERE (CARDINALITY($1) = 0 OR subscriber_lists.list_id = ANY($1::INT[])) %s ORDER BY %s %s OFFSET $2 LIMIT (CASE WHEN $3 = 0 THEN NULL ELSE $3 END); @@ -254,7 +254,7 @@ SELECT COUNT(*) AS total FROM subscribers (CASE WHEN CARDINALITY($1::INT[]) > 0 THEN true ELSE false END) AND subscriber_lists.subscriber_id = subscribers.id ) - WHERE subscriber_lists.list_id = ALL($1::INT[]) %s; + WHERE (CARDINALITY($1) = 0 OR subscriber_lists.list_id = ANY($1::INT[])) %s; -- name: query-subscribers-for-export -- raw: true