NAME
WebService::Ares - Perl class to communication with ARES service.
SYNOPSIS
use WebService::Ares;
my $obj = WebService::Ares->new(%parameters);
my @commands = $obj->commands;
my $error = $obj->error($clean);
my $data_hr = $obj->get($command, $def_hr);
my $xml_data = $obj->get_xml($command, $def_hr);
DESCRIPTION
ARES - "Administrativní registr ekonomických subjektů" is Czech information system of Ministry of Finance.
METHODS
new(%parameters)
-
Constructor.
agent
User agent setting. Default is 'WebService::Ares/$VERSION'.
debug
Debug mode flag. Default is 0.
commands()
-
Get web service commands. Returns array of commands.
error($clean)
-
Get error. When $clean variable is present, cleans internal error variable. Returns string with error or undef.
get($command, $def_hr)
-
Get data for command '$command' and definitition defined in $dev_hr reference of hash. Possible definition keys are: - ic - company identification number. Returns reference to hash with data or undef as error.
get_xml($command, $def_hr)
-
Get XML data for command '$command' and definition defined in $dev_hr reference to hash. Possible definition keys are: - ic - company identification number. Returns string with XML data or undef as error.
ERRORS
get():
Method '%s' is unimplemented.
get_xml():
Method '%s' is unimplemented.
EXAMPLE1
use strict;
use warnings;
use Data::Printer;
use WebService::Ares;
# Arguments.
if (@ARGV < 1) {
print STDERR "Usage: $0 ic\n";
exit 1;
}
my $ic = $ARGV[0];
# Object.
my $obj = WebService::Ares->new;
# Get data.
my $data_hr = $obj->get('standard', {'ic' => $ic});
# Print data.
p $data_hr;
# Output:
# Usage: /tmp/8PICXQSYF3 ic
# Output with (44992785) arguments:
# \ {
# address {
# district "Brno-město",
# num 196,
# num2 1,
# psc 60200,
# street "Dominikánské náměstí",
# town "Brno",
# town_part "Brno-město",
# town_urban "Brno-střed"
# },
# create_date "1992-07-01",
# firm "Statutární město Brno",
# ic 44992785
# }
EXAMPLE2
use strict;
use warnings;
use WebService::Ares;
# Arguments.
if (@ARGV < 1) {
print STDERR "Usage: $0 ic\n";
exit 1;
}
my $ic = $ARGV[0];
# Object.
my $obj = WebService::Ares->new;
# Get data.
my $data_xml = $obj->get_xml('standard', {'ic' => $ic});
# Print data.
print $data_xml."\n";
# Output:
# Usage: /tmp/8PICXQSYF3 ic
# Output with (44992785) arguments:
# <?xml version="1.0" encoding="UTF-8"?>
# <are:Ares_odpovedi
# xmlns:are="http://wwwinfo.mfcr.cz/ares/xml_doc/schemas/ares/ares_answer/v_1.0.1"
# xmlns:dtt="http://wwwinfo.mfcr.cz/ares/xml_doc/schemas/ares/ares_datatypes/v_1.0.4"
# xmlns:udt="http://wwwinfo.mfcr.cz/ares/xml_doc/schemas/uvis_datatypes/v_1.0.1"
# odpoved_datum_cas="2014-08-18T07:43:50" odpoved_pocet="1" odpoved_typ="Standard"
# vystup_format="XML" xslt="klient"
# validation_XSLT="/ares/xml_doc/schemas/ares/ares_answer/v_1.0.0/ares_answer.xsl"
# xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
# xsi:schemaLocation="http://wwwinfo.mfcr.cz/ares/xml_doc/schemas/ares/ares_answer/v_1.0.1
# http://wwwinfo.mfcr.cz/ares/xml_doc/schemas/ares/ares_answer/v_1.0.1/ares_answer_v_1.0.1.xsd"
# Id="ares">
# <are:Odpoved>
# <are:Pocet_zaznamu>1</are:Pocet_zaznamu>
# <are:Typ_vyhledani>FREE</are:Typ_vyhledani>
# <are:Zaznam>
# <are:Shoda_ICO>
# <dtt:Kod>9</dtt:Kod>
# </are:Shoda_ICO>
# <are:Vyhledano_dle>ICO</are:Vyhledano_dle>
# <are:Typ_registru>
# <dtt:Kod>3</dtt:Kod>
# <dtt:Text>RES</dtt:Text>
# </are:Typ_registru>
# <are:Datum_vzniku>1992-07-01</are:Datum_vzniku>
# <are:Datum_platnosti>2014-08-18</are:Datum_platnosti>
# <are:Pravni_forma>
# <dtt:Kod_PF>801</dtt:Kod_PF>
# </are:Pravni_forma>
# <are:Obchodni_firma>Statutární město Brno</are:Obchodni_firma>
# <are:ICO>44992785</are:ICO>
# <are:Identifikace>
# <are:Adresa_ARES>
# <dtt:ID_adresy>314885828</dtt:ID_adresy>
# <dtt:Kod_statu>203</dtt:Kod_statu>
# <dtt:Nazev_okresu>Brno-město</dtt:Nazev_okresu>
# <dtt:Nazev_obce>Brno</dtt:Nazev_obce>
# <dtt:Nazev_casti_obce>Brno-město</dtt:Nazev_casti_obce>
# <dtt:Nazev_mestske_casti>Brno-střed</dtt:Nazev_mestske_casti>
# <dtt:Nazev_ulice>Dominikánské náměstí</dtt:Nazev_ulice>
# <dtt:Cislo_domovni>196</dtt:Cislo_domovni>
# <dtt:Typ_cislo_domovni>1</dtt:Typ_cislo_domovni>
# <dtt:Cislo_orientacni>1</dtt:Cislo_orientacni>
# <dtt:PSC>60200</dtt:PSC>
# <dtt:Adresa_UIR>
# <udt:Kod_oblasti>60</udt:Kod_oblasti>
# <udt:Kod_kraje>116</udt:Kod_kraje>
# <udt:Kod_okresu>3702</udt:Kod_okresu>
# <udt:Kod_obce>582786</udt:Kod_obce>
# <udt:Kod_casti_obce>411582</udt:Kod_casti_obce>
# <udt:Kod_mestske_casti>550973</udt:Kod_mestske_casti>
# <udt:PSC>60200</udt:PSC>
# <udt:Kod_ulice>22829</udt:Kod_ulice>
# <udt:Cislo_domovni>196</udt:Cislo_domovni>
# <udt:Typ_cislo_domovni>1</udt:Typ_cislo_domovni>
# <udt:Cislo_orientacni>1</udt:Cislo_orientacni>
# <udt:Kod_adresy>19095597</udt:Kod_adresy>
# <udt:Kod_objektu>18945341</udt:Kod_objektu>
# <udt:PCD>649906</udt:PCD>
# </dtt:Adresa_UIR>
# </are:Adresa_ARES>
# </are:Identifikace>
# <are:Priznaky_subjektu>NNAANANANNAANNNNNNNNPNNNANNNNN</are:Priznaky_subjektu>
# </are:Zaznam>
# </are:Odpoved>
# </are:Ares_odpovedi>
EXAMPLE3
use strict;
use warnings;
use WebService::Ares;
# Object.
my $obj = WebService::Ares->new;
# Get commands.
my @commands = $obj->commands;
# Print commands.
print join "\n", @commands;
print "\n";
# Output:
# standard
DEPENDENCIES
Ares::Standard, Class::Utils, Error::Pure, HTTP::Request, LWP::UserAgent.
SEE ALSO
- WebService::Ares::Standard
-
Perl XML::Parser parser for Ares standard XML file.
REPOSITORY
https://github.com/michal-josef-spacek/WebService-Ares
AUTHOR
Michal Josef Špaček skim@cpan.org
LICENSE AND COPYRIGHT
© Michal Josef Špaček 2009-2020
BSD 2-Clause License
VERSION
0.03