Source code for terminusgps.authorizenet.profiles.subscriptions

from authorizenet import apicontractsv1, apicontrollers

from terminusgps.authorizenet.constants import AuthorizenetSubscriptionStatus
from terminusgps.authorizenet.profiles.base import AuthorizenetSubProfileBase


[docs] class SubscriptionProfile(AuthorizenetSubProfileBase): """An Authorizenet subscription profile.""" @property def status(self) -> AuthorizenetSubscriptionStatus | None: """ Current subscription status. :type: :py:obj:`~terminusgps.authorizenet.constants.AuthorizenetSubscriptionStatus` | :py:obj:`None` """ return ( AuthorizenetSubscriptionStatus( self._authorizenet_get_subscription_status().status ) if self.id else None ) @property def transactions(self) -> list[dict[str, str]]: """ Subscription transactions. :type: :py:obj:`list` """ if not self.id: return [] sub = self._authorizenet_get_subscription( include_transactions=True ).subscription return [t.arbTransaction for t in sub.arbTransactions]
[docs] def create(self, subscription: apicontractsv1.ARBSubscriptionType) -> int: """ Creates a subscription in Authorizenet. :param subscription: A subscription. :type subscription: :py:obj:`~authorizenet.apicontractsv1.ARBSubscriptionType` :raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call. :returns: A subscription id. :rtype: :py:obj:`int` """ return int(self._authorizenet_create_subscription(subscription).subscriptionId)
[docs] def update(self, subscription: apicontractsv1.ARBSubscriptionType) -> None: """ Updates a subscription in Authorizenet if :py:attr:`id` is set. :param subscription: A subscription. :type subscription: :py:obj:`~authorizenet.apicontractsv1.ARBSubscriptionType` :raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call. :returns: Nothing. :rtype: :py:obj:`None` """ if self.id: self._authorizenet_update_subscription(subscription)
[docs] def delete(self) -> None: """ Deletes (cancels) a subscription in Authorizenet if :py:attr:`id` is set. :raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call. :returns: Nothing. :rtype: :py:obj:`None` """ if self.id: self._authorizenet_cancel_subscription()
def _authorizenet_create_subscription( self, subscription: apicontractsv1.ARBSubscriptionType ) -> dict | None: """ Executes a :py:obj:`~authorizenet.apicontractsv1.ARBCreateSubscriptionRequest` using the Authorizenet API. `ARBCreateSubscriptionRequest <https://developer.authorize.net/api/reference/index.html#recurring-billing-create-a-subscription-from-customer-profile>`_ :raises AssertionError: If :py:attr:`id` wasn't set. :raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call. :returns: An Authorizenet API response, if any. :rtype: :py:obj:`dict` | :py:obj:`None` """ request = apicontractsv1.ARBCreateSubscriptionRequest( merchantAuthentication=self.merchantAuthentication, subscription=subscription, ) controller = apicontrollers.ARBCreateSubscriptionController(request) return self.execute_controller(controller) def _authorizenet_get_subscription( self, include_transactions: bool = False ) -> dict | None: """ Executes a :py:obj:`~authorizenet.apicontractsv1.ARBGetSubscriptionRequest` using the Authorizenet API. `ARBGetSubscriptionRequest <https://developer.authorize.net/api/reference/index.html#recurring-billing-get-subscription>`_ :param include_transactions: Whether or not to include subscription transactions in the Authorizenet API response. Default is :py:obj:`False`. :type include_transaction: :py:obj:`bool` :raises AssertionError: If :py:attr:`id` wasn't set. :raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call. :returns: An Authorizenet API response, if any. :rtype: :py:obj:`dict` | :py:obj:`None` """ assert self.id, "'id' was not set." request = apicontractsv1.ARBGetSubscriptionRequest( merchantAuthentication=self.merchantAuthentication, subscriptionId=self.id, includeTransactions=str(include_transactions).lower(), ) controller = apicontrollers.ARBGetSubscriptionController(request) return self.execute_controller(controller) def _authorizenet_get_subscription_status(self) -> dict | None: """ Executes a :py:obj:`~authorizenet.apicontractsv1.ARBGetSubscriptionStatusRequest` using the Authorizenet API. `ARBGetSubscriptionStatusRequest <https://developer.authorize.net/api/reference/index.html#recurring-billing-get-subscription-status>`_ :raises AssertionError: If :py:attr:`id` wasn't set. :raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call. :returns: An Authorizenet API response, if any. :rtype: :py:obj:`dict` | :py:obj:`None` """ assert self.id, "'id' was not set." request = apicontractsv1.ARBGetSubscriptionStatusRequest( merchantAuthentication=self.merchantAuthentication, subscriptionId=self.id ) controller = apicontrollers.ARBGetSubscriptionStatusController(request) return self.execute_controller(controller) def _authorizenet_update_subscription( self, subscription: apicontractsv1.ARBSubscriptionType ) -> dict | None: """ Executes a :py:obj:`~authorizenet.apicontractsv1.ARBUpdateSubscriptionRequest` using the Authorizenet API. `ARBUpdateSubscriptionRequest <https://developer.authorize.net/api/reference/index.html#recurring-billing-update-a-subscription>`_ :raises AssertionError: If :py:attr:`id` wasn't set. :raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call. :returns: An Authorizenet API response, if any. :rtype: :py:obj:`dict` | :py:obj:`None` """ assert self.id, "'id' was not set." request = apicontractsv1.ARBUpdateSubscriptionRequest( merchantAuthentication=self.merchantAuthentication, subscriptionId=self.id, subscription=subscription, ) controller = apicontrollers.ARBUpdateSubscriptionController(request) return self.execute_controller(controller) def _authorizenet_cancel_subscription(self) -> dict | None: """ Executes a :py:obj:`~authorizenet.apicontractsv1.ARBCancelSubscriptionRequest` using the Authorizenet API. `ARBCancelSubscriptionRequest <https://developer.authorize.net/api/reference/index.html#recurring-billing-cancel-a-subscription>`_ :raises AssertionError: If :py:attr:`id` wasn't set. :raises AuthorizenetControllerExecutionError: If something goes wrong during an Authorizenet API call. :returns: An Authorizenet API response, if any. :rtype: :py:obj:`dict` | :py:obj:`None` """ assert self.id, "'id' was not set." request = apicontractsv1.ARBCancelSubscriptionRequest( merchantAuthentication=self.merchantAuthentication, subscriptionId=self.id ) controller = apicontrollers.ARBCancelSubscriptionController(request) return self.execute_controller(controller)