def share_to_group(request, repo, from_user, group, permission): """Share repo to group with given permission. """ repo_id = repo.id group_id = group.id group_name = group.group_name if repo.id in seafile_api.get_group_repoids(group.id): msg = _( u'"%(repo)s" is already in group %(group)s. <a href="%(href)s">View</a>' ) % { 'repo': repo.name, 'group': group.group_name, 'href': reverse('group_info', args=[group.id]) } messages.error(request, msg) return try: seafile_api.group_share_repo(repo_id, group_id, from_user, permission) except Exception, e: logger.error(e) msg = _(u'Failed to share %(repo)s to %(group)s, please try again later.') % \ {'repo': repo.name, 'group': group_name} messages.error(request, msg)
def test_share_repo_to_group(repo, group, permission): assert api.check_permission(repo.id, USER) == 'rw' assert api.check_permission(repo.id, USER2) is None repos = api.get_repos_by_group(group.id) assert len(repos) == 0 group_list = ccnet_api.get_groups(USER) assert len(group_list) == 1 group_list = ccnet_api.get_groups(USER2) assert len(group_list) == 0 api.group_share_repo(repo.id, group.id, USER, permission) repos = api.get_repos_by_group(group.id) assert_repo_with_permission(repo, repos, permission) ccnet_api.group_add_member(group.id, USER, USER2) group_list = ccnet_api.get_groups(USER2) assert len(group_list) == 1 group = group_list[0] assert group.id == group.id repos2 = api.get_repos_by_group(group.id) assert_repo_with_permission(repo, repos2, permission) assert api.check_permission(repo.id, USER2) == permission api.group_unshare_repo(repo.id, group.id, USER) repos = api.get_repos_by_group(group.id) assert len(repos) == 0 assert api.check_permission(repo.id, USER2) is None
def test_get_group_repos(repo, group): repo = api.get_repo(repo.id) api.group_share_repo(repo.id, group.id, USER, 'rw') repos = api.get_repos_by_group(group.id) assert_group_repos_attr(repo, repos[0]) repos = api.get_group_repos_by_owner(USER) assert_group_repos_attr(repo, repos[0]) v_repo_id = api.share_subdir_to_group(repo.id, '/dir1', USER, group.id, 'rw') v_repo = api.get_repo(v_repo_id) v_repo_to_test = api.get_group_shared_repo_by_path(repo.id, '/dir1', group.id) assert_group_repos_attr(v_repo, v_repo_to_test) api.unshare_subdir_for_group(repo.id, '/dir1', USER, group.id) repos = api.get_group_repos_by_user(USER) assert_group_repos_attr(repo, repos[0]) assert api.group_unshare_repo(repo.id, group.id, USER) == 0
def share_to_group(request, repo, from_user, group, permission): """Share repo to group with given permission. """ repo_id = repo.id group_id = group.id group_name = group.group_name if repo.id in seafile_api.get_group_repoids(group.id): msg = _(u'"%(repo)s" is already in group %(group)s. <a href="%(href)s">View</a>') % { 'repo': repo.name, 'group': group.group_name, 'href': reverse('group_info', args=[group.id])} messages.error(request, msg) return try: seafile_api.group_share_repo(repo_id, group_id, from_user, permission) except Exception, e: logger.error(e) msg = _(u'Failed to share %(repo)s to %(group)s, please try again later.') % \ {'repo': repo.name, 'group': group_name} messages.error(request, msg)
def test_repo_perm_in_structure(repo, permission): id1 = ccnet_api.create_group('group1', USER, parent_group_id=-1) id2 = ccnet_api.create_group('group2', USER, parent_group_id=id1) assert id1 != -1 and id2 != -1 assert ccnet_api.group_add_member(id2, USER, USER2) != -1 assert api.group_share_repo(repo.id, id1, USER2, permission) != -1 assert api.check_permission(repo.id, USER2) == permission assert api.group_unshare_repo(repo.id, id1, USER2) != -1 assert api.check_permission(repo.id, USER2) == None assert ccnet_api.remove_group(id2) != -1 assert ccnet_api.remove_group(id1) != -1
def test_share_repo_to_group(repo, group, permission): assert api.check_permission(repo.id, USER) == 'rw' assert api.check_permission(repo.id, USER2) is None repos = api.get_repos_by_group(group.id) assert len(repos) == 0 group_list = ccnet_api.get_groups(USER) assert len(group_list) == 1 group_list = ccnet_api.get_groups(USER2) assert len(group_list) == 0 api.group_share_repo(repo.id, group.id, USER, permission) repos = api.get_repos_by_group(group.id) assert_repo_with_permission(repo, repos, permission) group_ids = api.get_shared_group_ids_by_repo(repo.id) assert group_ids[0] == str(group.id) group_list = api.list_repo_shared_group_by_user(USER, repo.id) assert len(group_list) == 1 group_list = api.list_repo_shared_group_by_user(USER2, repo.id) assert len(group_list) == 0 repo_get = api.get_group_shared_repo_by_path(repo.id, None, group.id) assert repo_get and repo_get.repo_id == repo.id ccnet_api.group_add_member(group.id, USER, USER2) group_list = ccnet_api.get_groups(USER2) assert len(group_list) == 1 group = group_list[0] assert group.id == group.id repos2 = api.get_repos_by_group(group.id) assert_repo_with_permission(repo, repos2, permission) assert api.check_permission(repo.id, USER2) == permission repos = api.get_group_repos_by_user(USER) assert len(repos) == 1 repoids = api.get_group_repoids(group.id) assert len(repoids) == 1 repos = api.get_group_repos_by_owner(USER) assert len(repos) == 1 api.remove_group_repos_by_owner(group.id, USER) repos = api.get_group_repos_by_owner(USER) assert len(repos) == 0 api.set_group_repo(repo.id, group.id, USER, permission) repos = api.get_repos_by_group(group.id) assert len(repos) == 1 api.remove_group_repos(group.id) repos = api.get_repos_by_group(group.id) assert len(repos) == 0 api.group_unshare_repo(repo.id, group.id, USER) repos = api.get_repos_by_group(group.id) assert len(repos) == 0 assert api.check_permission(repo.id, USER2) is None
class SharedRepo(APIView): """ Support uniform interface for shared libraries. """ authentication_classes = (TokenAuthentication, ) permission_classes = (IsAuthenticated, IsRepoOwner) throttle_classes = (UserRateThrottle, ) def delete(self, request, repo_id, format=None): """ Unshare a library. Only repo owner can perform this operation. """ share_type = request.GET.get('share_type', '') user = request.GET.get('user', '') group_id = request.GET.get('group_id', '') if not (share_type and user and group_id): return api_error(status.HTTP_400_BAD_REQUEST, 'share_type and user and group_id is required.') if share_type == 'personal': remove_share(repo_id, request.user.username, user) elif share_type == 'group': unshare_group_repo(repo_id, group_id, user) elif share_type == 'public': unset_inner_pub_repo(repo_id) else: return api_error( status.HTTP_400_BAD_REQUEST, 'share_type can only be personal or group or public.') return Response('success', status=status.HTTP_200_OK) def put(self, request, repo_id, format=None): """ Share a repo to users/groups/public. """ share_type = request.GET.get('share_type') user = request.GET.get('user') group_id = request.GET.get('group_id') permission = request.GET.get('permission') if permission != 'rw' and permission != "r": return api_error(status.HTTP_400_BAD_REQUEST, 'Permission need to be rw or r.') if share_type == 'personal': if not is_registered_user(user): return api_error(status.HTTP_400_BAD_REQUEST, 'User does not exist') try: from_email = seafile_api.get_repo_owner(repo_id) seafserv_threaded_rpc.add_share(repo_id, from_email, user, permission) except SearpcError, e: return api_error(status.HTTP_500_INTERNAL_SERVER_ERROR, "Searpc Error: " + e.msg) elif share_type == 'group': try: group_id = int(group_id) except ValueError: return api_error(status.HTTP_400_BAD_REQUEST, 'Group id must be integer.') from_email = seafile_api.get_repo_owner(repo_id) group = get_group(group_id) if not group: return api_error(status.HTTP_400_BAD_REQUEST, 'Group does not exist .') try: seafile_api.group_share_repo(repo_id, int(group_id), from_email, permission) except SearpcError, e: return api_error(status.HTTP_500_INTERNAL_SERVER_ERROR, "Searpc Error: " + e.msg)