discord.js/packages/core
Jiralite 4f59b740d0
feat: Premium buttons (#10353)
* feat: premium buttons

* docs: deprecation string

* feat(InteractionResponses): add deprecation message

* feat(builders): add tests

* chore: remove @ts-expect-errors

* test: update method name

* refactor(formatters): stricter types

* docs: deprecate method in typings

---------

Co-authored-by: kodiakhq[bot] <49736102+kodiakhq[bot]@users.noreply.github.com>
2024-07-04 18:57:35 +00:00
..
docs chore: refactor workspace 2023-05-03 02:14:22 +02:00
src feat: Premium buttons (#10353) 2024-07-04 18:57:35 +00:00
.cliff-jumperrc.json chore: No identifier base in development versions (#9848) 2023-10-03 19:24:13 +00:00
.gitignore chore: refactor workspace 2023-05-03 02:14:22 +02:00
.lintstagedrc.js build: multi-config build and dep update 2023-11-14 01:26:22 +01:00
.prettierignore build: ignores/swap/concurrency 2023-08-24 21:58:34 +02:00
.prettierrc.js build: multi-config build and dep update 2023-11-14 01:26:22 +01:00
api-extractor.json feat(website): add support for source file links (#9048) 2023-01-12 13:49:11 +01:00
CHANGELOG.md chore(core): release @discordjs/core@1.2.0 2024-05-04 20:50:15 +03:00
cliff.toml build: git-cliff config 2023-04-02 01:55:39 +02:00
LICENSE
package.json build: Bump discord-api-types to 0.37.90 (#10354) 2024-06-18 18:37:16 +00:00
README.md chore: update engine field in packages & deploy website manually 2023-11-08 00:25:38 +01:00
tsconfig.docs.json build: fix the messy dependency graph 2023-11-09 00:13:01 +01:00
tsconfig.eslint.json build: fix the messy dependency graph 2023-11-09 00:13:01 +01:00
tsconfig.json build: fix the messy dependency graph 2023-11-09 00:13:01 +01:00
tsup.config.ts build: multi-config build and dep update 2023-11-14 01:26:22 +01:00


discord.js


Discord server npm version npm downloads Build status Code coverage

Vercel Cloudflare Workers

About

@discordjs/core is a thinly abstracted wrapper around the "core" components of the Discord API: REST, and gateway.

Installation

Node.js 18 or newer is required.

npm install @discordjs/core
yarn add @discordjs/core
pnpm add @discordjs/core

Example usage

import { REST } from '@discordjs/rest';
import { WebSocketManager } from '@discordjs/ws';
import { GatewayDispatchEvents, GatewayIntentBits, InteractionType, MessageFlags, Client } from '@discordjs/core';

// Create REST and WebSocket managers directly
const rest = new REST({ version: '10' }).setToken(process.env.DISCORD_TOKEN);

const gateway = new WebSocketManager({
	token: process.env.DISCORD_TOKEN,
	intents: GatewayIntentBits.GuildMessages | GatewayIntentBits.MessageContent,
	rest,
});

// Create a client to emit relevant events.
const client = new Client({ rest, gateway });

// Listen for interactions
// Each event contains an `api` prop along with the event data that allows you to interface with the Discord REST API
client.on(GatewayDispatchEvents.InteractionCreate, async ({ data: interaction, api }) => {
	if (interaction.type !== InteractionType.ApplicationCommand || interaction.data.name !== 'ping') {
		return;
	}

	await api.interactions.reply(interaction.id, interaction.token, { content: 'Pong!', flags: MessageFlags.Ephemeral });
});

// Listen for the ready event
client.once(GatewayDispatchEvents.Ready, () => console.log('Ready!'));

// Start the WebSocket connection.
gateway.connect();

Independent REST API Usage

// Create REST instance
const rest = new REST({ version: '10' }).setToken(token);

// Pass into API
const api = new API(rest);

// Fetch a guild using the API wrapper
const guild = await api.guilds.get('1234567891011');

Contributing

Before creating an issue, please ensure that it hasn't already been reported/suggested, and double-check the documentation.
See the contribution guide if you'd like to submit a PR.

Help

If you don't understand something in the documentation, you are experiencing problems, or you just need a gentle nudge in the right direction, please don't hesitate to join our official discord.js Server.