openapi_first 0.12.2 → 0.12.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.rubocop.yml +2 -0
- data/CHANGELOG.md +3 -0
- data/Gemfile.lock +10 -10
- data/README.md +17 -1
- data/benchmarks/Gemfile.lock +6 -6
- data/examples/app.rb +2 -1
- data/lib/openapi_first.rb +29 -4
- data/lib/openapi_first/app.rb +11 -4
- data/lib/openapi_first/version.rb +1 -1
- metadata +2 -2
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA256:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: 8f5e77e342d4dba0c6ac4d535511148333efac5bc4b2cea62ee6d8b75219233e
         | 
| 4 | 
            +
              data.tar.gz: 9b3341115e77bd4abc4b14d89464093d78483e251cf69e2b2508461c98aa1ccf
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 86f19dc76569748825731014124b689b7bddf5cce6a6fe38b5d95adb4643eeeeaa3ae6024a290aaf2aed92127147cc948a55faa062b5d97b99b7d2fe65df98cd
         | 
| 7 | 
            +
              data.tar.gz: 27cef03d9ef7e0b49af33154e44ca68d3e0e860dcd94cbf6d2cdc4661ff90a4be590b92365aabfcdffe330f2aa2e96c12f7277ee2fa572fe02a2cc2c263e34b5
         | 
    
        data/.rubocop.yml
    CHANGED
    
    
    
        data/CHANGELOG.md
    CHANGED
    
    
    
        data/Gemfile.lock
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            PATH
         | 
| 2 2 | 
             
              remote: .
         | 
| 3 3 | 
             
              specs:
         | 
