Installing Hyvä CMS
With a license key
TODO
For Contributions and for Technology Partners
If you have access to the Hyvä Commerce CMS GitLab repository, you can install it in development environments using SSH key authentication.
You can configure the git repositories in your root composer.json and use the repositories directly as git repo's beneath your vendor directory. You can check out tags and branches, make commits and push contributions.
-
Ensure your public SSH key is added to your account on gitlab.hyva.io.
-
Set minimum-stability to
dev
in the Magento composer.json -
Add the Hyvä CMS repository to the Magento
composer.json
-
Require the
hyva-themes/commerce-module-cms
packages using thedev-main
branch version: -
Run
bin/magento setup:upgrade
-
Run tailwind to generate the styles for the Hyvä CMS, replacing
vendor/hyva-themes/magento2-default-theme/web/tailwind/
with the path to your theme'sweb/tailwind
folder:
Multi-Store Setup
When using Hyvä CMS Liveview Editor with multiple storefronts on different domains, browsers block iframes by default. Since the editor loads storefront previews inside the Magento admin, you must securely allow embedding within the admin domain for it to work properly.
The correct way to achieve this is to configure Content Security Policy (CSP) frame-ancestors to allow the admin domain.
Production Environments
Configure Content Security Policy (CSP) settings to ensure proper iframe functionality between domains. 1. Enable CSP Restrict Mode in the admin area. Add or update the following configuration in `config.xml`:<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:module:Magento_Store:etc/config.xsd">
<default>
<csp>
<mode>
<admin>
<report_only>0</report_only>
</admin>
</mode>
</csp>
</default>
</config>
<?xml version="1.0"?>
<csp_whitelist xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:module:Magento_Csp:etc/csp_whitelist.xsd">
<policies>
<policy id="frame-ancestors">
<values>
<value id="magento-admin-domain" type="host">your-admin-domain.com</value>
<value id="self" type="host">self</value>
<value id="https" type="host">https:</value>
</values>
</policy>
</policies>
</csp_whitelist>