<?php
/*
 * Copyright (c) 2017-2018 THL A29 Limited, a Tencent company. All Rights Reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *    http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
namespace TencentCloud\Faceid\V20180301\Models;
use TencentCloud\Common\AbstractModel;

/**
 * BankCard4EVerification请求参数结构体
 *
 * @method string getName() 获取姓名
 * @method void setName(string $Name) 设置姓名
 * @method string getBankCard() 获取银行卡
 * @method void setBankCard(string $BankCard) 设置银行卡
 * @method string getPhone() 获取手机号码
 * @method void setPhone(string $Phone) 设置手机号码
 * @method string getIdCard() 获取开户证件号,与CertType参数的证件类型一致,如:身份证,则传入身份证号。
 * @method void setIdCard(string $IdCard) 设置开户证件号,与CertType参数的证件类型一致,如:身份证,则传入身份证号。
 * @method integer getCertType() 获取证件类型,请确认该证件为开户时使用的证件类型,未用于开户的证件信息不支持验证。
目前默认为0:身份证,其他证件类型暂不支持。
 * @method void setCertType(integer $CertType) 设置证件类型,请确认该证件为开户时使用的证件类型,未用于开户的证件信息不支持验证。
目前默认为0:身份证,其他证件类型暂不支持。
 * @method Encryption getEncryption() 获取敏感数据加密信息。对传入信息(姓名、身份证号、手机号、银行卡号)有加密需求的用户可使用此参数,详情请点击左侧链接。
 * @method void setEncryption(Encryption $Encryption) 设置敏感数据加密信息。对传入信息(姓名、身份证号、手机号、银行卡号)有加密需求的用户可使用此参数,详情请点击左侧链接。
 */
class BankCard4EVerificationRequest extends AbstractModel
{
    /**
     * @var string 姓名
     */
    public $Name;

    /**
     * @var string 银行卡
     */
    public $BankCard;

    /**
     * @var string 手机号码
     */
    public $Phone;

    /**
     * @var string 开户证件号,与CertType参数的证件类型一致,如:身份证,则传入身份证号。
     */
    public $IdCard;

    /**
     * @var integer 证件类型,请确认该证件为开户时使用的证件类型,未用于开户的证件信息不支持验证。
目前默认为0:身份证,其他证件类型暂不支持。
     */
    public $CertType;

    /**
     * @var Encryption 敏感数据加密信息。对传入信息(姓名、身份证号、手机号、银行卡号)有加密需求的用户可使用此参数,详情请点击左侧链接。
     */
    public $Encryption;

    /**
     * @param string $Name 姓名
     * @param string $BankCard 银行卡
     * @param string $Phone 手机号码
     * @param string $IdCard 开户证件号,与CertType参数的证件类型一致,如:身份证,则传入身份证号。
     * @param integer $CertType 证件类型,请确认该证件为开户时使用的证件类型,未用于开户的证件信息不支持验证。
目前默认为0:身份证,其他证件类型暂不支持。
     * @param Encryption $Encryption 敏感数据加密信息。对传入信息(姓名、身份证号、手机号、银行卡号)有加密需求的用户可使用此参数,详情请点击左侧链接。
     */
    function __construct()
    {

    }

    /**
     * For internal only. DO NOT USE IT.
     */
    public function deserialize($param)
    {
        if ($param === null) {
            return;
        }
        if (array_key_exists("Name",$param) and $param["Name"] !== null) {
            $this->Name = $param["Name"];
        }

        if (array_key_exists("BankCard",$param) and $param["BankCard"] !== null) {
            $this->BankCard = $param["BankCard"];
        }

        if (array_key_exists("Phone",$param) and $param["Phone"] !== null) {
            $this->Phone = $param["Phone"];
        }

        if (array_key_exists("IdCard",$param) and $param["IdCard"] !== null) {
            $this->IdCard = $param["IdCard"];
        }

        if (array_key_exists("CertType",$param) and $param["CertType"] !== null) {
            $this->CertType = $param["CertType"];
        }

        if (array_key_exists("Encryption",$param) and $param["Encryption"] !== null) {
            $this->Encryption = new Encryption();
            $this->Encryption->deserialize($param["Encryption"]);
        }
    }
}