Обновил лонгполл, мелкие исправления
This commit is contained in:
		| @@ -27,8 +27,7 @@ | ||||
|         "psr/log": "1.*", | ||||
|         "monolog/monolog": ">=1.6", | ||||
|         "jasny/error-handler": "^0.2.0", | ||||
|         "vlucas/phpdotenv": "5.*", | ||||
|         "guzzlehttp/guzzle": "^7.0" | ||||
|         "vlucas/phpdotenv": "5.*" | ||||
|     }, | ||||
|     "require-dev": { | ||||
|         "phpdocumentor/phpdocumentor": ">=2.9", | ||||
|   | ||||
| @@ -6,24 +6,74 @@ namespace VK\API; | ||||
|  | ||||
| class LongPoll extends LongPollAbstract | ||||
| { | ||||
|     /** | ||||
|      * Объект взаимодействия лонгпола | ||||
|      *  | ||||
|      * @var object | ||||
|      */ | ||||
|     private $robot; | ||||
|  | ||||
|     /** | ||||
|      * Тип объекта: пользователь или группа | ||||
|      *  | ||||
|      * @var string | ||||
|      */ | ||||
|     private $auth_type; | ||||
|  | ||||
|     /** | ||||
|      * Ключ сессии | ||||
|      *  | ||||
|      * @var string | ||||
|      */ | ||||
|     private $key; | ||||
|  | ||||
|     /** | ||||
|      * @var int | ||||
|      */ | ||||
|     private $user_id; | ||||
|  | ||||
|     /** | ||||
|      * @var int | ||||
|      */ | ||||
|     private $group_id; | ||||
|  | ||||
|     /** | ||||
|      * @var int | ||||
|      */ | ||||
|     private $ts; | ||||
|  | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     private $server; | ||||
|      | ||||
|     public function __construct(object $robot, array $params = []) | ||||
|     { | ||||
|         return; | ||||
|         echo get_class($robot), PHP_EOL; | ||||
|         die; | ||||
|         $this->robot = $robot;  | ||||
|         if ($_ENV['ROBOT_TYPE']) { | ||||
|             $this->vk->auth_type = 'user'; | ||||
|             $this->user_id = $data['id']; | ||||
|             $this->robot->auth_type = 'user'; | ||||
|             $this->user_id = $this->robot->request('users.get', [])['id']; | ||||
|         } else { | ||||
|             $this->vk->auth_type = 'group'; | ||||
|             $this->group_id = $this->vk->request('groups.getById', [])[0]['id']; | ||||
|             $this->vk->request('groups.setLongPollSettings', [ | ||||
|             $this->robot->auth_type = 'group'; | ||||
|             $this->group_id = $this->robot->request('groups.getById', [])['id']; | ||||
|             $this->robot->request('groups.setLongPollSettings', [ | ||||
|                 'group_id' => $this->group_id, | ||||
|                 'enabled' => 1, | ||||
|                 'api_version' => $this->vk->version, | ||||
|                 'api_version' => $this->robot->version, | ||||
|                 'message_new' => 1, | ||||
|             ]); | ||||
|         } | ||||
|         $this->getLongPollServer(); | ||||
|     } | ||||
|      | ||||
|     public function getLongPollServer() | ||||
|     { | ||||
|         if ($this->robot->auth_type == 'user') { | ||||
|             $data = $this->robot->request('messages.getLongPollServer', ['need_pts' => 1, 'lp_version' => 3]); | ||||
|         } else { | ||||
|             $data = $this->robot->request('groups.getLongPollServer', ['group_id' => $this->group_id]); | ||||
|         } | ||||
|         unset($this->key, $this->server, $this->ts); | ||||
|         list($this->key, $this->server, $this->ts) = [$data['key'], $data['server'], $data['ts']]; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -7,4 +7,5 @@ namespace VK\API; | ||||
| abstract class LongPollAbstract | ||||
| { | ||||
|     abstract public function __construct(object $robot, array $params = []); | ||||
|     abstract public function getRobotInfo(); | ||||
| } | ||||
| @@ -38,10 +38,6 @@ class User extends RobotAbstract | ||||
|             $this->auth = $token; | ||||
|             $this->version = $version; | ||||
|             $this->token = $this->auth->getAccessToken(); | ||||
|         } else if (isset($also_version)) { | ||||
|             $this->auth = new Auth($token, $version); | ||||
|             $this->token = $this->auth->getAccessToken(); | ||||
|             $this->version = $also_version; | ||||
|         } else { | ||||
|             $this->token = $token; | ||||
|             $this->version = $version; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Paradise
					Paradise