Skip to content
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

Conditionally enable Taxoman for Ficus #201

Merged

Conversation

johnbaldwin
Copy link

@johnbaldwin johnbaldwin commented Jan 23, 2018

I didn't put effort into abstracting away taxoman inclusions since we need to figure out a much slimmer way to integrate Appsembler specific features into edx-platform, and we also need to march forward with Ginko then Hawthorne when it get released,

What I did do was add conditionals and test that it works in a GCP staging server both with Taxoman enabled and with taxoman disabled and the taxoman and taxoman_api python packages not installed

The Search API app in CMS is mostly unchanged from Dogwood

The search api provides a programmatic interface to course indexing. The
driver is to support course reindexing from Taxoma.

This commit is just the app. It does not contain the hooks to use the
code:

* cms/urls.py
* cms/envs/common.py
This commit adds required hooks to `cms/urls.py` and
`cms/envs/common.py` in order to use the search api
Courseware Index performs the initial indexing. This is what provides
the custom facets that the built-in LMS courseware discovery uses
Enables conditional use of Taxoman in devstack and prod/staging
environments
@johnbaldwin
Copy link
Author

@@ -2024,6 +2024,7 @@

# User API
'rest_framework',
'rest_framework.authtoken',
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@OmarIthawi Been thinking of just adding webpack_loader here (and in the pip requirements). edx.org has it in their master branch (assume for Hawthorne) (but they're behind the latest 0.5.0, they're using 0.4.1):

Currently I'm specifying webpack loader in the server-vars

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've had a very busy week juggling between urgent issues, so I can't do anything extra. I might visit it later next week.

@johnbaldwin johnbaldwin requested a review from tkeemon January 24, 2018 21:01
@johnbaldwin johnbaldwin changed the title WIP Conditionally enable Taxoman for Ficus Conditionally enable Taxoman for Ficus Jan 24, 2018
@johnbaldwin
Copy link
Author

@bryanlandia bryanlandia self-requested a review January 30, 2018 19:51
# Appsembler addition
if using_taxoman:
for facet in Facet.objects.all():
print("facet = {}".format(facet))

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe safer to use u"facet = {}".format .... here. Looks like you are using the __unicode__ property of facet here and I think you can get in trouble if that has characters outside of ascii and you are mixing with a format string.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I removed the print statement

Copy link

@bryanlandia bryanlandia Jan 31, 2018

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

haha, ok. 👍

"""
Arguments:
course_id - The course id for a course. This is the 'course_id' property
for the course as returend from:

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

quibble: "returned"

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fixed!

<lms-host>/api/courses/v1/courses/

Raises:
InvalidKeyError - if the opaque course

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

looks like an unfinished thought here...

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yep. Fixed, thanks!

"""
def has_permission(self, request, view):
return request.user and request.user.is_active and (
request.user.is_staff or request.user.is_superuser)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

quibble: newline

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Added a newline

from .permissions import IsStaffUser

# Restrict access to the LMS server
ALLOWED_ORIGIN = settings.LMS_BASE

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This will be an issue with sites using multiple domains, via Site. I suggest changing this to do a lookup of Site.objects.all() and use the domains returned, and then append settings.LMS_BASE just to be sure.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@bryanlandia Great catch!

Right now, this is only an issue if we install Taxoman on multi-site instances since right now search_api is only used by Taxoman. So for now I'll comment inline that this is broken for multi-site instances and create an issue/card to address it

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

OK, we are not going to worry about it at this point, since the only customer using at this point doesn't have any additional domains (except Preview, but that's not a worry). This will be good to fix before upstreaming. I'll file an Issue.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I created an issue: #202


# Appsembler API extensions
urlpatterns += (
url(r'^api/search/', include('search_api.urls')),

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Are we in danger of colliding with another eventual feature using such a generic name for this api, search?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@bryanlandia Good point. Could be. Same thing could also be said for adding a package called search_api to the CMS. I don't think we can 100% future proof this. Right now this is not in edx/edx-platform/master, so we've got time to rework this ahead if this is implemented in the future by edx.org. Plus we have to customize the CMS to use this functionality unless/until we make this a CMS only plugin or move in a different direction with providing course discovery. Thoughts on this?

Do you have any suggestions for a different path?

@@ -29,6 +29,18 @@
log = logging.getLogger('edx.modulestore')


# Interim code to get courseware_index to work with Taxoman

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If this is interim what is the eventual strategy?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@bryanlandia Good question. What I see as the eventual strategy generally follows the following:

A) Understand/evaluate how Hawthorn does plugins and see if that will aid in including taxoman. See: https://github.com/edx/edx-platform/tree/master/openedx/core/djangoapps/plugins

How far will this go to help integrate custom facets into the course discovery built into edx-platform? We answer this question and see

B) Generalize Taxoman integration in edx-platform and edx-search so that
B.1 edx-platform and edx-search optionally accept a vender generic custom facet provider/handler
B.2 Make Taxoman have an interface to meet this
B.3 Document how the interface works so that it is open and others can write custom facet handlers using the same means

Then we've got something that should be upstreamable (after making sure we also have appropriate tests and documentation)

@johnbaldwin
Copy link
Author

@bryanlandia Do you see anything else that prevents this being merged into develop?

@bryanlandia
Copy link

I think it's good to go, @johnbaldwin

Copy link

@tkeemon tkeemon left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This seems fine as an interim solution, we should definitely look into abstracting some of this into a separate Django package (especially the edxsearch app).

# Appsembler API Extensions
'rest_framework',
'rest_framework.authtoken',
'search_api',
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we pull these three items into our appsembler_ settings files to minimize the footprint in core edx-platform?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I was thinking that initially but since search_api is in the CMS djangoapps, it requires the rest_framework.authtoken. and it seems weird to have to add an installed app via the appsembler app/edx-configs for an app that lives in edx-platform.

Once we move search_api to a pluggable app, then totally, I agree that we pull it out of common and load it via edx-configs

@johnbaldwin johnbaldwin merged commit ff1608d into appsembler/ficus/develop Feb 9, 2018
@johnbaldwin johnbaldwin deleted the appsembler/ficus/feature/taxoman branch February 9, 2018 21:59
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants