dof-dss / maestro-hosting
Maestro hosting resources
Installs: 10 135
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 5
Forks: 0
Open Issues: 1
Requires
- dof-dss/maestro-core: ^1.0
- dev-main
- 1.0.26
- 1.0.25
- 1.0.24
- 1.0.23
- 1.0.22
- 1.0.21
- 1.0.20
- 1.0.19
- 1.0.18
- 1.0.17
- 1.0.16
- 1.0.15
- 1.0.14
- 1.0.13
- 1.0.12
- 1.0.11
- 1.0.10
- 1.0.9
- 1.0.8
- 1.0.7
- 1.0.6
- 1.0.5
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0
- 0.0.6
- 0.0.5
- 0.0.4
- 0.0.3
- 0.0.2
- dev-lando_php_upgrade
- dev-php_upgrade
- dev-platform_build_fixes
- dev-corp_lite_platform_changes
- dev-site_checks
- dev-add_redirect_processing
- dev-no_www_route
- dev-D8UN-2214
- dev-update-core
- dev-increase_solr_size
- dev-increase_disk_sizes
This package is auto-updated.
Last update: 2024-04-25 14:07:47 UTC
README
Hosting providers and assets for Maestro.
Directory structure
└─ resources/ ## Root resources directory.
├─── unity/ ## Resources for hosting providers operating on Unity Projects.
├─ src/ ## Root code directory.
├─── provider/ ## Hosting providers which perform the build operations.
├─── Hosting.php ## Base class for writing a hosting provider.
├─ composer.json ## PHP packages for this project.
├─ composer.lock ## Record of package versions defined in composer.json
├─ vendor/ ## Installed packages from composer.
Updating hosting configuration
Under resources/<project_type> you will find the resources for each hosting provider. Each resource directory will typically contain a 'files' and 'templates' directory.
- Files are copied across during the build without needing alteration.
- Templates are files that are modified during the build process before added to the project.
Changes to content in the files directory can be added and published as a new release.
If you require changes to a template you should make your changes but also look at the
hosting provider class to check the alterations made to the file.
Updating hosting build steps
If you need to alter how a hosting provider constructs the overall hosting setup you will need to change the steps in the build function of the provider class.
Adding a new hosting provider
To add a new hosting provider create a new class that inherits the Hosting base class. Add the various setup steps to the build function and add any resources to resources/<project_type>/</provider_name>. It's important that the provider_name directory matches the name of your provider class (including case).
Injected services
Each providers build method is injected with 3 services:
- StyleInterface $io,
- FilesystemInterface $fs,
- ProjectInterface $project
StyleInterface
The styleinterface provides method to communicate user messages to the Maestro shell.
See: https://github.com/symfony/console/blob/4.2/Style/StyleInterface.php for details.
FilesystemInterface
The FilesystemInterface provides methods to interact with the filesystem IO and mirrors the functionality of the Symfony Filesystem class but provides the following additional features:
- Paths starting with a forward slash will be relative to the current directory.
- Paths starting with a double forward slash will be treated as absolute paths.
- The Read method will automatically parse the given filepath based on the file extension.
- The Write method will automatically compile the content parameter to the correct format based on file extension.
See: https://github.com/dof-dss/maestro-core/blob/main/src/FilesystemInterface.php
ProjectInterface
The projectInterface provides methods to manage the Maestro project.
You will usually call and iterate over the sites() method from within your build()
function to setup the hosting environment for each site.
See https://github.com/symfony/console/blob/4.2/Style/StyleInterface.php for details.
Enabling a hosting provider
Each forked project repository must contain a maestro.yml file with the required hosting provider
entries. When the maestro shell project:build command runs, it will iterate each of these providers
and run their build method.
Entries must have a service name (which isn't strict), the FQN of the provider class and a tag of 'maestro.hosting'.
See the example below.
services: hosting.platformSH: class: 'Maestro\Hosting\Provider\PlatformSH' tags: - { name: maestro.hosting } hosting.lando: class: 'Maestro\Hosting\Provider\Lando' tags: - { name: maestro.hosting }