Type
magento2-module
magento2-module
AL-2.0
None
None
None
None
None
The extension is using Satis, composer.json and packages (stored on the server). For each package ordered through the web shop it checks if the ordered products are M2 packages (based on product_id) and inserts this into the customer_packages table so that the user will have access to the purchased package. If there is no customer_auth key available one will be generated.
Here's how the extension works in the 3 steps outlined below:
With the auth key and secret the customer can install the package from the command file with Composer. For this Composer will request the packages.json from the repository. Based on the used key and secret the customer_id is checked for available packages and the output is built.
When a download is requested it requests /composer/download/file/ with the parameters (m/[package_name]/h/[package_hash]/v/[normalized_version, again based on the used key and secret access to the file and version is checked, if allowed file is send from the [satis archive directory] to the user.
Thru the notify-batch URL the installation of a package is recorded for the user (stores IP, Package, Version and User ID).
Satis installation
Install Satis outside of Magento Webroot, but accessible from the Magento web user. To install it, run the following command in your console:
php bin/magento eadesign:composerrepo
[path] → The place where you want to install the Satis directory.
NOTE !!!
The Satis installation folder should not be accessible from the web. It is only used to collect composer's json files and to generate downloaded files.
After installation of the extension go to: Stores => Configuration => EADESIGN SETTINGS => Composer Repo and complete the following fields:
[Configuration]
Repository name: This name is used for the composer config repositories (for example: Eadesign's repositories),
Repository URL: The url that serves the Repository (for example: [ your domain ]/composer/packagist/index ),
[Satis Configuration]
Satis command path: Path to the Satis executable (for example: [ your project ]/satis/bin/satis ),
Satis config path: Path to the satis.json configuration file (for example: [ your project ]/satis/satis.json ),
[Satis Archive]
Format: Export format (zip or tar) of the packages (for example: zip)
Absolute Directory: Path to where the downloaded packages should be places (for example: [your project]/satis/packages/)
The Magento 2 package/extensions should be stored in a repository, it is important that the account where Satis is running from has access to download from this repository.
To add a Magento 2 package go to: Eadesign => Composer Repository => Packages => Add new Package
[Package Information]
Package Name: composer package name (for example: eadesign/composerrepo),
Status: Enabled,
When the configuration and packages are ready the configration can be build with:
php bin/magento eadesign:composerrepo
This command can also be scheduled to run daily (or any frequency you prefer) and automatically update the repository data.