-
-
Notifications
You must be signed in to change notification settings - Fork 249
Discord
Discord is the main object of your Discord BOT Application
Creates a Discord Bot client instance.
function __construct([array<string|int, mixed> $options = [] ]) : mixedReturn
- Discord the Bot client object
Example
$discord = new Discord([
'token' => 'bot-token',
]);Closes the Discord Bot client.
function close([bool $closeLoop = true ]) : voidExample
$discord->close();Creates a Part or Repository inside the Bot client.
function factory(string $class[, mixed $data = [] ][, bool $created = false ]) : Part|AbstractRepositoryThe use of factory with part is possible with the new Part($discord, $data, $created);
Return
- Part or AbstractRepository
Example
// Preferred way
$channel = new Channel($discord, ['name' => 'newchannel']);
// Is equivalent to:
$channel = $discord->factory(Channel::class, ['name' => 'newchannel']);Gets a channel from the Bot cache by Snowflake ID.
function getChannel(string|int $channel_id) : Channel|nullReturn
- Channel the Channel, Thread, or Private Channel Part
Example
$channel = $discord->getChannel('012345678910111213');Gets the factory being used by the Bot client.
function getFactory() : FactoryReturn
- Factory the Factory object
Example
$factory = $discord->getFactory();Gets the Discord HTTP client being used by the Bot client.
function getHttpClient() : HttpReturn
- Http the DiscordPHP Http object
Example
$httpClient = $discord->getHttpClient();Gets the PSR-3 logger being used by the Bot client.
function getLogger() : LoggerInterfaceReturn
- LoggerInterface the Logger interface
Example
$logger = $discord->getLogger();Gets the ReactPHP event loop loop being used by the Bot client.
function getLoop() : LoopInterfaceReturn
- LoopInterface Loop interface
Example
$loop = $discord->getLoop();Gets the bot voice client from a guild ID. Returns null if there is no voice client.
function getVoiceClient(string $guild_id) : VoiceClient|nullReturn
- VoiceClient the bot Voice Client
-
nullthe bot has no Voice Client
Example
$voiceClient = $discord->getVoiceClient('012345678910111213');Joins a voice channel.
function joinVoiceChannel(Channel $channel[, bool $mute = false ][, bool $deaf = true ][, LoggerInterface|null $logger = null ][, bool $check = true ]) : PromiseInterfaceReturn
- PromiseInterface the promise when Bot has joined the voice channel
Example
$channel = $discord->getChannel('0123456789'); // Get the voice channel by ID
$discord->joinVoiceChannel($channel)->done(function (VoiceClient $vc) {
echo "Joined voice channel.\r\n";
$vc->playFile('myaudio.mp3');
}, function ($e) {
echo "There was an error joining the voice channel: {$e->getMessage()}\r\n";
});Run the Bot client, starts the ReactPHP event loop.
function run() : voidExample
// Should be placed at bottom of the script
$discord->run();Updates the Bot client's presence and status.
function updatePresence([Activity|null $activity = null ][, bool $idle = false ][, string $status = 'online' ][, bool $afk = false ]) : voidSee Activity
API Documentation: https://discord.com/developers/docs/topics/gateway#update-presence
Example
$activity = new Activity($discord, [
'name' => 'https://www.youtube.com/watch?v=dQw4w9WgXcQ',
'type' => Activity::TYPE_WATCHING
]);
$discord->updatePresence($activity);To handle various events from Discord, you can use $discord->on(string EVENTNAME, callable CALLBACK);
Unlike "READY", this event is emitted once when the Discord BOT is ready (e.g. after start-up tasks like loadAllMembers is done).
Gateway event listeners should be registered inside this event.
Example
$discord->on('ready', function ($discord) {
echo "Bot is ready.", PHP_EOL;
});This event is called when the Bot client's web socket has successfully reconnected to Discord server.
Example
$discord->on('reconnected', function ($discord) {
echo "Bot is reconnected.", PHP_EOL;
});This event is called when $discord->close() is called.
Example
$discord->on('closed', function ($discord) {
// do something, e.g. clean up
});This is only for advanced users.
This event is called when any enabled events from gateway is dispatched from the Bot client's web socket containing the raw data, before the respective Repository and Part is formed.
Example
$discord->on('raw', function ($data, $discord) {
// $data contains the payload after json_decode()
});This is only for advanced users.
This event is called the Bot client's web socket error occurred. The web socket connection is immediately closed so you cannot interrupt this event.
Example
$discord->on('error', function ($error, $discord) {
// do something e.g. log the error or do clean up
});Note: This wiki is currently Work In Progress. Consider reading the docs instead.
- Application Command (Slash based)
Command Client (Message based)
- Activity
- Application
- Guild
- Private Channel
- User
Components
-
ActionRow
- Buttons
- Option (commands)
- SelectMenu
- TextInput
Builders