123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390 |
- <?php
- /* For licensing terms, see /license.txt */
- /*
- *
- * 1. This script creates users everytime the page is executed using the Chamilo Webservices
- * 2. The username is generated everytime with a random value from 0 to 1000
- * 3. The default user extra field (profile) is "uid" is created when calling the WSCreateUserPasswordCrypted for the first time, you can change this value.
- * In this field your third party user_id will be registered. See the main/admin/user_fields.php to view the current user fields.
- * 4. You need to create manually a course called Test(with code TEST) After the user was created the new user will be added to this course via webservices.
- *
- */
- exit; //Uncomment this in order to execute the page
- //require_once '../inc/global.inc.php';
- $libpath = api_get_path(LIBRARY_PATH);
- // Create the client instance
- $url = api_get_path(WEB_CODE_PATH)."webservices/registration.soap.php?wsdl";
- //$url = api_get_path(WEB_CODE_PATH)."webservices/access_url.php?wsdl";
- // see the main/inc/configuration.php file to get this value
- $security_key = api_get_configuration_value('security_key');
- $client = new nusoap_client($url, true);
- /*$client->xml_encoding = 'UTF-8';
- $client->http_encoding = 'UTF-8';
- $client->charencoding = 'UTF-8';*/
- $soap_error = $client->getError();
- if (!empty($soap_error)) {
- $error_message = 'Nusoap object creation failed: ' . $soap_error;
- throw new Exception($error_message);
- }
- $client->setDebugLevel(10000);
- $client->debug_flag = true;
- // This should be the IP address of the client
- $ip_address = $_SERVER['SERVER_ADDR'];
- $ip_address = "192.168.1.54";
- $ip_address = "127.0.0.1";
- //Secret key
- $secret_key = sha1($ip_address.$security_key);// Hash of the combination of IP Address + Chamilo security key
- //$secret_key = sha1($security_key);
- //Creating a random user_id, this values need to be provided from your system
- $random_user_id = rand(0, 1000);
- //Creating a random username this values need to be provided from your system
- $generate_user_name = 'jbrion'.$random_user_id;
- //Creating a password (the username)
- $generate_password = sha1($generate_user_name);
- $user_field = 'uid';
- $sessionField = 'external_session_id';
- $params = array(
- 'firstname' => 'Jon',
- 'lastname' => 'Brion',
- 'status' => '5', // 5 STUDENT - 1 TEACHER
- 'email' => 'jon@example.com',
- 'loginname' => $generate_user_name,
- 'password' => $generate_password, // encrypted using sha1
- 'encrypt_method' => 'sha1',
- 'language' => 'english',
- 'official_code' => 'official',
- 'phone' => '00000000',
- 'expiration_date' => '0000-00-00',
- /* the extra user field that will be automatically created
- in the user profile see: main/admin/user_fields.php */
- 'original_user_id_name' => $user_field,
- // third party user id
- 'original_user_id_value' => $random_user_id,
- 'secret_key' => $secret_key,
- // Extra fields
- 'extra' => array(
- array('field_name' => 'ruc', 'field_value' => '123'),
- array('field_name' => 'DNI', 'field_value' => '4200000')
- ),
- );
- //1. Create user webservice
- $user_id = $client->call(
- 'WSCreateUserPasswordCrypted',
- array('createUserPasswordCrypted' => $params)
- );
- // Check for an error
- $err = $client->getError();
- if ($err) {
- // Display the error
- echo '<h2>Constructor error</h2><pre>' . $err . '</pre>';
- }
- $sessionValueRandom = uniqid();
- $params = [
- 'sessions' => [
- [
- 'name' => 'session from ws: '.$sessionValueRandom,
- 'year_start' => '2015',
- 'month_start' => '10',
- 'day_start' => '1',
- 'year_end' => '',
- 'month_end' => '',
- 'day_end' => '',
- 'nb_days_access_before' => 0,
- 'nb_days_access_after' => 0,
- 'nolimit' => 1,
- 'user_id' => 1,
- 'original_session_id_name' => $sessionField,
- 'original_session_id_value' => $sessionValueRandom,
- 'extra' => ''
- ]
- ],
- 'secret_key' => $secret_key,
- ];
- $user_id = $client->call(
- 'WSCreateSession',
- array('createSession' => $params)
- );
- $data = [
- 'secret_key' => $secret_key,
- 'userssessions' => [
- [
- 'original_user_id_name' => $user_field,
- 'original_session_id_value' => $sessionValueRandom,
- 'original_session_id_name' => $sessionField,
- 'original_user_id_values' => [
- [
- 'original_user_id_value' => $random_user_id
- ]
- ]
- ],
- ],
- ];
- $result = $client->call(
- 'WSSuscribeUsersToSession',
- array('subscribeUsersToSession' => $data)
- );
- $err = $client->getError();
- var_dump($result);
- var_dump($err);
- if (!empty($user_id) && is_numeric($user_id)) {
- // 2. Get user info of the new user
- echo '<h2>Trying to create an user via webservices</h2>';
- $original_params = $params;
- $params = array(
- 'original_user_id_value' => $random_user_id, // third party user id
- 'original_user_id_name' => $user_field, // the system field in the user profile (See Profiling)
- 'secret_key' => $secret_key
- );
- $result = $client->call('WSGetUser', array('GetUser' => $params));
- if ($result) {
- echo "Random user was created user_id: $user_id <br /><br />";
- echo 'User info: <br />';
- print_r($original_params);
- echo '<br /><br />';
- } else {
- echo $result;
- }
- //3. Updating user info
- $params = array(
- 'firstname' => 'Jon edited',
- 'lastname' => 'Brion edited',
- 'status' => '5', // STUDENT
- 'email' => 'jon@example.com',
- 'username' => $generate_user_name,
- 'password' => $generate_password, // encrypted using sha1
- 'encrypt_method' => 'sha1',
- 'phone' => '00000000',
- 'expiration_date' => '0000-00-00',
- 'original_user_id_name' => $user_field, // the extra user field that will be automatically created in the user profile see: main/admin/user_fields.php
- 'original_user_id_value' => $random_user_id, // third party user id
- 'secret_key' => $secret_key,
- 'extra' => array(
- array('field_name' => 'ruc', 'field_value' => '666 edited'),
- array('field_name' => 'DNI', 'field_value' => '888 edited')
- ),
- );
- $result = $client->call('WSEditUserPasswordCrypted', array('editUserPasswordCrypted' => $params));
- if ($result) {
- echo "Random user was update user_id: $user_id <br /><br />";
- echo 'User info: <br />';
- print_r($params);
- echo '<br /><br />';
- } else {
- $err = $client->getError();
- var_dump($result);
- var_dump($err);
- }
- $params = array(
- 'ids' => array(
- array(
- 'original_user_id_name' => $user_field,
- 'original_user_id_value' => $random_user_id
- )
- ),
- 'secret_key' => $secret_key
- );
- //Disable user
- $result = $client->call('WSDisableUsers', array('user_ids' => $params));
- //Enable user
- $result = $client->call('WSEnableUsers', array('user_ids' => $params));
- //4 Creating course TEST123
- $params = array(
- 'courses' => array(
- array(
- 'title' => 'PRUEBA', //Chamilo string course code
- 'category_code' => 'LANG',
- 'wanted_code' => '',
- 'course_language' => 'english',
- 'original_course_id_name' => 'course_id_test',
- 'original_course_id_value' => '666',
- )
- ),
- 'secret_key'=> $secret_key,
- );
- $result = $client->call('WSCreateCourse', array('createCourse' => $params));
- //5 .Adding user to the course TEST. The course TEST must be created manually in Chamilo
- echo '<h2>Trying to add user to a course called TEST via webservices</h2>';
- $course_info = api_get_course_info('TEST123');
- if (!empty($course_info)) {
- $params = array(
- 'course' => 'TEST', //Chamilo string course code
- 'user_id' => $user_id,
- 'secret_key' => $secret_key
- );
- $result = $client->call('WSSubscribeUserToCourseSimple', array('subscribeUserToCourseSimple' => $params));
- } else {
- echo 'Course TEST does not exists please create one course with code "TEST"';
- }
- if ($result == 1) {
- echo "User $user_id was added to course TEST";
- } else {
- echo $result;
- }
- //4. Adding course Test to the Session Session1
- $course_id_list = array(
- array('course_code' => 'TEST1'),
- array('course_code' => 'TEST2'),
- );
- $params = array(
- 'coursessessions' => array(
- array(
- 'original_course_id_values' => $course_id_list,
- 'original_course_id_name' => 'course_id_name',
- 'original_session_id_value' => '1',
- 'original_session_id_name' => 'session_id_value',
- ),
- ),
- 'secret_key' => $secret_key,
- );
- //$result = $client->call('WSSuscribeCoursesToSession', array('subscribeCoursesToSession' => $params));
- // ------------------------
- //Calling the WSSubscribeUserToCourse
- $course_array = array(
- 'original_course_id_name' => 'TEST',
- 'original_course_id_value' => 'TEST',
- );
- $user_array = array(
- 'original_user_id_value' => $user_id,
- 'original_user_id_name' => 'name',
- );
- $user_courses = array();
- $user_courses[] = array(
- 'course_id' => $course_array,
- 'user_id' => $user_array,
- 'status' => '1',
- );
- $params = array(
- 'userscourses' => $user_courses,
- 'secret_key' => $secret_key,
- );
- $result = $client->call('WSSubscribeUserToCourse', array('subscribeUserToCourse' => $params));
- var_dump($result);
- } else {
- echo 'User was not created, activate the debug=true in the registration.soap.php file and see the error logs';
- }
- // Check for an error
- $err = $client->getError();
- if ($err) {
- // Display the error
- echo '<h2>Constructor error</h2><pre>' . $err . '</pre>';
- }
- //1. Create user webservice
- $result = $client->call(
- 'WSGetPortals',
- array('getPortals' => [ 'secret_key' => $secret_key])
- );
- $result = $client->call(
- 'WSAddUserToPortal',
- array('addUserToPortal' => ['user_id' => 1, 'portal_id'=> 1, 'secret_key' => $secret_key])
- );
- $result = $client->call(
- 'WSGetPortalListFromUser',
- array('getPortalListFromUser' => ['user_id' => 1, 'secret_key' => $secret_key])
- );
- $result = $client->call(
- 'WSGetPortalListFromCourse',
- array('getPortalListFromCourse' => ['course_id' => 20, 'secret_key' => $secret_key])
- );
- $result = $client->call(
- 'WSAddCourseToPortal',
- array('addCourseToPortal' => ['course_id' => 20, 'portal_id' => 1, 'secret_key' => $secret_key])
- );
- $result = $client->call(
- 'WSRemoveUserFromPortal',
- array('removeUserFromPortal' => ['course_id' => 20, 'portal_id'=> 1, 'secret_key' => $secret_key])
- );
- var_dump($user_id);exit;
- if ($client->fault) {
- echo '<h2>Fault</h2><pre>';
- print_r($result);
- echo '</pre>';
- } else {
- // Check for errors
- $err = $client->getError();
- if ($err) {
- // Display the error
- echo '<h2>Error</h2><pre>' . $err . '</pre>';
- } else {
- // Display the result
- echo '<h2>There are no errors</h2>';
- var_dump($result);
- }
- }
|