rebuild from latest cookiecutter

This commit is contained in:
lpm0073 2022-09-13 20:37:37 -05:00
parent 9caab3710f
commit 17549a4d4b
2 changed files with 137 additions and 118 deletions

View File

@ -1 +1 @@
__version__ = "0.0.2"
__version__ = "0.0.3"

View File

@ -2,131 +2,165 @@ from glob import glob
import os
import pkg_resources
from tutor import hooks as tutor_hooks
from tutor import hooks
from .__about__ import __version__
################# Configuration
config = {
"defaults": {
"CREDENTIALS_BACKEND_SERVICE_EDX_OAUTH2_PROVIDER_URL": "http://lms:8000/oauth2",
"CREDENTIALS_BACKEND_SERVICE_EDX_OAUTH2_KEY": "{{ CREDENTIALS_OAUTH2_KEY }}",
"CREDENTIALS_CATALOG_API_URL": "{{ CREDENTIALS_LMS_HOST }}",
"CREDENTIALS_DOCKER_IMAGE": "{{ DOCKER_REGISTRY }}lpm0073/openedx-credentials:{{ CREDENTIALS_VERSION }}",
"CREDENTIALS_EXTRA_PIP_REQUIREMENTS": [],
"CREDENTIALS_FAVICON_URL": "https://edx-cdn.org/v3/default/favicon.ico",
"CREDENTIALS_HOST": "credentials.{{ CREDENTIALS_LMS_HOST }}",
"CREDENTIALS_LMS_HOST": "myopenedxsite.com",
"CREDENTIALS_LMS_URL": "http://{{ CREDENTIALS_LMS_HOST }}",
"CREDENTIALS_LMS_URL_ROOT": "http://{{ CREDENTIALS_LMS_HOST }}",
"CREDENTIALS_LOGO_TRADEMARK_URL": "https://edx-cdn.org/v3/default/logo-trademark.svg",
"CREDENTIALS_LOGO_TRADEMARK_URL_PNG": "https://edx-cdn.org/v3/default/logo-trademark.png",
"CREDENTIALS_LOGO_TRADEMARK_URL_SVG": "https://edx-cdn.org/v3/default/logo-trademark.svg",
"CREDENTIALS_LOGO_URL": "https://edx-cdn.org/v3/default/logo.svg",
"CREDENTIALS_LOGO_URL_PNG": "https://edx-cdn.org/v3/default/logo.png",
"CREDENTIALS_LOGO_URL_SVG": "https://edx-cdn.org/v3/default/logo.svg",
"CREDENTIALS_LOGO_WHITE_URL": "https://edx-cdn.org/v3/default/logo-white.svg",
"CREDENTIALS_LOGO_WHITE_URL_PNG": "https://edx-cdn.org/v3/default/logo-white.png",
"CREDENTIALS_LOGO_WHITE_URL_SVG": "https://edx-cdn.org/v3/default/logo-white.svg",
"CREDENTIALS_MYSQL_DATABASE": "credentials",
"CREDENTIALS_MYSQL_USERNAME": "credentials",
"CREDENTIALS_OAUTH2_KEY": "credentials-backend-service-key",
"CREDENTIALS_PRIVACY_POLICY_URL": "{{ CREDENTIALS_LMS_HOST }}/privacy-policy",
"CREDENTIALS_SITE_NAME": "{{ CREDENTIALS_LMS_HOST }}",
"CREDENTIALS_SOCIAL_AUTH_REDIRECT_IS_HTTPS": False,
"CREDENTIALS_SOCIAL_AUTH_EDX_OAUTH2_ISSUER": "https://{{ CREDENTIALS_LMS_HOST }}",
"CREDENTIALS_SOCIAL_AUTH_EDX_OAUTH2_URL_ROOT": "http://lms:8000",
"CREDENTIALS_SOCIAL_AUTH_EDX_OAUTH2_KEY": "credentials-sso-key",
"CREDENTIALS_SOCIAL_AUTH_EDX_OAUTH2_LOGOUT_URL": "{{ CREDENTIALS_LMS_HOST }}/logout",
"CREDENTIALS_VERSION": __version__,
"CREDENTIALS_THEME_NAME": "edx-theme",
"CREDENTIALS_TOS_URL": "{{ CREDENTIALS_LMS_HOST }}/tos",
},
# Add here settings that don't have a reasonable default for all users. For
# instance: passwords, secret keys, etc.
"unique": {
"CREDENTIALS_MYSQL_PASSWORD": "{{ 8|random_string }}",
"CREDENTIALS_OAUTH2_SECRET": "{{ 16|random_string }}",
"CREDENTIALS_SECRET_KEY": "{{ 24|random_string }}",
"CREDENTIALS_SOCIAL_AUTH_EDX_OAUTH2_SECRET": "{{ 16|random_string }}",
"CREDENTIALS_BACKEND_SERVICE_EDX_OAUTH2_SECRET": "{{ 16|random_string }}",
},
# Danger zone! Add here values to override settings from Tutor core or other plugins.
"overrides": {
# "PLATFORM_NAME": "My platform",
},
}
########################################
# CONFIGURATION
########################################
################# Initialization tasks
tutor_hooks.Filters.COMMANDS_INIT.add_item(
(
hooks.Filters.CONFIG_DEFAULTS.add_items(
[
# Add your new settings that have default values here.
# Each new setting is a pair, (setting_name, default_value).
# Prefix your setting names with 'CREDENTIALS_'.
("CREDENTIALS_VERSION", __version__),
("CREDENTIALS_BACKEND_SERVICE_EDX_OAUTH2_PROVIDER_URL", "http://lms:8000/oauth2"),
("CREDENTIALS_BACKEND_SERVICE_EDX_OAUTH2_KEY", "{{ CREDENTIALS_OAUTH2_KEY }}"),
("CREDENTIALS_CATALOG_API_URL", "{{ CREDENTIALS_LMS_HOST }}"),
("CREDENTIALS_DOCKER_IMAGE", "{{ DOCKER_REGISTRY }}lpm0073/openedx-credentials:{{ CREDENTIALS_VERSION }}"),
("CREDENTIALS_EXTRA_PIP_REQUIREMENTS", []),
("CREDENTIALS_FAVICON_URL", "https://edx-cdn.org/v3/default/favicon.ico"),
("CREDENTIALS_HOST", "credentials.{{ CREDENTIALS_LMS_HOST }}"),
("CREDENTIALS_LMS_HOST", "myopenedxsite.com"),
("CREDENTIALS_LMS_URL", "http://{{ CREDENTIALS_LMS_HOST }}"),
("CREDENTIALS_LMS_URL_ROOT", "http://{{ CREDENTIALS_LMS_HOST }}"),
("CREDENTIALS_LOGO_TRADEMARK_URL", "https://edx-cdn.org/v3/default/logo-trademark.svg"),
("CREDENTIALS_LOGO_TRADEMARK_URL_PNG", "https://edx-cdn.org/v3/default/logo-trademark.png"),
("CREDENTIALS_LOGO_TRADEMARK_URL_SVG", "https://edx-cdn.org/v3/default/logo-trademark.svg"),
("CREDENTIALS_LOGO_URL", "https://edx-cdn.org/v3/default/logo.svg"),
("CREDENTIALS_LOGO_URL_PNG", "https://edx-cdn.org/v3/default/logo.png"),
("CREDENTIALS_LOGO_URL_SVG", "https://edx-cdn.org/v3/default/logo.svg"),
("CREDENTIALS_LOGO_WHITE_URL", "https://edx-cdn.org/v3/default/logo-white.svg"),
("CREDENTIALS_LOGO_WHITE_URL_PNG", "https://edx-cdn.org/v3/default/logo-white.png"),
("CREDENTIALS_LOGO_WHITE_URL_SVG", "https://edx-cdn.org/v3/default/logo-white.svg"),
("CREDENTIALS_MYSQL_DATABASE", "credentials"),
("CREDENTIALS_MYSQL_USERNAME", "credentials"),
("CREDENTIALS_OAUTH2_KEY", "credentials-backend-service-key"),
("CREDENTIALS_PRIVACY_POLICY_URL", "{{ CREDENTIALS_LMS_HOST }}/privacy-policy"),
("CREDENTIALS_SITE_NAME", "{{ CREDENTIALS_LMS_HOST }}"),
("CREDENTIALS_SOCIAL_AUTH_REDIRECT_IS_HTTPS", False),
("CREDENTIALS_SOCIAL_AUTH_EDX_OAUTH2_ISSUER", "https://{{ CREDENTIALS_LMS_HOST }}"),
("CREDENTIALS_SOCIAL_AUTH_EDX_OAUTH2_URL_ROOT", "http://lms:8000"),
("CREDENTIALS_SOCIAL_AUTH_EDX_OAUTH2_KEY", "credentials-sso-key"),
("CREDENTIALS_SOCIAL_AUTH_EDX_OAUTH2_LOGOUT_URL", "{{ CREDENTIALS_LMS_HOST }}/logout"),
("CREDENTIALS_THEME_NAME", "edx-theme"),
("CREDENTIALS_TOS_URL", "{{ CREDENTIALS_LMS_HOST }}/tos"),
]
)
hooks.Filters.CONFIG_UNIQUE.add_items(
[
# Add settings that don't have a reasonable default for all users here.
# For instance, passwords, secret keys, etc.
# Each new setting is a pair, (setting_name, unique_generated_value).
# Prefix your setting names with 'CREDENTIALS_'.
# For example:
# ("CREDENTIALS_SECRET_KEY", "{{ 24|random_string }}"),
("CREDENTIALS_MYSQL_PASSWORD", "{{ 8|random_string }}"),
("CREDENTIALS_OAUTH2_SECRET", "{{ 16|random_string }}"),
("CREDENTIALS_SECRET_KEY", "{{ 24|random_string }}"),
("CREDENTIALS_SOCIAL_AUTH_EDX_OAUTH2_SECRET", "{{ 16|random_string }}"),
("CREDENTIALS_BACKEND_SERVICE_EDX_OAUTH2_SECRET", "{{ 16|random_string }}"),
]
)
hooks.Filters.CONFIG_OVERRIDES.add_items(
[
# Danger zone!
# Add values to override settings from Tutor core or other plugins here.
# Each override is a pair, (setting_name, new_value). For example:
# ("PLATFORM_NAME", "My platform"),
]
)
########################################
# INITIALIZATION TASKS
########################################
# To run the script from templates/credentials/tasks/myservice/init, add:
hooks.Filters.COMMANDS_INIT.add_item((
"mysql",
("credentials", "tasks", "mysql", "init"),
)
)
tutor_hooks.Filters.COMMANDS_INIT.add_item(
(
))
hooks.Filters.COMMANDS_INIT.add_item((
"lms",
("credentials", "tasks", "lms", "init"),
)
)
tutor_hooks.Filters.COMMANDS_INIT.add_item(
(
))
hooks.Filters.COMMANDS_INIT.add_item((
"credentials",
("credentials", "tasks", "credentials", "init"),
)
)
tutor_hooks.Filters.IMAGES_BUILD.add_item(
(
))
hooks.Filters.IMAGES_BUILD.add_item((
"credentials",
("plugins", "credentials", "build", "credentials"),
"{{ CREDENTIALS_DOCKER_IMAGE }}",
(),
)
)
tutor_hooks.Filters.COMMANDS_INIT.add_item(
(
))
hooks.Filters.COMMANDS_INIT.add_item((
"mysql",
("credentials", "tasks", "mysql", "sync_users"),
)
))
########################################
# DOCKER IMAGE MANAGEMENT
########################################
# To build an image with `tutor images build myimage`, add a Dockerfile to templates/credentials/build/myimage and write:
hooks.Filters.IMAGES_BUILD.add_item((
"credentials",
("plugins", "credentials", "build", "credentials"),
"{{ LICENSE_MANAGER_DOCKER_IMAGE }}",
(),
))
# To pull/push an image with `tutor images pull myimage` and `tutor images push myimage`, write:
# hooks.Filters.IMAGES_PULL.add_item((
# "myimage",
# "docker.io/myimage:{{ CREDENTIALS_VERSION }}",
# )
# hooks.Filters.IMAGES_PUSH.add_item((
# "myimage",
# "docker.io/myimage:{{ CREDENTIALS_VERSION }}",
# )
########################################
# TEMPLATE RENDERING
# (It is safe & recommended to leave
# this section as-is :)
########################################
hooks.Filters.ENV_TEMPLATE_ROOTS.add_items(
# Root paths for template files, relative to the project root.
[
pkg_resources.resource_filename("tutorcredentials", "templates"),
]
)
@tutor_hooks.Filters.IMAGES_PULL.add()
@tutor_hooks.Filters.IMAGES_PUSH.add()
def _add_remote_credentials_image_iff_customized(images, user_config):
"""
Register CREDENTIALS image for pushing & pulling if and only if it has
been set to something other than the default.
This is work-around to an upstream issue with CREDENTIALS config. Briefly:
User config is baked into CREDENTIALS builds, so Tutor cannot host a generic
pre-built CREDENTIALS image. Howevever, individual Tutor users may want/need to
build and host their own CREDENTIALS image. So, as a compromise, we tell Tutor
to push/pull the CREDENTIALS image if the user has customized it to anything
other than the default image URL.
"""
image_tag = user_config["CREDENTIALS_DOCKER_IMAGE"]
if not image_tag.startswith("docker.io/lpm0073/openedx-credentials:"):
# Image has been customized. Add to list for pulling/pushing.
images.append(("credentials", image_tag))
return images
################# You don't really have to bother about what's below this line,
################# except maybe for educational purposes :)
# Plugin templates
tutor_hooks.Filters.ENV_TEMPLATE_ROOTS.add_item(
pkg_resources.resource_filename("tutorcredentials", "templates")
)
tutor_hooks.Filters.ENV_TEMPLATE_TARGETS.add_items(
hooks.Filters.ENV_TEMPLATE_TARGETS.add_items(
# For each pair (source_path, destination_path):
# templates at ``source_path`` (relative to your ENV_TEMPLATE_ROOTS) will be
# rendered to ``destination_path`` (relative to your Tutor environment).
[
("credentials/build", "plugins"),
("credentials/apps", "plugins"),
],
)
# Load all patches from the "patches" folder
########################################
# PATCH LOADING
# (It is safe & recommended to leave
# this section as-is :)
########################################
# For each file in tutorcredentials/patches,
# apply a patch based on the file's name and contents.
for path in glob(
os.path.join(
pkg_resources.resource_filename("tutorcredentials", "patches"),
@ -134,19 +168,4 @@ for path in glob(
)
):
with open(path, encoding="utf-8") as patch_file:
tutor_hooks.Filters.ENV_PATCHES.add_item((os.path.basename(path), patch_file.read()))
# Load all configuration entries
tutor_hooks.Filters.CONFIG_DEFAULTS.add_items(
[
(f"CREDENTIALS_{key}", value)
for key, value in config["defaults"].items()
]
)
tutor_hooks.Filters.CONFIG_UNIQUE.add_items(
[
(f"CREDENTIALS_{key}", value)
for key, value in config["unique"].items()
]
)
tutor_hooks.Filters.CONFIG_OVERRIDES.add_items(list(config["overrides"].items()))
hooks.Filters.ENV_PATCHES.add_item((os.path.basename(path), patch_file.read()))