Getting Started
System requirements
- PHP 8.2+
- Apache/Nginx/Caddy/FrankenPHP1
- MySQL 5.7+ (8.0+ recommended) or MariaDB
patch
command 2.7+ (orgpatch
on macOS/HomeBrew)
Create your project
Info
yourproject
is the name of the directory where you want to create the project
Configure your web server
With Maho you have to point your web server's document root to the /public
directory.
This is a necessary step to ensure the highest level of security.
Local development server
Alternatively, if you're just developing on your computer, you can run ./maho serve
to start the built-in PHP web server (you will still need a database tho).
./maho serve --help
Description:
Run Maho with the built in server
Usage:
serve [<port>]
Arguments:
port Default is 8000 [default: 8000]
Do you like docker?
If docker is your go-to choice then we suggest you check the Docker Starter community project by Simone Fantini.
Install Maho
This is the moment where the database tables are created and the first settings are set.
So, reach to your sysadmins and ask them to create a database on your server(s) and give you the access credentials, you'll need them in a minute.
There are two ways of installing Maho to your database:
- via command line, using the maho CLI tool
- via web on your browser, with the web installer
Command line installation
./maho install --help
Usage:
install [options]
Options:
--license_agreement_accepted=LICENSE_AGREEMENT_ACCEPTED It will accept "yes" value only
--locale=LOCALE Locale
--timezone=TIMEZONE Timezone
--default_currency=DEFAULT_CURRENCY Default currency
--db_host=DB_HOST You can specify server port (localhost:3307) or UNIX socket (/var/run/mysqld/mysqld.sock)
--db_name=DB_NAME Database name
--db_user=DB_USER Database username
--db_pass=DB_PASS Database password
--db_prefix[=DB_PREFIX] Database Tables Prefix. No table prefix will be used if not specified [default: ""]
--session_save[=SESSION_SAVE] Where to store session data (files/db) [default: "files"]
--admin_frontname[=ADMIN_FRONTNAME] Admin panel path, "admin" by default [default: "admin"]
--url=URL URL the store is supposed to be available at
--use_secure[=USE_SECURE] Use Secure URLs (SSL). Enable this option only if you have SSL available. [default: false]
--secure_base_url[=SECURE_BASE_URL] Secure Base URL. Provide a complete base URL for SSL connection. For example: https://mydomain.com/
--use_secure_admin[=USE_SECURE_ADMIN] Run admin interface with SSL [default: false]
--admin_lastname=ADMIN_LASTNAME Admin user last name
--admin_firstname=ADMIN_FIRSTNAME Admin user first name
--admin_email=ADMIN_EMAIL Admin user email
--admin_username=ADMIN_USERNAME Admin user login
--admin_password=ADMIN_PASSWORD Admin user password
--encryption_key[=ENCRYPTION_KEY] Will be automatically generated and displayed on success, if not specified
--sample_data[=SAMPLE_DATA] Also install sample data
-h, --help Display help for the given command. When no command is given display help for the list command
-q, --quiet Do not output any message
-V, --version Display this application version
--ansi|--no-ansi Force (or disable --no-ansi) ANSI output
-n, --no-interaction Do not ask any interactive question
-v|vv|vvv, --verbose Increase the verbosity of messages: 1 for normal output, 2 for more verbose output and 3 for debug
Sample of a complete CLI installation command:
./maho install \
--license_agreement_accepted yes \
--locale en_US --timezone Europe/London --default_currency EUR \
--db_host localhost --db_name maho --db_user root --db_pass root \
--url http://yourdomain.test/ --secure_base_url http://yourdomain.test/ \
--use_secure 0 --use_secure_admin 0 \
--admin_lastname admin --admin_firstname admin \
--admin_email [email protected] --admin_username admin \
--admin_password samplepassword
If you need a list of the available currencies, locales or timezones, simply run one of these commands:
Sample data
Maho sample data is a ready-made demo online store that you can play with to learn how Maho works, without having to build and configure everything from scratch.
To install Maho with sample data, just add --sample_data 1
to the installation, eg:
./maho install \
--license_agreement_accepted yes \
--locale en_US --timezone Europe/London --default_currency EUR \
--db_host localhost --db_name maho --db_user root --db_pass root \
--url http://yourdomain.test/ --secure_base_url http://yourdomain.test/ \
--use_secure 0 --use_secure_admin 0 \
--admin_lastname admin --admin_firstname admin \
--admin_email [email protected] --admin_username admin \
--admin_password samplepassword \
--sample_data 1
and everything will be automatically downloaded and setup for you by Maho installer.
Info
Remember to revise and adapt all the parameters above, like the database host/username/password, the admin password and so on.
Installation via the web installer
If you're not familiar with the command line, simply open your browser to type the URL you configured in your web server, pointing to your Maho project public
directory, the web installer will start automatically, and you'll be guided through the complete installation of Maho into your database.
Warning
Sample data installation is not available using the web installer.
Cron setup
Please check cron setup dedicated documentation.
-
Standalone binary building with FrankenPHP is untested at the moment. ↩