audited-deferrable 0.1.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.
- data/LICENSE +20 -0
- data/README.md +41 -0
- data/lib/audited/deferrable.rb +52 -0
- data/lib/audited/deferrable/base.rb +39 -0
- data/lib/audited/deferrable/resque.rb +30 -0
- data/lib/audited/deferrable/version.rb +5 -0
- metadata +108 -0
data/LICENSE
ADDED
@@ -0,0 +1,20 @@
|
|
1
|
+
The MIT License (MIT)
|
2
|
+
|
3
|
+
Copyright (c) 2013 Ben Hughes
|
4
|
+
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
6
|
+
this software and associated documentation files (the "Software"), to deal in
|
7
|
+
the Software without restriction, including without limitation the rights to
|
8
|
+
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
9
|
+
the Software, and to permit persons to whom the Software is furnished to do so,
|
10
|
+
subject to the following conditions:
|
11
|
+
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
13
|
+
copies or substantial portions of the Software.
|
14
|
+
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
17
|
+
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
18
|
+
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
19
|
+
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
20
|
+
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
data/README.md
ADDED
@@ -0,0 +1,41 @@
|
|
1
|
+
# audited-deferrable
|
2
|
+
|
3
|
+
Extension to the audited gem to deferred writing of audits via Resque, but with modular architecture to support adding other providers such as sidekiq and delayed job (pull requests, please!)
|
4
|
+
|
5
|
+
NOTE: This currently only works with Resque v1, not Resque v2 which is a different API. I'd gladly accept pull requests supporting both.
|
6
|
+
|
7
|
+
## Usage:
|
8
|
+
|
9
|
+
In Gemfile:
|
10
|
+
|
11
|
+
gem "audited-activerecord", "~> 3.0.0"
|
12
|
+
gem "resque", "~> 1.24"
|
13
|
+
gem "audited-deferrable", "~> 0.1.0"
|
14
|
+
|
15
|
+
In an initializer (config/initializers/audited.rb):
|
16
|
+
|
17
|
+
Audited.defer_with = :resque
|
18
|
+
|
19
|
+
After this, all of your audits will be written to the resque queue, and to completely them you'll need to run a resque worker:
|
20
|
+
|
21
|
+
$ QUEUE=audited rake environment resque:work
|
22
|
+
|
23
|
+
## Configuration
|
24
|
+
|
25
|
+
By default, the resque queue is set to :audited, but can be changed:
|
26
|
+
|
27
|
+
Audited::Deferrable::Resque.queue = :custom_queue
|
28
|
+
|
29
|
+
## Custom Handlers
|
30
|
+
|
31
|
+
If you want to write a handler for sidekiq or delayed job, please fork the project and implement as a subclass of Audited::Deferrable::Base, then send a pull request so all can use.
|
32
|
+
|
33
|
+
A completely custom handler can be implemented outside of the gem by subclassing Audited::Deferrable::Base, then setting that class to defer_with directly:
|
34
|
+
|
35
|
+
class Audited::Deferrable::CustomProvider < Audited::Deferrable::Base
|
36
|
+
...
|
37
|
+
end
|
38
|
+
|
39
|
+
Audited.defer_with = Audited::Deferrable::CustomProvider
|
40
|
+
|
41
|
+
|
@@ -0,0 +1,52 @@
|
|
1
|
+
require "audited"
|
2
|
+
|
3
|
+
module Audited
|
4
|
+
module Deferrable
|
5
|
+
extend ActiveSupport::Concern
|
6
|
+
|
7
|
+
included do
|
8
|
+
Audited::Auditor::AuditedInstanceMethods.class_eval do
|
9
|
+
alias_method :write_audit_without_deferrable, :write_audit
|
10
|
+
|
11
|
+
def write_audit(attrs)
|
12
|
+
if Audited.deferrable
|
13
|
+
Audited.deferrable.new(self, Audited::Sweeper.instance.current_user, attrs).defer if auditing_enabled
|
14
|
+
else
|
15
|
+
write_audit_without_deferrable(attrs)
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
module ClassMethods
|
22
|
+
def defer_with
|
23
|
+
@defer_with
|
24
|
+
end
|
25
|
+
|
26
|
+
def defer_with=(value)
|
27
|
+
@defer_with = value
|
28
|
+
deferrable
|
29
|
+
@defer_with
|
30
|
+
end
|
31
|
+
|
32
|
+
def deferrable
|
33
|
+
if @defer_with.nil?
|
34
|
+
nil
|
35
|
+
elsif @defer_with.is_a?(Class)
|
36
|
+
@defer_with
|
37
|
+
else
|
38
|
+
begin
|
39
|
+
require "audited/deferrable/#{@defer_with}"
|
40
|
+
@defer_with = Audited::Deferrable.const_get(@defer_with.to_s.classify)
|
41
|
+
rescue LoadError
|
42
|
+
raise ArgumentError, "No handler exists for '#{@defer_with}'"
|
43
|
+
end
|
44
|
+
end
|
45
|
+
end
|
46
|
+
end
|
47
|
+
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
Audited.send :include, Audited::Deferrable
|
52
|
+
|
@@ -0,0 +1,39 @@
|
|
1
|
+
module Audited
|
2
|
+
module Deferrable
|
3
|
+
class Base
|
4
|
+
|
5
|
+
def initialize(object, user, attrs)
|
6
|
+
@object = object
|
7
|
+
@user = user
|
8
|
+
@attrs = attrs
|
9
|
+
end
|
10
|
+
|
11
|
+
def arguments
|
12
|
+
[
|
13
|
+
@object.class.name,
|
14
|
+
@object.id,
|
15
|
+
@user.try(:class).try(:name),
|
16
|
+
@user.try(:id),
|
17
|
+
@attrs
|
18
|
+
]
|
19
|
+
end
|
20
|
+
|
21
|
+
def self.from_arguments(object_class_name, object_id, user_class_name, user_id, attrs)
|
22
|
+
object = object_class_name.constantize.find(object_id)
|
23
|
+
user = user_class_name.constantize.find(user_id) if user_class_name
|
24
|
+
new(object, user, attrs)
|
25
|
+
end
|
26
|
+
|
27
|
+
def defer
|
28
|
+
raise ArgumentError, "Implementation Required"
|
29
|
+
end
|
30
|
+
|
31
|
+
def work
|
32
|
+
Audited.audit_class.as_user(@user) do
|
33
|
+
@object.send(:write_audit_without_deferrable, @attrs)
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
require "audited"
|
2
|
+
require "audited/deferrable/base"
|
3
|
+
|
4
|
+
module Audited
|
5
|
+
module Deferrable
|
6
|
+
class Resque < Base
|
7
|
+
@queue = :audited
|
8
|
+
|
9
|
+
def self.queue
|
10
|
+
@queue
|
11
|
+
end
|
12
|
+
def self.queue=(value)
|
13
|
+
@queue = value
|
14
|
+
end
|
15
|
+
|
16
|
+
def resque
|
17
|
+
@resque ||= Resque.new
|
18
|
+
end
|
19
|
+
|
20
|
+
def defer
|
21
|
+
::Resque.enqueue(self.class, *arguments)
|
22
|
+
end
|
23
|
+
|
24
|
+
def self.perform(*args)
|
25
|
+
from_arguments(*args).work
|
26
|
+
end
|
27
|
+
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
metadata
ADDED
@@ -0,0 +1,108 @@
|
|
1
|
+
--- !ruby/object:Gem::Specification
|
2
|
+
name: audited-deferrable
|
3
|
+
version: !ruby/object:Gem::Version
|
4
|
+
version: 0.1.0
|
5
|
+
prerelease:
|
6
|
+
platform: ruby
|
7
|
+
authors:
|
8
|
+
- Ben Hughes
|
9
|
+
autorequire:
|
10
|
+
bindir: bin
|
11
|
+
cert_chain: []
|
12
|
+
date: 2013-07-15 00:00:00.000000000 Z
|
13
|
+
dependencies:
|
14
|
+
- !ruby/object:Gem::Dependency
|
15
|
+
name: rails
|
16
|
+
requirement: &70329449422300 !ruby/object:Gem::Requirement
|
17
|
+
none: false
|
18
|
+
requirements:
|
19
|
+
- - ! '>='
|
20
|
+
- !ruby/object:Gem::Version
|
21
|
+
version: 3.1.0
|
22
|
+
type: :runtime
|
23
|
+
prerelease: false
|
24
|
+
version_requirements: *70329449422300
|
25
|
+
- !ruby/object:Gem::Dependency
|
26
|
+
name: audited
|
27
|
+
requirement: &70329449420780 !ruby/object:Gem::Requirement
|
28
|
+
none: false
|
29
|
+
requirements:
|
30
|
+
- - ! '>='
|
31
|
+
- !ruby/object:Gem::Version
|
32
|
+
version: 3.0.0
|
33
|
+
type: :runtime
|
34
|
+
prerelease: false
|
35
|
+
version_requirements: *70329449420780
|
36
|
+
- !ruby/object:Gem::Dependency
|
37
|
+
name: rspec
|
38
|
+
requirement: &70329449418760 !ruby/object:Gem::Requirement
|
39
|
+
none: false
|
40
|
+
requirements:
|
41
|
+
- - ~>
|
42
|
+
- !ruby/object:Gem::Version
|
43
|
+
version: '2.13'
|
44
|
+
type: :development
|
45
|
+
prerelease: false
|
46
|
+
version_requirements: *70329449418760
|
47
|
+
- !ruby/object:Gem::Dependency
|
48
|
+
name: appraisal
|
49
|
+
requirement: &70329449416480 !ruby/object:Gem::Requirement
|
50
|
+
none: false
|
51
|
+
requirements:
|
52
|
+
- - ~>
|
53
|
+
- !ruby/object:Gem::Version
|
54
|
+
version: 0.5.1
|
55
|
+
type: :development
|
56
|
+
prerelease: false
|
57
|
+
version_requirements: *70329449416480
|
58
|
+
- !ruby/object:Gem::Dependency
|
59
|
+
name: sqlite3-ruby
|
60
|
+
requirement: &70329449434560 !ruby/object:Gem::Requirement
|
61
|
+
none: false
|
62
|
+
requirements:
|
63
|
+
- - ~>
|
64
|
+
- !ruby/object:Gem::Version
|
65
|
+
version: 1.3.1
|
66
|
+
type: :development
|
67
|
+
prerelease: false
|
68
|
+
version_requirements: *70329449434560
|
69
|
+
description: Extension to the audited gem to deferred writing of audits via Resque,
|
70
|
+
Delayed Job, or Sidekiq
|
71
|
+
email: ben@railsgarden.com
|
72
|
+
executables: []
|
73
|
+
extensions: []
|
74
|
+
extra_rdoc_files: []
|
75
|
+
files:
|
76
|
+
- lib/audited/deferrable/base.rb
|
77
|
+
- lib/audited/deferrable/resque.rb
|
78
|
+
- lib/audited/deferrable/version.rb
|
79
|
+
- lib/audited/deferrable.rb
|
80
|
+
- LICENSE
|
81
|
+
- README.md
|
82
|
+
homepage: http://github.com/rubiety/audited-deferrable
|
83
|
+
licenses: []
|
84
|
+
post_install_message:
|
85
|
+
rdoc_options: []
|
86
|
+
require_paths:
|
87
|
+
- lib
|
88
|
+
required_ruby_version: !ruby/object:Gem::Requirement
|
89
|
+
none: false
|
90
|
+
requirements:
|
91
|
+
- - ! '>='
|
92
|
+
- !ruby/object:Gem::Version
|
93
|
+
version: '0'
|
94
|
+
required_rubygems_version: !ruby/object:Gem::Requirement
|
95
|
+
none: false
|
96
|
+
requirements:
|
97
|
+
- - ! '>='
|
98
|
+
- !ruby/object:Gem::Version
|
99
|
+
version: 1.3.4
|
100
|
+
requirements: []
|
101
|
+
rubyforge_project: audited-deferrable
|
102
|
+
rubygems_version: 1.8.16
|
103
|
+
signing_key:
|
104
|
+
specification_version: 3
|
105
|
+
summary: Extension to the audited gem to deferred writing of audits via Resque, Delayed
|
106
|
+
Job, or Sidekiq
|
107
|
+
test_files: []
|
108
|
+
has_rdoc:
|