-
Notifications
You must be signed in to change notification settings - Fork 4.2k
fix: [FC-0092] Fix 500 on return_type is list #36969
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from all commits
6547cea
ebf08de
e1f8c47
5b66a87
09715ed
bd03bdb
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -11,47 +11,55 @@ | |
|
|
||
| def filter_discussion_xblocks_from_response(response, course_key): | ||
| """ | ||
| Removes discussion xblocks if discussion provider is openedx | ||
| Removes discussion xblocks if discussion provider is openedx. | ||
| """ | ||
| configuration = DiscussionsConfiguration.get(context_key=course_key) | ||
| provider = configuration.provider_type | ||
| if provider == Provider.OPEN_EDX: | ||
| # Finding ids of discussion xblocks | ||
| if isinstance(response.data, ReturnList): | ||
| discussion_xblocks = [ | ||
| value.get('id') for value in response.data if value.get('type') == 'discussion' | ||
| ] | ||
| else: | ||
| discussion_xblocks = [ | ||
| key for key, value in response.data.get('blocks', {}).items() | ||
| if value.get('type') == 'discussion' | ||
| ] | ||
| # Filtering discussion xblocks keys from blocks | ||
| if isinstance(response.data, ReturnList): | ||
| filtered_blocks = { | ||
| value.get('id'): value | ||
| for value in response.data | ||
| if value.get('type') != 'discussion' | ||
| } | ||
| else: | ||
| filtered_blocks = { | ||
| key: value | ||
| for key, value in response.data.get('blocks', {}).items() | ||
| if value.get('type') != 'discussion' | ||
| } | ||
| # Removing reference of discussion xblocks from unit | ||
| # These references needs to be removed because they no longer exist | ||
| for _, block_data in filtered_blocks.items(): | ||
| for key in ['descendants', 'children']: | ||
| descendants = block_data.get(key, []) | ||
| if descendants: | ||
| descendants = [ | ||
| descendant for descendant in descendants | ||
| if descendant not in discussion_xblocks | ||
| ] | ||
| block_data[key] = descendants | ||
| if isinstance(response.data, ReturnList): | ||
| response.data = filtered_blocks | ||
| else: | ||
| response.data['blocks'] = filtered_blocks | ||
|
|
||
| if provider != Provider.OPEN_EDX: | ||
| return response | ||
|
|
||
| is_list_response = isinstance(response.data, ReturnList) | ||
|
|
||
| # Find discussion xblock IDs | ||
| if is_list_response: | ||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. [Nit, for the future, not necessary for merge]: There's so much logic branched off of
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Agree. Noted for the future, thank you! |
||
| discussion_xblocks = [ | ||
| block.get('id') for block in response.data | ||
| if block.get('type') == 'discussion' | ||
| ] | ||
| else: | ||
| discussion_xblocks = [ | ||
| key for key, value in response.data.get('blocks', {}).items() | ||
| if value.get('type') == 'discussion' | ||
| ] | ||
|
|
||
| # Filter out discussion blocks | ||
| if is_list_response: | ||
| filtered_blocks = [ | ||
| block for block in response.data | ||
| if block.get('type') != 'discussion' | ||
| ] | ||
| else: | ||
| filtered_blocks = { | ||
| key: value for key, value in response.data.get('blocks', {}).items() | ||
| if value.get('type') != 'discussion' | ||
| } | ||
|
|
||
| # Remove references to discussion xblocks | ||
| # These references needs to be removed because they no longer exist | ||
| blocks_iterable = filtered_blocks if is_list_response else filtered_blocks.values() | ||
| for block_data in blocks_iterable: | ||
| for key in ['descendants', 'children']: | ||
| if key in block_data: | ||
| block_data[key] = [ | ||
| descendant for descendant in block_data[key] | ||
| if descendant not in discussion_xblocks | ||
| ] | ||
|
|
||
| # Update response | ||
| if is_list_response: | ||
| response.data = ReturnList(filtered_blocks, serializer=None) | ||
| else: | ||
| response.data['blocks'] = filtered_blocks | ||
|
|
||
| return response | ||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -330,12 +330,14 @@ def list(self, request, hide_access_denials=False): # pylint: disable=arguments | |
|
|
||
| if course_block.get('type') == 'course': | ||
| root = course_block['id'] | ||
| else: | ||
| root = str(course_usage_key) | ||
| else: | ||
| root = response.data['root'] | ||
| course_blocks = response.data['blocks'] | ||
|
|
||
| if not root: | ||
| raise ValueError(f"Unable to find course block in {course_key_string}") | ||
| raise ValidationError(f"Unable to find course block in '{course_key_string}'") | ||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why do we need this change?
Contributor
Author
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why not use
So, raise |
||
|
|
||
| recurse_mark_complete(root, course_blocks) | ||
| return response | ||
|
|
||
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Isn't this comment still relevant as it explains why this is being done?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, this comment can still be useful, I re-added it.