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
4cbdf90d
Commit
4cbdf90d
authored
12 years ago
by
ichuang
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
cleaned up access.py - now has _has_instructor_access_to_loation
parent
d6430570
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
45 additions
and
17 deletions
+45
-17
lms/djangoapps/courseware/access.py
+45
-17
No files found.
lms/djangoapps/courseware/access.py
View file @
4cbdf90d
...
@@ -153,7 +153,7 @@ def _has_access_course_desc(user, course, action):
...
@@ -153,7 +153,7 @@ def _has_access_course_desc(user, course, action):
'enroll'
:
can_enroll
,
'enroll'
:
can_enroll
,
'see_exists'
:
see_exists
,
'see_exists'
:
see_exists
,
'staff'
:
lambda
:
_has_staff_access_to_descriptor
(
user
,
course
),
'staff'
:
lambda
:
_has_staff_access_to_descriptor
(
user
,
course
),
'instructor'
:
lambda
:
_has_
staff_access_to_descriptor
(
user
,
course
,
require_instructor
=
Tru
e
),
'instructor'
:
lambda
:
_has_
instructor_access_to_descriptor
(
user
,
cours
e
),
}
}
return
_dispatch
(
checkers
,
action
,
user
,
course
)
return
_dispatch
(
checkers
,
action
,
user
,
course
)
...
@@ -314,6 +314,7 @@ def _course_staff_group_name(location):
...
@@ -314,6 +314,7 @@ def _course_staff_group_name(location):
"""
"""
return
'staff_
%
s'
%
Location
(
location
)
.
course
return
'staff_
%
s'
%
Location
(
location
)
.
course
def
_course_instructor_group_name
(
location
):
def
_course_instructor_group_name
(
location
):
"""
"""
Get the name of the instructor group for a location. Right now, that's instructor_COURSE.
Get the name of the instructor group for a location. Right now, that's instructor_COURSE.
...
@@ -323,6 +324,7 @@ def _course_instructor_group_name(location):
...
@@ -323,6 +324,7 @@ def _course_instructor_group_name(location):
"""
"""
return
'instructor_
%
s'
%
Location
(
location
)
.
course
return
'instructor_
%
s'
%
Location
(
location
)
.
course
def
_has_global_staff_access
(
user
):
def
_has_global_staff_access
(
user
):
if
user
.
is_staff
:
if
user
.
is_staff
:
debug
(
"Allow: user.is_staff"
)
debug
(
"Allow: user.is_staff"
)
...
@@ -332,19 +334,28 @@ def _has_global_staff_access(user):
...
@@ -332,19 +334,28 @@ def _has_global_staff_access(user):
return
False
return
False
def
_has_staff_access_to_location
(
user
,
location
,
require_instructor
=
False
):
def
_has_instructor_access_to_location
(
user
,
location
):
'''
return
_has_access_to_location
(
user
,
location
,
'instructor'
)
Returns True if the given user has staff access to a location. For now this
is equivalent to having staff access to the course location.course.
def
_has_staff_access_to_location
(
user
,
location
):
return
_has_access_to_location
(
user
,
location
,
'staff'
)
If require_instructor=True, then user must be in instructor_* group.
This means that user is in the staff_* group, or is an overall admin.
def
_has_access_to_location
(
user
,
location
,
access_level
):
'''
Returns True if the given user has access_level (= staff or
instructor) access to a location. For now this is equivalent to
having staff / instructor access to the course location.course.
This means that user is in the staff_* group or instructor_* group, or is an overall admin.
TODO (vshnayder): this needs to be changed to allow per-course_id permissions, not per-course
TODO (vshnayder): this needs to be changed to allow per-course_id permissions, not per-course
(e.g. staff in 2012 is different from 2013, but maybe some people always have access)
(e.g. staff in 2012 is different from 2013, but maybe some people always have access)
course is a string: the course field of the location being accessed.
course is a string: the course field of the location being accessed.
location = location
access_level = string, either "staff" or "instructor"
'''
'''
if
user
is
None
or
(
not
user
.
is_authenticated
()):
if
user
is
None
or
(
not
user
.
is_authenticated
()):
debug
(
"Deny: no user or anon user"
)
debug
(
"Deny: no user or anon user"
)
...
@@ -355,29 +366,46 @@ def _has_staff_access_to_location(user, location, require_instructor=False):
...
@@ -355,29 +366,46 @@ def _has_staff_access_to_location(user, location, require_instructor=False):
# If not global staff, is the user in the Auth group for this class?
# If not global staff, is the user in the Auth group for this class?
user_groups
=
[
g
.
name
for
g
in
user
.
groups
.
all
()]
user_groups
=
[
g
.
name
for
g
in
user
.
groups
.
all
()]
staff_group
=
_course_staff_group_name
(
location
)
if
not
require_instructor
:
if
access_level
==
'staff'
:
staff_group
=
_course_staff_group_name
(
location
)
if
staff_group
in
user_groups
:
if
staff_group
in
user_groups
:
debug
(
"Allow: user in group
%
s"
,
staff_group
)
debug
(
"Allow: user in group
%
s"
,
staff_group
)
return
True
return
True
instructor_group
=
_course_instructor_group_name
(
location
)
debug
(
"Deny: user not in group
%
s"
,
staff_group
)
if
instructor_group
in
user_groups
:
debug
(
"Allow: user in group
%
s"
,
instructor_group
)
if
access_level
==
'instructor'
or
access_level
==
'staff'
:
# instructors get staff privileges
return
True
instructor_group
=
_course_instructor_group_name
(
location
)
debug
(
"Deny: user not in group
%
s"
,
staff_group
)
if
instructor_group
in
user_groups
:
debug
(
"Allow: user in group
%
s"
,
instructor_group
)
return
True
debug
(
"Deny: user not in group
%
s"
,
instructor_group
)
else
:
log
.
debug
(
"Error in access._has_access_to_location access_level=
%
s unknown"
%
access_level
)
return
False
return
False
def
_has_staff_access_to_course_id
(
user
,
course_id
):
def
_has_staff_access_to_course_id
(
user
,
course_id
):
"""Helper method that takes a course_id instead of a course name"""
"""Helper method that takes a course_id instead of a course name"""
loc
=
CourseDescriptor
.
id_to_location
(
course_id
)
loc
=
CourseDescriptor
.
id_to_location
(
course_id
)
return
_has_staff_access_to_location
(
user
,
loc
)
return
_has_staff_access_to_location
(
user
,
loc
)
def
_has_staff_access_to_descriptor
(
user
,
descriptor
,
require_instructor
=
False
):
def
_has_instructor_access_to_descriptor
(
user
,
descriptor
):
"""Helper method that checks whether the user has staff access to
the course of the location.
descriptor: something that has a location attribute
"""
return
_has_instructor_access_to_location
(
user
,
descriptor
.
location
)
def
_has_staff_access_to_descriptor
(
user
,
descriptor
):
"""Helper method that checks whether the user has staff access to
"""Helper method that checks whether the user has staff access to
the course of the location.
the course of the location.
location: something that can be passed to Location
descriptor: something that has a location attribute
"""
"""
return
_has_staff_access_to_location
(
user
,
descriptor
.
location
,
require_instructor
=
require_instructor
)
return
_has_staff_access_to_location
(
user
,
descriptor
.
location
)
This diff is collapsed.
Click to expand it.
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