From b24a02f2157ba47824366331a3d7a027f3c75aae Mon Sep 17 00:00:00 2001 From: Erick Ruiz de Chavez Date: Sun, 4 Sep 2016 23:22:45 -0400 Subject: [PATCH] Improve summary Improved summary with some background of the project, configuration and usage details. --- README.md | 91 +++++++++++++++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 89 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 022abed..4bfb4fe 100644 --- a/README.md +++ b/README.md @@ -1,2 +1,89 @@ -# contact -A basic clone of formspree.io for internal use +# Contact + +## A basic node server for sending email forms. + +[Formspree.io](https://formspree.io/) is a great free service for sending email forms, specially for static web sites like those based on Jekyll. It gives your site the ability to send emails without having to code and run your own backend server, configure SMTP services, etc. **BUT** it might *not* be the best option for everyone. + +For me, 2 key factors drived me to create this clone: + + 1. Setup (and maintenance) should be minimal. + Formspree is opensource and it's code is on GitHub, but the setup process is way more than a trivial task, not to mention the requirements. Requirement 1 not met. + + 1. Should allow me to send attachments. + Formspree does not allow you to send email forms with attachments (at least not at the time when this written). Requirement 2 not met. + +Someone way smarter than me said, if there is nothing that solves your problem, code your solution, and so I did. + +**Contact** is a super basic Node.js application that enables you to send email forms with minimal configuration and, as a bonus, it follows almost the same fields and usage as Formspree with a few differences (all of them explained bellow). + +## Requirements + +- Node.js v6.0.0 or greater. +- A Mailgun account. + +## Installation + +Clone this repo on your server or download the zip file. + +Once you have the code, run `npn install --production` to download and install all the project dependencies required to run this project. + +Next step, configure your server. Open `config/config.yml` which should look like this: + +```yml +emails: +mailgun: + url: + key: +``` + +And update the values to match your preferences: + +- **emails** is an array of email addresses. This emails are the **ONLY** emails this server will be allowed to send emails to (authorized emails) +- **mailgun.ulr** your Mailgun API URL +- **mailgun.key** you Mailgun Domain API Key + +An example of a `config.yml` file: + +```yml +emails: + - sales@example.com + - contact@example.com + - support@example.com +mailgun: + url: https://api.mailgun.net/v3/example.com/messages + key: key-l0r3m1p5umd0l0r5174m37c0n53c737u +``` + +**Contact** uses **indecent.js** for loading YAML configuration files, this allows you to override the above settings based on the value of `NODE_ENV`. You can read more about that in the module site. + +## Server Usage + +To run the server, just run `node index.js`. You can use other node runners to keep the server always running like `forever` or `nodemon`. + +## Sending Emails + +Once your server is up and running, all you need to do is create an HTML form and point it to your server. Asumming your **contact** server is running in `example.com:8081`, A form would look like this: + +```html +
+ + + + + + +
+``` + +Your form's action should point to your **contact** server using a valid email address (defined in the YAML file). If the email address is not in the whitelist the email will not be sent. + +### Fields + +- **_from**: *Required*. This is usually the email address of the user submitting the email form. It will be used as the Form field. +- **_subject**: *Optional*. The email subject. +- **_info**: *Optional*. This text will be included in the email body before the values. Useful for providing some context in the email body. +- **_attachment**: *Optional*. A file can be attached to the email form using this for the name of an ``. When sending attachments do not forget to include `enctype="multipart/form-data"` in your form tag. +- **_next**: *Optional*. A URL to redirect the user once the form was submited succesfully. +- **_fake**: *For testing*. If `true`, the email will not be sent and instead a JSON paylod will be shown. Useful when testing the form with a REST client. + +All other form fields will be send by title casing the name. For example `` will be displayed in the email as "First Name:"