tilde.news/db/schema.rb

372 lines
22 KiB
Ruby

# This file is auto-generated from the current state of the database. Instead
# of editing this file, please use the migrations feature of Active Record to
# incrementally modify your database, and then regenerate this schema definition.
#
# This file is the source Rails uses to define your schema when running `bin/rails
# db:schema:load`. When creating a new database, `bin/rails db:schema:load` tends to
# be faster and is potentially less error prone than running all of your
# migrations from scratch. Old migrations may fail to apply correctly if those
# migrations use external dependencies or application code.
#
# It's strongly recommended that you check this file into your version control system.
ActiveRecord::Schema[7.0].define(version: 2023_10_23_155620) do
create_table "categories", charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.string "category"
t.datetime "created_at", precision: nil, null: false
t.datetime "updated_at", precision: nil, null: false
t.index ["category"], name: "index_categories_on_category", unique: true
end
create_table "comments", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.datetime "created_at", precision: nil, null: false
t.datetime "updated_at", precision: nil
t.string "short_id", limit: 10, default: "", null: false
t.bigint "story_id", null: false, unsigned: true
t.binary "confidence_order", limit: 3, null: false
t.bigint "user_id", null: false, unsigned: true
t.bigint "parent_comment_id", unsigned: true
t.bigint "thread_id", unsigned: true
t.text "comment", size: :medium, null: false
t.integer "score", default: 1, null: false
t.integer "flags", default: 0, null: false, unsigned: true
t.decimal "confidence", precision: 20, scale: 19, default: "0.0", null: false
t.text "markeddown_comment", size: :medium
t.boolean "is_deleted", default: false
t.boolean "is_moderated", default: false
t.boolean "is_from_email", default: false
t.bigint "hat_id", unsigned: true
t.index ["comment"], name: "index_comments_on_comment", type: :fulltext
t.index ["confidence"], name: "confidence_idx"
t.index ["hat_id"], name: "comments_hat_id_fk"
t.index ["parent_comment_id"], name: "comments_parent_comment_id_fk"
t.index ["score"], name: "index_comments_on_score"
t.index ["short_id"], name: "short_id", unique: true
t.index ["story_id", "short_id"], name: "story_id_short_id"
t.index ["thread_id"], name: "thread_id"
t.index ["user_id"], name: "index_comments_on_user_id"
end
create_table "domains", charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.string "domain"
t.datetime "created_at", precision: nil, null: false
t.datetime "updated_at", precision: nil, null: false
t.datetime "banned_at", precision: nil
t.integer "banned_by_user_id"
t.string "banned_reason", limit: 200
end
create_table "hat_requests", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.datetime "created_at", precision: nil
t.datetime "updated_at", precision: nil
t.bigint "user_id", null: false, unsigned: true
t.string "hat", null: false
t.string "link", null: false
t.text "comment", size: :medium, null: false
t.index ["user_id"], name: "hat_requests_user_id_fk"
end
create_table "hats", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.datetime "created_at", precision: nil
t.datetime "updated_at", precision: nil
t.bigint "user_id", null: false, unsigned: true
t.bigint "granted_by_user_id", null: false, unsigned: true
t.string "hat", null: false
t.string "link"
t.boolean "modlog_use", default: false
t.datetime "doffed_at", precision: nil
t.index ["granted_by_user_id"], name: "hats_granted_by_user_id_fk"
t.index ["user_id"], name: "hats_user_id_fk"
end
create_table "hidden_stories", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.bigint "user_id", null: false, unsigned: true
t.bigint "story_id", null: false, unsigned: true
t.index ["story_id"], name: "hidden_stories_story_id_fk"
t.index ["user_id", "story_id"], name: "index_hidden_stories_on_user_id_and_story_id", unique: true
end
create_table "invitation_requests", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.string "code"
t.boolean "is_verified", default: false
t.string "email", null: false
t.string "name", null: false
t.text "memo"
t.string "ip_address"
t.datetime "created_at", precision: nil, null: false
t.datetime "updated_at", precision: nil, null: false
end
create_table "invitations", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.bigint "user_id", null: false, unsigned: true
t.string "email"
t.string "code"
t.datetime "created_at", precision: nil, null: false
t.datetime "updated_at", precision: nil, null: false
t.text "memo", size: :medium
t.datetime "used_at", precision: nil
t.bigint "new_user_id", unsigned: true
t.index ["new_user_id"], name: "invitations_new_user_id_fk"
t.index ["user_id"], name: "invitations_user_id_fk"
end
create_table "keystores", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.string "key", limit: 50, default: "", null: false
t.bigint "value"
t.index ["key"], name: "key", unique: true
end
create_table "messages", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.datetime "created_at", precision: nil
t.bigint "author_user_id", unsigned: true
t.bigint "recipient_user_id", null: false, unsigned: true
t.boolean "has_been_read", default: false
t.string "subject", limit: 100
t.text "body", size: :medium
t.string "short_id", limit: 30
t.boolean "deleted_by_author", default: false
t.boolean "deleted_by_recipient", default: false
t.bigint "hat_id", unsigned: true
t.index ["hat_id"], name: "index_messages_on_hat_id"
t.index ["recipient_user_id"], name: "messages_recipient_user_id_fk"
t.index ["short_id"], name: "random_hash", unique: true
end
create_table "mod_notes", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.bigint "moderator_user_id", null: false, unsigned: true
t.bigint "user_id", null: false, unsigned: true
t.text "note", null: false
t.text "markeddown_note", null: false
t.datetime "created_at", precision: nil, null: false
t.index ["id", "user_id"], name: "index_mod_notes_on_id_and_user_id"
t.index ["moderator_user_id"], name: "mod_notes_moderator_user_id_fk"
t.index ["user_id"], name: "mod_notes_user_id_fk"
end
create_table "moderations", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.datetime "created_at", precision: nil, null: false
t.datetime "updated_at", precision: nil, null: false
t.bigint "moderator_user_id", unsigned: true
t.bigint "story_id", unsigned: true
t.bigint "comment_id", unsigned: true
t.bigint "user_id", unsigned: true
t.text "action", size: :medium
t.text "reason", size: :medium
t.boolean "is_from_suggestions", default: false
t.bigint "tag_id", unsigned: true
t.integer "domain_id"
t.bigint "category_id"
t.index ["comment_id"], name: "moderations_comment_id_fk"
t.index ["created_at"], name: "index_moderations_on_created_at"
t.index ["domain_id"], name: "index_moderations_on_domain_id"
t.index ["moderator_user_id"], name: "moderations_moderator_user_id_fk"
t.index ["story_id"], name: "moderations_story_id_fk"
t.index ["tag_id"], name: "moderations_tag_id_fk"
t.index ["user_id"], name: "index_moderations_on_user_id"
end
create_table "read_ribbons", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.boolean "is_following", default: true
t.datetime "created_at", precision: nil, null: false
t.datetime "updated_at", precision: nil, null: false
t.bigint "user_id", null: false, unsigned: true
t.bigint "story_id", null: false, unsigned: true
t.index ["story_id"], name: "index_read_ribbons_on_story_id"
t.index ["user_id"], name: "index_read_ribbons_on_user_id"
end
create_table "saved_stories", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.datetime "created_at", precision: nil, null: false
t.datetime "updated_at", precision: nil, null: false
t.bigint "user_id", null: false, unsigned: true
t.bigint "story_id", null: false, unsigned: true
t.index ["story_id"], name: "saved_stories_story_id_fk"
t.index ["user_id", "story_id"], name: "index_saved_stories_on_user_id_and_story_id", unique: true
end
create_table "stories", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.datetime "created_at", precision: nil
t.bigint "user_id", null: false, unsigned: true
t.string "url", limit: 250, default: ""
t.string "normalized_url"
t.string "title", limit: 150, default: "", null: false
t.text "description", size: :medium
t.string "short_id", limit: 6, default: "", null: false
t.boolean "is_deleted", default: false, null: false
t.integer "score", default: 1, null: false
t.integer "flags", default: 0, null: false, unsigned: true
t.boolean "is_moderated", default: false, null: false
t.decimal "hotness", precision: 20, scale: 10, default: "0.0", null: false
t.text "markeddown_description", size: :medium
t.integer "comments_count", default: 0, null: false
t.bigint "merged_story_id", unsigned: true
t.datetime "unavailable_at", precision: nil
t.string "twitter_id", limit: 20
t.boolean "user_is_author", default: false
t.boolean "user_is_following", default: false, null: false
t.bigint "domain_id"
t.index ["created_at"], name: "index_stories_on_created_at"
t.index ["domain_id"], name: "index_stories_on_domain_id"
t.index ["hotness"], name: "hotness_idx"
t.index ["id", "is_deleted"], name: "index_stories_on_id_and_is_deleted"
t.index ["merged_story_id"], name: "index_stories_on_merged_story_id"
t.index ["normalized_url"], name: "index_stories_on_normalized_url"
t.index ["score"], name: "index_stories_on_score"
t.index ["short_id"], name: "unique_short_id", unique: true
t.index ["twitter_id"], name: "index_stories_on_twitter_id"
t.index ["url"], name: "url", length: 191
t.index ["user_id"], name: "index_stories_on_user_id"
end
create_table "story_texts", charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.string "title", limit: 150, default: "", null: false
t.text "description", size: :medium
t.text "body", size: :medium
t.timestamp "created_at", default: -> { "current_timestamp() ON UPDATE current_timestamp()" }, null: false
t.index ["title", "description", "body"], name: "index_story_texts_on_title_and_description_and_body", type: :fulltext
t.index ["title"], name: "index_story_texts_on_title", type: :fulltext
end
create_table "suggested_taggings", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.bigint "story_id", null: false, unsigned: true
t.bigint "tag_id", null: false, unsigned: true
t.bigint "user_id", null: false, unsigned: true
t.index ["story_id"], name: "suggested_taggings_story_id_fk"
t.index ["tag_id"], name: "suggested_taggings_tag_id_fk"
t.index ["user_id"], name: "suggested_taggings_user_id_fk"
end
create_table "suggested_titles", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.bigint "story_id", null: false, unsigned: true
t.bigint "user_id", null: false, unsigned: true
t.string "title", limit: 150, default: "", null: false
t.index ["story_id"], name: "suggested_titles_story_id_fk"
t.index ["user_id"], name: "suggested_titles_user_id_fk"
end
create_table "tag_filters", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.datetime "created_at", precision: nil, null: false
t.datetime "updated_at", precision: nil, null: false
t.bigint "user_id", null: false, unsigned: true
t.bigint "tag_id", null: false, unsigned: true
t.index ["tag_id"], name: "tag_filters_tag_id_fk"
t.index ["user_id", "tag_id"], name: "user_tag_idx"
end
create_table "taggings", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.bigint "story_id", null: false, unsigned: true
t.bigint "tag_id", null: false, unsigned: true
t.index ["story_id", "tag_id"], name: "story_id_tag_id", unique: true
t.index ["tag_id"], name: "taggings_tag_id_fk"
end
create_table "tags", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.string "tag", limit: 25, null: false
t.string "description", limit: 100
t.boolean "privileged", default: false, null: false
t.boolean "is_media", default: false, null: false
t.boolean "active", default: true, null: false
t.float "hotness_mod", default: 0.0
t.boolean "permit_by_new_users", default: true, null: false
t.bigint "category_id", null: false
t.index ["category_id"], name: "index_tags_on_category_id"
t.index ["tag"], name: "tag", unique: true
end
create_table "users", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.string "username", limit: 50
t.string "email", limit: 100
t.string "password_digest", limit: 75
t.datetime "created_at", precision: nil
t.boolean "is_admin", default: false
t.string "password_reset_token", limit: 75
t.string "session_token", limit: 75, default: "", null: false
t.text "about", size: :medium
t.bigint "invited_by_user_id", unsigned: true
t.boolean "is_moderator", default: false
t.boolean "pushover_mentions", default: false
t.string "rss_token", limit: 75
t.string "mailing_list_token", limit: 75
t.integer "mailing_list_mode", default: 0
t.integer "karma", default: 0, null: false
t.datetime "banned_at", precision: nil
t.bigint "banned_by_user_id", unsigned: true
t.string "banned_reason", limit: 200
t.datetime "deleted_at", precision: nil
t.datetime "disabled_invite_at", precision: nil
t.bigint "disabled_invite_by_user_id", unsigned: true
t.string "disabled_invite_reason", limit: 200
t.text "settings", size: :medium
t.boolean "show_email", default: false, null: false
t.index ["banned_by_user_id"], name: "users_banned_by_user_id_fk"
t.index ["disabled_invite_by_user_id"], name: "users_disabled_invite_by_user_id_fk"
t.index ["email"], name: "index_users_on_email", unique: true
t.index ["invited_by_user_id"], name: "users_invited_by_user_id_fk"
t.index ["mailing_list_mode"], name: "mailing_list_enabled"
t.index ["mailing_list_token"], name: "mailing_list_token", unique: true
t.index ["password_reset_token"], name: "password_reset_token", unique: true
t.index ["rss_token"], name: "rss_token", unique: true
t.index ["session_token"], name: "session_hash", unique: true
t.index ["username"], name: "username", unique: true
end
create_table "votes", id: { type: :bigint, unsigned: true }, charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t|
t.bigint "user_id", null: false, unsigned: true
t.bigint "story_id", null: false, unsigned: true
t.bigint "comment_id", unsigned: true
t.integer "vote", limit: 1, null: false
t.string "reason", limit: 1
t.datetime "updated_at", precision: nil, null: false
t.index ["comment_id"], name: "index_votes_on_comment_id"
t.index ["story_id"], name: "votes_story_id_fk"
t.index ["user_id", "comment_id"], name: "user_id_comment_id"
t.index ["user_id", "story_id"], name: "user_id_story_id"
end
add_foreign_key "comments", "comments", column: "parent_comment_id", name: "comments_parent_comment_id_fk"
add_foreign_key "comments", "hats", name: "comments_hat_id_fk"
add_foreign_key "comments", "stories", name: "comments_story_id_fk"
add_foreign_key "comments", "users", name: "comments_user_id_fk"
add_foreign_key "hat_requests", "users", name: "hat_requests_user_id_fk"
add_foreign_key "hats", "users", column: "granted_by_user_id", name: "hats_granted_by_user_id_fk"
add_foreign_key "hats", "users", name: "hats_user_id_fk"
add_foreign_key "hidden_stories", "stories", name: "hidden_stories_story_id_fk"
add_foreign_key "hidden_stories", "users", name: "hidden_stories_user_id_fk"
add_foreign_key "invitations", "users", column: "new_user_id", name: "invitations_new_user_id_fk"
add_foreign_key "invitations", "users", name: "invitations_user_id_fk"
add_foreign_key "messages", "hats", name: "messages_hat_id_fk"
add_foreign_key "messages", "users", column: "recipient_user_id", name: "messages_recipient_user_id_fk"
add_foreign_key "mod_notes", "users", column: "moderator_user_id", name: "mod_notes_moderator_user_id_fk"
add_foreign_key "mod_notes", "users", name: "mod_notes_user_id_fk"
add_foreign_key "moderations", "comments", name: "moderations_comment_id_fk"
add_foreign_key "moderations", "stories", name: "moderations_story_id_fk"
add_foreign_key "moderations", "tags", name: "moderations_tag_id_fk"
add_foreign_key "moderations", "users", column: "moderator_user_id", name: "moderations_moderator_user_id_fk"
add_foreign_key "read_ribbons", "stories", name: "read_ribbons_story_id_fk"
add_foreign_key "read_ribbons", "users", name: "read_ribbons_user_id_fk"
add_foreign_key "saved_stories", "stories", name: "saved_stories_story_id_fk"
add_foreign_key "saved_stories", "users", name: "saved_stories_user_id_fk"
add_foreign_key "stories", "domains"
add_foreign_key "stories", "stories", column: "merged_story_id", name: "stories_merged_story_id_fk"
add_foreign_key "stories", "users", name: "stories_user_id_fk"
add_foreign_key "suggested_taggings", "stories", name: "suggested_taggings_story_id_fk"
add_foreign_key "suggested_taggings", "tags", name: "suggested_taggings_tag_id_fk"
add_foreign_key "suggested_taggings", "users", name: "suggested_taggings_user_id_fk"
add_foreign_key "suggested_titles", "stories", name: "suggested_titles_story_id_fk"
add_foreign_key "suggested_titles", "users", name: "suggested_titles_user_id_fk"
add_foreign_key "tag_filters", "tags", name: "tag_filters_tag_id_fk"
add_foreign_key "tag_filters", "users", name: "tag_filters_user_id_fk"
add_foreign_key "taggings", "stories", name: "taggings_story_id_fk"
add_foreign_key "taggings", "tags", name: "taggings_tag_id_fk", on_update: :cascade, on_delete: :cascade
add_foreign_key "users", "users", column: "banned_by_user_id", name: "users_banned_by_user_id_fk"
add_foreign_key "users", "users", column: "disabled_invite_by_user_id", name: "users_disabled_invite_by_user_id_fk"
add_foreign_key "users", "users", column: "invited_by_user_id", name: "users_invited_by_user_id_fk"
add_foreign_key "votes", "comments", name: "votes_comment_id_fk", on_update: :cascade, on_delete: :cascade
add_foreign_key "votes", "stories", name: "votes_story_id_fk"
add_foreign_key "votes", "users", name: "votes_user_id_fk"
create_view "replying_comments", sql_definition: <<-SQL
select `read_ribbons`.`user_id` AS `user_id`,`comments`.`id` AS `comment_id`,`read_ribbons`.`story_id` AS `story_id`,`comments`.`parent_comment_id` AS `parent_comment_id`,`comments`.`created_at` AS `comment_created_at`,`parent_comments`.`user_id` AS `parent_comment_author_id`,`comments`.`user_id` AS `comment_author_id`,`stories`.`user_id` AS `story_author_id`,`read_ribbons`.`updated_at` < `comments`.`created_at` AS `is_unread`,(select `votes`.`vote` from `votes` where `votes`.`user_id` = `read_ribbons`.`user_id` and `votes`.`comment_id` = `comments`.`id`) AS `current_vote_vote`,(select `votes`.`reason` from `votes` where `votes`.`user_id` = `read_ribbons`.`user_id` and `votes`.`comment_id` = `comments`.`id`) AS `current_vote_reason` from (((`read_ribbons` join `comments` on(`comments`.`story_id` = `read_ribbons`.`story_id`)) join `stories` on(`stories`.`id` = `comments`.`story_id`)) left join `comments` `parent_comments` on(`parent_comments`.`id` = `comments`.`parent_comment_id`)) where `read_ribbons`.`is_following` = 1 and `comments`.`user_id` <> `read_ribbons`.`user_id` and `comments`.`is_deleted` = 0 and `comments`.`is_moderated` = 0 and (`parent_comments`.`user_id` = `read_ribbons`.`user_id` or `parent_comments`.`user_id` is null and `stories`.`user_id` = `read_ribbons`.`user_id`) and `stories`.`score` >= 0 and `comments`.`score` >= 0 and (`parent_comments`.`id` is null or `parent_comments`.`score` >= 0 and `parent_comments`.`is_moderated` = 0 and `parent_comments`.`is_deleted` = 0) and !exists(select 1 from (`votes` `f` join `comments` `c` on(`f`.`comment_id` = `c`.`id`)) where `f`.`vote` < 0 and `f`.`user_id` = `parent_comments`.`user_id` and `c`.`user_id` = `comments`.`user_id` and `f`.`story_id` = `comments`.`story_id` limit 1)
SQL
end