@atproto/ozone 0.1.172 → 0.1.174

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 (450) hide show
  1. package/CHANGELOG.md +18 -0
  2. package/dist/api/index.d.ts.map +1 -1
  3. package/dist/api/index.js +40 -0
  4. package/dist/api/index.js.map +1 -1
  5. package/dist/api/moderation/emitEvent.d.ts.map +1 -1
  6. package/dist/api/moderation/emitEvent.js +31 -0
  7. package/dist/api/moderation/emitEvent.js.map +1 -1
  8. package/dist/api/queue/assignModerator.d.ts +4 -0
  9. package/dist/api/queue/assignModerator.d.ts.map +1 -0
  10. package/dist/api/queue/assignModerator.js +28 -0
  11. package/dist/api/queue/assignModerator.js.map +1 -0
  12. package/dist/api/queue/createQueue.d.ts +4 -0
  13. package/dist/api/queue/createQueue.d.ts.map +1 -0
  14. package/dist/api/queue/createQueue.js +44 -0
  15. package/dist/api/queue/createQueue.js.map +1 -0
  16. package/dist/api/queue/deleteQueue.d.ts +4 -0
  17. package/dist/api/queue/deleteQueue.d.ts.map +1 -0
  18. package/dist/api/queue/deleteQueue.js +40 -0
  19. package/dist/api/queue/deleteQueue.js.map +1 -0
  20. package/dist/api/queue/getAssignments.d.ts +4 -0
  21. package/dist/api/queue/getAssignments.d.ts.map +1 -0
  22. package/dist/api/queue/getAssignments.js +19 -0
  23. package/dist/api/queue/getAssignments.js.map +1 -0
  24. package/dist/api/queue/listQueues.d.ts +4 -0
  25. package/dist/api/queue/listQueues.d.ts.map +1 -0
  26. package/dist/api/queue/listQueues.js +29 -0
  27. package/dist/api/queue/listQueues.js.map +1 -0
  28. package/dist/api/queue/routeReports.d.ts +4 -0
  29. package/dist/api/queue/routeReports.d.ts.map +1 -0
  30. package/dist/api/queue/routeReports.js +33 -0
  31. package/dist/api/queue/routeReports.js.map +1 -0
  32. package/dist/api/queue/unassignModerator.d.ts +4 -0
  33. package/dist/api/queue/unassignModerator.d.ts.map +1 -0
  34. package/dist/api/queue/unassignModerator.js +24 -0
  35. package/dist/api/queue/unassignModerator.js.map +1 -0
  36. package/dist/api/queue/updateQueue.d.ts +4 -0
  37. package/dist/api/queue/updateQueue.d.ts.map +1 -0
  38. package/dist/api/queue/updateQueue.js +39 -0
  39. package/dist/api/queue/updateQueue.js.map +1 -0
  40. package/dist/api/report/assignModerator.d.ts +4 -0
  41. package/dist/api/report/assignModerator.d.ts.map +1 -0
  42. package/dist/api/report/assignModerator.js +33 -0
  43. package/dist/api/report/assignModerator.js.map +1 -0
  44. package/dist/api/report/createActivity.d.ts +4 -0
  45. package/dist/api/report/createActivity.d.ts.map +1 -0
  46. package/dist/api/report/createActivity.js +44 -0
  47. package/dist/api/report/createActivity.js.map +1 -0
  48. package/dist/api/report/getAssignments.d.ts +4 -0
  49. package/dist/api/report/getAssignments.d.ts.map +1 -0
  50. package/dist/api/report/getAssignments.js +19 -0
  51. package/dist/api/report/getAssignments.js.map +1 -0
  52. package/dist/api/report/getHistoricalStats.d.ts +4 -0
  53. package/dist/api/report/getHistoricalStats.d.ts.map +1 -0
  54. package/dist/api/report/getHistoricalStats.js +32 -0
  55. package/dist/api/report/getHistoricalStats.js.map +1 -0
  56. package/dist/api/report/getLatestReport.d.ts +4 -0
  57. package/dist/api/report/getLatestReport.d.ts.map +1 -0
  58. package/dist/api/report/getLatestReport.js +31 -0
  59. package/dist/api/report/getLatestReport.js.map +1 -0
  60. package/dist/api/report/getLiveStats.d.ts +4 -0
  61. package/dist/api/report/getLiveStats.d.ts.map +1 -0
  62. package/dist/api/report/getLiveStats.js +25 -0
  63. package/dist/api/report/getLiveStats.js.map +1 -0
  64. package/dist/api/report/getReport.d.ts +4 -0
  65. package/dist/api/report/getReport.d.ts.map +1 -0
  66. package/dist/api/report/getReport.js +35 -0
  67. package/dist/api/report/getReport.js.map +1 -0
  68. package/dist/api/report/listActivities.d.ts +4 -0
  69. package/dist/api/report/listActivities.d.ts.map +1 -0
  70. package/dist/api/report/listActivities.js +25 -0
  71. package/dist/api/report/listActivities.js.map +1 -0
  72. package/dist/api/report/queryReports.d.ts +4 -0
  73. package/dist/api/report/queryReports.d.ts.map +1 -0
  74. package/dist/api/report/queryReports.js +29 -0
  75. package/dist/api/report/queryReports.js.map +1 -0
  76. package/dist/api/report/reassignQueue.d.ts +4 -0
  77. package/dist/api/report/reassignQueue.d.ts.map +1 -0
  78. package/dist/api/report/reassignQueue.js +45 -0
  79. package/dist/api/report/reassignQueue.js.map +1 -0
  80. package/dist/api/report/refreshStats.d.ts +4 -0
  81. package/dist/api/report/refreshStats.d.ts.map +1 -0
  82. package/dist/api/report/refreshStats.js +26 -0
  83. package/dist/api/report/refreshStats.js.map +1 -0
  84. package/dist/api/report/unassignModerator.d.ts +4 -0
  85. package/dist/api/report/unassignModerator.d.ts.map +1 -0
  86. package/dist/api/report/unassignModerator.js +21 -0
  87. package/dist/api/report/unassignModerator.js.map +1 -0
  88. package/dist/api/util.d.ts +2 -0
  89. package/dist/api/util.d.ts.map +1 -1
  90. package/dist/api/util.js +9 -1
  91. package/dist/api/util.js.map +1 -1
  92. package/dist/assignment/index.d.ts +89 -0
  93. package/dist/assignment/index.d.ts.map +1 -0
  94. package/dist/assignment/index.js +537 -0
  95. package/dist/assignment/index.js.map +1 -0
  96. package/dist/config/config.d.ts +14 -0
  97. package/dist/config/config.d.ts.map +1 -1
  98. package/dist/config/config.js +9 -0
  99. package/dist/config/config.js.map +1 -1
  100. package/dist/config/env.d.ts +3 -0
  101. package/dist/config/env.d.ts.map +1 -1
  102. package/dist/config/env.js +3 -0
  103. package/dist/config/env.js.map +1 -1
  104. package/dist/context.d.ts +9 -0
  105. package/dist/context.d.ts.map +1 -1
  106. package/dist/context.js +31 -10
  107. package/dist/context.js.map +1 -1
  108. package/dist/daemon/context.d.ts +6 -0
  109. package/dist/daemon/context.d.ts.map +1 -1
  110. package/dist/daemon/context.js +28 -4
  111. package/dist/daemon/context.js.map +1 -1
  112. package/dist/daemon/event-reverser.d.ts +1 -0
  113. package/dist/daemon/event-reverser.d.ts.map +1 -1
  114. package/dist/daemon/event-reverser.js +42 -1
  115. package/dist/daemon/event-reverser.js.map +1 -1
  116. package/dist/daemon/job-cursor.d.ts +5 -0
  117. package/dist/daemon/job-cursor.d.ts.map +1 -0
  118. package/dist/daemon/job-cursor.js +28 -0
  119. package/dist/daemon/job-cursor.js.map +1 -0
  120. package/dist/daemon/queue-router.d.ts +17 -0
  121. package/dist/daemon/queue-router.d.ts.map +1 -0
  122. package/dist/daemon/queue-router.js +114 -0
  123. package/dist/daemon/queue-router.js.map +1 -0
  124. package/dist/daemon/stats-computer.d.ts +51 -0
  125. package/dist/daemon/stats-computer.d.ts.map +1 -0
  126. package/dist/daemon/stats-computer.js +117 -0
  127. package/dist/daemon/stats-computer.js.map +1 -0
  128. package/dist/daemon/strike-expiry-processor.d.ts.map +1 -1
  129. package/dist/daemon/strike-expiry-processor.js +4 -19
  130. package/dist/daemon/strike-expiry-processor.js.map +1 -1
  131. package/dist/db/migrations/20260219T164523000Z-create-report-table.d.ts +4 -0
  132. package/dist/db/migrations/20260219T164523000Z-create-report-table.d.ts.map +1 -0
  133. package/dist/db/migrations/20260219T164523000Z-create-report-table.js +126 -0
  134. package/dist/db/migrations/20260219T164523000Z-create-report-table.js.map +1 -0
  135. package/dist/db/migrations/20260219T165302248Z-moderator-assignment.d.ts +4 -0
  136. package/dist/db/migrations/20260219T165302248Z-moderator-assignment.d.ts.map +1 -0
  137. package/dist/db/migrations/20260219T165302248Z-moderator-assignment.js +35 -0
  138. package/dist/db/migrations/20260219T165302248Z-moderator-assignment.js.map +1 -0
  139. package/dist/db/migrations/20260225T000000000Z-add-report-queue-table.d.ts +4 -0
  140. package/dist/db/migrations/20260225T000000000Z-add-report-queue-table.d.ts.map +1 -0
  141. package/dist/db/migrations/20260225T000000000Z-add-report-queue-table.js +36 -0
  142. package/dist/db/migrations/20260225T000000000Z-add-report-queue-table.js.map +1 -0
  143. package/dist/db/migrations/20260313T000000000Z-add-report-activity-table.d.ts +4 -0
  144. package/dist/db/migrations/20260313T000000000Z-add-report-activity-table.d.ts.map +1 -0
  145. package/dist/db/migrations/20260313T000000000Z-add-report-activity-table.js +39 -0
  146. package/dist/db/migrations/20260313T000000000Z-add-report-activity-table.js.map +1 -0
  147. package/dist/db/migrations/20260318T152058935Z-add-report-stat.d.ts +4 -0
  148. package/dist/db/migrations/20260318T152058935Z-add-report-stat.d.ts.map +1 -0
  149. package/dist/db/migrations/20260318T152058935Z-add-report-stat.js +34 -0
  150. package/dist/db/migrations/20260318T152058935Z-add-report-stat.js.map +1 -0
  151. package/dist/db/migrations/20260428T000000000Z-add-expiring-tag-table.d.ts +4 -0
  152. package/dist/db/migrations/20260428T000000000Z-add-expiring-tag-table.d.ts.map +1 -0
  153. package/dist/db/migrations/20260428T000000000Z-add-expiring-tag-table.js +32 -0
  154. package/dist/db/migrations/20260428T000000000Z-add-expiring-tag-table.js.map +1 -0
  155. package/dist/db/migrations/index.d.ts +6 -0
  156. package/dist/db/migrations/index.d.ts.map +1 -1
  157. package/dist/db/migrations/index.js +7 -1
  158. package/dist/db/migrations/index.js.map +1 -1
  159. package/dist/db/pagination.d.ts +31 -0
  160. package/dist/db/pagination.d.ts.map +1 -1
  161. package/dist/db/pagination.js +74 -1
  162. package/dist/db/pagination.js.map +1 -1
  163. package/dist/db/schema/expiring_tag.d.ts +15 -0
  164. package/dist/db/schema/expiring_tag.d.ts.map +1 -0
  165. package/dist/db/schema/expiring_tag.js +5 -0
  166. package/dist/db/schema/expiring_tag.js.map +1 -0
  167. package/dist/db/schema/index.d.ts +7 -1
  168. package/dist/db/schema/index.d.ts.map +1 -1
  169. package/dist/db/schema/index.js.map +1 -1
  170. package/dist/db/schema/moderator_assignment.d.ts +14 -0
  171. package/dist/db/schema/moderator_assignment.d.ts.map +1 -0
  172. package/dist/db/schema/moderator_assignment.js +5 -0
  173. package/dist/db/schema/moderator_assignment.js.map +1 -0
  174. package/dist/db/schema/report.d.ts +25 -0
  175. package/dist/db/schema/report.d.ts.map +1 -0
  176. package/dist/db/schema/report.js +5 -0
  177. package/dist/db/schema/report.js.map +1 -0
  178. package/dist/db/schema/report_activity.d.ts +18 -0
  179. package/dist/db/schema/report_activity.d.ts.map +1 -0
  180. package/dist/db/schema/report_activity.js +5 -0
  181. package/dist/db/schema/report_activity.js.map +1 -0
  182. package/dist/db/schema/report_queue.d.ts +19 -0
  183. package/dist/db/schema/report_queue.d.ts.map +1 -0
  184. package/dist/db/schema/report_queue.js +5 -0
  185. package/dist/db/schema/report_queue.js.map +1 -0
  186. package/dist/db/schema/report_stat.d.ts +20 -0
  187. package/dist/db/schema/report_stat.d.ts.map +1 -0
  188. package/dist/db/schema/report_stat.js +5 -0
  189. package/dist/db/schema/report_stat.js.map +1 -0
  190. package/dist/lexicon/index.d.ts +50 -0
  191. package/dist/lexicon/index.d.ts.map +1 -1
  192. package/dist/lexicon/index.js +120 -2
  193. package/dist/lexicon/index.js.map +1 -1
  194. package/dist/lexicon/lexicons.d.ts +11255 -7885
  195. package/dist/lexicon/lexicons.d.ts.map +1 -1
  196. package/dist/lexicon/lexicons.js +1900 -120
  197. package/dist/lexicon/lexicons.js.map +1 -1
  198. package/dist/lexicon/types/app/bsky/embed/external.d.ts +2 -0
  199. package/dist/lexicon/types/app/bsky/embed/external.d.ts.map +1 -1
  200. package/dist/lexicon/types/app/bsky/embed/external.js.map +1 -1
  201. package/dist/lexicon/types/chat/bsky/actor/defs.d.ts +8 -2
  202. package/dist/lexicon/types/chat/bsky/actor/defs.d.ts.map +1 -1
  203. package/dist/lexicon/types/chat/bsky/actor/defs.js +9 -0
  204. package/dist/lexicon/types/chat/bsky/actor/defs.js.map +1 -1
  205. package/dist/lexicon/types/chat/bsky/convo/defs.d.ts +37 -10
  206. package/dist/lexicon/types/chat/bsky/convo/defs.d.ts.map +1 -1
  207. package/dist/lexicon/types/chat/bsky/convo/defs.js +9 -0
  208. package/dist/lexicon/types/chat/bsky/convo/defs.js.map +1 -1
  209. package/dist/lexicon/types/chat/bsky/convo/getMessages.d.ts +3 -0
  210. package/dist/lexicon/types/chat/bsky/convo/getMessages.d.ts.map +1 -1
  211. package/dist/lexicon/types/chat/bsky/convo/getMessages.js.map +1 -1
  212. package/dist/lexicon/types/tools/ozone/moderation/defs.d.ts +2 -0
  213. package/dist/lexicon/types/tools/ozone/moderation/defs.d.ts.map +1 -1
  214. package/dist/lexicon/types/tools/ozone/moderation/defs.js.map +1 -1
  215. package/dist/lexicon/types/tools/ozone/moderation/emitEvent.d.ts +19 -0
  216. package/dist/lexicon/types/tools/ozone/moderation/emitEvent.d.ts.map +1 -1
  217. package/dist/lexicon/types/tools/ozone/moderation/emitEvent.js +9 -0
  218. package/dist/lexicon/types/tools/ozone/moderation/emitEvent.js.map +1 -1
  219. package/dist/lexicon/types/tools/ozone/queue/assignModerator.d.ts +27 -0
  220. package/dist/lexicon/types/tools/ozone/queue/assignModerator.d.ts.map +1 -0
  221. package/dist/lexicon/types/tools/ozone/queue/assignModerator.js +7 -0
  222. package/dist/lexicon/types/tools/ozone/queue/assignModerator.js.map +1 -0
  223. package/dist/lexicon/types/tools/ozone/queue/createQueue.d.ts +35 -0
  224. package/dist/lexicon/types/tools/ozone/queue/createQueue.d.ts.map +1 -0
  225. package/dist/lexicon/types/tools/ozone/queue/createQueue.js +7 -0
  226. package/dist/lexicon/types/tools/ozone/queue/createQueue.js.map +1 -0
  227. package/dist/lexicon/types/tools/ozone/queue/defs.d.ts +62 -0
  228. package/dist/lexicon/types/tools/ozone/queue/defs.d.ts.map +1 -0
  229. package/dist/lexicon/types/tools/ozone/queue/defs.js +34 -0
  230. package/dist/lexicon/types/tools/ozone/queue/defs.js.map +1 -0
  231. package/dist/lexicon/types/tools/ozone/queue/deleteQueue.d.ts +29 -0
  232. package/dist/lexicon/types/tools/ozone/queue/deleteQueue.d.ts.map +1 -0
  233. package/dist/lexicon/types/tools/ozone/queue/deleteQueue.js +7 -0
  234. package/dist/lexicon/types/tools/ozone/queue/deleteQueue.js.map +1 -0
  235. package/dist/lexicon/types/tools/ozone/queue/getAssignments.d.ts +30 -0
  236. package/dist/lexicon/types/tools/ozone/queue/getAssignments.d.ts.map +1 -0
  237. package/dist/lexicon/types/tools/ozone/queue/getAssignments.js +7 -0
  238. package/dist/lexicon/types/tools/ozone/queue/getAssignments.js.map +1 -0
  239. package/dist/lexicon/types/tools/ozone/queue/listQueues.d.ts +32 -0
  240. package/dist/lexicon/types/tools/ozone/queue/listQueues.d.ts.map +1 -0
  241. package/dist/lexicon/types/tools/ozone/queue/listQueues.js +7 -0
  242. package/dist/lexicon/types/tools/ozone/queue/listQueues.js.map +1 -0
  243. package/dist/lexicon/types/tools/ozone/queue/routeReports.d.ts +31 -0
  244. package/dist/lexicon/types/tools/ozone/queue/routeReports.d.ts.map +1 -0
  245. package/dist/lexicon/types/tools/ozone/queue/routeReports.js +7 -0
  246. package/dist/lexicon/types/tools/ozone/queue/routeReports.js.map +1 -0
  247. package/dist/lexicon/types/tools/ozone/queue/unassignModerator.d.ts +18 -0
  248. package/dist/lexicon/types/tools/ozone/queue/unassignModerator.d.ts.map +1 -0
  249. package/dist/lexicon/types/tools/ozone/queue/unassignModerator.js +7 -0
  250. package/dist/lexicon/types/tools/ozone/queue/unassignModerator.js.map +1 -0
  251. package/dist/lexicon/types/tools/ozone/queue/updateQueue.d.ts +32 -0
  252. package/dist/lexicon/types/tools/ozone/queue/updateQueue.d.ts.map +1 -0
  253. package/dist/lexicon/types/tools/ozone/queue/updateQueue.js +7 -0
  254. package/dist/lexicon/types/tools/ozone/queue/updateQueue.js.map +1 -0
  255. package/dist/lexicon/types/tools/ozone/report/assignModerator.d.ts +31 -0
  256. package/dist/lexicon/types/tools/ozone/report/assignModerator.d.ts.map +1 -0
  257. package/dist/lexicon/types/tools/ozone/report/assignModerator.js +7 -0
  258. package/dist/lexicon/types/tools/ozone/report/assignModerator.js.map +1 -0
  259. package/dist/lexicon/types/tools/ozone/report/createActivity.d.ts +37 -0
  260. package/dist/lexicon/types/tools/ozone/report/createActivity.d.ts.map +1 -0
  261. package/dist/lexicon/types/tools/ozone/report/createActivity.js +7 -0
  262. package/dist/lexicon/types/tools/ozone/report/createActivity.js.map +1 -0
  263. package/dist/lexicon/types/tools/ozone/report/defs.d.ts +185 -0
  264. package/dist/lexicon/types/tools/ozone/report/defs.d.ts.map +1 -1
  265. package/dist/lexicon/types/tools/ozone/report/defs.js +108 -0
  266. package/dist/lexicon/types/tools/ozone/report/defs.js.map +1 -1
  267. package/dist/lexicon/types/tools/ozone/report/getAssignments.d.ts +30 -0
  268. package/dist/lexicon/types/tools/ozone/report/getAssignments.d.ts.map +1 -0
  269. package/dist/lexicon/types/tools/ozone/report/getAssignments.js +7 -0
  270. package/dist/lexicon/types/tools/ozone/report/getAssignments.js.map +1 -0
  271. package/dist/lexicon/types/tools/ozone/report/getHistoricalStats.d.ts +36 -0
  272. package/dist/lexicon/types/tools/ozone/report/getHistoricalStats.d.ts.map +1 -0
  273. package/dist/lexicon/types/tools/ozone/report/getHistoricalStats.js +7 -0
  274. package/dist/lexicon/types/tools/ozone/report/getHistoricalStats.js.map +1 -0
  275. package/dist/lexicon/types/tools/ozone/report/getLatestReport.d.ts +21 -0
  276. package/dist/lexicon/types/tools/ozone/report/getLatestReport.d.ts.map +1 -0
  277. package/dist/lexicon/types/tools/ozone/report/getLatestReport.js +7 -0
  278. package/dist/lexicon/types/tools/ozone/report/getLatestReport.js.map +1 -0
  279. package/dist/lexicon/types/tools/ozone/report/getLiveStats.d.ts +27 -0
  280. package/dist/lexicon/types/tools/ozone/report/getLiveStats.d.ts.map +1 -0
  281. package/dist/lexicon/types/tools/ozone/report/getLiveStats.js +7 -0
  282. package/dist/lexicon/types/tools/ozone/report/getLiveStats.js.map +1 -0
  283. package/dist/lexicon/types/tools/ozone/report/getReport.d.ts +22 -0
  284. package/dist/lexicon/types/tools/ozone/report/getReport.d.ts.map +1 -0
  285. package/dist/lexicon/types/tools/ozone/report/getReport.js +7 -0
  286. package/dist/lexicon/types/tools/ozone/report/getReport.js.map +1 -0
  287. package/dist/lexicon/types/tools/ozone/report/listActivities.d.ts +26 -0
  288. package/dist/lexicon/types/tools/ozone/report/listActivities.d.ts.map +1 -0
  289. package/dist/lexicon/types/tools/ozone/report/listActivities.js +7 -0
  290. package/dist/lexicon/types/tools/ozone/report/listActivities.js.map +1 -0
  291. package/dist/lexicon/types/tools/ozone/report/queryReports.d.ts +48 -0
  292. package/dist/lexicon/types/tools/ozone/report/queryReports.d.ts.map +1 -0
  293. package/dist/lexicon/types/tools/ozone/report/queryReports.js +7 -0
  294. package/dist/lexicon/types/tools/ozone/report/queryReports.js.map +1 -0
  295. package/dist/lexicon/types/tools/ozone/report/reassignQueue.d.ts +31 -0
  296. package/dist/lexicon/types/tools/ozone/report/reassignQueue.d.ts.map +1 -0
  297. package/dist/lexicon/types/tools/ozone/report/reassignQueue.js +7 -0
  298. package/dist/lexicon/types/tools/ozone/report/reassignQueue.js.map +1 -0
  299. package/dist/lexicon/types/tools/ozone/report/refreshStats.d.ts +28 -0
  300. package/dist/lexicon/types/tools/ozone/report/refreshStats.d.ts.map +1 -0
  301. package/dist/lexicon/types/tools/ozone/report/refreshStats.js +7 -0
  302. package/dist/lexicon/types/tools/ozone/report/refreshStats.js.map +1 -0
  303. package/dist/lexicon/types/tools/ozone/report/unassignModerator.d.ts +25 -0
  304. package/dist/lexicon/types/tools/ozone/report/unassignModerator.d.ts.map +1 -0
  305. package/dist/lexicon/types/tools/ozone/report/unassignModerator.js +7 -0
  306. package/dist/lexicon/types/tools/ozone/report/unassignModerator.js.map +1 -0
  307. package/dist/mod-service/expiring-tags.d.ts +27 -0
  308. package/dist/mod-service/expiring-tags.d.ts.map +1 -0
  309. package/dist/mod-service/expiring-tags.js +62 -0
  310. package/dist/mod-service/expiring-tags.js.map +1 -0
  311. package/dist/mod-service/index.d.ts +3 -1
  312. package/dist/mod-service/index.d.ts.map +1 -1
  313. package/dist/mod-service/index.js +61 -2
  314. package/dist/mod-service/index.js.map +1 -1
  315. package/dist/mod-service/report.d.ts +64 -0
  316. package/dist/mod-service/report.d.ts.map +1 -0
  317. package/dist/mod-service/report.js +282 -0
  318. package/dist/mod-service/report.js.map +1 -0
  319. package/dist/mod-service/status.d.ts +24 -0
  320. package/dist/mod-service/status.d.ts.map +1 -1
  321. package/dist/queue/service.d.ts +86 -0
  322. package/dist/queue/service.d.ts.map +1 -0
  323. package/dist/queue/service.js +430 -0
  324. package/dist/queue/service.js.map +1 -0
  325. package/dist/report/activity.d.ts +77 -0
  326. package/dist/report/activity.d.ts.map +1 -0
  327. package/dist/report/activity.js +141 -0
  328. package/dist/report/activity.js.map +1 -0
  329. package/dist/report/handle-report-update.d.ts +47 -0
  330. package/dist/report/handle-report-update.d.ts.map +1 -0
  331. package/dist/report/handle-report-update.js +178 -0
  332. package/dist/report/handle-report-update.js.map +1 -0
  333. package/dist/report/reassign.d.ts +10 -0
  334. package/dist/report/reassign.d.ts.map +1 -0
  335. package/dist/report/reassign.js +75 -0
  336. package/dist/report/reassign.js.map +1 -0
  337. package/dist/report/stats.d.ts +105 -0
  338. package/dist/report/stats.d.ts.map +1 -0
  339. package/dist/report/stats.js +619 -0
  340. package/dist/report/stats.js.map +1 -0
  341. package/dist/report/views.d.ts +111 -0
  342. package/dist/report/views.d.ts.map +1 -0
  343. package/dist/report/views.js +156 -0
  344. package/dist/report/views.js.map +1 -0
  345. package/dist/team/index.d.ts +1 -0
  346. package/dist/team/index.d.ts.map +1 -1
  347. package/dist/team/index.js +11 -0
  348. package/dist/team/index.js.map +1 -1
  349. package/package.json +3 -3
  350. package/src/api/index.ts +40 -0
  351. package/src/api/moderation/emitEvent.ts +38 -0
  352. package/src/api/queue/assignModerator.ts +31 -0
  353. package/src/api/queue/createQueue.ts +62 -0
  354. package/src/api/queue/deleteQueue.ts +56 -0
  355. package/src/api/queue/getAssignments.ts +19 -0
  356. package/src/api/queue/listQueues.ts +39 -0
  357. package/src/api/queue/routeReports.ts +44 -0
  358. package/src/api/queue/unassignModerator.ts +26 -0
  359. package/src/api/queue/updateQueue.ts +54 -0
  360. package/src/api/report/assignModerator.ts +36 -0
  361. package/src/api/report/createActivity.ts +57 -0
  362. package/src/api/report/getAssignments.ts +20 -0
  363. package/src/api/report/getHistoricalStats.ts +41 -0
  364. package/src/api/report/getLatestReport.ts +44 -0
  365. package/src/api/report/getLiveStats.ts +26 -0
  366. package/src/api/report/getReport.ts +55 -0
  367. package/src/api/report/listActivities.ts +34 -0
  368. package/src/api/report/queryReports.ts +44 -0
  369. package/src/api/report/reassignQueue.ts +68 -0
  370. package/src/api/report/refreshStats.ts +27 -0
  371. package/src/api/report/unassignModerator.ts +21 -0
  372. package/src/api/util.ts +12 -0
  373. package/src/assignment/index.ts +731 -0
  374. package/src/config/config.ts +27 -0
  375. package/src/config/env.ts +8 -0
  376. package/src/context.ts +31 -0
  377. package/src/daemon/context.ts +34 -0
  378. package/src/daemon/event-reverser.ts +50 -1
  379. package/src/daemon/job-cursor.ts +33 -0
  380. package/src/daemon/queue-router.ts +101 -0
  381. package/src/daemon/stats-computer.ts +101 -0
  382. package/src/daemon/strike-expiry-processor.ts +4 -20
  383. package/src/db/migrations/20260219T164523000Z-create-report-table.ts +155 -0
  384. package/src/db/migrations/20260219T165302248Z-moderator-assignment.ts +42 -0
  385. package/src/db/migrations/20260225T000000000Z-add-report-queue-table.ts +41 -0
  386. package/src/db/migrations/20260313T000000000Z-add-report-activity-table.ts +48 -0
  387. package/src/db/migrations/20260318T152058935Z-add-report-stat.ts +35 -0
  388. package/src/db/migrations/20260428T000000000Z-add-expiring-tag-table.ts +32 -0
  389. package/src/db/migrations/index.ts +6 -0
  390. package/src/db/pagination.ts +85 -0
  391. package/src/db/schema/expiring_tag.ts +17 -0
  392. package/src/db/schema/index.ts +13 -1
  393. package/src/db/schema/moderator_assignment.ts +16 -0
  394. package/src/db/schema/report.ts +27 -0
  395. package/src/db/schema/report_activity.ts +22 -0
  396. package/src/db/schema/report_queue.ts +21 -0
  397. package/src/db/schema/report_stat.ts +27 -0
  398. package/src/lexicon/index.ts +280 -0
  399. package/src/lexicon/lexicons.ts +2083 -214
  400. package/src/lexicon/types/app/bsky/embed/external.ts +2 -0
  401. package/src/lexicon/types/chat/bsky/actor/defs.ts +17 -1
  402. package/src/lexicon/types/chat/bsky/convo/defs.ts +50 -10
  403. package/src/lexicon/types/chat/bsky/convo/getMessages.ts +3 -0
  404. package/src/lexicon/types/tools/ozone/moderation/defs.ts +2 -0
  405. package/src/lexicon/types/tools/ozone/moderation/emitEvent.ts +24 -0
  406. package/src/lexicon/types/tools/ozone/queue/assignModerator.ts +46 -0
  407. package/src/lexicon/types/tools/ozone/queue/createQueue.ts +54 -0
  408. package/src/lexicon/types/tools/ozone/queue/defs.ts +99 -0
  409. package/src/lexicon/types/tools/ozone/queue/deleteQueue.ts +48 -0
  410. package/src/lexicon/types/tools/ozone/queue/getAssignments.ts +48 -0
  411. package/src/lexicon/types/tools/ozone/queue/listQueues.ts +50 -0
  412. package/src/lexicon/types/tools/ozone/queue/routeReports.ts +50 -0
  413. package/src/lexicon/types/tools/ozone/queue/unassignModerator.ts +37 -0
  414. package/src/lexicon/types/tools/ozone/queue/updateQueue.ts +51 -0
  415. package/src/lexicon/types/tools/ozone/report/assignModerator.ts +50 -0
  416. package/src/lexicon/types/tools/ozone/report/createActivity.ts +60 -0
  417. package/src/lexicon/types/tools/ozone/report/defs.ts +327 -0
  418. package/src/lexicon/types/tools/ozone/report/getAssignments.ts +48 -0
  419. package/src/lexicon/types/tools/ozone/report/getHistoricalStats.ts +54 -0
  420. package/src/lexicon/types/tools/ozone/report/getLatestReport.ts +39 -0
  421. package/src/lexicon/types/tools/ozone/report/getLiveStats.ts +45 -0
  422. package/src/lexicon/types/tools/ozone/report/getReport.ts +38 -0
  423. package/src/lexicon/types/tools/ozone/report/listActivities.ts +44 -0
  424. package/src/lexicon/types/tools/ozone/report/queryReports.ts +72 -0
  425. package/src/lexicon/types/tools/ozone/report/reassignQueue.ts +55 -0
  426. package/src/lexicon/types/tools/ozone/report/refreshStats.ts +46 -0
  427. package/src/lexicon/types/tools/ozone/report/unassignModerator.ts +44 -0
  428. package/src/mod-service/expiring-tags.ts +98 -0
  429. package/src/mod-service/index.ts +71 -3
  430. package/src/mod-service/report.ts +408 -0
  431. package/src/queue/service.ts +599 -0
  432. package/src/report/activity.ts +234 -0
  433. package/src/report/handle-report-update.ts +209 -0
  434. package/src/report/reassign.ts +109 -0
  435. package/src/report/stats.ts +850 -0
  436. package/src/report/views.ts +241 -0
  437. package/src/team/index.ts +11 -0
  438. package/tests/expiring-tags.test.ts +231 -0
  439. package/tests/get-report.test.ts +136 -0
  440. package/tests/query-reports.test.ts +608 -0
  441. package/tests/queue-assignment.test.ts +428 -0
  442. package/tests/queue-router.test.ts +306 -0
  443. package/tests/queues.test.ts +690 -0
  444. package/tests/report-action.test.ts +308 -0
  445. package/tests/report-activity.test.ts +567 -0
  446. package/tests/report-assignment.test.ts +517 -0
  447. package/tests/report-reassign-queue.test.ts +340 -0
  448. package/tests/report-routing.test.ts +245 -0
  449. package/tests/report-stats.test.ts +545 -0
  450. package/tsconfig.build.tsbuildinfo +1 -1
