Installation

Preparation

Supported operating systems

Operating SystemVersionSupported
Ubuntu20.04
22.04
CentOS7
8
Debian10
11
WindowsAny

Install Dependencies

apt -y install software-properties-common curl apt-transport-https ca-certificates gnupg

LC_ALL=C.UTF-8 add-apt-repository -y ppa:ondrej/php

curl -LsS https://downloads.mariadb.com/MariaDB/mariadb_repo_setup | sudo bash -s -- --mariadb-server-version="mariadb-10.11"

apt update

apt -y install php8.2 php8.2-{common,cli,gd,mysql,mbstring,bcmath,xml,fpm,curl,zip} mariadb-server nginx tar unzip git redis-server

Install Composer

curl -sS https://getcomposer.org/installer | sudo php -- --install-dir=/usr/local/bin --filename=composer

Download the code

Clone our repo from Github to your server:

mkdir /var/www/paymenter
cd /var/www/paymenter
curl -Lo paymenter.tar.gz https://github.com/paymenter/paymenter/releases/latest/download/paymenter.tar.gz
tar -xzvf paymenter.tar.gz
chmod -R 755 storage/* bootstrap/cache/

Install & Setup Database

You will need a database setup and a user with the correct permissions created for that database before continuing any further. See below to create a user and database for your Paymenter panel quickly. To find more detailed information please have a look at Setting up MySQL.

mysql -u root -p

# Remember to change 'yourPassword' below to be a unique password
CREATE USER 'paymenter'@'127.0.0.1' IDENTIFIED BY 'yourPassword';
CREATE DATABASE paymenter;
GRANT ALL PRIVILEGES ON paymenter.* TO 'paymenter'@'127.0.0.1' WITH GRANT OPTION;
exit

First we will copy over our default environment settings file, install core dependencies, and then generate a new application encryption key.

cp .env.example .env
composer install --no-dev --optimize-autoloader

# Only run the command below if you are installing this Panel for
# the first time and do not have any Paymenter Panel data in the database.
php artisan key:generate --force
php artisan storage:link
Warning
Back up your encryption key (APP_KEY in the .env file). It is used as an encryption key for all data that needs to be stored securely (e.g. user passwords). Store it somewhere safe - not just on your server. If you lose it all encrypted data is irrecoverable – even if you have database backups.

Environment Configuration

Change the database connection information in the .env file to match the credentials you created in the previous step.

DB_DATABASE=paymenter
DB_USERNAME=paymenter
DB_PASSWORD=yourPassword

Database Setup

Now we need to setup all of the base data for the Panel in the database you created earlier. The command below may take some time to run depending on your machine. Please DO NOT exit the process until it is completed! This command will setup the database tables that power Paymenter.

php artisan migrate --force --seed

Add The First User

You’ll then need to create an administrative user so that you can log into the admin side. To do so, run the command below.

php artisan p:user:create

Webserver configuration

For nginx you can create a file in /etc/nginx/sites-available/ called paymenter.conf and add the following:

server {
    listen 80;
    listen [::]:80;
    server_name paymenter.org;
    root /var/www/paymenter/public;

    index index.php;

    location / {
        try_files $uri $uri/ /index.php?$query_string;
    }

    location ~ \.php$ {
        include snippets/fastcgi-php.conf;
        fastcgi_pass unix:/var/run/php/php8.2-fpm.sock;
    }
}

Then run the following commands to enable the site and restart nginx:

sudo ln -s /etc/nginx/sites-available/paymenter.conf /etc/nginx/sites-enabled/
sudo systemctl restart nginx

Be sure to replace paymenter.org with your domain name.

Fix the permmisions of paymenter with the following command:

chown -R www-data:www-data /var/www/paymenter/*

Cronjob

Crontab Configuration The first thing we need to do is create a new cronjob that runs every minute to process specific Paymenter tasks. You’ll want to open your crontab using sudo crontab -e and then paste the line below.

* * * * * php /var/www/paymenter/artisan schedule:run >> /dev/null 2>&1

Create Queue Worker

Paymenter uses Laravel’s built in queue system to handle tasks that are able to be run in the background.

Create a new file in /etc/systemd/system/ called paymenter.service and add the following:

[Unit]
Description=Paymenter Queue Worker

[Service]
# On some systems the user and group might be different.
# Some systems use `apache` or `nginx` as the user and group.
User=www-data
Group=www-data
Restart=always
ExecStart=/usr/bin/php /var/www/paymenter/artisan queue:work
StartLimitInterval=180
StartLimitBurst=30
RestartSec=5s

[Install]
WantedBy=multi-user.target

Then run the following commands to enable the service and start it:

sudo systemctl enable --now paymenter.service