package os
|
|
|
|
import (
|
|
"fmt"
|
|
"io/ioutil"
|
|
"os"
|
|
"os/signal"
|
|
"syscall"
|
|
)
|
|
|
|
type logger interface {
|
|
Info(msg string, keyvals ...interface{})
|
|
}
|
|
|
|
// TrapSignal catches the SIGTERM/SIGINT and executes cb function. After that it exits
|
|
// with code 0.
|
|
func TrapSignal(logger logger, cb func()) {
|
|
c := make(chan os.Signal, 1)
|
|
signal.Notify(c, os.Interrupt, syscall.SIGTERM)
|
|
go func() {
|
|
for sig := range c {
|
|
logger.Info(fmt.Sprintf("captured %v, exiting...", sig))
|
|
if cb != nil {
|
|
cb()
|
|
}
|
|
os.Exit(0)
|
|
}
|
|
}()
|
|
}
|
|
|
|
// Kill the running process by sending itself SIGTERM.
|
|
func Kill() error {
|
|
p, err := os.FindProcess(os.Getpid())
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return p.Signal(syscall.SIGTERM)
|
|
}
|
|
|
|
func Exit(s string) {
|
|
fmt.Printf(s + "\n")
|
|
os.Exit(1)
|
|
}
|
|
|
|
func EnsureDir(dir string, mode os.FileMode) error {
|
|
if _, err := os.Stat(dir); os.IsNotExist(err) {
|
|
err := os.MkdirAll(dir, mode)
|
|
if err != nil {
|
|
return fmt.Errorf("could not create directory %v: %w", dir, err)
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func FileExists(filePath string) bool {
|
|
_, err := os.Stat(filePath)
|
|
return !os.IsNotExist(err)
|
|
}
|
|
|
|
func ReadFile(filePath string) ([]byte, error) {
|
|
return ioutil.ReadFile(filePath)
|
|
}
|
|
|
|
func MustReadFile(filePath string) []byte {
|
|
fileBytes, err := ioutil.ReadFile(filePath)
|
|
if err != nil {
|
|
Exit(fmt.Sprintf("MustReadFile failed: %v", err))
|
|
return nil
|
|
}
|
|
return fileBytes
|
|
}
|
|
|
|
func WriteFile(filePath string, contents []byte, mode os.FileMode) error {
|
|
return ioutil.WriteFile(filePath, contents, mode)
|
|
}
|
|
|
|
func MustWriteFile(filePath string, contents []byte, mode os.FileMode) {
|
|
err := WriteFile(filePath, contents, mode)
|
|
if err != nil {
|
|
Exit(fmt.Sprintf("MustWriteFile failed: %v", err))
|
|
}
|
|
}
|