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
b98d85fd
Commit
b98d85fd
authored
May 14, 2015
by
Ned Batchelder
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #7943 from edx/ned/move-xmodule-modifiers
Move xmodule_modifiers.py to openedx/xblock
parents
25eb6942
05cd3316
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
36 additions
and
16 deletions
+36
-16
cms/djangoapps/contentstore/course_info_model.py
+1
-1
cms/djangoapps/contentstore/views/item.py
+1
-1
cms/djangoapps/contentstore/views/preview.py
+1
-1
lms/djangoapps/courseware/module_render.py
+1
-1
lms/djangoapps/courseware/tests/test_module_render.py
+2
-2
lms/djangoapps/instructor/views/instructor_dashboard.py
+1
-1
lms/djangoapps/mobile_api/course_info/views.py
+1
-1
openedx/core/lib/xblock_utils.py
+28
-8
No files found.
cms/djangoapps/contentstore/course_info_model.py
View file @
b98d85fd
...
...
@@ -22,7 +22,7 @@ from xmodule.modulestore.exceptions import ItemNotFoundError
from
xmodule.modulestore.django
import
modulestore
from
xmodule.html_module
import
CourseInfoModule
from
xmodule_modifier
s
import
get_course_update_items
from
openedx.core.lib.xblock_util
s
import
get_course_update_items
from
cms.djangoapps.contentstore.push_notification
import
enqueue_push_course_update
# # This should be in a class which inherits from XmlDescriptor
...
...
cms/djangoapps/contentstore/views/item.py
View file @
b98d85fd
...
...
@@ -11,7 +11,7 @@ import json
from
collections
import
OrderedDict
from
functools
import
partial
from
static_replace
import
replace_static_urls
from
xmodule_modifier
s
import
wrap_xblock
,
request_token
from
openedx.core.lib.xblock_util
s
import
wrap_xblock
,
request_token
import
dogstats_wrapper
as
dog_stats_api
from
django.conf
import
settings
...
...
cms/djangoapps/contentstore/views/preview.py
View file @
b98d85fd
...
...
@@ -9,7 +9,7 @@ from django.http import Http404, HttpResponseBadRequest
from
django.contrib.auth.decorators
import
login_required
from
edxmako.shortcuts
import
render_to_string
from
xmodule_modifier
s
import
replace_static_urls
,
wrap_xblock
,
wrap_fragment
,
request_token
from
openedx.core.lib.xblock_util
s
import
replace_static_urls
,
wrap_xblock
,
wrap_fragment
,
request_token
from
xmodule.x_module
import
PREVIEW_VIEWS
,
STUDENT_VIEW
,
AUTHOR_VIEW
from
xmodule.contentstore.django
import
contentstore
from
xmodule.error_module
import
ErrorDescriptor
...
...
lms/djangoapps/courseware/module_render.py
View file @
b98d85fd
...
...
@@ -57,7 +57,7 @@ from opaque_keys.edx.locations import SlashSeparatedCourseKey
from
xmodule.contentstore.django
import
contentstore
from
xmodule.modulestore.django
import
modulestore
,
ModuleI18nService
from
xmodule.modulestore.exceptions
import
ItemNotFoundError
from
xmodule_modifier
s
import
(
from
openedx.core.lib.xblock_util
s
import
(
replace_course_urls
,
replace_jump_to_id_urls
,
replace_static_urls
,
...
...
lms/djangoapps/courseware/tests/test_module_render.py
View file @
b98d85fd
...
...
@@ -1000,7 +1000,7 @@ class TestStaffDebugInfo(ModuleStoreTestCase):
self
.
user
,
self
.
descriptor
)
with
patch
(
'
xmodule_modifier
s.grade_histogram'
)
as
mock_grade_histogram
:
with
patch
(
'
openedx.core.lib.xblock_util
s.grade_histogram'
)
as
mock_grade_histogram
:
mock_grade_histogram
.
return_value
=
[]
module
=
render
.
get_module
(
self
.
user
,
...
...
@@ -1022,7 +1022,7 @@ class TestStaffDebugInfo(ModuleStoreTestCase):
max_grade
=
1
,
state
=
"{}"
,
)
with
patch
(
'
xmodule_modifier
s.grade_histogram'
)
as
mock_grade_histogram
:
with
patch
(
'
openedx.core.lib.xblock_util
s.grade_histogram'
)
as
mock_grade_histogram
:
mock_grade_histogram
.
return_value
=
[]
module
=
render
.
get_module
(
self
.
user
,
...
...
lms/djangoapps/instructor/views/instructor_dashboard.py
View file @
b98d85fd
...
...
@@ -23,7 +23,7 @@ from util.json_request import JsonResponse
from
mock
import
patch
from
lms.djangoapps.lms_xblock.runtime
import
quote_slashes
from
xmodule_modifier
s
import
wrap_xblock
from
openedx.core.lib.xblock_util
s
import
wrap_xblock
from
xmodule.html_module
import
HtmlDescriptor
from
xmodule.modulestore.django
import
modulestore
from
xblock.field_data
import
DictFieldData
...
...
lms/djangoapps/mobile_api/course_info/views.py
View file @
b98d85fd
...
...
@@ -7,7 +7,7 @@ from rest_framework.response import Response
from
courseware.courses
import
get_course_about_section
,
get_course_info_section_module
from
static_replace
import
make_static_urls_absolute
,
replace_static_urls
from
xmodule_modifier
s
import
get_course_update_items
from
openedx.core.lib.xblock_util
s
import
get_course_update_items
from
..utils
import
mobile_view
,
mobile_course_access
...
...
common/djangoapps/xmodule_modifier
s.py
→
openedx/core/lib/xblock_util
s.py
View file @
b98d85fd
...
...
@@ -45,13 +45,24 @@ def request_token(request):
This token will be the same for all calls to `request_token`
made on the same request object.
"""
# pylint: disable=protected-access
if
not
hasattr
(
request
,
'_xblock_token'
):
request
.
_xblock_token
=
uuid
.
uuid1
()
.
get_hex
()
return
request
.
_xblock_token
def
wrap_xblock
(
runtime_class
,
block
,
view
,
frag
,
context
,
usage_id_serializer
,
request_token
,
display_name_only
=
False
,
extra_data
=
None
):
# pylint: disable=unused-argument
def
wrap_xblock
(
runtime_class
,
block
,
view
,
frag
,
context
,
# pylint: disable=unused-argument
usage_id_serializer
,
request_token
,
# pylint: disable=redefined-outer-name
display_name_only
=
False
,
extra_data
=
None
):
"""
Wraps the results of rendering an XBlock view in a standard <section> with identifying
data so that the appropriate javascript module can be loaded onto it.
...
...
@@ -181,13 +192,14 @@ def grade_histogram(module_id):
from
django.db
import
connection
cursor
=
connection
.
cursor
()
q
=
"""SELECT courseware_studentmodule.grade,
query
=
"""
\
SELECT courseware_studentmodule.grade,
COUNT(courseware_studentmodule.student_id)
FROM courseware_studentmodule
WHERE courseware_studentmodule.module_id=
%
s
GROUP BY courseware_studentmodule.grade"""
# Passing module_id this way prevents sql-injection.
cursor
.
execute
(
q
,
[
module_id
.
to_deprecated_string
()])
cursor
.
execute
(
q
uery
,
[
module_id
.
to_deprecated_string
()])
grades
=
list
(
cursor
.
fetchall
())
grades
.
sort
(
key
=
lambda
x
:
x
[
0
])
# Add ORDER BY to sql query?
...
...
@@ -218,7 +230,13 @@ def add_staff_markup(user, has_instructor_access, block, view, frag, context):
edit_link
=
"//"
+
settings
.
CMS_BASE
+
'/container/'
+
unicode
(
block
.
location
)
# return edit link in rendered HTML for display
return
wrap_fragment
(
frag
,
render_to_string
(
"edit_unit_link.html"
,
{
'frag_content'
:
frag
.
content
,
'edit_link'
:
edit_link
}))
return
wrap_fragment
(
frag
,
render_to_string
(
"edit_unit_link.html"
,
{
'frag_content'
:
frag
.
content
,
'edit_link'
:
edit_link
}
)
)
else
:
return
frag
...
...
@@ -251,8 +269,9 @@ def add_staff_markup(user, has_instructor_access, block, view, frag, context):
source_file
=
block
.
source_file
# source used to generate the problem XML, eg latex or word
# useful to indicate to staff if problem has been released or not
# TODO (ichuang): use _has_access_descriptor.can_load in lms.courseware.access, instead of now>mstart comparison here
# Useful to indicate to staff if problem has been released or not.
# TODO (ichuang): use _has_access_descriptor.can_load in lms.courseware.access,
# instead of now>mstart comparison here.
now
=
datetime
.
datetime
.
now
(
UTC
())
is_released
=
"unknown"
mstart
=
block
.
start
...
...
@@ -268,7 +287,8 @@ def add_staff_markup(user, has_instructor_access, block, view, frag, context):
log
.
warning
(
"Unable to read field in Staff Debug information"
,
exc_info
=
True
)
field_contents
.
append
((
name
,
"WARNING: Unable to read field"
))
staff_context
=
{
'fields'
:
field_contents
,
staff_context
=
{
'fields'
:
field_contents
,
'xml_attributes'
:
getattr
(
block
,
'xml_attributes'
,
{}),
'location'
:
block
.
location
,
'xqa_key'
:
block
.
xqa_key
,
...
...
@@ -323,7 +343,7 @@ def get_course_update_items(course_updates, provided_index=0):
# purely to handle free formed updates not done via editor. Actually kills them, but at least doesn't break.
try
:
course_html_parsed
=
html
.
fromstring
(
course_updates
.
data
)
except
(
etree
.
XMLSyntaxError
,
etree
.
ParserError
):
except
(
etree
.
XMLSyntaxError
,
etree
.
ParserError
):
# pylint: disable=no-member
log
.
error
(
"Cannot parse: "
+
course_updates
.
data
)
escaped
=
escape
(
course_updates
.
data
)
course_html_parsed
=
html
.
fromstring
(
"<ol><li>"
+
escaped
+
"</li></ol>"
)
...
...
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