DEV: Added default queries for finding the most active lurkers and inactive users

This commit is contained in:
Rishabh 2018-12-28 12:15:41 +05:30
parent 931bbb67a0
commit 7de1e5a68e
1 changed files with 53 additions and 2 deletions

View File

@ -5,6 +5,8 @@ class Queries
# Feel free to add new queries at the bottom of the hash in numerical order # Feel free to add new queries at the bottom of the hash in numerical order
# If any query has been run on an instance, it is then saved in the local db # If any query has been run on an instance, it is then saved in the local db
# Locally stored queries are updated from the below data only when they are run again # Locally stored queries are updated from the below data only when they are run again
# eg. If you update a query with id=-1 in this file and the query has been run on a site,
# you must run the query with id=-1 on the site again to update these changes in the site db
queries = { queries = {
"most-common-likers": { "most-common-likers": {
@ -45,12 +47,22 @@ class Queries
"user-participation": { "user-participation": {
"id": -8, "id": -8,
"name": "User Participation Statistics", "name": "User Participation Statistics",
"description": "Detailed statistics for the most active users" "description": "Detailed statistics for the most active users."
}, },
"largest-uploads": { "largest-uploads": {
"id": -9, "id": -9,
"name": "Top 50 Largest Uploads", "name": "Top 50 Largest Uploads",
"description": "sorted by file size" "description": "sorted by file size."
},
"inactive-users": {
"id": -10,
"name": "Inactive Users with no posts",
"description": "analyze pre-Discourse signups."
},
"active-lurkers": {
"id": -11,
"name": "Most Active Lurkers",
"description": "active users without posts and excessive read times, it accepts a post_read_count paramteter that sets the threshold for posts read."
} }
}.with_indifferent_access }.with_indifferent_access
@ -306,6 +318,45 @@ class Queries
LIMIT 50 LIMIT 50
SQL SQL
queries["inactive-users"]["sql"] = <<~SQL
SELECT
u.id,
u.username_lower AS "username",
u.created_at,
u.last_seen_at
FROM users u
WHERE u.active = false
ORDER BY u.id
SQL
queries["active-lurkers"]["sql"] = <<~SQL
-- [params]
-- int :post_read_count = 100
WITH posts_by_user AS (
SELECT COUNT(*) AS posts, user_id
FROM posts
GROUP BY user_id
), posts_read_by_user AS (
SELECT SUM(posts_read) AS posts_read, user_id
FROM user_visits
GROUP BY user_id
)
SELECT
u.id,
u.username_lower AS "username",
u.created_at,
u.last_seen_at,
COALESCE(pbu.posts, 0) AS "posts_created",
COALESCE(prbu.posts_read, 0) AS "posts_read"
FROM users u
LEFT JOIN posts_by_user pbu ON pbu.user_id = u.id
LEFT JOIN posts_read_by_user prbu ON prbu.user_id = u.id
WHERE u.active = true
AND posts IS NULL
AND posts_read > :post_read_count
ORDER BY u.id
SQL
# convert query ids from "mostcommonlikers" to "-1", "mostmessages" to "-2" etc. # convert query ids from "mostcommonlikers" to "-1", "mostmessages" to "-2" etc.
queries.transform_keys!.with_index { |key, idx| "-#{idx + 1}" } queries.transform_keys!.with_index { |key, idx| "-#{idx + 1}" }
queries queries