2020-07-30 14:09:39 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module Gitlab
|
|
|
|
module Audit
|
|
|
|
class NullAuthor
|
|
|
|
attr_reader :id, :name
|
|
|
|
|
|
|
|
# Creates an Author
|
|
|
|
#
|
|
|
|
# While tracking events that could take place even when
|
|
|
|
# a user is not logged in, (eg: downloading repo of a public project),
|
|
|
|
# we set the author_id of such events as -1
|
|
|
|
#
|
|
|
|
# @param [Integer] id
|
|
|
|
# @param [String] name
|
2022-05-10 11:09:19 -04:00
|
|
|
# rubocop: disable Layout/LineLength
|
|
|
|
# @return [Gitlab::Audit::UnauthenticatedAuthor, Gitlab::Audit::DeletedAuthor, Gitlab::Audit::CiRunnerTokenAuthor, Gitlab::Audit::DeployTokenAuthor]
|
2022-01-20 07:16:19 -05:00
|
|
|
def self.for(id, audit_event)
|
|
|
|
name = audit_event[:author_name] || audit_event.details[:author_name]
|
|
|
|
|
2022-02-16 10:14:05 -05:00
|
|
|
if audit_event.target_type == ::Ci::Runner.name
|
|
|
|
Gitlab::Audit::CiRunnerTokenAuthor.new(audit_event)
|
2022-01-20 07:16:19 -05:00
|
|
|
elsif id == -1
|
2020-07-30 14:09:39 -04:00
|
|
|
Gitlab::Audit::UnauthenticatedAuthor.new(name: name)
|
2022-05-10 11:09:19 -04:00
|
|
|
elsif id == -2
|
|
|
|
Gitlab::Audit::DeployTokenAuthor.new(name: name)
|
2022-07-29 14:08:58 -04:00
|
|
|
elsif id == -3
|
|
|
|
Gitlab::Audit::DeployKeyAuthor.new(name: name)
|
2020-07-30 14:09:39 -04:00
|
|
|
else
|
|
|
|
Gitlab::Audit::DeletedAuthor.new(id: id, name: name)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def initialize(id:, name:)
|
|
|
|
@id = id
|
|
|
|
@name = name
|
|
|
|
end
|
|
|
|
|
|
|
|
def current_sign_in_ip
|
|
|
|
nil
|
|
|
|
end
|
2022-01-20 07:16:19 -05:00
|
|
|
|
|
|
|
def full_path
|
|
|
|
nil
|
|
|
|
end
|
2020-07-30 14:09:39 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|