Skip to content

Commit

Permalink
Initial commit
Browse files Browse the repository at this point in the history
  • Loading branch information
nd1012 committed Apr 6, 2024
1 parent 05c9034 commit bd0a548
Show file tree
Hide file tree
Showing 47 changed files with 3,024 additions and 1 deletion.
26 changes: 26 additions & 0 deletions .github/workflows/docfx.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
name: docfx

on:
push:
branches: [ "main" ]

jobs:
build:

runs-on: ubuntu-latest

steps:
- name: Checkout
uses: actions/checkout@v3
- name: Setup .NET
uses: actions/setup-dotnet@v3
with:
dotnet-version: 8.0.x
- name: Setup docfx
run: dotnet tool update -g docfx
- name: Copy README
run: cp README.md "./src/wan24-AutoDiscover Docs/index.md"
- name: Build docs
run: docfx "./src/wan24-AutoDiscover Docs/docfx.json" -t default,templates/singulinkfx
- name: Commit
uses: stefanzweifel/git-auto-commit-action@v5
26 changes: 26 additions & 0 deletions .github/workflows/dotnet.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
# This workflow will build a .NET project
# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-net

name: .NET

on:
push:
branches: [ "main" ]
pull_request:
branches: [ "main" ]

jobs:
build:

runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v3
- name: Setup .NET
uses: actions/setup-dotnet@v3
with:
dotnet-version: 8.0.x
- name: Restore dependencies
run: dotnet restore ./src/wan24-AutoDiscover.sln --ignore-failed-sources
- name: Build lib
run: dotnet build "./src/wan24-AutoDiscover/wan24-AutoDiscover.csproj" --no-restore
197 changes: 196 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1,2 +1,197 @@
# wan24-AutoDiscover
Mailserver autodiscovery

This is a micro-webservice which supports a small part of the Microsoft
Exchange POX autodiscover standard, which allows email clients to receive
automatic configuration information for an email account.

It was created using .NET 8 and ASP.NET. You find a published release build
for each published release on GitHub as ZIP download for self-hosting.

## Usage

### `appsettings.json`

The `appsettings.json` file contains the webservice configuration. The
`DiscoveryConfig` is a `wan24.AutoDiscovery.Models.DiscoveryConfig` object. An
example:

```json
{
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft.AspNetCore": "Warning"
}
},
"Kestrel": {
"Endpoints": {
"AutoDiscover": {
"Url": "http://localhost:5000"
}
}
},
"AllowedHosts": "*",
"DiscoveryConfig": {
"PreForkResponses": 10,
"Discovery": {
"localhost": {
"AcceptedDomains": [
"wan24.de",
"wan-solutions.de"
],
"Protocols": [
{
"Type": "IMAP",
"Server": "imap.wan24.de",
"Port": 993
},
{
"Type": "SMTP",
"Server": "smtp.wan24.de",
"Port": 587
}
]
}
}
}
}
```

Since the webservice should only listen local and be proxied by a real
webserver (like Apache2), there is a `wan24.AutoDiscover.Models.DomainConfig`
for `localhost`, which produces POX response for the allowed domains
`wan24.de` and `wan-solutions.de` in this example (you should use your own
domain names instead).

The email client configuration will get an `IMAP` and a `SMTP` server pre-
configuration, which contains the alias of the requested email address as
login name and has all the other defaults from a
`wan24.AutoDiscover.Models.Protocol` instance.

With the `PreForkResponses` value you can define a number of pre-forked POX
response XML documents to serve faster responses.

Any change to this file will cause an automatic reload of the `DomainConfig`
section.

For serving a request, the `DomainConfig` will be looked up

1. by the email address domain part
1. by the served request hostname
1. by any `DomainConfig` which has the email address domain part in the
`AcceptedDomains` property, which contains a list of accepted domain names
1. by the `DomainConfig` with an empty domain name as key

Any unmatched `DomainConfig` will cause a `Bad request` http response.

### Apache2 proxy setup

Create the file `/etc/apache2/sites-available/autodiscover.conf`:

```txt
<VirtualHost [IP]:443>
ServerName [DOMAIN]
SSLEngine on
SSLCertificateFile /etc/letsencrypt/live/[DOMAIN]/fullchain.pem
SSLCertificateKeyFile /etc/letsencrypt/[DOMAIN]/privkey.pem
ProxyPreserveHost On
ProxyPass / http://localhost:5000/
ProxyPassReverse / http://localhost:5000/
RewriteEngine on
RewriteCond %{SERVER_NAME} =[DOMAIN]
RewriteRule ^ https://%{SERVER_NAME}%{REQUEST_URI} [END,NE,R=permanent]
</VirtualHost>
```

Replace `[IP]` with your servers public IP address and `[DOMAIN]` with your
domain name which you'd like to use for serving autodiscover.

Then activate the proxy:

```bash
a2enmod rewrite proxy
a2ensite autodiscover
systemctl restart apache2
```

