Class: PaypalServerSdk::PaypalWalletVaultInstruction

Inherits:
BaseModel
  • Object
show all
Defined in:
lib/paypal_server_sdk/models/paypal_wallet_vault_instruction.rb

Overview

PaypalWalletVaultInstruction Model.

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from BaseModel

#to_hash, #to_json

Constructor Details

#initialize(usage_type:, store_in_vault: SKIP, description: SKIP, usage_pattern: SKIP, customer_type: PaypalPaymentTokenCustomerType::CONSUMER, permit_multiple_payment_tokens: false) ⇒ PaypalWalletVaultInstruction

Returns a new instance of PaypalWalletVaultInstruction.



76
77
78
79
80
81
82
83
84
85
86
87
88
89
# File 'lib/paypal_server_sdk/models/paypal_wallet_vault_instruction.rb', line 76

def initialize(usage_type:, store_in_vault: SKIP, description: SKIP,
               usage_pattern: SKIP,
               customer_type: PaypalPaymentTokenCustomerType::CONSUMER,
               permit_multiple_payment_tokens: false)
  @store_in_vault = store_in_vault unless store_in_vault == SKIP
  @description = description unless description == SKIP
  @usage_pattern = usage_pattern unless usage_pattern == SKIP
  @usage_type = usage_type
  @customer_type = customer_type unless customer_type == SKIP
  unless permit_multiple_payment_tokens == SKIP
    @permit_multiple_payment_tokens =
      permit_multiple_payment_tokens
  end
end

Instance Attribute Details

#customer_typePaypalPaymentTokenCustomerType

The customer type associated with the PayPal payment token. This is to indicate whether the customer acting on the merchant / platform is either a business or a consumer.



34
35
36
# File 'lib/paypal_server_sdk/models/paypal_wallet_vault_instruction.rb', line 34

def customer_type
  @customer_type
end

#descriptionString

The description displayed to PayPal consumer on the approval flow for PayPal, as well as on the PayPal payment token management experience on PayPal.com.

Returns:

  • (String)


20
21
22
# File 'lib/paypal_server_sdk/models/paypal_wallet_vault_instruction.rb', line 20

def description
  @description
end

#permit_multiple_payment_tokensTrueClass | FalseClass

Create multiple payment tokens for the same payer, merchant/platform combination. Use this when the customer has not logged in at merchant/platform. The payment token thus generated, can then also be used to create the customer account at merchant/platform. Use this also when multiple payment tokens are required for the same payer, different customer at merchant/platform. This helps to identify customers distinctly even though they may share the same PayPal account. This only applies to PayPal payment source.

Returns:

  • (TrueClass | FalseClass)


45
46
47
# File 'lib/paypal_server_sdk/models/paypal_wallet_vault_instruction.rb', line 45

def permit_multiple_payment_tokens
  @permit_multiple_payment_tokens
end

#store_in_vaultStoreInVaultInstruction

Defines how and when the payment source gets vaulted.



14
15
16
# File 'lib/paypal_server_sdk/models/paypal_wallet_vault_instruction.rb', line 14

def store_in_vault
  @store_in_vault
end

#usage_patternPaypalPaymentTokenUsagePattern

Expected business/pricing model for the billing agreement.



24
25
26
# File 'lib/paypal_server_sdk/models/paypal_wallet_vault_instruction.rb', line 24

def usage_pattern
  @usage_pattern
end

#usage_typePaypalPaymentTokenUsageType

The usage type associated with the PayPal payment token.



28
29
30
# File 'lib/paypal_server_sdk/models/paypal_wallet_vault_instruction.rb', line 28

def usage_type
  @usage_type
end

Class Method Details

.from_hash(hash) ⇒ Object

Creates an instance of the object from a hash.



92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
# File 'lib/paypal_server_sdk/models/paypal_wallet_vault_instruction.rb', line 92

def self.from_hash(hash)
  return nil unless hash

  # Extract variables from the hash.
  usage_type = hash.key?('usage_type') ? hash['usage_type'] : nil
  store_in_vault =
    hash.key?('store_in_vault') ? hash['store_in_vault'] : SKIP
  description = hash.key?('description') ? hash['description'] : SKIP
  usage_pattern = hash.key?('usage_pattern') ? hash['usage_pattern'] : SKIP
  customer_type =
    hash['customer_type'] ||= PaypalPaymentTokenCustomerType::CONSUMER
  permit_multiple_payment_tokens =
    hash['permit_multiple_payment_tokens'] ||= false

  # Create object from extracted values.
  PaypalWalletVaultInstruction.new(usage_type: usage_type,
                                   store_in_vault: store_in_vault,
                                   description: description,
                                   usage_pattern: usage_pattern,
                                   customer_type: customer_type,
                                   permit_multiple_payment_tokens: permit_multiple_payment_tokens)
end

.namesObject

A mapping from model property names to API property names.



48
49
50
51
52
53
54
55
56
57
58
# File 'lib/paypal_server_sdk/models/paypal_wallet_vault_instruction.rb', line 48

def self.names
  @_hash = {} if @_hash.nil?
  @_hash['store_in_vault'] = 'store_in_vault'
  @_hash['description'] = 'description'
  @_hash['usage_pattern'] = 'usage_pattern'
  @_hash['usage_type'] = 'usage_type'
  @_hash['customer_type'] = 'customer_type'
  @_hash['permit_multiple_payment_tokens'] =
    'permit_multiple_payment_tokens'
  @_hash
end

.nullablesObject

An array for nullable fields



72
73
74
# File 'lib/paypal_server_sdk/models/paypal_wallet_vault_instruction.rb', line 72

def self.nullables
  []
end

.optionalsObject

An array for optional fields



61
62
63
64
65
66
67
68
69
# File 'lib/paypal_server_sdk/models/paypal_wallet_vault_instruction.rb', line 61

def self.optionals
  %w[
    store_in_vault
    description
    usage_pattern
    customer_type
    permit_multiple_payment_tokens
  ]
end