openpsa / installer
Installer for OpenPSA components and projects
Installs: 25 171
Dependents: 5
Suggesters: 0
Security: 0
Stars: 0
Watchers: 3
Forks: 0
Open Issues: 0
Type:composer-plugin
Requires
- php: >=8.1
- composer-plugin-api: ^2.0
- openpsa/midgard-portable: >=1.10
- symfony/console: >=6.4
- symfony/filesystem: >=6.4
Requires (Dev)
- composer/composer: ^2.0
- phpunit/phpunit: ^10.5.10
This package is auto-updated.
Last update: 2024-12-01 11:59:57 UTC
README
Installation and setup tools for OpenPSA/MidCOM packages and projects.
Composer Support
Due to the logic of Composer, this basically consists of two parts,
a custom installer, that is to say, an implementation of Composer\Installer\InstallerInterface
which is used for
packages installed in the vendor
directory, and static functions that are run from script hooks in the root package.
What the installer will do is link all the schema files to the central Midgard 2 schema dir, and all the static
directories (both from themes and from components' static folders) to midcom-static
, so that they are accessible via
the web server.
Usage
To use the installer in a libary or component, simply set the type
key to midcom-package
in composer.json
. You should
also add openpsa/installer
to your require
s.
To use the installer in a root package, add openpsa/installer
to your require
s in composer.json
.
Additionally, add the following hooks:
"scripts": { "post-install-cmd": [ "openpsa\\installer\\installer::setup_root_package" ], "post-update-cmd": [ "openpsa\\installer\\installer::setup_root_package" ] },
Database setup
The installer package contains a CLI utility to set up new databases. From your project's root directory, you can run it like this:
./vendor/bin/openpsa-installer midgard2:setup
You can pass the name or location of an existing Midgard2 configuration file as an argument to the script, or you can optionally specify the DB type you want to create. Run
./vendor/bin/openpsa-installer help midgard2:setup
to see all available options.
Database Conversion
The installer can also convert (simple) Midgard 1 databases. This performs the following actions:
- preparing config file Midgard 2 storage and connection (like the setup command)
- copying contents from multilang tables
- resetting
host
fields to 0 - migrating user accounts
Be advised that this command does not support databases with multiple languages or sitegroups yet. From your project's root directory, you can run it like this:
./vendor/bin/openpsa-installer midgard2:convert
You can pass the name or location of an existing Midgard2 configuration file as an argument to the script, or you can optionally specify the auth (i.e. password storage) type you want to use. This can be useful if you have used encrypted passwords under Midgard1. By setting authtype
to Legacy
, you can migrate them unchanged.
Run
./vendor/bin/openpsa-installer help midgard2:convert
to see all available options.