mirror of
https://github.com/haiwen/seahub.git
synced 2025-08-19 23:48:51 +00:00
* delete thridpart/social_django
* delete social_django in seahub/urls.py
* delete social_django in seahub/settings.py
* delete seahub/notifications/management/commands/send_wxwork_notices.py
* delete social_django in code annotation
* delete seahub/social_core
* delete tests/seahub/social_core
* delete social_core in seahub/urls.py
* delete social_core in seahub/settings.py
* change app_label to auth in SocialAuthUser model
* 2to3 asserts
* 2to3 basestring
* 2to3 dict
* 2to3 except
* 2to3 filter
* 2to3 future
* 2to3 has_key
* 2to3 idioms
* 2to3 import
* 2to3 imports
* 2to3 long
* 2to3 map
* 2to3 next
* 2to3 numliterals
* 2to3 print
* 2to3 raise
* 2to3 raw_input
* 2to3 reduce
* 2to3 reload
* 2to3 set_literal
* 2to3 unicode
* 2to3 urllib
* 2to3 ws_comma
* 2to3 xrange
* 2to3 zip
* add pymysql in __init__.py
* fix encode and decode in seahub/cconvert.py
* fix seafserv_rpc.is_passwd_set in seahub/views/__init__.py
* fix smart_unicode to smart_text
* fix force_unicode to force_text
* delete seaserv.get_session_info
* delete seaserv.ccnet_rpc
* fix indent error in seahub/auth/middleware.py
* update dev-requirements
* update test-requirements
* update requirements
* fix StringIO to BytesIO in thumbnail
* fix seaserv.list_inner_pub_repos to seafile_api.get_inner_pub_repo_list
* fix seaserv.list_org_inner_pub_repos to seafile_api.list_org_inner_pub_repos
* add logger in seahub/utils/__init__.py
* fix sort cmp in seahub/views/__init__.py
* fix sort cmp in seahub/base/management/commands/export_file_access_log.py
* fix sort cmp in seahub/api2/endpoints/repo_trash.py
* fix sort cmp in seahub/api2/endpoints/shared_repos.py
* fix sort cmp in seahub/api2/endpoints/shared_folders.py
* fix sort cmp in seahub/wiki/views.py
* fix sort cmp in seahub/api2/endpoints/wiki_pages.py
* fix sort cmp in seahub/api2/endpoints/group_libraries.py
* fix sort cmp in seahub/base/models.py
* fix sort cmp in seahub/api2/endpoints/upload_links.py
* fix sort cmp in seahub/views/ajax.py
* fix sort cmp in seahub/api2/views.py
* fix sort cmp in seahub/views/wiki.py
* fix sort cmp in seahub/api2/endpoints/repos.py
* fix sort cmp in seahub/api2/endpoints/starred_items.py
* fix sort cmp in seahub/views/file.py
* fix sort cmp in seahub/api2/endpoints/dir.py
* fix sort cmp in seahub/api2/endpoints/share_links.py
* fix cmp to cmp_to_key in seahub/api2/endpoints/admin/device_trusted_ip.py
* fix cmp to cmp_to_key in tests/api/endpoints/admin/test_device_trusted_ip.py
* delete encode('utf-8') in seafile_api.list_dir_by_commit_and_path
* delete encode('utf-8') in is_file_starred
* delete encode('utf-8') in seafile_api.list_dir_by_path
* delete path.encode('utf-8') in seahub/views/file.py
* fix os.write to add encode('utf-8')
* add encode('utf-8') for hashlib
* add encode('utf-8') for hmac
* fix with open(file, 'wb') for binary file
* fix encode and decode in seahub/utils/hasher.py
* fix next in thirdpart/shibboleth/views.py
* fix next in seahub/profile/views.py
* fix next in seahub/notifications/views.py
* fix next in seahub/institutions/views.py
* fix next in seahub/options/views.py
* fix next in seahub/share/views.py
* fix next in seahub/avatar/views.py
* fix next in seahub/views/__init__.py
* fix next in seahub/group/views.py
* fix next in seahub/views/wiki.py
* fix next in seahub/views/sysadmin.py
* fix next in seahub/views/file.py
* fix string.lowercase to string.ascii_lowercase in test
* fix open file add 'rb' in test
* fix self.user.username in test
* add migrations in file_participants
* fix list_org_inner_pub_repos to list_org_inner_pub_repos_by_owner
* fix from seaserv import is_passwd_set to seafile_api.is_password_set
* fix assert bytes resp.content in test
* fix seafile_api.get_inner_pub_repo_list to seafile_api.list_inner_pub_repos_by_owner
* fix seafile_api.is_passwd_set to seafile_api.is_password_set
* fix AccountsApiTest assert length
* rewrite sort_devices cmp to operator.lt
* fix bytes + str in seahub/api2/views.py
* fix assert bytes resp.content in test
* fix hashlib encode in seahub/thirdpart/registration/models.py
* change app_label to base in SocialAuthUser
* fix base64 encode in seahub/base/database_storage/database_storage.py
* fix assert bytes resp.content
* remove path.decode in def mkstemp()
* remove path.decode in FpathToLinkTest
* remove str decode in FileTagTest
* remove mock_write_xls.assert_called_once() in SysUserAdminExportExcelTest
* fix urllib assert in FilesApiTest
* fix link fields in FileCommentsTest
* fix get_related_users_by_repo()
* fix assert list in GetRepoSharedUsersTest
* fix create user in AccountTest
* fix repeated key in dict seahub/api2/views.py
* add drone.yml
* update nginx conf in test
* update test conf in test
* update dist and push after test success
* update drone conf to dist and push
* fix assert in BeSharedReposTest
* fix seafile_api.list_org_inner_pub_repos_by_owner(org_id, username) to seafile_api.list_org_inner_pub_repos(org_id)
* fix seafile_api.list_inner_pub_repos_by_owner(username) to seafile_api.get_inner_pub_repo_list()
* update pyjwt requirement
* update dist branch in drone
* add SKIP in dist and push
* fix StringIO to BytesIO in seahub/avatar/models.py
* fix if org_id > 0 to if org_id and org_id > 0
* remove payment
* fix StringIO to BytesIO in seahub/base/database_storage/database_storage.py
* fix send_message to seafile_api.publish_event in seahub/drafts/utils.py
* fix send_message to seafile_api.publish_event in seahub/api2/views.py
* fix send_message to seafile_api.publish_event in seahub/api2/endpoints/repos.py
* fix send_message to seafile_api.publish_event in seahub/views/file.py
* fix send_message to seafile_api.publish_event in seahub/utils/__init__.py
* fix image_file.read encode in seahub/base/database_storage/database_storage.py
* fix DatabaseStorageTest
* remove .travis.yml
* drone branch include master
328 lines
12 KiB
Python
328 lines
12 KiB
Python
#coding: UTF-8
|
|
from django.core.cache import cache
|
|
import pytest
|
|
pytestmark = pytest.mark.django_db
|
|
|
|
from seahub.share.models import FileShare, UploadLinkShare
|
|
from seahub.test_utils import BaseTestCase
|
|
from tests.common.utils import randstring
|
|
|
|
|
|
class FileSharedLinkApiTest(BaseTestCase):
|
|
|
|
def setUp(self):
|
|
cache.clear()
|
|
from constance import config
|
|
self.config = config
|
|
|
|
self.curr_passwd_len = self.config.SHARE_LINK_PASSWORD_MIN_LENGTH
|
|
self.config.SHARE_LINK_PASSWORD_MIN_LENGTH = 3
|
|
|
|
def tearDown(self):
|
|
self.remove_repo()
|
|
self.config.SHARE_LINK_PASSWORD_MIN_LENGTH = self.curr_passwd_len
|
|
|
|
def test_create_file_shared_link_with_invalid_path(self):
|
|
self.login_as(self.user)
|
|
|
|
resp = self.client.put(
|
|
'/api2/repos/%s/file/shared-link/' % (self.repo.id),
|
|
"ps=%s&type=f" % (self.file),
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
self.assertEqual(400, resp.status_code)
|
|
|
|
resp = self.client.put(
|
|
'/api2/repos/%s/file/shared-link/' % (self.repo.id),
|
|
"type=f",
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
self.assertEqual(400, resp.status_code)
|
|
|
|
resp = self.client.put(
|
|
'/api2/repos/%s/file/shared-link/' % (self.repo.id),
|
|
"p=%s&type=f" % randstring(6),
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
self.assertEqual(400, resp.status_code)
|
|
|
|
def test_can_create_file_download_link(self):
|
|
self.login_as(self.user)
|
|
|
|
# create file download share link
|
|
resp = self.client.put(
|
|
'/api2/repos/%s/file/shared-link/' % (self.repo.id),
|
|
"p=%s&type=f" % (self.file),
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
self.assertEqual(201, resp.status_code)
|
|
self.assertRegex(resp._headers['location'][1],
|
|
r'http(.*)/f/(\w{10,100})/')
|
|
|
|
token = resp._headers['location'][1].split('/')[-2]
|
|
self.assertIsNotNone(FileShare.objects.get(token=token))
|
|
|
|
def test_can_create_file_download_link_with_exipre(self):
|
|
self.login_as(self.user)
|
|
|
|
# create file download share link with expire
|
|
resp = self.client.put(
|
|
'/api2/repos/%s/file/shared-link/' % (self.repo.id),
|
|
"p=%s&type=f&expire=5" % (self.file),
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
self.assertEqual(201, resp.status_code)
|
|
self.assertRegex(resp._headers['location'][1],
|
|
r'http(.*)/f/(\w{10,100})/')
|
|
|
|
token = resp._headers['location'][1].split('/')[-2]
|
|
fileshare = FileShare.objects.get(token=token)
|
|
self.assertIsNotNone(fileshare.expire_date)
|
|
|
|
def test_can_create_file_download_link_with_password(self):
|
|
self.login_as(self.user)
|
|
|
|
# create file download share link with password
|
|
resp = self.client.put(
|
|
'/api2/repos/%s/file/shared-link/' % (self.repo.id),
|
|
"p=%s&type=f&password=123" % (self.file),
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
self.assertEqual(201, resp.status_code)
|
|
self.assertRegex(resp._headers['location'][1],
|
|
r'http(.*)/f/(\w{10,100})/')
|
|
|
|
token = resp._headers['location'][1].split('/')[-2]
|
|
fileshare = FileShare.objects.get(token=token)
|
|
self.assertIsNotNone(fileshare.password)
|
|
|
|
def test_can_create_file_download_link_with_password_exipre(self):
|
|
self.login_as(self.user)
|
|
|
|
# create file download share link with password and expire
|
|
resp = self.client.put(
|
|
'/api2/repos/%s/file/shared-link/' % (self.repo.id),
|
|
"p=%s&type=f&password=123&expire=5" % (self.file),
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
self.assertEqual(201, resp.status_code)
|
|
self.assertRegex(resp._headers['location'][1],
|
|
r'http(.*)/f/(\w{10,100})/')
|
|
|
|
token = resp._headers['location'][1].split('/')[-2]
|
|
fileshare = FileShare.objects.get(token=token)
|
|
self.assertIsNotNone(fileshare.expire_date)
|
|
self.assertIsNotNone(fileshare.password)
|
|
|
|
def test_can_create_dir_download_link(self):
|
|
self.login_as(self.user)
|
|
|
|
# create dir download share link
|
|
resp = self.client.put(
|
|
'/api2/repos/%s/file/shared-link/' % (self.repo.id),
|
|
"p=%s&type=d" % (self.folder),
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
self.assertEqual(201, resp.status_code)
|
|
self.dir_link_location = resp._headers['location'][1]
|
|
self.assertRegex(self.dir_link_location,
|
|
r'http(.*)/d/(\w{10,100})/')
|
|
|
|
token = resp._headers['location'][1].split('/')[-2]
|
|
self.assertIsNotNone(FileShare.objects.get(token=token))
|
|
|
|
def test_can_create_dir_download_link_with_exipre(self):
|
|
self.login_as(self.user)
|
|
|
|
# create dir download share link with expire
|
|
resp = self.client.put(
|
|
'/api2/repos/%s/file/shared-link/' % (self.repo.id),
|
|
"p=%s&type=d&expire=5" % (self.folder),
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
self.assertEqual(201, resp.status_code)
|
|
self.dir_link_location = resp._headers['location'][1]
|
|
self.assertRegex(self.dir_link_location,
|
|
r'http(.*)/d/(\w{10,100})/')
|
|
|
|
token = resp._headers['location'][1].split('/')[-2]
|
|
fileshare = FileShare.objects.get(token=token)
|
|
self.assertIsNotNone(fileshare.expire_date)
|
|
|
|
def test_can_create_dir_download_link_with_password(self):
|
|
self.login_as(self.user)
|
|
|
|
# create dir download share link with password
|
|
resp = self.client.put(
|
|
'/api2/repos/%s/file/shared-link/' % (self.repo.id),
|
|
"p=%s&type=d&password=123" % (self.folder),
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
self.assertEqual(201, resp.status_code)
|
|
self.dir_link_location = resp._headers['location'][1]
|
|
self.assertRegex(self.dir_link_location,
|
|
r'http(.*)/d/(\w{10,100})/')
|
|
|
|
token = resp._headers['location'][1].split('/')[-2]
|
|
fileshare = FileShare.objects.get(token=token)
|
|
self.assertIsNotNone(fileshare.password)
|
|
|
|
def test_can_create_dir_download_link_with_password_exipre(self):
|
|
self.login_as(self.user)
|
|
|
|
# create dir download share link with password and expire
|
|
resp = self.client.put(
|
|
'/api2/repos/%s/file/shared-link/' % (self.repo.id),
|
|
"p=%s&type=d&password=123&expire=5" % (self.folder),
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
self.assertEqual(201, resp.status_code)
|
|
self.dir_link_location = resp._headers['location'][1]
|
|
self.assertRegex(self.dir_link_location,
|
|
r'http(.*)/d/(\w{10,100})/')
|
|
|
|
token = resp._headers['location'][1].split('/')[-2]
|
|
fileshare = FileShare.objects.get(token=token)
|
|
self.assertIsNotNone(fileshare.expire_date)
|
|
self.assertIsNotNone(fileshare.password)
|
|
|
|
def test_can_create_dir_upload_link(self):
|
|
self.login_as(self.user)
|
|
|
|
# create dir download share link
|
|
resp = self.client.put(
|
|
'/api2/repos/%s/file/shared-link/' % (self.repo.id),
|
|
"p=%s&type=d&share_type=upload" % (self.folder),
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
self.assertEqual(201, resp.status_code)
|
|
self.dir_link_location = resp._headers['location'][1]
|
|
self.assertRegex(self.dir_link_location,
|
|
r'http(.*)/u/d/(\w{10,100})/')
|
|
|
|
token = resp._headers['location'][1].split('/')[-2]
|
|
self.assertIsNotNone(UploadLinkShare.objects.get(token=token))
|
|
|
|
def test_can_create_dir_upload_link_with_password(self):
|
|
self.login_as(self.user)
|
|
|
|
# create dir download share link with password
|
|
resp = self.client.put(
|
|
'/api2/repos/%s/file/shared-link/' % (self.repo.id),
|
|
"p=%s&type=d&share_type=upload&password=123" % (self.folder),
|
|
'application/x-www-form-urlencoded',
|
|
)
|
|
self.assertEqual(201, resp.status_code)
|
|
self.dir_link_location = resp._headers['location'][1]
|
|
self.assertRegex(self.dir_link_location,
|
|
r'http(.*)/u/d/(\w{10,100})/')
|
|
|
|
token = resp._headers['location'][1].split('/')[-2]
|
|
uls = UploadLinkShare.objects.get(token=token)
|
|
self.assertIsNotNone(uls.password)
|
|
|
|
class SharedFileDetailApiTest(BaseTestCase):
|
|
|
|
def _add_file_shared_link_with_password(self):
|
|
password = randstring(6)
|
|
uls = FileShare.objects.create_file_link(self.user.username,
|
|
self.repo.id, self.file,
|
|
password)
|
|
|
|
return (uls.token, password)
|
|
|
|
def tearDown(self):
|
|
self.remove_repo()
|
|
|
|
def test_get_file_share_detail_with_password(self):
|
|
self.login_as(self.user)
|
|
|
|
token, password = self._add_file_shared_link_with_password()
|
|
|
|
url = '/api2/f/%s/detail/' % (token)
|
|
resp = self.client.get(url + '?password=' + password)
|
|
self.assertEqual(200, resp.status_code)
|
|
self.assertIsNotNone(resp)
|
|
|
|
def test_get_file_share_detail_with_invalid_password(self):
|
|
self.login_as(self.user)
|
|
|
|
token, password = self._add_file_shared_link_with_password()
|
|
|
|
url = '/api2/f/%s/detail/' % (token)
|
|
resp = self.client.get(url + '?password=' + randstring(5))
|
|
self.assertEqual(403, resp.status_code)
|
|
|
|
resp = self.client.get('/api2/f/%s/detail/' % (token))
|
|
self.assertEqual(403, resp.status_code)
|
|
|
|
class SharedDirApiTest(BaseTestCase):
|
|
|
|
def tearDown(self):
|
|
self.remove_repo()
|
|
|
|
def _add_dir_download_link(self):
|
|
ls = FileShare.objects.create_dir_link(self.user.username,
|
|
self.repo.id, self.folder)
|
|
|
|
self.create_folder(repo_id=self.repo.id,
|
|
parent_dir=self.folder,
|
|
dirname='sub-folder',
|
|
username='test@test.com')
|
|
|
|
self.create_file(repo_id=self.repo.id,
|
|
parent_dir=self.folder,
|
|
filename='sub-test.txt',
|
|
username='test@test.com')
|
|
|
|
return ls.token
|
|
|
|
def test_can_get_direntry_in_dir_download_link(self):
|
|
self.login_as(self.user)
|
|
|
|
token = self._add_dir_download_link()
|
|
|
|
# get direntry in dir download share link
|
|
resp = self.client.get(
|
|
'/api2/d/%s/dir/' % (token),
|
|
)
|
|
self.assertEqual(200, resp.status_code)
|
|
self.assertIsNotNone(resp)
|
|
|
|
class SharedLinksApiTest(BaseTestCase):
|
|
|
|
def tearDown(self):
|
|
self.remove_repo()
|
|
|
|
def _add_file_shared_link(self):
|
|
ls = FileShare.objects.create_dir_link(self.user.username,
|
|
self.repo.id, self.folder)
|
|
|
|
return ls.token
|
|
|
|
def _add_upload_shared_link(self):
|
|
uls = UploadLinkShare.objects.create_upload_link_share(
|
|
self.user.username, self.repo.id, self.folder)
|
|
|
|
return uls.token
|
|
|
|
def test_can_delete_file_shared_link(self):
|
|
self.login_as(self.user)
|
|
|
|
token = self._add_file_shared_link()
|
|
|
|
resp = self.client.get(
|
|
'/api2/shared-links/?t=%s' % (token),
|
|
)
|
|
self.assertEqual(200, resp.status_code)
|
|
|
|
def test_can_delete_upload_shared_link(self):
|
|
self.login_as(self.user)
|
|
|
|
token = self._add_upload_shared_link()
|
|
|
|
resp = self.client.get(
|
|
'/api2/shared-links/?t=%s' % (token),
|
|
)
|
|
self.assertEqual(200, resp.status_code)
|