policy.go 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. package core
  2. import (
  3. "sync"
  4. "time"
  5. "v2ray.com/core/common"
  6. "v2ray.com/core/features/policy"
  7. )
  8. type syncPolicyManager struct {
  9. sync.RWMutex
  10. policy.Manager
  11. }
  12. func (m *syncPolicyManager) ForLevel(level uint32) policy.Session {
  13. m.RLock()
  14. defer m.RUnlock()
  15. if m.Manager == nil {
  16. p := policy.SessionDefault()
  17. if level == 1 {
  18. p.Timeouts.ConnectionIdle = time.Second * 600
  19. }
  20. return p
  21. }
  22. return m.Manager.ForLevel(level)
  23. }
  24. func (m *syncPolicyManager) ForSystem() policy.System {
  25. m.RLock()
  26. defer m.RUnlock()
  27. if m.Manager == nil {
  28. return policy.System{}
  29. }
  30. return m.Manager.ForSystem()
  31. }
  32. func (m *syncPolicyManager) Start() error {
  33. m.RLock()
  34. defer m.RUnlock()
  35. if m.Manager == nil {
  36. return nil
  37. }
  38. return m.Manager.Start()
  39. }
  40. func (m *syncPolicyManager) Close() error {
  41. m.RLock()
  42. defer m.RUnlock()
  43. return common.Close(m.Manager)
  44. }
  45. func (m *syncPolicyManager) Set(manager policy.Manager) {
  46. if manager == nil {
  47. return
  48. }
  49. m.Lock()
  50. defer m.Unlock()
  51. common.Close(m.Manager) // nolint: errcheck
  52. m.Manager = manager
  53. }