SQLPage can be configured through either environment variables
or a JSON file placed in sqlpage/sqlpage.json
.
You can find an example configuration file in sqlpage/sqlpage.json
.
Here are the available configuration options and their default values:
variable | default | description |
---|---|---|
listen_on |
0.0.0.0:8080 | Interface and port on which the web server should listen |
database_url |
sqlite://sqlpage.db?mode=rwc | Database connection URL, in the form dbengine://user:password@host:port/dbname . Special characters in user and password should be percent-encoded. |
database_password |
Database password. If set, this will override any password specified in the database_url . This allows you to keep the password separate from the connection string for better security. |
|
port |
8080 | Like listen_on, but specifies only the port. |
unix_socket |
Path to a UNIX socket to listen on instead of the TCP port. If specified, SQLPage will accept HTTP connections only on this socket and not on any TCP port. This option is mutually exclusive with listen_on and port . |
|
max_database_pool_connections |
PostgreSQL: 50 MySql: 75 SQLite: 16 MSSQL: 100 |
How many simultaneous database connections to open at most |
database_connection_idle_timeout_seconds |
SQLite: None All other: 30 minutes |
Automatically close database connections after this period of inactivity |
database_connection_max_lifetime_seconds |
SQLite: None All other: 60 minutes |
Always close database connections after this amount of time |
database_connection_retries |
6 | Database connection attempts before giving up. Retries will happen every 5 seconds. |
database_connection_acquire_timeout_seconds |
10 | How long to wait when acquiring a database connection from the pool before giving up and returning an error. |
sqlite_extensions |
An array of SQLite extensions to load, such as mod_spatialite |
|
web_root |
. |
The root directory of the web server, where the index.sql file is located. |
site_prefix |
/ |
Base path of the site. If you want to host SQLPage at https://example.com/sqlpage/ , set this to /sqlpage/ . When using a reverse proxy, this allows hosting SQLPage together with other applications on the same subdomain. |
configuration_directory |
./sqlpage/ |
The directory where the sqlpage.json file is located. This is used to find the path to templates/ , migrations/ , and on_connect.sql . Obviously, this configuration parameter can be set only through environment variables, not through the sqlpage.json file itself in order to find the sqlpage.json file. Be careful not to use a path that is accessible from the public WEB_ROOT |
allow_exec |
false | Allow usage of the sqlpage.exec function. Do this only if all users with write access to sqlpage query files and to the optional sqlpage_files table on the database are trusted. |
max_uploaded_file_size |
5242880 | Maximum size of forms and uploaded files in bytes. Defaults to 5 MiB. |
max_pending_rows |
256 | Maximum number of rendered rows that can be queued up in memory when a client is slow to receive them. |
compress_responses |
true | When the client supports it, compress the http response body. This can save bandwidth and speed up page loading on slow connections, but can also increase CPU usage and cause rendering delays on pages that take time to render (because streaming responses are buffered for longer than necessary). |
https_domain |
Domain name to request a certificate for. Setting this parameter will automatically make SQLPage listen on port 443 and request an SSL certificate. The server will take a little bit longer to start the first time it has to request a certificate. | |
https_certificate_email |
contact@<https_domain> | The email address to use when requesting a certificate. |
https_certificate_cache_dir |
./sqlpage/https | A writeable directory where to cache the certificates, so that SQLPage can serve https traffic immediately when it restarts. |
https_acme_directory_url |
https://acme-v02.api.letsencrypt.org/directory | The URL of the ACME directory to use when requesting a certificate. |
environment |
development | The environment in which SQLPage is running. Can be either development or production . In production mode, SQLPage will hide error messages and stack traces from the user, and will cache sql files in memory to avoid reloading them from disk. |
content_security_policy |
script-src 'self' 'nonce-XXX |
The Content Security Policy to set in the HTTP headers. If you get CSP errors in the browser console, you can set this to the empty string to disable CSP. |
system_root_ca_certificates |
false | Whether to use the system root CA certificates to validate SSL certificates when making http requests with sqlpage.fetch . If set to false, SQLPage will use its own set of root CA certificates. If the SSL_CERT_FILE or SSL_CERT_DIR environment variables are set, they will be used instead of the system root CA certificates. |
max_recursion_depth |
10 | Maximum depth of recursion allowed in the run_sql function. Maximum value is 255. |
Multiple configuration file formats are supported:
you can use a .json5
file, a .toml
file, or a .yaml
file.
All the parameters above can be set through environment variables.
The name of the environment variable is the same as the name of the configuration variable, but in uppercase.
The environment variable name can optionally be prefixed with SQLPAGE_
.
Additionnally, when troubleshooting, you can set the RUST_LOG
environment variable to sqlpage=debug
to get more detailed logs and see exactly what SQLPage is doing.
If you have a .env
file in the current directory or in any of its parent directories, SQLPage will automatically load environment variables from it.
The database_url
parameter sets all the connection parameters for the database, including
- the database engine type (
sqlite
,postgres
,mysql
,mssql
, etc.) - the username and password
- the host (or ip adress) and port
- the database name
- any additional parameters, including
mode=rwc
for SQLite to allow read-write connectionssslmode=require
(ordisable
,allow
,verify-ca
,verify-full
) for PostgreSQL to enable or disable SSLsslrootcert=/path/to/ca.pem
for PostgreSQL to specify the path to the CA certificate filesslcert=/path/to/cert.pem
to specify the path to the TLS client certificate file andsslkey=/path/to/key.pem
to specify the path to the TLS client key file for PostgreSQL and MySQL.application_name=my_application
for PostgreSQL to set the application name, which can be useful for monitoring and logging on the database server side.collation=utf8mb4_unicode_ci
for MySQL to set the collation of the connection
All the parameters need to be properly percent-encoded if they contain special characters like @
(%40
), :
(%3A
), /
(%2F
), ?
(%3F
), #
(%23
).
A full connection string for a PostgreSQL database might look like this:
postgres://my_user:p%40ss@localhost:5432/my_database?sslmode=verify-ca&sslrootcert=/path/to/ca.pem&sslcert=/path/to/cert.pem&sslkey=/path/to/key.pem&application_name=my_application
If the database_password
configuration parameter is set, it will override any password specified in the database_url
.
It does not need to be percent-encoded.
This allows you to keep the password separate from the connection string, which can be useful for security purposes, especially when storing configurations in version control systems.
DATABASE_URL="postgres://my_user@localhost:5432/my_database?sslmode=verify-ca&sslrootcert=/path/to/ca.pem"
DATABASE_PASSWORD="my_secure_password"
SQLITE_EXTENSIONS="mod_spatialite crypto define regexp"
SQLPage allows you to create custom components in addition to or instead of the default ones.
To create a custom component, create a .handlebars
file in the sqlpage/templates
directory of your SQLPage installation.
For instance, if you want to create a custom my_component
component, that displays the value of the my_column
column, create a sqlpage/templates/my_component.handlebars
file with the following content:
See the full custom component documentation.
SQLPage allows you to run a SQL script when a new database connection is opened,
by simply creating a sqlpage/on_connect.sql
file.
This can be useful to set up the database connection for your application.
For instance, on postgres, you can use this to set the search path
and various other connection options.
SET TIME ZONE 'UTC';
SET search_path = my_schema;
On SQLite, you can use this to ATTACH
additional databases.
ATTACH DATABASE '/path/to/my_other_database.db' AS my_other_database;
(and then, you can use my_other_database.my_table
in your queries)
You can also use this to create temporary tables to store intermediate results that are useful in your SQLPage application, but that you don't want to store permanently in the database.
CREATE TEMPORARY TABLE my_temporary_table(
my_temp_column TEXT
);
SQLPage allows you to run a SQL script after a request has been processed,
by simply creating a sqlpage/on_reset.sql
file.
This can be useful to clean up temporary tables, rollback transactions that were left open, or other resources that were created during the request.
You can also use this script to close database connections that are
in an undesirable state, such as being in a transaction that was left open.
To close a connection, write a select statement that returns a single row
with a single boolean column named is_healthy
, and set it to false.
You can automatically rollback any open transactions when a connection is returned to the pool, so that a new request is never executed in the context of an open transaction from a previous request.
For this to work, you need to create a sqlpage/on_reset.sql
containing the following line:
ROLLBACK;
Some databases allow you to clean up all the state associatPed with a connection.
By creating a sqlpage/on_reset.sql
file containing a DISCARD ALL
statement.
DISCARD ALL;
By creating a sqlpage/on_reset.sql
file containing a call to the sp_reset_connection
stored procedure.
EXEC sp_reset_connection;
SQLPage allows you to run SQL scripts when the database schema changes, by creating a sqlpage/migrations
directory.
We have a guide on how to create migrations.
By default, SQLPage encourages a simple mapping between the URL and the SQL file that is executed.
You can also create custom URL routes by creating 404.sql
files.
If you need advanced routing, you can also add a reverse proxy in front of SQLPage.