1
0
mirror of https://github.com/haiwen/seahub.git synced 2025-09-02 15:38:15 +00:00

admin api role check (#4353)

* admin api role check

* add check to new tabs and tests

* fix work-weixin virus scan check
This commit is contained in:
Leo
2019-12-16 18:31:29 +08:00
committed by lian
parent 44459bb36b
commit 7df1192cbf
84 changed files with 1089 additions and 142 deletions

View File

@@ -13,6 +13,25 @@ class FileOperationsInfoText(BaseTestCase):
def setUp(self):
self.login_as(self.admin)
@patch("seahub.api2.endpoints.admin.statistics.EVENTS_ENABLED")
@patch("seahub.api2.endpoints.admin.statistics.is_pro_version")
@patch("seahub.api2.endpoints.admin.statistics.get_file_ops_stats_by_day")
def test_admin_permission_denied(self, mock_get_file_audit_stats_by_day, mock_is_pro, mock_events_enabled):
mock_get_file_audit_stats_by_day.return_value = [
(datetime.datetime(2017, 6, 2, 4, 2), 'Added', 2),
(datetime.datetime(2017, 6, 2, 4, 2), 'Deleted', 2),
(datetime.datetime(2017, 6, 2, 4, 2), 'Visited', 2),
(datetime.datetime(2017, 6, 2, 4, 2), 'Modified', 2),
]
mock_is_pro.return_value = True
mock_events_enabled = True
url = reverse('api-v2.1-admin-statistics-file-operations')
url += "?start=2017-06-01 07:00:00&end=2017-06-03 07:00:00"
self.logout()
self.login_as(self.admin_cannot_view_statistic)
resp = self.client.get(url)
self.assertEqual(403, resp.status_code)
@patch("seahub.api2.endpoints.admin.statistics.EVENTS_ENABLED")
@patch("seahub.api2.endpoints.admin.statistics.is_pro_version")
@patch("seahub.api2.endpoints.admin.statistics.get_file_ops_stats_by_day")
@@ -92,3 +111,97 @@ class FileOperationsInfoText(BaseTestCase):
assert json_resp[-1]['datetime'] == '2018-08-23T00:00:00+00:00'
assert json_resp[-1]['web-file-download'] == 13
assert json_resp[-1]['sync-file-download'] == 131793
class TotalStorageTest(BaseTestCase):
@patch("seahub.api2.endpoints.admin.statistics.EVENTS_ENABLED")
@patch("seahub.api2.endpoints.admin.statistics.is_pro_version")
@patch("seahub.api2.endpoints.admin.statistics.get_file_ops_stats_by_day")
def test_admin_permission_denied(self, mock_get_file_audit_stats_by_day, mock_is_pro, mock_events_enabled):
mock_get_file_audit_stats_by_day.return_value = [
(datetime.datetime(2017, 6, 2, 4, 2), 'Added', 2),
(datetime.datetime(2017, 6, 2, 4, 2), 'Deleted', 2),
(datetime.datetime(2017, 6, 2, 4, 2), 'Visited', 2),
(datetime.datetime(2017, 6, 2, 4, 2), 'Modified', 2),
]
mock_is_pro.return_value = True
mock_events_enabled = True
url = reverse('api-v2.1-admin-statistics-total-storage')
url += "?start=2017-06-01 07:00:00&end=2017-06-03 07:00:00"
self.login_as(self.admin_cannot_view_statistic)
resp = self.client.get(url)
self.assertEqual(403, resp.status_code)
class ActiveUsersTest(BaseTestCase):
@patch("seahub.api2.endpoints.admin.statistics.EVENTS_ENABLED")
@patch("seahub.api2.endpoints.admin.statistics.is_pro_version")
@patch("seahub.api2.endpoints.admin.statistics.get_file_ops_stats_by_day")
def test_admin_permission_denied(self, mock_get_file_audit_stats_by_day, mock_is_pro, mock_events_enabled):
mock_get_file_audit_stats_by_day.return_value = [
(datetime.datetime(2017, 6, 2, 4, 2), 'Added', 2),
(datetime.datetime(2017, 6, 2, 4, 2), 'Deleted', 2),
(datetime.datetime(2017, 6, 2, 4, 2), 'Visited', 2),
(datetime.datetime(2017, 6, 2, 4, 2), 'Modified', 2),
]
mock_is_pro.return_value = True
mock_events_enabled = True
url = reverse('api-v2.1-admin-statistics-active-users')
url += "?start=2017-06-01 07:00:00&end=2017-06-03 07:00:00"
self.login_as(self.admin_cannot_view_statistic)
resp = self.client.get(url)
self.assertEqual(403, resp.status_code)
class SystemTrafficTest(BaseTestCase):
@patch("seahub.api2.endpoints.admin.statistics.EVENTS_ENABLED")
@patch("seahub.api2.endpoints.admin.statistics.is_pro_version")
@patch("seahub.api2.endpoints.admin.statistics.get_file_ops_stats_by_day")
def test_admin_permission_denied(self, mock_get_file_audit_stats_by_day, mock_is_pro, mock_events_enabled):
mock_get_file_audit_stats_by_day.return_value = [
(datetime.datetime(2017, 6, 2, 4, 2), 'Added', 2),
(datetime.datetime(2017, 6, 2, 4, 2), 'Deleted', 2),
(datetime.datetime(2017, 6, 2, 4, 2), 'Visited', 2),
(datetime.datetime(2017, 6, 2, 4, 2), 'Modified', 2),
]
mock_is_pro.return_value = True
mock_events_enabled = True
url = reverse('api-v2.1-admin-statistics-system-traffic')
url += "?start=2017-06-01 07:00:00&end=2017-06-03 07:00:00"
self.login_as(self.admin_cannot_view_statistic)
resp = self.client.get(url)
self.assertEqual(403, resp.status_code)
class SystemUserTrafficTest(BaseTestCase):
def test_admin_permission_denied(self):
self.login_as(self.admin_cannot_view_statistic)
url = reverse('api-v2.1-admin-statistics-system-user-traffic')
resp = self.client.get(url)
self.assertEqual(403, resp.status_code)
class SystemOrgTrafficTest(BaseTestCase):
def test_admin_permission_denied(self):
self.login_as(self.admin_cannot_view_statistic)
url = reverse('api-v2.1-admin-statistics-system-org-traffic')
resp = self.client.get(url)
self.assertEqual(403, resp.status_code)
class SystemUserTrafficExcelTest(BaseTestCase):
def test_admin_permission_denied(self):
self.login_as(self.admin_cannot_view_statistic)
url = reverse('api-v2.1-admin-statistics-system-user-traffic-excel')
resp = self.client.get(url)
self.assertEqual(403, resp.status_code)
class SystemUserStorageExcelTest(BaseTestCase):
def test_admin_permission_denied(self):
self.login_as(self.admin_cannot_view_statistic)
url = reverse('api-v2.1-admin-statistics-system-user-storage-excel')
resp = self.client.get(url)
self.assertEqual(403, resp.status_code)