mirror of
https://github.com/SrIzan10/hc-harbor.git
synced 2026-05-01 10:45:21 +00:00
audit logs because neon messed it up
This commit is contained in:
5
db/migrate/20250630000001_add_is_superadmin_to_users.rb
Normal file
5
db/migrate/20250630000001_add_is_superadmin_to_users.rb
Normal file
@@ -0,0 +1,5 @@
|
||||
class AddIsSuperadminToUsers < ActiveRecord::Migration[8.0]
|
||||
def change
|
||||
add_column :users, :is_superadmin, :boolean, default: false, null: false
|
||||
end
|
||||
end
|
||||
17
db/migrate/20250630000002_create_trust_level_audit_logs.rb
Normal file
17
db/migrate/20250630000002_create_trust_level_audit_logs.rb
Normal file
@@ -0,0 +1,17 @@
|
||||
class CreateTrustLevelAuditLogs < ActiveRecord::Migration[8.0]
|
||||
def change
|
||||
create_table :trust_level_audit_logs do |t|
|
||||
t.references :user, null: false, foreign_key: true, index: true
|
||||
t.references :changed_by, null: false, foreign_key: { to_table: :users }, index: true
|
||||
t.string :previous_trust_level, null: false
|
||||
t.string :new_trust_level, null: false
|
||||
t.text :reason, null: true
|
||||
t.text :notes, null: true
|
||||
|
||||
t.timestamps null: false
|
||||
end
|
||||
|
||||
add_index :trust_level_audit_logs, [ :user_id, :created_at ], name: 'index_trust_level_audit_logs_on_user_and_created_at'
|
||||
add_index :trust_level_audit_logs, [ :changed_by_id, :created_at ], name: 'index_trust_level_audit_logs_on_changed_by_and_created_at'
|
||||
end
|
||||
end
|
||||
20
db/schema.rb
generated
20
db/schema.rb
generated
@@ -10,7 +10,7 @@
|
||||
#
|
||||
# It's strongly recommended that you check this file into your version control system.
|
||||
|
||||
ActiveRecord::Schema[8.0].define(version: 2025_06_28_011017) do
|
||||
ActiveRecord::Schema[8.0].define(version: 2025_06_30_000002) do
|
||||
create_schema "pganalyze"
|
||||
|
||||
# These are extensions that must be enabled in order to support this database
|
||||
@@ -483,6 +483,21 @@ ActiveRecord::Schema[8.0].define(version: 2025_06_28_011017) do
|
||||
t.index ["key_hash"], name: "index_solid_cache_entries_on_key_hash", unique: true
|
||||
end
|
||||
|
||||
create_table "trust_level_audit_logs", force: :cascade do |t|
|
||||
t.bigint "user_id", null: false
|
||||
t.bigint "changed_by_id", null: false
|
||||
t.string "previous_trust_level", null: false
|
||||
t.string "new_trust_level", null: false
|
||||
t.text "reason"
|
||||
t.text "notes"
|
||||
t.datetime "created_at", null: false
|
||||
t.datetime "updated_at", null: false
|
||||
t.index ["changed_by_id", "created_at"], name: "index_trust_level_audit_logs_on_changed_by_and_created_at"
|
||||
t.index ["changed_by_id"], name: "index_trust_level_audit_logs_on_changed_by_id"
|
||||
t.index ["user_id", "created_at"], name: "index_trust_level_audit_logs_on_user_and_created_at"
|
||||
t.index ["user_id"], name: "index_trust_level_audit_logs_on_user_id"
|
||||
end
|
||||
|
||||
create_table "users", force: :cascade do |t|
|
||||
t.string "slack_uid"
|
||||
t.datetime "created_at", null: false
|
||||
@@ -506,6 +521,7 @@ ActiveRecord::Schema[8.0].define(version: 2025_06_28_011017) do
|
||||
t.string "mailing_address_otc"
|
||||
t.boolean "allow_public_stats_lookup", default: true, null: false
|
||||
t.boolean "default_timezone_leaderboard", default: true, null: false
|
||||
t.boolean "is_superadmin", default: false, null: false
|
||||
t.index ["github_uid", "github_access_token"], name: "index_users_on_github_uid_and_access_token"
|
||||
t.index ["github_uid"], name: "index_users_on_github_uid"
|
||||
t.index ["slack_uid"], name: "index_users_on_slack_uid", unique: true
|
||||
@@ -552,5 +568,7 @@ ActiveRecord::Schema[8.0].define(version: 2025_06_28_011017) do
|
||||
add_foreign_key "project_repo_mappings", "users"
|
||||
add_foreign_key "repo_host_events", "users"
|
||||
add_foreign_key "sign_in_tokens", "users"
|
||||
add_foreign_key "trust_level_audit_logs", "users"
|
||||
add_foreign_key "trust_level_audit_logs", "users", column: "changed_by_id"
|
||||
add_foreign_key "wakatime_mirrors", "users"
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user