X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;f=classes%2Fxmlrpcclient.php;h=d9365f7ece30e844bd1c141fe29a5dda02cb479f;hb=fa7ffd661d77b24cdb385aca7bdb04c938214061;hp=dfc74da3a449c16ac6b2da38cb33a16164c18721;hpb=08fa70684fd1332178cddb6b318151335fb4506c;p=platal.git diff --git a/classes/xmlrpcclient.php b/classes/xmlrpcclient.php index dfc74da..d9365f7 100644 --- a/classes/xmlrpcclient.php +++ b/classes/xmlrpcclient.php @@ -1,6 +1,6 @@ bt) { $this->bt->stop(); } + if (is_null($answer)) { + Platal::page()->trigError("L'accès aux listes de diffusion n'est pas disponible actuellement."); + if ($this->bt) { + $this->bt->update(0, "Connection failed"); + } + return null; + } + Platal::assert(starts_with($answer, 'HTTP/1.0 200 OK'), "HTTP Error:\n" . $answer, + "Une erreur est survenue lors de l'accès aux listes de diffusion."); $result = $this->find_and_decode_xml($answer); if ($this->bt) { - if (isset($result['faultCode'])) { + if (is_array($result) && isset($result['faultCode'])) { $this->bt->update(0, $result['faultString']); } else { $this->bt->update(count($result)); } + } else { + Platal::assert(!is_array($result) || !isset($result['faultCode']), + "RPC Error:\n" . $answer, + "Une erreur est survenue lors de l'accès aux listes de diffusion."); } if (is_array($result) && isset($result['faultCode'])) { @@ -126,5 +139,5 @@ class XmlrpcClient } } -// vim:set et sw=4 sts=4 sws=4 enc=utf-8: +// vim:set et sw=4 sts=4 sws=4 fenc=utf-8: ?>