active_archive 2.2.2 → 2.3.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
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA1:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: 60185c6924bee924839cffc700ca82fea6244b3c
         | 
| 4 | 
            +
              data.tar.gz: 3b533e035064b8d54f20cef9f8a8b1dadc81538a
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 282ea0ada88bbb6d94e26100b9f2d1701fa8f532a0a396b8979648a3126dd4d2573c582f2c962f3cd46151bd2a899d69aec9164b08ef405856f994fd467fbe15
         | 
| 7 | 
            +
              data.tar.gz: 77573041c37ac6dae54b8d12e3ccf9bbc3420112657e8feca96b0ec570366310ae680c84ad7751891c418f435f9efb1524a303e65b0446c76b2063275c997eb2
         | 
    
        data/lib/active_archive.rb
    CHANGED
    
    | @@ -1,5 +1,5 @@ | |
| 1 | 
            -
            require  | 
| 2 | 
            -
            require  | 
| 1 | 
            +
            require 'active_archive/version'
         | 
| 2 | 
            +
            require 'active_archive/configuration'
         | 
| 3 3 |  | 
| 4 4 | 
             
            module ActiveArchive
         | 
| 5 5 |  | 
| @@ -21,11 +21,11 @@ module ActiveArchive | |
| 21 21 |  | 
| 22 22 | 
             
            end
         | 
| 23 23 |  | 
| 24 | 
            -
            require  | 
| 25 | 
            -
            require  | 
| 26 | 
            -
            require  | 
| 27 | 
            -
            require  | 
| 28 | 
            -
            require  | 
| 24 | 
            +
            require 'active_archive/table_definition'
         | 
| 25 | 
            +
            require 'active_archive/methods'
         | 
| 26 | 
            +
            require 'active_archive/scopes'
         | 
| 27 | 
            +
            require 'active_archive/base'
         | 
| 28 | 
            +
            require 'generators/active_archive/install_generator'
         | 
| 29 29 |  | 
| 30 30 | 
             
            ActiveRecord::Base.send(:include, ActiveArchive::Base)
         | 
| 31 31 |  | 
    
        data/lib/active_archive/base.rb
    CHANGED
    
    | @@ -71,7 +71,7 @@ module ActiveArchive | |
| 71 71 |  | 
| 72 72 | 
             
                def get_dependent_records
         | 
| 73 73 | 
             
                  dependent_records = {}
         | 
| 74 | 
            -
                  self.class.reflections.each do |key, reflection|
         | 
| 74 | 
            +
                  self.class.reflections.lazy.each do |key, reflection|
         | 
| 75 75 | 
             
                    if reflection.options[:dependent] == :destroy
         | 
| 76 76 | 
             
                      next unless records = self.send(key)
         | 
| 77 77 | 
             
                      if records.respond_to?(:size)
         | 
| @@ -88,7 +88,7 @@ module ActiveArchive | |
| 88 88 | 
             
                end
         | 
| 89 89 |  | 
| 90 90 | 
             
                def permanently_delete_records(dependent_records)
         | 
| 91 | 
            -
                  dependent_records.each do |klass, ids|
         | 
| 91 | 
            +
                  dependent_records.lazy.each do |klass, ids|
         | 
| 92 92 | 
             
                    ids.each do |id|
         | 
| 93 93 | 
             
                      record = begin
         | 
| 94 94 | 
             
                        klass.unscoped.find(id)
         | 
| @@ -110,11 +110,12 @@ module ActiveArchive | |
| 110 110 |  | 
| 111 111 | 
             
                def unarchive_destroyed_dependent_records
         | 
| 112 112 | 
             
                  self.class.reflections
         | 
| 113 | 
            -
                            . | 
| 113 | 
            +
                            .lazy
         | 
| 114 | 
            +
                            .select { |name, reflection| (reflection.options[:dependent].to_s == 'destroy'.freeze) && reflection.klass.archivable? }
         | 
| 114 115 | 
             
                            .each do |name, reflection|
         | 
| 115 | 
            -
                              cardinality = reflection.macro.to_s.gsub('has_', '')
         | 
| 116 | 
            +
                              cardinality = reflection.macro.to_s.gsub('has_'.freeze, ''.freeze)
         | 
| 116 117 |  | 
| 117 | 
            -
                              if cardinality == 'many'
         | 
| 118 | 
            +
                              if cardinality == 'many'.freeze
         | 
| 118 119 | 
             
                                records = archived_at.nil? ? send(name).unscoped : send(name).unscoped.where(
         | 
| 119 120 | 
             
                                    [
         | 
| 120 121 | 
             
                                      "#{reflection.quoted_table_name}.archived_at > ? AND #{reflection.quoted_table_name}.archived_at < ?",
         | 
| @@ -122,13 +123,13 @@ module ActiveArchive | |
| 122 123 | 
             
                                      archived_at + ActiveArchive.configuration.dependent_record_window
         | 
| 123 124 | 
             
                                    ]
         | 
| 124 125 | 
             
                                  )
         | 
| 125 | 
            -
                              elsif cardinality == 'one' or cardinality == 'belongs_to'
         | 
