Skip to content

Commit

Permalink
feat(config): Rework how we grab the mfe_config based on domain cha…
Browse files Browse the repository at this point in the history
…nge.

With a S3/Cloudfront distribution fro the MFE frontends, we went with a https://{mfe}.{lms-domain} change making the MFE app a subdomain of the lms domain.

Example of additional `BASE_URL` needed within each MFE app configuraiton.
```
{
    "MFE_CONFIG": {
        "BASE_URL": "https://apps.{lms-domain}"
    },
    "MFE_CONFIG_ACCOUNT": {
        "BASE_URL": "https://account.{lms-domain}"
    },
    "MFE_CONFIG_COURSE-AUTHORING": {
        "BASE_URL": "https://course-authoring.{lms-domain}"
    },
    "MFE_CONFIG_GRADEBOOK": {
        "BASE_URL": "https://gradebook.{lms-domain}"
    },
    "MFE_CONFIG_LEARNING": {
        "BASE_URL": "https://learning.{lms-domain}"
    },
    "MFE_CONFIG_PROFILE": {
        "BASE_URL": "https://profile.{lms-domain}"
    }
}
```
  • Loading branch information
becdavid committed Jan 6, 2025
1 parent 03ab530 commit 9cb3b9e
Showing 1 changed file with 22 additions and 8 deletions.
30 changes: 22 additions & 8 deletions lms/djangoapps/mfe_config_api/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -65,26 +65,40 @@ def get(self, request):
referer = re.sub(r'^https?:\/\/', '', request.META.get('HTTP_REFERER')).split('/')[0] # pylint: disable=anomalous-backslash-in-string

for site_config in SiteConfiguration.objects.all():
configuration = getattr(site_config.site, "configuration", None)
mfe_config = site_config.site_values.get("MFE_CONFIG", {})

if request.query_params.get('mfe'):
mfe = str(request.query_params.get('mfe')).upper()

mfe_config.update(configuration.get_value(
f'MFE_CONFIG_{mfe}', getattr(settings, f'MFE_CONFIG_{mfe}', {}))
)

if mfe_config.get("BASE_URL"):
mfe_config_base_url = re.sub(r'^https?:\/\/', '', mfe_config.get("BASE_URL")).split('/')[0] # pylint: disable=anomalous-backslash-in-string

log.info(
"MFEConfigView.get - mfe_config_base_url (%s), referrer (%s)",
mfe_config_base_url, referer
)
if mfe_config_base_url == referer:
log.info(
"Found the site configuration that matches the MFE base domain."
)

configuration = getattr(site_config.site, "configuration", None)
# configuration = getattr(site_config.site, "configuration", None)

mfe_config = configuration.get_value(
'MFE_CONFIG', getattr(settings, 'MFE_CONFIG', {}))
# mfe_config = configuration.get_value(
# 'MFE_CONFIG', getattr(settings, 'MFE_CONFIG', {})
# )

if request.query_params.get('mfe'):
mfe = str(request.query_params.get('mfe')).upper()
# if request.query_params.get('mfe'):
# mfe = str(request.query_params.get('mfe')).upper()

mfe_config.update(configuration.get_value(
f'MFE_CONFIG_{mfe}', getattr(settings, f'MFE_CONFIG_{mfe}', {}))
)
# mfe_config.update(configuration.get_value(
# f'MFE_CONFIG_{mfe}', getattr(settings, f'MFE_CONFIG_{mfe}', {}))
# )

# Exit out of the loop once you find first correct
# MFE_CONFIG in Site Configuration.
Expand Down

0 comments on commit 9cb3b9e

Please sign in to comment.