2
0

cmd_provider.go 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. package worker
  2. import (
  3. "time"
  4. "github.com/anmitsu/go-shlex"
  5. )
  6. type cmdConfig struct {
  7. name string
  8. upstreamURL, command string
  9. workingDir, logDir, logFile string
  10. interval time.Duration
  11. env map[string]string
  12. }
  13. type cmdProvider struct {
  14. baseProvider
  15. cmdConfig
  16. command []string
  17. }
  18. func newCmdProvider(c cmdConfig) (*cmdProvider, error) {
  19. // TODO: check config options
  20. provider := &cmdProvider{
  21. baseProvider: baseProvider{
  22. name: c.name,
  23. ctx: NewContext(),
  24. interval: c.interval,
  25. },
  26. cmdConfig: c,
  27. }
  28. provider.ctx.Set(_WorkingDirKey, c.workingDir)
  29. provider.ctx.Set(_LogDirKey, c.logDir)
  30. provider.ctx.Set(_LogFileKey, c.logFile)
  31. cmd, err := shlex.Split(c.command, true)
  32. if err != nil {
  33. return nil, err
  34. }
  35. provider.command = cmd
  36. return provider, nil
  37. }
  38. func (p *cmdProvider) Run() error {
  39. if err := p.Start(); err != nil {
  40. return err
  41. }
  42. return p.Wait()
  43. }
  44. func (p *cmdProvider) Start() error {
  45. env := map[string]string{
  46. "TUNASYNC_MIRROR_NAME": p.Name(),
  47. "TUNASYNC_WORKING_DIR": p.WorkingDir(),
  48. "TUNASYNC_UPSTREAM_URL": p.upstreamURL,
  49. "TUNASYNC_LOG_FILE": p.LogFile(),
  50. }
  51. for k, v := range p.env {
  52. env[k] = v
  53. }
  54. p.cmd = newCmdJob(p.command, p.WorkingDir(), env)
  55. if err := p.prepareLogFile(); err != nil {
  56. return err
  57. }
  58. if err := p.cmd.Start(); err != nil {
  59. return err
  60. }
  61. p.isRunning.Store(true)
  62. return nil
  63. }