cache_associations 0.2.2 → 0.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/README.md +10 -1
- data/lib/cache_associations.rb +15 -0
- data/lib/cache_associations/version.rb +1 -1
- metadata +3 -3
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA1:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: 32b28bb91ce8272843abdf8a1bad4a378d7ef6c6
         | 
| 4 | 
            +
              data.tar.gz: f604864414fa453b35bb0427d845eddb26cdbdaa
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 24dee2057a4960ea396a6c1bb22b56e37deb8343e67701b21d67a868d391e4ce2aef3d691b1642258061c44bf149156f3bb9103ef4533543388bf1e5d8e59c18
         | 
| 7 | 
            +
              data.tar.gz: 2fee5df99f3fffcb8620f1aed261430284533f7def49cb6920a6340dd36dc3a71a77cdd694ca8ca2e6b654402febb81d96c1f81e269d5d5e0bd4973b5af9d900
         | 
    
        data/README.md
    CHANGED
    
    | @@ -29,10 +29,19 @@ class User < ApplicationRecord | |
| 29 29 |  | 
| 30 30 | 
             
              has_one :profile
         | 
| 31 31 | 
             
              cache_association :profile do 
         | 
| 32 | 
            -
                #  | 
| 32 | 
            +
                # Put your cache name here
         | 
| 33 | 
            +
                # 
         | 
| 34 | 
            +
                # This is the default naming convention,
         | 
| 35 | 
            +
                # so if you follow the naming strategy,
         | 
| 36 | 
            +
                # you are free with providing the block
         | 
| 33 37 | 
             
                [self.class.name, id, 'profile', update_at.to_i]
         | 
| 34 38 | 
             
              end
         | 
| 35 39 |  | 
| 40 | 
            +
              # you do not need to provide a block to specify the cache 
         | 
| 41 | 
            +
              # name, this will provide you a default name composed of  
         | 
| 42 | 
            +
              # [self.class.reflect_on_association(name).klass.name, id]
         | 
| 43 | 
            +
              cache_global_association :profile
         | 
| 44 | 
            +
              
         | 
| 36 45 | 
             
              def factorial_1000
         | 
| 37 46 | 
             
                (1..1000).inject(:*)
         | 
| 38 47 | 
             
              end
         | 
    
        data/lib/cache_associations.rb
    CHANGED
    
    | @@ -10,6 +10,11 @@ module CacheAssociations | |
| 10 10 | 
             
                  unless reflection = reflect_on_association(name)
         | 
| 11 11 | 
             
                    raise UndefinedAssociationError, "Undefined asscociation #{name}"
         | 
| 12 12 | 
             
                  end
         | 
| 13 | 
            +
             | 
| 14 | 
            +
                  unless block_given?
         | 
| 15 | 
            +
                    cache_name_block = lambda { [self.class.name, id, name, updated_at.to_i] }
         | 
| 16 | 
            +
                  end
         | 
| 17 | 
            +
             | 
| 13 18 | 
             
                  register_cache_name_block(name, cache_name_block)
         | 
| 14 19 | 
             
                  options = Rails.cache.options.merge(options)
         | 
| 15 20 |  | 
| @@ -34,6 +39,16 @@ module CacheAssociations | |
| 34 39 | 
             
                    cache
         | 
| 35 40 | 
             
                  end
         | 
| 36 41 | 
             
                end
         | 
| 42 | 
            +
             | 
| 43 | 
            +
                def cache_global_association(name, global_key = nil, **options)
         | 
| 44 | 
            +
                  if global_key.blank?
         | 
| 45 | 
            +
                    cache_name_block = lambda { [self.class.reflect_on_association(name).klass.name, id] }
         | 
| 46 | 
            +
                  else
         | 
| 47 | 
            +
                    cache_name_block = lambda { global_key }
         | 
| 48 | 
            +
                  end
         | 
| 49 | 
            +
             | 
| 50 | 
            +
                  cache_association(name, **options, &cache_name_block)
         | 
| 51 | 
            +
                end
         | 
| 37 52 |  | 
| 38 53 | 
             
                def cache_method(name, **options, &cache_name_block)
         | 
| 39 54 | 
             
                  register_cache_name_block(name, cache_name_block)
         | 
    
        metadata
    CHANGED
    
    | @@ -1,14 +1,14 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: cache_associations
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 0. | 
| 4 | 
            +
              version: '0.3'
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Fuxin Hao
         | 
| 8 8 | 
             
            autorequire: 
         | 
| 9 9 | 
             
            bindir: exe
         | 
| 10 10 | 
             
            cert_chain: []
         | 
| 11 | 
            -
            date:  | 
| 11 | 
            +
            date: 2018-07-10 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies:
         | 
| 13 13 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 14 14 | 
             
              name: rails
         | 
| @@ -105,7 +105,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement | |
| 105 105 | 
             
                  version: '0'
         | 
| 106 106 | 
             
            requirements: []
         | 
| 107 107 | 
             
            rubyforge_project: 
         | 
| 108 | 
            -
            rubygems_version: 2. | 
| 108 | 
            +
            rubygems_version: 2.6.11
         | 
| 109 109 | 
             
            signing_key: 
         | 
| 110 110 | 
             
            specification_version: 4
         | 
| 111 111 | 
             
            summary: To make Low-Level caching collaborate with Association caching.
         |