woocommerce/includes/payment-tokens/class-wc-payment-token-cc.php

153 lines
3.2 KiB
PHP
Raw Normal View History

2016-02-02 17:08:32 +00:00
<?php
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly
}
/**
* WooCommerce Credit Card Payment Token.
2016-02-02 17:08:32 +00:00
*
* Representation of a payment token for credit cards.
2016-02-02 17:08:32 +00:00
*
* @class WC_Payment_Token_CC
* @since 2.6.0
* @category PaymentTokens
* @package WooCommerce/PaymentTokens
* @author WooThemes
*/
class WC_Payment_Token_CC extends WC_Payment_Token {
2016-02-02 17:08:32 +00:00
/** @protected string Token Type String. */
protected $type = 'CC';
2016-06-06 19:04:45 +00:00
/**
* Validate credit card payment tokens.
2016-02-02 17:08:32 +00:00
*
* These fields are required by all credit card payment tokens:
* expiry_month - string Expiration date (MM) for the card
* expiry_year - string Expiration date (YYYY) for the card
* last4 - string Last 4 digits of the card
* card_type - string Card type (visa, mastercard, etc)
2016-02-02 17:08:32 +00:00
*
* @since 2.6.0
* @return boolean True if the passed data is valid
2016-02-02 17:08:32 +00:00
*/
public function validate() {
if ( false === parent::validate() ) {
return false;
}
if ( ! $this->get_last4() ) {
2016-02-02 17:08:32 +00:00
return false;
}
if ( ! $this->get_expiry_year() ) {
2016-02-02 17:08:32 +00:00
return false;
}
if ( ! $this->get_expiry_month() ) {
2016-02-02 17:08:32 +00:00
return false;
}
if ( ! $this->get_card_type() ) {
2016-02-02 17:08:32 +00:00
return false;
}
if ( 4 !== strlen( $this->get_expiry_year() ) ) {
return false;
}
if ( 2 !== strlen( $this->get_expiry_month() ) ) {
return false;
}
2016-02-02 17:08:32 +00:00
return true;
}
2016-05-26 10:55:11 +00:00
/**
* Get type to display to user.
* @return string
*/
public function get_display_name() {
$display = sprintf(
__( '%1$s ending in %2$s (expires %3$s/%4$s)', 'woocommerce' ),
wc_get_credit_card_type_label( $this->get_card_type() ),
$this->get_last4(),
$this->get_expiry_month(),
substr( $this->get_expiry_year(), 2 )
);
return $display;
2016-05-26 10:55:11 +00:00
}
2016-02-02 17:08:32 +00:00
/**
* Returns the card type (mastercard, visa, ...).
2016-02-02 17:08:32 +00:00
* @since 2.6.0
* @return string Card type
*/
public function get_card_type() {
return $this->get_meta( 'card_type' );
2016-02-02 17:08:32 +00:00
}
/**
* Set the card type (mastercard, visa, ...).
2016-02-02 17:08:32 +00:00
* @since 2.6.0
* @param string $type
*/
public function set_card_type( $type ) {
$this->add_meta_data( 'card_type', $type, true );
2016-02-02 17:08:32 +00:00
}
/**
* Returns the card expiration year (YYYY).
2016-02-02 17:08:32 +00:00
* @since 2.6.0
* @return string Expiration year
*/
public function get_expiry_year() {
return $this->get_meta( 'expiry_year' );
2016-02-02 17:08:32 +00:00
}
/**
* Set the expiration year for the card (YYYY format).
2016-02-02 17:08:32 +00:00
* @since 2.6.0
* @param string $year
*/
public function set_expiry_year( $year ) {
$this->add_meta_data( 'expiry_year', $year, true );
2016-02-02 17:08:32 +00:00
}
/**
* Returns the card expiration month (MM).
2016-02-02 17:08:32 +00:00
* @since 2.6.0
* @return string Expiration month
*/
public function get_expiry_month() {
return $this->get_meta( 'expiry_month' );
2016-02-02 17:08:32 +00:00
}
/**
2016-06-01 11:17:10 +00:00
* Set the expiration month for the card (formats into MM format).
2016-02-02 17:08:32 +00:00
* @since 2.6.0
* @param string $month
*/
public function set_expiry_month( $month ) {
2016-06-01 11:17:10 +00:00
$this->add_meta_data( 'expiry_month', str_pad( $month, 2, '0', STR_PAD_LEFT ), true );
2016-02-02 17:08:32 +00:00
}
/**
* Returns the last four digits.
* @since 2.6.0
* @return string Last 4 digits
*/
public function get_last4() {
return $this->get_meta( 'last4' );
}
/**
* Set the last four digits.
* @since 2.6.0
* @param string $last4
*/
public function set_last4( $last4 ) {
$this->add_meta_data( 'last4', $last4, true );
}
2016-02-02 17:08:32 +00:00
}