contrast-agent 3.9.1 → 3.12.0

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.
Files changed (319) hide show
  1. checksums.yaml +4 -4
  2. data/.flayignore +1 -0
  3. data/.simplecov +5 -2
  4. data/ext/build_funchook.rb +12 -7
  5. data/ext/cs__assess_active_record_named/cs__active_record_named.c +12 -14
  6. data/ext/cs__assess_active_record_named/cs__active_record_named.h +1 -0
  7. data/ext/cs__assess_active_record_named/extconf.rb +3 -0
  8. data/ext/cs__assess_array/cs__assess_array.c +5 -6
  9. data/ext/cs__assess_array/cs__assess_array.h +1 -0
  10. data/ext/cs__assess_array/extconf.rb +3 -0
  11. data/ext/cs__assess_basic_object/cs__assess_basic_object.c +13 -11
  12. data/ext/cs__assess_basic_object/cs__assess_basic_object.h +2 -1
  13. data/ext/cs__assess_basic_object/extconf.rb +3 -0
  14. data/ext/cs__assess_fiber_track/cs__assess_fiber_track.c +4 -3
  15. data/ext/cs__assess_fiber_track/cs__assess_fiber_track.h +3 -3
  16. data/ext/cs__assess_fiber_track/extconf.rb +3 -0
  17. data/ext/cs__assess_hash/cs__assess_hash.c +40 -17
  18. data/ext/cs__assess_hash/cs__assess_hash.h +4 -6
  19. data/ext/cs__assess_hash/extconf.rb +3 -0
  20. data/ext/cs__assess_kernel/cs__assess_kernel.c +11 -9
  21. data/ext/cs__assess_kernel/cs__assess_kernel.h +1 -0
  22. data/ext/cs__assess_kernel/extconf.rb +3 -0
  23. data/ext/cs__assess_marshal_module/cs__assess_marshal_module.c +3 -6
  24. data/ext/cs__assess_marshal_module/extconf.rb +3 -0
  25. data/ext/cs__assess_module/cs__assess_module.c +16 -14
  26. data/ext/cs__assess_module/cs__assess_module.h +3 -0
  27. data/ext/cs__assess_module/extconf.rb +3 -0
  28. data/ext/cs__assess_regexp/cs__assess_regexp.c +13 -9
  29. data/ext/cs__assess_regexp/cs__assess_regexp.h +1 -0
  30. data/ext/cs__assess_regexp/extconf.rb +3 -0
  31. data/ext/cs__assess_string/cs__assess_string.c +5 -8
  32. data/ext/cs__assess_string/cs__assess_string.h +2 -1
  33. data/ext/cs__assess_string/extconf.rb +3 -0
  34. data/ext/cs__assess_string_interpolation26/cs__assess_string_interpolation26.c +2 -2
  35. data/ext/cs__assess_string_interpolation26/cs__assess_string_interpolation26.h +3 -3
  36. data/ext/cs__assess_string_interpolation26/extconf.rb +3 -0
  37. data/ext/cs__assess_yield_track/cs__assess_yield_track.h +1 -1
  38. data/ext/cs__assess_yield_track/extconf.rb +3 -0
  39. data/ext/cs__common/cs__common.c +80 -1
  40. data/ext/cs__common/cs__common.h +34 -0
  41. data/ext/cs__common/extconf.rb +9 -8
  42. data/ext/cs__contrast_patch/cs__contrast_patch.h +1 -6
  43. data/ext/cs__contrast_patch/extconf.rb +3 -0
  44. data/ext/cs__protect_kernel/cs__protect_kernel.c +23 -12
  45. data/ext/cs__protect_kernel/cs__protect_kernel.h +1 -0
  46. data/ext/cs__protect_kernel/extconf.rb +3 -0
  47. data/ext/extconf_common.rb +10 -8
  48. data/funchook/autom4te.cache/requests +48 -48
  49. data/funchook/config.log +4 -4
  50. data/lib/contrast.rb +1 -1
  51. data/lib/contrast/agent.rb +32 -29
  52. data/lib/contrast/agent/assess.rb +1 -11
  53. data/lib/contrast/agent/assess/adjusted_span.rb +3 -1
  54. data/lib/contrast/agent/assess/contrast_event.rb +20 -68
  55. data/lib/contrast/agent/assess/events/event_factory.rb +25 -0
  56. data/lib/contrast/agent/assess/events/source_event.rb +83 -0
  57. data/lib/contrast/agent/assess/insulator.rb +0 -4
  58. data/lib/contrast/agent/assess/policy/patcher.rb +6 -2
  59. data/lib/contrast/agent/assess/policy/policy_node.rb +1 -8
  60. data/lib/contrast/agent/assess/policy/policy_scanner.rb +2 -2
  61. data/lib/contrast/agent/assess/policy/preshift.rb +1 -1
  62. data/lib/contrast/agent/assess/policy/propagation_method.rb +68 -33
  63. data/lib/contrast/agent/assess/policy/propagation_node.rb +2 -1
  64. data/lib/contrast/agent/assess/policy/propagator.rb +1 -0
  65. data/lib/contrast/agent/assess/policy/propagator/custom.rb +1 -1
  66. data/lib/contrast/agent/assess/policy/propagator/database_write.rb +1 -3
  67. data/lib/contrast/agent/assess/policy/propagator/match_data.rb +80 -0
  68. data/lib/contrast/agent/assess/policy/propagator/select.rb +35 -22
  69. data/lib/contrast/agent/assess/policy/propagator/split.rb +26 -6
  70. data/lib/contrast/agent/assess/policy/propagator/substitution.rb +2 -0
  71. data/lib/contrast/agent/assess/policy/rewriter_patch.rb +40 -27
  72. data/lib/contrast/agent/assess/policy/source_method.rb +20 -20
  73. data/lib/contrast/agent/assess/policy/source_node.rb +0 -15
  74. data/lib/contrast/agent/assess/policy/trigger/reflected_xss.rb +90 -0
  75. data/lib/contrast/agent/assess/policy/trigger/xpath.rb +57 -0
  76. data/lib/contrast/agent/assess/policy/trigger_method.rb +30 -45
  77. data/lib/contrast/agent/assess/policy/trigger_node.rb +7 -7
  78. data/lib/contrast/agent/assess/policy/trigger_validation/ssrf_validator.rb +2 -31
  79. data/lib/contrast/agent/assess/properties.rb +5 -3
  80. data/lib/contrast/agent/assess/rule/base.rb +1 -20
  81. data/lib/contrast/agent/assess/rule/provider/hardcoded_value_rule.rb +23 -6
  82. data/lib/contrast/agent/assess/rule/redos.rb +4 -5
  83. data/lib/contrast/agent/assess/tag.rb +24 -14
  84. data/lib/contrast/agent/at_exit_hook.rb +16 -13
  85. data/lib/contrast/agent/class_reopener.rb +24 -10
  86. data/lib/contrast/agent/deadzone/policy/policy.rb +2 -2
  87. data/lib/contrast/agent/disable_reaction.rb +3 -4
  88. data/lib/contrast/agent/exclusion_matcher.rb +7 -48
  89. data/lib/contrast/agent/inventory/policy/datastores.rb +54 -0
  90. data/lib/contrast/agent/inventory/policy/policy.rb +1 -1
  91. data/lib/contrast/agent/middleware.rb +101 -260
  92. data/lib/contrast/agent/module_data.rb +2 -1
  93. data/lib/contrast/agent/patching/policy/after_load_patch.rb +13 -3
  94. data/lib/contrast/agent/patching/policy/after_load_patcher.rb +59 -47
  95. data/lib/contrast/agent/patching/policy/method_policy.rb +3 -3
  96. data/lib/contrast/agent/patching/policy/module_policy.rb +0 -25
  97. data/lib/contrast/agent/patching/policy/patch.rb +97 -23
  98. data/lib/contrast/agent/patching/policy/patcher.rb +28 -30
  99. data/lib/contrast/agent/patching/policy/policy.rb +7 -7
  100. data/lib/contrast/agent/patching/policy/policy_node.rb +3 -11
  101. data/lib/contrast/agent/patching/policy/trigger_node.rb +2 -5
  102. data/lib/contrast/agent/protect/policy/applies_command_injection_rule.rb +63 -0
  103. data/lib/contrast/agent/protect/policy/applies_deserialization_rule.rb +52 -0
  104. data/lib/contrast/agent/protect/policy/applies_no_sqli_rule.rb +68 -0
  105. data/lib/contrast/agent/protect/policy/applies_path_traversal_rule.rb +117 -0
  106. data/lib/contrast/agent/protect/policy/applies_sqli_rule.rb +54 -0
  107. data/lib/contrast/agent/protect/policy/applies_xxe_rule.rb +129 -0
  108. data/lib/contrast/agent/protect/policy/policy.rb +6 -6
  109. data/lib/contrast/agent/protect/policy/rule_applicator.rb +51 -0
  110. data/lib/contrast/agent/protect/rule.rb +0 -5
  111. data/lib/contrast/agent/protect/rule/base.rb +19 -37
  112. data/lib/contrast/agent/protect/rule/base_service.rb +3 -1
  113. data/lib/contrast/agent/protect/rule/cmd_injection.rb +12 -15
  114. data/lib/contrast/agent/protect/rule/default_scanner.rb +0 -13
  115. data/lib/contrast/agent/protect/rule/deserialization.rb +2 -0
  116. data/lib/contrast/agent/protect/rule/http_method_tampering.rb +2 -2
  117. data/lib/contrast/agent/protect/rule/no_sqli.rb +4 -4
  118. data/lib/contrast/agent/protect/rule/path_traversal.rb +6 -10
  119. data/lib/contrast/agent/protect/rule/sqli.rb +5 -4
  120. data/lib/contrast/agent/protect/rule/unsafe_file_upload.rb +2 -0
  121. data/lib/contrast/agent/protect/rule/xss.rb +2 -0
  122. data/lib/contrast/agent/protect/rule/xxe.rb +10 -4
  123. data/lib/contrast/agent/railtie.rb +3 -8
  124. data/lib/contrast/agent/reaction_processor.rb +5 -5
  125. data/lib/contrast/agent/request.rb +11 -18
  126. data/lib/contrast/agent/request_context.rb +16 -19
  127. data/lib/contrast/agent/request_handler.rb +35 -0
  128. data/lib/contrast/agent/response.rb +39 -86
  129. data/lib/contrast/agent/rewriter.rb +25 -11
  130. data/lib/contrast/agent/rule_set.rb +49 -0
  131. data/lib/contrast/agent/scope.rb +4 -12
  132. data/lib/contrast/agent/service_heartbeat.rb +3 -4
  133. data/lib/contrast/agent/socket_client.rb +25 -19
  134. data/lib/contrast/agent/static_analysis.rb +41 -0
  135. data/lib/contrast/agent/thread.rb +1 -1
  136. data/lib/contrast/agent/tracepoint_hook.rb +1 -5
  137. data/lib/contrast/agent/version.rb +1 -1
  138. data/lib/contrast/api.rb +1 -1
  139. data/lib/contrast/api/decorators.rb +14 -0
  140. data/lib/contrast/api/decorators/application_settings.rb +37 -0
  141. data/lib/contrast/api/decorators/application_update.rb +66 -0
  142. data/lib/contrast/api/decorators/input_analysis.rb +17 -0
  143. data/lib/contrast/api/decorators/server_features.rb +24 -0
  144. data/lib/contrast/api/speedracer.rb +32 -30
  145. data/lib/contrast/api/tcp_socket.rb +0 -2
  146. data/lib/contrast/components/agent.rb +34 -24
  147. data/lib/contrast/components/app_context.rb +45 -38
  148. data/lib/contrast/components/assess.rb +25 -15
  149. data/lib/contrast/components/config.rb +7 -5
  150. data/lib/contrast/components/contrast_service.rb +23 -71
  151. data/lib/contrast/components/heap_dump.rb +12 -8
  152. data/lib/contrast/components/interface.rb +15 -22
  153. data/lib/contrast/components/inventory.rb +5 -1
  154. data/lib/contrast/components/logger.rb +3 -68
  155. data/lib/contrast/components/protect.rb +40 -4
  156. data/lib/contrast/components/sampling.rb +22 -11
  157. data/lib/contrast/components/scope.rb +2 -52
  158. data/lib/contrast/components/settings.rb +42 -23
  159. data/lib/contrast/config/base_configuration.rb +1 -0
  160. data/lib/contrast/config/default_value.rb +1 -0
  161. data/lib/contrast/config/protect_rule_configuration.rb +0 -14
  162. data/lib/contrast/config/protect_rules_configuration.rb +0 -1
  163. data/lib/contrast/configuration.rb +3 -5
  164. data/lib/contrast/{extensions/ruby_core → extension}/assess.rb +12 -15
  165. data/lib/contrast/extension/assess/array.rb +77 -0
  166. data/lib/contrast/{extensions/ruby_core → extension}/assess/assess_extension.rb +29 -24
  167. data/lib/contrast/{extensions/ruby_core → extension}/assess/erb.rb +0 -8
  168. data/lib/contrast/extension/assess/eval_trigger.rb +78 -0
  169. data/lib/contrast/{extensions/ruby_core → extension}/assess/exec_trigger.rb +7 -9
  170. data/lib/contrast/extension/assess/fiber.rb +113 -0
  171. data/lib/contrast/extension/assess/hash.rb +39 -0
  172. data/lib/contrast/extension/assess/kernel.rb +110 -0
  173. data/lib/contrast/extension/assess/regexp.rb +84 -0
  174. data/lib/contrast/{extensions/ruby_core → extension}/assess/string.rb +18 -10
  175. data/lib/contrast/{extensions/ruby_core → extension}/delegator.rb +0 -0
  176. data/lib/contrast/{extensions/ruby_core → extension}/inventory.rb +2 -2
  177. data/lib/contrast/extension/kernel.rb +54 -0
  178. data/lib/contrast/{extensions/ruby_core → extension}/module.rb +0 -0
  179. data/lib/contrast/{extensions/ruby_core → extension}/protect.rb +2 -2
  180. data/lib/contrast/extension/protect/kernel.rb +44 -0
  181. data/lib/contrast/{extensions/ruby_core → extension}/protect/psych.rb +1 -1
  182. data/lib/contrast/{extensions/ruby_core → extension}/thread.rb +0 -0
  183. data/lib/contrast/framework/base_support.rb +32 -0
  184. data/lib/contrast/framework/manager.rb +59 -8
  185. data/lib/contrast/framework/platform_version.rb +1 -0
  186. data/lib/contrast/framework/rack/patch/session_cookie.rb +126 -0
  187. data/lib/contrast/framework/rack/patch/support.rb +24 -0
  188. data/lib/contrast/framework/rack/support.rb +22 -0
  189. data/lib/contrast/framework/rails/patch/action_controller_live_buffer.rb +43 -0
  190. data/lib/contrast/framework/rails/patch/assess_configuration.rb +103 -0
  191. data/lib/contrast/framework/rails/patch/rails_application_configuration.rb +31 -0
  192. data/lib/contrast/framework/rails/patch/support.rb +67 -0
  193. data/lib/contrast/framework/rails/rewrite/action_controller_railties_helper_inherited.rb +34 -0
  194. data/lib/contrast/framework/rails/rewrite/active_record_attribute_methods_read.rb +39 -0
  195. data/lib/contrast/framework/rails/rewrite/active_record_named.rb +73 -0
  196. data/lib/contrast/framework/rails/rewrite/active_record_time_zone_inherited.rb +33 -0
  197. data/lib/contrast/framework/rails/support.rb +115 -0
  198. data/lib/contrast/framework/sinatra/application_helper.rb +51 -0
  199. data/lib/contrast/framework/sinatra/patch/base.rb +83 -0
  200. data/lib/contrast/framework/sinatra/patch/support.rb +27 -0
  201. data/lib/contrast/framework/sinatra/support.rb +109 -0
  202. data/lib/contrast/framework/view_technologies_descriptor.rb +1 -0
  203. data/lib/contrast/logger/application.rb +80 -0
  204. data/lib/contrast/logger/log.rb +142 -0
  205. data/lib/contrast/logger/time.rb +50 -0
  206. data/lib/contrast/tasks/config.rb +54 -0
  207. data/lib/contrast/tasks/service.rb +3 -13
  208. data/lib/contrast/utils/assess/sampling_util.rb +4 -9
  209. data/lib/contrast/utils/assess/tracking_util.rb +7 -1
  210. data/lib/contrast/utils/boolean_util.rb +2 -5
  211. data/lib/contrast/utils/cache.rb +0 -11
  212. data/lib/contrast/utils/class_util.rb +21 -2
  213. data/lib/contrast/utils/gemfile_reader.rb +7 -5
  214. data/lib/contrast/utils/hash_digest.rb +2 -11
  215. data/lib/contrast/utils/heap_dump_util.rb +12 -11
  216. data/lib/contrast/utils/invalid_configuration_util.rb +4 -4
  217. data/lib/contrast/utils/inventory_util.rb +2 -2
  218. data/lib/contrast/utils/io_util.rb +1 -11
  219. data/lib/contrast/utils/job_servers_running.rb +6 -4
  220. data/lib/contrast/utils/object_share.rb +1 -38
  221. data/lib/contrast/utils/os.rb +1 -25
  222. data/lib/contrast/utils/ruby_ast_rewriter.rb +5 -1
  223. data/lib/contrast/utils/service_response_util.rb +36 -60
  224. data/lib/contrast/utils/service_sender_util.rb +84 -23
  225. data/lib/contrast/utils/sinatra_helper.rb +0 -6
  226. data/lib/contrast/utils/stack_trace_utils.rb +86 -182
  227. data/lib/contrast/utils/string_utils.rb +18 -2
  228. data/lib/contrast/utils/tag_util.rb +11 -1
  229. data/lib/contrast/utils/thread_tracker.rb +2 -2
  230. data/lib/contrast/utils/timer.rb +0 -40
  231. data/resources/assess/policy.json +42 -71
  232. data/resources/inventory/policy.json +2 -2
  233. data/resources/protect/policy.json +15 -15
  234. data/ruby-agent.gemspec +12 -5
  235. data/service_executables/VERSION +1 -1
  236. data/service_executables/linux/contrast-service +0 -0
  237. data/service_executables/mac/contrast-service +0 -0
  238. metadata +123 -112
  239. data/ext/cs__assess_regexp_track/cs__assess_regexp_track.c +0 -63
  240. data/ext/cs__assess_regexp_track/cs__assess_regexp_track.h +0 -29
  241. data/ext/cs__assess_regexp_track/extconf.rb +0 -2
  242. data/lib/contrast/agent/assess/frozen_properties.rb +0 -41
  243. data/lib/contrast/agent/assess/rule/csrf.rb +0 -66
  244. data/lib/contrast/agent/assess/rule/csrf/csrf_action.rb +0 -28
  245. data/lib/contrast/agent/assess/rule/csrf/csrf_applicator.rb +0 -73
  246. data/lib/contrast/agent/assess/rule/csrf/csrf_watcher.rb +0 -132
  247. data/lib/contrast/agent/assess/rule/response_scanning_rule.rb +0 -47
  248. data/lib/contrast/agent/assess/rule/response_watcher.rb +0 -36
  249. data/lib/contrast/agent/assess/rule/watcher.rb +0 -36
  250. data/lib/contrast/agent/feature_state.rb +0 -379
  251. data/lib/contrast/agent/logger_manager.rb +0 -116
  252. data/lib/contrast/agent/protect/rule/csrf.rb +0 -118
  253. data/lib/contrast/agent/protect/rule/csrf/csrf_evaluator.rb +0 -103
  254. data/lib/contrast/agent/protect/rule/csrf/csrf_token_injector.rb +0 -85
  255. data/lib/contrast/agent/settings_state.rb +0 -152
  256. data/lib/contrast/delegators.rb +0 -9
  257. data/lib/contrast/delegators/application_update.rb +0 -32
  258. data/lib/contrast/extensions/framework/rack/cookie.rb +0 -24
  259. data/lib/contrast/extensions/framework/rack/request.rb +0 -24
  260. data/lib/contrast/extensions/framework/rack/response.rb +0 -23
  261. data/lib/contrast/extensions/framework/rails/action_controller_railties_helper_inherited.rb +0 -20
  262. data/lib/contrast/extensions/framework/rails/active_record.rb +0 -26
  263. data/lib/contrast/extensions/framework/rails/active_record_named.rb +0 -53
  264. data/lib/contrast/extensions/framework/rails/active_record_time_zone_inherited.rb +0 -21
  265. data/lib/contrast/extensions/framework/rails/buffer.rb +0 -28
  266. data/lib/contrast/extensions/framework/rails/configuration.rb +0 -27
  267. data/lib/contrast/extensions/framework/sinatra/base.rb +0 -59
  268. data/lib/contrast/extensions/ruby_core/assess/array.rb +0 -59
  269. data/lib/contrast/extensions/ruby_core/assess/basic_object.rb +0 -15
  270. data/lib/contrast/extensions/ruby_core/assess/fiber.rb +0 -124
  271. data/lib/contrast/extensions/ruby_core/assess/hash.rb +0 -22
  272. data/lib/contrast/extensions/ruby_core/assess/kernel.rb +0 -95
  273. data/lib/contrast/extensions/ruby_core/assess/module.rb +0 -14
  274. data/lib/contrast/extensions/ruby_core/assess/regexp.rb +0 -206
  275. data/lib/contrast/extensions/ruby_core/assess/tilt_template_trigger.rb +0 -73
  276. data/lib/contrast/extensions/ruby_core/assess/xpath_library_trigger.rb +0 -40
  277. data/lib/contrast/extensions/ruby_core/eval_trigger.rb +0 -52
  278. data/lib/contrast/extensions/ruby_core/inventory/datastores.rb +0 -37
  279. data/lib/contrast/extensions/ruby_core/protect/applies_command_injection_rule.rb +0 -72
  280. data/lib/contrast/extensions/ruby_core/protect/applies_deserialization_rule.rb +0 -60
  281. data/lib/contrast/extensions/ruby_core/protect/applies_no_sqli_rule.rb +0 -83
  282. data/lib/contrast/extensions/ruby_core/protect/applies_path_traversal_rule.rb +0 -123
  283. data/lib/contrast/extensions/ruby_core/protect/applies_sqli_rule.rb +0 -65
  284. data/lib/contrast/extensions/ruby_core/protect/applies_xxe_rule.rb +0 -143
  285. data/lib/contrast/extensions/ruby_core/protect/kernel.rb +0 -30
  286. data/lib/contrast/framework/rails_support.rb +0 -88
  287. data/lib/contrast/framework/sinatra_application_helper.rb +0 -49
  288. data/lib/contrast/framework/sinatra_support.rb +0 -94
  289. data/lib/contrast/utils/comment_range.rb +0 -19
  290. data/lib/contrast/utils/data_store_util.rb +0 -23
  291. data/lib/contrast/utils/environment_util.rb +0 -82
  292. data/lib/contrast/utils/performs_logging.rb +0 -152
  293. data/lib/contrast/utils/rack_assess_session_cookie.rb +0 -104
  294. data/lib/contrast/utils/rails_assess_configuration.rb +0 -95
  295. data/lib/contrast/utils/random_util.rb +0 -22
  296. data/resources/csrf/inject.js +0 -44
  297. data/resources/factory-bot-spec/spec_helper.rb +0 -30
  298. data/resources/rubocops/kernel/catch_cop.rb +0 -37
  299. data/resources/rubocops/kernel/require_cop.rb +0 -37
  300. data/resources/rubocops/kernel/require_relative_cop.rb +0 -33
  301. data/resources/rubocops/module/autoload_cop.rb +0 -37
  302. data/resources/rubocops/module/const_defined_cop.rb +0 -37
  303. data/resources/rubocops/module/const_get_cop.rb +0 -37
  304. data/resources/rubocops/module/const_set_cop.rb +0 -37
  305. data/resources/rubocops/module/constants_cop.rb +0 -37
  306. data/resources/rubocops/module/name_cop.rb +0 -37
  307. data/resources/rubocops/object/class_cop.rb +0 -37
  308. data/resources/rubocops/object/freeze_cop.rb +0 -37
  309. data/resources/rubocops/object/frozen_cop.rb +0 -37
  310. data/resources/rubocops/object/is_a_cop.rb +0 -37
  311. data/resources/rubocops/object/method_cop.rb +0 -37
  312. data/resources/rubocops/object/respond_to_cop.rb +0 -37
  313. data/resources/rubocops/object/singleton_class_cop.rb +0 -37
  314. data/resources/rubocops/regexp/spelling_cop.rb +0 -44
  315. data/resources/rubocops/thread/new_cop.rb +0 -39
  316. data/resources/ruby-spec/ancestors_spec.rb +0 -70
  317. data/resources/ruby-spec/modulo_spec.rb +0 -831
  318. data/resources/ruby-spec/parameters_spec.rb +0 -261
  319. data/resources/ruby-spec/ruby_spec_spec_helper.rb +0 -35
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: f0a8762b07c0f0d3d160bbb27e17889197263e3a791ea904df5e8fd6718ea380
4
- data.tar.gz: e4e19fa0f8f300f4c7450d9d2cc83d907c03f5b2d0ab66662ba91fb200e0df1e
3
+ metadata.gz: 0dbe37872e820951219da1fe4ec999627ac80d353c7bcb410f9ba23eb1cde1f5
4
+ data.tar.gz: b047e09b04b21d8aa8d6aa18628f18e27db5d29582186071b2914c1782690979
5
5
  SHA512:
