Skip to content
  • Our Product
    • Namazu Elements
      • What is Elements?
      • Why open source?
      • Docs
        • Namazu Elements in Five Minutes or Less
        • RESTful APIs Library
        • Security Model
        • Accessing the Web UI (CMS)

    Our Product

    A logomark with three layered rhombuses adorning the lettermark that says Elements in bold all-caps sans-serif letters.
    • What is Namazu Elements? Discover our easy-to-use backend network solution built for online games. Rapidly enables full-scale multiplayer games or online solo adventures.
    • Why open source? Is there a truly open source server backend for connected games? There is now. Download and run a local copy of Namazu Elements and try it for yourself.
    Download Namazu Elements

    Get started

    • Quick start Read our Elements 5-minute quick start guide
    • Documentation Read our developer docs for learning more about Elements
    • RESTful APIs A full list of core API specs for working with the Elements framework
    • Security An overview of the server-authoritative security model of Elements
    • Accessing the CMS Manage your game with ease via the Namazu Elements CMS.

    Co-development Reimagined

    • Best real-time game backends in 2026 If you're researching an alternative to your current backend solution, we've prepared a report of all of the backend solutions on the market in 2026 and how Namazu Elements compares.
      Co-dev

    Recent Posts

    • The watercolor-styled Namazu Studios logo over a giant namazu lurking in the depth
      Namazu Studios Featured in San Diego Business Journal
      22 Sep 2025 Press
    • Namazu Elements 3.1 Released – Service Layer Fixes, Secure APIs, and Steam Bug Fix
      22 Apr 2025 Release Notes
  • Case Studies
  • About Us
  • News
  • Services
  • Book a call
namazu-studios-logo
Book a call

Getting Started

  • Namazu Elements in Five Minutes or Less
  • Accessing the Web UI (CMS)
  • CMS Feature Overview

Fundamentals

  • Why You Need a Server (and What “Authoritative” Means)
  • Elements as a Game Runtime
  • Where Your Authoritative Code Runs
  • Lifecycles and Flows

General Concepts

  • Overview
  • Custom Elements
  • Data Models
  • Security Model
  • N-Tier Architecture

Namazu Elements Core Features

  • User Authentication / Sign In
    • What is a User?
    • User Authentication in Elements
    • Auth Schemes
      • Auth Schemes
      • OAuth2
      • OIDC
  • Features
    • Applications
    • Sessions
    • Users and Profiles
    • Digital Goods
    • Progress and Missions
    • Progress and Missions (3.4+)
    • Leaderboards
    • Matchmaking – Comprehensive Guide
    • Followers
    • Friends
    • Product Bundles and SKUs
    • Receipts
    • Reward Issuances
    • Save Data
    • Metadata
    • Metadata (3.4+)
    • Email Service
    • Queries
    • Web3
      • Wallets
      • Vaults
      • Omni Chain Support
      • Smart Contracts
        • Smart Contracts
  • Queries
    • Advanced Operators
    • Object Graph Navigation
    • Boolean Queries
    • Base Query Syntax
  • Advanced Operators
    • .name
    • .ref

Your Game Code - Adding Custom Elements

  • Custom Code Overview
  • Windows Setup
  • Mac OS Setup
  • Ubuntu Linux Setup
  • Element Anatomy: A Technical Deep Dive
  • Introduction to Guice and Jakarta in Elements
  • Structuring your Element
  • Events
  • Packaging an Element with Maven
  • Deploying an Element
  • Preparing for code generation
  • Properties
  • Websockets
  • RESTful APIs
  • Direct MongoDB Access (3.5+)

Configuration

  • Matchmaking – Comprehensive Guide
  • Direct Database Access and Batch Configuration
  • Batch Samples
    • Mission Upload Bash Script Sample
    • Item Upload Bash Script Sample

RESTful APIs

  • Importing into Postman
  • RESTful APIs Library
  • Swagger and Swagger UI

Add-Ons

  • Crossplay
    • Namazu Crossfire (Multiplayer)
    • Deploying Namazu Crossfire in your game
  • Roblox
    • Roblox Overview
    • Secure Player Authentication & Registration
    • Global Matchmaking
    • Roblox Security Best Practices

