openvk/VKAPI
lalka2018 f9f6270da0
Search: Add search with parameters (#880)
* Search with parameters

* Small improvements

* Small improvements no.2

Поиск теперь нормально выглядит на других темах
При поиске по группам отображается количество участников там
Костыль с пропуском постов возвращён но немного изменён
Добавлен костыль к комментариям чтобы не показывались комменты с удалённых постов и не было бага как в вепуровке
Добавлены ключи в советском и имперском языке для моих прошлых пуллов (ну и этого конечно)

* Fix debilny oshibky

Убрал лишние ключи локализации, исправил панель поеска и исправил hometown

* fiksy bagiv

* ok

* ok 2

* ok

* rrrrrrrrrrrrrrrr

Добавил параметры в vkapi users.search(), пофиксил проверку коммерции, сузил параметры ещё больше и добавил анимацию выдвижения поиска чтобы красиво было
2023-06-10 18:54:02 +03:00
..
Exceptions [WIP] Add VK API compat layer 2020-08-12 11:39:06 +00:00
Handlers Search: Add search with parameters (#880) 2023-06-10 18:54:02 +03:00
Structures Add text field to Message object (#519) 2022-03-27 20:12:05 +03:00
README.md Add API documentation link for clients (#779) 2022-11-10 15:25:10 +03:00

VK API Compatability layer for OpenVK

This directory contains VK API handlers, structures and relared exceptions. It is still a work-in-progress functionality.
Note: requests to API are routed through openvk.Web.Presenters.VKAPIPresenter, this dir contains only handlers.

Documentation for API clients

Implementing API methods

VK API methods have names like this: example.test. To implement a method like this you will need to create a class Example in the Handlers subdirectory. This class must extend VKAPIHandler and be final.
Next step is to create test method. It must have a type hint that is not void. Everything else is fine, the return value of method will be authomatically converted to JSON and sent back to client.

Parameters

Method arguments are parameters. To declare a parameter just create an argument with the same name. You should also provide correct type hints for them. Type conversion is done automatically if possible. If not possible error №1 will be returned.
If parameter is not passed by client then router will pass default value to argument. If there is no default value but argument accepts NULL then NULL will be passed. If NULL is not acceptable, default value is undefined and parameter is not passed, API will return missing parameter error to client.

Returning errors

To return an error, call fail method like this: $this->fail(5, "error") (first argument is error code and second is error message). You can also throw the exception manually: throw new APIErrorException("error", 5) (class: openvk.VKAPI.Exceptions.APIErrorException).
If you throw any exception that does not inherit APIErrorException then API will return error №1 (unknown error) to client.

Refering to user

To get user use getUser method: $this->getUser(). Keep in mind it will return NULL if user is undefined (no access_token passed or it is invalid/expired or roaming authentification failed).
If you need to check whether user is defined use userAuthorized. This method returns true if user is present and false if not.
If your method cant work without user context call requireUser and it will automatically return unauthorized error.

Working with data

You can use OpenVK models for that. However, do not return them (either you will leak data or JSON conversion will fail). It is better to create a response object and return it. It is also a good idea to define a structure in Structures subdirectory.

Have a lot of fun