2017-03-11 19:54:51 +01:00
---
title: searchChatMessages
description: Searches for messages with given words in the chat. Returns result in reverse chronological order, i. e. in order of decreasimg message_id. Doesn't work in secret chats
---
## Method: searchChatMessages
[Back to methods index ](index.md )
2017-06-06 18:39:21 +02:00
YOU CANNOT USE THIS METHOD IN MADELINEPROTO
2017-03-11 19:54:51 +01:00
Searches for messages with given words in the chat. Returns result in reverse chronological order, i. e. in order of decreasimg message_id. Doesn't work in secret chats
### Params:
| Name | Type | Required | Description |
|----------|:-------------:|:--------:|------------:|
2017-04-11 10:09:20 +02:00
|chat\_id|[InputPeer](../types/InputPeer.md) | Yes|Chat identifier to search in|
2017-03-11 19:54:51 +01:00
|query|[string](../types/string.md) | Yes|Query to search for|
|from\_message\_id|[long](../types/long.md) | Yes|Identifier of the message from which we need a history, you can use 0 to get results from beginning|
|limit|[int](../types/int.md) | Yes|Maximum number of messages to be returned, can't be greater than 100|
|filter|[SearchMessagesFilter](../types/SearchMessagesFilter.md) | Yes|Filter for content of searched messages|
### Return type: [Messages](../types/Messages.md)
### Example:
```
$MadelineProto = new \danog\MadelineProto\API();
2017-04-10 13:49:32 +02:00
if (isset($token)) { // Login as a bot
2017-06-19 18:56:47 +02:00
$MadelineProto->bot_login($token);
2017-03-11 19:54:51 +01:00
}
2017-04-10 13:49:32 +02:00
if (isset($number)) { // Login as a user
2017-03-11 19:54:51 +01:00
$sentCode = $MadelineProto->phone_login($number);
echo 'Enter the code you received: ';
$code = '';
for ($x = 0; $x < $sentCode['type']['length']; $x++) {
$code .= fgetc(STDIN);
}
$MadelineProto->complete_phone_login($code);
}
2017-07-23 16:33:46 +02:00
$Messages = $MadelineProto->searchChatMessages(['chat_id' => InputPeer, 'query' => 'string', 'from_message_id' => long, 'limit' => int, 'filter' => SearchMessagesFilter, ]);
2017-03-11 19:54:51 +01:00
```
2017-07-23 16:11:02 +02:00
Or, if you're using [PWRTelegram ](https://pwrtelegram.xyz ):
### As a bot:
POST/GET to `https://api.pwrtelegram.xyz/botTOKEN/madeline`
Parameters:
* method - searchChatMessages
2017-07-23 16:40:54 +02:00
* params - `{"chat_id": InputPeer, "query": "string", "from_message_id": long, "limit": int, "filter": SearchMessagesFilter, }`
2017-07-23 16:11:02 +02:00
2017-07-23 16:34:36 +02:00
2017-07-23 16:11:02 +02:00
### As a user:
POST/GET to `https://api.pwrtelegram.xyz/userTOKEN/searchChatMessages`
Parameters:
chat_id - Json encoded InputPeer
query - Json encoded string
from_message_id - Json encoded long
limit - Json encoded int
filter - Json encoded SearchMessagesFilter
2017-07-23 16:40:54 +02:00
2017-07-23 16:11:02 +02:00
2017-03-11 19:54:51 +01:00
Or, if you're into Lua:
```
2017-07-23 16:33:46 +02:00
Messages = searchChatMessages({chat_id=InputPeer, query='string', from_message_id=long, limit=int, filter=SearchMessagesFilter, })
2017-03-11 19:54:51 +01:00
```