diff --git a/.github/workflows/description.yml b/.github/workflows/description.yml index 4811e3b..c4862ef 100644 --- a/.github/workflows/description.yml +++ b/.github/workflows/description.yml @@ -3,7 +3,7 @@ name: Update Docker Hub Description on: push: branches: - - '6.0.x' + - '6.1.x' paths: - "README.md" - .github/workflows/description.yml diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 7e5edcd..94b4317 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -9,7 +9,7 @@ on: env: BASE_IMAGE_NAME: plone/server PLATFORMS: linux/amd64,linux/arm64 - IS_LATEST: true + IS_LATEST: false jobs: diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 5eecd78..b308cd7 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -3,10 +3,10 @@ name: Test generated image on: push: branches: - - "6.0.x" + - "6.1.x" pull_request: branches: - - "6.0.x" + - "6.1.x" jobs: diff --git a/README.md b/README.md index 5311a22..035e3bc 100644 --- a/README.md +++ b/README.md @@ -28,6 +28,7 @@ These images are **not** Buildout based! | Plone Version | Tags | Dockerfile | | --- | --- | --- | | 6 | `6.0.13`, `6.0`, `6`, `latest` | [(6.0.x/Dockerfile)](https://github.com/plone/plone-backend/blob/v6.0.13/Dockerfile)| +| 6.1 | `6.1.0b1`, `6.1` | [(6.1.x/Dockerfile)](https://github.com/plone/plone-backend/blob/v6.1.0b1/Dockerfile)| | 6 (nightly) | `nightly` | [(Dockerfile.nightly)](https://github.com/plone/plone-backend/blob/6.0.x/Dockerfile.nightly) | ### Unsupported tags diff --git a/skeleton/scripts/create_site.py b/skeleton/scripts/create_site.py index d530d26..c92c9a3 100644 --- a/skeleton/scripts/create_site.py +++ b/skeleton/scripts/create_site.py @@ -1,13 +1,29 @@ from AccessControl.SecurityManagement import newSecurityManager -from Products.CMFPlone.factory import _DEFAULT_PROFILE -from Products.CMFPlone.factory import addPloneSite +from pathlib import Path +from plone.distribution.api import site as site_api from Testing.makerequest import makerequest -import transaction +import json +import logging import os +import transaction + + +logging.basicConfig(format="%(message)s") + +# Silence some loggers +for logger_name in [ + "GenericSetup.componentregistry", + "Products.MimetypesRegistry.MimeTypesRegistry", +]: + logging.getLogger(logger_name).setLevel(logging.ERROR) +logger = logging.getLogger("Plone Site Creation") +logger.setLevel(logging.DEBUG) -truthy = frozenset(('t', 'true', 'y', 'yes', 'on', '1')) +SCRIPT_DIR = Path().cwd() / "scripts" + +truthy = frozenset(("t", "true", "y", "yes", "on", "1")) def asbool(s): @@ -22,7 +38,7 @@ def asbool(s): return s.lower() in truthy -app = makerequest(app) +app = makerequest(globals()["app"]) request = app.REQUEST @@ -31,56 +47,71 @@ def asbool(s): newSecurityManager(None, admin) # VARS -TYPE = os.getenv("TYPE", "volto") -SITE_ID = os.getenv("SITE_ID", "Plone") -SETUP_CONTENT = asbool(os.getenv("SETUP_CONTENT")) +ANSWERS = os.getenv("ANSWERS", "default") DELETE_EXISTING = asbool(os.getenv("DELETE_EXISTING")) -LANGUAGE = os.getenv("LANGUAGE", "en") -TIMEZONE = os.getenv("TIMEZONE", "Europe/Berlin") +DISTRIBUTION = os.getenv("DISTRIBUTION", "") + +if not DISTRIBUTION: + # We used to support setting TYPE 'volto' or 'classic'. + TYPE = os.getenv("TYPE", "") + if TYPE == "classic": + DISTRIBUTION = "classic" + elif TYPE == "volto": + DISTRIBUTION = "default" + +# Load default site creation parameters +answers_file = SCRIPT_DIR / f"{ANSWERS}.json" +answers = json.loads(answers_file.read_text()) + +# Override the defaults from the OS environment +if DISTRIBUTION: + answers["distribution"] = DISTRIBUTION +SITE_ID = os.getenv("SITE_ID") +if SITE_ID: + answers["site_id"] = SITE_ID +LANGUAGE = os.getenv("LANGUAGE") +if LANGUAGE: + answers["default_language"] = LANGUAGE +SETUP_CONTENT = os.getenv("SETUP_CONTENT") +if SETUP_CONTENT is not None: + answers["setup_content"] = asbool(SETUP_CONTENT) +TIMEZONE = os.getenv("TIMEZONE") +if TIMEZONE: + answers["portal_timezone"] = TIMEZONE ADDITIONAL_PROFILES = os.getenv("PROFILES", os.getenv("ADDITIONAL_PROFILES", "")) +additional_profiles = [] +if ADDITIONAL_PROFILES: + additional_profiles = [profile.strip() for profile in ADDITIONAL_PROFILES.split(",")] + +# Get the final site_id and distribution from the updated answers. +site_id = answers["site_id"] +DISTRIBUTION = answers["distribution"] +logger.info(f"Creating a new Plone site @ {site_id}") +logger.info(f" - Using the {DISTRIBUTION} distribution and answers from {answers_file}") -PROFILES = { - "volto": [ - "plone.app.caching:default", - "plonetheme.barceloneta:default", - "plone.volto:default", - "plone.volto:default-homepage", - ], - "classic": [ - "plone.app.caching:default", - "plonetheme.barceloneta:default", - ], -} - - -def profile_ids(site_type): - extension_ids = PROFILES[site_type] - if ADDITIONAL_PROFILES: - extension_ids.extend( - [ - profile.strip() - for profile in ADDITIONAL_PROFILES.split(" ") - if profile.strip() - ] - ) - return extension_ids - - -payload = { - "title": "Plone", - "profile_id": _DEFAULT_PROFILE, - "extension_ids": profile_ids(TYPE), - "setup_content": SETUP_CONTENT, - "default_language": LANGUAGE, - "portal_timezone": TIMEZONE, -} - -if SITE_ID in app.objectIds() and DELETE_EXISTING: - app.manage_delObjects([SITE_ID]) + +if site_id in app.objectIds() and DELETE_EXISTING: + app.manage_delObjects([site_id]) transaction.commit() app._p_jar.sync() - -if SITE_ID not in app.objectIds(): - site = addPloneSite(app, SITE_ID, **payload) + logger.info(f" - Deleted existing site with id {site_id}") +else: + logger.info( + f" - Stopping site creation, as there is already a site with id {site_id}. " + "Set DELETE_EXISTING=1 to delete the existing site before creating a new one." + ) + +if site_id not in app.objectIds(): + site = site_api._create_site( + context=app, distribution_name=DISTRIBUTION, answers=answers + ) transaction.commit() app._p_jar.sync() + logger.info(" - Site created!") + + if additional_profiles: + for profile_id in additional_profiles: + logger.info(f" - Importing profile {profile_id}") + site.portal_setup.runAllImportStepsFromProfile(f"profile-{profile_id}") + transaction.commit() + app._p_jar.sync() diff --git a/skeleton/scripts/default.json b/skeleton/scripts/default.json new file mode 100644 index 0000000..baf6d0a --- /dev/null +++ b/skeleton/scripts/default.json @@ -0,0 +1,8 @@ +{ + "site_id": "Plone", + "title": "Welcome to Plone 6", + "description": "Site created with a new Plone Distribution", + "default_language": "en", + "portal_timezone": "Europe/Berlin", + "setup_content": true +} \ No newline at end of file diff --git a/test/tests/plone-arbitrary-user/run.sh b/test/tests/plone-arbitrary-user/run.sh index caf50c5..4c1b998 100755 --- a/test/tests/plone-arbitrary-user/run.sh +++ b/test/tests/plone-arbitrary-user/run.sh @@ -22,19 +22,7 @@ get() { -c "from urllib.request import urlopen; con = urlopen('$1'); print(con.read())" } -get_auth() { - docker run --rm -i \ - --link "$cname":plone \ - --entrypoint /app/bin/python \ - "$image" \ - -c "from urllib.request import urlopen, Request; request = Request('$1'); request.add_header('Authorization', 'Basic $2'); print(urlopen(request).read())" -} - - . "$dir/../../retry.sh" --tries "$PLONE_TEST_TRIES" --sleep "$PLONE_TEST_SLEEP" get "http://plone:8080" # Plone is up and running -[[ "$(get 'http://plone:8080')" == *"Plone is up and running"* ]] - -# Create a Plone site -[[ "$(get_auth 'http://plone:8080/@@plone-addsite' "$(echo -n 'admin:admin' | base64)")" == *"Create a Plone site"* ]] \ No newline at end of file +[[ "$(get 'http://plone:8080')" == *"Welcome to Plone!"* ]] diff --git a/test/tests/plone-basics/run.sh b/test/tests/plone-basics/run.sh index f252529..d6f90d4 100755 --- a/test/tests/plone-basics/run.sh +++ b/test/tests/plone-basics/run.sh @@ -20,19 +20,7 @@ get() { -c "from urllib.request import urlopen; con = urlopen('$1'); print(con.read())" } -get_auth() { - docker run --rm -i \ - --link "$cname":plone \ - --entrypoint /app/bin/python \ - "$image" \ - -c "from urllib.request import urlopen, Request; request = Request('$1'); request.add_header('Authorization', 'Basic $2'); print(urlopen(request).read())" -} - - . "$dir/../../retry.sh" --tries "$PLONE_TEST_TRIES" --sleep "$PLONE_TEST_SLEEP" get "http://plone:8080" # Plone is up and running -[[ "$(get 'http://plone:8080')" == *"Plone is up and running"* ]] - -# Create a Plone site -[[ "$(get_auth 'http://plone:8080/@@plone-addsite' "$(echo -n 'admin:admin' | base64)")" == *"Create a Plone site"* ]] \ No newline at end of file +[[ "$(get 'http://plone:8080')" == *"Welcome to Plone!"* ]] diff --git a/test/tests/plone-listenport/run.sh b/test/tests/plone-listenport/run.sh index 58de13a..b2bb34b 100755 --- a/test/tests/plone-listenport/run.sh +++ b/test/tests/plone-listenport/run.sh @@ -23,4 +23,4 @@ get() { . "$dir/../../retry.sh" --tries "$PLONE_TEST_TRIES" --sleep "$PLONE_TEST_SLEEP" get "http://plone:8081" # Plone is up and running -[[ "$(get 'http://plone:8081')" == *"Plone is up and running"* ]] +[[ "$(get 'http://plone:8081')" == *"Welcome to Plone!"* ]] diff --git a/test/tests/plone-relstorage/run.sh b/test/tests/plone-relstorage/run.sh index 0905e70..51bd704 100755 --- a/test/tests/plone-relstorage/run.sh +++ b/test/tests/plone-relstorage/run.sh @@ -28,18 +28,7 @@ get() { -c "from urllib.request import urlopen; con = urlopen('$1'); print(con.read())" } -get_auth() { - docker run --rm -i \ - --link "$pname":plone \ - --entrypoint /app/bin/python \ - "$image" \ - -c "from urllib.request import urlopen, Request; request = Request('$1'); request.add_header('Authorization', 'Basic $2'); print(urlopen(request).read())" -} - . "$dir/../../retry.sh" --tries "$PLONE_TEST_TRIES" --sleep "$PLONE_TEST_SLEEP" get "http://plone:8080" # Plone is up and running -[[ "$(get 'http://plone:8080')" == *"Plone is up and running"* ]] - -# Create a Plone site -[[ "$(get_auth 'http://plone:8080/@@plone-addsite' "$(echo -n 'admin:admin' | base64)")" == *"Create a Plone site"* ]] +[[ "$(get 'http://plone:8080')" == *"Welcome to Plone!"* ]] diff --git a/test/tests/plone-shared-blob-dir/run.sh b/test/tests/plone-shared-blob-dir/run.sh index 99dd4f0..0fc1164 100755 --- a/test/tests/plone-shared-blob-dir/run.sh +++ b/test/tests/plone-shared-blob-dir/run.sh @@ -28,18 +28,7 @@ get() { -c "from urllib.request import urlopen; con = urlopen('$1'); print(con.read())" } -get_auth() { - docker run --rm -i \ - --link "${pname}":plone \ - --entrypoint /app/bin/python \ - "$image" \ - -c "from urllib.request import urlopen, Request; request = Request('$1'); request.add_header('Authorization', 'Basic $2'); print(urlopen(request).read())" -} - . "$dir/../../retry.sh" --tries "$PLONE_TEST_TRIES" --sleep "$PLONE_TEST_SLEEP" get "http://plone:8080" # Plone is up and running -[[ "$(get 'http://plone:8080')" == *"Plone is up and running"* ]] - -# Create a Plone site -[[ "$(get_auth 'http://plone:8080/@@plone-addsite' "$(echo -n 'admin:admin' | base64)")" == *"Create a Plone site"* ]] +[[ "$(get 'http://plone:8080')" == *"Welcome to Plone!"* ]] diff --git a/test/tests/plone-zeoclient/run.sh b/test/tests/plone-zeoclient/run.sh index 7d51cc3..35186cf 100755 --- a/test/tests/plone-zeoclient/run.sh +++ b/test/tests/plone-zeoclient/run.sh @@ -28,18 +28,7 @@ get() { -c "from urllib.request import urlopen; con = urlopen('$1'); print(con.read())" } -get_auth() { - docker run --rm -i \ - --link "$pname":plone \ - --entrypoint /app/bin/python \ - "$image" \ - -c "from urllib.request import urlopen, Request; request = Request('$1'); request.add_header('Authorization', 'Basic $2'); print(urlopen(request).read())" -} - . "$dir/../../retry.sh" --tries "$PLONE_TEST_TRIES" --sleep "$PLONE_TEST_SLEEP" get "http://plone:8080" # Plone is up and running -[[ "$(get 'http://plone:8080')" == *"Plone is up and running"* ]] - -# Create a Plone site -[[ "$(get_auth 'http://plone:8080/@@plone-addsite' "$(echo -n 'admin:admin' | base64)")" == *"Create a Plone site"* ]] +[[ "$(get 'http://plone:8080')" == *"Welcome to Plone!"* ]] diff --git a/version.txt b/version.txt index 50e9dae..c52c7d3 100644 --- a/version.txt +++ b/version.txt @@ -1 +1 @@ -6.0.13 \ No newline at end of file +6.1.0b1