rocketfellows/iso-standard-3166-factory

v1.0.0 2023-01-14 13:05 UTC

This package is not auto-updated.

Last update: 2024-05-05 17:47:37 UTC


README

Code Coverage Badge

This component provides factory for create country according to ISO-3166 standard by:

  • code (alpha2, alpha3, numeric code)
  • full english name

Factory creates instance of arslanimamutdinov\ISOStandard3166\Country.

Installation

composer require rocketfellows/iso-standard-3166-factory

Create Country by code

Note: create by code case-insensitive.

Example create Country by alpha2, alpha3, numeric code:

$factory = new CountryFactory();

$factory->createByCode('AT');   // creates by alpha2 code
$factory->createByCode('at');   // creates by alpha2 code in lower case
$factory->createByCode('AUT');  // creates by alpha3
$factory->createByCode('aut');  // creates by alpha3 in lower case
$factory->createByCode('040');  // creates by numeric code

Examples above will return:

object(arslanimamutdinov\ISOStandard3166\Country)#3 (4) {
["name":"arslanimamutdinov\ISOStandard3166\Country":private]=>
string(7) "Austria"
["alpha2":"arslanimamutdinov\ISOStandard3166\Country":private]=>
string(2) "AT"
["alpha3":"arslanimamutdinov\ISOStandard3166\Country":private]=>
string(3) "AUT"
["numericCode":"arslanimamutdinov\ISOStandard3166\Country":private]=>
string(3) "040"
}

If code is empty or unknown factory will throw:

  • EmptyCountryCodeException
  • UnknownCountryCodeException

Create Country by english name

Note: create by code case-sensitive and need full name.

Example create Country by name:

$factory = new CountryFactory();

$factory->createByName('Austria');

Examples above will return:

object(arslanimamutdinov\ISOStandard3166\Country)#6 (4) {
  ["name":"arslanimamutdinov\ISOStandard3166\Country":private]=>
  string(7) "Austria"
  ["alpha2":"arslanimamutdinov\ISOStandard3166\Country":private]=>
  string(2) "AT"
  ["alpha3":"arslanimamutdinov\ISOStandard3166\Country":private]=>
  string(3) "AUT"
  ["numericCode":"arslanimamutdinov\ISOStandard3166\Country":private]=>
  string(3) "040"
}

If name is empty or unknown factory will throw:

  • UnknownCountryNameException
  • EmptyCountryNameException

Contributing

Welcome to pull requests. If there is a major changes, first please open an issue for discussion.

Please make sure to update tests as appropriate.