session.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. // Package session provides functions for sessions of incoming requests.
  2. package session // import "github.com/xtls/xray-core/common/session"
  3. import (
  4. "context"
  5. "math/rand"
  6. "github.com/xtls/xray-core/common/errors"
  7. "github.com/xtls/xray-core/common/net"
  8. "github.com/xtls/xray-core/common/protocol"
  9. "github.com/xtls/xray-core/common/signal"
  10. )
  11. // ID of a session.
  12. type ID uint32
  13. // NewID generates a new ID. The generated ID is high likely to be unique, but not cryptographically secure.
  14. // The generated ID will never be 0.
  15. func NewID() ID {
  16. for {
  17. id := ID(rand.Uint32())
  18. if id != 0 {
  19. return id
  20. }
  21. }
  22. }
  23. // ExportIDToError transfers session.ID into an error object, for logging purpose.
  24. // This can be used with error.WriteToLog().
  25. func ExportIDToError(ctx context.Context) errors.ExportOption {
  26. id := IDFromContext(ctx)
  27. return func(h *errors.ExportOptionHolder) {
  28. h.SessionID = uint32(id)
  29. }
  30. }
  31. // Inbound is the metadata of an inbound connection.
  32. type Inbound struct {
  33. // Source address of the inbound connection.
  34. Source net.Destination
  35. // Gateway address.
  36. Gateway net.Destination
  37. // Tag of the inbound proxy that handles the connection.
  38. Tag string
  39. // User is the user that authencates for the inbound. May be nil if the protocol allows anounymous traffic.
  40. User *protocol.MemoryUser
  41. // Conn is actually internet.Connection. May be nil.
  42. Conn net.Conn
  43. // Timer of the inbound buf copier. May be nil.
  44. Timer *signal.ActivityTimer
  45. }
  46. // Outbound is the metadata of an outbound connection.
  47. type Outbound struct {
  48. // Target address of the outbound connection.
  49. Target net.Destination
  50. RouteTarget net.Destination
  51. // Gateway address
  52. Gateway net.Address
  53. }
  54. // SniffingRequest controls the behavior of content sniffing.
  55. type SniffingRequest struct {
  56. ExcludeForDomain []string
  57. OverrideDestinationForProtocol []string
  58. Enabled bool
  59. MetadataOnly bool
  60. RouteOnly bool
  61. }
  62. // Content is the metadata of the connection content.
  63. type Content struct {
  64. // Protocol of current content.
  65. Protocol string
  66. SniffingRequest SniffingRequest
  67. Attributes map[string]string
  68. SkipDNSResolve bool
  69. }
  70. // Sockopt is the settings for socket connection.
  71. type Sockopt struct {
  72. // Mark of the socket connection.
  73. Mark int32
  74. }
  75. // SetAttribute attaches additional string attributes to content.
  76. func (c *Content) SetAttribute(name string, value string) {
  77. if c.Attributes == nil {
  78. c.Attributes = make(map[string]string)
  79. }
  80. c.Attributes[name] = value
  81. }
  82. // Attribute retrieves additional string attributes from content.
  83. func (c *Content) Attribute(name string) string {
  84. if c.Attributes == nil {
  85. return ""
  86. }
  87. return c.Attributes[name]
  88. }