timelines 0.4.0 → 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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 24c65a5feb6df7817fe888742b8de6d6c7f81e532ccc41d7290fbd265ff54b1e
4
- data.tar.gz: cb783db345463c6553cbcb3a689ad50effc5b1d83afb84e7492d66fd16e6b9b2
3
+ metadata.gz: 0eff14a1838b467534d2d35233a9a2026958cc4f62f9cdb782f5ccbd9d7185d0
4
+ data.tar.gz: 785b4ca671477ad7e6f9b339407d377fb0ab1c8f51a4ed36655dced6464c659e
5
5
  SHA512:
6
- metadata.gz: 803e6084c141d0bdae68bb4d95062c56d7e2173b15fddc9c22c804c2019317def240954d765e8e82f506e4f48ac34c10124ef0c6290a6ddc531081bd19a34cfa
7
- data.tar.gz: 03f429339c43f0372a58e24c9db90acec09e4f828f9ba74607166edd34a427ceebcf1b2cd699e5e460cfdb58ea0ee78f028ceadfe8d405fc54c03f6e4f9bb499
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,6 +6,7 @@ module Timelines
6
6
 
7
7
  included do
8
8
  include ::Timelines::HasEvents
9
+ include ::Timelines::TracksEvents
9
10
 
10
11
  def audit_trail(reverse: false)
11
12
  ::Timelines::AuditTrail.new(resource: self, reverse: reverse)
@@ -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
@@ -1,3 +1,3 @@
1
1
  module Timelines
2
- VERSION = "0.4.0"
2
+ VERSION = "1.0.0"
3
3
  end
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.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-08-06 00:00:00.000000000 Z
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