Žiadny popis

ayn2op c262f03380 refactor(cmd): update channel sorting to use `slices.SortFunc` and `cmp.Compare` instead of `sort.Slice` 5 mesiacov pred
.github e39b764856 ci: update actions/{checkout,setup-go} version 7 mesiacov pred
cmd c262f03380 refactor(cmd): update channel sorting to use `slices.SortFunc` and `cmp.Compare` instead of `sort.Slice` 5 mesiacov pred
internal 6033c923fd feat(logger): switch to text handler for slog from tint (#622) 5 mesiacov pred
nix 2c1546a81a build(nix): update vendorHash 11 mesiacov pred
.gitignore e976dc6537 refactor: unexport local symbols 11 mesiacov pred
LICENSE 51fa556cd4 SWITCH TO A SUPERIOR LICENSE 1 rok pred
README.md a5b847afe9 docs(README): mention alternative method to set token 5 mesiacov pred
flake.lock 1e316ebbb5 add nix 11 mesiacov pred
flake.nix 1e316ebbb5 add nix 11 mesiacov pred
go.mod 735e29604a build: go mod tidy 5 mesiacov pred
go.sum 735e29604a build: go mod tidy 5 mesiacov pred
main.go 647ce6f9ec refactor(cmd): use cobra for CLI parsing 5 mesiacov pred

README.md

Discordo · discord ci Go Report Card license

Discordo is a lightweight, secure, and feature-rich Discord terminal client. Heavily work-in-progress, expect breaking changes.

Preview

Features

  • Lightweight
  • Configurable
  • Mouse & clipboard support
  • Attachments
  • Notifications
  • 2-Factor & QR code authentication
  • Discord-flavored markdown

Installation

Prebuilt binaries

You can download and install a prebuilt binary here for Windows, macOS, or Linux.

Package managers

  • Arch Linux: yay -S discordo-git
  • Gentoo (available on the guru repos as a live ebuild): emerge net-im/discordo
  • FreeBSD: pkg install discordo or via the ports system make -C /usr/ports/net-im/discordo install clean.
  • Nix (NixOS, home-manager)
    • Downstream nixpkgs installation: Add pkgs.discordo to environment.systemPackages or home.packages.
    • Upstream flake installation: Add inputs.discordo.url = "github:ayn2op/discordo". Install using inputs.discordo.homeModules.default (.enable, .package, .settings TOML).
  • Windows (Scoop):

    scoop bucket add vvxrtues https://github.com/vvirtues/bucket
    scoop install discordo
    

Building from source

git clone https://github.com/ayn2op/discordo
cd discordo
go build .

Wayland clipboard support

x11-dev is required for X11 clipboard compatibility:

  • Ubuntu: apt install xwayland
  • Arch Linux: pacman -S xorg-xwayland

Usage

  1. Run the discordo executable with no arguments.

If you are logging in using an authentication token, provide the token command-line flag to the executable (eg: --token "OTI2MDU5NTQxNDE2Nzc5ODA2.Yc2KKA.2iZ-5JxgxG-9Ub8GHzBSn-NJjNg"). Alternatively, set the value of the DISCORDO_TOKEN environment variable to the authentication token. The token is stored securely in the default OS-specific keyring.

  1. Enter your email and password and click on the "Login" button to continue.

Configuration

The configuration file allows you to configure and customize the behavior, keybindings, and theme of the application.

  • Unix: $XDG_CONFIG_HOME/discordo/config.toml or $HOME/.config/discordo/config.toml
  • Darwin: $HOME/Library/Application Support/discordo/config.toml
  • Windows: %AppData%/discordo/config.toml

Discordo uses the default configuration if a configuration file is not found in the aforementioned path; however, the default configuration file is not written to the path. The default configuration can be found here.

FAQ

Manually adding token to keyring

Do this if you get the error:

failed to get token from keyring: secret not found in keyring

Windows

Run the following command in a terminal window. Replace YOUR_DISCORD_TOKEN with your authentication token.

cmdkey /add:discordo /user:token /pass:YOUR_DISCORD_TOKEN

MacOS

Run the following command in a terminal window. Replace YOUR_DISCORD_TOKEN with your authentication token.

security add-generic-password -s discordo -a token -w "YOUR_DISCORD_TOKEN"

Linux

  1. Start the keyring daemon.

    eval $(gnome-keyring-daemon --start)
    export $(gnome-keyring-daemon --start)
    
  2. Create the login keyring if it does not exist already. See GNOME/Keyring for more information.

  3. Run the following command to create the token entry.

    secret-tool store --label="Discord Token" service discordo username token
    
  4. When it prompts for the password, paste your token, and hit enter to confirm.

[!IMPORTANT] Automated user accounts or "self-bots" are against Discord's Terms of Service. I am not responsible for any loss caused by using "self-bots" or Discordo.