parent
23e925b259
commit
043699cfb3
1 changed files with 11 additions and 6 deletions
|
@ -42,6 +42,11 @@ def get_log_entry_kinds():
|
||||||
return kind_map
|
return kind_map
|
||||||
|
|
||||||
|
|
||||||
|
def _get_log_entry_kind(name):
|
||||||
|
kinds = get_log_entry_kinds()
|
||||||
|
return kinds[name]
|
||||||
|
|
||||||
|
|
||||||
def get_aggregated_logs(start_time, end_time, performer=None, repository=None, namespace=None,
|
def get_aggregated_logs(start_time, end_time, performer=None, repository=None, namespace=None,
|
||||||
ignore=None):
|
ignore=None):
|
||||||
date = db.extract_date('day', LogEntry.datetime)
|
date = db.extract_date('day', LogEntry.datetime)
|
||||||
|
@ -83,7 +88,7 @@ def log_action(kind_name, user_or_organization_name, performer=None, repository=
|
||||||
if account is None:
|
if account is None:
|
||||||
account = User.select(fn.Min(User.id)).tuples().get()[0]
|
account = User.select(fn.Min(User.id)).tuples().get()[0]
|
||||||
|
|
||||||
kind = LogEntryKind.get(LogEntryKind.name == kind_name)
|
kind = _get_log_entry_kind(kind_name)
|
||||||
metadata_json = json.dumps(metadata, default=_json_serialize)
|
metadata_json = json.dumps(metadata, default=_json_serialize)
|
||||||
LogEntry.create(kind=kind, account=account, performer=performer,
|
LogEntry.create(kind=kind, account=account, performer=performer,
|
||||||
repository=repository, ip=ip, metadata_json=metadata_json,
|
repository=repository, ip=ip, metadata_json=metadata_json,
|
||||||
|
@ -121,22 +126,22 @@ def _get_repository_events(repository, time_delta, time_delta_earlier, clause):
|
||||||
|
|
||||||
|
|
||||||
def get_repository_pushes(repository, time_delta, time_delta_earlier):
|
def get_repository_pushes(repository, time_delta, time_delta_earlier):
|
||||||
push_repo = LogEntryKind.get(name='push_repo')
|
push_repo = _get_log_entry_kind('push_repo')
|
||||||
clauses = (LogEntry.kind == push_repo)
|
clauses = (LogEntry.kind == push_repo)
|
||||||
return _get_repository_events(repository, time_delta, time_delta_earlier, clauses)
|
return _get_repository_events(repository, time_delta, time_delta_earlier, clauses)
|
||||||
|
|
||||||
|
|
||||||
def get_repository_pulls(repository, time_delta, time_delta_earlier):
|
def get_repository_pulls(repository, time_delta, time_delta_earlier):
|
||||||
repo_pull = LogEntryKind.get(name='pull_repo')
|
repo_pull = _get_log_entry_kind('pull_repo')
|
||||||
repo_verb = LogEntryKind.get(name='repo_verb')
|
repo_verb = _get_log_entry_kind('repo_verb')
|
||||||
clauses = ((LogEntry.kind == repo_pull) | (LogEntry.kind == repo_verb))
|
clauses = ((LogEntry.kind == repo_pull) | (LogEntry.kind == repo_verb))
|
||||||
return _get_repository_events(repository, time_delta, time_delta_earlier, clauses)
|
return _get_repository_events(repository, time_delta, time_delta_earlier, clauses)
|
||||||
|
|
||||||
|
|
||||||
def get_repository_usage():
|
def get_repository_usage():
|
||||||
one_month_ago = date.today() - timedelta(weeks=4)
|
one_month_ago = date.today() - timedelta(weeks=4)
|
||||||
repo_pull = LogEntryKind.get(name='pull_repo')
|
repo_pull = _get_log_entry_kind('pull_repo')
|
||||||
repo_verb = LogEntryKind.get(name='repo_verb')
|
repo_verb = _get_log_entry_kind('repo_verb')
|
||||||
return (LogEntry
|
return (LogEntry
|
||||||
.select(LogEntry.ip, LogEntry.repository)
|
.select(LogEntry.ip, LogEntry.repository)
|
||||||
.where((LogEntry.kind == repo_pull) | (LogEntry.kind == repo_verb))
|
.where((LogEntry.kind == repo_pull) | (LogEntry.kind == repo_verb))
|
||||||
|
|
Reference in a new issue