@atproto/pds 0.4.140 → 0.4.142

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.
Files changed (59) hide show
  1. package/CHANGELOG.md +19 -0
  2. package/dist/account-manager/account-manager.d.ts.map +1 -1
  3. package/dist/account-manager/account-manager.js +3 -0
  4. package/dist/account-manager/account-manager.js.map +1 -1
  5. package/dist/account-manager/helpers/scrypt.d.ts +2 -0
  6. package/dist/account-manager/helpers/scrypt.d.ts.map +1 -1
  7. package/dist/account-manager/helpers/scrypt.js +3 -1
  8. package/dist/account-manager/helpers/scrypt.js.map +1 -1
  9. package/dist/account-manager/oauth-store.js +1 -1
  10. package/dist/account-manager/oauth-store.js.map +1 -1
  11. package/dist/api/com/atproto/admin/updateAccountPassword.d.ts.map +1 -1
  12. package/dist/api/com/atproto/admin/updateAccountPassword.js +5 -0
  13. package/dist/api/com/atproto/admin/updateAccountPassword.js.map +1 -1
  14. package/dist/api/com/atproto/server/createAccount.d.ts.map +1 -1
  15. package/dist/api/com/atproto/server/createAccount.js +4 -0
  16. package/dist/api/com/atproto/server/createAccount.js.map +1 -1
  17. package/dist/api/com/atproto/server/createSession.d.ts.map +1 -1
  18. package/dist/api/com/atproto/server/createSession.js +4 -0
  19. package/dist/api/com/atproto/server/createSession.js.map +1 -1
  20. package/dist/api/com/atproto/server/deleteAccount.d.ts.map +1 -1
  21. package/dist/api/com/atproto/server/deleteAccount.js +4 -0
  22. package/dist/api/com/atproto/server/deleteAccount.js.map +1 -1
  23. package/dist/api/com/atproto/server/resetPassword.d.ts.map +1 -1
  24. package/dist/api/com/atproto/server/resetPassword.js +5 -0
  25. package/dist/api/com/atproto/server/resetPassword.js.map +1 -1
  26. package/dist/lexicon/lexicons.d.ts +116 -124
  27. package/dist/lexicon/lexicons.d.ts.map +1 -1
  28. package/dist/lexicon/lexicons.js +68 -66
  29. package/dist/lexicon/lexicons.js.map +1 -1
  30. package/dist/lexicon/types/app/bsky/unspecced/defs.d.ts +33 -0
  31. package/dist/lexicon/types/app/bsky/unspecced/defs.d.ts.map +1 -1
  32. package/dist/lexicon/types/app/bsky/unspecced/defs.js +36 -0
  33. package/dist/lexicon/types/app/bsky/unspecced/defs.js.map +1 -1
  34. package/dist/lexicon/types/app/bsky/unspecced/getPostThreadHiddenV2.d.ts +5 -13
  35. package/dist/lexicon/types/app/bsky/unspecced/getPostThreadHiddenV2.d.ts.map +1 -1
  36. package/dist/lexicon/types/app/bsky/unspecced/getPostThreadHiddenV2.js +0 -9
  37. package/dist/lexicon/types/app/bsky/unspecced/getPostThreadHiddenV2.js.map +1 -1
  38. package/dist/lexicon/types/app/bsky/unspecced/getPostThreadV2.d.ts +2 -29
  39. package/dist/lexicon/types/app/bsky/unspecced/getPostThreadV2.d.ts.map +1 -1
  40. package/dist/lexicon/types/app/bsky/unspecced/getPostThreadV2.js +0 -36
  41. package/dist/lexicon/types/app/bsky/unspecced/getPostThreadV2.js.map +1 -1
  42. package/dist/lexicon/types/tools/ozone/moderation/defs.d.ts +1 -1
  43. package/dist/lexicon/types/tools/ozone/moderation/defs.d.ts.map +1 -1
  44. package/dist/lexicon/types/tools/ozone/moderation/defs.js.map +1 -1
  45. package/package.json +9 -9
  46. package/src/account-manager/account-manager.ts +4 -0
  47. package/src/account-manager/helpers/scrypt.ts +3 -0
  48. package/src/account-manager/oauth-store.ts +1 -1
  49. package/src/api/com/atproto/admin/updateAccountPassword.ts +7 -0
  50. package/src/api/com/atproto/server/createAccount.ts +7 -0
  51. package/src/api/com/atproto/server/createSession.ts +7 -0
  52. package/src/api/com/atproto/server/deleteAccount.ts +5 -0
  53. package/src/api/com/atproto/server/resetPassword.ts +6 -0
  54. package/src/lexicon/lexicons.ts +74 -71
  55. package/src/lexicon/types/app/bsky/unspecced/defs.ts +73 -0
  56. package/src/lexicon/types/app/bsky/unspecced/getPostThreadHiddenV2.ts +5 -22
  57. package/src/lexicon/types/app/bsky/unspecced/getPostThreadV2.ts +5 -72
  58. package/src/lexicon/types/tools/ozone/moderation/defs.ts +1 -0
  59. package/tests/proxied/admin.test.ts +1 -1