### Run as systemd service

On a Debian Linux host you can run the `wan24-AutoDiscover` microservice using
systemd:

```bash
dotnet wan24AutoDiscover.dll autodiscover systemd > /etc/systemd/system/autodiscover.service
systemctl enable autodiscover
systemctl start autodiscover
systemctl status autodiscover
```

### Required DNS configuration

In order to make autodiscover working in an email client, you'll need to
create a SRV record for your email domain - example:

```txt
_autodiscover._tcp 1D IN SRV 0 0 443 [MTA-DOMAIN].
```

The domain `wan24.de` uses this record, for example:

```txt
_autodiscover._tcp 1D IN SRV 0 0 443 mail.wan24.de.
```

### POX request and response

This is an example POX request to `/autodiscover/autodiscover.xml`:

```xml
<Autodiscover xmlns="https://schemas.microsoft.com/exchange/autodiscover/outlook/requestschema/2006">
<Request>
<EMailAddress>[email protected]</EMailAddress>
<AcceptableResponseSchema>https://schemas.microsoft.com/exchange/autodiscover/outlook/responseschema/2006a</AcceptableResponseSchema>
</Request>
</Autodiscover>
```

The response with the demo `appsettings.json`:

```xml
<Autodiscover xmlns="http://schemas.microsoft.com/exchange/autodiscover/responseschema/2006">
<Response xmlns="https://schemas.microsoft.com/exchange/autodiscover/outlook/responseschema/2006a">
<Account>
<AccountType>email</AccountType>
<Action>settings</Action>
<Protocol>
<Type>IMAP</Type>
<Server>imap.wan24.de</Server>
<Port>993</Port>
<LoginName>alias</LoginName>
<SPA>off</SPA>
<SSL>on</SSL>
<AuthRequired>on</AuthRequired>
</Protocol>
<Protocol>
<Type>SMTP</Type>
<Server>smtp.wan24.de</Server>
<Port>587</Port>
<LoginName>alias</LoginName>
<SPA>off</SPA>
<SSL>on</SSL>
<AuthRequired>on</AuthRequired>
</Protocol>
</Account>
</Response>
</Autodiscover>
```

### CLI API

The `wan24-AutoDiscover` has a small built in CLI API, which can do some
things for you:

#### Create a systemd service file

```bash
dotnet wan24AutoDiscover.dll autodiscover systemd > /etc/systemd/system/autodiscover.service
```
9 changes: 9 additions & 0 deletions src/wan24-AutoDiscover Docs/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
###############
# folder #
###############
/**/DROP/
/**/TEMP/
/**/packages/
/**/bin/
/**/obj/
_site
5 changes: 5 additions & 0 deletions src/wan24-AutoDiscover Docs/api/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
###############
# temp file #
###############
*.yml
.manifest
3 changes: 3 additions & 0 deletions src/wan24-AutoDiscover Docs/api/index.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
# API reference

Choose a type from the left to start browsing.
1 change: 1 addition & 0 deletions src/wan24-AutoDiscover Docs/articles/intro.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
# Add your introductions here!
2 changes: 2 additions & 0 deletions src/wan24-AutoDiscover Docs/articles/toc.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
- name: Introduction
href: intro.md
80 changes: 80 additions & 0 deletions src/wan24-AutoDiscover Docs/docfx.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
{
"metadata": [
{
"src": [
{
"files": [
"**.csproj"
],
"exclude": [
"**/*Tests.csproj",
"**/*Demo.csproj"
],
"src": ".."
}
],
"dest": "api",
"disableGitFeatures": false,
"disableDefaultFilter": false
}
],
"build": {
"content": [
{
"files": [
"api/**.yml",
"api/index.md"
]
},
{
"files": [
"articles/**.md",
"articles/**/toc.yml",
"toc.yml",
"*.md"
]
}
],
"resource": [
{
"files": [
"images/**"
]
}
],
"overwrite": [
{
"files": [
],
"exclude": [
"obj/**"
]
}
],
"dest": "../../docs/",
"globalMetadataFiles": [],
"globalMetadata": {
"_appTitle": "wan24-AutoDiscover",
"_appFooter": "(c) 2024 Andreas Zimmermann, wan24.de",
"_copyrightFooter": "(c) 2024 Andreas Zimmermann, wan24.de",
//"_appLogoPath": "custom/logo.png",
//"_appFaviconPath": "custom/favicon.ico",
"_enableSearch": true,
"_disableSideFilter": false,
"_enableNewTab": true,
"_disableContribution": false,
"_disableBreadcrumb": false,
},
"fileMetadataFiles": [],
"template": [
"default",
"templates/singulinkfx"
],
"postProcessors": [],
"markdownEngineName": "markdig",
"noLangKeyword": false,
"keepFileLink": false,
"cleanupCacheHistory": false,
"disableGitFeatures": false
}
}
Loading

0 comments on commit bd0a548

Please sign in to comment.