phpheaders.go 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. package phpheaders
  2. import (
  3. "strings"
  4. )
  5. // Translate header names to PHP header names
  6. // All headers in 'commonHeaders' can be cached and registered safely
  7. // All other headers must be sanitized
  8. var CommonRequestHeaders = map[string]string{
  9. "Accept": "HTTP_ACCEPT",
  10. "Accept-Charset": "HTTP_ACCEPT_CHARSET",
  11. "Accept-Encoding": "HTTP_ACCEPT_ENCODING",
  12. "Accept-Language": "HTTP_ACCEPT_LANGUAGE",
  13. "Access-Control-Request-Headers": "HTTP_ACCESS_CONTROL_REQUEST_HEADERS",
  14. "Access-Control-Request-Method": "HTTP_ACCESS_CONTROL_REQUEST_METHOD",
  15. "Authorization": "HTTP_AUTHORIZATION",
  16. "Cache-Control": "HTTP_CACHE_CONTROL",
  17. "Connection": "HTTP_CONNECTION",
  18. "Content-Disposition": "HTTP_CONTENT_DISPOSITION",
  19. "Content-Encoding": "HTTP_CONTENT_ENCODING",
  20. "Content-Length": "HTTP_CONTENT_LENGTH",
  21. "Content-Type": "HTTP_CONTENT_TYPE",
  22. "Cookie": "HTTP_COOKIE",
  23. "Date": "HTTP_DATE",
  24. "Device-Memory": "HTTP_DEVICE_MEMORY",
  25. "DNT": "HTTP_DNT",
  26. "Downlink": "HTTP_DOWNLINK",
  27. "DPR": "HTTP_DPR",
  28. "Early-Data": "HTTP_EARLY_DATA",
  29. "ECT": "HTTP_ECT",
  30. "AM-I": "HTTP_AM_I",
  31. "Expect": "HTTP_EXPECT",
  32. "Forwarded": "HTTP_FORWARDED",
  33. "From": "HTTP_FROM",
  34. "Host": "HTTP_HOST",
  35. "If-Match": "HTTP_IF_MATCH",
  36. "If-Modified-Since": "HTTP_IF_MODIFIED_SINCE",
  37. "If-None-Match": "HTTP_IF_NONE_MATCH",
  38. "If-Range": "HTTP_IF_RANGE",
  39. "If-Unmodified-Since": "HTTP_IF_UNMODIFIED_SINCE",
  40. "Keep-Alive": "HTTP_KEEP_ALIVE",
  41. "Max-Forwards": "HTTP_MAX_FORWARDS",
  42. "Origin": "HTTP_ORIGIN",
  43. "Pragma": "HTTP_PRAGMA",
  44. "Proxy-Authorization": "HTTP_PROXY_AUTHORIZATION",
  45. "Range": "HTTP_RANGE",
  46. "Referer": "HTTP_REFERER",
  47. "RTT": "HTTP_RTT",
  48. "Save-Data": "HTTP_SAVE_DATA",
  49. "Sec-CH-UA": "HTTP_SEC_CH_UA",
  50. "Sec-CH-UA-Arch": "HTTP_SEC_CH_UA_ARCH",
  51. "Sec-CH-UA-Bitness": "HTTP_SEC_CH_UA_BITNESS",
  52. "Sec-CH-UA-Full-Version": "HTTP_SEC_CH_UA_FULL_VERSION",
  53. "Sec-CH-UA-Full-Version-List": "HTTP_SEC_CH_UA_FULL_VERSION_LIST",
  54. "Sec-CH-UA-Mobile": "HTTP_SEC_CH_UA_MOBILE",
  55. "Sec-CH-UA-Model": "HTTP_SEC_CH_UA_MODEL",
  56. "Sec-CH-UA-Platform": "HTTP_SEC_CH_UA_PLATFORM",
  57. "Sec-CH-UA-Platform-Version": "HTTP_SEC_CH_UA_PLATFORM_VERSION",
  58. "Sec-Fetch-Dest": "HTTP_SEC_FETCH_DEST",
  59. "Sec-Fetch-Mode": "HTTP_SEC_FETCH_MODE",
  60. "Sec-Fetch-Site": "HTTP_SEC_FETCH_SITE",
  61. "Sec-Fetch-User": "HTTP_SEC_FETCH_USER",
  62. "Sec-GPC": "HTTP_SEC_GPC",
  63. "Service-Worker-Navigation-Preload": "HTTP_SERVICE_WORKER_NAVIGATION_PRELOAD",
  64. "TE": "HTTP_TE",
  65. "Trailer": "HTTP_TRAILER",
  66. "Transfer-Encoding": "HTTP_TRANSFER_ENCODING",
  67. "Upgrade": "HTTP_UPGRADE",
  68. "Upgrade-Insecure-Requests": "HTTP_UPGRADE_INSECURE_REQUESTS",
  69. "User-Agent": "HTTP_USER_AGENT",
  70. "Via": "HTTP_VIA",
  71. "Viewport-Width": "HTTP_VIEWPORT_WIDTH",
  72. "Want-Digest": "HTTP_WANT_DIGEST",
  73. "Warning": "HTTP_WARNING",
  74. "Width": "HTTP_WIDTH",
  75. "X-Forwarded-For": "HTTP_X_FORWARDED_FOR",
  76. "X-Forwarded-Host": "HTTP_X_FORWARDED_HOST",
  77. "X-Forwarded-Proto": "HTTP_X_FORWARDED_PROTO",
  78. "A-IM": "HTTP_A_IM",
  79. "Accept-Datetime": "HTTP_ACCEPT_DATETIME",
  80. "Content-MD5": "HTTP_CONTENT_MD5",
  81. "HTTP2-Settings": "HTTP_HTTP2_SETTINGS",
  82. "Prefer": "HTTP_PREFER",
  83. "X-Requested-With": "HTTP_X_REQUESTED_WITH",
  84. "Front-End-Https": "HTTP_FRONT_END_HTTPS",
  85. "X-Http-Method-Override": "HTTP_X_HTTP_METHOD_OVERRIDE",
  86. "X-ATT-DeviceId": "HTTP_X_ATT_DEVICEID",
  87. "X-Wap-Profile": "HTTP_X_WAP_PROFILE",
  88. "Proxy-Connection": "HTTP_PROXY_CONNECTION",
  89. "X-UIDH": "HTTP_X_UIDH",
  90. "X-Csrf-Token": "HTTP_X_CSRF_TOKEN",
  91. "X-Request-ID": "HTTP_X_REQUEST_ID",
  92. "X-Correlation-ID": "HTTP_X_CORRELATION_ID",
  93. // Additional CDN/Framework headers
  94. "Cloudflare-Visitor": "HTTP_CLOUDFLARE_VISITOR",
  95. "Cloudfront-Viewer-Address": "HTTP_CLOUDFRONT_VIEWER_ADDRESS",
  96. "Cloudfront-Viewer-Country": "HTTP_CLOUDFRONT_VIEWER_COUNTRY",
  97. "X-Amzn-Trace-Id": "HTTP_X_AMZN_TRACE_ID",
  98. "X-Cloud-Trace-Context": "HTTP_X_CLOUD_TRACE_CONTEXT",
  99. "CF-Ray": "HTTP_CF_RAY",
  100. "CF-Visitor": "HTTP_CF_VISITOR",
  101. "CF-Request-ID": "HTTP_CF_REQUEST_ID",
  102. "CF-IPCountry": "HTTP_CF_IPCOUNTRY",
  103. "X-Device-Type": "HTTP_X_DEVICE_TYPE",
  104. "X-Network-Info": "HTTP_X_NETWORK_INFO",
  105. "X-Client-ID": "HTTP_X_CLIENT_ID",
  106. "X-Livewire": "HTTP_X_LIVEWIRE",
  107. }
  108. var headerNameReplacer = strings.NewReplacer(" ", "_", "-", "_")
  109. func GetCommonHeader(key string) string {
  110. return CommonRequestHeaders[key]
  111. }
  112. func GetUnCommonHeader(key string) string {
  113. return "HTTP_" + headerNameReplacer.Replace(strings.ToUpper(key)) + "\x00"
  114. }