Код запускается кроном каждые 30 минут:
КОД<?php
/**
* Created by PhpStorm.
* User: igrek
* Date: 03.12.2018
* Time: 2:08
*/
header("Cache-Control: no-store, no-cache, must-revalidate");
header("Expires: " . date("r"));
include '../partials/db.php';
require '../vendor/autoload.php'; //Подключаем библиотеку
use Telegram\Bot\Api;
/*
* Подтягиваем данные с гугл таблицы и отсылаем в телеграмм об изменениях
*/
$telegram = new Api('TOKEN'); //Устанавливаем токен, полученный у BotFather
$query = mysqli_query($db, "SELECT * FROM new_offer");
while ($result = mysqli_fetch_array($query)) {
if ($result['google_num'] != 0) {
/*
* Google таблица
*/
$client = new \Google_Client();
$client->setApplicationName('Managment');
$client->setScopes([\Google_Service_Sheets::SPREADSHEETS]);
$client->setAccessType('offline');
$client->setAuthConfig('./managment.json');
$service = new \Google_Service_Sheets($client);
$spreadsheetId = 'TOKEN';
$range = '1 - потенциальные офферы!M' . $result['google_num'] . ':N' . $result['google_num'];
$response = $service->spreadsheets_values->get($spreadsheetId, $range);
$info = $response->getValues();
$status_manage = $info[0][0];
$name_manage = '('.$info[0][1].')';
if($result['google_status'] != $status_manage){
mysqli_query($db, "UPDATE `new_offer` SET `google_status`='".$status_manage."',`google_name`='".$name_manage."' WHERE `id`='".$result['id']."'");
echo $status_manage.' '.$name_manage.' '.$result['id'].'<br>';
$reply = "Оффер: ".$result['name'].
"\nПредыдущий статус: ".$result['google_status'].
"\nСтатус обновлен: $status_manage $name_manage";
$telegram->sendMessage([ 'chat_id' => $chat_id, 'parse_mode' => 'HTML', 'text' => $reply ]);
}
}
}
/*
* Google таблица END
*/
?>
Скрипт отслеживает изменения в таблице Гугла, и записывает их в базу
UPDATE
Заметил что последние две добавленные записи, не UPDATятся. Если изменить запись до этих двух записей то UPDATE делает везде и всё вроде бы ок, но это только если я заапдейтил запись до этих двух записей, все новые записи теперь не адпдейтит -_-
Вот эти ячейки уже не апдейтит:
P.S. Надеюсь нормально объяснил