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
a761e2e8
Commit
a761e2e8
authored
Mar 15, 2013
by
Your Name
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
make pinning backward compatible
parent
0a53ec3e
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
16 additions
and
140 deletions
+16
-140
common/static/coffee/src/discussion/views/discussion_thread_show_view.coffee
+3
-1
lms/djangoapps/django_comment_client/base/views.py
+3
-2
lms/djangoapps/django_comment_client/forum/views.py
+10
-6
lms/lib/comment_client/models.py
+0
-131
No files found.
common/static/coffee/src/discussion/views/discussion_thread_show_view.coffee
View file @
a761e2e8
...
...
@@ -128,7 +128,9 @@ if Backbone?
type
:
"POST"
success
:
(
response
,
textStatus
)
=>
if
textStatus
==
'success'
@
model
.
set
(
'pinned'
,
true
)
@
model
.
set
(
'pinned'
,
true
)
error
:
=>
$
(
'.admin-pin'
).
text
(
"Pinning not currently available"
)
unPin
:
->
url
=
@
model
.
urlFor
(
"unPinThread"
)
...
...
lms/djangoapps/django_comment_client/base/views.py
View file @
a761e2e8
...
...
@@ -116,8 +116,9 @@ def create_thread(request, course_id, commentable_id):
thread
.
save
()
#patch for backward compatibility with comments service
thread
[
'pinned'
]
=
False
#patch for backward compatibility to comments service
if
not
'pinned'
in
thread
.
attributes
:
thread
[
'pinned'
]
=
False
if
post
.
get
(
'auto_subscribe'
,
'false'
)
.
lower
()
==
'true'
:
user
=
cc
.
User
.
from_django_user
(
request
.
user
)
...
...
lms/djangoapps/django_comment_client/forum/views.py
View file @
a761e2e8
...
...
@@ -99,8 +99,10 @@ def get_threads(request, course_id, discussion_id=None, per_page=THREADS_PER_PAG
thread
[
'group_name'
]
=
""
thread
[
'group_string'
]
=
"This post visible to everyone."
#temporary patch for backward compatibility to comments service
thread
[
'pinning'
]
=
False
#patch for backward compatibility to comments service
if
not
'pinned'
in
thread
:
thread
[
'pinned'
]
=
False
query_params
[
'page'
]
=
page
query_params
[
'num_pages'
]
=
num_pages
...
...
@@ -249,8 +251,9 @@ def single_thread(request, course_id, discussion_id, thread_id):
try
:
thread
=
cc
.
Thread
.
find
(
thread_id
)
.
retrieve
(
recursive
=
True
,
user_id
=
request
.
user
.
id
)
#temporary patch for backward compatibility with comments service
thread
[
"pinned"
]
=
False
#patch for backward compatibility with comments service
if
not
'pinned'
in
thread
.
attributes
:
thread
[
'pinned'
]
=
False
except
(
cc
.
utils
.
CommentClientError
,
cc
.
utils
.
CommentClientUnknownError
)
as
err
:
log
.
error
(
"Error loading single thread."
)
...
...
@@ -292,8 +295,9 @@ def single_thread(request, course_id, discussion_id, thread_id):
if
thread
.
get
(
'group_id'
)
and
not
thread
.
get
(
'group_name'
):
thread
[
'group_name'
]
=
get_cohort_by_id
(
course_id
,
thread
.
get
(
'group_id'
))
.
name
#temporary patch for backward compatibility with comments service
thread
[
"pinned"
]
=
False
#patch for backward compatibility with comments service
if
not
"pinned"
in
thread
:
thread
[
"pinned"
]
=
False
threads
=
[
utils
.
safe_content
(
thread
)
for
thread
in
threads
]
...
...
lms/lib/comment_client/models.py
deleted
100644 → 0
View file @
0a53ec3e
from
utils
import
*
class
Model
(
object
):
accessible_fields
=
[
'id'
]
updatable_fields
=
[
'id'
]
initializable_fields
=
[
'id'
]
base_url
=
None
default_retrieve_params
=
{}
DEFAULT_ACTIONS_WITH_ID
=
[
'get'
,
'put'
,
'delete'
]
DEFAULT_ACTIONS_WITHOUT_ID
=
[
'get_all'
,
'post'
]
DEFAULT_ACTIONS
=
DEFAULT_ACTIONS_WITH_ID
+
DEFAULT_ACTIONS_WITHOUT_ID
def
__init__
(
self
,
*
args
,
**
kwargs
):
self
.
attributes
=
extract
(
kwargs
,
self
.
accessible_fields
)
self
.
retrieved
=
False
def
__getattr__
(
self
,
name
):
if
name
==
'id'
:
return
self
.
attributes
.
get
(
'id'
,
None
)
try
:
return
self
.
attributes
[
name
]
except
KeyError
:
if
self
.
retrieved
or
self
.
id
is
None
:
raise
AttributeError
(
"Field {0} does not exist"
.
format
(
name
))
self
.
retrieve
()
return
self
.
__getattr__
(
name
)
def
__setattr__
(
self
,
name
,
value
):
if
name
==
'attributes'
or
name
not
in
self
.
accessible_fields
:
super
(
Model
,
self
)
.
__setattr__
(
name
,
value
)
else
:
self
.
attributes
[
name
]
=
value
def
__getitem__
(
self
,
key
):
if
key
not
in
self
.
accessible_fields
:
raise
KeyError
(
"Field {0} does not exist"
.
format
(
key
))
return
self
.
attributes
.
get
(
key
)
def
__setitem__
(
self
,
key
,
value
):
if
key
not
in
self
.
accessible_fields
:
raise
KeyError
(
"Field {0} does not exist"
.
format
(
key
))
self
.
attributes
.
__setitem__
(
key
,
value
)
def
items
(
self
,
*
args
,
**
kwargs
):
return
self
.
attributes
.
items
(
*
args
,
**
kwargs
)
def
get
(
self
,
*
args
,
**
kwargs
):
return
self
.
attributes
.
get
(
*
args
,
**
kwargs
)
def
to_dict
(
self
):
self
.
retrieve
()
return
self
.
attributes
def
retrieve
(
self
,
*
args
,
**
kwargs
):
if
not
self
.
retrieved
:
self
.
_retrieve
(
*
args
,
**
kwargs
)
self
.
retrieved
=
True
return
self
def
_retrieve
(
self
,
*
args
,
**
kwargs
):
url
=
self
.
url
(
action
=
'get'
,
params
=
self
.
attributes
)
response
=
perform_request
(
'get'
,
url
,
self
.
default_retrieve_params
)
self
.
update_attributes
(
**
response
)
@classmethod
def
find
(
cls
,
id
):
return
cls
(
id
=
id
)
def
update_attributes
(
self
,
*
args
,
**
kwargs
):
for
k
,
v
in
kwargs
.
items
():
if
k
in
self
.
accessible_fields
:
self
.
__setattr__
(
k
,
v
)
else
:
raise
AttributeError
(
"Field {0} does not exist"
.
format
(
k
))
def
updatable_attributes
(
self
):
return
extract
(
self
.
attributes
,
self
.
updatable_fields
)
def
initializable_attributes
(
self
):
return
extract
(
self
.
attributes
,
self
.
initializable_fields
)
@classmethod
def
before_save
(
cls
,
instance
):
pass
@classmethod
def
after_save
(
cls
,
instance
):
pass
def
save
(
self
):
self
.
__class__
.
before_save
(
self
)
if
self
.
id
:
# if we have id already, treat this as an update
url
=
self
.
url
(
action
=
'put'
,
params
=
self
.
attributes
)
response
=
perform_request
(
'put'
,
url
,
self
.
updatable_attributes
())
else
:
# otherwise, treat this as an insert
url
=
self
.
url
(
action
=
'post'
,
params
=
self
.
attributes
)
response
=
perform_request
(
'post'
,
url
,
self
.
initializable_attributes
())
self
.
retrieved
=
True
self
.
update_attributes
(
**
response
)
self
.
__class__
.
after_save
(
self
)
def
delete
(
self
):
url
=
self
.
url
(
action
=
'delete'
,
params
=
self
.
attributes
)
response
=
perform_request
(
'delete'
,
url
)
self
.
retrieved
=
True
self
.
update_attributes
(
**
response
)
@classmethod
def
url_with_id
(
cls
,
params
=
{}):
return
cls
.
base_url
+
'/'
+
str
(
params
[
'id'
])
@classmethod
def
url_without_id
(
cls
,
params
=
{}):
return
cls
.
base_url
@classmethod
def
url
(
cls
,
action
,
params
=
{}):
if
cls
.
base_url
is
None
:
raise
CommentClientError
(
"Must provide base_url when using default url function"
)
if
action
not
in
cls
.
DEFAULT_ACTIONS
:
raise
ValueError
(
"Invalid action {0}. The supported action must be in {1}"
.
format
(
action
,
str
(
cls
.
DEFAULT_ACTIONS
)))
elif
action
in
cls
.
DEFAULT_ACTIONS_WITH_ID
:
try
:
return
cls
.
url_with_id
(
params
)
except
KeyError
:
raise
CommentClientError
(
"Cannot perform action {0} without id"
.
format
(
action
))
else
:
# action must be in DEFAULT_ACTIONS_WITHOUT_ID now
return
cls
.
url_without_id
()
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