mirror of
https://github.com/internetee/registry.git
synced 2025-06-06 20:55:44 +02:00
Add registrant verification versions table according to existing logic
Creates a log_registrant_verifications table and version class as per https://github.com/internetee/registry/issues/1425#issuecomment-567117002
This commit is contained in:
parent
7f308d4123
commit
c4ffdbd650
6 changed files with 300 additions and 202 deletions
|
@ -1,7 +1,7 @@
|
||||||
# Used in Registrant portal to collect registrant verifications
|
# Used in Registrant portal to collect registrant verifications
|
||||||
# Registrant postgres user can access this table directly.
|
# Registrant postgres user can access this table directly.
|
||||||
class RegistrantVerification < ApplicationRecord
|
class RegistrantVerification < ApplicationRecord
|
||||||
has_paper_trail
|
has_paper_trail class_name: 'RegistrantVerificationVersion'
|
||||||
|
|
||||||
# actions
|
# actions
|
||||||
CONFIRMED = 'confirmed'
|
CONFIRMED = 'confirmed'
|
||||||
|
|
7
app/models/version/registrant_verification_version.rb
Normal file
7
app/models/version/registrant_verification_version.rb
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
class RegistrantVerificationVersion < PaperTrail::Version
|
||||||
|
include VersionSession
|
||||||
|
self.table_name = :log_registrant_verifications
|
||||||
|
self.sequence_name = :log_registrant_verifications_id_seq
|
||||||
|
|
||||||
|
scope :deleted, -> { where(event: 'destroy') }
|
||||||
|
end
|
|
@ -0,0 +1,24 @@
|
||||||
|
class AddJsonBasedVersionToRegistrantVerifications < ActiveRecord::Migration[5.0]
|
||||||
|
def change
|
||||||
|
name = 'registrant_verification'
|
||||||
|
table_name = "log_#{name.tableize}"
|
||||||
|
|
||||||
|
create_table table_name do |t|
|
||||||
|
t.string :item_type, null: false
|
||||||
|
t.integer :item_id, null: false
|
||||||
|
t.string :event, null: false
|
||||||
|
t.string :whodunnit
|
||||||
|
t.json :object
|
||||||
|
t.json :object_changes
|
||||||
|
t.datetime :created_at
|
||||||
|
t.string :session
|
||||||
|
end
|
||||||
|
add_index table_name, [:item_type, :item_id]
|
||||||
|
add_index table_name, :whodunnit
|
||||||
|
|
||||||
|
add_column name.tableize, :creator_id_tmp, :integer
|
||||||
|
add_column name.tableize, :updater_id_tmp, :integer
|
||||||
|
rename_column name.tableize, :creator_id_tmp, :creator_id
|
||||||
|
rename_column name.tableize, :updater_id_tmp, :updater_id
|
||||||
|
end
|
||||||
|
end
|
|
@ -1511,6 +1511,42 @@ CREATE SEQUENCE public.log_notifications_id_seq
|
||||||
ALTER SEQUENCE public.log_notifications_id_seq OWNED BY public.log_notifications.id;
|
ALTER SEQUENCE public.log_notifications_id_seq OWNED BY public.log_notifications.id;
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Name: log_registrant_verifications; Type: TABLE; Schema: public; Owner: -; Tablespace:
|
||||||
|
--
|
||||||
|
|
||||||
|
CREATE TABLE public.log_registrant_verifications (
|
||||||
|
id integer NOT NULL,
|
||||||
|
item_type character varying NOT NULL,
|
||||||
|
item_id integer NOT NULL,
|
||||||
|
event character varying NOT NULL,
|
||||||
|
whodunnit character varying,
|
||||||
|
object json,
|
||||||
|
object_changes json,
|
||||||
|
created_at timestamp without time zone,
|
||||||
|
session character varying
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Name: log_registrant_verifications_id_seq; Type: SEQUENCE; Schema: public; Owner: -
|
||||||
|
--
|
||||||
|
|
||||||
|
CREATE SEQUENCE public.log_registrant_verifications_id_seq
|
||||||
|
START WITH 1
|
||||||
|
INCREMENT BY 1
|
||||||
|
NO MINVALUE
|
||||||
|
NO MAXVALUE
|
||||||
|
CACHE 1;
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Name: log_registrant_verifications_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
|
||||||
|
--
|
||||||
|
|
||||||
|
ALTER SEQUENCE public.log_registrant_verifications_id_seq OWNED BY public.log_registrant_verifications.id;
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Name: log_registrars; Type: TABLE; Schema: public; Owner: -; Tablespace:
|
-- Name: log_registrars; Type: TABLE; Schema: public; Owner: -; Tablespace:
|
||||||
--
|
--
|
||||||
|
@ -1868,7 +1904,9 @@ CREATE TABLE public.registrant_verifications (
|
||||||
updated_at timestamp without time zone,
|
updated_at timestamp without time zone,
|
||||||
action character varying NOT NULL,
|
action character varying NOT NULL,
|
||||||
domain_id integer NOT NULL,
|
domain_id integer NOT NULL,
|
||||||
action_type character varying NOT NULL
|
action_type character varying NOT NULL,
|
||||||
|
creator_id integer,
|
||||||
|
updater_id integer
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
|
@ -2456,6 +2494,13 @@ ALTER TABLE ONLY public.log_nameservers ALTER COLUMN id SET DEFAULT nextval('pub
|
||||||
ALTER TABLE ONLY public.log_notifications ALTER COLUMN id SET DEFAULT nextval('public.log_notifications_id_seq'::regclass);
|
ALTER TABLE ONLY public.log_notifications ALTER COLUMN id SET DEFAULT nextval('public.log_notifications_id_seq'::regclass);
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Name: id; Type: DEFAULT; Schema: public; Owner: -
|
||||||
|
--
|
||||||
|
|
||||||
|
ALTER TABLE ONLY public.log_registrant_verifications ALTER COLUMN id SET DEFAULT nextval('public.log_registrant_verifications_id_seq'::regclass);
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Name: id; Type: DEFAULT; Schema: public; Owner: -
|
-- Name: id; Type: DEFAULT; Schema: public; Owner: -
|
||||||
--
|
--
|
||||||
|
@ -2854,6 +2899,14 @@ ALTER TABLE ONLY public.log_notifications
|
||||||
ADD CONSTRAINT log_notifications_pkey PRIMARY KEY (id);
|
ADD CONSTRAINT log_notifications_pkey PRIMARY KEY (id);
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Name: log_registrant_verifications_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
|
||||||
|
--
|
||||||
|
|
||||||
|
ALTER TABLE ONLY public.log_registrant_verifications
|
||||||
|
ADD CONSTRAINT log_registrant_verifications_pkey PRIMARY KEY (id);
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Name: log_registrars_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
|
-- Name: log_registrars_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace:
|
||||||
--
|
--
|
||||||
|
@ -3487,6 +3540,20 @@ CREATE INDEX index_log_notifications_on_item_type_and_item_id ON public.log_noti
|
||||||
CREATE INDEX index_log_notifications_on_whodunnit ON public.log_notifications USING btree (whodunnit);
|
CREATE INDEX index_log_notifications_on_whodunnit ON public.log_notifications USING btree (whodunnit);
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Name: index_log_registrant_verifications_on_item_type_and_item_id; Type: INDEX; Schema: public; Owner: -; Tablespace:
|
||||||
|
--
|
||||||
|
|
||||||
|
CREATE INDEX index_log_registrant_verifications_on_item_type_and_item_id ON public.log_registrant_verifications USING btree (item_type, item_id);
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Name: index_log_registrant_verifications_on_whodunnit; Type: INDEX; Schema: public; Owner: -; Tablespace:
|
||||||
|
--
|
||||||
|
|
||||||
|
CREATE INDEX index_log_registrant_verifications_on_whodunnit ON public.log_registrant_verifications USING btree (whodunnit);
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Name: index_log_registrars_on_item_type_and_item_id; Type: INDEX; Schema: public; Owner: -; Tablespace:
|
-- Name: index_log_registrars_on_item_type_and_item_id; Type: INDEX; Schema: public; Owner: -; Tablespace:
|
||||||
--
|
--
|
||||||
|
@ -4263,6 +4330,7 @@ INSERT INTO "schema_migrations" (version) VALUES
|
||||||
('20191024153351'),
|
('20191024153351'),
|
||||||
('20191024160038'),
|
('20191024160038'),
|
||||||
('20191206183853'),
|
('20191206183853'),
|
||||||
('20191212133136');
|
('20191212133136'),
|
||||||
|
('20191227110904');
|
||||||
|
|
||||||
|
|
||||||
|
|
1
test/fixtures/registrant_verifications.yml
vendored
1
test/fixtures/registrant_verifications.yml
vendored
|
@ -3,5 +3,4 @@ one:
|
||||||
action_type: domain_delete
|
action_type: domain_delete
|
||||||
created_at: <%= Time.zone.parse('2010-07-05') %>
|
created_at: <%= Time.zone.parse('2010-07-05') %>
|
||||||
domain: shop
|
domain: shop
|
||||||
domain_name: shop.test
|
|
||||||
verification_token: 1234
|
verification_token: 1234
|
||||||
|
|
|
@ -5,7 +5,7 @@ class RegistrantVerificationTest < ActiveSupport::TestCase
|
||||||
registrant_verification = registrant_verifications(:one)
|
registrant_verification = registrant_verifications(:one)
|
||||||
random_action = "random#{rand(100)}"
|
random_action = "random#{rand(100)}"
|
||||||
|
|
||||||
assert_difference -> { PaperTrail::Version.count } do
|
assert_difference -> { RegistrantVerificationVersion.count } do
|
||||||
registrant_verification.update_attributes!(action: random_action)
|
registrant_verification.update_attributes!(action: random_action)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue