Обсуждение статьи "Создание бота для Telegram на языке MQL5" - страница 6

 

Ошибки очень понятны и точно соответствуют действительности.

Компилятор предупреждает, что не может найти включаемый файл.

В включаемом файле содержатся недостающие функции, поэтому и возникают дополнительные ошибки.

Вы должны убедиться, что файл telegram.mqh существует в папке files.

Начните с него, так как есть еще ошибки, которые, по-видимому, связаны с другими проблемами кода.
 

Можно ли сделать это из пользовательского индикатора, а не из советника?

 
Franky Frentiono Nangoy:

Можно ли сделать это не из советника, а из пользовательского индикатора?

Если попытаться вызвать функцию WebRequest из индикатора, то GetLastError() вернет ошибку 4014 - "Функция не разрешена для вызова".

Для этого необходимо переделать проект для работы с Wininet.dll из индикаторов.

Documentation on MQL5: Common Functions / WebRequest
Documentation on MQL5: Common Functions / WebRequest
  • www.mql5.com
Common Functions / WebRequest - Reference on algorithmic/automated trading language for MetaTrader 5
 
Andrey Voytenko:

Если попытаться вызвать функцию WebRequest из индикатора, то GetLastError() вернет ошибку 4014 - "Функция не разрешена для вызова".

Для этого необходимо переделать проект для работы с Wininet.dll из индикаторов.


Спасибо, посмотрим

 

заглянуть в

<Telegram.mqh>
{ 
   "ok":true,
   "result":[ 
      { 
         "update_id":349778698,
         "message":{ 
            "message_id":2,
            "from":{ 
               "id":198289825,
               "first_name":"Andriy",
               "last_name":"Voitenko",
               "username":"avaticks"
            },
            "chat":{ 
               "id":198289825,
               "first_name":"Andriy",
               "last_name":"Voitenko",
               "username":"avaticks",
               "type":"private"
            },
            "date":1459775817,
            "text":"\/start"
         }
      }
   ]
}
 

Aimak:

Буду признателен, если вы поможете мне найти ошибку. Заранее спасибо.

Переключите свой канал в публичный режим. Или используйте chatID (а не имя канала) для связи с вашим приватным каналом.

 
Aimak:

Канал является общедоступным, и я получаю тот же результат, используя имя канала или ID. См. скриншот

Вы используете последнюю версию Telegram.mqh и Jason.mqh?

 

Уважаемый Андрей,

большое спасибо за вашу работу. Я установил ваши файлы и настроил эксперта, который делает следующее:

1) эксперт отправляет сообщения боту каждые x минут (просто для теста),

2) я читаю сообщение в telegram и нажимаю "открыть сделку" на клавиатуре клиента telegram,

3) метатрейдер открывает сделку (если это возможно).

Все работает хорошо, но через некоторое время бот перестает быть доступным; чтобы заставить его снова работать, я должен разбудить его, нажав какую-нибудь команду в меню клавиатуры (например, charts или /start или account info....). Метатрейдер пишет "bad request:chat not found", но если я снова разбужу бота, он прекрасно работает в течение часа или более, но затем останавливается.

Я создал бота, как вы посоветовали (с помощью botFather). Как я могу решить эту проблему?

Еще раз спасибо

Файлы:
error.gif  26 kb
 

Спасибо за интересную статью. Есть ошибка в коде (на скриншоте видно):

Ошибка при отправке фото, заголовок

