Class: LogStruct::Log::ActiveJob::Finish

Inherits:
T::Struct
  • Object
show all
Extended by:
T::Sig
Includes:
Interfaces::CommonFields, Shared::SerializeCommon
Defined in:
lib/log_struct/log/active_job/finish.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from Shared::SerializeCommon

#as_json, #serialize, #serialize_common

Methods included from Interfaces::CommonFields

#serialize

Constructor Details

#initialize(source: Source::Job, event: Event::Finish, timestamp:, level: Level::Info, job_id:, job_class:, queue_name: nil, arguments: nil, executions: nil, provider_job_id: nil, duration_ms:, finished_at:) ⇒ void

Parameters:

  • source (Source::Job) (defaults to: Source::Job)

    Shared/common fields

  • event (Event) (defaults to: Event::Finish)
  • timestamp (Time)
  • level (Level) (defaults to: Level::Info)
  • job_id (String)
  • job_class (String)
  • queue_name (Symbol, nil) (defaults to: nil)
  • arguments (Array<T.untyped>, nil) (defaults to: nil)
  • executions (Integer, nil) (defaults to: nil)
  • provider_job_id (String, nil) (defaults to: nil)
  • duration_ms (Float)

    Event-specific fields

  • finished_at (Time)


# File ''

const :source, Source::Job, default: Source::Job
const :event, Event, default: Event::Finish
const :timestamp, Time, factory: -> { Time.now }
const :level, Level, default: Level::Info
const :job_id, String
const :job_class, String
const :queue_name, T.nilable(Symbol), default: nil
const :arguments, T.nilable(T::Array[T.untyped]), default: nil
const :executions, T.nilable(Integer), default: nil
const :provider_job_id, T.nilable(String), default: nil
const :duration_ms, Float
const :finished_at, Time

Instance Attribute Details

#argumentsArray<T.untyped>? (readonly)

Returns the value of prop arguments.

Returns:

  • (Array<T.untyped>, nil)


# File ''

const :arguments, T.nilable(T::Array[T.untyped]), default: nil

#duration_msFloat (readonly)

Event-specific fields

Returns:

  • (Float)


# File ''

const :duration_ms, Float

#eventEvent (readonly)

Returns the value of prop event.

Returns:



# File ''

const :event, Event, default: Event::Finish

#executionsInteger? (readonly)

Returns the value of prop executions.

Returns:

  • (Integer, nil)


# File ''

const :executions, T.nilable(Integer), default: nil

#finished_atTime (readonly)

Returns the value of prop finished_at.

Returns:

  • (Time)


# File ''

const :finished_at, Time

#job_classString (readonly)

Returns the value of prop job_class.

Returns:

  • (String)


# File ''

const :job_class, String

#job_idString (readonly)

Returns the value of prop job_id.

Returns:

  • (String)


# File ''

const :job_id, String

#levelLevel (readonly)

Returns the value of prop level.

Returns:



# File ''

const :level, Level, default: Level::Info

#provider_job_idString? (readonly)

Returns the value of prop provider_job_id.

Returns:

  • (String, nil)


# File ''

const :provider_job_id, T.nilable(String), default: nil

#queue_nameSymbol? (readonly)

Returns the value of prop queue_name.

Returns:

  • (Symbol, nil)


# File ''

const :queue_name, T.nilable(Symbol), default: nil

#sourceSource::Job (readonly)

Shared/common fields

Returns:



# File ''

const :source, Source::Job, default: Source::Job

#timestampTime (readonly)

Returns the value of prop timestamp.

Returns:

  • (Time)


# File ''

const :timestamp, Time, factory: -> { Time.now }

Instance Method Details

#to_hHash{LogStruct::LogField => T.untyped}

Returns:



48
49
50
51
52
53
54
55
56
57
58
59
# File 'lib/log_struct/log/active_job/finish.rb', line 48

def to_h
  h = T.let({}, T::Hash[LogStruct::LogField, T.untyped])
  h[LogField::JobId] = job_id
  h[LogField::JobClass] = job_class
  h[LogField::QueueName] = queue_name unless queue_name.nil?
  h[LogField::Arguments] = arguments unless arguments.nil?
  h[LogField::Executions] = executions unless executions.nil?
  h[LogField::ProviderJobId] = provider_job_id unless provider_job_id.nil?
  h[LogField::DurationMs] = duration_ms
  h[LogField::FinishedAt] = finished_at
  h
end