ROR Firebase Уведомление

У меня есть вопрос, у меня есть работающий сценарий уведомления Firebase PHP, но я все еще отправляю уведомление локально через XAMPP, если я хочу, чтобы мой сервер RoR отправлял уведомление, нужно ли мне повторно кодировать весь сценарий PHP в сценарий ruby ? или я могу просто вызвать свой скрипт php с сервера RoR напрямую?

Ниже мой рабочий скрипт php.

function send_notification($tokens, $message)
{
$url = "https://fcm.googleapis.com/fcm/send";
$fields = array(
'registration_ids' => $tokens,
'data' => array("message"=> $message) ,
);

$headers = array(
'Authorization:key = AuthorizationKey',
'Content-Type: application/json'
);

$ch = curl_init();
curl_setopt($ch,CURLOPT_URL,$url);
curl_setopt($ch,CURLOPT_POST,true);
curl_setopt($ch,CURLOPT_HTTPHEADER,$headers);
curl_setopt($ch,CURLOPT_RETURNTRANSFER,true);
curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,0);
curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false);
curl_setopt($ch,CURLOPT_POSTFIELDS,json_encode($fields));

$result = curl_exec($ch);
if ($result === FALSE)
{
die('Curl Failed:' . curl_error($ch));
}
curl_close($ch);

return $result;
}

$conn = mysqli_connect("localhost","root","","demoflying");

$sql = "Select Token From Users";

$result = mysqli_query($conn,$sql);
$tokens = array();

if(mysqli_num_rows($result)>0)
{
while ($row = mysqli_fetch_assoc($result))
{
$tokens[] = $row["Token"];
}
}

mysqli_close($conn);

$fromCountry = "UK";
$toCountry= "US";

$message = array(
"FromCountry" => $fromCountry,
"ToCountry" => $toCountry,
);
$message_status = send_notification($tokens,$message);
echo $message_status;
?>

0

Решение

Можно запустить скрипт PHP, написав это php #{RAILS_ROOT}/public/php_script.php в вашем контроллере

0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]