Envio de Emails
Antes de começar
Antes de proceder certifique-se que que tem noções básicas em JavaScript e que já tem as noções básicas do Netuno com o passo-a-passo disponível na Academia.
Demonstração do Envio de Emails
Com o Netuno é muito simples enviar emails, seja com anexos ou imagens embutidas no próprio conteúdo (útil no caso de assinaturas).
A aplicação que vem com o Netuno denominada demo (aplicação de demonstração) contém bastantes exemplos das possíveis implementações de código em várias linguagens, incluindo a demonstração de envio de emails através do serviço mail-send
que se localiza em:
/apps/demo/server/services/samples/groovy/mail-send.groovy
/apps/demo/server/services/samples/javascript/mail-send.js
/apps/demo/server/services/samples/kotlin/mail-send.kts
/apps/demo/server/services/samples/python/mail-send.py
/apps/demo/server/services/samples/ruby/mail-send.rb
Configuração
O primeiro passo será configurar a conta SMTP que o Netuno irá utilizar para o envio de emails.
Para o fazer, navegue dentro da aplicação que está a desenvolver até ao ficheiro de configuração de ambiente. Neste exemplo, iremos utilizar o ficheiro de ambiente de desenvolvimento localizado em:
config/_development.json
Verifique se já não existe configurações para o SMTP, se não existir ainda então no fim do ficheiro de configuração (em formato JSON) adicione os parâmetros de configuração do SMTP:
{
...,
"smtp": {
"default": {
"enabled": true,
"host": "smtp.gmail.com",
"port": 465,
"ssl": true,
"username": "*****@gmail.com",
"password": "*****"
}
}
...
}
Caso esteja a configurar para Gmail substitua apenas os asteriscos pelas suas credenciais e ative a conexão SMTP nas configurações da sua conta Gmail. Caso contrário substitua todos os parâmetros pelos da sua conta SMTP.
Após guardar as alterações, basta reiniciar o Netuno para assumir as alterações da configuração. Sendo estas as configurações padrão para envio de emails como indica o nome default
.
...
"default": {
...
}
...
Pode adicionar mais contas de SMTP, mas apenas uma poderá ser definida como padrão.
Para adicionar mais contas de SMTP basta repetir o bloco de configuração do SMTP padrão e trocar o nome default
por um outro nome à sua escolha, como por exemplo:
{
...,
"smtp": {
"default": {
"enabled": true,
"host": "smtp.gmail.com",
"port": 465, "ssl": true,
"username": "*****@gmail.com",
"password": "*****"
},
"test": {
"enabled": true,
"host": "smtp.gmail.com",
"port": 465,
"ssl": true,
"username": "*****@gmail.com",
"password": "*****"
}
}
...
}
Uma configuração semelhante ao exemplo acima vai permitir utilizar a conta default
quando for chamada da seguinte forma no código:
const smtp = _smtp.init()
E para utilizar a configuração test
basta adicionar o nome da configuração como parâmetro à função _smtp.init()
da seguinte forma:
const smtp = _smtp.init("test")
Se não adicionar um nome de configuração como parâmetro será utilizada sempre a conta default.
Código Detalhado
Vamos agora analizar com atenção o código de exemplo que o Netuno disponibiliza. Neste caso é em JavaScript e é estruturado da seguinte forma:
Inicialização do SMTP:
const smtp = _smtp.init()
Recorde que pode iniciar com outra configuração, por exemplo:
_smtp.init("test")
Adicionando .to
à variável smtp define-se o endereço do destinatário do email, no caso de múltiplos destinatários basta separar por ‘;‘ ou ‘,‘:
smtp.to = '*****@gmail.com'
Adicionando .from
define-se o endereço do remetente do email:
smtp.from = '*****@gmail.com'
Adicionando .cc
define-se o endereço de destinatários em cópia do email, no caso de múltiplos destinatários em cópia basta separar por ‘;‘ ou ‘,‘:
smtp.cc = '*****@gmail.com'
O mesmo se sucede para .bcc
em que se define os destinatários em cópia mas de forma oculta:
smtp.bcc = '*****@gmail.com'
Adicionado .subject
define-se o assunto do email:
smtp.subject = 'Teste do Netuno'
Adicionado .text
define-se o conteúdo em pleno texto:
smtp.text = 'Recebeste este email?'
Adicionando .html
define-se o conteúdo do mail em HTML:
smtp.html = `<div>
<img src="cid:logo" width="200" />
Recebeste este email?</p>
</div>`
Para adicionar uma imagem como anexo adiciona-se (como exemplificado acima), no HTML é definido nas imagens (img
) no atributo src
o cid:
(Content ID) como prefixo e logo a seguir o cid
que é definido ao adicionar anexos com a função attachment
(como exemplificado abaixo).
Para se adicionar a imagem anexada ao email adiciona-se .attachment
à variável smtp da seguinte forma:
smtp.attachment(
"logo.png", // Ficheiro
"image/png", // Formato do ficheiro
_storage.filesystem("server", "samples/mail", "logo.png").file(), // Localização do ficheiro
"logo" // Nome da variável definida em "cid:logo"
)
Note que o
cid
(Content ID) é apenas necessário para embutir imagens que estão em anexo no conteúdo HTML do email.
Para se adicionar um anexo sem ser embutido no HTML (caso de documentos) procede-se da seguinte forma:
smtp.attachment(
"doc.text",
"text/plain",
_storage.filesystem("server", "samples/mail", "doc.txt").file()
)
Por fim para submeter o envio do email basta inserir o seguinte código:
smtp.send()
Por fim, se tudo tiver configurado corretamente, irá receber um email semelhante ao seguinte:
Note que consoante o seu cliente de email poderá diferenciar da imagem acima.
Exemplo Completo com Template
Colocar conteúdo HTML no meio do código não é muito elegante, como foi exemplificado acima:
smtp.html = `<div>
<img src="cid:logo" width="200" />
Did you receive this email?</p>
</div>`
Para evitar isto e manter o código mais limpo e elegante, o conteúdo HTML deve ser importado como um template, da seguinte forma:
smtp.html = _template.getOutput('email/contact', data)
Neste exemplo a configuração do SMTP na configuração da aplicação, seria assim:
...
"smtp": {
"contact": {
"enabled": true,
"host": "MEU.SERVIDOR.com",
"port": 465,
"ssl": true,
"subjectPrefix": "Website Contacto - ",
"from": "noreply@MEU.DOMINIO.com",
"to": "info@MEU.DOMINIO.com",
"username": "noreply@MEU.DOMINIO.com",
"password": "S3gr3d0"
}
},
...
Repare abaixo como pode ser utilizado neste exemplo de código de servico completo, que poderá ficar no ficheiro server/services/contact.js
:
const name = _req.getString("name")
const email = _req.getString("email")
const subject = _req.getString("subject")
const message = _req.getString("message")
const smtp = _smtp.init("contact")
smtp.subject = subject
smtp.text = "Conteúdo em HTML."
const data = _val.map()
.set("name", name)
.set("email", email)
.set("subject", subject)
.set("message", message)
smtp.html = _template.getOutput('email/contact', data)
smtp.attachment(
"logo.png",
"image/png",
_app.file("public/images/logo.png"),
"logo"
)
smtp.send()
_out.json(
_val.map()
.set("result", true)
)
No caminho relativo do template não é necessário por a extensão
.html
, e note que opcionalmente é possível passar informação para dentro do template.
O conteúdo HTML do template deve ser definido dentro de um ficheiro à parte que deve ficar dentro da pasta server/templates/
, este caminho é encontrado a partir da pasta raíz da aplicação.
Seguindo o exemplo demonstrado acima, então o ficheiro template de exemplo ficará aqui:
server/templates/email/contact.html
O conteúdo de exemplo deste ficheiro poderá ser:
<div style="padding: 40px; background: #ffffff;">
<img src="cid:logo" height="60" />
<div style="padding: 20px;"></div>
<div style="padding: 40px; background: #ffffff; font-size: 20px; font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; border: 5px solid #666;">
<h1 style="color: #666; font-weight: bold; margin-bottom: 15px;">
Contacto do Website
</h1>
<p>Nome: _{&data=name}</p>
<p>Email: _{data=email}</p>
<p>Título: _{&data=subject}</p>
<p>_{&data=message}</p>
</div>
</div>
Quando são injectados dados no template com _{data=...}
o &
é adicionado quando deve ser realizado a codificação dos caracteres especial em HTML, ficando _{&data=...}
, e a seguir ao =
no lugar dos ...
é a chave do conteúdo que será injetado.
Configurações Avançadas
As configurações de ambiente config/_*.json
permitem muitas mais configurações avançadas.
As propriedades do smtp
utilizadas no código como .from
, .to
, .cc
, .bcc
, .subject
, .text
e .html
, podem ser definidas na configuração para ficarem pré-definidas por padrão da seguinte forma:
...
"default": {
...
"from": "*****@gmail.com",
"to": "*****@gmail.com",
"cc": "*****@gmail.com",
"bcc": "*****@gmail.com",
"subject": "Título padrão...",
"text": "Conteúdo padrão... ok!",
"html": "<p>Conteúdo padrão... <b>ok!</b></p>"
...
}
...
Pré definir o .from é bastante útil já que normalmente o envio de mails é feito sempre a partir do mesmo endereço.
Também são possíveis outras configurações. Segue-se uma lista completa das mesmas:
PARÂMETRO | TIPO | PADRÃO | DESCRIÇÃO |
---|---|---|---|
enabled | boolean | true | Ativa e desativa o envio de mail. |
debug | boolean | false | Habilita o modo debug, o que vai apresentar mensagens que detalha a comunicação com o servidor. |
protocol | string | Define o tipo de protocolo, smtp ou smtps. | |
host | string | Nome ou IP do servidor de SMTP. | |
port | integer | 465 | Número da porta do servidor SMTP. |
ssl | boolean | true | Ativa o SSL. |
tls | boolean | false | Ativa o TLS |
socketFactoryFallback | boolean | true | Se falhar a geração do Socket então será utilizado o socket nativo java.net.Socket. |
socketFactoryClass | string | Define uma classe que implementa a interface javax.net.SocketFactory que será utilizada para gerar os socket para o SMTP. | |
socketFactoryPort | integer | Define a porta que deve ser utilizada pelos sockets. | |
quitWait | boolean | false | Se ativado aguarda a resposta do servidor após o comando QUIT, se desativado desliga logo a conexão com o servidor após o comando QUIT. |
authMechanisms | string | Lista de mecanismo de autênticação, por padrão é “LOGIN PLAIN DIGEST-MD5 NTLM”, assim suporta todos os mecanismos. | |
authNTLMDomain | string | Domínio de autenticação do NTLM. | |
username | string | Define o utilizador na autenticação com o servidor. | |
html | string | Conteúdo em HTML do e-mail. | |
password | string | Define a palavra-passe na autenticação com o servidor. | |
from | string | Endereço de e-mail de quem envia. | |
to | string | Endereço de e-mail de quem deve receber, pode ser acrescentado mais mails separados por “;” ou “,”. | |
cc | strinf | Endereço de e-mail de quem deve receber uma cópia, pode ser acrescentado mais mails separados por “;” ou “,”. | |
bcc | string | Endereço de e-mail de quem deve receber uma cópia oculta, pode ser acrescentado mais mails separados por “;” ou “,”. | |
subjectPrefix | string | Define um prefixo ao título do e-mail, assim garante que todos os mails enviados tem o prefixo. | |
subject | string | Assunto do e-mail. | |
text | string | Conteúdo em texto do e-mail em pleno texto. |
Caso tenha alguma questão não hesite em contactar-nos através dos meios apresentados no fim da página.
Bom desenvolvimento!