ClubReady Api

<back to all web services

PaymentProfileUpdateEndpoint

The following routes are available for this service:
PUT/sales/wallet/paymentprofileupdateUpdate the personal information of a Payment ProfileOmitting fields or providing `null` will not update that field.
Providing an empty or whitespace string will remove the data from the field.
To update the account information (Account Number, Last4, Country, etc), create a new Payment Profile.
import datetime
import decimal
from marshmallow.fields import *
from servicestack import *
from typing import *
from dataclasses import dataclass, field
from dataclasses_json import dataclass_json, LetterCase, Undefined, config
from enum import Enum, IntEnum


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ApiDtoBase:
    api_key: Optional[str] = None
    store_id: Optional[int] = None
    chain_id: Optional[int] = None


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class PaymentProfileUpdateRequestDto(ApiDtoBase):
    acct_token: Optional[str] = None
    modified_by: Optional[int] = None
    cc_exp_month: Optional[int] = None
    cc_exp_year: Optional[int] = None
    full_name: Optional[str] = None
    prefix_name: Optional[str] = None
    first_name: Optional[str] = None
    middle_name: Optional[str] = None
    last_name: Optional[str] = None
    suffix_name: Optional[str] = None
    address1: Optional[str] = None
    address2: Optional[str] = None
    urbanization: Optional[str] = None
    city: Optional[str] = None
    state: Optional[str] = None
    postal_code: Optional[str] = None
    is_disabled: Optional[bool] = None
    exclude_from_acct_updater: Optional[bool] = None


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ApiResponseBase:
    success: bool = False
    message: Optional[str] = None


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class PaymentProfileUpdateResponseDto(ApiResponseBase):
    pass


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class PaymentProfileUpdateResponse(PaymentProfileUpdateResponseDto):
    pass


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class PaymentProfileUpdateEndpoint(PaymentProfileUpdateRequestDto):
    # @ApiMember(Description="Grants access to resources", IsRequired=true)
    api_key: Optional[str] = None
    """
    Grants access to resources
    """


    # @ApiMember(Description="AcctToken to update", IsRequired=true)
    acct_token: Optional[str] = None
    """
    AcctToken to update
    """


    # @ApiMember(Description="UserId that is updating profile", IsRequired=true)
    modified_by: Optional[int] = None
    """
    UserId that is updating profile
    """


    # @ApiMember(Description="Expiry Month: 1 = January, 12 = December")
    cc_exp_month: Optional[int] = None
    """
    Expiry Month: 1 = January, 12 = December
    """


    # @ApiMember(Description="Expiry Year: Two digit year")
    cc_exp_year: Optional[int] = None
    """
    Expiry Year: Two digit year
    """


    # @ApiMember(Description="The name can be provided with FullName OR as separate fields (PrefixName, FirstName, MiddleName, LastName, SuffixName).<br />Providing both will cause an error.")
    full_name: Optional[str] = None
    """
    The name can be provided with FullName OR as separate fields (PrefixName, FirstName, MiddleName, LastName, SuffixName).<br />Providing both will cause an error.
    """


    # @ApiMember()
    prefix_name: Optional[str] = None

    # @ApiMember()
    first_name: Optional[str] = None

    # @ApiMember()
    middle_name: Optional[str] = None

    # @ApiMember()
    last_name: Optional[str] = None

    # @ApiMember()
    suffix_name: Optional[str] = None

    # @ApiMember()
    address1: Optional[str] = None

    # @ApiMember()
    address2: Optional[str] = None

    # @ApiMember()
    urbanization: Optional[str] = None

    # @ApiMember()
    city: Optional[str] = None

    # @ApiMember()
    state: Optional[str] = None

    # @ApiMember()
    postal_code: Optional[str] = None

    # @ApiMember(Description="Disable (or Enabled) the Payment Profile")
    is_disabled: Optional[bool] = None
    """
    Disable (or Enabled) the Payment Profile
    """


    # @ApiMember(Description="Exclude (or Include) from Account Updater")
    exclude_from_acct_updater: Optional[bool] = None
    """
    Exclude (or Include) from Account Updater
    """

Python PaymentProfileUpdateEndpoint DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv

HTTP + JSV

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

PUT /sales/wallet/paymentprofileupdate HTTP/1.1 
Host: www.clubready.com 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	ApiKey: String,
	AcctToken: String,
	ModifiedBy: 0,
	CcExpMonth: 0,
	CcExpYear: 0,
	FullName: String,
	PrefixName: String,
	FirstName: String,
	MiddleName: String,
	LastName: String,
	SuffixName: String,
	Address1: String,
	Address2: String,
	Urbanization: String,
	City: String,
	State: String,
	PostalCode: String,
	IsDisabled: False,
	ExcludeFromAcctUpdater: False,
	StoreId: 0,
	ChainId: 0
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	Success: False,
	Message: String
}