1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
# 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[8.1].define(version: 2025_11_06_214319) do
# These are extensions that must be enabled in order to support this database
enable_extension "pg_catalog.plpgsql"
create_table "clients", force: :cascade do |t|
t.string "address"
t.datetime "created_at", null: false
t.string "first_name", null: false
t.string "last_name", null: false
t.string "mobile_number", null: false
t.string "notes", default: "", null: false
t.datetime "updated_at", null: false
t.uuid "uuid", default: -> { "gen_random_uuid()" }, null: false
t.index ["first_name"], name: "index_clients_on_first_name"
t.index ["last_name"], name: "index_clients_on_last_name"
t.index ["mobile_number"], name: "index_clients_on_mobile_number", unique: true
t.index ["uuid"], name: "index_clients_on_uuid", unique: true
end
create_table "household_members", force: :cascade do |t|
t.bigint "client_id", null: false
t.datetime "created_at", null: false
t.string "first_name", null: false
t.string "last_name", null: false
t.integer "member_type", null: false
t.datetime "updated_at", null: false
t.index ["client_id"], name: "index_household_members_on_client_id"
end
create_table "sessions", force: :cascade do |t|
t.datetime "created_at", null: false
t.string "ip_address"
t.datetime "updated_at", null: false
t.string "user_agent"
t.bigint "user_id", null: false
t.index ["user_id"], name: "index_sessions_on_user_id"
end
create_table "users", force: :cascade do |t|
t.datetime "created_at", null: false
t.string "password_digest", null: false
t.integer "role", default: 0, null: false
t.datetime "updated_at", null: false
t.string "username", null: false
end
create_table "visits", force: :cascade do |t|
t.bigint "client_id", null: false
t.datetime "created_at", null: false
t.datetime "updated_at", null: false
t.bigint "user_id", null: false
t.index ["client_id"], name: "index_visits_on_client_id"
t.index ["created_at"], name: "index_visits_on_created_at"
t.index ["user_id"], name: "index_visits_on_user_id"
end
add_foreign_key "household_members", "clients"
add_foreign_key "sessions", "users"
add_foreign_key "visits", "clients"
add_foreign_key "visits", "users"
end
|