openapi_parameters 0.7.0 → 0.9.0.beta1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 2c8fe7a86aaad928b6277f62969502db824f37ff92624c6f33abfa43dad15454
4
- data.tar.gz: f8b36c4416ff14775bf9cb7ca05c5d6ad45589a5a1a390a6bcaa395142027241
3
+ metadata.gz: 333fd99034d125536a4a747d4c611e474ba8f2c41aa84d9c983f0cd7425b13cb
4
+ data.tar.gz: '067223459914938a710d91de39125b4e8c7a7dc820b637fa5c3fa2bc1502465e'
5
5
  SHA512:
6
- metadata.gz: f447c974255d4f21c3822c975b655ddb3f988a513bdb1684491a4bc0a60406f66d170378b8d5e2bc7d64eed5b94366716fdafa9f4074e90f5f1f1ad4567b0d2d
7
- data.tar.gz: f3ac74f5faecfca7aa8513fe0e4ce901a5cca2ca42833e0f0c07e2b844e8e8ded7166ac99b492631d0d2173173cce438f4a8c37daa0b16491db0d7ddaf09aa1f
6
+ metadata.gz: 653a7d0631784ed6ce34187307a973f08fee2560dceb93390d4d509f49c68acb6101d4cd1a274eb009df9020a81a0081089c24af4aeb6f64be43f4f46a9bdbfc
7
+ data.tar.gz: e458b12c372881a3e2503e891348da76ad735fc197f66343c6ff74fd1dd8107d2054c553b246959c7ef3a793e52b4432ca2e3c2d955ef7b66d6f59968f2bd1ab
data/CHANGELOG.md CHANGED
@@ -1,5 +1,11 @@
1
1
  ## [Unreleased]
2
2
 
3
+ - Add basic support unpacking query paramters that use deepObject and oneOf
4
+
5
+ ## [0.8.0] - 2025-09-17
6
+
7
+ - No longer parse more than one level of nested objects when parsing `deepObject` parameters. This is actually in line with what `deepObject` supports.
8
+
3
9
  ## [0.7.0] - 2025-09-12
4
10
 
5
11
  - Correctly handle `style:deepObject` with `explode: true` and parse into array
@@ -9,7 +9,6 @@ module OpenapiParameters
9
9
  @definition = definition
10
10
  @name = definition['name']
11
11
  @is_deep_object = style == 'deepObject'
12
- @is_explode = explode?
13
12
  @converter = Converters[schema]
14
13
  check_supported!
15
14
  end
@@ -1,6 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  require 'rack'
4
+ require_relative 'converter'
4
5
 
5
6
  module OpenapiParameters
6
7
  # Query parses query parameters from a http query strings.
@@ -11,21 +12,14 @@ module OpenapiParameters
11
12
  @parameters = parameters.map { Parameter.new(_1) }
12
13
  @convert = convert
13
14
  @remove_array_brackets = rack_array_compat
14
- @any_deep_object = @parameters.any?(&:deep_object?)
15
15
  end
16
16
 
17
- def unpack(query_string) # rubocop:disable Metrics/AbcSize,Metrics/MethodLength
17
+ def unpack(query_string) # rubocop:disable Metrics/AbcSize
18
18
  parsed_query = parse_query(query_string)
19
- parsed_nested_query = Rack::Utils.parse_nested_query(query_string) if any_deep_object?
20
19
  parameters.each_with_object({}) do |parameter, result|
21
20
  if parameter.deep_object?
22
- next unless parsed_nested_query.key?(parameter.name)
23
-
24
- value = if parameter.explode?
25
- handle_deep_object_explode(parameter, parsed_nested_query[parameter.name], parsed_query)
26
- else
27
- parsed_nested_query[parameter.name]
28
- end
21
+ value = parse_deep_object(parameter, parsed_query)
22
+ next if value.empty?
29
23
  else
30
24
  next unless parsed_query.key?(parameter.name)
31
25
 
@@ -41,14 +35,10 @@ module OpenapiParameters
41
35
  end
