Commit 8db84714
Changed files (3)
app
models
app/models/location.rb
@@ -1,5 +1,6 @@
class Location < ActiveRecord::Base
belongs_to :locatable, polymorphic: true
+ validates :locatable, presence: true
GEO_IP=GeoIP.new('config/GeoLiteCity.dat')
db/migrate/20140929024135_migrate_user_sessions_to_locations.rb
@@ -0,0 +1,9 @@
+class MigrateUserSessionsToLocations < ActiveRecord::Migration
+ def change
+ UserSession.find_each do |session|
+ location = Location.build_from_ip(session.ip)
+ location.locatable = session
+ location.save
+ end
+ end
+end
db/schema.rb
@@ -11,11 +11,11 @@
#
# It's strongly recommended that you check this file into your version control system.
-ActiveRecord::Schema.define(version: 20140927141151) do
+ActiveRecord::Schema.define(version: 20140929024135) do
# These are extensions that must be enabled in order to support this database
- enable_extension "plpgsql"
enable_extension "uuid-ossp"
+ enable_extension "plpgsql"
create_table "activities", force: true do |t|
t.integer "subject_id", null: false
@@ -31,8 +31,8 @@ ActiveRecord::Schema.define(version: 20140927141151) do
create_table "avatars", force: true do |t|
t.integer "user_id"
- t.datetime "created_at"
- t.datetime "updated_at"
+ t.datetime "created_at", null: false
+ t.datetime "updated_at", null: false
t.string "avatar"
t.boolean "avatar_processing"
t.string "avatar_tmp"
@@ -85,8 +85,8 @@ ActiveRecord::Schema.define(version: 20140927141151) do
t.datetime "failed_at"
t.string "locked_by"
t.string "queue"
- t.datetime "created_at"
- t.datetime "updated_at"
+ t.datetime "created_at", null: false
+ t.datetime "updated_at", null: false
end
add_index "delayed_jobs", ["priority", "run_at"], name: "delayed_jobs_priority", using: :btree
@@ -103,8 +103,8 @@ ActiveRecord::Schema.define(version: 20140927141151) do
create_table "interests", force: true do |t|
t.string "name"
- t.datetime "created_at"
- t.datetime "updated_at"
+ t.datetime "created_at", null: false
+ t.datetime "updated_at", null: false
end
create_table "locations", id: :uuid, default: "uuid_generate_v4()", force: true do |t|
@@ -157,15 +157,13 @@ ActiveRecord::Schema.define(version: 20140927141151) do
t.integer "taggings_count", default: 0
end
- add_index "tags", ["name"], name: "index_tags_on_name", unique: true, using: :btree
-
create_table "tutorials", force: true do |t|
t.string "heading"
t.text "description"
t.string "url"
t.integer "user_id"
- t.datetime "created_at"
- t.datetime "updated_at"
+ t.datetime "created_at", null: false
+ t.datetime "updated_at", null: false
t.string "image_url"
t.string "author"
t.string "author_url"
@@ -194,12 +192,12 @@ ActiveRecord::Schema.define(version: 20140927141151) do
add_index "user_sessions", ["user_id"], name: "index_user_sessions_on_user_id", using: :btree
create_table "users", force: true do |t|
- t.string "email", default: "", null: false
- t.string "encrypted_password", default: "", null: false
+ t.string "email", default: "", null: false
+ t.string "encrypted_password", limit: 128, default: "", null: false
t.string "reset_password_token"
t.datetime "reset_password_sent_at"
t.datetime "remember_created_at"
- t.integer "sign_in_count", default: 0
+ t.integer "sign_in_count", default: 0
t.datetime "current_sign_in_at"
t.datetime "last_sign_in_at"
t.string "current_sign_in_ip"
@@ -218,13 +216,13 @@ ActiveRecord::Schema.define(version: 20140927141151) do
t.datetime "confirmed_at"
t.datetime "confirmation_sent_at"
t.string "unconfirmed_email"
- t.integer "failed_attempts", default: 0
+ t.integer "failed_attempts", default: 0
t.string "unlock_token"
t.datetime "locked_at"
t.string "authentication_token"
t.string "invitation_token"
t.string "full_address"
- t.integer "creations_count", default: 0
+ t.integer "creations_count", default: 0
t.boolean "admin"
end