diff options
Diffstat (limited to '')
-rw-r--r-- | pkg/datamaps/config.go | 267 |
1 files changed, 0 insertions, 267 deletions
diff --git a/pkg/datamaps/config.go b/pkg/datamaps/config.go deleted file mode 100644 index ec6f91e..0000000 --- a/pkg/datamaps/config.go +++ /dev/null @@ -1,267 +0,0 @@ -package datamaps - -import ( - "log" - "os" - "path/filepath" -) - -const ( - configDirName = "datamaps" - dbName = "datamaps.db" -) - -// Help text. -const Usage = ` -usage: datamaps COMMAND [OPTIONS] - --Managing datamap files- - -Command: datamap - -All datamap related actions. Before datamaps can do much, it must know about a datamap. -A datamap starts life as a CSV file with the format: - -cell_key,template_sheet,cell_reference,type -key1,sheet1,A10,TEXT -key2,sheet1,A11,NUMBER -... - -Options: - --import PATH Import a datamap the csv datamap at PATH - --datamapname NAME Name for imported datamap -` - -// mocking funcs in go https://stackoverflow.com/questions/19167970/mock-functions-in-go -// we only need the func signature to create the type. This is pretty weird, we're want to mock -// os.UserHomeDir so that we can set it to something like /tmp in our tests. Here we are creating -// two types: getUserConfigDir to represent the os.UserConfigDir function, dbPathChecker as a wrapper -// which which we can assign methods to that holds the value of the func os.UserConfigDir and the -// method, check(), which does the work, using the passed in func to determine the user $HOME/.config -// directory. -// Which is a lot of work for what it is, but it does make this testable and serves as an example -// of how things could be done in Go. - -// getUserConfigDir allows replaces os.UserConfigDir -// for testing purposes. -type getUserConfigDir func() (string, error) - -// DBPathChecker contains the func used to create the user config dir. -type DBPathChecker struct { - userConfig getUserConfigDir -} - -// NewDBPathChecker creates a DBPathChecker using whatever -// func you want as the argument, as long as it matches the -// type os.UserConfigDir. This makes it convenient for testing -// and was done as an experiment here to practice mocking in Go. -func NewDBPathChecker(h getUserConfigDir) *DBPathChecker { - return &DBPathChecker{userConfig: h} -} - -// Check returns true if the necessary config files (including -// the database) are in place - false if not -func (db *DBPathChecker) Check() bool { - userConfig, err := db.userConfig() - if err != nil { - log.Fatal(err) - } - dbPath := filepath.Join(userConfig, "datamaps.db") - if _, err := os.Stat(dbPath); os.IsNotExist(err) { - return false - } - return true -} - -// SetUp creates the config directory and requisite files -func SetUp() (string, error) { - dir, err := os.UserConfigDir() - if err != nil { - return "", err - } - // check if config folder exists - configPath := filepath.Join(dir, configDirName) - dbPath := filepath.Join(configPath, dbName) - if _, err := os.Stat(configPath); os.IsNotExist(err) { - log.Println("Config directory does not exist.") - log.Printf("Creating config directory %s.\n", configPath) - if err := os.Mkdir(filepath.Join(dir, "datamaps"), 0700); err != nil { - return "", err - } - } else { - log.Println("Config directory found.") - } - if _, err := os.Stat(dbPath); os.IsNotExist(err) { - log.Println("Database does not exist.") - _, err = os.Create(dbPath) - if err != nil { - return "", err - } - log.Printf("Creating database file at %s.\n", dbPath) - _, err := setupDB(dbPath) - if err != nil { - return "", err - } - } else { - log.Println("Database file found.") - } - return dir, nil -} - -func userConfigDir() (string, error) { - dir, err := os.UserConfigDir() - if err != nil { - return "", err - } - - configPath := filepath.Join(dir, configDirName) - - return configPath, nil -} - -func defaultDMPath() (string, error) { - dir, err := os.UserHomeDir() - if err != nil { - return "", err - } - - return filepath.Join(dir, "Documents", "datamaps"), nil -} - -func defaultXLSXPath() (string, error) { - dir, err := os.UserHomeDir() - if err != nil { - return "", err - } - - return filepath.Join(dir, "Documents", "datamaps", "import"), nil -} - -// Options for the whole CLI application. -type Options struct { - // Command is the main CLI sub-command (e.g. "datamap" handles all datamap - // operations and the flags that follow pertain only to that operation. - Command string - - // DBPath is the path to the database file. - DBPath string - - // DMPath is the path to a datamap file. - DMPath string - - // DMNane is the name of a datamap, whether setting or querying. - DMName string - - // XLSXPath is the path to a directory containing ".xlsx" files for - // importing. - XLSXPath string - - // ReturnName is the name of a Return, whether setting or querying. - ReturnName string - - // DMOverwrite is currently not used. - DMOverwrite bool - - // DMInitial is currently not used. - DMInitial bool - - // MasterOutPutPath is where the master.xlsx file is to be saved - MasterOutPutPath string -} - -func defaultOptions() *Options { - dbpath, err := userConfigDir() - if err != nil { - log.Fatalf("Unable to get user config directory %v", err) - } - - dmPath, err := defaultDMPath() - if err != nil { - log.Fatalf("unable to get default datamaps directory path: %v", err) - } - - xlsxPath, err := defaultXLSXPath() - if err != nil { - log.Fatalf("unable to get default XLSX directory path: %v", err) - } - - homeDir, err := os.UserHomeDir() - if err != nil { - log.Fatal("unable to get user home directory") - } - - return &Options{ - Command: "help", - DBPath: filepath.Join(dbpath, dbName), - DMPath: dmPath, - DMName: "Unnamed Datamap", - XLSXPath: xlsxPath, - ReturnName: "Unnamed Return", - DMOverwrite: false, - DMInitial: false, - MasterOutPutPath: filepath.Join(homeDir, "Desktop"), - } -} - -// nextString get the next string in a slice. -func nextString(args []string, i *int, message string) string { - if len(args) > *i+1 { - *i++ - } else { - log.Fatal(message) - } - - return args[*i] -} - -func processOptions(opts *Options, allArgs []string) { - if len(allArgs) == 0 { - allArgs = append(allArgs, "help") - } - switch allArgs[0] { - case "import": - opts.Command = "import" - case "help": - opts.Command = "help" - case "datamap": - opts.Command = "datamap" - case "setup": - opts.Command = "setup" - case "server": - opts.Command = "server" - case "createmaster": - opts.Command = "createmaster" - default: - log.Fatal("No relevant command provided.") - } - - restArgs := allArgs[1:] - - for i := 0; i < len(allArgs[1:]); i++ { - arg := restArgs[i] - switch arg { - case "--xlsxpath": - opts.XLSXPath = nextString(restArgs, &i, "xlsx directory path required") - case "--returnname": - opts.ReturnName = nextString(restArgs, &i, "return name required") - case "--import": - opts.DMPath = nextString(restArgs, &i, "import path required") - case "--datamapname": - opts.DMName = nextString(restArgs, &i, "datamap name required") - case "--overwrite": - opts.DMOverwrite = true - case "--initial": - opts.DMInitial = true - case "--masteroutputdir": - opts.MasterOutPutPath = nextString(restArgs, &i, "master output directory required") - } - } -} - -//ParseOptions for CLI. -func ParseOptions() *Options { - opts := defaultOptions() - processOptions(opts, os.Args[1:]) - - return opts -} |