Skip to content

Commit 0929824

Browse files
authored
Merge pull request #10 from eclipxe13/master
Version 1.0.0: remove backwards compatibility with 0.4.2
2 parents f8e0f83 + ca76616 commit 0929824

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

50 files changed

+518
-783
lines changed

.gitattributes

+2
Original file line numberDiff line numberDiff line change
@@ -12,7 +12,9 @@
1212
/.gitattributes export-ignore
1313
/.gitignore export-ignore
1414
/.php_cs.dist export-ignore
15+
/.phplint.yml export-ignore
1516
/.scrutinizer.yml export-ignore
1617
/.travis.yml export-ignore
1718
/phpcs.xml.dist export-ignore
19+
/phpstan.neon.dist export-ignore
1820
/phpunit.xml.dist export-ignore

.gitignore

-1
Original file line numberDiff line numberDiff line change
@@ -2,4 +2,3 @@
22
/vendor
33
/build
44
/composer.lock
5-
.phpunit.result.cache

.travis.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -19,7 +19,7 @@ cache:
1919
- $HOME/.composer
2020

2121
before_script:
22-
- phpenv config-rm xdebug.ini
22+
- phpenv config-rm xdebug.ini || true
2323
- travis_retry composer install --no-interaction --prefer-dist
2424
- mkdir -p build
2525

README.md

+7-11
Original file line numberDiff line numberDiff line change
@@ -43,7 +43,7 @@ composer require phpcfdi/xml-cancelacion
4343

4444
use PhpCfdi\XmlCancelacion\XmlCancelacionHelper;
4545
use PhpCfdi\XmlCancelacion\Definitions\RfcRole;
46-
use PhpCfdi\XmlCancelacion\Definitions\CancellationAnswer;
46+
use PhpCfdi\XmlCancelacion\Definitions\CancelAnswer;
4747

4848
$xmlCancelacion = new XmlCancelacionHelper();
4949

