Nothing in this document is an official recommendation for LORIS but is only intended to be helpful!
- We recommend installing LORIS on Ubuntu or CentOS as macOS is no longer supported for "production" as of v15.10
- These instructions were last tested on LORIS version v20.*
This is a guide on how to get a LORIS instance running on your Apple computer for development. You're expected to have basic understanding of using a terminal and editing configuration files. For production servers, we recommend installing LORIS on Ubuntu or CentOS.
The following list provides foresight into the proceeding sections and versions to install:
- macOS (tested on Mojave 10.14.3)
- XCode Command Line Tools
- Homebrew
- Apache (a.k.a httpd)
- PHP (tested on v7.2.14)
- PHP extension: ast-0.1.5
- pkg-config
- Composer
- Node.js (npm)
- MySQL (tested with 10.3.12-MariaDB)
- Xdebug (tested on v2.6.1)
You should have a GitHub account and git installed on your local development machine.
- Navigate to github.com/aces/Loris
- Click on the Fork button.
You should now have your own LORIS repository on Github.
a. Create a directory for development where you will clone your fork of LORIS.
Paste the following in your terminal and hit enter:
mkdir -p ~/Development/GitHub
b. Clone your fork to ~/Development/GitHub
Paste the following lines in your terminal, and replace <your_username> with your github username before pressing enter.
cd ~/Development/GitHub
git clone https://github.com/<your_username>/Loris.git
Type the following in your terminal and hit enter:
xcode-select --install
1.4 Install Homebrew
Visit the Homebrew official website and run their installer script in your terminal to install it.
The following commands will install Apache and launch it as a service on startup:
brew update
brew upgrade
brew install httpd
brew link httpd
sudo brew services start httpd
How to start, stop, and restart Apache.
sudo apachectl start
sudo apachectl stop
sudo apachectl -k restart
php -S localhost:8000 -t . router.php
Logs will be sent to stderr.
Modify the Apache configuration file for our development environment.
sudo open -e /usr/local/etc/httpd/httpd.conf
a. Find & modify the ServerName
to:
ServerName localhost
b. Find the lines for DocumentRoot
and Directory
in Apache and change them to:
DocumentRoot "/Users/<your_user>/Development/GitHub/Loris/htdocs/"
<Directory "/Users/<your_user>/Development/GitHub/Loris/htdocs/">
c. In the same <Directory>
block, modify AllowOverride
to allow all:
# AllowOverride controls what directives may be placed in .htaccess files.
# It can be "All", "None", or any combination of the keywords:
# AllowOverride FileInfo AuthConfig Limit
#
AllowOverride All
d. Enable mod_rewrite
which is commented out by default:
LoadModule rewrite_module lib/httpd/modules/mod_rewrite.so
e. Modify the User
& Group
(replace your_user again with your macOS user) to:
User your_user
Group staff
sudo apachectl -k restart
Type these commands into your terminal and hit enter:
brew install php72
brew link php72
brew services start php72
brew install pkg-config
Modify the Apache configuration file to enable php.
sudo open -e /usr/local/etc/httpd/httpd.conf
a. Add the line below to LoadModules
(Change php@<version>
to the correct version):
LoadModule php7_module /usr/local/opt/php@<version>/lib/httpd/modules/libphp7.so
b. Modify <IfModule dir_module>
to this:
<IfModule dir_module>
DirectoryIndex index.php index.html
</IfModule>
c. Add the lines below under </IfModule>
:
<FilesMatch \.php$>
SetHandler application/x-httpd-php
</FilesMatch>
sudo apachectl -k restart
Xdebug allows debugging with breakpoints (such as when using an IDE ex. Intellij).
Type into your terminal and hit enter:
pecl install xdebug
a. Comment out the line zend_extensions=“xdebug.so”
from the top of your php.ini
file (Note: replace your_php_version
with the correct php version installed):
sudo open -e /usr/local/etc/php/<your_php_version>/php.ini
b. Create the file ext-xdebug.ini
with this command:
sudo touch /usr/local/etc/php/<your_php_version>/conf.d/ext-xdebug.ini
c. Type the following into the ext-xdebug.ini
file you just created (Note: replace the zend_extension
path with the correct one on your machine):
[xdebug]
zend_extension="/usr/local/Cellar/[email protected]/7.2.14/pecl/20170718/xdebug.so"
xdebug.remote_enable=on
xdebug.remote_host=localhost
xdebug.remote_port=9000
xdebug.show_error_trace=1
xdebug.remote_autostart=1
xdebug.remote_connect_back=0
xdebug.idekey=phpstorm
sudo apachectl -k restart
1.7.2 Install Xdebug toggle for OSX (recommended)
a. Install from the GitHub repository.
b. Terminal command to view Xdebug state:
xdebug
c. Terminal command to toggle xdebug (On or Off)
xdebug on
xdebug off
We’re installing MariaDB (fork of mysql).
a. Type the commands into your terminal and hit enter:
brew update
brew upgrade
brew install mariadb
brew services start mariadb
b. Securing MySQL (set password for user “root” and disable outside localhost, remove anonymous users & test dbs):
mysql_secure_installation
Sequel Pro (free)
Type into your terminal and hit enter:
brew install composer
Type into your terminal and hit enter:
pecl install ast-0.1.5;
Navigate in your browser to NodeJS.org to download and run the installer.
Type into your terminal and hit enter:
cd ~/Development/GitHub/Loris
make dev
cd /tools
./install.sh
Open a browser (Firefox & Chrome are supported) and navigate to:
localhost:8080/installdb.php
or
localhost:8000/installdb.php
depending if using Apache or php -S.
Once finished hooray, LORIS should be accessible and you can start developing!