PromoteChatMember
extends TelegramMethod
in package
Use this method to promote or demote a user in a supergroup or a channel. The bot must be an administrator in the chat for this to work and must have the appropriate administrator rights. Pass False for all boolean parameters to demote a user. Returns True on success.
Source: https://core.telegram.org/bots/api#promotechatmember
Tags
Table of Contents
Constants
- ApiMethod : string = 'promoteChatMember'
- ReturnsType : string = 'bool'
- Subclasses override with either: - a `class-string<TelegramObject>` (e.g. Message::class) for object returns - a scalar type name ('bool', 'int', 'string') for primitive returns - 'list:<inner>' for array returns
Properties
- $bot : Bot|null
- $canChangeInfo : bool|null
- $canDeleteMessages : bool|null
- $canDeleteStories : bool|null
- $canEditMessages : bool|null
- $canEditStories : bool|null
- $canInviteUsers : bool|null
- $canManageChat : bool|null
- $canManageDirectMessages : bool|null
- $canManageTags : bool|null
- $canManageTopics : bool|null
- $canManageVideoChats : bool|null
- $canPinMessages : bool|null
- $canPostMessages : bool|null
- $canPostStories : bool|null
- $canPromoteMembers : bool|null
- $canRestrictMembers : bool|null
- $chatId : int|string
- $isAnonymous : bool|null
- $userId : int
Methods
- __construct() : mixed
- as_() : static
- Alias of withBot() for grep-translating aiogram code that uses obj.as_(bot).
- bindBot() : static
- Returns a clone bound to $bot. Used by hand-authored shortcut methods (Message::answer, etc.) so the chained ->emit() picks up the bot without an explicit argument.
- emit() : TReturn
- Emit this method via the bound bot (or the explicitly-passed 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
ApiMethod
public
string
ApiMethod
= 'promoteChatMember'
ReturnsType
Subclasses override with either: - a `class-string<TelegramObject>` (e.g. Message::class) for object returns - a scalar type name ('bool', 'int', 'string') for primitive returns - 'list:<inner>' for array returns
public
string
ReturnsType
= 'bool'
Stays '' on the abstract base — Phase 2 codegen sets it per concrete method.
Properties
$bot read-only
public
Bot|null
$bot
= null
$canChangeInfo read-only
public
bool|null
$canChangeInfo
= null
$canDeleteMessages read-only
public
bool|null
$canDeleteMessages
= null
$canDeleteStories read-only
public
bool|null
$canDeleteStories
= null
$canEditMessages read-only
public
bool|null
$canEditMessages
= null
$canEditStories read-only
public
bool|null
$canEditStories
= null
$canInviteUsers read-only
public
bool|null
$canInviteUsers
= null
$canManageChat read-only
public
bool|null
$canManageChat
= null
$canManageDirectMessages read-only
public
bool|null
$canManageDirectMessages
= null
$canManageTags read-only
public
bool|null
$canManageTags
= null
$canManageTopics read-only
public
bool|null
$canManageTopics
= null
$canManageVideoChats read-only
public
bool|null
$canManageVideoChats
= null
$canPinMessages read-only
public
bool|null
$canPinMessages
= null
$canPostMessages read-only
public
bool|null
$canPostMessages
= null
$canPostStories read-only
public
bool|null
$canPostStories
= null
$canPromoteMembers read-only
public
bool|null
$canPromoteMembers
= null
$canRestrictMembers read-only
public
bool|null
$canRestrictMembers
= null
$chatId read-only
public
int|string
$chatId
$isAnonymous read-only
public
bool|null
$isAnonymous
= null
$userId read-only
public
int
$userId
Methods
__construct()
public
__construct(int|string $chatId, int $userId[, bool|null $isAnonymous = null ][, bool|null $canManageChat = null ][, bool|null $canDeleteMessages = null ][, bool|null $canManageVideoChats = null ][, bool|null $canRestrictMembers = null ][, bool|null $canPromoteMembers = null ][, bool|null $canChangeInfo = null ][, bool|null $canInviteUsers = null ][, bool|null $canPostStories = null ][, bool|null $canEditStories = null ][, bool|null $canDeleteStories = null ][, bool|null $canPostMessages = null ][, bool|null $canEditMessages = null ][, bool|null $canPinMessages = null ][, bool|null $canManageTopics = null ][, bool|null $canManageDirectMessages = null ][, bool|null $canManageTags = null ][, Bot|null $bot = null ]) : mixed
Parameters
- $chatId : int|string
- $userId : int
- $isAnonymous : bool|null = null
- $canManageChat : bool|null = null
- $canDeleteMessages : bool|null = null
- $canManageVideoChats : bool|null = null
- $canRestrictMembers : bool|null = null
- $canPromoteMembers : bool|null = null
- $canChangeInfo : bool|null = null
- $canInviteUsers : bool|null = null
- $canPostStories : bool|null = null
- $canEditStories : bool|null = null
- $canDeleteStories : bool|null = null
- $canPostMessages : bool|null = null
- $canEditMessages : bool|null = null
- $canPinMessages : bool|null = null
- $canManageTopics : bool|null = null
- $canManageDirectMessages : bool|null = null
- $canManageTags : bool|null = null
- $bot : Bot|null = null
as_()
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
staticbindBot()
Returns a clone bound to $bot. Used by hand-authored shortcut methods (Message::answer, etc.) so the chained ->emit() picks up the bot without an explicit argument.
public
bindBot(Bot|null $bot) : static
Parameters
- $bot : Bot|null
Return values
staticemit()
Emit this method via the bound bot (or the explicitly-passed bot).
public
emit([Bot|null $bot = null ]) : TReturn
Mirrors upstream methods/base.py:81-93 (await + emit).
Parameters
- $bot : Bot|null = null
Return values
TReturnwithBot()
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