# frozen_string_literal: true
class CustomWizard::Api::LogEntry
  include ActiveModel::SerializerSupport

  attr_accessor :log_id,
                :time,
                :user_id,
                :status,
                :url,
                :error,
                :username,
                :userpath,
                :name,
                :avatar_template

  def initialize(api_name, data = {})
    @api_name = api_name

    data.each do |k, v|
      self.send "#{k}=", v if self.respond_to?(k)
    end
  end

  def self.set(api_name, new_data)
    if new_data['log_id']
      data = self.get(api_name, new_data['log_id'], data_only: true)
      log_id = new_data['log_id']
    else
      data = {}
      log_id = SecureRandom.hex(3)
    end

    new_data.each do |k, v|
      data[k.to_sym] = v
    end

    PluginStore.set("custom_wizard_api_#{api_name}", "log_#{log_id}", data)

    self.get(api_name, log_id)
  end

  def self.get(api_name, log_id, opts = {})
    return nil if !log_id

    if data = PluginStore.get("custom_wizard_api_#{api_name}", "log_#{log_id}")
      if opts[:data_only]
        data
      else
        data[:log_id] = log_id
        self.new(api_name, data)
      end
    else
      nil
    end
  end

  def self.remove(api_name)
    PluginStoreRow.where("plugin_name = 'custom_wizard_api_#{api_name}' AND key LIKE 'log_%'").destroy_all
  end

  def self.list(api_name)
    PluginStoreRow.where("plugin_name LIKE 'custom_wizard_api_#{api_name}' AND key LIKE 'log_%'")
      .map do |record|
        api_name = record['plugin_name'].sub("custom_wizard_api_", "")
        data = ::JSON.parse(record['value'])
        data[:log_id] = record['key'].split('_').last
        this_user = User.find_by(id: data['user_id'])
        unless this_user.nil?
          data[:user_id] = this_user.id || nil
          data[:username] = this_user.username || ""
          data[:userpath] = "/u/#{this_user.username_lower}/activity"
          data[:name] = this_user.name || ""
          data[:avatar_template] = "/user_avatar/default/#{this_user.username_lower}/97/#{this_user.uploaded_avatar_id}.png"
        else
          data[:user_id] = nil
          data[:username] = ""
          data[:userpath] = ""
          data[:name] = ""
          data[:avatar_template] = ""
        end
        self.new(api_name, data)
      end
  end

  def self.clear(api_name)
    PluginStoreRow.where("plugin_name = 'custom_wizard_api_#{api_name}' AND key LIKE 'log_%'").destroy_all
  end

end