ILIAS  release_5-3 Revision v5.3.23-19-g915713cf615
class.ilSOAPAuth.php
Go to the documentation of this file.
1 <?php
2 /*
3  +-----------------------------------------------------------------------------+
4  | ILIAS open source |
5  +-----------------------------------------------------------------------------+
6  | Copyright (c) 1998-2006 ILIAS open source, University of Cologne |
7  | |
8  | This program is free software; you can redistribute it and/or |
9  | modify it under the terms of the GNU General Public License |
10  | as published by the Free Software Foundation; either version 2 |
11  | of the License, or (at your option) any later version. |
12  | |
13  | This program is distributed in the hope that it will be useful, |
14  | but WITHOUT ANY WARRANTY; without even the implied warranty of |
15  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
16  | GNU General Public License for more details. |
17  | |
18  | You should have received a copy of the GNU General Public License |
19  | along with this program; if not, write to the Free Software |
20  | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
21  +-----------------------------------------------------------------------------+
22 */
23 
24 
25 include_once("Auth/Auth.php");
26 include_once("./webservice/soap/lib/nusoap.php");
27 
34 class ilSOAPAuth extends Auth
35 {
36  public $valid = array();
37 
46  public static function testConnection($a_ext_uid, $a_soap_pw, $a_new_user)
47  {
48  global $ilSetting;
49 
50  $settings = $ilSetting->getAll();
51 
52  $server_hostname = $settings["soap_auth_server"];
53  $server_port = (int) $settings["soap_auth_port"];
54  $server_uri = $settings["soap_auth_uri"];
55  $namespace = $settings["soap_auth_namespace"];
56  $use_dotnet = $settings["soap_auth_use_dotnet"];
57  if ($settings["soap_auth_use_https"]) {
58  $uri = "https://";
59  } else {
60  $uri = "http://";
61  }
62 
63  $uri.= $server_hostname;
64 
65  if ($server_port > 0) {
66  $uri.= ":" . $server_port;
67  }
68 
69  if ($server_uri != "") {
70  $uri.= "/" . $server_uri;
71  }
72 
73  $soap_client = new nusoap_client($uri);
74  if ($err = $soap_client->getError()) {
75  return "SOAP Authentication Initialisation Error: " . $err;
76  }
77 
78  $soapAction = "";
79  $nspref = "";
80  if ($use_dotnet) {
81  $soapAction = $namespace . "/isValidSession";
82  $nspref = "ns1:";
83  }
84 
85  $valid = $soap_client->call(
86  'isValidSession',
87  array($nspref . 'ext_uid' => $a_ext_uid,
88  $nspref . 'soap_pw' => $a_soap_pw,
89  $nspref . 'new_user' => $a_new_user),
90  $namespace,
91  $soapAction
92  );
93 
94  return
95  "<br>== Request ==" .
96  '<br><pre>' . htmlspecialchars(str_replace("\" ", "\"\n ", str_replace(">", ">\n", $soap_client->request)), ENT_QUOTES) . '</pre><br>' .
97  "<br>== Response ==" .
98  "<br>Valid: -" . $valid["valid"] . "-" .
99  '<br><pre>' . htmlspecialchars(str_replace("\" ", "\"\n ", str_replace(">", ">\n", $soap_client->response)), ENT_QUOTES) . '</pre>';
100  }
101 } // END class.ilSOAPAuth
if($err=$client->getError()) $namespace
Class SOAPAuth.
static testConnection($a_ext_uid, $a_soap_pw, $a_new_user)
Constructor public.
[nu]soapclient higher level class for easy usage.
Definition: nusoap.php:7064
Create styles array
The data for the language used.
global $ilSetting
Definition: privfeed.php:17