Game Engine & Client Support

  • Unity
    • Elements Unity Plugin
    • Unity Crossfire Plugin

Troubleshooting

  • Common Issues with Docker
  • Local SDK
    • Unable to deploy application : dev.getelements.elements.sdk.exception.SdkElementNotFoundException
    • Could not load class : java.lang.NoClassDefFoundError
  • Namazu Elements Community Edition
    • Common Issues with Docker
    • Unable to deploy application : dev.getelements.elements.sdk.exception.SdkElementNotFoundException
    • Running in the IDE
      • Exception in monitor thread while connecting to server localhost:27017
      • Could not deployAvailableApplications Jetty server Failed to bind to /0.0.0.0:8080 Address already in use

Releases

  • 3.6 Release Notes
  • 3.5 Release Notes
  • 3.4 Release Notes
  • 3.3 Release Notes
  • 3.2 Release Notes
  • 3.1 Release Notes
View Categories
  • Home
  • Docs
  • Namazu Elements Core Features
  • Features
  • Email Service

Email Service

Est. read time: 5 min read

Elements version 3.8+

EmailService is a first-class platform service for sending transactional email via SMTP. It is available to platform code through normal Guice injection and to plugin developers through the built-in email-element ELM.


Interface #

package dev.getelements.elements.sdk.service.email;

public interface EmailService {
    void send(String from, String to, String subject, String body, boolean html);
}
ParameterDescription
fromSender address. Pass null or blank to use the configured DEFAULT_FROM.
toRecipient address.
subjectSubject line.
bodyMessage body – plain text or HTML depending on the html flag.
htmltrue -> text/html 
false -> text/plain

Throws InvalidDataException if SMTP is not configured (i.e. SMTP_HOST is blank).


Platform configuration #

Configure the platform-level SMTP connection via system defines (JVM properties or environment variables). These apply to the entire server and to any code running outside an element context.

Constant keyDefaultDescription
dev.getelements.elements.email.smtp.host(blank – disabled)SMTP hostname. Leave blank to disable email at the platform level.
dev.getelements.elements.email.smtp.port587SMTP port.
dev.getelements.elements.email.smtp.starttlstrueEnable STARTTLS.
dev.getelements.elements.email.smtp.user(blank)SMTP username.
dev.getelements.elements.email.smtp.password(blank)SMTP password.
dev.getelements.elements.email.default.from(blank)Default sender address used when from is null.

Example (passing as JVM system properties on startup):

-Ddev.getelements.elements.email.smtp.host=smtp.sendgrid.net
-Ddev.getelements.elements.email.smtp.port=587
-Ddev.getelements.elements.email.smtp.starttls=true
-Ddev.getelements.elements.email.smtp.user=apikey
-Ddev.getelements.elements.email.smtp.password=SG.xxxxx
-Ddev.getelements.elements.email.default.from=noreply@mygame.com

Using EmailService in platform code #

Once SMTP is configured, inject EmailService anywhere in the platform service layer:

import dev.getelements.elements.sdk.service.email.EmailService;
import jakarta.inject.Inject;

public class MyPlatformService {

    private EmailService emailService;

    public void notifyUser(String userEmail, String message) {
        emailService.send(null, userEmail, "Notification", message, false);
    }

    @Inject
    public void setEmailService(EmailService emailService) {
        this.emailService = emailService;
    }
}

For UNSCOPED platform code inject with @Named(Constants.UNSCOPED):

@Inject @Named(Constants.UNSCOPED)
public void setEmailService(EmailService emailService) { ... }

Using EmailService inside a custom Element #

Elements access EmailService through the email-element built-in ELM. It provides an element-scoped SMTP connection configured independently from the platform, so different game Elements can each use a different mail provider or sender identity.

Step 1 – declare email-element as a dependency #

In your Element deployment’s Additional Elements configuration, add email-element (using the deployed artifact ID). When the platform loads your element, email-element is loaded first as a dependency and its EmailService binding is available to your element’s Guice child injector.

Alternatively, if you manage deployments via the API:

{
  "elements": [
    { "groupId": "dev.getelements.elements", "artifactId": "email-element" }
  ]
}

