flexisip-account-manager/flexiapi
Timothée Jaussoin 8fd7e8adbf Add a captcha on subscription
Complete the documentation
Disable (for now) timestamps in Account
2020-09-14 11:24:59 +02:00
..
app Add a captcha on subscription 2020-09-14 11:24:59 +02:00
bootstrap Import a new API, build with Laravel 2020-02-03 15:20:48 +01:00
config Add Account creation 2020-09-14 11:24:59 +02:00
database Import a new API, build with Laravel 2020-02-03 15:20:48 +01:00
public Integrate FlexiAPI in the RPM package (logs, conf, env…) 2020-02-10 10:52:28 +01:00
resources Add a captcha on subscription 2020-09-14 11:24:59 +02:00
routes Add Account creation 2020-09-14 11:24:59 +02:00
storage Import a new API, build with Laravel 2020-02-03 15:20:48 +01:00
tests Integrate FlexiAPI in the RPM package (logs, conf, env…) 2020-02-10 10:52:28 +01:00
.editorconfig Import a new API, build with Laravel 2020-02-03 15:20:48 +01:00
.env.example Add a captcha on subscription 2020-09-14 11:24:59 +02:00
.gitattributes Import a new API, build with Laravel 2020-02-03 15:20:48 +01:00
.gitignore Import a new API, build with Laravel 2020-02-03 15:20:48 +01:00
.styleci.yml Import a new API, build with Laravel 2020-02-03 15:20:48 +01:00
artisan Import a new API, build with Laravel 2020-02-03 15:20:48 +01:00
composer.json Add a captcha on subscription 2020-09-14 11:24:59 +02:00
composer.lock Add a captcha on subscription 2020-09-14 11:24:59 +02:00
package.json Import a new API, build with Laravel 2020-02-03 15:20:48 +01:00
phpunit.xml Import a new API, build with Laravel 2020-02-03 15:20:48 +01:00
README.md Add a captcha on subscription 2020-09-14 11:24:59 +02:00
server.php Import a new API, build with Laravel 2020-02-03 15:20:48 +01:00
webpack.mix.js Import a new API, build with Laravel 2020-02-03 15:20:48 +01:00

FlexiAPI

This tool connects to the Flexisip CLI interface and exposes several endpoints to request and manage it.

Setup

Clone the repository, install the dependencies and generate a key.

composer install --no-dev
php artisan key:generate

Then configure the two databases connections in the .env file (from the .env.example one). And migrate the tables.

php artisan migrate

The local one (that is by default using SQLite) is used to store authentications sessions. The remote one should be configured to connect directly to the Flexisip database.

You can also run the test suit using phpunit.

To know more about the web server configuration part, you can directly visit the official Laravel installation documentation.

Configure the .env file

Complete all the other variables in the .env file:

  • The OVH SMS connector
  • SMTP configuration
  • App name, SIP domain…

SELinux

If you are running on a CentOS/RedHat machine, please ensure that SELinux is correctly configured.

Allow the webserver user to write in the storage/ directory:

chcon -R -t httpd_sys_rw_content_t storage/

If your external database is locate on a remote machine, you should also allow your webserver user to connect to remote hosts:

semanage port -a -t http_port_t -p tcp 3306 // Open remote connections on the MySQL port for example
setsebool httpd_can_network_connect 1 // Allow remote network connected
setsebool httpd_can_network_connect_db 1 // Allow remote database connection

CRON job

The DIGEST authentication method is saving some temporary information (nonces) in the database.

To expire and/or clear old nonces a specific command should be called periodically.

php artisan digest:expired-nonces-clear <minutes>

Usage

The root page contains all the required documentation to authenticate and request the API.