# 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_04_05_013826) do create_table "active_storage_attachments", charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t| t.string "name", null: false t.string "record_type", null: false t.bigint "record_id", null: false t.bigint "blob_id", null: false t.datetime "created_at", null: false t.index ["blob_id"], name: "index_active_storage_attachments_on_blob_id" t.index ["record_type", "record_id", "name", "blob_id"], name: "index_active_storage_attachments_uniqueness", unique: true end create_table "active_storage_blobs", charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t| t.string "key", null: false t.string "filename", null: false t.string "content_type" t.text "metadata" t.string "service_name", null: false t.bigint "byte_size", null: false t.string "checksum" t.datetime "created_at", null: false t.index ["key"], name: "index_active_storage_blobs_on_key", unique: true end create_table "active_storage_variant_records", charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t| t.bigint "blob_id", null: false t.string "variation_digest", null: false t.index ["blob_id", "variation_digest"], name: "index_active_storage_variant_records_uniqueness", unique: true end create_table "addresses", charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t| t.integer "number" t.string "street" t.string "zip_code" t.string "country" t.string "city" t.datetime "created_at", null: false t.datetime "updated_at", null: false end create_table "cards", charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t| t.string "number" t.integer "expiration_month" t.integer "expiration_year" t.integer "expiration_day" t.integer "security_code" t.bigint "user_account_id", null: false t.datetime "created_at", null: false t.datetime "updated_at", null: false t.index ["user_account_id"], name: "index_cards_on_user_account_id" end create_table "carts", charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t| t.bigint "user_account_id", null: false t.datetime "created_at", null: false t.datetime "updated_at", null: false t.index ["user_account_id"], name: "index_carts_on_user_account_id", unique: true end create_table "companies", charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t| t.string "name" t.string "country" t.string "short_name" t.datetime "created_at", null: false t.datetime "updated_at", null: false end create_table "product_reviews", charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t| t.bigint "user_account_id", null: false t.bigint "product_id", null: false t.text "review" t.integer "rating" t.datetime "created_at", null: false t.datetime "updated_at", null: false t.index ["product_id", "user_account_id"], name: "index_product_reviews_on_product_id_and_user_account_id", unique: true t.index ["product_id"], name: "index_product_reviews_on_product_id" t.index ["user_account_id"], name: "index_product_reviews_on_user_account_id" end create_table "products", charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t| t.string "public_id" t.string "name" t.float "unitary_price" t.float "bulk_price" t.bigint "company_id", null: false t.integer "available_quantity" t.text "categories" t.datetime "created_at", null: false t.datetime "updated_at", null: false t.index ["company_id"], name: "index_products_on_company_id" end create_table "user_account_addresses", charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t| t.datetime "created_at", null: false t.datetime "updated_at", null: false t.bigint "user_account_id" t.bigint "address_id" t.index ["address_id", "user_account_id"], name: "index_user_account_addresses_on_address_id_and_user_account_id", unique: true t.index ["address_id"], name: "index_user_account_addresses_on_address_id" t.index ["user_account_id"], name: "index_user_account_addresses_on_user_account_id" end create_table "user_accounts", charset: "utf8mb4", collation: "utf8mb4_general_ci", force: :cascade do |t| t.string "email" t.string "password_digest" t.string "first_name" t.string "last_name" t.string "session_key" t.datetime "created_at", null: false t.datetime "updated_at", null: false t.string "role" end add_foreign_key "active_storage_attachments", "active_storage_blobs", column: "blob_id" add_foreign_key "active_storage_variant_records", "active_storage_blobs", column: "blob_id" add_foreign_key "cards", "user_accounts" add_foreign_key "carts", "user_accounts" add_foreign_key "product_reviews", "products" add_foreign_key "product_reviews", "user_accounts" add_foreign_key "products", "companies" end