41 lines
848 B
Ruby
41 lines
848 B
Ruby
# frozen_string_literal: true
|
|
|
|
# == Schema Information
|
|
#
|
|
# Table name: system_keys
|
|
#
|
|
# id :bigint(8) not null, primary key
|
|
# key :binary
|
|
# created_at :datetime not null
|
|
# updated_at :datetime not null
|
|
#
|
|
class SystemKey < ApplicationRecord
|
|
ROTATION_PERIOD = 1.week.freeze
|
|
|
|
before_validation :set_key
|
|
|
|
scope :expired, ->(now = Time.now.utc) { where(arel_table[:created_at].lt(now - ROTATION_PERIOD * 3)) }
|
|
|
|
class << self
|
|
def current_key
|
|
previous_key = order(id: :asc).last
|
|
|
|
if previous_key && previous_key.created_at >= ROTATION_PERIOD.ago
|
|
previous_key.key
|
|
else
|
|
create.key
|
|
end
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def set_key
|
|
return if key.present?
|
|
|
|
cipher = OpenSSL::Cipher.new('AES-256-GCM')
|
|
cipher.encrypt
|
|
|
|
self.key = cipher.random_key
|
|
end
|
|
end
|