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.



1717
1718
1719
1720
1721
1722
1723
1724
1725
1726
1727
1728
1729
1730
1731
1732
1733
1734
1735
# File 'lib/models/porcelain.rb', line 1717

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.



1698
1699
1700
# File 'lib/models/porcelain.rb', line 1698

def actor
  @actor
end

#completed_atObject

The time this activity took effect.



1700
1701
1702
# File 'lib/models/porcelain.rb', line 1700

def completed_at
  @completed_at
end

#descriptionObject

A humanized description of the activity.



1702
1703
1704
# File 'lib/models/porcelain.rb', line 1702

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.



1706
1707
1708
# File 'lib/models/porcelain.rb', line 1706

def entities
  @entities
end

#idObject

Unique identifier of the Activity.



1708
1709
1710
# File 'lib/models/porcelain.rb', line 1708

def id
  @id
end

#ip_addressObject

The IP from which this action was taken.



1710
1711
1712
# File 'lib/models/porcelain.rb', line 1710

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



1713
1714
1715
# File 'lib/models/porcelain.rb', line 1713

def user_agent
  @user_agent
end

#verbObject

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



1715
1716
1717
# File 'lib/models/porcelain.rb', line 1715

def verb
  @verb
end

Instance Method Details

#to_json(options = {}) ⇒ Object



1737
1738
1739
1740
1741
1742
1743
# File 'lib/models/porcelain.rb', line 1737

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