fix: resolve handle in feed/list urls (#2497)

zio/stable
Mary 2024-01-24 06:11:07 +07:00 committed by GitHub
parent 439f459cef
commit 6076b8f730
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 14 additions and 7 deletions

View File

@ -5,6 +5,7 @@ import {LikelyType, LinkMeta} from './link-meta'
import {convertBskyAppUrlIfNeeded, makeRecordUri} from '../strings/url-helpers'
import {ComposerOptsQuote} from 'state/shell/composer'
import {useGetPost} from '#/state/queries/post'
import {useFetchDid} from '#/state/queries/handle'
// TODO
// import {Home} from 'view/screens/Home'
@ -120,11 +121,13 @@ export async function getPostAsQuote(
export async function getFeedAsEmbed(
agent: BskyAgent,
fetchDid: ReturnType<typeof useFetchDid>,
url: string,
): Promise<apilib.ExternalEmbedDraft> {
url = convertBskyAppUrlIfNeeded(url)
const [_0, user, _1, rkey] = url.split('/').filter(Boolean)
const feed = makeRecordUri(user, 'app.bsky.feed.generator', rkey)
const [_0, handleOrDid, _1, rkey] = url.split('/').filter(Boolean)
const did = await fetchDid(handleOrDid)
const feed = makeRecordUri(did, 'app.bsky.feed.generator', rkey)
const res = await agent.app.bsky.feed.getFeedGenerator({feed})
return {
isLoading: false,
@ -146,11 +149,13 @@ export async function getFeedAsEmbed(
export async function getListAsEmbed(
agent: BskyAgent,
fetchDid: ReturnType<typeof useFetchDid>,
url: string,
): Promise<apilib.ExternalEmbedDraft> {
url = convertBskyAppUrlIfNeeded(url)
const [_0, user, _1, rkey] = url.split('/').filter(Boolean)
const list = makeRecordUri(user, 'app.bsky.graph.list', rkey)
const [_0, handleOrDid, _1, rkey] = url.split('/').filter(Boolean)
const did = await fetchDid(handleOrDid)
const list = makeRecordUri(did, 'app.bsky.graph.list', rkey)
const res = await agent.app.bsky.graph.getList({list})
return {
isLoading: false,

View File

@ -18,6 +18,7 @@ import {POST_IMG_MAX} from 'lib/constants'
import {logger} from '#/logger'
import {getAgent} from '#/state/session'
import {useGetPost} from '#/state/queries/post'
import {useFetchDid} from '#/state/queries/handle'
export function useExternalLinkFetch({
setQuote,
@ -28,6 +29,7 @@ export function useExternalLinkFetch({
undefined,
)
const getPost = useGetPost()
const fetchDid = useFetchDid()
useEffect(() => {
let aborted = false
@ -55,7 +57,7 @@ export function useExternalLinkFetch({
},
)
} else if (isBskyCustomFeedUrl(extLink.uri)) {
getFeedAsEmbed(getAgent(), extLink.uri).then(
getFeedAsEmbed(getAgent(), fetchDid, extLink.uri).then(
({embed, meta}) => {
if (aborted) {
return
@ -73,7 +75,7 @@ export function useExternalLinkFetch({
},
)
} else if (isBskyListUrl(extLink.uri)) {
getListAsEmbed(getAgent(), extLink.uri).then(
getListAsEmbed(getAgent(), fetchDid, extLink.uri).then(
({embed, meta}) => {
if (aborted) {
return
@ -133,7 +135,7 @@ export function useExternalLinkFetch({
})
}
return cleanup
}, [extLink, setQuote, getPost])
}, [extLink, setQuote, getPost, fetchDid])
return {extLink, setExtLink}
}