Librería de PHP para trabajar con RFC.
🇺🇸 The documentation of this project is in spanish as this is the natural language for the intended audience.
En México, toda persona física o moral para realizar cualquier actividad económica requiere de un registro ante la Secretaría de Hacienda y Crédito Público (SHCP) llamado Registro Federal de Contribuyentes (RFC).
Esta librería permite trabajar con esta clave desde el aplicativo de PHP.
Usa composer
composer require phpcfdi/rfc
use PhpCfdi\Rfc\Rfc;
// suponiendo que llega un formulario con rfc => COSC8001137NA
$rfc = Rfc::parse($_POST['rfc']);
echo $rfc->getRfc(); // COSC8001137NA
echo $rfc; // COSC8001137NA
echo json_encode(['data' => $rfc]); // {"data": "COSC8001137NA"}
var_dump($rfc->isFisica()); // bool(true)
var_dump($rfc->isMoral()); // bool(false)
var_dump($rfc->isGeneric()); // bool(false)
var_dump($rfc->isForeign()); // bool(false)
El objeto Rfc
se puede crear a partir de cuatro formas:
Rfc::parse(string): Rfc
: Se validan los datos de entrada y surge una excepción si son inválidos.Rfc::parseOrNull(string): ?Rfc
: Se validan los datos de entrada y retorna nulo si son inválidos.Rfc::unparsed(string): Rfc
: No se validan los datos de entrada, se creará el objeto con la cadena de caracteres como Rfc.Rfc::fromSerial(int): Rfc
: Se convierte el número de serie del RFC a su representación de cadena de caracteres.
No se puede crear un objeto a partir del constructor new Rfc
. Use Rfc::unparsed
en su lugar.
Se recomienda que, siempre que se crea el objeto y los datos de origen no son de confianza, se utilice Rfc::parse
.
El único dato importante dentro del RFC es la cadena de caracteres misma. Por ello se ha implementado que la conversión a cadena de caracteres y la exportación a JSON devuelvan específicamente este dato.
La representación del número de serie corresponde a un número creado con esta misma librería, este número es un entero de 64 bits que se puede almacenar como un entero largo en una base de datos.
Para obtener el número de serie de un RFC puede usar el método Rfc::calculateSerial()
.
Para crear un Rfc a partir de un entero puede usar Rfc::fromSerial()
.
La clase responsable de los cálculos involucrados en esta conversión está optimizada con arreglos constantes de conversión por lo que su ejecución es lo más veloz que puede ser.
Es frecuente utilizar RFC que son virtuales, por ejemplo, para operaciones sin identificar como una
venta de mostrador u operaciones con extranjeros, en estos casos están las constantes
Rfc::RFC_GENERIC = 'XAXX010101000'
y Rfc::RFC_FOREIGN = 'XEXX010101000'
respectivamente.
Puede usar los métodos Rfc::newGeneric()
y Rfc::newForeign()
para crear instancias con estos datos.
Si se desea saber que el RFC es genérico se puede usar el método Rfc::isGeneric()
y para RFC extranjero Rfc::isForeign()
.
Es común usar generadores (ficticios) de datos, esta librería provee la clase RfcFaker
que se puede utilizar
por sí sola o en conjunto con FakerPHP/Faker
.
Provee métodos para crear una cadena de caracteres que es una clave RFC:
RfcFaker::mexicanRfcFisica()
para persona física (13 posiciones).RfcFaker::mexicanRfcMoral()
para persona moral (12 posiciones).RfcFaker::mexicanRfc()
indistintamente una persona moral o física.
Se puede obtener el dígito verificador calculado con el método Rfc::calculateCheckSum()
,
así como conocer si el dígito verificador coincide con el método Rfc::doesCheckSumMatch()
.
La además provee la clase CheckSum
para realizar el cálculo del dígito verificador de un RFC.
Cabe mencionar que, si bien debería ser siempre coincidente, hay algunos casos donde esto
no se respeta (SAT, ¿todo bien?), por ejemplo, el caso de Restaurantes TOKS ha tenido
los RFC RT0840921REA
(dígito A
) y también RT0840921RE4
.
Puede ver el procedimiento del dígito verificador en alguno de estos enlaces:
- https://www.studocu.com/es-mx/document/universidad-del-valle-de-mexico/administracion/algoritmo-para-generar-el-rfc-con-homoclave-para-personas-fisicas-y-morales/12002840
- https://solucionfactible.com/sfic/capitulos/timbrado/rfc-digito-verificador.jsp
Para entender esta librería en el ámbito de desarrollo (para extender o modificar), lee los siguientes documentos:
- Revisa la guía de contribución.
- Consideraciones generales de la librería.
- Conversión de un RFC a entero y viceversa.
- Generador de RFC ficticios.
Puedes obtener soporte abriendo un ticker en Github.
Adicionalmente, esta librería pertenece a la comunidad PhpCfdi, así que puedes usar los mismos canales de comunicación para obtener ayuda de algún miembro de la comunidad.
Esta librería se mantendrá compatible con al menos la versión con soporte activo de PHP más reciente.
También utilizamos Versionado Semántico 2.0.0 por lo que puedes usar esta librería sin temor a romper tu aplicación.
Las contribuciones con bienvenidas. Por favor lee CONTRIBUTING para más detalles y recuerda revisar el archivo de tareas pendientes TODO y el archivo CHANGELOG.
The phpcfdi/rfc
library is copyright © PhpCfdi
and licensed for use under the MIT License (MIT). Please see LICENSE for more information.