timelines 0.3.1 → 1.0.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 +12 -0
- data/lib/timelines/jobs/event_logger.rb +16 -0
- data/lib/timelines/models/concerns/ephemeral.rb +5 -5
- 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: 0eff14a1838b467534d2d35233a9a2026958cc4f62f9cdb782f5ccbd9d7185d0
|
4
|
+
data.tar.gz: 785b4ca671477ad7e6f9b339407d377fb0ab1c8f51a4ed36655dced6464c659e
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: a6eca22beb642e9b503235aa829c6a8f97fc399ee59c7082cd77f664ef7e38ef49d2fd5993fd30aeb8da973cde3bbeb27b510e5fa4989502a631f614ecec10bc
|
7
|
+
data.tar.gz: c6022bf2a2ef87372fcc5d85ff54e3702a2a7c193b62766b2e3cb95b7d5b29f7a828b6c3458efaffe844bb63d9452eaa16d23327a1edec147a72beb5534eb02a
|
data/README.md
CHANGED
@@ -47,6 +47,18 @@ 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 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
|
+
actor: ->(instance) { instance.created_by },
|
58
|
+
event: ->(instance) { "instance::create" },
|
59
|
+
conditions: ->(instance) { instance.new_record? }
|
60
|
+
```
|
61
|
+
|
50
62
|
## Installation
|
51
63
|
Add this line to your application's Gemfile:
|
52
64
|
|
@@ -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
|
@@ -6,12 +6,12 @@ module Timelines
|
|
6
6
|
|
7
7
|
included do
|
8
8
|
scope :draft, -> { where(started_at: nil) }
|
9
|
-
scope :active, -> {
|
10
|
-
scope :active_at, ->(date) { where(
|
9
|
+
scope :active, -> { active_at(Time.current) }
|
10
|
+
scope :active_at, ->(date) { where(started_at: [..date], ended_at: nil).or(where(started_at: [..date], ended_at: [date..])) }
|
11
11
|
scope :with_deleted, -> { unscope(where: :ended_at) }
|
12
|
-
scope :ended, -> { where
|
12
|
+
scope :ended, -> { where(ended_at: [..Time.current]) }
|
13
13
|
scope :deleted, -> { ended }
|
14
|
-
scope :not_deleted, -> { where(ended_at: nil) }
|
14
|
+
scope :not_deleted, -> { where(ended_at: nil).or(where(ended_at: [Time.current..])) }
|
15
15
|
|
16
16
|
def active?
|
17
17
|
started? && !ended?
|
@@ -32,7 +32,7 @@ module Timelines
|
|
32
32
|
end
|
33
33
|
|
34
34
|
def end!
|
35
|
-
return self if ended_at.present?
|
35
|
+
return self if ended_at.present? && ended_at.past?
|
36
36
|
|
37
37
|
result = ActiveRecord::Base.transaction do
|
38
38
|
run_callbacks(:destroy) do
|
@@ -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:)
|
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
|
+
before_save 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.0
|
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-
|
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
|