Step 2 – configure SMTP attributes on the deployment #

Set the SMTP attributes on your element’s deployment record. These are resolved from the element’s Attributes at load time and override the platform defaults.

Attribute keyRequired
dev.getelements.elements.email.smtp.hostYes (leave blank to disable)
dev.getelements.elements.email.smtp.portNo (default: 587)
dev.getelements.elements.email.smtp.starttlsNo (default: true)
dev.getelements.elements.email.smtp.userYes (for authenticated SMTP)
dev.getelements.elements.email.smtp.passwordYes (for authenticated SMTP)
dev.getelements.elements.email.default.fromRecommended

Via the REST API:

PUT /api/rest/element/deployment/{id}
Content-Type: application/json

{
  "pathAttributes": {
    "dev.getelements.elements.email.smtp.host":     "smtp.mailgun.org",
    "dev.getelements.elements.email.smtp.port":     "587",
    "dev.getelements.elements.email.smtp.starttls": "true",
    "dev.getelements.elements.email.smtp.user":     "postmaster@mg.mygame.com",
    "dev.getelements.elements.email.smtp.password": "key-xxxxx",
    "dev.getelements.elements.email.default.from":  "noreply@mygame.com"
  }
}

Step 3 – inject and use EmailService in your element #

import dev.getelements.elements.sdk.service.email.EmailService;
import jakarta.inject.Inject;

public class WelcomeEmailService {

    private EmailService emailService;

    public void sendWelcome(String toAddress, String displayName) {
        final var body = "<h2>Welcome, " + displayName + "!</h2>"
                       + "<p>Thanks for joining. Good luck out there.</p>";
        emailService.send(null, toAddress, "Welcome to the game!", body, true);
    }

    @Inject
    public void setEmailService(EmailService emailService) {
        this.emailService = emailService;
    }
}

Register this service in your element’s @GuiceElementModule:

public class MyGameElementModule extends AbstractModule {
    @Override
    protected void configure() {
        bind(WelcomeEmailService.class);
        // EmailService and MailSessionProvider are provided by email-element
    }
}

Graceful degradation #

If SMTP_HOST is blank the MailSessionProvider logs a warning and returns null. Any call to EmailService.send() then throws InvalidDataException with the message "Email service is not configured (SMTP_HOST is blank)." – no NPE, no silent failure.

This means you can deploy your element and configure SMTP later without crashing the server on startup.


Overriding the mail transport (advanced) #

To use a custom transport (e.g. a cloud-native SDK instead of SMTP), rebind MailSessionProvider in your element module:

public class MyGameElementModule extends AbstractModule {
    @Override
    protected void configure() {
        bind(MailSessionProvider.class).to(MyCustomMailSessionProvider.class);
        bind(EmailService.class).to(DefaultEmailService.class);
    }
}

MailSessionProvider extends jakarta.inject.Provider<jakarta.mail.Session>. Return a Session configured with a custom Transport implementation registered via the standard Jakarta Mail Provider SPI.

What are your Feelings
Still stuck? How can we help?

How can we help?

Updated on March 30, 2026
Metadata (3.4+)Queries
Table of Contents
  • Interface
  • Platform configuration
  • Using EmailService in platform code
  • Using EmailService inside a custom Element
    • Step 1 - declare email-element as a dependency
    • Step 2 - configure SMTP attributes on the deployment
    • Step 3 - inject and use EmailService in your element
  • Welcome, " + displayName + "!
  • Graceful degradation
  • Overriding the mail transport (advanced)
  • Documentation
  • Terms of Service
  • Privacy Policy
  • Contact us
  • Linkedin
  • Join our Discord

Namazu Studios LLC is powered by Namazu Elements, an open source modular backend framework for connected games.

Namazu Elements
  • Download
  • About Elements
  • Open source
  • Documentation
  • Support
Namazu Studios
  • Case Studies
  • About Us
  • News
Best realtime game backends 2026
Get in Touch
  • info@namazustudios.com
  • Book a call
  • (619) 862-2890
  • Linkedin
  • Discord

©2008-2026 Namazu Studios. All Rights Reserved.