* Add self-label schemas * switch around array and union for self-labels * apply self-labels to post and profile views * test for self labels in pds * apply self-labels to post and profile views in bsky appview * test for self labels in bsky appview * update pds proxied test snapshots * Add support for self-labels to the mdoeration sdk * Disable unknown-labeler filtering until 3P support is added --------- Co-authored-by: Devin Ivy <devinivy@gmail.com>
Packages
Applications
- PDS: The Personal Data Server (PDS). This is atproto's main server-side implementation.
- Dev Env: A command-line application for developers to construct and manage development environments.
- Lexicon CLI: A command-line application for generating code and documentation from Lexicon schemas.
Libraries
- API: A library for communicating with atproto servers.
- Common: A library containing code which is shared between atproto packages.
- Crypto: Atproto's common cryptographic operations.
- Identity: A library for resolving atproto DIDs and handles.
- Lexicon: A library for validating data using atproto's schema system.
- NSID: A parser and generator of NSIDs.
- Repo: The "atproto repository" core implementation (a Merkle Search Tree).
- URI: A parser and generator of
at://
uris. - XRPC: An XRPC client implementation.
- XRPC Server: An XRPC server implementation.
Benchmarking and profiling
Only applicable to packages which contain benchmarks(jest.bench.config.js
).
You can run benchmarks with yarn bench
.
Attaching a profiler
Running yarn bench:profile
will launch bench
with --inspect-brk
flag.
Execution will be paused until a debugger is attached, you can read more
about node debuggers here
An easy way to profile is:
- open
about://inspect
in chrome - select which process to connect to(there will probably only be one)
- go to performance tab
- press record, this will unpause execution
- wait for the benches to run
- finish recording