1098 Коммитов (21ac230cce57f4fd92ca108967acab3cf4872118)

Автор SHA1 Сообщение Дата
Florent Daigniere e4a32b55f5 Send ISRG_X1 on port 25, make DANE pin that 4 лет назад
Florent Daigniere d3e7ea5389 spell it out 4 лет назад
Florent Daigniere a8dc20962a workaround a bug in coredns 4 лет назад
Dimitri Huisman 55a601de5a Add missing import for validators, improve behaviour when an error occurs. 4 лет назад
Dimitri Huisman 7d801c560c Improve if statement 4 лет назад
Florent Daigniere 9466ad4131 fix #2220 4 лет назад
Kevin Falcoz 278d74ce6f
Add title attribute on user-panel div 4 лет назад
Kevin Falcoz 3fe1dbe881
Add input validation for domain creation 4 лет назад
Kevin Falcoz c69f886a73 Update code with ghostwheel42 comments 4 лет назад
Kevin Falcoz 3e394faf92
Patch function "Display Name" into admin page 4 лет назад
Florent Daigniere b9e614145f there too 4 лет назад
Florent Daigniere b7fb8c661a switch to new API 4 лет назад
Billy Chan 90394d7d8c 🎨 use resolver.resolve 4 лет назад
shing6326 32446f03e7
Update start.py
fix missing leading . for the resolver test
4 лет назад
bors[bot] 1e53530164
Merge #2144
2144: Enable unbound by default, warn if the DNS resolver doesn't work r=mergify[bot] a=nextgens

## What type of PR?

bug-fix

## What does this PR do?

Enable unbound by default, warn if the DNS resolver doesn't work

### Related issue(s)
- close #2135

## Prerequisites
Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [ ] In case of feature or enhancement: documentation updated accordingly
- [x] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/workflow.html#changelog) entry file.


Co-authored-by: Florent Daigniere <nextgens@freenetproject.org>
Co-authored-by: Florent Daigniere <nextgens@users.noreply.github.com>
4 лет назад
Florent Daigniere a9da0c084a
syntax error 4 лет назад
Florent Daigniere a2f6243382
remove the error variable 4 лет назад
Florent Daigniere b12616b93f
Make the recommendation clearer 4 лет назад
Alexander Graf f809be39bf
supply missing fields argument 4 лет назад
Florent Daigniere 7bd1fd3489 fix 2145 4 лет назад
Florent Daigniere 379fe18f7a test dns resolvers at startup 4 лет назад
Florent Daigniere 98973223fd
reduce TTL to 1d 4 лет назад
Florent Daigniere 792893caae change TTL to 1y 4 лет назад
Florent Daigniere 671f3e382a Fix 2138: Pin DANE with the full cert 4 лет назад
Florent Daigniere 7f89a29790 Fix 2125
Make the caller responsible to know whether the rate-limit code should
be called or not
4 лет назад
bors[bot] 65d905fe62
Merge #2099
2099: update Dockerfile to alpine 3.14.3 r=mergify[bot] a=willofr

## What type of PR?
Security fix

## What does this PR do?
Updated the Dockerfile to use the latest alpine version 3.14.3 where several CVEs have been fixed: https://alpinelinux.org/posts/Alpine-3.14.3-released.html
New images successfully built on my test env.

### Related issue(s)
None

## Prerequisites
Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [x] In case of feature or enhancement: documentation updated accordingly
- [x] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/workflow.html#changelog) entry file.


Co-authored-by: Will <will@packer-output-c8fcfb40-3d93-4475-8f87-e14a9dd683b6>
Co-authored-by: willofr <willofr@users.noreply.github.com>
4 лет назад
bors[bot] 3eca813182
Merge #2116
2116: fix 2114: redirect old path r=mergify[bot] a=nextgens

## What type of PR?

bug-fix

## What does this PR do?

Old paths may still be cached in browsers, it's easy enough to redirect them

### Related issue(s)
- close #2114


Co-authored-by: Florent Daigniere <nextgens@freenetproject.org>
4 лет назад
Florent Daigniere c4675e6e75 fix 2114: redirect old path 4 лет назад
Dimitri Huisman b4d3d4b3c9 Preparations for 1.9 release. 4 лет назад
Dimitri Huisman 51d94b8d14 Fix issue 2102 4 лет назад
Will b2abbc8856 update Dockerfile to alpine 3.14.3 4 лет назад
Florent Daigniere bee6e980e3 doh 4 лет назад
Florent Daigniere 58d0faff7f ensure we clear the token on delete() 4 лет назад
Florent Daigniere 2b29cfb3f0 fix cleanup_sessions() 4 лет назад
Florent Daigniere f0247a2faf Use self where appropriate 4 лет назад
Florent Daigniere c161a2c987 syntax 4 лет назад
bors[bot] 18865bf03b
Merge #2094
2094: Sessions tweaks r=mergify[bot] a=nextgens

## What type of PR?

bug-fix

## What does this PR do?

- Make all sessions permanent, introduce SESSION_TIMEOUT and PERMANENT_SESSION_LIFETIME.
- Prevent the creation of a session before there is a login attempt
- Ensure that webmail tokens are in sync with sessions

### Related issue(s)
- close #2080 

## Prerequisites
Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [x] In case of feature or enhancement: documentation updated accordingly
- [x] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/workflow.html#changelog) entry file.


Co-authored-by: Florent Daigniere <nextgens@freenetproject.org>
Co-authored-by: Dimitri Huisman <diman@huisman.xyz>
4 лет назад
Dimitri Huisman d40be05117 Fix missing edit buttons in alias, relay and fetchmail lists in admin. 4 лет назад
Florent Daigniere a28c7f903e do it once 4 лет назад
Dimitri Huisman f88daa1e77 Add missing cast to int 4 лет назад
Florent Daigniere 5f313310d4 regenerate() shouldn't extend lifetime 4 лет назад
Florent Daigniere fe18cf9743 Fix 2080
Ensure that webmail tokens are in sync with sessions
4 лет назад
Florent Daigniere 02c93c44f2 Tweak sessions
simplify:
- make all sessions permanent by default
- update the TTL of sessions on access (save always)
- fix session-expiry, modulo 8byte precision
4 лет назад
Florent Daigniere ea96a68eb4 don't create a session if we don't have to 4 лет назад
Florent Daigniere 346ace5fb3 Make webmail the default action 4 лет назад
bors[bot] 08be233607
Merge #2058
2058: Implement versioning for CI/CD workflow. r=mergify[bot] a=Diman0

## What type of PR?

Feature!

## What does this PR do?
This PR introduces 3 things
- Add versioning (tagging) for branch x.y (1.8). E.g. 1.8.0, 1.8.1 etc.
  - docker repo will contain x.y (latest) and x.y.z (pinned version) images.
  - The X.Y.Z tag is incremented automatically. E.g. if 1.8.0 already exists, then the next merge on 1.8 will result in the new tag 1.8.1 being used.
- Make the version available in the image.
  -  For X.Y and X.Y.Z write the version (X.Y.Z) into /version on the image and add a label with version=X.Y.Z
	  -  This means that the latest X.Y image shows the pinned version (X.Y.Z e.g. 1.8.1) it was based on. Via the tag X.Y.Z you can see the commit hash that triggered the built.
  -  For master write the commit hash into /version on the image and add a label with version={commit hash}
