//go:build darwin || dragonfly || freebsd || linux || netbsd || openbsd || solaris // +build darwin dragonfly freebsd linux netbsd openbsd solaris /* Maddy Mail Server - Composable all-in-one email server. Copyright © 2019-2020 Max Mazurov , Maddy Mail Server contributors This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ package maddy import ( "os" "os/signal" "syscall" "github.com/foxcpp/maddy/framework/hooks" "github.com/foxcpp/maddy/framework/log" ) // handleSignals function creates and listens on OS signals channel. // // OS-specific signals that correspond to the program termination // (SIGTERM, SIGHUP, SIGINT) will cause this function to return. // // SIGUSR1 will call reinitLogging without returning. func handleSignals() os.Signal { sig := make(chan os.Signal, 5) signal.Notify(sig, os.Interrupt, syscall.SIGTERM, syscall.SIGHUP, syscall.SIGINT, syscall.SIGUSR1, syscall.SIGUSR2) for { switch s := <-sig; s { case syscall.SIGUSR1: log.Printf("signal received (%s), rotating logs", s.String()) systemdStatus(SDReloading, "Reopening logs...") hooks.RunHooks(hooks.EventLogRotate) systemdStatus(SDReady, "Listening for incoming connections...") case syscall.SIGUSR2: log.Printf("signal received (%s), reloading state", s.String()) systemdStatus(SDReloading, "Reloading state...") hooks.RunHooks(hooks.EventReload) systemdStatus(SDReady, "Listening for incoming connections...") default: go func() { s := handleSignals() log.Printf("forced shutdown due to signal (%v)!", s) os.Exit(1) }() log.Printf("signal received (%v), next signal will force immediate shutdown.", s) return s } } }