gam/estafeta-command

PHP library to run 'estafeta interactive command' web portal operations programmatically.

v1.2.0 2022-08-24 00:06 UTC

This package is auto-updated.

Last update: 2024-10-24 04:36:25 UTC


README

Total Downloads GitHub Workflow Status GitHub GitHub release (latest by date) Packagist PHP Version Support

PHP library to run 'estafeta interactive command' web portal operations programmatically.

Sponsors

EP    

Features

  • Get Estafeta Account information programmatically:
    • Available services
    • Available content types
  • Find Locations by Postal code.
  • Find Suburbs (Colonia) by name.
  • Create Labels (Guias).

Installation

composer require gam/estafeta-command

Usage

This is a simple example:

// 1. set your credentials
$credentials = new Credentials('user', 'password');
$command = new Command($credentials);

// 2. fetch your account data
$account = $command->fetchAccount();
$terrestre = $account->getServiceByName(Service::NEXT_DAY);
$caja = $account->getContentTypeByName(ContentType::BOX);

// 3. Find a Suburb by Postal Code & Name
$originSection= $command->fetchSections('97306')
    ->findBySuburb('LOS HEROES', true)
    ->first();

// 4. Create an Origin Address
$originAddress = new Address('Salome', '587');
// 5. Create an Origin Contact
$originContact = new Contact(
    'Foo',
    'Bar',
    new Rfc('Foo Company'),
    'foo@bar.com',
    new ContactPhone('0000000000', '0000000000')
);
// 6. Create the Origin
$origin = new Location(
    '', // not necessary
    $originSection,
    $originAddress,
    LocationCategory::OTHERS(),
    LocationType::ORIGIN(),
    $originContact
);

// 7. Find Destination Section by postal code
$destinationSection = $command->fetchSections('81000')
    ->findBySuburb('CENTRO', true)
    ->first();

// 8. Create Destination Address
$destinationAddress = new Address('Vicente Guerrero', '790', '2');
// 9. Create Destination Contact
$destinationContact = new Contact(
    'Foo',
    'Bar',
    new Rfc('Bar SA')
);
// 10. Create the Destination
$destination = new Location(
    '', // not necessary
    $destinationSection,
    $destinationAddress,
    LocationCategory::OTHERS(),
    LocationType::DESTINATION(),
    $destinationContact
);
// 11. Set Print Config
$pringConfig = new PrintConfig(PrintType::LOCAL(), PaperType::BOND());

// 12. Build the Label.
$labelParameters = (new \Gam\Estafeta\Command\LabelParametersBuilder())
    ->withAccount($account)
    ->withService($terrestre)
    ->withContentType($caja)
    ->withPackage(new Package(
        14.0,
        new \Gam\Estafeta\Command\Model\Dimension(57, 57, 21),
        'Vasos termicos'
    ))
    ->withPackagingType(PackagingType::PACKAGE())
    ->withOrigin($origin)
    ->withDestination($destination)
    ->withPrintConfig($pringConfig)
    ->build();

$label = $command->createLabel($labelParameters);

// store the label file
file_put_contents("{$label->getId()}.pdf", $label->getPdf());

// finally, close the session
$command->logout();

Model Validation & Cleaner

The package has built-in validation according to official web portal rules. The following models are validated in the constructor because their attributes cannot be modified after object construction.

  • Address
  • Contact
  • ContactPhone
  • Dimension
  • LabelReference
  • Package
  • Reference
  • Rfc

The following models have buil-in cleaner (data sanitization) to remove not allowed characters:

Address

  • firstStreet: Diferent characters of [a-z ÁÉÍÓÚáéíóú\d.,;:#*^\/] are removed.
  • streetAddress: Diferent characters of [^a-zÁÉÍÓÚáéíóú \d_] are removed.
  • apartmentNumber: Diferent characters of [a-z ÁÉÍÓÚáéíóú\d.,;:#*^\/] are removed.
  • secondStreet: Diferent characters of [^a-zÁÉÍÓÚáéíóú \d_] are removed.

Contact

  • shortName: Diferent characters of [a-z ÁÉÍÓÚáéíóú\d.,;:#*^\/] are removed.
  • contactName: Diferent characters of [a-z ÁÉÍÓÚáéíóú\d.,;:#*^\/] are removed.

LabelReference

  • contentDescription: Diferent characters of [^a-zÁÉÍÓÚáéíóú \d_] are removed.
  • reference: Diferent characters of [a-z ÁÉÍÓÚáéíóú\d.,;:#*^\/] are removed.
  • description: Diferent characters of [a-zÁÉÍÓÚáéíóú \d_] are removed.

Package

  • additionalInfo: Diferent characters of [a-z ÁÉÍÓÚáéíóú\d.,;:#*^\/] are removed.
  • costCenter: Diferent characters of [a-zÁÉÍÓÚáéíóú \d_] are removed.

Reference

  • betweenStreet: Diferent characters of [a-zÁÉÍÓÚáéíóú \d_] are removed.
  • andStreet: Diferent characters of [a-zÁÉÍÓÚáéíóú \d_] are removed.
  • shed: Diferent characters of [a-zÁÉÍÓÚáéíóú \d_] are removed.
  • platform: Diferent characters of [a-zÁÉÍÓÚáéíóú \d_] are removed.
  • references: Diferent characters of [a-zÁÉÍÓÚáéíóú \d_] are removed.

If you want to disable this sanitization on some models, please set:

Reference::disablePrepareData();

Also you could add your own sanitization methods:

Reference::registerPrepareCallbacks([
    'betweenStreet' => [MyOwnCleaner::class, 'sizeTruncate']
]);

See CleanerTest for more examples.

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

Please make sure to update tests as appropriate.

License

The Apache License. Please see License File for more information.

Credits

Todo

  • Setup a CD workflow: I need a secret file to run the tests
  • Validate models: Validate Model properties according to Estafeta Web App Rules.
  • Improve docs: Maybe ReadTheDocs, using markdown, etc...