PHP SDK: Difference between revisions
m (Added community python SDK) |
No edit summary |
||
Line 1: | Line 1: | ||
__NOTOC__ | __NOTOC__ | ||
= MTA:SA PHP SDK = | |||
You can access the MTA Web Interface from almost any programming language that can request web pages. PHP can do this very easily. | |||
This SDK provides one function call that will allow you to call any exported script functions on any server that you have access to. | |||
See the [https://wiki.multitheftauto.com/wiki/PHP_SDK official wiki page] for further information. | |||
== | == Installation == | ||
''' | === Prerequisites === | ||
This SDK requires PHP 7.1 or greater. | |||
=== HTTPlug client abstraction === | |||
</ | |||
As this SDK uses HTTPlug, you will have to require some libraries for get it working. See [http://docs.php-http.org/en/latest/httplug/users.html “HTTPlug for library users”] for more info. | |||
:warning: '''Note''': If you don’t follow this requirement before require the SDK, composer will throw you an error. | |||
=== Setup === | |||
The only supported installation method is via [https://getcomposer.org Composer]. Run the following command to require this SDK in your project: | |||
<pre>composer require multitheftauto/mtasa-php-sdk</pre> | |||
== A simple example == | |||
There are three ways to call an MTA server’s exported functions, as shown in the following example: | |||
<syntaxhighlight lang="php"> | <syntaxhighlight lang="php"> | ||
<?php | |||
< | |||
require_once('vendor/autoload.php'); | |||
use MultiTheftAuto\Sdk\Mta; | |||
use MultiTheftAuto\Sdk\Model\Server; | |||
use MultiTheftAuto\Sdk\Model\Authentication; | |||
$server = new Server('127.0.0.1', 22005); | |||
$auth = new Authentication('myUser', 'myPassword'); | |||
$mta = new Mta($server, $auth); | |||
$ | |||
$ | |||
$ | |||
= | $response = $mta->getResource('someResource')->call('callableFunction', $arg1, $arg2, $arg3, ...); | ||
// or | |||
$response = $mta->getResource('someResource')->call->callableFunction($arg1, $arg2, $arg3, ...); | |||
var_dump($response); | |||
$ | |||
</syntaxhighlight> | </syntaxhighlight> | ||
Line 61: | Line 54: | ||
'''PHP:''' (for the page that LUA expects to be at ''<nowiki>http://www.example.com/page.php</nowiki>'') | '''PHP:''' (for the page that LUA expects to be at ''<nowiki>http://www.example.com/page.php</nowiki>'') | ||
<syntaxhighlight lang="php"> | <syntaxhighlight lang="php"> | ||
<?php | |||
$input = | |||
require_once('vendor/autoload.php'); | |||
$input = Mta::getInput(); | |||
Mta::doReturn($input[0] + $input[1]); | |||
</syntaxhighlight> | </syntaxhighlight> | ||
'''LUA:''' | '''LUA:''' | ||
<syntaxhighlight lang="lua"> | <syntaxhighlight lang="lua"> | ||
Line 77: | Line 74: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
== | == Releases == | ||
Visit [https://github.com/multitheftauto/mtasa-php-sdk/releases the releases page on GitHub] to download the SDK. | Visit [https://github.com/multitheftauto/mtasa-php-sdk/releases the releases page on GitHub] to download the SDK. | ||
Line 151: | Line 84: | ||
== Version History == | == Version History == | ||
You can see in the [https://github.com/multitheftauto/mtasa-php-sdk/blob/master/CHANGELOG.md repository changelog file] the changes applied. | |||
[[Category:Tutorials]] | [[Category:Tutorials]] |
Revision as of 01:30, 4 October 2019
MTA:SA PHP SDK
You can access the MTA Web Interface from almost any programming language that can request web pages. PHP can do this very easily.
This SDK provides one function call that will allow you to call any exported script functions on any server that you have access to.
See the official wiki page for further information.
Installation
Prerequisites
This SDK requires PHP 7.1 or greater.
HTTPlug client abstraction
As this SDK uses HTTPlug, you will have to require some libraries for get it working. See “HTTPlug for library users” for more info.
- warning: Note: If you don’t follow this requirement before require the SDK, composer will throw you an error.
Setup
The only supported installation method is via Composer. Run the following command to require this SDK in your project:
composer require multitheftauto/mtasa-php-sdk
A simple example
There are three ways to call an MTA server’s exported functions, as shown in the following example:
<?php require_once('vendor/autoload.php'); use MultiTheftAuto\Sdk\Mta; use MultiTheftAuto\Sdk\Model\Server; use MultiTheftAuto\Sdk\Model\Authentication; $server = new Server('127.0.0.1', 22005); $auth = new Authentication('myUser', 'myPassword'); $mta = new Mta($server, $auth); $response = $mta->getResource('someResource')->call('callableFunction', $arg1, $arg2, $arg3, ...); // or $response = $mta->getResource('someResource')->call->callableFunction($arg1, $arg2, $arg3, ...); var_dump($response);
A page that can be called by callRemote
This example just adds two numbers passed to it by a lua script.
PHP: (for the page that LUA expects to be at http://www.example.com/page.php)
<?php require_once('vendor/autoload.php'); $input = Mta::getInput(); Mta::doReturn($input[0] + $input[1]);
LUA:
-- result is called when the function returns function result(sum) outputChatBox(sum) end function addNumbers(number1, number2) callRemote ( "http://www.example.com/page.php", result, number1, number2 ) end addNumbers ( 123, 456 ) -- call the function
Releases
Visit the releases page on GitHub to download the SDK.
Note for Python
There is a community made Python SDK with the same semantics on the OwlGaming Gitlab for use on Python projects.
Version History
You can see in the repository changelog file the changes applied.