@@ -1,6 +1,7 @@
1
1
  import { MINUTE } from '@atproto/common'
2
2
  import { AuthRequiredError, InvalidRequestError } from '@atproto/xrpc-server'
3
3
  import { AccountStatus } from '../../../../account-manager/account-manager'
4
+ import { OLD_PASSWORD_MAX_LENGTH } from '../../../../account-manager/helpers/scrypt'
4
5
  import { AppContext } from '../../../../context'
5
6
  import { Server } from '../../../../lexicon'
6
7
 
@@ -29,6 +30,10 @@ export default function (server: Server, ctx: AppContext) {
29
30
  return
30
31
  }
31
32
 
33
+ if (password.length > OLD_PASSWORD_MAX_LENGTH) {
34
+ throw new InvalidRequestError('Invalid password length.')
35
+ }
36
+
32
37
  const validPass = await ctx.accountManager.verifyAccountPassword(
33
38
  did,
34
39
  password,
@@ -1,4 +1,6 @@
1
1
  import { MINUTE } from '@atproto/common'
2
+ import { InvalidRequestError } from '@atproto/xrpc-server'
3
+ import { NEW_PASSWORD_MAX_LENGTH } from '../../../../account-manager/helpers/scrypt'
2
4
  import { AppContext } from '../../../../context'
3
5
  import { Server } from '../../../../lexicon'
4
6
 
@@ -21,6 +23,10 @@ export default function (server: Server, ctx: AppContext) {
21
23
 
22
24
  const { token, password } = input.body
23
25
 
26
+ if (password.length > NEW_PASSWORD_MAX_LENGTH) {
27
+ throw new InvalidRequestError('Invalid password length.')
28
+ }
29
+
24
30
  await ctx.accountManager.resetPassword({ token, password })
25
31
  },
26
32
  })
@@ -10201,6 +10201,66 @@ export const schemaDict = {
10201
10201
  },
10202
10202
  },
10203
10203
  },
