b934b396b1
* feat(api): support creation of oauth based AtpAgents * oauth: misc fixes for confidential clients * fix(xprc): remove ReadableStream.from polyfill * OAuth docs tweaks (#2679) * OAuth: clarification about client_name being shown * OAuth: re-write handle resolution privacy concern * avoid relying on ReadableStream.from in xrpc-server tests * feat(oauth-types): expose "ALLOW_UNSECURE_ORIGINS" constant * feat(handle-resolver): expose "AtprotoIdentityDidMethods" type * fix(oauth-client): ensure that the oauth metadata document contains client_id_metadata_document_supported * fix(oauth-types): prevent unknown query string in loopback client id * fix(identity-resolver): check that handle is in did doc's "alsoKnownAs" * feat(oauth-client:oauth-resolver): allow logging in using either the PDS URL or Entryway URL * fix(oauth-client): return better error in case of invalid "oauth-protected-resource" status code * refactor(did): group atproto specific checks in own * feat(api): relax typing of "appLabelers" and "labelers" AtpClient properties * allow any did as labeller (for tests mainly) * fix(api): allow to override "atproto-proxy" on a per-request basis * remove release candidate versions from changelog * update changeset for api and xrpc packages * Add missing changeset * revert RC versions * Proper wording in OAUTH.md api example * remove "pre" changeset file * xrpc: restore original behavior of setHEader and unsetHeader * docs: add comment for XrpcClient 's constructor arg * feat(api): expose "schemas" publicly * feat(api): allow customizing the whatwg fetch function of the AtpAgent * docs(api): improve migration docs * docs: change reference to BskyAgent to AtpAgent * docs: mention the breaking change regarding setSessionPersistHandler * fix(api): better split AtpClient concerns * fix(xrpc): remove unused import * refactor(api): simplify class hierarchu by removeing AtpClient * fix(api): mock proper method for facets detection * restore ability to restore session asynchronously * feat(api): allow instantiating Agent with same argument as super class * docs(api): properly extend Agent class * style(xrpc): var name * docs(api): remove "async" to header getter --------- Co-authored-by: Devin Ivy <devinivy@gmail.com> Co-authored-by: bnewbold <bnewbold@robocracy.org> Co-authored-by: Hailey <me@haileyok.com>
175 lines
4.7 KiB
TypeScript
175 lines
4.7 KiB
TypeScript
import { AtpAgent } from '@atproto/api'
|
|
import { TestNetwork, SeedClient } from '@atproto/dev-env'
|
|
import basicSeed from '../seeds/basic'
|
|
|
|
describe('proxies appview procedures', () => {
|
|
let network: TestNetwork
|
|
let agent: AtpAgent
|
|
let sc: SeedClient
|
|
|
|
let alice: string
|
|
let bob: string
|
|
let carol: string
|
|
|
|
beforeAll(async () => {
|
|
network = await TestNetwork.create({
|
|
dbPostgresSchema: 'proxy_procedures',
|
|
})
|
|
agent = network.pds.getClient()
|
|
sc = network.getSeedClient()
|
|
await basicSeed(sc, { addModLabels: network.bsky })
|
|
await network.processAll()
|
|
alice = sc.dids.alice
|
|
bob = sc.dids.bob
|
|
carol = sc.dids.carol
|
|
})
|
|
|
|
afterAll(async () => {
|
|
await network.close()
|
|
})
|
|
|
|
it('maintains muted actors.', async () => {
|
|
// mute actors
|
|
await agent.api.app.bsky.graph.muteActor(
|
|
{ actor: bob },
|
|
{
|
|
headers: sc.getHeaders(alice),
|
|
encoding: 'application/json',
|
|
},
|
|
)
|
|
await agent.api.app.bsky.graph.muteActor(
|
|
{ actor: carol },
|
|
{
|
|
headers: sc.getHeaders(alice),
|
|
encoding: 'application/json',
|
|
},
|
|
)
|
|
// check
|
|
const { data: result1 } = await agent.api.app.bsky.graph.getMutes(
|
|
{},
|
|
{ headers: sc.getHeaders(alice) },
|
|
)
|
|
expect(result1.mutes.map((x) => x.handle)).toEqual([
|
|
'carol.test',
|
|
'bob.test',
|
|
])
|
|
// unmute actors
|
|
await agent.api.app.bsky.graph.unmuteActor(
|
|
{ actor: bob },
|
|
{
|
|
headers: sc.getHeaders(alice),
|
|
encoding: 'application/json',
|
|
},
|
|
)
|
|
// check
|
|
const { data: result2 } = await agent.api.app.bsky.graph.getMutes(
|
|
{},
|
|
{ headers: sc.getHeaders(alice) },
|
|
)
|
|
expect(result2.mutes.map((x) => x.handle)).toEqual(['carol.test'])
|
|
})
|
|
|
|
it('maintains muted actor lists.', async () => {
|
|
// setup lists
|
|
const bobList = await agent.api.app.bsky.graph.list.create(
|
|
{ repo: bob },
|
|
{
|
|
name: 'bob mutes',
|
|
purpose: 'app.bsky.graph.defs#modlist',
|
|
description: "bob's list of mutes",
|
|
createdAt: new Date().toISOString(),
|
|
},
|
|
sc.getHeaders(bob),
|
|
)
|
|
const carolList = await agent.api.app.bsky.graph.list.create(
|
|
{ repo: carol },
|
|
{
|
|
name: 'carol mutes',
|
|
purpose: 'app.bsky.graph.defs#modlist',
|
|
description: "carol's list of mutes",
|
|
createdAt: new Date().toISOString(),
|
|
},
|
|
sc.getHeaders(carol),
|
|
)
|
|
await network.processAll()
|
|
|
|
// mute lists
|
|
await agent.api.app.bsky.graph.muteActorList(
|
|
{ list: bobList.uri },
|
|
{
|
|
headers: sc.getHeaders(alice),
|
|
encoding: 'application/json',
|
|
},
|
|
)
|
|
await agent.api.app.bsky.graph.muteActorList(
|
|
{ list: carolList.uri },
|
|
{
|
|
headers: sc.getHeaders(alice),
|
|
encoding: 'application/json',
|
|
},
|
|
)
|
|
await network.processAll()
|
|
// check
|
|
const { data: result1 } = await agent.api.app.bsky.graph.getListMutes(
|
|
{},
|
|
{ headers: sc.getHeaders(alice) },
|
|
)
|
|
expect(result1.lists.map((x) => x.uri)).toEqual([
|
|
carolList.uri,
|
|
bobList.uri,
|
|
])
|
|
// unmute lists
|
|
await agent.api.app.bsky.graph.unmuteActorList(
|
|
{ list: bobList.uri },
|
|
{
|
|
headers: sc.getHeaders(alice),
|
|
encoding: 'application/json',
|
|
},
|
|
)
|
|
// check
|
|
const { data: result2 } = await agent.api.app.bsky.graph.getListMutes(
|
|
{},
|
|
{ headers: sc.getHeaders(alice) },
|
|
)
|
|
expect(result2.lists.map((x) => x.uri)).toEqual([carolList.uri])
|
|
})
|
|
|
|
it('maintains notification last seen state.', async () => {
|
|
// check original notifs
|
|
const { data: result1 } =
|
|
await agent.api.app.bsky.notification.listNotifications(
|
|
{},
|
|
{ headers: sc.getHeaders(alice) },
|
|
)
|
|
expect(result1.notifications.length).toBeGreaterThanOrEqual(5)
|
|
expect(
|
|
result1.notifications.every((n, i) => {
|
|
return (i === 0 && !n.isRead) || (i !== 0 && n.isRead)
|
|
}),
|
|
).toBe(true)
|
|
// update last seen
|
|
const { indexedAt: lastSeenAt } = result1.notifications[2]
|
|
await agent.api.app.bsky.notification.updateSeen(
|
|
{ seenAt: lastSeenAt },
|
|
{
|
|
headers: sc.getHeaders(alice),
|
|
encoding: 'application/json',
|
|
},
|
|
)
|
|
// check
|
|
const { data: result2 } =
|
|
await agent.api.app.bsky.notification.listNotifications(
|
|
{},
|
|
{ headers: sc.getHeaders(alice) },
|
|
)
|
|
expect(result2.notifications.some((n) => n.isRead)).toBe(true)
|
|
expect(result2.notifications.some((n) => !n.isRead)).toBe(true)
|
|
expect(result2.notifications).toEqual(
|
|
result1.notifications.map((n) => ({
|
|
...n,
|
|
isRead: n.indexedAt < lastSeenAt,
|
|
})),
|
|
)
|
|
})
|
|
})
|