I have used FCM with the legacy protocol but cannot find any concrete documentation to use the new FCM HTTP v1 API with php. I have managed to import the Google API Client Library into my project but cannot find any documentation or tutorials on how to obtain the access token for the required scopes for fcm messages.
37.6k 10 10 gold badges 145 145 silver badges 283 283 bronze badges asked Apr 11, 2018 at 18:28 Jude Fernandes Jude Fernandes 7,517 12 12 gold badges 54 54 silver badges 91 91 bronze badgesWell I do not know how you are doing since you did not code, what is that to send messages through FCM you have the api key in the configuration of your project in the same console of firebase, on the other hand, I leave unh repo in which I have a form to send notifications with firebase, look it up and see if it helps. REPOSITORY
Commented Apr 12, 2018 at 3:21@CarlosQuintero I looked at your code and you are using the older legacy way of sending fcm requests which I have already got, I wanted to know how to code for the new way using the HTTP v1 API with php
Commented Apr 12, 2018 at 5:05 Commented Apr 12, 2018 at 5:23@CarlosQuintero Thanks that seem like it should help , will try it out and mark yours as the correct answer once done.
Commented Apr 12, 2018 at 6:16Maybe a bit late, but this is how to retrieve an oath token to be used with the FCM HTTP v1 API.
public function configureClient() < $client = new Google_Client(); try < $client->setAuthConfig("include_your_private_json_key_path_here"); $client->addScope(Google_Service_FirebaseCloudMessaging::CLOUD_PLATFORM); // retrieve the saved oauth token if it exists, you can save it on your database or in a secure place on your server $savedTokenJson = $this->readFile(); if ($savedTokenJson != null) < // the token exists, set it to the client and check if it's still valid $client->setAccessToken($savedTokenJson); if ($client->isAccessTokenExpired()) < // the token is expired, generate a new token and set it to the client $accessToken = $this->generateToken($client); $client->setAccessToken($accessToken); > > else < // the token doesn't exist, generate a new token and set it to the client $accessToken = $this->generateToken($client); $client->setAccessToken($accessToken); > $oauthToken = $accessToken["access_token"]; // the client is configured, now you can send the push notification using the $oauthToken. > catch (Google_Exception $e) < // handle exception >>
private function generateToken($client) < $client->fetchAccessTokenWithAssertion(); $accessToken = $client->getAccessToken(); // save the oauth token json on your database or in a secure place on your server $tokenJson = json_encode($accessToken); $this->saveFile($tokenJson); return $accessToken; >
Please note that saveFile() and readFile() methods should be implemented as you prefer to store and retrieve the oath token json. Follow the migration guide for the payload structure.
answered May 18, 2020 at 14:28 4,130 4 4 gold badges 32 32 silver badges 55 55 bronze badgesif you just want to send notifications to apps use this, using a laravel library will just be an over kill for this task and this approach is far more easier to use.
Commented Aug 8, 2020 at 15:29 Hi, can you explain what is Google_Service_FirebaseCloudMessaging::CLOUD_PLATFORM for ? Commented Oct 20, 2022 at 6:20@RifkiMaulana this defines the scope for the Google Client. To send push notifications this scope would be enough: Google_Service_FirebaseCloudMessaging::FIREBASE_MESSAGING
Commented Oct 24, 2022 at 10:05 Liked your idea; really work for me. ~Thanks. Commented Jun 18 at 15:48Update July 2023
The batch messaging endpoint has been deprecated and will be removed in July 2024. The recommendation is to iterate through the tokens using the standard v1 api send method: https://firebase.google.com/docs/cloud-messaging/send-message#send-a-batch-of-messages
Here is example on how to send a notification to a single device:
/vendor/autoload.php'; function getOATHToken() < $client = new Google_Client(); try < $client->setAuthConfig(""); $client->addScope(Google_Service_FirebaseCloudMessaging::CLOUD_PLATFORM); $savedTokenJson = readSavedToken(); if ($savedTokenJson) < // the token exists, set it to the client and check if it's still valid $client->setAccessToken($savedTokenJson); $accessToken = $savedTokenJson; if ($client->isAccessTokenExpired()) < // the token is expired, generate a new token and set it to the client $accessToken = generateToken($client); $client->setAccessToken($accessToken); > > else < // the token doesn't exist, generate a new token and set it to the client $accessToken = generateToken($client); $client->setAccessToken($accessToken); > $oauthToken = $accessToken["access_token"]; return $oauthToken; > catch (Google_Exception $e) <> return false; > //Using a simple file to cache and read the toke, can store it in a databse also function readSavedToken() < $tk = @file_get_contents('token.cache'); if ($tk) return json_decode($tk, true); else return false; >function writeToken($tk) < file_put_contents("token.cache",$tk); >function generateToken($client) < $client->fetchAccessTokenWithAssertion(); $accessToken = $client->getAccessToken(); $tokenJson = json_encode($accessToken); writeToken($tokenJson); return $accessToken; > // Finally function sendNotification($token, $title, $body, $accessToken) < $payload = ["message" =>["token" => $token, "notification"=>["title" => $title, "body"=> $body]]]; $postdata = json_encode($payload); $opts = array('http' => array( 'method' => 'POST', 'header' => 'Content-Type: application/json' . "\r\nAuthorization: Bearer $accessToken", 'content' => $postdata ) ); $context = stream_context_create($opts); $result = file_get_contents('https://fcm.googleapis.com/v1/projects//messages:send', false, $context); echo "\n\n======RESPONSE======\n\n"; echo $result; > $token = "token-1"; //FCM Device token $title = "Test from PHP"; $body = "This is a test from PHP"; sendNotification($token, $title, $body, getOATHToken()); ?>
The batch sending example (now deprecated)
Here is a complete example on how to send a push to multiple tokens using the Google API PHP Client, using the FCM HTTP v1 api, as given in the FCM docs.
(Modified from lubilis answer above)
/vendor/autoload.php'; function getOATHToken() < $client = new Google_Client(); try < $client->setAuthConfig(""); $client->addScope(Google_Service_FirebaseCloudMessaging::CLOUD_PLATFORM); $savedTokenJson = readSavedToken(); if ($savedTokenJson) < // the token exists, set it to the client and check if it's still valid $client->setAccessToken($savedTokenJson); $accessToken = $savedTokenJson; if ($client->isAccessTokenExpired()) < // the token is expired, generate a new token and set it to the client $accessToken = generateToken($client); $client->setAccessToken($accessToken); > > else < // the token doesn't exist, generate a new token and set it to the client $accessToken = generateToken($client); $client->setAccessToken($accessToken); > $oauthToken = $accessToken["access_token"]; return $oauthToken; > catch (Google_Exception $e) <> return false; > //Using a simple file to cache and read the toke, can store it in a databse also function readSavedToken() < $tk = @file_get_contents('token.cache'); if ($tk) return json_decode($tk, true); else return false; >function writeToken($tk) < file_put_contents("token.cache",$tk); >function generateToken($client) < $client->fetchAccessTokenWithAssertion(); $accessToken = $client->getAccessToken(); $tokenJson = json_encode($accessToken); writeToken($tokenJson); return $accessToken; > // Finally function sendNotification($tokens, $title, $body, $accessToken) < $boundary = "--subrequest_boundary"; $multiPayload = $boundary; foreach ($tokens as $token) < $head = "Content-Type: application/http\r\n". "Content-Transfer-Encoding: binary\r\n\r\n". "POST /v1/projects//messages:send\r\n". "Content-Type: application/json\r\n". "accept: application/json\r\n\r\n"; $payload = ["message" => ["token" => $token, "notification"=>["title" => $title, "body"=> $body]]]; $postdata = json_encode($payload); $multiPayload .= "\r\n".$head.$postdata."\r\n".$boundary; > $multiPayload .= "--"; //Uncomment for debugging //echo "\n\n==== POST DATA====\n\n"; //echo $multiPayload; $opts = array('http' => array( 'method' => 'POST', 'header' => 'Content-Type: multipart/mixed; boundary="subrequest_boundary"' . "\r\nAuthorization: Bearer $accessToken", 'content' => $multiPayload ) ); //Uncomment for debugging //echo "\n\n==== HTTP OPTIONS====\n\n"; //var_dump($opts); $context = stream_context_create($opts); // This is the path for sending push multiple tokens (upto 500 as per the docs) $result = file_get_contents('https://fcm.googleapis.com/batch', false, $context); echo "\n\n======RESPONSE======\n\n"; echo $result; > $tokens = ["token-1","token-2"]; //FCM Device tokens as array $title = "Test from PHP"; $body = "This is a test from PHP"; sendNotification($tokens, $title, $body, getOATHToken()); ?>