10204
+ threadItemPost: {
10205
+ type: 'object',
10206
+ required: [
10207
+ 'post',
10208
+ 'moreParents',
10209
+ 'moreReplies',
10210
+ 'opThread',
10211
+ 'hiddenByThreadgate',
10212
+ 'mutedByViewer',
10213
+ ],
10214
+ properties: {
10215
+ post: {
10216
+ type: 'ref',
10217
+ ref: 'lex:app.bsky.feed.defs#postView',
10218
+ },
10219
+ moreParents: {
10220
+ type: 'boolean',
10221
+ description:
10222
+ 'This post has more parents that were not present in the response. This is just a boolean, without the number of parents.',
10223
+ },
10224
+ moreReplies: {
10225
+ type: 'integer',
10226
+ description:
10227
+ 'This post has more replies that were not present in the response. This is a numeric value, which is best-effort and might not be accurate.',
10228
+ },
10229
+ opThread: {
10230
+ type: 'boolean',
10231
+ description:
10232
+ 'This post is part of a contiguous thread by the OP from the thread root. Many different OP threads can happen in the same thread.',
10233
+ },
10234
+ hiddenByThreadgate: {
10235
+ type: 'boolean',
10236
+ description:
10237
+ 'The threadgate created by the author indicates this post as a reply to be hidden for everyone consuming the thread.',
10238
+ },
10239
+ mutedByViewer: {
10240
+ type: 'boolean',
10241
+ description:
10242
+ 'This is by an account muted by the viewer requesting it.',
10243
+ },
10244
+ },
10245
+ },
10246
+ threadItemNoUnauthenticated: {
10247
+ type: 'object',
10248
+ properties: {},
10249
+ },
10250
+ threadItemNotFound: {
10251
+ type: 'object',
10252
+ properties: {},
10253
+ },
10254
+ threadItemBlocked: {
10255
+ type: 'object',
10256
+ required: ['author'],
10257
+ properties: {
10258
+ author: {
10259
+ type: 'ref',
10260
+ ref: 'lex:app.bsky.feed.defs#blockedAuthor',
10261
+ },
10262
+ },
10263
+ },
10204
10264
  },
10205
10265
  },
10206
10266
  AppBskyUnspeccedGetConfig: {
@@ -10312,6 +10372,12 @@ export const schemaDict = {
10312
10372
  description:
10313
10373
  'Reference (AT-URI) to post record. This is the anchor post.',
10314
10374
  },
10375
+ prioritizeFollowedUsers: {
10376
+ type: 'boolean',
10377
+ description:
10378
+ 'Whether to prioritize posts from followed users. It only has effect when the user is authenticated.',
10379
+ default: false,
10380
+ },
10315
10381
  },
10316
10382
  },
