salestation 5.1.0 → 5.2.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.
- checksums.yaml +4 -4
- data/README.md +8 -0
- data/lib/salestation/web/extractors.rb +13 -29
- data/salestation.gemspec +2 -1
- metadata +16 -2
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA256:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: 2e5fcc23d8c9f54b0aaa72e76f5f38d791c92330a462427bf5a16e8abe18a14b
         | 
| 4 | 
            +
              data.tar.gz: fe02f21991d869abd3c6eb71c2bbc7163c36a61f0e7850384fe9b4030a01f868
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: c877ea4130f851227bb93461deef52e72b27c92c504cd8bc837d866d43be045ae632036772a571c8dbc01239afa455d8440bdcd90bcbad52732fcc2cd732b3dd
         | 
| 7 | 
            +
              data.tar.gz: a74f378182c0306e5b88b13adf8c25a48ba6bb4efc13ae1e5392b97c3392ede261bb0445cef7e36110fc11e78adda79fe000896769e9c300a19329a48a469b5b
         | 
    
        data/README.md
    CHANGED
    
    | @@ -104,6 +104,14 @@ Multiple extractors can be merged together. If two or more extractors use the sa | |
| 104 104 |  | 
| 105 105 | 
             
            `coercions` can optionally be provided to `BodyParamExtractor` and `QueryParamExtractor`. These can be used to transform the values of the extracted parameters.
         | 
| 106 106 |  | 
| 107 | 
            +
            #### ParamExtractor
         | 
| 108 | 
            +
             | 
| 109 | 
            +
            ParamExtractor, which is also used by `BodyParamExtractor` and `QueryParamExtractor`, 
         | 
| 110 | 
            +
            extracts only the content of such root level keys that are specified when creating the
         | 
| 111 | 
            +
            extractor instance. All other root level keys are discarded. Everything inside the 
         | 
| 112 | 
            +
            whitelisted root level keys is automatically whitelisted.
         | 
| 113 | 
            +
             | 
| 114 | 
            +
             | 
| 107 115 | 
             
            Define a route
         | 
