The taxonomy service is a library that can be installed in other edX components that provides access to third party taxonomy vendors. EMSI is currently the only vendor available, but others may be integrated as necessary. This service can communicate with the vendor to get job, skill, and salary data. This service can also be used to submit data (course descriptions, etc.) to the vendor to produce potential matches for a skill or job.
After submitting a pull request, please use the Github "Reviewers" widget to add relevant reviewers and track review process.
To install taxonomy-connector, for example, in Course Discovery, follow these steps:
- It is recommended that you clone this repo into a sub-folder of your working directory. Create a sub-folder with name
srcif it doesn't already exist. - Clone this repository into the
srcfolder. - Go to the shell of the host environment where you want to install this package and run this
pip install -e /edx/src/taxonomy-connector - Changes made into the taxonomy repository will now be picked up by your host environment.
Notes:
- In order to communicate with EMSI service, you need to set the values of
client_idandclient_secret. These values are picked up from the host environment so you need to pass them in.yamlfile of the host environment. - Also, to make taxonomy work, the host platform must add an implementation of data providers written in
./taxonomy/providers - Taxonomy APIs use throttle rate set in
DEFAULT_THROTTLE_RATESsettings by default. Custom Throttle rate can by set by addingScopedRateThrottleclass inDEFAULT_THROTTLE_CLASSESsettings andtaxonomy-api-throttle-scopekey inDEFAULT_THROTTLE_RATES - For the skill tags to be verified, the management command
finalize_xblockskill_tagsneeds to be run periodically. - Also, You can configure the skill tags verification by setting the values of
SKILLS_VERIFICATION_THRESHOLD,SKILLS_VERIFICATION_RATIO_THRESHOLD,SKILLS_IGNORED_THRESHOLDandSKILLS_IGNORED_RATIO_THRESHOLDin the host platform or by passing the values to the command using the args--min-verified-votes,--ratio-verified-threshold,--min-ignored-votesand--ratio-ignored-threshold.
REST_FRAMEWORK = {
'DEFAULT_THROTTLE_CLASSES': (
'rest_framework.throttling.UserRateThrottle',
'rest_framework.throttling.ScopedRateThrottle'
),
'DEFAULT_THROTTLE_RATES': {
'user': '100/hour',
'taxonomy-api-throttle-scope': '60/min', # custom throttle rate for taxonomy api
},
}- To run unit tests, create a virtualenv, install the requirements with
make requirementsand then runmake test - To update the requirements, run
make upgrade - To run quality checks, run
make quality - Please do not import models directly in course discovery. e:g if you want to import CourseSkills in Discovery, use the utility get_whitelisted_course_skills instead of directly importing it.
Please do not report security issues in public. Please email security@openedx.org.
Have a question about this repository, or about Open edX in general? Please refer to this list of resources if you need any assistance.