6
- metadata.gz: be95e36b2c836a20cc8fab92c3dc5840b087f6ab762ddce901bc109ec2ef71cd25bb75a46dbb5f092f44621eaedc4655cff04956bd72075d7d432394fbd0e3e3
7
- data.tar.gz: fcdbda9a333c872c43f4ab7079bd067573891c23b42b56afd42f09bf73613ba4c22c214d9bb21570e888463312985141a568d8a7e1cd826bb3f13db988e0e9cd
6
+ metadata.gz: ecae0eb3a447018a25090a709f100def02ee94f1ff6e8218a9acdbd32ee6a4bd5e5b118921aecc94888c5c99b0ece6b17bb1bd15d2c56b8995506856070712c7
7
+ data.tar.gz: 7675ace867f1e8e92003e03c52fbaf516b97c723b600dff7544e33dd4f1a9c5e4333f054cf45a984cd2117ef073a8b1b1775756fc1ee353ddb6c36a287a77c56
@@ -0,0 +1 @@
1
+ ./lib/contrast/api/*_pb.rb
data/.simplecov CHANGED
@@ -1,4 +1,7 @@
1
- SimpleCov.minimum_coverage 92.30
1
+ # Copyright (c) 2020 Contrast Security, Inc. See https://www.contrastsecurity.com/enduser-terms-0317a for more details.
2
+ # frozen_string_literal: true
3
+
4
+ SimpleCov.minimum_coverage line: 92.30
2
5
  SimpleCov.start do
3
6
  add_filter '/spec/'
4
- end
7
+ end
@@ -31,15 +31,15 @@ unless find_header('funchook.h', ext_path)
31
31
  end
32
32
 
33
33
  SOURCE_PATHS = [
34
- File.join('include', 'funchook.h'),
35
- File.join('src', 'libfunchook.dylib'),
36
- File.join('src', 'libfunchook.so')
34
+ File.join('include', 'funchook.h'),
35
+ File.join('src', 'libfunchook.dylib'),
36
+ File.join('src', 'libfunchook.so')
37
37
  ].freeze
38
38
 
39
39
  TARGET_PATHS = ([
40
- File.expand_path(File.join(File.expand_path(__dir__), '..', 'shared_libraries')),
41
- File.expand_path(__dir__)
42
- ] + (bundler_install_target_paths)).freeze
40
+ File.expand_path(File.join(File.expand_path(__dir__), '..', 'shared_libraries')),
41
+ File.expand_path(__dir__)
42
+ ] + bundler_install_target_paths).freeze
43
43
 
44
44
  puts 'Copying required files'
45
45
 
@@ -51,11 +51,16 @@ unless find_header('funchook.h', ext_path)
51
51
  end
52
52
 
53
53
  TARGET_PATHS.each do |target_path|
54
+ unless File.writable?(target_path)
55
+ puts "Unable to copy into #{ target_path } - directory not writable"
56
+ next
57
+ end
54
58
  puts "Copying #{ source_file_path } into #{ target_path }"
55
59
  FileUtils.cp(source_file_path, target_path)
60
+ rescue StandardError
61
+ puts "Error while copying #{ source_file } to #{ target_path }"
56
62
  end
57
63
  end
58
64
  end
59
65
 
60
-
61
66
  have_header('funchook.h', ext_path)
@@ -3,6 +3,7 @@
3
3
 
4
4
  #include "cs__active_record_named.h"
5
5
  #include <ruby.h>
6
+ #include "../cs__common/cs__common.h"
6
7
 
7
8
  VALUE contrast_assess_active_record_scope(const int argc, const VALUE *argv,
8
9
  const VALUE self) {
@@ -18,7 +19,7 @@ VALUE contrast_assess_active_record_scope(const int argc, const VALUE *argv,
18
19
  */
