ruby-lsp-doclinks 0.1.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 (65) hide show
  1. checksums.yaml +7 -0
  2. data/.rubocop.yml +2 -0
  3. data/CHANGELOG.md +3 -0
  4. data/CODE_OF_CONDUCT.md +132 -0
  5. data/LICENSE.txt +21 -0
  6. data/README.md +67 -0
  7. data/Rakefile +12 -0
  8. data/lib/ruby-lsp-doclinks.rb +1 -0
  9. data/lib/ruby_lsp/doclinks/addon.rb +165 -0
  10. data/lib/ruby_lsp/doclinks/version.rb +7 -0
  11. data/lib/ruby_lsp/doclinks.rb +9 -0
  12. data/sig/ruby_lsp/doclinks.rbs +4 -0
  13. data/sorbet/config +4 -0
  14. data/sorbet/rbi/annotations/.gitattributes +1 -0
  15. data/sorbet/rbi/annotations/activesupport.rbi +457 -0
  16. data/sorbet/rbi/annotations/minitest.rbi +119 -0
  17. data/sorbet/rbi/annotations/rainbow.rbi +269 -0
  18. data/sorbet/rbi/gems/.gitattributes +1 -0
  19. data/sorbet/rbi/gems/activesupport@8.0.2.rbi +11 -0
  20. data/sorbet/rbi/gems/ast@2.4.3.rbi +585 -0
  21. data/sorbet/rbi/gems/base64@0.2.0.rbi +9 -0
  22. data/sorbet/rbi/gems/benchmark@0.4.0.rbi +618 -0
  23. data/sorbet/rbi/gems/bigdecimal@3.1.9.rbi +9 -0
  24. data/sorbet/rbi/gems/concurrent-ruby@1.3.5.rbi +9 -0
  25. data/sorbet/rbi/gems/connection_pool@2.5.0.rbi +9 -0
  26. data/sorbet/rbi/gems/drb@2.2.1.rbi +9 -0
  27. data/sorbet/rbi/gems/erubi@1.13.1.rbi +155 -0
  28. data/sorbet/rbi/gems/i18n@1.14.7.rbi +9 -0
  29. data/sorbet/rbi/gems/json@2.10.2.rbi +2112 -0
  30. data/sorbet/rbi/gems/language_server-protocol@3.17.0.4.rbi +9 -0
  31. data/sorbet/rbi/gems/lint_roller@1.1.0.rbi +86 -0
  32. data/sorbet/rbi/gems/logger@1.6.6.rbi +940 -0
  33. data/sorbet/rbi/gems/minitest@5.25.5.rbi +1547 -0
  34. data/sorbet/rbi/gems/netrc@0.11.0.rbi +159 -0
  35. data/sorbet/rbi/gems/parallel@1.26.3.rbi +291 -0
  36. data/sorbet/rbi/gems/parser@3.3.7.2.rbi +5532 -0
  37. data/sorbet/rbi/gems/prism@1.4.0.rbi +41732 -0
  38. data/sorbet/rbi/gems/racc@1.8.1.rbi +160 -0
  39. data/sorbet/rbi/gems/rack@3.1.12.rbi +4898 -0
  40. data/sorbet/rbi/gems/rainbow@3.1.1.rbi +403 -0
  41. data/sorbet/rbi/gems/rake@13.2.1.rbi +3033 -0
  42. data/sorbet/rbi/gems/rbi@0.3.1.rbi +6599 -0
  43. data/sorbet/rbi/gems/rbs@3.9.1.rbi +6978 -0
  44. data/sorbet/rbi/gems/regexp_parser@2.10.0.rbi +3795 -0
  45. data/sorbet/rbi/gems/rubocop-ast@1.42.0.rbi +7715 -0
  46. data/sorbet/rbi/gems/rubocop-performance@1.24.0.rbi +9 -0
  47. data/sorbet/rbi/gems/rubocop-rails-omakase@1.1.0.rbi +9 -0
  48. data/sorbet/rbi/gems/rubocop-rails@2.30.3.rbi +9 -0
  49. data/sorbet/rbi/gems/rubocop@1.74.0.rbi +61400 -0
  50. data/sorbet/rbi/gems/ruby-lsp@0.23.12.rbi +9 -0
  51. data/sorbet/rbi/gems/ruby-progressbar@1.13.0.rbi +1318 -0
  52. data/sorbet/rbi/gems/securerandom@0.4.1.rbi +75 -0
  53. data/sorbet/rbi/gems/spoom@1.6.1.rbi +7274 -0
  54. data/sorbet/rbi/gems/tapioca@0.16.11.rbi +3628 -0
  55. data/sorbet/rbi/gems/thor@1.3.2.rbi +4378 -0
  56. data/sorbet/rbi/gems/tzinfo@2.0.6.rbi +9 -0
  57. data/sorbet/rbi/gems/unicode-display_width@3.1.4.rbi +132 -0
  58. data/sorbet/rbi/gems/unicode-emoji@4.0.4.rbi +251 -0
  59. data/sorbet/rbi/gems/uri@1.0.3.rbi +2349 -0
  60. data/sorbet/rbi/gems/yard-sorbet@0.9.0.rbi +435 -0
  61. data/sorbet/rbi/gems/yard@0.9.37.rbi +18379 -0
  62. data/sorbet/rbi/todo.rbi +15 -0
  63. data/sorbet/tapioca/config.yml +13 -0
  64. data/sorbet/tapioca/require.rb +4 -0
  65. metadata +131 -0
