class UsersController < ApplicationController
skip_before_filter :find_object_by_uuid, :only => [:welcome, :activity]
skip_around_filter :thread_with_mandatory_api_token, :only => :welcome
- before_filter :ensure_current_user_is_admin, only: :sudo
+ before_filter :ensure_current_user_is_admin, only: [:sudo, :unsetup]
def welcome
if current_user
jobs: {},
pipeline_instances: {}
}
+ @total_activity = {}
@spans = [['This week', Time.now.beginning_of_week, Time.now],
['Last week',
Time.now.beginning_of_week.advance(weeks:-1),
@user_activity[record.modified_by_user_uuid] ||= {}
@user_activity[record.modified_by_user_uuid][span + ' ' + type.to_s] ||= 0
@user_activity[record.modified_by_user_uuid][span + ' ' + type.to_s] += 1
+ @total_activity[span + ' ' + type.to_s] ||= 0
+ @total_activity[span + ' ' + type.to_s] += 1
end
end
end
@users = @users.sort_by do |a|
[-@user_activity[a.uuid].values.inject(:+), a.full_name]
end
+ # Prepend a "Total" pseudo-user to the sorted list
+ @user_activity[nil] = @total_activity
+ @users = [OpenStruct.new(uuid: nil)] + @users
end
def show_pane_list
end
end
+ def index_pane_list
+ if current_user.andand.is_admin
+ super | %w(Activity)
+ else
+ super
+ end
+ end
+
def sudo
resp = $arvados_api_client.api(ApiClientAuthorization, '', {
api_client_authorization: {
f.html { render template: 'users/home' }
end
end
+
+ def unsetup
+ if current_user.andand.is_admin
+ @object.unsetup @object
+ end
+ show
+ end
+
end