mirror of
https://github.com/foxcpp/maddy.git
synced 2025-04-03 05:07:38 +03:00
Make it easier to avoid permission issues when setting up maddy
1. Clarify that you need to manually create the user and group when building from source. ./build.sh does not do that since it is a packaging tool, not system configuration one. 2. Do not require "go" command to be present when running ./build.sh install. go installation may be user-specific and unavailable when running with sudo. 3. Ease UMask restrictions. Allow group access. This allows CLI commands to be run by any user in maddy group. See #569.
This commit is contained in:
parent
a2f8916183
commit
28bdf6d33f
5 changed files with 32 additions and 12 deletions
21
build.sh
21
build.sh
|
@ -146,10 +146,23 @@ install() {
|
|||
# Attempt to install systemd units only for Linux.
|
||||
# Check is done using GOOS instead of uname -s to account for possible
|
||||
# package cross-compilation.
|
||||
if [ "$(go env GOOS)" = "linux" ]; then
|
||||
command install -m 0755 -d "${destdir}/${prefix}/lib/systemd/system/"
|
||||
command install -m 0644 "${builddir}"/systemd/*.service "${destdir}/${prefix}/lib/systemd/system/"
|
||||
fi
|
||||
# Though go command might be unavailable if build.sh is run
|
||||
# with sudo and go installation is user-specific, so fallback
|
||||
# to using uname -s in the end.
|
||||
set +e
|
||||
if command -v go >/dev/null 2>/dev/null; then
|
||||
set -e
|
||||
if [ "$(go env GOOS)" = "linux" ]; then
|
||||
command install -m 0755 -d "${destdir}/${prefix}/lib/systemd/system/"
|
||||
command install -m 0644 "${builddir}"/systemd/*.service "${destdir}/${prefix}/lib/systemd/system/"
|
||||
fi
|
||||
else
|
||||
set -e
|
||||
if [ "$(uname -s)" = "Linux" ]; then
|
||||
command install -m 0755 -d "${destdir}/${prefix}/lib/systemd/system/"
|
||||
command install -m 0644 "${builddir}"/systemd/*.service "${destdir}/${prefix}/lib/systemd/system/"
|
||||
fi
|
||||
fi
|
||||
|
||||
if [ -e "${builddir}"/man ]; then
|
||||
command install -m 0755 -d "${destdir}/${prefix}/share/man/man1/"
|
||||
|
|
5
dist/systemd/maddy.service
vendored
5
dist/systemd/maddy.service
vendored
|
@ -54,8 +54,9 @@ KillSignal=SIGTERM
|
|||
AmbientCapabilities=CAP_NET_BIND_SERVICE
|
||||
CapabilityBoundingSet=CAP_NET_BIND_SERVICE
|
||||
|
||||
# Force all files created by maddy to be only readable by it.
|
||||
UMask=0027
|
||||
# Force all files created by maddy to be only readable by it
|
||||
# and maddy group.
|
||||
UMask=0007
|
||||
|
||||
# Bump FD limitations. Even idle mail server can have a lot of FDs open (think
|
||||
# of idle IMAP connections, especially ones abandoned on the other end and
|
||||
|
|
5
dist/systemd/maddy@.service
vendored
5
dist/systemd/maddy@.service
vendored
|
@ -50,8 +50,9 @@ KillSignal=SIGTERM
|
|||
AmbientCapabilities=CAP_NET_BIND_SERVICE
|
||||
CapabilityBoundingSet=CAP_NET_BIND_SERVICE
|
||||
|
||||
# Force all files created by maddy to be only readable by it.
|
||||
UMask=0027
|
||||
# Force all files created by maddy to be only readable by it and
|
||||
# maddy group.
|
||||
UMask=0007
|
||||
|
||||
# Bump FD limitations. Even idle mail server can have a lot of FDs open (think
|
||||
# of idle IMAP connections, especially ones abandoned on the other end and
|
||||
|
|
|
@ -34,17 +34,19 @@ $ git clone https://github.com/foxcpp/maddy.git
|
|||
$ cd maddy
|
||||
```
|
||||
|
||||
3. Select the appropriate version to build:
|
||||
2. Select the appropriate version to build:
|
||||
```
|
||||
$ git checkout v0.7.0 # a specific release
|
||||
$ git checkout master # next bugfix release
|
||||
$ git checkout dev # next feature release
|
||||
```
|
||||
|
||||
2. Build & install it
|
||||
3. Build & install it
|
||||
```
|
||||
$ ./build.sh
|
||||
# ./build.sh install
|
||||
$ sudo ./build.sh install
|
||||
```
|
||||
|
||||
3. Have fun!
|
||||
4. Finish setup as described in [Setting up](../setting-up) (starting from System configuration).
|
||||
|
||||
|
||||
|
|
|
@ -246,6 +246,9 @@ storage account:
|
|||
$ maddy imap-acct create postmaster@example.org
|
||||
```
|
||||
|
||||
Note: to run `maddy` CLI commands, your user should be in the `maddy`
|
||||
group. Alternatively, just use `sudo -u maddy`.
|
||||
|
||||
That is it. Now you have your first e-mail address. when authenticating using
|
||||
your e-mail client, do not forget the username is "postmaster@example.org", not
|
||||
just "postmaster".
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue