]> ruderich.org/simon Gitweb - nsscash/nsscash.git/blobdiff - main.go
nsscash: split main() into separate functions
[nsscash/nsscash.git] / main.go
diff --git a/main.go b/main.go
index 50263877f2a71380b1b774e40f3984498324a8c6..6322157f2ca9564d6523606095ee0967fd2d8daa 100644 (file)
--- a/main.go
+++ b/main.go
 package main
 
 import (
+       "bytes"
+       "flag"
+       "fmt"
+       "io/ioutil"
        "log"
        "os"
 )
 
 func main() {
-       if len(os.Args) != 2 {
-               log.SetFlags(0)
-               log.Fatalf("usage: %s <path/to/config>\n", os.Args[0])
+       flag.Usage = func() {
+               fmt.Fprintf(os.Stderr,
+                       "usage: %[1]s [options] fetch <config>\n"+
+                               "usage: %[1]s [options] convert <type> <src> <dst>\n"+
+                               "",
+                       os.Args[0])
+               flag.PrintDefaults()
        }
+       flag.Parse()
 
-       cfg, err := LoadConfig(os.Args[1])
-       if err != nil {
-               log.Fatal(err)
-       }
-       state, err := LoadState(cfg.StatePath)
-       if err != nil {
-               log.Fatal(err)
+       args := flag.Args()
+       if len(args) == 0 {
+               flag.Usage()
+               os.Exit(1)
        }
 
-       err = handleFiles(cfg, state)
-       if err != nil {
-               log.Fatal(err)
-       }
+       switch args[0] {
+       case "fetch":
+               if len(args) != 2 {
+                       break
+               }
+
+               mainFetch(args[1])
+               return
 
-       err = WriteStateIfChanged(cfg.StatePath, state)
-       if err != nil {
-               log.Fatal(err)
+       case "convert":
+               if len(args) != 4 {
+                       break
+               }
+
+               mainConvert(args[1], args[2], args[3])
+               return
        }
+
+       flag.Usage()
+       os.Exit(1)
+}
+
+func mainFetch(cfgPath string) {
+               cfg, err := LoadConfig(cfgPath)
+               if err != nil {
+                       log.Fatal(err)
+               }
+               state, err := LoadState(cfg.StatePath)
+               if err != nil {
+                       log.Fatal(err)
+               }
+               err = handleFiles(cfg, state)
+               if err != nil {
+                       log.Fatal(err)
+               }
+               // NOTE: Make sure to call WriteState() only if there were no
+               // errors (see WriteState() and README)
+               err = WriteState(cfg.StatePath, state)
+               if err != nil {
+                       log.Fatal(err)
+               }
+}
+
+func mainConvert(typ, srcPath, dstPath string) {
+               var t FileType
+               err := t.UnmarshalText([]byte(typ))
+               if err != nil {
+                       log.Fatal(err)
+               }
+
+               src, err := ioutil.ReadFile(srcPath)
+               if err != nil {
+                       log.Fatal(err)
+               }
+               var x bytes.Buffer
+               if t == FileTypePlain {
+                       x.Write(src)
+               } else if t == FileTypePasswd {
+                       pws, err := ParsePasswds(bytes.NewReader(src))
+                       if err != nil {
+                               log.Fatal(err)
+                       }
+                       err = SerializePasswds(&x, pws)
+                       if err != nil {
+                               log.Fatal(err)
+                       }
+               } else if t == FileTypeGroup {
+                       grs, err := ParseGroups(bytes.NewReader(src))
+                       if err != nil {
+                               log.Fatal(err)
+                       }
+                       err = SerializeGroups(&x, grs)
+                       if err != nil {
+                               log.Fatal(err)
+                       }
+               } else {
+                       log.Fatalf("unsupported file type %v", t)
+               }
+
+               // We must create the file first or deployFile() will abort
+               f, err := os.Create(dstPath)
+               if err != nil {
+                       log.Fatal(err)
+               }
+               f.Close()
+
+               err = deployFile(&File{
+                       Type: t,
+                       Url:  srcPath,
+                       Path: dstPath,
+                       body: x.Bytes(),
+               })
+               if err != nil {
+                       log.Fatal(err)
+               }
 }