apihub-cdc / reportar-en-linea-client-php
Requires
- php: >=5.5
- ext-curl: *
- ext-json: *
- ext-mbstring: *
- guzzlehttp/guzzle: ^6.2
- monolog/monolog: ^1.24
- vlucas/phpdotenv: ^3.5
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-11-10 03:51:37 UTC
README
Carga de cuentas de personas físicas.
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 \APIHub\Client\Interceptor\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. Capturar los datos de la petición
Los siguientes datos a modificar se encuentran en test/Api/CargaDeCuentasDePersonasFsicasApiTest.php
Es importante contar con el setUp() que se encargará de inicializar la url, firmar y verificar la petición. Modificar la URL de la petición del objeto $config, como se muestra en el siguiente fragmento de código:
<?php public function setUp() { $password = getenv('KEY_PASSWORD'); $this->signer = new \APIHub\Client\Interceptor\KeyHandler(null, null, $password); $events = new \APIHub\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]); $config = new \ReportarEnLinea\Client\Configuration(); $config->setHost('the_url'); $this->apiInstance = new \ReportarEnLinea\Client\Api\CargaDeCuentasDePersonasFsicasApi($client,$config); }
<?php /** * Este es el método que se será ejecutado en la prueba ubicado en path/to/repository/test/Api/CargaDeCuentasDePersonasFsicasApiTest.php */ public function testRegistrar() { $x_api_key = "your_api_key"; $username = "your_username"; $password = "your_password"; $requestNombre = new \APIHub\Client\Model\Nombre(); $requestNombre->setApellidoPaterno("PATERNO"); $requestNombre->setApellidoMaterno("MATERNO"); $requestNombre->setApellidoAdicional(null); $requestNombre->setNombres("NOMBRE"); $requestNombre->setFechaNacimiento("YYYYMMDD"); $requestNombre->setRfc("PAPN860627"); $requestNombre->setCurp("PAPN860627MOCNSB02"); $requestNombre->setNumeroSeguridadSocial(null); $requestNombre->setNacionalidad("MX"); $requestNombre->setResidencia("1"); $requestNombre->setNumeroLicenciaConducir(null); $requestNombre->setEstadoCivil("S"); $requestNombre->setSexo("F"); $requestNombre->setClaveElectorIfe(null); $requestNombre->setNumeroDependientes("0"); $requestNombre->setFechaDefuncion("YYYYMMDD"); $requestNombre->setTipoPersona("PF"); $requestNombre->setIndicadorDefuncion("1"); $requestDomicilio = new \APIHub\Client\Model\Domicilio(); $requestDomicilio->setDireccion("CONOCIDA S/N"); $requestDomicilio->setColoniaPoblacion("CONOCIDA"); $requestDomicilio->setDelegacionMunicipio("MUNICIPIO"); $requestDomicilio->setCiudad("CIUDAD"); $requestDomicilio->setEstado("MEX"); $requestDomicilio->setEstadoExtranjero(null); $requestDomicilio->setCp("55010"); $requestDomicilio->setFechaResidencia("YYYYMMDD"); $requestDomicilio->setNumeroCelular(null); $requestDomicilio->setNumeroTelefono(null); $requestDomicilio->setExtension(null); $requestDomicilio->setFax(null); $requestDomicilio->setTipoDomicilio("C"); $requestDomicilio->setTipoAsentamiento("2"); $requestDomicilio->setOrigenDomicilio("2"); $requestEmpleo = new \APIHub\Client\Model\Empleo(); $requestEmpleo->setNombreEmpresa("VTA DE PRODUCTOS"); $requestEmpleo->setDireccion("CONOCIDA S/N"); $requestEmpleo->setColoniaPoblacion("CONOCIDA"); $requestEmpleo->setDelegacionMunicipio("MUNICIPIO"); $requestEmpleo->setCiudad("CIUDAD"); $requestEmpleo->setEstado("MX"); $requestEmpleo->setCp("55010"); $requestEmpleo->setNumeroTelefono(null); $requestEmpleo->setExtension(null); $requestEmpleo->setFax(null); $requestEmpleo->setPuesto(null); $requestEmpleo->setFechaContratacion("YYYYMMDD"); $requestEmpleo->setClaveMoneda("MX"); $requestEmpleo->setSalarioMensual("5600"); $requestEmpleo->setFechaUltimoDiaEmpleo("YYYYMMDD"); $requestEmpleo->setFechaVerificacionEmpleo("YYYYMMDD"); $requestEmpleo->setOrigenRazonSocialDomicilio("2"); $requestCuenta = new \APIHub\Client\Model\Cuenta(); $requestCuenta->setClaveActualOtorgante("0000080008"); $requestCuenta->setNombreOtorgante("OTORGANTE"); $requestCuenta->setCuentaActual("TCDC000001"); $requestCuenta->setTipoResponsabilidad("O"); $requestCuenta->setTipoCuenta("F"); $requestCuenta->setTipoContrato("BC"); $requestCuenta->setClaveUnidadMonetaria("MX"); $requestCuenta->setValorActivoValuacion(null); $requestCuenta->setNumeroPagos("17"); $requestCuenta->setFrecuenciaPagos("S"); $requestCuenta->setMontoPagar("0"); $requestCuenta->setFechaAperturaCuenta("YYYYMMDD"); $requestCuenta->setFechaUltimoPago("YYYYMMDD"); $requestCuenta->setFechaUltimaCompra("YYYYMMDD"); $requestCuenta->setFechaCierreCuenta("YYYYMMDD"); $requestCuenta->setFechaCorte("YYYYMMDD"); $requestCuenta->setGarantia(null); $requestCuenta->setCreditoMaximo("10000"); $requestCuenta->setSaldoActual("0"); $requestCuenta->setLimiteCredito("0"); $requestCuenta->setSaldoVencido("0"); $requestCuenta->setNumeroPagosVencidos("2"); $requestCuenta->setPagoActual(" V"); $requestCuenta->setHistoricoPagos(null); $requestCuenta->setClavePrevencion("1"); $requestCuenta->setTotalPagosreportados("0"); $requestCuenta->setClaveAnteriorOtorgante(null); $requestCuenta->setNombreAnteriorOtorgante(null); $requestCuenta->setNumeroCuentaAnterior(null); $requestCuenta->setFechaPrimerIncumplimiento("YYYYMMDD"); $requestCuenta->setSaldoInsoluto(null); $requestCuenta->setMontoUltimoPago(null); $requestCuenta->setFechaIngresoCarteraVencida("YYYYMMDD"); $requestCuenta->setMontoCorrespondienteIntereses("2"); $requestCuenta->setFormaPagoActualIntereses("2"); $requestCuenta->setDiasVencimiento("3"); $requestCuenta->setPlazoMeses(null); $requestCuenta->setMontoCreditoOriginacion(null); $requestCuenta->setCorreoElectronicoConsumidor(null); $requestCuenta->setEstatusCan("01"); $requestCuenta->setOrdenPrelacionOrigen("01"); $requestCuenta->setOrdenPrelacionActual("01"); $requestCuenta->setFechaAperturaCan("YYYYMMDD"); $requestCuenta->setFechaCancelacionCan("null"); $requestPersona = new \APIHub\Client\Model\Persona(); $requestPersona->setNombre($requestNombre); $requestPersona->setDomicilio($requestDomicilio); $requestPersona->setEmpleo($requestEmpleo); $requestPersona->setCuenta($requestCuenta); $requestEncabezado = new \APIHub\Client\Model\Encabezado(); $requestEncabezado->setNombreOtorgante("OTORGANTE"); $requestEncabezado->setClaveOtorgante("100000"); $request = new \APIHub\Client\Model\CargasPFRegistrarRequest(); $request->setEncabezado($requestEncabezado); $request->setPersona($requestPersona); try { $result = $this->apiInstance->registrar($x_api_key, $username, $password, $request); print_r($result); } catch (Exception $e) { echo 'Exception when calling CargaDeCuentasDePersonasFsicasApi->registrar: ', $e->getMessage(), PHP_EOL; } } ?>
Pruebas unitarias
Para ejecutar las pruebas unitarias:
./vendor/bin/phpunit