apihub-cdc / vantage-client
Requires
- php: >=5.5
- ext-curl: *
- ext-json: *
- ext-mbstring: *
- apihub-cdc/signature-manager: ^1.0
- 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 not auto-updated.
Last update: 2024-11-08 15:21:56 UTC
README
Es un modelo que segmenta a los clientes morosos en 6 calificaciones, de acuerdo al avance esperado de mora en los siguientes 30 días. Reduce costos de gestión y administración de cartera morosa al segmentar a la población.
Requisitos
PHP 7.1 ó superior
Dependencias adicionales
- Se debe contar con las siguientes dependencias de PHP:
- ext-curl
- ext-mbstring
- En caso de no ser así, para linux use los siguientes comandos
#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 vea como instalar
Instalación
Ejecutar: composer install
Guía de inicio
Paso 1. Generar llave y certificado
- Se tiene que tener un contenedor en formato PKCS12.
- En caso de no contar con uno, ejecutar las instrucciones contenidas en lib/Interceptor/key_pair_gen.sh ó con los siguientes comandos.
- opcional: Para cifrar el contenedor, colocar una contraseña en una variable de ambiente.
export KEY_PASSWORD=your_password
- Definir los nombres de archivos y alias.
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
- Generar llave y certificado.
#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}"
- Generar contenedor en formato 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}
Paso 2. Carga del certificado dentro del portal de desarrolladores
- Iniciar sesión.
- Dar clic en la sección "Mis aplicaciones".
- Seleccionar la aplicación.
- Ir a la pestaña de "Certificados para @tuApp".
- Al abrirse la ventana emergente, seleccionar el certificado previamente creado y dar clic en el botón "Cargar":
Paso 3. Descarga del certificado de Círculo de Crédito dentro del portal de desarrolladores
- Iniciar sesión.
- Dar clic en la sección "Mis aplicaciones".
- Seleccionar la aplicación.
- Ir a la pestaña de "Certificados para @tuApp".
- Al abrirse la ventana emergente, dar clic al botón "Descargar":
Es importante que este contenedor sea almacenado en la siguiente ruta: /path/to/repository/lib/Interceptor/keypair.p12
Así mismo el certificado proporcionado por círculo de crédito en la siguiente ruta: /path/to/repository/lib/Interceptor/cdc_cert.pem
- En caso de que no se almacene así, se debe especificar la ruta donde se encuentra el contenedor y el certificado. Ver el siguiente ejemplo:
/** * Esto es parte del setUp() de las pruebas unitarias. */ $password = getenv('KEY_PASSWORD'); $this->signer = new KeyHandler( "/example/route/keypair.p12", "/example/route/cdc_cert.pem", $password );
NOTA: Sólamente en caso de que el contenedor haya cifrado, se debe colocar la contraseña en una variable de ambiente e indicar el nombre de la misma, como se ve en la imagen anterior.
Paso 4. Modificar URL
Modificar la URL de la petición en lib/Configuration.php en la línea 19, como se muestra en el siguiente fragmento de código:
protected $host = 'the_url';
Paso 5. Capturar los datos de la petición
Es importante contar con el setUp() que se encargará de firmar y verificar la petición.
<?php public function setUp() { $password = getenv('KEY_PASSWORD'); $this->keypair = 'path/to/keypair.p12'; $this->cert = 'path/to/certificate.pem'; $this->url = 'this_url'; $this->signer = new KeyHandler($this->keypair, $this->cert, $password); $events = new MiddlewareEvents($this->signer); $handler = handlerStack::create(); $handler->push($events->add_signature_header('x-signature')); $handler->push($events->verify_signature_header('x-signature')); $client = new Client(['handler' => $handler]); $config = new Configuration(); $config->setHost($this->url); $this->apiInstance = new Instance($client, $config); $this->x_api_key = "your_api_key"; $this->username = "your_username"; $this->password = "your_password"; }
NOTA: Los datos de la siguiente petición son solo representativos.
<?php public function testGetVantageAportantes(){ try { $request = new AportantesPeticion(); $tipoContrato = new CatalogoContrato(); $request->setFolio("0000001"); $request->setTipoContrato($tipoContrato::TC); $request->setNumeroCuenta("4772133042201399"); $request->setDiasAtraso(1); $result = $this->apiInstance->getVantageAportantes($this->x_api_key, $this->username, $this->password, $request); if($this->apiInstance->getStatusCode() == 200){ print_r($result); } } catch (ApiException $e) { if($e->getCode() !== 204){ echo 'Exception when calling ApiTest->testGetVantageAportantes: ', $e->getMessage(), PHP_EOL; } } $this->assertTrue($this->apiInstance->getStatusCode() == 200); } public function testGetVantageNoAportantes(){ try { $tipoContrato = new CatalogoContrato(); $catalogoPago = new CatalogoFrecuenciaPago(); $persona = new PersonaPeticion(); $domicilio = new DomicilioPeticion(); $catalogoEstados = new CatalogoEstados(); $request = new NoAportantesPeticion(); $domicilio->setDireccion("INSURGENTES SUR 1007"); $domicilio->setColoniaPoblacion("INSURGENTES"); $domicilio->setDelegacionMunicipio("BENITO JUAREZ"); $domicilio->setCiudad("CIUDAD DE MÉXICO"); $domicilio->setEstado($catalogoEstados::DF); $domicilio->setCp("11230"); $persona->setPrimerNombre("JUAN"); $persona->setApellidoPaterno("PRUEBA"); $persona->setApellidoMaterno("SIETE"); $persona->setFechaNacimiento("1980-01-07"); $persona->setDomicilio($domicilio); $request->setFolio("0000002"); $request->setTipoProducto("O"); $request->setTipoContrato($tipoContrato::TC); $request->setFrecuenciaPago($catalogoPago::M); $request->setDiasAtraso(1); $request->setNumeroCuenta("123456"); $request->setFechaApertura("1990-10-19"); $request->setSaldoActual(15301); $request->setPersona($persona); $result = $this->apiInstance->getVantageNoAportantes($this->x_api_key, $this->username, $this->password, $request); if($this->apiInstance->getStatusCode() == 200){ print_r($result); } } catch (ApiException $e) { if($e->getCode() !== 204){ echo 'Exception when calling ApiTest->testGetVantageNoAportantes: ', $e->getMessage(), PHP_EOL; } } $this->assertTrue($this->apiInstance->getStatusCode() == 200); } ?>
Pruebas unitarias
Para ejecutar las pruebas unitarias:
./vendor/bin/phpunit