-
Notifications
You must be signed in to change notification settings - Fork 48
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: Create django admin for default enrollments (#2264)
- Loading branch information
1 parent
b8e2795
commit 3bd4bd6
Showing
12 changed files
with
466 additions
and
28 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,4 +2,4 @@ | |
Your project description goes here. | ||
""" | ||
|
||
__version__ = "4.28.4" | ||
__version__ = "4.29.0" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
""" | ||
Utils for interacting with cache interfaces. | ||
""" | ||
import hashlib | ||
|
||
from django.conf import settings | ||
|
||
from enterprise import __version__ as code_version | ||
|
||
CACHE_KEY_SEP = ':' | ||
DEFAULT_NAMESPACE = 'edx-enterprise-default' | ||
|
||
|
||
def versioned_cache_key(*args): | ||
""" | ||
Utility to produce a versioned cache key, which includes | ||
an optional settings variable and the current code version, | ||
so that we can perform key-based cache invalidation. | ||
""" | ||
components = [str(arg) for arg in args] | ||
components.append(code_version) | ||
if stamp_from_settings := getattr(settings, 'CACHE_KEY_VERSION_STAMP', None): | ||
components.append(stamp_from_settings) | ||
decoded_cache_key = CACHE_KEY_SEP.join(components) | ||
return hashlib.sha512(decoded_cache_key.encode()).hexdigest() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,60 @@ | ||
""" | ||
Python API for interacting with content metadata. | ||
""" | ||
import logging | ||
|
||
from edx_django_utils.cache import TieredCache | ||
from requests.exceptions import HTTPError | ||
|
||
from django.conf import settings | ||
|
||
from enterprise.api_client.enterprise_catalog import EnterpriseCatalogApiClient | ||
from enterprise.cache_utils import versioned_cache_key | ||
|
||
logger = logging.getLogger(__name__) | ||
|
||
DEFAULT_CACHE_TIMEOUT = getattr(settings, 'CONTENT_METADATA_CACHE_TIMEOUT', 60 * 5) | ||
|
||
|
||
def get_and_cache_customer_content_metadata(enterprise_customer_uuid, content_key, timeout=None): | ||
""" | ||
Returns the metadata corresponding to the requested | ||
``content_key`` within catalogs associated to the provided ``enterprise_customer``. | ||
The response is cached in a ``TieredCache`` (meaning in both the RequestCache, | ||
_and_ the django cache for the configured expiration period). | ||
Returns: A dict with content metadata for the given key. | ||
Raises: An HTTPError if there's a problem getting the content metadata | ||
via the enterprise-catalog service. | ||
""" | ||
cache_key = versioned_cache_key('get_content_metadata_content_identifier', enterprise_customer_uuid, content_key) | ||
cached_response = TieredCache.get_cached_response(cache_key) | ||
if cached_response.is_found: | ||
logger.info(f'cache hit for enterprise customer {enterprise_customer_uuid} and content {content_key}') | ||
return cached_response.value | ||
|
||
try: | ||
result = EnterpriseCatalogApiClient().get_content_metadata_content_identifier( | ||
enterprise_uuid=enterprise_customer_uuid, | ||
content_id=content_key, | ||
) | ||
except HTTPError as exc: | ||
raise exc | ||
|
||
if not result: | ||
logger.warning( | ||
'No content found for customer %s and content_key %s', | ||
enterprise_customer_uuid, | ||
content_key, | ||
) | ||
return {} | ||
|
||
logger.info( | ||
'Fetched catalog for customer %s and content_key %s. Result = %s', | ||
enterprise_customer_uuid, | ||
content_key, | ||
result, | ||
) | ||
TieredCache.set_all_tiers(cache_key, result, timeout or DEFAULT_CACHE_TIMEOUT) | ||
return result |
27 changes: 27 additions & 0 deletions
27
...prise/migrations/0227_alter_defaultenterpriseenrollmentintention_content_type_and_more.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
# Generated by Django 4.2.16 on 2024-10-24 15:42 | ||
|
||
from django.db import migrations, models | ||
|
||
|
||
class Migration(migrations.Migration): | ||
|
||
dependencies = [ | ||
('enterprise', '0226_alter_enterprisegroup_name_and_more'), | ||
] | ||
|
||
operations = [ | ||
migrations.AlterField( | ||
model_name='defaultenterpriseenrollmentintention', | ||
name='content_type', | ||
field=models.CharField(blank=True, choices=[('course', 'Course'), ('course_run', 'Course Run')], help_text='The type of content (e.g. a course vs. a course run).', max_length=127, null=True), | ||
), | ||
migrations.AlterField( | ||
model_name='historicaldefaultenterpriseenrollmentintention', | ||
name='content_type', | ||
field=models.CharField(blank=True, choices=[('course', 'Course'), ('course_run', 'Course Run')], help_text='The type of content (e.g. a course vs. a course run).', max_length=127, null=True), | ||
), | ||
migrations.AddConstraint( | ||
model_name='defaultenterpriseenrollmentintention', | ||
constraint=models.UniqueConstraint(fields=('enterprise_customer', 'content_key'), name='unique_default_enrollment_intention'), | ||
), | ||
] |
Oops, something went wrong.