twitterchiver/viewer: add stats to index page

This commit is contained in:
Luke Granger-Brown 2020-10-21 02:04:34 +00:00
parent 0da26f3e42
commit 23c7f8e520
2 changed files with 51 additions and 5 deletions

View file

@ -7,3 +7,14 @@
<li><strong><a href="/view/{{.Username}}">{{.Username}}</a></strong> ({{.TweetCount}} tweets, latest tweet at {{.LatestTweet}}) <li><strong><a href="/view/{{.Username}}">{{.Username}}</a></strong> ({{.TweetCount}} tweets, latest tweet at {{.LatestTweet}})
{{end}} {{end}}
</ul> </ul>
<h2>Stats</h2>
<dl>
<dt>Tweets</dt>
<dd>{{.TotalTweets}} tweets ({{.TimelineTweets}} on timeline)</dd>
<dt>Unfetched Media</dt>
<dd>{{.UnfetchedMedia}}</dd>
<dt>Unfetched Related</dt>
<dd>{{.UnfetchedRelated}}</dd>
</dl>

View file

@ -110,7 +110,34 @@ func main() {
user := userFromContext(ctx) user := userFromContext(ctx)
twitterAccounts := userMapping[user] twitterAccounts := userMapping[user]
rows, err := pool.Query(ctx, "SELECT ua.username, COUNT(uat.tweetid) tweet_count, (SELECT CAST(object->>'created_at' AS timestamp with time zone) FROM tweets WHERE id=MAX(uat.tweetid)) latest_tweet FROM user_accounts ua LEFT JOIN user_accounts_tweets uat ON uat.userid=ua.userid WHERE ua.username = ANY($1::text[]) GROUP BY 1 ORDER BY 1", twitterAccounts) var allTweets, timelineTweets, unfetchedMedia, unfetchedRelated int
if err := pool.QueryRow(ctx, `
SELECT
(SELECT COUNT(id) FROM tweets) all_tweets,
(SELECT COUNT(DISTINCT tweetid) FROM user_accounts_tweets WHERE on_timeline) timeline_tweets,
(SELECT COUNT(id) FROM tweets WHERE NOT fetched_media) not_fetched_media,
(SELECT COUNT(id) FROM tweets WHERE NOT fetched_related_tweets) not_fetched_related
`).Scan(&allTweets, &timelineTweets, &unfetchedMedia, &unfetchedRelated); err != nil {
writeError(rw, http.StatusInternalServerError, "querying stats", err)
return
}
rows, err := pool.Query(ctx, `
SELECT
ua.username,
COUNT(uat.tweetid) tweet_count,
(SELECT CAST(object->>'created_at' AS timestamp with time zone) FROM tweets WHERE id=MAX(uat.tweetid)) latest_tweet
FROM
user_accounts ua
LEFT JOIN
user_accounts_tweets uat ON uat.userid=ua.userid
WHERE 1=1
AND ua.username = ANY($1::text[])
AND uat.on_timeline
GROUP BY 1
ORDER BY 1
`, twitterAccounts)
if err != nil { if err != nil {
writeError(rw, http.StatusInternalServerError, "querying database", err) writeError(rw, http.StatusInternalServerError, "querying database", err)
return return
@ -137,9 +164,17 @@ func main() {
indexTmpl.Execute(rw, struct { indexTmpl.Execute(rw, struct {
Username string Username string
TwitterAccounts []twitterData TwitterAccounts []twitterData
TotalTweets int
TimelineTweets int
UnfetchedMedia int
UnfetchedRelated int
}{ }{
Username: user, Username: user,
TwitterAccounts: tds, TwitterAccounts: tds,
TotalTweets: allTweets,
TimelineTweets: timelineTweets,
UnfetchedMedia: unfetchedMedia,
UnfetchedRelated: unfetchedRelated,
}) })
}) })
isAllowedToSee := func(ctx context.Context, twitterUser string) bool { isAllowedToSee := func(ctx context.Context, twitterUser string) bool {