Laravel version update
Laravel version update
This commit is contained in:
		| @@ -1,142 +1,151 @@ | ||||
| <?php namespace LaravelFCM\Response; | ||||
| <?php | ||||
|  | ||||
| namespace LaravelFCM\Response; | ||||
|  | ||||
| use Monolog\Logger; | ||||
| use LaravelFCM\Message\Topics; | ||||
| use Monolog\Handler\StreamHandler; | ||||
| use GuzzleHttp\Psr7\Response as GuzzleResponse; | ||||
| use Psr\Http\Message\ResponseInterface; | ||||
|  | ||||
| /** | ||||
|  * Class TopicResponse | ||||
|  * | ||||
|  * @package LaravelFCM\Response | ||||
|  * Class TopicResponse. | ||||
|  */ | ||||
| class TopicResponse extends BaseResponse implements TopicResponseContract{ | ||||
| class TopicResponse extends BaseResponse implements TopicResponseContract | ||||
| { | ||||
|     const LIMIT_RATE_TOPICS_EXCEEDED = 'TopicsMessageRateExceeded'; | ||||
|  | ||||
| 	const LIMIT_RATE_TOPICS_EXCEEDED = "TopicsMessageRateExceeded"; | ||||
|     /** | ||||
|      * @internal | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     protected $topic; | ||||
|  | ||||
| 	/** | ||||
| 	 * @internal | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	protected $topic; | ||||
|     /** | ||||
|      * @internal | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     protected $messageId; | ||||
|  | ||||
| 	/** | ||||
| 	 * @internal | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	protected $messageId; | ||||
|     /** | ||||
|      * @internal | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     protected $error; | ||||
|  | ||||
| 	/** | ||||
| 	 * @internal | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	protected $error; | ||||
|     /** | ||||
|      * @internal | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     protected $needRetry = false; | ||||
|  | ||||
| 	/** | ||||
| 	 * @internal | ||||
| 	 * @var bool | ||||
| 	 */ | ||||
| 	protected $needRetry = false; | ||||
|     /** | ||||
|      * TopicResponse constructor. | ||||
|      * | ||||
|      * @param \Psr\Http\Message\ResponseInterface $response | ||||
|      * @param Topics         $topic | ||||
|      */ | ||||
|     public function __construct(ResponseInterface $response, Topics $topic) | ||||
|     { | ||||
|         $this->topic = $topic; | ||||
|         parent::__construct($response); | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * TopicResponse constructor. | ||||
| 	 * | ||||
| 	 * @param GuzzleResponse $response | ||||
| 	 * @param Topics         $topic | ||||
| 	 */ | ||||
| 	public function __construct(GuzzleResponse $response, Topics $topic) | ||||
| 	{ | ||||
| 		$this->topic = $topic; | ||||
| 		parent::__construct($response); | ||||
| 	} | ||||
|     /** | ||||
|      * parse the response. | ||||
|      * | ||||
|      * @param $responseInJson | ||||
|      */ | ||||
|     protected function parseResponse($responseInJson) | ||||
|     { | ||||
|         if (!$this->parseSuccess($responseInJson)) { | ||||
|             $this->parseError($responseInJson); | ||||
|         } | ||||
|  | ||||
| 	/** | ||||
| 	 * parse the response | ||||
| 	 * | ||||
| 	 * @param $responseInJson | ||||
| 	 */ | ||||
| 	protected function parseResponse($responseInJson) | ||||
| 	{ | ||||
| 		if (!$this->parseSuccess($responseInJson)) { | ||||
| 			$this->parseError($responseInJson); | ||||
| 		} | ||||
|         if ($this->logEnabled) { | ||||
|             $this->logResponse(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| 		$this->logResponse(); | ||||
| 	} | ||||
|     /** | ||||
|      * @internal | ||||
|      * | ||||
|      * @param $responseInJson | ||||
|      */ | ||||
|     private function parseSuccess($responseInJson) | ||||
|     { | ||||
|         if (array_key_exists(self::MESSAGE_ID, $responseInJson)) { | ||||
|             $this->messageId = $responseInJson[ self::MESSAGE_ID ]; | ||||
|         } | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * @internal | ||||
| 	 * @param $responseInJson | ||||
| 	 */ | ||||
| 	private function parseSuccess($responseInJson) | ||||
| 	{ | ||||
| 		if (array_key_exists(self::MESSAGE_ID, $responseInJson)) { | ||||
| 			$this->messageId = $responseInJson[ self::MESSAGE_ID ]; | ||||
| 		} | ||||
| 	} | ||||
|     /** | ||||
|      * @internal | ||||
|      * | ||||
|      * @param $responseInJson | ||||
|      */ | ||||
|     private function parseError($responseInJson) | ||||
|     { | ||||
|         if (array_key_exists(self::ERROR, $responseInJson)) { | ||||
|             if (in_array(self::LIMIT_RATE_TOPICS_EXCEEDED, $responseInJson)) { | ||||
|                 $this->needRetry = true; | ||||
|             } | ||||
|  | ||||
| 	/** | ||||
| 	 * @internal  | ||||
| 	 * @param $responseInJson | ||||
| 	 */ | ||||
| 	private function parseError($responseInJson) | ||||
| 	{ | ||||
| 		if (array_key_exists(self::ERROR, $responseInJson)) { | ||||
| 			if (in_array(self::LIMIT_RATE_TOPICS_EXCEEDED, $responseInJson)) { | ||||
| 				$this->needRetry = true; | ||||
| 			} | ||||
|             $this->error = $responseInJson[ self::ERROR ]; | ||||
|         } | ||||
|     } | ||||
|  | ||||
| 			$this->error = $responseInJson[ self::ERROR ]; | ||||
| 		} | ||||
| 	} | ||||
|     /** | ||||
|      * Log the response. | ||||
|      */ | ||||
|     protected function logResponse() | ||||
|     { | ||||
|         $logger = new Logger('Laravel-FCM'); | ||||
|         $logger->pushHandler(new StreamHandler(storage_path('logs/laravel-fcm.log'))); | ||||
|  | ||||
| 	/** | ||||
| 	 * Log the response | ||||
| 	 */ | ||||
| 	protected function logResponse() | ||||
| 	{ | ||||
| 		$logger = new Logger('Laravel-FCM'); | ||||
| 		$logger->pushHandler(new StreamHandler(storage_path('logs/laravel-fcm.log'))); | ||||
|         $topic = $this->topic->build(); | ||||
|  | ||||
| 		$topic = $this->topic->build(); | ||||
| 		$logMessage = "notification send to topic: $topic"; | ||||
| 		if ($this->messageId) { | ||||
| 			$logMessage .= "with success (message-id : $this->messageId)"; | ||||
| 		} | ||||
| 		else { | ||||
| 			$logMessage .= "with error (error : $this->error)"; | ||||
| 		} | ||||
|         $logMessage = "notification send to topic: ".json_encode($topic); | ||||
|         if ($this->messageId) { | ||||
|             $logMessage .= "with success (message-id : $this->messageId)"; | ||||
|         } else { | ||||
|             $logMessage .= "with error (error : $this->error)"; | ||||
|         } | ||||
|  | ||||
| 		$logger->info($logMessage); | ||||
| 	} | ||||
|         $logger->info($logMessage); | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * true if topic sent with success | ||||
| 	 * @return bool | ||||
| 	 */ | ||||
| 	public function isSuccess() | ||||
| 	{ | ||||
| 		return (bool) $this->messageId; | ||||
| 	} | ||||
|     /** | ||||
|      * true if topic sent with success. | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function isSuccess() | ||||
|     { | ||||
|         return (bool) $this->messageId; | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * return error message | ||||
| 	 * you should test if it's necessary to resent it | ||||
| 	 * | ||||
| 	 * @return string error | ||||
| 	 */ | ||||
| 	public function error() | ||||
| 	{ | ||||
| 		return $this->error; | ||||
| 	} | ||||
|     /** | ||||
|      * return error message | ||||
|      * you should test if it's necessary to resent it. | ||||
|      * | ||||
|      * @return string error | ||||
|      */ | ||||
|     public function error() | ||||
|     { | ||||
|         return $this->error; | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * return true if it's necessary resent it using exponential backoff | ||||
| 	 * | ||||
| 	 * @return bool | ||||
| 	 */ | ||||
| 	public function shouldRetry() | ||||
| 	{ | ||||
| 		return $this->needRetry; | ||||
| 	} | ||||
| } | ||||
|     /** | ||||
|      * return true if it's necessary resent it using exponential backoff. | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function shouldRetry() | ||||
|     { | ||||
|         return $this->needRetry; | ||||
|     } | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Manish Verma
					Manish Verma