Formulate

A backend server application that listens for web form submissions, implemented with the rocket framework (0.5 release candidate). Minimum supported rust version (MSRV) is 1.65.0.

formulate is currently capable of using the host server's (or container's) built-in sendmail functionality to send email, after successfully receiving form data.

Configuration

Configuration is currenly very simple. Two email addresses, a sending_email and a destination_email are required. These email addresses may be set in the Rocket.toml configuration file (e.g. Rocket.toml.template).

Alternatively, two environment variables: FORM_SUBMISSION_destination_email and FORM_SUBMISSION_sending_email may be used to provide the values. Configuration overriding follows that of the Rocket framework, so if both the config file and environment variables are set, the environment variables take precedence.

destination_email should be the email address you would like the form submissions sent to.

sending_email is the address the emails will come from once delivered to your inbox. It is meant to be a stable address which you can use to filter your form submission emails. This "sending email" will be used in the email's 'From:' header.

Any replies will be set to the 'Reply-To' address, which will be the email address set by the form's user.

Relaying email

Another pair of configuration variables, mail_relay_host and mail_relay_port, are optional. These are used if relaying emails via the SMTP protocol is desired.

mail_relay_host defines the hostname for the relaying mail server. - May also be set using the FORM_SUBMISSION_mail_relay_host environment variable.

mail_relay_port defaults to port 25 if not set, and allows users to choose an alternate port which the mail relay is listening on. - May also be set using the FORM_SUBMISSION_mail_relay_port environment variable.

Accepted Form Fields

It accepts the following parameters, most of which are required:

After passing the email on to sendmail, formulate responds with appropriate HTTP status codes to indicate success or failure.

Successful URL-encoded or Multi-part submissions will be redirected to the URL defined in the from_site field when the redirect field is set to true. If redirect is omitted, or false, a message with an appropriate HTTP status is provided. On failure, a user readable error is provided, along with the appropriate HTTP status.

JSON form submissions receive a JSON response with appropriate success or failure messages and HTTP statuses.

Deployment

A Dockerfile is included in the git repository and may be used as a starting point for containerized deployments on Linux.

An rc script is also provided to aid in deployment on FreeBSD platforms.

Dependencies

A description of the project dependencies and some reasoning behind why they were added can be found in README.dependencies.