| 4 | 
            -
                openapi_first (0.12. | 
| 4 | 
            +
                openapi_first (0.12.3)
         | 
| 5 5 | 
             
                  deep_merge (>= 1.2.1)
         | 
| 6 6 | 
             
                  hanami-router (~> 2.0.alpha3)
         | 
| 7 7 | 
             
                  hanami-utils (~> 2.0.alpha1)
         | 
| @@ -26,7 +26,7 @@ GEM | |
| 26 26 | 
             
                coderay (1.1.3)
         | 
| 27 27 | 
             
                concurrent-ruby (1.1.6)
         | 
| 28 28 | 
             
                deep_merge (1.2.1)
         | 
| 29 | 
            -
                diff-lcs (1.4. | 
| 29 | 
            +
                diff-lcs (1.4.4)
         | 
| 30 30 | 
             
                ecma-re-validator (0.2.1)
         | 
| 31 31 | 
             
                  regexp_parser (~> 1.2)
         | 
| 32 32 | 
             
                hana (1.3.6)
         | 
| @@ -49,15 +49,15 @@ GEM | |
| 49 49 | 
             
                method_source (1.0.0)
         | 
| 50 50 | 
             
                mini_portile2 (2.4.0)
         | 
| 51 51 | 
             
                minitest (5.14.1)
         | 
| 52 | 
            -
                multi_json (1. | 
| 52 | 
            +
                multi_json (1.15.0)
         | 
| 53 53 | 
             
                mustermann (1.1.1)
         | 
| 54 54 | 
             
                  ruby2_keywords (~> 0.0.1)
         | 
| 55 55 | 
             
                mustermann-contrib (1.1.1)
         | 
| 56 56 | 
             
                  hansi (~> 0.2.0)
         | 
| 57 57 | 
             
                  mustermann (= 1.1.1)
         | 
| 58 | 
            -
                nokogiri (1.10. | 
| 58 | 
            +
                nokogiri (1.10.10)
         | 
| 59 59 | 
             
                  mini_portile2 (~> 2.4.0)
         | 
| 60 | 
            -
                oas_parser (0.25. | 
| 60 | 
            +
                oas_parser (0.25.1)
         | 
| 61 61 | 
             
                  activesupport (>= 4.0.0)
         | 
| 62 62 | 
             
                  addressable (~> 2.3)
         | 
| 63 63 | 
             
                  builder (~> 3.2.3)
         | 
| @@ -92,16 +92,16 @@ GEM | |
| 92 92 | 
             
                  diff-lcs (>= 1.2.0, < 2.0)
         | 
| 93 93 | 
             
                  rspec-support (~> 3.9.0)
         | 
| 94 94 | 
             
                rspec-support (3.9.3)
         | 
| 95 | 
            -
                rubocop (0. | 
| 95 | 
            +
                rubocop (0.87.1)
         | 
| 96 96 | 
             
                  parallel (~> 1.10)
         | 
| 97 | 
            -
                  parser (>= 2.7. | 
| 97 | 
            +
                  parser (>= 2.7.1.1)
         | 
| 98 98 | 
             
                  rainbow (>= 2.2.2, < 4.0)
         | 
| 99 99 | 
             
                  regexp_parser (>= 1.7)
         | 
| 100 100 | 
             
                  rexml
         | 
| 101 | 
            -
                  rubocop-ast (>= 0.0 | 
| 101 | 
            +
                  rubocop-ast (>= 0.1.0, < 1.0)
         | 
| 102 102 | 
             
                  ruby-progressbar (~> 1.7)
         | 
| 103 103 | 
             
                  unicode-display_width (>= 1.4.0, < 2.0)
         | 
| 104 | 
            -
                rubocop-ast (0.0 | 
| 104 | 
            +
                rubocop-ast (0.1.0)
         | 
| 105 105 | 
             
                  parser (>= 2.7.0.1)
         | 
| 106 106 | 
             
                ruby-progressbar (1.10.1)
         | 
| 107 107 | 
             
                ruby2_keywords (0.0.2)
         | 
| @@ -111,7 +111,7 @@ GEM | |
| 111 111 | 
             
                  thread_safe (~> 0.1)
         | 
| 112 112 | 
             
                unicode-display_width (1.7.0)
         | 
| 113 113 | 
             
                uri_template (0.7.0)
         | 
| 114 | 
            -
                zeitwerk (2.3. | 
| 114 | 
            +
                zeitwerk (2.3.1)
         | 
| 115 115 |  | 
| 116 116 | 
             
            PLATFORMS
         | 
| 117 117 | 
             
              ruby
         | 
    
        data/README.md
    CHANGED
    
    | @@ -150,7 +150,12 @@ end | |
| 150 150 |  | 
| 151 151 | 
             
            # In config.ru:
         | 
| 152 152 | 
             
            require 'openapi_first'
         | 
| 153 | 
            -
            run OpenapiFirst.app( | 
| 153 | 
            +
            run OpenapiFirst.app(
         | 
| 154 | 
            +
              './openapi/openapi.yaml',
         | 
| 155 | 
            +
              namespace: Pets,
         | 
| 156 | 
            +
              response_validation: ENV['RACK_ENV'] == 'test',
         | 
| 157 | 
            +
              router_raise_error:  ENV['RACK_ENV'] == 'test'
         | 
| 158 | 
            +
            )
         | 
| 154 159 | 
             
            ```
         | 
| 155 160 |  | 
| 156 161 | 
             
            The above will use the mentioned Rack middlewares to:
         | 
| @@ -159,6 +164,17 @@ The above will use the mentioned Rack middlewares to: | |
| 159 164 | 
             
            - Map the request to a method call `Pets.find_pet` based on the `operationId` in the API description
         | 
| 160 165 | 
             
            - Set the response content type according to your spec (here with the default status code `200`)
         | 
| 161 166 |  | 
| 167 | 
            +
            ### Options and their defaults:
         | 
| 168 | 
            +
             | 
| 169 | 
            +
            | Name | Possible values | Description | Default
         | 
| 170 | 
            +
            |:---|---|---|---|
         | 
| 171 | 
            +
            | `spec_path` || A filepath to an OpenAPI definition file. |
         | 
| 172 | 
            +
            | `namespace:` || A class or module where to find the handler methods.|
         | 
| 173 | 
            +
            | `response_validation:` | `true`, `false` | If set to true it raises an exception if the response is invalid. This is useful during testing. | `false`
         | 
| 174 | 
            +
            | `router_raise_error:` | `true`, `false` | If set to true it raises an exception (subclass of `OpenapiFirst::Error` when a request path/method is not specified. This is useful during testing. | `false`
         | 
| 175 | 
            +
            | `request_validation_raise_error:` | `true`, `false` | If set to true it raises an exception (subclass of `OpenapiFirst::Error` when a request is not valid. | `false`
         | 
| 176 | 
            +
             | 
| 177 | 
            +
             | 
| 162 178 | 
             
            Handler functions (`find_pet`) are called with two arguments:
         | 
| 163 179 |  | 
| 164 180 | 
             
            - `params` - Holds the parsed request body, filtered query params and path parameters
         | 
    
        data/benchmarks/Gemfile.lock
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            PATH
         | 
| 2 2 | 
             
              remote: ..
         | 
| 3 3 | 
             
              specs:
         | 
| 4 | 
            -
                openapi_first (0.12. | 
| 4 | 
            +
                openapi_first (0.12.3)
         | 
| 5 5 | 
             
                  deep_merge (>= 1.2.1)
         | 
| 6 6 | 
             
                  hanami-router (~> 2.0.alpha3)
         | 
| 7 7 | 
             
                  hanami-utils (~> 2.0.alpha1)
         | 
| @@ -25,7 +25,7 @@ GEM | |
| 25 25 | 
             
                benchmark-memory (0.1.2)
         | 
| 26 26 | 
             
                  memory_profiler (~> 0.9)
         | 
| 27 27 | 
             
                builder (3.2.4)
         | 
| 28 | 
            -
                committee (4. | 
| 28 | 
            +
                committee (4.1.0)
         | 
| 29 29 | 
             
                  json_schema (~> 0.14, >= 0.14.3)
         | 
| 30 30 | 
             
                  openapi_parser (>= 0.11.1)
         | 
| 31 31 | 
             
                  rack (>= 1.5)
         | 
| @@ -83,7 +83,7 @@ GEM | |
| 83 83 | 
             
                memory_profiler (0.9.14)
         | 
| 84 84 | 
             
                mini_portile2 (2.4.0)
         | 
| 85 85 | 
             
                minitest (5.14.1)
         | 
| 86 | 
            -
                multi_json (1. | 
| 86 | 
            +
                multi_json (1.15.0)
         | 
| 87 87 | 
             
                mustermann (1.1.1)
         | 
| 88 88 | 
             
                  ruby2_keywords (~> 0.0.1)
         | 
| 89 89 | 
             
                mustermann-contrib (1.1.1)
         | 
| @@ -91,9 +91,9 @@ GEM | |
| 91 91 | 
             
                  mustermann (= 1.1.1)
         | 
| 92 92 | 
             
                mustermann-grape (1.0.1)
         | 
| 93 93 | 
             
                  mustermann (>= 1.0.0)
         | 
| 94 | 
            -
                nokogiri (1.10. | 
| 94 | 
            +
                nokogiri (1.10.10)
         | 
| 95 95 | 
             
                  mini_portile2 (~> 2.4.0)
         | 
| 96 | 
            -
                oas_parser (0.25. | 
| 96 | 
            +
                oas_parser (0.25.1)
         | 
| 97 97 | 
             
                  activesupport (>= 4.0.0)
         | 
| 98 98 | 
             
                  addressable (~> 2.3)
         | 
| 99 99 | 
             
                  builder (~> 3.2.3)
         | 
| @@ -125,7 +125,7 @@ GEM | |
| 125 125 | 
             
                tzinfo (1.2.7)
         | 
| 126 126 | 
             
                  thread_safe (~> 0.1)
         | 
| 127 127 | 
             
                uri_template (0.7.0)
         | 
| 128 | 
            -
                zeitwerk (2.3. | 
| 128 | 
            +
                zeitwerk (2.3.1)
         | 
| 129 129 |  | 
| 130 130 | 
             
            PLATFORMS
         | 
| 131 131 | 
             
              ruby
         | 
    
        data/examples/app.rb
    CHANGED
    
    | @@ -17,5 +17,6 @@ oas_path = File.absolute_path('./openapi.yaml', __dir__) | |
| 17 17 | 
             
            App = OpenapiFirst.app(
         | 
| 18 18 | 
             
              oas_path,
         | 
| 19 19 | 
             
              namespace: Web,
         | 
| 20 | 
            -
               | 
| 20 | 
            +
              router_raise_error: OpenapiFirst.env == 'test',
         | 
| 21 | 
            +
              response_validation: OpenapiFirst.env == 'test'
         | 
| 21 22 | 
             
            )
         | 
    
        data/lib/openapi_first.rb
    CHANGED
    
    | @@ -31,14 +31,39 @@ module OpenapiFirst | |
| 31 31 | 
             
                Definition.new(parsed)
         | 
| 32 32 | 
             
              end
         | 
| 33 33 |  | 
| 34 | 
            -
              def self.app( | 
| 34 | 
            +
              def self.app(
         | 
| 35 | 
            +
                spec,
         | 
| 36 | 
            +
                namespace:,
         | 
| 37 | 
            +
                router_raise_error: false,
         | 
| 38 | 
            +
                request_validation_raise_error: false,
         | 
| 39 | 
            +
                response_validation: false
         | 
| 40 | 
            +
              )
         | 
| 35 41 | 
             
                spec = OpenapiFirst.load(spec) if spec.is_a?(String)
         | 
| 36 | 
            -
                App.new( | 
| 42 | 
            +
                App.new(
         | 
| 43 | 
            +
                  nil,
         | 
| 44 | 
            +
                  spec,
         | 
| 45 | 
            +
                  namespace: namespace,
         | 
| 46 | 
            +
                  router_raise_error: router_raise_error,
         | 
| 47 | 
            +
                  request_validation_raise_error: request_validation_raise_error,
         | 
| 48 | 
            +
                  response_validation: response_validation
         | 
| 49 | 
            +
                )
         | 
| 37 50 | 
             
              end
         | 
| 38 51 |  | 
| 39 | 
            -
              def self.middleware( | 
| 52 | 
            +
              def self.middleware(
         | 
| 53 | 
            +
                spec,
         | 
| 54 | 
            +
                namespace:,
         | 
| 55 | 
            +
                router_raise_error: false,
         | 
| 56 | 
            +
                request_validation_raise_error: false,
         | 
| 57 | 
            +
                response_validation: false
         | 
| 58 | 
            +
              )
         | 
| 40 59 | 
             
                spec = OpenapiFirst.load(spec) if spec.is_a?(String)
         | 
| 41 | 
            -
                AppWithOptions.new( | 
| 60 | 
            +
                AppWithOptions.new(
         | 
| 61 | 
            +
                  spec,
         | 
| 62 | 
            +
                  namespace: namespace,
         | 
| 63 | 
            +
                  router_raise_error: router_raise_error,
         | 
| 64 | 
            +
                  request_validation_raise_error: request_validation_raise_error,
         | 
| 65 | 
            +
                  response_validation: response_validation
         | 
| 66 | 
            +
                )
         | 
| 42 67 | 
             
              end
         | 
| 43 68 |  | 
| 44 69 | 
             
              class AppWithOptions
         | 
    
        data/lib/openapi_first/app.rb
    CHANGED
    
    | @@ -5,12 +5,19 @@ require 'logger' | |
| 5 5 |  | 
| 6 6 | 
             
            module OpenapiFirst
         | 
| 7 7 | 
             
              class App
         | 
| 8 | 
            -
                def initialize( | 
| 8 | 
            +
                def initialize( # rubocop:disable Metrics/ParameterLists
         | 
| 9 | 
            +
                  parent_app,
         | 
| 10 | 
            +
                  spec,
         | 
| 11 | 
            +
                  namespace:,
         | 
| 12 | 
            +
                  router_raise_error: false,
         | 
| 13 | 
            +
                  request_validation_raise_error: false,
         | 
| 14 | 
            +
                  response_validation: false
         | 
| 15 | 
            +
                )
         | 
| 9 16 | 
             
                  @stack = Rack::Builder.app do
         | 
| 10 17 | 
             
                    freeze_app
         | 
| 11 | 
            -
                    use OpenapiFirst::Router, spec: spec, raise_error:  | 
| 12 | 
            -
                    use OpenapiFirst::RequestValidation, raise_error:  | 
| 13 | 
            -
                    use OpenapiFirst::ResponseValidation if  | 
| 18 | 
            +
                    use OpenapiFirst::Router, spec: spec, raise_error: router_raise_error, parent_app: parent_app
         | 
| 19 | 
            +
                    use OpenapiFirst::RequestValidation, raise_error: request_validation_raise_error
         | 
| 20 | 
            +
                    use OpenapiFirst::ResponseValidation if response_validation
         | 
| 14 21 | 
             
                    run OpenapiFirst::Responder.new(
         | 
| 15 22 | 
             
                      spec: spec,
         | 
| 16 23 | 
             
                      namespace: namespace
         | 
    
        metadata
    CHANGED
    
    | @@ -1,14 +1,14 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: openapi_first
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 0.12. | 
| 4 | 
            +
              version: 0.12.3
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Andreas Haller
         | 
| 8 8 | 
             
            autorequire: 
         | 
| 9 9 | 
             
            bindir: exe
         | 
| 10 10 | 
             
            cert_chain: []
         | 
| 11 | 
            -
            date: 2020- | 
| 11 | 
            +
            date: 2020-07-10 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies:
         | 
| 13 13 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 14 14 | 
             
              name: deep_merge
         |