Skip to content
This repository has been archived by the owner on Jan 3, 2024. It is now read-only.
/ Discord.swift Public archive

A Discord API library written in Swift for creating your own bot.

License

Notifications You must be signed in to change notification settings

Defxult/Discord.swift

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

A Discord API library written in Swift.

Links

Key Features

  • Asynchronous functionality using async and await
  • Full application command support
    • Slash commands
    • Message commands
    • User commands
  • Full message components support
    • Buttons
    • Select menus
    • Modals/text input

Application Commands Example

import Discord

let bot = Bot(token: "...", intents: Intents.default)

bot.addSlashCommand(
    name: "example",
    description: "Example command",
    guildId: nil,
    onInteraction: { interaction in
        try! await interaction.respondWithMessage("This is an example", ephemeral: true)
    }
)

bot.addUserCommand(
    name: "Who is",
    guildId: 1234567890123456789,
    onInteraction: { interaction in
        try! await interaction.respondWithMessage("...")
    }
)

try! await bot.syncApplicationCommands() // Only needs to be done once
bot.run()

Event Listener Example

import Discord

let bot = Bot(token: "...", intents: Intents.default)

class MyListener : EventListener {
    override func onMessageCreate(message: Message) async {
        // Don't respond to our own message
        guard !message.author.isBot else {
            return
        }

        if message.content == "hi swifty" {
            try! await message.channel.send("Hello!")
        }
    }
}

try! bot.addListeners(MyListener(name: "example"))
bot.run()

Swift Package Manager

dependencies: [
    .package(url: "https://github.com/Defxult/Discord.swift.git", .exact("<version here>"))
]
// ...
dependencies: [
    .product(name: "Discord", package: "Discord.swift")
]