athar 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.
@@ -0,0 +1,14 @@
1
+ CREATE TRIGGER "<%= trigger_name %>"
2
+ BEFORE DELETE ON "<%= schema_name %>"."<%= table_name %>"
3
+ FOR EACH ROW
4
+ WHEN (coalesce(current_setting('athar.disabled', true), '') <> 'on')
5
+ EXECUTE PROCEDURE athar_capture_delete(
6
+ '<%= record_type %>',
7
+ '<%= schema_name %>',
8
+ '<%= table_name %>',
9
+ '<%= primary_key %>',
10
+ '<%= id_type %>',
11
+ <%= record_type_column_arg %>,
12
+ '<%= capture_mode %>',
13
+ <%= columns_arg %>
14
+ );
@@ -0,0 +1,8 @@
1
+ CREATE TRIGGER "<%= truncate_trigger_name %>"
2
+ AFTER TRUNCATE ON "<%= schema_name %>"."<%= table_name %>"
3
+ FOR EACH STATEMENT
4
+ WHEN (coalesce(current_setting('athar.disabled', true), '') <> 'on')
5
+ EXECUTE PROCEDURE athar_capture_truncate(
6
+ '<%= schema_name %>',
7
+ '<%= table_name %>'
8
+ );
metadata ADDED
@@ -0,0 +1,144 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: athar
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Ali Hamdi Ali Fadel
8
+ bindir: exe
9
+ cert_chain: []
10
+ date: 1980-01-02 00:00:00.000000000 Z
11
+ dependencies:
12
+ - !ruby/object:Gem::Dependency
13
+ name: activejob
14
+ requirement: !ruby/object:Gem::Requirement
15
+ requirements:
16
+ - - ">="
17
+ - !ruby/object:Gem::Version
18
+ version: '7.2'
19
+ type: :runtime
20
+ prerelease: false
21
+ version_requirements: !ruby/object:Gem::Requirement
22
+ requirements:
23
+ - - ">="
24
+ - !ruby/object:Gem::Version
25
+ version: '7.2'
26
+ - !ruby/object:Gem::Dependency
27
+ name: activerecord
28
+ requirement: !ruby/object:Gem::Requirement
29
+ requirements:
30
+ - - ">="
31
+ - !ruby/object:Gem::Version
32
+ version: '7.2'
33
+ type: :runtime
34
+ prerelease: false
35
+ version_requirements: !ruby/object:Gem::Requirement
36
+ requirements:
37
+ - - ">="
38
+ - !ruby/object:Gem::Version
39
+ version: '7.2'
40
+ - !ruby/object:Gem::Dependency
41
+ name: activesupport
42
+ requirement: !ruby/object:Gem::Requirement
43
+ requirements:
44
+ - - ">="
45
+ - !ruby/object:Gem::Version
46
+ version: '7.2'
47
+ type: :runtime
48
+ prerelease: false
49
+ version_requirements: !ruby/object:Gem::Requirement
50
+ requirements:
51
+ - - ">="
52
+ - !ruby/object:Gem::Version
53
+ version: '7.2'
54
+ - !ruby/object:Gem::Dependency
55
+ name: fx
56
+ requirement: !ruby/object:Gem::Requirement
57
+ requirements:
58
+ - - "~>"
59
+ - !ruby/object:Gem::Version
60
+ version: '0.10'
61
+ type: :runtime
62
+ prerelease: false
63
+ version_requirements: !ruby/object:Gem::Requirement
64
+ requirements:
65
+ - - "~>"
66
+ - !ruby/object:Gem::Version
67
+ version: '0.10'
68
+ - !ruby/object:Gem::Dependency
69
+ name: railties
70
+ requirement: !ruby/object:Gem::Requirement
71
+ requirements:
72
+ - - ">="
73
+ - !ruby/object:Gem::Version
74
+ version: '7.2'
75
+ type: :runtime
76
+ prerelease: false
77
+ version_requirements: !ruby/object:Gem::Requirement
78
+ requirements:
79
+ - - ">="
80
+ - !ruby/object:Gem::Version
81
+ version: '7.2'
82
+ description: Athar records database deletions to a separate audit table using PostgreSQL
83
+ triggers, instead of soft-deleting rows in their original tables.
84
+ email:
85
+ - aliosm1997@gmail.com
86
+ executables: []
87
+ extensions: []
88
+ extra_rdoc_files: []
89
+ files:
90
+ - CHANGELOG.md
91
+ - LICENSE.txt
92
+ - README.md
93
+ - lib/athar.rb
94
+ - lib/athar/actor_lookup.rb
95
+ - lib/athar/configuration.rb
96
+ - lib/athar/context.rb
97
+ - lib/athar/deletion.rb
98
+ - lib/athar/engine.rb
99
+ - lib/athar/metadata_stack.rb
100
+ - lib/athar/retention.rb
101
+ - lib/athar/retention_job.rb
102
+ - lib/athar/sql.rb
103
+ - lib/athar/table_event.rb
104
+ - lib/athar/version.rb
105
+ - lib/generators/athar/fx_helper.rb
106
+ - lib/generators/athar/install/functions/athar_capture_delete.sql
107
+ - lib/generators/athar/install/functions/athar_capture_truncate.sql.erb
108
+ - lib/generators/athar/install/functions/athar_filter_keys.sql
109
+ - lib/generators/athar/install/install_generator.rb
110
+ - lib/generators/athar/install/templates/install_migration.rb.erb
111
+ - lib/generators/athar/install/templates/install_migration_fx.rb.erb
112
+ - lib/generators/athar/model/model_generator.rb
113
+ - lib/generators/athar/model/templates/migration.rb.erb
114
+ - lib/generators/athar/model/templates/migration_fx.rb.erb
115
+ - lib/generators/athar/model/triggers/athar_delete.sql.erb
116
+ - lib/generators/athar/model/triggers/athar_truncate.sql.erb
117
+ homepage: https://github.com/milkstrawai/athar
118
+ licenses:
119
+ - MIT
120
+ metadata:
121
+ allowed_push_host: https://rubygems.org
122
+ homepage_uri: https://github.com/milkstrawai/athar
123
+ source_code_uri: https://github.com/milkstrawai/athar
124
+ changelog_uri: https://github.com/milkstrawai/athar/blob/main/CHANGELOG.md
125
+ rubygems_mfa_required: 'true'
126
+ rdoc_options: []
127
+ require_paths:
128
+ - lib
129
+ required_ruby_version: !ruby/object:Gem::Requirement
130
+ requirements:
131
+ - - ">="
132
+ - !ruby/object:Gem::Version
133
+ version: 3.2.0
134
+ required_rubygems_version: !ruby/object:Gem::Requirement
135
+ requirements:
136
+ - - ">="
137
+ - !ruby/object:Gem::Version
138
+ version: '0'
139
+ requirements: []
140
+ rubygems_version: 3.6.9
141
+ specification_version: 4
142
+ summary: Database-level deletion auditing for Rails applications using PostgreSQL
143
+ triggers.
144
+ test_files: []