From f1cc88a0b1feb8baab43c9a5b16bd8f1a3f9c9a3 Mon Sep 17 00:00:00 2001 From: Adrian Amaglio Date: Fri, 1 May 2020 08:12:14 +0200 Subject: [PATCH] readme --- readme.md | 68 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 68 insertions(+) create mode 100644 readme.md diff --git a/readme.md b/readme.md new file mode 100644 index 0000000..06799ef --- /dev/null +++ b/readme.md @@ -0,0 +1,68 @@ +# Contact Mailer +A minimal python app to send mail when people fills in your contact form! + +## Why? + +Here at Jean-Cloud, we are fans of static websites. They are easily distributed, use few ressources and are very secured. + +But the first limitation is… No interractions… So no contact form… That would be a shame to deploy a website without a contact section! + +## How does it work? +### Create the contact form +- Create or reuse an existing contact form +- Add the `action` parameter to the mailer address + `/submit` +- Get a token from this mailer app and place it in your form like : +``` +
+ + + + + + +
+``` + +### Identifying on the mailer +Ask for an account to the mailer admin. + They will hand you a password like : `hepaNRSkqcxKD1QujwTr9I6XyiA7VOCGnsWbMtdlZJz0o8ULHP` + +### Configure the mail sending +You can choose how information sent with form will be displayed in the final mail! Actually there are two templatable fields: the mail subject and content. +Here is a template example : +``` +subject: "[Contact] {{nom|anonyme}} — {{object|no object}}" +content: "{{message}}" +``` +When the form will be submitted to the mailer, parts like `{{…}}` will be replaced by fields content of the same name! +If the field holds no value, two possibilities: +- The default value specified after `|` is used +- There is no default value, the form is rejected. +TIP: you can set an empty default value in order to have a facultative field: `{{name|}}`. + +## Installation +### Docker +`docker pull jeancloud/contact-mailer` +### Git & Pip in virtualenv +``` +git clone https://git.jean-cloud.net/adrian/contact-mailer +cd contact-mailer +virtualenv venv +. venv/bin/activate +pip install -r requirements.txt +``` + +## Running it +The app needs a lot of env vars to run : +``` +SMTP_SERVER_ADDRESS=mail.gandi.net +SMTP_SERVER_PORT=465 +SMTP_SSL=true +SMTP_SERVER_USERNAME=nepasrepondre@jean-cloud.org +SMTP_SERVER_PASSWORD=B9UZtOnIlJcRzx8mh2jCsPTQujwTr9I6XyiA +SMTP_SERVER_SENDER=nepasrepondre@jean-cloud.org +MONGODB_HOST=mongodb +ADMIN_PASSWORD=test +UID=1000 +``` +You can store them in a `.env` file. The python app will read it or you can pass it to the docker container with `run` option `--env-file`.