InlineQuery
extends TelegramObject
in package
This object represents an incoming inline query. When the user sends an empty query, your bot could return some default or trending results.
Source: https://core.telegram.org/bots/api#inlinequery
Table of Contents
Constants
- WireNames : array<string|int, mixed> = ['fromUser' => 'from']
Properties
- $bot : Bot|null
- $chatType : string|null
- $fromUser : User
- $id : string
- $location : Location|null
- $offset : string
- $query : string
Methods
- __construct() : mixed
- answer() : AnswerInlineQuery
- as_() : static
- Alias of withBot() for grep-translating aiogram code that uses obj.as_(bot).
- withBot() : static
- Returns a clone of $this with $bot rebound recursively. Walks every public property; nested `BotContextController` instances are rebound via their own `withBot`, arrays (including nested arrays of arbitrary depth — e.g.
Constants
WireNames
public
array<string|int, mixed>
WireNames
= ['fromUser' => 'from']
Properties
$bot read-only
public
Bot|null
$bot
= null
$chatType read-only
public
string|null
$chatType
= null
$fromUser read-only
public
User
$fromUser
$id read-only
public
string
$id
$location read-only
public
Location|null
$location
= null
$offset read-only
public
string
$offset
$query read-only
public
string
$query
Methods
__construct()
public
__construct(string $id, User $fromUser, string $query, string $offset[, string|null $chatType = null ][, Location|null $location = null ][, Bot|null $bot = null ]) : mixed
Parameters
answer()
public
answer(array<int, InlineQueryResult> $results[, int|null $cacheTime = null ][, bool|null $isPersonal = null ][, string|null $nextOffset = null ][, InlineQueryResultsButton|null $button = null ]) : AnswerInlineQuery
Parameters
- $results : array<int, InlineQueryResult>
- $cacheTime : int|null = null
- $isPersonal : bool|null = null
- $nextOffset : string|null = null
- $button : InlineQueryResultsButton|null = null
Return values
AnswerInlineQueryas_()
Alias of withBot() for grep-translating aiogram code that uses obj.as_(bot).
public
as_(Bot|null $bot) : static
IMPORTANT: behaves DIFFERENTLY from upstream — upstream mutates self.bot in place and returns self. The PHP port can't mutate readonly, so this returns a clone. Callers must reassign: $msg = $msg->as($bot).
Parameters
- $bot : Bot|null
Return values
staticwithBot()
Returns a clone of $this with $bot rebound recursively. Walks every public property; nested `BotContextController` instances are rebound via their own `withBot`, arrays (including nested arrays of arbitrary depth — e.g.
public
withBot(Bot|null $bot) : static
list<list<KeyboardButton>>) are walked element-wise. Plain values
(scalars, DateTime, enums, InputFile etc.) pass through untouched.
Mirrors upstream pydantic model_validate(context={"bot": bot}) (aiogram
ContextController.as_/model_dump_json+model_validate).
Scope note: PHP 8.5 treats public readonly as effectively
public protected(set) readonly for clone-with — only code running with
a scope in the property's declaring class hierarchy (declaring class plus
its ancestors and descendants) can use clone($obj, ['x' => ...]) against
it. Because this method lives on BotContextController and every
TelegramObject/TelegramMethod subclass extends it, the walker's
clone($this, [...]) call legally rewrites subclass-declared readonly
slots like Message::$chat. External callers cannot use the same syntax
— they must funnel through this method.
Parameters
- $bot : Bot|null