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.



1708
1709
1710
1711
1712
1713
1714
1715
1716
1717
1718
1719
1720
1721
1722
1723
1724
1725
1726
# File 'lib/models/porcelain.rb', line 1708

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.



1689
1690
1691
# File 'lib/models/porcelain.rb', line 1689

def actor
  @actor
end

#completed_atObject

The time this activity took effect.



1691
1692
1693
# File 'lib/models/porcelain.rb', line 1691

def completed_at
  @completed_at
end

#descriptionObject

A humanized description of the activity.



1693
1694
1695
# File 'lib/models/porcelain.rb', line 1693

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.



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

def entities
  @entities
end

#idObject

Unique identifier of the Activity.



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

def id
  @id
end

#ip_addressObject

The IP from which this action was taken.



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

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



1704
1705
1706
# File 'lib/models/porcelain.rb', line 1704

def user_agent
  @user_agent
end

#verbObject

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



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

def verb
  @verb
end

Instance Method Details

#to_json(options = {}) ⇒ Object



1728
1729
1730
1731
1732
1733
1734
# File 'lib/models/porcelain.rb', line 1728

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