@@ -0,0 +1,428 @@
1
+ import AtpAgent, {
2
+ ToolsOzoneQueueAssignModerator,
3
+ ToolsOzoneQueueGetAssignments,
4
+ ToolsOzoneQueueUnassignModerator,
5
+ } from '@atproto/api'
6
+ import { SeedClient, TestNetwork, basicSeed } from '@atproto/dev-env'
7
+ import { ids } from '../src/lexicon/lexicons'
8
+
9
+ describe('queue', () => {
10
+ let network: TestNetwork
11
+ let agent: AtpAgent
12
+ let sc: SeedClient
13
+
14
+ let q1: number
15
+ let q2: number
16
+ let q3: number
17
+
18
+ const assign = async (
19
+ input: ToolsOzoneQueueAssignModerator.InputSchema,
20
+ callerRole: 'admin' | 'moderator' | 'triage' = 'moderator',
21
+ ) => {
22
+ const { data } = await agent.tools.ozone.queue.assignModerator(input, {
23
+ encoding: 'application/json',
24
+ headers: await network.ozone.modHeaders(
25
+ ids.ToolsOzoneQueueAssignModerator,
26
+ callerRole,
27
+ ),
28
+ })
29
+ return data
30
+ }
31
+
32
+ const getAssignments = async (
33
+ input: ToolsOzoneQueueGetAssignments.QueryParams,
34
+ callerRole: 'admin' | 'moderator' | 'triage' = 'moderator',
35
+ ) => {
36
+ const { data } = await agent.tools.ozone.queue.getAssignments(input, {
37
+ headers: await network.ozone.modHeaders(
38
+ ids.ToolsOzoneQueueGetAssignments,
39
+ callerRole,
40
+ ),
41
+ })
42
+ return data
43
+ }
44
+
45
+ const unassign = async (
46
+ input: ToolsOzoneQueueUnassignModerator.InputSchema,
47
+ callerRole: 'admin' | 'moderator' | 'triage' = 'moderator',
48
+ ) => {
49
+ await agent.tools.ozone.queue.unassignModerator(input, {
50
+ encoding: 'application/json',
51
+ headers: await network.ozone.modHeaders(
52
+ ids.ToolsOzoneQueueUnassignModerator,
53
+ callerRole,
54
+ ),
55
+ })
56
+ }
57
+
58
+ const clearAssignments = async () => {
59
+ await network.ozone.ctx.db.db.deleteFrom('moderator_assignment').execute()
60
+ }
61
+
62
+ const createQueue = async (name: string, reportTypes: string[]) => {
63
+ const { data } = await agent.tools.ozone.queue.createQueue(
64
+ {
65
+ name,
66
+ subjectTypes: ['account'],
67
+ reportTypes,
68
+ },
69
+ {
70
+ encoding: 'application/json',
71
+ headers: await network.ozone.modHeaders(
72
+ ids.ToolsOzoneQueueCreateQueue,
73
+ 'admin',
74
+ ),
75
+ },
76
+ )
77
+ return data
78
+ }
79
+
80
+ beforeAll(async () => {
81
+ network = await TestNetwork.create({
82
+ dbPostgresSchema: 'queue_assignment',
83
+ })
84
+ agent = network.ozone.getAgent()
85
+ sc = network.getSeedClient()
86
+ await basicSeed(sc)
87
+ await network.processAll()
88
+
89
+ // Clean up any leftover data from previous runs
90
+ await network.ozone.ctx.db.db.deleteFrom('moderator_assignment').execute()
91
+ await network.ozone.ctx.db.db.deleteFrom('report_queue').execute()
92
+
93
+ // Seed queues and capture their actual IDs
94
+ const queue1 = await createQueue('Queue 1', [
95
+ 'com.atproto.moderation.defs#reasonSpam',
96
+ ])
97
+ const queue2 = await createQueue('Queue 2', [
98
+ 'com.atproto.moderation.defs#reasonOther',
99
+ ])
100
+ const queue3 = await createQueue('Queue 3', [
101
+ 'com.atproto.moderation.defs#reasonMisleading',
102
+ ])
103
+ q1 = queue1.queue.id
104
+ q2 = queue2.queue.id
105
+ q3 = queue3.queue.id
106
+ })
107
+
108
+ afterAll(async () => {
109
+ await network.close()
110
+ })
111
+
112
+ it('get active assignments', async () => {
113
+ await assign({ queueId: q1, did: network.ozone.adminAccnt.did }, 'admin')
114
+ const result = await getAssignments({ onlyActive: true })
115
+
116
+ expect(result.assignments.length).toBeGreaterThanOrEqual(1)
117
+ const queueIds = result.assignments.map((a) => a.queue.id)
118
+ expect(queueIds).toContain(q1)
119
+ })
120
+
121
+ it('filters assignments by queueId', async () => {
122
+ await assign(
123
+ { queueId: q1, did: network.ozone.moderatorAccnt.did },
124
+ 'moderator',
125
+ )
126
+
127
+ const result = await getAssignments({
128
+ queueIds: [q1],
129
+ })
130
+
131
+ expect(result.assignments.length).toBeGreaterThanOrEqual(1)
132
+ expect(result.assignments[0].queue.id).toBe(q1)
133
+ })
134
+
135
+ it('filters assignments by dids', async () => {
136
+ await assign({ queueId: q1, did: sc.dids.bob }, 'admin')
137
+ await assign({ queueId: q1, did: sc.dids.carol }, 'admin')
138
+
139
+ const result = await getAssignments({
140
+ dids: [sc.dids.bob],
141
+ })
142
+
143
+ expect(result.assignments.length).toBeGreaterThanOrEqual(1)
144
+ })
145
+
146
+ it('get assignments for a user', async () => {
147
+ await assign({ queueId: q1, did: sc.dids.bob }, 'admin')
148
+
149
+ const result = await getAssignments({
150
+ dids: [sc.dids.bob],
151
+ })
152
+
153
+ expect(result.assignments.length).toBeGreaterThanOrEqual(1)
154
+ })
155
+
156
+ it('get active assignments for queue', async () => {
157
+ await clearAssignments()
158
+ await assign({ queueId: q1, did: sc.dids.bob }, 'admin')
159
+ const result = await getAssignments({
160
+ queueIds: [q1],
161
+ onlyActive: true,
162
+ })
163
+ expect(result.assignments.length).toBe(1)
164
+ })
165
+
166
+ it('get all assignments for queue', async () => {
167
+ await clearAssignments()
168
+ await assign({ queueId: q1, did: sc.dids.alice }, 'admin')
169
+ const result = await getAssignments({
170
+ queueIds: [q1],
171
+ onlyActive: false,
172
+ })
173
+ expect(result.assignments.length).toBe(1)
174
+ })
175
+
176
+ it('invalid queue ID throws error', async () => {
177
+ const p = assign(
178
+ { queueId: 9999, did: network.ozone.adminAccnt.did },
179
+ 'admin',
180
+ )
181
+ await expect(p).rejects.toThrow('Invalid queue')
182
+ })
183
+
184
+ describe('pagination', () => {
185
+ it('paginates assignments with limit', async () => {
186
+ await clearAssignments()
187
+ // Create assignments for multiple queues
188
+ await assign({ queueId: q1, did: sc.dids.alice }, 'admin')
189
+ await assign({ queueId: q2, did: sc.dids.alice }, 'admin')
190
+ await assign({ queueId: q3, did: sc.dids.alice }, 'admin')
191
+
192
+ const firstPage = await getAssignments({ limit: 2 })
193
+ expect(firstPage.assignments.length).toBe(2)
194
+ expect(firstPage.cursor).toBeDefined()
195
+ })
196
+
197
+ it('returns all results when limit exceeds total', async () => {
198
+ await clearAssignments()
199
+ await assign({ queueId: q1, did: sc.dids.alice }, 'admin')
200
+ await assign({ queueId: q2, did: sc.dids.alice }, 'admin')
201
+
202
+ const result = await getAssignments({ limit: 50 })
203
+ expect(result.assignments.length).toBe(2)
204
+ // Cursor always points to the last item returned, even when all results fit in one page
205
+ expect(result.cursor).toBeDefined()
206
+ })
207
+
208
+ it('fetches next page using cursor', async () => {
209
+ await clearAssignments()
210
+ await assign({ queueId: q1, did: sc.dids.alice }, 'admin')
211
+ await assign({ queueId: q2, did: sc.dids.bob }, 'admin')
212
+ await assign({ queueId: q3, did: sc.dids.carol }, 'admin')
213
+
214
+ const firstPage = await getAssignments({ limit: 2 })
215
+ expect(firstPage.assignments.length).toBe(2)
216
+ expect(firstPage.cursor).toBeDefined()
217
+
218
+ const secondPage = await getAssignments({
219
+ limit: 2,
220
+ cursor: firstPage.cursor,
221
+ })
222
+ expect(secondPage.assignments.length).toBe(1)
223
+ // Cursor points to the last item returned; a subsequent fetch with this cursor would return 0 results
224
+ expect(secondPage.cursor).toBeDefined()
225
+
226
+ // Ensure no overlap between pages
227
+ const firstPageIds = firstPage.assignments.map((a) => a.id)
228
+ const secondPageIds = secondPage.assignments.map((a) => a.id)
229
+ for (const id of secondPageIds) {
230
+ expect(firstPageIds).not.toContain(id)
231
+ }
232
+ })
233
+
234
+ it('returns all assignments across pages', async () => {
235
+ await clearAssignments()
236
+ await assign({ queueId: q1, did: sc.dids.alice }, 'admin')
237
+ await assign({ queueId: q2, did: sc.dids.bob }, 'admin')
238
+ await assign({ queueId: q3, did: sc.dids.carol }, 'admin')
239
+
240
+ // Collect all assignments via pagination
241
+ const allAssignments: typeof firstPage.assignments = []
242
+ let cursor: string | undefined
243
+ const firstPage = await getAssignments({ limit: 1 })
244
+ allAssignments.push(...firstPage.assignments)
245
+ cursor = firstPage.cursor
246
+
247
+ while (cursor) {
248
+ const page = await getAssignments({ limit: 1, cursor })
249
+ allAssignments.push(...page.assignments)
250
+ cursor = page.cursor
251
+ }
252
+
253
+ expect(allAssignments.length).toBe(3)
254
+ // Verify all unique
255
+ const ids = allAssignments.map((a) => a.id)
256
+ expect(new Set(ids).size).toBe(3)
257
+ })
258
+
259
+ it('applies filters alongside pagination', async () => {
260
+ await clearAssignments()
261
+ await assign({ queueId: q1, did: sc.dids.alice }, 'admin')
262
+ await assign({ queueId: q1, did: sc.dids.bob }, 'admin')
263
+ await assign({ queueId: q2, did: sc.dids.carol }, 'admin')
264
+
265
+ const result = await getAssignments({ queueIds: [q1], limit: 1 })
266
+ expect(result.assignments.length).toBe(1)
267
+ expect(result.assignments[0].queue.id).toBe(q1)
268
+ expect(result.cursor).toBeDefined()
269
+
270
+ const nextPage = await getAssignments({
271
+ queueIds: [q1],
272
+ limit: 1,
273
+ cursor: result.cursor,
274
+ })
275
+ expect(nextPage.assignments.length).toBe(1)
276
+ expect(nextPage.assignments[0].queue.id).toBe(q1)
277
+ })
278
+ })
279
+
280
+ describe('admin', () => {
281
+ it('should be able to assign self to a queue', async () => {
282
+ const assignment = await assign(
283
+ { queueId: q1, did: network.ozone.adminAccnt.did },
284
+ 'admin',
285
+ )
286
+
287
+ expect(assignment.queue.id).toBe(q1)
288
+ expect(assignment.moderator?.did).toBe(network.ozone.adminAccnt.did)
289
+
290
+ const assignments = await getAssignments({ onlyActive: true }, 'admin')
291
+ const queueIds = assignments.assignments.map((a) => a.queue.id)
292
+ expect(queueIds).toContain(q1)
293
+ })
294
+ it('should be able to assign a mod to a queue', async () => {
295
+ const assignment = await assign(
296
+ { queueId: q1, did: sc.dids.bob },
297
+ 'admin',
298
+ )
299
+
300
+ expect(assignment.queue.id).toBe(q1)
301
+
302
+ const assignments = await getAssignments({ onlyActive: true }, 'admin')
303
+ const queueIds = assignments.assignments.map((a) => a.queue.id)
304
+ expect(queueIds).toContain(q1)
305
+ })
306
+ it('should be able to assign multiple mods to a queue', async () => {
307
+ await assign({ queueId: q1, did: sc.dids.bob }, 'admin')
308
+ await assign({ queueId: q1, did: sc.dids.carol }, 'admin')
309
+ const assignments = await getAssignments(
310
+ { onlyActive: true, queueIds: [q1] },
311
+ 'admin',
312
+ )
313
+ expect(assignments.assignments.length).toBeGreaterThanOrEqual(2)
314
+ })
315
+ })
316
+
317
+ describe('moderator', () => {
318
+ it('should be able to assign self to a queue', async () => {
319
+ const assignment = await assign(
320
+ { queueId: q1, did: network.ozone.moderatorAccnt.did },
321
+ 'moderator',
322
+ )
323
+
324
+ expect(assignment.queue.id).toBe(q1)
325
+ expect(assignment.moderator?.did).toBe(network.ozone.moderatorAccnt.did)
326
+
327
+ const assignments = await getAssignments({ onlyActive: true }, 'admin')
328
+ const queueIds = assignments.assignments.map((a) => a.queue.id)
329
+ expect(queueIds).toContain(q1)
330
+ })
331
+ it('should not be able to assign another user to a queue', async () => {
332
+ const p = assign(
333
+ { queueId: q1, did: network.ozone.adminAccnt.did },
334
+ 'moderator',
335
+ )
336
+ await expect(p).rejects.toThrow('Unauthorized')
337
+ })
338
+
339
+ it('assigns permanently with no endAt', async () => {
340
+ const assignment = await assign(
341
+ { queueId: q1, did: network.ozone.moderatorAccnt.did },
342
+ 'moderator',
343
+ )
344
+ expect(assignment.endAt).toBeUndefined()
345
+ })
346
+ })
347
+
348
+ describe('triage', () => {
349
+ it('should not be able to assign self to a queue', async () => {
350
+ const p = assign(
351
+ { queueId: q1, did: network.ozone.triageAccnt.did },
352
+ 'triage',
353
+ )
354
+ await expect(p).rejects.toThrow('Unauthorized')
355
+ })
356
+ it('should not be able to assign another user to a queue', async () => {
357
+ const p = assign(
358
+ { queueId: q1, did: network.ozone.adminAccnt.did },
359
+ 'triage',
360
+ )
361
+ await expect(p).rejects.toThrow('Unauthorized')
362
+ })
363
+ })
364
+
365
+ describe('unassign', () => {
366
+ it('moderator can unassign self and assignment becomes inactive', async () => {
367
+ await clearAssignments()
368
+ await assign(
369
+ { queueId: q1, did: network.ozone.moderatorAccnt.did },
370
+ 'moderator',
371
+ )
372
+
373
+ await unassign(
374
+ { queueId: q1, did: network.ozone.moderatorAccnt.did },
375
+ 'moderator',
376
+ )
377
+
378
+ const active = await getAssignments({
379
+ queueIds: [q1],
380
+ dids: [network.ozone.moderatorAccnt.did],
381
+ onlyActive: true,
382
+ })
383
+ expect(active.assignments.length).toBe(0)
384
+ })
385
+
386
+ it('admin can unassign another moderator', async () => {
387
+ await clearAssignments()
388
+ await assign({ queueId: q1, did: sc.dids.bob }, 'admin')
389
+
390
+ await unassign({ queueId: q1, did: sc.dids.bob }, 'admin')
391
+
392
+ const active = await getAssignments({
393
+ queueIds: [q1],
394
+ dids: [sc.dids.bob],
395
+ onlyActive: true,
396
+ })
397
+ expect(active.assignments.length).toBe(0)
398
+ })
399
+
400
+ it('moderator cannot unassign another user', async () => {
401
+ await clearAssignments()
402
+ await assign({ queueId: q1, did: sc.dids.bob }, 'admin')
403
+
404
+ const p = unassign({ queueId: q1, did: sc.dids.bob }, 'moderator')
405
+ await expect(p).rejects.toThrow('Unauthorized')
406
+ })
407
+
408
+ it('triage cannot unassign', async () => {
409
+ await clearAssignments()
410
+ await assign({ queueId: q1, did: network.ozone.triageAccnt.did }, 'admin')
411
+
412
+ const p = unassign(
413
+ { queueId: q1, did: network.ozone.triageAccnt.did },
414
+ 'triage',
415
+ )
416
+ await expect(p).rejects.toThrow('Unauthorized')
417
+ })
418
+
419
+ it('throws InvalidAssignment when no active assignment exists', async () => {
420
+ await clearAssignments()
421
+ const p = unassign(
422
+ { queueId: q1, did: network.ozone.moderatorAccnt.did },
423
+ 'moderator',
424
+ )
425
+ await expect(p).rejects.toThrow('No active assignment')
426
+ })
427
+ })
428
+ })