Add ability to download logs

This commit is contained in:
Joseph Schorr 2013-12-06 15:59:59 -05:00
parent 52bee66c9f
commit 59046b2e79
5 changed files with 14 additions and 6 deletions

View file

@ -1058,13 +1058,12 @@ def delete_webhook(namespace_name, repository_name, public_id):
webhook.delete_instance() webhook.delete_instance()
return webhook return webhook
def list_logs(user_or_organization_name, repository = None): def list_logs(user_or_organization_name, start_time, repository = None):
week_ago = datetime.today() - timedelta(7) # One week
joined = LogEntry.select().join(User) joined = LogEntry.select().join(User)
if repository: if repository:
joined = joined.where(LogEntry.repository == repository) joined = joined.where(LogEntry.repository == repository)
return joined.where(User.username == user_or_organization_name, LogEntry.datetime >= week_ago).order_by(LogEntry.datetime.desc()) return joined.where(User.username == user_or_organization_name, LogEntry.datetime >= start_time).order_by(LogEntry.datetime.desc())
def log_action(kind_name, user_or_organization_name, performer=None, repository=None, def log_action(kind_name, user_or_organization_name, performer=None, repository=None,
access_token=None, ip=None, metadata={}, timestamp=None): access_token=None, ip=None, metadata={}, timestamp=None):

View file

@ -28,7 +28,7 @@ from auth.permissions import (ReadRepositoryPermission,
from endpoints import registry from endpoints import registry
from endpoints.web import common_login from endpoints.web import common_login
from util.cache import cache_control from util.cache import cache_control
from datetime import datetime, timedelta
store = app.config['STORAGE'] store = app.config['STORAGE']
user_files = app.config['USERFILES'] user_files = app.config['USERFILES']
@ -1727,8 +1727,10 @@ def log_view(log):
def org_logs_api(orgname): def org_logs_api(orgname):
permission = AdministerOrganizationPermission(orgname) permission = AdministerOrganizationPermission(orgname)
if permission.can(): if permission.can():
logs = model.list_logs(orgname) week_ago = datetime.today() - timedelta(7) # One week
logs = model.list_logs(orgname, week_ago)
return jsonify({ return jsonify({
'start_time': week_ago,
'logs': [log_view(log) for log in logs] 'logs': [log_view(log) for log in logs]
}) })

View file

@ -25,6 +25,7 @@ html, body {
font-size: 22px; font-size: 22px;
padding: 6px; padding: 6px;
cursor: pointer; cursor: pointer;
color: black;
} }
i.toggle-icon:hover { i.toggle-icon:hover {

View file

@ -8,6 +8,9 @@
<span class="right"> <span class="right">
<i class="fa fa-bar-chart-o toggle-icon" ng-class="chartVisible ? 'active' : ''" <i class="fa fa-bar-chart-o toggle-icon" ng-class="chartVisible ? 'active' : ''"
ng-click="toggleChart()" title="Toggle Chart" bs-tooltip="tooltip.title"></i> ng-click="toggleChart()" title="Toggle Chart" bs-tooltip="tooltip.title"></i>
<a href="{{ logsPath }}" download="usage-log.json" target="_new">
<i class="fa fa-download toggle-icon" title="Download Logs" bs-tooltip="tooltip.title"></i>
</a>
</span> </span>
</div> </div>

View file

@ -686,6 +686,7 @@ quayApp.directive('logsView', function () {
$scope.logs = null; $scope.logs = null;
$scope.kindsAllowed = null; $scope.kindsAllowed = null;
$scope.chartVisible = true; $scope.chartVisible = true;
$scope.logsPath = '';
var logDescriptions = { var logDescriptions = {
'account_change_plan': 'Change plan', 'account_change_plan': 'Change plan',
@ -781,9 +782,11 @@ quayApp.directive('logsView', function () {
if ($scope.repository) { if ($scope.repository) {
url = getRestUrl('repository', $scope.repository.namespace, $scope.repository.name, 'logs'); url = getRestUrl('repository', $scope.repository.namespace, $scope.repository.name, 'logs');
} }
var loadLogs = Restangular.one(url); var loadLogs = Restangular.one(url);
loadLogs.customGET().then(function(resp) { loadLogs.customGET().then(function(resp) {
$scope.logsPath = '/api/' + url;
if (!$scope.chart) { if (!$scope.chart) {
$scope.chart = new LogUsageChart(logKinds); $scope.chart = new LogUsageChart(logKinds);
$($scope.chart).bind('filteringChanged', function(e) { $($scope.chart).bind('filteringChanged', function(e) {