Превышено максимальное время выполнения 60 секунд - PullRequest
0 голосов
/ 11 января 2020

У меня есть пара изображений, которые я хочу отправить на номер WhatsApp с помощью Twilio. Я хочу отправить текстовое сообщение только после того, как все изображения будут доставлены. При отправке изображения я указываю обратный вызов, который получает статус доставки и сохраняет его, используя redis. После того, как я позвонил, чтобы отправить эти изображения, я проверяю статусы доставки всех изображений, если ни одно из изображений не имеет статуса, равного нулю, я затем отправляю текстовое сообщение, иначе я делаю проверку, пока не получу статус доставки, который не равен нулю. Тем не менее, мое предлагаемое решение истекает. Я получаю эту ошибку - Maximum execution time of 60 seconds exceeded from Redis Даже изображения не отправляются. Смотрите прикрепленное изображение enter image description here

Вот что я делаю:

Route::get('test', function (){
    $redis = new \Predis\Client();
    $images = \App\ProductImage::where('product_id', 7)->get();

    foreach ($images as$image){
        $imgUrl = url(env('BOT_URL').'/images/'.$image['img_url']);
        $sid[] = \App\Libraries\Utilities::sendMediaMessage('+23xxxxx', '', $imgUrl);
    }
    foreach ($sid as $id){
        $statuses[] = $redis->get($id);
    }

    if(in_array(0, $statuses)){
           $check = \App\Libraries\Utilities::checkIfWhatsAppStatusHasChanged($sid);
        if ($check){
            \App\Libraries\Utilities::sendWhatsAppMessage('+23xxxxx', 'Send message - had to check');
        }
    }else{
        \App\Libraries\Utilities::sendWhatsAppMessage('+23xxxx', 'Send message ');
    }

});

Вот метод sendMediaMessage

 public static function sendMediaMessage($phone, $msg, $mediaUrl){
             try{

            $client = new Client(env('TWILIO_SID'), env('TWILIO_TOKEN'));
            $send = $client->messages->create(
                "whatsapp:".$phone, // Text this number
                array(
                    'from' => "whatsapp:".env('TWILIO_NUMBER'), // From a valid Twilio number
                    'body' => $msg,
                    'mediaUrl' => $mediaUrl,
                    'statusCallback' => url(env('BOT_URL').'/whatsapp-delivery-status')
                )
            );
            //
            if($send != false){
                $message_sid = $send->sid;
                return $message_sid;
            }

        }catch (\Exception $exception){
        }
    }

Здесь это метод обратного вызова -

   public function checkWhatsapDelivery(Request $request)
    {
        $redis = new Client();
        $body = $request->all();
        $messageSid = $body['MessageSid'];
        $MessageStatus = $body['MessageStatus'];
        $status_id = Utilities::getWhatsappMessageStatus($MessageStatus);
        $redis->set($messageSid, $status_id);
    }

Вот метод getWhatsappMessageStatus

 public static function getWhatsappMessageStatus($status){
        switch (strtolower($status)){
            case 'queued':
                $id = 1;
                break;
            case 'failed':
                $id = 2;
                break;
            case 'sent':
                $id = 3;
                break;
            case 'delivered':
                $id = 4;
                break;
            case 'read':
                $id = 5;
                break;
            default:
                $id = 0;
        }
        return $id;
    }

Вот метод checkIfWhatsAppStatusHasChanged

  public static function checkIfWhatsAppStatusHasChanged($sids){
        $statuses = self::getWhatsAppStatuses($sids);
        if(in_array(0, $statuses)){
            self::checkIfWhatsAppStatusHasChanged($sids);
        }else{
            return true;
        }
    }

Вот метод getWhatsAppStatuses

public static function getWhatsAppStatuses($sids){
        $redis = new \Predis\Client();
        foreach ($sids as $id){
            $statuses[] = $redis->get($id);
        }
        return $statuses;
}

Пожалуйста, что я делаю не так?

1 Ответ

0 голосов
/ 11 января 2020

Проверьте файл php.ini, расположенный в C:\xampp\php\php.ini (windows) и opt/lampp/etc/php.ini в linux. Здесь max_execution_time = 60 секунд по умолчанию. Поэтому вы должны увеличить max_execution_time для отправки / публикации данных большого размера.

...