mirror of
https://github.com/discourse/discourse.git
synced 2024-12-14 13:43:49 +08:00
30990006a9
This reduces chances of errors where consumers of strings mutate inputs and reduces memory usage of the app. Test suite passes now, but there may be some stuff left, so we will run a few sites on a branch prior to merging
41 lines
1.2 KiB
Ruby
41 lines
1.2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class AddUserAuthTokens < ActiveRecord::Migration[4.2]
|
|
def down
|
|
execute <<SQL
|
|
UPDATE users
|
|
SET auth_token = user_auth_tokens.auth_token,
|
|
auth_token_updated_at = user_auth_tokens.created_at
|
|
FROM user_auth_tokens
|
|
WHERE legacy AND user_auth_tokens.user_id = users.id
|
|
SQL
|
|
|
|
drop_table :user_auth_tokens
|
|
|
|
end
|
|
|
|
def up
|
|
create_table :user_auth_tokens do |t|
|
|
t.integer :user_id, null: false
|
|
t.string :auth_token, null: false
|
|
t.string :prev_auth_token, null: false
|
|
t.string :user_agent
|
|
t.boolean :auth_token_seen, default: false, null: false
|
|
t.boolean :legacy, default: false, null: false
|
|
t.inet :client_ip
|
|
t.datetime :rotated_at, null: false
|
|
t.timestamps null: false
|
|
end
|
|
|
|
add_index :user_auth_tokens, [:auth_token]
|
|
add_index :user_auth_tokens, [:prev_auth_token]
|
|
|
|
execute <<~SQL
|
|
INSERT INTO user_auth_tokens(user_id, auth_token, prev_auth_token, legacy, updated_at, created_at, rotated_at)
|
|
SELECT id, auth_token, auth_token, true, auth_token_updated_at, auth_token_updated_at, auth_token_updated_at
|
|
FROM users
|
|
WHERE auth_token_updated_at IS NOT NULL AND auth_token IS NOT NULL
|
|
SQL
|
|
end
|
|
end
|