2017-09-13 22:00:41 +08:00
|
|
|
package printer
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bufio"
|
|
|
|
"fmt"
|
2018-10-09 04:10:44 +08:00
|
|
|
"io"
|
2017-09-13 22:00:41 +08:00
|
|
|
"os"
|
|
|
|
"strings"
|
|
|
|
|
2020-04-15 04:47:30 +08:00
|
|
|
"github.com/StackExchange/dnscontrol/v3/models"
|
2017-09-13 22:00:41 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
// CLI is an abstraction around the CLI.
|
|
|
|
type CLI interface {
|
|
|
|
Printer
|
|
|
|
StartDomain(domain string)
|
|
|
|
StartDNSProvider(name string, skip bool)
|
|
|
|
EndProvider(numCorrections int, err error)
|
|
|
|
StartRegistrar(name string, skip bool)
|
|
|
|
|
|
|
|
PrintCorrection(n int, c *models.Correction)
|
|
|
|
EndCorrection(err error)
|
|
|
|
PromptToRun() bool
|
|
|
|
}
|
|
|
|
|
2018-01-10 01:53:16 +08:00
|
|
|
// Printer is a simple abstraction for printing data. Can be passed to providers to give simple output capabilities.
|
2017-09-13 22:00:41 +08:00
|
|
|
type Printer interface {
|
|
|
|
Debugf(fmt string, args ...interface{})
|
2018-10-09 04:10:44 +08:00
|
|
|
Printf(fmt string, args ...interface{})
|
2022-06-18 21:01:02 +08:00
|
|
|
Println(lines ...string)
|
2017-09-13 22:00:41 +08:00
|
|
|
Warnf(fmt string, args ...interface{})
|
2022-06-18 21:01:02 +08:00
|
|
|
Errorf(fmt string, args ...interface{})
|
2017-09-13 22:00:41 +08:00
|
|
|
}
|
|
|
|
|
2018-10-09 04:10:44 +08:00
|
|
|
// Debugf is called to print/format debug information.
|
|
|
|
func Debugf(fmt string, args ...interface{}) {
|
|
|
|
DefaultPrinter.Debugf(fmt, args...)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Printf is called to print/format information.
|
|
|
|
func Printf(fmt string, args ...interface{}) {
|
|
|
|
DefaultPrinter.Printf(fmt, args...)
|
|
|
|
}
|
|
|
|
|
2022-06-18 21:01:02 +08:00
|
|
|
// Println is called to print/format information.
|
|
|
|
func Println(lines ...string) {
|
|
|
|
DefaultPrinter.Println(lines...)
|
|
|
|
}
|
|
|
|
|
2018-10-09 04:10:44 +08:00
|
|
|
// Warnf is called to print/format a warning.
|
|
|
|
func Warnf(fmt string, args ...interface{}) {
|
|
|
|
DefaultPrinter.Warnf(fmt, args...)
|
|
|
|
}
|
|
|
|
|
2022-06-18 21:01:02 +08:00
|
|
|
// Errorf is called to print/format an error.
|
|
|
|
func Errorf(fmt string, args ...interface{}) {
|
|
|
|
DefaultPrinter.Errorf(fmt, args...)
|
|
|
|
}
|
|
|
|
|
2018-10-09 04:10:44 +08:00
|
|
|
var (
|
|
|
|
// DefaultPrinter is the default Printer, used by Debugf, Printf, and Warnf.
|
|
|
|
DefaultPrinter = &ConsolePrinter{
|
|
|
|
Reader: bufio.NewReader(os.Stdin),
|
|
|
|
Writer: os.Stdout,
|
|
|
|
Verbose: false,
|
|
|
|
}
|
|
|
|
)
|
2017-09-13 22:00:41 +08:00
|
|
|
|
2018-01-10 01:53:16 +08:00
|
|
|
// ConsolePrinter is a handle for the console printer.
|
2018-10-09 04:10:44 +08:00
|
|
|
type ConsolePrinter struct {
|
|
|
|
Reader *bufio.Reader
|
|
|
|
Writer io.Writer
|
|
|
|
|
|
|
|
Verbose bool
|
|
|
|
}
|
2017-09-13 22:00:41 +08:00
|
|
|
|
2018-01-10 01:53:16 +08:00
|
|
|
// StartDomain is called at the start of each domain.
|
2017-09-13 22:00:41 +08:00
|
|
|
func (c ConsolePrinter) StartDomain(domain string) {
|
2018-10-09 04:10:44 +08:00
|
|
|
fmt.Fprintf(c.Writer, "******************** Domain: %s\n", domain)
|
2017-09-13 22:00:41 +08:00
|
|
|
}
|
|
|
|
|
2018-01-10 01:53:16 +08:00
|
|
|
// PrintCorrection is called to print/format each correction.
|
2017-09-13 22:00:41 +08:00
|
|
|
func (c ConsolePrinter) PrintCorrection(i int, correction *models.Correction) {
|
2018-10-09 04:10:44 +08:00
|
|
|
fmt.Fprintf(c.Writer, "#%d: %s\n", i+1, correction.Msg)
|
2017-09-13 22:00:41 +08:00
|
|
|
}
|
|
|
|
|
2018-01-10 01:53:16 +08:00
|
|
|
// PromptToRun prompts the user to see if they want to execute a correction.
|
2017-09-13 22:00:41 +08:00
|
|
|
func (c ConsolePrinter) PromptToRun() bool {
|
2018-10-09 04:10:44 +08:00
|
|
|
fmt.Fprint(c.Writer, "Run? (Y/n): ")
|
|
|
|
txt, err := c.Reader.ReadString('\n')
|
2017-09-13 22:00:41 +08:00
|
|
|
run := true
|
|
|
|
if err != nil {
|
|
|
|
run = false
|
|
|
|
}
|
|
|
|
txt = strings.ToLower(strings.TrimSpace(txt))
|
|
|
|
if txt != "y" {
|
|
|
|
run = false
|
|
|
|
}
|
|
|
|
if !run {
|
2018-10-09 04:10:44 +08:00
|
|
|
fmt.Fprintln(c.Writer, "Skipping")
|
2017-09-13 22:00:41 +08:00
|
|
|
}
|
|
|
|
return run
|
|
|
|
}
|
|
|
|
|
2018-01-10 01:53:16 +08:00
|
|
|
// EndCorrection is called at the end of each correction.
|
2017-09-13 22:00:41 +08:00
|
|
|
func (c ConsolePrinter) EndCorrection(err error) {
|
|
|
|
if err != nil {
|
2018-10-09 04:10:44 +08:00
|
|
|
fmt.Fprintln(c.Writer, "FAILURE!", err)
|
2017-09-13 22:00:41 +08:00
|
|
|
} else {
|
2018-10-09 04:10:44 +08:00
|
|
|
fmt.Fprintln(c.Writer, "SUCCESS!")
|
2017-09-13 22:00:41 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-01-10 01:53:16 +08:00
|
|
|
// StartDNSProvider is called at the start of each new provider.
|
2017-09-13 22:00:41 +08:00
|
|
|
func (c ConsolePrinter) StartDNSProvider(provider string, skip bool) {
|
|
|
|
lbl := ""
|
|
|
|
if skip {
|
|
|
|
lbl = " (skipping)\n"
|
|
|
|
}
|
2021-06-22 22:24:49 +08:00
|
|
|
fmt.Fprintf(c.Writer, "----- DNS Provider: %s...%s\n", provider, lbl)
|
2017-09-13 22:00:41 +08:00
|
|
|
}
|
|
|
|
|
2018-01-10 01:53:16 +08:00
|
|
|
// StartRegistrar is called at the start of each new registrar.
|
2017-09-13 22:00:41 +08:00
|
|
|
func (c ConsolePrinter) StartRegistrar(provider string, skip bool) {
|
|
|
|
lbl := ""
|
|
|
|
if skip {
|
|
|
|
lbl = " (skipping)\n"
|
|
|
|
}
|
2021-06-22 22:24:49 +08:00
|
|
|
fmt.Fprintf(c.Writer, "----- Registrar: %s...%s\n", provider, lbl)
|
2017-09-13 22:00:41 +08:00
|
|
|
}
|
|
|
|
|
2018-01-10 01:53:16 +08:00
|
|
|
// EndProvider is called at the end of each provider.
|
2017-09-13 22:00:41 +08:00
|
|
|
func (c ConsolePrinter) EndProvider(numCorrections int, err error) {
|
|
|
|
if err != nil {
|
2018-10-09 04:10:44 +08:00
|
|
|
fmt.Fprintln(c.Writer, "ERROR")
|
|
|
|
fmt.Fprintf(c.Writer, "Error getting corrections: %s\n", err)
|
2017-09-13 22:00:41 +08:00
|
|
|
} else {
|
|
|
|
plural := "s"
|
|
|
|
if numCorrections == 1 {
|
|
|
|
plural = ""
|
|
|
|
}
|
2018-10-09 04:10:44 +08:00
|
|
|
fmt.Fprintf(c.Writer, "%d correction%s\n", numCorrections, plural)
|
2017-09-13 22:00:41 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-01-10 01:53:16 +08:00
|
|
|
// Debugf is called to print/format debug information.
|
2017-09-13 22:00:41 +08:00
|
|
|
func (c ConsolePrinter) Debugf(format string, args ...interface{}) {
|
2018-10-09 04:10:44 +08:00
|
|
|
if c.Verbose {
|
|
|
|
fmt.Fprintf(c.Writer, format, args...)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Printf is called to print/format information.
|
|
|
|
func (c ConsolePrinter) Printf(format string, args ...interface{}) {
|
|
|
|
fmt.Fprintf(c.Writer, format, args...)
|
2017-09-13 22:00:41 +08:00
|
|
|
}
|
|
|
|
|
2022-06-18 21:01:02 +08:00
|
|
|
// Println is called to print/format information.
|
|
|
|
func (c ConsolePrinter) Println(lines ...string) {
|
|
|
|
fmt.Fprintln(c.Writer, lines)
|
|
|
|
}
|
|
|
|
|
2018-01-10 01:53:16 +08:00
|
|
|
// Warnf is called to print/format a warning.
|
2017-09-13 22:00:41 +08:00
|
|
|
func (c ConsolePrinter) Warnf(format string, args ...interface{}) {
|
2018-10-09 04:10:44 +08:00
|
|
|
fmt.Fprintf(c.Writer, "WARNING: "+format, args...)
|
2017-09-13 22:00:41 +08:00
|
|
|
}
|
2022-06-18 21:01:02 +08:00
|
|
|
|
|
|
|
// Errorf is called to print/format an error.
|
|
|
|
func (c ConsolePrinter) Errorf(format string, args ...interface{}) {
|
|
|
|
fmt.Fprintf(c.Writer, "ERROR: "+format, args...)
|
|
|
|
}
|