itsi-server 0.1.1 → 0.2.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/Cargo.lock +4487 -0
- data/Cargo.toml +7 -0
- data/README.md +6 -0
- data/Rakefile +7 -4
- data/exe/itsi +152 -46
- data/ext/itsi_acme/Cargo.toml +86 -0
- data/ext/itsi_acme/examples/high_level.rs +63 -0
- data/ext/itsi_acme/examples/high_level_warp.rs +52 -0
- data/ext/itsi_acme/examples/low_level.rs +87 -0
- data/ext/itsi_acme/examples/low_level_axum.rs +66 -0
- data/ext/itsi_acme/src/acceptor.rs +81 -0
- data/ext/itsi_acme/src/acme.rs +354 -0
- data/ext/itsi_acme/src/axum.rs +86 -0
- data/ext/itsi_acme/src/cache.rs +39 -0
- data/ext/itsi_acme/src/caches/boxed.rs +80 -0
- data/ext/itsi_acme/src/caches/composite.rs +69 -0
- data/ext/itsi_acme/src/caches/dir.rs +106 -0
- data/ext/itsi_acme/src/caches/mod.rs +11 -0
- data/ext/itsi_acme/src/caches/no.rs +78 -0
- data/ext/itsi_acme/src/caches/test.rs +136 -0
- data/ext/itsi_acme/src/config.rs +172 -0
- data/ext/itsi_acme/src/https_helper.rs +69 -0
- data/ext/itsi_acme/src/incoming.rs +142 -0
- data/ext/itsi_acme/src/jose.rs +161 -0
- data/ext/itsi_acme/src/lib.rs +142 -0
- data/ext/itsi_acme/src/resolver.rs +59 -0
- data/ext/itsi_acme/src/state.rs +424 -0
- data/ext/itsi_error/Cargo.toml +3 -0
- data/ext/itsi_error/src/lib.rs +98 -24
- data/ext/itsi_error/target/debug/build/clang-sys-da71b0344e568175/out/common.rs +355 -0
- data/ext/itsi_error/target/debug/build/clang-sys-da71b0344e568175/out/dynamic.rs +276 -0
- data/ext/itsi_error/target/debug/build/clang-sys-da71b0344e568175/out/macros.rs +49 -0
- data/ext/itsi_error/target/debug/build/rb-sys-49f554618693db24/out/bindings-0.9.110-mri-arm64-darwin23-3.4.2.rs +8865 -0
- data/ext/itsi_error/target/debug/incremental/itsi_error-1mmt5sux7jb0i/s-h510z7m8v9-0bxu7yd.lock +0 -0
- data/ext/itsi_error/target/debug/incremental/itsi_error-2vn3jey74oiw0/s-h5113n0e7e-1v5qzs6.lock +0 -0
- data/ext/itsi_error/target/debug/incremental/itsi_error-37uv9dicz7awp/s-h510ykifhe-0tbnep2.lock +0 -0
- data/ext/itsi_error/target/debug/incremental/itsi_error-37uv9dicz7awp/s-h510yyocpj-0tz7ug7.lock +0 -0
- data/ext/itsi_error/target/debug/incremental/itsi_error-37uv9dicz7awp/s-h510z0xc8g-14ol18k.lock +0 -0
- data/ext/itsi_error/target/debug/incremental/itsi_error-3g5qf4y7d54uj/s-h5113n0e7d-1trk8on.lock +0 -0
- data/ext/itsi_error/target/debug/incremental/itsi_error-3lpfftm45d3e2/s-h510z7m8r3-1pxp20o.lock +0 -0
- data/ext/itsi_error/target/debug/incremental/itsi_error-3o4qownhl3d7n/s-h510ykifek-1uxasnk.lock +0 -0
- data/ext/itsi_error/target/debug/incremental/itsi_error-3o4qownhl3d7n/s-h510yyocki-11u37qm.lock +0 -0
- data/ext/itsi_error/target/debug/incremental/itsi_error-3o4qownhl3d7n/s-h510z0xc93-0pmy0zm.lock +0 -0
- data/ext/itsi_instrument_entry/Cargo.toml +15 -0
- data/ext/itsi_instrument_entry/src/lib.rs +31 -0
- data/ext/itsi_rb_helpers/Cargo.toml +3 -0
- data/ext/itsi_rb_helpers/src/heap_value.rs +139 -0
- data/ext/itsi_rb_helpers/src/lib.rs +141 -10
- data/ext/itsi_rb_helpers/target/debug/build/clang-sys-da71b0344e568175/out/common.rs +355 -0
- data/ext/itsi_rb_helpers/target/debug/build/clang-sys-da71b0344e568175/out/dynamic.rs +276 -0
- data/ext/itsi_rb_helpers/target/debug/build/clang-sys-da71b0344e568175/out/macros.rs +49 -0
- data/ext/itsi_rb_helpers/target/debug/build/rb-sys-eb9ed4ff3a60f995/out/bindings-0.9.110-mri-arm64-darwin23-3.4.2.rs +8865 -0
- data/ext/itsi_rb_helpers/target/debug/incremental/itsi_rb_helpers-040pxg6yhb3g3/s-h5113n7a1b-03bwlt4.lock +0 -0
- data/ext/itsi_rb_helpers/target/debug/incremental/itsi_rb_helpers-131g1u4dzkt1a/s-h51113xnh3-1eik1ip.lock +0 -0
- data/ext/itsi_rb_helpers/target/debug/incremental/itsi_rb_helpers-131g1u4dzkt1a/s-h5111704jj-0g4rj8x.lock +0 -0
- data/ext/itsi_rb_helpers/target/debug/incremental/itsi_rb_helpers-1q2d3drtxrzs5/s-h5113n79yl-0bxcqc5.lock +0 -0
- data/ext/itsi_rb_helpers/target/debug/incremental/itsi_rb_helpers-374a9h7ovycj0/s-h51113xoox-10de2hp.lock +0 -0
- data/ext/itsi_rb_helpers/target/debug/incremental/itsi_rb_helpers-374a9h7ovycj0/s-h5111704w7-0vdq7gq.lock +0 -0
- data/ext/itsi_scheduler/Cargo.toml +24 -0
- data/ext/itsi_scheduler/src/itsi_scheduler/io_helpers.rs +56 -0
- data/ext/itsi_scheduler/src/itsi_scheduler/io_waiter.rs +44 -0
- data/ext/itsi_scheduler/src/itsi_scheduler/timer.rs +44 -0
- data/ext/itsi_scheduler/src/itsi_scheduler.rs +314 -0
- data/ext/itsi_scheduler/src/lib.rs +39 -0
- data/ext/itsi_server/Cargo.lock +2956 -0
- data/ext/itsi_server/Cargo.toml +75 -14
- data/ext/itsi_server/extconf.rb +1 -1
- data/ext/itsi_server/src/default_responses/html/401.html +68 -0
- data/ext/itsi_server/src/default_responses/html/403.html +68 -0
- data/ext/itsi_server/src/default_responses/html/404.html +68 -0
- data/ext/itsi_server/src/default_responses/html/413.html +71 -0
- data/ext/itsi_server/src/default_responses/html/429.html +68 -0
- data/ext/itsi_server/src/default_responses/html/500.html +71 -0
- data/ext/itsi_server/src/default_responses/html/502.html +71 -0
- data/ext/itsi_server/src/default_responses/html/503.html +68 -0
- data/ext/itsi_server/src/default_responses/html/504.html +69 -0
- data/ext/itsi_server/src/default_responses/html/index.html +238 -0
- data/ext/itsi_server/src/default_responses/json/401.json +6 -0
- data/ext/itsi_server/src/default_responses/json/403.json +6 -0
- data/ext/itsi_server/src/default_responses/json/404.json +6 -0
- data/ext/itsi_server/src/default_responses/json/413.json +6 -0
- data/ext/itsi_server/src/default_responses/json/429.json +6 -0
- data/ext/itsi_server/src/default_responses/json/500.json +6 -0
- data/ext/itsi_server/src/default_responses/json/502.json +6 -0
- data/ext/itsi_server/src/default_responses/json/503.json +6 -0
- data/ext/itsi_server/src/default_responses/json/504.json +6 -0
- data/ext/itsi_server/src/default_responses/mod.rs +11 -0
- data/ext/itsi_server/src/env.rs +43 -0
- data/ext/itsi_server/src/lib.rs +133 -40
- data/ext/itsi_server/src/prelude.rs +2 -0
- data/ext/itsi_server/src/ruby_types/itsi_body_proxy/big_bytes.rs +109 -0
- data/ext/itsi_server/src/ruby_types/itsi_body_proxy/mod.rs +143 -0
- data/ext/itsi_server/src/ruby_types/itsi_grpc_call.rs +344 -0
- data/ext/itsi_server/src/ruby_types/itsi_grpc_response_stream/mod.rs +264 -0
- data/ext/itsi_server/src/ruby_types/itsi_http_request.rs +362 -0
- data/ext/itsi_server/src/ruby_types/itsi_http_response.rs +391 -0
- data/ext/itsi_server/src/ruby_types/itsi_server/file_watcher.rs +233 -0
- data/ext/itsi_server/src/ruby_types/itsi_server/itsi_server_config.rs +565 -0
- data/ext/itsi_server/src/ruby_types/itsi_server.rs +86 -0
- data/ext/itsi_server/src/ruby_types/mod.rs +48 -0
- data/ext/itsi_server/src/server/binds/bind.rs +204 -0
- data/ext/itsi_server/src/server/binds/bind_protocol.rs +37 -0
- data/ext/itsi_server/src/server/binds/listener.rs +444 -0
- data/ext/itsi_server/src/server/binds/mod.rs +4 -0
- data/ext/itsi_server/src/server/binds/tls/locked_dir_cache.rs +132 -0
- data/ext/itsi_server/src/server/binds/tls.rs +278 -0
- data/ext/itsi_server/src/server/byte_frame.rs +32 -0
- data/ext/itsi_server/src/server/http_message_types.rs +97 -0
- data/ext/itsi_server/src/server/io_stream.rs +105 -0
- data/ext/itsi_server/src/server/lifecycle_event.rs +12 -0
- data/ext/itsi_server/src/server/middleware_stack/middleware.rs +170 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/allow_list.rs +63 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/auth_api_key.rs +94 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/auth_basic.rs +94 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/auth_jwt.rs +343 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/cache_control.rs +151 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/compression.rs +316 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/cors.rs +301 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/csp.rs +193 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/deny_list.rs +64 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/error_response/default_responses.rs +192 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/error_response.rs +171 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/etag.rs +198 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/header_interpretation.rs +82 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/intrusion_protection.rs +209 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/log_requests.rs +82 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/max_body.rs +47 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/mod.rs +116 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/proxy.rs +411 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/rate_limit.rs +142 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/redirect.rs +55 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/request_headers.rs +54 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/response_headers.rs +51 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/ruby_app.rs +126 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/static_assets.rs +187 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/static_response.rs +55 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/string_rewrite.rs +173 -0
- data/ext/itsi_server/src/server/middleware_stack/middlewares/token_source.rs +31 -0
- data/ext/itsi_server/src/server/middleware_stack/mod.rs +381 -0
- data/ext/itsi_server/src/server/mod.rs +13 -5
- data/ext/itsi_server/src/server/process_worker.rs +247 -0
- data/ext/itsi_server/src/server/redirect_type.rs +26 -0
- data/ext/itsi_server/src/server/request_job.rs +11 -0
- data/ext/itsi_server/src/server/serve_strategy/cluster_mode.rs +354 -0
- data/ext/itsi_server/src/server/serve_strategy/mod.rs +30 -0
- data/ext/itsi_server/src/server/serve_strategy/single_mode.rs +481 -0
- data/ext/itsi_server/src/server/signal.rs +77 -0
- data/ext/itsi_server/src/server/size_limited_incoming.rs +107 -0
- data/ext/itsi_server/src/server/thread_worker.rs +479 -0
- data/ext/itsi_server/src/services/cache_store.rs +74 -0
- data/ext/itsi_server/src/services/itsi_http_service.rs +257 -0
- data/ext/itsi_server/src/services/mime_types.rs +1416 -0
- data/ext/itsi_server/src/services/mod.rs +6 -0
- data/ext/itsi_server/src/services/password_hasher.rs +83 -0
- data/ext/itsi_server/src/services/rate_limiter.rs +580 -0
- data/ext/itsi_server/src/services/static_file_server.rs +1340 -0
- data/ext/itsi_tracing/Cargo.toml +5 -0
- data/ext/itsi_tracing/src/lib.rs +366 -7
- data/ext/itsi_tracing/target/debug/incremental/itsi_tracing-0994n8rpvvt9m/s-h510hfz1f6-1kbycmq.lock +0 -0
- data/ext/itsi_tracing/target/debug/incremental/itsi_tracing-0bob7bf4yq34i/s-h5113125h5-0lh4rag.lock +0 -0
- data/ext/itsi_tracing/target/debug/incremental/itsi_tracing-2fcodulrxbbxo/s-h510h2infk-0hp5kjw.lock +0 -0
- data/ext/itsi_tracing/target/debug/incremental/itsi_tracing-2iak63r1woi1l/s-h510h2in4q-0kxfzw1.lock +0 -0
- data/ext/itsi_tracing/target/debug/incremental/itsi_tracing-2kk4qj9gn5dg2/s-h5113124kv-0enwon2.lock +0 -0
- data/ext/itsi_tracing/target/debug/incremental/itsi_tracing-2mwo0yas7dtw4/s-h510hfz1ha-1udgpei.lock +0 -0
- data/lib/itsi/http_request/response_status_shortcodes.rb +76 -0
- data/lib/itsi/http_request.rb +218 -0
- data/lib/itsi/http_response.rb +42 -0
- data/lib/itsi/passfile.rb +108 -0
- data/lib/itsi/server/config/config_helpers.rb +105 -0
- data/lib/itsi/server/config/dsl.rb +211 -0
- data/lib/itsi/server/config/known_paths/KitchensinkDirectories.txt +2346 -0
- data/lib/itsi/server/config/known_paths/Randomfiles.txt +24 -0
- data/lib/itsi/server/config/known_paths/UnixDotfiles.txt +52 -0
- data/lib/itsi/server/config/known_paths/backdoors/ASP_CommonBackdoors.txt +29 -0
- data/lib/itsi/server/config/known_paths/backdoors/bot_control_panels.txt +1668 -0
- data/lib/itsi/server/config/known_paths/backdoors/shells.txt +1167 -0
- data/lib/itsi/server/config/known_paths/cgi/CGI_HTTP_POST.txt +7 -0
- data/lib/itsi/server/config/known_paths/cgi/CGI_HTTP_POST_Windows.txt +6 -0
- data/lib/itsi/server/config/known_paths/cgi/CGI_Microsoft.txt +79 -0
- data/lib/itsi/server/config/known_paths/cgi/CGI_XPlatform.txt +3948 -0
- data/lib/itsi/server/config/known_paths/cms/README.md +5 -0
- data/lib/itsi/server/config/known_paths/cms/drupal_plugins.txt +6320 -0
- data/lib/itsi/server/config/known_paths/cms/drupal_themes.txt +828 -0
- data/lib/itsi/server/config/known_paths/cms/joomla_plugins.txt +224 -0
- data/lib/itsi/server/config/known_paths/cms/joomla_themes.txt +30 -0
- data/lib/itsi/server/config/known_paths/cms/php-nuke.txt +2142 -0
- data/lib/itsi/server/config/known_paths/cms/wordpress.txt +1566 -0
- data/lib/itsi/server/config/known_paths/cms/wp_common_theme_files.txt +46 -0
- data/lib/itsi/server/config/known_paths/cms/wp_plugins.txt +13366 -0
- data/lib/itsi/server/config/known_paths/cms/wp_plugins_full.txt +68662 -0
- data/lib/itsi/server/config/known_paths/cms/wp_plugins_top225.txt +225 -0
- data/lib/itsi/server/config/known_paths/cms/wp_themes.readme +12 -0
- data/lib/itsi/server/config/known_paths/cms/wp_themes.txt +7336 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/3CharExtBrute.txt +17576 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/CommonWebExtensions.txt +80 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/Extensions.Backup.txt +14 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/Extensions.Common.txt +865 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/Extensions.Compressed.txt +186 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/Extensions.Mostcommon.txt +30 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/Extensions.Skipfish.txt +93 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/WordlistSkipfish.txt +1918 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/copy_of.txt +8 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-large-directories-lowercase.txt +56180 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-large-directories.txt +62290 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-large-extensions-lowercase.txt +2367 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-large-extensions.txt +2450 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-large-files-lowercase.txt +35323 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-large-files.txt +37037 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-large-words-lowercase.txt +107982 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-large-words.txt +119600 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-medium-directories-lowercase.txt +26593 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-medium-directories.txt +30009 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-medium-extensions-lowercase.txt +1233 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-medium-extensions.txt +1289 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-medium-files-lowercase.txt +16243 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-medium-files.txt +17128 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-medium-words-lowercase.txt +56293 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-medium-words.txt +63087 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-small-directories-lowercase.txt +17776 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-small-directories.txt +20122 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-small-extensions-lowercase.txt +914 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-small-extensions.txt +963 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-small-files-lowercase.txt +10848 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-small-files.txt +11424 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-small-words-lowercase.txt +38267 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/raft-small-words.txt +43003 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/spanish.txt +445 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/test_demo.txt +36 -0
- data/lib/itsi/server/config/known_paths/filename-dirname-bruteforce/upload_variants.txt +44 -0
- data/lib/itsi/server/config/known_paths/login-file-locations/Logins.txt +71 -0
- data/lib/itsi/server/config/known_paths/login-file-locations/cfm.txt +294 -0
- data/lib/itsi/server/config/known_paths/login-file-locations/html.txt +295 -0
- data/lib/itsi/server/config/known_paths/login-file-locations/jsp.txt +294 -0
- data/lib/itsi/server/config/known_paths/login-file-locations/php.txt +294 -0
- data/lib/itsi/server/config/known_paths/login-file-locations/windows-asp.txt +294 -0
- data/lib/itsi/server/config/known_paths/login-file-locations/windows-aspx.txt +294 -0
- data/lib/itsi/server/config/known_paths/password-file-locations/Passwords.txt +47 -0
- data/lib/itsi/server/config/known_paths/php/PHP.txt +30 -0
- data/lib/itsi/server/config/known_paths/php/PHP_CommonBackdoors.txt +5 -0
- data/lib/itsi/server/config/known_paths/proxy-conf.txt +31 -0
- data/lib/itsi/server/config/known_paths/tftp.txt +79 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/ADFS.txt +86 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/AdobeXML.txt +16 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/Apache.txt +101 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/ApacheTomcat.txt +47 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/Apache_Axis.txt +16 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/ColdFusion.txt +111 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/FatwireCMS.txt +390 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/Frontpage.txt +38 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/HP_System_Mgmt_Homepage.txt +239 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/HTTP_POST_Microsoft.txt +2 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/Hyperion.txt +578 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/IIS.txt +187 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/JBoss.txt +5 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/JRun.txt +13 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/JavaServlets_Common.txt +3 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/Joomla_exploitable.txt +1937 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/LotusNotes.txt +206 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/Netware.txt +18 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/Oracle9i.txt +60 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/OracleAppServer.txt +192 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/README.md +6 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/Ruby_Rails.txt +121 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/SAP.txt +463 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/Sharepoint.txt +1707 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/SiteMinder.txt +19 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/SunAppServerGlassfish.txt +51 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/SuniPlanet.txt +35 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/Vignette.txt +73 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/Weblogic.txt +160 -0
- data/lib/itsi/server/config/known_paths/webservers-appservers/Websphere.txt +366 -0
- data/lib/itsi/server/config/known_paths/wellknown-rfc5785.txt +30 -0
- data/lib/itsi/server/config/known_paths.rb +20 -0
- data/lib/itsi/server/config/middleware/_index.md +56 -0
- data/lib/itsi/server/config/middleware/allow_list.md +46 -0
- data/lib/itsi/server/config/middleware/allow_list.rb +42 -0
- data/lib/itsi/server/config/middleware/auth_api_key.md +90 -0
- data/lib/itsi/server/config/middleware/auth_api_key.rb +51 -0
- data/lib/itsi/server/config/middleware/auth_basic.md +45 -0
- data/lib/itsi/server/config/middleware/auth_basic.rb +44 -0
- data/lib/itsi/server/config/middleware/auth_jwt.md +82 -0
- data/lib/itsi/server/config/middleware/auth_jwt.rb +38 -0
- data/lib/itsi/server/config/middleware/cache_control.md +78 -0
- data/lib/itsi/server/config/middleware/cache_control.rb +45 -0
- data/lib/itsi/server/config/middleware/cidr_to_regex.rb +50 -0
- data/lib/itsi/server/config/middleware/compression.md +50 -0
- data/lib/itsi/server/config/middleware/compression.rb +37 -0
- data/lib/itsi/server/config/middleware/cors.md +93 -0
- data/lib/itsi/server/config/middleware/cors.rb +32 -0
- data/lib/itsi/server/config/middleware/csp.md +37 -0
- data/lib/itsi/server/config/middleware/csp.rb +44 -0
- data/lib/itsi/server/config/middleware/deny_list.md +45 -0
- data/lib/itsi/server/config/middleware/deny_list.rb +42 -0
- data/lib/itsi/server/config/middleware/endpoint/_index.md +159 -0
- data/lib/itsi/server/config/middleware/endpoint/controller.md +186 -0
- data/lib/itsi/server/config/middleware/endpoint/controller.rb +33 -0
- data/lib/itsi/server/config/middleware/endpoint/delete.md +12 -0
- data/lib/itsi/server/config/middleware/endpoint/delete.rb +42 -0
- data/lib/itsi/server/config/middleware/endpoint/endpoint.rb +99 -0
- data/lib/itsi/server/config/middleware/endpoint/get.md +12 -0
- data/lib/itsi/server/config/middleware/endpoint/get.rb +42 -0
- data/lib/itsi/server/config/middleware/endpoint/http_request.md +44 -0
- data/lib/itsi/server/config/middleware/endpoint/http_response.md +39 -0
- data/lib/itsi/server/config/middleware/endpoint/patch.md +12 -0
- data/lib/itsi/server/config/middleware/endpoint/patch.rb +42 -0
- data/lib/itsi/server/config/middleware/endpoint/post.md +12 -0
- data/lib/itsi/server/config/middleware/endpoint/post.rb +42 -0
- data/lib/itsi/server/config/middleware/endpoint/put.md +12 -0
- data/lib/itsi/server/config/middleware/endpoint/put.rb +42 -0
- data/lib/itsi/server/config/middleware/endpoint/schemas.md +122 -0
- data/lib/itsi/server/config/middleware/error_response.md +61 -0
- data/lib/itsi/server/config/middleware/error_response.rb +36 -0
- data/lib/itsi/server/config/middleware/etag.md +59 -0
- data/lib/itsi/server/config/middleware/etag.rb +27 -0
- data/lib/itsi/server/config/middleware/grpc.md +172 -0
- data/lib/itsi/server/config/middleware/grpc.rb +54 -0
- data/lib/itsi/server/config/middleware/intrusion_protection.md +124 -0
- data/lib/itsi/server/config/middleware/intrusion_protection.rb +61 -0
- data/lib/itsi/server/config/middleware/location.md +107 -0
- data/lib/itsi/server/config/middleware/location.rb +99 -0
- data/lib/itsi/server/config/middleware/log_requests.md +65 -0
- data/lib/itsi/server/config/middleware/log_requests.rb +31 -0
- data/lib/itsi/server/config/middleware/max_body.md +18 -0
- data/lib/itsi/server/config/middleware/max_body.rb +21 -0
- data/lib/itsi/server/config/middleware/proxy.md +62 -0
- data/lib/itsi/server/config/middleware/proxy.rb +41 -0
- data/lib/itsi/server/config/middleware/rackup_file.md +54 -0
- data/lib/itsi/server/config/middleware/rackup_file.rb +44 -0
- data/lib/itsi/server/config/middleware/rate_limit.md +126 -0
- data/lib/itsi/server/config/middleware/rate_limit.rb +34 -0
- data/lib/itsi/server/config/middleware/rate_limit_store.rb +25 -0
- data/lib/itsi/server/config/middleware/redirect.md +55 -0
- data/lib/itsi/server/config/middleware/redirect.rb +25 -0
- data/lib/itsi/server/config/middleware/request_headers.md +34 -0
- data/lib/itsi/server/config/middleware/request_headers.rb +24 -0
- data/lib/itsi/server/config/middleware/response_headers.md +33 -0
- data/lib/itsi/server/config/middleware/response_headers.rb +25 -0
- data/lib/itsi/server/config/middleware/run.md +60 -0
- data/lib/itsi/server/config/middleware/run.rb +43 -0
- data/lib/itsi/server/config/middleware/static_assets.md +73 -0
- data/lib/itsi/server/config/middleware/static_assets.rb +87 -0
- data/lib/itsi/server/config/middleware/static_response.md +44 -0
- data/lib/itsi/server/config/middleware/static_response.rb +29 -0
- data/lib/itsi/server/config/middleware/string_rewrite.md +67 -0
- data/lib/itsi/server/config/middleware/token_source.rb +32 -0
- data/lib/itsi/server/config/middleware.rb +13 -0
- data/lib/itsi/server/config/option.rb +14 -0
- data/lib/itsi/server/config/options/_index.md +37 -0
- data/lib/itsi/server/config/options/auto_reload_config.md +13 -0
- data/lib/itsi/server/config/options/auto_reload_config.rb +41 -0
- data/lib/itsi/server/config/options/bind.md +71 -0
- data/lib/itsi/server/config/options/bind.rb +26 -0
- data/lib/itsi/server/config/options/certificates.md +65 -0
- data/lib/itsi/server/config/options/daemonize.md +14 -0
- data/lib/itsi/server/config/options/daemonize.rb +19 -0
- data/lib/itsi/server/config/options/fiber_scheduler.md +34 -0
- data/lib/itsi/server/config/options/fiber_scheduler.rb +21 -0
- data/lib/itsi/server/config/options/header_read_timeout.md +17 -0
- data/lib/itsi/server/config/options/header_read_timeout.rb +19 -0
- data/lib/itsi/server/config/options/hooks/_index.md +11 -0
- data/lib/itsi/server/config/options/hooks/after_fork.md +13 -0
- data/lib/itsi/server/config/options/hooks/after_fork.rb +28 -0
- data/lib/itsi/server/config/options/hooks/after_memory_limit_reached.md +14 -0
- data/lib/itsi/server/config/options/hooks/after_memory_limit_reached.rb +28 -0
- data/lib/itsi/server/config/options/hooks/after_start.md +12 -0
- data/lib/itsi/server/config/options/hooks/after_start.rb +28 -0
- data/lib/itsi/server/config/options/hooks/before_fork.md +13 -0
- data/lib/itsi/server/config/options/hooks/before_fork.rb +28 -0
- data/lib/itsi/server/config/options/hooks/before_restart.md +12 -0
- data/lib/itsi/server/config/options/hooks/before_restart.rb +28 -0
- data/lib/itsi/server/config/options/hooks/before_shutdown.md +12 -0
- data/lib/itsi/server/config/options/hooks/before_shutdown.rb +28 -0
- data/lib/itsi/server/config/options/include.md +20 -0
- data/lib/itsi/server/config/options/include.rb +36 -0
- data/lib/itsi/server/config/options/listen_backlog.md +11 -0
- data/lib/itsi/server/config/options/listen_backlog.rb +19 -0
- data/lib/itsi/server/config/options/log_format.md +18 -0
- data/lib/itsi/server/config/options/log_format.rb +19 -0
- data/lib/itsi/server/config/options/log_level.md +34 -0
- data/lib/itsi/server/config/options/log_level.rb +20 -0
- data/lib/itsi/server/config/options/log_target.md +38 -0
- data/lib/itsi/server/config/options/log_target.rb +19 -0
- data/lib/itsi/server/config/options/log_target_filters.md +17 -0
- data/lib/itsi/server/config/options/log_target_filters.rb +19 -0
- data/lib/itsi/server/config/options/multithreaded_reactor.md +27 -0
- data/lib/itsi/server/config/options/multithreaded_reactor.rb +24 -0
- data/lib/itsi/server/config/options/nodelay.md +16 -0
- data/lib/itsi/server/config/options/nodelay.rb +19 -0
- data/lib/itsi/server/config/options/oob_gc_responses_threshold.md +19 -0
- data/lib/itsi/server/config/options/oob_gc_responses_threshold.rb +18 -0
- data/lib/itsi/server/config/options/pin_worker_cores.md +17 -0
- data/lib/itsi/server/config/options/pin_worker_cores.rb +19 -0
- data/lib/itsi/server/config/options/preload.md +21 -0
- data/lib/itsi/server/config/options/preload.rb +18 -0
- data/lib/itsi/server/config/options/recv_buffer_size.md +15 -0
- data/lib/itsi/server/config/options/recv_buffer_size.rb +19 -0
- data/lib/itsi/server/config/options/redirect_http_to_https.md +21 -0
- data/lib/itsi/server/config/options/redirect_http_to_https.rb +30 -0
- data/lib/itsi/server/config/options/request_timeout.md +23 -0
- data/lib/itsi/server/config/options/request_timeout.rb +19 -0
- data/lib/itsi/server/config/options/reuse_address.md +16 -0
- data/lib/itsi/server/config/options/reuse_address.rb +19 -0
- data/lib/itsi/server/config/options/reuse_port.md +16 -0
- data/lib/itsi/server/config/options/reuse_port.rb +19 -0
- data/lib/itsi/server/config/options/scheduler_threads.md +34 -0
- data/lib/itsi/server/config/options/scheduler_threads.rb +17 -0
- data/lib/itsi/server/config/options/shutdown_timeout.md +17 -0
- data/lib/itsi/server/config/options/shutdown_timeout.rb +19 -0
- data/lib/itsi/server/config/options/stream_body.md +32 -0
- data/lib/itsi/server/config/options/stream_body.rb +18 -0
- data/lib/itsi/server/config/options/threads.md +44 -0
- data/lib/itsi/server/config/options/threads.rb +17 -0
- data/lib/itsi/server/config/options/watch.md +16 -0
- data/lib/itsi/server/config/options/watch.rb +28 -0
- data/lib/itsi/server/config/options/worker_memory_limit.md +22 -0
- data/lib/itsi/server/config/options/worker_memory_limit.rb +18 -0
- data/lib/itsi/server/config/options/workers.md +42 -0
- data/lib/itsi/server/config/options/workers.rb +17 -0
- data/lib/itsi/server/config/typed_struct.rb +242 -0
- data/lib/itsi/server/config.rb +289 -0
- data/lib/itsi/server/default_app/default_app.rb +34 -0
- data/lib/itsi/server/default_app/index.html +115 -0
- data/lib/itsi/server/default_config/Itsi.rb +107 -0
- data/lib/itsi/server/grpc/grpc_call.rb +246 -0
- data/lib/itsi/server/grpc/grpc_interface.rb +107 -0
- data/lib/itsi/server/grpc/reflection/v1/reflection_pb.rb +26 -0
- data/lib/itsi/server/grpc/reflection/v1/reflection_services_pb.rb +122 -0
- data/lib/itsi/server/rack/handler/itsi.rb +27 -0
- data/lib/itsi/server/rack_interface.rb +94 -0
- data/lib/itsi/server/route_tester.rb +157 -0
- data/lib/itsi/server/scheduler_interface.rb +21 -0
- data/lib/itsi/server/scheduler_mode.rb +10 -0
- data/lib/itsi/server/signal_trap.rb +33 -0
- data/lib/itsi/server/typed_handlers/param_parser.rb +196 -0
- data/lib/itsi/server/typed_handlers/source_parser.rb +56 -0
- data/lib/itsi/server/typed_handlers.rb +25 -0
- data/lib/itsi/server/version.rb +1 -1
- data/lib/itsi/server.rb +265 -9
- data/lib/itsi/standard_headers.rb +86 -0
- data/lib/ruby_lsp/itsi/addon.rb +129 -0
- data/lib/shell_completions/completions.rb +26 -0
- metadata +454 -28
- data/CHANGELOG.md +0 -5
- data/CODE_OF_CONDUCT.md +0 -132
- data/LICENSE.txt +0 -21
- data/ext/itsi_server/src/request/itsi_request.rs +0 -143
- data/ext/itsi_server/src/request/mod.rs +0 -1
- data/ext/itsi_server/src/server/bind.rs +0 -138
- data/ext/itsi_server/src/server/itsi_ca/itsi_ca.crt +0 -32
- data/ext/itsi_server/src/server/itsi_ca/itsi_ca.key +0 -52
- data/ext/itsi_server/src/server/itsi_server.rs +0 -182
- data/ext/itsi_server/src/server/listener.rs +0 -218
- data/ext/itsi_server/src/server/tls.rs +0 -138
- data/ext/itsi_server/src/server/transfer_protocol.rs +0 -23
- data/ext/itsi_server/src/stream_writer/mod.rs +0 -21
- data/lib/itsi/request.rb +0 -39
data/ext/itsi_tracing/Cargo.toml
CHANGED
data/ext/itsi_tracing/src/lib.rs
CHANGED
@@ -1,11 +1,370 @@
|
|
1
|
+
use atty::{Stream, is};
|
2
|
+
use std::{
|
3
|
+
env,
|
4
|
+
sync::{Mutex, OnceLock},
|
5
|
+
};
|
6
|
+
use tracing::Level;
|
1
7
|
pub use tracing::{debug, error, info, trace, warn};
|
2
|
-
use
|
8
|
+
use tracing_appender::rolling;
|
9
|
+
use tracing_subscriber::fmt::{
|
10
|
+
format::{FmtSpan, JsonFields},
|
11
|
+
writer::BoxMakeWriter,
|
12
|
+
};
|
13
|
+
use tracing_subscriber::{EnvFilter, fmt, prelude::*, reload};
|
14
|
+
use tracing_subscriber::{Layer, Registry, layer::Layered};
|
3
15
|
|
16
|
+
// Global reload handle for changing the level at runtime.
|
17
|
+
static RELOAD_HANDLE: OnceLock<
|
18
|
+
Mutex<Option<reload::Handle<EnvFilter, tracing_subscriber::Registry>>>,
|
19
|
+
> = OnceLock::new();
|
20
|
+
|
21
|
+
// Global reload handle for changing the formatting layer (log target/format) at runtime.
|
22
|
+
type ReloadFmtHandle = reload::Handle<
|
23
|
+
Box<
|
24
|
+
dyn Layer<
|
25
|
+
tracing_subscriber::layer::Layered<
|
26
|
+
reload::Layer<EnvFilter, tracing_subscriber::Registry>,
|
27
|
+
tracing_subscriber::Registry,
|
28
|
+
>,
|
29
|
+
> + Send
|
30
|
+
+ Sync,
|
31
|
+
>,
|
32
|
+
Layered<tracing_subscriber::reload::Layer<EnvFilter, Registry>, Registry>,
|
33
|
+
>;
|
34
|
+
|
35
|
+
static RELOAD_FMT_HANDLE: OnceLock<Mutex<Option<ReloadFmtHandle>>> = OnceLock::new();
|
36
|
+
|
37
|
+
// Global current log configuration for formatting options.
|
38
|
+
static CURRENT_CONFIG: OnceLock<Mutex<LogConfig>> = OnceLock::new();
|
39
|
+
|
40
|
+
/// Log format: Plain or JSON.
|
41
|
+
#[derive(Debug, Clone)]
|
42
|
+
pub enum LogFormat {
|
43
|
+
Plain,
|
44
|
+
Json,
|
45
|
+
}
|
46
|
+
|
47
|
+
/// Log target: STDOUT, File, or Both.
|
48
|
+
#[derive(Debug, Clone)]
|
49
|
+
pub enum LogTarget {
|
50
|
+
Stdout,
|
51
|
+
File(String), // file name (rotated daily)
|
52
|
+
Both(String), // file name (rotated daily) plus STDOUT
|
53
|
+
}
|
54
|
+
|
55
|
+
/// Logger configuration.
|
56
|
+
#[derive(Debug, Clone)]
|
57
|
+
pub struct LogConfig {
|
58
|
+
/// Log level as a string (e.g. "info", "debug").
|
59
|
+
pub level: String,
|
60
|
+
/// Format: Plain (with optional ANSI) or JSON.
|
61
|
+
pub format: LogFormat,
|
62
|
+
/// Target: STDOUT, File, or Both.
|
63
|
+
pub target: LogTarget,
|
64
|
+
/// Whether to enable ANSI coloring (for plain text).
|
65
|
+
pub use_ansi: bool,
|
66
|
+
}
|
67
|
+
|
68
|
+
fn default_log_file() -> String {
|
69
|
+
env::var("ITSI_LOG_FILE").unwrap_or_else(|_| "itsi-app.log".into())
|
70
|
+
}
|
71
|
+
|
72
|
+
impl Default for LogConfig {
|
73
|
+
fn default() -> Self {
|
74
|
+
let level = env::var("ITSI_LOG").unwrap_or_else(|_| "info".into());
|
75
|
+
let format = match env::var("ITSI_LOG_FORMAT").as_deref() {
|
76
|
+
Ok("json") => LogFormat::Json,
|
77
|
+
_ => LogFormat::Plain,
|
78
|
+
};
|
79
|
+
let target = match env::var("ITSI_LOG_TARGET").as_deref() {
|
80
|
+
Ok("file") => LogTarget::File(default_log_file()),
|
81
|
+
Ok("both") => LogTarget::Both(default_log_file()),
|
82
|
+
_ => LogTarget::Stdout,
|
83
|
+
};
|
84
|
+
// If ITSI_LOG_ANSI is set, use that; otherwise, use ANSI if stdout is a TTY.
|
85
|
+
let use_ansi = env::var("ITSI_LOG_ANSI")
|
86
|
+
.map(|s| s == "true")
|
87
|
+
.unwrap_or_else(|_| is(Stream::Stdout));
|
88
|
+
Self {
|
89
|
+
level,
|
90
|
+
format,
|
91
|
+
target,
|
92
|
+
use_ansi,
|
93
|
+
}
|
94
|
+
}
|
95
|
+
}
|
96
|
+
|
97
|
+
/// Build the formatting layer based on the provided configuration.
|
98
|
+
fn build_fmt_layer(
|
99
|
+
config: &LogConfig,
|
100
|
+
) -> Box<
|
101
|
+
dyn Layer<
|
102
|
+
tracing_subscriber::layer::Layered<
|
103
|
+
reload::Layer<EnvFilter, tracing_subscriber::Registry>,
|
104
|
+
tracing_subscriber::Registry,
|
105
|
+
>,
|
106
|
+
> + Send
|
107
|
+
+ Sync,
|
108
|
+
> {
|
109
|
+
match &config.target {
|
110
|
+
LogTarget::Stdout => match config.format {
|
111
|
+
LogFormat::Plain => fmt::layer()
|
112
|
+
.compact()
|
113
|
+
.with_file(false)
|
114
|
+
.with_line_number(false)
|
115
|
+
.with_target(true)
|
116
|
+
.with_thread_ids(false)
|
117
|
+
.with_writer(BoxMakeWriter::new(std::io::stdout))
|
118
|
+
.with_ansi(config.use_ansi)
|
119
|
+
.with_span_events(FmtSpan::NONE)
|
120
|
+
.fmt_fields(JsonFields::new())
|
121
|
+
.boxed(),
|
122
|
+
LogFormat::Json => {
|
123
|
+
fmt::layer()
|
124
|
+
.compact()
|
125
|
+
.with_file(false)
|
126
|
+
.with_line_number(false)
|
127
|
+
.with_target(true)
|
128
|
+
.with_thread_ids(false)
|
129
|
+
.with_writer(BoxMakeWriter::new(std::io::stdout))
|
130
|
+
.with_ansi(config.use_ansi)
|
131
|
+
.event_format(fmt::format().json()) // set the JSON event formatter
|
132
|
+
.with_span_events(FmtSpan::NONE)
|
133
|
+
.fmt_fields(JsonFields::new())
|
134
|
+
.boxed()
|
135
|
+
}
|
136
|
+
},
|
137
|
+
LogTarget::File(file) => {
|
138
|
+
let file_clone = file.clone();
|
139
|
+
match config.format {
|
140
|
+
LogFormat::Plain => fmt::layer()
|
141
|
+
.compact()
|
142
|
+
.with_file(false)
|
143
|
+
.with_line_number(false)
|
144
|
+
.with_target(true)
|
145
|
+
.with_thread_ids(false)
|
146
|
+
.with_writer(BoxMakeWriter::new(move || {
|
147
|
+
rolling::daily(".", file_clone.clone())
|
148
|
+
}))
|
149
|
+
.with_ansi(false)
|
150
|
+
.with_span_events(FmtSpan::NONE)
|
151
|
+
.fmt_fields(JsonFields::new())
|
152
|
+
.boxed(),
|
153
|
+
LogFormat::Json => {
|
154
|
+
let file_clone = file.clone();
|
155
|
+
fmt::layer()
|
156
|
+
.compact()
|
157
|
+
.with_file(false)
|
158
|
+
.with_line_number(false)
|
159
|
+
.with_target(true)
|
160
|
+
.with_thread_ids(false)
|
161
|
+
.with_writer(BoxMakeWriter::new(move || {
|
162
|
+
rolling::daily(".", file_clone.clone())
|
163
|
+
}))
|
164
|
+
.with_ansi(false)
|
165
|
+
.event_format(fmt::format().json()) // set the JSON event formatter
|
166
|
+
.with_span_events(FmtSpan::NONE)
|
167
|
+
.fmt_fields(JsonFields::new())
|
168
|
+
.boxed()
|
169
|
+
}
|
170
|
+
}
|
171
|
+
}
|
172
|
+
LogTarget::Both(file) => {
|
173
|
+
let file_clone = file.clone();
|
174
|
+
match config.format {
|
175
|
+
LogFormat::Plain => {
|
176
|
+
let stdout_layer = fmt::layer()
|
177
|
+
.compact()
|
178
|
+
.with_file(false)
|
179
|
+
.with_line_number(false)
|
180
|
+
.with_target(true)
|
181
|
+
.with_thread_ids(false)
|
182
|
+
.with_writer(BoxMakeWriter::new(std::io::stdout))
|
183
|
+
.with_span_events(FmtSpan::NONE)
|
184
|
+
.fmt_fields(JsonFields::new())
|
185
|
+
.with_ansi(config.use_ansi);
|
186
|
+
let file_layer = fmt::layer()
|
187
|
+
.compact()
|
188
|
+
.with_file(false)
|
189
|
+
.with_line_number(false)
|
190
|
+
.with_target(true)
|
191
|
+
.with_thread_ids(false)
|
192
|
+
.with_writer(BoxMakeWriter::new(move || {
|
193
|
+
rolling::daily(".", file_clone.clone())
|
194
|
+
}))
|
195
|
+
.with_span_events(FmtSpan::NONE)
|
196
|
+
.fmt_fields(JsonFields::new())
|
197
|
+
.with_ansi(false);
|
198
|
+
stdout_layer.and_then(file_layer).boxed()
|
199
|
+
}
|
200
|
+
LogFormat::Json => {
|
201
|
+
let stdout_layer = fmt::layer()
|
202
|
+
.compact()
|
203
|
+
.with_file(false)
|
204
|
+
.with_line_number(false)
|
205
|
+
.with_target(true)
|
206
|
+
.with_thread_ids(false)
|
207
|
+
.with_writer(BoxMakeWriter::new(std::io::stdout))
|
208
|
+
.with_ansi(config.use_ansi)
|
209
|
+
.event_format(fmt::format().json()) // set the JSON event formatter
|
210
|
+
.with_span_events(FmtSpan::NONE)
|
211
|
+
.fmt_fields(JsonFields::new());
|
212
|
+
let file_layer = fmt::layer()
|
213
|
+
.compact()
|
214
|
+
.with_file(false)
|
215
|
+
.with_line_number(false)
|
216
|
+
.with_target(true)
|
217
|
+
.with_thread_ids(false)
|
218
|
+
.with_writer(BoxMakeWriter::new(move || {
|
219
|
+
rolling::daily(".", file_clone.clone())
|
220
|
+
}))
|
221
|
+
.with_ansi(false)
|
222
|
+
.event_format(fmt::format().json()) // set the JSON event formatter
|
223
|
+
.with_span_events(FmtSpan::NONE)
|
224
|
+
.fmt_fields(JsonFields::new());
|
225
|
+
stdout_layer.and_then(file_layer).boxed()
|
226
|
+
}
|
227
|
+
}
|
228
|
+
}
|
229
|
+
}
|
230
|
+
}
|
231
|
+
|
232
|
+
/// Update the formatting layer using the current configuration.
|
233
|
+
fn update_fmt_layer(config: &LogConfig) {
|
234
|
+
if let Some(handle) = RELOAD_FMT_HANDLE.get().unwrap().lock().unwrap().as_ref() {
|
235
|
+
let new_layer = build_fmt_layer(config);
|
236
|
+
handle
|
237
|
+
.modify(|layer| {
|
238
|
+
*layer = new_layer;
|
239
|
+
})
|
240
|
+
.expect("Failed to update formatting layer");
|
241
|
+
} else {
|
242
|
+
eprintln!("Reload handle for formatting layer not initialized; call init() first.");
|
243
|
+
}
|
244
|
+
}
|
245
|
+
|
246
|
+
/// Initialize the global tracing subscriber with the default configuration.
|
4
247
|
pub fn init() {
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
248
|
+
init_with_config(LogConfig::default());
|
249
|
+
}
|
250
|
+
|
251
|
+
/// Initialize the global tracing subscriber with a given configuration.
|
252
|
+
pub fn init_with_config(config: LogConfig) {
|
253
|
+
// Store the current config in a global for future updates.
|
254
|
+
CURRENT_CONFIG.set(Mutex::new(config.clone())).ok();
|
255
|
+
|
256
|
+
// Build an EnvFilter from the configured level.
|
257
|
+
let env_filter = EnvFilter::new(config.clone().level);
|
258
|
+
|
259
|
+
// Build the formatting layer based on the configuration.
|
260
|
+
let fmt_layer = build_fmt_layer(&config);
|
261
|
+
|
262
|
+
// Create a reloadable filter layer so we can update the level at runtime.
|
263
|
+
let (filter_layer, filter_handle) = reload::Layer::new(env_filter);
|
264
|
+
|
265
|
+
// Create a reloadable formatting layer so we can update the target/format at runtime.
|
266
|
+
let (fmt_layer, fmt_handle) = reload::Layer::new(fmt_layer);
|
267
|
+
|
268
|
+
// Build the subscriber registry.
|
269
|
+
let subscriber = tracing_subscriber::registry()
|
270
|
+
.with(filter_layer)
|
271
|
+
.with(fmt_layer);
|
272
|
+
|
273
|
+
tracing::subscriber::set_global_default(subscriber)
|
274
|
+
.expect("Unable to set global tracing subscriber");
|
275
|
+
|
276
|
+
RELOAD_HANDLE.set(Mutex::new(Some(filter_handle))).unwrap();
|
277
|
+
RELOAD_FMT_HANDLE.set(Mutex::new(Some(fmt_handle))).ok();
|
278
|
+
}
|
279
|
+
|
280
|
+
/// Change the log level at runtime.
|
281
|
+
pub fn set_level(new_level: &str) {
|
282
|
+
if let Some(handle) = RELOAD_HANDLE.get().unwrap().lock().unwrap().as_ref() {
|
283
|
+
handle
|
284
|
+
.modify(|filter| *filter = EnvFilter::new(new_level))
|
285
|
+
.expect("Failed to update log level");
|
286
|
+
|
287
|
+
// Also update the stored config.
|
288
|
+
if let Some(config_mutex) = CURRENT_CONFIG.get() {
|
289
|
+
let mut config = config_mutex.lock().unwrap();
|
290
|
+
config.level = new_level.to_string();
|
291
|
+
}
|
292
|
+
} else {
|
293
|
+
eprintln!("Reload handle not initialized; call init() first.");
|
294
|
+
}
|
295
|
+
}
|
296
|
+
|
297
|
+
/// Change the log target at runtime.
|
298
|
+
pub fn set_target(new_target: &str) {
|
299
|
+
let target: LogTarget = match new_target {
|
300
|
+
"stdout" => LogTarget::Stdout,
|
301
|
+
"both" => LogTarget::Both(default_log_file()),
|
302
|
+
path => LogTarget::File(path.to_string()),
|
303
|
+
};
|
304
|
+
if let Some(config_mutex) = CURRENT_CONFIG.get() {
|
305
|
+
let mut config = config_mutex.lock().unwrap();
|
306
|
+
config.target = target;
|
307
|
+
update_fmt_layer(&config);
|
308
|
+
} else {
|
309
|
+
eprintln!("Current configuration not initialized; call init() first.");
|
310
|
+
}
|
311
|
+
}
|
312
|
+
|
313
|
+
/// Change the log format at runtime.
|
314
|
+
pub fn set_format(new_format: &str) {
|
315
|
+
let format = match new_format {
|
316
|
+
"json" => LogFormat::Json,
|
317
|
+
"plain" => LogFormat::Plain,
|
318
|
+
_ => LogFormat::Json,
|
319
|
+
};
|
320
|
+
if let Some(config_mutex) = CURRENT_CONFIG.get() {
|
321
|
+
let mut config = config_mutex.lock().unwrap();
|
322
|
+
config.format = format;
|
323
|
+
update_fmt_layer(&config);
|
324
|
+
} else {
|
325
|
+
eprintln!("Current configuration not initialized; call init() first.");
|
326
|
+
}
|
327
|
+
}
|
328
|
+
pub fn set_target_filters(targets: Vec<(&str, Level)>) {
|
329
|
+
if let Some(reload_handle_mutex) = RELOAD_HANDLE.get() {
|
330
|
+
if let Ok(handle_guard) = reload_handle_mutex.lock() {
|
331
|
+
if let Some(handle) = handle_guard.as_ref() {
|
332
|
+
let mut new_filter = EnvFilter::new("");
|
333
|
+
|
334
|
+
if let Some(config_mutex) = CURRENT_CONFIG.get() {
|
335
|
+
if let Ok(config) = config_mutex.lock() {
|
336
|
+
if let Ok(directive) = config.level.parse() {
|
337
|
+
new_filter = new_filter.add_directive(directive);
|
338
|
+
}
|
339
|
+
}
|
340
|
+
}
|
341
|
+
|
342
|
+
for (target, level) in targets {
|
343
|
+
let directive_str = format!("{}={}", target, level);
|
344
|
+
if let Ok(directive) = directive_str.parse() {
|
345
|
+
new_filter = new_filter.add_directive(directive);
|
346
|
+
}
|
347
|
+
}
|
348
|
+
|
349
|
+
if let Err(e) = handle.modify(|filter| *filter = new_filter) {
|
350
|
+
eprintln!("Failed to update filter with target directives: {}", e);
|
351
|
+
}
|
352
|
+
}
|
353
|
+
}
|
354
|
+
} else {
|
355
|
+
eprintln!("Reload handle for filter not initialized; call init() first.");
|
356
|
+
}
|
357
|
+
}
|
358
|
+
|
359
|
+
/// Run a function silently by temporarily setting a no-op subscriber.
|
360
|
+
pub fn run_silently<F, R>(f: F) -> R
|
361
|
+
where
|
362
|
+
F: FnOnce() -> R,
|
363
|
+
{
|
364
|
+
let no_op_subscriber = tracing_subscriber::fmt()
|
365
|
+
.with_writer(std::io::sink)
|
366
|
+
.with_max_level(tracing_subscriber::filter::LevelFilter::OFF)
|
367
|
+
.finish();
|
368
|
+
let dispatch = tracing::Dispatch::new(no_op_subscriber);
|
369
|
+
tracing::dispatcher::with_default(&dispatch, f)
|
11
370
|
}
|
data/ext/itsi_tracing/target/debug/incremental/itsi_tracing-0994n8rpvvt9m/s-h510hfz1f6-1kbycmq.lock
ADDED
File without changes
|
data/ext/itsi_tracing/target/debug/incremental/itsi_tracing-0bob7bf4yq34i/s-h5113125h5-0lh4rag.lock
ADDED
File without changes
|
data/ext/itsi_tracing/target/debug/incremental/itsi_tracing-2fcodulrxbbxo/s-h510h2infk-0hp5kjw.lock
ADDED
File without changes
|
data/ext/itsi_tracing/target/debug/incremental/itsi_tracing-2iak63r1woi1l/s-h510h2in4q-0kxfzw1.lock
ADDED
File without changes
|
data/ext/itsi_tracing/target/debug/incremental/itsi_tracing-2kk4qj9gn5dg2/s-h5113124kv-0enwon2.lock
ADDED
File without changes
|
data/ext/itsi_tracing/target/debug/incremental/itsi_tracing-2mwo0yas7dtw4/s-h510hfz1ha-1udgpei.lock
ADDED
File without changes
|
@@ -0,0 +1,76 @@
|
|
1
|
+
module Itsi
|
2
|
+
class HttpRequest
|
3
|
+
module ResponseStatusShortcodes
|
4
|
+
|
5
|
+
HTTP_STATUS_CODES = {
|
6
|
+
100 => :continue,
|
7
|
+
101 => :switching_protocols,
|
8
|
+
102 => :processing,
|
9
|
+
200 => :ok,
|
10
|
+
201 => :created,
|
11
|
+
202 => :accepted,
|
12
|
+
203 => :non_authoritative_information,
|
13
|
+
204 => :no_content,
|
14
|
+
205 => :reset_content,
|
15
|
+
206 => :partial_content,
|
16
|
+
207 => :multi_status,
|
17
|
+
208 => :already_reported,
|
18
|
+
226 => :im_used,
|
19
|
+
300 => :multiple_choices,
|
20
|
+
301 => :moved_permanently,
|
21
|
+
302 => :found,
|
22
|
+
303 => :see_other,
|
23
|
+
304 => :not_modified,
|
24
|
+
305 => :use_proxy,
|
25
|
+
307 => :temporary_redirect,
|
26
|
+
308 => :permanent_redirect,
|
27
|
+
400 => :bad_request,
|
28
|
+
401 => :unauthorized,
|
29
|
+
402 => :payment_required,
|
30
|
+
403 => :forbidden,
|
31
|
+
404 => :not_found,
|
32
|
+
405 => :method_not_allowed,
|
33
|
+
406 => :not_acceptable,
|
34
|
+
407 => :proxy_authentication_required,
|
35
|
+
408 => :request_timeout,
|
36
|
+
409 => :conflict,
|
37
|
+
410 => :gone,
|
38
|
+
411 => :length_required,
|
39
|
+
412 => :precondition_failed,
|
40
|
+
413 => :payload_too_large,
|
41
|
+
414 => :uri_too_long,
|
42
|
+
415 => :unsupported_media_type,
|
43
|
+
416 => :range_not_satisfiable,
|
44
|
+
417 => :expectation_failed,
|
45
|
+
418 => :im_a_teapot,
|
46
|
+
421 => :misdirected_request,
|
47
|
+
422 => :unprocessable_entity,
|
48
|
+
423 => :locked,
|
49
|
+
424 => :failed_dependency,
|
50
|
+
425 => :too_early,
|
51
|
+
426 => :upgrade_required,
|
52
|
+
428 => :precondition_required,
|
53
|
+
429 => :too_many_requests,
|
54
|
+
431 => :request_header_fields_too_large,
|
55
|
+
451 => :unavailable_for_legal_reasons,
|
56
|
+
500 => :internal_server_error,
|
57
|
+
501 => :not_implemented,
|
58
|
+
502 => :bad_gateway,
|
59
|
+
503 => :service_unavailable,
|
60
|
+
504 => :gateway_timeout,
|
61
|
+
505 => :http_version_not_supported,
|
62
|
+
506 => :variant_also_negotiates,
|
63
|
+
507 => :insufficient_storage,
|
64
|
+
508 => :loop_detected,
|
65
|
+
510 => :not_extended,
|
66
|
+
511 => :network_authentication_required
|
67
|
+
}.freeze
|
68
|
+
|
69
|
+
HTTP_STATUS_NAME_TO_CODE_MAP = HTTP_STATUS_CODES.invert.freeze
|
70
|
+
|
71
|
+
HTTP_STATUS_CODES.each do |code, name|
|
72
|
+
define_method(name) {|*args, **kwargs| respond(*args, **kwargs, status: code) }
|
73
|
+
end
|
74
|
+
end
|
75
|
+
end
|
76
|
+
end
|
@@ -0,0 +1,218 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require "stringio"
|
4
|
+
require "socket"
|
5
|
+
require "uri"
|
6
|
+
require_relative 'http_request/response_status_shortcodes'
|
7
|
+
|
8
|
+
module Itsi
|
9
|
+
class HttpRequest
|
10
|
+
include Server::TypedHandlers::ParamParser
|
11
|
+
include ResponseStatusShortcodes
|
12
|
+
attr_accessor :hijacked
|
13
|
+
|
14
|
+
EMPTY_IO = StringIO.new("")
|
15
|
+
RACK_HEADER_MAP = StandardHeaders::ALL.map do |header|
|
16
|
+
rack_form = if header == "content-type"
|
17
|
+
"CONTENT_TYPE"
|
18
|
+
elsif header == "content-length"
|
19
|
+
"CONTENT_LENGTH"
|
20
|
+
else
|
21
|
+
"HTTP_#{header.upcase.gsub(/-/, "_")}"
|
22
|
+
end
|
23
|
+
[header, rack_form]
|
24
|
+
end.to_h.tap do |hm|
|
25
|
+
hm.default_proc = proc { |hsh, key| "HTTP_#{key.upcase.gsub(/-/, "_")}" }
|
26
|
+
end
|
27
|
+
|
28
|
+
def to_rack_env
|
29
|
+
path = self.path
|
30
|
+
host = self.host
|
31
|
+
version = self.version
|
32
|
+
|
33
|
+
{
|
34
|
+
"SERVER_SOFTWARE" => "Itsi",
|
35
|
+
"SCRIPT_NAME" => script_name,
|
36
|
+
"REQUEST_METHOD" => request_method,
|
37
|
+
"PATH_INFO" => path,
|
38
|
+
"REQUEST_PATH" => path,
|
39
|
+
"QUERY_STRING" => query_string,
|
40
|
+
"REMOTE_ADDR" => remote_addr,
|
41
|
+
"SERVER_PORT" => port.to_s,
|
42
|
+
"SERVER_NAME" => host,
|
43
|
+
"SERVER_PROTOCOL" => version,
|
44
|
+
"HTTP_HOST" => host,
|
45
|
+
"HTTP_VERSION" => version,
|
46
|
+
"itsi.request" => self,
|
47
|
+
"itsi.response" => response,
|
48
|
+
"rack.version" => [version],
|
49
|
+
"rack.url_scheme" => scheme,
|
50
|
+
"rack.input" => build_input_io,
|
51
|
+
"rack.errors" => $stderr,
|
52
|
+
"rack.multithread" => true,
|
53
|
+
"rack.multiprocess" => true,
|
54
|
+
"rack.run_once" => false,
|
55
|
+
"rack.hijack?" => true,
|
56
|
+
"rack.multipart.buffer_size" => 16_384,
|
57
|
+
"rack.hijack" => method(:hijack)
|
58
|
+
}.tap do |r|
|
59
|
+
headers.each do |(k, v)|
|
60
|
+
r[case k
|
61
|
+
when "content-type" then "CONTENT_TYPE"
|
62
|
+
when "content-length" then "CONTENT_LENGTH"
|
63
|
+
when "accept" then "HTTP_ACCEPT"
|
64
|
+
when "accept-encoding" then "HTTP_ACCEPT_ENCODING"
|
65
|
+
when "accept-language" then "HTTP_ACCEPT_LANGUAGE"
|
66
|
+
when "user-agent" then "HTTP_USER_AGENT"
|
67
|
+
when "referer" then "HTTP_REFERER"
|
68
|
+
when "origin" then "HTTP_ORIGIN"
|
69
|
+
when "cookie" then "HTTP_COOKIE"
|
70
|
+
when "authorization" then "HTTP_AUTHORIZATION"
|
71
|
+
when "x-forwarded-for" then "HTTP_X_FORWARDED_FOR"
|
72
|
+
when "x-forwarded-proto" then "HTTP_X_FORWARDED_PROTO"
|
73
|
+
else RACK_HEADER_MAP[k]
|
74
|
+
end
|
75
|
+
] = v
|
76
|
+
end
|
77
|
+
end
|
78
|
+
end
|
79
|
+
|
80
|
+
def respond(
|
81
|
+
_body = nil, _status = 200, _headers = nil,
|
82
|
+
json: nil,
|
83
|
+
html: nil,
|
84
|
+
text: nil,
|
85
|
+
xml: nil,
|
86
|
+
hijack: false,
|
87
|
+
as: nil,
|
88
|
+
status: _status,
|
89
|
+
headers: _headers,
|
90
|
+
body: _body,
|
91
|
+
&blk
|
92
|
+
)
|
93
|
+
|
94
|
+
if json
|
95
|
+
if as
|
96
|
+
begin
|
97
|
+
validate!(json, as: as)
|
98
|
+
rescue ValidationError => e
|
99
|
+
json = {type: 'error', message: "Validation Error: #{e.message}"}
|
100
|
+
status = 400
|
101
|
+
end
|
102
|
+
end
|
103
|
+
body = json.to_json
|
104
|
+
headers ||= {}
|
105
|
+
headers["Content-Type"] ||= "application/json"
|
106
|
+
elsif html
|
107
|
+
body = html
|
108
|
+
headers ||= {}
|
109
|
+
headers["Content-Type"] ||= "text/html"
|
110
|
+
elsif xml
|
111
|
+
body = xml
|
112
|
+
headers ||= {}
|
113
|
+
headers["Content-Type"] ||= "application/xml"
|
114
|
+
elsif text
|
115
|
+
body = text
|
116
|
+
headers ||= {}
|
117
|
+
headers["Content-Type"] ||= "text/plain"
|
118
|
+
end
|
119
|
+
|
120
|
+
response.respond(status: status, headers: headers, body: body, hijack: hijack, &blk)
|
121
|
+
|
122
|
+
|
123
|
+
end
|
124
|
+
|
125
|
+
def hijack
|
126
|
+
self.hijacked = true
|
127
|
+
UNIXSocket.pair.yield_self do |(server_sock, app_sock)|
|
128
|
+
server_sock.autoclose = false
|
129
|
+
self.response.hijack(server_sock.fileno)
|
130
|
+
server_sock.sync = true
|
131
|
+
app_sock.sync = true
|
132
|
+
app_sock
|
133
|
+
end
|
134
|
+
end
|
135
|
+
|
136
|
+
def body
|
137
|
+
@body ||= build_input_io
|
138
|
+
end
|
139
|
+
|
140
|
+
def build_input_io
|
141
|
+
case body_parts
|
142
|
+
when nil then EMPTY_IO
|
143
|
+
when String then StringIO.new(body_parts)
|
144
|
+
when Array then File.open(body_parts.first, "rb")
|
145
|
+
else body_parts
|
146
|
+
end
|
147
|
+
end
|
148
|
+
|
149
|
+
def validate!(params, as: nil)
|
150
|
+
as ? apply_schema!(params, as) : params
|
151
|
+
end
|
152
|
+
|
153
|
+
def params(schema=nil)
|
154
|
+
params = case
|
155
|
+
when url_encoded? then URI.decode_www_form(build_input_io.read).to_h
|
156
|
+
when json? then JSON.parse(build_input_io.read)
|
157
|
+
when multipart?
|
158
|
+
Rack::Multipart::Parser.parse(
|
159
|
+
build_input_io,
|
160
|
+
content_length,
|
161
|
+
content_type,
|
162
|
+
Rack::Multipart::Parser::TEMPFILE_FACTORY,
|
163
|
+
Rack::Multipart::Parser::BUFSIZE,
|
164
|
+
Rack::Utils.default_query_parser
|
165
|
+
).params
|
166
|
+
else
|
167
|
+
{}
|
168
|
+
end
|
169
|
+
|
170
|
+
params.merge!(query_params).merge!(url_params)
|
171
|
+
validated = schema ? apply_schema!(params, schema) : params
|
172
|
+
unless block_given?
|
173
|
+
if multipart?
|
174
|
+
raise "#params must take a block for multipart requests"
|
175
|
+
else
|
176
|
+
return validated
|
177
|
+
end
|
178
|
+
else
|
179
|
+
yield validated
|
180
|
+
end
|
181
|
+
rescue ValidationError => e
|
182
|
+
if response.json?
|
183
|
+
respond(json: {error: e.message}, status: 400)
|
184
|
+
else
|
185
|
+
respond(e.message, 400)
|
186
|
+
end
|
187
|
+
rescue StandardError => e
|
188
|
+
Itsi.log_error e.message
|
189
|
+
puts e.backtrace
|
190
|
+
|
191
|
+
# Unexpected error.
|
192
|
+
# Don't reveal potential sensitive information to client.
|
193
|
+
if response.json?
|
194
|
+
respond(json: {error: "Internal Server Error"}, status: 500)
|
195
|
+
else
|
196
|
+
respond("Internal Server Error", 500)
|
197
|
+
end
|
198
|
+
ensure
|
199
|
+
clean_temp_files(params)
|
200
|
+
end
|
201
|
+
|
202
|
+
def clean_temp_files(params)
|
203
|
+
case params
|
204
|
+
when Hash
|
205
|
+
if params.key?(:tempfile)
|
206
|
+
params[:tempfile].unlink
|
207
|
+
else
|
208
|
+
params.each_value { |v| clean_temp_files(v) }
|
209
|
+
end
|
210
|
+
when Array then params.each { |v| clean_temp_files(v) }
|
211
|
+
end
|
212
|
+
end
|
213
|
+
|
214
|
+
def query_params
|
215
|
+
URI.decode_www_form(query_string).to_h
|
216
|
+
end
|
217
|
+
end
|
218
|
+
end
|