Class: Plaid::Application

Inherits:
BaseModel
  • Object
show all
Defined in:
lib/plaid/models/application.rb

Overview

Metadata about the application

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from BaseModel

#check_for_conflict, #process_additional_properties, #process_array, #process_basic_value, #process_hash, #to_hash, #to_json

Constructor Details

#initialize(application_id:, name:, created_at:, logo_url:, application_url:, reason_for_access:, additional_properties: nil) ⇒ Application

Returns a new instance of Application.



66
67
68
69
70
71
72
73
74
75
76
77
78
79
# File 'lib/plaid/models/application.rb', line 66

def initialize(application_id:, name:, created_at:, logo_url:,
               application_url:, reason_for_access:,
               additional_properties: nil)
  # Add additional model properties to the instance
  additional_properties = {} if additional_properties.nil?

  @application_id = application_id
  @name = name
  @created_at = created_at
  @logo_url = logo_url
  @application_url = application_url
  @reason_for_access = reason_for_access
  @additional_properties = additional_properties
end

Instance Attribute Details

#application_idString

This field will map to the application ID that is returned from /item/applications/list, or provided to the institution in an oauth redirect.

Returns:

  • (String)


16
17
18
# File 'lib/plaid/models/application.rb', line 16

def application_id
  @application_id
end

#application_urlString

The URL for the application’s website

Returns:

  • (String)


33
34
35
# File 'lib/plaid/models/application.rb', line 33

def application_url
  @application_url
end

#created_atDate

The date this application was linked in [ISO 8601](wikipedia.org/wiki/ISO_8601) (YYYY-MM-DD) format in UTC.

Returns:

  • (Date)


25
26
27
# File 'lib/plaid/models/application.rb', line 25

def created_at
  @created_at
end

#logo_urlString

A URL that links to the application logo image.

Returns:

  • (String)


29
30
31
# File 'lib/plaid/models/application.rb', line 29

def logo_url
  @logo_url
end

#nameString

The name of the application

Returns:

  • (String)


20
21
22
# File 'lib/plaid/models/application.rb', line 20

def name
  @name
end

#reason_for_accessString

A string provided by the connected app stating why they use their respective enabled products.

Returns:

  • (String)


38
39
40
# File 'lib/plaid/models/application.rb', line 38

def reason_for_access
  @reason_for_access
end

Class Method Details

.from_hash(hash) ⇒ Object

Creates an instance of the object from a hash.



82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
# File 'lib/plaid/models/application.rb', line 82

def self.from_hash(hash)
  return nil unless hash

  # Extract variables from the hash.
  application_id =
    hash.key?('application_id') ? hash['application_id'] : nil
  name = hash.key?('name') ? hash['name'] : nil
  created_at = hash.key?('created_at') ? hash['created_at'] : nil
  logo_url = hash.key?('logo_url') ? hash['logo_url'] : nil
  application_url =
    hash.key?('application_url') ? hash['application_url'] : nil
  reason_for_access =
    hash.key?('reason_for_access') ? hash['reason_for_access'] : nil

  # Create a new hash for additional properties, removing known properties.
  new_hash = hash.reject { |k, _| names.value?(k) }

  additional_properties = APIHelper.get_additional_properties(
    new_hash, proc { |value| value }
  )

  # Create object from extracted values.
  Application.new(application_id: application_id,
                  name: name,
                  created_at: created_at,
                  logo_url: logo_url,
                  application_url: application_url,
                  reason_for_access: reason_for_access,
                  additional_properties: additional_properties)
end

.namesObject

A mapping from model property names to API property names.



41
42
43
44
45
46
47
48
49
50
# File 'lib/plaid/models/application.rb', line 41

def self.names
  @_hash = {} if @_hash.nil?
  @_hash['application_id'] = 'application_id'
  @_hash['name'] = 'name'
  @_hash['created_at'] = 'created_at'
  @_hash['logo_url'] = 'logo_url'
  @_hash['application_url'] = 'application_url'
  @_hash['reason_for_access'] = 'reason_for_access'
  @_hash
end

.nullablesObject

An array for nullable fields



58
59
60
61
62
63
64
# File 'lib/plaid/models/application.rb', line 58

def self.nullables
  %w[
    logo_url
    application_url
    reason_for_access
  ]
end

.optionalsObject

An array for optional fields



53
54
55
# File 'lib/plaid/models/application.rb', line 53

def self.optionals
  []
end

Instance Method Details

#inspectObject

Provides a debugging-friendly string with detailed object information.



123
124
125
126
127
128
129
# File 'lib/plaid/models/application.rb', line 123

def inspect
  class_name = self.class.name.split('::').last
  "<#{class_name} application_id: #{@application_id.inspect}, name: #{@name.inspect},"\
  " created_at: #{@created_at.inspect}, logo_url: #{@logo_url.inspect}, application_url:"\
  " #{@application_url.inspect}, reason_for_access: #{@reason_for_access.inspect},"\
  " additional_properties: #{@additional_properties}>"
end

#to_sObject

Provides a human-readable string representation of the object.



114
115
116
117
118
119
120
# File 'lib/plaid/models/application.rb', line 114

def to_s
  class_name = self.class.name.split('::').last
  "<#{class_name} application_id: #{@application_id}, name: #{@name}, created_at:"\
  " #{@created_at}, logo_url: #{@logo_url}, application_url: #{@application_url},"\
  " reason_for_access: #{@reason_for_access}, additional_properties:"\
  " #{@additional_properties}>"
end