45 lines
1.6 KiB
Ruby
45 lines
1.6 KiB
Ruby
|
# frozen_string_literal: true
|
||
|
|
||
|
class DropNonPartitionedAuditEvents < ActiveRecord::Migration[6.0]
|
||
|
include Gitlab::Database::MigrationHelpers
|
||
|
include Gitlab::Database::PartitioningMigrationHelpers::TableManagementHelpers
|
||
|
|
||
|
DOWNTIME = false
|
||
|
|
||
|
def up
|
||
|
drop_nonpartitioned_archive_table(:audit_events)
|
||
|
end
|
||
|
|
||
|
def down
|
||
|
execute(<<~SQL)
|
||
|
CREATE TABLE audit_events_archived (
|
||
|
id integer NOT NULL,
|
||
|
author_id integer NOT NULL,
|
||
|
entity_id integer NOT NULL,
|
||
|
entity_type character varying NOT NULL,
|
||
|
details text,
|
||
|
created_at timestamp without time zone,
|
||
|
ip_address inet,
|
||
|
author_name text,
|
||
|
entity_path text,
|
||
|
target_details text,
|
||
|
target_type text,
|
||
|
target_id bigint,
|
||
|
CONSTRAINT check_492aaa021d CHECK ((char_length(entity_path) <= 5500)),
|
||
|
CONSTRAINT check_82294106dd CHECK ((char_length(target_type) <= 255)),
|
||
|
CONSTRAINT check_83ff8406e2 CHECK ((char_length(author_name) <= 255)),
|
||
|
CONSTRAINT check_d493ec90b5 CHECK ((char_length(target_details) <= 5500))
|
||
|
);
|
||
|
|
||
|
ALTER TABLE ONLY audit_events_archived ADD CONSTRAINT audit_events_archived_pkey PRIMARY KEY (id);
|
||
|
|
||
|
CREATE INDEX analytics_index_audit_events_on_created_at_and_author_id ON audit_events_archived USING btree (created_at, author_id);
|
||
|
CREATE INDEX idx_audit_events_on_entity_id_desc_author_id_created_at ON audit_events_archived USING btree (entity_id, entity_type, id DESC, author_id, created_at);
|
||
|
SQL
|
||
|
|
||
|
with_lock_retries do
|
||
|
create_trigger_to_sync_tables(:audit_events, :audit_events_archived, 'id')
|
||
|
end
|
||
|
end
|
||
|
end
|