-  Automatic releases. For x.y triggered builts (e.g. merge on 1.9) do a new github release for the pinned x.y.z (e.g. 1.9.2). 
  -  Release shows a static message (see RELEASE_TEMPLATE.md) that explains how to reach the newsfragments folder and change the branch to the tag (x.y.z) mentioned in the release. Now you can get the changelog by reading all newsfragment files in this folder.

This PR does not change anything to our workflow (what we (human persons) do). Our processes are still exactly the same. The above introduced logic is automatic. When we backport to X.Y all the magic for creating the pinned version X.Y.Z is handled by the CI/CD workflow.

### Related issue(s)
- closes #1182

## Prerequisites
Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [x] In case of feature or enhancement: documentation updated accordingly
- [x] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/workflow.html#changelog) entry file.

## Testing
Suggested testing steps. This should cover all situations including BORS. It does require that you use your own docker repo or temporarily create a new one.
Suggested testing steps.
1. Create new github repo.
2. Add the required docker secrets to the project (see beginning of CI.yml for the secret names), DOCKER_UN, DOCKER_PW, DOCKER_ORG, DOCKER_ORG_TESTS.
3. Clone the project.
4. Copy the contents of the PR to the cloned project.
5. Push to your new github repo.
6. Now master images are built. Check that images with tag master are pushed to your docker repo
7. Check with docker inspect nginx:master that it has the label version={commit hash}.
8. Run an image, run `docker-compose exec <name> cat /version`. Note that /version also contains the pinned version. For master the pinned version is the commit hash.
9. Create branch 1.8. 
10. Push branch 1.8 to repo.
11. Note that tags 1.8 and 1.8.0 are built and pushed to docker repo
12. Inspect label and /version. Note that 1.8 and 1.8.0 both show version 1.8.0.
13. Push another commit to branch 1.8.
14. Note that tags 1.8 and 1.8.1 are built and pushed to docker repo
15. Inspect label and /version. Note that 1.8 and 1.8.1 both show version 1.8.1.
16. Let's check BORS stuff.
17. Create branch testing.
18. Push the commit with the exact commit text (IMPORTANT!!): `Try #1234:`'.
19. Note that images are built and pushed for tag `pr-1234`.
20. Inspect label and /version. Note that the version is `pr-1234`.
20. Create branch staging.
21. Push the commit with commit text: `Merge #1234`.
22. Note that this image is not pushed to docker (as expected).

but you could also check the GH repo and docker repo I used:
https://github.com/Diman0/Mailu_Fork
https://hub.docker.com/r/diman/rainloop/tags

