# frozen_string_literal: true module Neetob class CLI module MonthlyAudit module Databases class UuidPrimaryKey < CLI::Base def initialize super() end def run repo_data = [[ "Repository", "All tables have UUID primary keys", "Comments", "Audit Passed" ] ] last_comment = nil NeetoCompliance::NeetoRepos.products.keys.each do |repo| ui.info "Checking #{repo}...", print_to_audit_log: false code_audit_result = Neetob::CLI::Code::Audit.new([repo]).run[0] if code_audit_result[:error] repo_data << [repo, nil, code_audit_result[:error], "No"] next end tables_without_uuid = code_audit_result[:tables_without_uuid] tables_without_uuid.reject! { |table| table == "data_migrations" || table == "server_side_sessions" || table.include?("solid_queue") || table.include?("active_storage") } all_tables_have_uuid_primary_keys = tables_without_uuid.empty? ? "Yes" : "No" audit_passed = all_tables_have_uuid_primary_keys == "Yes" ? "Yes" : "No" comments = tables_without_uuid.empty? ? nil : "Tables without UUID primary keys: #{tables_without_uuid.join(', ')}" same_as_last_comment = audit_passed == "No" && comments == last_comment last_comment = comments if same_as_last_comment comments = "''" end repo_data << [repo, all_tables_have_uuid_primary_keys, comments, audit_passed] end ui.print_table(repo_data) end end end end end end