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
be1b0638
Commit
be1b0638
authored
Aug 15, 2012
by
Calen Pennington
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #417 from MITx/kimth/sjsu
Kimth/sjsu
parents
13b9e58f
58932bb2
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
37 additions
and
13 deletions
+37
-13
common/djangoapps/xmodule_modifiers.py
+11
-0
lms/djangoapps/courseware/module_render.py
+20
-8
lms/djangoapps/courseware/views.py
+6
-5
No files found.
common/djangoapps/xmodule_modifiers.py
View file @
be1b0638
...
...
@@ -34,6 +34,17 @@ def wrap_xmodule(get_html, module, template):
return
_get_html
def
replace_course_urls
(
get_html
,
course_id
,
module
):
"""
Updates the supplied module with a new get_html function that wraps
the old get_html function and substitutes urls of the form /course/...
with urls that are /courses/<course_id>/...
"""
@wraps
(
get_html
)
def
_get_html
():
return
replace_urls
(
get_html
(),
staticfiles_prefix
=
'/courses/'
+
course_id
,
replace_prefix
=
'/course/'
)
return
_get_html
def
replace_static_urls
(
get_html
,
prefix
,
module
):
"""
Updates the supplied module with a new get_html function that wraps
...
...
lms/djangoapps/courseware/module_render.py
View file @
be1b0638
...
...
@@ -19,7 +19,7 @@ from xmodule.exceptions import NotFoundError
from
xmodule.modulestore
import
Location
from
xmodule.modulestore.django
import
modulestore
from
xmodule.x_module
import
ModuleSystem
from
xmodule_modifiers
import
replace_static_urls
,
add_histogram
,
wrap_xmodule
from
xmodule_modifiers
import
replace_
course_urls
,
replace_
static_urls
,
add_histogram
,
wrap_xmodule
log
=
logging
.
getLogger
(
"mitx.courseware"
)
...
...
@@ -48,7 +48,7 @@ def make_track_function(request):
return
f
def
toc_for_course
(
user
,
request
,
course
,
active_chapter
,
active_section
):
def
toc_for_course
(
user
,
request
,
course
,
active_chapter
,
active_section
,
course_id
=
None
):
'''
Create a table of contents from the module store
...
...
@@ -71,7 +71,7 @@ def toc_for_course(user, request, course, active_chapter, active_section):
'''
student_module_cache
=
StudentModuleCache
.
cache_for_descriptor_descendents
(
user
,
course
,
depth
=
2
)
course
=
get_module
(
user
,
request
,
course
.
location
,
student_module_cache
)
course
=
get_module
(
user
,
request
,
course
.
location
,
student_module_cache
,
course_id
=
course_id
)
chapters
=
list
()
for
chapter
in
course
.
get_display_items
():
...
...
@@ -127,7 +127,7 @@ def get_section(course_module, chapter, section):
return
section_module
def
get_module
(
user
,
request
,
location
,
student_module_cache
,
position
=
None
):
def
get_module
(
user
,
request
,
location
,
student_module_cache
,
position
=
None
,
course_id
=
None
):
''' Get an instance of the xmodule class identified by location,
setting the state based on an existing StudentModule, or creating one if none
exists.
...
...
@@ -145,6 +145,14 @@ def get_module(user, request, location, student_module_cache, position=None):
'''
descriptor
=
modulestore
()
.
get_item
(
location
)
# NOTE:
# A 'course_id' is understood to be the triplet (org, course, run), for example
# (MITx, 6.002x, 2012_Spring).
# At the moment generic XModule does not contain enough information to replicate
# the triplet (it is missing 'run'), so we must pass down course_id
if
course_id
is
None
:
course_id
=
descriptor
.
location
.
course_id
# Will NOT produce (org, course, run) for non-CourseModule's
# Short circuit--if the user shouldn't have access, bail without doing any work
if
not
has_access
(
user
,
descriptor
,
'load'
):
return
None
...
...
@@ -167,7 +175,7 @@ def get_module(user, request, location, student_module_cache, position=None):
# Setup system context for module instance
ajax_url
=
reverse
(
'modx_dispatch'
,
kwargs
=
dict
(
course_id
=
descriptor
.
location
.
course_id
,
kwargs
=
dict
(
course_id
=
course_id
,
id
=
descriptor
.
location
.
url
(),
dispatch
=
''
),
)
...
...
@@ -175,7 +183,7 @@ def get_module(user, request, location, student_module_cache, position=None):
# Fully qualified callback URL for external queueing system
xqueue_callback_url
=
request
.
build_absolute_uri
(
'/'
)[:
-
1
]
# Trailing slash provided by reverse
xqueue_callback_url
+=
reverse
(
'xqueue_callback'
,
kwargs
=
dict
(
course_id
=
descriptor
.
location
.
course_id
,
kwargs
=
dict
(
course_id
=
course_id
,
userid
=
str
(
user
.
id
),
id
=
descriptor
.
location
.
url
(),
dispatch
=
'score_update'
),
...
...
@@ -195,7 +203,7 @@ def get_module(user, request, location, student_module_cache, position=None):
Delegate to get_module. It does an access check, so may return None
"""
return
get_module
(
user
,
request
,
location
,
student_module_cache
,
position
)
student_module_cache
,
position
,
course_id
=
course_id
)
# TODO (cpennington): When modules are shared between courses, the static
# prefix is going to have to be specific to the module, not the directory
...
...
@@ -225,6 +233,10 @@ def get_module(user, request, location, student_module_cache, position=None):
module
.
metadata
[
'data_dir'
],
module
)
# Allow URLs of the form '/course/' refer to the root of multicourse directory
# hierarchy of this course
module
.
get_html
=
replace_course_urls
(
module
.
get_html
,
course_id
,
module
)
if
settings
.
MITX_FEATURES
.
get
(
'DISPLAY_HISTOGRAMS_TO_STAFF'
):
if
has_access
(
user
,
module
,
'staff'
):
module
.
get_html
=
add_histogram
(
module
.
get_html
,
module
,
user
)
...
...
@@ -370,7 +382,7 @@ def modx_dispatch(request, dispatch=None, id=None, course_id=None):
p
[
inputfile_id
]
=
inputfile
student_module_cache
=
StudentModuleCache
.
cache_for_descriptor_descendents
(
request
.
user
,
modulestore
()
.
get_item
(
id
))
instance
=
get_module
(
request
.
user
,
request
,
id
,
student_module_cache
)
instance
=
get_module
(
request
.
user
,
request
,
id
,
student_module_cache
,
course_id
=
course_id
)
if
instance
is
None
:
# Either permissions just changed, or someone is trying to be clever
# and load something they shouldn't have access to.
...
...
lms/djangoapps/courseware/views.py
View file @
be1b0638
...
...
@@ -33,6 +33,7 @@ log = logging.getLogger("mitx.courseware")
template_imports
=
{
'urllib'
:
urllib
}
def
user_groups
(
user
):
"""
TODO (vshnayder): This is not used. When we have a new plan for groups, adjust appropriately.
...
...
@@ -68,7 +69,7 @@ def courses(request):
return
render_to_response
(
"courses.html"
,
{
'universities'
:
universities
})
def
render_accordion
(
request
,
course
,
chapter
,
section
):
def
render_accordion
(
request
,
course
,
chapter
,
section
,
course_id
=
None
):
''' Draws navigation bar. Takes current position in accordion as
parameter.
...
...
@@ -79,7 +80,7 @@ def render_accordion(request, course, chapter, section):
Returns the html string'''
# grab the table of contents
toc
=
toc_for_course
(
request
.
user
,
request
,
course
,
chapter
,
section
)
toc
=
toc_for_course
(
request
.
user
,
request
,
course
,
chapter
,
section
,
course_id
=
course_id
)
context
=
dict
([(
'toc'
,
toc
),
(
'course_id'
,
course
.
id
),
...
...
@@ -121,7 +122,7 @@ def index(request, course_id, chapter=None, section=None,
try
:
context
=
{
'csrf'
:
csrf
(
request
)[
'csrf_token'
],
'accordion'
:
render_accordion
(
request
,
course
,
chapter
,
section
),
'accordion'
:
render_accordion
(
request
,
course
,
chapter
,
section
,
course_id
=
course_id
),
'COURSE_TITLE'
:
course
.
title
,
'course'
:
course
,
'init'
:
''
,
...
...
@@ -138,7 +139,7 @@ def index(request, course_id, chapter=None, section=None,
section_descriptor
)
module
=
get_module
(
request
.
user
,
request
,
section_descriptor
.
location
,
student_module_cache
)
student_module_cache
,
course_id
=
course_id
)
if
module
is
None
:
# User is probably being clever and trying to access something
# they don't have access to.
...
...
@@ -278,7 +279,7 @@ def profile(request, course_id, student_id=None):
user_info
=
UserProfile
.
objects
.
get
(
user
=
student
)
student_module_cache
=
StudentModuleCache
.
cache_for_descriptor_descendents
(
request
.
user
,
course
)
course_module
=
get_module
(
request
.
user
,
request
,
course
.
location
,
student_module_cache
)
course_module
=
get_module
(
request
.
user
,
request
,
course
.
location
,
student_module_cache
,
course_id
=
course_id
)
courseware_summary
=
grades
.
progress_summary
(
student
,
course_module
,
course
.
grader
,
student_module_cache
)
grade_summary
=
grades
.
grade
(
request
.
user
,
request
,
course
,
student_module_cache
)
...
...
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