26if (! defined(
'NOTOKENRENEWAL')) {
27 define(
'NOTOKENRENEWAL',
'1');
30require
"../../main.inc.php";
31require_once DOL_DOCUMENT_ROOT.
'/core/lib/company.lib.php';
32require_once NUSOAP_PATH.
'/nusoap.php';
40$langs->load(
"companies");
43$WS_DOL_URL =
'https://ec.europa.eu/taxation_customs/vies/services/checkVatService';
45$WS_DOL_URL_WSDL =
'https://ec.europa.eu/taxation_customs/vies/checkVatService.wsdl';
46$WS_METHOD =
'checkVat';
49$conf->dol_hide_topmenu = 1;
50$conf->dol_hide_leftmenu = 1;
52llxHeader(
'', $langs->trans(
"VATIntraCheckableOnEUSite"),
'',
'', 0, 0,
'',
'',
'',
'marginpopup');
54print
'<div class="vatcheckarea margintoponly marginbottomonly">';
56print
load_fiche_titre($langs->trans(
"VATIntraCheckableOnEUSite"),
'',
'title_setup');
60$vatNumber =
GETPOST(
"vatNumber",
'alpha');
64 print
'<span class="error">'.$langs->transnoentities(
"ErrorFieldRequired", $langs->trans(
"VATIntraShort")).
'</span><br>';
66 $vatNumber = preg_replace(
'/\^\w/',
'', $vatNumber);
67 $vatNumber = str_replace(array(
' ',
'.'),
'', $vatNumber);
68 $countryCode = substr($vatNumber, 0, 2);
69 $vatNumber = substr($vatNumber, 2);
71 print
'<b>'.$langs->trans(
"Country").
'</b>: '.$countryCode.
'<br>';
72 print
'<b>'.$langs->trans(
"VATIntraShort").
'</b>: '.$vatNumber.
'<br>';
77 "countryCode" => $countryCode,
78 "vatNumber" => $vatNumber,
82 dol_syslog(
"Create nusoap_client for URL=".$WS_DOL_URL.
" WSDL=".$WS_DOL_URL_WSDL);
83 require_once DOL_DOCUMENT_ROOT.
'/core/lib/functions2.lib.php';
87 $soapclient =
new nusoap_client($WS_DOL_URL_WSDL,
true, $params[
'proxy_host'], $params[
'proxy_port'], $params[
'proxy_login'], $params[
'proxy_password'], $params[
'connection_timeout'], $params[
'response_timeout']);
88 $soapclient->soap_defencoding =
'utf-8';
89 $soapclient->xml_encoding =
'utf-8';
90 $soapclient->decode_utf8 =
false;
93 $err = $soapclient->getError();
95 dol_syslog(
"Constructor error ".$WS_DOL_URL, LOG_ERR);
100 $result = $soapclient->call($WS_METHOD, $parameters);
102 print
'<b>'.$langs->trans(
"Response").
'</b>:<br>';
103 $faultstring = $result[
'faultstring'] ??
'';
105 if (!is_array($result) || preg_match(
'/SERVICE_UNAVAILABLE/i', $faultstring)) {
106 print
'<span class="error">'.$langs->trans(
"ErrorServiceUnavailableTryLater").
'</span><br>';
107 $messagetoshow = $soapclient->response;
108 } elseif (preg_match(
'/TIMEOUT/i', $faultstring)) {
109 print
'<span class="error">'.$langs->trans(
"ErrorServiceUnavailableTryLater").
'</span><br>';
110 $messagetoshow = $soapclient->response;
111 } elseif (preg_match(
'/SERVER_BUSY/i', $faultstring)) {
112 print
'<span class="error">'.$langs->trans(
"ErrorServiceUnavailableTryLater").
'</span><br>';
113 $messagetoshow = $soapclient->response;
114 } elseif ($faultstring) {
115 print
'<span class="error">'.$langs->trans(
"Error").
'</span><br>';
116 $messagetoshow = $faultstring;
117 } elseif (preg_match(
'/INVALID_INPUT/i', $faultstring)
118 || ($result[
'requestDate'] && !$result[
'valid'])) {
120 if ($result[
'requestDate']) {
121 print $langs->trans(
"Date").
': '.$result[
'requestDate'].
'<br>';
123 print $langs->trans(
"VATIntraSyntaxIsValid").
': <span class="error">'.$langs->trans(
"No").
'</span> (Might be a non europeen VAT)<br>';
124 print $langs->trans(
"ValueIsValid").
': <span class="error">'.$langs->trans(
"No").
'</span> (Might be a non europeen VAT)<br>';
128 if ($result[
'requestDate']) {
129 print $langs->trans(
"Date").
': '.$result[
'requestDate'].
'<br>';
131 print $langs->trans(
"VATIntraSyntaxIsValid").
': <span class="ok">'.$langs->trans(
"Yes").
'</span><br>';
132 print $langs->trans(
"ValueIsValid").
': ';
133 if (preg_match(
'/MS_UNAVAILABLE/i', $faultstring)) {
134 print
'<span class="error">'.$langs->trans(
"ErrorVATCheckMS_UNAVAILABLE", $countryCode).
'</span><br>';
136 if (!empty($result[
'valid']) && ($result[
'valid'] == 1 || $result[
'valid'] ==
'true')) {
137 print
'<span class="ok">'.$langs->trans(
"Yes").
'</span>';
139 print $langs->trans(
"Name").
': '.$result[
'name'].
'<br>';
140 print $langs->trans(
"Address").
': '.$result[
'address'].
'<br>';
142 print
'<span class="error">'.$langs->trans(
"No").
'</span>';
156print
'<span class="opacitymedium small">'.$langs->trans(
"VATIntraManualCheck", $langs->trans(
"VATIntraCheckURL"), $langs->transnoentitiesnoconv(
"VATIntraCheckURL")).
'</span><br>';
158print
'<div class="center"><input type="button" class="button small" value="'.$langs->trans(
"CloseWindow").
'" onclick="window.close()"></div>';
162 print
'<span class="opacitymedium small">Error returned:</small>'.
"\n";
163 print
'<textarea class="small centpercent">';
llxFooter($comment='', $zone='private', $disabledoutputofmessages=0)
Empty footer.
if(!defined('NOREQUIRESOC')) if(!defined( 'NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined( 'NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined( 'NOREQUIREAJAX')) llxHeader($head='', $title='', $help_url='', $target='', $disablejs=0, $disablehead=0, $arrayofjs='', $arrayofcss='', $morequerystring='', $morecssonbody='', $replacemainareaby='', $disablenofollow=0, $disablenoindex=0)
Empty header.
getSoapParams()
Return array to use for SoapClient constructor.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
load_fiche_titre($title, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='', $morecssonpicto='widthpictotitle')
Load a title with picto.
dol_htmlentitiesbr($stringtoencode, $nl2brmode=0, $pagecodefrom='UTF-8', $removelasteolbr=1)
This function is called to encode a string into a HTML string but differs from htmlentities because a...
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.