mirror of
https://github.com/haiwen/seahub.git
synced 2025-09-20 10:58:33 +00:00
enable sysadmin view user's repo
This commit is contained in:
@@ -222,6 +222,9 @@ LOGIN_REDIRECT_URL = '/profile/'
|
||||
|
||||
ACCOUNT_ACTIVATION_DAYS = 7
|
||||
|
||||
# allow seafile amdin view user's repo
|
||||
ENABLE_SYS_ADMIN_VIEW_REPO = False
|
||||
|
||||
# show traffic on the UI
|
||||
SHOW_TRAFFIC = True
|
||||
|
||||
|
94
seahub/templates/sysadmin/admin_repo_view.html
Normal file
94
seahub/templates/sysadmin/admin_repo_view.html
Normal file
@@ -0,0 +1,94 @@
|
||||
{% extends "myhome_base.html" %}
|
||||
|
||||
{% load seahub_tags avatar_tags i18n upload_tags %}
|
||||
|
||||
{% block sub_title %}{{repo.name}} - {% endblock %}
|
||||
{% block extra_style %}
|
||||
<style type="text/css">
|
||||
#footer { display:none; }
|
||||
</style>
|
||||
{% endblock %}
|
||||
|
||||
{% block main_panel %}
|
||||
<div id="repo-top">
|
||||
<h2 class="hd">{{repo.props.name}}</h2>
|
||||
</div>
|
||||
|
||||
<div id="repo-file-list">
|
||||
<div class="repo-file-list-topbar">
|
||||
<p class="path fleft">
|
||||
{% for name, link in zipped %}
|
||||
{% if forloop.first or not forloop.last %}
|
||||
<a href="{% url 'sys_admin_repo' repo.id %}?p={{link|urlencode}}" class="dir-link normal">{{ name }}</a> /
|
||||
{% else %}
|
||||
<span id="cur-dir-name">{{ name }}</span> /
|
||||
{% endif %}
|
||||
{% endfor %}
|
||||
</p>
|
||||
<div id="repo-latest-commit" class="clear">
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<table class="repo-file-list">
|
||||
<tr>
|
||||
<th class="dirent-icon"></th>
|
||||
<th><span class="dirent-name">{% trans "Name"%}</span></th>
|
||||
<th class="dirent-size">{% trans "Size"%}</th>
|
||||
<th class="dirent-update">{% trans "Last Update" %}</th>
|
||||
<th class="dirent-op">{% trans "Operations"%}</th>
|
||||
</tr>
|
||||
{% for dirent in dir_list %}
|
||||
<tr class="dir-item">
|
||||
<td class="dirent-icon"><img src="{{ MEDIA_URL }}img/folder-24.png" alt="{% trans "Directory icon"%}" /></td>
|
||||
<td>
|
||||
<span class="dirent-name"><a href="?p={{path|urlencode}}{{ dirent.obj_name|urlencode }}" class="dir-link">{{ dirent.obj_name }}</a></span>
|
||||
</td>
|
||||
|
||||
<td class="dirent-size"></td>
|
||||
<td class="dirent-update">
|
||||
{{ dirent.last_modified|translate_seahub_time }}
|
||||
</td>
|
||||
<td class="dirent-op">
|
||||
</td>
|
||||
</tr>
|
||||
{% endfor %}
|
||||
{% for dirent in file_list %}
|
||||
<tr class="file-item">
|
||||
<td class="dirent-icon">
|
||||
<img src="{{ MEDIA_URL }}img/file/{{ dirent.obj_name|file_icon_filter }}" alt="{% trans "File"%}" />
|
||||
</td>
|
||||
<td>
|
||||
<span class="dirent-name">{{ dirent.obj_name }}</span>
|
||||
</td>
|
||||
<td class="dirent-size">{{ dirent.file_size|filesizeformat }}</td>
|
||||
<td class="dirent-update">
|
||||
{{ dirent.last_modified|translate_seahub_time }}
|
||||
</td>
|
||||
<td class="dirent-op">
|
||||
<div class="repo-file-op vh">
|
||||
<div class="displayed-op">
|
||||
<a class="op file-download" href="{% url 'sys_admin_repo_download_file' repo.id %}?p={{path|urlencode}}{{ dirent.obj_name|urlencode }}" title="{% trans "Download"%}">
|
||||
<img src="{{MEDIA_URL}}img/download.png" alt="" />
|
||||
</a>
|
||||
</div>
|
||||
</div>
|
||||
</td>
|
||||
</tr>
|
||||
{% endfor %}
|
||||
</table>
|
||||
</div>
|
||||
|
||||
{% endblock %}
|
||||
|
||||
{% block extra_script %}
|
||||
<script type="text/javascript">
|
||||
$('.dir-item, .file-item').unbind().hover( // remove previously binded hover handler at first
|
||||
function() {
|
||||
$(this).addClass('hl').find('.repo-file-op').removeClass('vh');
|
||||
},
|
||||
function() {
|
||||
$(this).removeClass('hl').find('.repo-file-op').addClass('vh');
|
||||
}
|
||||
);
|
||||
</script>
|
||||
{% endblock %}
|
@@ -11,10 +11,17 @@
|
||||
<tr>
|
||||
{% if repo.encrypted %}
|
||||
<td><img src="{{MEDIA_URL}}img/sync-folder-encrypt-20.png" title="{% trans "Encrypted"%}" alt="{% trans "directory icon" %}" /></td>
|
||||
<td>{{ repo.props.name }}</td>
|
||||
{% else %}
|
||||
<td><img src="{{MEDIA_URL}}img/sync-folder-20.png?t=1387267140" title="{% trans "Read-Write"%}" alt="{% trans "directory icon" %}" /></td>
|
||||
{% if repo.is_default_repo %}
|
||||
<td><a href="{% url 'repo' repo.id %}">{{ repo.props.name }}</a></td>
|
||||
{% elif enable_sys_admin_view_repo %}
|
||||
<td><a href="{% url 'sys_admin_repo' repo.id %}">{{ repo.props.name }}</a></td>
|
||||
{% else %}
|
||||
<td>{{ repo.props.name }}</td>
|
||||
{% endif %}
|
||||
{% endif %}
|
||||
<td>{{ repo.props.name }}</td>
|
||||
<td style="font-size:11px;">{{ repo.id }}</td>
|
||||
<td>
|
||||
{% if repo.owner %}
|
||||
|
@@ -52,7 +52,13 @@
|
||||
{% else %}
|
||||
<td><img src="{{MEDIA_URL}}img/sync-folder-20.png?t=1387267140" title="{% trans "Read-Write" %}" alt="{% trans "library icon" %}" /></td>
|
||||
{% endif %}
|
||||
<td><a href="{% url 'view_common_lib_dir' repo.id '' %}">{{ repo.name }}</a></td>
|
||||
{% if repo.encrypted %}
|
||||
<td>{{ repo.name }}</td>
|
||||
{% elif enable_sys_admin_view_repo %}
|
||||
<td><a href="{% url 'sys_admin_repo' repo.id %}">{{ repo.name }}</a></td>
|
||||
{% else %}
|
||||
<td>{{ repo.name }}</td>
|
||||
{% endif %}
|
||||
<td>{{ repo.size|filesizeformat }}</td>
|
||||
<td><a href="{% url 'user_info' repo.user %}">{{ repo.user }}</a></td>
|
||||
<td data-id="{{ repo.id }}" data-name="{{repo.name}}">
|
||||
|
@@ -89,7 +89,13 @@
|
||||
{% else %}
|
||||
<td><img src="{{MEDIA_URL}}img/sync-folder-20.png?t=1387267140" title="{% trans "Read-Write" %}" alt="{% trans "library icon" %}" /></td>
|
||||
{% endif %}
|
||||
<td><a href="{% url 'view_common_lib_dir' repo.id '' %}">{{ repo.props.name }}</a></td>
|
||||
{% if repo.encrypted %}
|
||||
<td>{{ repo.name }}</td>
|
||||
{% elif enable_sys_admin_view_repo %}
|
||||
<td><a href="{% url 'sys_admin_repo' repo.id %}">{{ repo.name }}</a></td>
|
||||
{% else %}
|
||||
<td>{{ repo.name }}</td>
|
||||
{% endif %}
|
||||
<td>{{ repo.size|filesizeformat }}</td>
|
||||
<td>{{ repo.last_modify|translate_seahub_time }}</td>
|
||||
<td data-id="{{ repo.props.id }}" data-name="{{repo.name}}">
|
||||
@@ -123,7 +129,11 @@
|
||||
{% else %}
|
||||
<td><img src="{{MEDIA_URL}}img/sync-folder-20.png?t=1387267140" title="{% trans "Read-Write" %}" alt="{% trans "library icon" %}" /></td>
|
||||
{% endif %}
|
||||
<td><a href="{% url 'view_common_lib_dir' repo.id '' %}">{{ repo.props.repo_name }}</a></td>
|
||||
{% if enable_sys_admin_view_repo %}
|
||||
<td><a href="{% url 'sys_admin_repo' repo.id %}">{{ repo.name }}</a></td>
|
||||
{% else %}
|
||||
<td>{{ repo.name }}</td>
|
||||
{% endif %}
|
||||
<td>{{ repo.props.user }}</td>
|
||||
<td>{{ repo.size|filesizeformat }}</td>
|
||||
<td>{{ repo.last_modify|translate_seahub_time }}</td>
|
||||
|
@@ -207,6 +207,8 @@ urlpatterns = patterns(
|
||||
url(r'^sys/info/$', sys_info, name='sys_info'),
|
||||
url(r'^sys/settings/$', sys_settings, name='sys_settings'),
|
||||
url(r'^sys/seafadmin/$', sys_repo_admin, name='sys_repo_admin'),
|
||||
url(r'^sys/seafadmin/repo/(?P<repo_id>[-0-9a-f]{36})/$', sys_admin_repo, name='sys_admin_repo'),
|
||||
url(r'^sys/seafadmin/repo/(?P<repo_id>[-0-9a-f]{36})/download-file/$', sys_admin_repo_download_file, name='sys_admin_repo_download_file'),
|
||||
url(r'^sys/seafadmin/system/$', sys_list_system, name='sys_list_system'),
|
||||
url(r'^sys/seafadmin/repo-trash/$', sys_repo_trash, name='sys_repo_trash'),
|
||||
url(r'^sys/seafadmin/repo-trash/clear/$', sys_repo_trash_clear, name="sys_repo_trash_clear"),
|
||||
@@ -255,7 +257,6 @@ urlpatterns = patterns(
|
||||
url(r'^useradmin/batchadduser/$', batch_add_user, name='batch_add_user'),
|
||||
|
||||
url(r'^client-login/$', client_token_login, name='client_token_login'),
|
||||
|
||||
)
|
||||
|
||||
from seahub.utils import EVENTS_ENABLED
|
||||
|
@@ -6,6 +6,7 @@ import logging
|
||||
import json
|
||||
import re
|
||||
import datetime
|
||||
import stat
|
||||
import csv, chardet, StringIO
|
||||
from constance import config
|
||||
|
||||
@@ -18,7 +19,8 @@ from django.utils import timezone
|
||||
from django.utils.translation import ugettext as _
|
||||
|
||||
from seaserv import ccnet_threaded_rpc, seafserv_threaded_rpc, get_emailusers, \
|
||||
CALC_SHARE_USAGE, seafile_api, get_group, get_group_members
|
||||
CALC_SHARE_USAGE, seafile_api, get_group, get_group_members, get_repo, \
|
||||
get_file_size
|
||||
from pysearpc import SearpcError
|
||||
|
||||
from seahub.base.accounts import User
|
||||
@@ -31,21 +33,22 @@ from seahub.constants import GUEST_USER, DEFAULT_USER
|
||||
|
||||
from seahub.utils import IS_EMAIL_CONFIGURED, string2list, is_valid_username, \
|
||||
is_pro_version, send_html_email, get_user_traffic_list, get_server_id, \
|
||||
clear_token
|
||||
clear_token, gen_file_get_url, is_org_context
|
||||
from seahub.utils.rpc import mute_seafile_api
|
||||
from seahub.utils.licenseparse import parse_license
|
||||
from seahub.utils.sysinfo import get_platform_name
|
||||
|
||||
from seahub.views import get_system_default_repo_id
|
||||
from seahub.views.ajax import (get_related_users_by_org_repo,
|
||||
get_related_users_by_repo)
|
||||
from seahub.views import get_system_default_repo_id, gen_path_link
|
||||
from seahub.forms import SetUserQuotaForm, AddUserForm, BatchAddUserForm
|
||||
from seahub.profile.models import Profile, DetailedProfile
|
||||
from seahub.signals import repo_deleted
|
||||
from seahub.share.models import FileShare, UploadLinkShare
|
||||
import seahub.settings as settings
|
||||
from seahub.settings import INIT_PASSWD, SITE_NAME, CONSTANCE_CONFIG, \
|
||||
SEND_EMAIL_ON_ADDING_SYSTEM_MEMBER, SEND_EMAIL_ON_RESETTING_USER_PASSWD
|
||||
from seahub.settings import INIT_PASSWD, SITE_NAME, \
|
||||
SEND_EMAIL_ON_ADDING_SYSTEM_MEMBER, SEND_EMAIL_ON_RESETTING_USER_PASSWD, \
|
||||
ENABLE_SYS_ADMIN_VIEW_REPO
|
||||
try:
|
||||
from seahub.settings import ENABLE_TRIAL_ACCOUNT
|
||||
except:
|
||||
@@ -155,7 +158,9 @@ def sys_repo_admin(request):
|
||||
else:
|
||||
page_next = False
|
||||
|
||||
default_repo_id = get_system_default_repo_id()
|
||||
for repo in repos:
|
||||
repo.is_default_repo = True if repo.id == default_repo_id else False
|
||||
try:
|
||||
repo.owner = seafile_api.get_repo_owner(repo.id)
|
||||
except:
|
||||
@@ -163,6 +168,7 @@ def sys_repo_admin(request):
|
||||
|
||||
return render_to_response(
|
||||
'sysadmin/sys_repo_admin.html', {
|
||||
'enable_sys_admin_view_repo': ENABLE_SYS_ADMIN_VIEW_REPO,
|
||||
'repos': repos,
|
||||
'current_page': current_page,
|
||||
'prev_page': current_page-1,
|
||||
@@ -172,6 +178,102 @@ def sys_repo_admin(request):
|
||||
},
|
||||
context_instance=RequestContext(request))
|
||||
|
||||
@login_required
|
||||
@sys_staff_required
|
||||
def sys_admin_repo_download_file(request, repo_id):
|
||||
"""
|
||||
"""
|
||||
repo = get_repo(repo_id)
|
||||
path = request.GET.get('p', '')
|
||||
obj_id = seafile_api.get_file_id_by_path(repo_id, path)
|
||||
|
||||
next = request.META.get('HTTP_REFERER', None)
|
||||
if not next:
|
||||
next = reverse('sys_admin_repo')
|
||||
|
||||
if not repo or repo.encrypted or not is_pro_version() \
|
||||
or not ENABLE_SYS_ADMIN_VIEW_REPO or not obj_id:
|
||||
messages.error(request, _(u'Unable to download file'))
|
||||
return HttpResponseRedirect(next)
|
||||
|
||||
try:
|
||||
token = seafile_api.get_fileserver_access_token(repo_id, obj_id,
|
||||
'download', request.user.username)
|
||||
except SearpcError as e:
|
||||
logger.error(e)
|
||||
messages.error(request, _(u'Unable to view library'))
|
||||
return HttpResponseRedirect(next)
|
||||
|
||||
file_name = os.path.basename(path.rstrip('/'))
|
||||
redirect_url = gen_file_get_url(token, file_name)
|
||||
return HttpResponseRedirect(redirect_url)
|
||||
|
||||
@login_required
|
||||
@sys_staff_required
|
||||
def sys_admin_repo(request, repo_id):
|
||||
next = request.META.get('HTTP_REFERER', None)
|
||||
if not next:
|
||||
next = reverse('sys_repo_admin')
|
||||
|
||||
if not is_pro_version() or not ENABLE_SYS_ADMIN_VIEW_REPO:
|
||||
messages.error(request, _(u'Unable to view library, this feature is not enabled.'))
|
||||
return HttpResponseRedirect(next)
|
||||
|
||||
repo = get_repo(repo_id)
|
||||
if not repo:
|
||||
messages.error(request, _(u'Library does not exist'))
|
||||
return HttpResponseRedirect(next)
|
||||
|
||||
if repo.encrypted:
|
||||
messages.error(request, _(u'Library is encrypted'))
|
||||
return HttpResponseRedirect(next)
|
||||
|
||||
path = request.GET.get('p', '/')
|
||||
if path[-1] != '/':
|
||||
path = path + '/'
|
||||
|
||||
dir_id = seafile_api.get_dir_id_by_path(repo_id, path)
|
||||
if not dir_id:
|
||||
messages.error(request, _(u'Unable to view library, wrong folder path.'))
|
||||
return HttpResponseRedirect(next)
|
||||
|
||||
if is_org_context(request):
|
||||
repo_owner = seafile_api.get_org_repo_owner(repo_id)
|
||||
else:
|
||||
repo_owner = seafile_api.get_repo_owner(repo_id)
|
||||
|
||||
try:
|
||||
dirs = seafserv_threaded_rpc.list_dir_with_perm(repo_id, path,
|
||||
dir_id, repo_owner,
|
||||
-1, -1)
|
||||
except SearpcError as e:
|
||||
logger.error(e)
|
||||
messages.error(request, _(u'Unable to view library'))
|
||||
return HttpResponseRedirect(next)
|
||||
|
||||
file_list, dir_list = [], []
|
||||
for dirent in dirs:
|
||||
dirent.last_modified = dirent.mtime
|
||||
if stat.S_ISDIR(dirent.props.mode):
|
||||
dir_list.append(dirent)
|
||||
else:
|
||||
if repo.version == 0:
|
||||
dirent.file_size = get_file_size(repo.store_id, repo.version, dirent.obj_id)
|
||||
else:
|
||||
dirent.file_size = dirent.size
|
||||
file_list.append(dirent)
|
||||
|
||||
zipped = gen_path_link(path, repo.name)
|
||||
|
||||
return render_to_response('sysadmin/admin_repo_view.html', {
|
||||
'repo': repo,
|
||||
'repo_owner': repo_owner,
|
||||
'dir_list': dir_list,
|
||||
'file_list': file_list,
|
||||
'path': path,
|
||||
'zipped': zipped,
|
||||
}, context_instance=RequestContext(request))
|
||||
|
||||
@login_required
|
||||
@sys_staff_required
|
||||
def sys_list_system(request):
|
||||
@@ -332,6 +434,7 @@ def sys_repo_search(request):
|
||||
'repos': repos,
|
||||
'name': repo_name,
|
||||
'owner': owner,
|
||||
'enable_sys_admin_view_repo': ENABLE_SYS_ADMIN_VIEW_REPO,
|
||||
}, context_instance=RequestContext(request))
|
||||
|
||||
def _populate_user_quota_usage(user):
|
||||
@@ -723,6 +826,7 @@ def user_info(request, email):
|
||||
'd_profile': d_profile,
|
||||
'org_name': org_name,
|
||||
'user_shared_links': user_shared_links,
|
||||
'enable_sys_admin_view_repo': ENABLE_SYS_ADMIN_VIEW_REPO,
|
||||
}, context_instance=RequestContext(request))
|
||||
|
||||
@login_required_ajax
|
||||
@@ -1171,6 +1275,7 @@ def sys_admin_group_info(request, group_id):
|
||||
'group': group,
|
||||
'repos': repos,
|
||||
'members': members,
|
||||
'enable_sys_admin_view_repo': ENABLE_SYS_ADMIN_VIEW_REPO,
|
||||
}, context_instance=RequestContext(request))
|
||||
|
||||
@login_required
|
||||
|
Reference in New Issue
Block a user