Go to file
Tim Zandbergen c70d23859a
Removed non-translated lines.
2025-01-26 00:00:51 +01:00
.github Update FUNDING.yml 2021-09-03 21:02:40 +02:00
cron Add IP whitelist turn off option (#1249) 2025-01-25 23:28:57 +01:00
dev Add IP whitelist turn off option (#1249) 2025-01-25 23:28:57 +01:00
docs Changed IP from 192.168.50.100 to 192.168.56.100 2021-12-27 23:56:35 +01:00
logs Jabber (XMPP) notifications (#852) 2020-04-19 15:31:40 +02:00
src Removed non-translated lines. 2025-01-26 00:00:51 +01:00
.gitattributes Update .gitattributes 2016-05-19 01:22:07 -04:00
.gitignore Fix Uncaught TypeError: Cannot access offset of type string on string in PHP8 in sendWebHook method. 2022-06-10 07:16:42 +02:00
.htaccess Added some basic pagespeed settings 2016-12-25 23:00:49 +01:00
CHANGELOG.rst Added correct version number 2020-08-12 13:11:52 +02:00
LICENSE moving changelog + license to root 2014-01-07 23:34:54 +01:00
Makefile File mode changed from 775 to 644 2020-02-09 18:04:26 +01:00
README.rst Added Tele2 API (#1130) 2021-06-21 22:49:40 +02:00
SECURITY.md Create SECURITY.md 2019-09-19 14:39:38 +02:00
Vagrantfile Changed IP from 192.168.50.100 to 192.168.56.100 2021-12-27 23:56:35 +01:00
composer.json Bump paragonie/random_compat from 2.0.20 to 9.99.100 2025-01-06 19:38:15 +00:00
composer.lock Bump paragonie/random_compat from 2.0.20 to 9.99.100 2025-01-06 19:38:15 +00:00
composer.phar Updated composer 2019-05-19 23:25:00 +02:00
config.php.sample Add IP whitelist turn off option (#1249) 2025-01-25 23:28:57 +01:00
favicon.ico new favicon (with higher res available) 2014-08-01 11:38:16 +02:00
favicon.png Compressed images 2014-10-18 17:22:10 -04:00
index.php Implementing the PSR12 standard 2019-12-11 21:27:04 +01:00
install.php Implementing the PSR12 standard 2019-12-11 21:27:04 +01:00
manifest.json File mode changed from 775 to 644 2020-02-09 18:04:26 +01:00
phpservermon.png File mode changed from 775 to 644 2020-02-09 18:04:26 +01:00
provision.yaml Fix typo in provision.yaml 2024-03-05 13:04:03 +10:00
public.php Prevent unautorized warning 2020-08-18 17:50:06 +02:00
service-worker.js Prevent loading main page if installed in subdirectory (fix #869) (#870) 2020-04-19 14:30:13 +02:00
setup-mysql.sh Update and Fix Vagrant development setup (#1111) 2021-12-10 20:57:20 +01:00
setup-php.sh Update and Fix Vagrant development setup (#1111) 2021-12-10 20:57:20 +01:00
updater.sh Make updater.sh more robust #898 (#979) 2021-05-31 04:06:52 +02:00

README.rst

PHP Server Monitor
==================

.. image:: https://badges.gitter.im/Join%20Chat.svg
   :alt: Join the chat at https://gitter.im/erickrf/nlpnet
   :target: https://gitter.im/phpservermon/phpservermon
.. image:: https://cdn.huntr.dev/huntr_security_badge_mono.svg
   :alt: huntr
   :target: https://huntr.dev
Version 3.6.0.beta2

PHP Server Monitor is a script that checks whether your websites and servers are up and running.
It comes with a web based user interface where you can manage your services and websites,
and you can manage users for each server with a mobile number and email address.


Features:
---------

* Monitor services and websites (see below).
* Email, SMS, Discord, Pushover, Telegram and Jabber notifications.
* View history graphs of uptime and latency.
* User authentication with 2 levels (administrator and regular user).
* Logs of connection errors, outgoing emails and text messages.
* Easy cronjob implementation to automatically check your servers.

There are two different ways to monitor a server:

* Service

  A connection will be made to the entered ip or domain, on the given port.
  This way you can check if certain services on your machine are still running.
  To check your IMAP service for example, enter port 143.

* Website

  You can enter a link to a website, it will then use cURL to open the website and check the HTTP status code.
  If the HTTP status code is in the 4xx/5xx, it means an error occurred and the website is not accessible to the public.
  You can also set a regular expression to match for content on the page itself.
  If the regular expression returns no matches, the website is considered down.
  In both cases the script will return a "status offline", and will start sending out notifications.

Each server has its own settings regarding notification.
You can choose for email, text message (SMS), Pushover.net, Telegram and Jabber notifications.
The following SMS gateways are currently available:

* Clickatell - <https://www.clickatell.com>
* Inetworx - <https://www.inetworx.ch>
* Messagebird - <https://www.messagebird.com>
* Mosms - <https://www.mosms.com>
* Smsglobal - <https://smsglobal.com>
* SMSit - <https://www.smsit.dk>
* Spryng - <https://www.spryng.nl>
* Textmarketer - <https://www.textmarketer.co.uk>
* FreeVoipDeal - <https://www.freevoipdeal.com>
* Nexmo - <https://www.nexmo.com>
* OctoPush - <https://www.octopush.com>
* FreeMobile (FR) - <https://mobile.free.fr>
* Twilio - <https://twilio.com>
* CM Telecom - <https://www.cm.com>
* GatewayAPI - <https://gatewayapi.com>
* SolutionsInfini - <https://solutionsinfini.com>
* Plivo - <https://www.plivo.com>
* Callr - <https://www.callr.com>
* SMSAPI - <https://www.smsapi.com/en>
* OVH SMS PRO - <https://www.ovhtelecom.fr/sms>
* PromoSMS - <https://promosms.com>
* Infobip - <https://www.infobip.com>
* LabsMobile - <https://www.labsmobile.com>
* Tele2 Messaging - <https://portal.tele2messaging.com>

Please note: for these gateways you will need an account with sufficient credits.


Download
--------

The latest version can be downloaded from https://github.com/phpservermon/phpservermon/releases.


Requirements
------------

* Web server
* MySQL database
* For PHP5: 5.5.9+
* For PHP7: 7.0.8+
* PHP Extensions (modules)

  * ext-curl
  * ext-ctype
  * ext-filter
  * ext-hash
  * ext-json
  * ext-libxml
  * ext-openssl
  * ext-pdo
  * ext-pcre
  * ext-sockets
  * ext-xml

Install
-------

Please see docs/install.rst.
In a nutshell: unzip, upload, run install.php, enjoy.

If you have downloaded the source from GitHub (and not a pre-built package), the dependencies are not included.
To be able to run an installation from the repo, you need to run the following command to install the dependencies::

     php composer.phar install

If you are familiar with Vagrant (https://www.vagrantup.com)::

     vagrant up

.. and browse to http://localhost:8080/psm/.


Documentation
-------------

The documentation is available in the docs folder or https://docs.phpservermonitor.org.


License
-------

PHP Server Monitor is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

PHP Server Monitor is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with PHP Server Monitor.  If not, see https://www.gnu.org/licenses/.

Docker
-------

PHPServerMonitor is now available on Docker : https://github.com/phpservermon/docker-phpservermonitor