@@ -59,7 +59,7 @@ $consultaRelacionados = $xmlCancelacion->signObtainRelated(
5959

6060
$consultaRelacionados = $xmlCancelacion->signCancellationAnswer(
6161
'11111111-2222-3333-4444-000000000002', // uuid a responder
62-
CancellationAnswer::accept(), // aceptar la cancelación
62+
CancelAnswer::accept(), // aceptar la cancelación
6363
'CVD110412TF6' // RFC del PAC (Quadrum & Finkok)
6464
);
6565

@@ -69,15 +69,15 @@ $consultaRelacionados = $xmlCancelacion->signCancellationAnswer(
6969

7070
```php
7171
<?php
72-
use PhpCfdi\XmlCancelacion\Cancellation\CancellationCapsule;
73-
use PhpCfdi\XmlCancelacion\DOMSigner;
72+
use PhpCfdi\XmlCancelacion\Capsules\Cancellation;
73+
use PhpCfdi\XmlCancelacion\Signers\DOMSigner;
7474
use PhpCfdi\XmlCancelacion\Credentials;
7575

7676
// certificado, llave privada y clave de llave
7777
$credentials = new Credentials('certificado.cer.pem', 'privatekey.key.pem', '12345678a');
7878

7979
// datos de cancelación
80-
$data = new CancellationCapsule('LAN7008173R5', ['12345678-1234-1234-1234-123456789012']);
80+
$data = new Cancellation('LAN7008173R5', ['12345678-1234-1234-1234-123456789012']);
8181

8282
// generación del xml
8383
$xml = (new DOMSigner())->signCapsule($data, $credentials);
@@ -180,12 +180,8 @@ Al parecer es obligatorio incluir en la firma los nombres de espacio `xmlns:xsd`
180180
Si bien, esto no es necesario para producir un documento con la firma correcta, sí parece ser necesario para
181181
producir la información que se requiere por parte del PAC o del SAT.
182182

183-
Se podría utilizar [`robrichards/xmlseclibs`] para hacer el firmado, sin embargo al 2019-04-09 aun no se
184-
habían implementado los mecanismos para incluir el `RSAKeyValue`, a pesar de tener un
185-
[PR abierto](https://github.com/robrichards/xmlseclibs/pull/75) desde 2015-09-03.
186-
Las otras dos desventajas están en la forma en que escribe los valores de `X509IssuerSerial`.
187-
Que aunque creo que no son muy relevantes para generar una firma correcta, sí podrían ser importantes,
188-
y motivo de rechazo -o pretexto- en el servicio de cancelación del SAT.
183+
A partir de 2019-08-27 con la versión `1.0.0` se puede usar [`robrichards/xmlseclibs`](https://github.com/robrichards/xmlseclibs).
184+
Para más información ver el archivo [XmlSecLibs](https://github.com/phpcfdi/xml-cancelacion/blob/master/XmlSecLibs.md).
189185

190186
A partir de 2019-08-13 con la versión `0.4.0` se eliminó la dependencia a `eclipxe/cfdiutils` y se cambió a la
191187
librería [`phpcfdi/credentials`](https://github.com/phpcfdi/xml-cancelacion), con esta nueva dependencia se trabaja

docs/CHANGELOG.md

+1-2
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
# CHANGELOG
22

3-
# Version 0.5.0 2019-09-25
3+
# Version 1.0.0 2019-09-28
44

55
- This version is a major change, it is not compatible with previous versions
66
Read [UPGRADE-0.5](https://github.com/phpcfdi/xml-cancelacion/blob/master/docs/UPGRADE-0.5.md)
@@ -23,7 +23,6 @@
2323
- `XmlCancelacionLogicException` extends `LogicException`
2424
- `DocumentWithoutRootElement`
2525
- `HelperDoesNotHaveCredentials`
26-
- `InvalidCapsuleType`
2726
- `XmlCancelacionRuntimeException` extends `RuntimeException`
2827
- `CannotLoadCertificateAndPrivateKey`
2928
- `CapsuleRfcDoesnotBelongToCertificateRfc`

docs/TODO.md

+1-5
Original file line numberDiff line numberDiff line change
@@ -1,9 +1,5 @@
11
# phpcfdi/xml-cancelacion To Do List
22

3-
- Remover @deprecated
4-
- Centralizar la creación de credenciales
5-
6-
- [ ] Generar excepciones internas en lugar de excepciones genéricas de SPL.
7-
3+
- [X] Generar excepciones internas en lugar de excepciones genéricas de SPL.
84
- [X] Poner el copyright correcto en cuanto esté el sitio de PhpCfdi
95
- [X] Dejar de usar CfdiUtils y usar phpcfdi/credentials cuando esté publicada y estable

docs/UPGRADE-0.5.md

+39-26
Original file line numberDiff line numberDiff line change
@@ -15,16 +15,29 @@ Si estás usando `Capsule` directamente:
1515
<?php
1616
$credentials = new Credentials('certificado.cer.pem', 'privatekey.key.pem', '12345678a');
1717
18-
// cambia este código
18+
// código de 0.4.0
1919
$data = new Capsule('LAN7008173R5', ['12345678-1234-1234-1234-123456789012']);
2020
$xml = (new CapsuleSigner())->sign($data, $credentials);
21+
```
22+
23+
Cualquiera de estas dos formas pueden ser un remplazo:
24+
25+
```php
26+
<?php
27+
28+
use PhpCfdi\XmlCancelacion\Credentials;
29+
use PhpCfdi\XmlCancelacion\XmlCancelacionHelper;
30+
use PhpCfdi\XmlCancelacion\Capsules\Cancellation;
31+
use PhpCfdi\XmlCancelacion\Signers\DOMSigner;
32+
33+
$credentials = new Credentials('certificado.cer.pem', 'privatekey.key.pem', '12345678a');
2134

22-
// a este código
35+
// código de 1.0.0 con helper
2336
$xmlCancelacion = new XmlCancelacionHelper($credentials);
24-
$xml = $xmlCancelacion->signCancellation(['12345678-1234-1234-1234-123456789012']);
37+
$xml = $xmlCancelacion->signCancellation('12345678-1234-1234-1234-123456789012');
2538

26-
// o a este otro
27-
$data = new CancellationCapsule('LAN7008173R5', ['12345678-1234-1234-1234-123456789012']);
39+
// código de 1.0.0 granulado
40+
$data = new Cancellation('LAN7008173R5', ['12345678-1234-1234-1234-123456789012'], new DateTimeImmutable());
2841
$signer = new DOMSigner(); // o new XmlSecLibsSigner()
2942
$xml = $signer->signCapsule($data, $credentials);
3043
```
@@ -37,18 +50,18 @@ solicitud de cancelación, solicitud de UUID relacionados y aceptación/rechazo
3750
La solicitud de cancelación es lo único que se cubría hasta la versión `0.4.x` y en la versión `0.5.x` se han
3851
creado las firmas de las otras dos comunicaciones.
3952

40-
Este cambio evidenció que se necesitaba restructurar la librería para poder firmar los mensajes de
41-
solicitud de UUID relacionados y aceptación/rechazo de cancelaciones pendientes porque antes solo se procesaba el
42-
mensaje de solicitud de cancelación.
53+
Este cambio evidenció que se necesitaba restructurar la librería para poder firmar los otros mensajes de
54+
solicitud de UUID relacionados y aceptación/rechazo de cancelaciones.
4355

44-
## Nuevos conceptos desde la versión 0.5.0
56+
## Nuevos conceptos desde la versión 1.0.0
4557

4658
A los mensajes se les llaman *cápsulas (capsule)* y tienen tres características: Almacenan los datos del mensaje,
4759
pueden producir un documento XML `DOMDocument` con la información que será firmada y pueden verificar que el RFC
48-
de la cápsula coincide con un RFC (usado para verificar que se está usando la el CSD correcto)
60+
de la cápsula coincide con un RFC dado (usado para verificar que se está usando el RFC del CSD).
4961

50-
Para que una cápsula fabrique el documento XML utiliza un *DocumentBuilder*.
62+
Para que una cápsula fabrique el documento XML utiliza un `BaseDocumentBuilder`.
5163
A cada cápsula le corresponde un objeto relacionado para fabricar este documento.
64+
Y aunque no es necesario hacerlo así provee una mejor manera de testeo.
5265

5366
Los documentos XML pueden ser firmados utilizando cualquier objeto que implemente `SignerInterface`.
5467
Anteriormente solo se producían utilizando `DOMSigner`, ahora `DOMSigner` es el usado por defecto pero se puede cambiar.
@@ -69,18 +82,19 @@ y se puede crear la credencial de esta librería con los datos de una credencial
6982
<?php
7083

7184
use PhpCfdi\Credentials\Certificate;
72-
use PhpCfdi\Credentials\Credential;
85+
use PhpCfdi\Credentials\Credential as PhpCfdiCredential;
7386
use PhpCfdi\Credentials\PrivateKey;
87+
use PhpCfdi\XmlCancelacion\Credentials;
7488

7589
$certificateContents = ''; // contenido del certificado desde algún lugar, como la base de datos
7690
$privateKeyPemContents = ''; // contenido de la llave privada como PEM desde algún lugar, como la base de datos
7791
$passPhrase = '';
78-
$phpCfdiCretential = new Credential(
92+
$phpCfdiCretential = new PhpCfdiCredential(
7993
new Certificate($certificateContents),
8094
new PrivateKey($privateKeyPemContents, $passPhrase)
8195
);
8296

83-
$credentials = PhpCfdi\XmlCancelacion\Credentials::createWithPhpCfdiCredential($phpCfdiCretential);
97+
$credentials = Credentials::createWithPhpCfdiCredential($phpCfdiCretential);
8498
```
8599

86100
## Excepciones de dominio
@@ -89,7 +103,6 @@ $credentials = PhpCfdi\XmlCancelacion\Credentials::createWithPhpCfdiCredential($
89103
- `class XmlCancelacionLogicException` extends `\LogicException`
90104
- `class DocumentWithoutRootElement`
91105
- `class HelperDoesNotHaveCredentials`
92-
- `class InvalidCapsuleType`
93106
- `class XmlCancelacionRuntimeException` extends `\RuntimeException`
94107
- `class CannotLoadCertificateAndPrivateKey`
95108
- `class CapsuleRfcDoesnotBelongToCertificateRfc`
@@ -113,17 +126,17 @@ roave-backward-compatibility-check roave-backwards-compatibility-check:assert-ba
113126
114127
[BC] REMOVED: Method PhpCfdi\XmlCancelacion\XmlCancelacionHelper#createCapsule() was removed
115128
[BC] REMOVED: Method PhpCfdi\XmlCancelacion\XmlCancelacionHelper#createCapsuleSigner() was removed
116-
[BC] REMOVED: Method PhpCfdi\XmlCancelacion\DOMSigner#createKeyValueElement() was removed
117-
[BC] CHANGED: The parameter $document of PhpCfdi\XmlCancelacion\DOMSigner#__construct() changed from DOMDocument to ?DOMDocument
118-
[BC] CHANGED: The number of required arguments for PhpCfdi\XmlCancelacion\DOMSigner#createKeyInfoElement() increased from 4 to 5
119-
[BC] CHANGED: The parameter $issuerName of PhpCfdi\XmlCancelacion\DOMSigner#createKeyInfoElement() changed from string to a non-contravariant DOMDocument
120-
[BC] CHANGED: The parameter $pubKeyData of PhpCfdi\XmlCancelacion\DOMSigner#createKeyInfoElement() changed from array to a non-contravariant string
121-
[BC] CHANGED: The parameter $issuerName of PhpCfdi\XmlCancelacion\DOMSigner#createKeyInfoElement() changed from string to DOMDocument
122-
[BC] CHANGED: The parameter $pubKeyData of PhpCfdi\XmlCancelacion\DOMSigner#createKeyInfoElement() changed from array to string
123-
[BC] CHANGED: Method createKeyValueElement() of class PhpCfdi\XmlCancelacion\DOMSigner visibility reduced from protected to private
124-
[BC] CHANGED: The number of required arguments for PhpCfdi\XmlCancelacion\DOMSigner#createKeyValueElement() increased from 1 to 2
125-
[BC] CHANGED: The parameter $pubKeyData of PhpCfdi\XmlCancelacion\DOMSigner#createKeyValueElement() changed from array to a non-contravariant DOMDocument
126-
[BC] CHANGED: The parameter $pubKeyData of PhpCfdi\XmlCancelacion\DOMSigner#createKeyValueElement() changed from array to DOMDocument
129+
[BC] REMOVED: Method PhpCfdi\XmlCancelacion\Signers\DOMSigner#createKeyValueElement() was removed
130+
[BC] CHANGED: The parameter $document of PhpCfdi\XmlCancelacion\Signers\DOMSigner#__construct() changed from DOMDocument to ?DOMDocument
131+
[BC] CHANGED: The number of required arguments for PhpCfdi\XmlCancelacion\Signers\DOMSigner#createKeyInfoElement() increased from 4 to 5
132+
[BC] CHANGED: The parameter $issuerName of PhpCfdi\XmlCancelacion\Signers\DOMSigner#createKeyInfoElement() changed from string to a non-contravariant DOMDocument
133+
[BC] CHANGED: The parameter $pubKeyData of PhpCfdi\XmlCancelacion\Signers\DOMSigner#createKeyInfoElement() changed from array to a non-contravariant string
134+
[BC] CHANGED: The parameter $issuerName of PhpCfdi\XmlCancelacion\Signers\DOMSigner#createKeyInfoElement() changed from string to DOMDocument
135+
[BC] CHANGED: The parameter $pubKeyData of PhpCfdi\XmlCancelacion\Signers\DOMSigner#createKeyInfoElement() changed from array to string
136+
[BC] CHANGED: Method createKeyValueElement() of class PhpCfdi\XmlCancelacion\Signers\DOMSigner visibility reduced from protected to private
137+
[BC] CHANGED: The number of required arguments for PhpCfdi\XmlCancelacion\Signers\DOMSigner#createKeyValueElement() increased from 1 to 2
138+
[BC] CHANGED: The parameter $pubKeyData of PhpCfdi\XmlCancelacion\Signers\DOMSigner#createKeyValueElement() changed from array to a non-contravariant DOMDocument
139+
[BC] CHANGED: The parameter $pubKeyData of PhpCfdi\XmlCancelacion\Signers\DOMSigner#createKeyValueElement() changed from array to DOMDocument
127140
[BC] CHANGED: Method defaultExtraNamespaces() of class PhpCfdi\XmlCancelacion\CapsuleSigner changed scope from instance to static
128141
```
129142

docs/XmlSecLibs.md

+39
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,39 @@
1+
# Uso de XmlSecLibs `robrichards/xmlseclibs`
2+
3+
A partir de la versión `1.0.0` se incluye un objeto `XmlSecLibsSigner` que implementa `SignerInterface`.
4+
5+
Se puede utilizar [`robrichards/xmlseclibs`](https://github.com/robrichards/xmlseclibs) para hacer el firmado,
6+
sin embargo al 2019-04-09 aun no se han implementado los mecanismos para incluir el elemento `KeyValue`,
7+
a pesar de tener un [PR #75](https://github.com/robrichards/xmlseclibs/pull/75) desde 2015-09-03.
8+
9+
Las otras dos desventajas están en la forma en que escribe los valores de `X509IssuerSerial`,
10+
tanto `X509IssuerName` como `X509SerialNumber`.
11+
12+
Por lo anterior, para escribir el contenido de `KeyValue` usando `XmlSecLibsSigner` se usa la misma
13+
implementación manual y no la incompleta/incorrecta de XmlSecLibs.
14+
15+
## Ejemplo de uso:
16+
17+
```php
18+
<?php declare(strict_types=1);
19+
20+
use PhpCfdi\XmlCancelacion\Signers\XmlSecLibsSigner;
21+
use PhpCfdi\XmlCancelacion\XmlCancelacionHelper;
22+
23+
$xmlhelper = new XmlCancelacionHelper();
24+
$xmlhelper->setSigner(new XmlSecLibsSigner()); // change signer to XmlSecLibsSigner
25+
$cancellation = $xmlhelper->signCancellation('11111111-2222-3333-4444-000000000001');
26+
```
27+
28+
29+
## Instalación
30+
31+
Recuerda que `robrichards/xmlseclibs` no es una dependencia (es una recomendación) de `phpcfdi/xml-cancelacion`
32+
33+
```shell script
34+
# instalar esta librería
35+
composer require phpcfdi/xml-cancelacion
36+
37+
# instalar xmlseclibs
38+
composer require robrichards/xmlseclibs
39+
```

docs/xmlseclibs.md

-65
This file was deleted.

phpunit.xml.dist

+1-2
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,4 @@
1-
<phpunit xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
2-
xsi:noNamespaceSchemaLocation="https://schema.phpunit.de/8.0/phpunit.xsd"
1+
<phpunit xsi:noNamespaceSchemaLocation="https://schema.phpunit.de/8.0/phpunit.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
32
bootstrap="./tests/bootstrap.php" colors="true" verbose="true" cacheResultFile="./build/phpunit.result.cache">
43
<testsuites>
54
<testsuite name="Default">

src/Cancellation/CancellationCapsule.php

-61
This file was deleted.

0 commit comments

Comments
 (0)