api.conf 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. if ($_origin_id = '') {
  2. return 403 'ERROR: origin `$http_origin` is not allowed';
  3. }
  4. if ($http_x_jsproxy) {
  5. return 500 'ERROR: circular dependency';
  6. }
  7. proxy_set_header x-jsproxy 1;
  8. proxy_set_header Connection $http_connection;
  9. set $_level '';
  10. set $_switched '';
  11. set $_url '';
  12. set $_ver '';
  13. set $_ref '';
  14. set $_type '';
  15. set $_mode '';
  16. set $_bodyhash '';
  17. location = /preflight {
  18. internal;
  19. access_log off;
  20. more_set_headers
  21. 'access-control-allow-origin: *'
  22. 'access-control-allow-methods: GET,POST,PUT,PATCH,TRACE,DELETE,HEAD,OPTIONS'
  23. 'access-control-allow-headers: --raw-info,--level,--url,--referer,--cookie,--origin,--ext,--aceh,--ver,--type,--mode,accept,accept-charset,accept-encoding,accept-language,accept-datetime,authorization,cache-control,content-length,content-type,date,if-match,if-modified-since,if-none-match,if-range,if-unmodified-since,max-forwards,pragma,range,te,upgrade,upgrade-insecure-requests,x-requested-with,chrome-proxy,purpose'
  24. 'access-control-max-age: 1728000'
  25. ;
  26. return 204;
  27. }
  28. # HTTP(S) Proxy
  29. location = /http {
  30. if ($http_access_control_request_headers) {
  31. rewrite ^ /preflight;
  32. }
  33. access_by_lua_file ../lua/http-dec-req-hdr.lua;
  34. proxy_cache my_cache;
  35. proxy_pass $_url;
  36. more_set_headers
  37. 'server: $upstream_http_server'
  38. 'content-security-policy'
  39. 'content-security-policy-report-only'
  40. 'x-frame-options'
  41. ;
  42. header_filter_by_lua_file ../lua/http-enc-res-hdr.lua;
  43. body_filter_by_lua_file ../lua/http-body-hash.lua;
  44. }
  45. # WebSocket Proxy
  46. location = /ws {
  47. access_by_lua_file ../lua/ws-dec-req-hdr.lua;
  48. proxy_pass $_url;
  49. }