1
0
mirror of https://github.com/haiwen/seahub.git synced 2025-06-18 19:38:07 +00:00
seahub/views.py

184 lines
5.2 KiB
Python
Raw Normal View History

2011-03-19 05:15:02 +00:00
from django.http import HttpResponse, HttpResponseRedirect
from django.shortcuts import render_to_response
from django.core.urlresolvers import reverse
from django.template import RequestContext
from django.contrib.auth.decorators import login_required
2011-09-10 12:07:46 +00:00
from django.db import IntegrityError
2011-03-19 05:15:02 +00:00
2011-08-16 13:05:42 +00:00
from seaserv import cclient, ccnet_rpc, get_groups, get_users, get_repos, \
2011-09-10 12:07:46 +00:00
get_repo, get_commits, get_branches, seafile_rpc, get_group
from seahub.profile.models import UserProfile
from seahub.group.models import GroupRepo
from seahub.group.forms import GroupAddRepoForm
2011-09-07 02:57:47 +00:00
def get_user_cid(user):
try:
profile = user.get_profile()
return profile.ccnet_user_id
except UserProfile.DoesNotExist:
return None
2011-03-19 14:06:58 +00:00
2011-08-16 13:37:27 +00:00
2011-03-19 05:15:02 +00:00
def root(request):
2011-05-08 07:19:58 +00:00
if request.user.is_authenticated():
return HttpResponseRedirect(reverse(myhome))
else:
return HttpResponseRedirect(reverse(home))
2011-03-19 05:15:02 +00:00
2011-03-20 13:47:28 +00:00
2011-03-19 05:15:02 +00:00
def home(request):
2011-08-16 13:05:42 +00:00
return render_to_response('home.html', {
2011-03-19 05:15:02 +00:00
}, context_instance=RequestContext(request))
2011-03-19 14:06:58 +00:00
2011-03-19 14:06:58 +00:00
def peers(request):
peer_type = request.REQUEST.get('type', 'all')
peer_ids = ccnet_rpc.list_peers()
peers = []
for peer_id in peer_ids.split("\n"):
# too handle the ending '\n'
if peer_id == '':
continue
peer = ccnet_rpc.get_peer(peer_id)
if peer_type == 'all':
peers.append(peer)
if peer_type == 'mypeer':
if peer.props.role_list.find('MyPeer') != -1:
peers.append(peer)
2011-04-11 15:06:05 +00:00
users = get_users()
2011-03-19 14:06:58 +00:00
return render_to_response('peers.html', {
'peers': peers,
2011-04-11 15:06:05 +00:00
'users': users,
2011-03-19 14:06:58 +00:00
}, context_instance=RequestContext(request))
2011-03-20 13:47:28 +00:00
def groups(request):
groups = get_groups()
return render_to_response('groups.html', {
'groups': groups,
}, context_instance=RequestContext(request))
2011-05-08 07:19:58 +00:00
2011-09-10 12:07:46 +00:00
def group(request, group_id):
"""Show a group.
Login is not required, but permission check based on token should
be added later.
"""
group = get_group(group_id)
shared_repos = GroupRepo.objects.filter(group_id=group_id)
return render_to_response('group.html', {
'group': group, 'shared_repos': shared_repos,
}, context_instance=RequestContext(request))
def group_add_repo(request, group_id):
"""Add a repo to a group"""
group = get_group(group_id)
if not group:
raise Http404
if request.method == 'POST':
form = GroupAddRepoForm(request.POST)
if form.is_valid():
group_repo = GroupRepo()
group_repo.group_id = group_id
group_repo.repo_id = form.cleaned_data['repo_id']
try:
group_repo.save()
except IntegrityError:
# catch the case repo added to group before
pass
return HttpResponseRedirect(reverse('view_group', args=[group_id]))
else:
form = GroupAddRepoForm()
return render_to_response("group_add_repo.html", {
'form': form, 'group': group
}, context_instance=RequestContext(request))
2011-10-18 07:41:48 +00:00
2011-09-07 02:57:47 +00:00
def repo(request, repo_id):
# TODO: check permission
repo = get_repo(repo_id)
commits = get_commits(repo_id)
branches = get_branches(repo_id)
2011-10-18 07:41:48 +00:00
token = ""
is_owner = False
if request.user.is_authenticated():
cid = get_user_cid(request.user)
if seafile_rpc.is_repo_owner(cid, repo_id):
is_owner = True
token = seafile_rpc.get_repo_token(repo_id)
2011-09-07 02:57:47 +00:00
return render_to_response('repo.html', {
"repo": repo,
"commits": commits,
"branches": branches,
2011-10-18 07:41:48 +00:00
"is_owner": is_owner,
"token": token,
2011-09-07 02:57:47 +00:00
}, context_instance=RequestContext(request))
@login_required
def repo_share(request, repo_id):
return render_to_response('repo_share.html', {
"repo": repo,
"commits": commits,
"branches": branches,
}, context_instance=RequestContext(request))
2011-10-18 07:41:48 +00:00
@login_required
def modify_token(request, repo_id):
cid = get_user_cid(request.user)
if not seafile_rpc.is_repo_owner(cid, repo_id):
return HttpResponseRedirect(reverse(repo, args=[repo_id]))
token = request.POST.get('token', '')
if token:
seafile_rpc.set_repo_token(repo_id, token)
return HttpResponseRedirect(reverse(repo, args=[repo_id]))
2011-09-07 02:57:47 +00:00
@login_required
def myhome(request):
ccnet_user_id = ""
try:
profile = request.user.get_profile()
ccnet_user_id = profile.ccnet_user_id
except UserProfile.DoesNotExist:
pass
2011-10-12 16:17:48 +00:00
owned_repos = []
if ccnet_user_id:
owned_repos = seafile_rpc.list_owned_repos(ccnet_user_id)
2011-09-07 02:57:47 +00:00
return render_to_response('myhome.html', {
"ccnet_user_id": ccnet_user_id,
2011-10-12 16:17:48 +00:00
"owned_repos": owned_repos,
2011-09-07 02:57:47 +00:00
}, context_instance=RequestContext(request))
@login_required
def mypeers(request):
cid = get_user_cid(request.user)
2011-05-08 07:19:58 +00:00
@login_required
2011-09-07 02:57:47 +00:00
def myrepos(request):
2011-05-08 07:19:58 +00:00
cid = get_user_cid(request.user)
2011-09-07 02:57:47 +00:00
owned_repos = seafile_rpc.list_owned_repos(cid)
2011-10-18 07:41:48 +00:00
2011-09-07 02:57:47 +00:00
return render_to_response('myrepos.html', {
'owned_repos': owned_repos,
2011-05-08 07:19:58 +00:00
}, context_instance=RequestContext(request))