| 108 116 |  | 
| 109 117 | 
             
            ```ruby
         | 
| @@ -1,4 +1,5 @@ | |
| 1 1 | 
             
            # frozen_string_literal: true
         | 
| 2 | 
            +
            require "symbolizer"
         | 
| 2 3 |  | 
| 3 4 | 
             
            module Salestation
         | 
| 4 5 | 
             
              class Web < Module
         | 
| @@ -192,35 +193,18 @@ module Salestation | |
| 192 193 | 
             
                    end
         | 
| 193 194 |  | 
| 194 195 | 
             
                    def self.extract(filters, request_hash)
         | 
| 195 | 
            -
                       | 
| 196 | 
            -
             | 
| 197 | 
            -
             | 
| 198 | 
            -
             | 
| 199 | 
            -
             | 
| 200 | 
            -
             | 
| 201 | 
            -
             | 
| 202 | 
            -
             | 
| 203 | 
            -
             | 
| 204 | 
            -
             | 
| 205 | 
            -
             | 
| 206 | 
            -
             | 
| 207 | 
            -
                            }
         | 
| 208 | 
            -
                          end
         | 
| 209 | 
            -
                        when Hash
         | 
| 210 | 
            -
                          filter.each do |key, nested_filters|
         | 
| 211 | 
            -
                            stringified_key = key.to_s
         | 
| 212 | 
            -
                            if request_hash.key?(stringified_key)
         | 
| 213 | 
            -
                              value = request_hash.fetch(stringified_key)
         | 
| 214 | 
            -
                              extracted_data[key] =
         | 
| 215 | 
            -
                                if !value.is_a?(Hash)
         | 
| 216 | 
            -
                                  value
         | 
| 217 | 
            -
                                else
         | 
| 218 | 
            -
                                  extract(nested_filters, value)
         | 
| 219 | 
            -
                                end
         | 
| 220 | 
            -
                            end
         | 
| 221 | 
            -
                          end
         | 
| 222 | 
            -
                        end
         | 
| 223 | 
            -
                      end
         | 
| 196 | 
            +
                      # Filter as a hash is used in some existing implementations that did not expect full 
         | 
| 197 | 
            +
                      # recursive symbolizing of keys. In this case hash objects at the highest level of object 
         | 
| 198 | 
            +
                      # are represented as hash of filter keys. This is no longer needed, but we support it 
         | 
| 199 | 
            +
                      # to avoid a breaking change.
         | 
| 200 | 
            +
             | 
| 201 | 
            +
                      filters_flat = filters
         | 
| 202 | 
            +
                                      .flat_map {|filter| filter.is_a?(Hash) ? filter.keys : filter}
         | 
| 203 | 
            +
                                      .map(&:to_s)
         | 
| 204 | 
            +
             | 
| 205 | 
            +
                      request_hash = request_hash.select {|k,v| filters_flat.include?(k)}
         | 
| 206 | 
            +
             | 
| 207 | 
            +
                      Symbolizer.symbolize(request_hash)
         | 
| 224 208 | 
             
                    end
         | 
| 225 209 | 
             
                  end
         | 
| 226 210 |  | 
    
        data/salestation.gemspec
    CHANGED
    
    | @@ -4,7 +4,7 @@ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib) | |
| 4 4 |  | 
| 5 5 | 
             
            Gem::Specification.new do |spec|
         | 
| 6 6 | 
             
              spec.name          = "salestation"
         | 
| 7 | 
            -
              spec.version       = "5. | 
| 7 | 
            +
              spec.version       = "5.2.0"
         | 
| 8 8 | 
             
              spec.authors       = ["Glia TechMovers"]
         | 
| 9 9 | 
             
              spec.email         = ["techmovers@glia.com"]
         | 
| 10 10 |  | 
| @@ -30,4 +30,5 @@ Gem::Specification.new do |spec| | |
| 30 30 | 
             
              spec.add_dependency 'dry-struct'
         | 
| 31 31 | 
             
              spec.add_dependency 'dry-types'
         | 
| 32 32 | 
             
              spec.add_dependency 'http-accept', '~> 2.1'
         | 
| 33 | 
            +
              spec.add_dependency 'symbolizer'
         | 
| 33 34 | 
             
            end
         | 
    
        metadata
    CHANGED
    
    | @@ -1,14 +1,14 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: salestation
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 5. | 
| 4 | 
            +
              version: 5.2.0
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Glia TechMovers
         | 
| 8 8 | 
             
            autorequire: 
         | 
| 9 9 | 
             
            bindir: bin
         | 
| 10 10 | 
             
            cert_chain: []
         | 
| 11 | 
            -
            date: 2022-08- | 
| 11 | 
            +
            date: 2022-08-30 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies:
         | 
| 13 13 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 14 14 | 
             
              name: bundler
         | 
| @@ -150,6 +150,20 @@ dependencies: | |
| 150 150 | 
             
                - - "~>"
         | 
| 151 151 | 
             
                  - !ruby/object:Gem::Version
         | 
| 152 152 | 
             
                    version: '2.1'
         | 
| 153 | 
            +
            - !ruby/object:Gem::Dependency
         | 
| 154 | 
            +
              name: symbolizer
         | 
| 155 | 
            +
              requirement: !ruby/object:Gem::Requirement
         | 
| 156 | 
            +
                requirements:
         | 
| 157 | 
            +
                - - ">="
         | 
| 158 | 
            +
                  - !ruby/object:Gem::Version
         | 
| 159 | 
            +
                    version: '0'
         | 
| 160 | 
            +
              type: :runtime
         | 
| 161 | 
            +
              prerelease: false
         | 
| 162 | 
            +
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 163 | 
            +
                requirements:
         | 
| 164 | 
            +
                - - ">="
         | 
| 165 | 
            +
                  - !ruby/object:Gem::Version
         | 
| 166 | 
            +
                    version: '0'
         | 
| 153 167 | 
             
            description: ''
         | 
| 154 168 | 
             
            email:
         | 
| 155 169 | 
             
            - techmovers@glia.com
         |