@@ -0,0 +1,4898 @@
1
+ # typed: true
2
+
3
+ # DO NOT EDIT MANUALLY
4
+ # This is an autogenerated file for types exported from the `rack` gem.
5
+ # Please instead update this file by running `bin/tapioca gem rack`.
6
+
7
+
8
+ # The Rack main module, serving as a namespace for all core Rack
9
+ # modules and classes.
10
+ #
11
+ # All modules meant for use in your application are <tt>autoload</tt>ed here,
12
+ # so it should be enough just to <tt>require 'rack'</tt> in your code.
13
+ #
14
+ # source://rack//lib/rack/version.rb#14
15
+ module Rack
16
+ class << self
17
+ # Return the Rack release as a dotted string.
18
+ #
19
+ # source://rack//lib/rack/version.rb#18
20
+ def release; end
21
+ end
22
+ end
23
+
24
+ # source://rack//lib/rack.rb#60
25
+ module Rack::Auth; end
26
+
27
+ # Rack::Auth::AbstractHandler implements common authentication functionality.
28
+ #
29
+ # +realm+ should be set for all handlers.
30
+ #
31
+ # source://rack//lib/rack/auth/abstract/handler.rb#11
32
+ class Rack::Auth::AbstractHandler
33
+ # @return [AbstractHandler] a new instance of AbstractHandler
34
+ #
35
+ # source://rack//lib/rack/auth/abstract/handler.rb#15
36
+ def initialize(app, realm = T.unsafe(nil), &authenticator); end
37
+
38
+ # Returns the value of attribute realm.
39
+ #
40
+ # source://rack//lib/rack/auth/abstract/handler.rb#13
41
+ def realm; end
42
+
43
+ # Sets the attribute realm
44
+ #
45
+ # @param value the value to set the attribute realm to.
46
+ #
47
+ # source://rack//lib/rack/auth/abstract/handler.rb#13
48
+ def realm=(_arg0); end
49
+
50
+ private
51
+
52
+ # source://rack//lib/rack/auth/abstract/handler.rb#31
53
+ def bad_request; end
54
+
55
+ # source://rack//lib/rack/auth/abstract/handler.rb#22
56
+ def unauthorized(www_authenticate = T.unsafe(nil)); end
57
+ end
58
+
59
+ # source://rack//lib/rack/auth/abstract/request.rb#7
60
+ class Rack::Auth::AbstractRequest
61
+ # @return [AbstractRequest] a new instance of AbstractRequest
62
+ #
63
+ # source://rack//lib/rack/auth/abstract/request.rb#9
64
+ def initialize(env); end
65
+
66
+ # source://rack//lib/rack/auth/abstract/request.rb#33
67
+ def params; end
68
+
69
+ # source://rack//lib/rack/auth/abstract/request.rb#25
70
+ def parts; end
71
+
72
+ # @return [Boolean]
73
+ #
74
+ # source://rack//lib/rack/auth/abstract/request.rb#17
75
+ def provided?; end
76
+
77
+ # source://rack//lib/rack/auth/abstract/request.rb#13
78
+ def request; end
79
+
80
+ # source://rack//lib/rack/auth/abstract/request.rb#29
81
+ def scheme; end
82
+
83
+ # @return [Boolean]
84
+ #
85
+ # source://rack//lib/rack/auth/abstract/request.rb#21
86
+ def valid?; end
87
+
88
+ private
89
+
90
+ # source://rack//lib/rack/auth/abstract/request.rb#42
91
+ def authorization_key; end
92
+ end
93
+
94
+ # source://rack//lib/rack/auth/abstract/request.rb#40
95
+ Rack::Auth::AbstractRequest::AUTHORIZATION_KEYS = T.let(T.unsafe(nil), Array)
96
+
97
+ # Rack::Auth::Basic implements HTTP Basic Authentication, as per RFC 2617.
98
+ #
99
+ # Initialize with the Rack application that you want protecting,
100
+ # and a block that checks if a username and password pair are valid.
101
+ #
102
+ # source://rack//lib/rack/auth/basic.rb#13
103
+ class Rack::Auth::Basic < ::Rack::Auth::AbstractHandler
104
+ # source://rack//lib/rack/auth/basic.rb#15
105
+ def call(env); end
106
+
107
+ private
108
+
109
+ # source://rack//lib/rack/auth/basic.rb#34
110
+ def challenge; end
111
+
112
+ # @return [Boolean]
113
+ #
114
+ # source://rack//lib/rack/auth/basic.rb#38
115
+ def valid?(auth); end
116
+ end
117
+
118
+ # source://rack//lib/rack/auth/basic.rb#42
119
+ class Rack::Auth::Basic::Request < ::Rack::Auth::AbstractRequest
120
+ # @return [Boolean]
121
+ #
122
+ # source://rack//lib/rack/auth/basic.rb#43
123
+ def basic?; end
124
+
125
+ # source://rack//lib/rack/auth/basic.rb#47
126
+ def credentials; end
127
+
128
+ # source://rack//lib/rack/auth/basic.rb#51
129
+ def username; end
130
+ end
131
+
132
+ # source://rack//lib/rack/builder.rb#6
133
+ Rack::BUILDER_TOPLEVEL_BINDING = T.let(T.unsafe(nil), Proc)
134
+
135
+ # Represents a 400 Bad Request error when input data fails to meet the
136
+ # requirements.
137
+ #
138
+ # source://rack//lib/rack/bad_request.rb#6
139
+ module Rack::BadRequest; end
140
+
141
+ # Proxy for response bodies allowing calling a block when
142
+ # the response body is closed (after the response has been fully
143
+ # sent to the client).
144
+ #
145
+ # source://rack//lib/rack/body_proxy.rb#7
146
+ class Rack::BodyProxy
147
+ # Set the response body to wrap, and the block to call when the
148
+ # response has been fully sent.
149
+ #
150
+ # @return [BodyProxy] a new instance of BodyProxy
151
+ #
152
+ # source://rack//lib/rack/body_proxy.rb#10
153
+ def initialize(body, &block); end
154
+
155
+ # If not already closed, close the wrapped body and
156
+ # then call the block the proxy was initialized with.
157
+ #
158
+ # source://rack//lib/rack/body_proxy.rb#28
159
+ def close; end
160
+
161
+ # Whether the proxy is closed. The proxy starts as not closed,
162
+ # and becomes closed on the first call to close.
163
+ #
164
+ # @return [Boolean]
165
+ #
166
+ # source://rack//lib/rack/body_proxy.rb#40
167
+ def closed?; end
168
+
169
+ # Delegate missing methods to the wrapped body.
170
+ #
171
+ # source://rack//lib/rack/body_proxy.rb#45
172
+ def method_missing(method_name, *args, **_arg2, &block); end
173
+
174
+ private
175
+
176
+ # Return whether the wrapped body responds to the method.
177
+ #
178
+ # @return [Boolean]
179
+ #
180
+ # source://rack//lib/rack/body_proxy.rb#17
181
+ def respond_to_missing?(method_name, include_all = T.unsafe(nil)); end
182
+ end
183
+
184
+ # Rack::Builder provides a domain-specific language (DSL) to construct Rack
185
+ # applications. It is primarily used to parse +config.ru+ files which
186
+ # instantiate several middleware and a final application which are hosted
187
+ # by a Rack-compatible web server.
188
+ #
189
+ # Example:
190
+ #
191
+ # app = Rack::Builder.new do
192
+ # use Rack::CommonLogger
193
+ # map "/ok" do
194
+ # run lambda { |env| [200, {'content-type' => 'text/plain'}, ['OK']] }
195
+ # end
196
+ # end
197
+ #
198
+ # run app
199
+ #
200
+ # Or
201
+ #
202
+ # app = Rack::Builder.app do
203
+ # use Rack::CommonLogger
204
+ # run lambda { |env| [200, {'content-type' => 'text/plain'}, ['OK']] }
205
+ # end
206
+ #
207
+ # run app
208
+ #
209
+ # +use+ adds middleware to the stack, +run+ dispatches to an application.
210
+ # You can use +map+ to construct a Rack::URLMap in a convenient way.
211
+ #
212
+ # source://rack//lib/rack/builder.rb#36
213
+ class Rack::Builder
214
+ # Initialize a new Rack::Builder instance. +default_app+ specifies the
215
+ # default application if +run+ is not called later. If a block
216
+ # is given, it is evaluated in the context of the instance.
217
+ #
218
+ # @return [Builder] a new instance of Builder
219
+ #
220
+ # source://rack//lib/rack/builder.rb#116
221
+ def initialize(default_app = T.unsafe(nil), **options, &block); end
222
+
223
+ # Call the Rack application generated by this builder instance. Note that
224
+ # this rebuilds the Rack application and runs the warmup code (if any)
225
+ # every time it is called, so it should not be used if performance is important.
226
+ #
227
+ # source://rack//lib/rack/builder.rb#276
228
+ def call(env); end
229
+
230
+ # Freeze the app (set using run) and all middleware instances when building the application
231
+ # in to_app.
232
+ #
233
+ # source://rack//lib/rack/builder.rb#259
234
+ def freeze_app; end
235
+
236
+ # Creates a route within the application. Routes under the mapped path will be sent to
237
+ # the Rack application specified by run inside the block. Other requests will be sent to the
238
+ # default application specified by run outside the block.
239
+ #
240
+ # class App
241
+ # def call(env)
242
+ # [200, {'content-type' => 'text/plain'}, ["Hello World"]]
243
+ # end
244
+ # end
245
+ #
246
+ # class Heartbeat
247
+ # def call(env)
248
+ # [200, { "content-type" => "text/plain" }, ["OK"]]
249
+ # end
250
+ # end
251
+ #
252
+ # app = Rack::Builder.app do
253
+ # map '/heartbeat' do
254
+ # run Heartbeat.new
255
+ # end
256
+ # run App.new
257
+ # end
258
+ #
259
+ # run app
260
+ #
261
+ # The +use+ method can also be used inside the block to specify middleware to run under a specific path:
262
+ #
263
+ # app = Rack::Builder.app do
264
+ # map '/heartbeat' do
265
+ # use Middleware
266
+ # run Heartbeat.new
267
+ # end
268
+ # run App.new
269
+ # end
270
+ #
271
+ # This example includes a piece of middleware which will run before +/heartbeat+ requests hit +Heartbeat+.
272
+ #
273
+ # Note that providing a +path+ of +/+ will ignore any default application given in a +run+ statement
274
+ # outside the block.
275
+ #
276
+ # source://rack//lib/rack/builder.rb#252
277
+ def map(path, &block); end
278
+
279
+ # Any options provided to the Rack::Builder instance at initialization.
280
+ # These options can be server-specific. Some general options are:
281
+ #
282
+ # * +:isolation+: One of +process+, +thread+ or +fiber+. The execution
283
+ # isolation model to use.
284
+ #
285
+ # source://rack//lib/rack/builder.rb#132
286
+ def options; end
287
+
288
+ # Takes a block or argument that is an object that responds to #call and
289
+ # returns a Rack response.
290
+ #
291
+ # You can use a block:
292
+ #
293
+ # run do |env|
294
+ # [200, { "content-type" => "text/plain" }, ["Hello World!"]]
295
+ # end
296
+ #
297
+ # You can also provide a lambda:
298
+ #
299
+ # run lambda { |env| [200, { "content-type" => "text/plain" }, ["OK"]] }
300
+ #
301
+ # You can also provide a class instance:
302
+ #
303
+ # class Heartbeat
304
+ # def call(env)
305
+ # [200, { "content-type" => "text/plain" }, ["OK"]]
306
+ # end
307
+ # end
308
+ #
309
+ # run Heartbeat.new
310
+ #
311
+ # @raise [ArgumentError]
312
+ #
313
+ # source://rack//lib/rack/builder.rb#193
314
+ def run(app = T.unsafe(nil), &block); end
315
+
316
+ # Return the Rack application generated by this instance.
317
+ #
318
+ # source://rack//lib/rack/builder.rb#264
319
+ def to_app; end
320
+
321
+ # Specifies middleware to use in a stack.
322
+ #
323
+ # class Middleware
324
+ # def initialize(app)
325
+ # @app = app
326
+ # end
327
+ #
328
+ # def call(env)
329
+ # env["rack.some_header"] = "setting an example"
330
+ # @app.call(env)
331
+ # end
332
+ # end
333
+ #
334
+ # use Middleware
335
+ # run lambda { |env| [200, { "content-type" => "text/plain" }, ["OK"]] }
336
+ #
337
+ # All requests through to this application will first be processed by the middleware class.
338
+ # The +call+ method in this example sets an additional environment key which then can be
339
+ # referenced in the application if required.
340
+ #
341
+ # source://rack//lib/rack/builder.rb#159
342
+ def use(middleware, *args, **_arg2, &block); end
343
+
344
+ # Takes a lambda or block that is used to warm-up the application. This block is called
345
+ # before the Rack application is returned by to_app.
346
+ #
347
+ # warmup do |app|
348
+ # client = Rack::MockRequest.new(app)
349
+ # client.get('/')
350
+ # end
351
+ #
352
+ # use SomeMiddleware
353
+ # run MyApp
354
+ #
355
+ # source://rack//lib/rack/builder.rb#209
356
+ def warmup(prc = T.unsafe(nil), &block); end
357
+
358
+ private
359
+
360
+ # Generate a URLMap instance by generating new Rack applications for each
361
+ # map block in this instance.
362
+ #
363
+ # source://rack//lib/rack/builder.rb#284
364
+ def generate_map(default_app, mapping); end
365
+
366
+ class << self
367
+ # Create a new Rack::Builder instance and return the Rack application
368
+ # generated from it.
369
+ #
370
+ # source://rack//lib/rack/builder.rb#136
371
+ def app(default_app = T.unsafe(nil), &block); end
372
+
373
+ # Load the given file as a rackup file, treating the
374
+ # contents as if specified inside a Rack::Builder block.
375
+ #
376
+ # Ignores content in the file after +__END__+, so that
377
+ # use of +__END__+ will not result in a syntax error.
378
+ #
379
+ # Example config.ru file:
380
+ #
381
+ # $ cat config.ru
382
+ #
383
+ # use Rack::ContentLength
384
+ # require './app.rb'
385
+ # run App
386
+ #
387
+ # source://rack//lib/rack/builder.rb#87
388
+ def load_file(path, **options); end
389
+
390
+ # Evaluate the given +builder_script+ string in the context of
391
+ # a Rack::Builder block, returning a Rack application.
392
+ #
393
+ # source://rack//lib/rack/builder.rb#102
394
+ def new_from_string(builder_script, path = T.unsafe(nil), **options); end
395
+
396
+ # Parse the given config file to get a Rack application.
397
+ #
398
+ # If the config file ends in +.ru+, it is treated as a
399
+ # rackup file and the contents will be treated as if
400
+ # specified inside a Rack::Builder block.
401
+ #
402
+ # If the config file does not end in +.ru+, it is
403
+ # required and Rack will use the basename of the file
404
+ # to guess which constant will be the Rack application to run.
405
+ #
406
+ # Examples:
407
+ #
408
+ # Rack::Builder.parse_file('config.ru')
409
+ # # Rack application built using Rack::Builder.new
410
+ #
411
+ # Rack::Builder.parse_file('app.rb')
412
+ # # requires app.rb, which can be anywhere in Ruby's
413
+ # # load path. After requiring, assumes App constant
414
+ # # is a Rack application
415
+ #
416
+ # Rack::Builder.parse_file('./my_app.rb')
417
+ # # requires ./my_app.rb, which should be in the
418
+ # # process's current directory. After requiring,
419
+ # # assumes MyApp constant is a Rack application
420
+ #
421
+ # source://rack//lib/rack/builder.rb#65
422
+ def parse_file(path, **options); end
423
+ end
424
+ end
425
+
426
+ # https://stackoverflow.com/questions/2223882/whats-the-difference-between-utf-8-and-utf-8-without-bom
427
+ #
428
+ # source://rack//lib/rack/builder.rb#39
429
+ Rack::Builder::UTF_8_BOM = T.let(T.unsafe(nil), String)
430
+
431
+ # Response Header Keys
432
+ #
433
+ # source://rack//lib/rack/constants.rb#19
434
+ Rack::CACHE_CONTROL = T.let(T.unsafe(nil), String)
435
+
436
+ # source://rack//lib/rack/constants.rb#35
437
+ Rack::CONNECT = T.let(T.unsafe(nil), String)
438
+
439
+ # source://rack//lib/rack/constants.rb#20
440
+ Rack::CONTENT_LENGTH = T.let(T.unsafe(nil), String)
441
+
442
+ # source://rack//lib/rack/constants.rb#21
443
+ Rack::CONTENT_TYPE = T.let(T.unsafe(nil), String)
444
+
445
+ # Rack::Cascade tries a request on several apps, and returns the
446
+ # first response that is not 404 or 405 (or in a list of configured
447
+ # status codes). If all applications tried return one of the configured
448
+ # status codes, return the last response.
449
+ #
450
+ # source://rack//lib/rack/cascade.rb#11
451
+ class Rack::Cascade
452
+ # Set the apps to send requests to, and what statuses result in
453
+ # cascading. Arguments:
454
+ #
455
+ # apps: An enumerable of rack applications.
456
+ # cascade_for: The statuses to use cascading for. If a response is received
457
+ # from an app, the next app is tried.
458
+ #
459
+ # @return [Cascade] a new instance of Cascade
460
+ #
461
+ # source://rack//lib/rack/cascade.rb#21
462
+ def initialize(apps, cascade_for = T.unsafe(nil)); end
463
+
464
+ # Append an app to the list of apps to cascade. This app will
465
+ # be tried last.
466
+ #
467
+ # source://rack//lib/rack/cascade.rb#56
468
+ def <<(app); end
469
+
470
+ # Append an app to the list of apps to cascade. This app will
471
+ # be tried last.
472
+ #
473
+ # source://rack//lib/rack/cascade.rb#56
474
+ def add(app); end
475
+
476
+ # An array of applications to try in order.
477
+ #
478
+ # source://rack//lib/rack/cascade.rb#13
479
+ def apps; end
480
+
481
+ # Call each app in order. If the responses uses a status that requires
482
+ # cascading, try the next app. If all responses require cascading,
483
+ # return the response from the last app.
484
+ #
485
+ # source://rack//lib/rack/cascade.rb#32
486
+ def call(env); end
487
+
488
+ # Whether the given app is one of the apps to cascade to.
489
+ #
490
+ # @return [Boolean]
491
+ #
492
+ # source://rack//lib/rack/cascade.rb#61
493
+ def include?(app); end
494
+ end
495
+
496
+ # Rack::CommonLogger forwards every request to the given +app+, and
497
+ # logs a line in the
498
+ # {Apache common log format}[http://httpd.apache.org/docs/1.3/logs.html#common]
499
+ # to the configured logger.
500
+ #
501
+ # source://rack//lib/rack/common_logger.rb#13
502
+ class Rack::CommonLogger
503
+ # +logger+ can be any object that supports the +write+ or +<<+ methods,
504
+ # which includes the standard library Logger. These methods are called
505
+ # with a single string argument, the log message.
506
+ # If +logger+ is nil, CommonLogger will fall back <tt>env['rack.errors']</tt>.
507
+ #
508
+ # @return [CommonLogger] a new instance of CommonLogger
509
+ #
510
+ # source://rack//lib/rack/common_logger.rb#29
511
+ def initialize(app, logger = T.unsafe(nil)); end
512
+
513
+ # Log all requests in common_log format after a response has been
514
+ # returned. Note that if the app raises an exception, the request
515
+ # will not be logged, so if exception handling middleware are used,
516
+ # they should be loaded after this middleware. Additionally, because
517
+ # the logging happens after the request body has been fully sent, any
518
+ # exceptions raised during the sending of the response body will
519
+ # cause the request not to be logged.
520
+ #
521
+ # source://rack//lib/rack/common_logger.rb#41
522
+ def call(env); end
523
+
524
+ private
525
+
526
+ # Attempt to determine the content length for the response to
527
+ # include it in the logged data.
528
+ #
529
+ # source://rack//lib/rack/common_logger.rb#84
530
+ def extract_content_length(headers); end
531
+
532
+ # Log the request to the configured logger.
533
+ #
534
+ # source://rack//lib/rack/common_logger.rb#52
535
+ def log(env, status, response_headers, began_at); end
536
+ end
537
+
538
+ # Common Log Format: http://httpd.apache.org/docs/1.3/logs.html#common
539
+ #
540
+ # lilith.local - - [07/Aug/2006 23:58:02 -0400] "GET / HTTP/1.1" 500 -
541
+ #
542
+ # %{%s - %s [%s] "%s %s%s %s" %d %s\n} %
543
+ #
544
+ # The actual format is slightly different than the above due to the
545
+ # separation of SCRIPT_NAME and PATH_INFO, and because the elapsed
546
+ # time in seconds is included at the end.
547
+ #
548
+ # source://rack//lib/rack/common_logger.rb#23
549
+ Rack::CommonLogger::FORMAT = T.let(T.unsafe(nil), String)
550
+
551
+ # Middleware that enables conditional GET using if-none-match and
552
+ # if-modified-since. The application should set either or both of the
553
+ # last-modified or etag response headers according to RFC 2616. When
554
+ # either of the conditions is met, the response body is set to be zero
555
+ # length and the response status is set to 304 Not Modified.
556
+ #
557
+ # Applications that defer response body generation until the body's each
558
+ # message is received will avoid response body generation completely when
559
+ # a conditional GET matches.
560
+ #
561
+ # Adapted from Michael Klishin's Merb implementation:
562
+ # https://github.com/wycats/merb/blob/master/merb-core/lib/merb-core/rack/middleware/conditional_get.rb
563
+ #
564
+ # source://rack//lib/rack/conditional_get.rb#21
565
+ class Rack::ConditionalGet
566
+ # @return [ConditionalGet] a new instance of ConditionalGet
567
+ #
568
+ # source://rack//lib/rack/conditional_get.rb#22
569
+ def initialize(app); end
570
+
571
+ # Return empty 304 response if the response has not been
572
+ # modified since the last request.
573
+ #
574
+ # source://rack//lib/rack/conditional_get.rb#28
575
+ def call(env); end
576
+
577
+ private
578
+
579
+ # Whether the etag response header matches the if-none-match request header.
580
+ # If so, the request has not been modified.
581
+ #
582
+ # @return [Boolean]
583
+ #
584
+ # source://rack//lib/rack/conditional_get.rb#62
585
+ def etag_matches?(none_match, headers); end
586
+
587
+ # Return whether the response has not been modified since the
588
+ # last request.
589
+ #
590
+ # @return [Boolean]
591
+ #
592
+ # source://rack//lib/rack/conditional_get.rb#51
593
+ def fresh?(env, headers); end
594
+
595
+ # Whether the last-modified response header matches the if-modified-since
596
+ # request header. If so, the request has not been modified.
597
+ #
598
+ # @return [Boolean]
599
+ #
600
+ # source://rack//lib/rack/conditional_get.rb#68
601
+ def modified_since?(modified_since, headers); end
602
+
603
+ # Return a Time object for the given string (which should be in RFC2822
604
+ # format), or nil if the string cannot be parsed.
605
+ #
606
+ # source://rack//lib/rack/conditional_get.rb#75
607
+ def to_rfc2822(since); end
608
+ end
609
+
610
+ # Rack::Config modifies the environment using the block given during
611
+ # initialization.
612
+ #
613
+ # Example:
614
+ # use Rack::Config do |env|
615
+ # env['my-key'] = 'some-value'
616
+ # end
617
+ #
618
+ # source://rack//lib/rack/config.rb#11
619
+ class Rack::Config
620
+ # @return [Config] a new instance of Config
621
+ #
622
+ # source://rack//lib/rack/config.rb#12
623
+ def initialize(app, &block); end
624
+
625
+ # source://rack//lib/rack/config.rb#17
626
+ def call(env); end
627
+ end
628
+
629
+ # Sets the content-length header on responses that do not specify
630
+ # a content-length or transfer-encoding header. Note that this
631
+ # does not fix responses that have an invalid content-length
632
+ # header specified.
633
+ #
634
+ # source://rack//lib/rack/content_length.rb#12
635
+ class Rack::ContentLength
636
+ include ::Rack::Utils
637
+
638
+ # @return [ContentLength] a new instance of ContentLength
639
+ #
640
+ # source://rack//lib/rack/content_length.rb#15
641
+ def initialize(app); end
642
+
643
+ # source://rack//lib/rack/content_length.rb#19
644
+ def call(env); end
645
+ end
646
+
647
+ # Sets the content-type header on responses which don't have one.
648
+ #
649
+ # Builder Usage:
650
+ # use Rack::ContentType, "text/plain"
651
+ #
652
+ # When no content type argument is provided, "text/html" is the
653
+ # default.
654
+ #
655
+ # source://rack//lib/rack/content_type.rb#15
656
+ class Rack::ContentType
657
+ include ::Rack::Utils
658
+
659
+ # @return [ContentType] a new instance of ContentType
660
+ #
661
+ # source://rack//lib/rack/content_type.rb#18
662
+ def initialize(app, content_type = T.unsafe(nil)); end
663
+
664
+ # source://rack//lib/rack/content_type.rb#23
665
+ def call(env); end
666
+ end
667
+
668
+ # source://rack//lib/rack/constants.rb#32
669
+ Rack::DELETE = T.let(T.unsafe(nil), String)
670
+
671
+ # This middleware enables content encoding of http responses,
672
+ # usually for purposes of compression.
673
+ #
674
+ # Currently supported encodings:
675
+ #
676
+ # * gzip
677
+ # * identity (no transformation)
678
+ #
679
+ # This middleware automatically detects when encoding is supported
680
+ # and allowed. For example no encoding is made when a cache
681
+ # directive of 'no-transform' is present, when the response status
682
+ # code is one that doesn't allow an entity body, or when the body
683
+ # is empty.
684
+ #
685
+ # Note that despite the name, Deflater does not support the +deflate+
686
+ # encoding.
687
+ #
688
+ # source://rack//lib/rack/deflater.rb#28
689
+ class Rack::Deflater
690
+ # Creates Rack::Deflater middleware. Options:
691
+ #
692
+ # :if :: a lambda enabling / disabling deflation based on returned boolean value
693
+ # (e.g <tt>use Rack::Deflater, :if => lambda { |*, body| sum=0; body.each { |i| sum += i.length }; sum > 512 }</tt>).
694
+ # However, be aware that calling `body.each` inside the block will break cases where `body.each` is not idempotent,
695
+ # such as when it is an +IO+ instance.
696
+ # :include :: a list of content types that should be compressed. By default, all content types are compressed.
697
+ # :sync :: determines if the stream is going to be flushed after every chunk. Flushing after every chunk reduces
698
+ # latency for time-sensitive streaming applications, but hurts compression and throughput.
699
+ # Defaults to +true+.
700
+ #
701
+ # @return [Deflater] a new instance of Deflater
702
+ #
703
+ # source://rack//lib/rack/deflater.rb#39
704
+ def initialize(app, options = T.unsafe(nil)); end
705
+
706
+ # source://rack//lib/rack/deflater.rb#46
707
+ def call(env); end
708
+
709
+ private
710
+
711
+ # Whether the body should be compressed.
712
+ #
713
+ # @return [Boolean]
714
+ #
715
+ # source://rack//lib/rack/deflater.rb#136
716
+ def should_deflate?(env, status, headers, body); end
717
+ end
718
+
719
+ # Body class used for gzip encoded responses.
720
+ #
721
+ # source://rack//lib/rack/deflater.rb#83
722
+ class Rack::Deflater::GzipStream
723
+ # Initialize the gzip stream. Arguments:
724
+ # body :: Response body to compress with gzip
725
+ # mtime :: The modification time of the body, used to set the
726
+ # modification time in the gzip header.
727
+ # sync :: Whether to flush each gzip chunk as soon as it is ready.
728
+ #
729
+ # @return [GzipStream] a new instance of GzipStream
730
+ #
731
+ # source://rack//lib/rack/deflater.rb#92
732
+ def initialize(body, mtime, sync); end
733
+
734
+ # Close the original body if possible.
735
+ #
736
+ # source://rack//lib/rack/deflater.rb#128
737
+ def close; end
738
+
739
+ # Yield gzip compressed strings to the given block.
740
+ #
741
+ # source://rack//lib/rack/deflater.rb#99
742
+ def each(&block); end
743
+
744
+ # Call the block passed to #each with the gzipped data.
745
+ #
746
+ # source://rack//lib/rack/deflater.rb#123
747
+ def write(data); end
748
+ end
749
+
750
+ # source://rack//lib/rack/deflater.rb#85
751
+ Rack::Deflater::GzipStream::BUFFER_LENGTH = T.let(T.unsafe(nil), Integer)
752
+
753
+ # Rack::Directory serves entries below the +root+ given, according to the
754
+ # path info of the Rack request. If a directory is found, the file's contents
755
+ # will be presented in an html based index. If a file is found, the env will
756
+ # be passed to the specified +app+.
757
+ #
758
+ # If +app+ is not specified, a Rack::Files of the same +root+ will be used.
759
+ #
760
+ # source://rack//lib/rack/directory.rb#19
761
+ class Rack::Directory
762
+ # Set the root directory and application for serving files.
763
+ #
764
+ # @return [Directory] a new instance of Directory
765
+ #
766
+ # source://rack//lib/rack/directory.rb#83
767
+ def initialize(root, app = T.unsafe(nil)); end
768
+
769
+ # source://rack//lib/rack/directory.rb#89
770
+ def call(env); end
771
+
772
+ # Rack response to use for requests with invalid paths, or nil if path is valid.
773
+ #
774
+ # source://rack//lib/rack/directory.rb#109
775
+ def check_bad_request(path_info); end
776
+
777
+ # Rack response to use for requests with paths outside the root, or nil if path is inside the root.
778
+ #
779
+ # source://rack//lib/rack/directory.rb#119
780
+ def check_forbidden(path_info); end
781
+
782
+ # Rack response to use for unreadable and non-file, non-directory entries.
783
+ #
784
+ # source://rack//lib/rack/directory.rb#181
785
+ def entity_not_found(path_info); end
786
+
787
+ # Provide human readable file sizes
788
+ #
789
+ # source://rack//lib/rack/directory.rb#197
790
+ def filesize_format(int); end
791
+
792
+ # Internals of request handling. Similar to call but does
793
+ # not remove body for HEAD requests.
794
+ #
795
+ # source://rack//lib/rack/directory.rb#96
796
+ def get(env); end
797
+
798
+ # Rack response to use for directories under the root.
799
+ #
800
+ # source://rack//lib/rack/directory.rb#130
801
+ def list_directory(path_info, path, script_name); end
802
+
803
+ # Rack response to use for files and directories under the root.
804
+ # Unreadable and non-file, non-directory entries will get a 404 response.
805
+ #
806
+ # source://rack//lib/rack/directory.rb#171
807
+ def list_path(env, path, path_info, script_name); end
808
+
809
+ # The root of the directory hierarchy. Only requests for files and
810
+ # directories inside of the root directory are supported.
811
+ #
812
+ # source://rack//lib/rack/directory.rb#80
813
+ def root; end
814
+
815
+ # File::Stat for the given path, but return nil for missing/bad entries.
816
+ #
817
+ # source://rack//lib/rack/directory.rb#163
818
+ def stat(path); end
819
+ end
820
+
821
+ # source://rack//lib/rack/directory.rb#20
822
+ Rack::Directory::DIR_FILE = T.let(T.unsafe(nil), String)
823
+
824
+ # source://rack//lib/rack/directory.rb#43
825
+ Rack::Directory::DIR_PAGE_FOOTER = T.let(T.unsafe(nil), String)
826
+
827
+ # source://rack//lib/rack/directory.rb#21
828
+ Rack::Directory::DIR_PAGE_HEADER = T.let(T.unsafe(nil), String)
829
+
830
+ # Body class for directory entries, showing an index page with links
831
+ # to each file.
832
+ #
833
+ # source://rack//lib/rack/directory.rb#51
834
+ class Rack::Directory::DirectoryBody < ::Struct
835
+ # Yield strings for each part of the directory entry
836
+ #
837
+ # @yield [DIR_PAGE_HEADER % [ show_path, show_path ]]
838
+ #
839
+ # source://rack//lib/rack/directory.rb#53
840
+ def each; end
841
+
842
+ private
843
+
844
+ # Escape each element in the array of html strings.
845
+ #
846
+ # source://rack//lib/rack/directory.rb#73
847
+ def DIR_FILE_escape(htmls); end
848
+ end
849
+
850
+ # Stolen from Ramaze
851
+ #
852
+ # source://rack//lib/rack/directory.rb#189
853
+ Rack::Directory::FILESIZE_FORMAT = T.let(T.unsafe(nil), Array)
854
+
855
+ # source://rack//lib/rack/constants.rb#22
856
+ Rack::ETAG = T.let(T.unsafe(nil), String)
857
+
858
+ # Automatically sets the etag header on all String bodies.
859
+ #
860
+ # The etag header is skipped if etag or last-modified headers are sent or if
861
+ # a sendfile body (body.responds_to :to_path) is given (since such cases
862
+ # should be handled by apache/nginx).
863
+ #
864
+ # On initialization, you can pass two parameters: a cache-control directive
865
+ # used when etag is absent and a directive when it is present. The first
866
+ # defaults to nil, while the second defaults to "max-age=0, private, must-revalidate"
867
+ #
868
+ # source://rack//lib/rack/etag.rb#18
869
+ class Rack::ETag
870
+ # @return [ETag] a new instance of ETag
871
+ #
872
+ # source://rack//lib/rack/etag.rb#22
873
+ def initialize(app, no_cache_control = T.unsafe(nil), cache_control = T.unsafe(nil)); end
874
+
875
+ # source://rack//lib/rack/etag.rb#28
876
+ def call(env); end
877
+
878
+ private
879
+
880
+ # source://rack//lib/rack/etag.rb#58
881
+ def digest_body(body); end
882
+
883
+ # @return [Boolean]
884
+ #
885
+ # source://rack//lib/rack/etag.rb#50
886
+ def etag_status?(status); end
887
+
888
+ # @return [Boolean]
889
+ #
890
+ # source://rack//lib/rack/etag.rb#54
891
+ def skip_caching?(headers); end
892
+ end
893
+
894
+ # source://rack//lib/rack/etag.rb#20
895
+ Rack::ETag::DEFAULT_CACHE_CONTROL = T.let(T.unsafe(nil), String)
896
+
897
+ # source://rack//lib/rack/etag.rb#19
898
+ Rack::ETag::ETAG_STRING = T.let(T.unsafe(nil), String)
899
+
900
+ # source://rack//lib/rack/constants.rb#23
901
+ Rack::EXPIRES = T.let(T.unsafe(nil), String)
902
+
903
+ # This middleware provides hooks to certain places in the request /
904
+ # response lifecycle. This is so that middleware that don't need to filter
905
+ # the response data can safely leave it alone and not have to send messages
906
+ # down the traditional "rack stack".
907
+ #
908
+ # The events are:
909
+ #
910
+ # * on_start(request, response)
911
+ #
912
+ # This event is sent at the start of the request, before the next
913
+ # middleware in the chain is called. This method is called with a request
914
+ # object, and a response object. Right now, the response object is always
915
+ # nil, but in the future it may actually be a real response object.
916
+ #
917
+ # * on_commit(request, response)
918
+ #
919
+ # The response has been committed. The application has returned, but the
920
+ # response has not been sent to the webserver yet. This method is always
921
+ # called with a request object and the response object. The response
922
+ # object is constructed from the rack triple that the application returned.
923
+ # Changes may still be made to the response object at this point.
924
+ #
925
+ # * on_send(request, response)
926
+ #
927
+ # The webserver has started iterating over the response body and presumably
928
+ # has started sending data over the wire. This method is always called with
929
+ # a request object and the response object. The response object is
930
+ # constructed from the rack triple that the application returned. Changes
931
+ # SHOULD NOT be made to the response object as the webserver has already
932
+ # started sending data. Any mutations will likely result in an exception.
933
+ #
934
+ # * on_finish(request, response)
935
+ #
936
+ # The webserver has closed the response, and all data has been written to
937
+ # the response socket. The request and response object should both be
938
+ # read-only at this point. The body MAY NOT be available on the response
939
+ # object as it may have been flushed to the socket.
940
+ #
941
+ # * on_error(request, response, error)
942
+ #
943
+ # An exception has occurred in the application or an `on_commit` event.
944
+ # This method will get the request, the response (if available) and the
945
+ # exception that was raised.
946
+ #
947
+ # ## Order
948
+ #
949
+ # `on_start` is called on the handlers in the order that they were passed to
950
+ # the constructor. `on_commit`, on_send`, `on_finish`, and `on_error` are
951
+ # called in the reverse order. `on_finish` handlers are called inside an
952
+ # `ensure` block, so they are guaranteed to be called even if something
953
+ # raises an exception. If something raises an exception in a `on_finish`
954
+ # method, then nothing is guaranteed.
955
+ #
956
+ # source://rack//lib/rack/events.rb#61
957
+ class Rack::Events
958
+ # @return [Events] a new instance of Events
959
+ #
960
+ # source://rack//lib/rack/events.rb#106
961
+ def initialize(app, handlers); end
962
+
963
+ # source://rack//lib/rack/events.rb#111
964
+ def call(env); end
965
+
966
+ private
967
+
968
+ # source://rack//lib/rack/events.rb#149
969
+ def make_request(env); end
970
+
971
+ # source://rack//lib/rack/events.rb#153
972
+ def make_response(status, headers, body); end
973
+
974
+ # source://rack//lib/rack/events.rb#137
975
+ def on_commit(request, response); end
976
+
977
+ # source://rack//lib/rack/events.rb#133
978
+ def on_error(request, response, e); end
979
+
980
+ # source://rack//lib/rack/events.rb#145
981
+ def on_finish(request, response); end
982
+
983
+ # source://rack//lib/rack/events.rb#141
984
+ def on_start(request, response); end
985
+ end
986
+
987
+ # source://rack//lib/rack/events.rb#62
988
+ module Rack::Events::Abstract
989
+ # source://rack//lib/rack/events.rb#66
990
+ def on_commit(req, res); end
991
+
992
+ # source://rack//lib/rack/events.rb#75
993
+ def on_error(req, res, e); end
994
+
995
+ # source://rack//lib/rack/events.rb#72
996
+ def on_finish(req, res); end
997
+
998
+ # source://rack//lib/rack/events.rb#69
999
+ def on_send(req, res); end
1000
+
1001
+ # source://rack//lib/rack/events.rb#63
1002
+ def on_start(req, res); end
1003
+ end
1004
+
1005
+ # source://rack//lib/rack/events.rb#95
1006
+ class Rack::Events::BufferedResponse < ::Rack::Response::Raw
1007
+ # @return [BufferedResponse] a new instance of BufferedResponse
1008
+ #
1009
+ # source://rack//lib/rack/events.rb#98
1010
+ def initialize(status, headers, body); end
1011
+
1012
+ # Returns the value of attribute body.
1013
+ #
1014
+ # source://rack//lib/rack/events.rb#96
1015
+ def body; end
1016
+
1017
+ # source://rack//lib/rack/events.rb#103
1018
+ def to_a; end
1019
+ end
1020
+
1021
+ # source://rack//lib/rack/events.rb#79
1022
+ class Rack::Events::EventedBodyProxy < ::Rack::BodyProxy
1023
+ # @return [EventedBodyProxy] a new instance of EventedBodyProxy
1024
+ #
1025
+ # source://rack//lib/rack/events.rb#82
1026
+ def initialize(body, request, response, handlers, &block); end
1027
+
1028
+ # source://rack//lib/rack/events.rb#89
1029
+ def each; end
1030
+
1031
+ # Returns the value of attribute request.
1032
+ #
1033
+ # source://rack//lib/rack/events.rb#80
1034
+ def request; end
1035
+
1036
+ # Returns the value of attribute response.
1037
+ #
1038
+ # source://rack//lib/rack/events.rb#80
1039
+ def response; end
1040
+ end
1041
+
1042
+ # Rack::Files serves files below the +root+ directory given, according to the
1043
+ # path info of the Rack request.
1044
+ # e.g. when Rack::Files.new("/etc") is used, you can access 'passwd' file
1045
+ # as http://localhost:9292/passwd
1046
+ #
1047
+ # Handlers can detect if bodies are a Rack::Files, and use mechanisms
1048
+ # like sendfile on the +path+.
1049
+ #
1050
+ # source://rack//lib/rack/files.rb#20
1051
+ class Rack::Files
1052
+ # @return [Files] a new instance of Files
1053
+ #
1054
+ # source://rack//lib/rack/files.rb#27
1055
+ def initialize(root, headers = T.unsafe(nil), default_mime = T.unsafe(nil)); end
1056
+
1057
+ # source://rack//lib/rack/files.rb#34
1058
+ def call(env); end
1059
+
1060
+ # source://rack//lib/rack/files.rb#39
1061
+ def get(env); end
1062
+
1063
+ # Returns the value of attribute root.
1064
+ #
1065
+ # source://rack//lib/rack/files.rb#25
1066
+ def root; end
1067
+
1068
+ # source://rack//lib/rack/files.rb#68
1069
+ def serving(request, path); end
1070
+
1071
+ private
1072
+
1073
+ # source://rack//lib/rack/files.rb#190
1074
+ def fail(status, body, headers = T.unsafe(nil)); end
1075
+
1076
+ # source://rack//lib/rack/files.rb#209
1077
+ def filesize(path); end
1078
+
1079
+ # The MIME type for the contents of the file located at @path
1080
+ #
1081
+ # source://rack//lib/rack/files.rb#205
1082
+ def mime_type(path, default_mime); end
1083
+ end
1084
+
1085
+ # source://rack//lib/rack/files.rb#21
1086
+ Rack::Files::ALLOWED_VERBS = T.let(T.unsafe(nil), Array)
1087
+
1088
+ # source://rack//lib/rack/files.rb#22
1089
+ Rack::Files::ALLOW_HEADER = T.let(T.unsafe(nil), String)
1090
+
1091
+ # source://rack//lib/rack/files.rb#121
1092
+ class Rack::Files::BaseIterator
1093
+ # @return [BaseIterator] a new instance of BaseIterator
1094
+ #
1095
+ # source://rack//lib/rack/files.rb#124
1096
+ def initialize(path, ranges, options); end
1097
+
1098
+ # source://rack//lib/rack/files.rb#144
1099
+ def bytesize; end
1100
+
1101
+ # source://rack//lib/rack/files.rb#153
1102
+ def close; end
1103
+
1104
+ # source://rack//lib/rack/files.rb#130
1105
+ def each; end
1106
+
1107
+ # Returns the value of attribute options.
1108
+ #
1109
+ # source://rack//lib/rack/files.rb#122
1110
+ def options; end
1111
+
1112
+ # Returns the value of attribute path.
1113
+ #
1114
+ # source://rack//lib/rack/files.rb#122
1115
+ def path; end
1116
+
1117
+ # Returns the value of attribute ranges.
1118
+ #
1119
+ # source://rack//lib/rack/files.rb#122
1120
+ def ranges; end
1121
+
1122
+ private
1123
+
1124
+ # source://rack//lib/rack/files.rb#171
1125
+ def each_range_part(file, range); end
1126
+
1127
+ # @return [Boolean]
1128
+ #
1129
+ # source://rack//lib/rack/files.rb#157
1130
+ def multipart?; end
1131
+
1132
+ # source://rack//lib/rack/files.rb#161
1133
+ def multipart_heading(range); end
1134
+ end
1135
+
1136
+ # source://rack//lib/rack/files.rb#184
1137
+ class Rack::Files::Iterator < ::Rack::Files::BaseIterator
1138
+ # source://rack//lib/rack/files.rb#122
1139
+ def to_path; end
1140
+ end
1141
+
1142
+ # source://rack//lib/rack/files.rb#23
1143
+ Rack::Files::MULTIPART_BOUNDARY = T.let(T.unsafe(nil), String)
1144
+
1145
+ # Rack::ForwardRequest gets caught by Rack::Recursive and redirects
1146
+ # the current request to the app at +url+.
1147
+ #
1148
+ # raise ForwardRequest.new("/not-found")
1149
+ #
1150
+ # source://rack//lib/rack/recursive.rb#14
1151
+ class Rack::ForwardRequest < ::Exception
1152
+ # @return [ForwardRequest] a new instance of ForwardRequest
1153
+ #
1154
+ # source://rack//lib/rack/recursive.rb#17
1155
+ def initialize(url, env = T.unsafe(nil)); end
1156
+
1157
+ # Returns the value of attribute env.
1158
+ #
1159
+ # source://rack//lib/rack/recursive.rb#15
1160
+ def env; end
1161
+
1162
+ # Returns the value of attribute url.
1163
+ #
1164
+ # source://rack//lib/rack/recursive.rb#15
1165
+ def url; end
1166
+ end
1167
+
1168
+ # HTTP method verbs
1169
+ #
1170
+ # source://rack//lib/rack/constants.rb#28
1171
+ Rack::GET = T.let(T.unsafe(nil), String)
1172
+
1173
+ # source://rack//lib/rack/constants.rb#33
1174
+ Rack::HEAD = T.let(T.unsafe(nil), String)
1175
+
1176
+ # source://rack//lib/rack/constants.rb#7
1177
+ Rack::HTTPS = T.let(T.unsafe(nil), String)
1178
+
1179
+ # source://rack//lib/rack/constants.rb#16
1180
+ Rack::HTTP_COOKIE = T.let(T.unsafe(nil), String)
1181
+
1182
+ # Request env keys
1183
+ #
1184
+ # source://rack//lib/rack/constants.rb#5
1185
+ Rack::HTTP_HOST = T.let(T.unsafe(nil), String)
1186
+
1187
+ # source://rack//lib/rack/constants.rb#6
1188
+ Rack::HTTP_PORT = T.let(T.unsafe(nil), String)
1189
+
1190
+ # Rack::Head returns an empty body for all HEAD requests. It leaves
1191
+ # all other requests unchanged.
1192
+ #
1193
+ # source://rack//lib/rack/head.rb#9
1194
+ class Rack::Head
1195
+ # @return [Head] a new instance of Head
1196
+ #
1197
+ # source://rack//lib/rack/head.rb#10
1198
+ def initialize(app); end
1199
+
1200
+ # source://rack//lib/rack/head.rb#14
1201
+ def call(env); end
1202
+ end
1203
+
1204
+ # Rack::Headers is a Hash subclass that downcases all keys. It's designed
1205
+ # to be used by rack applications that don't implement the Rack 3 SPEC
1206
+ # (by using non-lowercase response header keys), automatically handling
1207
+ # the downcasing of keys.
1208
+ #
1209
+ # source://rack//lib/rack/headers.rb#8
1210
+ class Rack::Headers < ::Hash
1211
+ # source://rack//lib/rack/headers.rb#110
1212
+ def [](key); end
1213
+
1214
+ # source://rack//lib/rack/headers.rb#114
1215
+ def []=(key, value); end
1216
+
1217
+ # source://rack//lib/rack/headers.rb#119
1218
+ def assoc(key); end
1219
+
1220
+ # @raise [TypeError]
1221
+ #
1222
+ # source://rack//lib/rack/headers.rb#123
1223
+ def compare_by_identity; end
1224
+
1225
+ # source://rack//lib/rack/headers.rb#127
1226
+ def delete(key); end
1227
+
1228
+ # source://rack//lib/rack/headers.rb#131
1229
+ def dig(key, *a); end
1230
+
1231
+ # :nocov:
1232
+ #
1233
+ # source://rack//lib/rack/headers.rb#227
1234
+ def except(*a); end
1235
+
1236
+ # source://rack//lib/rack/headers.rb#135
1237
+ def fetch(key, *default, &block); end
1238
+
1239
+ # source://rack//lib/rack/headers.rb#140
1240
+ def fetch_values(*a); end
1241
+
1242
+ # @return [Boolean]
1243
+ #
1244
+ # source://rack//lib/rack/headers.rb#144
1245
+ def has_key?(key); end
1246
+
1247
+ # @return [Boolean]
1248
+ #
1249
+ # source://rack//lib/rack/headers.rb#144
1250
+ def include?(key); end
1251
+
1252
+ # source://rack//lib/rack/headers.rb#151
1253
+ def invert; end
1254
+
1255
+ # @return [Boolean]
1256
+ #
1257
+ # source://rack//lib/rack/headers.rb#144
1258
+ def key?(key); end
1259
+
1260
+ # @return [Boolean]
1261
+ #
1262
+ # source://rack//lib/rack/headers.rb#144
1263
+ def member?(key); end
1264
+
1265
+ # source://rack//lib/rack/headers.rb#157
1266
+ def merge(hash, &block); end
1267
+
1268
+ # source://rack//lib/rack/headers.rb#186
1269
+ def merge!(hash, &block); end
1270
+
1271
+ # source://rack//lib/rack/headers.rb#161
1272
+ def reject(&block); end
1273
+
1274
+ # source://rack//lib/rack/headers.rb#167
1275
+ def replace(hash); end
1276
+
1277
+ # source://rack//lib/rack/headers.rb#172
1278
+ def select(&block); end
1279
+
1280
+ # :nocov:
1281
+ #
1282
+ # source://rack//lib/rack/headers.rb#205
1283
+ def slice(*a); end
1284
+
1285
+ # source://rack//lib/rack/headers.rb#114
1286
+ def store(key, value); end
1287
+
1288
+ # source://rack//lib/rack/headers.rb#178
1289
+ def to_proc; end
1290
+
1291
+ # source://rack//lib/rack/headers.rb#211
1292
+ def transform_keys(&block); end
1293
+
1294
+ # source://rack//lib/rack/headers.rb#215
1295
+ def transform_keys!; end
1296
+
1297
+ # source://rack//lib/rack/headers.rb#182
1298
+ def transform_values(&block); end
1299
+
1300
+ # source://rack//lib/rack/headers.rb#186
1301
+ def update(hash, &block); end
1302
+
1303
+ # source://rack//lib/rack/headers.rb#198
1304
+ def values_at(*keys); end
1305
+
1306
+ private
1307
+
1308
+ # source://rack//lib/rack/headers.rb#234
1309
+ def downcase_key(key); end
1310
+
1311
+ class << self
1312
+ # source://rack//lib/rack/headers.rb#91
1313
+ def [](*items); end
1314
+ end
1315
+ end
1316
+
1317
+ # source://rack//lib/rack/headers.rb#9
1318
+ Rack::Headers::KNOWN_HEADERS = T.let(T.unsafe(nil), Hash)
1319
+
1320
+ # source://rack//lib/rack/constants.rb#36
1321
+ Rack::LINK = T.let(T.unsafe(nil), String)
1322
+
1323
+ # Rack::Lint validates your application and the requests and
1324
+ # responses according to the Rack spec.
1325
+ #
1326
+ # source://rack//lib/rack/lint.rb#13
1327
+ class Rack::Lint
1328
+ # @return [Lint] a new instance of Lint
1329
+ #
1330
+ # source://rack//lib/rack/lint.rb#19
1331
+ def initialize(app); end
1332
+
1333
+ # AUTHORS: n.b. The trailing whitespace between paragraphs is important and
1334
+ # should not be removed. The whitespace creates paragraphs in the RDoc
1335
+ # output.
1336
+ #
1337
+ # This specification aims to formalize the Rack protocol. You
1338
+ # can (and should) use Rack::Lint to enforce it.
1339
+ #
1340
+ # When you develop middleware, be sure to add a Lint before and
1341
+ # after to catch all mistakes.
1342
+ #
1343
+ # = Rack applications
1344
+ #
1345
+ # A Rack application is a Ruby object (not a class) that
1346
+ # responds to +call+.
1347
+ #
1348
+ # source://rack//lib/rack/lint.rb#40
1349
+ def call(env = T.unsafe(nil)); end
1350
+ end
1351
+
1352
+ # :stopdoc:
1353
+ #
1354
+ # source://rack//lib/rack/lint.rb#25
1355
+ class Rack::Lint::LintError < ::RuntimeError; end
1356
+
1357
+ # source://rack//lib/rack/lint.rb#15
1358
+ Rack::Lint::REQUEST_PATH_ABSOLUTE_FORM = T.let(T.unsafe(nil), Regexp)
1359
+
1360
+ # source://rack//lib/rack/lint.rb#17
1361
+ Rack::Lint::REQUEST_PATH_ASTERISK_FORM = T.let(T.unsafe(nil), String)
1362
+
1363
+ # source://rack//lib/rack/lint.rb#16
1364
+ Rack::Lint::REQUEST_PATH_AUTHORITY_FORM = T.let(T.unsafe(nil), Regexp)
1365
+
1366
+ # source://rack//lib/rack/lint.rb#14
1367
+ Rack::Lint::REQUEST_PATH_ORIGIN_FORM = T.let(T.unsafe(nil), Regexp)
1368
+
1369
+ # source://rack//lib/rack/lint.rb#44
1370
+ class Rack::Lint::Wrapper
1371
+ # @return [Wrapper] a new instance of Wrapper
1372
+ #
1373
+ # source://rack//lib/rack/lint.rb#45
1374
+ def initialize(app, env); end
1375
+
1376
+ # ==== Streaming Body
1377
+ #
1378
+ # @raise [LintError]
1379
+ #
1380
+ # source://rack//lib/rack/lint.rb#939
1381
+ def call(stream); end
1382
+
1383
+ # ==== The +content-length+ Header
1384
+ #
1385
+ # source://rack//lib/rack/lint.rb#757
1386
+ def check_content_length_header(status, headers); end
1387
+
1388
+ # ==== The +content-type+ Header
1389
+ #
1390
+ # source://rack//lib/rack/lint.rb#741
1391
+ def check_content_type_header(status, headers); end
1392
+
1393
+ # === Early Hints
1394
+ #
1395
+ # The application or any middleware may call the <tt>rack.early_hints</tt>
1396
+ # with an object which would be valid as the headers of a Rack response.
1397
+ #
1398
+ # source://rack//lib/rack/lint.rb#657
1399
+ def check_early_hints(env); end
1400
+
1401
+ # == The Environment
1402
+ #
1403
+ # @raise [LintError]
1404
+ #
1405
+ # source://rack//lib/rack/lint.rb#101
1406
+ def check_environment(env); end
1407
+
1408
+ # === The Error Stream
1409
+ #
1410
+ # source://rack//lib/rack/lint.rb#531
1411
+ def check_error_stream(error); end
1412
+
1413
+ # source://rack//lib/rack/lint.rb#731
1414
+ def check_header_value(key, value); end
1415
+
1416
+ # === The Headers
1417
+ #
1418
+ # source://rack//lib/rack/lint.rb#691
1419
+ def check_headers(headers); end
1420
+
1421
+ # === Hijacking
1422
+ #
1423
+ # The hijacking interfaces provides a means for an application to take
1424
+ # control of the HTTP connection. There are two distinct hijack
1425
+ # interfaces: full hijacking where the application takes over the raw
1426
+ # connection, and partial hijacking where the application takes over
1427
+ # just the response body stream. In both cases, the application is
1428
+ # responsible for closing the hijacked stream.
1429
+ #
1430
+ # Full hijacking only works with HTTP/1. Partial hijacking is functionally
1431
+ # equivalent to streaming bodies, and is still optionally supported for
1432
+ # backwards compatibility with older Rack versions.
1433
+ #
1434
+ # ==== Full Hijack
1435
+ #
1436
+ # Full hijack is used to completely take over an HTTP/1 connection. It
1437
+ # occurs before any headers are written and causes the request to
1438
+ # ignores any response generated by the application.
1439
+ #
1440
+ # It is intended to be used when applications need access to raw HTTP/1
1441
+ # connection.
1442
+ #
1443
+ # source://rack//lib/rack/lint.rb#591
1444
+ def check_hijack(env); end
1445
+
1446
+ # ==== Partial Hijack
1447
+ #
1448
+ # Partial hijack is used for bi-directional streaming of the request and
1449
+ # response body. It occurs after the status and headers are written by
1450
+ # the server and causes the server to ignore the Body of the response.
1451
+ #
1452
+ # It is intended to be used when applications need bi-directional
1453
+ # streaming.
1454
+ #
1455
+ # source://rack//lib/rack/lint.rb#619
1456
+ def check_hijack_response(headers, env); end
1457
+
1458
+ # === The Input Stream
1459
+ #
1460
+ # The input stream is an IO-like object which contains the raw HTTP
1461
+ # POST data.
1462
+ #
1463
+ # source://rack//lib/rack/lint.rb#427
1464
+ def check_input_stream(input); end
1465
+
1466
+ # ==== The +rack.protocol+ Header
1467
+ #
1468
+ # source://rack//lib/rack/lint.rb#785
1469
+ def check_rack_protocol_header(status, headers); end
1470
+
1471
+ # == The Response
1472
+ #
1473
+ # === The Status
1474
+ #
1475
+ # source://rack//lib/rack/lint.rb#680
1476
+ def check_status(status); end
1477
+
1478
+ # Setting this value informs the server that it should perform a
1479
+ # connection upgrade. In HTTP/1, this is done using the +upgrade+
1480
+ # header. In HTTP/2, this is done by accepting the request.
1481
+ #
1482
+ # === The Body
1483
+ #
1484
+ # The Body is typically an +Array+ of +String+ instances, an enumerable
1485
+ # that yields +String+ instances, a +Proc+ instance, or a File-like
1486
+ # object.
1487
+ #
1488
+ # The Body must respond to +each+ or +call+. It may optionally respond
1489
+ # to +to_path+ or +to_ary+. A Body that responds to +each+ is considered
1490
+ # to be an Enumerable Body. A Body that responds to +call+ is considered
1491
+ # to be a Streaming Body.
1492
+ #
1493
+ # A Body that responds to both +each+ and +call+ must be treated as an
1494
+ # Enumerable Body, not a Streaming Body. If it responds to +each+, you
1495
+ # must call +each+ and not +call+. If the Body doesn't respond to
1496
+ # +each+, then you can assume it responds to +call+.
1497
+ #
1498
+ # The Body must either be consumed or returned. The Body is consumed by
1499
+ # optionally calling either +each+ or +call+.
1500
+ # Then, if the Body responds to +close+, it must be called to release
1501
+ # any resources associated with the generation of the body.
1502
+ # In other words, +close+ must always be called at least once; typically
1503
+ # after the web server has sent the response to the client, but also in
1504
+ # cases where the Rack application makes internal/virtual requests and
1505
+ # discards the response.
1506
+ #
1507
+ # source://rack//lib/rack/lint.rb#831
1508
+ def close; end
1509
+
1510
+ # ==== Enumerable Body
1511
+ #
1512
+ # @raise [LintError]
1513
+ #
1514
+ # source://rack//lib/rack/lint.rb#865
1515
+ def each; end
1516
+
1517
+ # @return [Boolean]
1518
+ #
1519
+ # source://rack//lib/rack/lint.rb#910
1520
+ def respond_to?(name, *_arg1); end
1521
+
1522
+ # @raise [LintError]
1523
+ #
1524
+ # source://rack//lib/rack/lint.rb#60
1525
+ def response; end
1526
+
1527
+ # If the Body responds to +to_ary+, it must return an +Array+ whose
1528
+ # contents are identical to that produced by calling +each+.
1529
+ # Middleware may call +to_ary+ directly on the Body and return a new
1530
+ # Body in its place. In other words, middleware can only process the
1531
+ # Body directly if it responds to +to_ary+. If the Body responds to both
1532
+ # +to_ary+ and +close+, its implementation of +to_ary+ must call
1533
+ # +close+.
1534
+ #
1535
+ # source://rack//lib/rack/lint.rb#926
1536
+ def to_ary; end
1537
+
1538
+ # source://rack//lib/rack/lint.rb#906
1539
+ def to_path; end
1540
+
1541
+ # source://rack//lib/rack/lint.rb#770
1542
+ def verify_content_length(size); end
1543
+
1544
+ # source://rack//lib/rack/lint.rb#847
1545
+ def verify_to_path; end
1546
+ end
1547
+
1548
+ # source://rack//lib/rack/lint.rb#904
1549
+ Rack::Lint::Wrapper::BODY_METHODS = T.let(T.unsafe(nil), Hash)
1550
+
1551
+ # source://rack//lib/rack/lint.rb#540
1552
+ class Rack::Lint::Wrapper::ErrorWrapper
1553
+ # @return [ErrorWrapper] a new instance of ErrorWrapper
1554
+ #
1555
+ # source://rack//lib/rack/lint.rb#541
1556
+ def initialize(error); end
1557
+
1558
+ # * +close+ must never be called on the error stream.
1559
+ #
1560
+ # @raise [LintError]
1561
+ #
1562
+ # source://rack//lib/rack/lint.rb#563
1563
+ def close(*args); end
1564
+
1565
+ # * +flush+ must be called without arguments and must be called
1566
+ # in order to make the error appear for sure.
1567
+ #
1568
+ # source://rack//lib/rack/lint.rb#558
1569
+ def flush; end
1570
+
1571
+ # * +puts+ must be called with a single argument that responds to +to_s+.
1572
+ #
1573
+ # source://rack//lib/rack/lint.rb#546
1574
+ def puts(str); end
1575
+
1576
+ # * +write+ must be called with a single argument that is a String.
1577
+ #
1578
+ # @raise [LintError]
1579
+ #
1580
+ # source://rack//lib/rack/lint.rb#551
1581
+ def write(str); end
1582
+ end
1583
+
1584
+ # source://rack//lib/rack/lint.rb#445
1585
+ class Rack::Lint::Wrapper::InputWrapper
1586
+ # @return [InputWrapper] a new instance of InputWrapper
1587
+ #
1588
+ # source://rack//lib/rack/lint.rb#446
1589
+ def initialize(input); end
1590
+
1591
+ # * +close+ can be called on the input stream to indicate that
1592
+ # any remaining input is not needed.
1593
+ #
1594
+ # source://rack//lib/rack/lint.rb#523
1595
+ def close(*args); end
1596
+
1597
+ # * +each+ must be called without arguments and only yield Strings.
1598
+ #
1599
+ # @raise [LintError]
1600
+ #
1601
+ # source://rack//lib/rack/lint.rb#511
1602
+ def each(*args); end
1603
+
1604
+ # * +gets+ must be called without arguments and return a string,
1605
+ # or +nil+ on EOF.
1606
+ #
1607
+ # @raise [LintError]
1608
+ #
1609
+ # source://rack//lib/rack/lint.rb#452
1610
+ def gets(*args); end
1611
+
1612
+ # * +read+ behaves like <tt>IO#read</tt>.
1613
+ # Its signature is <tt>read([length, [buffer]])</tt>.
1614
+ #
1615
+ # If given, +length+ must be a non-negative Integer (>= 0) or +nil+,
1616
+ # and +buffer+ must be a String and may not be nil.
1617
+ #
1618
+ # If +length+ is given and not nil, then this method reads at most
1619
+ # +length+ bytes from the input stream.
1620
+ #
1621
+ # If +length+ is not given or nil, then this method reads
1622
+ # all data until EOF.
1623
+ #
1624
+ # When EOF is reached, this method returns nil if +length+ is given
1625
+ # and not nil, or "" if +length+ is not given or is nil.
1626
+ #
1627
+ # If +buffer+ is given, then the read data will be placed
1628
+ # into +buffer+ instead of a newly created String object.
1629
+ #
1630
+ # source://rack//lib/rack/lint.rb#478
1631
+ def read(*args); end
1632
+ end
1633
+
1634
+ # source://rack//lib/rack/lint.rb#959
1635
+ class Rack::Lint::Wrapper::StreamWrapper
1636
+ extend ::Forwardable
1637
+
1638
+ # @return [StreamWrapper] a new instance of StreamWrapper
1639
+ #
1640
+ # source://rack//lib/rack/lint.rb#974
1641
+ def initialize(stream); end
1642
+
1643
+ # source://forwardable/1.3.3/forwardable.rb#231
1644
+ def <<(*args, **_arg1, &block); end
1645
+
1646
+ # source://forwardable/1.3.3/forwardable.rb#231
1647
+ def close(*args, **_arg1, &block); end
1648
+
1649
+ # source://forwardable/1.3.3/forwardable.rb#231
1650
+ def close_read(*args, **_arg1, &block); end
1651
+
1652
+ # source://forwardable/1.3.3/forwardable.rb#231
1653
+ def close_write(*args, **_arg1, &block); end
1654
+
1655
+ # source://forwardable/1.3.3/forwardable.rb#231
1656
+ def closed?(*args, **_arg1, &block); end
1657
+
1658
+ # source://forwardable/1.3.3/forwardable.rb#231
1659
+ def flush(*args, **_arg1, &block); end
1660
+
1661
+ # source://forwardable/1.3.3/forwardable.rb#231
1662
+ def read(*args, **_arg1, &block); end
1663
+
1664
+ # source://forwardable/1.3.3/forwardable.rb#231
1665
+ def write(*args, **_arg1, &block); end
1666
+ end
1667
+
1668
+ # The semantics of these IO methods must be a best effort match to
1669
+ # those of a normal Ruby IO or Socket object, using standard arguments
1670
+ # and raising standard exceptions. Servers are encouraged to simply
1671
+ # pass on real IO objects, although it is recognized that this approach
1672
+ # is not directly compatible with HTTP/2.
1673
+ #
1674
+ # source://rack//lib/rack/lint.rb#967
1675
+ Rack::Lint::Wrapper::StreamWrapper::REQUIRED_METHODS = T.let(T.unsafe(nil), Array)
1676
+
1677
+ # Rack::Lock locks every request inside a mutex, so that every request
1678
+ # will effectively be executed synchronously.
1679
+ #
1680
+ # source://rack//lib/rack/lock.rb#8
1681
+ class Rack::Lock
1682
+ # @return [Lock] a new instance of Lock
1683
+ #
1684
+ # source://rack//lib/rack/lock.rb#9
1685
+ def initialize(app, mutex = T.unsafe(nil)); end
1686
+
1687
+ # source://rack//lib/rack/lock.rb#13
1688
+ def call(env); end
1689
+
1690
+ private
1691
+
1692
+ # source://rack//lib/rack/lock.rb#25
1693
+ def unlock; end
1694
+ end
1695
+
1696
+ # Sets up rack.logger to write to rack.errors stream
1697
+ #
1698
+ # source://rack//lib/rack/logger.rb#10
1699
+ class Rack::Logger
1700
+ # @return [Logger] a new instance of Logger
1701
+ #
1702
+ # source://rack//lib/rack/logger.rb#11
1703
+ def initialize(app, level = T.unsafe(nil)); end
1704
+
1705
+ # source://rack//lib/rack/logger.rb#15
1706
+ def call(env); end
1707
+ end
1708
+
1709
+ # Rack::MediaType parse media type and parameters out of content_type string
1710
+ #
1711
+ # source://rack//lib/rack/media_type.rb#6
1712
+ class Rack::MediaType
1713
+ class << self
1714
+ # The media type parameters provided in CONTENT_TYPE as a Hash, or
1715
+ # an empty Hash if no CONTENT_TYPE or media-type parameters were
1716
+ # provided. e.g., when the CONTENT_TYPE is "text/plain;charset=utf-8",
1717
+ # this method responds with the following Hash:
1718
+ # { 'charset' => 'utf-8' }
1719
+ #
1720
+ # This will pass back parameters with empty strings in the hash if they
1721
+ # lack a value (e.g., "text/plain;charset=" will return { 'charset' => '' },
1722
+ # and "text/plain;charset" will return { 'charset' => '' }, similarly to
1723
+ # the query params parser (barring the latter case, which returns nil instead)).
1724
+ #
1725
+ # source://rack//lib/rack/media_type.rb#35
1726
+ def params(content_type); end
1727
+
1728
+ # The media type (type/subtype) portion of the CONTENT_TYPE header
1729
+ # without any media type parameters. e.g., when CONTENT_TYPE is
1730
+ # "text/plain;charset=utf-8", the media-type is "text/plain".
1731
+ #
1732
+ # For more information on the use of media types in HTTP, see:
1733
+ # http://www.w3.org/Protocols/rfc2616/rfc2616-sec3.html#sec3.7
1734
+ #
1735
+ # source://rack//lib/rack/media_type.rb#16
1736
+ def type(content_type); end
1737
+
1738
+ private
1739
+
1740
+ # source://rack//lib/rack/media_type.rb#48
1741
+ def strip_doublequotes(str); end
1742
+ end
1743
+ end
1744
+
1745
+ # source://rack//lib/rack/media_type.rb#7
1746
+ Rack::MediaType::SPLIT_PATTERN = T.let(T.unsafe(nil), Regexp)
1747
+
1748
+ # source://rack//lib/rack/method_override.rb#8
1749
+ class Rack::MethodOverride
1750
+ # @return [MethodOverride] a new instance of MethodOverride
1751
+ #
1752
+ # source://rack//lib/rack/method_override.rb#15
1753
+ def initialize(app); end
1754
+
1755
+ # source://rack//lib/rack/method_override.rb#19
1756
+ def call(env); end
1757
+
1758
+ # source://rack//lib/rack/method_override.rb#31
1759
+ def method_override(env); end
1760
+
1761
+ private
1762
+
1763
+ # source://rack//lib/rack/method_override.rb#44
1764
+ def allowed_methods; end
1765
+
1766
+ # source://rack//lib/rack/method_override.rb#48
1767
+ def method_override_param(req); end
1768
+ end
1769
+
1770
+ # source://rack//lib/rack/method_override.rb#13
1771
+ Rack::MethodOverride::ALLOWED_METHODS = T.let(T.unsafe(nil), Array)
1772
+
1773
+ # source://rack//lib/rack/method_override.rb#9
1774
+ Rack::MethodOverride::HTTP_METHODS = T.let(T.unsafe(nil), Array)
1775
+
1776
+ # source://rack//lib/rack/method_override.rb#12
1777
+ Rack::MethodOverride::HTTP_METHOD_OVERRIDE_HEADER = T.let(T.unsafe(nil), String)
1778
+
1779
+ # source://rack//lib/rack/method_override.rb#11
1780
+ Rack::MethodOverride::METHOD_OVERRIDE_PARAM_KEY = T.let(T.unsafe(nil), String)
1781
+
1782
+ # source://rack//lib/rack/mime.rb#4
1783
+ module Rack::Mime
1784
+ private
1785
+
1786
+ # Returns true if the given value is a mime match for the given mime match
1787
+ # specification, false otherwise.
1788
+ #
1789
+ # Rack::Mime.match?('text/html', 'text/*') => true
1790
+ # Rack::Mime.match?('text/plain', '*') => true
1791
+ # Rack::Mime.match?('text/html', 'application/json') => false
1792
+ #
1793
+ # @return [Boolean]
1794
+ #
1795
+ # source://rack//lib/rack/mime.rb#30
1796
+ def match?(value, matcher); end
1797
+
1798
+ # Returns String with mime type if found, otherwise use +fallback+.
1799
+ # +ext+ should be filename extension in the '.ext' format that
1800
+ # File.extname(file) returns.
1801
+ # +fallback+ may be any object
1802
+ #
1803
+ # Also see the documentation for MIME_TYPES
1804
+ #
1805
+ # Usage:
1806
+ # Rack::Mime.mime_type('.foo')
1807
+ #
1808
+ # This is a shortcut for:
1809
+ # Rack::Mime::MIME_TYPES.fetch('.foo', 'application/octet-stream')
1810
+ #
1811
+ # source://rack//lib/rack/mime.rb#18
1812
+ def mime_type(ext, fallback = T.unsafe(nil)); end
1813
+
1814
+ class << self
1815
+ # Returns true if the given value is a mime match for the given mime match
1816
+ # specification, false otherwise.
1817
+ #
1818
+ # Rack::Mime.match?('text/html', 'text/*') => true
1819
+ # Rack::Mime.match?('text/plain', '*') => true
1820
+ # Rack::Mime.match?('text/html', 'application/json') => false
1821
+ #
1822
+ # @return [Boolean]
1823
+ #
1824
+ # source://rack//lib/rack/mime.rb#30
1825
+ def match?(value, matcher); end
1826
+
1827
+ # Returns String with mime type if found, otherwise use +fallback+.
1828
+ # +ext+ should be filename extension in the '.ext' format that
1829
+ # File.extname(file) returns.
1830
+ # +fallback+ may be any object
1831
+ #
1832
+ # Also see the documentation for MIME_TYPES
1833
+ #
1834
+ # Usage:
1835
+ # Rack::Mime.mime_type('.foo')
1836
+ #
1837
+ # This is a shortcut for:
1838
+ # Rack::Mime::MIME_TYPES.fetch('.foo', 'application/octet-stream')
1839
+ #
1840
+ # source://rack//lib/rack/mime.rb#18
1841
+ def mime_type(ext, fallback = T.unsafe(nil)); end
1842
+ end
1843
+ end
1844
+
1845
+ # List of most common mime-types, selected various sources
1846
+ # according to their usefulness in a webserving scope for Ruby
1847
+ # users.
1848
+ #
1849
+ # To amend this list with your local mime.types list you can use:
1850
+ #
1851
+ # require 'webrick/httputils'
1852
+ # list = WEBrick::HTTPUtils.load_mime_types('/etc/mime.types')
1853
+ # Rack::Mime::MIME_TYPES.merge!(list)
1854
+ #
1855
+ # N.B. On Ubuntu the mime.types file does not include the leading period, so
1856
+ # users may need to modify the data before merging into the hash.
1857
+ #
1858
+ # source://rack//lib/rack/mime.rb#51
1859
+ Rack::Mime::MIME_TYPES = T.let(T.unsafe(nil), Hash)
1860
+
1861
+ # Rack::MockRequest helps testing your Rack application without
1862
+ # actually using HTTP.
1863
+ #
1864
+ # After performing a request on a URL with get/post/put/patch/delete, it
1865
+ # returns a MockResponse with useful helper methods for effective
1866
+ # testing.
1867
+ #
1868
+ # You can pass a hash with additional configuration to the
1869
+ # get/post/put/patch/delete.
1870
+ # <tt>:input</tt>:: A String or IO-like to be used as rack.input.
1871
+ # <tt>:fatal</tt>:: Raise a FatalWarning if the app writes to rack.errors.
1872
+ # <tt>:lint</tt>:: If true, wrap the application in a Rack::Lint.
1873
+ #
1874
+ # source://rack//lib/rack/mock_request.rb#23
1875
+ class Rack::MockRequest
1876
+ # @return [MockRequest] a new instance of MockRequest
1877
+ #
1878
+ # source://rack//lib/rack/mock_request.rb#44
1879
+ def initialize(app); end
1880
+
1881
+ # Make a DELETE request and return a MockResponse. See #request.
1882
+ #
1883
+ # source://rack//lib/rack/mock_request.rb#57
1884
+ def delete(uri, opts = T.unsafe(nil)); end
1885
+
1886
+ # Make a GET request and return a MockResponse. See #request.
1887
+ #
1888
+ # source://rack//lib/rack/mock_request.rb#49
1889
+ def get(uri, opts = T.unsafe(nil)); end
1890
+
1891
+ # Make a HEAD request and return a MockResponse. See #request.
1892
+ #
1893
+ # source://rack//lib/rack/mock_request.rb#59
1894
+ def head(uri, opts = T.unsafe(nil)); end
1895
+
1896
+ # Make an OPTIONS request and return a MockResponse. See #request.
1897
+ #
1898
+ # source://rack//lib/rack/mock_request.rb#61
1899
+ def options(uri, opts = T.unsafe(nil)); end
1900
+
1901
+ # Make a PATCH request and return a MockResponse. See #request.
1902
+ #
1903
+ # source://rack//lib/rack/mock_request.rb#55
1904
+ def patch(uri, opts = T.unsafe(nil)); end
1905
+
1906
+ # Make a POST request and return a MockResponse. See #request.
1907
+ #
1908
+ # source://rack//lib/rack/mock_request.rb#51
1909
+ def post(uri, opts = T.unsafe(nil)); end
1910
+
1911
+ # Make a PUT request and return a MockResponse. See #request.
1912
+ #
1913
+ # source://rack//lib/rack/mock_request.rb#53
1914
+ def put(uri, opts = T.unsafe(nil)); end
1915
+
1916
+ # Make a request using the given request method for the given
1917
+ # uri to the rack application and return a MockResponse.
1918
+ # Options given are passed to MockRequest.env_for.
1919
+ #
1920
+ # source://rack//lib/rack/mock_request.rb#66
1921
+ def request(method = T.unsafe(nil), uri = T.unsafe(nil), opts = T.unsafe(nil)); end
1922
+
1923
+ class << self
1924
+ # Return the Rack environment used for a request to +uri+.
1925
+ # All options that are strings are added to the returned environment.
1926
+ # Options:
1927
+ # :fatal :: Whether to raise an exception if request outputs to rack.errors
1928
+ # :input :: The rack.input to set
1929
+ # :http_version :: The SERVER_PROTOCOL to set
1930
+ # :method :: The HTTP request method to use
1931
+ # :params :: The params to use
1932
+ # :script_name :: The SCRIPT_NAME to set
1933
+ #
1934
+ # source://rack//lib/rack/mock_request.rb#98
1935
+ def env_for(uri = T.unsafe(nil), opts = T.unsafe(nil)); end
1936
+
1937
+ # For historical reasons, we're pinning to RFC 2396.
1938
+ # URI::Parser = URI::RFC2396_Parser
1939
+ #
1940
+ # source://rack//lib/rack/mock_request.rb#84
1941
+ def parse_uri_rfc2396(uri); end
1942
+ end
1943
+ end
1944
+
1945
+ # source://rack//lib/rack/mock_request.rb#27
1946
+ class Rack::MockRequest::FatalWarner
1947
+ # source://rack//lib/rack/mock_request.rb#36
1948
+ def flush; end
1949
+
1950
+ # @raise [FatalWarning]
1951
+ #
1952
+ # source://rack//lib/rack/mock_request.rb#28
1953
+ def puts(warning); end
1954
+
1955
+ # source://rack//lib/rack/mock_request.rb#39
1956
+ def string; end
1957
+
1958
+ # @raise [FatalWarning]
1959
+ #
1960
+ # source://rack//lib/rack/mock_request.rb#32
1961
+ def write(warning); end
1962
+ end
1963
+
1964
+ # source://rack//lib/rack/mock_request.rb#24
1965
+ class Rack::MockRequest::FatalWarning < ::RuntimeError; end
1966
+
1967
+ # Rack::MockResponse provides useful helpers for testing your apps.
1968
+ # Usually, you don't create the MockResponse on your own, but use
1969
+ # MockRequest.
1970
+ #
1971
+ # source://rack//lib/rack/mock_response.rb#13
1972
+ class Rack::MockResponse < ::Rack::Response
1973
+ # @return [MockResponse] a new instance of MockResponse
1974
+ #
1975
+ # source://rack//lib/rack/mock_response.rb#24
1976
+ def initialize(status, headers, body, errors = T.unsafe(nil)); end
1977
+
1978
+ # source://rack//lib/rack/mock_response.rb#39
1979
+ def =~(other); end
1980
+
1981
+ # source://rack//lib/rack/mock_response.rb#47
1982
+ def body; end
1983
+
1984
+ # source://rack//lib/rack/mock_response.rb#73
1985
+ def cookie(name); end
1986
+
1987
+ # Headers
1988
+ #
1989
+ # source://rack//lib/rack/mock_response.rb#19
1990
+ def cookies; end
1991
+
1992
+ # @return [Boolean]
1993
+ #
1994
+ # source://rack//lib/rack/mock_response.rb#69
1995
+ def empty?; end
1996
+
1997
+ # Errors
1998
+ #
1999
+ # source://rack//lib/rack/mock_response.rb#22
2000
+ def errors; end
2001
+
2002
+ # Errors
2003
+ #
2004
+ # source://rack//lib/rack/mock_response.rb#22
2005
+ def errors=(_arg0); end
2006
+
2007
+ # source://rack//lib/rack/mock_response.rb#43
2008
+ def match(other); end
2009
+
2010
+ # Headers
2011
+ #
2012
+ # source://rack//lib/rack/mock_response.rb#19
2013
+ def original_headers; end
2014
+
2015
+ private
2016
+
2017
+ # source://rack//lib/rack/mock_response.rb#100
2018
+ def identify_cookie_attributes(cookie_filling); end
2019
+
2020
+ # source://rack//lib/rack/mock_response.rb#79
2021
+ def parse_cookies_from_header; end
2022
+
2023
+ class << self
2024
+ def [](*_arg0); end
2025
+ end
2026
+ end
2027
+
2028
+ # A multipart form data parser, adapted from IOWA.
2029
+ #
2030
+ # Usually, Rack::Request#POST takes care of calling this.
2031
+ #
2032
+ # source://rack//lib/rack/multipart/parser.rb#9
2033
+ module Rack::Multipart
2034
+ class << self
2035
+ # source://rack//lib/rack/multipart.rb#72
2036
+ def build_multipart(params, first = T.unsafe(nil)); end
2037
+
2038
+ # source://rack//lib/rack/multipart.rb#68
2039
+ def extract_multipart(request, params = T.unsafe(nil)); end
2040
+
2041
+ # source://rack//lib/rack/multipart.rb#48
2042
+ def parse_multipart(env, params = T.unsafe(nil)); end
2043
+ end
2044
+ end
2045
+
2046
+ # Base class for multipart exceptions that do not subclass from
2047
+ # other exception classes for backwards compatibility.
2048
+ #
2049
+ # source://rack//lib/rack/multipart/parser.rb#26
2050
+ class Rack::Multipart::BoundaryTooLongError < ::StandardError
2051
+ include ::Rack::BadRequest
2052
+ end
2053
+
2054
+ # source://rack//lib/rack/multipart/parser.rb#33
2055
+ Rack::Multipart::EOL = T.let(T.unsafe(nil), String)
2056
+
2057
+ # Use specific error class when parsing multipart request
2058
+ # that ends early.
2059
+ #
2060
+ # source://rack//lib/rack/multipart/parser.rb#20
2061
+ class Rack::Multipart::EmptyContentError < ::EOFError
2062
+ include ::Rack::BadRequest
2063
+ end
2064
+
2065
+ # Prefer to use the BoundaryTooLongError class or Rack::BadRequest.
2066
+ #
2067
+ # source://rack//lib/rack/multipart/parser.rb#31
2068
+ Rack::Multipart::Error = Rack::Multipart::BoundaryTooLongError
2069
+
2070
+ # source://rack//lib/rack/multipart/generator.rb#7
2071
+ class Rack::Multipart::Generator
2072
+ # @return [Generator] a new instance of Generator
2073
+ #
2074
+ # source://rack//lib/rack/multipart/generator.rb#8
2075
+ def initialize(params, first = T.unsafe(nil)); end
2076
+
2077
+ # source://rack//lib/rack/multipart/generator.rb#16
2078
+ def dump; end
2079
+
2080
+ private
2081
+
2082
+ # source://rack//lib/rack/multipart/generator.rb#89
2083
+ def content_for_other(file, name); end
2084
+
2085
+ # source://rack//lib/rack/multipart/generator.rb#77
2086
+ def content_for_tempfile(io, file, name); end
2087
+
2088
+ # source://rack//lib/rack/multipart/generator.rb#52
2089
+ def flattened_params; end
2090
+
2091
+ # @return [Boolean]
2092
+ #
2093
+ # source://rack//lib/rack/multipart/generator.rb#37
2094
+ def multipart?; end
2095
+ end
2096
+
2097
+ # source://rack//lib/rack/multipart/parser.rb#34
2098
+ Rack::Multipart::MULTIPART = T.let(T.unsafe(nil), Regexp)
2099
+
2100
+ # source://rack//lib/rack/multipart.rb#16
2101
+ Rack::Multipart::MULTIPART_BOUNDARY = T.let(T.unsafe(nil), String)
2102
+
2103
+ # source://rack//lib/rack/multipart/parser.rb#36
2104
+ Rack::Multipart::MULTIPART_CONTENT_DISPOSITION = T.let(T.unsafe(nil), Regexp)
2105
+
2106
+ # source://rack//lib/rack/multipart/parser.rb#37
2107
+ Rack::Multipart::MULTIPART_CONTENT_ID = T.let(T.unsafe(nil), Regexp)
2108
+
2109
+ # source://rack//lib/rack/multipart/parser.rb#35
2110
+ Rack::Multipart::MULTIPART_CONTENT_TYPE = T.let(T.unsafe(nil), Regexp)
2111
+
2112
+ # source://rack//lib/rack/multipart.rb#18
2113
+ class Rack::Multipart::MissingInputError < ::StandardError
2114
+ include ::Rack::BadRequest
2115
+ end
2116
+
2117
+ # source://rack//lib/rack/multipart/parser.rb#10
2118
+ class Rack::Multipart::MultipartPartLimitError < ::Errno::EMFILE
2119
+ include ::Rack::BadRequest
2120
+ end
2121
+
2122
+ # source://rack//lib/rack/multipart/parser.rb#14
2123
+ class Rack::Multipart::MultipartTotalPartLimitError < ::StandardError
2124
+ include ::Rack::BadRequest
2125
+ end
2126
+
2127
+ # Accumulator for multipart form data, conforming to the QueryParser API.
2128
+ # In future, the Parser could return the pair list directly, but that would
2129
+ # change its API.
2130
+ #
2131
+ # source://rack//lib/rack/multipart.rb#25
2132
+ class Rack::Multipart::ParamList
2133
+ # @return [ParamList] a new instance of ParamList
2134
+ #
2135
+ # source://rack//lib/rack/multipart.rb#34
2136
+ def initialize; end
2137
+
2138
+ # source://rack//lib/rack/multipart.rb#38
2139
+ def <<(pair); end
2140
+
2141
+ # source://rack//lib/rack/multipart.rb#42
2142
+ def to_params_hash; end
2143
+
2144
+ class << self
2145
+ # source://rack//lib/rack/multipart.rb#26
2146
+ def make_params; end
2147
+
2148
+ # source://rack//lib/rack/multipart.rb#30
2149
+ def normalize_params(params, key, value); end
2150
+ end
2151
+ end
2152
+
2153
+ # source://rack//lib/rack/multipart/parser.rb#39
2154
+ class Rack::Multipart::Parser
2155
+ # @return [Parser] a new instance of Parser
2156
+ #
2157
+ # source://rack//lib/rack/multipart/parser.rb#200
2158
+ def initialize(boundary, tempfile, bufsize, query_parser); end
2159
+
2160
+ # source://rack//lib/rack/multipart/parser.rb#217
2161
+ def parse(io); end
2162
+
2163
+ # source://rack//lib/rack/multipart/parser.rb#240
2164
+ def result; end
2165
+
2166
+ # Returns the value of attribute state.
2167
+ #
2168
+ # source://rack//lib/rack/multipart/parser.rb#198
2169
+ def state; end
2170
+
2171
+ private
2172
+
2173
+ # Scan until the we find the start or end of the boundary.
2174
+ # If we find it, return the appropriate symbol for the start or
2175
+ # end of the boundary. If we don't find the start or end of the
2176
+ # boundary, clear the buffer and return nil.
2177
+ #
2178
+ # source://rack//lib/rack/multipart/parser.rb#434
2179
+ def consume_boundary; end
2180
+
2181
+ # From WEBrick::HTTPUtils
2182
+ #
2183
+ # source://rack//lib/rack/multipart/parser.rb#252
2184
+ def dequote(str); end
2185
+
2186
+ # Return the related Encoding object. However, because
2187
+ # enc is submitted by the user, it may be invalid, so
2188
+ # use a binary encoding in that case.
2189
+ #
2190
+ # source://rack//lib/rack/multipart/parser.rb#489
2191
+ def find_encoding(enc); end
2192
+
2193
+ # source://rack//lib/rack/multipart/parser.rb#294
2194
+ def handle_consume_token; end
2195
+
2196
+ # source://rack//lib/rack/multipart/parser.rb#495
2197
+ def handle_empty_content!(content); end
2198
+
2199
+ # This handles the initial parser state. We read until we find the starting
2200
+ # boundary, then we can transition to the next state. If we find the ending
2201
+ # boundary, this is an invalid multipart upload, but keep scanning for opening
2202
+ # boundary in that case. If no boundary found, we need to keep reading data
2203
+ # and retry. It's highly unlikely the initial read will not consume the
2204
+ # boundary. The client would have to deliberately craft a response
2205
+ # with the opening boundary beyond the buffer size for that to happen.
2206
+ #
2207
+ # source://rack//lib/rack/multipart/parser.rb#271
2208
+ def handle_fast_forward; end
2209
+
2210
+ # source://rack//lib/rack/multipart/parser.rb#411
2211
+ def handle_mime_body; end
2212
+
2213
+ # source://rack//lib/rack/multipart/parser.rb#306
2214
+ def handle_mime_head; end
2215
+
2216
+ # source://rack//lib/rack/multipart/parser.rb#443
2217
+ def normalize_filename(filename); end
2218
+
2219
+ # source://rack//lib/rack/multipart/parser.rb#258
2220
+ def read_data(io, outbuf); end
2221
+
2222
+ # source://rack//lib/rack/multipart/parser.rb#456
2223
+ def tag_multipart_encoding(filename, content_type, name, body); end
2224
+
2225
+ class << self
2226
+ # source://rack//lib/rack/multipart/parser.rb#87
2227
+ def parse(io, content_length, content_type, tmpfile, bufsize, qp); end
2228
+
2229
+ # source://rack//lib/rack/multipart/parser.rb#80
2230
+ def parse_boundary(content_type); end
2231
+ end
2232
+ end
2233
+
2234
+ # source://rack//lib/rack/multipart/parser.rb#40
2235
+ Rack::Multipart::Parser::BUFSIZE = T.let(T.unsafe(nil), Integer)
2236
+
2237
+ # source://rack//lib/rack/multipart/parser.rb#48
2238
+ class Rack::Multipart::Parser::BoundedIO
2239
+ # @return [BoundedIO] a new instance of BoundedIO
2240
+ #
2241
+ # source://rack//lib/rack/multipart/parser.rb#49
2242
+ def initialize(io, content_length); end
2243
+
2244
+ # source://rack//lib/rack/multipart/parser.rb#55
2245
+ def read(size, outbuf = T.unsafe(nil)); end
2246
+ end
2247
+
2248
+ # source://rack//lib/rack/multipart/parser.rb#453
2249
+ Rack::Multipart::Parser::CHARSET = T.let(T.unsafe(nil), String)
2250
+
2251
+ # source://rack//lib/rack/multipart/parser.rb#305
2252
+ Rack::Multipart::Parser::CONTENT_DISPOSITION_MAX_BYTES = T.let(T.unsafe(nil), Integer)
2253
+
2254
+ # source://rack//lib/rack/multipart/parser.rb#304
2255
+ Rack::Multipart::Parser::CONTENT_DISPOSITION_MAX_PARAMS = T.let(T.unsafe(nil), Integer)
2256
+
2257
+ # source://rack//lib/rack/multipart/parser.rb#107
2258
+ class Rack::Multipart::Parser::Collector
2259
+ include ::Enumerable
2260
+
2261
+ # @return [Collector] a new instance of Collector
2262
+ #
2263
+ # source://rack//lib/rack/multipart/parser.rb#143
2264
+ def initialize(tempfile); end
2265
+
2266
+ # source://rack//lib/rack/multipart/parser.rb#149
2267
+ def each; end
2268
+
2269
+ # source://rack//lib/rack/multipart/parser.rb#169
2270
+ def on_mime_body(mime_index, content); end
2271
+
2272
+ # source://rack//lib/rack/multipart/parser.rb#173
2273
+ def on_mime_finish(mime_index); end
2274
+
2275
+ # source://rack//lib/rack/multipart/parser.rb#153
2276
+ def on_mime_head(mime_index, head, filename, content_type, name); end
2277
+
2278
+ private
2279
+
2280
+ # source://rack//lib/rack/multipart/parser.rb#178
2281
+ def check_part_limits; end
2282
+ end
2283
+
2284
+ # source://rack//lib/rack/multipart/parser.rb#131
2285
+ class Rack::Multipart::Parser::Collector::BufferPart < ::Rack::Multipart::Parser::Collector::MimePart
2286
+ # source://rack//lib/rack/multipart/parser.rb#133
2287
+ def close; end
2288
+
2289
+ # @return [Boolean]
2290
+ #
2291
+ # source://rack//lib/rack/multipart/parser.rb#132
2292
+ def file?; end
2293
+ end
2294
+
2295
+ # source://rack//lib/rack/multipart/parser.rb#108
2296
+ class Rack::Multipart::Parser::Collector::MimePart < ::Struct
2297
+ # @yield [data]
2298
+ #
2299
+ # source://rack//lib/rack/multipart/parser.rb#109
2300
+ def get_data; end
2301
+ end
2302
+
2303
+ # source://rack//lib/rack/multipart/parser.rb#136
2304
+ class Rack::Multipart::Parser::Collector::TempfilePart < ::Rack::Multipart::Parser::Collector::MimePart
2305
+ # source://rack//lib/rack/multipart/parser.rb#138
2306
+ def close; end
2307
+
2308
+ # @return [Boolean]
2309
+ #
2310
+ # source://rack//lib/rack/multipart/parser.rb#137
2311
+ def file?; end
2312
+ end
2313
+
2314
+ # source://rack//lib/rack/multipart/parser.rb#78
2315
+ Rack::Multipart::Parser::EMPTY = T.let(T.unsafe(nil), Rack::Multipart::Parser::MultipartInfo)
2316
+
2317
+ # source://rack//lib/rack/multipart/parser.rb#77
2318
+ class Rack::Multipart::Parser::MultipartInfo < ::Struct
2319
+ # Returns the value of attribute params
2320
+ #
2321
+ # @return [Object] the current value of params
2322
+ def params; end
2323
+
2324
+ # Sets the attribute params
2325
+ #
2326
+ # @param value [Object] the value to set the attribute params to.
2327
+ # @return [Object] the newly set value
2328
+ def params=(_); end
2329
+
2330
+ # Returns the value of attribute tmp_files
2331
+ #
2332
+ # @return [Object] the current value of tmp_files
2333
+ def tmp_files; end
2334
+
2335
+ # Sets the attribute tmp_files
2336
+ #
2337
+ # @param value [Object] the value to set the attribute tmp_files to.
2338
+ # @return [Object] the newly set value
2339
+ def tmp_files=(_); end
2340
+
2341
+ class << self
2342
+ def [](*_arg0); end
2343
+ def inspect; end
2344
+ def keyword_init?; end
2345
+ def members; end
2346
+ def new(*_arg0); end
2347
+ end
2348
+ end
2349
+
2350
+ # source://rack//lib/rack/multipart/parser.rb#42
2351
+ Rack::Multipart::Parser::TEMPFILE_FACTORY = T.let(T.unsafe(nil), Proc)
2352
+
2353
+ # source://rack//lib/rack/multipart/parser.rb#41
2354
+ Rack::Multipart::Parser::TEXT_PLAIN = T.let(T.unsafe(nil), String)
2355
+
2356
+ # source://rack//lib/rack/multipart/uploaded_file.rb#8
2357
+ class Rack::Multipart::UploadedFile
2358
+ # @return [UploadedFile] a new instance of UploadedFile
2359
+ #
2360
+ # source://rack//lib/rack/multipart/uploaded_file.rb#16
2361
+ def initialize(filepath = T.unsafe(nil), ct = T.unsafe(nil), bin = T.unsafe(nil), path: T.unsafe(nil), content_type: T.unsafe(nil), binary: T.unsafe(nil), filename: T.unsafe(nil), io: T.unsafe(nil)); end
2362
+
2363
+ # The content type of the "uploaded" file
2364
+ #
2365
+ # source://rack//lib/rack/multipart/uploaded_file.rb#14
2366
+ def content_type; end
2367
+
2368
+ # The content type of the "uploaded" file
2369
+ #
2370
+ # source://rack//lib/rack/multipart/uploaded_file.rb#14
2371
+ def content_type=(_arg0); end
2372
+
2373
+ # source://rack//lib/rack/multipart/uploaded_file.rb#31
2374
+ def local_path; end
2375
+
2376
+ # source://rack//lib/rack/multipart/uploaded_file.rb#40
2377
+ def method_missing(method_name, *args, &block); end
2378
+
2379
+ # The filename, *not* including the path, of the "uploaded" file
2380
+ #
2381
+ # source://rack//lib/rack/multipart/uploaded_file.rb#11
2382
+ def original_filename; end
2383
+
2384
+ # source://rack//lib/rack/multipart/uploaded_file.rb#31
2385
+ def path; end
2386
+
2387
+ # @return [Boolean]
2388
+ #
2389
+ # source://rack//lib/rack/multipart/uploaded_file.rb#36
2390
+ def respond_to?(*args); end
2391
+ end
2392
+
2393
+ # source://rack//lib/rack/null_logger.rb#6
2394
+ class Rack::NullLogger
2395
+ # @return [NullLogger] a new instance of NullLogger
2396
+ #
2397
+ # source://rack//lib/rack/null_logger.rb#7
2398
+ def initialize(app); end
2399
+
2400
+ # source://rack//lib/rack/null_logger.rb#45
2401
+ def <<(msg); end
2402
+
2403
+ # source://rack//lib/rack/null_logger.rb#43
2404
+ def add(severity, message = T.unsafe(nil), progname = T.unsafe(nil), &block); end
2405
+
2406
+ # source://rack//lib/rack/null_logger.rb#11
2407
+ def call(env); end
2408
+
2409
+ # source://rack//lib/rack/null_logger.rb#42
2410
+ def close; end
2411
+
2412
+ # source://rack//lib/rack/null_logger.rb#34
2413
+ def datetime_format; end
2414
+
2415
+ # source://rack//lib/rack/null_logger.rb#39
2416
+ def datetime_format=(datetime_format); end
2417
+
2418
+ # source://rack//lib/rack/null_logger.rb#17
2419
+ def debug(progname = T.unsafe(nil), &block); end
2420
+
2421
+ # source://rack//lib/rack/null_logger.rb#27
2422
+ def debug!; end
2423
+
2424
+ # @return [Boolean]
2425
+ #
2426
+ # source://rack//lib/rack/null_logger.rb#23
2427
+ def debug?; end
2428
+
2429
+ # source://rack//lib/rack/null_logger.rb#19
2430
+ def error(progname = T.unsafe(nil), &block); end
2431
+
2432
+ # source://rack//lib/rack/null_logger.rb#28
2433
+ def error!; end
2434
+
2435
+ # @return [Boolean]
2436
+ #
2437
+ # source://rack//lib/rack/null_logger.rb#25
2438
+ def error?; end
2439
+
2440
+ # source://rack//lib/rack/null_logger.rb#20
2441
+ def fatal(progname = T.unsafe(nil), &block); end
2442
+
2443
+ # source://rack//lib/rack/null_logger.rb#29
2444
+ def fatal!; end
2445
+
2446
+ # @return [Boolean]
2447
+ #
2448
+ # source://rack//lib/rack/null_logger.rb#26
2449
+ def fatal?; end
2450
+
2451
+ # source://rack//lib/rack/null_logger.rb#35
2452
+ def formatter; end
2453
+
2454
+ # source://rack//lib/rack/null_logger.rb#40
2455
+ def formatter=(formatter); end
2456
+
2457
+ # source://rack//lib/rack/null_logger.rb#16
2458
+ def info(progname = T.unsafe(nil), &block); end
2459
+
2460
+ # source://rack//lib/rack/null_logger.rb#30
2461
+ def info!; end
2462
+
2463
+ # @return [Boolean]
2464
+ #
2465
+ # source://rack//lib/rack/null_logger.rb#22
2466
+ def info?; end
2467
+
2468
+ # source://rack//lib/rack/null_logger.rb#32
2469
+ def level; end
2470
+
2471
+ # source://rack//lib/rack/null_logger.rb#37
2472
+ def level=(level); end
2473
+
2474
+ # source://rack//lib/rack/null_logger.rb#44
2475
+ def log(severity, message = T.unsafe(nil), progname = T.unsafe(nil), &block); end
2476
+
2477
+ # source://rack//lib/rack/null_logger.rb#33
2478
+ def progname; end
2479
+
2480
+ # source://rack//lib/rack/null_logger.rb#38
2481
+ def progname=(progname); end
2482
+
2483
+ # source://rack//lib/rack/null_logger.rb#46
2484
+ def reopen(logdev = T.unsafe(nil)); end
2485
+
2486
+ # source://rack//lib/rack/null_logger.rb#36
2487
+ def sev_threshold; end
2488
+
2489
+ # source://rack//lib/rack/null_logger.rb#41
2490
+ def sev_threshold=(sev_threshold); end
2491
+
2492
+ # source://rack//lib/rack/null_logger.rb#21
2493
+ def unknown(progname = T.unsafe(nil), &block); end
2494
+
2495
+ # source://rack//lib/rack/null_logger.rb#18
2496
+ def warn(progname = T.unsafe(nil), &block); end
2497
+
2498
+ # source://rack//lib/rack/null_logger.rb#31
2499
+ def warn!; end
2500
+
2501
+ # @return [Boolean]
2502
+ #
2503
+ # source://rack//lib/rack/null_logger.rb#24
2504
+ def warn?; end
2505
+ end
2506
+
2507
+ # source://rack//lib/rack/constants.rb#34
2508
+ Rack::OPTIONS = T.let(T.unsafe(nil), String)
2509
+
2510
+ # source://rack//lib/rack/constants.rb#31
2511
+ Rack::PATCH = T.let(T.unsafe(nil), String)
2512
+
2513
+ # source://rack//lib/rack/constants.rb#8
2514
+ Rack::PATH_INFO = T.let(T.unsafe(nil), String)
2515
+
2516
+ # source://rack//lib/rack/constants.rb#29
2517
+ Rack::POST = T.let(T.unsafe(nil), String)
2518
+
2519
+ # source://rack//lib/rack/constants.rb#30
2520
+ Rack::PUT = T.let(T.unsafe(nil), String)
2521
+
2522
+ # source://rack//lib/rack/constants.rb#12
2523
+ Rack::QUERY_STRING = T.let(T.unsafe(nil), String)
2524
+
2525
+ # source://rack//lib/rack/query_parser.rb#7
2526
+ class Rack::QueryParser
2527
+ # @return [QueryParser] a new instance of QueryParser
2528
+ #
2529
+ # source://rack//lib/rack/query_parser.rb#36
2530
+ def initialize(params_class, param_depth_limit); end
2531
+
2532
+ # source://rack//lib/rack/query_parser.rb#166
2533
+ def make_params; end
2534
+
2535
+ # source://rack//lib/rack/query_parser.rb#170
2536
+ def new_depth_limit(param_depth_limit); end
2537
+
2538
+ # normalize_params recursively expands parameters into structural types. If
2539
+ # the structural types represented by two different parameter names are in
2540
+ # conflict, a ParameterTypeError is raised. The depth argument is deprecated
2541
+ # and should no longer be used, it is kept for backwards compatibility with
2542
+ # earlier versions of rack.
2543
+ #
2544
+ # source://rack//lib/rack/query_parser.rb#94
2545
+ def normalize_params(params, name, v, _depth = T.unsafe(nil)); end
2546
+
2547
+ # Returns the value of attribute param_depth_limit.
2548
+ #
2549
+ # source://rack//lib/rack/query_parser.rb#34
2550
+ def param_depth_limit; end
2551
+
2552
+ # parse_nested_query expands a query string into structural types. Supported
2553
+ # types are Arrays, Hashes and basic value types. It is possible to supply
2554
+ # query strings with parameters of conflicting types, in this case a
2555
+ # ParameterTypeError is raised. Users are encouraged to return a 400 in this
2556
+ # case.
2557
+ #
2558
+ # source://rack//lib/rack/query_parser.rb#73
2559
+ def parse_nested_query(qs, separator = T.unsafe(nil)); end
2560
+
2561
+ # Stolen from Mongrel, with some small modifications:
2562
+ # Parses a query string by breaking it up at the '&'. You can also use this
2563
+ # to parse cookies by changing the characters used in the second parameter
2564
+ # (which defaults to '&').
2565
+ #
2566
+ # source://rack//lib/rack/query_parser.rb#45
2567
+ def parse_query(qs, separator = T.unsafe(nil), &unescaper); end
2568
+
2569
+ private
2570
+
2571
+ # @raise [ParamsTooDeepError]
2572
+ #
2573
+ # source://rack//lib/rack/query_parser.rb#98
2574
+ def _normalize_params(params, name, v, depth); end
2575
+
2576
+ # @return [Boolean]
2577
+ #
2578
+ # source://rack//lib/rack/query_parser.rb#180
2579
+ def params_hash_has_key?(hash, key); end
2580
+
2581
+ # @return [Boolean]
2582
+ #
2583
+ # source://rack//lib/rack/query_parser.rb#176
2584
+ def params_hash_type?(obj); end
2585
+
2586
+ # source://rack//lib/rack/query_parser.rb#192
2587
+ def unescape(string, encoding = T.unsafe(nil)); end
2588
+
2589
+ class << self
2590
+ # source://rack//lib/rack/query_parser.rb#30
2591
+ def make_default(param_depth_limit); end
2592
+ end
2593
+ end
2594
+
2595
+ # source://rack//lib/rack/query_parser.rb#9
2596
+ Rack::QueryParser::COMMON_SEP = T.let(T.unsafe(nil), Hash)
2597
+
2598
+ # source://rack//lib/rack/query_parser.rb#8
2599
+ Rack::QueryParser::DEFAULT_SEP = T.let(T.unsafe(nil), Regexp)
2600
+
2601
+ # InvalidParameterError is the error that is raised when incoming structural
2602
+ # parameters (parsed by parse_nested_query) contain invalid format or byte
2603
+ # sequence.
2604
+ #
2605
+ # source://rack//lib/rack/query_parser.rb#20
2606
+ class Rack::QueryParser::InvalidParameterError < ::ArgumentError
2607
+ include ::Rack::BadRequest
2608
+ end
2609
+
2610
+ # ParameterTypeError is the error that is raised when incoming structural
2611
+ # parameters (parsed by parse_nested_query) contain conflicting types.
2612
+ #
2613
+ # source://rack//lib/rack/query_parser.rb#13
2614
+ class Rack::QueryParser::ParameterTypeError < ::TypeError
2615
+ include ::Rack::BadRequest
2616
+ end
2617
+
2618
+ # source://rack//lib/rack/query_parser.rb#196
2619
+ class Rack::QueryParser::Params < ::Hash
2620
+ def to_params_hash; end
2621
+ end
2622
+
2623
+ # ParamsTooDeepError is the error that is raised when params are recursively
2624
+ # nested over the specified limit.
2625
+ #
2626
+ # source://rack//lib/rack/query_parser.rb#26
2627
+ class Rack::QueryParser::ParamsTooDeepError < ::RangeError
2628
+ include ::Rack::BadRequest
2629
+ end
2630
+
2631
+ # source://rack//lib/rack/constants.rb#43
2632
+ Rack::RACK_EARLY_HINTS = T.let(T.unsafe(nil), String)
2633
+
2634
+ # source://rack//lib/rack/constants.rb#44
2635
+ Rack::RACK_ERRORS = T.let(T.unsafe(nil), String)
2636
+
2637
+ # source://rack//lib/rack/constants.rb#51
2638
+ Rack::RACK_HIJACK = T.let(T.unsafe(nil), String)
2639
+
2640
+ # source://rack//lib/rack/constants.rb#46
2641
+ Rack::RACK_INPUT = T.let(T.unsafe(nil), String)
2642
+
2643
+ # source://rack//lib/rack/constants.rb#52
2644
+ Rack::RACK_IS_HIJACK = T.let(T.unsafe(nil), String)
2645
+
2646
+ # source://rack//lib/rack/constants.rb#45
2647
+ Rack::RACK_LOGGER = T.let(T.unsafe(nil), String)
2648
+
2649
+ # source://rack//lib/rack/constants.rb#66
2650
+ Rack::RACK_METHODOVERRIDE_ORIGINAL_METHOD = T.let(T.unsafe(nil), String)
2651
+
2652
+ # source://rack//lib/rack/constants.rb#54
2653
+ Rack::RACK_MULTIPART_BUFFER_SIZE = T.let(T.unsafe(nil), String)
2654
+
2655
+ # source://rack//lib/rack/constants.rb#55
2656
+ Rack::RACK_MULTIPART_TEMPFILE_FACTORY = T.let(T.unsafe(nil), String)
2657
+
2658
+ # source://rack//lib/rack/constants.rb#53
2659
+ Rack::RACK_RECURSIVE_INCLUDE = T.let(T.unsafe(nil), String)
2660
+
2661
+ # source://rack//lib/rack/constants.rb#62
2662
+ Rack::RACK_REQUEST_COOKIE_HASH = T.let(T.unsafe(nil), String)
2663
+
2664
+ # source://rack//lib/rack/constants.rb#63
2665
+ Rack::RACK_REQUEST_COOKIE_STRING = T.let(T.unsafe(nil), String)
2666
+
2667
+ # source://rack//lib/rack/constants.rb#61
2668
+ Rack::RACK_REQUEST_FORM_ERROR = T.let(T.unsafe(nil), String)
2669
+
2670
+ # source://rack//lib/rack/constants.rb#58
2671
+ Rack::RACK_REQUEST_FORM_HASH = T.let(T.unsafe(nil), String)
2672
+
2673
+ # source://rack//lib/rack/constants.rb#57
2674
+ Rack::RACK_REQUEST_FORM_INPUT = T.let(T.unsafe(nil), String)
2675
+
2676
+ # source://rack//lib/rack/constants.rb#59
2677
+ Rack::RACK_REQUEST_FORM_PAIRS = T.let(T.unsafe(nil), String)
2678
+
2679
+ # source://rack//lib/rack/constants.rb#60
2680
+ Rack::RACK_REQUEST_FORM_VARS = T.let(T.unsafe(nil), String)
2681
+
2682
+ # source://rack//lib/rack/constants.rb#64
2683
+ Rack::RACK_REQUEST_QUERY_HASH = T.let(T.unsafe(nil), String)
2684
+
2685
+ # source://rack//lib/rack/constants.rb#65
2686
+ Rack::RACK_REQUEST_QUERY_STRING = T.let(T.unsafe(nil), String)
2687
+
2688
+ # source://rack//lib/rack/constants.rb#56
2689
+ Rack::RACK_RESPONSE_FINISHED = T.let(T.unsafe(nil), String)
2690
+
2691
+ # source://rack//lib/rack/constants.rb#47
2692
+ Rack::RACK_SESSION = T.let(T.unsafe(nil), String)
2693
+
2694
+ # source://rack//lib/rack/constants.rb#48
2695
+ Rack::RACK_SESSION_OPTIONS = T.let(T.unsafe(nil), String)
2696
+
2697
+ # source://rack//lib/rack/constants.rb#49
2698
+ Rack::RACK_SHOWSTATUS_DETAIL = T.let(T.unsafe(nil), String)
2699
+
2700
+ # source://rack//lib/rack/constants.rb#42
2701
+ Rack::RACK_TEMPFILES = T.let(T.unsafe(nil), String)
2702
+
2703
+ # source://rack//lib/rack/constants.rb#50
2704
+ Rack::RACK_URL_SCHEME = T.let(T.unsafe(nil), String)
2705
+
2706
+ # Rack environment variables
2707
+ #
2708
+ # source://rack//lib/rack/constants.rb#41
2709
+ Rack::RACK_VERSION = T.let(T.unsafe(nil), String)
2710
+
2711
+ # source://rack//lib/rack/version.rb#15
2712
+ Rack::RELEASE = T.let(T.unsafe(nil), String)
2713
+
2714
+ # source://rack//lib/rack/constants.rb#9
2715
+ Rack::REQUEST_METHOD = T.let(T.unsafe(nil), String)
2716
+
2717
+ # source://rack//lib/rack/constants.rb#10
2718
+ Rack::REQUEST_PATH = T.let(T.unsafe(nil), String)
2719
+
2720
+ # Rack::Recursive allows applications called down the chain to
2721
+ # include data from other applications (by using
2722
+ # <tt>rack['rack.recursive.include'][...]</tt> or raise a
2723
+ # ForwardRequest to redirect internally.
2724
+ #
2725
+ # source://rack//lib/rack/recursive.rb#36
2726
+ class Rack::Recursive
2727
+ # @return [Recursive] a new instance of Recursive
2728
+ #
2729
+ # source://rack//lib/rack/recursive.rb#37
2730
+ def initialize(app); end
2731
+
2732
+ # source://rack//lib/rack/recursive.rb#45
2733
+ def _call(env); end
2734
+
2735
+ # source://rack//lib/rack/recursive.rb#41
2736
+ def call(env); end
2737
+
2738
+ # source://rack//lib/rack/recursive.rb#52
2739
+ def include(env, path); end
2740
+ end
2741
+
2742
+ # High performant source reloader
2743
+ #
2744
+ # This class acts as Rack middleware.
2745
+ #
2746
+ # What makes it especially suited for use in a production environment is that
2747
+ # any file will only be checked once and there will only be made one system
2748
+ # call stat(2).
2749
+ #
2750
+ # Please note that this will not reload files in the background, it does so
2751
+ # only when actively called.
2752
+ #
2753
+ # It is performing a check/reload cycle at the start of every request, but
2754
+ # also respects a cool down time, during which nothing will be done.
2755
+ #
2756
+ # source://rack//lib/rack/reloader.rb#24
2757
+ class Rack::Reloader
2758
+ # @return [Reloader] a new instance of Reloader
2759
+ #
2760
+ # source://rack//lib/rack/reloader.rb#25
2761
+ def initialize(app, cooldown = T.unsafe(nil), backend = T.unsafe(nil)); end
2762
+
2763
+ # source://rack//lib/rack/reloader.rb#36
2764
+ def call(env); end
2765
+
2766
+ # source://rack//lib/rack/reloader.rb#50
2767
+ def reload!(stderr = T.unsafe(nil)); end
2768
+
2769
+ # A safe Kernel::load, issuing the hooks depending on the results
2770
+ #
2771
+ # source://rack//lib/rack/reloader.rb#58
2772
+ def safe_load(file, mtime, stderr = T.unsafe(nil)); end
2773
+ end
2774
+
2775
+ # source://rack//lib/rack/reloader.rb#68
2776
+ module Rack::Reloader::Stat
2777
+ # Takes a relative or absolute +file+ name, a couple possible +paths+ that
2778
+ # the +file+ might reside in. Returns the full path and File::Stat for the
2779
+ # path.
2780
+ #
2781
+ # source://rack//lib/rack/reloader.rb#88
2782
+ def figure_path(file, paths); end
2783
+
2784
+ # source://rack//lib/rack/reloader.rb#69
2785
+ def rotation; end
2786
+
2787
+ # source://rack//lib/rack/reloader.rb#103
2788
+ def safe_stat(file); end
2789
+ end
2790
+
2791
+ # Rack::Request provides a convenient interface to a Rack
2792
+ # environment. It is stateless, the environment +env+ passed to the
2793
+ # constructor will be directly modified.
2794
+ #
2795
+ # req = Rack::Request.new(env)
2796
+ # req.post?
2797
+ # req.params["data"]
2798
+ #
2799
+ # source://rack//lib/rack/request.rb#16
2800
+ class Rack::Request
2801
+ include ::Rack::Request::Env
2802
+ include ::Rack::Request::Helpers
2803
+
2804
+ # @return [Request] a new instance of Request
2805
+ #
2806
+ # source://rack//lib/rack/request.rb#62
2807
+ def initialize(env); end
2808
+
2809
+ # source://rack//lib/rack/request.rb#76
2810
+ def delete_param(k); end
2811
+
2812
+ # source://rack//lib/rack/request.rb#67
2813
+ def params; end
2814
+
2815
+ # source://rack//lib/rack/request.rb#71
2816
+ def update_param(k, v); end
2817
+
2818
+ class << self
2819
+ # The priority when checking forwarded headers. The default
2820
+ # is <tt>[:forwarded, :x_forwarded]</tt>, which means, check the
2821
+ # +Forwarded+ header first, followed by the appropriate
2822
+ # <tt>X-Forwarded-*</tt> header. You can revert the priority by
2823
+ # reversing the priority, or remove checking of either
2824
+ # or both headers by removing elements from the array.
2825
+ #
2826
+ # This should be set as appropriate in your environment
2827
+ # based on what reverse proxies are in use. If you are not
2828
+ # using reverse proxies, you should probably use an empty
2829
+ # array.
2830
+ #
2831
+ # source://rack//lib/rack/request.rb#31
2832
+ def forwarded_priority; end
2833
+
2834
+ # The priority when checking forwarded headers. The default
2835
+ # is <tt>[:forwarded, :x_forwarded]</tt>, which means, check the
2836
+ # +Forwarded+ header first, followed by the appropriate
2837
+ # <tt>X-Forwarded-*</tt> header. You can revert the priority by
2838
+ # reversing the priority, or remove checking of either
2839
+ # or both headers by removing elements from the array.
2840
+ #
2841
+ # This should be set as appropriate in your environment
2842
+ # based on what reverse proxies are in use. If you are not
2843
+ # using reverse proxies, you should probably use an empty
2844
+ # array.
2845
+ #
2846
+ # source://rack//lib/rack/request.rb#31
2847
+ def forwarded_priority=(_arg0); end
2848
+
2849
+ # Returns the value of attribute ip_filter.
2850
+ #
2851
+ # source://rack//lib/rack/request.rb#18
2852
+ def ip_filter; end
2853
+
2854
+ # Sets the attribute ip_filter
2855
+ #
2856
+ # @param value the value to set the attribute ip_filter to.
2857
+ #
2858
+ # source://rack//lib/rack/request.rb#18
2859
+ def ip_filter=(_arg0); end
2860
+
2861
+ # The priority when checking either the <tt>X-Forwarded-Proto</tt>
2862
+ # or <tt>X-Forwarded-Scheme</tt> header for the forwarded protocol.
2863
+ # The default is <tt>[:proto, :scheme]</tt>, to try the
2864
+ # <tt>X-Forwarded-Proto</tt> header before the
2865
+ # <tt>X-Forwarded-Scheme</tt> header. Rack 2 had behavior
2866
+ # similar to <tt>[:scheme, :proto]</tt>. You can remove either or
2867
+ # both of the entries in array to ignore that respective header.
2868
+ #
2869
+ # source://rack//lib/rack/request.rb#40
2870
+ def x_forwarded_proto_priority; end
2871
+
2872
+ # The priority when checking either the <tt>X-Forwarded-Proto</tt>
2873
+ # or <tt>X-Forwarded-Scheme</tt> header for the forwarded protocol.
2874
+ # The default is <tt>[:proto, :scheme]</tt>, to try the
2875
+ # <tt>X-Forwarded-Proto</tt> header before the
2876
+ # <tt>X-Forwarded-Scheme</tt> header. Rack 2 had behavior
2877
+ # similar to <tt>[:scheme, :proto]</tt>. You can remove either or
2878
+ # both of the entries in array to ignore that respective header.
2879
+ #
2880
+ # source://rack//lib/rack/request.rb#40
2881
+ def x_forwarded_proto_priority=(_arg0); end
2882
+ end
2883
+ end
2884
+
2885
+ # source://rack//lib/rack/request.rb#60
2886
+ Rack::Request::ALLOWED_SCHEMES = T.let(T.unsafe(nil), Array)
2887
+
2888
+ # source://rack//lib/rack/request.rb#82
2889
+ module Rack::Request::Env
2890
+ # source://rack//lib/rack/request.rb#86
2891
+ def initialize(env); end
2892
+
2893
+ # Add a header that may have multiple values.
2894
+ #
2895
+ # Example:
2896
+ # request.add_header 'Accept', 'image/png'
2897
+ # request.add_header 'Accept', '*/*'
2898
+ #
2899
+ # assert_equal 'image/png,*/*', request.get_header('Accept')
2900
+ #
2901
+ # http://www.w3.org/Protocols/rfc2616/rfc2616-sec4.html#sec4.2
2902
+ #
2903
+ # source://rack//lib/rack/request.rb#129
2904
+ def add_header(key, v); end
2905
+
2906
+ # Delete a request specific value for `name`.
2907
+ #
2908
+ # source://rack//lib/rack/request.rb#140
2909
+ def delete_header(name); end
2910
+
2911
+ # Loops through each key / value pair in the request specific data.
2912
+ #
2913
+ # source://rack//lib/rack/request.rb#111
2914
+ def each_header(&block); end
2915
+
2916
+ # The environment of the request.
2917
+ #
2918
+ # source://rack//lib/rack/request.rb#84
2919
+ def env; end
2920
+
2921
+ # If a block is given, it yields to the block if the value hasn't been set
2922
+ # on the request.
2923
+ #
2924
+ # source://rack//lib/rack/request.rb#106
2925
+ def fetch_header(name, &block); end
2926
+
2927
+ # Get a request specific value for `name`.
2928
+ #
2929
+ # source://rack//lib/rack/request.rb#100
2930
+ def get_header(name); end
2931
+
2932
+ # Predicate method to test to see if `name` has been set as request
2933
+ # specific data
2934
+ #
2935
+ # @return [Boolean]
2936
+ #
2937
+ # source://rack//lib/rack/request.rb#95
2938
+ def has_header?(name); end
2939
+
2940
+ # Set a request specific value for `name` to `v`
2941
+ #
2942
+ # source://rack//lib/rack/request.rb#116
2943
+ def set_header(name, v); end
2944
+
2945
+ private
2946
+
2947
+ # source://rack//lib/rack/request.rb#144
2948
+ def initialize_copy(other); end
2949
+ end
2950
+
2951
+ # source://rack//lib/rack/request.rb#149
2952
+ module Rack::Request::Helpers
2953
+ # Returns the data received in the query string.
2954
+ #
2955
+ # source://rack//lib/rack/request.rb#484
2956
+ def GET; end
2957
+
2958
+ # Returns the data received in the request body.
2959
+ #
2960
+ # This method support both application/x-www-form-urlencoded and
2961
+ # multipart/form-data.
2962
+ #
2963
+ # source://rack//lib/rack/request.rb#503
2964
+ def POST; end
2965
+
2966
+ # source://rack//lib/rack/request.rb#607
2967
+ def accept_encoding; end
2968
+
2969
+ # source://rack//lib/rack/request.rb#611
2970
+ def accept_language; end
2971
+
2972
+ # The authority of the incoming request as defined by RFC3976.
2973
+ # https://tools.ietf.org/html/rfc3986#section-3.2
2974
+ #
2975
+ # In HTTP/1, this is the `host` header.
2976
+ # In HTTP/2, this is the `:authority` pseudo-header.
2977
+ #
2978
+ # source://rack//lib/rack/request.rb#266
2979
+ def authority; end
2980
+
2981
+ # source://rack//lib/rack/request.rb#590
2982
+ def base_url; end
2983
+
2984
+ # source://rack//lib/rack/request.rb#190
2985
+ def body; end
2986
+
2987
+ # The character set of the request body if a "charset" media type
2988
+ # parameter was given, or nil if no "charset" was specified. Note
2989
+ # that, per RFC2616, text/* media types that specify no explicit
2990
+ # charset are to be considered ISO-8859-1.
2991
+ #
2992
+ # source://rack//lib/rack/request.rb#458
2993
+ def content_charset; end
2994
+
2995
+ # source://rack//lib/rack/request.rb#199
2996
+ def content_length; end
2997
+
2998
+ # source://rack//lib/rack/request.rb#308
2999
+ def content_type; end
3000
+
3001
+ # source://rack//lib/rack/request.rb#293
3002
+ def cookies; end
3003
+
3004
+ # Checks the HTTP request method (or verb) to see if it was of type DELETE
3005
+ #
3006
+ # @return [Boolean]
3007
+ #
3008
+ # source://rack//lib/rack/request.rb#220
3009
+ def delete?; end
3010
+
3011
+ # Destructively delete a parameter, whether it's in GET or POST. Returns the value of the deleted parameter.
3012
+ #
3013
+ # If the parameter is in both GET and POST, the POST value takes precedence since that's how #params works.
3014
+ #
3015
+ # <tt>env['rack.input']</tt> is not touched.
3016
+ #
3017
+ # source://rack//lib/rack/request.rb#585
3018
+ def delete_param(k); end
3019
+
3020
+ # Determine whether the request body contains form-data by checking
3021
+ # the request content-type for one of the media-types:
3022
+ # "application/x-www-form-urlencoded" or "multipart/form-data". The
3023
+ # list of form-data media types can be modified through the
3024
+ # +FORM_DATA_MEDIA_TYPES+ array.
3025
+ #
3026
+ # A request body is also assumed to contain form-data when no
3027
+ # content-type header is provided and the request_method is POST.
3028
+ #
3029
+ # @return [Boolean]
3030
+ #
3031
+ # source://rack//lib/rack/request.rb#470
3032
+ def form_data?; end
3033
+
3034
+ # source://rack//lib/rack/request.rb#393
3035
+ def forwarded_authority; end
3036
+
3037
+ # source://rack//lib/rack/request.rb#353
3038
+ def forwarded_for; end
3039
+
3040
+ # source://rack//lib/rack/request.rb#374
3041
+ def forwarded_port; end
3042
+
3043
+ # source://rack//lib/rack/request.rb#603
3044
+ def fullpath; end
3045
+
3046
+ # Checks the HTTP request method (or verb) to see if it was of type GET
3047
+ #
3048
+ # @return [Boolean]
3049
+ #
3050
+ # source://rack//lib/rack/request.rb#223
3051
+ def get?; end
3052
+
3053
+ # Checks the HTTP request method (or verb) to see if it was of type HEAD
3054
+ #
3055
+ # @return [Boolean]
3056
+ #
3057
+ # source://rack//lib/rack/request.rb#226
3058
+ def head?; end
3059
+
3060
+ # Returns a formatted host, suitable for being used in a URI.
3061
+ #
3062
+ # source://rack//lib/rack/request.rb#333
3063
+ def host; end
3064
+
3065
+ # The `HTTP_HOST` header.
3066
+ #
3067
+ # source://rack//lib/rack/request.rb#318
3068
+ def host_authority; end
3069
+
3070
+ # source://rack//lib/rack/request.rb#322
3071
+ def host_with_port(authority = T.unsafe(nil)); end
3072
+
3073
+ # Returns an address suitable for being to resolve to an address.
3074
+ # In the case of a domain name or IPv4 address, the result is the same
3075
+ # as +host+. In the case of IPv6 or future address formats, the square
3076
+ # brackets are removed.
3077
+ #
3078
+ # source://rack//lib/rack/request.rb#341
3079
+ def hostname; end
3080
+
3081
+ # source://rack//lib/rack/request.rb#414
3082
+ def ip; end
3083
+
3084
+ # Checks the HTTP request method (or verb) to see if it was of type LINK
3085
+ #
3086
+ # @return [Boolean]
3087
+ #
3088
+ # source://rack//lib/rack/request.rb#232
3089
+ def link?; end
3090
+
3091
+ # source://rack//lib/rack/request.rb#200
3092
+ def logger; end
3093
+
3094
+ # The media type (type/subtype) portion of the CONTENT_TYPE header
3095
+ # without any media type parameters. e.g., when CONTENT_TYPE is
3096
+ # "text/plain;charset=utf-8", the media-type is "text/plain".
3097
+ #
3098
+ # For more information on the use of media types in HTTP, see:
3099
+ # http://www.w3.org/Protocols/rfc2616/rfc2616-sec3.html#sec3.7
3100
+ #
3101
+ # source://rack//lib/rack/request.rb#441
3102
+ def media_type; end
3103
+
3104
+ # The media type parameters provided in CONTENT_TYPE as a Hash, or
3105
+ # an empty Hash if no CONTENT_TYPE or media-type parameters were
3106
+ # provided. e.g., when the CONTENT_TYPE is "text/plain;charset=utf-8",
3107
+ # this method responds with the following Hash:
3108
+ # { 'charset' => 'utf-8' }
3109
+ #
3110
+ # source://rack//lib/rack/request.rb#450
3111
+ def media_type_params; end
3112
+
3113
+ # Checks the HTTP request method (or verb) to see if it was of type OPTIONS
3114
+ #
3115
+ # @return [Boolean]
3116
+ #
3117
+ # source://rack//lib/rack/request.rb#229
3118
+ def options?; end
3119
+
3120
+ # The union of GET and POST data.
3121
+ #
3122
+ # Note that modifications will not be persisted in the env. Use update_param or delete_param if you want to destructively modify params.
3123
+ #
3124
+ # source://rack//lib/rack/request.rb#556
3125
+ def params; end
3126
+
3127
+ # Determine whether the request body contains data by checking
3128
+ # the request media_type against registered parse-data media-types
3129
+ #
3130
+ # @return [Boolean]
3131
+ #
3132
+ # source://rack//lib/rack/request.rb#479
3133
+ def parseable_data?; end
3134
+
3135
+ # Checks the HTTP request method (or verb) to see if it was of type PATCH
3136
+ #
3137
+ # @return [Boolean]
3138
+ #
3139
+ # source://rack//lib/rack/request.rb#235
3140
+ def patch?; end
3141
+
3142
+ # source://rack//lib/rack/request.rb#599
3143
+ def path; end
3144
+
3145
+ # source://rack//lib/rack/request.rb#194
3146
+ def path_info; end
3147
+
3148
+ # source://rack//lib/rack/request.rb#195
3149
+ def path_info=(s); end
3150
+
3151
+ # source://rack//lib/rack/request.rb#345
3152
+ def port; end
3153
+
3154
+ # Checks the HTTP request method (or verb) to see if it was of type POST
3155
+ #
3156
+ # @return [Boolean]
3157
+ #
3158
+ # source://rack//lib/rack/request.rb#238
3159
+ def post?; end
3160
+
3161
+ # Checks the HTTP request method (or verb) to see if it was of type PUT
3162
+ #
3163
+ # @return [Boolean]
3164
+ #
3165
+ # source://rack//lib/rack/request.rb#241
3166
+ def put?; end
3167
+
3168
+ # source://rack//lib/rack/request.rb#198
3169
+ def query_string; end
3170
+
3171
+ # the referer of the client
3172
+ #
3173
+ # source://rack//lib/rack/request.rb#204
3174
+ def referer; end
3175
+
3176
+ # the referer of the client
3177
+ #
3178
+ # source://rack//lib/rack/request.rb#204
3179
+ def referrer; end
3180
+
3181
+ # source://rack//lib/rack/request.rb#197
3182
+ def request_method; end
3183
+
3184
+ # source://rack//lib/rack/request.rb#249
3185
+ def scheme; end
3186
+
3187
+ # source://rack//lib/rack/request.rb#191
3188
+ def script_name; end
3189
+
3190
+ # source://rack//lib/rack/request.rb#192
3191
+ def script_name=(s); end
3192
+
3193
+ # The authority as defined by the `SERVER_NAME` and `SERVER_PORT`
3194
+ # variables.
3195
+ #
3196
+ # source://rack//lib/rack/request.rb#272
3197
+ def server_authority; end
3198
+
3199
+ # source://rack//lib/rack/request.rb#285
3200
+ def server_name; end
3201
+
3202
+ # source://rack//lib/rack/request.rb#289
3203
+ def server_port; end
3204
+
3205
+ # source://rack//lib/rack/request.rb#207
3206
+ def session; end
3207
+
3208
+ # source://rack//lib/rack/request.rb#213
3209
+ def session_options; end
3210
+
3211
+ # @return [Boolean]
3212
+ #
3213
+ # source://rack//lib/rack/request.rb#410
3214
+ def ssl?; end
3215
+
3216
+ # Checks the HTTP request method (or verb) to see if it was of type TRACE
3217
+ #
3218
+ # @return [Boolean]
3219
+ #
3220
+ # source://rack//lib/rack/request.rb#244
3221
+ def trace?; end
3222
+
3223
+ # @return [Boolean]
3224
+ #
3225
+ # source://rack//lib/rack/request.rb#615
3226
+ def trusted_proxy?(ip); end
3227
+
3228
+ # Checks the HTTP request method (or verb) to see if it was of type UNLINK
3229
+ #
3230
+ # @return [Boolean]
3231
+ #
3232
+ # source://rack//lib/rack/request.rb#247
3233
+ def unlink?; end
3234
+
3235
+ # Destructively update a parameter, whether it's in GET and/or POST. Returns nil.
3236
+ #
3237
+ # The parameter is updated wherever it was previous defined, so GET, POST, or both. If it wasn't previously defined, it's inserted into GET.
3238
+ #
3239
+ # <tt>env['rack.input']</tt> is not touched.
3240
+ #
3241
+ # source://rack//lib/rack/request.rb#565
3242
+ def update_param(k, v); end
3243
+
3244
+ # Tries to return a remake of the original request URL as a string.
3245
+ #
3246
+ # source://rack//lib/rack/request.rb#595
3247
+ def url; end
3248
+
3249
+ # source://rack//lib/rack/request.rb#201
3250
+ def user_agent; end
3251
+
3252
+ # like Hash#values_at
3253
+ #
3254
+ # source://rack//lib/rack/request.rb#620
3255
+ def values_at(*keys); end
3256
+
3257
+ # @return [Boolean]
3258
+ #
3259
+ # source://rack//lib/rack/request.rb#313
3260
+ def xhr?; end
3261
+
3262
+ private
3263
+
3264
+ # source://rack//lib/rack/request.rb#776
3265
+ def allowed_scheme(header); end
3266
+
3267
+ # source://rack//lib/rack/request.rb#628
3268
+ def default_session; end
3269
+
3270
+ # source://rack//lib/rack/request.rb#684
3271
+ def expand_param_pairs(pairs, query_parser = T.unsafe(nil)); end
3272
+
3273
+ # source://rack//lib/rack/request.rb#780
3274
+ def forwarded_priority; end
3275
+
3276
+ # source://rack//lib/rack/request.rb#752
3277
+ def forwarded_scheme; end
3278
+
3279
+ # Get an array of values set in the RFC 7239 `Forwarded` request header.
3280
+ #
3281
+ # source://rack//lib/rack/request.rb#668
3282
+ def get_http_forwarded(token); end
3283
+
3284
+ # source://rack//lib/rack/request.rb#644
3285
+ def parse_http_accept_header(header); end
3286
+
3287
+ # source://rack//lib/rack/request.rb#680
3288
+ def parse_multipart; end
3289
+
3290
+ # source://rack//lib/rack/request.rb#676
3291
+ def parse_query(qs, d = T.unsafe(nil)); end
3292
+
3293
+ # source://rack//lib/rack/request.rb#672
3294
+ def query_parser; end
3295
+
3296
+ # source://rack//lib/rack/request.rb#743
3297
+ def reject_trusted_ip_addresses(ip_addresses); end
3298
+
3299
+ # source://rack//lib/rack/request.rb#737
3300
+ def split_authority(authority); end
3301
+
3302
+ # source://rack//lib/rack/request.rb#694
3303
+ def split_header(value); end
3304
+
3305
+ # Assist with compatibility when processing `X-Forwarded-For`.
3306
+ #
3307
+ # source://rack//lib/rack/request.rb#631
3308
+ def wrap_ipv6(host); end
3309
+
3310
+ # source://rack//lib/rack/request.rb#784
3311
+ def x_forwarded_proto_priority; end
3312
+ end
3313
+
3314
+ # source://rack//lib/rack/request.rb#722
3315
+ Rack::Request::Helpers::AUTHORITY = T.let(T.unsafe(nil), Regexp)
3316
+
3317
+ # Default ports depending on scheme. Used to decide whether or not
3318
+ # to include the port in a generated URI.
3319
+ #
3320
+ # source://rack//lib/rack/request.rb#168
3321
+ Rack::Request::Helpers::DEFAULT_PORTS = T.let(T.unsafe(nil), Hash)
3322
+
3323
+ # The set of form-data media-types. Requests that do not indicate
3324
+ # one of the media types present in this list will not be eligible
3325
+ # for form-data / param parsing.
3326
+ #
3327
+ # source://rack//lib/rack/request.rb#153
3328
+ Rack::Request::Helpers::FORM_DATA_MEDIA_TYPES = T.let(T.unsafe(nil), Array)
3329
+
3330
+ # source://rack//lib/rack/request.rb#747
3331
+ Rack::Request::Helpers::FORWARDED_SCHEME_HEADERS = T.let(T.unsafe(nil), Hash)
3332
+
3333
+ # source://rack//lib/rack/request.rb#176
3334
+ Rack::Request::Helpers::HTTP_FORWARDED = T.let(T.unsafe(nil), String)
3335
+
3336
+ # The address of the client which connected to the proxy.
3337
+ #
3338
+ # source://rack//lib/rack/request.rb#171
3339
+ Rack::Request::Helpers::HTTP_X_FORWARDED_FOR = T.let(T.unsafe(nil), String)
3340
+
3341
+ # The contents of the host/:authority header sent to the proxy.
3342
+ #
3343
+ # source://rack//lib/rack/request.rb#174
3344
+ Rack::Request::Helpers::HTTP_X_FORWARDED_HOST = T.let(T.unsafe(nil), String)
3345
+
3346
+ # The port used to connect to the proxy.
3347
+ #
3348
+ # source://rack//lib/rack/request.rb#185
3349
+ Rack::Request::Helpers::HTTP_X_FORWARDED_PORT = T.let(T.unsafe(nil), String)
3350
+
3351
+ # The protocol used to connect to the proxy.
3352
+ #
3353
+ # source://rack//lib/rack/request.rb#182
3354
+ Rack::Request::Helpers::HTTP_X_FORWARDED_PROTO = T.let(T.unsafe(nil), String)
3355
+
3356
+ # The value of the scheme sent to the proxy.
3357
+ #
3358
+ # source://rack//lib/rack/request.rb#179
3359
+ Rack::Request::Helpers::HTTP_X_FORWARDED_SCHEME = T.let(T.unsafe(nil), String)
3360
+
3361
+ # Another way for specifying https scheme was used.
3362
+ #
3363
+ # source://rack//lib/rack/request.rb#188
3364
+ Rack::Request::Helpers::HTTP_X_FORWARDED_SSL = T.let(T.unsafe(nil), String)
3365
+
3366
+ # The set of media-types. Requests that do not indicate
3367
+ # one of the media types present in this list will not be eligible
3368
+ # for param parsing like soap attachments or generic multiparts
3369
+ #
3370
+ # source://rack//lib/rack/request.rb#161
3371
+ Rack::Request::Helpers::PARSEABLE_DATA_MEDIA_TYPES = T.let(T.unsafe(nil), Array)
3372
+
3373
+ # Rack::Response provides a convenient interface to create a Rack
3374
+ # response.
3375
+ #
3376
+ # It allows setting of headers and cookies, and provides useful
3377
+ # defaults (an OK response with empty headers and body).
3378
+ #
3379
+ # You can use Response#write to iteratively generate your response,
3380
+ # but note that this is buffered by Rack::Response until you call
3381
+ # +finish+. +finish+ however can take a block inside which calls to
3382
+ # +write+ are synchronous with the Rack response.
3383
+ #
3384
+ # Your application's +call+ should end returning Response#finish.
3385
+ #
3386
+ # source://rack//lib/rack/response.rb#23
3387
+ class Rack::Response
3388
+ include ::Rack::Response::Helpers
3389
+
3390
+ # Initialize the response object with the specified +body+, +status+
3391
+ # and +headers+.
3392
+ #
3393
+ # If the +body+ is +nil+, construct an empty response object with internal
3394
+ # buffering.
3395
+ #
3396
+ # If the +body+ responds to +to_str+, assume it's a string-like object and
3397
+ # construct a buffered response object containing using that string as the
3398
+ # initial contents of the buffer.
3399
+ #
3400
+ # Otherwise it is expected +body+ conforms to the normal requirements of a
3401
+ # Rack response body, typically implementing one of +each+ (enumerable
3402
+ # body) or +call+ (streaming body).
3403
+ #
3404
+ # The +status+ defaults to +200+ which is the "OK" HTTP status code. You
3405
+ # can provide any other valid status code.
3406
+ #
3407
+ # The +headers+ must be a +Hash+ of key-value header pairs which conform to
3408
+ # the Rack specification for response headers. The key must be a +String+
3409
+ # instance and the value can be either a +String+ or +Array+ instance.
3410
+ #
3411
+ # @return [Response] a new instance of Response
3412
+ # @yield [_self]
3413
+ # @yieldparam _self [Rack::Response] the object that the method was called on
3414
+ #
3415
+ # source://rack//lib/rack/response.rb#54
3416
+ def initialize(body = T.unsafe(nil), status = T.unsafe(nil), headers = T.unsafe(nil)); end
3417
+
3418
+ # @raise [ArgumentError]
3419
+ #
3420
+ # source://rack//lib/rack/response.rb#164
3421
+ def [](key); end
3422
+
3423
+ # @raise [ArgumentError]
3424
+ #
3425
+ # source://rack//lib/rack/response.rb#168
3426
+ def []=(key, value); end
3427
+
3428
+ # Returns the value of attribute body.
3429
+ #
3430
+ # source://rack//lib/rack/response.rb#31
3431
+ def body; end
3432
+
3433
+ # Sets the attribute body
3434
+ #
3435
+ # @param value the value to set the attribute body to.
3436
+ #
3437
+ # source://rack//lib/rack/response.rb#31
3438
+ def body=(_arg0); end
3439
+
3440
+ # @return [Boolean]
3441
+ #
3442
+ # source://rack//lib/rack/response.rb#95
3443
+ def chunked?; end
3444
+
3445
+ # source://rack//lib/rack/response.rb#152
3446
+ def close; end
3447
+
3448
+ # @raise [ArgumentError]
3449
+ #
3450
+ # source://rack//lib/rack/response.rb#172
3451
+ def delete_header(key); end
3452
+
3453
+ # source://rack//lib/rack/response.rb#130
3454
+ def each(&callback); end
3455
+
3456
+ # @return [Boolean]
3457
+ #
3458
+ # source://rack//lib/rack/response.rb#156
3459
+ def empty?; end
3460
+
3461
+ # Generate a response array consistent with the requirements of the SPEC.
3462
+ # which is suitable to be returned from the middleware `#call(env)` method.
3463
+ #
3464
+ # @return [Array] a 3-tuple suitable of `[status, headers, body]`
3465
+ #
3466
+ # source://rack//lib/rack/response.rb#107
3467
+ def finish(&block); end
3468
+
3469
+ # @raise [ArgumentError]
3470
+ #
3471
+ # source://rack//lib/rack/response.rb#164
3472
+ def get_header(key); end
3473
+
3474
+ # @raise [ArgumentError]
3475
+ # @return [Boolean]
3476
+ #
3477
+ # source://rack//lib/rack/response.rb#160
3478
+ def has_header?(key); end
3479
+
3480
+ # Returns the value of attribute headers.
3481
+ #
3482
+ # source://rack//lib/rack/response.rb#32
3483
+ def headers; end
3484
+
3485
+ # Returns the value of attribute length.
3486
+ #
3487
+ # source://rack//lib/rack/response.rb#31
3488
+ def length; end
3489
+
3490
+ # Sets the attribute length
3491
+ #
3492
+ # @param value the value to set the attribute length to.
3493
+ #
3494
+ # source://rack//lib/rack/response.rb#31
3495
+ def length=(_arg0); end
3496
+
3497
+ # @return [Boolean]
3498
+ #
3499
+ # source://rack//lib/rack/response.rb#99
3500
+ def no_entity_body?; end
3501
+
3502
+ # source://rack//lib/rack/response.rb#90
3503
+ def redirect(target, status = T.unsafe(nil)); end
3504
+
3505
+ # @raise [ArgumentError]
3506
+ #
3507
+ # source://rack//lib/rack/response.rb#168
3508
+ def set_header(key, value); end
3509
+
3510
+ # Returns the value of attribute status.
3511
+ #
3512
+ # source://rack//lib/rack/response.rb#31
3513
+ def status; end
3514
+
3515
+ # Sets the attribute status
3516
+ #
3517
+ # @param value the value to set the attribute status to.
3518
+ #
3519
+ # source://rack//lib/rack/response.rb#31
3520
+ def status=(_arg0); end
3521
+
3522
+ # Generate a response array consistent with the requirements of the SPEC.
3523
+ # which is suitable to be returned from the middleware `#call(env)` method.
3524
+ # For *response
3525
+ #
3526
+ # @return [Array] a 3-tuple suitable of `[status, headers, body]`
3527
+ #
3528
+ # source://rack//lib/rack/response.rb#107
3529
+ def to_a(&block); end
3530
+
3531
+ # Append a chunk to the response body.
3532
+ #
3533
+ # Converts the response into a buffered response if it wasn't already.
3534
+ #
3535
+ # NOTE: Do not mix #write and direct #body access!
3536
+ #
3537
+ # source://rack//lib/rack/response.rb#146
3538
+ def write(chunk); end
3539
+
3540
+ class << self
3541
+ # source://rack//lib/rack/response.rb#24
3542
+ def [](status, headers, body); end
3543
+ end
3544
+ end
3545
+
3546
+ # source://rack//lib/rack/response.rb#28
3547
+ Rack::Response::CHUNKED = T.let(T.unsafe(nil), String)
3548
+
3549
+ # source://rack//lib/rack/response.rb#180
3550
+ module Rack::Response::Helpers
3551
+ # @return [Boolean]
3552
+ #
3553
+ # source://rack//lib/rack/response.rb#191
3554
+ def accepted?; end
3555
+
3556
+ # Add a header that may have multiple values.
3557
+ #
3558
+ # Example:
3559
+ # response.add_header 'vary', 'accept-encoding'
3560
+ # response.add_header 'vary', 'cookie'
3561
+ #
3562
+ # assert_equal 'accept-encoding,cookie', response.get_header('vary')
3563
+ #
3564
+ # http://www.w3.org/Protocols/rfc2616/rfc2616-sec4.html#sec4.2
3565
+ #
3566
+ # @raise [ArgumentError]
3567
+ #
3568
+ # source://rack//lib/rack/response.rb#219
3569
+ def add_header(key, value); end
3570
+
3571
+ # @return [Boolean]
3572
+ #
3573
+ # source://rack//lib/rack/response.rb#194
3574
+ def bad_request?; end
3575
+
3576
+ # Specify that the content should be cached.
3577
+ #
3578
+ # @option directive
3579
+ # @param duration [Integer] The number of seconds until the cache expires.
3580
+ # @param directive [Hash] a customizable set of options
3581
+ #
3582
+ # source://rack//lib/rack/response.rb#307
3583
+ def cache!(duration = T.unsafe(nil), directive: T.unsafe(nil)); end
3584
+
3585
+ # source://rack//lib/rack/response.rb#290
3586
+ def cache_control; end
3587
+
3588
+ # source://rack//lib/rack/response.rb#294
3589
+ def cache_control=(value); end
3590
+
3591
+ # @return [Boolean]
3592
+ #
3593
+ # source://rack//lib/rack/response.rb#186
3594
+ def client_error?; end
3595
+
3596
+ # source://rack//lib/rack/response.rb#257
3597
+ def content_length; end
3598
+
3599
+ # Get the content type of the response.
3600
+ #
3601
+ # source://rack//lib/rack/response.rb#240
3602
+ def content_type; end
3603
+
3604
+ # Set the content type of the response.
3605
+ #
3606
+ # source://rack//lib/rack/response.rb#245
3607
+ def content_type=(content_type); end
3608
+
3609
+ # @return [Boolean]
3610
+ #
3611
+ # source://rack//lib/rack/response.rb#190
3612
+ def created?; end
3613
+
3614
+ # source://rack//lib/rack/response.rb#274
3615
+ def delete_cookie(key, value = T.unsafe(nil)); end
3616
+
3617
+ # Specifies that the content shouldn't be cached. Overrides `cache!` if already called.
3618
+ #
3619
+ # source://rack//lib/rack/response.rb#299
3620
+ def do_not_cache!; end
3621
+
3622
+ # source://rack//lib/rack/response.rb#314
3623
+ def etag; end
3624
+
3625
+ # source://rack//lib/rack/response.rb#318
3626
+ def etag=(value); end
3627
+
3628
+ # @return [Boolean]
3629
+ #
3630
+ # source://rack//lib/rack/response.rb#196
3631
+ def forbidden?; end
3632
+
3633
+ # @return [Boolean]
3634
+ #
3635
+ # source://rack//lib/rack/response.rb#206
3636
+ def include?(header); end
3637
+
3638
+ # @return [Boolean]
3639
+ #
3640
+ # source://rack//lib/rack/response.rb#183
3641
+ def informational?; end
3642
+
3643
+ # @return [Boolean]
3644
+ #
3645
+ # source://rack//lib/rack/response.rb#181
3646
+ def invalid?; end
3647
+
3648
+ # source://rack//lib/rack/response.rb#262
3649
+ def location; end
3650
+
3651
+ # source://rack//lib/rack/response.rb#266
3652
+ def location=(location); end
3653
+
3654
+ # source://rack//lib/rack/response.rb#249
3655
+ def media_type; end
3656
+
3657
+ # source://rack//lib/rack/response.rb#253
3658
+ def media_type_params; end
3659
+
3660
+ # @return [Boolean]
3661
+ #
3662
+ # source://rack//lib/rack/response.rb#198
3663
+ def method_not_allowed?; end
3664
+
3665
+ # @return [Boolean]
3666
+ #
3667
+ # source://rack//lib/rack/response.rb#193
3668
+ def moved_permanently?; end
3669
+
3670
+ # @return [Boolean]
3671
+ #
3672
+ # source://rack//lib/rack/response.rb#192
3673
+ def no_content?; end
3674
+
3675
+ # @return [Boolean]
3676
+ #
3677
+ # source://rack//lib/rack/response.rb#199
3678
+ def not_acceptable?; end
3679
+
3680
+ # @return [Boolean]
3681
+ #
3682
+ # source://rack//lib/rack/response.rb#197
3683
+ def not_found?; end
3684
+
3685
+ # @return [Boolean]
3686
+ #
3687
+ # source://rack//lib/rack/response.rb#189
3688
+ def ok?; end
3689
+
3690
+ # @return [Boolean]
3691
+ #
3692
+ # source://rack//lib/rack/response.rb#201
3693
+ def precondition_failed?; end
3694
+
3695
+ # @return [Boolean]
3696
+ #
3697
+ # source://rack//lib/rack/response.rb#204
3698
+ def redirect?; end
3699
+
3700
+ # @return [Boolean]
3701
+ #
3702
+ # source://rack//lib/rack/response.rb#185
3703
+ def redirection?; end
3704
+
3705
+ # @return [Boolean]
3706
+ #
3707
+ # source://rack//lib/rack/response.rb#200
3708
+ def request_timeout?; end
3709
+
3710
+ # @return [Boolean]
3711
+ #
3712
+ # source://rack//lib/rack/response.rb#187
3713
+ def server_error?; end
3714
+
3715
+ # source://rack//lib/rack/response.rb#270
3716
+ def set_cookie(key, value); end
3717
+
3718
+ # source://rack//lib/rack/response.rb#282
3719
+ def set_cookie_header; end
3720
+
3721
+ # source://rack//lib/rack/response.rb#286
3722
+ def set_cookie_header=(value); end
3723
+
3724
+ # @return [Boolean]
3725
+ #
3726
+ # source://rack//lib/rack/response.rb#184
3727
+ def successful?; end
3728
+
3729
+ # @return [Boolean]
3730
+ #
3731
+ # source://rack//lib/rack/response.rb#195
3732
+ def unauthorized?; end
3733
+
3734
+ # @return [Boolean]
3735
+ #
3736
+ # source://rack//lib/rack/response.rb#202
3737
+ def unprocessable?; end
3738
+
3739
+ protected
3740
+
3741
+ # source://rack//lib/rack/response.rb#359
3742
+ def append(chunk); end
3743
+
3744
+ # Convert the body of this response into an internally buffered Array if possible.
3745
+ #
3746
+ # `@buffered` is a ternary value which indicates whether the body is buffered. It can be:
3747
+ # * `nil` - The body has not been buffered yet.
3748
+ # * `true` - The body is buffered as an Array instance.
3749
+ # * `false` - The body is not buffered and cannot be buffered.
3750
+ #
3751
+ # @return [Boolean] whether the body is buffered as an Array instance.
3752
+ #
3753
+ # source://rack//lib/rack/response.rb#332
3754
+ def buffered_body!; end
3755
+ end
3756
+
3757
+ # source://rack//lib/rack/response.rb#375
3758
+ class Rack::Response::Raw
3759
+ include ::Rack::Response::Helpers
3760
+
3761
+ # @return [Raw] a new instance of Raw
3762
+ #
3763
+ # source://rack//lib/rack/response.rb#381
3764
+ def initialize(status, headers); end
3765
+
3766
+ # source://rack//lib/rack/response.rb#398
3767
+ def delete_header(key); end
3768
+
3769
+ # source://rack//lib/rack/response.rb#390
3770
+ def get_header(key); end
3771
+
3772
+ # @return [Boolean]
3773
+ #
3774
+ # source://rack//lib/rack/response.rb#386
3775
+ def has_header?(key); end
3776
+
3777
+ # Returns the value of attribute headers.
3778
+ #
3779
+ # source://rack//lib/rack/response.rb#378
3780
+ def headers; end
3781
+
3782
+ # source://rack//lib/rack/response.rb#394
3783
+ def set_header(key, value); end
3784
+
3785
+ # Returns the value of attribute status.
3786
+ #
3787
+ # source://rack//lib/rack/response.rb#379
3788
+ def status; end
3789
+
3790
+ # Sets the attribute status
3791
+ #
3792
+ # @param value the value to set the attribute status to.
3793
+ #
3794
+ # source://rack//lib/rack/response.rb#379
3795
+ def status=(_arg0); end
3796
+ end
3797
+
3798
+ # source://rack//lib/rack/response.rb#29
3799
+ Rack::Response::STATUS_WITH_NO_ENTITY_BODY = T.let(T.unsafe(nil), Hash)
3800
+
3801
+ # Class which can make any IO object rewindable, including non-rewindable ones. It does
3802
+ # this by buffering the data into a tempfile, which is rewindable.
3803
+ #
3804
+ # Don't forget to call #close when you're done. This frees up temporary resources that
3805
+ # RewindableInput uses, though it does *not* close the original IO object.
3806
+ #
3807
+ # source://rack//lib/rack/rewindable_input.rb#14
3808
+ class Rack::RewindableInput
3809
+ # @return [RewindableInput] a new instance of RewindableInput
3810
+ #
3811
+ # source://rack//lib/rack/rewindable_input.rb#29
3812
+ def initialize(io); end
3813
+
3814
+ # Closes this RewindableInput object without closing the originally
3815
+ # wrapped IO object. Cleans up any temporary resources that this RewindableInput
3816
+ # has created.
3817
+ #
3818
+ # This method may be called multiple times. It does nothing on subsequent calls.
3819
+ #
3820
+ # source://rack//lib/rack/rewindable_input.rb#65
3821
+ def close; end
3822
+
3823
+ # source://rack//lib/rack/rewindable_input.rb#45
3824
+ def each(&block); end
3825
+
3826
+ # source://rack//lib/rack/rewindable_input.rb#35
3827
+ def gets; end
3828
+
3829
+ # source://rack//lib/rack/rewindable_input.rb#40
3830
+ def read(*args); end
3831
+
3832
+ # source://rack//lib/rack/rewindable_input.rb#50
3833
+ def rewind; end
3834
+
3835
+ # source://rack//lib/rack/rewindable_input.rb#55
3836
+ def size; end
3837
+
3838
+ private
3839
+
3840
+ # @return [Boolean]
3841
+ #
3842
+ # source://rack//lib/rack/rewindable_input.rb#109
3843
+ def filesystem_has_posix_semantics?; end
3844
+
3845
+ # source://rack//lib/rack/rewindable_input.rb#78
3846
+ def make_rewindable; end
3847
+ end
3848
+
3849
+ # Makes rack.input rewindable, for compatibility with applications and middleware
3850
+ # designed for earlier versions of Rack (where rack.input was required to be
3851
+ # rewindable).
3852
+ #
3853
+ # source://rack//lib/rack/rewindable_input.rb#18
3854
+ class Rack::RewindableInput::Middleware
3855
+ # @return [Middleware] a new instance of Middleware
3856
+ #
3857
+ # source://rack//lib/rack/rewindable_input.rb#19
3858
+ def initialize(app); end
3859
+
3860
+ # source://rack//lib/rack/rewindable_input.rb#23
3861
+ def call(env); end
3862
+ end
3863
+
3864
+ # Sets an "x-runtime" response header, indicating the response
3865
+ # time of the request, in seconds
3866
+ #
3867
+ # You can put it right before the application to see the processing
3868
+ # time, or before all the other middlewares to include time for them,
3869
+ # too.
3870
+ #
3871
+ # source://rack//lib/rack/runtime.rb#12
3872
+ class Rack::Runtime
3873
+ # @return [Runtime] a new instance of Runtime
3874
+ #
3875
+ # source://rack//lib/rack/runtime.rb#16
3876
+ def initialize(app, name = T.unsafe(nil)); end
3877
+
3878
+ # source://rack//lib/rack/runtime.rb#22
3879
+ def call(env); end
3880
+ end
3881
+
3882
+ # source://rack//lib/rack/runtime.rb#13
3883
+ Rack::Runtime::FORMAT_STRING = T.let(T.unsafe(nil), String)
3884
+
3885
+ # source://rack//lib/rack/runtime.rb#14
3886
+ Rack::Runtime::HEADER_NAME = T.let(T.unsafe(nil), String)
3887
+
3888
+ # source://rack//lib/rack/constants.rb#11
3889
+ Rack::SCRIPT_NAME = T.let(T.unsafe(nil), String)
3890
+
3891
+ # source://rack//lib/rack/constants.rb#14
3892
+ Rack::SERVER_NAME = T.let(T.unsafe(nil), String)
3893
+
3894
+ # source://rack//lib/rack/constants.rb#15
3895
+ Rack::SERVER_PORT = T.let(T.unsafe(nil), String)
3896
+
3897
+ # source://rack//lib/rack/constants.rb#13
3898
+ Rack::SERVER_PROTOCOL = T.let(T.unsafe(nil), String)
3899
+
3900
+ # source://rack//lib/rack/constants.rb#24
3901
+ Rack::SET_COOKIE = T.let(T.unsafe(nil), String)
3902
+
3903
+ # = Sendfile
3904
+ #
3905
+ # The Sendfile middleware intercepts responses whose body is being
3906
+ # served from a file and replaces it with a server specific x-sendfile
3907
+ # header. The web server is then responsible for writing the file contents
3908
+ # to the client. This can dramatically reduce the amount of work required
3909
+ # by the Ruby backend and takes advantage of the web server's optimized file
3910
+ # delivery code.
3911
+ #
3912
+ # In order to take advantage of this middleware, the response body must
3913
+ # respond to +to_path+ and the request must include an x-sendfile-type
3914
+ # header. Rack::Files and other components implement +to_path+ so there's
3915
+ # rarely anything you need to do in your application. The x-sendfile-type
3916
+ # header is typically set in your web servers configuration. The following
3917
+ # sections attempt to document
3918
+ #
3919
+ # === Nginx
3920
+ #
3921
+ # Nginx supports the x-accel-redirect header. This is similar to x-sendfile
3922
+ # but requires parts of the filesystem to be mapped into a private URL
3923
+ # hierarchy.
3924
+ #
3925
+ # The following example shows the Nginx configuration required to create
3926
+ # a private "/files/" area, enable x-accel-redirect, and pass the special
3927
+ # x-sendfile-type and x-accel-mapping headers to the backend:
3928
+ #
3929
+ # location ~ /files/(.*) {
3930
+ # internal;
3931
+ # alias /var/www/$1;
3932
+ # }
3933
+ #
3934
+ # location / {
3935
+ # proxy_redirect off;
3936
+ #
3937
+ # proxy_set_header Host $host;
3938
+ # proxy_set_header X-Real-IP $remote_addr;
3939
+ # proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
3940
+ #
3941
+ # proxy_set_header x-sendfile-type x-accel-redirect;
3942
+ # proxy_set_header x-accel-mapping /var/www/=/files/;
3943
+ #
3944
+ # proxy_pass http://127.0.0.1:8080/;
3945
+ # }
3946
+ #
3947
+ # Note that the x-sendfile-type header must be set exactly as shown above.
3948
+ # The x-accel-mapping header should specify the location on the file system,
3949
+ # followed by an equals sign (=), followed name of the private URL pattern
3950
+ # that it maps to. The middleware performs a simple substitution on the
3951
+ # resulting path.
3952
+ #
3953
+ # See Also: https://www.nginx.com/resources/wiki/start/topics/examples/xsendfile
3954
+ #
3955
+ # === lighttpd
3956
+ #
3957
+ # Lighttpd has supported some variation of the x-sendfile header for some
3958
+ # time, although only recent version support x-sendfile in a reverse proxy
3959
+ # configuration.
3960
+ #
3961
+ # $HTTP["host"] == "example.com" {
3962
+ # proxy-core.protocol = "http"
3963
+ # proxy-core.balancer = "round-robin"
3964
+ # proxy-core.backends = (
3965
+ # "127.0.0.1:8000",
3966
+ # "127.0.0.1:8001",
3967
+ # ...
3968
+ # )
3969
+ #
3970
+ # proxy-core.allow-x-sendfile = "enable"
3971
+ # proxy-core.rewrite-request = (
3972
+ # "x-sendfile-type" => (".*" => "x-sendfile")
3973
+ # )
3974
+ # }
3975
+ #
3976
+ # See Also: http://redmine.lighttpd.net/wiki/lighttpd/Docs:ModProxyCore
3977
+ #
3978
+ # === Apache
3979
+ #
3980
+ # x-sendfile is supported under Apache 2.x using a separate module:
3981
+ #
3982
+ # https://tn123.org/mod_xsendfile/
3983
+ #
3984
+ # Once the module is compiled and installed, you can enable it using
3985
+ # XSendFile config directive:
3986
+ #
3987
+ # RequestHeader Set x-sendfile-type x-sendfile
3988
+ # ProxyPassReverse / http://localhost:8001/
3989
+ # XSendFile on
3990
+ #
3991
+ # === Mapping parameter
3992
+ #
3993
+ # The third parameter allows for an overriding extension of the
3994
+ # x-accel-mapping header. Mappings should be provided in tuples of internal to
3995
+ # external. The internal values may contain regular expression syntax, they
3996
+ # will be matched with case indifference.
3997
+ #
3998
+ # source://rack//lib/rack/sendfile.rb#104
3999
+ class Rack::Sendfile
4000
+ # @return [Sendfile] a new instance of Sendfile
4001
+ #
4002
+ # source://rack//lib/rack/sendfile.rb#105
4003
+ def initialize(app, variation = T.unsafe(nil), mappings = T.unsafe(nil)); end
4004
+
4005
+ # source://rack//lib/rack/sendfile.rb#113
4006
+ def call(env); end
4007
+
4008
+ private
4009
+
4010
+ # source://rack//lib/rack/sendfile.rb#154
4011
+ def map_accel_path(env, path); end
4012
+
4013
+ # source://rack//lib/rack/sendfile.rb#148
4014
+ def variation(env); end
4015
+ end
4016
+
4017
+ # Rack::ShowExceptions catches all exceptions raised from the app it
4018
+ # wraps. It shows a useful backtrace with the sourcefile and
4019
+ # clickable context, the whole Rack environment and the request
4020
+ # data.
4021
+ #
4022
+ # Be careful when you use this on public-facing sites as it could
4023
+ # reveal information helpful to attackers.
4024
+ #
4025
+ # source://rack//lib/rack/show_exceptions.rb#18
4026
+ class Rack::ShowExceptions
4027
+ # @return [ShowExceptions] a new instance of ShowExceptions
4028
+ #
4029
+ # source://rack//lib/rack/show_exceptions.rb#26
4030
+ def initialize(app); end
4031
+
4032
+ # source://rack//lib/rack/show_exceptions.rb#30
4033
+ def call(env); end
4034
+
4035
+ # source://rack//lib/rack/show_exceptions.rb#65
4036
+ def dump_exception(exception); end
4037
+
4038
+ # source://rack//lib/rack/show_exceptions.rb#116
4039
+ def h(obj); end
4040
+
4041
+ # @return [Boolean]
4042
+ #
4043
+ # source://rack//lib/rack/show_exceptions.rb#56
4044
+ def prefers_plaintext?(env); end
4045
+
4046
+ # source://rack//lib/rack/show_exceptions.rb#76
4047
+ def pretty(env, exception); end
4048
+
4049
+ # source://rack//lib/rack/show_exceptions.rb#112
4050
+ def template; end
4051
+
4052
+ private
4053
+
4054
+ # @return [Boolean]
4055
+ #
4056
+ # source://rack//lib/rack/show_exceptions.rb#60
4057
+ def accepts_html?(env); end
4058
+ end
4059
+
4060
+ # source://rack//lib/rack/show_exceptions.rb#19
4061
+ Rack::ShowExceptions::CONTEXT = T.let(T.unsafe(nil), Integer)
4062
+
4063
+ # source://rack//lib/rack/show_exceptions.rb#21
4064
+ class Rack::ShowExceptions::Frame < ::Struct
4065
+ # Returns the value of attribute context_line
4066
+ #
4067
+ # @return [Object] the current value of context_line
4068
+ def context_line; end
4069
+
4070
+ # Sets the attribute context_line
4071
+ #
4072
+ # @param value [Object] the value to set the attribute context_line to.
4073
+ # @return [Object] the newly set value
4074
+ def context_line=(_); end
4075
+
4076
+ # Returns the value of attribute filename
4077
+ #
4078
+ # @return [Object] the current value of filename
4079
+ def filename; end
4080
+
4081
+ # Sets the attribute filename
4082
+ #
4083
+ # @param value [Object] the value to set the attribute filename to.
4084
+ # @return [Object] the newly set value
4085
+ def filename=(_); end
4086
+
4087
+ # Returns the value of attribute function
4088
+ #
4089
+ # @return [Object] the current value of function
4090
+ def function; end
4091
+
4092
+ # Sets the attribute function
4093
+ #
4094
+ # @param value [Object] the value to set the attribute function to.
4095
+ # @return [Object] the newly set value
4096
+ def function=(_); end
4097
+
4098
+ # Returns the value of attribute lineno
4099
+ #
4100
+ # @return [Object] the current value of lineno
4101
+ def lineno; end
4102
+
4103
+ # Sets the attribute lineno
4104
+ #
4105
+ # @param value [Object] the value to set the attribute lineno to.
4106
+ # @return [Object] the newly set value
4107
+ def lineno=(_); end
4108
+
4109
+ # Returns the value of attribute post_context
4110
+ #
4111
+ # @return [Object] the current value of post_context
4112
+ def post_context; end
4113
+
4114
+ # Sets the attribute post_context
4115
+ #
4116
+ # @param value [Object] the value to set the attribute post_context to.
4117
+ # @return [Object] the newly set value
4118
+ def post_context=(_); end
4119
+
4120
+ # Returns the value of attribute post_context_lineno
4121
+ #
4122
+ # @return [Object] the current value of post_context_lineno
4123
+ def post_context_lineno; end
4124
+
4125
+ # Sets the attribute post_context_lineno
4126
+ #
4127
+ # @param value [Object] the value to set the attribute post_context_lineno to.
4128
+ # @return [Object] the newly set value
4129
+ def post_context_lineno=(_); end
4130
+
4131
+ # Returns the value of attribute pre_context
4132
+ #
4133
+ # @return [Object] the current value of pre_context
4134
+ def pre_context; end
4135
+
4136
+ # Sets the attribute pre_context
4137
+ #
4138
+ # @param value [Object] the value to set the attribute pre_context to.
4139
+ # @return [Object] the newly set value
4140
+ def pre_context=(_); end
4141
+
4142
+ # Returns the value of attribute pre_context_lineno
4143
+ #
4144
+ # @return [Object] the current value of pre_context_lineno
4145
+ def pre_context_lineno; end
4146
+
4147
+ # Sets the attribute pre_context_lineno
4148
+ #
4149
+ # @param value [Object] the value to set the attribute pre_context_lineno to.
4150
+ # @return [Object] the newly set value
4151
+ def pre_context_lineno=(_); end
4152
+
4153
+ class << self
4154
+ def [](*_arg0); end
4155
+ def inspect; end
4156
+ def keyword_init?; end
4157
+ def members; end
4158
+ def new(*_arg0); end
4159
+ end
4160
+ end
4161
+
4162
+ # source://rack//lib/rack/show_exceptions.rb#131
4163
+ Rack::ShowExceptions::TEMPLATE = T.let(T.unsafe(nil), ERB)
4164
+
4165
+ # Rack::ShowStatus catches all empty responses and replaces them
4166
+ # with a site explaining the error.
4167
+ #
4168
+ # Additional details can be put into <tt>rack.showstatus.detail</tt>
4169
+ # and will be shown as HTML. If such details exist, the error page
4170
+ # is always rendered, even if the reply was not empty.
4171
+ #
4172
+ # source://rack//lib/rack/show_status.rb#18
4173
+ class Rack::ShowStatus
4174
+ # @return [ShowStatus] a new instance of ShowStatus
4175
+ #
4176
+ # source://rack//lib/rack/show_status.rb#19
4177
+ def initialize(app); end
4178
+
4179
+ # source://rack//lib/rack/show_status.rb#24
4180
+ def call(env); end
4181
+
4182
+ # source://rack//lib/rack/show_status.rb#54
4183
+ def h(obj); end
4184
+ end
4185
+
4186
+ # source://rack//lib/rack/show_status.rb#69
4187
+ Rack::ShowStatus::TEMPLATE = T.let(T.unsafe(nil), String)
4188
+
4189
+ # The Rack::Static middleware intercepts requests for static files
4190
+ # (javascript files, images, stylesheets, etc) based on the url prefixes or
4191
+ # route mappings passed in the options, and serves them using a Rack::Files
4192
+ # object. This allows a Rack stack to serve both static and dynamic content.
4193
+ #
4194
+ # Examples:
4195
+ #
4196
+ # Serve all requests beginning with /media from the "media" folder located
4197
+ # in the current directory (ie media/*):
4198
+ #
4199
+ # use Rack::Static, :urls => ["/media"]
4200
+ #
4201
+ # Same as previous, but instead of returning 404 for missing files under
4202
+ # /media, call the next middleware:
4203
+ #
4204
+ # use Rack::Static, :urls => ["/media"], :cascade => true
4205
+ #
4206
+ # Serve all requests beginning with /css or /images from the folder "public"
4207
+ # in the current directory (ie public/css/* and public/images/*):
4208
+ #
4209
+ # use Rack::Static, :urls => ["/css", "/images"], :root => "public"
4210
+ #
4211
+ # Serve all requests to / with "index.html" from the folder "public" in the
4212
+ # current directory (ie public/index.html):
4213
+ #
4214
+ # use Rack::Static, :urls => {"/" => 'index.html'}, :root => 'public'
4215
+ #
4216
+ # Serve all requests normally from the folder "public" in the current
4217
+ # directory but uses index.html as default route for "/"
4218
+ #
4219
+ # use Rack::Static, :urls => [""], :root => 'public', :index =>
4220
+ # 'index.html'
4221
+ #
4222
+ # Set custom HTTP Headers for based on rules:
4223
+ #
4224
+ # use Rack::Static, :root => 'public',
4225
+ # :header_rules => [
4226
+ # [rule, {header_field => content, header_field => content}],
4227
+ # [rule, {header_field => content}]
4228
+ # ]
4229
+ #
4230
+ # Rules for selecting files:
4231
+ #
4232
+ # 1) All files
4233
+ # Provide the :all symbol
4234
+ # :all => Matches every file
4235
+ #
4236
+ # 2) Folders
4237
+ # Provide the folder path as a string
4238
+ # '/folder' or '/folder/subfolder' => Matches files in a certain folder
4239
+ #
4240
+ # 3) File Extensions
4241
+ # Provide the file extensions as an array
4242
+ # ['css', 'js'] or %w(css js) => Matches files ending in .css or .js
4243
+ #
4244
+ # 4) Regular Expressions / Regexp
4245
+ # Provide a regular expression
4246
+ # %r{\.(?:css|js)\z} => Matches files ending in .css or .js
4247
+ # /\.(?:eot|ttf|otf|woff2|woff|svg)\z/ => Matches files ending in
4248
+ # the most common web font formats (.eot, .ttf, .otf, .woff2, .woff, .svg)
4249
+ # Note: This Regexp is available as a shortcut, using the :fonts rule
4250
+ #
4251
+ # 5) Font Shortcut
4252
+ # Provide the :fonts symbol
4253
+ # :fonts => Uses the Regexp rule stated right above to match all common web font endings
4254
+ #
4255
+ # Rule Ordering:
4256
+ # Rules are applied in the order that they are provided.
4257
+ # List rather general rules above special ones.
4258
+ #
4259
+ # Complete example use case including HTTP header rules:
4260
+ #
4261
+ # use Rack::Static, :root => 'public',
4262
+ # :header_rules => [
4263
+ # # Cache all static files in public caches (e.g. Rack::Cache)
4264
+ # # as well as in the browser
4265
+ # [:all, {'cache-control' => 'public, max-age=31536000'}],
4266
+ #
4267
+ # # Provide web fonts with cross-origin access-control-headers
4268
+ # # Firefox requires this when serving assets using a Content Delivery Network
4269
+ # [:fonts, {'access-control-allow-origin' => '*'}]
4270
+ # ]
4271
+ #
4272
+ # source://rack//lib/rack/static.rb#92
4273
+ class Rack::Static
4274
+ # @return [Static] a new instance of Static
4275
+ #
4276
+ # source://rack//lib/rack/static.rb#93
4277
+ def initialize(app, options = T.unsafe(nil)); end
4278
+
4279
+ # @return [Boolean]
4280
+ #
4281
+ # source://rack//lib/rack/static.rb#109
4282
+ def add_index_root?(path); end
4283
+
4284
+ # Convert HTTP header rules to HTTP headers
4285
+ #
4286
+ # source://rack//lib/rack/static.rb#167
4287
+ def applicable_rules(path); end
4288
+
4289
+ # source://rack//lib/rack/static.rb#125
4290
+ def call(env); end
4291
+
4292
+ # source://rack//lib/rack/static.rb#121
4293
+ def can_serve(path); end
4294
+
4295
+ # source://rack//lib/rack/static.rb#113
4296
+ def overwrite_file_path(path); end
4297
+
4298
+ # source://rack//lib/rack/static.rb#117
4299
+ def route_file(path); end
4300
+ end
4301
+
4302
+ # source://rack//lib/rack/constants.rb#38
4303
+ Rack::TRACE = T.let(T.unsafe(nil), String)
4304
+
4305
+ # source://rack//lib/rack/constants.rb#25
4306
+ Rack::TRANSFER_ENCODING = T.let(T.unsafe(nil), String)
4307
+
4308
+ # Middleware tracks and cleans Tempfiles created throughout a request (i.e. Rack::Multipart)
4309
+ # Ideas/strategy based on posts by Eric Wong and Charles Oliver Nutter
4310
+ # https://groups.google.com/forum/#!searchin/rack-devel/temp/rack-devel/brK8eh-MByw/sw61oJJCGRMJ
4311
+ #
4312
+ # source://rack//lib/rack/tempfile_reaper.rb#11
4313
+ class Rack::TempfileReaper
4314
+ # @return [TempfileReaper] a new instance of TempfileReaper
4315
+ #
4316
+ # source://rack//lib/rack/tempfile_reaper.rb#12
4317
+ def initialize(app); end
4318
+
4319
+ # source://rack//lib/rack/tempfile_reaper.rb#16
4320
+ def call(env); end
4321
+ end
4322
+
4323
+ # source://rack//lib/rack/constants.rb#37
4324
+ Rack::UNLINK = T.let(T.unsafe(nil), String)
4325
+
4326
+ # Rack::URLMap takes a hash mapping urls or paths to apps, and
4327
+ # dispatches accordingly. Support for HTTP/1.1 host names exists if
4328
+ # the URLs start with <tt>http://</tt> or <tt>https://</tt>.
4329
+ #
4330
+ # URLMap modifies the SCRIPT_NAME and PATH_INFO such that the part
4331
+ # relevant for dispatch is in the SCRIPT_NAME, and the rest in the
4332
+ # PATH_INFO. This should be taken care of when you need to
4333
+ # reconstruct the URL in order to create links.
4334
+ #
4335
+ # URLMap dispatches in such a way that the longest paths are tried
4336
+ # first, since they are most specific.
4337
+ #
4338
+ # source://rack//lib/rack/urlmap.rb#20
4339
+ class Rack::URLMap
4340
+ # @return [URLMap] a new instance of URLMap
4341
+ #
4342
+ # source://rack//lib/rack/urlmap.rb#21
4343
+ def initialize(map = T.unsafe(nil)); end
4344
+
4345
+ # source://rack//lib/rack/urlmap.rb#48
4346
+ def call(env); end
4347
+
4348
+ # source://rack//lib/rack/urlmap.rb#25
4349
+ def remap(map); end
4350
+
4351
+ private
4352
+
4353
+ # @return [Boolean]
4354
+ #
4355
+ # source://rack//lib/rack/urlmap.rb#87
4356
+ def casecmp?(v1, v2); end
4357
+ end
4358
+
4359
+ # Rack::Utils contains a grab-bag of useful methods for writing web
4360
+ # applications adopted from all kinds of Ruby libraries.
4361
+ #
4362
+ # source://rack//lib/rack/utils.rb#20
4363
+ module Rack::Utils
4364
+ private
4365
+
4366
+ # Return best accept value to use, based on the algorithm
4367
+ # in RFC 2616 Section 14. If there are multiple best
4368
+ # matches (same specificity and quality), the value returned
4369
+ # is arbitrary.
4370
+ #
4371
+ # source://rack//lib/rack/utils.rb#167
4372
+ def best_q_match(q_value_header, available_mimes); end
4373
+
4374
+ # source://rack//lib/rack/utils.rb#120
4375
+ def build_nested_query(value, prefix = T.unsafe(nil)); end
4376
+
4377
+ # source://rack//lib/rack/utils.rb#110
4378
+ def build_query(params); end
4379
+
4380
+ # Parses the "Range:" header, if present, into an array of Range objects.
4381
+ # Returns nil if the header is missing or syntactically invalid.
4382
+ # Returns an empty array if none of the ranges are satisfiable.
4383
+ #
4384
+ # source://rack//lib/rack/utils.rb#409
4385
+ def byte_ranges(env, size); end
4386
+
4387
+ # source://rack//lib/rack/utils.rb#609
4388
+ def clean_path_info(path_info); end
4389
+
4390
+ # :nocov:
4391
+ #
4392
+ # source://rack//lib/rack/utils.rb#91
4393
+ def clock_time; end
4394
+
4395
+ # source://rack//lib/rack/utils.rb#367
4396
+ def delete_cookie_header!(headers, key, value = T.unsafe(nil)); end
4397
+
4398
+ # :call-seq:
4399
+ # delete_set_cookie_header(key, value = {}) -> encoded string
4400
+ #
4401
+ # Generate an encoded string based on the given +key+ and +value+ using
4402
+ # set_cookie_header for the purpose of causing the specified cookie to be
4403
+ # deleted. The +value+ may be an instance of +Hash+ and can include
4404
+ # attributes as outlined by set_cookie_header. The encoded cookie will have
4405
+ # a +max_age+ of 0 seconds, an +expires+ date in the past and an empty
4406
+ # +value+. When used with the +set-cookie+ header, it will cause the client
4407
+ # to *remove* any matching cookie.
4408
+ #
4409
+ # delete_set_cookie_header("myname")
4410
+ # # => "myname=; max-age=0; expires=Thu, 01 Jan 1970 00:00:00 GMT"
4411
+ #
4412
+ # source://rack//lib/rack/utils.rb#363
4413
+ def delete_set_cookie_header(key, value = T.unsafe(nil)); end
4414
+
4415
+ # :call-seq:
4416
+ # delete_set_cookie_header!(header, key, value = {}) -> header value
4417
+ #
4418
+ # Set an expired cookie in the specified headers with the given cookie
4419
+ # +key+ and +value+ using delete_set_cookie_header. This causes
4420
+ # the client to immediately delete the specified cookie.
4421
+ #
4422
+ # delete_set_cookie_header!(nil, "mycookie")
4423
+ # # => "mycookie=; max-age=0; expires=Thu, 01 Jan 1970 00:00:00 GMT"
4424
+ #
4425
+ # If the header is non-nil, it will be modified in place.
4426
+ #
4427
+ # header = []
4428
+ # delete_set_cookie_header!(header, "mycookie")
4429
+ # # => ["mycookie=; max-age=0; expires=Thu, 01 Jan 1970 00:00:00 GMT"]
4430
+ # header
4431
+ # # => ["mycookie=; max-age=0; expires=Thu, 01 Jan 1970 00:00:00 GMT"]
4432
+ #
4433
+ # source://rack//lib/rack/utils.rb#391
4434
+ def delete_set_cookie_header!(header, key, value = T.unsafe(nil)); end
4435
+
4436
+ # URI escapes. (CGI style space to +)
4437
+ #
4438
+ # source://rack//lib/rack/utils.rb#40
4439
+ def escape(s); end
4440
+
4441
+ # source://rack//lib/rack/utils.rb#262
4442
+ def escape_cookie_key(key); end
4443
+
4444
+ # Escape ampersands, brackets and quotes to their HTML/XML entities.
4445
+ def escape_html(_arg0); end
4446
+
4447
+ # Like URI escaping, but with %20 instead of +. Strictly speaking this is
4448
+ # true URI escaping.
4449
+ #
4450
+ # source://rack//lib/rack/utils.rb#46
4451
+ def escape_path(s); end
4452
+
4453
+ # source://rack//lib/rack/utils.rb#149
4454
+ def forwarded_values(forwarded_header); end
4455
+
4456
+ # source://rack//lib/rack/utils.rb#413
4457
+ def get_byte_ranges(http_range, size); end
4458
+
4459
+ # :call-seq:
4460
+ # parse_cookies(env) -> hash
4461
+ #
4462
+ # Parse cookies from the provided request environment using
4463
+ # parse_cookies_header. Returns a map of cookie +key+ to cookie +value+.
4464
+ #
4465
+ # parse_cookies({'HTTP_COOKIE' => 'myname=myvalue'})
4466
+ # # => {'myname' => 'myvalue'}
4467
+ #
4468
+ # source://rack//lib/rack/utils.rb#253
4469
+ def parse_cookies(env); end
4470
+
4471
+ # :call-seq:
4472
+ # parse_cookies_header(value) -> hash
4473
+ #
4474
+ # Parse cookies from the provided header +value+ according to RFC6265. The
4475
+ # syntax for cookie headers only supports semicolons. Returns a map of
4476
+ # cookie +key+ to cookie +value+.
4477
+ #
4478
+ # parse_cookies_header('myname=myvalue; max-age=0')
4479
+ # # => {"myname"=>"myvalue", "max-age"=>"0"}
4480
+ #
4481
+ # source://rack//lib/rack/utils.rb#234
4482
+ def parse_cookies_header(value); end
4483
+
4484
+ # source://rack//lib/rack/utils.rb#106
4485
+ def parse_nested_query(qs, d = T.unsafe(nil)); end
4486
+
4487
+ # source://rack//lib/rack/utils.rb#102
4488
+ def parse_query(qs, d = T.unsafe(nil), &unescaper); end
4489
+
4490
+ # source://rack//lib/rack/utils.rb#138
4491
+ def q_values(q_value_header); end
4492
+
4493
+ # source://rack//lib/rack/utils.rb#402
4494
+ def rfc2822(time); end
4495
+
4496
+ # :nocov:
4497
+ #
4498
+ # source://rack//lib/rack/utils.rb#455
4499
+ def secure_compare(a, b); end
4500
+
4501
+ # source://rack//lib/rack/utils.rb#192
4502
+ def select_best_encoding(available_encodings, accept_encoding); end
4503
+
4504
+ # :call-seq:
4505
+ # set_cookie_header(key, value) -> encoded string
4506
+ #
4507
+ # Generate an encoded string using the provided +key+ and +value+ suitable
4508
+ # for the +set-cookie+ header according to RFC6265. The +value+ may be an
4509
+ # instance of either +String+ or +Hash+.
4510
+ #
4511
+ # If the cookie +value+ is an instance of +Hash+, it considers the following
4512
+ # cookie attribute keys: +domain+, +max_age+, +expires+ (must be instance
4513
+ # of +Time+), +secure+, +http_only+, +same_site+ and +value+. For more
4514
+ # details about the interpretation of these fields, consult
4515
+ # [RFC6265 Section 5.2](https://datatracker.ietf.org/doc/html/rfc6265#section-5.2).
4516
+ #
4517
+ # An extra cookie attribute +escape_key+ can be provided to control whether
4518
+ # or not the cookie key is URL encoded. If explicitly set to +false+, the
4519
+ # cookie key name will not be url encoded (escaped). The default is +true+.
4520
+ #
4521
+ # set_cookie_header("myname", "myvalue")
4522
+ # # => "myname=myvalue"
4523
+ #
4524
+ # set_cookie_header("myname", {value: "myvalue", max_age: 10})
4525
+ # # => "myname=myvalue; max-age=10"
4526
+ #
4527
+ # source://rack//lib/rack/utils.rb#294
4528
+ def set_cookie_header(key, value); end
4529
+
4530
+ # :call-seq:
4531
+ # set_cookie_header!(headers, key, value) -> header value
4532
+ #
4533
+ # Append a cookie in the specified headers with the given cookie +key+ and
4534
+ # +value+ using set_cookie_header.
4535
+ #
4536
+ # If the headers already contains a +set-cookie+ key, it will be converted
4537
+ # to an +Array+ if not already, and appended to.
4538
+ #
4539
+ # source://rack//lib/rack/utils.rb#337
4540
+ def set_cookie_header!(headers, key, value); end
4541
+
4542
+ # source://rack//lib/rack/utils.rb#589
4543
+ def status_code(status); end
4544
+
4545
+ # Unescapes a URI escaped string with +encoding+. +encoding+ will be the
4546
+ # target encoding of the string returned, and it defaults to UTF-8
4547
+ #
4548
+ # source://rack//lib/rack/utils.rb#58
4549
+ def unescape(s, encoding = T.unsafe(nil)); end
4550
+
4551
+ # Unescapes the **path** component of a URI. See Rack::Utils.unescape for
4552
+ # unescaping query parameters or form components.
4553
+ #
4554
+ # source://rack//lib/rack/utils.rb#52
4555
+ def unescape_path(s); end
4556
+
4557
+ # source://rack//lib/rack/utils.rb#626
4558
+ def valid_path?(path); end
4559
+
4560
+ class << self
4561
+ # Return best accept value to use, based on the algorithm
4562
+ # in RFC 2616 Section 14. If there are multiple best
4563
+ # matches (same specificity and quality), the value returned
4564
+ # is arbitrary.
4565
+ #
4566
+ # source://rack//lib/rack/utils.rb#167
4567
+ def best_q_match(q_value_header, available_mimes); end
4568
+
4569
+ # source://rack//lib/rack/utils.rb#120
4570
+ def build_nested_query(value, prefix = T.unsafe(nil)); end
4571
+
4572
+ # source://rack//lib/rack/utils.rb#110
4573
+ def build_query(params); end
4574
+
4575
+ # Parses the "Range:" header, if present, into an array of Range objects.
4576
+ # Returns nil if the header is missing or syntactically invalid.
4577
+ # Returns an empty array if none of the ranges are satisfiable.
4578
+ #
4579
+ # source://rack//lib/rack/utils.rb#409
4580
+ def byte_ranges(env, size); end
4581
+
4582
+ # source://rack//lib/rack/utils.rb#609
4583
+ def clean_path_info(path_info); end
4584
+
4585
+ # source://rack//lib/rack/utils.rb#91
4586
+ def clock_time; end
4587
+
4588
+ # Returns the value of attribute default_query_parser.
4589
+ #
4590
+ # source://rack//lib/rack/utils.rb#30
4591
+ def default_query_parser; end
4592
+
4593
+ # Sets the attribute default_query_parser
4594
+ #
4595
+ # @param value the value to set the attribute default_query_parser to.
4596
+ #
4597
+ # source://rack//lib/rack/utils.rb#30
4598
+ def default_query_parser=(_arg0); end
4599
+
4600
+ # source://rack//lib/rack/utils.rb#367
4601
+ def delete_cookie_header!(headers, key, value = T.unsafe(nil)); end
4602
+
4603
+ # :call-seq:
4604
+ # delete_set_cookie_header(key, value = {}) -> encoded string
4605
+ #
4606
+ # Generate an encoded string based on the given +key+ and +value+ using
4607
+ # set_cookie_header for the purpose of causing the specified cookie to be
4608
+ # deleted. The +value+ may be an instance of +Hash+ and can include
4609
+ # attributes as outlined by set_cookie_header. The encoded cookie will have
4610
+ # a +max_age+ of 0 seconds, an +expires+ date in the past and an empty
4611
+ # +value+. When used with the +set-cookie+ header, it will cause the client
4612
+ # to *remove* any matching cookie.
4613
+ #
4614
+ # delete_set_cookie_header("myname")
4615
+ # # => "myname=; max-age=0; expires=Thu, 01 Jan 1970 00:00:00 GMT"
4616
+ #
4617
+ # source://rack//lib/rack/utils.rb#363
4618
+ def delete_set_cookie_header(key, value = T.unsafe(nil)); end
4619
+
4620
+ # :call-seq:
4621
+ # delete_set_cookie_header!(header, key, value = {}) -> header value
4622
+ #
4623
+ # Set an expired cookie in the specified headers with the given cookie
4624
+ # +key+ and +value+ using delete_set_cookie_header. This causes
4625
+ # the client to immediately delete the specified cookie.
4626
+ #
4627
+ # delete_set_cookie_header!(nil, "mycookie")
4628
+ # # => "mycookie=; max-age=0; expires=Thu, 01 Jan 1970 00:00:00 GMT"
4629
+ #
4630
+ # If the header is non-nil, it will be modified in place.
4631
+ #
4632
+ # header = []
4633
+ # delete_set_cookie_header!(header, "mycookie")
4634
+ # # => ["mycookie=; max-age=0; expires=Thu, 01 Jan 1970 00:00:00 GMT"]
4635
+ # header
4636
+ # # => ["mycookie=; max-age=0; expires=Thu, 01 Jan 1970 00:00:00 GMT"]
4637
+ #
4638
+ # source://rack//lib/rack/utils.rb#391
4639
+ def delete_set_cookie_header!(header, key, value = T.unsafe(nil)); end
4640
+
4641
+ # URI escapes. (CGI style space to +)
4642
+ #
4643
+ # source://rack//lib/rack/utils.rb#40
4644
+ def escape(s); end
4645
+
4646
+ # source://rack//lib/rack/utils.rb#262
4647
+ def escape_cookie_key(key); end
4648
+
4649
+ def escape_html(_arg0); end
4650
+
4651
+ # Like URI escaping, but with %20 instead of +. Strictly speaking this is
4652
+ # true URI escaping.
4653
+ #
4654
+ # source://rack//lib/rack/utils.rb#46
4655
+ def escape_path(s); end
4656
+
4657
+ # source://rack//lib/rack/utils.rb#149
4658
+ def forwarded_values(forwarded_header); end
4659
+
4660
+ # source://rack//lib/rack/utils.rb#413
4661
+ def get_byte_ranges(http_range, size); end
4662
+
4663
+ # Returns the value of attribute multipart_file_limit.
4664
+ #
4665
+ # source://rack//lib/rack/utils.rb#65
4666
+ def multipart_file_limit; end
4667
+
4668
+ # Sets the attribute multipart_file_limit
4669
+ #
4670
+ # @param value the value to set the attribute multipart_file_limit to.
4671
+ #
4672
+ # source://rack//lib/rack/utils.rb#65
4673
+ def multipart_file_limit=(_arg0); end
4674
+
4675
+ # Returns the value of attribute multipart_file_limit.
4676
+ # multipart_part_limit is the original name of multipart_file_limit, but
4677
+ # the limit only counts parts with filenames.
4678
+ #
4679
+ # source://rack//lib/rack/utils.rb#65
4680
+ def multipart_part_limit; end
4681
+
4682
+ # Sets the attribute multipart_file_limit
4683
+ #
4684
+ # @param value the value to set the attribute multipart_file_limit to.
4685
+ #
4686
+ # source://rack//lib/rack/utils.rb#65
4687
+ def multipart_part_limit=(_arg0); end
4688
+
4689
+ # Returns the value of attribute multipart_total_part_limit.
4690
+ #
4691
+ # source://rack//lib/rack/utils.rb#63
4692
+ def multipart_total_part_limit; end
4693
+
4694
+ # Sets the attribute multipart_total_part_limit
4695
+ #
4696
+ # @param value the value to set the attribute multipart_total_part_limit to.
4697
+ #
4698
+ # source://rack//lib/rack/utils.rb#63
4699
+ def multipart_total_part_limit=(_arg0); end
4700
+
4701
+ # source://rack//lib/rack/utils.rb#82
4702
+ def param_depth_limit; end
4703
+
4704
+ # source://rack//lib/rack/utils.rb#86
4705
+ def param_depth_limit=(v); end
4706
+
4707
+ # :call-seq:
4708
+ # parse_cookies(env) -> hash
4709
+ #
4710
+ # Parse cookies from the provided request environment using
4711
+ # parse_cookies_header. Returns a map of cookie +key+ to cookie +value+.
4712
+ #
4713
+ # parse_cookies({'HTTP_COOKIE' => 'myname=myvalue'})
4714
+ # # => {'myname' => 'myvalue'}
4715
+ #
4716
+ # source://rack//lib/rack/utils.rb#253
4717
+ def parse_cookies(env); end
4718
+
4719
+ # :call-seq:
4720
+ # parse_cookies_header(value) -> hash
4721
+ #
4722
+ # Parse cookies from the provided header +value+ according to RFC6265. The
4723
+ # syntax for cookie headers only supports semicolons. Returns a map of
4724
+ # cookie +key+ to cookie +value+.
4725
+ #
4726
+ # parse_cookies_header('myname=myvalue; max-age=0')
4727
+ # # => {"myname"=>"myvalue", "max-age"=>"0"}
4728
+ #
4729
+ # source://rack//lib/rack/utils.rb#234
4730
+ def parse_cookies_header(value); end
4731
+
4732
+ # source://rack//lib/rack/utils.rb#106
4733
+ def parse_nested_query(qs, d = T.unsafe(nil)); end
4734
+
4735
+ # source://rack//lib/rack/utils.rb#102
4736
+ def parse_query(qs, d = T.unsafe(nil), &unescaper); end
4737
+
4738
+ # source://rack//lib/rack/utils.rb#138
4739
+ def q_values(q_value_header); end
4740
+
4741
+ # source://rack//lib/rack/utils.rb#402
4742
+ def rfc2822(time); end
4743
+
4744
+ # source://rack//lib/rack/utils.rb#455
4745
+ def secure_compare(a, b); end
4746
+
4747
+ # source://rack//lib/rack/utils.rb#192
4748
+ def select_best_encoding(available_encodings, accept_encoding); end
4749
+
4750
+ # :call-seq:
4751
+ # set_cookie_header(key, value) -> encoded string
4752
+ #
4753
+ # Generate an encoded string using the provided +key+ and +value+ suitable
4754
+ # for the +set-cookie+ header according to RFC6265. The +value+ may be an
4755
+ # instance of either +String+ or +Hash+.
4756
+ #
4757
+ # If the cookie +value+ is an instance of +Hash+, it considers the following
4758
+ # cookie attribute keys: +domain+, +max_age+, +expires+ (must be instance
4759
+ # of +Time+), +secure+, +http_only+, +same_site+ and +value+. For more
4760
+ # details about the interpretation of these fields, consult
4761
+ # [RFC6265 Section 5.2](https://datatracker.ietf.org/doc/html/rfc6265#section-5.2).
4762
+ #
4763
+ # An extra cookie attribute +escape_key+ can be provided to control whether
4764
+ # or not the cookie key is URL encoded. If explicitly set to +false+, the
4765
+ # cookie key name will not be url encoded (escaped). The default is +true+.
4766
+ #
4767
+ # set_cookie_header("myname", "myvalue")
4768
+ # # => "myname=myvalue"
4769
+ #
4770
+ # set_cookie_header("myname", {value: "myvalue", max_age: 10})
4771
+ # # => "myname=myvalue; max-age=10"
4772
+ #
4773
+ # source://rack//lib/rack/utils.rb#294
4774
+ def set_cookie_header(key, value); end
4775
+
4776
+ # :call-seq:
4777
+ # set_cookie_header!(headers, key, value) -> header value
4778
+ #
4779
+ # Append a cookie in the specified headers with the given cookie +key+ and
4780
+ # +value+ using set_cookie_header.
4781
+ #
4782
+ # If the headers already contains a +set-cookie+ key, it will be converted
4783
+ # to an +Array+ if not already, and appended to.
4784
+ #
4785
+ # source://rack//lib/rack/utils.rb#337
4786
+ def set_cookie_header!(headers, key, value); end
4787
+
4788
+ # source://rack//lib/rack/utils.rb#589
4789
+ def status_code(status); end
4790
+
4791
+ # Unescapes a URI escaped string with +encoding+. +encoding+ will be the
4792
+ # target encoding of the string returned, and it defaults to UTF-8
4793
+ #
4794
+ # source://rack//lib/rack/utils.rb#58
4795
+ def unescape(s, encoding = T.unsafe(nil)); end
4796
+
4797
+ # Unescapes the **path** component of a URI. See Rack::Utils.unescape for
4798
+ # unescaping query parameters or form components.
4799
+ #
4800
+ # source://rack//lib/rack/utils.rb#52
4801
+ def unescape_path(s); end
4802
+
4803
+ # @return [Boolean]
4804
+ #
4805
+ # source://rack//lib/rack/utils.rb#626
4806
+ def valid_path?(path); end
4807
+ end
4808
+ end
4809
+
4810
+ # source://rack//lib/rack/utils.rb#25
4811
+ Rack::Utils::COMMON_SEP = T.let(T.unsafe(nil), Hash)
4812
+
4813
+ # Context allows the use of a compatible middleware at different points
4814
+ # in a request handling stack. A compatible middleware must define
4815
+ # #context which should take the arguments env and app. The first of which
4816
+ # would be the request environment. The second of which would be the rack
4817
+ # application that the request would be forwarded to.
4818
+ #
4819
+ # source://rack//lib/rack/utils.rb#478
4820
+ class Rack::Utils::Context
4821
+ # @return [Context] a new instance of Context
4822
+ #
4823
+ # source://rack//lib/rack/utils.rb#481
4824
+ def initialize(app_f, app_r); end
4825
+
4826
+ # Returns the value of attribute app.
4827
+ #
4828
+ # source://rack//lib/rack/utils.rb#479
4829
+ def app; end
4830
+
4831
+ # source://rack//lib/rack/utils.rb#486
4832
+ def call(env); end
4833
+
4834
+ # source://rack//lib/rack/utils.rb#494
4835
+ def context(env, app = T.unsafe(nil)); end
4836
+
4837
+ # Returns the value of attribute for.
4838
+ #
4839
+ # source://rack//lib/rack/utils.rb#479
4840
+ def for; end
4841
+
4842
+ # source://rack//lib/rack/utils.rb#490
4843
+ def recontext(app); end
4844
+ end
4845
+
4846
+ # source://rack//lib/rack/utils.rb#24
4847
+ Rack::Utils::DEFAULT_SEP = T.let(T.unsafe(nil), Regexp)
4848
+
4849
+ # Every standard HTTP code mapped to the appropriate message.
4850
+ # Generated with:
4851
+ # curl -s https://www.iana.org/assignments/http-status-codes/http-status-codes-1.csv \
4852
+ # | ruby -rcsv -e "puts CSV.parse(STDIN, headers: true) \
4853
+ # .reject {|v| v['Description'] == 'Unassigned' or v['Description'].include? '(' } \
4854
+ # .map {|v| %Q/#{v['Value']} => '#{v['Description']}'/ }.join(','+?\n)"
4855
+ #
4856
+ # source://rack//lib/rack/utils.rb#505
4857
+ Rack::Utils::HTTP_STATUS_CODES = T.let(T.unsafe(nil), Hash)
4858
+
4859
+ # source://rack//lib/rack/utils.rb#22
4860
+ Rack::Utils::InvalidParameterError = Rack::QueryParser::InvalidParameterError
4861
+
4862
+ # source://rack//lib/rack/utils.rb#26
4863
+ Rack::Utils::KeySpaceConstrainedParams = Rack::QueryParser::Params
4864
+
4865
+ # source://rack//lib/rack/utils.rb#624
4866
+ Rack::Utils::NULL_BYTE = T.let(T.unsafe(nil), String)
4867
+
4868
+ # source://rack//lib/rack/utils.rb#575
4869
+ Rack::Utils::OBSOLETE_SYMBOLS_TO_STATUS_CODES = T.let(T.unsafe(nil), Hash)
4870
+
4871
+ # source://rack//lib/rack/utils.rb#583
4872
+ Rack::Utils::OBSOLETE_SYMBOL_MAPPINGS = T.let(T.unsafe(nil), Hash)
4873
+
4874
+ # source://rack//lib/rack/utils.rb#607
4875
+ Rack::Utils::PATH_SEPS = T.let(T.unsafe(nil), Regexp)
4876
+
4877
+ # source://rack//lib/rack/utils.rb#21
4878
+ Rack::Utils::ParameterTypeError = Rack::QueryParser::ParameterTypeError
4879
+
4880
+ # source://rack//lib/rack/utils.rb#23
4881
+ Rack::Utils::ParamsTooDeepError = Rack::QueryParser::ParamsTooDeepError
4882
+
4883
+ # Responses with HTTP status codes that should not have an entity body
4884
+ #
4885
+ # source://rack//lib/rack/utils.rb#569
4886
+ Rack::Utils::STATUS_WITH_NO_ENTITY_BODY = T.let(T.unsafe(nil), Hash)
4887
+
4888
+ # source://rack//lib/rack/utils.rb#571
4889
+ Rack::Utils::SYMBOL_TO_STATUS_CODE = T.let(T.unsafe(nil), Hash)
4890
+
4891
+ # source://rack//lib/rack/utils.rb#27
4892
+ Rack::Utils::URI_PARSER = T.let(T.unsafe(nil), URI::RFC2396_Parser)
4893
+
4894
+ # A valid cookie key according to RFC2616.
4895
+ # A <cookie-name> can be any US-ASCII characters, except control characters, spaces, or tabs. It also must not contain a separator character like the following: ( ) < > @ , ; : \ " / [ ] ? = { }.
4896
+ #
4897
+ # source://rack//lib/rack/utils.rb#259
4898
+ Rack::Utils::VALID_COOKIE_KEY = T.let(T.unsafe(nil), Regexp)