forked from MirrorHub/synapse
add monthly active users to phonehome stats (#5252)
* add monthly active users to phonehome stats
This commit is contained in:
parent
abce00fc6a
commit
94dac0f3e5
3 changed files with 31 additions and 15 deletions
1
changelog.d/5252.feature
Normal file
1
changelog.d/5252.feature
Normal file
|
@ -0,0 +1 @@
|
||||||
|
Add monthly active users to phonehome stats.
|
|
@ -541,6 +541,7 @@ def run(hs):
|
||||||
stats["total_room_count"] = room_count
|
stats["total_room_count"] = room_count
|
||||||
|
|
||||||
stats["daily_active_users"] = yield hs.get_datastore().count_daily_users()
|
stats["daily_active_users"] = yield hs.get_datastore().count_daily_users()
|
||||||
|
stats["monthly_active_users"] = yield hs.get_datastore().count_monthly_users()
|
||||||
stats["daily_active_rooms"] = yield hs.get_datastore().count_daily_active_rooms()
|
stats["daily_active_rooms"] = yield hs.get_datastore().count_daily_active_rooms()
|
||||||
stats["daily_messages"] = yield hs.get_datastore().count_daily_messages()
|
stats["daily_messages"] = yield hs.get_datastore().count_daily_messages()
|
||||||
|
|
||||||
|
|
|
@ -279,10 +279,27 @@ class DataStore(
|
||||||
"""
|
"""
|
||||||
Counts the number of users who used this homeserver in the last 24 hours.
|
Counts the number of users who used this homeserver in the last 24 hours.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def _count_users(txn):
|
|
||||||
yesterday = int(self._clock.time_msec()) - (1000 * 60 * 60 * 24)
|
yesterday = int(self._clock.time_msec()) - (1000 * 60 * 60 * 24)
|
||||||
|
return self.runInteraction("count_daily_users", self._count_users, yesterday,)
|
||||||
|
|
||||||
|
def count_monthly_users(self):
|
||||||
|
"""
|
||||||
|
Counts the number of users who used this homeserver in the last 30 days.
|
||||||
|
Note this method is intended for phonehome metrics only and is different
|
||||||
|
from the mau figure in synapse.storage.monthly_active_users which,
|
||||||
|
amongst other things, includes a 3 day grace period before a user counts.
|
||||||
|
"""
|
||||||
|
thirty_days_ago = int(self._clock.time_msec()) - (1000 * 60 * 60 * 24 * 30)
|
||||||
|
return self.runInteraction(
|
||||||
|
"count_monthly_users",
|
||||||
|
self._count_users,
|
||||||
|
thirty_days_ago,
|
||||||
|
)
|
||||||
|
|
||||||
|
def _count_users(self, txn, time_from):
|
||||||
|
"""
|
||||||
|
Returns number of users seen in the past time_from period
|
||||||
|
"""
|
||||||
sql = """
|
sql = """
|
||||||
SELECT COALESCE(count(*), 0) FROM (
|
SELECT COALESCE(count(*), 0) FROM (
|
||||||
SELECT user_id FROM user_ips
|
SELECT user_id FROM user_ips
|
||||||
|
@ -290,13 +307,10 @@ class DataStore(
|
||||||
GROUP BY user_id
|
GROUP BY user_id
|
||||||
) u
|
) u
|
||||||
"""
|
"""
|
||||||
|
txn.execute(sql, (time_from,))
|
||||||
txn.execute(sql, (yesterday,))
|
|
||||||
count, = txn.fetchone()
|
count, = txn.fetchone()
|
||||||
return count
|
return count
|
||||||
|
|
||||||
return self.runInteraction("count_users", _count_users)
|
|
||||||
|
|
||||||
def count_r30_users(self):
|
def count_r30_users(self):
|
||||||
"""
|
"""
|
||||||
Counts the number of 30 day retained users, defined as:-
|
Counts the number of 30 day retained users, defined as:-
|
||||||
|
|
Loading…
Reference in a new issue