apihub-cdc / pld-morales-client-php
此软件包最新版本(v1.0.1)没有提供许可信息。
v1.0.1
2020-04-08 18:53 UTC
Requires
- php: >=5.5
- ext-curl: *
- ext-json: *
- ext-mbstring: *
- guzzlehttp/guzzle: ^6.2
- monolog/monolog: ^1.24
Requires (Dev)
- friendsofphp/php-cs-fixer: ~2.12
- phpunit/phpunit: ^4.8
- squizlabs/php_codesniffer: ~2.6
This package is auto-updated.
Last update: 2024-09-10 03:59:46 UTC
README
这是一个针对预防洗钱和恐怖主义融资(PLD/FT)的道德实体过滤解决方案。
要求
PHP 7.1或更高版本
额外依赖
- 需要以下PHP依赖项:
- ext-curl
- ext-mbstring
- 如果不符合要求,对于Linux,请使用以下命令
#ejemplo con php en versión 7.3 para otra versión colocar php{version}-curl
apt-get install php7.3-curl
apt-get install php7.3-mbstring
- Composer 如何安装
安装
执行:composer install
入门指南
步骤1. 生成密钥和证书
- 需要有一个PKCS12格式的容器。
- 如果没有,请执行
lib/Interceptor/key_pair_gen.sh
中的说明,或者使用以下命令。 - 可选:为了加密容器,在环境变量中设置一个密码。
export KEY_PASSWORD=your_password
- 定义文件名和别名。
export PRIVATE_KEY_FILE=pri_key.pem export CERTIFICATE_FILE=certificate.pem export SUBJECT=/C=MX/ST=MX/L=MX/O=CDC/CN=CDC export PKCS12_FILE=keypair.p12 export ALIAS=circulo_de_credito
- 生成密钥和证书。
#Genera la llave privada. openssl ecparam -name secp384r1 -genkey -out ${PRIVATE_KEY_FILE} #Genera el certificado público. openssl req -new -x509 -days 365 \ -key ${PRIVATE_KEY_FILE} \ -out ${CERTIFICATE_FILE} \ -subj "${SUBJECT}"
- 生成PKCS12格式的容器。
# Genera el archivo pkcs12 a partir de la llave privada y el certificado. # Deberá empaquetar la llave privada y el certificado. openssl pkcs12 -name ${ALIAS} \ -export -out ${PKCS12_FILE} \ -inkey ${PRIVATE_KEY_FILE} \ -in ${CERTIFICATE_FILE} -password pass:${KEY_PASSWORD}
步骤2. 在开发者门户中加载证书
步骤3. 在开发者门户中下载信用圈证书
非常重要,这个容器应该存储在以下路径:/path/to/repository/lib/Interceptor/keypair.p12
同样,信用圈提供的证书应存储在以下路径:/path/to/repository/lib/Interceptor/cdc_cert.pem
- 如果没有按照这种方式存储,则必须指定容器和证书的存储路径。请看以下示例
$password = getenv('KEY_PASSWORD'); $this->signer = new \PldPmClientePhp\Client\Interceptor\KeyHandler( "/example/route/keypair.p12", "/example/route/cdc_cert.pem", $password );
注意:仅在容器已加密的情况下,才需要在环境变量中放置密码并指定其名称,如上图所示。
步骤4. 修改URL
修改test/Api/PLDPersonasMoralesApiTest.php中的请求URL,如下代码片段所示
$config = new \PldPmClientePhp\Client\Configuration(); $config->setHost('the_url');
步骤5. 捕获请求数据
重要的是要有setUp(),它将负责签名和验证请求。
class PLDPersonasMoralesApiTest extends \PHPUnit_Framework_TestCase { public function setUp() { $password = getenv('KEY_PASSWORD'); $this->signer = new \PldPmClientePhp\Client\Interceptor\KeyHandler(null, null, $password); $events = new \PldPmClientePhp\Client\Interceptor\MiddlewareEvents($this->signer); $handler = \GuzzleHttp\HandlerStack::create(); $handler->push($events->add_signature_header('x-signature')); $handler->push($events->verify_signature_header('x-signature')); $client = new \GuzzleHttp\Client(['handler' => $handler, 'verify' => false]); $config = new \PldPmClientePhp\Client\Configuration(); $config->setHost('the_url'); $this->apiInstance = new \PldPmClientePhp\Client\Api\PLDPersonasMoralesApi($client,$config); } public function testGetPLDPm() { $x_api_key = "your_api_key"; $username = "your_username"; $password = "your_password"; $request = new \PldPmClientePhp\Client\Model\Peticion(); $request->setRazonSocial("EMPRESA SA DE CV"); try { $result = $this->apiInstance->getPLDPm($x_api_key, $username, $password, $request); print_r($result); } catch (Exception $e) { echo 'Exception when calling ApiTest->getPLDPm: ', $e->getMessage(), PHP_EOL; } } }
单元测试
要运行单元测试
./vendor/bin/phpunit