Co-authored-by: Dimitri Huisman <diman@huisman.xyz>
4 лет назад
Dimitri Huisman d76773b1df Also check the SMTP port for webmail/token 4 лет назад
Dimitri Huisman f26fa8da84 Fix Webmail token check. Fix Auth-Port for Webmail. #2079 4 лет назад
Florent Daigniere 4fffdd95e9 Reduce logging level 4 лет назад
Dimitri Huisman f7677543c6 Process code review remarks
- Moved run to bottom of Dockerfile to allow using unmodified / cached states.
- Simplified bash code in deploy.sh.
- Improved the large bash one-liner in CI.yml. It could not handle >9 for 1.x.
4 лет назад
Dimitri Huisman 56dd70cf4a Implement versioning for CI/CD workflow (see #1182). 4 лет назад
Alexander Graf aa1d605665
Merge remote-tracking branch 'upstream/master' into passlib 4 лет назад
Alexander Graf 84a5514a97
fixed auto reply form 4 лет назад
Alexander Graf cf7914d050
fixed field iteration 4 лет назад
Alexander Graf fd5bdc8650
added localized date output 4 лет назад
Alexander Graf 0315ed78d9
Merge remote-tracking branch 'upstream/master' into update_deps 4 лет назад
bors[bot] 56cbc56df7
Merge #2044
2044: Vault/rspamd: don't return any key for relayed domains r=mergify[bot] a=nextgens

## What type of PR?

enhancement

## What does this PR 

Don't return any key for relayed domains. We may want to revisit this (ARC signing)... but in the meantime it saves from a scary message in rspamd.
    
```signing failure: cannot request data from the vault url: /internal/rspamd/vault/v1/dkim/ ...```


Co-authored-by: Florent Daigniere <nextgens@freenetproject.org>
4 лет назад
bors[bot] 78dd13a217
Merge #2042
2042: Add MESSAGE_RATELIMIT_EXEMPTION r=mergify[bot] a=nextgens

## What type of PR?

Enhancement

## What does this PR do?

Add a new knob called ```MESSAGE_RATELIMIT_EXEMPTION```.

### Related issue(s)
- #1774

## Prerequisites
Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [x] In case of feature or enhancement: documentation updated accordingly
- [ ] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/workflow.html#changelog) entry file.


Co-authored-by: Florent Daigniere <nextgens@freenetproject.org>
4 лет назад
Florent Daigniere 6bf1a178b9 Go with ghostwheel42's suggestion 4 лет назад
Florent Daigniere b68033eb43 only parse it once 4 лет назад
Alexander Graf 82e14f1292
Merge branch 'master' into update_deps 4 лет назад
bors[bot] f0188d9623
Merge #2034
2034: Add timezone to containers r=mergify[bot] a=DjVinnii

## What type of PR?

Enhancement

## What does this PR do?
This PR adds the tzdata package so that the environment variable `TZ` can be used to set the timezone of containers.

### Related issue(s)
- closes #1154 

## Prerequisites
Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [x] In case of feature or enhancement: documentation updated accordingly
- [x] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/workflow.html#changelog) entry file.


Co-authored-by: DjVinnii <vincentkling@msn.com>
4 лет назад
Florent Daigniere dc6e970a7f handle HTTP too 4 лет назад
Florent Daigniere bbef4bee27 Don't return any key for relayed domains
We may want to revisit this (ARC signing)... but in the meantime
it saves from a scary message in rspamd

signing failure: cannot request data from the vault url: /internal/rspamd/vault/v1/dkim/ ...
4 лет назад
Florent Daigniere 6c6b0b161c Set the right flags on the rate_limit cookie 4 лет назад
Florent Daigniere f9373eacab Merge remote-tracking branch 'upstream/master' into misc 4 лет назад
Florent Daigniere 5714b4f4b0 introduce MESSAGE_RATELIMIT_EXEMPTION 4 лет назад
DjVinnii 30d7e72765 Move TZ to Advanced settings 4 лет назад
DjVinnii 225160610b Set default TZ in Dockerfiles 4 лет назад
DjVinnii 81e33d3679 Add default TZ to config manager 4 лет назад
Alexander Graf 97e79a973f fix sso login button spacing again 4 лет назад
Alexander Graf 73ab4327c2 updated database libraries (sqlalchemy etc.)
this is working fine, but introduces a sqlalchemy warning
when using config-import:

  /app/mailu/schemas.py:822:
    SAWarning: Identity map already had an identity for (...),
    replacing it with newly flushed object.
    Are there load operations occurring inside of an event handler
    within the flush?
4 лет назад
Alexander Graf 4669374b9e use python wheels 4 лет назад
Alexander Graf 85d86d4156 some more libs updated 4 лет назад
Alexander Graf ffd99c3fa8 updated flask
ConfigManager should not replace app.config - this is causing trouble
with some other flask modules (swagger).
Updated ConfigManager to only modify app.config and not replace it.
4 лет назад
Alexander Graf 87884213c4 update misc helper libs 4 лет назад
Alexander Graf 56f65d724d update babel 4 лет назад
Alexander Graf 5238b00f0b update alembic 4 лет назад
Alexander Graf f613205fe1 update tenacity 4 лет назад
Alexander Graf 833ccb5544 reload page using GET when selecting language 4 лет назад
Alexander Graf 8b15820b01 fix sso login button spacing 4 лет назад
Alexander Graf 26fb108a3f updated Flask-Login 4 лет назад
Alexander Graf abc4112242 updated Werkzeug, Click and Flask-Migrate 4 лет назад
Alexander Graf f1d7bedd1b fix display of range inputs (again) 4 лет назад
Alexander Graf 13e6793c9f Merge remote-tracking branch 'upstream/master' into update_deps 4 лет назад
Alexander Graf aca1e13648 update socrate - will be removed later 4 лет назад
Alexander Graf 866741bcbe updated WTForms-Components deps 4 лет назад
Alexander Graf ef19869cde updated redis 4 лет назад
Alexander Graf d8efd3057c updated idna 4 лет назад
Alexander Graf 8ad8cde0e2 removed some obsolete requirements 4 лет назад
Alexander Graf 3ac1b3d86c update pyyaml and pygments 4 лет назад
Alexander Graf 40cdff4911 updated dnspython 4 лет назад
Alexander Graf dcbe55f062 updated crypto 4 лет назад
Alexander Graf 771b2d1112 duh 4 лет назад
Alexander Graf 23d0cd0466 update tabluate. fix audit.py and include in container 4 лет назад
Alexander Graf 8d90a74624 update werkzeug to 1.x 4 лет назад
bors[bot] 5e212ea46d
Merge #2036
2036: round display of range inputs to 2 decimals r=mergify[bot] a=ghostwheel42

## What type of PR?

small fix

## What does this PR do?

rounds display of range inputs to 2 decimals 

### Related issue(s)

- small fix to #1966

## Prerequisites
Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [X] In case of feature or enhancement: documentation updated accordingly
- [X] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/workflow.html#changelog) entry file.


Co-authored-by: Alexander Graf <ghostwheel42@users.noreply.github.com>
4 лет назад
Alexander Graf 80be3506da upgrade pip. completed reqs via pip freeze 4 лет назад
Alexander Graf 598b2df5a0 update wtforms 4 лет назад
Alexander Graf e8b5f1a185 round display of range inputs to 2 decimals 4 лет назад
DjVinnii 1d6809193b Add tzdata to core 4 лет назад
Florent Daigniere f3c93212c6 The Rate-limiter should run after the deny 4 лет назад
Alexander Graf 9bc685c30b removed some more whitespace 4 лет назад
Alexander Graf 8c31699baf fixed locale selector for no_NB 4 лет назад
Alexander Graf 882a27f87c simplified if's and added external link icon 4 лет назад
Alexander Graf 3141ffe791 removed some whitespace 4 лет назад
Dimitri Huisman 6b16756d92 Fix acessing antispam via sidebar. 4 лет назад
Dimitri Huisman 3449b67c86 Process code review remarks PR2023 4 лет назад
Dimitri Huisman 8784971b7f Merge rate limiting and failed login logging 4 лет назад
Dimitri Huisman 503044ef6e Reintroduce ProxyFix. Use two buttons for logging in. 4 лет назад
Dimitri Huisman c42ad8e71e Forgot to include changes for url_for of base.html 4 лет назад
Dimitri Huisman fb0f005343 Get rid of complicated prefix logic. Further simplify /static handling and nginx config. 4 лет назад
Dimitri Huisman da788ddee3 Merge branch 'fix-sso-1929' of github.com:Diman0/Mailu into fix-sso-1929 4 лет назад
Dimitri Huisman bdcc183165 Redirect to configured ENV VAR for Admin/Webmail, further simplify nginx config. 4 лет назад
Florent Daigniere fee13e6c4b Save a redirect 4 лет назад
Florent Daigniere d3f07a0882 Simplify the handling of /static 4 лет назад
Dimitri Huisman a47afec4ee Make logic more readable. 4 лет назад
Dimitri Huisman 48764f0400 Ensure all requests from the page sso go through the page sso. 4 лет назад
Dimitri Huisman aab258d284 Move handling of logging out in admin, to sso logout page. 4 лет назад
Dimitri Huisman 615743b331 Improve indendation of conditions. 4 лет назад
Dimitri Huisman 5d81846c5d Introduce the shared stub /static for providing all static files 4 лет назад
Dimitri Huisman 44d2448412 Updated SSO logic for webmails. Fixed small bug rate limiting. 4 лет назад
Dimitri Huisman f9eee0cbaf Adapt HEALTHCHECK to new URL 4 лет назад
Dimitri Huisman ed7adf52a6 Merge branch 'master' of github.com:Diman0/Mailu into fix-sso-1929 4 лет назад
Dimitri Huisman 913a6304a7 Finishing touches. Introduce /static stub for handling all static files. 4 лет назад
bors[bot] a1192d8039
Merge #1987
1987: Enhancement to the rate limits r=mergify[bot] a=nextgens

## What type of PR?

enhancement

## What does this PR do?

Turn the rate-limiters into something useful (that won't fire for no reason).

- fix rate-limiting on /webdav/
- it changes the rate-limiting behaviour from limiting a single IP address to a subnet of a reasonable size (/24 on v4 and /56 on v6 both are now configurable) : AUTH_RATELIMIT_IP / AUTH_RATELIMIT_IP_V4_MASK / AUTH_RATELIMIT_IP_V6_MASK
- It ensures we only use IP-based rate-limits for attempts on accounts that do not exist
- it creates a new rate limit preventing attackers from targetting a specific user account (separate from what's above) : AUTH_RATELIMIT_USER
- it introduces a rate limiting exemption mechanism whereby, upon authentication, users will see their source-ip address being exempt for a specific amount of time AUTH_RATELIMIT_EXEMPTION_LENGTH. A similar mechanism is available for web-based sessions (see below)
- It introduces in AUTH_RATELIMIT_EXEMPTION a comma separated list of network CIDRs that will be exempt from both types of rate limiting
- it implements device-tokens, as described on https://owasp.org/www-community/Slow_Down_Online_Guessing_Attacks_with_Device_Cookies to ensure that genuine users aren't locked-out by a malicious attacker abusing the rate-limit feature.

Things that could be improved include:
- the IP-based rate limiter flags attempts against "non-existing" accounts: it could go further and flag the number of unique non-existing accounts attempted (to prevent the case of a user making a typo in his MUA configuration)
- the IP address exemption mechanism doesn't pin the exemption to a specific username: any real user can trivially bypass the rate limits (and attempt to brute-force someone else's account)

### Related issue(s)
- close #1926
- close #1745 
- close #1915


## Prerequisites
Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [x] In case of feature or enhancement: documentation updated accordingly
- [x] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/workflow.html#changelog) entry file.


Co-authored-by: Florent Daigniere <nextgens@freenetproject.org>
Co-authored-by: Diman0 <diman@huisman.xyz>
Co-authored-by: Florent Daigniere <nextgens@users.noreply.github.com>
4 лет назад
Florent Daigniere 693b578bbb The second strip isn't necessary 4 лет назад
Florent Daigniere 1c6165213c better that way 4 лет назад
Florent Daigniere 34497cff20 doh 4 лет назад
Florent Daigniere e8871dd77f doh 4 лет назад
Florent Daigniere 5b72c32251 Doh 4 лет назад
Florent Daigniere 19b784b198 Parse the network configuration only once
thanks @ghostwheel42
4 лет назад
Florent Daigniere 98742268e6 Make it more readable 4 лет назад
Florent Daigniere 94bbed9746 Ensure we have the right IP 4 лет назад
Florent Daigniere c5bd82650f doh 4 лет назад
Florent Daigniere 99c81c20a7 Introduce AUTH_RATELIMIT_EXEMPTION
This disables rate limiting on specific CIDRs
4 лет назад
Florent Daigniere c674f1567a Merge branch 'ratelimits' of https://github.com/nextgens/Mailu into ratelimits 4 лет назад
Florent Daigniere 8414dd5cf0 Merge remote-tracking branch 'upstream/master' into ratelimits 4 лет назад
Florent Daigniere e14d2e7c03 Error out explictely if Auth-Port isn't set 4 лет назад
Florent Daigniere abaa2e8cc3 simplify client_ip 4 лет назад
Florent Daigniere de276a6822 Simplify extract_network_from_ip 4 лет назад
Florent Daigniere 3bda8368e4 simplify the Auth-Status check 4 лет назад
Florent Daigniere 2dd9ea1506 simplify 4 лет назад
Florent Daigniere 068170c0ff Use app instead of flask.current_app where possible 4 лет назад
Florent Daigniere 57b0dd490c Initialize user_email in all cases 4 лет назад
qy117121 b1425015ef
Update messages.po
Fix wrong text
4 лет назад
bors[bot] afffe4063e
Merge #2018
2018: show dmarc record for report domain in domain details r=mergify[bot] a=ghostwheel42

## What type of PR?

documentation

## What does this PR do?

show dmarc record for report domain in domain details

### Related issue(s)

closes #1382

## Prerequisites

- [X] In case of feature or enhancement: documentation updated accordingly
- [X] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/workflow.html#changelog) entry file.


Co-authored-by: Alexander Graf <ghostwheel42@users.noreply.github.com>
4 лет назад
bors[bot] 9f2aa0aadc
Merge #1986 #2014
1986: Document how to setup client autoconfig r=mergify[bot] a=nextgens

## What type of PR?

enhancement

## What does this PR do?

Document how to setup autoconfig. This works with most open-source MUAs (thunderbird, evolution, ...)

We could go further than that by providing dynamic configuration (issue an auth token for each MUA request)... but it won't work unless a new DNS entry (and matching certificate) is created.

### Related issue(s)
- #224

## Prerequisites
Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [x] In case of feature or enhancement: documentation updated accordingly
- [x] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/workflow.html#changelog) entry file.


2014: Update Chinese translation r=mergify[bot] a=qy117121

## What type of PR?

translation

## What does this PR do?

Update Chinese translation. Use `zh` instead of `zh_CN`.

### Related issue(s)

none

## Prerequistes
Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [X] In case of feature or enhancement: documentation updated accordingly
- [X] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/workflow.html#changelog) entry file.


Co-authored-by: Florent Daigniere <nextgens@freenetproject.org>
Co-authored-by: qy117121 <mixuan121@gmail.com>
Co-authored-by: Alexander Graf <ghostwheel42@users.noreply.github.com>
4 лет назад
Alexander Graf 7fe15ea9cf added dmarc record for report domain 4 лет назад
bors[bot] a5b1d36171
Merge #2017
2017: rspamd: get dkim keys via REST API instead of filesystem r=mergify[bot] a=ghostwheel42

## What type of PR?

enhancement

## What does this PR do?

rspamd now uses hashicorp's vault api v1 to get dkim keys and selectors for a domain.
this allows future enhancement (multiple keys) without reconfiguring and restarting rspamd.
it also makes mounting the /dkim volume into the rspamd container unnecessary.

### Related issue(s)

- improves and closes #2012 
- allows to implement key rotation using multiple selectors (see #1700)
- allows to implement dkim for alternate domains (see #1519)
- fixes and closes #1345 (selector transmitted by admin container is used)
- closes #1179 (no keys on disk)
- allows to implement key rotation from the outside (ie. via a helper script talking to some dns provider's api) (see #547)

## Prerequisites

- [X] In case of feature or enhancement: documentation updated accordingly
- [X] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/workflow.html#changelog) entry file.


Co-authored-by: Alexander Graf <ghostwheel42@users.noreply.github.com>
4 лет назад
Alexander Graf 7b0c5935a8 only support GET method in vault 4 лет назад
Alexander Graf 303fae00fb cleanup modules. use dkim selector from config 4 лет назад
Alexander Graf dc9f970a91 removed zh_CN and updated locale-map for datatables 4 лет назад
Alexander Graf 893705169e PoC rspamd use dkimkeys from admin using vault api 4 лет назад
Florent Daigniere 632ce663ee Prevent logins with no password 4 лет назад
qy117121 866f784d06
Create messages.po
Update the translation
4 лет назад
qy117121 251eea5553
Update messages.po
Updated translation
4 лет назад
Florent Daigniere 7277e0b4e4
Merge branch 'master' into ratelimits 4 лет назад
bors[bot] 8c8c1b2015
Merge #1997
1997: Prevent traceback when using non-email in login r=mergify[bot] a=ghostwheel42

There's a traceback when the username used to log via SMTPAUTH
in is not an email address:

=== before ===
```
[...] ERROR in app: Exception on /internal/auth/email [GET]
Traceback (most recent call last):
  File "/usr/lib/python3.9/site-packages/sqlalchemy/engine/base.py", line 1179, in _execute_context
    context = constructor(dialect, self, conn, *args)
  File "/usr/lib/python3.9/site-packages/sqlalchemy/engine/default.py", line 719, in _init_compiled
    param.append(processors[key](compiled_params[key]))
  File "/usr/lib/python3.9/site-packages/sqlalchemy/sql/type_api.py", line 1201, in process
    return process_param(value, dialect)
  File "/app/mailu/models.py", line 60, in process_bind_param
    localpart, domain_name = value.lower().rsplit('`@',` 1)
ValueError: not enough values to unpack (expected 2, got 1)
[...]
[parameters: [{'%(140657157923216 param)s': 'foobar'}]]
```

=== after ===
```
[...] WARNING in nginx: Invalid user 'foobar': (builtins.ValueError) invalid email address (no "`@")`
```

## What type of PR?

enhancement

## What does this PR do?

replace traceback (ERROR) with error message (WARNING)

### Related issue(s)

## Prerequisites
Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [ ] In case of feature or enhancement: documentation updated accordingly
- [ ] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/workflow.html#changelog) entry file.


Co-authored-by: Alexander Graf <ghostwheel42@users.noreply.github.com>
4 лет назад
bors[bot] 9b01e663b2
Merge #2007
2007: allow sending emails as user+detail@domain.tld r=mergify[bot] a=ghostwheel42

## What type of PR?

bug-fix or enhancement

## What does this PR do?

Allows sending emails with an added "+detail" in the local part.
 
### Related issue(s)

closes #1948

## Prerequisites
Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [ ] In case of feature or enhancement: documentation updated accordingly
- [X] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/workflow.html#changelog) entry file.


Co-authored-by: Alexander Graf <ghostwheel42@users.noreply.github.com>
Co-authored-by: root <ghostwheel42@users.noreply.github.com>
Co-authored-by: Florent Daigniere <nextgens@freenetproject.org>
4 лет назад
Florent Daigniere 14360f8926 RECIPIENT_DELIMITER can have several characters 4 лет назад
root 8c59f35697 use RECIPIENT_DELIMITER for splitting 4 лет назад
Alexander Graf 1d571dedfc split localpart into user and tag 4 лет назад
Florent Daigniere d131d863ba The if needs to be inside the block 4 лет назад
Alexander Graf aaf3ddd002 moved javascript to app.js 4 лет назад
Florent Daigniere b48779ea70 SESSION_COOKIE_SECURE and HTTP won't work 4 лет назад
Florent Daigniere 10d78a888b Derive a new subkey for SRS 4 лет назад
Alexander Graf 65133a960a Prevent traceback when using non-email in login
There's a traceback when the username used to log via SMTPAUTH
in is not an email address:

=== before ===
```
[...] ERROR in app: Exception on /internal/auth/email [GET]
Traceback (most recent call last):
  File "/usr/lib/python3.9/site-packages/sqlalchemy/engine/base.py", line 1179, in _execute_context
    context = constructor(dialect, self, conn, *args)
  File "/usr/lib/python3.9/site-packages/sqlalchemy/engine/default.py", line 719, in _init_compiled
    param.append(processors[key](compiled_params[key]))
  File "/usr/lib/python3.9/site-packages/sqlalchemy/sql/type_api.py", line 1201, in process
    return process_param(value, dialect)
  File "/app/mailu/models.py", line 60, in process_bind_param
    localpart, domain_name = value.lower().rsplit('@', 1)
ValueError: not enough values to unpack (expected 2, got 1)
[...]
[parameters: [{'%(140657157923216 param)s': 'foobar'}]]
```

=== after ===
```
[...] WARNING in nginx: Invalid user 'foobar': (builtins.ValueError) invalid email address (no "@")
```
4 лет назад
Diman0 f4cde61148 Make header translatable. More finishing touches. 4 лет назад
Florent Daigniere 7d56ed3b70 Merge branch 'master' of https://github.com/Mailu/Mailu into ratelimits 4 лет назад
Diman0 fbe0a446b9 Merge branch 'master' of github.com:Mailu/Mailu into fix-sso-1929 4 лет назад
Florent Daigniere 1e07b85fa1 doh 4 лет назад
Diman0 9894b49cbd Merge/Update with changes from master 4 лет назад
Florent Daigniere 24aadf2f52 ensure we log when the rate limiter hits 4 лет назад
Florent Daigniere 64bc7972cc Make AUTH_RATELIMIT_IP 60/hour as discussed 4 лет назад
Florent Daigniere cab0ce2017 doh 4 лет назад
Florent Daigniere a9340e61f5 Log auth attempts on /admin 4 лет назад
Florent Daigniere 89ea51d570 Implement rate-limits 4 лет назад
Diman0 bf0aad9820 Merge branch 'master' of github.com:Mailu/Mailu into fix-sso-1929 4 лет назад
bors[bot] 4c5c6c3b5f
Merge #1966
1966: AdminLTE3 optimizations & compression and caching r=mergify[bot] a=ghostwheel42

## What type of PR?

enhancement, bugfix

## What does this PR do?

Optimization and cleanup of styles and javascript code for AdminLTE 3
Adds caching headers, gzip and robots.txt to nginx.

### Related issue(s)

Makes #1800 even better. Thanks to `@DjVinnii` and `@Diman0` for the good work.
Closes #1905

## Prerequistes

Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [X] In case of feature or enhancement: documentation updated accordingly
- [X] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/workflow.html#changelog) entry file.


Co-authored-by: Alexander Graf <ghostwheel42@users.noreply.github.com>
Co-authored-by: Dimitri Huisman <diman@huisman.xyz>
4 лет назад
bors[bot] b329971b87
Merge #1971
1971: Updated Polish translation. r=mergify[bot] a=ghostwheel42

## What type of PR?

translation

## What does this PR do?

Update polish translation. Used `pl/LC_MESSAGES/messages.po` from PR #1751 created by `@martys71`
Part of Discussion of 1.9 roadmap #1930

### Related issue(s)

closes #1751 

## Prerequistes
Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [X] In case of feature or enhancement: documentation updated accordingly
- [X] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/workflow.html#changelog) entry file.


Co-authored-by: Alexander Graf <ghostwheel42@users.noreply.github.com>
4 лет назад
Alexander Graf 25cf8b5358 better help formatting 4 лет назад
Alexander Graf b63081cb48 display error (not exception) when creating admin
repleace misleading python exception (mailu broken)
with error message stating that the admin user is
already present
4 лет назад
Alexander Graf 7bec8029a4 strip not necessary anymore 4 лет назад
Alexander Graf 1e8b41f731 Merge remote-tracking branch 'upstream/master' into adminlte3_fixes 4 лет назад
Alexander Graf b883e3c4a6 duh. 4 лет назад
Alexander Graf bb40ccc4b0 normalize HOSTNAMES
should be moved to python lib and normalized in start.py
4 лет назад
Alexander Graf 45a2be3766 Updated Polish translation.
Used pl/LC_MESSAGES/messages.po from PR#1751 created by martys71
4 лет назад
bors[bot] d464187477
Merge #1964
1964: Alpine3.14.2 r=mergify[bot] a=nextgens

Upgrade to alpine 3.14.2, retry upgrading unbound & switch back to libressl

Co-authored-by: Florent Daigniere <nextgens@freenetproject.org>
4 лет назад
Alexander Graf 0094268410 allow to change logo. default color for flash msg
- two new environment variables allow to change logo background color
  and graphic
- flash messages are now green (not cyan)
4 лет назад
Alexander Graf d8b4a016af use blue color from https://mailu.io/ 4 лет назад
bors[bot] 6fe265b548
Merge #1968
1968: optimize handle_authentication r=mergify[bot] a=ghostwheel42

## What type of PR?

bug-fix

## What does this PR do?

catch utf-8 decoding errors and log a warning in handle_authentication instead of writing a traceback into the log.

### Related issue(s)

closes #1361

## Prerequistes

Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [X] In case of feature or enhancement: documentation updated accordingly
- [X] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/workflow.html#changelog) entry file.


Co-authored-by: Alexander Graf <ghostwheel42@users.noreply.github.com>
4 лет назад
Alexander Graf 90c96bdddc optimize handle_authentication
- catch decoding of nginx headers (utf-8 exception)
- re-ordered function
4 лет назад
Florent Daigniere 0ee52ba65b Doh 4 лет назад
Florent Daigniere 0f0459e9b2 suggestions from @ghostwheel42 4 лет назад
Alexander Graf 7bede55fce more verbose cleaning message 4 лет назад
Florent Daigniere a9a1b3e55e Reduce the EDNS0 size to 1232
@see
https://github.com/dns-violations/dnsflagday/issues/125
4 лет назад
Alexander Graf 7fd605cc21 fixed brand link target for normal users 4 лет назад
Diman0 b148e41d9b Fix nginx config 4 лет назад
Florent Daigniere d8c22db547 Merge remote-tracking branch 'upstream/master' into policyd-mta-sts 4 лет назад
Alexander Graf 8cdd7e911d duh. removed debug 4 лет назад
Alexander Graf 2ba0d552e0 Merge remote-tracking branch 'upstream/master' into passlib 4 лет назад
Alexander Graf 34df8b3168 AdminLTE3 optimizations & compression and caching
- fixed copy of qemu-arm-static for alpine
- added 'set -eu' safeguard
- silenced npm update notification
- added color to webpack call
- changed Admin-LTE default blue
  (core/admin/Dockerfile)

- AdminLTE 3 style tweaks
  (core/admin/assets/app.css)
  (core/admin/mailu/ui/templates/base.html)
  (core/admin/mailu/ui/templates/sidebar.html)

- localized datatables
  (core/admin/Dockerfile)
  (core/admin/assets/app.js)
  (core/admin/package.json)

- moved external javascript code to vendor.js
  (core/admin/assets/app.js)
  (core/admin/assets/vendor.js)
  (core/admin/webpack.config.js)

- added mailu logo
  (core/admin/assets/app.js)
  (core/admin/assets/app.css)
  (core/admin/assets/mailu.png)

- moved all inline javascript to app.js
  (core/admin/assets/app.js)
  (core/admin/mailu/ui/templates/domain/create.html)
  (core/admin/mailu/ui/templates/user/create.html)

- added iframe display of rspamd page
  (core/admin/assets/app.js)
  (core/admin/mailu/ui/views/base.py)
  (core/admin/mailu/ui/templates/sidebar.html)
  (core/admin/mailu/ui/templates/antispam.html)

- updated language-selector to display full language names and use post
  (core/admin/assets/app.js)
  (core/admin/mailu/__init__.py)
  (core/admin/mailu/utils.py)
  (core/admin/mailu/ui/views/languages.py)

- added fieldset to group and en/disable input fields
  (core/admin/assets/app.js)
  (core/admin/mailu/ui/templates/macros.html)
  (core/admin/mailu/ui/templates/user/settings.html)
  (core/admin/mailu/ui/templates/user/reply.html)

- added clipboard copy buttons
  (core/admin/assets/app.js)
  (core/admin/assets/vendor.js)
  (core/admin/mailu/ui/templates/macros.html)
  (core/admin/mailu/ui/templates/domain/details.html)

- cleaned external javascript imports
  (core/admin/assets/vendor.js)

- pre-split first hostname for further use
  (core/admin/mailu/__init__.py)
  (core/admin/mailu/models.py)
  (core/admin/mailu/ui/templates/client.html)
  (core/admin/mailu/ui/templates/domain/signup.html)

- cache dns_* properties of domain object (immutable during runtime)
  (core/admin/mailu/models.py)
  (core/admin/mailu/ui/templates/domain/details.html)

- fixed and splitted dns_dkim property of domain object (space missing)
- added autoconfig and tlsa properties to domain object
  (core/admin/mailu/models.py)

- suppressed extra vertical spacing in jinja2 templates
- improved accessibility for screen reader
  (core/admin/mailu/ui/templates/**.html)

- deleted unused/broken /user/forward route
  (core/admin/mailu/ui/templates/user/forward.html)
  (core/admin/mailu/ui/views/users.py)

- updated gunicorn to 20.1.0 to get rid of buffering error at startup
  (core/admin/requirements-prod.txt)

- switched webpack to production mode
  (core/admin/webpack.config.js)

- added css and javascript minimization
- added pre-compression of assets (gzip)
  (core/admin/webpack.config.js)
  (core/admin/package.json)

- removed obsolte dependencies
- switched from node-sass to dart-sass
  (core/admin/package.json)

- changed startup cleaning message from error to info
  (core/admin/mailu/utils.py)

- move client config to "my account" section when logged in
  (core/admin/mailu/ui/templates/sidebar.html)
4 лет назад
Diman0 960033525d configure sso in nginx 4 лет назад
Diman0 8868aec0dc Merge master. Make sso login working for admin. 4 лет назад
Diman0 1cfc9ee1c4 Merge branch 'master' of github.com:Diman0/Mailu into fix-sso-1929 4 лет назад
Diman0 9fac3d7ad3 Initial implementation for standalone sso page 4 лет назад
Florent Daigniere d7c2b510c7 Give alpine 3.14.2 a shot 4 лет назад
Florent Daigniere fe186afb6f Revert "Switch to openssl to workaround alpine #12763"
This reverts commit f8362d04e4.
4 лет назад
Florent Daigniere c1d94bb725 Ensure that postfix will be able to use the TLSA records
see https://www.huque.com/dane/testsite/ for the testcases
4 лет назад
Florent Daigniere 9f66e2672b Use DEFER_ON_TLS_ERROR here too
We just don't know whether the lookup failed because we are under attack
or whether it's a glitch; the safe behaviour is to defer
4 лет назад
Florent Daigniere a1da4daa4c Implement the DANE-only lookup policyd
https://github.com/Snawoot/postfix-mta-sts-resolver/issues/67 for
context
4 лет назад
Dimitri Huisman 5f18860669 Remove workaround. Remove deprecated url-loader. 4 лет назад
Dimitri Huisman 60be06e298 Temporary workaround to get FontAwesome icons working. 4 лет назад
Dimitri Huisman 5da7a06675 Resolve webpack.config.js error 4 лет назад
Dimitri Huisman 00276d8b70
Merge branch 'master' into AdminLTE-3 4 лет назад
bors[bot] 6e32092abd
Merge #1873
1873: Completed Hebrew translation r=mergify[bot] a=yarons

The Hebrew translation is incomplete so I've completed it.

Co-authored-by: Yaron Shahrabani <sh.yaron@gmail.com>
4 лет назад
Dimitri Huisman 169a540692 Use punycode for HTTP header for radicale and create changelog 4 лет назад
Dimitri Huisman 4f5cb0974e Make sure HTTP header only contains ASCII 4 лет назад
Florent Daigniere b4102ba464 doh 4 лет назад
Florent Daigniere 9ec7590171 Merge branch 'master' of https://github.com/Mailu/Mailu into wildcard_senders 4 лет назад
Florent Daigniere 7252a73e11 WILDCARD_SENDERS can have spaces 4 лет назад
bors[bot] b57df78dac
Merge #1916
1916: Ratelimit outgoing emails per user r=mergify[bot] a=nextgens

## What type of PR?

Feature

## What does this PR do?

A conflict-free version of #1360 implementing per-user sender limits

### Related issue(s)
- close #1360 
- close #1031
- close #1774 

## Prerequistes
Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [x] In case of feature or enhancement: documentation updated accordingly
- [x] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/workflow.html#changelog) entry file.


Co-authored-by: Florent Daigniere <nextgens@freenetproject.org>
Co-authored-by: Dimitri Huisman <diman@huisman.xyz>
4 лет назад
Dimitri Huisman e5972bd9ec Set default message rate limit to 200/day 4 лет назад
Florent Daigniere facc4b6427 Allow specific users to send email from any address 4 лет назад
Diman0 5afbf37292 Resolve build issues 4 лет назад
Dimitri Huisman df64601b28
Merge branch 'master' into AdminLTE-3 4 лет назад
Florent Daigniere dccd8afd51 Thanks @Diman0!
ENEEDSLEEP
4 лет назад
Florent Daigniere 5e7d5adf17 AUTH shouldn't happen on port 25 4 лет назад
Florent Daigniere 6d244222da better error message 4 лет назад
Florent Daigniere 1438253a06 Ratelimit outgoing emails per user 4 лет назад
Diman0 588904078e Set default of AUTH_RATELIMIT_SUBNET to False. Increase default AUTH_RATELIMIT value. 4 лет назад
Florent Daigniere defea3258d update arm builds too 4 лет назад
Florent Daigniere d44608ed04 Merge remote-tracking branch 'upstream/master' into upgrade-alpine 4 лет назад
Florent Daigniere f8362d04e4 Switch to openssl to workaround alpine #12763 4 лет назад
bors[bot] 6ea4e3217a
Merge #1901
1901: treat localpart case insensitive again r=mergify[bot] a=ghostwheel42

## What type of PR?

bug-fix

## What does this PR do?

fixes error introduced by #1604 where the localpart of an email address was handled case sensitive.
this screwed things up at various other places.
 
### Related issue(s)

closes #1895
closes #1900

Co-authored-by: Alexander Graf <ghostwheel42@users.noreply.github.com>
4 лет назад
Alexander Graf 6856c2c80f treat localpart case insensitive again
by lowercasing it where necessary
4 лет назад
bors[bot] 656cf22126
Merge #1856
1856: update asset builder dependencies r=mergify[bot] a=ghostwheel42

## What type of PR?

update asset builder dependencies

## What does this PR do?

only include needed dependencies to build mailu assets with nodejs v8

### Related issue(s)

update dependencies as discussed in #1829


Co-authored-by: Alexander Graf <ghostwheel42@users.noreply.github.com>
4 лет назад
bors[bot] 9289fa6420
Merge #1896
1896: save dkim key after creation r=mergify[bot] a=ghostwheel42

## What type of PR?

bug-fix

## What does this PR do?

saves generated dkim key after creation vi web ui.
after the model change the domain object needs to be added and flushed via sqlalchemy.

### Related issue(s)

closes #1892


Co-authored-by: Alexander Graf <ghostwheel42@users.noreply.github.com>
4 лет назад
bors[bot] 9a4c6385e5
Merge #1888
1888: Use threads in gunicorn rather than workers/processes r=mergify[bot] a=nextgens

## What type of PR?

enhancement

## What does this PR do?

This ensures that we share the auth-cache... will enable memory savings
and may improve performances when a higher number of cores is available

"smarter default"

Co-authored-by: Florent Daigniere <nextgens@freenetproject.org>
4 лет назад
Alexander Graf 54b46a13c6 save dkim key after creation 4 лет назад
Alexander Graf c2c3030a2f rephrased comments 4 лет назад
Alexander Graf ad1b036f20 fix Email class 4 лет назад
Florent Daigniere 8d9f3214cc Use threads in gunicorn rather than processes
This ensures that we share the auth-cache... will enable memory savings
and may improve performances when a higher number of cores is available

"smarter default"
4 лет назад
Yaron Shahrabani e0bf75ae17
Completed Hebrew translation 4 лет назад
bors[bot] c5ff72d657
Merge #1857
1857: disable startdate when autoreply is disabled r=mergify[bot] a=ghostwheel42

## What type of PR?

bug-fix

## What does this PR do?

disable the reply startdate field when autoreply is disabled


Co-authored-by: Alexander Graf <ghostwheel42@users.noreply.github.com>
4 лет назад
Florent Daigniere a0dcd46483 fix #1861: Handle colons in passwords 4 лет назад
Alexander Graf 180026bd77 also disable startdate 4 лет назад
Alexander Graf 56cfcf8b64 converted tabs to spaces 4 лет назад
Alexander Graf 6377ccb2cb re-add jquery and select2 used in app.js 4 лет назад
Alexander Graf 3c8a8aa8f0 use less v3 to make less-loader happy 4 лет назад
Alexander Graf 1bb059f4c1 switched to newest possible versions for nodejs v8 4 лет назад
Alexander Graf 858312a5cb remove explicit jQuery dependency 4 лет назад
Alexander Graf 3f91dcb7af compile scheme list using a generator 4 лет назад
Alexander Graf 3bb0d68ead add cargo to build cryptography 4 лет назад
Alexander Graf 9790dcdabe updated dependencies 4 лет назад
Florent Daigniere 420afa53f8 Upgrade to alpine 3.14 4 лет назад
bors[bot] 4a5f6b1f92
Merge #1791
1791: Enhanced session handling r=mergify[bot] a=ghostwheel42

## What type of PR?

bug-fix

## What does this PR do?

- replaces flask_kvsession and simplekv with a mailu-specific session store
- call cleanup_sessions before first request and not on startup.
  this allows to run cmdline actions without redis (and makes it faster)
- allow running without redis for debugging purposes by setting MEMORY_SESSIONS to True
- don't sign session id, as it has plenty of entropy (as suggested by nextgens)
- adds method to prune a user's sessions

### Related issue(s)
- enhances and close #1787


Co-authored-by: Alexander Graf <ghostwheel42@users.noreply.github.com>
4 лет назад
Alexander Graf 8b71a92219 use fixed msg for key derivation 4 лет назад
Alexander Graf 92896ae646 fix bugs in model and schema introduced by #1604 4 лет назад
Alexander Graf 6740c77e43 small bugfix for exception 4 лет назад
Alexander Graf fab3168c23 Merge remote-tracking branch 'upstream/master' into kvsession 4 лет назад
Alexander Graf fbd945390d cleaned imports and fixed datetime and passlib use 4 лет назад
Dimitri Huisman 6dc1a19390
Merge branch 'master' into import-export 4 лет назад
bors[bot] fc1a663da2
Merge #1754
1754: centralize Webmail authentication behind the admin panel (SSO) r=mergify[bot] a=nextgens

## What type of PR?

Enhancement: it centralizes the authentication of webmails to the admin interface.

## What does this PR do?

It implements the glue required for webmails to do SSO using the admin interface.
One of the main advantages of centralizing things this way is that it reduces significantly the attack surface available to an unauthenticated attacker (no webmail access until there is a valid Flask session).

Others include the ability to implement 2FA down the line and rate-limit things as required.

### Related issue(s)
- #783

## Prerequistes
Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [x] In case of feature or enhancement: documentation updated accordingly
- [x] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/guide.html#changelog) entry file.


Co-authored-by: Florent Daigniere <nextgens@freenetproject.org>
4 лет назад
bors[bot] 4ff90683ca
Merge #1758 #1776
1758: Implement a simpler credential cache (alternative to #1755) r=mergify[bot] a=nextgens

## What type of PR?

Feature: it implements a credential cache to speedup authentication requests.

## What does this PR do?

Credentials are stored in cold-storage using a slow, salted/iterated hash function to prevent offline bruteforce attacks. This creates a performance bottleneck for no valid reason (see the
rationale/long version on https://github.com/Mailu/Mailu/issues/1194#issuecomment-762115549).

The new credential cache makes things fast again.

This is the simpler version of #1755 (with no new dependencies)

### Related issue(s)
- close #1411
- close #1194 
- close #1755

## Prerequistes
Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [x] In case of feature or enhancement: documentation updated accordingly
- [x] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/guide.html#changelog) entry file.


1776: optimize generation of transport nexthop r=mergify[bot] a=ghostwheel42

## What type of PR?

bug-fix and enhancement.

## What does this PR do?

Possibly there should be more input validation when editing a relay, but for now this tries to make the best out of the existing "smtp" attribute while maintaining backwards compatibility. When relay is empty, the transport's nexthop is the MX of the relayed domain to fix #1588 

```
RELAY			NEXTHOP						TRANSPORT
empty			use MX of relay domain				smtp:domain
:port			use MX of relay domain and use port	smtp:domain:port
target			resolve A/AAAA of target			smtp:[target]
target:port		resolve A/AAAA of target and use port	smtp:[target]:port
mx:target		resolve MX of target				smtp:target
mx:target:port	resolve MX of target and use port	smtp:target:port
lmtp:target		resolve A/AAAA of target			lmtp:target
lmtp:target:port	resolve A/AAAA of target and use port	lmtp:target:port

target can also be an IPv4 or IPv6 address (an IPv6 address must be enclosed in []: [2001:DB8::]).
```

When there is proper input validation and existing database entries are migrated this function can be made much shorter again.

### Related issue(s)
- closes #1588 
- closes #1815 

## Prerequistes
Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [x] In case of feature or enhancement: documentation updated accordingly
- [X] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/guide.html#changelog) entry file.


Co-authored-by: Florent Daigniere <nextgens@freenetproject.org>
Co-authored-by: Alexander Graf <ghostwheel42@users.noreply.github.com>
4 лет назад
bors[bot] d9da8e4bb2
Merge #1746
1746: DNS records for client autoconfiguration (RFC6186) r=Diman0 a=nextgens

## What type of PR?

Feature

## What does this PR do?

Add instructions on how to configure rfc6186 DNS records for client autoconfiguration

### Related issue(s)
- #224
- #498

## Prerequistes
Before we can consider review and merge, please make sure the following list is done and checked.
If an entry in not applicable, you can check it or remove it from the list.

- [x ] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/guide.html#changelog) entry file.


Co-authored-by: Florent Daigniere <nextgens@freenetproject.org>
4 лет назад
Alexander Graf 3f23e199f6 modified generation of session key and added refresh
- the session key is now generated using
  - a hash of the uid seeded by the apps secret_key (size: SESSION_KEY_BITS)
  - a random token (size: 128 bits)
  - the session's creation time (size: 32 bits)

- redis server side sessions are now refreshed after 1/2 the session lifetime
  even if not modified
- the cookie is also updated if necessary
4 лет назад
Alexander Graf 9ef8aaf698 removed double confiog and fixed shaker 4 лет назад
Alexander Graf a1fd44fced added lmtp: prefix and documentation 4 лет назад
Florent Daigniere 875308d405 Revert "In fact it could be global"
This reverts commit f52984e4c3.
4 лет назад
Florent Daigniere f52984e4c3 In fact it could be global 4 лет назад
Florent Daigniere ae9206e968 Implement a simple credential cache 4 лет назад
DjVinnii 419fed5e6e Add language selector 5 лет назад
Alexander Graf 731ce8ede9 fix permanent sessions. hash uid using SECRET_KEY
clean session in redis only once when starting
5 лет назад
Alexander Graf 4b8bbf760b default to 128 bits 5 лет назад
Alexander Graf 4b71bd56c4 replace flask_kvsession with mailu's own storage 5 лет назад
DjVinnii 7dafa22762 Add /language/<language> route for changing the locale using a session variable 5 лет назад
DjVinnii f30cca1263 Do imports based on AdminLTE plugins 5 лет назад
DjVinnii a4bb42faeb Remove extra space between 'AdminLTE' and 'on' in footer 5 лет назад
DjVinnii b2498e8c8f Refactor box macro to card 5 лет назад
DjVinnii 5ddea07c9a Fix form input append class 5 лет назад
DjVinnii 1db0a870f3 Fix log in icon in sidebar 5 лет назад
DjVinnii 51346c4860 Fix pre- and append styling 5 лет назад
DjVinnii e963e7495d Create datatable based on dataTable class instead of table class 5 лет назад
DjVinnii 0984173504 Change label to badge 5 лет назад
DjVinnii 8246497d16 Add card header to tables 5 лет назад
DjVinnii 49d68fa6d1 Fix horizontal scrollbar in sidebar 5 лет назад
DjVinnii 7d3c9d412d Change tables to datatables 5 лет назад
DjVinnii cdfa94c243 Make main action float right 5 лет назад
DjVinnii 0c5fda3fca Change macros.box to macros.card 5 лет назад
DjVinnii deca6e0c4a update user/settings 5 лет назад
DjVinnii 6b3170cb4c Update side menu 5 лет назад
DjVinnii c97728289b Update node version for building the image (AdminLTE requires node 10 or higher) 5 лет назад
DjVinnii e46d9e1fc9 Update admin-lte version in package.json 5 лет назад
Vincent Kling c6d0ef229f
Update messages.po 5 лет назад
Alexander Graf f0f79b23a3 Allow cleanup of sessions by key&value in data
This can be used to delete all sessions belonging to a user/login.
For no it just iterates over all sessions.
This could be enhanced by using a prefix for and deleting by prefix.
5 лет назад
Alexander Graf 83b1fbb9d6 Lazy loading of KVSessionExtension
- call cleanup_sessions on first kvstore access
  this allows to run cmdline actions without redis (and makes it faster)
- Allow development using DictStore by setting REDIS_ADDRESS to the empty string in env
- don't sign 64bit random session id as suggested by nextgens
5 лет назад
Alexander Graf 8bc4445572 Sync update of localpart, domain_name and email 5 лет назад
Alexander Graf 0c38128c4e Add pygments to requirements 5 лет назад