19
20
  VALUE new_body, ret;
20
21
  VALUE new_args[3];
21
- new_body = rb_funcall(self, rb_sym_assess_rewrite, 2, argv[0], argv[1]);
22
+ new_body = rb_funcall(active_record_named, rb_sym_assess_rewrite, 3, self, argv[0], argv[1]);
22
23
  new_args[0] = argv[0];
23
24
  if (NIL_P(new_body)) {
24
25
  new_args[1] = argv[1];
@@ -31,17 +32,14 @@ VALUE contrast_assess_active_record_scope(const int argc, const VALUE *argv,
31
32
  }
32
33
 
33
34
  void Init_cs__assess_active_record_named(void) {
34
- rb_sym_assess_rewrite = rb_intern("_cs__rewrite");
35
- rb_sym_assess_scope = rb_intern("cs__patched_scope");
36
-
37
- VALUE active_record_module = rb_define_module("ActiveRecord");
38
- VALUE scoping_module =
39
- rb_define_module_under(active_record_module, "Scoping");
40
- VALUE named_module = rb_define_module_under(scoping_module, "Named");
41
- VALUE class_methods_module =
42
- rb_define_module_under(named_module, "ClassMethods");
43
-
44
- contrast_alias_method(class_methods_module, "cs__patched_scope", "scope");
45
- rb_define_method(class_methods_module, "scope",
46
- contrast_assess_active_record_scope, -1);
35
+ VALUE framework, rails, rewrite;
36
+ framework = rb_define_module_under(contrast, "Framework");
37
+ rails = rb_define_module_under(framework, "Rails");
38
+ rewrite = rb_define_module_under(rails, "Rewrite");
39
+ active_record_named = rb_define_class_under(rewrite, "ActiveRecordNamed", rb_cObject);
40
+ rb_sym_assess_rewrite = rb_intern("rewrite");
41
+ rb_sym_assess_scope = contrast_register_patch("ActiveRecord::Scoping::Named::ClassMethods",
42
+ "scope",
43
+ contrast_assess_active_record_scope);
47
44
  }
45
+
@@ -1,5 +1,6 @@
1
1
  #include <ruby.h>
2
2
 
3
+ static VALUE active_record_named;
3
4
  static VALUE rb_sym_assess_rewrite;
4
5
  static VALUE rb_sym_assess_scope;
5
6
 
@@ -1,2 +1,5 @@
1
+ # Copyright (c) 2020 Contrast Security, Inc. See https://www.contrastsecurity.com/enduser-terms-0317a for more details.
2
+ # frozen_string_literal: true
3
+
1
4
  $TO_MAKE = File.basename(__dir__)
2
5
  require_relative '../extconf_common'
@@ -23,16 +23,15 @@ static VALUE contrast_assess_array_join(const int argc, const VALUE *argv,
23
23
  /* Finally, default to empty String. Implicit since nil.to_s is ''*/
24
24
 
25
25
  result = rb_funcall2(ary, rb_sym_assess_array_join, argc, argv);
26
- result = rb_funcall(ary, rb_sym_assess_track_array_join, 2, sep, result);
26
+ result = rb_funcall(array_propagator, rb_sym_assess_track_array_join, 3, ary, sep, result);
27
27
 
28
28
  return result;
29
29
  }
30
30
 
31
31
  void Init_cs__assess_array(void) {
32
- rb_sym_assess_array_join = rb_intern("cs__patched_join");
32
+ array_propagator = rb_define_class_under(core_assess, "ArrayPropagator", rb_cObject);
33
33
  rb_sym_assess_track_array_join = rb_intern("cs__track_join");
34
-
35
- VALUE array_class = rb_define_class("Array", rb_cObject);
36
- contrast_alias_method(array_class, "cs__patched_join", "join");
37
- rb_define_method(array_class, "join", contrast_assess_array_join, -1);
34
+ rb_sym_assess_array_join = contrast_register_patch("Array",
35
+ "join",
36
+ contrast_assess_array_join);
38
37
  }
@@ -1,5 +1,6 @@
1
1
  #include <ruby.h>
2
2
 
3
+ static VALUE array_propagator;
3
4
  static VALUE rb_sym_assess_array_join;
4
5
  static VALUE rb_sym_assess_track_array_join;
5
6
 
@@ -1,2 +1,5 @@
1
+ # Copyright (c) 2020 Contrast Security, Inc. See https://www.contrastsecurity.com/enduser-terms-0317a for more details.
2
+ # frozen_string_literal: true
3
+
1
4
  $TO_MAKE = File.basename(__dir__)
2
5
  require_relative '../extconf_common'
@@ -5,14 +5,9 @@
5
5
  #include "../cs__common/cs__common.h"
6
6
  #include <ruby.h>
7
7
 
8
- void contrast_assess_instance_eval_trigger_check(VALUE module, VALUE source,
8
+ void contrast_assess_instance_eval_trigger_check(VALUE self, VALUE source,
9
9
  VALUE ret) {
10
- VALUE has_trigger_check =
11
- rb_respond_to(rb_cBasicObject, instance_trigger_check_method);
12
- if (has_trigger_check) {
13
- rb_funcall(rb_cBasicObject, instance_trigger_check_method, 2, source,
14
- ret);
15
- }
10
+ rb_funcall(basic_eval_trigger, instance_trigger_check_method, 3, self, source, ret);
16
11
  }
17
12
 
18
13
  VALUE
@@ -41,10 +36,17 @@ contrast_assess_basic_object_instance_eval(const int argc, const VALUE *argv,
41
36
  }
42
37
 
43
38
  void Init_cs__assess_basic_object(void) {
39
+ basic_eval_trigger = rb_define_class_under(core_assess, "EvalTrigger", rb_cObject);
44
40
  instance_trigger_check_method = rb_intern("instance_eval_trigger_check");
45
41
 
46
- contrast_alias_method(rb_cBasicObject, "cs__patched_instance_eval",
47
- "instance_eval");
48
- rb_define_method(rb_cBasicObject, "instance_eval",
49
- contrast_assess_basic_object_instance_eval, -1);
42
+ /* We don't keep a reference to the underlying method.
43
+ * Instead, we call rb_obj_instance_eval directly.
44
+ * This should work an overwhelming majority of the time,
45
+ * but if someone else patched BasicObject#instance_eval,
46
+ * IDK if this is intentional... noting it. -ajm
47
+ */
48
+ contrast_register_patch("BasicObject",
49
+ "instance_eval",
50
+ contrast_assess_basic_object_instance_eval);
51
+
50
52
  }
@@ -1,6 +1,7 @@
1
1
  #include <ruby.h>
2
2
 
3
- /* Contrast::Agent::Patching::Policy::Patcher */
3
+ /* Contrast::Extension::Assess::EvalTrigger */
4
+ static VALUE basic_eval_trigger;
4
5
  static VALUE instance_trigger_check_method;
5
6
 
6
7
  void contrast_alias_method(const VALUE target, const char *to,
@@ -1,2 +1,5 @@
1
+ # Copyright (c) 2020 Contrast Security, Inc. See https://www.contrastsecurity.com/enduser-terms-0317a for more details.
2
+ # frozen_string_literal: true
3
+
1
4
  $TO_MAKE = File.basename(__dir__)
2
5
  require_relative '../extconf_common'
@@ -2,6 +2,7 @@
2
2
  * https://www.contrastsecurity.com/enduser-terms-0317a for more details. */
3
3
 
4
4
  #include "cs__assess_fiber_track.h"
5
+ #include "../cs__common/cs__common.h"
5
6
  #include <funchook.h>
6
7
  #include <ruby.h>
7
8
 
@@ -44,7 +45,7 @@ VALUE rb_fiber_new_hook(VALUE (*func)(ANYARGS), VALUE obj) {
44
45
  VALUE enumerator_method = ID2SYM(enum_ptr->meth);
45
46
  /* e.g.: 1..100, #each_value. Should reflect #inspect on the enum. */
46
47
 
47
- rb_funcall(fiber_class, track_rb_fiber_new, 5, fiber, obj,
48
+ rb_funcall(fiber_propagator, track_rb_fiber_new, 5, fiber, obj,
48
49
  enumerator_method, underlying, calling_method);
49
50
  }
50
51
 
@@ -56,7 +57,7 @@ VALUE rb_fiber_yield_hook(int argc, const VALUE *argv) {
56
57
  VALUE yielding_fiber = rb_fiber_current();
57
58
 
58
59
  /* propagate from yielding_fiber -> result */
59
- rb_funcall(fiber_class, track_rb_fiber_yield, 3, yielding_fiber,
60
+ rb_funcall(fiber_propagator, track_rb_fiber_yield, 3, yielding_fiber,
60
61
  calling_method, *argv);
61
62
 
62
63
  return rb_fiber_yield_original(argc, argv);
@@ -78,7 +79,7 @@ int install_fiber_hooks() {
78
79
  }
79
80
 
80
81
  void Init_cs__assess_fiber_track(void) {
81
- fiber_class = rb_define_class("Fiber", rb_cObject);
82
+ fiber_propagator = rb_define_class_under(core_assess, "FiberPropagator", rb_cObject);
82
83
  track_rb_fiber_new = rb_intern("track_rb_fiber_new");
83
84
  track_rb_fiber_yield = rb_intern("track_rb_fiber_yield");
84
85
  rb_sym_next = rb_intern("next");
@@ -2,15 +2,15 @@
2
2
  #include <ruby.h>
3
3
 
4
4
  static VALUE rb_sym_next;
5
- static VALUE fiber_class;
5
+ static VALUE fiber_propagator;
6
6
  static VALUE track_rb_fiber_new;
7
7
  static VALUE track_rb_fiber_yield;
8
8
 
9
9
  VALUE rb_fiber_new(VALUE (*func)(ANYARGS), VALUE obj);
10
- VALUE *(*rb_fiber_new_original)(VALUE (*func)(ANYARGS), VALUE obj);
10
+ VALUE (*rb_fiber_new_original)(VALUE (*func)(ANYARGS), VALUE obj);
11
11
 
12
12
  VALUE rb_fiber_yield(int argc, const VALUE *argv);
13
- VALUE *(*rb_fiber_yield_original)(int argc, const VALUE *argv);
13
+ VALUE (*rb_fiber_yield_original)(int argc, const VALUE *argv);
14
14
 
15
15
  /* If you call `#next` on an enumerator object, that enumerator object
16
16
  * instantiates a fiber and runs its given proc inside of that fiber.
@@ -1,2 +1,5 @@
1
+ # Copyright (c) 2020 Contrast Security, Inc. See https://www.contrastsecurity.com/enduser-terms-0317a for more details.
2
+ # frozen_string_literal: true
3
+
1
4
  $TO_MAKE = File.basename(__dir__)
2
5
  require_relative '../extconf_common'
@@ -5,7 +5,14 @@
5
5
  #include "../cs__common/cs__common.h"
6
6
  #include <ruby.h>
7
7
 
8
- static VALUE contrast_assess_hash_bracket_get(const int argc, VALUE *argv,
8
+ /* Hashes can be constructed thusly):
9
+ * irb(main):001:0> Hash[:a, :b]
10
+ * => {:a=>:b}
11
+ *
12
+ * This method instruments that unique bracket-construction style
13
+ * of initializing a hash.
14
+ */
15
+ static VALUE contrast_assess_hash_bracket_constructor(const int argc, VALUE *argv,
9
16
  const VALUE hash) {
10
17
  VALUE result;
11
18
 
@@ -14,14 +21,14 @@ static VALUE contrast_assess_hash_bracket_get(const int argc, VALUE *argv,
14
21
  int i;
15
22
  for (i = 0; i < argc; i++) {
16
23
  argv[i] =
17
- rb_funcall(hash, rb_sym_assess_hash_dup_and_freeze, 1, argv[i]);
24
+ rb_funcall(hash_propagator, rb_sym_assess_hash_dup_and_freeze, 1, argv[i]);
18
25
  }
19
26
  /* Hash[ key, value, ... ] -> new_hash */
20
27
  } else if (argc > 1) {
21
28
  int i;
22
29
  for (i = 0; i < argc; i += 2) {
23
30
  argv[i] =
24
- rb_funcall(hash, rb_sym_assess_hash_dup_and_freeze, 1, argv[i]);
31
+ rb_funcall(hash_propagator, rb_sym_assess_hash_dup_and_freeze, 1, argv[i]);
25
32
  }
26
33
  }
27
34
 
@@ -29,36 +36,52 @@ static VALUE contrast_assess_hash_bracket_get(const int argc, VALUE *argv,
29
36
  * String keys
30
37
  * # Hash[ object ] -> new_hash
31
38
  */
32
- result = rb_funcall2(hash, rb_sym_assess_hash_brackets, argc, argv);
39
+ result = rb_funcall2(hash, rb_sym_assess_hash_bracket_constructor, argc, argv);
33
40
 
34
41
  return result;
35
42
  }
36
43
 
44
+ /* Hashes, when keyed with a string, will dup & freeze that string.
45
+ * This is resource-efficient, but inconvenient for instrumentation.
46
+ */
37
47
  static VALUE contrast_assess_hash_bracket_set(const int argc, VALUE *argv,
38
48
  const VALUE hash) {
39
49
  VALUE result;
40
- VALUE key;
41
-
42
- key = rb_funcall2(hash, rb_sym_assess_hash_bracket_set, argc, argv);
43
- argv[0] = key;
50
+ /* Current name (assess_hash_bracket_set).
51
+ * It doesn't set anything on the hash.
52
+ * It takes the arg that /would/ have been the key, and preemptively
53
+ * calls #dup and then #freeze, and then gives you that key.
54
+ *
55
+ * We intentionally don't enter Contrast scope for this patch.
56
+ * #dup instruments the string, and #freeze gets the hash to accept
57
+ * the key directly, without calling its own #dup/#freeze.
58
+ * (That naturally happens in C-land, our instrumentation is in Ruby,
59
+ * so our patches to #dup don't take effect within Hash#[]= unless we
60
+ * specifically do this instrumentation.
61
+ * We haven't revisited this approach since we started more extensively
62
+ * hooking public C functions.)
63
+ */
64
+ if(argc > 0) {
65
+ argv[0] = rb_funcall(hash_propagator, rb_sym_assess_hash_dup_and_freeze, 1, argv[0]);
66
+ }
67
+ /* This is the underlying assignment, w/ our instrumented key. */
44
68
  result = rb_funcall2(hash, rb_sym_assess_hash_bracket_equals, argc, argv);
45
69
 
46
70
  return result;
47
71
  }
48
72
 
49
73
  void Init_cs__assess_hash(void) {
74
+ hash_propagator = rb_define_class_under(core_assess, "HashPropagator", rb_cObject);
50
75
  rb_sym_assess_hash_dup_and_freeze = rb_intern("cs__duplicate_and_freeze");
51
- rb_sym_assess_hash_brackets = rb_intern("cs__patched_[]");
52
- rb_sym_assess_hash_bracket_set = rb_intern("cs__bracket_set");
53
- rb_sym_assess_hash_bracket_equals = rb_intern("cs__patched_[]=");
54
76
 
55
77
  VALUE hash_class = rb_define_class("Hash", rb_cObject);
56
- array_class = rb_define_class("Array", rb_cObject);
57
78
 
58
- VALUE singleton = rb_singleton_class(hash_class);
59
- contrast_alias_method(singleton, "cs__patched_[]", "[]");
60
- rb_define_method(singleton, "[]", contrast_assess_hash_bracket_get, -1);
79
+ rb_sym_assess_hash_bracket_constructor = contrast_register_singleton_patch("Hash",
80
+ "[]",
81
+ contrast_assess_hash_bracket_constructor);
82
+
83
+ rb_sym_assess_hash_bracket_equals = contrast_register_patch("Hash",
84
+ "[]=",
85
+ contrast_assess_hash_bracket_set);
61
86
 
62
- contrast_alias_method(hash_class, "cs__patched_[]=", "[]=");
63
- rb_define_method(hash_class, "[]=", contrast_assess_hash_bracket_set, -1);
64
87
  }
@@ -1,11 +1,9 @@
1
1
  #include <ruby.h>
2
2
 
3
- static VALUE array_class;
4
-
5
3
  static VALUE rb_sym_assess_hash_dup_and_freeze;
6
- static VALUE rb_sym_assess_hash_brackets;
7
- static VALUE rb_sym_assess_hash_bracket_set;
4
+ static VALUE rb_sym_assess_hash_bracket_constructor;
8
5
  static VALUE rb_sym_assess_hash_bracket_equals;
6
+ static VALUE hash_propagator;
9
7
 
10
8
  /*
11
9
  * Monkeypatch Ruby Hash with Contrast Security Hash in order ot avoid losing
@@ -15,8 +13,8 @@ static VALUE rb_sym_assess_hash_bracket_equals;
15
13
  * ahead of time should avoid this, similar to the behavior of the -@ Strings
16
14
  * -HM
17
15
  */
18
- static VALUE contrast_assess_hash_bracket_get(const int argc, VALUE *argv,
19
- const VALUE hash);
16
+ static VALUE contrast_assess_hash_bracket_constructor(const int argc, VALUE *argv,
17
+ const VALUE hash);
20
18
 
21
19
  static VALUE contrast_assess_hash_bracket_set(const int argc, VALUE *argv,
22
20
  const VALUE hash);
@@ -1,2 +1,5 @@
1
+ # Copyright (c) 2020 Contrast Security, Inc. See https://www.contrastsecurity.com/enduser-terms-0317a for more details.
2
+ # frozen_string_literal: true
3
+
1
4
  $TO_MAKE = File.basename(__dir__)
2
5
  require_relative '../extconf_common'
@@ -18,19 +18,21 @@ contrast_patched_kernel_exec(const int argc, const VALUE *argv,
18
18
  rb_funcall(contrast_patcher(), rb_sym_exit_scope, 0);
19
19
  }
20
20
 
21
- return rb_funcall(self, rb_intern("cs__assess_kernel_exec"), argc, *argv);
21
+ /* maybe this should be rb_funcall2. this works right now because *argv == argv[0].
22
+ * exec shouldn't ever be called with != 1 argc, so not a huge problem */
23
+ return rb_funcall(self, rb_sym_assess_kernel_exec, argc, *argv);
22
24
  }
23
25
 
24
26
  void Init_cs__assess_kernel(void) {
25
- kernel_propagator = rb_define_module("KernelPropagator");
27
+ kernel_propagator = rb_define_module_under(core_assess, "KernelPropagator");
26
28
  exec_apply_trigger = rb_intern("apply_trigger");
27
29
 
28
- VALUE singleton = rb_singleton_class(rb_mKernel);
30
+ rb_sym_assess_kernel_exec = contrast_register_patch("Kernel",
31
+ "exec",
32
+ contrast_patched_kernel_exec);
29
33
 
30
- contrast_alias_method(rb_mKernel, "cs__assess_kernel_exec", "exec");
31
- rb_define_private_method(rb_mKernel, "exec", contrast_patched_kernel_exec,
32
- -1);
33
-
34
- contrast_alias_method(singleton, "cs__assess_kernel_exec", "exec");
35
- rb_define_method(singleton, "exec", contrast_patched_kernel_exec, -1);
34
+ /* should return the same value as above */
35
+ rb_sym_assess_kernel_exec = contrast_register_singleton_patch("Kernel",
36
+ "exec",
37
+ contrast_patched_kernel_exec);
36
38
  }
@@ -2,6 +2,7 @@
2
2
 
3
3
  static VALUE exec_apply_trigger;
4
4
  static VALUE kernel_propagator;
5
+ static VALUE rb_sym_assess_kernel_exec;
5
6
 
6
7
  VALUE
7
8
  contrast_patched_kernel_exec(const int argc, const VALUE *argv,