Matchu
696b2aedaf
Lots of scary bugs were being caused by the fact that the possibly-duplicate Neopets ID was being treated as an SWF's real primary key, meaning that a save meant for object swf number 123 could be saved to biology swf number 123. Which is awful. This update gives SWFs their own unique internal ID numbers. All external lookups still use the remote ID and the type, meaning that the client side remains totally unchanged (phew). However, all database relationships with SWFs use the new ID numbers, making everything cleaner. Yay. There are probably a few places where it would be appropriate to optimize certain lookups that still depend on remote ID and type. Whatever. Today's goal was to remove crazy glitches that have been floating around like mad. And I think that goal has been met.
210 lines
8.8 KiB
Ruby
210 lines
8.8 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.
|
|
#
|
|
# Note that this schema.rb definition is the authoritative source for your
|
|
# database schema. If you need to create the application database on another
|
|
# system, you should be using db:schema:load, not running all the migrations
|
|
# from scratch. The latter is a flawed and unsustainable approach (the more migrations
|
|
# you'll amass, the slower it'll run and the greater likelihood for issues).
|
|
#
|
|
# It's strongly recommended to check this file into your version control system.
|
|
|
|
ActiveRecord::Schema.define(:version => 20120112204234) do
|
|
|
|
create_table "auth_servers", :force => true do |t|
|
|
t.string "short_name", :limit => 10, :null => false
|
|
t.string "name", :limit => 40, :null => false
|
|
t.text "icon", :limit => 16777215, :null => false
|
|
t.text "gateway", :limit => 16777215, :null => false
|
|
t.string "secret", :limit => 64, :null => false
|
|
end
|
|
|
|
create_table "closet_hangers", :force => true do |t|
|
|
t.integer "item_id"
|
|
t.integer "user_id"
|
|
t.integer "quantity"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.boolean "owned", :default => true, :null => false
|
|
t.integer "list_id"
|
|
end
|
|
|
|
create_table "closet_lists", :force => true do |t|
|
|
t.string "name"
|
|
t.text "description"
|
|
t.integer "user_id"
|
|
t.boolean "hangers_owned", :null => false
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.integer "visibility", :default => 1, :null => false
|
|
end
|
|
|
|
create_table "colors", :force => true do |t|
|
|
t.string "name"
|
|
t.boolean "basic", :default => false, :null => false
|
|
end
|
|
|
|
create_table "contributions", :force => true do |t|
|
|
t.string "contributed_type", :limit => 8, :null => false
|
|
t.integer "contributed_id", :null => false
|
|
t.integer "user_id", :null => false
|
|
t.datetime "created_at", :null => false
|
|
end
|
|
|
|
create_table "forums", :force => true do |t|
|
|
t.string "name"
|
|
t.text "description"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.integer "sort_index"
|
|
end
|
|
|
|
create_table "item_outfit_relationships", :force => true do |t|
|
|
t.integer "item_id"
|
|
t.integer "outfit_id"
|
|
t.boolean "is_worn"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
end
|
|
|
|
create_table "login_cookies", :force => true do |t|
|
|
t.integer "user_id", :null => false
|
|
t.integer "series", :null => false
|
|
t.integer "token", :null => false
|
|
end
|
|
|
|
add_index "login_cookies", ["user_id", "series"], :name => "login_cookies_user_id_and_series"
|
|
add_index "login_cookies", ["user_id"], :name => "login_cookies_user_id"
|
|
|
|
create_table "objects", :force => true do |t|
|
|
t.text "zones_restrict", :null => false
|
|
t.text "thumbnail_url", :limit => 16777215, :null => false
|
|
t.string "name", :limit => 100, :null => false
|
|
t.text "description", :limit => 16777215, :null => false
|
|
t.string "category", :limit => 50
|
|
t.string "type", :limit => 50
|
|
t.string "rarity", :limit => 25
|
|
t.integer "rarity_index", :limit => 2
|
|
t.integer "price", :limit => 3, :null => false
|
|
t.integer "weight_lbs", :limit => 2
|
|
t.text "species_support_ids", :limit => 16777215
|
|
t.boolean "sold_in_mall", :null => false
|
|
t.datetime "last_spidered"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
end
|
|
|
|
add_index "objects", ["last_spidered"], :name => "objects_last_spidered"
|
|
add_index "objects", ["name"], :name => "name"
|
|
|
|
create_table "outfits", :force => true do |t|
|
|
t.integer "pet_state_id"
|
|
t.integer "user_id"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.string "name"
|
|
t.boolean "starred", :default => false, :null => false
|
|
end
|
|
|
|
create_table "parents_swf_assets", :force => true do |t|
|
|
t.integer "parent_id", :limit => 3, :null => false
|
|
t.integer "swf_asset_id", :limit => 3, :null => false
|
|
t.string "parent_type", :limit => 8, :null => false
|
|
end
|
|
|
|
add_index "parents_swf_assets", ["parent_id", "swf_asset_id"], :name => "unique_parents_swf_assets", :unique => true
|
|
add_index "parents_swf_assets", ["parent_id"], :name => "parent_swf_assets_parent_id"
|
|
add_index "parents_swf_assets", ["swf_asset_id"], :name => "parents_swf_assets_swf_asset_id"
|
|
|
|
create_table "pet_loads", :force => true do |t|
|
|
t.string "pet_name", :limit => 20, :null => false
|
|
t.text "amf", :limit => 16777215, :null => false
|
|
t.datetime "created_at", :null => false
|
|
end
|
|
|
|
create_table "pet_states", :force => true do |t|
|
|
t.integer "pet_type_id", :limit => 3, :null => false
|
|
t.text "swf_asset_ids", :null => false
|
|
end
|
|
|
|
add_index "pet_states", ["pet_type_id"], :name => "pet_states_pet_type_id"
|
|
|
|
create_table "pet_types", :force => true do |t|
|
|
t.integer "color_id", :limit => 1, :null => false
|
|
t.integer "species_id", :limit => 1, :null => false
|
|
t.datetime "created_at", :null => false
|
|
t.integer "body_id", :limit => 2, :null => false
|
|
t.string "image_hash", :limit => 8
|
|
end
|
|
|
|
add_index "pet_types", ["species_id", "color_id"], :name => "pet_types_species_color", :unique => true
|
|
|
|
create_table "pets", :force => true do |t|
|
|
t.string "name", :limit => 20, :null => false
|
|
t.integer "pet_type_id", :limit => 3, :null => false
|
|
end
|
|
|
|
add_index "pets", ["name"], :name => "pets_name", :unique => true
|
|
add_index "pets", ["pet_type_id"], :name => "pets_pet_type_id"
|
|
|
|
create_table "posts", :force => true do |t|
|
|
t.integer "topic_id"
|
|
t.integer "user_id"
|
|
t.text "body"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
end
|
|
|
|
create_table "swf_assets", :force => true do |t|
|
|
t.string "type", :limit => 7, :null => false
|
|
t.integer "remote_id", :limit => 3, :null => false
|
|
t.text "url", :limit => 16777215, :null => false
|
|
t.integer "zone_id", :limit => 1, :null => false
|
|
t.text "zones_restrict", :null => false
|
|
t.datetime "created_at", :null => false
|
|
t.integer "body_id", :limit => 2, :null => false
|
|
t.boolean "has_image", :default => false, :null => false
|
|
t.boolean "image_requested", :default => false, :null => false
|
|
t.datetime "reported_broken_at"
|
|
t.datetime "converted_at"
|
|
end
|
|
|
|
add_index "swf_assets", ["body_id"], :name => "swf_assets_body_id_and_object_id"
|
|
add_index "swf_assets", ["type", "remote_id"], :name => "swf_assets_type_and_id"
|
|
add_index "swf_assets", ["zone_id"], :name => "idx_swf_assets_zone_id"
|
|
|
|
create_table "topics", :force => true do |t|
|
|
t.string "title"
|
|
t.integer "user_id"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.integer "forum_id"
|
|
t.integer "original_post_id"
|
|
end
|
|
|
|
create_table "users", :force => true do |t|
|
|
t.string "name", :limit => 20, :null => false
|
|
t.integer "auth_server_id", :limit => 1, :null => false
|
|
t.integer "remote_id", :null => false
|
|
t.integer "points", :default => 0, :null => false
|
|
t.boolean "beta", :default => false, :null => false
|
|
t.string "remember_token"
|
|
t.datetime "remember_created_at"
|
|
t.boolean "forum_admin", :default => false, :null => false
|
|
t.boolean "forum_moderator"
|
|
t.boolean "image_mode_tester", :default => false, :null => false
|
|
t.text "closet_description", :null => false
|
|
t.string "neopets_username"
|
|
t.integer "owned_closet_hangers_visibility", :default => 1, :null => false
|
|
t.integer "wanted_closet_hangers_visibility", :default => 1, :null => false
|
|
end
|
|
|
|
create_table "zones", :force => true do |t|
|
|
t.integer "depth", :limit => 1, :null => false
|
|
t.integer "type_id", :limit => 1, :null => false
|
|
t.string "type", :limit => 40, :null => false
|
|
t.string "label", :limit => 40, :null => false
|
|
end
|
|
|
|
end
|