The Bluesky Social application for Web, iOS, and Android https://bsky.app
Find a file
2026-01-06 00:18:33 +00:00
.bundle Initial commit 2022-06-07 17:50:05 -05:00
.github update actions (#9586) 2025-12-22 19:21:17 -08:00
.husky Run lint-staged without concurrency (#8489) 2025-06-14 20:47:05 +03:00
__e2e__ Prep v1.111.0 e2e (#9494) 2025-12-05 16:34:08 -06:00
__mocks__ Add displayName to contexts (#8814) 2025-08-14 01:12:31 +03:00
__tests__/lib Age Assurance V2 (#9479) 2025-12-04 15:20:00 -06:00
assets [Contacts] Contacts matching flow (#9486) 2025-12-12 10:32:06 -08:00
bskyembed [APP-1321]: Update brand embeds more clearly (#8955) 2025-10-29 17:24:48 -07:00
bskylink fix regex (#9234) 2025-10-19 09:20:53 -07:00
bskyogcard Start migrating blink. Also add better shutdown handling for ogcard 2025-09-23 15:17:49 -07:00
bskyweb Better copy for "must be signed in" message (#9602) 2025-12-29 01:38:04 -08:00
code-signing add expo-updates github action (#3270) 2024-03-19 11:18:22 -07:00
docs [Contacts] Contacts matching flow (#9486) 2025-12-12 10:32:06 -08:00
eslint Add eslint rule to fix imports without the #/ path alias (#5175) 2024-09-20 09:11:29 +01:00
jest remove root sibling library (#9097) 2025-09-29 14:31:55 -05:00
modules Reading the optional String extras from attachment share intents (#9396) 2025-11-22 03:03:30 -08:00
patches Update react native screens, remove patch (#9210) 2025-12-29 10:16:49 -08:00
plugins Fix translations on Android using PROCESS_TEXT intent (#8486) 2025-08-11 08:37:39 -07:00
scripts disable new arch (#8561) 2025-06-23 10:11:17 -07:00
src Nightly source-language update 2026-01-06 00:18:33 +00:00
web Age Assurance V2 (#9479) 2025-12-04 15:20:00 -06:00
.buckconfig Initial commit 2022-06-07 17:50:05 -05:00
.easignore fix bad bool check in action (#3885) 2024-05-06 20:13:12 -07:00
.editorconfig Lint native files (#4768) 2024-07-11 18:15:35 -07:00
.env.example Age Assurance V2 (#9479) 2025-12-04 15:20:00 -06:00
.eslintrc.js SegmentedControl component (#8606) 2025-11-14 11:43:28 -08:00
.gitignore Ignore new flag SVGs in build output (#9567) 2025-12-18 09:45:51 -06:00
.nvmrc Update Node.js to 20.x in Dockerfile (#6099) 2024-11-11 18:58:22 +00:00
.prettierignore Ignore built files (#5572) 2024-10-02 11:18:15 -05:00
.prettierrc.js Add state management 2022-06-09 13:03:25 -05:00
.ruby-version Improve lightbox... and update to React Native 0.71.0 (#49) 2023-01-17 20:40:02 -06:00
.watchmanconfig Initial commit 2022-06-07 17:50:05 -05:00
app.config.js [Contacts] Contacts matching flow (#9486) 2025-12-12 10:32:06 -08:00
babel.config.js bump it bop it upgrade it (rn 79/expo 53) (#8281) 2025-05-02 13:23:39 -07:00
crowdin.yml Release 1.103.0 prep (#8434) 2025-05-30 16:58:23 -07:00
Dockerfile update golang to v1.25 (and some containers do debian bookworm) (#9442) 2025-11-25 10:35:50 -08:00
Dockerfile.bskylink Bsky short link service (#4542) 2024-06-21 12:41:06 -04:00
Dockerfile.bskyogcard edit dockerfile to match 2025-09-22 10:28:17 -07:00
Dockerfile.embedr update golang to v1.25 (and some containers do debian bookworm) (#9442) 2025-11-25 10:35:50 -08:00
eas.json Get iOS debug files into Sentry (#9242) 2025-10-22 09:17:52 -05:00
Gemfile Improve lightbox... and update to React Native 0.71.0 (#49) 2023-01-17 20:40:02 -06:00
google-services.json.example Add example google-services file (#1545) 2023-09-28 12:22:23 -07:00
index.js Gate bitdrift integration (#7088) 2024-12-13 17:14:41 +00:00
index.web.js Upgrade API, implement XRPC rework (#4857) 2024-08-12 14:00:15 -07:00
LICENSE use legally registered name for company (#8338) 2025-05-06 12:09:50 -07:00
lingui.config.js Add language: European Portuguese (pt-PT) (#8375) 2025-05-30 16:38:09 -07:00
Makefile makefile: bump nvm to use node 20 (#7324) 2025-02-19 16:12:51 -08:00
metro.config.js bump it bop it upgrade it (rn 79/expo 53) (#8281) 2025-05-02 13:23:39 -07:00
package.json Replace graphemer with unicode-segmenter (#9526) 2025-12-30 03:39:09 -08:00
README.md add patent pledge link to readme (#9118) 2025-10-01 11:49:06 -07:00
svgo.config.mjs Upgrade prettier to 3.6 (#8558) 2025-06-23 07:44:40 -07:00
tsconfig.check.json [APP-786] Native notifications (#1095) 2023-08-23 16:28:51 -07:00
tsconfig.e2e.json E2E runner fixes (#2428) 2024-01-04 17:33:57 -08:00
tsconfig.json add sort import suggestions plugin (#8335) 2025-10-15 09:37:07 -07:00
webpack.config.js Remove RNGH from web bundle (#9528) 2025-12-30 03:40:19 -08:00
yarn.lock Replace graphemer with unicode-segmenter (#9526) 2025-12-30 03:39:09 -08:00

Bluesky Social App

Welcome friends! This is the codebase for the Bluesky Social app.

Get the app itself:

Development Resources

This is a React Native application, written in the TypeScript programming language. It builds on the atproto TypeScript packages (like @atproto/api), which are also open source, but in a different git repository.

There is a small amount of Go language source code (in ./bskyweb/), for a web service that returns the React Native Web application.

The Build Instructions are a good place to get started with the app itself.

The Authenticated Transfer Protocol ("AT Protocol" or "atproto") is a decentralized social media protocol. You don't need to understand AT Protocol to work with this application, but it can help. Learn more at:

The Bluesky Social application encompasses a set of schemas and APIs built in the overall AT Protocol framework. The namespace for these "Lexicons" is app.bsky.*.

Contributions

Note

While we do accept contributions, we prioritize high quality issues and pull requests. Adhering to the below guidelines will ensure a more timely review.

Rules:

  • We may not respond to your issue or PR.
  • We may close an issue or PR without much feedback.
  • We may lock discussions or contributions if our attention is getting DDOSed.
  • We're not going to provide support for build issues.

Guidelines:

  • Check for existing issues before filing a new one please.
  • Open an issue and give some time for discussion before submitting a PR.
  • Stay away from PRs like...
    • Changing "Post" to "Skeet."
    • Refactoring the codebase, e.g., to replace React Query with Redux Toolkit or something.
    • Adding entirely new features without prior discussion.

Remember, we serve a wide community of users. Our day-to-day involves us constantly asking "which top priority is our top priority." If you submit well-written PRs that solve problems concisely, that's an awesome contribution. Otherwise, as much as we'd love to accept your ideas and contributions, we really don't have the bandwidth. That's what forking is for!

Forking guidelines

You have our blessing 🪄 to fork this application! However, it's very important to be clear to users when you're giving them a fork.

Please be sure to:

  • Change all branding in the repository and UI to clearly differentiate from Bluesky.
  • Change any support links (feedback, email, terms of service, etc) to your own systems.
  • Replace any analytics or error-collection systems with your own so we don't get super confused.

Security disclosures

If you discover any security issues, please send an email to security@bsky.app. The email is automatically CC'd to the entire team and we'll respond promptly.

Are you a developer interested in building on atproto?

Bluesky is an open social network built on the AT Protocol, a flexible technology that will never lock developers out of the ecosystems that they help build. With atproto, third-party integration can be as seamless as first-party through custom feeds, federated services, clients, and more.

License (MIT)

See ./LICENSE for the full license.

Bluesky Social PBC has committed to a software patent non-aggression pledge. For details see the original announcement.

P.S.

We ❤️ you and all of the ways you support us. Thank you for making Bluesky a great place!