10317
10383
  output: {
@@ -10323,7 +10389,7 @@ export const schemaDict = {
10323
10389
  thread: {
10324
10390
  type: 'array',
10325
10391
  description:
10326
- 'A flat list of thread hidden items. The depth of each item is indicated by the depth property inside the item.',
10392
+ 'A flat list of hidden thread items. The depth of each item is indicated by the depth property inside the item.',
10327
10393
  items: {
10328
10394
  type: 'ref',
10329
10395
  ref: 'lex:app.bsky.unspecced.getPostThreadHiddenV2#threadHiddenItem',
@@ -10348,29 +10414,7 @@ export const schemaDict = {
10348
10414
  },
10349
10415
  value: {
10350
10416
  type: 'union',
10351
- refs: [
10352
- 'lex:app.bsky.unspecced.getPostThreadHiddenV2#threadHiddenItemPost',
10353
- ],
10354
- },
10355
- },
10356
- },
10357
- threadHiddenItemPost: {
10358
- type: 'object',
10359
- required: ['post', 'hiddenByThreadgate', 'mutedByViewer'],
10360
- properties: {
10361
- post: {
10362
- type: 'ref',
10363
- ref: 'lex:app.bsky.feed.defs#postView',
10364
- },
10365
- hiddenByThreadgate: {
10366
- type: 'boolean',
10367
- description:
10368
- 'The threadgate created by the author indicates this post as a reply to be hidden for everyone consuming the thread.',
10369
- },
10370
- mutedByViewer: {
10371
- type: 'boolean',
10372
- description:
10373
- 'This is by an account muted by the viewer requesting it.',
10417
+ refs: ['lex:app.bsky.unspecced.defs#threadItemPost'],
10374
10418
  },
10375
10419
  },
10376
10420
  },
@@ -10473,57 +10517,14 @@ export const schemaDict = {
10473
10517
  value: {
10474
10518
  type: 'union',
10475
10519
  refs: [
10476
- 'lex:app.bsky.unspecced.getPostThreadV2#threadItemPost',
10477
- 'lex:app.bsky.unspecced.getPostThreadV2#threadItemNoUnauthenticated',
10478
- 'lex:app.bsky.unspecced.getPostThreadV2#threadItemNotFound',
10479
- 'lex:app.bsky.unspecced.getPostThreadV2#threadItemBlocked',
10520
+ 'lex:app.bsky.unspecced.defs#threadItemPost',
10521
+ 'lex:app.bsky.unspecced.defs#threadItemNoUnauthenticated',
10522
+ 'lex:app.bsky.unspecced.defs#threadItemNotFound',
10523
+ 'lex:app.bsky.unspecced.defs#threadItemBlocked',
10480
10524
  ],
10481
10525
  },
10482
10526
  },
10483
10527
  },
10484
- threadItemPost: {
10485
- type: 'object',
10486
- required: ['post', 'moreParents', 'moreReplies', 'opThread'],
10487
- properties: {
10488
- post: {
10489
- type: 'ref',
10490
- ref: 'lex:app.bsky.feed.defs#postView',
10491
- },
10492
- moreParents: {
10493
- type: 'boolean',
10494
- description:
10495
- 'This post has more parents that were not present in the response. This is just a boolean, without the number of parents.',
10496
- },
10497
- moreReplies: {
10498
- type: 'integer',
10499
- description:
10500
- 'This post has more replies that were not present in the response. This is a numeric value, which is best-effort and might not be accurate.',
10501
- },
10502
- opThread: {
10503
- type: 'boolean',
10504
- description:
10505
- 'This post is part of a contiguous thread by the OP from the thread root. Many different OP threads can happen in the same thread.',
10506
- },
10507
- },
10508
- },
10509
- threadItemNoUnauthenticated: {
10510
- type: 'object',
10511
- properties: {},
10512
- },
10513
- threadItemNotFound: {
10514
- type: 'object',
10515
- properties: {},
10516
- },
10517
- threadItemBlocked: {
10518
- type: 'object',
10519
- required: ['author'],
10520
- properties: {
10521
- author: {
10522
- type: 'ref',
10523
- ref: 'lex:app.bsky.feed.defs#blockedAuthor',
10524
- },
10525
- },
10526
- },
10527
10528
  },
10528
10529
  },
