{"id":49735675,"url":"https://github.com/chojs23/concord","last_synced_at":"2026-06-07T10:01:12.376Z","repository":{"id":356547469,"uuid":"1233111215","full_name":"chojs23/concord","owner":"chojs23","description":"A feature-rich TUI client for Discord, written in Rust.","archived":false,"fork":false,"pushed_at":"2026-05-14T13:40:24.000Z","size":3296,"stargazers_count":333,"open_issues_count":15,"forks_count":18,"subscribers_count":3,"default_branch":"main","last_synced_at":"2026-05-14T13:45:59.955Z","etag":null,"topics":["chat-client","cli","discord","discord-client","ratatui","rust","terminal","terminal-ui","tui"],"latest_commit_sha":null,"homepage":"https://github.com/chojs23/concord","language":"Rust","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"gpl-3.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/chojs23.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":"CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2026-05-08T15:51:03.000Z","updated_at":"2026-05-14T13:40:28.000Z","dependencies_parsed_at":"2026-05-11T10:01:19.055Z","dependency_job_id":null,"html_url":"https://github.com/chojs23/concord","commit_stats":null,"previous_names":["chojs23/concord"],"tags_count":10,"template":false,"template_full_name":null,"purl":"pkg:github/chojs23/concord","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/chojs23%2Fconcord","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/chojs23%2Fconcord/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/chojs23%2Fconcord/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/chojs23%2Fconcord/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/chojs23","download_url":"https://codeload.github.com/chojs23/concord/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/chojs23%2Fconcord/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":33068894,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-15T11:35:32.926Z","status":"ssl_error","status_checked_at":"2026-05-15T11:35:31.362Z","response_time":103,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.5:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["chat-client","cli","discord","discord-client","ratatui","rust","terminal","terminal-ui","tui"],"created_at":"2026-05-09T08:09:56.185Z","updated_at":"2026-06-07T10:01:12.368Z","avatar_url":"https://github.com/chojs23.png","language":"Rust","funding_links":[],"categories":["Rust","Applications","Table of Contents","Entertainment","💻 Apps"],"sub_categories":["Social networks","Chat","🤡 Social Media"],"readme":"# Concord\n\n\u003cimg width=\"1613\" height=\"848\" alt=\"concord - a feature-rich TUI client for\n  Discord\" src=\"./docs/example.png\" /\u003e\n\nConcord is a feature-rich TUI (terminal user interface) client for Discord, written in Rust with ratatui. Full Discord experience, right in your terminal.\n\n## Table of contents\n\n- [Installation](#installation)\n- [Features](#features)\n- [Configuration](#configuration)\n- [Performance](#performance)\n- [FAQ](#faq)\n- [Security](#security)\n- [Contributing](#contributing)\n- [License](#license)\n\n## Installation\n\n### Homebrew\n\n```sh\nbrew install chojs23/tap/concord\n```\n\n### npm\n\n```sh\nnpm install -g @chojs23/concord\n```\n\nYou can also run Concord without a global install:\n\n```sh\nnpx @chojs23/concord\n```\n\nThe npm package installs a prebuilt binary from the GitHub Release artifacts.\n\n### Cargo\n\nInstall native audio dependencies first. On macOS with Homebrew:\n\n```sh\nbrew install opus pkg-config\n```\n\nOn Fedora:\n\n```sh\nsudo dnf install opus-devel alsa-lib-devel pkgconf-pkg-config\n```\n\nOn Debian or Ubuntu:\n\n```sh\nsudo apt install libopus-dev libasound2-dev pkg-config\n```\n\nOn macOS with Homebrew:\n\n```sh\nbrew install opus pkg-config\n```\n\n```sh\ncargo install concord --locked\n```\n\nTo install without local voice playback and microphone support:\n\n```sh\ncargo install concord --locked --no-default-features\n```\n\nTo install the latest unreleased version directly from the Git repository:\n\n```sh\ncargo install --locked --git https://github.com/chojs23/concord\n```\n\n### Nix\n\nRun without installing (requires flakes enabled):\n\n```sh\nnix run github:chojs23/concord\n```\n\nInstall into your profile:\n\n```sh\nnix profile install github:chojs23/concord\n```\n\nOr add the flake as an input in your own `flake.nix`:\n\n```nix\n{\n  inputs.concord.url = \"github:chojs23/concord\";\n}\n```\n\n### GitHub Release installer\n\nInstall the latest release with the cargo-dist shell installer:\n\n```sh\ncurl --proto '=https' --tlsv1.2 -LsSf https://github.com/chojs23/concord/releases/latest/download/concord-installer.sh | sh\n```\n\nOn Windows, use the PowerShell installer instead:\n\n```powershell\npowershell -ExecutionPolicy Bypass -c \"irm https://github.com/chojs23/concord/releases/latest/download/concord-installer.ps1 | iex\"\n```\n\nThe installer places `concord` under `$CARGO_HOME/bin`, which is usually\n`~/.cargo/bin` on Unix and `%USERPROFILE%\\.cargo\\bin` on Windows.\n\n### Build from source\n\nYou need the Rust stable toolchain, Cargo, and the native dependencies listed in\nthe Cargo install section.\n\n```sh\ngit clone https://github.com/chojs23/concord.git\ncd concord\ncargo build --release\n```\n\nThe release binary is produced at:\n\n```sh\ntarget/release/concord\n```\n\nTo build without local voice playback and microphone support, disable default features:\n\n```sh\ncargo build --release --no-default-features\n```\n\nOn WSLg, audio is usually exposed through PulseAudio instead of a real ALSA\nsound card. If playback does not start, check that PulseAudio and ALSA routing\nwork before debugging Discord voice itself:\n\n```sh\npactl info\npaplay /usr/share/sounds/alsa/Front_Center.wav\naplay -D pulse /usr/share/sounds/alsa/Front_Center.wav\n```\n\n## Features\n\n### Authentication\n\n- **Token** : paste an existing Discord token.\n- **Email / Password** : login with credentials. MFA (TOTP, SMS) is fully supported.\n- **QR Code** : scan the code from the Discord mobile app.\n\nEmail and QR code logins may trigger a CAPTCHA challenge on Discord's side. We cannot solve that, so I strongly recommend using token authentication.\n\nTokens are saved under Concord's config directory in plain text. See the Security section below for details.\n\n### Guilds \u0026 Channels\n\n- Browse servers with guild folder grouping\n- Navigate text channels, threads, and forum channels\n- View and filter forum posts (active / archived)\n- Load pinned messages per channel\n- Open channel actions for pinned messages, thread lists, and mark-as-read\n- Join and leave voice channels\n- Highlight active voice speakers in voice channel participant rows\n- Track unread messages and mention counts per channel\n- Mute and unmute channels and servers\n- Leave the selected server after confirmation\n\n### Messaging\n\n- Send, edit, and delete messages\n- Upload / Download attachments\n- Search messages with filters with `/`\n- Use @mention autocomplete\n- Use custom emoji from other servers when your account supports it\n- Send custom emoji your account cannot use directly as image links when enabled\n- View full message history\n- Rich content display (embeds, attachments, stickers, and mentions)\n- Detect URLs in message bodies and markdown links, then open them in your default browser\n- Direct message shortcuts for copy, reply, edit, delete, reactions, URL opening,\n  and image viewing. More message actions are available from the action menu.\n\n#### Markdown Rendering\n\n![Markdown rendering example](./docs/markdown-example.png)\n\nConcord renders a practical subset of Discord-style Markdown in message bodies:\n\n- Headings: `# H1`, `## H2`, `### H3`\n- Quotes: `\u003e quoted text`\n- Bullets: `- item` and `* item`\n- Inline styles: `**bold**`, `*italic*`, and `` `inline code` ``\n- Fenced code blocks with optional language labels, rendered as compact boxes\n- Raw URLs and markdown link destinations are underlined and can be opened from message actions\n\n### Reactions \u0026 Polls\n\n- View, add, and remove emoji reactions (Unicode and custom server emoji)\n- Use custom emoji from other servers as reactions when your account supports it\n- Browse who reacted with a specific emoji\n- View and vote on polls\n\n### Media \u0026 Images\n\nImage rendering is powered by [ratatui-image](https://github.com/benjajaja/ratatui-image). On startup, Concord queries the terminal to detect the best available graphics protocol. Supported protocols:\n\n- **Kitty Graphics Protocol** - Kitty, WezTerm, Ghostty, etc.\n- **iTerm2 Inline Images** - iTerm2, WezTerm, mintty, etc.\n- **Sixel** - foot, mlterm, xterm (if compiled with Sixel support), etc.\n- **Halfblocks** (fallback) - works on any terminal, but uses block characters instead of true pixels.\n\nIf your terminal does not support any graphics protocol, images will be rendered as halfblock approximations. For the best experience, use a terminal that supports the Kitty or iTerm2 protocol.\n\nYou can toggle image viewing on or off in the configuration file. When image viewing is off, attachments and emojis will be shown as text placeholders.\n\n### Members \u0026 Profiles\n\n- Member list with grouping\n- Presence indicators (Online, Idle, DND, Offline)\n- View User profile\n\n### Typing Indicators \u0026 Read State\n\n- Live \"user is typing...\" indicators\n- Unread message tracking with mention counts\n- Mark server, channel as read\n\n### Notifications\n\n- Desktop notifications for Discord messages that pass your Discord\n  notification settings\n- Active channel notifications are suppressed so Concord does not notify for\n  the conversation you are already viewing\n- Voice join and leave notification sounds while you are connected to voice.\n  You can keep the built-in tones or configure custom WAV files.\n\n### Navigation \u0026 Keyboard shortcuts\n\n\u003e ⚠️ Keymap action names and default bindings may have breaking changes between releases.\n\nAll default key settings in this section can be customized. See\n[Keymap options](./docs/keymap-options.md) for the config format and supported\nactions.\n\nConcord has a four-pane.\n**Guilds (1)**, **Channels (2)**, **Messages (3)**, **Members (4)**\n\nWith default vim-style navigation:\n\n| Key                                       | Action                                          |\n| ----------------------------------------- | ----------------------------------------------- |\n| `1` `2` `3` `4`                           | Focus pane                                      |\n| `Tab` / `Shift+Tab`                       | Cycle focus forward / backward                  |\n| `h` / `l`, `←` / `→`                      | Move focus left / right                         |\n| `j` / `k`, `↑` / `↓`, `Ctrl+n` / `Ctrl+p` | Move down / up                                  |\n| `J`, `K` / `H`, `L`                       | Scroll viewport                                 |\n| `Ctrl+d` / `Ctrl+u`                       | Half-page scroll                                |\n| `Alt+h/l/←/→`                             | Resize focused pane width                       |\n| `gg` / `G`                                | Jump or scroll to top / bottom                  |\n| `Enter`                                   | Open or activate the selected item              |\n| `/`                                       | Filter Guilds/Channels, search Messages/Members |\n| `Space`                                   | Open leader shortcut window                     |\n| `i`                                       | Text insert mode                                |\n| `Esc`                                     | Close popup, cancel mode, or go back            |\n| `q`                                       | Quit Concord                                    |\n\n`Ctrl+n` and `Ctrl+p` are fixed row movement keys. The default `j` and `k`\nrow movement keys are `SelectNext` and `SelectPrevious` and can be changed in\n`keymap.toml`.\n\n#### Leader key\n\nPress `Space` to open the leader shortcut window.\n\n| Key sequence     | Action                            |\n| ---------------- | --------------------------------- |\n| `Space`, `1`     | Toggle the Servers pane           |\n| `Space`, `2`     | Toggle the Channels pane          |\n| `Space`, `4`     | Toggle the Members pane           |\n| `Space`, `a`     | Open actions for the focused pane |\n| `Space`, `p`     | Open my profile settings          |\n| `Space`, `o`     | Choose concord option category    |\n| `Space`, `v`     | Voice command prefix              |\n| `Space`, `Space` | Open the fuzzy channel switcher   |\n\n#### Action menus\n\nFocus a pane, then press `Space`, `a` to open actions for that pane. Action\nshortcuts are shown inside the leader popup and only run when the action is\nenabled. In the Messages pane, the selected message also supports these direct\nshortcuts:\n\nMessage shortcuts:\n\n| Shortcut | Action              | Description                                                 |\n| -------- | ------------------- | ----------------------------------------------------------- |\n| `y`      | Copy                | Copy the selected message text and show a short toast       |\n| `r`      | Add/remove reaction | Open the reaction picker for the selected message           |\n| `R`      | Reply               | Start a reply to the selected message                       |\n| `d`      | Delete              | Open a delete confirmation before deleting the message      |\n| `e`      | Edit                | Start editing the selected message when editing is allowed  |\n| `o`      | Open URL            | Open the selected message URL, or choose from multiple URLs |\n| `v`      | View attachment     | Open the selected message's attachment viewer               |\n\nMessage action menu shortcuts:\n\n| Shortcut | Action                      | Description                                                 |\n| -------- | --------------------------- | ----------------------------------------------------------- |\n| `y`      | Copy                        | Copy the selected message text and show a short toast       |\n| `r`      | Add/remove reaction         | Open the reaction picker for the selected message           |\n| `R`      | Reply                       | Start a reply to the selected message                       |\n| `d`      | Delete                      | Open a delete confirmation before deleting the message      |\n| `e`      | Edit                        | Start editing the selected message when editing is allowed  |\n| `o`      | Open URL                    | Open the selected message URL, or choose from multiple URLs |\n| `v`      | View attachment             | Open the selected message's attachment viewer               |\n| `g`      | Go to referenced message    | Go to the replied or forwarded message                      |\n| `p`      | show message sender profile | Open the selected message author's profile                  |\n| `P`      | Pin / unpin                 | Open a pin or unpin confirmation for the selected message   |\n| `t`      | Open thread                 | Open the selected message's thread                          |\n| `u`      | Show reacted users          | Show users who reacted to the selected message              |\n| `c`      | Choose poll votes           | Choose poll votes for the selected message                  |\n\nWhen the attachment viewer is open, press `d` to download the current attachment directly.\n\nServer actions:\n\n| Shortcut | Action              | Description                                           |\n| -------- | ------------------- | ----------------------------------------------------- |\n| `m`      | Mark server as read | Mark all unread viewable channels in this server read |\n| `u`      | Mute / unmute       | Toggle server notification mute                       |\n| `l`      | Leave server        | Open a confirmation before leaving this server        |\n\nChannel actions:\n\n| Shortcut | Action               | Description                                  |\n| -------- | -------------------- | -------------------------------------------- |\n| `j`      | Join voice           | Join the selected voice channel              |\n| `l`      | Leave voice          | Leave the current voice channel              |\n| `p`      | Show pinned messages | Open the selected channel's pinned messages  |\n| `t`      | Show threads         | List threads for the selected channel        |\n| `m`      | Mark as read         | Mark the selected channel read               |\n| `u`      | Mute / unmute        | Toggle channel or category notification mute |\n\nVoice commands:\n\n| Sequence          | Action       | Description                               |\n| ----------------- | ------------ | ----------------------------------------- |\n| `Space`, `v`, `d` | Deafen voice | Toggle Concord's Discord voice deaf state |\n| `Space`, `v`, `m` | Mute voice   | Toggle Concord's Discord voice mute state |\n| `Space`, `v`, `l` | Leave voice  | Leave the current Concord voice channel   |\n\n#### Composer\n\nYou can paste copied files into the composer to attach them. Pending uploads\nare shown above the input before sending.\n\n| Shortcut                   | Action            | Description                                                      |\n| -------------------------- | ----------------- | ---------------------------------------------------------------- |\n| `Ctrl+v`                   | paste clipboard   | Attach copied files or images when present, otherwise paste text |\n| `Ctrl+e`                   | open $EDITOR      | Open $EDITOR on the current draft for long editing               |\n| `Ctrl+c`                   | clear             | Clear current draft                                              |\n| `Ctrl+Left`/ `Ctrl+Right`  | Jump word         | Jump the cursor by word                                          |\n| `Ctrl+Backspace`/ `Ctrl+w` | Delete word       | Delete the word before the cursor                                |\n| `Delete`                   | Detach attachment | Removes the last pending attachment                              |\n\n#### Mention picker\n\nWhen the @mention picker is open, use `Up` / `Down`,\n`Ctrl+p` / `Ctrl+n`, `Tab`, or `Enter` to choose a mention.\n\n#### Emoji picker\n\nType `:` plus at least two letters, such as `:he`, to pick Unicode, server, or\ncross-server custom emoji while writing a message.\n\nWhen `emojis_as_links` is enabled, custom emoji your account cannot send\ndirectly are inserted as Discord image links instead.\n\nTo react from the composer, select a message, enter insert mode, then type\n`+:`. The reaction picker opens for that message. Press `/` to search, Enter to\nlock the filter, then Enter again or use a shown shortcut to react.\n\n#### Bot commands\n\nWhen the composer input starts with a slash `/`, the command suggestion popup\n\n## Configuration\n\nConcord options are stored under Concord's config directory. If\n`XDG_CONFIG_HOME` is set, Concord uses `$XDG_CONFIG_HOME/concord/config.toml`\nfor app options and `$XDG_CONFIG_HOME/concord/keymap.toml` for key settings.\nOtherwise it uses the platform config directory. The usual fallback is\n`~/.config/concord/config.toml` and `~/.config/concord/keymap.toml` on Linux,\nmatching files under `~/Library/Application Support/concord/` on macOS, and the\nroaming AppData config directory on Windows.\n\nYou can change some configuration from the in-app Options menu, and Concord saves them back\nto `config.toml`. Key settings are read from `keymap.toml`.\n\n\u003cdetails\u003e\n\u003csummary\u003eDefault config\u003c/summary\u003e\n\n```toml\n[display]\n# Master switch that hides all image previews when true.\ndisable_image_preview = false\n\n# Show user avatars next to messages and in profile views.\nshow_avatars = true\n\n# Render inline image previews for attachments and embeds.\nshow_images = true\n\n# Preview quality: efficient, balanced, high, or original.\nimage_preview_quality = \"balanced\"\n\n# Render custom Discord emoji as images when possible.\nshow_custom_emoji = true\n\n# Crop avatars into circles instead of showing square images.\ncircular_avatars = false\n\n[composer]\n# Send custom emoji your account cannot use directly as image links.\nemojis_as_links = false\n\n[notifications]\n# Show desktop notifications for Discord messages that pass notification rules.\ndesktop_notifications = true\n\n# Optional notification icon to include in notifications. May not work on all platforms.\n# When unset, no icon is used. It must either be a name of an icon (typically in /usr/share/icons)\n# or a path to an icon.\nnotification_icon = \"/path/to/icon.svg\"\n\n# Optional WAV files for voice join and leave notification sounds.\n# When unset, Concord uses built-in generated tones.\nvoice_join_sound = \"/path/to/join.wav\"\nvoice_leave_sound = \"/path/to/leave.wav\"\n\n[voice]\n# Join or update Discord voice with Concord self-muted.\nself_mute = false\n\n# Join or update Discord voice with Concord self-deafened.\nself_deaf = false\n\n# Allow microphone transmit while this session is joined and not self-muted.\nallow_microphone_transmit = false\n\n# Voice activity threshold in dB. Lower values transmit quieter input.\nmicrophone_sensitivity = -30\n\n# Microphone input volume percentage, from 0 to 100.\nmicrophone_volume = 100\n\n# Received voice playback volume percentage, from 0 to 100.\nvoice_output_volume = 100\n```\n\n\u003c/details\u003e\u003cbr\u003e\n\n`image_preview_quality` supports these values:\n\n- `efficient`: smaller preview requests to reduce bandwidth and memory use.\n- `balanced`: default quality with bounded resource use.\n- `high`: sharper resized previews using lossless quality.\n- `original`: request the original source image for previews when possible.\n\nThis setting only applies to attachment, embed, and attachment viewer previews.\nAvatars and custom emoji keep their separate small-image behavior.\n\n\u003cdetails\u003e\n\u003csummary\u003eDefault keymap config\u003c/summary\u003e\n\n```toml\n[keymap]\nleader = \"space\"\nStartComposer = \"i\"\nOpenPaneFilter = \"/\"\nFocusGuildPane = \"1\"\nFocusChannelPane = \"2\"\nFocusMessagePane = \"3\"\nFocusMemberPane = \"4\"\nSelectNext = \"j\"\nSelectPrevious = \"k\"\nCycleFocusNext = { keys = [\"tab\", \"l\", \"right\"] }\nCycleFocusPrevious = { keys = [\"\u003cS-tab\u003e\", \"h\", \"left\"] }\nHalfPageDown = \"\u003cC-d\u003e\"\nHalfPageUp = \"\u003cC-u\u003e\"\nScrollViewportDown = \"J\"\nScrollViewportUp = \"K\"\nJumpTop = \"gg\"\nJumpBottom = \"G\"\nScrollHorizontalLeft = \"H\"\nScrollHorizontalRight = \"L\"\nResizePaneLeft = { keys = [\"\u003cA-h\u003e\", \"\u003cA-left\u003e\"] }\nResizePaneRight = { keys = [\"\u003cA-l\u003e\", \"\u003cA-right\u003e\"] }\nQuit = \"q\"\nCopyMessage = \"y\"\nReactMessage = \"r\"\nReplyMessage = \"R\"\nDeleteMessage = \"d\"\nEditMessage = \"e\"\nOpenMessageUrl = \"o\"\nViewMessageAttachment = \"v\"\nToggleGuildPane = \"\u003cleader\u003e1\"\nToggleChannelPane = \"\u003cleader\u003e2\"\nToggleMemberPane = \"\u003cleader\u003e4\"\nOpenFocusedPaneAction = \"\u003cleader\u003ea\"\nOpenCurrentUserProfile = \"\u003cleader\u003ep\"\nOpenOptions = \"\u003cleader\u003eo\"\nChannelSwitcher = \"\u003cleader\u003e\u003cleader\u003e\"\nVoiceDeafen = \"\u003cleader\u003evd\"\nVoiceMute = \"\u003cleader\u003evm\"\nVoiceLeave = \"\u003cleader\u003evl\"\n\n[keymap.groups]\n\"\u003cleader\u003ev\" = \"Voice\"\n\n[keymap.guild_actions]\nMarkAsRead = \"m\"\nMuteServer = \"u\"\nLeaveServer = \"l\"\n\n[keymap.channel_actions]\nJoinVoice = \"j\"\nLeaveVoice = \"l\"\nShowPinnedMessages = \"p\"\nShowThreads = \"t\"\nMarkAsRead = \"m\"\nMuteChannel = \"u\"\n\n[keymap.message_actions]\nCopyMessage = \"y\"\nReactMessage = \"r\"\nReplyMessage = \"R\"\nDeleteMessage = \"d\"\nEditMessage = \"e\"\nOpenMessageUrl = \"o\"\nViewMessageAttachment = \"v\"\nGoToReferencedMessage = \"g\"\nShowMessageProfile = \"p\"\nPinMessage = \"P\"\nOpenThread = \"t\"\nShowReactionUsers = \"u\"\nOpenPollVotePicker = \"c\"\n\n[keymap.member_actions]\nShowProfile = \"p\"\n\n[keymap.composer]\nOpenEditor = \"\u003cC-e\u003e\"\nPasteClipboard = \"\u003cC-v\u003e\"\nInsertNewline = { keys = [\"\u003cS-enter\u003e\", \"\u003cC-enter\u003e\", \"\u003cA-enter\u003e\"] }\nSubmit = \"enter\"\nClose = \"esc\"\nClearInput = \"\u003cC-c\u003e\"\nRemoveLastAttachment = \"delete\"\nDeletePreviousChar = \"backspace\"\nDeletePreviousWord = { keys = [\"\u003cC-backspace\u003e\", \"\u003cC-w\u003e\"] }\nMoveCursorUp = \"up\"\nMoveCursorDown = \"down\"\nMoveCursorWordLeft = \"\u003cC-left\u003e\"\nMoveCursorLeft = \"left\"\nMoveCursorWordRight = \"\u003cC-right\u003e\"\nMoveCursorRight = \"right\"\nMoveCursorHome = \"home\"\nMoveCursorEnd = \"end\"\n```\n\n\u003c/details\u003e\u003cbr\u003e\n\nYou can customize key bindings. Check the [Keymap options](./docs/keymap-options.md) for the config format, supported actions.\n\n## Performance\n\nConcord is designed to stay lightweight in normal terminal use. In observed\ntypical use, it usually uses about 20-40 MB of memory.\n\nImage-heavy screens can temporarily use more memory because compressed image\nbytes need to be decoded before they can be rendered in the terminal. When many\nimages are loaded, memory can briefly rise to around 100-200 MB while decoding\nand then drop again as work completes and caches are pruned.\n\nTo keep resource usage bounded, Concord limits media work in several places:\n\n- Attachment previews are downloaded with an 8 MiB per-preview cap.\n- Attachment downloads are capped at 64 MiB.\n- Up to 4 attachment previews are fetched at once.\n- Up to 2 inline image previews are decoded at once.\n- Inline image previews, avatars, and custom emoji use small LRU caches.\n- Image preview requests prefer resized Discord proxy URLs sized for the\n  terminal instead of original full-size media when possible.\n- The preview quality preset can lower preview source dimensions or opt into\n  original source images. It does not change avatar or custom emoji sizing.\n\nMessage history is also cached with a per-channel limit, so long-running\nsessions do not keep every message in memory forever.\n\n## FAQ\n\n### Can my account be blocked?\n\nHonestly, no.\n\nThere are some path that did trigger a account block:\n\n- Trying to **create a new DM channel and send a message to an unknown user**(meaning there was no pre-existing DM created through the Discord client) can immediately block your account temporarily.\n- Some features that requires a hCapcha challenge on Discord's side.\n\nOther features have not caused blocks in my testing.\n\nThat said, Concord is not an official Discord client. Using unofficial clients, automated user accounts, or self-bots can violate Discord's TOS, so there is always some risk. Use it at your own discretion.\n\n### Does Concord support CAPTCHA?\n\nNo. If Discord requires a CAPTCHA during login, use token login instead.\n\n## Security\n\n- Tokens are stored as **plain text** in Concord's config directory. So keep that file secure and do not share it. You can use the token from that file to log in to the official Discord client, so treat it like a password.\n- On Unix, the credential's parent directory is created with `0700` and the credential file with `0600` permissions.\n- All concord state (config, keymap, credential, log) lives under a single `concord/` directory inside `XDG_CONFIG_HOME` when it is set, or inside the platform config directory otherwise.\n- No system keychain integration yet.\n\n## Contributing\n\nAny issues, pull requests, and feedback are welcome. See [CONTRIBUTING.md](./CONTRIBUTING.md) for details.\n\n## License\n\nConcord is licensed under GPL-3.0-only.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fchojs23%2Fconcord","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fchojs23%2Fconcord","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fchojs23%2Fconcord/lists"}