Fork of https://github.com/rchakode/hugo-mx-gateway Contact form API for static websites
Go to file
Rodrigue Chakode dccdd6a8d3
Update README.md
2021-12-07 20:23:43 +01:00
.github/workflows Fixed a CI file 2021-09-10 10:22:26 +02:00
helm set version to 0.1.0 2020-05-31 15:27:40 +02:00
samples improvement of the contact form processing: 2021-10-26 20:14:24 +02:00
screenshots review docs 2020-06-13 12:22:01 +02:00
templates improved contact email template 2020-08-20 09:42:49 +02:00
vendor add go-recaptcha dependency 2020-06-02 20:05:21 +02:00
.dockerignore added dockerfile 2020-05-17 19:08:05 +02:00
.gcloudignore review docs 2020-06-13 12:22:01 +02:00
.gitignore ignore IntelliJ IDEA stuff 2020-06-02 15:31:52 +02:00
Dockerfile added healthz endpoint, misc improvements and docs review 2020-05-24 00:44:40 +02:00
LICENSE added LICENSE 2020-05-17 19:08:22 +02:00
Makefile fixed docker build on Github actions 2020-05-31 16:07:00 +02:00
README.md Update README.md 2021-12-07 20:23:43 +01:00
app.yaml.sample Updated app.yaml.sample 2021-09-14 23:37:07 +02:00
entrypoint.sh added healthz endpoint, misc improvements and docs review 2020-05-24 00:44:40 +02:00
go.mod use log instead of logrus for logging 2021-09-19 22:49:48 +02:00
go.sum use log instead of logrus for logging 2021-09-19 22:49:48 +02:00
healthz.go added healthz endpoint, misc improvements and docs review 2020-05-24 00:44:40 +02:00
hugo-mx-gateway-architecture-overview.png review docs 2020-05-31 13:46:26 +02:00
main.go use log instead of logrus for logging 2021-09-19 22:49:48 +02:00
sendmail.go improvement of the contact form processing: 2021-10-26 20:14:24 +02:00

README.md

Actions Status

Table of Contents

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 built for this only-designated purpose.

While this project is already deployed in production for several websites, the documentation may still contain misspellings or typos. Contributions in any form (code/docs/ideas...) are welcomed.

Why hugo-mx-gateway

Did you ever experience building a static website (e.g. using Hugo or whatever alternative), then did get stuck when coming the time to add a contact/demo request form?

You're at the right place.

This project, namely hugo-mx-gateway, is meant to provide a RESTful API that adds the dynamicity required to handle contact/demo requests for static web sites. It's a simple, yet a powerful tool built for this only-designated purpose.

Screenshot of a successful submission

How does it work

hugo-mx-gateway is built upon a simple request handling workflow:

  • Create an HTML form with a POST action pointing towards the hugo-mx-gateway service. This service enables a RESTful POST endpoint backed by an application built in Go. The application is released as container image along with manifests to ease deployment on Google App Engine, Kubernetes, and Docker environments.
  • For each user request, hugo-mx-gateway automatically retrieves information submitted by the user (email, subject, message details...), then generates and sends a templated email (based on Go Template) to the user-provided email address, while bccing a copy of that email to an address that you can define for internal tracking and follow up.
  • Once a request is processed (upon success or failure), hugo-mx-gateway handles the reply back towards the calling static page by redirecting the browser to the origin page with additional URL parameters describing the completion status of the processing (e.g. /contact.html?status=success&message=request%20submitted). The parameters can then be easily retrieved and shown to the user, e.g. with a few lines of Javascript within the static page.
  • The project is shipped with a sample HTML form intending to cover a basic use case of contact and demo requests. That said, this is a open source software, so you're free to adapt it for your specific use cases.

Prerequisites

hugo-mx-gateway is easily deployable in minutes, subject to fulfil the following requirements:

  • Deployment platform (at your choice): Google App Engine, Kubernetes, or Docker.
  • An SMTP account with the server supporting TLS.

These are basic requirements in the today's Internet world.

