Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
E
edx-platform
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
edx
edx-platform
Commits
bdc64a7c
Commit
bdc64a7c
authored
Dec 02, 2014
by
Brandon DeRosier
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Moved has_course_access from CMS to student.auth (common)
parent
aac3cc25
Show whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
41 additions
and
38 deletions
+41
-38
cms/djangoapps/contentstore/tests/test_clone_course.py
+1
-1
cms/djangoapps/contentstore/tests/test_permissions.py
+3
-4
cms/djangoapps/contentstore/views/access.py
+1
-21
cms/djangoapps/contentstore/views/assets.py
+1
-1
cms/djangoapps/contentstore/views/checklist.py
+1
-1
cms/djangoapps/contentstore/views/component.py
+1
-1
cms/djangoapps/contentstore/views/course.py
+1
-1
cms/djangoapps/contentstore/views/export_git.py
+1
-1
cms/djangoapps/contentstore/views/import_export.py
+1
-1
cms/djangoapps/contentstore/views/item.py
+1
-1
cms/djangoapps/contentstore/views/tabs.py
+1
-1
cms/djangoapps/contentstore/views/tests/test_course_index.py
+1
-1
cms/djangoapps/contentstore/views/transcripts_ajax.py
+1
-1
cms/djangoapps/contentstore/views/user.py
+1
-1
common/djangoapps/student/auth.py
+25
-1
No files found.
cms/djangoapps/contentstore/tests/test_clone_course.py
View file @
bdc64a7c
...
...
@@ -6,7 +6,7 @@ from opaque_keys.edx.locator import CourseLocator
from
xmodule.modulestore
import
ModuleStoreEnum
,
EdxJSONEncoder
from
contentstore.tests.utils
import
CourseTestCase
from
contentstore.tasks
import
rerun_course
from
contentstore.views.access
import
has_course_access
from
student.auth
import
has_course_access
from
course_action_state.models
import
CourseRerunState
from
course_action_state.managers
import
CourseRerunUIStateManager
from
mock
import
patch
,
Mock
...
...
cms/djangoapps/contentstore/tests/test_permissions.py
View file @
bdc64a7c
...
...
@@ -10,7 +10,6 @@ from contentstore.tests.utils import AjaxEnabledTestClient
from
opaque_keys.edx.locations
import
SlashSeparatedCourseKey
from
contentstore.utils
import
reverse_url
,
reverse_course_url
from
student.roles
import
CourseInstructorRole
,
CourseStaffRole
,
OrgStaffRole
,
OrgInstructorRole
from
contentstore.views.access
import
has_course_access
from
student
import
auth
...
...
@@ -93,7 +92,7 @@ class TestCourseAccess(ModuleStoreTestCase):
user
=
users
.
pop
()
group
.
add_users
(
user
)
user_by_role
[
role
]
.
append
(
user
)
self
.
assertTrue
(
has_course_access
(
user
,
self
.
course_key
),
"{} does not have access"
.
format
(
user
))
self
.
assertTrue
(
auth
.
has_course_access
(
user
,
self
.
course_key
),
"{} does not have access"
.
format
(
user
))
course_team_url
=
reverse_course_url
(
'course_team_handler'
,
self
.
course_key
)
response
=
self
.
client
.
get_html
(
course_team_url
)
...
...
@@ -126,9 +125,9 @@ class TestCourseAccess(ModuleStoreTestCase):
if
hasattr
(
user
,
'_roles'
):
del
user
.
_roles
self
.
assertTrue
(
has_course_access
(
user
,
copy_course_key
),
"{} no copy access"
.
format
(
user
))
self
.
assertTrue
(
auth
.
has_course_access
(
user
,
copy_course_key
),
"{} no copy access"
.
format
(
user
))
if
(
role
is
OrgStaffRole
)
or
(
role
is
OrgInstructorRole
):
auth
.
remove_users
(
self
.
user
,
role
(
self
.
course_key
.
org
),
user
)
else
:
auth
.
remove_users
(
self
.
user
,
role
(
self
.
course_key
),
user
)
self
.
assertFalse
(
has_course_access
(
user
,
self
.
course_key
),
"{} remove didn't work"
.
format
(
user
))
self
.
assertFalse
(
auth
.
has_course_access
(
user
,
self
.
course_key
),
"{} remove didn't work"
.
format
(
user
))
cms/djangoapps/contentstore/views/access.py
View file @
bdc64a7c
""" Helper methods for determining user access permissions in Studio """
from
student.roles
import
Course
StaffRole
,
GlobalStaff
,
CourseInstructorRole
,
OrgStaffRole
,
Org
InstructorRole
from
student.roles
import
CourseInstructorRole
from
student
import
auth
def
has_course_access
(
user
,
course_key
,
role
=
CourseStaffRole
):
"""
Return True if user allowed to access this course_id
Note that the CMS permissions model is with respect to courses
There is a super-admin permissions if user.is_staff is set
Also, since we're unifying the user database between LMS and CAS,
I'm presuming that the course instructor (formally known as admin)
will not be in both INSTRUCTOR and STAFF groups, so we have to cascade our
queries here as INSTRUCTOR has all the rights that STAFF do
"""
if
GlobalStaff
()
.
has_user
(
user
):
return
True
if
OrgInstructorRole
(
org
=
course_key
.
org
)
.
has_user
(
user
):
return
True
if
OrgStaffRole
(
org
=
course_key
.
org
)
.
has_user
(
user
):
return
True
# temporary to ensure we give universal access given a course until we impl branch specific perms
return
auth
.
has_access
(
user
,
role
(
course_key
.
for_branch
(
None
)))
def
get_user_role
(
user
,
course_id
):
"""
What type of access: staff or instructor does this user have in Studio?
...
...
cms/djangoapps/contentstore/views/assets.py
View file @
bdc64a7c
...
...
@@ -26,7 +26,7 @@ from util.json_request import JsonResponse
from
django.http
import
HttpResponseNotFound
from
django.utils.translation
import
ugettext
as
_
from
pymongo
import
ASCENDING
,
DESCENDING
from
.access
import
has_course_access
from
student.auth
import
has_course_access
from
xmodule.modulestore.exceptions
import
ItemNotFoundError
__all__
=
[
'assets_handler'
]
...
...
cms/djangoapps/contentstore/views/checklist.py
View file @
bdc64a7c
...
...
@@ -13,7 +13,7 @@ from opaque_keys.edx.keys import CourseKey
from
xmodule.modulestore.django
import
modulestore
from
contentstore.utils
import
reverse_course_url
from
.access
import
has_course_access
from
student.auth
import
has_course_access
from
xmodule.course_module
import
CourseDescriptor
from
django.utils.translation
import
ugettext
...
...
cms/djangoapps/contentstore/views/component.py
View file @
bdc64a7c
...
...
@@ -25,7 +25,7 @@ from contentstore.views.item import create_xblock_info
from
opaque_keys.edx.keys
import
UsageKey
from
.access
import
has_course_access
from
student.auth
import
has_course_access
from
django.utils.translation
import
ugettext
as
_
from
models.settings.course_grading
import
CourseGradingModel
...
...
cms/djangoapps/contentstore/views/course.py
View file @
bdc64a7c
...
...
@@ -47,7 +47,7 @@ from models.settings.course_grading import CourseGradingModel
from
models.settings.course_metadata
import
CourseMetadata
from
util.json_request
import
expect_json
from
util.string_utils
import
_has_non_ascii_characters
from
.access
import
has_course_access
from
student.auth
import
has_course_access
from
.component
import
(
OPEN_ENDED_COMPONENT_TYPES
,
NOTE_COMPONENT_TYPES
,
...
...
cms/djangoapps/contentstore/views/export_git.py
View file @
bdc64a7c
...
...
@@ -10,7 +10,7 @@ from django.core.exceptions import PermissionDenied
from
django_future.csrf
import
ensure_csrf_cookie
from
django.utils.translation
import
ugettext
as
_
from
.access
import
has_course_access
from
student.auth
import
has_course_access
import
contentstore.git_export_utils
as
git_export_utils
from
edxmako.shortcuts
import
render_to_response
from
xmodule.modulestore.django
import
modulestore
...
...
cms/djangoapps/contentstore/views/import_export.py
View file @
bdc64a7c
...
...
@@ -28,7 +28,7 @@ from opaque_keys.edx.keys import CourseKey
from
xmodule.modulestore.xml_importer
import
import_from_xml
from
xmodule.modulestore.xml_exporter
import
export_to_xml
from
.access
import
has_course_access
from
student.auth
import
has_course_access
from
extract_tar
import
safetar_extractall
from
util.json_request
import
JsonResponse
...
...
cms/djangoapps/contentstore/views/item.py
View file @
bdc64a7c
...
...
@@ -37,7 +37,7 @@ from util.date_utils import get_default_time_display
from
util.json_request
import
expect_json
,
JsonResponse
from
.access
import
has_course_access
from
student.auth
import
has_course_access
from
contentstore.utils
import
find_release_date_source
,
find_staff_lock_source
,
is_currently_visible_to_students
,
\
ancestor_has_staff_lock
from
contentstore.views.helpers
import
is_unit
,
xblock_studio_url
,
xblock_primary_child_category
,
\
...
...
cms/djangoapps/contentstore/views/tabs.py
View file @
bdc64a7c
"""
Views related to course tabs
"""
from
access
import
has_course_access
from
student.auth
import
has_course_access
from
util.json_request
import
expect_json
,
JsonResponse
from
django.http
import
HttpResponseNotFound
...
...
cms/djangoapps/contentstore/views/tests/test_course_index.py
View file @
bdc64a7c
...
...
@@ -7,7 +7,7 @@ import datetime
from
contentstore.tests.utils
import
CourseTestCase
from
contentstore.utils
import
reverse_course_url
,
add_instructor
from
contentstore.views.access
import
has_course_access
from
student.auth
import
has_course_access
from
contentstore.views.course
import
course_outline_initial_state
from
contentstore.views.item
import
create_xblock_info
,
VisibilityState
from
course_action_state.models
import
CourseRerunState
...
...
cms/djangoapps/contentstore/views/transcripts_ajax.py
View file @
bdc64a7c
...
...
@@ -38,7 +38,7 @@ from xmodule.video_module.transcripts_utils import (
TranscriptsRequestValidationException
)
from
.access
import
has_course_access
from
student.auth
import
has_course_access
__all__
=
[
'upload_transcripts'
,
...
...
cms/djangoapps/contentstore/views/user.py
View file @
bdc64a7c
...
...
@@ -13,7 +13,7 @@ from util.json_request import JsonResponse, expect_json
from
student.roles
import
CourseInstructorRole
,
CourseStaffRole
from
course_creators.views
import
user_requested_access
from
.access
import
has_course_access
from
student.auth
import
has_course_access
from
student.models
import
CourseEnrollment
from
django.http
import
HttpResponseNotFound
...
...
common/djangoapps/student/auth.py
View file @
bdc64a7c
...
...
@@ -8,7 +8,7 @@ from django.core.exceptions import PermissionDenied
from
django.conf
import
settings
from
student.roles
import
GlobalStaff
,
CourseCreatorRole
,
CourseStaffRole
,
CourseInstructorRole
,
CourseRole
,
\
CourseBetaTesterRole
CourseBetaTesterRole
,
OrgInstructorRole
,
OrgStaffRole
def
has_access
(
user
,
role
):
...
...
@@ -40,6 +40,30 @@ def has_access(user, role):
return
False
def
has_course_access
(
user
,
course_key
,
role
=
CourseStaffRole
):
"""
Return True if user allowed to access this course_id
Note that the CMS permissions model is with respect to courses
There is a super-admin permissions if user.is_staff is set
Also, since we're unifying the user database between LMS and CAS,
I'm presuming that the course instructor (formally known as admin)
will not be in both INSTRUCTOR and STAFF groups, so we have to cascade our
queries here as INSTRUCTOR has all the rights that STAFF do.
:param user:
:param course_key: A course key
:param role: an AccessRole
"""
if
GlobalStaff
()
.
has_user
(
user
):
return
True
if
OrgInstructorRole
(
org
=
course_key
.
org
)
.
has_user
(
user
):
return
True
if
OrgStaffRole
(
org
=
course_key
.
org
)
.
has_user
(
user
):
return
True
# temporary to ensure we give universal access given a course until we impl branch specific perms
return
has_access
(
user
,
role
(
course_key
.
for_branch
(
None
)))
def
add_users
(
caller
,
role
,
*
users
):
"""
The caller requests adding the given users to the role. Checks that the caller
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment