| Moodle PHP Documentation 4.5
    Moodle 4.5.5+ (Build: 20250711) (ce34e8ff087) | 
| Namespaces | |
| namespace | core_external | 
|  | |
| namespace | core_webservice | 
|  | |
| namespace | core_webservice\privacy | 
|  | |
| namespace | core_webservice\reportbuilder\local\entities | 
|  | |
| namespace | core_webservice\reportbuilder\local\systemreports | 
|  | |
| Functions | |
| webservice_access_exception::__construct ($debuginfo) | |
| Constructor. | |
| webservice_server::__construct ($authmethod) | |
| Constructor. | |
| core_webservice::__construct ($id, $filterdata=null) | |
| Sets up the table. | |
| webservice::add_external_function_to_service ($functionname, $serviceid) | |
| Add a function to a service. | |
| webservice::add_external_service ($service) | |
| Add a service It generates the timecreated field automatically. | |
| webservice::add_ws_authorised_user ($user) | |
| Allow user to call a service. | |
| webservice_server::authenticate_by_token ($tokentype) | |
| User authentication by token. | |
| webservice::authenticate_user ($token) | |
| Authenticate user (used by download/upload file scripts) | |
| webservice_server::authenticate_user () | |
| Authenticate user using username+password or token. | |
| core_webservice::col_creatorlastname ($data) | |
| Generate the creator column. | |
| core_webservice::col_fullname ($data) | |
| Generate the fullname column. | |
| core_webservice::col_lastaccess (\stdClass $data) | |
| Generate the last access column. | |
| core_webservice::col_name ($data) | |
| Generate the name column. | |
| core_webservice::col_operation ($data) | |
| Generate the operation column. | |
| core_webservice::col_servicename ($data) | |
| Format the service name column. | |
| core_webservice::col_token ($data) | |
| Generate the token column. | |
| core_webservice::col_validuntil ($data) | |
| Generate the validuntil column. | |
| webservice::delete_service ($serviceid) | |
| Delete a service Also delete function references and authorised user references. | |
| webservice::delete_user_ws_token ($tokenid) | |
| Delete a token. | |
| static | webservice::delete_user_ws_tokens ($userid) | 
| Delete all the tokens belonging to a user. | |
| external_create_service_token ($servicename, $contextid) | |
| Create and return a session linked token. | |
| external_delete_descriptions ($component) | |
| Delete all pre-built services (+ related tokens) and external functions information defined in the specified component. | |
| external_format_string ($str, $context, $striplinks=true, $options=[]) | |
| Format the string to be returned properly as requested by the either the web service server, either by an internally call. | |
| external_format_text ($text, $textformat, $context, $component=null, $filearea=null, $itemid=null, $options=null) | |
| Format the text to be returned properly as requested by the either the web service server, either by an internally call. | |
| external_generate_token ($tokentype, $serviceorid, $userid, $contextorid, $validuntil=0, $iprestriction='') | |
| Generate a token. | |
| external_generate_token_for_current_user ($service) | |
| Generate or return an existing token for the current authenticated user. | |
| external_log_token_request ($token) | |
| Set the last time a token was sent and trigger the core\event\webservice_token_sent event. | |
| external_validate_format ($format) | |
| Validate text field format against known FORMAT_XXX. | |
| webservice::generate_user_ws_tokens ($userid) | |
| Generate all tokens of a specific user. | |
| static | webservice::get_active_tokens ($userid) | 
| Return a list with all the valid user tokens for the given user, it only excludes expired tokens. | |
| webservice::get_created_by_user_ws_token ($userid, $tokenid) | |
| Return a token that has been created by the user (i.e. | |
| webservice::get_external_function_by_id ($functionid, $strictness=IGNORE_MISSING) | |
| Get an external function for a given function id. | |
| webservice::get_external_functions ($serviceids) | |
| Get the functions list of a service list (by id) | |
| webservice::get_external_functions_by_enabled_services ($serviceshortnames, $enabledonly=true) | |
| Get the functions of a service list (by shortname). | |
| webservice::get_external_service_by_id ($serviceid, $strictness=IGNORE_MISSING) | |
| Get an external service for a given service id. | |
| webservice::get_external_service_by_shortname ($shortname, $strictness=IGNORE_MISSING) | |
| Get an external service for a given shortname. | |
| webservice::get_missing_capabilities_by_users (array $users, int $serviceid) | |
| Get missing user capabilities for the given service's functions. | |
| webservice::get_not_associated_external_functions ($serviceid) | |
| Get functions not included in a service. | |
| webservice::get_service_required_capabilities ($serviceid) | |
| Get list of required capabilities of a service, sorted by functions Example of returned value: Array ( [core_group_create_groups] => Array ( [0] => moodle/course:managegroups ) | |
| webservice::get_token_by_id ($tokenid) | |
| Return a database token record for a token id. | |
| webservice::get_token_by_id_with_details ($tokenid) | |
| Return a token of an arbitrary user by tokenid, including details of the associated user and the service name. | |
| webservice::get_user_capabilities ($userid) | |
| Get user capabilities (with context) Only useful for documentation purpose WARNING: do not use this "broken" function. | |
| webservice::get_user_ws_token ($token) | |
| Get a full database token record for a given token value. | |
| webservice::get_user_ws_tokens ($userid) | |
| Return all tokens of a specific user. | |
| webservice::get_ws_authorised_user ($serviceid, $userid) | |
| Return an authorised user with their options (ip/timecreated / validuntil...) | |
| webservice::get_ws_authorised_users ($serviceid) | |
| Return list of allowed users with their options (ip/timecreated / validuntil...) for a given service. | |
| core_webservice::other_cols ($colname, $data) | |
| This function is used for the extra user fields. | |
| core_webservice::query_db ($pagesize, $useinitialsbar=false) | |
| Query the database for results to display in the table. | |
| webservice::remove_external_function_from_service ($functionname, $serviceid) | |
| Remove a function from a service. | |
| webservice::remove_ws_authorised_user ($user, $serviceid) | |
| Disallow a user to call a service. | |
| webservice_server_interface::run () | |
| Process request from client. | |
| webservice::service_function_exists ($functionname, $serviceid) | |
| Test whether an external function is already linked to a service. | |
| webservice_server::set_web_service_call_settings () | |
| Intercept some moodlewssettingXXX $_GET and $_POST parameter that are related to the web service call and are not the function parameters. | |
| webservice_test_client_interface::simpletest ($serverurl, $function, $params) | |
| Execute test client WS request. | |
| webservice::update_external_service ($service) | |
| Update a service It modifies the timemodified automatically. | |
| static | webservice::update_token_lastaccess ($token, int $time=0) | 
| Updates the last access time for a token. | |
| webservice::update_ws_authorised_user ($user) | |
| Update allowed user settings (ip restriction, valid until...) | |
| webservice_protocol_is_enabled ($protocol) | |
| Check if a protocol is enabled. | |
| Variables | |
| core_webservice::$attributes | |
| integer | webservice_server::$authmethod | 
| Authentication method one of WEBSERVICE_AUTHMETHOD_*. | |
| global | $CFG | 
| object | core_webservice::$filterdata | 
| $functions | |
| bool | core_webservice::$hasviewfullnames | 
| $hasviewfullnames Does the user have the viewfullnames capability. | |
| core_webservice::$mform = $this->_form | |
| core_webservice::$options = $DB->get_records_menu('external_services', null, '', 'id, name') | |
| string | webservice_server::$password = null | 
| Password of the local user. | |
| core_webservice::$presetdata = $this->_customdata | |
| stdClass | webservice_server::$restricted_context | 
| Restricted context. | |
| int | webservice_server::$restricted_serviceid = null | 
| Restrict call to one service id. | |
| $services | |
| string | webservice_server::$token = null | 
| Authentication token. | |
| array | core_webservice::$userextrafields | 
| int | webservice_server::$userid = null | 
| The local user. | |
| string | webservice_server::$username = null | 
| Name of local user. | |
| string | webservice_server::$wsname = null | 
| Name of the web server plugin. | |
| replacement | core_webservice::__pad0__ | 
| Form allowing to filter displayed tokens. | |
| if(empty($presetdata->token) &&empty($presetdata->users) &&empty($presetdata->services)) | core_webservice::else | 
| replacement | core_webservice::mdl | 
| replacement | core_webservice::reason | 
| replacement | core_webservice::since | 
| int const | webservice::TOKEN_LASTACCESS_UPDATE_SECS = 60 | 
| Only update token last access once per this many seconds. | |
| const | WEBSERVICE_AUTHMETHOD_PERMANENT_TOKEN 1 | 
| WEBSERVICE_AUTHMETHOD_PERMANENT_TOKEN - most common token authentication (external app, mobile app...) | |
| const | WEBSERVICE_AUTHMETHOD_SESSION_TOKEN 2 | 
| WEBSERVICE_AUTHMETHOD_SESSION_TOKEN - token for embedded application (requires Moodle session) | |
| const | WEBSERVICE_AUTHMETHOD_USERNAME 0 | 
| WEBSERVICE_AUTHMETHOD_USERNAME - username/password authentication (also called simple authentication) | |
| webservice_access_exception::__construct | ( | $debuginfo | ) | 
Constructor.
| string | $debuginfo | the debug info | 
| webservice_server::__construct | ( | $authmethod | ) | 
Constructor.
| integer | $authmethod | authentication method one of WEBSERVICE_AUTHMETHOD_* | 
| core_webservice\__construct | ( | $id, | |
| $filterdata = null ) | 
Sets up the table.
| int | $id | The id of the table | 
| object | $filterdata | The data submitted by the { | 
| webservice::add_external_function_to_service | ( | $functionname, | |
| $serviceid ) | 
Add a function to a service.
| string | $functionname | function name | 
| int | $serviceid | service id | 
| webservice::add_external_service | ( | $service | ) | 
Add a service It generates the timecreated field automatically.
| stdClass | $service | 
| serviceid | integer | 
| webservice::add_ws_authorised_user | ( | $user | ) | 
Allow user to call a service.
| stdClass | $user | a user | 
| 
 | protected | 
User authentication by token.
| string | $tokentype | token type (EXTERNAL_TOKEN_EMBEDDED or EXTERNAL_TOKEN_PERMANENT) | 
| stdClass | the authenticated user | 
| webservice_access_exception | 
| webservice::authenticate_user | ( | $token | ) | 
Authenticate user (used by download/upload file scripts)
| string | $token | 
| array | - contains the authenticated user, token and service objects | 
| 
 | protected | 
Authenticate user using username+password or token.
This function sets up $USER global. It is safe to use has_capability() after this. This method also verifies user is allowed to use this server.
| core_webservice\col_creatorlastname | ( | $data | ) | 
Generate the creator column.
| stdClass | $data | 
| string | 
| core_webservice\col_fullname | ( | $data | ) | 
Generate the fullname column.
Also includes capabilities the user is missing for the webservice (if any)
| stdClass | $data | Data for the current row | 
| string | Content for the column | 
| core_webservice\col_lastaccess | ( | \stdClass | $data | ) | 
Generate the last access column.
| stdClass | $data | 
| string | 
| core_webservice\col_name | ( | $data | ) | 
Generate the name column.
| stdClass | $data | Data for the current row | 
| string | Content for the column | 
| core_webservice\col_operation | ( | $data | ) | 
Generate the operation column.
| stdClass | $data | Data for the current row | 
| string | Content for the column | 
| core_webservice\col_servicename | ( | $data | ) | 
Format the service name column.
| stdClass | $data | 
| string | 
| core_webservice\col_token | ( | $data | ) | 
| core_webservice\col_validuntil | ( | $data | ) | 
Generate the validuntil column.
| stdClass | $data | Data for the current row | 
| string | Content for the column | 
| webservice::delete_service | ( | $serviceid | ) | 
Delete a service Also delete function references and authorised user references.
| int | $serviceid | service id | 
| webservice::delete_user_ws_token | ( | $tokenid | ) | 
Delete a token.
| int | $tokenid | token id | 
| 
 | static | 
Delete all the tokens belonging to a user.
| int | $userid | the user id whose tokens must be deleted | 
| external_create_service_token | ( | $servicename, | |
| $contextid ) | 
Create and return a session linked token.
Token to be used for html embedded client apps that want to communicate with the Moodle server through web services. The token is linked to the current session for the current page request. It is expected this will be called in the script generating the html page that is embedding the client app and that the returned token will be somehow passed into the client app being embedded in the page.
| string | $servicename | name of the web service. Service name as defined in db/services.php | 
| int | $context | context within which the web service can operate. | 
| string | returns token id. | 
| external_delete_descriptions | ( | $component | ) | 
Delete all pre-built services (+ related tokens) and external functions information defined in the specified component.
| string | $component | name of component (moodle, etc.) | 
| external_format_string | ( | $str, | |
| $context, | |||
| $striplinks = true, | |||
| $options = [] ) | 
Format the string to be returned properly as requested by the either the web service server, either by an internally call.
The caller can change the format (raw) with the external_settings singleton All web service servers must set this singleton when parsing the $_GET and $_POST.
Options are the same that in with some changes: filter : Can be set to false to force filters off, else observes .
| string | $str | The string to be filtered. Should be plain text, expect possibly for multilang tags. | 
| boolean | $striplinks | To strip any link in the result text. Moodle 1.8 default changed from false to true! MDL-8713 | 
| context | int | $contextorid | The id of the context for the string or the context (affects filters). | 
| array | $options | options array/object or courseid | 
| string | text | 
| external_format_text | ( | $text, | |
| $textformat, | |||
| $context, | |||
| $component = null, | |||
| $filearea = null, | |||
| $itemid = null, | |||
| $options = null ) | 
Format the text to be returned properly as requested by the either the web service server, either by an internally call.
The caller can change the format (raw, filter, file, fileurl) with the external_settings singleton All web service servers must set this singleton when parsing the $_GET and $_POST.
Options are the same that in with some changes in defaults to provide backwards compatibility: trusted : If true the string won't be cleaned. Default false. noclean : If true the string won't be cleaned only if trusted is also true. Default false. nocache : If true the string will not be cached and will be formatted every call. Default false. filter : Can be set to false to force filters off, else observes . para : If true then the returned string will be wrapped in div tags. Default (different from format_text) false. Default changed because div tags are not commonly needed. newlines : If true then lines newline breaks will be converted to HTML newline breaks. Default true. context : Not used! Using contextid parameter instead. overflowdiv : If set to true the formatted text will be encased in a div with the class no-overflow before being returned. Default false. allowid : If true then id attributes will not be removed, even when using htmlpurifier. Default (different from format_text) true. Default changed id attributes are commonly needed. blanktarget : If true all tags will have target="_blank" added unless target is explicitly specified.
| string | $text | The content that may contain ULRs in need of rewriting. | 
| int | $textformat | The text format. | 
| context | int | $context | This parameter and the next two identify the file area to use. | 
| string | $component | |
| string | $filearea | helps identify the file area. | 
| int | $itemid | helps identify the file area. | 
| object/array | $options text formatting options | 
| array | text + textformat | 
| external_generate_token | ( | $tokentype, | |
| $serviceorid, | |||
| $userid, | |||
| $contextorid, | |||
| $validuntil = 0, | |||
| $iprestriction = '' ) | 
Generate a token.
| string | $tokentype | EXTERNAL_TOKEN_EMBEDDED|EXTERNAL_TOKEN_PERMANENT | 
| stdClass | int | $serviceorid | service linked to the token | 
| int | $userid | user linked to the token | 
| stdClass | int | $contextorid | |
| int | $validuntil | date when the token expired | 
| string | $iprestriction | allowed ip - if 0 or empty then all ips are allowed | 
| string | generated token | 
| external_generate_token_for_current_user | ( | $service | ) | 
Generate or return an existing token for the current authenticated user.
This function is used for creating a valid token for users authenticathing via login/token.php or admin/tool/mobile/launch.php.
| stdClass | $service | external service object | 
| stdClass | token object | 
| external_log_token_request | ( | $token | ) | 
Set the last time a token was sent and trigger the core\event\webservice_token_sent event.
This function is used when a token is generated by the user via login/token.php or admin/tool/mobile/launch.php. In order to protect the privatetoken, we remove it from the event params.
| stdClass | $token | token object | 
| external_validate_format | ( | $format | ) | 
Validate text field format against known FORMAT_XXX.
| array | $format | the format to validate | 
| the | validated format | 
| coding_exception | 
| webservice::generate_user_ws_tokens | ( | $userid | ) | 
Generate all tokens of a specific user.
| int | $userid | user id | 
| 
 | static | 
Return a list with all the valid user tokens for the given user, it only excludes expired tokens.
| string | $userid | user id to retrieve tokens from | 
| array | array of token entries | 
| webservice::get_created_by_user_ws_token | ( | $userid, | |
| $tokenid ) | 
Return a token that has been created by the user (i.e.
to created by an admin) If no tokens exist an exception is thrown
The returned value is a stdClass: ->id token id ->token ->tokenname ->firstname user firstname ->lastname ->externalserviceid ->name service name
| int | $userid | user id | 
| int | $tokenid | token id | 
| stdClass | 
| webservice::get_external_function_by_id | ( | $functionid, | |
| $strictness = IGNORE_MISSING ) | 
Get an external function for a given function id.
| int | $functionid | function id | 
| int | $strictness | IGNORE_MISSING, MUST_EXIST... | 
| stdClass | external function | 
| webservice::get_external_functions | ( | $serviceids | ) | 
Get the functions list of a service list (by id)
| array | $serviceids | service ids | 
| array | of functions | 
| webservice::get_external_functions_by_enabled_services | ( | $serviceshortnames, | |
| $enabledonly = true ) | 
Get the functions of a service list (by shortname).
It can return only enabled functions if required.
| array | $serviceshortnames | service shortnames | 
| bool | $enabledonly | if true then only return functions for services that have been enabled | 
| array | functions | 
| webservice::get_external_service_by_id | ( | $serviceid, | |
| $strictness = IGNORE_MISSING ) | 
Get an external service for a given service id.
| int | $serviceid | service id | 
| int | $strictness | IGNORE_MISSING, MUST_EXIST... | 
| stdClass | external service | 
| webservice::get_external_service_by_shortname | ( | $shortname, | |
| $strictness = IGNORE_MISSING ) | 
Get an external service for a given shortname.
| string | $shortname | service shortname | 
| int | $strictness | IGNORE_MISSING, MUST_EXIST... | 
| stdClass | external service | 
| webservice::get_missing_capabilities_by_users | ( | array | $users, | 
| int | $serviceid ) | 
Get missing user capabilities for the given service's functions.
Every external function can declare some required capabilities to allow for easier setup of the web services. However, that is supposed to be used for informational admin report only. There is no automatic evaluation of the declared capabilities and the context of the capability evaluation is ignored. Also, actual capability evaluation is much more complex as it allows for overrides etc.
Returned are capabilities that the given users do not seem to have assigned anywhere at the site and that should be checked by the admin.
Do not use this method for anything else, particularly not for any security related checks. See MDL-29962 for the background of why we have this - there are arguments for dropping this feature completely.
| array | $users | List of users to check, consisting of objects, arrays or integer ids. | 
| int | $serviceid | The id of the external service to check. | 
| array | List of missing capabilities: (int)userid => array of (string)capabilitynames | 
| webservice::get_not_associated_external_functions | ( | $serviceid | ) | 
Get functions not included in a service.
| int | $serviceid | service id | 
| array | functions | 
| webservice::get_service_required_capabilities | ( | $serviceid | ) | 
Get list of required capabilities of a service, sorted by functions Example of returned value: Array ( [core_group_create_groups] => Array ( [0] => moodle/course:managegroups )
[core_enrol_get_enrolled_users] => Array ( [0] => moodle/user:viewdetails [1] => moodle/user:viewhiddendetails [2] => moodle/course:useremail [3] => moodle/user:update [4] => moodle/site:accessallgroups ) )
| int | $serviceid | service id | 
| array | 
| webservice::get_token_by_id | ( | $tokenid | ) | 
Return a database token record for a token id.
| int | $tokenid | token id | 
| object | token | 
| webservice::get_token_by_id_with_details | ( | $tokenid | ) | 
Return a token of an arbitrary user by tokenid, including details of the associated user and the service name.
If no tokens exist an exception is thrown
The returned value is a stdClass: ->id token id ->token ->firstname user firstname ->lastname ->name service name
| int | $tokenid | token id | 
| stdClass | 
| webservice::get_user_capabilities | ( | $userid | ) | 
Get user capabilities (with context) Only useful for documentation purpose WARNING: do not use this "broken" function.
It was created in the goal to display some capabilities required by users. In theory we should not need to display this kind of information as the front end does not display it itself. In pratice, admins would like the info, for more info you can follow: MDL-29962
| int | $userid | user id | 
| array | 
| webservice::get_user_ws_token | ( | $token | ) | 
Get a full database token record for a given token value.
| string | $token | 
| moodle_exception | if there is multiple result | 
| webservice::get_user_ws_tokens | ( | $userid | ) | 
Return all tokens of a specific user.
| int | $userid | user id | 
| array | 
| webservice::get_ws_authorised_user | ( | $serviceid, | |
| $userid ) | 
Return an authorised user with their options (ip/timecreated / validuntil...)
| int | $serviceid | the service id to search against | 
| int | $userid | the user to search against | 
| stdClass | 
| webservice::get_ws_authorised_users | ( | $serviceid | ) | 
Return list of allowed users with their options (ip/timecreated / validuntil...) for a given service.
| int | $serviceid | the service id to search against | 
| array#$users | 
| core_webservice\other_cols | ( | $colname, | |
| $data ) | 
This function is used for the extra user fields.
These are being dynamically added to the table so there are no functions 'col_<userfieldname>' as the list has the potential to increase in the future and we don't want to have to remember to add a new method to this class. We also don't want to pollute this class with unnecessary methods.
| string | $colname | The column name | 
| stdClass | $data | 
| string | 
| core_webservice\query_db | ( | $pagesize, | |
| $useinitialsbar = false ) | 
Query the database for results to display in the table.
Note: Initial bars are not implemented for this table because it includes user details twice and the initial bars do not work when the user table is included more than once.
| int | $pagesize | size of page for paginated displayed table. | 
| bool | $useinitialsbar | Not implemented. Please pass false. | 
| webservice::remove_external_function_from_service | ( | $functionname, | |
| $serviceid ) | 
Remove a function from a service.
| string | $functionname | function name | 
| int | $serviceid | service id | 
| webservice::remove_ws_authorised_user | ( | $user, | |
| $serviceid ) | 
Disallow a user to call a service.
| stdClass | $user | a user | 
| int | $serviceid | 
| webservice::service_function_exists | ( | $functionname, | |
| $serviceid ) | 
Test whether an external function is already linked to a service.
| string | $functionname | function name | 
| int | $serviceid | service id | 
| bool | true if a matching function exists for the service, else false. | 
| dml_exception | if error | 
| webservice_test_client_interface::simpletest | ( | $serverurl, | |
| $function, | |||
| $params ) | 
Execute test client WS request.
| string | $serverurl | server url (including the token param) | 
| string | $function | web service function name | 
| array | $params | parameters of the web service function | 
| mixed | 
Implemented in webservice_rest_test_client, and webservice_soap_test_client.
| webservice::update_external_service | ( | $service | ) | 
Update a service It modifies the timemodified automatically.
| stdClass | $service | 
| 
 | static | 
Updates the last access time for a token.
| stdClass | $token | Token object (must include id, lastaccess fields) | 
| int | $time | Time of access (0 = use current time) | 
| dml_exception | If database error | 
| webservice::update_ws_authorised_user | ( | $user | ) | 
Update allowed user settings (ip restriction, valid until...)
| stdClass | $user | 
| webservice_protocol_is_enabled | ( | $protocol | ) | 
Check if a protocol is enabled.
| string | $protocol | name of WS protocol ('rest', 'soap', ...) | 
| bool | true if the protocol is enabled | 
| core_webservice\$attributes | 
| $functions | 
| $services | 
| replacement core_webservice::__pad0__ | 
Form allowing to filter displayed tokens.
Class for the displaying the participants table.
| if (empty( $presetdata->token) &&empty( $presetdata->users) &&empty( $presetdata->services)) core_webservice\else | 
| int const webservice::TOKEN_LASTACCESS_UPDATE_SECS = 60 | 
Only update token last access once per this many seconds.
(This constant controls update of the external tokens last access field. There is a similar define LASTACCESS_UPDATE_SECS which controls update of the web site last access fields.)