review docs

review docs
This commit is contained in:
Rodrigue Chakode 2020-05-24 01:52:15 +02:00
parent 69139b6afc
commit 8f4b5cfa4d
3 changed files with 113 additions and 103 deletions

202
README.md
View File

@ -1,72 +1,62 @@
![](https://img.shields.io/github/license/rchakode/hugo-mx-gateway.svg?label=License) ![](https://img.shields.io/github/license/rchakode/`hugo-mx-gateway`.svg?label=License)
[![Actions Status](https://github.com/rchakode/hugo-mx-gateway/workflows/Build/badge.svg)](https://github.com/rchakode/hugo-mx-gateway/actions) [![Actions Status](https://github.com/rchakode/`hugo-mx-gateway`/workflows/Build/badge.svg)](https://github.com/rchakode/`hugo-mx-gateway`/actions)
![](https://img.shields.io/docker/pulls/rchakode/hugo-mx-gateway.svg?label=Docker%20Pulls) ![](https://img.shields.io/docker/pulls/rchakode/`hugo-mx-gateway`.svg?label=Docker%20Pulls)
# Overview
In a nutshell, ``hugo-mx-gateway`` provides a RESTful POST endpoint for static contact/demo request pages. It's a simple, yet a powerful tool for this only-designed purpose.
![](`hugo-mx-gateway`-architecture-overview.png)
# Table of contents
- [Overview](#overview) - [Overview](#overview)
- [Table of contents](#table-of-contents)
- [Why `hugo-mx-gateway`](#why-hugo-mx-gateway)
- [How it Works](#how-it-works) - [How it Works](#how-it-works)
- [Screenshots](#screenshots) - [Prerequisites](#prerequisites)
- [Configuration variables](#configuration-variables) - [Deployment](#deployment)
- [Deployment options](#deployment-options)
- [Deployment on Google Appp Engine](#deployment-on-google-appp-engine) - [Deployment on Google Appp Engine](#deployment-on-google-appp-engine)
- [Before you begin](#before-you-begin)
- [Configure and deploy the App](#configure-and-deploy-the-app)
- [Deployment on a Kubernetes cluster](#deployment-on-a-kubernetes-cluster) - [Deployment on a Kubernetes cluster](#deployment-on-a-kubernetes-cluster)
- [Installation using Helm 3 (i.e. without tiller)](#installation-using-helm-3-ie-without-tiller)
- [Installation using Kubectl](#installation-using-kubectl)
- [Deployment on Docker](#deployment-on-docker) - [Deployment on Docker](#deployment-on-docker)
- [Test the App](#test-the-app) - [Create a Contact/Demo Request Form for Hugo](#create-a-contactdemo-request-form-for-hugo)
- [Samples of Hugo Contact Forms](#samples-of-hugo-contact-forms) - [Configuration variables](#configuration-variables)
- [Developers' corner](#developers-corner)
- [License & Copyrights](#license--copyrights) - [License & Copyrights](#license--copyrights)
- [Support & Contributions](#support--contributions) - [Support & Contributions](#support--contributions)
# Overview # Why `hugo-mx-gateway`
Did you ever experience building a static website (e.g. using [Hugo](https://gohugo.io/)) or whatever alternative, and stuck when coming the time to add a contact or a demo request form? Did you ever experience building a static website (e.g. using [Hugo](https://gohugo.io/) or whatever alternative), then did get stuck when coming the time to add a contact/demo request form?
You're at the place. You're at the right place.
`hugo-mx-gateway` provides a HTTP POST endpoint that can be bound to your HTML template to handle user contact and demo requests in a simple yet powerful way. This project, namely `hugo-mx-gateway`, is meant to provide a RESTful endpoint that adds the dynamicity required to handle contact/demo requests for static web sites. It's a simple, yet a powerful tool for this only-designated purpose.
## How it Works
`hugo-mx-gateway` is built upon a simple request form handling workflow:
* You create a HTML form with a POST action pointing towards the `hugo-mx-gateway` service.
* The `hugo-mx-gateway` service is a RESTful HTTP POST endpoint backed by an application easily deployable on [Google App Engine](https://cloud.google.com/appengine), on Kubernetes, or on Docker. Hereafter we also refer to it as **the App**.
* For each form request, the App retrieves information submitted by the user (email, subject, message details...), **automatically generates and sends a _templated email_ to the user**, while **bcc**ing a copy of that email to an address that you do define for tracking and follow up.
* Once a request is processed (upon success or failure), the App copes with the reply towards the origin web site (static page) by redirecting the browser to the request page with additionnal URL parameters describing the status of the processing (e.g. `/contact.html?status=success&message=request%20submitted`). With this, you can then add a few lines of Javascript to retrieve and display the reply message on the page.
* The App is shipped with a sample HTML form including some common fields for contact and demo requests, as well as a sample Javascript code to handle the processing response. That said, this is a open source software, so you're free to adapt it for your specific use cases.
## Screenshots
This screenshot show an example of a form successfully submitted and handled by the backend, which replied with the message in green.
![Screenshot of a successful submission](./screenshots/form-submitted-and-processed-with-success.png) ![Screenshot of a successful submission](./screenshots/form-submitted-and-processed-with-success.png)
# Configuration variables ## How it Works
According to your deployment approach (Google App Engine, Kubernetes or Docker), you must provide the following configuration parameters as environment variables: `hugo-mx-gateway` is built upon a simple request handling workflow:
* `SMTP_SERVER_ADDR`: Set the address of the SMTP server in the form of `host:port`. It's required that the SMTP server being supporting TLS. * Create an HTML form with a POST action pointing towards the `hugo-mx-gateway` service. This service is a RESTful HTTP POST endpoint backed by an application easily deployable on [Google App Engine](https://cloud.google.com/appengine), Kubernetes, and Docker engines.
* `SMTP_VERITY_CERT`: Tell if the `hugo-mx-gateway` App should validate the SMTP certificate against valid authorities. If you're using a self-signed certificate on the SMTP server, this value must be set to `false`. * For each form request, `hugo-mx-gateway` retrieves information submitted by the user (email, subject, message details...), then it **automatically generates and sends** a **templated email** towards the user-provided email address, while **bcc**ing a copy of that email to an address that you do define for internal tracking and follow up.
* `SMTP_CLIENT_USERNAME`: Set the username to connect to the SMTP server. * Once a request is processed (upon success or failure), `hugo-mx-gateway` copes with the reply towards the origin web site (static page) by redirecting the browser to the originated page with additional URL parameters describing the status of the processing (e.g. `/contact.html?status=success&message=request%20submitted`). With this, you can then add a few lines of Javascript to retrieve and display the reply message on the page.
* `SMTP_CLIENT_PASSWORD`: Set the password to connect to the SMTP server. * `hugo-mx-gateway` is shipped with a sample HTML form including some common fields for contact and demo requests, as well as a sample Javascript code to handle the processing response. That said, this is a open source software, so you're free to adapt it for your specific use cases.
* `CONTACT_REPLY_EMAIL`: Set an email address for the reply email. It's not necessary a valid email address, for example if don't want the user to reply you can use something like `noreply@example.com`.
* `CONTACT_REPLY_BCC_EMAIL`: Sets an email address for bcc copy of the email sent to the user. This is useful for tracking and follow up.
* `DEMO_URL`: Specific for demo forms, it can be used to set the URL of the demo site that will be included to the user reply email (e.g. `https://demo.example.com/`).
* `ALLOWED_ORIGINS`: Set a list of comma-separated domains that the `hugo-mx-gateway` App shoudl trust. This is for security reason to filter requests. Only requests with an `Origin` header belonging to the defined origins will be accepted, through it's only required that the request has a valid `Referer` header. It's expected in the future to these request filtering and admission rules.
* `TEMPLATE_DEMO_REQUEST_REPLY`: Specify the path of the email template to reply to demo requests. The default templare used in described in the file `templates/template_reply_demo_request.html`
* `TEMPLATE_CONTACT_REQUEST_REPLY`: Specify the path of the email template to reply to contact requests. The default templare used in described in the file `templates/template_reply_contact_request.html`.
# Deployment options ## Prerequisites
`hugo-mx-gateway` is deployable in minutes, subject to fillful the following requirements:
* Deployment platform: Google App Engine, a Kubernetes cluster, or a Docker machine.
* An SMTP account along with the server supporting TLS. While it can be tempting to use a personal account, it's highly recommended to not do that for an internet-hosted service. Therefore, according to your situation, you may need to ask for an SMTP account to your corporate's IT staff. If you're an individual or a small business, you can opt for a cloud-based SMTP service like SendGrid, Mailgun, and Mailjet--they all offer free tier for small usage.
# Deployment
`hugo-mx-gateway` is deployable in minutes on the following platforms:
* Google Appp Engine
* Kubernetes
* Docker
## Deployment on Google Appp Engine ## Deployment on Google Appp Engine
This requires to have an active GCP account.
### Before you begin * Make sure to have [Google Cloud SDK](https://cloud.google.com/sdk) (gcloud) installed on your work station.
To deploy the `hugo-mx-gateway` App on Google App Engine, make sure that you have a active GCP account and: * Create/select a GCP project to deploy `hugo-mx-gateway`. Note that each GCP project can hold only a single App Engine instance.
* Install the [Google Cloud SDK](https://cloud.google.com/sdk) (gcloud) installed on your work station.
* Create/select a GCP project to deploy the App. Note that each GCP project can hold only a single App Engine instance.
### Configure and deploy the App
* Create the Google App Engine configuration file * Create the Google App Engine configuration file
``` ```
cp app.yaml.sample app.yaml cp app.yaml.sample app.yaml
@ -77,54 +67,49 @@ To deploy the `hugo-mx-gateway` App on Google App Engine, make sure that you hav
``` ```
make deploy-gcp make deploy-gcp
``` ```
* Check that `hugo-mx-gateway` is up and functioning
On success the sendmail POST endpoint shall be reachable at the address: `https://<project_id>.<region>.r.appspot.com/sendmail` ```
curl https://PROJECT-ID.REGION.r.appspot.com/healthz
Replace: ```
* `<project_id>` with the GCP project ID. Replace `PROJECT-ID` with the GCP project ID, and `REGION` with the deployment region.
* `<region>` with the region of the App Engine instance.
## Deployment on a Kubernetes cluster ## Deployment on a Kubernetes cluster
<a name="deployment-on-a-kubernetes-cluster"></a> There is a [Helm chart](./helm/) to ease the deployment on Kubernetes clusters. This chart has been validated with Helm 3.
There is a [Helm chart](./helm/) to ease the deployment on Kubernetes using Helm or `kubectl`.
The Helm based deployment has been validated with Helm 3, i.e. without `Tiller`.
Either way, check the [values.yaml](./helm/values.yaml) file to set the [configuration options](#configuration-variables) according to your specific settings.
> **Security Context:**
> `hugo-mx-gateway`'s pod is deployed with a unprivileged security context by default. However, if needed, it's possible to launch the pod in privileged mode by setting the Helm configuration value `securityContext.enabled` to `false`.
In the next deployment commands, it's assumed that the target namespace `hugo-mx-gateway` does exist. Otherwise create it first, or, alternatively, adapt the commands to use any other namespace of your choice.
### Installation using Helm 3 (i.e. without tiller)
<a name="installation-using-helm-3-ie-without-tiller"></a>
Helm 3 does not longer require to have [`tiller`](https://v2.helm.sh/docs/install/).
As a consequence the below command shall work with a fresh installation of `hugo-mx-gateway` or a former version installed with Helm 3. There is a [known issue](https://github.com/helm/helm/issues/6850) when there is already a version **not** installed with Helm 3.
* Note that the `hugo-mx-gateway`'s pod is run in an unprivileged mode with a **Security Context**.
* First check the Helm's [values.yaml](./helm/values.yaml) file to set [configuration options](#configuration-variables) appropriately.
* Choose the deployment namespace. In the deployment commands hereafter, it's assumed that the target namespace is `hugo-mx-gateway`. If you opt for another namespace, do consider to adapt the commands accordingly.
* Deployment with Helm (validated with Helm 3)
``` ```
helm upgrade --namespace hugo-mx-gateway --install hugo-mx-gateway helm/ helm upgrade \
--namespace hugo-mx-gateway \
--install hugo-mx-gateway \
helm/
```
* Installation using Kubectl (if not using Helm). The Helm client is required to generate a raw template for kubectl.
```
$ helm template \
hugo-mx-gateway \
--namespace hugo-mx-gateway \
helm/ | \
kubectl apply -f -
``` ```
### Installation using Kubectl * Check that the Service is up and running.
<a name="installation-using-kubectl"></a>
This approach requires to have the Helm client (version 2 or 3) installed to generate a raw template for kubectl.
``` ```
$ helm template hugo-mx-gateway --namespace hugo-mx-gateway helm/ | kubectl apply -f - kubectl -nhugo-mx-gateway port-forward service/hugo-mx-gateway 8080:80
curl https://127.0.0.1:8080/healthz
``` ```
## Deployment on Docker ## Deployment on Docker
`hugo-mx-gateway` is released as a Docker image. So you can quickly start an instance of the service by running the following command: `hugo-mx-gateway` is released as a Docker image, so you can quickly start an instance in any machine running Docker.
An instance can be started with the next command; please consider to adapt the [configuration variables](#configuration-variables) appropriately.
``` ```
$ docker run -d \ $ docker run -d \
--publish 8080:8080 \ --publish 8080:8080 \
--name 'hugo-mx-gateway' \ --name '`hugo-mx-gateway`' \
-e SMTP_SERVER_ADDR="smtp.example.com:465" \ -e SMTP_SERVER_ADDR="smtp.example.com:465" \
-e SMTP_VERITY_CERT=true \ -e SMTP_VERITY_CERT=true \
-e SMTP_CLIENT_USERNAME="postmaster@example.com" \ -e SMTP_CLIENT_USERNAME="postmaster@example.com" \
@ -133,31 +118,56 @@ $ docker run -d \
-e CONTACT_REPLY_BCC_EMAIL="contact@example.com" \ -e CONTACT_REPLY_BCC_EMAIL="contact@example.com" \
-e DEMO_URL="https://demo.example.com/" \ -e DEMO_URL="https://demo.example.com/" \
-e ALLOWED_ORIGINS="127.0.0.1,example.com" \ -e ALLOWED_ORIGINS="127.0.0.1,example.com" \
rchakode/hugo-mx-gateway rchakode/`hugo-mx-gateway`
``` ```
In this command, you SHOULD adapt the values of configuration variables as described [here](#configuration-variables). Check that `hugo-mx-gateway` is up and functionning.
## Test the App
``` ```
curl -H'Origin: http://example.com' \ curl https://127.0.0.1:8080/healthz
-H'Referer: example.com' \
-H'Content-Type: application/x-www-form-urlencoded' \
-d 'target=contact' \
-XPOST https://<project_id>.<region>.r.appspot.com/sendmail
``` ```
# Samples of Hugo Contact Forms # Create a Contact/Demo Request Form for Hugo
See in `./samples/`. The file `./samples/hugo-partial-contact-form.html` contains a sample HTML form for Hugo. It can be used for both contact and demo requests.
Open the file in a your favorite editor and review it.
Notice that the form is configured to be rendered specifically according to a Hugo parameter named **tags**, which is actually a **list of tags**. If the parameter holds a tag named `contact` then, the form will be rendered as a contact form. Otherwise, it'll be rendered as a demo form.
The integration works as follows:
* Copy the HTML form content in your target **Hugo HTML template**.
* Modify the **<form>** HTML tag to make the **action** point to the URL of the sendmail backend deployed previously.
* On Google App Engine, the endpoint shall be: https://PROJECT-ID.REGION.r.appspot.com/sendmail. Replace `PROJECT-ID` and `REGION`, repectively, with the GCP's project ID and the deployment region.
* On Kubernetes, the in-cluster endpoint shall be: http://`hugo-mx-gateway`.`hugo-mx-gateway`.svc.cluster.local/sendmail
* On Docker, the endpoint shall be: http://DOCKER-HOST:8080/sendmail. Replace `DOCKER-HOST` with the IP adress or the hostname of the Docker machine.
* Edit the **Hugo Markdown content** of the target contact/demo page to ensure that the **tags** parameter holds a appropriate value (i.e. `contact` for a contact form, or `demo` for a demo request form).
Here is an example of header for a Hugo Markdown page. Since the `tags` parameter holds a tag named `contact`), the page will be rendered as a contact request form.
# Developers' corner
To build the stack
``` ```
make build ---
title: "Contact Us"
description: "Contact request page"
date: 2020-04-25T00:20:27+02:00
tags: [contact]
---
``` ```
# Configuration variables
According to the deployment platform (Google App Engine, Kubernetes, Docker), the following configuration parameters must be provided as environment variables:
* `SMTP_SERVER_ADDR`: Set the address of the SMTP server in the form of `host:port`. It's required that the SMTP server being supporting TLS.
* `SMTP_VERITY_CERT`: Tell whether the SMTP certificate should be validated against top level authorities. If you're using a self-signed certificate on the SMTP server, this value must be set to `false`.
* `SMTP_CLIENT_USERNAME`: Set the username to connect to the SMTP server.
* `SMTP_CLIENT_PASSWORD`: Set the password to connect to the SMTP server.
* `CONTACT_REPLY_EMAIL`: Set an email address for the reply email. It's not necessary a valid email address, for example if don't want the user to reply you can use something like `noreply@example.com`.
* `CONTACT_REPLY_BCC_EMAIL`: Sets an email address for bcc copy of the email sent to the user. This is useful for tracking and follow up.
* `DEMO_URL`: Specific for demo forms, it can be used to set the URL of the demo site that will be included to the user reply email (e.g. `https://demo.example.com/`).
* `ALLOWED_ORIGINS`: Set a list of comma-separated domains that the `hugo-mx-gateway` App shoudl trust. This is for security reason to filter requests. Only requests with an `Origin` header belonging to the defined origins will be accepted, through it's only required that the request has a valid `Referer` header. It's expected in the future to these request filtering and admission rules.
* `TEMPLATE_DEMO_REQUEST_REPLY` (optional): Specify the path of the template to reply a demo request. The default templare is `templates/template_reply_demo_request.html`
* `TEMPLATE_CONTACT_REQUEST_REPLY` (optional): Specify the path of the template to reply a contact request. The default templare is `templates/template_reply_contact_request.html`.
# License & Copyrights # License & Copyrights
This tool (code and documentation) is licensed under the terms of Apache 2.0 License. Read the [LICENSE](LICENSE) file for more details on the license terms. This tool (code and documentation) is licensed under the terms of Apache 2.0 License. Read the [LICENSE](LICENSE) file for more details on the license terms.
@ -166,7 +176,7 @@ The tool may inlcude third-party libraries provided with their owns licenses and
# Support & Contributions # Support & Contributions
We encourage feedback and do make our best to handle any troubles you may encounter when using this tool. We encourage feedback and do make our best to handle any troubles you may encounter when using this tool.
Here is the link to submit issues: https://github.com/rchakode/hugo-mx-gateway/issues. Here is the link to submit issues: https://github.com/rchakode/`hugo-mx-gateway`/issues.
New ideas are welcomed, please open an issue to submit your idea if you have any one. New ideas are welcomed, please open an issue to submit your idea if you have any one.

View File

@ -1,5 +1,5 @@
runtime: go112 runtime: go112
version: v0.1.0
env_variables: env_variables:
TEMPLATE_DEMO_REQUEST_REPLY: templates/template_reply_demo_request.html TEMPLATE_DEMO_REQUEST_REPLY: templates/template_reply_demo_request.html
TEMPLATE_CONTACT_REQUEST_REPLY: templates/template_reply_contact_request.html TEMPLATE_CONTACT_REQUEST_REPLY: templates/template_reply_contact_request.html

Binary file not shown.

After

Width:  |  Height:  |  Size: 82 KiB