mailq-inspector/main.go

110 lines
3.1 KiB
Go
Raw Normal View History

2018-12-29 01:42:50 +01:00
package main
import (
"flag"
2018-12-29 18:09:44 +01:00
"fmt"
2018-12-30 14:51:08 +01:00
"io"
2018-12-29 18:09:44 +01:00
"os"
"os/exec"
2018-12-29 23:44:40 +01:00
"strconv"
"text/tabwriter"
2018-12-29 01:42:50 +01:00
)
2018-12-29 21:22:47 +01:00
import (
"mailq-inspector/parser"
)
var settings = make(map[string]string)
2018-12-29 23:44:40 +01:00
func main() {
parseArguments()
if settings["interactive"] == "false" {
showQueue()
}
if settings["interactive"] == "true" {
interactiveShell()
}
}
func parseArguments() {
2018-12-29 22:02:23 +01:00
mailqCommandPtr := flag.String("mailqCommand", "mailq", "Command to use for getting mailq output")
mailqCommandArgsPtr := flag.String("mailqCommandArgs", "", "Optional arguments to pass to mailqCommand")
2018-12-29 23:44:40 +01:00
interactivePtr := flag.Bool("interactive", false, "Set to true for shell mode")
flag.Parse()
2018-12-29 22:02:45 +01:00
settings["mailqCommand"] = *mailqCommandPtr
settings["mailqCommandArgs"] = *mailqCommandArgsPtr
2018-12-29 23:44:40 +01:00
settings["interactive"] = strconv.FormatBool(*interactivePtr)
}
2018-12-29 23:44:40 +01:00
func interactiveShell() {
}
func showQueue() {
2018-12-31 17:16:32 +01:00
queue, err := fetchQueue()
if err != nil {
fmt.Printf("Could not fetch queue entries: %s\n", err.Error())
os.Exit(1)
}
pagerReader, pagerWriter := io.Pipe()
pagerDone := make(chan bool)
go launchPager(pagerReader, pagerDone)
2018-12-31 17:16:32 +01:00
printQueueEntries(queue, pagerWriter)
pagerWriter.Close()
// Wait for pager to be closed before continuing the main program
<-pagerDone
}
2018-12-31 17:16:32 +01:00
func fetchQueue() (parser.MailQ, error) {
2018-12-30 13:34:45 +01:00
if settings["mailqCommandArgs"] == "" {
2018-12-31 17:16:32 +01:00
return readFromCmd(exec.Command(settings["mailqCommand"]))
2018-12-30 13:34:45 +01:00
} else {
2018-12-31 17:16:32 +01:00
return readFromCmd(exec.Command(settings["mailqCommand"], settings["mailqCommandArgs"]))
2018-12-30 13:34:45 +01:00
}
}
2018-12-31 17:16:32 +01:00
func printQueueEntries(queue parser.MailQ, writer io.Writer) {
fmt.Fprintf(writer, "%d entries total (%d active, %d deferred, %d on hold)\n\n", len(queue.Entries), queue.NumActive, queue.NumDeferred, queue.NumHold)
2018-12-31 16:47:53 +01:00
tabWriter := tabwriter.NewWriter(writer, 2, 2, 1, ' ', tabwriter.TabIndent)
2018-12-31 16:54:01 +01:00
fmt.Fprintf(tabWriter, "| %s\t| %s\t| %s\t| %s\t| %s\t| %s\t| %s\t| %s\t| \n", "Date", "Id", "Status", "Size", "Sender", "#", "First Recipient", "Reason")
2018-12-31 17:16:32 +01:00
for _, entry := range queue.Entries {
2018-12-31 17:20:48 +01:00
_, writeError := fmt.Fprintf(tabWriter, "| %s\t| %s\t| %s\t| %d\t| %s\t| {%d}\t| %s\t| %s\t| \n", entry.Date.Format(parser.SortableDateFormat), entry.Id, entry.Status, entry.Size, entry.Sender, len(entry.Recipients), entry.Recipients[0], entry.Reason)
if writeError != nil {
// A writeError is expected once the reader was closed
// This happens when the pager application got terminated
break
}
2018-12-30 14:51:08 +01:00
}
tabWriter.Flush()
2018-12-30 14:51:08 +01:00
}
func launchPager(reader *io.PipeReader, pagerDone chan<- bool) {
2018-12-31 16:47:53 +01:00
cmd := exec.Command("less", "--chop-long-lines")
2018-12-30 14:51:08 +01:00
cmd.Stdin = reader
cmd.Stdout = os.Stdout
if err := cmd.Start(); err != nil {
fmt.Printf("Error launching pager: %s\n", err.Error())
}
if err := cmd.Wait(); err != nil {
fmt.Printf("Error terminating pager: %s\n", err.Error())
} else {
reader.Close()
2018-12-30 14:51:08 +01:00
pagerDone <- true
}
}
2018-12-31 17:16:32 +01:00
func readFromCmd(cmd *exec.Cmd) (parser.MailQ, error) {
stdout, err := cmd.StdoutPipe()
2018-12-29 22:02:45 +01:00
if err != nil {
2018-12-31 17:16:32 +01:00
return parser.MailQ{}, err
2018-12-29 22:02:45 +01:00
}
2018-12-29 22:02:23 +01:00
if err := cmd.Start(); err != nil {
2018-12-31 17:16:32 +01:00
return parser.MailQ{}, err
2018-12-29 22:02:45 +01:00
}
2018-12-29 22:02:23 +01:00
result, resultError := parser.ParseMailQ(stdout)
if err := cmd.Wait(); err != nil {
2018-12-31 17:16:32 +01:00
return parser.MailQ{}, err
}
2018-12-29 22:02:23 +01:00
return result, resultError
2018-12-29 01:42:50 +01:00
}