10529
10530
  AppBskyUnspeccedGetSuggestedFeeds: {
@@ -13229,6 +13230,7 @@ export const schemaDict = {
13229
13230
  refs: [
13230
13231
  'lex:com.atproto.admin.defs#repoRef',
13231
13232
  'lex:com.atproto.repo.strongRef',
13233
+ 'lex:chat.bsky.convo.defs#messageRef',
13232
13234
  ],
13233
13235
  },
13234
13236
  hosting: {
@@ -16154,6 +16156,7 @@ export const schemaDict = {
16154
16156
  },
16155
16157
  createdAt: {
16156
16158
  type: 'string',
16159
+ format: 'datetime',
16157
16160
  description:
16158
16161
  'Timestamp for verification record. Defaults to current time when not specified.',
16159
16162
  },
@@ -10,6 +10,7 @@ import {
10
10
  type OmitKey,
11
11
  } from '../../../../util'
12
12
  import type * as AppBskyActorDefs from '../actor/defs.js'
13
+ import type * as AppBskyFeedDefs from '../feed/defs.js'
13
14
 
14
15
  const is$typed = _is$typed,
15
16
  validate = _validate
@@ -125,3 +126,75 @@ export function isTrendView<V>(v: V) {
125
126
  export function validateTrendView<V>(v: V) {
126
127
  return validate<TrendView & V>(v, id, hashTrendView)
127
128
  }
129
+
130
+ export interface ThreadItemPost {
131
+ $type?: 'app.bsky.unspecced.defs#threadItemPost'
132
+ post: AppBskyFeedDefs.PostView
133
+ /** This post has more parents that were not present in the response. This is just a boolean, without the number of parents. */
134
+ moreParents: boolean
135
+ /** This post has more replies that were not present in the response. This is a numeric value, which is best-effort and might not be accurate. */
136
+ moreReplies: number
137
+ /** This post is part of a contiguous thread by the OP from the thread root. Many different OP threads can happen in the same thread. */
138
+ opThread: boolean
139
+ /** The threadgate created by the author indicates this post as a reply to be hidden for everyone consuming the thread. */
140
+ hiddenByThreadgate: boolean
141
+ /** This is by an account muted by the viewer requesting it. */
142
+ mutedByViewer: boolean
143
+ }
144
+
145
+ const hashThreadItemPost = 'threadItemPost'
146
+
147
+ export function isThreadItemPost<V>(v: V) {
148
+ return is$typed(v, id, hashThreadItemPost)
149
+ }
150
+
151
+ export function validateThreadItemPost<V>(v: V) {
152
+ return validate<ThreadItemPost & V>(v, id, hashThreadItemPost)
153
+ }
154
+
155
+ export interface ThreadItemNoUnauthenticated {
156
+ $type?: 'app.bsky.unspecced.defs#threadItemNoUnauthenticated'
157
+ }
158
+
159
+ const hashThreadItemNoUnauthenticated = 'threadItemNoUnauthenticated'
160
+
161
+ export function isThreadItemNoUnauthenticated<V>(v: V) {
162
+ return is$typed(v, id, hashThreadItemNoUnauthenticated)
163
+ }
164
+
165
+ export function validateThreadItemNoUnauthenticated<V>(v: V) {
166
+ return validate<ThreadItemNoUnauthenticated & V>(
167
+ v,
168
+ id,
169
+ hashThreadItemNoUnauthenticated,
170
+ )
171
+ }
172
+
173
+ export interface ThreadItemNotFound {
174
+ $type?: 'app.bsky.unspecced.defs#threadItemNotFound'
175
+ }
176
+
177
+ const hashThreadItemNotFound = 'threadItemNotFound'
178
+
179
+ export function isThreadItemNotFound<V>(v: V) {
180
+ return is$typed(v, id, hashThreadItemNotFound)
181
+ }
182
+
183
+ export function validateThreadItemNotFound<V>(v: V) {
184
+ return validate<ThreadItemNotFound & V>(v, id, hashThreadItemNotFound)
185
+ }
186
+
187
+ export interface ThreadItemBlocked {
188
+ $type?: 'app.bsky.unspecced.defs#threadItemBlocked'
189
+ author: AppBskyFeedDefs.BlockedAuthor
190
+ }
191
+
192
+ const hashThreadItemBlocked = 'threadItemBlocked'
193
+
194
+ export function isThreadItemBlocked<V>(v: V) {
195
+ return is$typed(v, id, hashThreadItemBlocked)
196
+ }
197
+
198
+ export function validateThreadItemBlocked<V>(v: V) {
199
+ return validate<ThreadItemBlocked & V>(v, id, hashThreadItemBlocked)
200
+ }
@@ -11,7 +11,7 @@ import {
11
11
  type OmitKey,
12
12
  } from '../../../../util'
13
13
  import { HandlerAuth, HandlerPipeThrough } from '@atproto/xrpc-server'
14
- import type * as AppBskyFeedDefs from '../feed/defs.js'
14
+ import type * as AppBskyUnspeccedDefs from './defs.js'
15
15
 
16
16
  const is$typed = _is$typed,
17
17
  validate = _validate
@@ -20,12 +20,14 @@ const id = 'app.bsky.unspecced.getPostThreadHiddenV2'
20
20
  export interface QueryParams {
21
21
  /** Reference (AT-URI) to post record. This is the anchor post. */
22
22
  anchor: string
23
+ /** Whether to prioritize posts from followed users. It only has effect when the user is authenticated. */
24
+ prioritizeFollowedUsers: boolean
23
25
  }
24
26
 
25
27
  export type InputSchema = undefined
26
28
 
27
29
  export interface OutputSchema {
28
- /** A flat list of thread hidden items. The depth of each item is indicated by the depth property inside the item. */
30
+ /** A flat list of hidden thread items. The depth of each item is indicated by the depth property inside the item. */
29
31
  thread: ThreadHiddenItem[]
30
32
  }
31
33
 
@@ -60,7 +62,7 @@ export interface ThreadHiddenItem {
60
62
  uri: string
61
63
  /** The nesting level of this item in the thread. Depth 0 means the anchor item. Items above have negative depths, items below have positive depths. */
62
64
  depth: number
63
- value: $Typed<ThreadHiddenItemPost> | { $type: string }
65
+ value: $Typed<AppBskyUnspeccedDefs.ThreadItemPost> | { $type: string }
64
66
  }
65
67
 
66
68
  const hashThreadHiddenItem = 'threadHiddenItem'
@@ -72,22 +74,3 @@ export function isThreadHiddenItem<V>(v: V) {
72
74
  export function validateThreadHiddenItem<V>(v: V) {
73
75
  return validate<ThreadHiddenItem & V>(v, id, hashThreadHiddenItem)
74
76
  }
75
-
76
- export interface ThreadHiddenItemPost {
77
- $type?: 'app.bsky.unspecced.getPostThreadHiddenV2#threadHiddenItemPost'
78
- post: AppBskyFeedDefs.PostView
79
- /** The threadgate created by the author indicates this post as a reply to be hidden for everyone consuming the thread. */
80
- hiddenByThreadgate: boolean
81
- /** This is by an account muted by the viewer requesting it. */
82
- mutedByViewer: boolean
83
- }
84
-
85
- const hashThreadHiddenItemPost = 'threadHiddenItemPost'
86
-
87
- export function isThreadHiddenItemPost<V>(v: V) {
88
- return is$typed(v, id, hashThreadHiddenItemPost)
89
- }
90
-
91
- export function validateThreadHiddenItemPost<V>(v: V) {
92
- return validate<ThreadHiddenItemPost & V>(v, id, hashThreadHiddenItemPost)
93
- }
@@ -12,6 +12,7 @@ import {
12
12
  } from '../../../../util'
13
13
  import { HandlerAuth, HandlerPipeThrough } from '@atproto/xrpc-server'
14
14
  import type * as AppBskyFeedDefs from '../feed/defs.js'
15
+ import type * as AppBskyUnspeccedDefs from './defs.js'
15
16
 
16
17
  const is$typed = _is$typed,
17
18
  validate = _validate
@@ -74,10 +75,10 @@ export interface ThreadItem {
74
75
  /** The nesting level of this item in the thread. Depth 0 means the anchor item. Items above have negative depths, items below have positive depths. */
75
76
  depth: number
76
77
  value:
77
- | $Typed<ThreadItemPost>
78
- | $Typed<ThreadItemNoUnauthenticated>
79
- | $Typed<ThreadItemNotFound>
80
- | $Typed<ThreadItemBlocked>
78
+ | $Typed<AppBskyUnspeccedDefs.ThreadItemPost>
79
+ | $Typed<AppBskyUnspeccedDefs.ThreadItemNoUnauthenticated>
80
+ | $Typed<AppBskyUnspeccedDefs.ThreadItemNotFound>
81
+ | $Typed<AppBskyUnspeccedDefs.ThreadItemBlocked>
81
82
  | { $type: string }
82
83
  }
83
84
 
@@ -90,71 +91,3 @@ export function isThreadItem<V>(v: V) {
90
91
  export function validateThreadItem<V>(v: V) {
91
92
  return validate<ThreadItem & V>(v, id, hashThreadItem)
92
93
  }
93
-
94
- export interface ThreadItemPost {
95
- $type?: 'app.bsky.unspecced.getPostThreadV2#threadItemPost'
96
- post: AppBskyFeedDefs.PostView
97
- /** This post has more parents that were not present in the response. This is just a boolean, without the number of parents. */
98
- moreParents: boolean
99
- /** This post has more replies that were not present in the response. This is a numeric value, which is best-effort and might not be accurate. */
100
- moreReplies: number
101
- /** This post is part of a contiguous thread by the OP from the thread root. Many different OP threads can happen in the same thread. */
102
- opThread: boolean
103
- }
104
-
105
- const hashThreadItemPost = 'threadItemPost'
106
-
107
- export function isThreadItemPost<V>(v: V) {
108
- return is$typed(v, id, hashThreadItemPost)
109
- }
110
-
111
- export function validateThreadItemPost<V>(v: V) {
112
- return validate<ThreadItemPost & V>(v, id, hashThreadItemPost)
113
- }
114
-
115
- export interface ThreadItemNoUnauthenticated {
116
- $type?: 'app.bsky.unspecced.getPostThreadV2#threadItemNoUnauthenticated'
117
- }
118
-
119
- const hashThreadItemNoUnauthenticated = 'threadItemNoUnauthenticated'
120
-
121
- export function isThreadItemNoUnauthenticated<V>(v: V) {
122
- return is$typed(v, id, hashThreadItemNoUnauthenticated)
123
- }
124
-
125
- export function validateThreadItemNoUnauthenticated<V>(v: V) {
126
- return validate<ThreadItemNoUnauthenticated & V>(
127
- v,
128
- id,
129
- hashThreadItemNoUnauthenticated,
130
- )
131
- }
132
-
133
- export interface ThreadItemNotFound {
134
- $type?: 'app.bsky.unspecced.getPostThreadV2#threadItemNotFound'
135
- }
136
-
137
- const hashThreadItemNotFound = 'threadItemNotFound'
138
-
139
- export function isThreadItemNotFound<V>(v: V) {
140
- return is$typed(v, id, hashThreadItemNotFound)
141
- }
142
-
143
- export function validateThreadItemNotFound<V>(v: V) {
144
- return validate<ThreadItemNotFound & V>(v, id, hashThreadItemNotFound)
145
- }
146
-
147
- export interface ThreadItemBlocked {
148
- $type?: 'app.bsky.unspecced.getPostThreadV2#threadItemBlocked'
149
- author: AppBskyFeedDefs.BlockedAuthor
150
- }
151
-
152
- const hashThreadItemBlocked = 'threadItemBlocked'
153
-
154
- export function isThreadItemBlocked<V>(v: V) {
155
- return is$typed(v, id, hashThreadItemBlocked)
156
- }
157
-
158
- export function validateThreadItemBlocked<V>(v: V) {
159
- return validate<ThreadItemBlocked & V>(v, id, hashThreadItemBlocked)
160
- }
@@ -117,6 +117,7 @@ export interface SubjectStatusView {
117
117
  subject:
118
118
  | $Typed<ComAtprotoAdminDefs.RepoRef>
119
119
  | $Typed<ComAtprotoRepoStrongRef.Main>
120
+ | $Typed<ChatBskyConvoDefs.MessageRef>
120
121
  | { $type: string }
121
122
  hosting?: $Typed<AccountHosting> | $Typed<RecordHosting> | { $type: string }
122
123
  subjectBlobCids?: string[]
@@ -205,7 +205,7 @@ describe('proxies admin requests', () => {
205
205
  { uri: 'at://did:does:not:exist/bad.collection.name/badrkey' },
206
206
  { headers: sc.getHeaders(moderator) },
207
207
  )
208
- await expect(tryGetRecord).rejects.toThrow('Record not found')
208
+ await expect(tryGetRecord).rejects.toThrow('Could not locate record')
209
209
  })
210
210
 
211
211
  it('takesdown and labels repos, and reverts.', async () => {