Требуются исправления в методе SendPhoto класса CCustomBot. Предлагаю такой вариант:

   int SendPhoto(const string _channel_name,
                 const string _local_path,
                 string &_photo_id,
                 const string _caption=NULL,
                 const bool _common_flag=false,
                 const int _timeout=10000)
     {
      //---
      // const long _chat_id
      //---
      
      if(m_token==NULL)
         return(ERR_TOKEN_ISEMPTY);

      string name=StringTrim(_channel_name);
      if(StringGetCharacter(name,0)!='@')
         name="@"+name;
      
      
      ResetLastError();
      //--- copy file to memory buffer
      if(!FileIsExist(_local_path,_common_flag))
         return(ERR_FILE_NOT_EXIST);

      //---
      int flags=FILE_READ|FILE_BIN|FILE_SHARE_WRITE|FILE_SHARE_READ;
      if(_common_flag)
         flags|=FILE_COMMON;

      //---
      int file=FileOpen(_local_path,flags);
      if(file<0)
         return(_LastError);

      //---
      int file_size=(int)FileSize(file);
      uchar photo[];
      ArrayResize(photo,file_size);
      FileReadArray(file,photo,0,file_size);
      FileClose(file);

      //--- create boundary: (data -> base64 -> 1024 bytes -> md5)
      uchar base64[];
      uchar key[];
      CryptEncode(CRYPT_BASE64,photo,key,base64);
      //---
      uchar temp[1024]={0};
      ArrayCopy(temp,base64,0,0,1024);
      //---
      uchar md5[];
      CryptEncode(CRYPT_HASH_MD5,temp,key,md5);
      //---
      string hash=NULL;
      int total=ArraySize(md5);
      for(int i=0;i<total;i++)
         hash+=StringFormat("%02X",md5[i]);
      hash=StringSubstr(hash,0,16);
      //---

      //--- WebRequest
      uchar result[];
      string result_headers;

      string url=StringFormat("%s/bot%s/sendPhoto",TELEGRAM_BASE_URL,m_token);

      string part1="Content-Type: multipart/form-data; boundary="+hash+"\r\n";
      part1+="\r\n";

      //--- add chart_id
      part1+="--"+hash+"\r\n";
      part1+="Content-Disposition: form-data; name=\"chat_id\"\r\n";
      part1+="\r\n";
      part1+=name; //IntegerToString(_chat_id);
      part1+="\r\n";

      //--- add caption
      if(_caption!=NULL)
        {
         part1+="--"+hash+"\r\n";
         part1+="Content-Disposition: form-data; name=\"caption\"\r\n";
         //part1+="Content-Type: text/plain\r\n";
         //part1+="Content-Transfer-Encoding: quoted-printable\r\n";
         part1+="\r\n";
         //part1+=UrlEncode(_caption);
         part1+=_caption;
         part1+="\r\n";
        }

      //--- add image
      part1+="--"+hash+"\r\n";
      part1+="Content-Disposition: form-data; name=\"photo\"; filename=\"lampash.gif\"\r\n";
      part1+="\r\n";

      //--- 1
      uchar array1[];
      int size1=StringLen(part1);
      StringToCharArray(part1,array1,0,size1);

      //--- 2
      //photo
      int size2=ArraySize(photo);

      //---
      string part3="\r\n--"+hash+"--\r\n";
      int size3=StringLen(part3);
      uchar array3[];
      StringToCharArray(part3,array3,0,size3);

      //---
      uchar data[];
      ArrayResize(data,size1+size2+size3);
      ArrayCopy(data,array1,0);
      ArrayCopy(data,photo,size1);
      ArrayCopy(data,array3,size1+size2);

      //---
      string headers="Content-Type: multipart/form-data; boundary="+hash+"\r\n";
      int res=WebRequest("POST",url,headers,_timeout,data,result,result_headers);
      if(res==200)//OK
        {
         //--- delete BOM
         int start_index=0;
         int size=ArraySize(result);
         for(int i=0; i<fmin(size,8); i++)
           {
            if(result[i]==0xef || result[i]==0xbb || result[i]==0xbf)
               start_index=i+1;
            else
               break;
           }

         //---
         string out=CharArrayToString(result,start_index,WHOLE_ARRAY,CP_UTF8);

         //--- parse result
         CJAVal js(NULL,jtUNDEF);
         bool done=js.Deserialize(out);
         if(!done)
            return(ERR_JSON_PARSING);

         //--- get error description
         bool ok=js["ok"].ToBool();
         if(!ok)
            return(ERR_JSON_NOT_OK);

         total=ArraySize(js["result"]["photo"].m_e);
         for(int i=0; i<total; i++)
           {
            CJAVal image=js["result"]["photo"].m_e[i];

            long image_size=image["file_size"].ToInt();
            if(image_size<=file_size)
               _photo_id=image["file_id"].ToStr();
           }

         return(0);
        }
      else
        {
         if(res==-1)
           {
            string out=CharArrayToString(result,0,WHOLE_ARRAY,CP_UTF8);
            //Print(out);
            return(_LastError);
           }
         else
           {
            if(res>=100 && res<=511)
              {
               string out=CharArrayToString(result,0,WHOLE_ARRAY,CP_UTF8);
               //Print(out);
               return(ERR_HTTP_ERROR_FIRST+res);
              }
            return(res);
           }
        }
      //---        
      return(0);
     }
 
Andrey Emelyanov:

Спасибо за интересную статью. Есть ошибка в коде (на скриншоте видно):

Требуются исправления в методе SendPhoto класса CCustomBot. Предлагаю такой вариант:

Благодарю за сообщение. Однако, ваш исправленный вариант работает только с латиницей.

По логике, нужно преобразовать строку в массив с кодировкой UTF-8 и подставить в качестве caption в тело запроса.

Мой вариант в приложении.

Файлы:
Telegram.mqh  64 kb