@atcute/bluesky
v3.2.14
Published
Bluesky (app.bsky.* and chat.bsky.*) schema definitions
Downloads
10,035
Readme
@atcute/bluesky
Bluesky (app.bsky.* and chat.bsky.*) schema definitions
npm install @atcute/blueskyusage
import { is, type $type } from '@atcute/lexicons';
import { AppBskyFeedPost, AppBskyRichtextFacet } from '@atcute/bluesky';
type Facet = AppBskyRichtextFacet.Main;
type MentionFeature = $type.enforce<AppBskyRichtextFacet.Mention>;
const mention: MentionFeature = {
$type: 'app.bsky.richtext.facet#mention',
did: 'did:plc:z72i7hdynmk6r22z27h6tvur',
};
const facet: Facet = {
index: {
byteStart: 6,
byteEnd: 15,
},
features: [mention],
};
const record: AppBskyFeedPost.Main = {
$type: 'app.bsky.feed.post',
text: `hello @bsky.app!`,
facets: [facet],
createdAt: new Date().toISOString(),
};
is(AppBskyFeedPost.mainSchema, record);
// -> truewith @atcute/client
pick either one of these 3 options to register the ambient declarations
// file: tsconfig.json
{
"compilerOptions": {
"types": ["@atcute/bluesky"],
},
}// file: env.d.ts
/// <reference types="@atcute/bluesky" />// file: index.ts
import type {} from '@atcute/bluesky';now all the XRPC operations should be visible in the client
import { Client, simpleFetchHandler } from '@atcute/client';
const client = new Client({
handler: simpleFetchHandler({ service: 'https://public.api.bsky.app' }),
});
const response = await client.get('app.bsky.actor.getProfile', {
params: {
actor: 'did:plc:z72i7hdynmk6r22z27h6tvur',
},
});
// ...with @atcute/lex-cli
when building your own lexicons that reference Bluesky types, configure lex-cli to import from this package:
// file: lex.config.js
import { defineLexiconConfig } from '@atcute/lex-cli';
export default defineLexiconConfig({
files: ['lexicons/**/*.json'],
outdir: 'src/lexicons/',
imports: ['@atcute/bluesky'],
});