timelines 0.4.0 → 1.0.1
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 +13 -0
- data/lib/timelines/jobs/event_logger.rb +16 -0
- data/lib/timelines/models/concerns/has_audit_trail.rb +1 -0
- data/lib/timelines/models/concerns/tracks_events.rb +26 -0
- data/lib/timelines/version.rb +1 -1
- data/lib/timelines.rb +2 -0
- metadata +4 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 7c47e84c6bedc124729951662521fc68baeaede671752dc275f7d2114bcd4983
|
4
|
+
data.tar.gz: 1875a77f55430a151878b874b99dabb4d7adfb9a3ba68a2829d861485f907b47
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: d698afedff13c041581a16b149d5565eee5ce537740d2c8a601b292ab14dd1337eb0807e993e669e7e50ed98eb68c04d875da317a6aff607db910cac98d2d48b
|
7
|
+
data.tar.gz: 606a6e61c05cb1972b1ca4eca2d39556954e6adc75a640d81790a526411088abe392bc38a6428c72db652ef18a09b4a4592a0ed06c81ecac1025fe28f7b2b95b
|
data/README.md
CHANGED
@@ -47,6 +47,19 @@ And the following Class methods:
|
|
47
47
|
.self.destroy_all
|
48
48
|
```
|
49
49
|
|
50
|
+
Enables defining conditions for automated logging of events for a record's many lifecycle events, which are logged through an ActiveJob adapter.
|
51
|
+
|
52
|
+
The parameters are an optional `on:` param (which defaults to `before_save`), and 4 procs that define the resource, actor, event, and conditions for logging the event. Conditions can be used to ensure an event only fires on a new record, or on a record that has been updated in a specific way/meets certain criteria to be eligible to log the event.
|
53
|
+
```ruby
|
54
|
+
include Timelines::TracksEvents
|
55
|
+
tracks_timelines_event :create_event,
|
56
|
+
resource: ->(instance) { instance },
|
57
|
+
on: :before_create,
|
58
|
+
actor: ->(instance) { instance.created_by },
|
59
|
+
event: ->(instance) { "instance::create" },
|
60
|
+
conditions: ->(instance) { instance.new_record? }
|
61
|
+
```
|
62
|
+
|
50
63
|
## Installation
|
51
64
|
Add this line to your application's Gemfile:
|
52
65
|
|
@@ -0,0 +1,16 @@
|
|
1
|
+
module Timelines
|
2
|
+
class EventLogger < ::ActiveJob::Base
|
3
|
+
queue_as :default
|
4
|
+
|
5
|
+
def perform(actor_type, actor_id, resource_klass, resource_id, event, timestamp = Time.current)
|
6
|
+
actor = actor_type.constantize.find_by(id: actor_id)
|
7
|
+
resource = resource_klass.constantize.find_by(id: resource_id)
|
8
|
+
return unless actor.present? && resource.present? && event.present?
|
9
|
+
|
10
|
+
::Timelines::Event.create!(actor: actor, resource: resource, event: event, created_at: timestamp)
|
11
|
+
rescue => e
|
12
|
+
Rails.logger.error("Failed to log event: #{e.message} - #{actor_type} #{actor_id} - #{resource_klass} #{resource_id} - #{event}")
|
13
|
+
raise e
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
@@ -0,0 +1,26 @@
|
|
1
|
+
require "active_support/concern"
|
2
|
+
|
3
|
+
module Timelines
|
4
|
+
module TracksEvents
|
5
|
+
extend ActiveSupport::Concern
|
6
|
+
|
7
|
+
included do
|
8
|
+
def self.tracks_timelines_event(name, actor:, resource:, event:, conditions:, on: :before_save)
|
9
|
+
method_name = "track_#{name}_event"
|
10
|
+
define_method method_name.to_sym do
|
11
|
+
event_should_be_logged = conditions.call(self)
|
12
|
+
return unless event_should_be_logged
|
13
|
+
|
14
|
+
event_actor = actor.call(self)
|
15
|
+
event_resource = resource.call(self)
|
16
|
+
event_summary = event.call(self)
|
17
|
+
return unless event_actor.present? && event_resource.present? && event_summary.present?
|
18
|
+
|
19
|
+
::Timelines::EventLogger.perform_later(event_actor.class.name, event_actor.id, event_resource.class.name, event_resource.id, event_summary, Time.current)
|
20
|
+
end
|
21
|
+
|
22
|
+
send(on, method_name.to_sym)
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
data/lib/timelines/version.rb
CHANGED
data/lib/timelines.rb
CHANGED
@@ -1,7 +1,9 @@
|
|
1
1
|
require "timelines/version"
|
2
|
+
require "timelines/jobs/event_logger"
|
2
3
|
require "timelines/models/concerns/ephemeral"
|
3
4
|
require "timelines/models/concerns/has_events"
|
4
5
|
require "timelines/models/concerns/has_audit_trail"
|
6
|
+
require "timelines/models/concerns/tracks_events"
|
5
7
|
require "timelines/models/concerns/audit_trail"
|
6
8
|
require "timelines/models/event"
|
7
9
|
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: timelines
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 1.0.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Craig Gilchrist
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2024-08-
|
11
|
+
date: 2024-08-31 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rails
|
@@ -39,10 +39,12 @@ files:
|
|
39
39
|
- lib/generators/timelines/install/templates/create_timelines_events.rb
|
40
40
|
- lib/tasks/timelines_tasks.rake
|
41
41
|
- lib/timelines.rb
|
42
|
+
- lib/timelines/jobs/event_logger.rb
|
42
43
|
- lib/timelines/models/concerns/audit_trail.rb
|
43
44
|
- lib/timelines/models/concerns/ephemeral.rb
|
44
45
|
- lib/timelines/models/concerns/has_audit_trail.rb
|
45
46
|
- lib/timelines/models/concerns/has_events.rb
|
47
|
+
- lib/timelines/models/concerns/tracks_events.rb
|
46
48
|
- lib/timelines/models/event.rb
|
47
49
|
- lib/timelines/version.rb
|
48
50
|
homepage: https://github.com/Craggar/timelines
|