@atproto/ozone 0.2.8 → 0.2.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +33 -0
- package/package.json +25 -21
- package/bin/migration-create.ts +0 -38
- package/jest.config.cjs +0 -22
- package/src/api/chat/getActorMetadata.ts +0 -23
- package/src/api/chat/getConvo.ts +0 -23
- package/src/api/chat/getConvoMembers.ts +0 -23
- package/src/api/chat/getConvos.ts +0 -23
- package/src/api/chat/getMessageContext.ts +0 -42
- package/src/api/chat/index.ts +0 -16
- package/src/api/communication/createTemplate.ts +0 -51
- package/src/api/communication/deleteTemplate.ts +0 -23
- package/src/api/communication/listTemplates.ts +0 -31
- package/src/api/communication/updateTemplate.ts +0 -51
- package/src/api/health.ts +0 -27
- package/src/api/index.ts +0 -146
- package/src/api/label/fetchLabels.ts +0 -32
- package/src/api/label/queryLabels.ts +0 -57
- package/src/api/label/subscribeLabels.ts +0 -25
- package/src/api/moderation/cancelScheduledActions.ts +0 -72
- package/src/api/moderation/emitEvent.ts +0 -475
- package/src/api/moderation/getAccountTimeline.ts +0 -160
- package/src/api/moderation/getEvent.ts +0 -19
- package/src/api/moderation/getRecord.ts +0 -40
- package/src/api/moderation/getRecords.ts +0 -50
- package/src/api/moderation/getRepo.ts +0 -34
- package/src/api/moderation/getReporterStats.ts +0 -18
- package/src/api/moderation/getRepos.ts +0 -41
- package/src/api/moderation/getSubjects.ts +0 -101
- package/src/api/moderation/listScheduledActions.ts +0 -45
- package/src/api/moderation/queryEvents.ts +0 -72
- package/src/api/moderation/queryStatuses.ts +0 -23
- package/src/api/moderation/scheduleAction.ts +0 -129
- package/src/api/moderation/searchRepos.ts +0 -46
- package/src/api/moderation/util.ts +0 -96
- package/src/api/proxied.ts +0 -327
- package/src/api/queue/assignModerator.ts +0 -31
- package/src/api/queue/createQueue.ts +0 -62
- package/src/api/queue/deleteQueue.ts +0 -56
- package/src/api/queue/getAssignments.ts +0 -19
- package/src/api/queue/listQueues.ts +0 -39
- package/src/api/queue/routeReports.ts +0 -44
- package/src/api/queue/unassignModerator.ts +0 -26
- package/src/api/queue/updateQueue.ts +0 -54
- package/src/api/report/assignModerator.ts +0 -36
- package/src/api/report/createActivity.ts +0 -57
- package/src/api/report/createReport.ts +0 -93
- package/src/api/report/getAssignments.ts +0 -20
- package/src/api/report/getHistoricalStats.ts +0 -41
- package/src/api/report/getLatestReport.ts +0 -44
- package/src/api/report/getLiveStats.ts +0 -26
- package/src/api/report/getReport.ts +0 -55
- package/src/api/report/listActivities.ts +0 -37
- package/src/api/report/queryActivities.ts +0 -64
- package/src/api/report/queryReports.ts +0 -44
- package/src/api/report/reassignQueue.ts +0 -68
- package/src/api/report/refreshStats.ts +0 -27
- package/src/api/report/unassignModerator.ts +0 -21
- package/src/api/safelink/addRule.ts +0 -48
- package/src/api/safelink/queryEvents.ts +0 -32
- package/src/api/safelink/queryRules.ts +0 -58
- package/src/api/safelink/removeRule.ts +0 -42
- package/src/api/safelink/updateRule.ts +0 -48
- package/src/api/server/getConfig.ts +0 -35
- package/src/api/set/addValues.ts +0 -28
- package/src/api/set/deleteSet.ts +0 -34
- package/src/api/set/deleteValues.ts +0 -31
- package/src/api/set/getValues.ts +0 -42
- package/src/api/set/querySets.ts +0 -36
- package/src/api/set/upsertSet.ts +0 -38
- package/src/api/setting/listOptions.ts +0 -44
- package/src/api/setting/removeOptions.ts +0 -64
- package/src/api/setting/upsertOption.ts +0 -156
- package/src/api/team/addMember.ts +0 -51
- package/src/api/team/deleteMember.ts +0 -29
- package/src/api/team/listMembers.ts +0 -20
- package/src/api/team/updateMember.ts +0 -47
- package/src/api/util.ts +0 -265
- package/src/api/verification/grantVerifications.ts +0 -90
- package/src/api/verification/listVerifications.ts +0 -44
- package/src/api/verification/revokeVerifications.ts +0 -43
- package/src/api/well-known.ts +0 -46
- package/src/assignment/index.ts +0 -728
- package/src/auth-verifier.ts +0 -227
- package/src/background.ts +0 -183
- package/src/communication-service/template.ts +0 -110
- package/src/communication-service/util.ts +0 -8
- package/src/config/config.ts +0 -211
- package/src/config/env.ts +0 -95
- package/src/config/index.ts +0 -3
- package/src/config/secrets.ts +0 -17
- package/src/context.ts +0 -399
- package/src/daemon/blob-diverter.ts +0 -186
- package/src/daemon/context.ts +0 -247
- package/src/daemon/event-pusher.ts +0 -363
- package/src/daemon/event-reverser.ts +0 -128
- package/src/daemon/index.ts +0 -33
- package/src/daemon/job-cursor.ts +0 -33
- package/src/daemon/materialized-view-refresher.ts +0 -33
- package/src/daemon/queue-router.ts +0 -101
- package/src/daemon/scheduled-action-processor.ts +0 -304
- package/src/daemon/stats-computer.ts +0 -101
- package/src/daemon/strike-expiry-processor.ts +0 -95
- package/src/daemon/team-profile-synchronizer.ts +0 -15
- package/src/daemon/verification-listener.ts +0 -169
- package/src/db/index.ts +0 -203
- package/src/db/migrations/20231219T205730722Z-init.ts +0 -170
- package/src/db/migrations/20240116T085607200Z-communication-template.ts +0 -23
- package/src/db/migrations/20240201T051104136Z-mod-event-blobs.ts +0 -15
- package/src/db/migrations/20240208T213404429Z-add-tags-column-to-moderation-subject.ts +0 -31
- package/src/db/migrations/20240228T003647759Z-add-label-sigs.ts +0 -25
- package/src/db/migrations/20240408T192432676Z-mute-reporting.ts +0 -15
- package/src/db/migrations/20240506T225055595Z-message-subject.ts +0 -21
- package/src/db/migrations/20240521T211332580Z-member.ts +0 -17
- package/src/db/migrations/20240814T003647759Z-event-created-at-index.ts +0 -13
- package/src/db/migrations/20240903T205730722Z-add-template-lang.ts +0 -12
- package/src/db/migrations/20240904T205730722Z-add-subject-did-index.ts +0 -13
- package/src/db/migrations/20241001T205730722Z-subject-status-review-state-index.ts +0 -15
- package/src/db/migrations/20241008T205730722Z-sets.ts +0 -53
- package/src/db/migrations/20241018T205730722Z-setting.ts +0 -27
- package/src/db/migrations/20241026T205730722Z-add-hosting-status-to-subject-status.ts +0 -57
- package/src/db/migrations/20241220T144630860Z-stats-materialized-views.ts +0 -215
- package/src/db/migrations/20250204T003647759Z-add-subject-priority-score.ts +0 -22
- package/src/db/migrations/20250211T003647759Z-add-reporter-stats-index.ts +0 -38
- package/src/db/migrations/20250211T132135150Z-moderation-event-message-partial-idx.ts +0 -26
- package/src/db/migrations/20250221T132135150Z-member-details.ts +0 -14
- package/src/db/migrations/20250404T201720309Z-subject-status-sort-idxs.ts +0 -18
- package/src/db/migrations/20250415T201720309Z-verification.ts +0 -34
- package/src/db/migrations/20250417T201720309Z-firehose-cursor.ts +0 -16
- package/src/db/migrations/20250609T110704000Z-safelink.ts +0 -53
- package/src/db/migrations/20250618T180246000Z-add-mod-tool-to-moderation-event.ts +0 -18
- package/src/db/migrations/20250701T000000000Z-add-age-assurance-state.ts +0 -25
- package/src/db/migrations/20250715T000000000Z-add-mod-event-external-id.ts +0 -15
- package/src/db/migrations/20250718T150931000Z-update-appeal-reason-stats.ts +0 -310
- package/src/db/migrations/20250813T000000000Z-mod-tool-batch-id-index.ts +0 -14
- package/src/db/migrations/20250923T000000000Z-scheduled-actions.ts +0 -56
- package/src/db/migrations/20251008T120000000Z-add-strike-system.ts +0 -87
- package/src/db/migrations/20260210T154806448Z-mod-event-created-by-indexes.ts +0 -22
- package/src/db/migrations/20260219T164523000Z-create-report-table.ts +0 -155
- package/src/db/migrations/20260219T165302248Z-moderator-assignment.ts +0 -42
- package/src/db/migrations/20260225T000000000Z-add-report-queue-table.ts +0 -41
- package/src/db/migrations/20260313T000000000Z-add-report-activity-table.ts +0 -48
- package/src/db/migrations/20260318T152058935Z-add-report-stat.ts +0 -35
- package/src/db/migrations/20260428T000000000Z-add-expiring-tag-table.ts +0 -32
- package/src/db/migrations/20260513T202941104Z-add-subject-convo-id.ts +0 -114
- package/src/db/migrations/20260602T120000000Z-add-report-activity-created-index.ts +0 -17
- package/src/db/migrations/index.ts +0 -44
- package/src/db/migrations/provider.ts +0 -26
- package/src/db/pagination.ts +0 -335
- package/src/db/schema/account_events_stats.ts +0 -16
- package/src/db/schema/account_record_events_stats.ts +0 -15
- package/src/db/schema/account_record_status_stats.ts +0 -15
- package/src/db/schema/account_strike.ts +0 -13
- package/src/db/schema/blob_push_event.ts +0 -21
- package/src/db/schema/communication_template.ts +0 -19
- package/src/db/schema/expiring_tag.ts +0 -18
- package/src/db/schema/firehose_cursor.ts +0 -13
- package/src/db/schema/index.ts +0 -60
- package/src/db/schema/job_cursor.ts +0 -13
- package/src/db/schema/label.ts +0 -22
- package/src/db/schema/member.ts +0 -22
- package/src/db/schema/moderation_event.ts +0 -61
- package/src/db/schema/moderation_subject_status.ts +0 -52
- package/src/db/schema/moderator_assignment.ts +0 -16
- package/src/db/schema/ozone_set.ts +0 -24
- package/src/db/schema/record_events_stats.ts +0 -15
- package/src/db/schema/record_push_event.ts +0 -21
- package/src/db/schema/repo_push_event.ts +0 -19
- package/src/db/schema/report.ts +0 -28
- package/src/db/schema/report_activity.ts +0 -22
- package/src/db/schema/report_queue.ts +0 -21
- package/src/db/schema/report_stat.ts +0 -27
- package/src/db/schema/safelink.ts +0 -39
- package/src/db/schema/scheduled-action.ts +0 -25
- package/src/db/schema/setting.ts +0 -24
- package/src/db/schema/signing_key.ts +0 -10
- package/src/db/schema/verification.ts +0 -21
- package/src/db/types.ts +0 -24
- package/src/error.ts +0 -12
- package/src/image-invalidator.ts +0 -7
- package/src/index.ts +0 -154
- package/src/jetstream/service.ts +0 -107
- package/src/logger.ts +0 -29
- package/src/mod-service/expiring-tags.ts +0 -104
- package/src/mod-service/index.ts +0 -1842
- package/src/mod-service/profile.ts +0 -139
- package/src/mod-service/report.ts +0 -429
- package/src/mod-service/status.ts +0 -549
- package/src/mod-service/strike.ts +0 -96
- package/src/mod-service/subject.ts +0 -311
- package/src/mod-service/types.ts +0 -96
- package/src/mod-service/util.ts +0 -99
- package/src/mod-service/views.ts +0 -912
- package/src/queue/service.ts +0 -603
- package/src/report/activity.ts +0 -281
- package/src/report/handle-report-update.ts +0 -209
- package/src/report/reassign.ts +0 -109
- package/src/report/stats.ts +0 -852
- package/src/report/views.ts +0 -239
- package/src/safelink/service.ts +0 -304
- package/src/scheduled-action/service.ts +0 -281
- package/src/scheduled-action/types.ts +0 -17
- package/src/sequencer/index.ts +0 -2
- package/src/sequencer/outbox.ts +0 -123
- package/src/sequencer/sequencer.ts +0 -147
- package/src/set/service.ts +0 -230
- package/src/setting/constants.ts +0 -3
- package/src/setting/service.ts +0 -148
- package/src/setting/types.ts +0 -3
- package/src/setting/validators.ts +0 -333
- package/src/tag-service/content-tagger.ts +0 -30
- package/src/tag-service/embed-tagger.ts +0 -70
- package/src/tag-service/index.ts +0 -70
- package/src/tag-service/language-data.ts +0 -561
- package/src/tag-service/language-tagger.ts +0 -101
- package/src/tag-service/util.ts +0 -13
- package/src/team/index.ts +0 -296
- package/src/util.ts +0 -230
- package/src/verification/issuer.ts +0 -146
- package/src/verification/service.ts +0 -208
- package/src/verification/util.ts +0 -53
- package/test.env +0 -2
- package/tests/3p-labeler.test.ts +0 -288
- package/tests/__snapshots__/account-strikes.test.ts.snap +0 -159
- package/tests/__snapshots__/age-assurance.test.ts.snap +0 -66
- package/tests/__snapshots__/blob-divert.test.ts.snap +0 -219
- package/tests/__snapshots__/get-account-timeline.test.ts.snap +0 -36
- package/tests/__snapshots__/get-record.test.ts.snap +0 -271
- package/tests/__snapshots__/get-records.test.ts.snap +0 -175
- package/tests/__snapshots__/get-repo.test.ts.snap +0 -91
- package/tests/__snapshots__/get-repos.test.ts.snap +0 -127
- package/tests/__snapshots__/get-starter-pack.test.ts.snap +0 -535
- package/tests/__snapshots__/get-subjects.test.ts.snap +0 -529
- package/tests/__snapshots__/moderation-events.test.ts.snap +0 -347
- package/tests/__snapshots__/moderation-statuses.test.ts.snap +0 -276
- package/tests/__snapshots__/moderation.test.ts.snap +0 -85
- package/tests/__snapshots__/report-reason.test.ts.snap +0 -14
- package/tests/__snapshots__/safelink.test.ts.snap +0 -179
- package/tests/__snapshots__/scheduled-action.test.ts.snap +0 -61
- package/tests/__snapshots__/sets.test.ts.snap +0 -46
- package/tests/__snapshots__/settings.test.ts.snap +0 -52
- package/tests/__snapshots__/team.test.ts.snap +0 -374
- package/tests/__snapshots__/verification-listener.test.ts.snap +0 -152
- package/tests/__snapshots__/verification.test.ts.snap +0 -302
- package/tests/_util.ts +0 -242
- package/tests/account-strikes.test.ts +0 -184
- package/tests/ack-all-subjects-of-account.test.ts +0 -177
- package/tests/age-assurance.test.ts +0 -372
- package/tests/blob-divert.test.ts +0 -106
- package/tests/communication-templates.test.ts +0 -149
- package/tests/content-tagger.test.ts +0 -170
- package/tests/db.test.ts +0 -184
- package/tests/expiring-label.test.ts +0 -72
- package/tests/expiring-tags.test.ts +0 -232
- package/tests/get-account-timeline.test.ts +0 -85
- package/tests/get-config.test.ts +0 -55
- package/tests/get-lists.test.ts +0 -111
- package/tests/get-profiles.test.ts +0 -70
- package/tests/get-record.test.ts +0 -130
- package/tests/get-records.test.ts +0 -91
- package/tests/get-repo.test.ts +0 -171
- package/tests/get-report.test.ts +0 -136
- package/tests/get-reporter-stats.test.ts +0 -132
- package/tests/get-repos.test.ts +0 -91
- package/tests/get-starter-pack.test.ts +0 -115
- package/tests/get-subjects.test.ts +0 -81
- package/tests/mod-tool.test.ts +0 -268
- package/tests/moderation-appeals.test.ts +0 -260
- package/tests/moderation-events.test.ts +0 -756
- package/tests/moderation-status-tags.test.ts +0 -140
- package/tests/moderation-statuses.test.ts +0 -495
- package/tests/moderation.test.ts +0 -992
- package/tests/protected-tags.test.ts +0 -218
- package/tests/query-labels.test.ts +0 -238
- package/tests/query-reports.test.ts +0 -608
- package/tests/queue-assignment.test.ts +0 -428
- package/tests/queue-router.test.ts +0 -306
- package/tests/queues.test.ts +0 -690
- package/tests/record-and-account-events.test.ts +0 -197
- package/tests/repo-search.test.ts +0 -136
- package/tests/report-action.test.ts +0 -308
- package/tests/report-activity.test.ts +0 -711
- package/tests/report-assignment.test.ts +0 -517
- package/tests/report-muting.test.ts +0 -100
- package/tests/report-reason.test.ts +0 -154
- package/tests/report-reassign-queue.test.ts +0 -340
- package/tests/report-routing.test.ts +0 -245
- package/tests/report-stats.test.ts +0 -545
- package/tests/revoke-account-credentials.test.ts +0 -54
- package/tests/safelink.test.ts +0 -534
- package/tests/scheduled-action-processor.test.ts +0 -488
- package/tests/scheduled-action.test.ts +0 -334
- package/tests/sequencer.test.ts +0 -227
- package/tests/server.test.ts +0 -62
- package/tests/sets.test.ts +0 -246
- package/tests/settings.test.ts +0 -308
- package/tests/strike-expiry-processor.test.ts +0 -299
- package/tests/subject-priority-score.test.ts +0 -96
- package/tests/takedown.test.ts +0 -105
- package/tests/team.test.ts +0 -216
- package/tests/verification-listener.test.ts +0 -129
- package/tests/verification.test.ts +0 -186
- package/tsconfig.build.json +0 -9
- package/tsconfig.build.tsbuildinfo +0 -1
- package/tsconfig.json +0 -7
- package/tsconfig.tests.json +0 -8
package/tests/team.test.ts
DELETED
|
@@ -1,216 +0,0 @@
|
|
|
1
|
-
import { AtpAgent, ToolsOzoneTeamDefs } from '@atproto/api'
|
|
2
|
-
import { SeedClient, TestNetwork, basicSeed } from '@atproto/dev-env'
|
|
3
|
-
import { forSnapshot } from './_util.js'
|
|
4
|
-
|
|
5
|
-
describe('team management', () => {
|
|
6
|
-
let network: TestNetwork
|
|
7
|
-
let adminAgent: AtpAgent
|
|
8
|
-
let triageAgent: AtpAgent
|
|
9
|
-
let sc: SeedClient
|
|
10
|
-
|
|
11
|
-
beforeAll(async () => {
|
|
12
|
-
network = await TestNetwork.create({
|
|
13
|
-
dbPostgresSchema: 'ozone_team_test',
|
|
14
|
-
ozone: {
|
|
15
|
-
dbTeamProfileRefreshIntervalMs: 100,
|
|
16
|
-
},
|
|
17
|
-
})
|
|
18
|
-
adminAgent = network.pds.getAgent()
|
|
19
|
-
sc = network.getSeedClient()
|
|
20
|
-
await basicSeed(sc)
|
|
21
|
-
await network.processAll()
|
|
22
|
-
|
|
23
|
-
await network.ozone.addAdminDid(sc.dids.alice)
|
|
24
|
-
await network.ozone.addModeratorDid(sc.dids.bob)
|
|
25
|
-
await network.ozone.addTriageDid(sc.dids.carol)
|
|
26
|
-
await adminAgent.login({
|
|
27
|
-
identifier: sc.accounts[sc.dids.alice].handle,
|
|
28
|
-
password: sc.accounts[sc.dids.alice].password,
|
|
29
|
-
})
|
|
30
|
-
triageAgent = network.pds.getAgent()
|
|
31
|
-
await triageAgent.login({
|
|
32
|
-
identifier: sc.accounts[sc.dids.carol].handle,
|
|
33
|
-
password: sc.accounts[sc.dids.carol].password,
|
|
34
|
-
})
|
|
35
|
-
await network.processAll()
|
|
36
|
-
})
|
|
37
|
-
|
|
38
|
-
afterAll(async () => {
|
|
39
|
-
await network?.close()
|
|
40
|
-
})
|
|
41
|
-
|
|
42
|
-
describe('listMembers', () => {
|
|
43
|
-
it('allows all members to list all members', async () => {
|
|
44
|
-
const [{ data: forAdmin }, { data: forTriage }] = await Promise.all([
|
|
45
|
-
adminAgent.tools.ozone.team.listMembers({}),
|
|
46
|
-
triageAgent.tools.ozone.team.listMembers({}),
|
|
47
|
-
])
|
|
48
|
-
|
|
49
|
-
expect(forSnapshot(forAdmin.members)).toMatchSnapshot()
|
|
50
|
-
expect(forSnapshot(forTriage.members)).toMatchSnapshot()
|
|
51
|
-
// Validate that the list looks the same to both admin and triage members
|
|
52
|
-
|
|
53
|
-
expect(forAdmin.members.length).toEqual(forTriage.members.length)
|
|
54
|
-
})
|
|
55
|
-
it('allows filtering members by role', async () => {
|
|
56
|
-
const [{ data: onlyAdmins }, { data: onlyTriage }] = await Promise.all([
|
|
57
|
-
adminAgent.tools.ozone.team.listMembers({
|
|
58
|
-
roles: [ToolsOzoneTeamDefs.ROLEADMIN],
|
|
59
|
-
}),
|
|
60
|
-
adminAgent.tools.ozone.team.listMembers({
|
|
61
|
-
roles: [ToolsOzoneTeamDefs.ROLETRIAGE],
|
|
62
|
-
}),
|
|
63
|
-
])
|
|
64
|
-
|
|
65
|
-
expect(
|
|
66
|
-
onlyAdmins.members.find(
|
|
67
|
-
({ role }) => role !== ToolsOzoneTeamDefs.ROLEADMIN,
|
|
68
|
-
),
|
|
69
|
-
).toBeUndefined()
|
|
70
|
-
|
|
71
|
-
expect(
|
|
72
|
-
onlyTriage.members.find(
|
|
73
|
-
({ role }) => role !== ToolsOzoneTeamDefs.ROLETRIAGE,
|
|
74
|
-
),
|
|
75
|
-
).toBeUndefined()
|
|
76
|
-
})
|
|
77
|
-
it('allows filtering members by disabled status', async () => {
|
|
78
|
-
const [{ data: onlyDisabled }, { data: onlyEnabled }] = await Promise.all(
|
|
79
|
-
[
|
|
80
|
-
adminAgent.tools.ozone.team.listMembers({
|
|
81
|
-
disabled: true,
|
|
82
|
-
}),
|
|
83
|
-
adminAgent.tools.ozone.team.listMembers({
|
|
84
|
-
disabled: false,
|
|
85
|
-
}),
|
|
86
|
-
],
|
|
87
|
-
)
|
|
88
|
-
|
|
89
|
-
expect(
|
|
90
|
-
onlyDisabled.members.find(({ disabled }) => !disabled),
|
|
91
|
-
).toBeUndefined()
|
|
92
|
-
|
|
93
|
-
expect(
|
|
94
|
-
onlyEnabled.members.find(({ disabled }) => disabled),
|
|
95
|
-
).toBeUndefined()
|
|
96
|
-
})
|
|
97
|
-
it('allows filtering members by handle/display name', async () => {
|
|
98
|
-
const [{ data: matchingHandle }, { data: matchingName }] =
|
|
99
|
-
await Promise.all([
|
|
100
|
-
adminAgent.tools.ozone.team.listMembers({
|
|
101
|
-
q: 'bob',
|
|
102
|
-
}),
|
|
103
|
-
adminAgent.tools.ozone.team.listMembers({
|
|
104
|
-
q: 'dev',
|
|
105
|
-
}),
|
|
106
|
-
])
|
|
107
|
-
|
|
108
|
-
expect(matchingHandle.members.length).toEqual(1)
|
|
109
|
-
expect(matchingHandle.members[0]?.profile?.handle).toEqual('bob.test')
|
|
110
|
-
expect(matchingName.members.length).toEqual(1)
|
|
111
|
-
expect(matchingName.members[0]?.profile?.handle).toEqual(
|
|
112
|
-
'mod-authority.test',
|
|
113
|
-
)
|
|
114
|
-
})
|
|
115
|
-
})
|
|
116
|
-
|
|
117
|
-
describe('addMember', () => {
|
|
118
|
-
const newMemberData = {
|
|
119
|
-
did: 'did:plc:newMember',
|
|
120
|
-
role: 'tools.ozone.team.defs#roleAdmin',
|
|
121
|
-
disabled: false,
|
|
122
|
-
}
|
|
123
|
-
it('only allows admins to add member', async () => {
|
|
124
|
-
await expect(
|
|
125
|
-
triageAgent.tools.ozone.team.addMember(newMemberData),
|
|
126
|
-
).rejects.toThrow('Must be an admin to add a member')
|
|
127
|
-
const { data: newMember } =
|
|
128
|
-
await adminAgent.tools.ozone.team.addMember(newMemberData)
|
|
129
|
-
expect(forSnapshot(newMember)).toMatchSnapshot()
|
|
130
|
-
})
|
|
131
|
-
it('throws error when trying to add existing member', async () => {
|
|
132
|
-
await expect(
|
|
133
|
-
adminAgent.tools.ozone.team.addMember(newMemberData),
|
|
134
|
-
).rejects.toThrow('member already exists')
|
|
135
|
-
})
|
|
136
|
-
})
|
|
137
|
-
describe('deleteMember', () => {
|
|
138
|
-
it('only allows admins to delete members', async () => {
|
|
139
|
-
const {
|
|
140
|
-
data: { members: initialMembers },
|
|
141
|
-
} = await adminAgent.tools.ozone.team.listMembers({})
|
|
142
|
-
await expect(
|
|
143
|
-
triageAgent.tools.ozone.team.deleteMember({
|
|
144
|
-
did: sc.dids.bob,
|
|
145
|
-
}),
|
|
146
|
-
).rejects.toThrow('Must be an admin to delete a member')
|
|
147
|
-
|
|
148
|
-
await adminAgent.tools.ozone.team.deleteMember({
|
|
149
|
-
did: sc.dids.bob,
|
|
150
|
-
})
|
|
151
|
-
const {
|
|
152
|
-
data: { members: membersAfterDelete },
|
|
153
|
-
} = await adminAgent.tools.ozone.team.listMembers({})
|
|
154
|
-
|
|
155
|
-
expect(membersAfterDelete.length).toEqual(initialMembers.length - 1)
|
|
156
|
-
expect(membersAfterDelete.map(({ did }) => did)).not.toContain(
|
|
157
|
-
sc.dids.bob,
|
|
158
|
-
)
|
|
159
|
-
})
|
|
160
|
-
|
|
161
|
-
it('throws error when trying to remove non-existent member', async () => {
|
|
162
|
-
await expect(
|
|
163
|
-
adminAgent.tools.ozone.team.deleteMember({
|
|
164
|
-
did: 'did:plc:test',
|
|
165
|
-
}),
|
|
166
|
-
).rejects.toThrow('member not found')
|
|
167
|
-
})
|
|
168
|
-
})
|
|
169
|
-
describe('updateMember', () => {
|
|
170
|
-
it('allows admins to update member', async () => {
|
|
171
|
-
const getCarol = async () => {
|
|
172
|
-
const {
|
|
173
|
-
data: { members },
|
|
174
|
-
} = await adminAgent.tools.ozone.team.listMembers({})
|
|
175
|
-
|
|
176
|
-
return members.find(({ did }) => did === sc.dids.carol)
|
|
177
|
-
}
|
|
178
|
-
await expect(
|
|
179
|
-
triageAgent.tools.ozone.team.updateMember({
|
|
180
|
-
disabled: false,
|
|
181
|
-
did: sc.dids.carol,
|
|
182
|
-
role: 'tools.ozone.team.defs#roleAdmin',
|
|
183
|
-
}),
|
|
184
|
-
).rejects.toThrow('Must be an admin to update a member')
|
|
185
|
-
|
|
186
|
-
await adminAgent.tools.ozone.team.updateMember({
|
|
187
|
-
did: sc.dids.carol,
|
|
188
|
-
role: 'tools.ozone.team.defs#roleAdmin',
|
|
189
|
-
})
|
|
190
|
-
const carolAfterRoleChange = await getCarol()
|
|
191
|
-
expect(carolAfterRoleChange?.role).toEqual(
|
|
192
|
-
'tools.ozone.team.defs#roleAdmin',
|
|
193
|
-
)
|
|
194
|
-
// Verify that params that we didn't send did not get updated
|
|
195
|
-
expect(carolAfterRoleChange?.disabled).toEqual(false)
|
|
196
|
-
|
|
197
|
-
await adminAgent.tools.ozone.team.updateMember({
|
|
198
|
-
did: sc.dids.carol,
|
|
199
|
-
disabled: true,
|
|
200
|
-
})
|
|
201
|
-
const carolAfterDisable = await getCarol()
|
|
202
|
-
expect(carolAfterDisable?.disabled).toEqual(true)
|
|
203
|
-
// Verify that params that we didn't send did not get updated
|
|
204
|
-
expect(carolAfterDisable?.role).toEqual('tools.ozone.team.defs#roleAdmin')
|
|
205
|
-
})
|
|
206
|
-
it('throws error when trying to update non-existent member', async () => {
|
|
207
|
-
await expect(
|
|
208
|
-
adminAgent.tools.ozone.team.updateMember({
|
|
209
|
-
disabled: false,
|
|
210
|
-
did: 'did:plc:test',
|
|
211
|
-
role: 'tools.ozone.team.defs#roleAdmin',
|
|
212
|
-
}),
|
|
213
|
-
).rejects.toThrow('member not found')
|
|
214
|
-
})
|
|
215
|
-
})
|
|
216
|
-
})
|
|
@@ -1,129 +0,0 @@
|
|
|
1
|
-
import { once } from 'node:events'
|
|
2
|
-
import { createServer } from 'node:http'
|
|
3
|
-
import { AddressInfo } from 'node:net'
|
|
4
|
-
// eslint-disable-next-line import/default
|
|
5
|
-
import httpTerminator from 'http-terminator'
|
|
6
|
-
import { WebSocket, WebSocketServer } from 'ws'
|
|
7
|
-
import { AppBskyGraphVerification, AtpAgent } from '@atproto/api'
|
|
8
|
-
import { SeedClient, TestNetwork, basicSeed } from '@atproto/dev-env'
|
|
9
|
-
import { forSnapshot } from './_util.js'
|
|
10
|
-
|
|
11
|
-
describe('verification-listener', () => {
|
|
12
|
-
let network: TestNetwork
|
|
13
|
-
let sc: SeedClient
|
|
14
|
-
let adminAgent: AtpAgent
|
|
15
|
-
let jetstream: WebSocketServer
|
|
16
|
-
let relay: WebSocket
|
|
17
|
-
let terminator: httpTerminator.HttpTerminator
|
|
18
|
-
|
|
19
|
-
beforeAll(async () => {
|
|
20
|
-
const server = createServer()
|
|
21
|
-
terminator = httpTerminator.createHttpTerminator({ server })
|
|
22
|
-
|
|
23
|
-
await once(server.listen(0), 'listening')
|
|
24
|
-
const jetstreamPort = (server.address() as AddressInfo).port
|
|
25
|
-
|
|
26
|
-
jetstream = new WebSocketServer({ server })
|
|
27
|
-
const relayPromise = new Promise<WebSocket>((resolve, reject) => {
|
|
28
|
-
const cleanup = () => {
|
|
29
|
-
jetstream.off('connection', onConnection)
|
|
30
|
-
jetstream.off('error', onError)
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
const onConnection = (ws: WebSocket) => {
|
|
34
|
-
cleanup()
|
|
35
|
-
resolve(ws)
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
const onError = (err: Error) => {
|
|
39
|
-
cleanup()
|
|
40
|
-
reject(err)
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
jetstream.on('connection', onConnection)
|
|
44
|
-
jetstream.on('error', onError)
|
|
45
|
-
})
|
|
46
|
-
relayPromise.catch(() => {})
|
|
47
|
-
|
|
48
|
-
network = await TestNetwork.create({
|
|
49
|
-
dbPostgresSchema: 'ozone_verification_listener_test',
|
|
50
|
-
ozone: {
|
|
51
|
-
verifierUrl: 'http://localhost:2583',
|
|
52
|
-
verifierDid: 'did:example:verifier',
|
|
53
|
-
verifierPassword: 'test',
|
|
54
|
-
jetstreamUrl: `ws://localhost:${jetstreamPort}`,
|
|
55
|
-
},
|
|
56
|
-
})
|
|
57
|
-
sc = network.getSeedClient()
|
|
58
|
-
await basicSeed(sc)
|
|
59
|
-
|
|
60
|
-
adminAgent = network.pds.getAgent()
|
|
61
|
-
await adminAgent.login({
|
|
62
|
-
identifier: sc.accounts[sc.dids.alice].handle,
|
|
63
|
-
password: sc.accounts[sc.dids.alice].password,
|
|
64
|
-
})
|
|
65
|
-
await network.ozone.addAdminDid(sc.dids.alice)
|
|
66
|
-
|
|
67
|
-
relay = await relayPromise
|
|
68
|
-
})
|
|
69
|
-
|
|
70
|
-
beforeEach(async () => network.processAll())
|
|
71
|
-
afterAll(async () => network?.close())
|
|
72
|
-
afterAll(async () => relay.close())
|
|
73
|
-
afterAll(async () => terminator?.terminate())
|
|
74
|
-
|
|
75
|
-
it('indexes new and revoked verifications', async () => {
|
|
76
|
-
const { verificationListener } = network.ozone.daemon.ctx
|
|
77
|
-
const createEvent = {
|
|
78
|
-
kind: 'commit',
|
|
79
|
-
did: sc.dids.bob,
|
|
80
|
-
time_us: 123456789,
|
|
81
|
-
commit: {
|
|
82
|
-
rev: 'xyz',
|
|
83
|
-
operation: 'create',
|
|
84
|
-
collection: 'app.bsky.graph.verification',
|
|
85
|
-
rkey: 'abcdefg',
|
|
86
|
-
cid: 'xyz',
|
|
87
|
-
record: {
|
|
88
|
-
$type: 'app.bsky.graph.verification',
|
|
89
|
-
subject: sc.dids.alice,
|
|
90
|
-
handle: sc.accounts[sc.dids.alice].handle,
|
|
91
|
-
displayName: 'Alice',
|
|
92
|
-
createdAt: new Date().toISOString(),
|
|
93
|
-
} satisfies AppBskyGraphVerification.Record,
|
|
94
|
-
},
|
|
95
|
-
}
|
|
96
|
-
const deleteEvent = {
|
|
97
|
-
kind: 'commit',
|
|
98
|
-
did: sc.dids.bob,
|
|
99
|
-
time_us: 123456799,
|
|
100
|
-
commit: {
|
|
101
|
-
rev: 'yza',
|
|
102
|
-
operation: 'delete',
|
|
103
|
-
collection: 'app.bsky.graph.verification',
|
|
104
|
-
rkey: 'abcdefg',
|
|
105
|
-
},
|
|
106
|
-
}
|
|
107
|
-
relay.send(JSON.stringify(createEvent))
|
|
108
|
-
relay.send(JSON.stringify(deleteEvent))
|
|
109
|
-
const verificationService = network.ozone.ctx.verificationService(
|
|
110
|
-
network.ozone.ctx.db,
|
|
111
|
-
)
|
|
112
|
-
// Wait for the listener to process the events
|
|
113
|
-
let hasCursorUpdated = false
|
|
114
|
-
let attempt = 0
|
|
115
|
-
do {
|
|
116
|
-
const cursor = await verificationService.getFirehoseCursor()
|
|
117
|
-
hasCursorUpdated = cursor === 123456799
|
|
118
|
-
attempt++
|
|
119
|
-
} while (!hasCursorUpdated && attempt < 20)
|
|
120
|
-
// Give the processor enough time to handle the events
|
|
121
|
-
const {
|
|
122
|
-
data: { verifications },
|
|
123
|
-
} = await adminAgent.tools.ozone.verification.listVerifications({})
|
|
124
|
-
const cursor = await verificationListener?.getCursor()
|
|
125
|
-
|
|
126
|
-
expect(forSnapshot(verifications)).toMatchSnapshot()
|
|
127
|
-
expect(cursor).toEqual(123456799)
|
|
128
|
-
})
|
|
129
|
-
})
|
|
@@ -1,186 +0,0 @@
|
|
|
1
|
-
import { AppBskyActorDefs, AtpAgent, asPredicate } from '@atproto/api'
|
|
2
|
-
import { SeedClient, TestNetwork, basicSeed } from '@atproto/dev-env'
|
|
3
|
-
import { forSnapshot } from './_util.js'
|
|
4
|
-
|
|
5
|
-
const isValidProfile = asPredicate(AppBskyActorDefs.validateProfileViewDetailed)
|
|
6
|
-
|
|
7
|
-
describe('verification', () => {
|
|
8
|
-
let network: TestNetwork
|
|
9
|
-
let adminAgent: AtpAgent
|
|
10
|
-
let triageAgent: AtpAgent
|
|
11
|
-
let sc: SeedClient
|
|
12
|
-
|
|
13
|
-
beforeAll(async () => {
|
|
14
|
-
network = await TestNetwork.create({
|
|
15
|
-
dbPostgresSchema: 'ozone_verification_test',
|
|
16
|
-
})
|
|
17
|
-
adminAgent = network.pds.getAgent()
|
|
18
|
-
sc = network.getSeedClient()
|
|
19
|
-
await basicSeed(sc)
|
|
20
|
-
await network.processAll()
|
|
21
|
-
|
|
22
|
-
await network.ozone.addAdminDid(sc.dids.alice)
|
|
23
|
-
await network.ozone.addModeratorDid(sc.dids.bob)
|
|
24
|
-
await network.ozone.addTriageDid(sc.dids.carol)
|
|
25
|
-
await adminAgent.login({
|
|
26
|
-
identifier: sc.accounts[sc.dids.alice].handle,
|
|
27
|
-
password: sc.accounts[sc.dids.alice].password,
|
|
28
|
-
})
|
|
29
|
-
triageAgent = network.pds.getAgent()
|
|
30
|
-
await triageAgent.login({
|
|
31
|
-
identifier: sc.accounts[sc.dids.carol].handle,
|
|
32
|
-
password: sc.accounts[sc.dids.carol].password,
|
|
33
|
-
})
|
|
34
|
-
const {
|
|
35
|
-
data: { password },
|
|
36
|
-
} = await adminAgent.com.atproto.server.createAppPassword({
|
|
37
|
-
name: 'verifier',
|
|
38
|
-
})
|
|
39
|
-
network.ozone.ctx.cfg.verifier = {
|
|
40
|
-
url: network.pds.url,
|
|
41
|
-
did: sc.dids.alice,
|
|
42
|
-
password,
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
await network.processAll()
|
|
46
|
-
await network.bsky.db.db
|
|
47
|
-
.updateTable('actor')
|
|
48
|
-
.set({ trustedVerifier: true })
|
|
49
|
-
.where('did', 'in', [sc.dids.alice])
|
|
50
|
-
.execute()
|
|
51
|
-
})
|
|
52
|
-
|
|
53
|
-
afterAll(async () => {
|
|
54
|
-
await network?.close()
|
|
55
|
-
})
|
|
56
|
-
|
|
57
|
-
describe('list', () => {
|
|
58
|
-
// @TODO: This tests encapsulates the entire grant->revoke->list flow. we should have more detailed test for each path
|
|
59
|
-
it('returns paginated list of verifications', async () => {
|
|
60
|
-
const {
|
|
61
|
-
data: { verifications },
|
|
62
|
-
} = await adminAgent.tools.ozone.verification.grantVerifications({
|
|
63
|
-
verifications: [
|
|
64
|
-
{
|
|
65
|
-
subject: sc.dids.bob,
|
|
66
|
-
handle: sc.accounts[sc.dids.bob].handle,
|
|
67
|
-
displayName: 'bobby',
|
|
68
|
-
},
|
|
69
|
-
{
|
|
70
|
-
subject: sc.dids.carol,
|
|
71
|
-
handle: sc.accounts[sc.dids.carol].handle,
|
|
72
|
-
displayName: '',
|
|
73
|
-
},
|
|
74
|
-
],
|
|
75
|
-
})
|
|
76
|
-
|
|
77
|
-
const grantedVerificationUri = verifications.find(
|
|
78
|
-
(v) => v.subject === sc.dids.carol,
|
|
79
|
-
)?.uri
|
|
80
|
-
|
|
81
|
-
expect(grantedVerificationUri).toBeDefined()
|
|
82
|
-
|
|
83
|
-
if (grantedVerificationUri) {
|
|
84
|
-
await adminAgent.tools.ozone.verification.revokeVerifications({
|
|
85
|
-
uris: [grantedVerificationUri],
|
|
86
|
-
revokeReason: 'Testing',
|
|
87
|
-
})
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
await network.processAll()
|
|
91
|
-
|
|
92
|
-
const { data } =
|
|
93
|
-
await adminAgent.tools.ozone.verification.listVerifications({})
|
|
94
|
-
|
|
95
|
-
expect(data.verifications.find((v) => v.revokedAt)?.uri).toEqual(
|
|
96
|
-
grantedVerificationUri,
|
|
97
|
-
)
|
|
98
|
-
const bob = data.verifications.find((v) => v.subject === sc.dids.bob)
|
|
99
|
-
const carol = data.verifications.find((v) => v.subject === sc.dids.carol)
|
|
100
|
-
|
|
101
|
-
if (
|
|
102
|
-
!isValidProfile(bob?.subjectProfile) ||
|
|
103
|
-
!isValidProfile(carol?.subjectProfile)
|
|
104
|
-
) {
|
|
105
|
-
throw Error('Invalid profiles')
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
expect(forSnapshot(bob)).toMatchSnapshot()
|
|
109
|
-
expect(forSnapshot(carol)).toMatchSnapshot()
|
|
110
|
-
|
|
111
|
-
// Assert that profile record carries valid verification status for bob but not for carol
|
|
112
|
-
expect(carol.revokedAt).toBeDefined()
|
|
113
|
-
expect(carol.revokeReason).toEqual('Testing')
|
|
114
|
-
expect(carol.subjectProfile.verification).toBeUndefined()
|
|
115
|
-
expect(bob.subjectProfile?.verification?.verifiedStatus).toEqual('valid')
|
|
116
|
-
})
|
|
117
|
-
})
|
|
118
|
-
|
|
119
|
-
describe('grant', () => {
|
|
120
|
-
it('fails for non-admins and non-verifiers', async () => {
|
|
121
|
-
const attemptAsAdmin =
|
|
122
|
-
triageAgent.tools.ozone.verification.grantVerifications({
|
|
123
|
-
verifications: [
|
|
124
|
-
{
|
|
125
|
-
subject: sc.dids.bob,
|
|
126
|
-
handle: sc.accounts[sc.dids.bob].handle,
|
|
127
|
-
displayName: 'Bob',
|
|
128
|
-
},
|
|
129
|
-
],
|
|
130
|
-
})
|
|
131
|
-
await expect(attemptAsAdmin).rejects.toThrow(
|
|
132
|
-
'Must be an admin or verifier to grant verifications',
|
|
133
|
-
)
|
|
134
|
-
})
|
|
135
|
-
|
|
136
|
-
it('fails if the handle is invalid', async () => {
|
|
137
|
-
const {
|
|
138
|
-
data: { verifications, failedVerifications },
|
|
139
|
-
} = await adminAgent.tools.ozone.verification.grantVerifications({
|
|
140
|
-
verifications: [
|
|
141
|
-
{
|
|
142
|
-
subject: sc.dids.dan,
|
|
143
|
-
handle: 'handle.invalid',
|
|
144
|
-
displayName: 'Bob',
|
|
145
|
-
},
|
|
146
|
-
],
|
|
147
|
-
})
|
|
148
|
-
|
|
149
|
-
expect(verifications.length).toEqual(0)
|
|
150
|
-
expect(failedVerifications.length).toEqual(1)
|
|
151
|
-
const failed = failedVerifications.at(0)
|
|
152
|
-
expect(failed!.error).toEqual('Cannot verify with invalid handle')
|
|
153
|
-
expect(failed!.subject).toEqual(sc.dids.dan)
|
|
154
|
-
})
|
|
155
|
-
})
|
|
156
|
-
|
|
157
|
-
it('does not publish record if a valid one already exists', async () => {
|
|
158
|
-
const { data: beforePublish } =
|
|
159
|
-
await adminAgent.tools.ozone.verification.listVerifications({
|
|
160
|
-
subjects: [sc.dids.bob],
|
|
161
|
-
})
|
|
162
|
-
const {
|
|
163
|
-
data: { verifications },
|
|
164
|
-
} = await adminAgent.tools.ozone.verification.grantVerifications({
|
|
165
|
-
verifications: [
|
|
166
|
-
{
|
|
167
|
-
subject: sc.dids.bob,
|
|
168
|
-
handle: sc.accounts[sc.dids.bob].handle,
|
|
169
|
-
displayName: 'bobby',
|
|
170
|
-
},
|
|
171
|
-
],
|
|
172
|
-
})
|
|
173
|
-
|
|
174
|
-
const { data: afterPublish } =
|
|
175
|
-
await adminAgent.tools.ozone.verification.listVerifications({
|
|
176
|
-
subjects: [sc.dids.bob],
|
|
177
|
-
})
|
|
178
|
-
|
|
179
|
-
// assert that the response does not contain any new verification
|
|
180
|
-
expect(verifications.length).toEqual(0)
|
|
181
|
-
// assert that the list of verifications in db hasn't changed
|
|
182
|
-
expect(afterPublish.verifications.length).toEqual(
|
|
183
|
-
beforePublish.verifications.length,
|
|
184
|
-
)
|
|
185
|
-
})
|
|
186
|
-
})
|
package/tsconfig.build.json
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":"7.0.0-dev.20260614.1","root":["./src/auth-verifier.ts","./src/background.ts","./src/context.ts","./src/error.ts","./src/image-invalidator.ts","./src/index.ts","./src/logger.ts","./src/util.ts","./src/api/health.ts","./src/api/index.ts","./src/api/proxied.ts","./src/api/util.ts","./src/api/well-known.ts","./src/api/chat/getActorMetadata.ts","./src/api/chat/getConvo.ts","./src/api/chat/getConvoMembers.ts","./src/api/chat/getConvos.ts","./src/api/chat/getMessageContext.ts","./src/api/chat/index.ts","./src/api/communication/createTemplate.ts","./src/api/communication/deleteTemplate.ts","./src/api/communication/listTemplates.ts","./src/api/communication/updateTemplate.ts","./src/api/label/fetchLabels.ts","./src/api/label/queryLabels.ts","./src/api/label/subscribeLabels.ts","./src/api/moderation/cancelScheduledActions.ts","./src/api/moderation/emitEvent.ts","./src/api/moderation/getAccountTimeline.ts","./src/api/moderation/getEvent.ts","./src/api/moderation/getRecord.ts","./src/api/moderation/getRecords.ts","./src/api/moderation/getRepo.ts","./src/api/moderation/getReporterStats.ts","./src/api/moderation/getRepos.ts","./src/api/moderation/getSubjects.ts","./src/api/moderation/listScheduledActions.ts","./src/api/moderation/queryEvents.ts","./src/api/moderation/queryStatuses.ts","./src/api/moderation/scheduleAction.ts","./src/api/moderation/searchRepos.ts","./src/api/moderation/util.ts","./src/api/queue/assignModerator.ts","./src/api/queue/createQueue.ts","./src/api/queue/deleteQueue.ts","./src/api/queue/getAssignments.ts","./src/api/queue/listQueues.ts","./src/api/queue/routeReports.ts","./src/api/queue/unassignModerator.ts","./src/api/queue/updateQueue.ts","./src/api/report/assignModerator.ts","./src/api/report/createActivity.ts","./src/api/report/createReport.ts","./src/api/report/getAssignments.ts","./src/api/report/getHistoricalStats.ts","./src/api/report/getLatestReport.ts","./src/api/report/getLiveStats.ts","./src/api/report/getReport.ts","./src/api/report/listActivities.ts","./src/api/report/queryActivities.ts","./src/api/report/queryReports.ts","./src/api/report/reassignQueue.ts","./src/api/report/refreshStats.ts","./src/api/report/unassignModerator.ts","./src/api/safelink/addRule.ts","./src/api/safelink/queryEvents.ts","./src/api/safelink/queryRules.ts","./src/api/safelink/removeRule.ts","./src/api/safelink/updateRule.ts","./src/api/server/getConfig.ts","./src/api/set/addValues.ts","./src/api/set/deleteSet.ts","./src/api/set/deleteValues.ts","./src/api/set/getValues.ts","./src/api/set/querySets.ts","./src/api/set/upsertSet.ts","./src/api/setting/listOptions.ts","./src/api/setting/removeOptions.ts","./src/api/setting/upsertOption.ts","./src/api/team/addMember.ts","./src/api/team/deleteMember.ts","./src/api/team/listMembers.ts","./src/api/team/updateMember.ts","./src/api/verification/grantVerifications.ts","./src/api/verification/listVerifications.ts","./src/api/verification/revokeVerifications.ts","./src/assignment/index.ts","./src/communication-service/template.ts","./src/communication-service/util.ts","./src/config/config.ts","./src/config/env.ts","./src/config/index.ts","./src/config/secrets.ts","./src/daemon/blob-diverter.ts","./src/daemon/context.ts","./src/daemon/event-pusher.ts","./src/daemon/event-reverser.ts","./src/daemon/index.ts","./src/daemon/job-cursor.ts","./src/daemon/materialized-view-refresher.ts","./src/daemon/queue-router.ts","./src/daemon/scheduled-action-processor.ts","./src/daemon/stats-computer.ts","./src/daemon/strike-expiry-processor.ts","./src/daemon/team-profile-synchronizer.ts","./src/daemon/verification-listener.ts","./src/db/index.ts","./src/db/pagination.ts","./src/db/types.ts","./src/db/migrations/20231219T205730722Z-init.ts","./src/db/migrations/20240116T085607200Z-communication-template.ts","./src/db/migrations/20240201T051104136Z-mod-event-blobs.ts","./src/db/migrations/20240208T213404429Z-add-tags-column-to-moderation-subject.ts","./src/db/migrations/20240228T003647759Z-add-label-sigs.ts","./src/db/migrations/20240408T192432676Z-mute-reporting.ts","./src/db/migrations/20240506T225055595Z-message-subject.ts","./src/db/migrations/20240521T211332580Z-member.ts","./src/db/migrations/20240814T003647759Z-event-created-at-index.ts","./src/db/migrations/20240903T205730722Z-add-template-lang.ts","./src/db/migrations/20240904T205730722Z-add-subject-did-index.ts","./src/db/migrations/20241001T205730722Z-subject-status-review-state-index.ts","./src/db/migrations/20241008T205730722Z-sets.ts","./src/db/migrations/20241018T205730722Z-setting.ts","./src/db/migrations/20241026T205730722Z-add-hosting-status-to-subject-status.ts","./src/db/migrations/20241220T144630860Z-stats-materialized-views.ts","./src/db/migrations/20250204T003647759Z-add-subject-priority-score.ts","./src/db/migrations/20250211T003647759Z-add-reporter-stats-index.ts","./src/db/migrations/20250211T132135150Z-moderation-event-message-partial-idx.ts","./src/db/migrations/20250221T132135150Z-member-details.ts","./src/db/migrations/20250404T201720309Z-subject-status-sort-idxs.ts","./src/db/migrations/20250415T201720309Z-verification.ts","./src/db/migrations/20250417T201720309Z-firehose-cursor.ts","./src/db/migrations/20250609T110704000Z-safelink.ts","./src/db/migrations/20250618T180246000Z-add-mod-tool-to-moderation-event.ts","./src/db/migrations/20250701T000000000Z-add-age-assurance-state.ts","./src/db/migrations/20250715T000000000Z-add-mod-event-external-id.ts","./src/db/migrations/20250718T150931000Z-update-appeal-reason-stats.ts","./src/db/migrations/20250813T000000000Z-mod-tool-batch-id-index.ts","./src/db/migrations/20250923T000000000Z-scheduled-actions.ts","./src/db/migrations/20251008T120000000Z-add-strike-system.ts","./src/db/migrations/20260210T154806448Z-mod-event-created-by-indexes.ts","./src/db/migrations/20260219T164523000Z-create-report-table.ts","./src/db/migrations/20260219T165302248Z-moderator-assignment.ts","./src/db/migrations/20260225T000000000Z-add-report-queue-table.ts","./src/db/migrations/20260313T000000000Z-add-report-activity-table.ts","./src/db/migrations/20260318T152058935Z-add-report-stat.ts","./src/db/migrations/20260428T000000000Z-add-expiring-tag-table.ts","./src/db/migrations/20260513T202941104Z-add-subject-convo-id.ts","./src/db/migrations/20260602T120000000Z-add-report-activity-created-index.ts","./src/db/migrations/index.ts","./src/db/migrations/provider.ts","./src/db/schema/account_events_stats.ts","./src/db/schema/account_record_events_stats.ts","./src/db/schema/account_record_status_stats.ts","./src/db/schema/account_strike.ts","./src/db/schema/blob_push_event.ts","./src/db/schema/communication_template.ts","./src/db/schema/expiring_tag.ts","./src/db/schema/firehose_cursor.ts","./src/db/schema/index.ts","./src/db/schema/job_cursor.ts","./src/db/schema/label.ts","./src/db/schema/member.ts","./src/db/schema/moderation_event.ts","./src/db/schema/moderation_subject_status.ts","./src/db/schema/moderator_assignment.ts","./src/db/schema/ozone_set.ts","./src/db/schema/record_events_stats.ts","./src/db/schema/record_push_event.ts","./src/db/schema/repo_push_event.ts","./src/db/schema/report.ts","./src/db/schema/report_activity.ts","./src/db/schema/report_queue.ts","./src/db/schema/report_stat.ts","./src/db/schema/safelink.ts","./src/db/schema/scheduled-action.ts","./src/db/schema/setting.ts","./src/db/schema/signing_key.ts","./src/db/schema/verification.ts","./src/jetstream/service.ts","./src/lexicon/index.ts","./src/lexicon/lexicons.ts","./src/lexicon/util.ts","./src/lexicon/types/app/bsky/actor/defs.ts","./src/lexicon/types/app/bsky/actor/getPreferences.ts","./src/lexicon/types/app/bsky/actor/getProfile.ts","./src/lexicon/types/app/bsky/actor/getProfiles.ts","./src/lexicon/types/app/bsky/actor/getSuggestions.ts","./src/lexicon/types/app/bsky/actor/profile.ts","./src/lexicon/types/app/bsky/actor/putPreferences.ts","./src/lexicon/types/app/bsky/actor/searchActors.ts","./src/lexicon/types/app/bsky/actor/searchActorsTypeahead.ts","./src/lexicon/types/app/bsky/actor/status.ts","./src/lexicon/types/app/bsky/ageassurance/begin.ts","./src/lexicon/types/app/bsky/ageassurance/defs.ts","./src/lexicon/types/app/bsky/ageassurance/getConfig.ts","./src/lexicon/types/app/bsky/ageassurance/getState.ts","./src/lexicon/types/app/bsky/bookmark/createBookmark.ts","./src/lexicon/types/app/bsky/bookmark/defs.ts","./src/lexicon/types/app/bsky/bookmark/deleteBookmark.ts","./src/lexicon/types/app/bsky/bookmark/getBookmarks.ts","./src/lexicon/types/app/bsky/contact/defs.ts","./src/lexicon/types/app/bsky/contact/dismissMatch.ts","./src/lexicon/types/app/bsky/contact/getMatches.ts","./src/lexicon/types/app/bsky/contact/getSyncStatus.ts","./src/lexicon/types/app/bsky/contact/importContacts.ts","./src/lexicon/types/app/bsky/contact/removeData.ts","./src/lexicon/types/app/bsky/contact/sendNotification.ts","./src/lexicon/types/app/bsky/contact/startPhoneVerification.ts","./src/lexicon/types/app/bsky/contact/verifyPhone.ts","./src/lexicon/types/app/bsky/draft/createDraft.ts","./src/lexicon/types/app/bsky/draft/defs.ts","./src/lexicon/types/app/bsky/draft/deleteDraft.ts","./src/lexicon/types/app/bsky/draft/getDrafts.ts","./src/lexicon/types/app/bsky/draft/updateDraft.ts","./src/lexicon/types/app/bsky/embed/defs.ts","./src/lexicon/types/app/bsky/embed/external.ts","./src/lexicon/types/app/bsky/embed/gallery.ts","./src/lexicon/types/app/bsky/embed/getEmbedExternalView.ts","./src/lexicon/types/app/bsky/embed/images.ts","./src/lexicon/types/app/bsky/embed/record.ts","./src/lexicon/types/app/bsky/embed/recordWithMedia.ts","./src/lexicon/types/app/bsky/embed/video.ts","./src/lexicon/types/app/bsky/feed/defs.ts","./src/lexicon/types/app/bsky/feed/describeFeedGenerator.ts","./src/lexicon/types/app/bsky/feed/generator.ts","./src/lexicon/types/app/bsky/feed/getActorFeeds.ts","./src/lexicon/types/app/bsky/feed/getActorLikes.ts","./src/lexicon/types/app/bsky/feed/getAuthorFeed.ts","./src/lexicon/types/app/bsky/feed/getFeed.ts","./src/lexicon/types/app/bsky/feed/getFeedGenerator.ts","./src/lexicon/types/app/bsky/feed/getFeedGenerators.ts","./src/lexicon/types/app/bsky/feed/getFeedSkeleton.ts","./src/lexicon/types/app/bsky/feed/getLikes.ts","./src/lexicon/types/app/bsky/feed/getListFeed.ts","./src/lexicon/types/app/bsky/feed/getPostThread.ts","./src/lexicon/types/app/bsky/feed/getPosts.ts","./src/lexicon/types/app/bsky/feed/getQuotes.ts","./src/lexicon/types/app/bsky/feed/getRepostedBy.ts","./src/lexicon/types/app/bsky/feed/getSuggestedFeeds.ts","./src/lexicon/types/app/bsky/feed/getTimeline.ts","./src/lexicon/types/app/bsky/feed/like.ts","./src/lexicon/types/app/bsky/feed/post.ts","./src/lexicon/types/app/bsky/feed/postgate.ts","./src/lexicon/types/app/bsky/feed/repost.ts","./src/lexicon/types/app/bsky/feed/searchPosts.ts","./src/lexicon/types/app/bsky/feed/searchPostsV2.ts","./src/lexicon/types/app/bsky/feed/sendInteractions.ts","./src/lexicon/types/app/bsky/feed/threadgate.ts","./src/lexicon/types/app/bsky/graph/block.ts","./src/lexicon/types/app/bsky/graph/defs.ts","./src/lexicon/types/app/bsky/graph/follow.ts","./src/lexicon/types/app/bsky/graph/getActorStarterPacks.ts","./src/lexicon/types/app/bsky/graph/getBlocks.ts","./src/lexicon/types/app/bsky/graph/getFollowers.ts","./src/lexicon/types/app/bsky/graph/getFollows.ts","./src/lexicon/types/app/bsky/graph/getKnownFollowers.ts","./src/lexicon/types/app/bsky/graph/getList.ts","./src/lexicon/types/app/bsky/graph/getListBlocks.ts","./src/lexicon/types/app/bsky/graph/getListMutes.ts","./src/lexicon/types/app/bsky/graph/getLists.ts","./src/lexicon/types/app/bsky/graph/getListsWithMembership.ts","./src/lexicon/types/app/bsky/graph/getMutes.ts","./src/lexicon/types/app/bsky/graph/getRelationships.ts","./src/lexicon/types/app/bsky/graph/getStarterPack.ts","./src/lexicon/types/app/bsky/graph/getStarterPacks.ts","./src/lexicon/types/app/bsky/graph/getStarterPacksWithMembership.ts","./src/lexicon/types/app/bsky/graph/getSuggestedFollowsByActor.ts","./src/lexicon/types/app/bsky/graph/list.ts","./src/lexicon/types/app/bsky/graph/listblock.ts","./src/lexicon/types/app/bsky/graph/listitem.ts","./src/lexicon/types/app/bsky/graph/muteActor.ts","./src/lexicon/types/app/bsky/graph/muteActorList.ts","./src/lexicon/types/app/bsky/graph/muteThread.ts","./src/lexicon/types/app/bsky/graph/searchStarterPacks.ts","./src/lexicon/types/app/bsky/graph/starterpack.ts","./src/lexicon/types/app/bsky/graph/unmuteActor.ts","./src/lexicon/types/app/bsky/graph/unmuteActorList.ts","./src/lexicon/types/app/bsky/graph/unmuteThread.ts","./src/lexicon/types/app/bsky/graph/verification.ts","./src/lexicon/types/app/bsky/labeler/defs.ts","./src/lexicon/types/app/bsky/labeler/getServices.ts","./src/lexicon/types/app/bsky/labeler/service.ts","./src/lexicon/types/app/bsky/notification/declaration.ts","./src/lexicon/types/app/bsky/notification/defs.ts","./src/lexicon/types/app/bsky/notification/getPreferences.ts","./src/lexicon/types/app/bsky/notification/getUnreadCount.ts","./src/lexicon/types/app/bsky/notification/listActivitySubscriptions.ts","./src/lexicon/types/app/bsky/notification/listNotifications.ts","./src/lexicon/types/app/bsky/notification/putActivitySubscription.ts","./src/lexicon/types/app/bsky/notification/putPreferences.ts","./src/lexicon/types/app/bsky/notification/putPreferencesV2.ts","./src/lexicon/types/app/bsky/notification/registerPush.ts","./src/lexicon/types/app/bsky/notification/unregisterPush.ts","./src/lexicon/types/app/bsky/notification/updateSeen.ts","./src/lexicon/types/app/bsky/richtext/facet.ts","./src/lexicon/types/app/bsky/unspecced/defs.ts","./src/lexicon/types/app/bsky/unspecced/getAgeAssuranceState.ts","./src/lexicon/types/app/bsky/unspecced/getConfig.ts","./src/lexicon/types/app/bsky/unspecced/getOnboardingSuggestedStarterPacks.ts","./src/lexicon/types/app/bsky/unspecced/getOnboardingSuggestedStarterPacksSkeleton.ts","./src/lexicon/types/app/bsky/unspecced/getOnboardingSuggestedUsersSkeleton.ts","./src/lexicon/types/app/bsky/unspecced/getPopularFeedGenerators.ts","./src/lexicon/types/app/bsky/unspecced/getPostThreadOtherV2.ts","./src/lexicon/types/app/bsky/unspecced/getPostThreadV2.ts","./src/lexicon/types/app/bsky/unspecced/getSuggestedFeeds.ts","./src/lexicon/types/app/bsky/unspecced/getSuggestedFeedsSkeleton.ts","./src/lexicon/types/app/bsky/unspecced/getSuggestedOnboardingUsers.ts","./src/lexicon/types/app/bsky/unspecced/getSuggestedStarterPacks.ts","./src/lexicon/types/app/bsky/unspecced/getSuggestedStarterPacksSkeleton.ts","./src/lexicon/types/app/bsky/unspecced/getSuggestedUsers.ts","./src/lexicon/types/app/bsky/unspecced/getSuggestedUsersForDiscover.ts","./src/lexicon/types/app/bsky/unspecced/getSuggestedUsersForDiscoverSkeleton.ts","./src/lexicon/types/app/bsky/unspecced/getSuggestedUsersForExplore.ts","./src/lexicon/types/app/bsky/unspecced/getSuggestedUsersForExploreSkeleton.ts","./src/lexicon/types/app/bsky/unspecced/getSuggestedUsersForSeeMore.ts","./src/lexicon/types/app/bsky/unspecced/getSuggestedUsersForSeeMoreSkeleton.ts","./src/lexicon/types/app/bsky/unspecced/getSuggestedUsersSkeleton.ts","./src/lexicon/types/app/bsky/unspecced/getSuggestionsSkeleton.ts","./src/lexicon/types/app/bsky/unspecced/getTaggedSuggestions.ts","./src/lexicon/types/app/bsky/unspecced/getTrendingTopics.ts","./src/lexicon/types/app/bsky/unspecced/getTrends.ts","./src/lexicon/types/app/bsky/unspecced/getTrendsSkeleton.ts","./src/lexicon/types/app/bsky/unspecced/initAgeAssurance.ts","./src/lexicon/types/app/bsky/unspecced/searchActorsSkeleton.ts","./src/lexicon/types/app/bsky/unspecced/searchPostsSkeleton.ts","./src/lexicon/types/app/bsky/unspecced/searchStarterPacksSkeleton.ts","./src/lexicon/types/app/bsky/video/defs.ts","./src/lexicon/types/app/bsky/video/getJobStatus.ts","./src/lexicon/types/app/bsky/video/getUploadLimits.ts","./src/lexicon/types/app/bsky/video/uploadVideo.ts","./src/lexicon/types/chat/bsky/actor/declaration.ts","./src/lexicon/types/chat/bsky/actor/defs.ts","./src/lexicon/types/chat/bsky/actor/deleteAccount.ts","./src/lexicon/types/chat/bsky/actor/exportAccountData.ts","./src/lexicon/types/chat/bsky/actor/getStatus.ts","./src/lexicon/types/chat/bsky/convo/acceptConvo.ts","./src/lexicon/types/chat/bsky/convo/addReaction.ts","./src/lexicon/types/chat/bsky/convo/defs.ts","./src/lexicon/types/chat/bsky/convo/deleteMessageForSelf.ts","./src/lexicon/types/chat/bsky/convo/getConvo.ts","./src/lexicon/types/chat/bsky/convo/getConvoAvailability.ts","./src/lexicon/types/chat/bsky/convo/getConvoForMembers.ts","./src/lexicon/types/chat/bsky/convo/getConvoMembers.ts","./src/lexicon/types/chat/bsky/convo/getLog.ts","./src/lexicon/types/chat/bsky/convo/getMessages.ts","./src/lexicon/types/chat/bsky/convo/getUnreadCounts.ts","./src/lexicon/types/chat/bsky/convo/leaveConvo.ts","./src/lexicon/types/chat/bsky/convo/listConvoRequests.ts","./src/lexicon/types/chat/bsky/convo/listConvos.ts","./src/lexicon/types/chat/bsky/convo/lockConvo.ts","./src/lexicon/types/chat/bsky/convo/muteConvo.ts","./src/lexicon/types/chat/bsky/convo/removeReaction.ts","./src/lexicon/types/chat/bsky/convo/sendMessage.ts","./src/lexicon/types/chat/bsky/convo/sendMessageBatch.ts","./src/lexicon/types/chat/bsky/convo/unlockConvo.ts","./src/lexicon/types/chat/bsky/convo/unmuteConvo.ts","./src/lexicon/types/chat/bsky/convo/updateAllRead.ts","./src/lexicon/types/chat/bsky/convo/updateRead.ts","./src/lexicon/types/chat/bsky/embed/joinLink.ts","./src/lexicon/types/chat/bsky/group/addMembers.ts","./src/lexicon/types/chat/bsky/group/approveJoinRequest.ts","./src/lexicon/types/chat/bsky/group/createGroup.ts","./src/lexicon/types/chat/bsky/group/createJoinLink.ts","./src/lexicon/types/chat/bsky/group/defs.ts","./src/lexicon/types/chat/bsky/group/disableJoinLink.ts","./src/lexicon/types/chat/bsky/group/editGroup.ts","./src/lexicon/types/chat/bsky/group/editJoinLink.ts","./src/lexicon/types/chat/bsky/group/enableJoinLink.ts","./src/lexicon/types/chat/bsky/group/getJoinLinkPreviews.ts","./src/lexicon/types/chat/bsky/group/listJoinRequests.ts","./src/lexicon/types/chat/bsky/group/listMutualGroups.ts","./src/lexicon/types/chat/bsky/group/rejectJoinRequest.ts","./src/lexicon/types/chat/bsky/group/removeMembers.ts","./src/lexicon/types/chat/bsky/group/requestJoin.ts","./src/lexicon/types/chat/bsky/group/updateJoinRequestsRead.ts","./src/lexicon/types/chat/bsky/group/withdrawJoinRequest.ts","./src/lexicon/types/chat/bsky/moderation/defs.ts","./src/lexicon/types/chat/bsky/moderation/getActorMetadata.ts","./src/lexicon/types/chat/bsky/moderation/getConvo.ts","./src/lexicon/types/chat/bsky/moderation/getConvoMembers.ts","./src/lexicon/types/chat/bsky/moderation/getConvos.ts","./src/lexicon/types/chat/bsky/moderation/getMessageContext.ts","./src/lexicon/types/chat/bsky/moderation/subscribeModEvents.ts","./src/lexicon/types/chat/bsky/moderation/updateActorAccess.ts","./src/lexicon/types/chat/bsky/notification/defs.ts","./src/lexicon/types/chat/bsky/notification/getPreferences.ts","./src/lexicon/types/chat/bsky/notification/putPreferences.ts","./src/lexicon/types/com/atproto/admin/defs.ts","./src/lexicon/types/com/atproto/admin/deleteAccount.ts","./src/lexicon/types/com/atproto/admin/disableAccountInvites.ts","./src/lexicon/types/com/atproto/admin/disableInviteCodes.ts","./src/lexicon/types/com/atproto/admin/enableAccountInvites.ts","./src/lexicon/types/com/atproto/admin/getAccountInfo.ts","./src/lexicon/types/com/atproto/admin/getAccountInfos.ts","./src/lexicon/types/com/atproto/admin/getInviteCodes.ts","./src/lexicon/types/com/atproto/admin/getSubjectStatus.ts","./src/lexicon/types/com/atproto/admin/searchAccounts.ts","./src/lexicon/types/com/atproto/admin/sendEmail.ts","./src/lexicon/types/com/atproto/admin/updateAccountEmail.ts","./src/lexicon/types/com/atproto/admin/updateAccountHandle.ts","./src/lexicon/types/com/atproto/admin/updateAccountPassword.ts","./src/lexicon/types/com/atproto/admin/updateAccountSigningKey.ts","./src/lexicon/types/com/atproto/admin/updateSubjectStatus.ts","./src/lexicon/types/com/atproto/identity/defs.ts","./src/lexicon/types/com/atproto/identity/getRecommendedDidCredentials.ts","./src/lexicon/types/com/atproto/identity/refreshIdentity.ts","./src/lexicon/types/com/atproto/identity/requestPlcOperationSignature.ts","./src/lexicon/types/com/atproto/identity/resolveDid.ts","./src/lexicon/types/com/atproto/identity/resolveHandle.ts","./src/lexicon/types/com/atproto/identity/resolveIdentity.ts","./src/lexicon/types/com/atproto/identity/signPlcOperation.ts","./src/lexicon/types/com/atproto/identity/submitPlcOperation.ts","./src/lexicon/types/com/atproto/identity/updateHandle.ts","./src/lexicon/types/com/atproto/label/defs.ts","./src/lexicon/types/com/atproto/label/queryLabels.ts","./src/lexicon/types/com/atproto/label/subscribeLabels.ts","./src/lexicon/types/com/atproto/lexicon/resolveLexicon.ts","./src/lexicon/types/com/atproto/lexicon/schema.ts","./src/lexicon/types/com/atproto/moderation/createReport.ts","./src/lexicon/types/com/atproto/moderation/defs.ts","./src/lexicon/types/com/atproto/repo/applyWrites.ts","./src/lexicon/types/com/atproto/repo/createRecord.ts","./src/lexicon/types/com/atproto/repo/defs.ts","./src/lexicon/types/com/atproto/repo/deleteRecord.ts","./src/lexicon/types/com/atproto/repo/describeRepo.ts","./src/lexicon/types/com/atproto/repo/getRecord.ts","./src/lexicon/types/com/atproto/repo/importRepo.ts","./src/lexicon/types/com/atproto/repo/listMissingBlobs.ts","./src/lexicon/types/com/atproto/repo/listRecords.ts","./src/lexicon/types/com/atproto/repo/putRecord.ts","./src/lexicon/types/com/atproto/repo/strongRef.ts","./src/lexicon/types/com/atproto/repo/uploadBlob.ts","./src/lexicon/types/com/atproto/server/activateAccount.ts","./src/lexicon/types/com/atproto/server/checkAccountStatus.ts","./src/lexicon/types/com/atproto/server/confirmEmail.ts","./src/lexicon/types/com/atproto/server/createAccount.ts","./src/lexicon/types/com/atproto/server/createAppPassword.ts","./src/lexicon/types/com/atproto/server/createInviteCode.ts","./src/lexicon/types/com/atproto/server/createInviteCodes.ts","./src/lexicon/types/com/atproto/server/createSession.ts","./src/lexicon/types/com/atproto/server/deactivateAccount.ts","./src/lexicon/types/com/atproto/server/defs.ts","./src/lexicon/types/com/atproto/server/deleteAccount.ts","./src/lexicon/types/com/atproto/server/deleteSession.ts","./src/lexicon/types/com/atproto/server/describeServer.ts","./src/lexicon/types/com/atproto/server/getAccountInviteCodes.ts","./src/lexicon/types/com/atproto/server/getServiceAuth.ts","./src/lexicon/types/com/atproto/server/getSession.ts","./src/lexicon/types/com/atproto/server/listAppPasswords.ts","./src/lexicon/types/com/atproto/server/refreshSession.ts","./src/lexicon/types/com/atproto/server/requestAccountDelete.ts","./src/lexicon/types/com/atproto/server/requestEmailConfirmation.ts","./src/lexicon/types/com/atproto/server/requestEmailUpdate.ts","./src/lexicon/types/com/atproto/server/requestPasswordReset.ts","./src/lexicon/types/com/atproto/server/reserveSigningKey.ts","./src/lexicon/types/com/atproto/server/resetPassword.ts","./src/lexicon/types/com/atproto/server/revokeAppPassword.ts","./src/lexicon/types/com/atproto/server/updateEmail.ts","./src/lexicon/types/com/atproto/sync/defs.ts","./src/lexicon/types/com/atproto/sync/getBlob.ts","./src/lexicon/types/com/atproto/sync/getBlocks.ts","./src/lexicon/types/com/atproto/sync/getCheckout.ts","./src/lexicon/types/com/atproto/sync/getHead.ts","./src/lexicon/types/com/atproto/sync/getHostStatus.ts","./src/lexicon/types/com/atproto/sync/getLatestCommit.ts","./src/lexicon/types/com/atproto/sync/getRecord.ts","./src/lexicon/types/com/atproto/sync/getRepo.ts","./src/lexicon/types/com/atproto/sync/getRepoStatus.ts","./src/lexicon/types/com/atproto/sync/listBlobs.ts","./src/lexicon/types/com/atproto/sync/listHosts.ts","./src/lexicon/types/com/atproto/sync/listRepos.ts","./src/lexicon/types/com/atproto/sync/listReposByCollection.ts","./src/lexicon/types/com/atproto/sync/notifyOfUpdate.ts","./src/lexicon/types/com/atproto/sync/requestCrawl.ts","./src/lexicon/types/com/atproto/sync/subscribeRepos.ts","./src/lexicon/types/com/atproto/temp/addReservedHandle.ts","./src/lexicon/types/com/atproto/temp/checkHandleAvailability.ts","./src/lexicon/types/com/atproto/temp/checkSignupQueue.ts","./src/lexicon/types/com/atproto/temp/dereferenceScope.ts","./src/lexicon/types/com/atproto/temp/fetchLabels.ts","./src/lexicon/types/com/atproto/temp/requestPhoneVerification.ts","./src/lexicon/types/com/atproto/temp/revokeAccountCredentials.ts","./src/lexicon/types/tools/ozone/communication/createTemplate.ts","./src/lexicon/types/tools/ozone/communication/defs.ts","./src/lexicon/types/tools/ozone/communication/deleteTemplate.ts","./src/lexicon/types/tools/ozone/communication/listTemplates.ts","./src/lexicon/types/tools/ozone/communication/updateTemplate.ts","./src/lexicon/types/tools/ozone/hosting/getAccountHistory.ts","./src/lexicon/types/tools/ozone/moderation/cancelScheduledActions.ts","./src/lexicon/types/tools/ozone/moderation/defs.ts","./src/lexicon/types/tools/ozone/moderation/emitEvent.ts","./src/lexicon/types/tools/ozone/moderation/getAccountTimeline.ts","./src/lexicon/types/tools/ozone/moderation/getEvent.ts","./src/lexicon/types/tools/ozone/moderation/getRecord.ts","./src/lexicon/types/tools/ozone/moderation/getRecords.ts","./src/lexicon/types/tools/ozone/moderation/getRepo.ts","./src/lexicon/types/tools/ozone/moderation/getReporterStats.ts","./src/lexicon/types/tools/ozone/moderation/getRepos.ts","./src/lexicon/types/tools/ozone/moderation/getSubjects.ts","./src/lexicon/types/tools/ozone/moderation/listScheduledActions.ts","./src/lexicon/types/tools/ozone/moderation/queryEvents.ts","./src/lexicon/types/tools/ozone/moderation/queryStatuses.ts","./src/lexicon/types/tools/ozone/moderation/scheduleAction.ts","./src/lexicon/types/tools/ozone/moderation/searchRepos.ts","./src/lexicon/types/tools/ozone/queue/assignModerator.ts","./src/lexicon/types/tools/ozone/queue/createQueue.ts","./src/lexicon/types/tools/ozone/queue/defs.ts","./src/lexicon/types/tools/ozone/queue/deleteQueue.ts","./src/lexicon/types/tools/ozone/queue/getAssignments.ts","./src/lexicon/types/tools/ozone/queue/listQueues.ts","./src/lexicon/types/tools/ozone/queue/routeReports.ts","./src/lexicon/types/tools/ozone/queue/unassignModerator.ts","./src/lexicon/types/tools/ozone/queue/updateQueue.ts","./src/lexicon/types/tools/ozone/report/assignModerator.ts","./src/lexicon/types/tools/ozone/report/createActivity.ts","./src/lexicon/types/tools/ozone/report/defs.ts","./src/lexicon/types/tools/ozone/report/getAssignments.ts","./src/lexicon/types/tools/ozone/report/getHistoricalStats.ts","./src/lexicon/types/tools/ozone/report/getLatestReport.ts","./src/lexicon/types/tools/ozone/report/getLiveStats.ts","./src/lexicon/types/tools/ozone/report/getReport.ts","./src/lexicon/types/tools/ozone/report/listActivities.ts","./src/lexicon/types/tools/ozone/report/queryActivities.ts","./src/lexicon/types/tools/ozone/report/queryReports.ts","./src/lexicon/types/tools/ozone/report/reassignQueue.ts","./src/lexicon/types/tools/ozone/report/refreshStats.ts","./src/lexicon/types/tools/ozone/report/unassignModerator.ts","./src/lexicon/types/tools/ozone/safelink/addRule.ts","./src/lexicon/types/tools/ozone/safelink/defs.ts","./src/lexicon/types/tools/ozone/safelink/queryEvents.ts","./src/lexicon/types/tools/ozone/safelink/queryRules.ts","./src/lexicon/types/tools/ozone/safelink/removeRule.ts","./src/lexicon/types/tools/ozone/safelink/updateRule.ts","./src/lexicon/types/tools/ozone/server/getConfig.ts","./src/lexicon/types/tools/ozone/set/addValues.ts","./src/lexicon/types/tools/ozone/set/defs.ts","./src/lexicon/types/tools/ozone/set/deleteSet.ts","./src/lexicon/types/tools/ozone/set/deleteValues.ts","./src/lexicon/types/tools/ozone/set/getValues.ts","./src/lexicon/types/tools/ozone/set/querySets.ts","./src/lexicon/types/tools/ozone/set/upsertSet.ts","./src/lexicon/types/tools/ozone/setting/defs.ts","./src/lexicon/types/tools/ozone/setting/listOptions.ts","./src/lexicon/types/tools/ozone/setting/removeOptions.ts","./src/lexicon/types/tools/ozone/setting/upsertOption.ts","./src/lexicon/types/tools/ozone/signature/defs.ts","./src/lexicon/types/tools/ozone/signature/findCorrelation.ts","./src/lexicon/types/tools/ozone/signature/findRelatedAccounts.ts","./src/lexicon/types/tools/ozone/signature/searchAccounts.ts","./src/lexicon/types/tools/ozone/team/addMember.ts","./src/lexicon/types/tools/ozone/team/defs.ts","./src/lexicon/types/tools/ozone/team/deleteMember.ts","./src/lexicon/types/tools/ozone/team/listMembers.ts","./src/lexicon/types/tools/ozone/team/updateMember.ts","./src/lexicon/types/tools/ozone/verification/defs.ts","./src/lexicon/types/tools/ozone/verification/grantVerifications.ts","./src/lexicon/types/tools/ozone/verification/listVerifications.ts","./src/lexicon/types/tools/ozone/verification/revokeVerifications.ts","./src/mod-service/expiring-tags.ts","./src/mod-service/index.ts","./src/mod-service/profile.ts","./src/mod-service/report.ts","./src/mod-service/status.ts","./src/mod-service/strike.ts","./src/mod-service/subject.ts","./src/mod-service/types.ts","./src/mod-service/util.ts","./src/mod-service/views.ts","./src/queue/service.ts","./src/report/activity.ts","./src/report/handle-report-update.ts","./src/report/reassign.ts","./src/report/stats.ts","./src/report/views.ts","./src/safelink/service.ts","./src/scheduled-action/service.ts","./src/scheduled-action/types.ts","./src/sequencer/index.ts","./src/sequencer/outbox.ts","./src/sequencer/sequencer.ts","./src/set/service.ts","./src/setting/constants.ts","./src/setting/service.ts","./src/setting/types.ts","./src/setting/validators.ts","./src/tag-service/content-tagger.ts","./src/tag-service/embed-tagger.ts","./src/tag-service/index.ts","./src/tag-service/language-data.ts","./src/tag-service/language-tagger.ts","./src/tag-service/util.ts","./src/team/index.ts","./src/verification/issuer.ts","./src/verification/service.ts","./src/verification/util.ts"]}
|
package/tsconfig.json
DELETED