mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-25 17:44:32 +02:00 
			
		
		
		
	Even with #17688 email addresses that contain an initial `-` may still be present in the db and it may in future still be possible to imagine a situation whereby initial `-` are repermitted. This PR simply updates the documentation to warn users to set their SENDMAIL_ARGS with a terminal `--` to prevent this possibility email addresses being interpreted as options. Signed-off-by: Andrew Thornton <art27@cantab.net>
		
			
				
	
	
		
			86 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| date: "2019-10-15T10:10:00+05:00"
 | |
| title: "Usage: Email setup"
 | |
| slug: "email-setup"
 | |
| weight: 12
 | |
| toc: false
 | |
| draft: false
 | |
| menu:
 | |
|   sidebar:
 | |
|     parent: "usage"
 | |
|     name: "Email setup"
 | |
|     weight: 12
 | |
|     identifier: "email-setup"
 | |
| ---
 | |
| 
 | |
| # Email setup
 | |
| 
 | |
| **Table of Contents**
 | |
| 
 | |
| {{< toc >}}
 | |
| 
 | |
| Gitea has mailer functionality for sending transactional emails (such as registration confirmation). It can be configured to either use Sendmail (or compatible MTAs like Postfix and msmtp) or directly use SMTP server.
 | |
| 
 | |
| ## Using Sendmail
 | |
| 
 | |
| Use `sendmail` command as mailer.
 | |
| 
 | |
| Note: For use in the official Gitea Docker image, please configure with the SMTP version (see the following section).
 | |
| 
 | |
| Note: For Internet-facing sites consult documentation of your MTA for instructions to send emails over TLS. Also set up SPF, DMARC, and DKIM DNS records to make emails sent be accepted as legitimate by various email providers.
 | |
| 
 | |
| ```ini
 | |
| [mailer]
 | |
| ENABLED       = true
 | |
| FROM          = gitea@mydomain.com
 | |
| MAILER_TYPE   = sendmail
 | |
| SENDMAIL_PATH = /usr/sbin/sendmail
 | |
| SENDMAIL_ARGS = "--" ; most "sendmail" programs take options, "--" will prevent an email address being interpreted as an option.
 | |
| ```
 | |
| 
 | |
| ## Using SMTP
 | |
| 
 | |
| Directly use SMTP server as relay. This option is useful if you don't want to set up MTA on your instance but you have an account at email provider.
 | |
| 
 | |
| ```ini
 | |
| [mailer]
 | |
| ENABLED        = true
 | |
| FROM           = gitea@mydomain.com
 | |
| MAILER_TYPE    = smtp
 | |
| HOST           = mail.mydomain.com:587
 | |
| IS_TLS_ENABLED = true
 | |
| USER           = gitea@mydomain.com
 | |
| PASSWD         = `password`
 | |
| ```
 | |
| 
 | |
| Restart Gitea for the configuration changes to take effect.
 | |
| 
 | |
| To send a test email to validate the settings, go to Gitea > Site Administration > Configuration > SMTP Mailer Configuration.
 | |
| 
 | |
| For the full list of options check the [Config Cheat Sheet]({{< relref "doc/advanced/config-cheat-sheet.en-us.md" >}})
 | |
| 
 | |
| Please note: authentication is only supported when the SMTP server communication is encrypted with TLS or `HOST=localhost`. TLS encryption can be through:
 | |
|   - STARTTLS (also known as Opportunistic TLS) via port 587. Initial connection is done over cleartext, but then be upgraded over TLS if the server supports it.
 | |
|   - SMTPS connection (SMTP over TLS) via the default port 465. Connection to the server use TLS from the beginning.
 | |
|   - Forced SMTPS connection with `IS_TLS_ENABLED=true`. (These are both known as Implicit TLS.)
 | |
| This is due to protections imposed by the Go internal libraries against STRIPTLS attacks.
 | |
| 
 | |
| Note that Implicit TLS is recommended by [RFC8314](https://tools.ietf.org/html/rfc8314#section-3) since 2018.
 | |
| 
 | |
| ### Gmail
 | |
| 
 | |
| The following configuration should work with GMail's SMTP server:
 | |
| 
 | |
| ```ini
 | |
| [mailer]
 | |
| ENABLED        = true
 | |
| HOST           = smtp.gmail.com:465
 | |
| FROM           = example@gmail.com
 | |
| USER           = example@gmail.com
 | |
| PASSWD         = ***
 | |
| MAILER_TYPE    = smtp
 | |
| IS_TLS_ENABLED = true
 | |
| HELO_HOSTNAME  = example.com
 | |
| ```
 | |
| 
 |