| 126 | 
            +
                              elsif cardinality == 'one'.freeze or cardinality == 'belongs_to'.freeze
         | 
| 126 127 | 
             
                                self.class.unscoped do
         | 
| 127 128 | 
             
                                  records = [] << send(name)
         | 
| 128 129 | 
             
                                end
         | 
| 129 130 | 
             
                              end
         | 
| 130 131 |  | 
| 131 | 
            -
                              [records].flatten.compact.each { |d| d.unarchive }
         | 
| 132 | 
            +
                              [records].flatten.compact.lazy.each { |d| d.unarchive }
         | 
| 132 133 | 
             
                              send(name, :reload)
         | 
| 133 134 | 
             
                            end
         | 
| 134 135 | 
             
                end
         | 
| @@ -141,18 +142,18 @@ module ActiveArchive | |
| 141 142 | 
             
                  begin
         | 
| 142 143 | 
             
                    should_ignore_validations?(force) ? record.save(validate: false) : record.save!
         | 
| 143 144 |  | 
| 144 | 
            -
                    if ::Gem::Version.new(::ActiveRecord::VERSION::STRING) < ::Gem::Version.new('4.2.0')
         | 
| 145 | 
            +
                    if ::Gem::Version.new(::ActiveRecord::VERSION::STRING) < ::Gem::Version.new('4.2.0'.freeze)
         | 
| 145 146 | 
             
                      @attributes       = record.attributes
         | 
| 146 147 | 
             
                      @attributes_cache = record.attributes.except(record.class.serialized_attributes.keys)
         | 
| 147 148 |  | 
| 148 149 | 
             
                      if defined?(::ActiveRecord::AttributeMethods::Serialization::Attribute)
         | 
| 149 150 | 
             
                        serialized_attribute_class = ::ActiveRecord::AttributeMethods::Serialization::Attribute
         | 
| 150 | 
            -
                        self.class.serialized_attributes.each do |key, coder|
         | 
| 151 | 
            +
                        self.class.serialized_attributes.lazy.each do |key, coder|
         | 
| 151 152 | 
             
                          @attributes[key] = serialized_attribute_class.new(coder, @attributes[key], :unserialized) if @attributes.key?(key)
         | 
| 152 153 | 
             
                        end
         | 
| 153 154 | 
             
                      end
         | 
| 154 155 | 
             
                    else
         | 
| 155 | 
            -
                      @attributes = record.instance_variable_get('@attributes')
         | 
| 156 | 
            +
                      @attributes = record.instance_variable_get('@attributes'.freeze)
         | 
| 156 157 | 
             
                    end
         | 
| 157 158 | 
             
                  rescue Exception => e
         | 
| 158 159 | 
             
                    record.destroy
         | 
| @@ -2,7 +2,7 @@ module ActiveArchive | |
| 2 2 | 
             
              module Methods
         | 
| 3 3 |  | 
| 4 4 | 
             
                def archivable?
         | 
| 5 | 
            -
                  columns.detect { |c| c.name ==  | 
| 5 | 
            +
                  columns.lazy.detect { |c| c.name == 'archived_at'.freeze }
         | 
| 6 6 | 
             
                end
         | 
| 7 7 |  | 
| 8 8 | 
             
                def archive_all(conditions=nil)
         | 
| @@ -10,7 +10,7 @@ module ActiveArchive | |
| 10 10 | 
             
                end
         | 
| 11 11 |  | 
| 12 12 | 
             
                def unarchive_all(conditions=nil)
         | 
| 13 | 
            -
                  (conditions ? where(conditions) : all).to_a.each { |r| r.unarchive }
         | 
| 13 | 
            +
                  (conditions ? where(conditions) : all).to_a.lazy.each { |r| r.unarchive }
         | 
| 14 14 | 
             
                end
         | 
| 15 15 |  | 
| 16 16 | 
             
              end
         | 
| @@ -1,11 +1,11 @@ | |
| 1 | 
            -
            require  | 
| 1 | 
            +
            require 'rails/generators'
         | 
| 2 2 |  | 
| 3 3 | 
             
            module ActiveArchive
         | 
| 4 4 | 
             
              class InstallGenerator < Rails::Generators::Base
         | 
| 5 5 | 
             
                source_root File.expand_path('../templates', __FILE__)
         | 
| 6 6 |  | 
| 7 7 | 
             
                def copy_initializer_file
         | 
| 8 | 
            -
                  copy_file( | 
| 8 | 
            +
                  copy_file('install.rb'.freeze, 'config/initializers/active_archive.rb'.freeze)
         | 
| 9 9 | 
             
                end
         | 
| 10 10 |  | 
| 11 11 | 
             
              end
         | 
    
        metadata
    CHANGED
    
    | @@ -1,14 +1,14 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: active_archive
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 2. | 
| 4 | 
            +
              version: 2.3.0
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Juan Gomez
         | 
| 8 8 | 
             
            autorequire: 
         | 
| 9 9 | 
             
            bindir: exe
         | 
| 10 10 | 
             
            cert_chain: []
         | 
| 11 | 
            -
            date: 2015- | 
| 11 | 
            +
            date: 2015-10-17 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies:
         | 
| 13 13 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 14 14 | 
             
              name: rails
         |