mirror of
https://github.com/zulip/zulip.git
synced 2025-11-06 06:53:25 +00:00
Automatically generated by the following script, based on the output
of lint with flake8-comma:
import re
import sys
last_filename = None
last_row = None
lines = []
for msg in sys.stdin:
m = re.match(
r"\x1b\[35mflake8 \|\x1b\[0m \x1b\[1;31m(.+):(\d+):(\d+): (\w+)", msg
)
if m:
filename, row_str, col_str, err = m.groups()
row, col = int(row_str), int(col_str)
if filename == last_filename:
assert last_row != row
else:
if last_filename is not None:
with open(last_filename, "w") as f:
f.writelines(lines)
with open(filename) as f:
lines = f.readlines()
last_filename = filename
last_row = row
line = lines[row - 1]
if err in ["C812", "C815"]:
lines[row - 1] = line[: col - 1] + "," + line[col - 1 :]
elif err in ["C819"]:
assert line[col - 2] == ","
lines[row - 1] = line[: col - 2] + line[col - 1 :].lstrip(" ")
if last_filename is not None:
with open(last_filename, "w") as f:
f.writelines(lines)
Signed-off-by: Anders Kaseorg <anders@zulipchat.com>
57 lines
2.4 KiB
Python
57 lines
2.4 KiB
Python
import datetime
|
|
from typing import Any, Dict
|
|
|
|
from django.core.management.base import BaseCommand, CommandParser
|
|
|
|
from zerver.lib.statistics import seconds_usage_between
|
|
from zerver.models import UserProfile
|
|
|
|
|
|
def analyze_activity(options: Dict[str, Any]) -> None:
|
|
day_start = datetime.datetime.strptime(options["date"], "%Y-%m-%d").replace(tzinfo=datetime.timezone.utc)
|
|
day_end = day_start + datetime.timedelta(days=options["duration"])
|
|
|
|
user_profile_query = UserProfile.objects.all()
|
|
if options["realm"]:
|
|
user_profile_query = user_profile_query.filter(realm__string_id=options["realm"])
|
|
|
|
print("Per-user online duration:\n")
|
|
total_duration = datetime.timedelta(0)
|
|
for user_profile in user_profile_query:
|
|
duration = seconds_usage_between(user_profile, day_start, day_end)
|
|
|
|
if duration == datetime.timedelta(0):
|
|
continue
|
|
|
|
total_duration += duration
|
|
print("%-*s%s" % (37, user_profile.email, duration))
|
|
|
|
print(f"\nTotal Duration: {total_duration}")
|
|
print(f"\nTotal Duration in minutes: {total_duration.total_seconds() / 60.}")
|
|
print(f"Total Duration amortized to a month: {total_duration.total_seconds() * 30. / 60.}")
|
|
|
|
class Command(BaseCommand):
|
|
help = """Report analytics of user activity on a per-user and realm basis.
|
|
|
|
This command aggregates user activity data that is collected by each user using Zulip. It attempts
|
|
to approximate how much each user has been using Zulip per day, measured by recording each 15 minute
|
|
period where some activity has occurred (mouse move or keyboard activity).
|
|
|
|
It will correctly not count server-initiated reloads in the activity statistics.
|
|
|
|
The duration flag can be used to control how many days to show usage duration for
|
|
|
|
Usage: ./manage.py analyze_user_activity [--realm=zulip] [--date=2013-09-10] [--duration=1]
|
|
|
|
By default, if no date is selected 2013-09-10 is used. If no realm is provided, information
|
|
is shown for all realms"""
|
|
|
|
def add_arguments(self, parser: CommandParser) -> None:
|
|
parser.add_argument('--realm', action='store')
|
|
parser.add_argument('--date', action='store', default="2013-09-06")
|
|
parser.add_argument('--duration', action='store', default=1, type=int,
|
|
help="How many days to show usage information for")
|
|
|
|
def handle(self, *args: Any, **options: Any) -> None:
|
|
analyze_activity(options)
|