2
0

cmd_provider.go 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  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) Type() providerEnum {
  39. return provCommand
  40. }
  41. func (p *cmdProvider) Upstream() string {
  42. return p.upstreamURL
  43. }
  44. func (p *cmdProvider) Run() error {
  45. if err := p.Start(); err != nil {
  46. return err
  47. }
  48. return p.Wait()
  49. }
  50. func (p *cmdProvider) Start() error {
  51. env := map[string]string{
  52. "TUNASYNC_MIRROR_NAME": p.Name(),
  53. "TUNASYNC_WORKING_DIR": p.WorkingDir(),
  54. "TUNASYNC_UPSTREAM_URL": p.upstreamURL,
  55. "TUNASYNC_LOG_FILE": p.LogFile(),
  56. }
  57. for k, v := range p.env {
  58. env[k] = v
  59. }
  60. p.cmd = newCmdJob(p, p.command, p.WorkingDir(), env)
  61. if err := p.prepareLogFile(); err != nil {
  62. return err
  63. }
  64. if err := p.cmd.Start(); err != nil {
  65. return err
  66. }
  67. p.isRunning.Store(true)
  68. return nil
  69. }