add nice statistics
This commit is contained in:
44
db/migrate/20200511063156_devise_create_users.rb
Normal file
44
db/migrate/20200511063156_devise_create_users.rb
Normal file
@@ -0,0 +1,44 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
class DeviseCreateUsers < ActiveRecord::Migration[8.0]
|
||||
def change
|
||||
create_table :users do |t|
|
||||
## Database authenticatable
|
||||
t.string :email, null: false, default: ""
|
||||
t.string :encrypted_password, null: false, default: ""
|
||||
|
||||
## Recoverable
|
||||
t.string :reset_password_token
|
||||
t.datetime :reset_password_sent_at
|
||||
|
||||
## Rememberable
|
||||
t.datetime :remember_created_at
|
||||
|
||||
## Trackable
|
||||
# t.integer :sign_in_count, default: 0, null: false
|
||||
# t.datetime :current_sign_in_at
|
||||
# t.datetime :last_sign_in_at
|
||||
# t.string :current_sign_in_ip
|
||||
# t.string :last_sign_in_ip
|
||||
|
||||
## Confirmable
|
||||
# t.string :confirmation_token
|
||||
# t.datetime :confirmed_at
|
||||
# t.datetime :confirmation_sent_at
|
||||
# t.string :unconfirmed_email # Only if using reconfirmable
|
||||
|
||||
## Lockable
|
||||
# t.integer :failed_attempts, default: 0, null: false # Only if lock strategy is :failed_attempts
|
||||
# t.string :unlock_token # Only if unlock strategy is :email or :both
|
||||
# t.datetime :locked_at
|
||||
|
||||
|
||||
t.timestamps null: false
|
||||
end
|
||||
|
||||
add_index :users, :email, unique: true
|
||||
add_index :users, :reset_password_token, unique: true
|
||||
# add_index :users, :confirmation_token, unique: true
|
||||
# add_index :users, :unlock_token, unique: true
|
||||
end
|
||||
end
|
||||
12
db/migrate/20200516062316_create_logins.rb
Normal file
12
db/migrate/20200516062316_create_logins.rb
Normal file
@@ -0,0 +1,12 @@
|
||||
class CreateLogins < ActiveRecord::Migration[8.0]
|
||||
def change
|
||||
create_table :logins do |t|
|
||||
t.belongs_to :user, foreign_key: true
|
||||
t.string :platform, null: false
|
||||
t.jsonb :credentials, default: '{}'
|
||||
t.datetime :last_refresh_at, default: nil
|
||||
t.datetime :dead_since, default: nil
|
||||
t.timestamps
|
||||
end
|
||||
end
|
||||
end
|
||||
14
db/migrate/20200516063257_create_activity.rb
Normal file
14
db/migrate/20200516063257_create_activity.rb
Normal file
@@ -0,0 +1,14 @@
|
||||
class CreateActivity < ActiveRecord::Migration[8.0]
|
||||
def change
|
||||
create_table :activities do |t|
|
||||
t.belongs_to :user, foreign_key: true
|
||||
t.datetime :started_at, null: false
|
||||
t.datetime :ended_at
|
||||
t.string :platform
|
||||
t.string :item_ref, null: false
|
||||
t.string :item_title, null: false
|
||||
t.string :item_length
|
||||
t.timestamps
|
||||
end
|
||||
end
|
||||
end
|
||||
5
db/migrate/20200726102958_add_failed_count_to_logins.rb
Normal file
5
db/migrate/20200726102958_add_failed_count_to_logins.rb
Normal file
@@ -0,0 +1,5 @@
|
||||
class AddFailedCountToLogins < ActiveRecord::Migration[8.0]
|
||||
def change
|
||||
add_column :logins, :failed_count, :integer, default: 0
|
||||
end
|
||||
end
|
||||
6
db/migrate/20201101201031_add_missing_indices.rb
Normal file
6
db/migrate/20201101201031_add_missing_indices.rb
Normal file
@@ -0,0 +1,6 @@
|
||||
class AddMissingIndices < ActiveRecord::Migration[8.0]
|
||||
def change
|
||||
add_index :activities, :started_at
|
||||
add_index :activities, :platform
|
||||
end
|
||||
end
|
||||
58
db/schema.rb
generated
Normal file
58
db/schema.rb
generated
Normal file
@@ -0,0 +1,58 @@
|
||||
# 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.0].define(version: 2020_11_01_201031) do
|
||||
# These are extensions that must be enabled in order to support this database
|
||||
enable_extension "pg_catalog.plpgsql"
|
||||
|
||||
create_table "activities", force: :cascade do |t|
|
||||
t.bigint "user_id"
|
||||
t.datetime "started_at", null: false
|
||||
t.datetime "ended_at"
|
||||
t.string "platform"
|
||||
t.string "item_ref", null: false
|
||||
t.string "item_title", null: false
|
||||
t.string "item_length"
|
||||
t.datetime "created_at", null: false
|
||||
t.datetime "updated_at", null: false
|
||||
t.index ["platform"], name: "index_activities_on_platform"
|
||||
t.index ["started_at"], name: "index_activities_on_started_at"
|
||||
t.index ["user_id"], name: "index_activities_on_user_id"
|
||||
end
|
||||
|
||||
create_table "logins", force: :cascade do |t|
|
||||
t.bigint "user_id"
|
||||
t.string "platform", null: false
|
||||
t.jsonb "credentials", default: "{}"
|
||||
t.datetime "last_refresh_at"
|
||||
t.datetime "dead_since"
|
||||
t.datetime "created_at", null: false
|
||||
t.datetime "updated_at", null: false
|
||||
t.integer "failed_count", default: 0
|
||||
t.index ["user_id"], name: "index_logins_on_user_id"
|
||||
end
|
||||
|
||||
create_table "users", force: :cascade do |t|
|
||||
t.string "email", default: "", null: false
|
||||
t.string "encrypted_password", default: "", null: false
|
||||
t.string "reset_password_token"
|
||||
t.datetime "reset_password_sent_at"
|
||||
t.datetime "remember_created_at"
|
||||
t.datetime "created_at", null: false
|
||||
t.datetime "updated_at", null: false
|
||||
t.index ["email"], name: "index_users_on_email", unique: true
|
||||
t.index ["reset_password_token"], name: "index_users_on_reset_password_token", unique: true
|
||||
end
|
||||
|
||||
add_foreign_key "activities", "users"
|
||||
add_foreign_key "logins", "users"
|
||||
end
|
||||
Reference in New Issue
Block a user