42
36
 
43
37
  attr_reader :parameters
44
- private attr_reader :remove_array_brackets
38
+ private attr_reader :remove_array_brackets, :parameter_property_schemas
45
39
 
46
40
  private
47
41
 
48
- def any_deep_object?
49
- @any_deep_object
50
- end
51
-
52
42
  def parse_query(query_string)
53
43
  Rack::Utils.parse_query(query_string) do |s|
54
44
  Rack::Utils.unescape(s)
@@ -57,31 +47,48 @@ module OpenapiParameters
57
47
  end
58
48
  end
59
49
 
60
- def handle_deep_object_explode(parameter, value, parsed_query)
61
- return value unless value.is_a?(Hash)
50
+ def build_properties_schema(parameter)
51
+ schema = parameter.schema
52
+ return unless schema
62
53
 
63
- schema_props = parameter.schema['properties'] || {}
54
+ props = schema['properties']
55
+ return props if props
64
56
 
65
- array_prop_values = find_prop_matches(parameter.name, schema_props, parsed_query)
57
+ combinations = schema.slice('allOf', 'oneOf', 'anyOf')
58
+ if combinations.any?
59
+ props = combinations.values.flat_map { |value| value.map { |sub| sub['properties'] }.compact }
60
+ return {}.merge(*props.compact)
61
+ end
66
62
 
67
- schema_props.each_with_object(value) do |(prop, prop_schema), result|
68
- next unless prop_schema['type'] == 'array'
63
+ schema
64
+ end
69
65
 
70
- arr = array_prop_values[prop]
71
- result[prop] = if arr.empty? && value.key?(prop)
72
- Array(value[prop])
73
- else
74
- arr
75
- end
66
+ DEEP_PROP = '\[([\w-]+)\]$'
67
+ private_constant :DEEP_PROP
68
+
69
+ def parse_deep_object(parameter, parsed_query)
70
+ name = parameter.name
71
+ prop_regx = /^#{name}#{DEEP_PROP}/
72
+ parsed_query.each.with_object({}) do |(key, value), result|
73
+ next unless parsed_query.key?(key)
74
+
75
+ prop_key = key.match(prop_regx)&.[](1)
76
+ next if prop_key.nil?
77
+
78
+ is_array = parameter.schema&.dig('properties', prop_key, 'type') == 'array'
79
+ value = explode_value(value, parameter, is_array)
80
+ result[prop_key] = value
76
81
  end
77
82
  end
78
83
 
79
- def find_prop_matches(parameter_name, schema_props, parsed_query)
80
- schema_props.each_key.with_object({}) do |prop, result|
81
- key = "#{parameter_name}[#{prop}]"
82
- value = Array(parsed_query[key])
83
- result[prop] = value.map { |match| Rack::Utils.unescape(match) } if value.is_a?(Array)
84
+ def explode_value(value, parameter, is_array)
85
+ value = Array(value).map! { |v| Rack::Utils.unescape(v) }
86
+ if is_array
87
+ return value if parameter.explode?
88
+
89
+ return [value.last]
84
90
  end
91
+ value.last
85
92
  end
86
93
  end
87
94
  end
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module OpenapiParameters
4
- VERSION = '0.7.0'
4
+ VERSION = '0.9.0.beta1'
5
5
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: openapi_parameters
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.7.0
4
+ version: 0.9.0.beta1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Andreas Haller
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2025-09-12 00:00:00.000000000 Z
11
+ date: 2025-11-05 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rack
@@ -67,9 +67,9 @@ required_ruby_version: !ruby/object:Gem::Requirement
67
67
  version: 3.1.0
68
68
  required_rubygems_version: !ruby/object:Gem::Requirement
69
69
  requirements:
70
- - - ">="
70
+ - - ">"
71
71
  - !ruby/object:Gem::Version
72
- version: '0'
72
+ version: 1.3.1
73
73
  requirements: []
74
74
  rubygems_version: 3.4.6
75
75
  signing_key: