mirror of
https://github.com/ivuorinen/business-data-fetcher.git
synced 2026-01-26 03:04:07 +00:00
feat: parser now writes, added missing fields
updated docs, example, extensive use of Traits with better handling. valid level 9 phpstan codebase.
This commit is contained in:
@@ -5,7 +5,7 @@
|
||||
"license": "MIT",
|
||||
"require": {
|
||||
"php": "^8.2",
|
||||
"guzzlehttp/guzzle": "^7.4.5",
|
||||
"guzzlehttp/guzzle": "^7.4",
|
||||
"spatie/data-transfer-object": "^3.9"
|
||||
},
|
||||
"autoload": {
|
||||
@@ -15,6 +15,13 @@
|
||||
},
|
||||
"require-dev": {
|
||||
"squizlabs/php_codesniffer": "^3.10",
|
||||
"ivuorinen/markdowndocs": "^4.0"
|
||||
"ivuorinen/markdowndocs": "^4.0",
|
||||
"phpstan/phpstan": "^1.11"
|
||||
},
|
||||
"scripts": {
|
||||
"docs": "php vendor/bin/phpdoc-md generate src > docs.md",
|
||||
"lint": "php vendor/bin/phpcs --standard=PSR12 src",
|
||||
"lint-fix": "php vendor/bin/phpcbf --standard=PSR12 src",
|
||||
"phpstan": "php vendor/bin/phpstan analyse src --level=9"
|
||||
}
|
||||
}
|
||||
|
||||
60
composer.lock
generated
60
composer.lock
generated
@@ -4,7 +4,7 @@
|
||||
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
|
||||
"This file is @generated automatically"
|
||||
],
|
||||
"content-hash": "7364c4b7d7bc5996960ea3dafcba82ef",
|
||||
"content-hash": "03248eb4886355e9781bcffce2553099",
|
||||
"packages": [
|
||||
{
|
||||
"name": "guzzlehttp/guzzle",
|
||||
@@ -731,6 +731,64 @@
|
||||
},
|
||||
"time": "2024-08-15T01:08:58+00:00"
|
||||
},
|
||||
{
|
||||
"name": "phpstan/phpstan",
|
||||
"version": "1.11.10",
|
||||
"source": {
|
||||
"type": "git",
|
||||
"url": "https://github.com/phpstan/phpstan.git",
|
||||
"reference": "640410b32995914bde3eed26fa89552f9c2c082f"
|
||||
},
|
||||
"dist": {
|
||||
"type": "zip",
|
||||
"url": "https://api.github.com/repos/phpstan/phpstan/zipball/640410b32995914bde3eed26fa89552f9c2c082f",
|
||||
"reference": "640410b32995914bde3eed26fa89552f9c2c082f",
|
||||
"shasum": ""
|
||||
},
|
||||
"require": {
|
||||
"php": "^7.2|^8.0"
|
||||
},
|
||||
"conflict": {
|
||||
"phpstan/phpstan-shim": "*"
|
||||
},
|
||||
"bin": [
|
||||
"phpstan",
|
||||
"phpstan.phar"
|
||||
],
|
||||
"type": "library",
|
||||
"autoload": {
|
||||
"files": [
|
||||
"bootstrap.php"
|
||||
]
|
||||
},
|
||||
"notification-url": "https://packagist.org/downloads/",
|
||||
"license": [
|
||||
"MIT"
|
||||
],
|
||||
"description": "PHPStan - PHP Static Analysis Tool",
|
||||
"keywords": [
|
||||
"dev",
|
||||
"static analysis"
|
||||
],
|
||||
"support": {
|
||||
"docs": "https://phpstan.org/user-guide/getting-started",
|
||||
"forum": "https://github.com/phpstan/phpstan/discussions",
|
||||
"issues": "https://github.com/phpstan/phpstan/issues",
|
||||
"security": "https://github.com/phpstan/phpstan/security/policy",
|
||||
"source": "https://github.com/phpstan/phpstan-src"
|
||||
},
|
||||
"funding": [
|
||||
{
|
||||
"url": "https://github.com/ondrejmirtes",
|
||||
"type": "github"
|
||||
},
|
||||
{
|
||||
"url": "https://github.com/phpstan",
|
||||
"type": "github"
|
||||
}
|
||||
],
|
||||
"time": "2024-08-08T09:02:50+00:00"
|
||||
},
|
||||
{
|
||||
"name": "psr/container",
|
||||
"version": "2.0.2",
|
||||
|
||||
22
docs.md
22
docs.md
@@ -25,7 +25,7 @@
|
||||
|:-----------|:---------|
|
||||
| public | <strong>__construct()</strong> : <em>void</em><br /><em>BusinessDataFetcher constructor.</em> |
|
||||
| public | <strong>getBusinessInformation(</strong><em>\string</em> <strong>$businessId</strong>)</strong> : <em>array</em><br /><em>Fetch Business Information.</em> |
|
||||
| public | <strong>parse_response(</strong><em>\Psr\Http\Message\ResponseInterface</em> <strong>$response</strong>)</strong> : <em>array</em> |
|
||||
| public | <strong>parseResponse(</strong><em>\Psr\Http\Message\ResponseInterface</em> <strong>$response</strong>)</strong> : <em>array</em><br /><em>Parse the response from the API.</em> |
|
||||
|
||||
|
||||
<hr /><a id="class-ivuorinenbusinessdatafetcherdtobiscompanyname"></a>
|
||||
@@ -36,6 +36,7 @@
|
||||
|
||||
| Visibility | Function |
|
||||
|:-----------|:---------|
|
||||
| public | <strong>getLanguageString()</strong> : <em>string</em><br /><em>Get the language code as a string.</em> |
|
||||
| public | <strong>getSourceText()</strong> : <em>string</em> |
|
||||
|
||||
|
||||
@@ -49,6 +50,7 @@
|
||||
|
||||
| Visibility | Function |
|
||||
|:-----------|:---------|
|
||||
| public | <strong>getLanguageString()</strong> : <em>string</em><br /><em>Get the language code as a string.</em> |
|
||||
| public | <strong>getSourceText()</strong> : <em>string</em> |
|
||||
|
||||
|
||||
@@ -58,10 +60,12 @@
|
||||
|
||||
### Class: \Ivuorinen\BusinessDataFetcher\Dto\BisCompanyBusinessIdChange
|
||||
|
||||
> Company Business ID Change
|
||||
> Company Business Id Change
|
||||
|
||||
| Visibility | Function |
|
||||
|:-----------|:---------|
|
||||
| public | <strong>getChangeString()</strong> : <em>string</em><br /><em>Get the description string of the change.</em> |
|
||||
| public | <strong>getLanguageString()</strong> : <em>string</em><br /><em>Get the language code as a string.</em> |
|
||||
| public | <strong>getSourceText()</strong> : <em>string</em> |
|
||||
|
||||
|
||||
@@ -71,10 +75,11 @@
|
||||
|
||||
### Class: \Ivuorinen\BusinessDataFetcher\Dto\BisAddress
|
||||
|
||||
> Business Address
|
||||
> Address
|
||||
|
||||
| Visibility | Function |
|
||||
|:-----------|:---------|
|
||||
| public | <strong>getLanguageString()</strong> : <em>string</em><br /><em>Get the language code as a string.</em> |
|
||||
| public | <strong>getSourceText()</strong> : <em>string</em> |
|
||||
|
||||
|
||||
@@ -88,6 +93,7 @@
|
||||
|
||||
| Visibility | Function |
|
||||
|:-----------|:---------|
|
||||
| public | <strong>getLanguageString()</strong> : <em>string</em><br /><em>Get the language code as a string.</em> |
|
||||
| public | <strong>getSourceText()</strong> : <em>string</em> |
|
||||
|
||||
|
||||
@@ -101,6 +107,7 @@
|
||||
|
||||
| Visibility | Function |
|
||||
|:-----------|:---------|
|
||||
| public | <strong>getLanguageString()</strong> : <em>string</em><br /><em>Get the language code as a string.</em> |
|
||||
| public | <strong>getSourceText()</strong> : <em>string</em> |
|
||||
|
||||
|
||||
@@ -114,9 +121,9 @@
|
||||
|
||||
| Visibility | Function |
|
||||
|:-----------|:---------|
|
||||
| public | <strong>getAuthorityText()</strong> : <em>string</em> |
|
||||
| public | <strong>getRegisterText()</strong> : <em>string</em> |
|
||||
| public | <strong>getStatusText()</strong> : <em>string</em> |
|
||||
| public | <strong>getAuthorityString()</strong> : <em>string</em><br /><em>Get the name of the authority.</em> |
|
||||
| public | <strong>getLanguageString()</strong> : <em>string</em><br /><em>Get the language code as a string.</em> |
|
||||
| public | <strong>getRegisterString()</strong> : <em>string</em><br /><em>Get the name of the register.</em> |
|
||||
|
||||
|
||||
*This class extends \Spatie\DataTransferObject\DataTransferObject*
|
||||
@@ -129,6 +136,7 @@
|
||||
|
||||
| Visibility | Function |
|
||||
|:-----------|:---------|
|
||||
| public | <strong>getLanguageString()</strong> : <em>string</em><br /><em>Get the language code as a string.</em> |
|
||||
| public | <strong>getSourceText()</strong> : <em>string</em> |
|
||||
|
||||
|
||||
@@ -142,6 +150,7 @@
|
||||
|
||||
| Visibility | Function |
|
||||
|:-----------|:---------|
|
||||
| public | <strong>getLanguageString()</strong> : <em>string</em><br /><em>Get the language code as a string.</em> |
|
||||
| public | <strong>getSourceText()</strong> : <em>string</em> |
|
||||
|
||||
|
||||
@@ -167,6 +176,7 @@
|
||||
|
||||
| Visibility | Function |
|
||||
|:-----------|:---------|
|
||||
| public | <strong>getLanguageString()</strong> : <em>string</em><br /><em>Get the language code as a string.</em> |
|
||||
| public | <strong>getSourceText()</strong> : <em>string</em> |
|
||||
|
||||
|
||||
|
||||
@@ -6,6 +6,6 @@ $client = new Ivuorinen\BusinessDataFetcher\BusinessDataFetcher();
|
||||
try {
|
||||
$results = $client->getBusinessInformation("1639413-9");
|
||||
print_r($results);
|
||||
} catch (\GuzzleHttp\Exception\GuzzleException $e) {
|
||||
} catch (Exception $e) {
|
||||
var_dump($e);
|
||||
}
|
||||
|
||||
137
gen/parser.php
137
gen/parser.php
@@ -5,19 +5,18 @@
|
||||
// run this file: php parser.php
|
||||
$models = file_get_contents(sprintf('%s%2$smodels.txt', __DIR__, DIRECTORY_SEPARATOR));
|
||||
|
||||
// Capture the names as one group,
|
||||
// and blocks inside curly braces as another,
|
||||
// Capture the names as one group, and blocks inside curly braces as another,
|
||||
// then combine them later.
|
||||
preg_match_all("/(\w+)\s\{([\w\W]*?)\}/m", $models, $output_array);
|
||||
|
||||
[$all, $names, $fields] = $output_array;
|
||||
|
||||
$fields = array_map(function ($f) {
|
||||
$f = explode("\n", $f);
|
||||
$f = array_map("trim", $f);
|
||||
$f = array_filter($f);
|
||||
$fields = array_map(static function ($f) {
|
||||
$d = explode("\n", $f);
|
||||
$d = array_map("trim", $d);
|
||||
$d = array_filter($d);
|
||||
|
||||
$f = array_map(function ($field) {
|
||||
$d = array_map(static function ($field) {
|
||||
[$name_and_type, $docs] = explode(":", $field, 2);
|
||||
$names_and_types = explode(" ", $name_and_type, 2);
|
||||
|
||||
@@ -25,18 +24,21 @@ $fields = array_map(function ($f) {
|
||||
|
||||
$type = str_replace(["(", ")"], "", $type);
|
||||
|
||||
// Handle optional types.
|
||||
if (str_contains($type, "optional")) {
|
||||
$type = str_replace(["optional", ","], "", $type);
|
||||
$type = "?" . trim($type);
|
||||
}
|
||||
|
||||
// Handle integer types.
|
||||
if ($type === "integer") {
|
||||
$type = "int";
|
||||
}
|
||||
|
||||
// Handle array types. Convert Array[Type] to Type[].
|
||||
if (str_contains($type, "Array")) {
|
||||
$type = str_replace(["Array[", "]"], "", $type);
|
||||
$type = $type . "[]";
|
||||
$type .= "[]";
|
||||
}
|
||||
|
||||
$default = null;
|
||||
@@ -60,62 +62,92 @@ $fields = array_map(function ($f) {
|
||||
"default" => $default,
|
||||
],
|
||||
];
|
||||
}, $f ?? []);
|
||||
}, $d);
|
||||
|
||||
$f = array_merge(...$f);
|
||||
|
||||
return $f;
|
||||
return array_merge(...$d);
|
||||
}, $fields);
|
||||
|
||||
$classes = array_combine($names, $fields);
|
||||
|
||||
ksort($classes);
|
||||
|
||||
// print_r($classes);
|
||||
|
||||
// Files that have already been processed.
|
||||
// Uncomment to display the results again.
|
||||
$added = [
|
||||
// "BisCompanyRegisteredOffice",
|
||||
// "BisCompanyRegisteredEntry",
|
||||
// "BisCompanyName",
|
||||
// "BisCompanyLiquidation",
|
||||
// "BisCompanyLanguage",
|
||||
// "BisCompanyForm",
|
||||
// "BisCompanyDetails",
|
||||
// "BisCompanyContactDetail",
|
||||
// "BisCompanyBusinessLine",
|
||||
// "BisCompanyBusinessIdChange",
|
||||
// "BisAddress",
|
||||
];
|
||||
$files = [];
|
||||
|
||||
// Output the classes as preformatted for easier copypasta.
|
||||
// This is not the prettiest way to generate the codes, but it works.
|
||||
foreach ($classes as $className => $vars) {
|
||||
if (in_array($className, $added)) {
|
||||
continue;
|
||||
// Get name of the class from filename and split CamelCase to words.
|
||||
$classNameString = $className;
|
||||
$classNameString = str_replace("Bis", "", $classNameString);
|
||||
$classNameString = preg_replace('/(?<!^)[A-Z]/', ' $0', $classNameString);
|
||||
$classNameString = ucwords($classNameString);
|
||||
|
||||
$usesHeader = [
|
||||
"",
|
||||
"use Spatie\DataTransferObject\DataTransferObject;"
|
||||
];
|
||||
|
||||
$hasCasters = [
|
||||
"BisCompanyDetails",
|
||||
];
|
||||
|
||||
if (in_array($className, $hasCasters, true)) {
|
||||
$usesHeader["CastWith"] = "use Spatie\DataTransferObject\Attributes\CastWith;";
|
||||
$usesHeader["Casters"] = "use Spatie\DataTransferObject\Casters;";
|
||||
}
|
||||
$traits = [];
|
||||
|
||||
if (array_key_exists('authority', $vars)) {
|
||||
$traits[] = " use Traits\HasAuthority;";
|
||||
}
|
||||
if (array_key_exists('source', $vars)) {
|
||||
$traits[] = " use Traits\HasSource;";
|
||||
}
|
||||
if (array_key_exists('version', $vars)) {
|
||||
$traits[] = " use Traits\HasVersion;";
|
||||
}
|
||||
if (array_key_exists('language', $vars)) {
|
||||
$traits[] = " use Traits\HasLanguage;";
|
||||
}
|
||||
if (array_key_exists('change', $vars)) {
|
||||
$traits[] = " use Traits\HasChange;";
|
||||
}
|
||||
if (array_key_exists('register', $vars)) {
|
||||
$traits[] = " use Traits\HasRegister;";
|
||||
}
|
||||
|
||||
echo "
|
||||
if (!empty($traits)) {
|
||||
$usesHeader[] = "use Ivuorinen\BusinessDataFetcher\Traits;";
|
||||
}
|
||||
|
||||
$usesString = implode("\n", $usesHeader);
|
||||
|
||||
$used = ['authority', 'source', 'version', 'language', 'change', 'register'];
|
||||
|
||||
$file = "<?php
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Dto;
|
||||
$usesString
|
||||
|
||||
/**
|
||||
* $className
|
||||
* $classNameString
|
||||
*/
|
||||
class $className extends DataTransferObject
|
||||
{
|
||||
";
|
||||
if (array_key_exists("source", $vars)) {
|
||||
echo " use HasSource;\n";
|
||||
{";
|
||||
if (!empty($traits)) {
|
||||
$file .= "\n" . implode("\n", $traits) . "\n";
|
||||
}
|
||||
|
||||
|
||||
foreach ($vars as $varKey => $varData) {
|
||||
if ($varKey === "source") {
|
||||
if (in_array($varKey, $used, true)) {
|
||||
continue;
|
||||
}
|
||||
|
||||
$caster = "";
|
||||
if (str_contains($varData["type"], "[")) {
|
||||
$classType = str_replace(["[", "]", "?"], "", $varData["type"]);
|
||||
$caster = "\n #[CastWith(Casters\ArrayCaster::class, itemType: {$classType}::class)]";
|
||||
$caster = "\n #[CastWith(Casters\ArrayCaster::class, itemType: $classType::class)]";
|
||||
}
|
||||
|
||||
$type = $varData["type"];
|
||||
@@ -126,12 +158,33 @@ class $className extends DataTransferObject
|
||||
}
|
||||
|
||||
$default = $varData["default"] !== null ? " = " . $varData["default"] . ";" : ";";
|
||||
echo "
|
||||
$file .= "
|
||||
/**
|
||||
* {$varData["docs"]}{$typeHelper}
|
||||
*/{$caster}
|
||||
public {$type} \${$varData["name"]}{$default}
|
||||
public $type \${$varData["name"]}{$default}
|
||||
";
|
||||
}
|
||||
echo "\n}";
|
||||
$file .= "}\n";
|
||||
|
||||
$files[$className] = $file;
|
||||
}
|
||||
|
||||
if (!empty($files)) {
|
||||
echo "Generating files:\n";
|
||||
|
||||
foreach ($files as $className => $file) {
|
||||
$filePath = sprintf(
|
||||
'%s%s%s%s%s%s%s.php',
|
||||
dirname(__FILE__, 2),
|
||||
DIRECTORY_SEPARATOR,
|
||||
'src',
|
||||
DIRECTORY_SEPARATOR,
|
||||
'Dto',
|
||||
DIRECTORY_SEPARATOR,
|
||||
$className
|
||||
);
|
||||
echo $filePath . "\n";
|
||||
file_put_contents($filePath, $file);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -6,6 +6,7 @@ use GuzzleHttp\Client;
|
||||
use GuzzleHttp\Exception\RequestException;
|
||||
use Ivuorinen\BusinessDataFetcher\Dto\BisCompanyDetails;
|
||||
use Ivuorinen\BusinessDataFetcher\Exceptions\ApiResponseErrorException;
|
||||
use Psr\Http\Message\ResponseInterface;
|
||||
|
||||
/**
|
||||
* Fetches and returns business data from avoindata
|
||||
@@ -31,16 +32,13 @@ class BusinessDataFetcher
|
||||
/**
|
||||
* Fetch Business Information.
|
||||
*
|
||||
* @param string $businessId
|
||||
*
|
||||
* @return array $response_data
|
||||
* @return BisCompanyDetails[] $response_data
|
||||
* @throws \Exception|\GuzzleHttp\Exception\GuzzleException
|
||||
*/
|
||||
public function getBusinessInformation(string $businessId): array
|
||||
{
|
||||
// Set request variables
|
||||
$requestUrl = '/bis/v1';
|
||||
$response_data = [];
|
||||
|
||||
// Get the business data
|
||||
try {
|
||||
@@ -54,7 +52,7 @@ class BusinessDataFetcher
|
||||
);
|
||||
}
|
||||
|
||||
$response_data = $this->parse_response($response);
|
||||
$response_data = $this->parseResponse($response);
|
||||
} catch (RequestException $exception) {
|
||||
throw new ApiResponseErrorException(
|
||||
$exception->getMessage(),
|
||||
@@ -67,13 +65,14 @@ class BusinessDataFetcher
|
||||
}
|
||||
|
||||
/**
|
||||
* @param \Psr\Http\Message\ResponseInterface $response
|
||||
* Parse the response from the API.
|
||||
*
|
||||
* @return array
|
||||
* @return BisCompanyDetails[]
|
||||
* @throws \JsonException
|
||||
* @throws \Spatie\DataTransferObject\Exceptions\UnknownProperties
|
||||
* @throws \Ivuorinen\BusinessDataFetcher\Exceptions\ApiResponseErrorException
|
||||
*/
|
||||
public function parse_response(\Psr\Http\Message\ResponseInterface $response): array
|
||||
public function parseResponse(ResponseInterface $response): array
|
||||
{
|
||||
$data = json_decode(
|
||||
$response->getBody()->getContents(),
|
||||
@@ -82,6 +81,20 @@ class BusinessDataFetcher
|
||||
JSON_THROW_ON_ERROR
|
||||
);
|
||||
|
||||
if (!is_array($data)) {
|
||||
throw new ApiResponseErrorException(
|
||||
'Invalid response data',
|
||||
$response->getStatusCode()
|
||||
);
|
||||
}
|
||||
|
||||
if (!isset($data['results'])) {
|
||||
throw new ApiResponseErrorException(
|
||||
'Invalid response data',
|
||||
$response->getStatusCode()
|
||||
);
|
||||
}
|
||||
|
||||
$results = [];
|
||||
|
||||
foreach ($data['results'] as $result) {
|
||||
|
||||
@@ -2,25 +2,22 @@
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Dto;
|
||||
|
||||
use Ivuorinen\BusinessDataFetcher\Traits\HasSource;
|
||||
use Spatie\DataTransferObject\DataTransferObject;
|
||||
use Ivuorinen\BusinessDataFetcher\Traits;
|
||||
|
||||
/**
|
||||
* Business Address
|
||||
* Address
|
||||
*/
|
||||
class BisAddress extends DataTransferObject
|
||||
{
|
||||
use HasSource;
|
||||
|
||||
/**
|
||||
* One for current version and >1 for historical addresses
|
||||
*/
|
||||
public int $version;
|
||||
use Traits\HasSource;
|
||||
use Traits\HasVersion;
|
||||
use Traits\HasLanguage;
|
||||
|
||||
/**
|
||||
* Date of registration
|
||||
*/
|
||||
public string $registrationDate = "";
|
||||
public string $registrationDate = '';
|
||||
|
||||
/**
|
||||
* Ending date of registration
|
||||
@@ -47,11 +44,6 @@ class BisAddress extends DataTransferObject
|
||||
*/
|
||||
public ?string $city = null;
|
||||
|
||||
/**
|
||||
* Two letter language code
|
||||
*/
|
||||
public ?string $language = null;
|
||||
|
||||
/**
|
||||
* Type of address, 1 for street address, 2 for postal address
|
||||
*/
|
||||
|
||||
@@ -2,61 +2,40 @@
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Dto;
|
||||
|
||||
use Ivuorinen\BusinessDataFetcher\Traits\HasSource;
|
||||
use Spatie\DataTransferObject\DataTransferObject;
|
||||
use Ivuorinen\BusinessDataFetcher\Traits;
|
||||
|
||||
/**
|
||||
* Company Business ID Change
|
||||
* Company Business Id Change
|
||||
*/
|
||||
class BisCompanyBusinessIdChange extends DataTransferObject
|
||||
{
|
||||
use HasSource;
|
||||
use Traits\HasSource;
|
||||
use Traits\HasLanguage;
|
||||
use Traits\HasChange;
|
||||
|
||||
/**
|
||||
* Description of reason
|
||||
*/
|
||||
public string $description = "";
|
||||
public string $description = '';
|
||||
|
||||
/**
|
||||
* Reason code
|
||||
*/
|
||||
public string $reason = "";
|
||||
public string $reason = '';
|
||||
|
||||
/**
|
||||
* Date of Business ID change
|
||||
*/
|
||||
public ?string $changeDate = null;
|
||||
|
||||
/**
|
||||
* Business ID Change
|
||||
*
|
||||
* 2 = Business ID removal,
|
||||
* 3 = Combining of double IDs,
|
||||
* 5 = ID changed,
|
||||
* 44 = Fusion,
|
||||
* 45 = Operator continuing VAT activities,
|
||||
* 46 = Relation to predecessor,
|
||||
* 47 = Division,
|
||||
* 48 = Bankruptcy relationship,
|
||||
* 49 = Operations continued by a private trader,
|
||||
* 57 = Partial division,
|
||||
* DIF = Division,
|
||||
* FUU = Fusion
|
||||
*/
|
||||
public int $change;
|
||||
|
||||
/**
|
||||
* Old Business ID
|
||||
*/
|
||||
public string $oldBusinessId = "";
|
||||
public string $oldBusinessId = '';
|
||||
|
||||
/**
|
||||
* New Business ID
|
||||
*/
|
||||
public string $newBusinessId = "";
|
||||
|
||||
/**
|
||||
* Two letter language code
|
||||
*/
|
||||
public ?string $language = null;
|
||||
public string $newBusinessId = '';
|
||||
}
|
||||
|
||||
@@ -2,30 +2,27 @@
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Dto;
|
||||
|
||||
use Ivuorinen\BusinessDataFetcher\Traits\HasSource;
|
||||
use Spatie\DataTransferObject\DataTransferObject;
|
||||
use Ivuorinen\BusinessDataFetcher\Traits;
|
||||
|
||||
/**
|
||||
* Company Business Line
|
||||
*/
|
||||
class BisCompanyBusinessLine extends DataTransferObject
|
||||
{
|
||||
use HasSource;
|
||||
use Traits\HasSource;
|
||||
use Traits\HasVersion;
|
||||
use Traits\HasLanguage;
|
||||
|
||||
/**
|
||||
* Zero for main line of business, positive for others
|
||||
*/
|
||||
public int $order;
|
||||
|
||||
/**
|
||||
* One for current version and >1 for historical lines of business
|
||||
*/
|
||||
public int $version;
|
||||
|
||||
/**
|
||||
* Date of registration
|
||||
*/
|
||||
public string $registrationDate = "";
|
||||
public string $registrationDate = '';
|
||||
|
||||
/**
|
||||
* Ending date of registration
|
||||
@@ -35,10 +32,5 @@ class BisCompanyBusinessLine extends DataTransferObject
|
||||
/**
|
||||
* Name of line of business
|
||||
*/
|
||||
public string $name = "";
|
||||
|
||||
/**
|
||||
* Two letter language code
|
||||
*/
|
||||
public ?string $language = null;
|
||||
public string $name = '';
|
||||
}
|
||||
|
||||
@@ -2,43 +2,35 @@
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Dto;
|
||||
|
||||
use Ivuorinen\BusinessDataFetcher\Traits\HasSource;
|
||||
use Spatie\DataTransferObject\DataTransferObject;
|
||||
use Ivuorinen\BusinessDataFetcher\Traits;
|
||||
|
||||
/**
|
||||
* Company Contact Detail
|
||||
*/
|
||||
class BisCompanyContactDetail extends DataTransferObject
|
||||
{
|
||||
use HasSource;
|
||||
|
||||
/**
|
||||
* One for current version and >1 for historical contact details
|
||||
*/
|
||||
public int $version;
|
||||
use Traits\HasSource;
|
||||
use Traits\HasVersion;
|
||||
use Traits\HasLanguage;
|
||||
|
||||
/**
|
||||
* Date of registration
|
||||
*/
|
||||
public string $registrationDate = "";
|
||||
public string $registrationDate = '';
|
||||
|
||||
/**
|
||||
* Ending date of registration
|
||||
*/
|
||||
public ?string $endDate = null;
|
||||
|
||||
/**
|
||||
* Two letter language code
|
||||
*/
|
||||
public ?string $language = null;
|
||||
|
||||
/**
|
||||
* Value of contact detail
|
||||
*/
|
||||
public string $value = "";
|
||||
public string $value = '';
|
||||
|
||||
/**
|
||||
* Type of contact detail
|
||||
*/
|
||||
public string $type = "";
|
||||
public string $type = '';
|
||||
}
|
||||
|
||||
@@ -2,9 +2,9 @@
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Dto;
|
||||
|
||||
use Spatie\DataTransferObject\DataTransferObject;
|
||||
use Spatie\DataTransferObject\Attributes\CastWith;
|
||||
use Spatie\DataTransferObject\Casters;
|
||||
use Spatie\DataTransferObject\DataTransferObject;
|
||||
|
||||
/**
|
||||
* Company Details
|
||||
@@ -91,12 +91,12 @@ class BisCompanyDetails extends DataTransferObject
|
||||
/**
|
||||
* Business ID
|
||||
*/
|
||||
public string $businessId = "";
|
||||
public string $businessId = '';
|
||||
|
||||
/**
|
||||
* Date of registration
|
||||
*/
|
||||
public string $registrationDate = "";
|
||||
public string $registrationDate = '';
|
||||
|
||||
/**
|
||||
* Company form
|
||||
@@ -111,5 +111,5 @@ class BisCompanyDetails extends DataTransferObject
|
||||
/**
|
||||
* Primary company name
|
||||
*/
|
||||
public string $name = "";
|
||||
public string $name = '';
|
||||
}
|
||||
|
||||
@@ -2,25 +2,22 @@
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Dto;
|
||||
|
||||
use Ivuorinen\BusinessDataFetcher\Traits\HasSource;
|
||||
use Spatie\DataTransferObject\DataTransferObject;
|
||||
use Ivuorinen\BusinessDataFetcher\Traits;
|
||||
|
||||
/**
|
||||
* Company Form
|
||||
*/
|
||||
class BisCompanyForm extends DataTransferObject
|
||||
{
|
||||
use HasSource;
|
||||
|
||||
/**
|
||||
* One for current version and >1 for historical company forms
|
||||
*/
|
||||
public int $version;
|
||||
use Traits\HasSource;
|
||||
use Traits\HasVersion;
|
||||
use Traits\HasLanguage;
|
||||
|
||||
/**
|
||||
* Date of registration
|
||||
*/
|
||||
public string $registrationDate = "";
|
||||
public string $registrationDate = '';
|
||||
|
||||
/**
|
||||
* Ending date of registration
|
||||
@@ -30,20 +27,10 @@ class BisCompanyForm extends DataTransferObject
|
||||
/**
|
||||
* Name of company form
|
||||
*/
|
||||
public string $name = "";
|
||||
public string $name = '';
|
||||
|
||||
/**
|
||||
* Two letter language code
|
||||
* Type of company form
|
||||
*/
|
||||
public ?string $language = null;
|
||||
|
||||
/**
|
||||
* Type of company form.
|
||||
*
|
||||
* Note: According to spec, this shouldn't be nullable,
|
||||
* but payloads show otherwise.
|
||||
*
|
||||
* @var string|null
|
||||
*/
|
||||
public ?string $type;
|
||||
public string $type = '';
|
||||
}
|
||||
|
||||
@@ -2,25 +2,22 @@
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Dto;
|
||||
|
||||
use Ivuorinen\BusinessDataFetcher\Traits\HasSource;
|
||||
use Spatie\DataTransferObject\DataTransferObject;
|
||||
use Ivuorinen\BusinessDataFetcher\Traits;
|
||||
|
||||
/**
|
||||
* Company Language
|
||||
*/
|
||||
class BisCompanyLanguage extends DataTransferObject
|
||||
{
|
||||
use HasSource;
|
||||
|
||||
/**
|
||||
* One for current version and >1 for historical company forms
|
||||
*/
|
||||
public int $version;
|
||||
use Traits\HasSource;
|
||||
use Traits\HasVersion;
|
||||
use Traits\HasLanguage;
|
||||
|
||||
/**
|
||||
* Date of registration
|
||||
*/
|
||||
public string $registrationDate = "";
|
||||
public string $registrationDate = '';
|
||||
|
||||
/**
|
||||
* Ending date of registration
|
||||
@@ -28,17 +25,7 @@ class BisCompanyLanguage extends DataTransferObject
|
||||
public ?string $endDate = null;
|
||||
|
||||
/**
|
||||
* Bankruptcy, liquidation or restructuring proceedings
|
||||
* Name of language
|
||||
*/
|
||||
public string $name = "";
|
||||
|
||||
/**
|
||||
* Two letter language code
|
||||
*/
|
||||
public ?string $language = null;
|
||||
|
||||
/**
|
||||
* Type of liquidation
|
||||
*/
|
||||
public string $type = "";
|
||||
public string $name = '';
|
||||
}
|
||||
|
||||
@@ -2,25 +2,22 @@
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Dto;
|
||||
|
||||
use Ivuorinen\BusinessDataFetcher\Traits\HasSource;
|
||||
use Spatie\DataTransferObject\DataTransferObject;
|
||||
use Ivuorinen\BusinessDataFetcher\Traits;
|
||||
|
||||
/**
|
||||
* Company Liquidation
|
||||
*/
|
||||
class BisCompanyLiquidation extends DataTransferObject
|
||||
{
|
||||
use HasSource;
|
||||
|
||||
/**
|
||||
* One for current version and >1 for historical company forms
|
||||
*/
|
||||
public int $version;
|
||||
use Traits\HasSource;
|
||||
use Traits\HasVersion;
|
||||
use Traits\HasLanguage;
|
||||
|
||||
/**
|
||||
* Date of registration
|
||||
*/
|
||||
public string $registrationDate = "";
|
||||
public string $registrationDate = '';
|
||||
|
||||
/**
|
||||
* Ending date of registration
|
||||
@@ -30,15 +27,10 @@ class BisCompanyLiquidation extends DataTransferObject
|
||||
/**
|
||||
* Bankruptcy, liquidation or restructuring proceedings
|
||||
*/
|
||||
public string $name = "";
|
||||
|
||||
/**
|
||||
* Two letter language code
|
||||
*/
|
||||
public ?string $language = null;
|
||||
public string $name = '';
|
||||
|
||||
/**
|
||||
* Type of liquidation
|
||||
*/
|
||||
public string $type = "";
|
||||
public string $type = '';
|
||||
}
|
||||
|
||||
@@ -2,33 +2,27 @@
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Dto;
|
||||
|
||||
use Ivuorinen\BusinessDataFetcher\Traits\HasSource;
|
||||
use Spatie\DataTransferObject\DataTransferObject;
|
||||
use Ivuorinen\BusinessDataFetcher\Traits;
|
||||
|
||||
/**
|
||||
* Company Name
|
||||
*/
|
||||
class BisCompanyName extends DataTransferObject
|
||||
{
|
||||
use HasSource;
|
||||
use Traits\HasSource;
|
||||
use Traits\HasVersion;
|
||||
use Traits\HasLanguage;
|
||||
|
||||
/**
|
||||
* Order
|
||||
*
|
||||
* Zero for primary company name,
|
||||
* other for translations of the primary company name
|
||||
* and auxiliary company names
|
||||
* Zero for primary company name, other for translations of the primary company name and auxiliary company names
|
||||
*/
|
||||
public int $order;
|
||||
/**
|
||||
* One for current version and >1 for historical company names
|
||||
*/
|
||||
public int $version;
|
||||
|
||||
/**
|
||||
* Date of registration
|
||||
*/
|
||||
public string $registrationDate = "";
|
||||
public string $registrationDate = '';
|
||||
|
||||
/**
|
||||
* Ending date of registration
|
||||
@@ -38,10 +32,5 @@ class BisCompanyName extends DataTransferObject
|
||||
/**
|
||||
* Company name
|
||||
*/
|
||||
public string $name = "";
|
||||
|
||||
/**
|
||||
* Two letter language code
|
||||
*/
|
||||
public ?string $language = null;
|
||||
public string $name = '';
|
||||
}
|
||||
|
||||
@@ -2,18 +2,22 @@
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Dto;
|
||||
|
||||
use Ivuorinen\BusinessDataFetcher\Exceptions\UnexpectedValueException;
|
||||
use Spatie\DataTransferObject\DataTransferObject;
|
||||
use Ivuorinen\BusinessDataFetcher\Traits;
|
||||
|
||||
/**
|
||||
* Company Registered Entry
|
||||
*/
|
||||
class BisCompanyRegisteredEntry extends DataTransferObject
|
||||
{
|
||||
use Traits\HasAuthority;
|
||||
use Traits\HasLanguage;
|
||||
use Traits\HasRegister;
|
||||
|
||||
/**
|
||||
* Description of entry
|
||||
*/
|
||||
public string $description = "";
|
||||
public string $description = '';
|
||||
|
||||
/**
|
||||
* Zero for common entries, one for ‘Unregistered’ and two for ‘Registered’
|
||||
@@ -23,76 +27,10 @@ class BisCompanyRegisteredEntry extends DataTransferObject
|
||||
/**
|
||||
* Date of registration
|
||||
*/
|
||||
public string $registrationDate = "";
|
||||
public string $registrationDate = '';
|
||||
|
||||
/**
|
||||
* Ending date of registration
|
||||
*/
|
||||
public ?string $endDate = null;
|
||||
|
||||
/**
|
||||
* register (int):
|
||||
* - One for Trade Register,
|
||||
* - two for Register of Foundations,
|
||||
* - three for Register of Associations,
|
||||
* - four for Tax Administration,
|
||||
* - five for Prepayment Register,
|
||||
* - six for VAT Register,
|
||||
* - seven for Employer Register and
|
||||
* - eight for register of bodies liable for tax on insurance premiums
|
||||
*
|
||||
* @see getRegisterText()
|
||||
*/
|
||||
public int $register;
|
||||
/**
|
||||
* Two letter language code
|
||||
*/
|
||||
public ?string $language;
|
||||
/**
|
||||
* authority (int):
|
||||
* - One for Tax Administration,
|
||||
* - two for Finnish Patent and Registration Office and
|
||||
* - three for Population Register
|
||||
*
|
||||
* @see getAuthorityText()
|
||||
*
|
||||
* @var int
|
||||
*/
|
||||
public int $authority;
|
||||
|
||||
public function getStatusText(): string
|
||||
{
|
||||
// Zero for common entries, one for ‘Unregistered’ and two for ‘Registered’
|
||||
return match ($this->status) {
|
||||
0 => "Common",
|
||||
1 => "Unregistered",
|
||||
2 => "Registered",
|
||||
default => throw new UnexpectedValueException("Unexpected value: " . $this->status),
|
||||
};
|
||||
}
|
||||
|
||||
public function getRegisterText(): string
|
||||
{
|
||||
return match ($this->register) {
|
||||
1 => "Trade Register",
|
||||
2 => "Register of Foundations",
|
||||
3 => "Register of Associations",
|
||||
4 => "Tax Administration",
|
||||
5 => "Prepayment Register",
|
||||
6 => "VAT Register",
|
||||
7 => "Employer Register",
|
||||
8 => "register of bodies liable for tax on insurance premiums",
|
||||
default => throw new UnexpectedValueException("Unexpected value: " . $this->register),
|
||||
};
|
||||
}
|
||||
|
||||
public function getAuthorityText(): string
|
||||
{
|
||||
return match ($this->authority) {
|
||||
1 => "Tax Administration",
|
||||
2 => "Finnish Patent and Registration Office",
|
||||
3 => "Population Register",
|
||||
default => throw new UnexpectedValueException("Unexpected value: " . $this->authority),
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,30 +2,27 @@
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Dto;
|
||||
|
||||
use Ivuorinen\BusinessDataFetcher\Traits\HasSource;
|
||||
use Spatie\DataTransferObject\DataTransferObject;
|
||||
use Ivuorinen\BusinessDataFetcher\Traits;
|
||||
|
||||
/**
|
||||
* Company Registered Office
|
||||
*/
|
||||
class BisCompanyRegisteredOffice extends DataTransferObject
|
||||
{
|
||||
use HasSource;
|
||||
use Traits\HasSource;
|
||||
use Traits\HasVersion;
|
||||
use Traits\HasLanguage;
|
||||
|
||||
/**
|
||||
* Zero for primary place of registered office, positive for others
|
||||
*/
|
||||
public int $order;
|
||||
|
||||
/**
|
||||
* One for current version and >1 for historical places of registered office
|
||||
*/
|
||||
public int $version;
|
||||
|
||||
/**
|
||||
* Date of registration
|
||||
*/
|
||||
public string $registrationDate = "";
|
||||
public string $registrationDate = '';
|
||||
|
||||
/**
|
||||
* Ending date of registration
|
||||
@@ -35,10 +32,5 @@ class BisCompanyRegisteredOffice extends DataTransferObject
|
||||
/**
|
||||
* Name of place of registered office
|
||||
*/
|
||||
public string $name = "";
|
||||
|
||||
/**
|
||||
* Two letter language code
|
||||
*/
|
||||
public ?string $language = null;
|
||||
public string $name = '';
|
||||
}
|
||||
|
||||
@@ -2,6 +2,8 @@
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Exceptions;
|
||||
|
||||
class ApiResponseErrorException extends \Exception
|
||||
use Exception;
|
||||
|
||||
class ApiResponseErrorException extends Exception
|
||||
{
|
||||
}
|
||||
|
||||
@@ -2,6 +2,8 @@
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Exceptions;
|
||||
|
||||
class UnexpectedValueException extends \Exception
|
||||
use Exception;
|
||||
|
||||
class UnexpectedValueException extends Exception
|
||||
{
|
||||
}
|
||||
|
||||
25
src/Traits/HasAuthority.php
Normal file
25
src/Traits/HasAuthority.php
Normal file
@@ -0,0 +1,25 @@
|
||||
<?php
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Traits;
|
||||
|
||||
trait HasAuthority
|
||||
{
|
||||
/**
|
||||
* @see getChangeString()
|
||||
* @var int $authority What authority the change is related to.
|
||||
*/
|
||||
public int $authority;
|
||||
|
||||
/**
|
||||
* Get the name of the authority.
|
||||
*/
|
||||
public function getAuthorityString(): string
|
||||
{
|
||||
return match ($this->authority) {
|
||||
1 => 'Tax Administration',
|
||||
2 => 'Finnish Patent and Registration Office',
|
||||
3 => 'Population Register',
|
||||
default => 'unknown:' . $this->authority,
|
||||
};
|
||||
}
|
||||
}
|
||||
33
src/Traits/HasChange.php
Normal file
33
src/Traits/HasChange.php
Normal file
@@ -0,0 +1,33 @@
|
||||
<?php
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Traits;
|
||||
|
||||
trait HasChange
|
||||
{
|
||||
/**
|
||||
* @see getChangeString()
|
||||
* @var string|int|null $change Change as a string or integer.
|
||||
* Models claim this is an integer, but it can also be a string.
|
||||
*/
|
||||
public string|int|null $change;
|
||||
|
||||
/**
|
||||
* Get the description string of the change.
|
||||
*/
|
||||
public function getChangeString(): string
|
||||
{
|
||||
return match ($this->change) {
|
||||
2 => 'Business ID removal',
|
||||
3 => 'Combining of double IDs',
|
||||
5 => 'ID changed',
|
||||
44, 'FUU' => 'Fusion',
|
||||
45 => 'Operator continuing VAT activities',
|
||||
46 => 'Relation to predecessor',
|
||||
47, 'DIF' => 'Division',
|
||||
48 => 'Bankruptcy relationship',
|
||||
49 => 'Operations continued by a private trader',
|
||||
57 => 'Partial division',
|
||||
default => 'unknown:' . $this->change,
|
||||
};
|
||||
}
|
||||
}
|
||||
26
src/Traits/HasLanguage.php
Normal file
26
src/Traits/HasLanguage.php
Normal file
@@ -0,0 +1,26 @@
|
||||
<?php
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Traits;
|
||||
|
||||
trait HasLanguage
|
||||
{
|
||||
/**
|
||||
* @see getLanguageString()
|
||||
* @var string|null $language Two letter language code
|
||||
* (e.g. 'fi', 'sv', 'en')
|
||||
*/
|
||||
public ?string $language;
|
||||
|
||||
/**
|
||||
* Get the language code as a string.
|
||||
*/
|
||||
public function getLanguageString(): string
|
||||
{
|
||||
return match ($this->language) {
|
||||
'fi' => 'finnish',
|
||||
'en' => 'english',
|
||||
'sv' => 'swedish',
|
||||
default => 'unknown:' . $this->language,
|
||||
};
|
||||
}
|
||||
}
|
||||
30
src/Traits/HasRegister.php
Normal file
30
src/Traits/HasRegister.php
Normal file
@@ -0,0 +1,30 @@
|
||||
<?php
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Traits;
|
||||
|
||||
trait HasRegister
|
||||
{
|
||||
/**
|
||||
* @see getRegisterString()
|
||||
* @var int|null $register What register the change is related to.
|
||||
*/
|
||||
public int|null $register;
|
||||
|
||||
/**
|
||||
* Get the name of the register.
|
||||
*/
|
||||
public function getRegisterString(): string
|
||||
{
|
||||
return match ($this->register) {
|
||||
1 => 'Trade Register',
|
||||
2 => 'Register of Foundations',
|
||||
3 => 'Register of Associations',
|
||||
4 => 'Tax Administration',
|
||||
5 => 'Prepayment Register',
|
||||
6 => 'VAT Register',
|
||||
7 => 'Employer Register',
|
||||
8 => 'Register of bodies liable for tax on insurance premiums',
|
||||
default => 'unknown:' . $this->register,
|
||||
};
|
||||
}
|
||||
}
|
||||
11
src/Traits/HasVersion.php
Normal file
11
src/Traits/HasVersion.php
Normal file
@@ -0,0 +1,11 @@
|
||||
<?php
|
||||
|
||||
namespace Ivuorinen\BusinessDataFetcher\Traits;
|
||||
|
||||
trait HasVersion
|
||||
{
|
||||
/**
|
||||
* One for current version and >1 for historical contact details.
|
||||
*/
|
||||
public int $version = 0;
|
||||
}
|
||||
Reference in New Issue
Block a user