python-terminusgps 37.6.0__py3-none-any.whl → 37.6.2__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {python_terminusgps-37.6.0.dist-info → python_terminusgps-37.6.2.dist-info}/METADATA +1 -1
- {python_terminusgps-37.6.0.dist-info → python_terminusgps-37.6.2.dist-info}/RECORD +5 -10
- terminusgps/authorizenet/profiles/customers.py +21 -28
- terminusgps/authorizenet/items/__init__.py +0 -0
- terminusgps/authorizenet/items/address_profiles.py +0 -126
- terminusgps/authorizenet/items/base.py +0 -68
- terminusgps/authorizenet/items/customer_profiles.py +0 -227
- terminusgps/authorizenet/items/payment_profiles.py +0 -253
- {python_terminusgps-37.6.0.dist-info → python_terminusgps-37.6.2.dist-info}/WHEEL +0 -0
- {python_terminusgps-37.6.0.dist-info → python_terminusgps-37.6.2.dist-info}/licenses/COPYING +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: python-terminusgps
|
|
3
|
-
Version: 37.6.
|
|
3
|
+
Version: 37.6.2
|
|
4
4
|
Summary: Provides abstractions/utilities for working with Wialon API, Authorize.NET API, AWS API, and more.
|
|
5
5
|
Project-URL: Documentation, https://docs.terminusgps.com
|
|
6
6
|
Project-URL: Repository, https://github.com/terminusgps/python-terminusgps
|
|
@@ -4,15 +4,10 @@ terminusgps/authorizenet/auth.py,sha256=CKT_pfDEL-53GceOEaFtIU6IBXVuVd8MVHikpPAX
|
|
|
4
4
|
terminusgps/authorizenet/constants.py,sha256=uXkYVmQPrnYBDfGahVEmzwTny21A8jGcrH7qfSdLhvc,512
|
|
5
5
|
terminusgps/authorizenet/controllers.py,sha256=rMuBwSoKJjte7wVuB1ewaqnzfuDXxwus-d5mkqbfnGE,2193
|
|
6
6
|
terminusgps/authorizenet/utils.py,sha256=lkXjKfegFFN8TgtjlyI03416X6oqFIciFnWgSEuIgSM,6800
|
|
7
|
-
terminusgps/authorizenet/items/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
8
|
-
terminusgps/authorizenet/items/address_profiles.py,sha256=oiFw2T3TmyhLn8Vw-GWFrAeBbyOEG_dV8LLGr3oH7aI,5669
|
|
9
|
-
terminusgps/authorizenet/items/base.py,sha256=fcO0RRrOXytlSbBDLLFajfdkxYtqmniJ5FWV4z0UkOk,2004
|
|
10
|
-
terminusgps/authorizenet/items/customer_profiles.py,sha256=53cqXooXszTqMv2PuifDsDknuDxGtA73jZkquWZl0zs,9262
|
|
11
|
-
terminusgps/authorizenet/items/payment_profiles.py,sha256=kYvuq1xCmeIUmmXgbOapbA01roQ4k0zOLafcBtG-eM0,10830
|
|
12
7
|
terminusgps/authorizenet/profiles/__init__.py,sha256=IG4XCEEYtHKqXOatlZlob6J3ukAgF7cFR-RXxOSMS1c,161
|
|
13
8
|
terminusgps/authorizenet/profiles/addresses.py,sha256=MwJQzq3IrjYCLJzOglLfJIcMvH5osDu1MzN6_XGO0Tc,6376
|
|
14
9
|
terminusgps/authorizenet/profiles/base.py,sha256=Pu1NGrvC5Ox2W1oZuVcPqUw3aUoSK191Evexw1U6_3k,3940
|
|
15
|
-
terminusgps/authorizenet/profiles/customers.py,sha256=
|
|
10
|
+
terminusgps/authorizenet/profiles/customers.py,sha256=OlAY1ypK41PaTqiVVD-K-HyQsD7taxJdig0pxFc21wU,11832
|
|
16
11
|
terminusgps/authorizenet/profiles/payments.py,sha256=57qtiPKGS6loPMccLXQJoHV3fGyNNQ0AXcR9ukDNrXE,11313
|
|
17
12
|
terminusgps/authorizenet/profiles/subscriptions.py,sha256=TKTGeYCNSiDMAQGwMnFOL7E_SKt3GsiwgtIfGJE3yHc,10256
|
|
18
13
|
terminusgps/authorizenet/tests/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
@@ -55,7 +50,7 @@ terminusgps/wialon/items/route.py,sha256=2dEUK9o8nwutPE03W-5GUcZrjGvbwLoExVnFV9L
|
|
|
55
50
|
terminusgps/wialon/items/unit.py,sha256=P828NaWkTQncNre3n4h7AedeSxUXPKSxQFpBiliZCBk,12133
|
|
56
51
|
terminusgps/wialon/items/unit_group.py,sha256=HhYMZ9b7UATXeEgHkXN9r5-M_w82fabjDYADCUwBtxQ,4442
|
|
57
52
|
terminusgps/wialon/items/user.py,sha256=pR6OTrm6f7Zo0J8eLvKtWVsdhGi430OxMsMMthGh8YE,5382
|
|
58
|
-
python_terminusgps-37.6.
|
|
59
|
-
python_terminusgps-37.6.
|
|
60
|
-
python_terminusgps-37.6.
|
|
61
|
-
python_terminusgps-37.6.
|
|
53
|
+
python_terminusgps-37.6.2.dist-info/METADATA,sha256=jkLVAoaBjCBtOlDFZANLhnarDJa8DU4sA3T45Zjrgmk,1329
|
|
54
|
+
python_terminusgps-37.6.2.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
|
|
55
|
+
python_terminusgps-37.6.2.dist-info/licenses/COPYING,sha256=OXLcl0T2SZ8Pmy2_dmlvKuetivmyPd5m1q-Gyd-zaYY,35149
|
|
56
|
+
python_terminusgps-37.6.2.dist-info/RECORD,,
|
|
@@ -2,7 +2,6 @@ from authorizenet import apicontractsv1, apicontrollers
|
|
|
2
2
|
|
|
3
3
|
from terminusgps.authorizenet.auth import get_validation_mode
|
|
4
4
|
from terminusgps.authorizenet.constants import ANET_XMLNS
|
|
5
|
-
from terminusgps.authorizenet.controllers import AuthorizenetControllerExecutionError
|
|
6
5
|
from terminusgps.authorizenet.profiles.base import AuthorizenetProfileBase
|
|
7
6
|
|
|
8
7
|
|
|
@@ -27,16 +26,7 @@ class CustomerProfile(AuthorizenetProfileBase):
|
|
|
27
26
|
self._merchant_id = merchant_id
|
|
28
27
|
self._email = email
|
|
29
28
|
self._desc = desc
|
|
30
|
-
|
|
31
|
-
if not self.id:
|
|
32
|
-
try:
|
|
33
|
-
self.id = int(
|
|
34
|
-
self._authorizenet_get_customer_profile()
|
|
35
|
-
.find(f"{ANET_XMLNS}profile")
|
|
36
|
-
.find(f"{ANET_XMLNS}customerProfileId")
|
|
37
|
-
)
|
|
38
|
-
except AuthorizenetControllerExecutionError:
|
|
39
|
-
self.id = self.create()
|
|
29
|
+
self.id = self._get_id()
|
|
40
30
|
|
|
41
31
|
@property
|
|
42
32
|
def merchant_id(self) -> str:
|
|
@@ -46,13 +36,11 @@ class CustomerProfile(AuthorizenetProfileBase):
|
|
|
46
36
|
:type: :py:obj:`str`
|
|
47
37
|
|
|
48
38
|
"""
|
|
49
|
-
if self.id and not self._merchant_id:
|
|
50
|
-
response = self._authorizenet_get_customer_profile()
|
|
39
|
+
if self.id or self._email and not self._merchant_id:
|
|
51
40
|
self._merchant_id = (
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
else None
|
|
41
|
+
self._authorizenet_get_customer_profile()
|
|
42
|
+
.find(f"{ANET_XMLNS}profile")
|
|
43
|
+
.find(f"{ANET_XMLNS}merchantCustomerId")
|
|
56
44
|
)
|
|
57
45
|
return str(self._merchant_id)
|
|
58
46
|
|
|
@@ -69,12 +57,11 @@ class CustomerProfile(AuthorizenetProfileBase):
|
|
|
69
57
|
:type: :py:obj:`str`
|
|
70
58
|
|
|
71
59
|
"""
|
|
72
|
-
if self.id and not self._email:
|
|
73
|
-
response = self._authorizenet_get_customer_profile()
|
|
60
|
+
if self.id or self._merchant_id and not self._email:
|
|
74
61
|
self._email = (
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
62
|
+
self._authorizenet_get_customer_profile()
|
|
63
|
+
.find(f"{ANET_XMLNS}profile")
|
|
64
|
+
.find(f"{ANET_XMLNS}email")
|
|
78
65
|
)
|
|
79
66
|
return str(self._email)
|
|
80
67
|
|
|
@@ -91,12 +78,11 @@ class CustomerProfile(AuthorizenetProfileBase):
|
|
|
91
78
|
:type: :py:obj:`str`
|
|
92
79
|
|
|
93
80
|
"""
|
|
94
|
-
if self.id and not self._desc:
|
|
95
|
-
response = self._authorizenet_get_customer_profile()
|
|
81
|
+
if self.id or self._merchant_id or self._email and not self._desc:
|
|
96
82
|
self._desc = (
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
83
|
+
self._authorizenet_get_customer_profile()
|
|
84
|
+
.find(f"{ANET_XMLNS}profile")
|
|
85
|
+
.find(f"{ANET_XMLNS}description")
|
|
100
86
|
)
|
|
101
87
|
return str(self._desc)
|
|
102
88
|
|
|
@@ -190,7 +176,7 @@ class CustomerProfile(AuthorizenetProfileBase):
|
|
|
190
176
|
address_profiles = (
|
|
191
177
|
self._authorizenet_get_customer_profile()
|
|
192
178
|
.find(f"{ANET_XMLNS}profile")
|
|
193
|
-
.
|
|
179
|
+
.find(f"{ANET_XMLNS}shipToList")
|
|
194
180
|
)
|
|
195
181
|
return (
|
|
196
182
|
[
|
|
@@ -201,6 +187,13 @@ class CustomerProfile(AuthorizenetProfileBase):
|
|
|
201
187
|
else []
|
|
202
188
|
)
|
|
203
189
|
|
|
190
|
+
def _get_id(self) -> int:
|
|
191
|
+
return int(
|
|
192
|
+
self._authorizenet_get_customer_profile()
|
|
193
|
+
.find(f"{ANET_XMLNS}profile")
|
|
194
|
+
.find(f"{ANET_XMLNS}customerProfileId")
|
|
195
|
+
)
|
|
196
|
+
|
|
204
197
|
def _generate_customer_profile_ex_type(
|
|
205
198
|
self,
|
|
206
199
|
) -> apicontractsv1.customerProfileExType:
|
|
File without changes
|
|
@@ -1,126 +0,0 @@
|
|
|
1
|
-
import typing
|
|
2
|
-
|
|
3
|
-
from authorizenet import apicontractsv1, apicontrollers
|
|
4
|
-
|
|
5
|
-
from .base import AuthorizenetBase
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
class AuthorizenetAddressProfile(AuthorizenetBase):
|
|
9
|
-
"""An Authorizenet address profile."""
|
|
10
|
-
|
|
11
|
-
def __init__(self, customerProfileId: int | str, *args, **kwargs) -> None:
|
|
12
|
-
super().__init__(*args, **kwargs)
|
|
13
|
-
if isinstance(customerProfileId, str) and not customerProfileId.isdigit():
|
|
14
|
-
raise ValueError(
|
|
15
|
-
f"'customerProfileId' can only contain digits, got '{customerProfileId}'."
|
|
16
|
-
)
|
|
17
|
-
self.customerProfileId = customerProfileId
|
|
18
|
-
|
|
19
|
-
def _authorizenet_create_customer_shipping_address(
|
|
20
|
-
self, address: apicontractsv1.customerAddressType, default: bool = False
|
|
21
|
-
) -> dict[str, typing.Any] | None:
|
|
22
|
-
"""
|
|
23
|
-
Executes a :py:obj:`~authorizenet.apicontractsv1.createCustomerShippingAddressRequest` using the Authorizenet API.
|
|
24
|
-
|
|
25
|
-
`createCustomerShippingAddressRequest <https://developer.authorize.net/api/reference/index.html#customer-profiles-create-customer-shipping-address>`_
|
|
26
|
-
|
|
27
|
-
:param address: A customer address object.
|
|
28
|
-
:type address: :py:obj:`~authorizenet.apicontractsv1.customerAddressType`
|
|
29
|
-
:param default: Whether or not to set the address profile as default.
|
|
30
|
-
:type default: :py:obj:`bool`
|
|
31
|
-
:raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call.
|
|
32
|
-
:returns: An Authorizenet API response, if any.
|
|
33
|
-
:rtype: :py:obj:`dict` | :py:obj:`None`
|
|
34
|
-
|
|
35
|
-
"""
|
|
36
|
-
|
|
37
|
-
request = apicontractsv1.createCustomerShippingAddressRequest()
|
|
38
|
-
request.merchantAuthentication = self.merchantAuthentication
|
|
39
|
-
request.customerProfileId = self.customerProfileId
|
|
40
|
-
request.address = address
|
|
41
|
-
request.defaultShippingAddress = str(default).lower()
|
|
42
|
-
|
|
43
|
-
return self.execute_controller(
|
|
44
|
-
apicontrollers.createCustomerShippingAddressController(request)
|
|
45
|
-
)
|
|
46
|
-
|
|
47
|
-
def _authorizenet_get_customer_shipping_address(
|
|
48
|
-
self,
|
|
49
|
-
) -> dict[str, typing.Any] | None:
|
|
50
|
-
"""
|
|
51
|
-
Executes a :py:obj:`~authorizenet.apicontractsv1.getCustomerShippingAddressRequest` using the Authorizenet API.
|
|
52
|
-
|
|
53
|
-
`getCustomerShippingAddressRequest <https://developer.authorize.net/api/reference/index.html#customer-profiles-get-customer-shipping-address>`_
|
|
54
|
-
|
|
55
|
-
:raises AssertionError: If :py:attr:`id` wasn't set.
|
|
56
|
-
:raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call.
|
|
57
|
-
:returns: An Authorizenet API response, if any.
|
|
58
|
-
:rtype: :py:obj:`dict` | :py:obj:`None`
|
|
59
|
-
|
|
60
|
-
"""
|
|
61
|
-
|
|
62
|
-
assert self.id, "Address profile id wasn't set."
|
|
63
|
-
|
|
64
|
-
request = apicontractsv1.getCustomerShippingAddressRequest()
|
|
65
|
-
request.merchantAuthentication = self.merchantAuthentication
|
|
66
|
-
request.customerProfileId = self.customerProfileId
|
|
67
|
-
request.customerAddressId = self.id
|
|
68
|
-
|
|
69
|
-
return self.execute_controller(
|
|
70
|
-
apicontrollers.getCustomerShippingAddressController(request)
|
|
71
|
-
)
|
|
72
|
-
|
|
73
|
-
def _authorizenet_update_customer_shipping_address(
|
|
74
|
-
self, address: apicontractsv1.customerAddressType, default: bool = False
|
|
75
|
-
) -> dict[str, typing.Any] | None:
|
|
76
|
-
"""
|
|
77
|
-
Executes a :py:obj:`~authorizenet.apicontractsv1.updateCustomerShippingAddress` using the Authorizenet API.
|
|
78
|
-
|
|
79
|
-
`updateCustomerShippingAddressRequest <https://developer.authorize.net/api/reference/index.html#customer-profiles-update-customer-shipping-address>`_
|
|
80
|
-
|
|
81
|
-
:param address: A customer address object.
|
|
82
|
-
:type address: :py:obj:`~authorizenet.apicontractsv1.customerAddressType`
|
|
83
|
-
:param default: Whether or not to set the address profile as default.
|
|
84
|
-
:type default: :py:obj:`bool`
|
|
85
|
-
:raises AssertionError: If :py:attr:`id` wasn't set.
|
|
86
|
-
:raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call.
|
|
87
|
-
:returns: An Authorizenet API response, if any.
|
|
88
|
-
:rtype: :py:obj:`dict` | :py:obj:`None`
|
|
89
|
-
|
|
90
|
-
"""
|
|
91
|
-
request = apicontractsv1.updateCustomerShippingAddressRequest()
|
|
92
|
-
request.merchantAuthentication = self.merchantAuthentication
|
|
93
|
-
request.customerProfileId = self.customerProfileId
|
|
94
|
-
request.address = address
|
|
95
|
-
request.address.customerAddressId = self.id
|
|
96
|
-
request.defaultShippingAddress = str(default).lower()
|
|
97
|
-
|
|
98
|
-
return self.execute_controller(
|
|
99
|
-
apicontrollers.updateCustomerShippingAddressController(request)
|
|
100
|
-
)
|
|
101
|
-
|
|
102
|
-
def _authorizenet_delete_customer_shipping_address(
|
|
103
|
-
self,
|
|
104
|
-
) -> dict[str, typing.Any] | None:
|
|
105
|
-
"""
|
|
106
|
-
Executes a :py:obj:`~authorizenet.apicontractsv1.deleteCustomerShippingAddress` using the Authorizenet API.
|
|
107
|
-
|
|
108
|
-
`deleteCustomerShippingAddressRequest <https://developer.authorize.net/api/reference/index.html#customer-profiles-delete-customer-shipping-address>`_
|
|
109
|
-
|
|
110
|
-
:raises AssertionError: If :py:attr:`id` wasn't set.
|
|
111
|
-
:raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call.
|
|
112
|
-
:returns: An Authorizenet API response, if any.
|
|
113
|
-
:rtype: :py:obj:`dict` | :py:obj:`None`
|
|
114
|
-
|
|
115
|
-
"""
|
|
116
|
-
|
|
117
|
-
assert self.id, "Address profile id wasn't set."
|
|
118
|
-
|
|
119
|
-
request = apicontractsv1.deleteCustomerShippingAddressRequest()
|
|
120
|
-
request.merchantAuthentication = self.merchantAuthentication
|
|
121
|
-
request.customerProfileId = self.customerProfileId
|
|
122
|
-
request.customerAddressId = self.id
|
|
123
|
-
|
|
124
|
-
return self.execute_controller(
|
|
125
|
-
apicontrollers.deleteCustomerShippingAddressController(request)
|
|
126
|
-
)
|
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
from authorizenet import apicontractsv1
|
|
2
|
-
|
|
3
|
-
from terminusgps.authorizenet.auth import get_merchant_auth, get_validation_mode
|
|
4
|
-
from terminusgps.authorizenet.controllers import AuthorizenetControllerExecutor
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
class AuthorizenetBase(AuthorizenetControllerExecutor):
|
|
8
|
-
"""Base class for Authorizenet objects."""
|
|
9
|
-
|
|
10
|
-
def __init__(self, id: int | str | None = None, *args, **kwargs) -> None:
|
|
11
|
-
"""
|
|
12
|
-
Sets :py:attr:`id` if provided.
|
|
13
|
-
|
|
14
|
-
:returns: Nothing.
|
|
15
|
-
:rtype: :py:obj:`None`
|
|
16
|
-
|
|
17
|
-
"""
|
|
18
|
-
self.id = id
|
|
19
|
-
|
|
20
|
-
def __str__(self) -> str:
|
|
21
|
-
"""Returns the object in format: '#<ID>' if :py:attr:`id` is set."""
|
|
22
|
-
return f"#{self.id}" if self.id else ""
|
|
23
|
-
|
|
24
|
-
@property
|
|
25
|
-
def id(self) -> str | None:
|
|
26
|
-
"""
|
|
27
|
-
An Authorizenet generated id.
|
|
28
|
-
|
|
29
|
-
:type: :py:obj:`str` | :py:obj:`None`
|
|
30
|
-
|
|
31
|
-
"""
|
|
32
|
-
return self._id
|
|
33
|
-
|
|
34
|
-
@id.setter
|
|
35
|
-
def id(self, other: int | str | None) -> None:
|
|
36
|
-
"""
|
|
37
|
-
Sets :py:attr:`id` to ``other``.
|
|
38
|
-
|
|
39
|
-
:raises ValueError: If ``other`` was provided as a string containing non-digit characters.
|
|
40
|
-
:returns: Nothing.
|
|
41
|
-
:rtype: :py:obj:`None`
|
|
42
|
-
|
|
43
|
-
"""
|
|
44
|
-
if isinstance(other, str) and not other.isdigit():
|
|
45
|
-
raise ValueError(f"'id' can only contain digit characters, got '{other}'.")
|
|
46
|
-
self._id = str(other) if other is not None else None
|
|
47
|
-
|
|
48
|
-
@property
|
|
49
|
-
def merchantAuthentication(self) -> apicontractsv1.merchantAuthenticationType:
|
|
50
|
-
"""
|
|
51
|
-
Current merchant authentication object to authenticate Authorizenet API calls.
|
|
52
|
-
|
|
53
|
-
:returns: A merchant authentication object.
|
|
54
|
-
:rtype: :py:obj:`~authorizenet.apicontractsv1.merchantAuthenticationType`
|
|
55
|
-
|
|
56
|
-
"""
|
|
57
|
-
return get_merchant_auth()
|
|
58
|
-
|
|
59
|
-
@property
|
|
60
|
-
def validationMode(self) -> str:
|
|
61
|
-
"""
|
|
62
|
-
Current Authorizenet API validation mode.
|
|
63
|
-
|
|
64
|
-
:returns: An Authorizenet API validation mode string.
|
|
65
|
-
:rtype: :py:obj:`str`
|
|
66
|
-
|
|
67
|
-
"""
|
|
68
|
-
return get_validation_mode()
|
|
@@ -1,227 +0,0 @@
|
|
|
1
|
-
import typing
|
|
2
|
-
|
|
3
|
-
from authorizenet import apicontractsv1, apicontrollers
|
|
4
|
-
|
|
5
|
-
from .base import AuthorizenetBase
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
class AuthorizenetCustomerProfile(AuthorizenetBase):
|
|
9
|
-
"""An Authorizenet customer profile."""
|
|
10
|
-
|
|
11
|
-
def __init__(self, email: str, merchant_id: str, *args, **kwargs) -> None:
|
|
12
|
-
"""
|
|
13
|
-
Sets :py:attr:`_email` and :py:attr:`_merchant_id`.
|
|
14
|
-
|
|
15
|
-
:param email: An email address.
|
|
16
|
-
:type email: :py:obj:`str`
|
|
17
|
-
:param merchant_id: A merchant designated id string.
|
|
18
|
-
:type merchant_id: :py:obj:`str`
|
|
19
|
-
:returns: Nothing.
|
|
20
|
-
:rtype: :py:obj:`None`
|
|
21
|
-
|
|
22
|
-
"""
|
|
23
|
-
super().__init__(*args, **kwargs)
|
|
24
|
-
self._email = email
|
|
25
|
-
self._merchant_id = merchant_id
|
|
26
|
-
|
|
27
|
-
@property
|
|
28
|
-
def email(self) -> str:
|
|
29
|
-
"""An email address assigned to the customer profile."""
|
|
30
|
-
return str(self._email)
|
|
31
|
-
|
|
32
|
-
@property
|
|
33
|
-
def merchant_id(self) -> str:
|
|
34
|
-
"""A merchant designated id assigned to the customer profile."""
|
|
35
|
-
return str(self._merchant_id)
|
|
36
|
-
|
|
37
|
-
@email.setter
|
|
38
|
-
def email(self, other: str) -> None:
|
|
39
|
-
"""Sets :py:attr:`email` to ``other``."""
|
|
40
|
-
self._email = str(other)
|
|
41
|
-
|
|
42
|
-
@merchant_id.setter
|
|
43
|
-
def merchant_id(self, other: str) -> None:
|
|
44
|
-
"""Sets :py:attr:`merchant_id` to ``other``."""
|
|
45
|
-
self._merchant_id = str(other)
|
|
46
|
-
|
|
47
|
-
def create(self, desc: str | None = None, validate: bool = False) -> int:
|
|
48
|
-
"""
|
|
49
|
-
Creates an Authorizenet customer profile and returns its id as an integer.
|
|
50
|
-
|
|
51
|
-
If successfully created, sets :py:attr:`id` to the new customer profile id.
|
|
52
|
-
|
|
53
|
-
:param desc: An optional customer profile description. Default is :py:obj:`None`
|
|
54
|
-
:type desc: :py:obj:`str` | :py:obj:`None`
|
|
55
|
-
:param validate: Whether or not to validate a payment on the new customer profile. Default is :py:obj:`False`.
|
|
56
|
-
:type validate: :py:obj:`bool`
|
|
57
|
-
:raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call.
|
|
58
|
-
:returns: A customer profile id integer.
|
|
59
|
-
:rtype: :py:obj:`int`
|
|
60
|
-
|
|
61
|
-
"""
|
|
62
|
-
|
|
63
|
-
profile = apicontractsv1.customerProfileType()
|
|
64
|
-
profile.merchantCustomerId = self.merchant_id
|
|
65
|
-
if desc:
|
|
66
|
-
profile.description = desc
|
|
67
|
-
|
|
68
|
-
response = self._authorizenet_create_customer_profile(profile, validate)
|
|
69
|
-
profile_id = int(response.customerProfileId)
|
|
70
|
-
self.id = profile_id
|
|
71
|
-
|
|
72
|
-
return profile_id
|
|
73
|
-
|
|
74
|
-
def delete(self) -> None:
|
|
75
|
-
"""
|
|
76
|
-
Deletes the Authorizenet customer profile.
|
|
77
|
-
|
|
78
|
-
If successfully deleted, sets :py:attr:`id` to :py:obj:`None`.
|
|
79
|
-
|
|
80
|
-
:raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call.
|
|
81
|
-
:returns: Nothing.
|
|
82
|
-
:rtype: :py:obj:`None`
|
|
83
|
-
|
|
84
|
-
"""
|
|
85
|
-
|
|
86
|
-
if self.id:
|
|
87
|
-
self._authorizenet_delete_customer_profile()
|
|
88
|
-
self._id = None
|
|
89
|
-
|
|
90
|
-
def update(self, desc: str | None = None, validate: bool = False) -> None:
|
|
91
|
-
"""
|
|
92
|
-
Updates the Authorizenet customer profile if :py:attr:`id` is set.
|
|
93
|
-
|
|
94
|
-
:param desc: An optional customer profile description. Default is :py:obj:`None`
|
|
95
|
-
:type desc: :py:obj:`str` | :py:obj:`None`
|
|
96
|
-
:param validate: Whether or not to validate a payment on the customer profile. Default is :py:obj:`False`.
|
|
97
|
-
:type validate: :py:obj:`bool`
|
|
98
|
-
:raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call.
|
|
99
|
-
:returns: Nothing.
|
|
100
|
-
:rtype: :py:obj:`None`
|
|
101
|
-
|
|
102
|
-
"""
|
|
103
|
-
|
|
104
|
-
if self.id:
|
|
105
|
-
profile = apicontractsv1.customerProfileExType()
|
|
106
|
-
profile.customerProfileId = self.id
|
|
107
|
-
profile.merchantCustomerId = self.merchant_id
|
|
108
|
-
profile.email = self.email
|
|
109
|
-
if desc is not None:
|
|
110
|
-
profile.description = desc
|
|
111
|
-
|
|
112
|
-
self._authorizenet_update_customer_profile(profile, validate)
|
|
113
|
-
|
|
114
|
-
def _authorizenet_get_customer_profile(
|
|
115
|
-
self, issuer_info: bool = False
|
|
116
|
-
) -> dict[str, typing.Any] | None:
|
|
117
|
-
"""
|
|
118
|
-
Executes a :py:obj:`~authorizenet.apicontractsv1.getCustomerProfileRequest` using the Authorizenet API.
|
|
119
|
-
|
|
120
|
-
`getCustomerProfileRequest <https://developer.authorize.net/api/reference/index.html#customer-profiles-get-customer-profile>`_
|
|
121
|
-
|
|
122
|
-
:param issuer_info: Whether or not to include issuer information in the response. Default is :py:obj:`False`.
|
|
123
|
-
:type issuer_info: :py:obj:`bool`
|
|
124
|
-
:raises AssertionError: If none of :py:attr:`id`, :py:attr:`email` or :py:attr:`merchant_id` were set.
|
|
125
|
-
:raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call.
|
|
126
|
-
:returns: An Authorizenet API response, if any.
|
|
127
|
-
:rtype: :py:obj:`dict` | :py:obj:`None`
|
|
128
|
-
|
|
129
|
-
"""
|
|
130
|
-
|
|
131
|
-
assert any([self.id, self.email, self.merchant_id]), (
|
|
132
|
-
"At least one of 'id', 'email' or 'merchant_id' must be set."
|
|
133
|
-
)
|
|
134
|
-
|
|
135
|
-
request = apicontractsv1.getCustomerProfileRequest()
|
|
136
|
-
request.merchantAuthentication = self.merchantAuthentication
|
|
137
|
-
request.includeIssuerInfo = str(issuer_info).lower()
|
|
138
|
-
|
|
139
|
-
if self.id:
|
|
140
|
-
request.customerProfileId = self.id
|
|
141
|
-
if self.email:
|
|
142
|
-
request.email = self.email
|
|
143
|
-
if self.merchant_id:
|
|
144
|
-
request.customerMerchantId = self.merchant_id
|
|
145
|
-
|
|
146
|
-
return self.execute_controller(
|
|
147
|
-
apicontrollers.getCustomerProfileController(request)
|
|
148
|
-
)
|
|
149
|
-
|
|
150
|
-
def _authorizenet_create_customer_profile(
|
|
151
|
-
self, profile: apicontractsv1.customerProfileType, validate: bool = False
|
|
152
|
-
) -> dict[str, typing.Any] | None:
|
|
153
|
-
"""
|
|
154
|
-
Executes a :py:obj:`~authorizenet.apicontractsv1.createCustomerProfileRequest` using the Authorizenet API.
|
|
155
|
-
|
|
156
|
-
`createCustomerProfileRequest <https://developer.authorize.net/api/reference/index.html#customer-profiles-create-customer-profile>`_
|
|
157
|
-
|
|
158
|
-
:param profile: A customer profile object.
|
|
159
|
-
:type profile: :py:obj:`~authorizenet.apicontractsv1.customerProfileType`
|
|
160
|
-
:param validate: Whether or not to validate a payment profile for the customer profile. Default is :py:obj:`False`.
|
|
161
|
-
:type validate: :py:obj:`bool`
|
|
162
|
-
:raises AuthorizenetControllerExecutionError: If ``validate`` was :py:obj:`True` but validation was forbidden.
|
|
163
|
-
:raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call.
|
|
164
|
-
:returns: An Authorizenet API response, if any.
|
|
165
|
-
:rtype: :py:obj:`dict` | :py:obj:`None`
|
|
166
|
-
|
|
167
|
-
"""
|
|
168
|
-
request = apicontractsv1.createCustomerProfileRequest()
|
|
169
|
-
request.merchantAuthentication = self.merchantAuthentication
|
|
170
|
-
request.profile = profile
|
|
171
|
-
if validate:
|
|
172
|
-
request.validationMode = self.validationMode
|
|
173
|
-
|
|
174
|
-
return self.execute_controller(
|
|
175
|
-
apicontrollers.createCustomerProfileController(request)
|
|
176
|
-
)
|
|
177
|
-
|
|
178
|
-
def _authorizenet_update_customer_profile(
|
|
179
|
-
self, profile: apicontractsv1.customerProfileExType, validate: bool = False
|
|
180
|
-
) -> dict[str, typing.Any] | None:
|
|
181
|
-
"""
|
|
182
|
-
Executes a :py:obj:`~authorizenet.apicontractsv1.updateCustomerProfileRequest` using the Authorizenet API.
|
|
183
|
-
|
|
184
|
-
`updateCustomerProfileRequest <https://developer.authorize.net/api/reference/index.html#customer-profiles-update-customer-profile>`_
|
|
185
|
-
|
|
186
|
-
:param profile: A customer profile ex object.
|
|
187
|
-
:type profile: :py:obj:`~authorizenet.apicontractsv1.customerProfileExType`
|
|
188
|
-
:param validate: Whether or not to validate a payment profile for the customer profile. Default is :py:obj:`False`.
|
|
189
|
-
:type validate: :py:obj:`bool`
|
|
190
|
-
:raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call.
|
|
191
|
-
:returns: An Authorizenet API response, if any.
|
|
192
|
-
:rtype: :py:obj:`dict` | :py:obj:`None`
|
|
193
|
-
|
|
194
|
-
"""
|
|
195
|
-
|
|
196
|
-
request = apicontractsv1.updateCustomerProfileRequest()
|
|
197
|
-
request.merchantAuthentication = self.merchantAuthentication
|
|
198
|
-
request.profile = profile
|
|
199
|
-
if validate:
|
|
200
|
-
request.validationMode = self.validationMode
|
|
201
|
-
|
|
202
|
-
return self.execute_controller(
|
|
203
|
-
apicontrollers.updateCustomerProfileController(request)
|
|
204
|
-
)
|
|
205
|
-
|
|
206
|
-
def _authorizenet_delete_customer_profile(self) -> dict[str, typing.Any] | None:
|
|
207
|
-
"""
|
|
208
|
-
Executes a :py:obj:`~authorizenet.apicontractsv1.deleteCustomerProfileRequest` using the Authorizenet API.
|
|
209
|
-
|
|
210
|
-
`deleteCustomerProfileRequest <https://developer.authorize.net/api/reference/index.html#customer-profiles-delete-customer-profile>`_
|
|
211
|
-
|
|
212
|
-
:raises AssertionError: If :py:attr:`id` wasn't set.
|
|
213
|
-
:raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call.
|
|
214
|
-
:returns: An Authorizenet API response, if any.
|
|
215
|
-
:rtype: :py:obj:`dict` | :py:obj:`None`
|
|
216
|
-
|
|
217
|
-
"""
|
|
218
|
-
|
|
219
|
-
assert self.id, "Customer profile id wasn't set."
|
|
220
|
-
|
|
221
|
-
request = apicontractsv1.deleteCustomerProfileRequest()
|
|
222
|
-
request.merchantAuthentication = self.merchantAuthentication
|
|
223
|
-
request.customerProfileId = self.id
|
|
224
|
-
|
|
225
|
-
return self.execute_controller(
|
|
226
|
-
apicontrollers.deleteCustomerProfileController(request)
|
|
227
|
-
)
|
|
@@ -1,253 +0,0 @@
|
|
|
1
|
-
import typing
|
|
2
|
-
|
|
3
|
-
from authorizenet import apicontractsv1, apicontrollers
|
|
4
|
-
|
|
5
|
-
from .base import AuthorizenetBase
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
class AuthorizenetPaymentProfile(AuthorizenetBase):
|
|
9
|
-
"""An Authorizenet payment profile."""
|
|
10
|
-
|
|
11
|
-
def __init__(self, customerProfileId: int | str, *args, **kwargs) -> None:
|
|
12
|
-
super().__init__(*args, **kwargs)
|
|
13
|
-
if isinstance(customerProfileId, str) and not customerProfileId.isdigit():
|
|
14
|
-
raise ValueError(
|
|
15
|
-
f"'customerProfileId' can only contain digits, got '{customerProfileId}'."
|
|
16
|
-
)
|
|
17
|
-
self.customerProfileId = customerProfileId
|
|
18
|
-
|
|
19
|
-
def create(
|
|
20
|
-
self,
|
|
21
|
-
payment: apicontractsv1.paymentType,
|
|
22
|
-
address: apicontractsv1.customerAddressType,
|
|
23
|
-
default: bool = False,
|
|
24
|
-
validate: bool = False,
|
|
25
|
-
) -> int:
|
|
26
|
-
"""
|
|
27
|
-
Creates an Authorizenet payment profile and returns its id as an integer.
|
|
28
|
-
|
|
29
|
-
If successfully created, sets :py:attr:`id` to the new payment profile id.
|
|
30
|
-
|
|
31
|
-
:param payment: A payment object.
|
|
32
|
-
:type payment: :py:obj:`~authorizenet.apicontractsv1.paymentType`
|
|
33
|
-
:param address: A customer address object.
|
|
34
|
-
:type address: :py:obj:`~authorizenet.apicontractsv1.customerAddressType`
|
|
35
|
-
:param default: Whether or not to set the payment profile as default.
|
|
36
|
-
:type default: :py:obj:`bool`
|
|
37
|
-
:param validate: Whether or not to validate the payment profile.
|
|
38
|
-
:type validate: :py:obj:`bool`
|
|
39
|
-
:raises AuthorizenetControllerExecutionError: If something went wrong during an Authorizenet API call.
|
|
40
|
-
:returns: The new payment profile id.
|
|
41
|
-
:rtype: :py:obj:`int`
|
|
42
|
-
|
|
43
|
-
"""
|
|
44
|
-
response = self._authorizenet_create_customer_payment_profile(
|
|
45
|
-
payment=payment, address=address, default=default, validate=validate
|
|
46
|
-
)
|
|
47
|
-
|
|
48
|
-
payment_id = int(response.customerPaymentProfileId)
|
|
49
|
-
self.id = payment_id
|
|
50
|
-
|
|
51
|
-
return payment_id
|
|
52
|
-
|
|
53
|
-
def update(
|
|
54
|
-
self,
|
|
55
|
-
payment: apicontractsv1.paymentType,
|
|
56
|
-
address: apicontractsv1.customerAddressType,
|
|
57
|
-
default: bool = False,
|
|
58
|
-
validate: bool = False,
|
|
59
|
-
) -> None:
|
|
60
|
-
"""
|
|
61
|
-
Updates the Authorizenet payment profile if :py:attr:`id` is set.
|
|
62
|
-
|
|
63
|
-
:param payment: A payment object.
|
|
64
|
-
:type payment: :py:obj:`~authorizenet.apicontractsv1.paymentType`
|
|
65
|
-
:param address: A customer address object.
|
|
66
|
-
:type address: :py:obj:`~authorizenet.apicontractsv1.customerAddressType`
|
|
67
|
-
:param default: Whether or not to set the payment profile as default.
|
|
68
|
-
:type default: :py:obj:`bool`
|
|
69
|
-
:param validate: Whether or not to validate the payment profile.
|
|
70
|
-
:type validate: :py:obj:`bool`
|
|
71
|
-
:raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call.
|
|
72
|
-
:returns: Nothing.
|
|
73
|
-
:rtype: :py:obj:`None`
|
|
74
|
-
|
|
75
|
-
"""
|
|
76
|
-
if self.id:
|
|
77
|
-
self._authorizenet_update_customer_payment_profile(
|
|
78
|
-
payment=payment, address=address, default=default, validate=validate
|
|
79
|
-
)
|
|
80
|
-
|
|
81
|
-
def delete(self) -> None:
|
|
82
|
-
"""
|
|
83
|
-
Deletes the Authorizenet payment profile.
|
|
84
|
-
|
|
85
|
-
If successfully deleted, sets :py:attr:`id` to :py:obj:`None`.
|
|
86
|
-
|
|
87
|
-
:raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call.
|
|
88
|
-
:returns: Nothing.
|
|
89
|
-
:rtype: :py:obj:`None`
|
|
90
|
-
|
|
91
|
-
"""
|
|
92
|
-
|
|
93
|
-
if self.id:
|
|
94
|
-
self._authorizenet_delete_customer_payment_profile()
|
|
95
|
-
self.id = None
|
|
96
|
-
|
|
97
|
-
def _authorizenet_create_customer_payment_profile(
|
|
98
|
-
self,
|
|
99
|
-
payment: apicontractsv1.paymentType,
|
|
100
|
-
address: apicontractsv1.customerAddressType,
|
|
101
|
-
default: bool = False,
|
|
102
|
-
validate: bool = False,
|
|
103
|
-
) -> dict[str, typing.Any] | None:
|
|
104
|
-
"""
|
|
105
|
-
Executes a :py:obj:`~authorizenet.apicontractsv1.createCustomerPaymentProfileRequest` using the Authorizenet API.
|
|
106
|
-
|
|
107
|
-
`createCustomerPaymentProfileRequest <https://developer.authorize.net/api/reference/index.html#customer-profiles-create-customer-payment-profile>`_
|
|
108
|
-
|
|
109
|
-
:param payment: A payment object.
|
|
110
|
-
:type payment: :py:obj:`~authorizenet.apicontractsv1.paymentType`
|
|
111
|
-
:param address: A customer address object.
|
|
112
|
-
:type address: :py:obj:`~authorizenet.apicontractsv1.customerAddressType`
|
|
113
|
-
:param default: Whether or not to set the payment profile as default.
|
|
114
|
-
:type default: :py:obj:`bool`
|
|
115
|
-
:param validate: Whether or not to validate the payment profile in Authorizenet.
|
|
116
|
-
:type validate: :py:obj:`bool`
|
|
117
|
-
:raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call.
|
|
118
|
-
:returns: An Authorizenet API response, if any.
|
|
119
|
-
:rtype: :py:obj:`dict` | :py:obj:`None`
|
|
120
|
-
|
|
121
|
-
"""
|
|
122
|
-
|
|
123
|
-
request = apicontractsv1.createCustomerPaymentProfileRequest()
|
|
124
|
-
request.merchantAuthentication = self.merchantAuthentication
|
|
125
|
-
request.paymentProfile = apicontractsv1.customerPaymentProfileType()
|
|
126
|
-
request.paymentProfile.payment = payment
|
|
127
|
-
request.paymentProfile.address = address
|
|
128
|
-
request.paymentProfile.defaultPaymentProfile = str(default).lower()
|
|
129
|
-
|
|
130
|
-
if validate:
|
|
131
|
-
request.validationMode = self.validationMode
|
|
132
|
-
|
|
133
|
-
return self.execute_controller(
|
|
134
|
-
apicontrollers.createCustomerPaymentProfileController(request)
|
|
135
|
-
)
|
|
136
|
-
|
|
137
|
-
def _authorizenet_get_customer_payment_profile(
|
|
138
|
-
self, issuer_info: bool = False
|
|
139
|
-
) -> dict[str, typing.Any] | None:
|
|
140
|
-
"""
|
|
141
|
-
Executes a :py:obj:`~authorizenet.apicontractsv1.getCustomerPaymentProfileRequest` using the Authorizenet API.
|
|
142
|
-
|
|
143
|
-
`getCustomerPaymentProfileRequest <https://developer.authorize.net/api/reference/index.html#customer-profiles-get-customer-payment-profile>`_
|
|
144
|
-
|
|
145
|
-
:param issuer_info: Whether or not to include issuer information in the response.
|
|
146
|
-
:type issuer_info: :py:obj:`bool`
|
|
147
|
-
:raises AssertionError: If :py:attr:`id` wasn't set.
|
|
148
|
-
:raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call.
|
|
149
|
-
:returns: An Authorizenet API response, if any.
|
|
150
|
-
:rtype: :py:obj:`dict` | :py:obj:`None`
|
|
151
|
-
|
|
152
|
-
"""
|
|
153
|
-
|
|
154
|
-
assert self.id, "Customer payment profile id wasn't set."
|
|
155
|
-
|
|
156
|
-
request = apicontractsv1.getCustomerPaymentProfileRequest()
|
|
157
|
-
request.merchantAuthentication = self.merchantAuthentication
|
|
158
|
-
request.customerProfileId = self.customerProfileId
|
|
159
|
-
request.customerPaymentProfileId = self.id
|
|
160
|
-
request.includeIssuerInfo = str(issuer_info).lower()
|
|
161
|
-
|
|
162
|
-
return self.execute_controller(
|
|
163
|
-
apicontrollers.getCustomerPaymentProfileController(request)
|
|
164
|
-
)
|
|
165
|
-
|
|
166
|
-
def _authorizenet_validate_customer_payment_profile(
|
|
167
|
-
self,
|
|
168
|
-
) -> dict[str, typing.Any] | None:
|
|
169
|
-
"""
|
|
170
|
-
Executes a :py:obj:`~authorizenet.apicontractsv1.validateCustomerPaymentProfileRequest` using the Authorizenet API.
|
|
171
|
-
|
|
172
|
-
`validateCustomerPaymentProfileRequest <https://developer.authorize.net/api/reference/index.html#customer-profiles-validate-customer-payment-profile>`_
|
|
173
|
-
|
|
174
|
-
:raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call.
|
|
175
|
-
:returns: An Authorizenet API response, if any.
|
|
176
|
-
:rtype: :py:obj:`dict` | :py:obj:`None`
|
|
177
|
-
|
|
178
|
-
"""
|
|
179
|
-
|
|
180
|
-
request = apicontractsv1.validateCustomerPaymentProfileRequest()
|
|
181
|
-
request.merchantAuthentication = self.merchantAuthentication
|
|
182
|
-
request.customerProfileId = self.customerProfileId
|
|
183
|
-
request.customerPaymentProfileId = self.id
|
|
184
|
-
request.validationMode = self.validationMode
|
|
185
|
-
|
|
186
|
-
return self.execute_controller(
|
|
187
|
-
apicontrollers.validateCustomerPaymentProfileController(request)
|
|
188
|
-
)
|
|
189
|
-
|
|
190
|
-
def _authorizenet_update_customer_payment_profile(
|
|
191
|
-
self,
|
|
192
|
-
payment: apicontractsv1.paymentType,
|
|
193
|
-
address: apicontractsv1.customerAddressType,
|
|
194
|
-
default: bool = False,
|
|
195
|
-
validate: bool = False,
|
|
196
|
-
) -> dict[str, typing.Any] | None:
|
|
197
|
-
"""
|
|
198
|
-
Executes a :py:obj:`~authorizenet.apicontractsv1.updateCustomerPaymentProfileRequest` using the Authorizenet API.
|
|
199
|
-
|
|
200
|
-
`updateCustomerPaymentProfileRequest <https://developer.authorize.net/api/reference/index.html#customer-profiles-update-customer-payment-profile>`_
|
|
201
|
-
|
|
202
|
-
:param payment: A payment object.
|
|
203
|
-
:type payment: :py:obj:`~authorizenet.apicontractsv1.paymentType`
|
|
204
|
-
:param address: A customer address object.
|
|
205
|
-
:type address: :py:obj:`~authorizenet.apicontractsv1.customerAddressType`
|
|
206
|
-
:param default: Whether or not to set the payment profile as default.
|
|
207
|
-
:type default: :py:obj:`bool`
|
|
208
|
-
:param validate: Whether or not to validate the payment profile in Authorizenet.
|
|
209
|
-
:type validate: :py:obj:`bool`
|
|
210
|
-
:raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call.
|
|
211
|
-
:returns: An Authorizenet API response, if any.
|
|
212
|
-
:rtype: :py:obj:`dict` | :py:obj:`None`
|
|
213
|
-
|
|
214
|
-
"""
|
|
215
|
-
|
|
216
|
-
request = apicontractsv1.updateCustomerPaymentProfileRequest()
|
|
217
|
-
request.merchantAuthentication = self.merchantAuthentication
|
|
218
|
-
request.customerProfileId = self.customerProfileId
|
|
219
|
-
|
|
220
|
-
request.paymentProfile = apicontractsv1.customerPaymentProfileType()
|
|
221
|
-
request.paymentProfile.payment = payment
|
|
222
|
-
request.paymentProfile.address = address
|
|
223
|
-
request.paymentProfile.defaultPaymentProfile = str(default).lower()
|
|
224
|
-
request.paymentProfile.customerPaymentProfileId = self.id
|
|
225
|
-
|
|
226
|
-
if validate:
|
|
227
|
-
request.validationMode = self.validationMode
|
|
228
|
-
|
|
229
|
-
return self.execute_controller(
|
|
230
|
-
apicontrollers.updateCustomerPaymentProfileController(request)
|
|
231
|
-
)
|
|
232
|
-
|
|
233
|
-
def _authorizenet_delete_customer_payment_profile(
|
|
234
|
-
self,
|
|
235
|
-
) -> dict[str, typing.Any] | None:
|
|
236
|
-
"""
|
|
237
|
-
Executes a :py:obj:`~authorizenet.apicontractsv1.deleteCustomerPaymentProfileRequest` using the Authorizenet API.
|
|
238
|
-
|
|
239
|
-
`deleteCustomerPaymentProfileRequest <https://developer.authorize.net/api/reference/index.html#customer-profiles-delete-customer-payment-profile>`_
|
|
240
|
-
|
|
241
|
-
:raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call.
|
|
242
|
-
:returns: An Authorizenet API response, if any.
|
|
243
|
-
:rtype: :py:obj:`dict` | :py:obj:`None`
|
|
244
|
-
|
|
245
|
-
"""
|
|
246
|
-
request = apicontractsv1.deleteCustomerPaymentProfileRequest()
|
|
247
|
-
request.merchantAuthentication = self.merchantAuthentication
|
|
248
|
-
request.customerProfileId = self.customerProfileId
|
|
249
|
-
request.customerPaymentProfileId = self.id
|
|
250
|
-
|
|
251
|
-
return self.execute_controller(
|
|
252
|
-
apicontrollers.deleteCustomerPaymentProfileController(request)
|
|
253
|
-
)
|
|
File without changes
|
{python_terminusgps-37.6.0.dist-info → python_terminusgps-37.6.2.dist-info}/licenses/COPYING
RENAMED
|
File without changes
|