Class: SDM::Activity

Inherits:
Object
  • Object
show all
Defined in:
lib/models/porcelain.rb

Overview

An Activity is a record of an action taken against a strongDM deployment, e.g. a user creation, resource deletion, sso configuration change, etc.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(actor: nil, completed_at: nil, description: nil, entities: nil, id: nil, ip_address: nil, user_agent: nil, verb: nil) ⇒ Activity

Returns a new instance of Activity.



2144
2145
2146
2147
2148
2149
2150
2151
2152
2153
2154
2155
2156
2157
2158
2159
2160
2161
2162
# File 'lib/models/porcelain.rb', line 2144

def initialize(
  actor: nil,
  completed_at: nil,
  description: nil,
  entities: nil,
  id: nil,
  ip_address: nil,
  user_agent: nil,
  verb: nil
)
  @actor = actor == nil ? nil : actor
  @completed_at = completed_at == nil ? nil : completed_at
  @description = description == nil ? "" : description
  @entities = entities == nil ? [] : entities
  @id = id == nil ? "" : id
  @ip_address = ip_address == nil ? "" : ip_address
  @user_agent = user_agent == nil ? "" : user_agent
  @verb = verb == nil ? "" : verb
end

Instance Attribute Details

#actorObject

The account who executed this activity. If the actor later has a name or email change, that change is not reflected here. Actor is a snapshot of the executing account at the time an activity took place.



2125
2126
2127
# File 'lib/models/porcelain.rb', line 2125

def actor
  @actor
end

#completed_atObject

The time this activity took effect.



2127
2128
2129
# File 'lib/models/porcelain.rb', line 2127

def completed_at
  @completed_at
end

#descriptionObject

A humanized description of the activity.



2129
2130
2131
# File 'lib/models/porcelain.rb', line 2129

def description
  @description
end

#entitiesObject

The entities involved in this activity. These entities can be any first class entity in the strongDM system, eg. a user, a role, a node, an account grant. Not every activity affects explicit entities.



2133
2134
2135
# File 'lib/models/porcelain.rb', line 2133

def entities
  @entities
end

#idObject

Unique identifier of the Activity.



2135
2136
2137
# File 'lib/models/porcelain.rb', line 2135

def id
  @id
end

#ip_addressObject

The IP from which this action was taken.



2137
2138
2139
# File 'lib/models/porcelain.rb', line 2137

def ip_address
  @ip_address
end

#user_agentObject

The User Agent present when this request was executed. Generally a client type and version like strongdm-cli/55.66.77



2140
2141
2142
# File 'lib/models/porcelain.rb', line 2140

def user_agent
  @user_agent
end

#verbObject

The kind of activity which has taken place, one of the ActivityVerb constants.



2142
2143
2144
# File 'lib/models/porcelain.rb', line 2142

def verb
  @verb
end

Instance Method Details

#to_json(options = {}) ⇒ Object



2164
2165
2166
2167
2168
2169
2170
# File 'lib/models/porcelain.rb', line 2164

def to_json(options = {})
  hash = {}
  self.instance_variables.each do |var|
    hash[var.id2name.delete_prefix("@")] = self.instance_variable_get var
  end
  hash.to_json
end