While it can be tempting to use a personal email account, it's highly recommended for security and privacy reasons to not do that. According to your needs, you may have to ask for an SMTP account to your corporate's IT staff. When applicable, you can alternatively opt for a cloud-based SMTP service like SendGrid, Mailgun or Mailjet, which typically offer free tier for small usage.

Deployment

Consider one of the following resources according to the selected installation platform.

Deployment on Google App Engine

This requires to have an active GCP account and Google Cloud SDK (gcloud) installed on your work station.

  • Create/select a GCP project to deploy hugo-mx-gateway.

    Note that each GCP project can hold only a single App Engine instance. Several applications can be co-hosted as services for the root App Engine instance. In this case, a new application has to be declared as service in the app.yaml file.

  • Create the Google App Engine configuration file

    cp app.yaml.sample app.yaml
    
  • Open the app.yaml file with your favorite editor.

  • Edit the configuration variables as described here.

  • Start the deployment

    make deploy-gcp
    
  • Check that hugo-mx-gateway is up and working

    curl https://PROJECT-ID.REGION.r.appspot.com/ 
    {"status": "ok"}
    

    Replace PROJECT-ID with the GCP project ID, and REGION with the deployment region.

Deployment on a Kubernetes cluster

There is a Helm chart to ease the deployment on Kubernetes clusters.

Important: The chart is validated with Helm 3 and the pod is run in an unprivileged mode within a Security Context.

Proceed with the deployment as follows:

  • First edit the values.yaml file to set configuration values appropriately.

  • Choose a deployment namespace. In the sample commands provided 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.

  • Apply the deployment with Helm

    helm upgrade \
      --namespace hugo-mx-gateway \
      --install hugo-mx-gateway \
      helm/
    
  • Check that the application is up and running.

    kubectl -n hugo-mx-gateway port-forward service/hugo-mx-gateway 8080:80
    curl http://127.0.0.1:8080/
    {"status": "ok"}
    

Deployment on Docker

An instance of hugo-mx-gateway can be quickly started on any machine running Docker.

  • Please first review the configuration variables and adapt them appropriately.

  • Then apply the following command:

    $ docker run -d \
      --publish 8080:8080 \
      --name 'hugo-mx-gateway' \
      -e SMTP_SERVER_ADDR="smtp.example.com:465" \
      -e SMTP_VERITY_CERT=true \
      -e SMTP_CLIENT_USERNAME="postmaster@example.com" \
      -e SMTP_CLIENT_PASSWORD="postmasterSecretPassWord" \
      -e CONTACT_REPLY_EMAIL="noreply@example.com" \
      -e CONTACT_REPLY_BCC_EMAIL="contact@example.com" \
      -e DEMO_URL="https://demo.example.com/" \
      -e ALLOWED_ORIGINS="127.0.0.1,example.com" \
      rchakode/hugo-mx-gateway
    
  • Check that the container is up and functionning.

    curl http://127.0.0.1:8080/ 
    {"status": "ok"}
    

Use the built-in form for Hugo

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 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> tag to make the action point to the URL of the sendmail backend deployed previously.
  • 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. The tags parameter holds a tag named contact) meaning that the page will be rendered as a contact request form.

---
title: "Contact Us"
description: "Contact request page"
date: 2020-04-25T00:20:27+02:00
tags: [contact]
---

Configuration variables

Regardless of 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 the email, you can set 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 list of domains that the hugo-mx-gateway App should trust. For security reason, only requests with an Origin header belonging to the defined list of origins will be accepted.
  • RECAPTCHA_PRIVATE_KEY (optional): The reCaptcha private key.
  • 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. The template is based on Go Template.
  • 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. The template is based on Go Template.

License & Copyrights

This tool (code and documentation) is licensed under the terms of Apache 2.0 License. Read the LICENSE file for more details on the license terms.

The tool may inlcude third-party libraries provided with their owns licenses and copyrights, but always compatible with the Apache 2.0 License terms of use.

Support & Contributions

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.

New ideas are welcomed, please open an issue to submit your idea if you have any one.

Contributions are accepted subject that the code and documentation be released under the terms of Apache 2.0 License.

To contribute bug patches or new features, please use the Github Pull Request model.