rswag-api 2.9.0 → 2.10.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 (3) hide show
  1. checksums.yaml +4 -4
  2. data/lib/rswag/api/middleware.rb +6 -1
  3. metadata +2 -2
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 2f6a479873bdc22b8568bf5918bd56380c40dabb9b45577bc2b0ce3a439a226c
4
- data.tar.gz: d20109c13e90ab97c31fd8ae3a60a8e5c20a3be0598405ee4bcfccf71c6b1648
3
+ metadata.gz: 24a46129ae1192485e1d09b1c2930afd78c229007981af3e4ac14d2087f9bd37
4
+ data.tar.gz: 86aa96d20b65e8a7d4f739dc6eaad415e6b75bc57ca197ac402344949922bd5e
5
5
  SHA512:
6
- metadata.gz: 41b18aa4dd83c021d3b3a9135c7564d085eac48d909f4bf20cfc20cc174e1341f4216a9902384ab79ca7107e9112ea56bec30f80139aa67e269e38975d61f5b3
7
- data.tar.gz: 3801e309323ec05e77ac47bcd6bd33ef682b979481723d32d063b419af75201667e362ab01df8ecfd06cda165c96123191820a127cb0690af8b5d6d450f3b79c
6
+ metadata.gz: a7a8332ce317746707b505bd660e6c6a078e1f07170656324fa764cd436d565256f627e47a9ce7a8608f7d0bb8ba1a8e7c5a5da2066d439fc2db6ed96934d474
7
+ data.tar.gz: 9c94264f402db5fd0f936975b85dfd3e3a43aa1e47ab744d960a7f26d37f657ae09b3e9e2d30edcdf2542bbee01de347af07aa56367b5c252bbc7e689fd33ecc
@@ -13,7 +13,12 @@ module Rswag
13
13
 
14
14
  def call(env)
15
15
  path = env['PATH_INFO']
16
- filename = "#{@config.resolve_swagger_root(env)}/#{path}"
16
+ # Sanitize the filename for directory traversal by expanding, and ensuring
17
+ # its starts with the root directory.
18
+ filename = File.expand_path(path, @config.resolve_swagger_root(env))
19
+ unless filename.start_with? @config.resolve_swagger_root(env)
20
+ return @app.call(env)
21
+ end
17
22
 
18
23
  if env['REQUEST_METHOD'] == 'GET' && File.file?(filename)
19
24
  swagger = parse_file(filename)
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: rswag-api
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.9.0
4
+ version: 2.10.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Richie Morris
@@ -10,7 +10,7 @@ authors:
10
10
  autorequire:
11
11
  bindir: bin
12
12
  cert_chain: []
13
- date: 2023-04-24 00:00:00.000000000 Z
13
+ date: 2023-07-13 00:00:00.000000000 Z
14
14
  dependencies:
15
15
  - !ruby/object:Gem::Dependency
16
16
  name: railties