Skip to content

Latest commit

 

History

History

send_email_with_mailgun

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 

📧 Sending Welcome Emails using Mailgun's Email API

A sample NodeJS Cloud Function for sending emails using the Mailgun API.

Example input:

{
    "name": "John Doe",
    "email": "johndoe@gmail.com"
}

Example output:

{"id":"<xxxxxxxxx.xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx.mailgun.org>","message":"Queued. Thank you."}

📝 Environment Variables

List of environment variables used by this cloud function:

  • MAILGUN_API_KEY - API Key for Mailgun
  • MAILGUN_DOMAIN - Domain Name from Mailgun

🚀 Deployment

  1. Clone this repository, and enter this function folder:
$ git clone https://github.com/open-runtimes/examples.git && cd examples
$ cd node/send_email_with_mailgun
  1. Enter this function folder and build the code:
docker run --rm --interactive --tty --volume $PWD:/usr/code openruntimes/node:v2-17.0 sh /usr/local/src/build.sh

As a result, a code.tar.gz file will be generated.

  1. Start the Open Runtime:
docker run -p 3000:3000 -e INTERNAL_RUNTIME_ENTRYPOINT=src/index.js -e INTERNAL_RUNTIME_KEY=secret-key --rm --interactive --tty --volume $PWD/code.tar.gz:/tmp/code.tar.gz:ro openruntimes/node:v2-17.0 sh /usr/local/src/start.sh

Your function is now listening on port 3000, and you can execute it by sending POST request with appropriate authorization headers. To learn more about runtime, you can visit NodeJS runtime README.

📝 Notes

  • This function is designed for use with Appwrite Cloud Functions. You can learn more about it in Appwrite docs.
  • This example is compatible with NodeJS 17.0. Other versions may work but are not guarenteed to work as they haven't been tested.