main.go 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. // +build linux
  2. package main
  3. //go:generate go get dev.hexasoftware.com/hxs/genversion
  4. //go:generate genversion -package main -out version.go
  5. import (
  6. "fmt"
  7. "net/http"
  8. "os"
  9. "os/exec"
  10. "dev.hexasoftware.com/hxs/cloudmount/internal/core"
  11. "dev.hexasoftware.com/hxs/cloudmount/internal/fs/dropboxfs"
  12. "dev.hexasoftware.com/hxs/cloudmount/internal/fs/gdrivefs"
  13. "dev.hexasoftware.com/hxs/prettylog"
  14. )
  15. var (
  16. Name = "cloudmount"
  17. log = prettylog.New(Name)
  18. )
  19. func main() {
  20. // TODO: TEMP
  21. {
  22. // Globally insecure SSL for debugging
  23. r, _ := http.NewRequest("GET", "http://localhost", nil)
  24. cli := &http.Client{}
  25. cli.Do(r)
  26. tr := http.DefaultTransport.(*http.Transport)
  27. tr.TLSClientConfig.InsecureSkipVerify = true
  28. }
  29. prettylog.Global()
  30. // getClient
  31. fmt.Fprintf(os.Stderr, "%s-%s\n", Name, Version)
  32. core := core.New()
  33. // More will be added later
  34. core.Drivers["gdrive"] = gdrivefs.New
  35. core.Drivers["dropbox"] = dropboxfs.New
  36. if err := parseFlags(&core.Config); err != nil {
  37. log.Fatalln(err)
  38. }
  39. err := core.Init() // Before daemon, because might require interactivity
  40. if err != nil {
  41. log.Println("Err:", err)
  42. return
  43. }
  44. ////////////////////////////////
  45. // Daemon
  46. /////////////////
  47. if core.Config.Daemonize {
  48. subArgs := []string{}
  49. for _, arg := range os.Args[1:] {
  50. if arg == "-d" { // ignore daemon flag
  51. continue
  52. }
  53. subArgs = append(subArgs, arg)
  54. }
  55. cmd := exec.Command(os.Args[0], subArgs...)
  56. //cmd.Stdout = os.Stdout
  57. //cmd.Stderr = os.Stderr
  58. cmd.Start()
  59. fmt.Println("[PID]", cmd.Process.Pid)
  60. os.Exit(0)
  61. return
  62. }
  63. core.Mount()
  64. }