@atproto/bsky 0.0.242 → 0.0.243

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 (107) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/dist/api/app/bsky/actor/searchActors.d.ts.map +1 -1
  3. package/dist/api/app/bsky/actor/searchActors.js +7 -3
  4. package/dist/api/app/bsky/actor/searchActors.js.map +1 -1
  5. package/dist/api/app/bsky/actor/searchActorsTypeahead.d.ts.map +1 -1
  6. package/dist/api/app/bsky/actor/searchActorsTypeahead.js +7 -3
  7. package/dist/api/app/bsky/actor/searchActorsTypeahead.js.map +1 -1
  8. package/dist/api/app/bsky/feed/searchPosts.d.ts.map +1 -1
  9. package/dist/api/app/bsky/feed/searchPosts.js +8 -3
  10. package/dist/api/app/bsky/feed/searchPosts.js.map +1 -1
  11. package/dist/api/app/bsky/graph/searchStarterPacks.d.ts.map +1 -1
  12. package/dist/api/app/bsky/graph/searchStarterPacks.js +7 -3
  13. package/dist/api/app/bsky/graph/searchStarterPacks.js.map +1 -1
  14. package/dist/api/app/bsky/unspecced/getPopularFeedGenerators.d.ts.map +1 -1
  15. package/dist/api/app/bsky/unspecced/getPopularFeedGenerators.js +3 -2
  16. package/dist/api/app/bsky/unspecced/getPopularFeedGenerators.js.map +1 -1
  17. package/dist/api/util.d.ts +5 -0
  18. package/dist/api/util.d.ts.map +1 -1
  19. package/dist/api/util.js +11 -0
  20. package/dist/api/util.js.map +1 -1
  21. package/dist/config.d.ts +2 -0
  22. package/dist/config.d.ts.map +1 -1
  23. package/dist/config.js +5 -0
  24. package/dist/config.js.map +1 -1
  25. package/dist/data-plane/server/db/db.d.ts +4 -5
  26. package/dist/data-plane/server/db/db.d.ts.map +1 -1
  27. package/dist/data-plane/server/db/db.js +2 -1
  28. package/dist/data-plane/server/db/db.js.map +1 -1
  29. package/dist/data-plane/server/db/migrations/20230627T212437895Z-optional-handle.d.ts.map +1 -1
  30. package/dist/data-plane/server/db/migrations/20230627T212437895Z-optional-handle.js +2 -4
  31. package/dist/data-plane/server/db/migrations/20230627T212437895Z-optional-handle.js.map +1 -1
  32. package/dist/data-plane/server/db/migrations/provider.d.ts +2 -1
  33. package/dist/data-plane/server/db/migrations/provider.d.ts.map +1 -1
  34. package/dist/data-plane/server/db/migrations/provider.js.map +1 -1
  35. package/dist/data-plane/server/db/pagination.d.ts +3 -2
  36. package/dist/data-plane/server/db/pagination.d.ts.map +1 -1
  37. package/dist/data-plane/server/db/pagination.js +8 -8
  38. package/dist/data-plane/server/db/pagination.js.map +1 -1
  39. package/dist/data-plane/server/db/util.d.ts +5 -5
  40. package/dist/data-plane/server/db/util.d.ts.map +1 -1
  41. package/dist/data-plane/server/db/util.js.map +1 -1
  42. package/dist/data-plane/server/indexing/plugins/block.d.ts +9 -4
  43. package/dist/data-plane/server/indexing/plugins/block.d.ts.map +1 -1
  44. package/dist/data-plane/server/indexing/plugins/feed-generator.d.ts +13 -4
  45. package/dist/data-plane/server/indexing/plugins/feed-generator.d.ts.map +1 -1
  46. package/dist/data-plane/server/indexing/plugins/follow.d.ts +9 -4
  47. package/dist/data-plane/server/indexing/plugins/follow.d.ts.map +1 -1
  48. package/dist/data-plane/server/indexing/plugins/labeler.d.ts +8 -4
  49. package/dist/data-plane/server/indexing/plugins/labeler.d.ts.map +1 -1
  50. package/dist/data-plane/server/indexing/plugins/like.d.ts +12 -4
  51. package/dist/data-plane/server/indexing/plugins/like.d.ts.map +1 -1
  52. package/dist/data-plane/server/indexing/plugins/list-block.d.ts +9 -4
  53. package/dist/data-plane/server/indexing/plugins/list-block.d.ts.map +1 -1
  54. package/dist/data-plane/server/indexing/plugins/list-item.d.ts +10 -4
  55. package/dist/data-plane/server/indexing/plugins/list-item.d.ts.map +1 -1
  56. package/dist/data-plane/server/indexing/plugins/list.d.ts +13 -4
  57. package/dist/data-plane/server/indexing/plugins/list.d.ts.map +1 -1
  58. package/dist/data-plane/server/indexing/plugins/post.d.ts.map +1 -1
  59. package/dist/data-plane/server/indexing/plugins/post.js +4 -3
  60. package/dist/data-plane/server/indexing/plugins/post.js.map +1 -1
  61. package/dist/data-plane/server/indexing/plugins/repost.d.ts +12 -4
  62. package/dist/data-plane/server/indexing/plugins/repost.d.ts.map +1 -1
  63. package/dist/data-plane/server/indexing/plugins/starter-pack.d.ts +9 -4
  64. package/dist/data-plane/server/indexing/plugins/starter-pack.d.ts.map +1 -1
  65. package/dist/data-plane/server/indexing/plugins/verification.d.ts +12 -4
  66. package/dist/data-plane/server/indexing/plugins/verification.d.ts.map +1 -1
  67. package/dist/data-plane/server/routes/blocks.js +22 -14
  68. package/dist/data-plane/server/routes/blocks.js.map +1 -1
  69. package/dist/data-plane/server/routes/feed-gens.js +2 -2
  70. package/dist/data-plane/server/routes/feed-gens.js.map +1 -1
  71. package/dist/data-plane/server/routes/feeds.js +18 -16
  72. package/dist/data-plane/server/routes/feeds.js.map +1 -1
  73. package/dist/data-plane/server/routes/labels.js +1 -1
  74. package/dist/data-plane/server/routes/labels.js.map +1 -1
  75. package/dist/data-plane/server/routes/mutes.js +2 -2
  76. package/dist/data-plane/server/routes/mutes.js.map +1 -1
  77. package/dist/data-plane/server/routes/notifs.d.ts.map +1 -1
  78. package/dist/data-plane/server/routes/notifs.js +10 -9
  79. package/dist/data-plane/server/routes/notifs.js.map +1 -1
  80. package/dist/data-plane/server/routes/relationships.js.map +1 -1
  81. package/dist/data-plane/server/routes/suggestions.js +2 -2
  82. package/dist/data-plane/server/routes/suggestions.js.map +1 -1
  83. package/dist/data-plane/server/util.d.ts +31 -23
  84. package/dist/data-plane/server/util.d.ts.map +1 -1
  85. package/package.json +11 -11
  86. package/src/api/app/bsky/actor/searchActors.ts +17 -6
  87. package/src/api/app/bsky/actor/searchActorsTypeahead.ts +11 -5
  88. package/src/api/app/bsky/feed/searchPosts.ts +12 -5
  89. package/src/api/app/bsky/graph/searchStarterPacks.ts +14 -5
  90. package/src/api/app/bsky/unspecced/getPopularFeedGenerators.ts +9 -2
  91. package/src/api/util.ts +17 -0
  92. package/src/config.ts +9 -0
  93. package/src/data-plane/server/db/db.ts +1 -1
  94. package/src/data-plane/server/db/migrations/20230627T212437895Z-optional-handle.ts +2 -4
  95. package/src/data-plane/server/db/migrations/provider.ts +2 -1
  96. package/src/data-plane/server/db/pagination.ts +15 -15
  97. package/src/data-plane/server/db/util.ts +8 -5
  98. package/src/data-plane/server/indexing/plugins/post.ts +5 -4
  99. package/src/data-plane/server/routes/blocks.ts +30 -24
  100. package/src/data-plane/server/routes/feed-gens.ts +2 -2
  101. package/src/data-plane/server/routes/feeds.ts +23 -19
  102. package/src/data-plane/server/routes/labels.ts +2 -2
  103. package/src/data-plane/server/routes/mutes.ts +8 -6
  104. package/src/data-plane/server/routes/notifs.ts +15 -12
  105. package/src/data-plane/server/routes/relationships.ts +4 -2
  106. package/src/data-plane/server/routes/suggestions.ts +2 -2
  107. package/tests/data-plane/subscription.test.ts +2 -2
@@ -1,11 +1,20 @@
1
- import { Selectable } from 'kysely';
2
1
  import { app } from '../../../../lexicons/index.js';
3
2
  import { BackgroundQueue } from '../../background.js';
4
- import { DatabaseSchemaType } from '../../db/database-schema.js';
5
3
  import { Database } from '../../db/index.js';
6
4
  import { RecordProcessor } from '../processor.js';
7
- type IndexedFeedGenerator = Selectable<DatabaseSchemaType['feed_generator']>;
8
5
  export type PluginType = ReturnType<typeof makePlugin>;
9
- export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"any", "app.bsky.feed.generator", import("@atproto/lex").Validator<Omit<app.bsky.feed.generator.Main, "$type">, Omit<app.bsky.feed.generator.Main, "$type">>>, IndexedFeedGenerator>;
6
+ export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"any", "app.bsky.feed.generator", import("@atproto/lex").Validator<Omit<app.bsky.feed.generator.Main, "$type">, Omit<app.bsky.feed.generator.Main, "$type">>>, {
7
+ avatarCid: string | null;
8
+ cid: string;
9
+ createdAt: string;
10
+ creator: string;
11
+ description: string | null;
12
+ descriptionFacets: string | null;
13
+ displayName: string;
14
+ feedDid: string;
15
+ indexedAt: string;
16
+ sortAt: string;
17
+ uri: string;
18
+ }>;
10
19
  export default makePlugin;
11
20
  //# sourceMappingURL=feed-generator.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"feed-generator.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/feed-generator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAA;AAGnC,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAkB,kBAAkB,EAAE,MAAM,6BAA6B,CAAA;AAChF,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAEjD,KAAK,oBAAoB,GAAG,UAAU,CAAC,kBAAkB,CAAC,gBAAgB,CAAC,CAAC,CAAA;AAuD5E,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe,6OASnE,CAAA;eAEc,UAAU"}
1
+ {"version":3,"file":"feed-generator.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/feed-generator.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAErD,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAyDjD,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe;;;;;;;;;;;;EASnE,CAAA;eAEc,UAAU"}
@@ -1,11 +1,16 @@
1
- import { Selectable } from 'kysely';
2
1
  import { app } from '../../../../lexicons/index.js';
3
2
  import { BackgroundQueue } from '../../background.js';
4
- import { DatabaseSchemaType } from '../../db/database-schema.js';
5
3
  import { Database } from '../../db/index.js';
6
4
  import { RecordProcessor } from '../processor.js';
7
- type IndexedFollow = Selectable<DatabaseSchemaType['follow']>;
8
5
  export type PluginType = ReturnType<typeof makePlugin>;
9
- export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"tid", "app.bsky.graph.follow", import("@atproto/lex").Validator<Omit<app.bsky.graph.follow.Main, "$type">, Omit<app.bsky.graph.follow.Main, "$type">>>, IndexedFollow>;
6
+ export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"tid", "app.bsky.graph.follow", import("@atproto/lex").Validator<Omit<app.bsky.graph.follow.Main, "$type">, Omit<app.bsky.graph.follow.Main, "$type">>>, {
7
+ cid: string;
8
+ createdAt: string;
9
+ creator: string;
10
+ indexedAt: string;
11
+ sortAt: string;
12
+ subjectDid: string;
13
+ uri: string;
14
+ }>;
10
15
  export default makePlugin;
11
16
  //# sourceMappingURL=follow.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"follow.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/follow.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAA;AAGnC,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAkB,kBAAkB,EAAE,MAAM,6BAA6B,CAAA;AAChF,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAE5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAEjD,KAAK,aAAa,GAAG,UAAU,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC,CAAA;AAyG7D,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe,gOAUnE,CAAA;eAEc,UAAU"}
1
+ {"version":3,"file":"follow.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/follow.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAErD,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAE5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AA2GjD,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe;;;;;;;;EAUnE,CAAA;eAEc,UAAU"}
@@ -1,11 +1,15 @@
1
- import { Selectable } from 'kysely';
2
1
  import { app } from '../../../../lexicons/index.js';
3
2
  import { BackgroundQueue } from '../../background.js';
4
- import { DatabaseSchemaType } from '../../db/database-schema.js';
5
3
  import { Database } from '../../db/index.js';
6
4
  import { RecordProcessor } from '../processor.js';
7
- type IndexedLabeler = Selectable<DatabaseSchemaType['labeler']>;
8
5
  export type PluginType = ReturnType<typeof makePlugin>;
9
- export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"literal:self", "app.bsky.labeler.service", import("@atproto/lex").Validator<Omit<app.bsky.labeler.service.Main, "$type">, Omit<app.bsky.labeler.service.Main, "$type">>>, IndexedLabeler>;
6
+ export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"literal:self", "app.bsky.labeler.service", import("@atproto/lex").Validator<Omit<app.bsky.labeler.service.Main, "$type">, Omit<app.bsky.labeler.service.Main, "$type">>>, {
7
+ cid: string;
8
+ createdAt: string;
9
+ creator: string;
10
+ indexedAt: string;
11
+ sortAt: string;
12
+ uri: string;
13
+ }>;
10
14
  export default makePlugin;
11
15
  //# sourceMappingURL=labeler.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"labeler.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/labeler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAA;AAGnC,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAkB,kBAAkB,EAAE,MAAM,6BAA6B,CAAA;AAChF,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAEjD,KAAK,cAAc,GAAG,UAAU,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC,CAAA;AAiD/D,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe,mPASnE,CAAA;eAEc,UAAU"}
1
+ {"version":3,"file":"labeler.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/labeler.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAErD,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAmDjD,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe;;;;;;;EASnE,CAAA;eAEc,UAAU"}
@@ -1,11 +1,19 @@
1
- import { Selectable } from 'kysely';
2
1
  import { app } from '../../../../lexicons/index.js';
3
2
  import { BackgroundQueue } from '../../background.js';
4
- import { DatabaseSchemaType } from '../../db/database-schema.js';
5
3
  import { Database } from '../../db/index.js';
6
4
  import { RecordProcessor } from '../processor.js';
7
- type IndexedLike = Selectable<DatabaseSchemaType['like']>;
8
5
  export type PluginType = ReturnType<typeof makePlugin>;
9
- export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"tid", "app.bsky.feed.like", import("@atproto/lex").Validator<Omit<app.bsky.feed.like.Main, "$type">, Omit<app.bsky.feed.like.Main, "$type">>>, IndexedLike>;
6
+ export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"tid", "app.bsky.feed.like", import("@atproto/lex").Validator<Omit<app.bsky.feed.like.Main, "$type">, Omit<app.bsky.feed.like.Main, "$type">>>, {
7
+ cid: string;
8
+ createdAt: string;
9
+ creator: string;
10
+ indexedAt: string;
11
+ sortAt: string;
12
+ subject: string;
13
+ subjectCid: string;
14
+ uri: string;
15
+ via: string | null;
16
+ viaCid: string | null;
17
+ }>;
10
18
  export default makePlugin;
11
19
  //# sourceMappingURL=like.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"like.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/like.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,UAAU,EAAE,MAAM,QAAQ,CAAA;AAG/C,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAkB,kBAAkB,EAAE,MAAM,6BAA6B,CAAA;AAChF,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAG5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAGjD,KAAK,WAAW,GAAG,UAAU,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC,CAAA;AA0HzD,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe,qNAUnE,CAAA;eAEc,UAAU"}
1
+ {"version":3,"file":"like.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/like.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAErD,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAG5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AA6HjD,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe;;;;;;;;;;;EAUnE,CAAA;eAEc,UAAU"}
@@ -1,11 +1,16 @@
1
- import { Selectable } from 'kysely';
2
1
  import { app } from '../../../../lexicons/index.js';
3
2
  import { BackgroundQueue } from '../../background.js';
4
- import { DatabaseSchemaType } from '../../db/database-schema.js';
5
3
  import { Database } from '../../db/index.js';
6
4
  import { RecordProcessor } from '../processor.js';
7
- type IndexedListBlock = Selectable<DatabaseSchemaType['list_block']>;
8
5
  export type PluginType = ReturnType<typeof makePlugin>;
9
- export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"tid", "app.bsky.graph.listblock", import("@atproto/lex").Validator<Omit<app.bsky.graph.listblock.Main, "$type">, Omit<app.bsky.graph.listblock.Main, "$type">>>, IndexedListBlock>;
6
+ export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"tid", "app.bsky.graph.listblock", import("@atproto/lex").Validator<Omit<app.bsky.graph.listblock.Main, "$type">, Omit<app.bsky.graph.listblock.Main, "$type">>>, {
7
+ cid: string;
8
+ createdAt: string;
9
+ creator: string;
10
+ indexedAt: string;
11
+ sortAt: string;
12
+ subjectUri: string;
13
+ uri: string;
14
+ }>;
10
15
  export default makePlugin;
11
16
  //# sourceMappingURL=list-block.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"list-block.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/list-block.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAA;AAGnC,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAkB,kBAAkB,EAAE,MAAM,6BAA6B,CAAA;AAChF,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAEjD,KAAK,gBAAgB,GAAG,UAAU,CAAC,kBAAkB,CAAC,YAAY,CAAC,CAAC,CAAA;AA2DpE,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe,4OASnE,CAAA;eAEc,UAAU"}
1
+ {"version":3,"file":"list-block.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/list-block.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAErD,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AA6DjD,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe;;;;;;;;EASnE,CAAA;eAEc,UAAU"}
@@ -1,11 +1,17 @@
1
- import { Selectable } from 'kysely';
2
1
  import { app } from '../../../../lexicons/index.js';
3
2
  import { BackgroundQueue } from '../../background.js';
4
- import { DatabaseSchemaType } from '../../db/database-schema.js';
5
3
  import { Database } from '../../db/index.js';
6
4
  import { RecordProcessor } from '../processor.js';
7
- type IndexedListItem = Selectable<DatabaseSchemaType['list_item']>;
8
5
  export type PluginType = ReturnType<typeof makePlugin>;
9
- export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"tid", "app.bsky.graph.listitem", import("@atproto/lex").Validator<Omit<app.bsky.graph.listitem.Main, "$type">, Omit<app.bsky.graph.listitem.Main, "$type">>>, IndexedListItem>;
6
+ export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"tid", "app.bsky.graph.listitem", import("@atproto/lex").Validator<Omit<app.bsky.graph.listitem.Main, "$type">, Omit<app.bsky.graph.listitem.Main, "$type">>>, {
7
+ cid: string;
8
+ createdAt: string;
9
+ creator: string;
10
+ indexedAt: string;
11
+ listUri: string;
12
+ sortAt: string;
13
+ subjectDid: string;
14
+ uri: string;
15
+ }>;
10
16
  export default makePlugin;
11
17
  //# sourceMappingURL=list-item.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"list-item.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/list-item.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAA;AAInC,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAkB,kBAAkB,EAAE,MAAM,6BAA6B,CAAA;AAChF,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAEjD,KAAK,eAAe,GAAG,UAAU,CAAC,kBAAkB,CAAC,WAAW,CAAC,CAAC,CAAA;AAkElE,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe,wOASnE,CAAA;eAEc,UAAU"}
1
+ {"version":3,"file":"list-item.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/list-item.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAErD,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAoEjD,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe;;;;;;;;;EASnE,CAAA;eAEc,UAAU"}
@@ -1,11 +1,20 @@
1
- import { Selectable } from 'kysely';
2
1
  import { app } from '../../../../lexicons/index.js';
3
2
  import { BackgroundQueue } from '../../background.js';
4
- import { DatabaseSchemaType } from '../../db/database-schema.js';
5
3
  import { Database } from '../../db/index.js';
6
4
  import { RecordProcessor } from '../processor.js';
7
- type IndexedList = Selectable<DatabaseSchemaType['list']>;
8
5
  export type PluginType = ReturnType<typeof makePlugin>;
9
- export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"tid", "app.bsky.graph.list", import("@atproto/lex").Validator<Omit<app.bsky.graph.list.Main, "$type">, Omit<app.bsky.graph.list.Main, "$type">>>, IndexedList>;
6
+ export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"tid", "app.bsky.graph.list", import("@atproto/lex").Validator<Omit<app.bsky.graph.list.Main, "$type">, Omit<app.bsky.graph.list.Main, "$type">>>, {
7
+ avatarCid: string | null;
8
+ cid: string;
9
+ createdAt: string;
10
+ creator: string;
11
+ description: string | null;
12
+ descriptionFacets: string | null;
13
+ indexedAt: string;
14
+ name: string;
15
+ purpose: string;
16
+ sortAt: string;
17
+ uri: string;
18
+ }>;
10
19
  export default makePlugin;
11
20
  //# sourceMappingURL=list.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"list.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/list.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAA;AAGnC,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAkB,kBAAkB,EAAE,MAAM,6BAA6B,CAAA;AAChF,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAEjD,KAAK,WAAW,GAAG,UAAU,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC,CAAA;AAuDzD,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe,wNASnE,CAAA;eAEc,UAAU"}
1
+ {"version":3,"file":"list.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/list.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAErD,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAyDjD,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe;;;;;;;;;;;;EASnE,CAAA;eAEc,UAAU"}
@@ -1 +1 @@
1
- {"version":3,"file":"post.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/post.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,UAAU,EAAO,MAAM,QAAQ,CAAA;AAGpD,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AAQnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAkB,kBAAkB,EAAE,MAAM,6BAA6B,CAAA;AAChF,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAS5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAGjD,KAAK,IAAI,GAAG,UAAU,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC,CAAA;AAClD,KAAK,cAAc,GAAG,kBAAkB,CAAC,kBAAkB,CAAC,CAAA;AAC5D,KAAK,iBAAiB,GAAG,kBAAkB,CAAC,qBAAqB,CAAC,CAAA;AAClE,KAAK,eAAe,GAAG,kBAAkB,CAAC,mBAAmB,CAAC,CAAA;AAC9D,KAAK,cAAc,GAAG,kBAAkB,CAAC,kBAAkB,CAAC,CAAA;AAC5D,KAAK,qBAAqB,GAAG,kBAAkB,CAAC,0BAA0B,CAAC,CAAA;AAC3E,KAAK,YAAY,GAAG;IAClB,GAAG,EAAE,MAAM,CAAA;IACX,MAAM,EAAE,MAAM,CAAA;CACf,CAAA;AACD,KAAK,cAAc,GAAG;IACpB,GAAG,EAAE,MAAM,CAAA;IACX,KAAK,EAAE,MAAM,CAAA;IACb,GAAG,EAAE,MAAM,CAAA;IACX,OAAO,EAAE,MAAM,CAAA;IACf,MAAM,EAAE,MAAM,CAAA;CACf,CAAA;AACD,KAAK,WAAW,GAAG;IACjB,IAAI,EAAE,IAAI,CAAA;IACV,MAAM,CAAC,EAAE;QAAE,IAAI,EAAE,SAAS,GAAG,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,EAAE,CAAA;IACtD,MAAM,CAAC,EAAE,CACL,cAAc,EAAE,GAChB,iBAAiB,GACjB,eAAe,GACf,cAAc,GACd,qBAAqB,EAAE,CAC1B,EAAE,CAAA;IACH,SAAS,CAAC,EAAE,YAAY,EAAE,CAAA;IAC1B,WAAW,CAAC,EAAE,cAAc,EAAE,CAAA;IAC9B,UAAU,CAAC,EAAE,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAA;CAC3C,CAAA;AAgeD,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe,qNAUnE,CAAA;eAEc,UAAU"}
1
+ {"version":3,"file":"post.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/post.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,UAAU,EAAO,MAAM,QAAQ,CAAA;AAGpD,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AAQnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAkB,kBAAkB,EAAE,MAAM,6BAA6B,CAAA;AAChF,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAS5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAGjD,KAAK,IAAI,GAAG,UAAU,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC,CAAA;AAClD,KAAK,cAAc,GAAG,kBAAkB,CAAC,kBAAkB,CAAC,CAAA;AAC5D,KAAK,iBAAiB,GAAG,kBAAkB,CAAC,qBAAqB,CAAC,CAAA;AAClE,KAAK,eAAe,GAAG,kBAAkB,CAAC,mBAAmB,CAAC,CAAA;AAC9D,KAAK,cAAc,GAAG,kBAAkB,CAAC,kBAAkB,CAAC,CAAA;AAC5D,KAAK,qBAAqB,GAAG,kBAAkB,CAAC,0BAA0B,CAAC,CAAA;AAC3E,KAAK,YAAY,GAAG;IAClB,GAAG,EAAE,MAAM,CAAA;IACX,MAAM,EAAE,MAAM,CAAA;CACf,CAAA;AACD,KAAK,cAAc,GAAG;IACpB,GAAG,EAAE,MAAM,CAAA;IACX,KAAK,EAAE,MAAM,CAAA;IACb,GAAG,EAAE,MAAM,CAAA;IACX,OAAO,EAAE,MAAM,CAAA;IACf,MAAM,EAAE,MAAM,CAAA;CACf,CAAA;AACD,KAAK,WAAW,GAAG;IACjB,IAAI,EAAE,IAAI,CAAA;IACV,MAAM,CAAC,EAAE;QAAE,IAAI,EAAE,SAAS,GAAG,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,EAAE,CAAA;IACtD,MAAM,CAAC,EAAE,CACL,cAAc,EAAE,GAChB,iBAAiB,GACjB,eAAe,GACf,cAAc,GACd,qBAAqB,EAAE,CAC1B,EAAE,CAAA;IACH,SAAS,CAAC,EAAE,YAAY,EAAE,CAAA;IAC1B,WAAW,CAAC,EAAE,cAAc,EAAE,CAAA;IAC9B,UAAU,CAAC,EAAE,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAA;CAC3C,CAAA;AAieD,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe,qNAUnE,CAAA;eAEc,UAAU"}
@@ -399,9 +399,10 @@ const updateAggregates = async (db, postIdx) => {
399
399
  replyCount: db
400
400
  .selectFrom('post')
401
401
  .where('post.replyParent', '=', postIdx.post.replyParent)
402
- .where((qb) => qb
403
- .where('post.violatesThreadGate', 'is', null)
404
- .orWhere('post.violatesThreadGate', '=', false))
402
+ .where((eb) => eb.or([
403
+ eb('post.violatesThreadGate', 'is', null),
404
+ eb('post.violatesThreadGate', '=', false),
405
+ ]))
405
406
  .select(countAll.as('count')),
406
407
  })
407
408
  .onConflict((oc) => oc
@@ -1 +1 @@
1
- {"version":3,"file":"post.js","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/post.ts"],"names":[],"mappings":"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","sourcesContent":["import { Insertable, Selectable, sql } from 'kysely'\nimport { $Typed, Cid, getBlobCidString, lexParse } from '@atproto/lex'\nimport { AtUri, normalizeDatetimeAlways } from '@atproto/syntax'\nimport { app } from '../../../../lexicons/index.js'\nimport {\n postUriToPostgateUri,\n postUriToThreadgateUri,\n uriToDid,\n} from '../../../../util/uris.js'\nimport { RecordWithMedia } from '../../../../views/types.js'\nimport { parsePostgate } from '../../../../views/util.js'\nimport { BackgroundQueue } from '../../background.js'\nimport { DatabaseSchema, DatabaseSchemaType } from '../../db/database-schema.js'\nimport { Database } from '../../db/index.js'\nimport { Notification } from '../../db/tables/notification.js'\nimport { countAll, excluded } from '../../db/util.js'\nimport {\n getAncestorsAndSelfQb,\n getDescendentsQb,\n invalidReplyRoot as checkInvalidReplyRoot,\n violatesThreadGate as checkViolatesThreadGate,\n} from '../../util.js'\nimport { RecordProcessor } from '../processor.js'\n\ntype Notif = Insertable<Notification>\ntype Post = Selectable<DatabaseSchemaType['post']>\ntype PostEmbedImage = DatabaseSchemaType['post_embed_image']\ntype PostEmbedExternal = DatabaseSchemaType['post_embed_external']\ntype PostEmbedRecord = DatabaseSchemaType['post_embed_record']\ntype PostEmbedVideo = DatabaseSchemaType['post_embed_video']\ntype PostEmbedGalleryImage = DatabaseSchemaType['post_embed_gallery_image']\ntype PostAncestor = {\n uri: string\n height: number\n}\ntype PostDescendent = {\n uri: string\n depth: number\n cid: string\n creator: string\n sortAt: string\n}\ntype IndexedPost = {\n post: Post\n facets?: { type: 'mention' | 'link'; value: string }[]\n embeds?: (\n | PostEmbedImage[]\n | PostEmbedExternal\n | PostEmbedRecord\n | PostEmbedVideo\n | PostEmbedGalleryImage[]\n )[]\n ancestors?: PostAncestor[]\n descendents?: PostDescendent[]\n threadgate?: app.bsky.feed.threadgate.Main\n}\n\nconst REPLY_NOTIF_DEPTH = 5\n\nconst insertFn = async (\n db: DatabaseSchema,\n uri: AtUri,\n cid: Cid,\n obj: app.bsky.feed.post.Main,\n timestamp: string,\n): Promise<IndexedPost | null> => {\n const post = {\n uri: uri.toString(),\n cid: cid.toString(),\n creator: uri.host,\n text: obj.text,\n createdAt: normalizeDatetimeAlways(obj.createdAt),\n replyRoot: obj.reply?.root?.uri || null,\n replyRootCid: obj.reply?.root?.cid || null,\n replyParent: obj.reply?.parent?.uri || null,\n replyParentCid: obj.reply?.parent?.cid || null,\n langs: obj.langs?.length\n ? sql<string[]>`${JSON.stringify(obj.langs)}` // sidesteps kysely's array serialization, which is non-jsonb\n : null,\n tags: obj.tags?.length\n ? sql<string[]>`${JSON.stringify(obj.tags)}` // sidesteps kysely's array serialization, which is non-jsonb\n : null,\n indexedAt: timestamp,\n }\n const [insertedPost] = await Promise.all([\n db\n .insertInto('post')\n .values(post)\n .onConflict((oc) => oc.doNothing())\n .returningAll()\n .executeTakeFirst(),\n db\n .insertInto('feed_item')\n .values({\n type: 'post',\n uri: post.uri,\n cid: post.cid,\n postUri: post.uri,\n originatorDid: post.creator,\n sortAt:\n post.indexedAt < post.createdAt ? post.indexedAt : post.createdAt,\n })\n .onConflict((oc) => oc.doNothing())\n .executeTakeFirst(),\n ])\n if (!insertedPost) {\n return null // Post already indexed\n }\n\n if (obj.reply) {\n const { invalidReplyRoot, violatesThreadGate } = await validateReply(\n db,\n uri.host,\n obj.reply,\n )\n if (invalidReplyRoot || violatesThreadGate) {\n Object.assign(insertedPost, { invalidReplyRoot, violatesThreadGate })\n await db\n .updateTable('post')\n .where('uri', '=', post.uri)\n .set({ invalidReplyRoot, violatesThreadGate })\n .executeTakeFirst()\n }\n }\n\n const facets = (obj.facets || [])\n .flatMap((facet) => facet.features)\n .flatMap((feature) => {\n if (app.bsky.richtext.facet.mention.$matches(feature)) {\n return {\n type: 'mention' as const,\n value: feature.did,\n }\n }\n if (app.bsky.richtext.facet.link.$matches(feature)) {\n return {\n type: 'link' as const,\n value: feature.uri,\n }\n }\n return []\n })\n // Embed indices\n const embeds: (\n | PostEmbedImage[]\n | PostEmbedExternal\n | PostEmbedRecord\n | PostEmbedVideo\n | PostEmbedGalleryImage[]\n )[] = []\n const postEmbeds = separateEmbeds(obj.embed)\n for (const postEmbed of postEmbeds) {\n if (app.bsky.embed.images.$matches(postEmbed)) {\n const { images } = postEmbed\n const imagesEmbed = images.map((img, i) => ({\n postUri: uri.toString(),\n position: i,\n imageCid: getBlobCidString(img.image),\n alt: img.alt,\n }))\n embeds.push(imagesEmbed)\n await db.insertInto('post_embed_image').values(imagesEmbed).execute()\n } else if (app.bsky.embed.external.$matches(postEmbed)) {\n const { external } = postEmbed\n const externalEmbed = {\n postUri: uri.toString(),\n uri: external.uri,\n title: external.title,\n description: external.description,\n thumbCid: getBlobCidString(external.thumb) || null,\n }\n embeds.push(externalEmbed)\n await db.insertInto('post_embed_external').values(externalEmbed).execute()\n } else if (app.bsky.embed.record.$matches(postEmbed)) {\n const { record } = postEmbed\n const embedUri = new AtUri(record.uri)\n const recordEmbed = {\n postUri: uri.toString(),\n embedUri: record.uri,\n embedCid: record.cid,\n }\n embeds.push(recordEmbed)\n await db.insertInto('post_embed_record').values(recordEmbed).execute()\n\n if (embedUri.collection === app.bsky.feed.post.$type) {\n const quote = {\n uri: uri.toString(),\n cid: cid.toString(),\n subject: record.uri,\n subjectCid: record.cid,\n createdAt: normalizeDatetimeAlways(obj.createdAt),\n indexedAt: timestamp,\n }\n await db\n .insertInto('quote')\n .values(quote)\n .onConflict((oc) => oc.doNothing())\n .returningAll()\n .executeTakeFirst()\n\n const quoteCountQb = db\n .insertInto('post_agg')\n .values({\n uri: record.uri.toString(),\n quoteCount: db\n .selectFrom('quote')\n .where('quote.subjectCid', '=', record.cid.toString())\n .select(countAll.as('count')),\n })\n .onConflict((oc) =>\n oc\n .column('uri')\n .doUpdateSet({ quoteCount: excluded(db, 'quoteCount') }),\n )\n await quoteCountQb.execute()\n\n const { violatesEmbeddingRules } = await validatePostEmbed(\n db,\n embedUri.toString(),\n uri.toString(),\n )\n Object.assign(insertedPost, {\n violatesEmbeddingRules: violatesEmbeddingRules,\n })\n if (violatesEmbeddingRules) {\n await db\n .updateTable('post')\n .where('uri', '=', insertedPost.uri)\n .set({ violatesEmbeddingRules: violatesEmbeddingRules })\n .executeTakeFirst()\n }\n }\n } else if (app.bsky.embed.video.$matches(postEmbed)) {\n const { video } = postEmbed\n const videoEmbed = {\n postUri: uri.toString(),\n videoCid: getBlobCidString(video),\n // @NOTE: alt is required for image but not for video on the lexicon.\n alt: postEmbed.alt ?? null,\n }\n embeds.push(videoEmbed)\n\n await db.insertInto('post_embed_video').values(videoEmbed).execute()\n } else if (app.bsky.embed.gallery.$matches(postEmbed)) {\n // Gallery items are a union; today only `#image` exists, but we\n // defensively skip unknown variants for forward-compat.\n const galleryImages: PostEmbedGalleryImage[] = []\n postEmbed.items.forEach((item, i) => {\n if (app.bsky.embed.gallery.image.$matches(item)) {\n galleryImages.push({\n postUri: uri.toString(),\n position: i,\n imageCid: getBlobCidString(item.image),\n alt: item.alt,\n })\n }\n })\n if (galleryImages.length > 0) {\n embeds.push(galleryImages)\n await db\n .insertInto('post_embed_gallery_image')\n .values(galleryImages)\n .execute()\n }\n }\n }\n\n const threadgate = await getThreadgateRecord(db, post.replyRoot || post.uri)\n const ancestors = await getAncestorsAndSelfQb(db, {\n uri: post.uri,\n parentHeight: REPLY_NOTIF_DEPTH,\n })\n .selectFrom('ancestor')\n .selectAll()\n .execute()\n const descendents = await getDescendentsQb(db, {\n uri: post.uri,\n depth: REPLY_NOTIF_DEPTH,\n })\n .selectFrom('descendent')\n .innerJoin('post', 'post.uri', 'descendent.uri')\n .selectAll('descendent')\n .select(['cid', 'creator', 'sortAt'])\n .execute()\n return {\n post: insertedPost,\n facets,\n embeds,\n ancestors,\n descendents,\n threadgate,\n }\n}\n\nconst findDuplicate = async (): Promise<AtUri | null> => {\n return null\n}\n\nconst notifsForInsert = (obj: IndexedPost) => {\n const notifs: Notif[] = []\n const notified = new Set([obj.post.creator])\n const maybeNotify = (notif: Notif) => {\n if (!notified.has(notif.did)) {\n notified.add(notif.did)\n notifs.push(notif)\n }\n }\n for (const facet of obj.facets ?? []) {\n if (facet.type === 'mention') {\n maybeNotify({\n did: facet.value,\n reason: 'mention',\n author: obj.post.creator,\n recordUri: obj.post.uri,\n recordCid: obj.post.cid,\n sortAt: obj.post.sortAt,\n })\n }\n }\n\n if (!obj.post.violatesEmbeddingRules) {\n for (const embed of obj.embeds ?? []) {\n if ('embedUri' in embed) {\n const embedUri = new AtUri(embed.embedUri)\n if (embedUri.collection === app.bsky.feed.post.$type) {\n maybeNotify({\n did: embedUri.host,\n reason: 'quote',\n reasonSubject: embedUri.toString(),\n author: obj.post.creator,\n recordUri: obj.post.uri,\n recordCid: obj.post.cid,\n sortAt: obj.post.sortAt,\n })\n }\n }\n }\n }\n\n if (obj.post.violatesThreadGate) {\n // don't generate reply notifications when post violates threadgate\n return notifs\n }\n\n const threadgateHiddenReplies = obj.threadgate?.hiddenReplies || []\n\n // reply notifications\n\n for (const ancestor of obj.ancestors ?? []) {\n if (ancestor.uri === obj.post.uri) continue // no need to notify for own post\n if (ancestor.height < REPLY_NOTIF_DEPTH) {\n const ancestorUri = new AtUri(ancestor.uri)\n maybeNotify({\n did: ancestorUri.host,\n reason: 'reply',\n reasonSubject: ancestorUri.toString(),\n author: obj.post.creator,\n recordUri: obj.post.uri,\n recordCid: obj.post.cid,\n sortAt: obj.post.sortAt,\n })\n // found hidden reply, don't notify any higher ancestors\n if (threadgateHiddenReplies.includes(ancestorUri.toString())) break\n }\n }\n\n // descendents indicate out-of-order indexing: need to notify\n // the current post and upwards.\n for (const descendent of obj.descendents ?? []) {\n for (const ancestor of obj.ancestors ?? []) {\n const totalHeight = descendent.depth + ancestor.height\n if (totalHeight < REPLY_NOTIF_DEPTH) {\n const ancestorUri = new AtUri(ancestor.uri)\n maybeNotify({\n did: ancestorUri.host,\n reason: 'reply',\n reasonSubject: ancestorUri.toString(),\n author: descendent.creator,\n recordUri: descendent.uri,\n recordCid: descendent.cid,\n sortAt: descendent.sortAt,\n })\n }\n }\n }\n\n return notifs\n}\n\nconst deleteFn = async (\n db: DatabaseSchema,\n uri: AtUri,\n): Promise<IndexedPost | null> => {\n const uriStr = uri.toString()\n const [deleted] = await Promise.all([\n db\n .deleteFrom('post')\n .where('uri', '=', uriStr)\n .returningAll()\n .executeTakeFirst(),\n db.deleteFrom('feed_item').where('postUri', '=', uriStr).executeTakeFirst(),\n ])\n await db.deleteFrom('quote').where('subject', '=', uriStr).execute()\n const deletedEmbeds: (\n | PostEmbedImage[]\n | PostEmbedExternal\n | PostEmbedRecord\n | PostEmbedVideo\n | PostEmbedGalleryImage[]\n )[] = []\n const [\n deletedImgs,\n deletedExternals,\n deletedPosts,\n deletedVideo,\n deletedGalleryImgs,\n ] = await Promise.all([\n db\n .deleteFrom('post_embed_image')\n .where('postUri', '=', uriStr)\n .returningAll()\n .execute(),\n db\n .deleteFrom('post_embed_external')\n .where('postUri', '=', uriStr)\n .returningAll()\n .executeTakeFirst(),\n db\n .deleteFrom('post_embed_record')\n .where('postUri', '=', uriStr)\n .returningAll()\n .executeTakeFirst(),\n db\n .deleteFrom('post_embed_video')\n .where('postUri', '=', uriStr)\n .returningAll()\n .executeTakeFirst(),\n db\n .deleteFrom('post_embed_gallery_image')\n .where('postUri', '=', uriStr)\n .returningAll()\n .execute(),\n ])\n if (deletedImgs.length) {\n deletedEmbeds.push(deletedImgs)\n }\n if (deletedExternals) {\n deletedEmbeds.push(deletedExternals)\n }\n if (deletedVideo) {\n deletedEmbeds.push(deletedVideo)\n }\n if (deletedGalleryImgs.length) {\n deletedEmbeds.push(deletedGalleryImgs)\n }\n if (deletedPosts) {\n const embedUri = new AtUri(deletedPosts.embedUri)\n deletedEmbeds.push(deletedPosts)\n\n if (embedUri.collection === app.bsky.feed.post.$type) {\n await db.deleteFrom('quote').where('uri', '=', uriStr).execute()\n await db\n .insertInto('post_agg')\n .values({\n uri: deletedPosts.embedUri,\n quoteCount: db\n .selectFrom('quote')\n .where('quote.subjectCid', '=', deletedPosts.embedCid.toString())\n .select(countAll.as('count')),\n })\n .onConflict((oc) =>\n oc\n .column('uri')\n .doUpdateSet({ quoteCount: excluded(db, 'quoteCount') }),\n )\n .execute()\n }\n }\n return deleted\n ? {\n post: deleted,\n facets: [], // Not used\n embeds: deletedEmbeds,\n }\n : null\n}\n\nconst notifsForDelete = (\n deleted: IndexedPost,\n replacedBy: IndexedPost | null,\n) => {\n const notifs = replacedBy ? notifsForInsert(replacedBy) : []\n return {\n notifs,\n toDelete: [deleted.post.uri],\n }\n}\n\nconst updateAggregates = async (db: DatabaseSchema, postIdx: IndexedPost) => {\n const replyCountQb = postIdx.post.replyParent\n ? db\n .insertInto('post_agg')\n .values({\n uri: postIdx.post.replyParent,\n replyCount: db\n .selectFrom('post')\n .where('post.replyParent', '=', postIdx.post.replyParent)\n .where((qb) =>\n qb\n .where('post.violatesThreadGate', 'is', null)\n .orWhere('post.violatesThreadGate', '=', false),\n )\n .select(countAll.as('count')),\n })\n .onConflict((oc) =>\n oc\n .column('uri')\n .doUpdateSet({ replyCount: excluded(db, 'replyCount') }),\n )\n : null\n const postsCountQb = db\n .insertInto('profile_agg')\n .values({\n did: postIdx.post.creator,\n postsCount: db\n .selectFrom('post')\n .where('post.creator', '=', postIdx.post.creator)\n .select(countAll.as('count')),\n })\n .onConflict((oc) =>\n oc.column('did').doUpdateSet({ postsCount: excluded(db, 'postsCount') }),\n )\n await Promise.all([replyCountQb?.execute(), postsCountQb.execute()])\n}\n\nexport type PluginType = ReturnType<typeof makePlugin>\nexport const makePlugin = (db: Database, background: BackgroundQueue) => {\n return new RecordProcessor(db, background, {\n schema: app.bsky.feed.post.main,\n insertFn,\n findDuplicate,\n deleteFn,\n notifsForInsert,\n notifsForDelete,\n updateAggregates,\n })\n}\n\nexport default makePlugin\n\nfunction separateEmbeds(\n embed: app.bsky.feed.post.Main['embed'],\n): Array<\n | RecordWithMedia['media']\n | $Typed<RecordWithMedia['record']>\n | NonNullable<app.bsky.feed.post.Main['embed']>\n> {\n if (!embed) {\n return []\n }\n if (app.bsky.embed.recordWithMedia.$matches(embed)) {\n return [app.bsky.embed.record.$build(embed.record), embed.media]\n }\n return [embed]\n}\n\nasync function validateReply(\n db: DatabaseSchema,\n creator: string,\n reply: app.bsky.feed.post.ReplyRef,\n) {\n const replyRefs = await getReplyRefs(db, reply)\n // check reply\n const invalidReplyRoot =\n !replyRefs.parent || checkInvalidReplyRoot(reply, replyRefs.parent)\n // check interaction\n const violatesThreadGate = await checkViolatesThreadGate(\n db,\n creator,\n uriToDid(reply.root.uri),\n replyRefs.root?.record ?? null,\n replyRefs.gate?.record ?? null,\n )\n return {\n invalidReplyRoot,\n violatesThreadGate,\n }\n}\n\nasync function getThreadgateRecord(db: DatabaseSchema, postUri: string) {\n const threadgateRecordUri = postUriToThreadgateUri(postUri)\n const results = await db\n .selectFrom('record')\n .where('record.uri', '=', threadgateRecordUri)\n .selectAll()\n .execute()\n const threadgateRecord = results.find(\n (ref) => ref.uri === threadgateRecordUri,\n )\n if (threadgateRecord) {\n return lexParse<app.bsky.feed.threadgate.Main>(threadgateRecord.json)\n }\n}\n\nasync function validatePostEmbed(\n db: DatabaseSchema,\n embedUri: string,\n parentUri: string,\n) {\n const postgateRecordUri = postUriToPostgateUri(embedUri)\n const postgateRecord = await db\n .selectFrom('record')\n .where('record.uri', '=', postgateRecordUri)\n .selectAll()\n .executeTakeFirst()\n if (!postgateRecord) {\n return {\n violatesEmbeddingRules: false,\n }\n }\n const {\n embeddingRules: { canEmbed },\n } = parsePostgate({\n gate: lexParse<app.bsky.feed.postgate.Main>(postgateRecord.json),\n viewerDid: uriToDid(parentUri),\n authorDid: uriToDid(embedUri),\n })\n if (canEmbed) {\n return {\n violatesEmbeddingRules: false,\n }\n }\n return {\n violatesEmbeddingRules: true,\n }\n}\n\nasync function getReplyRefs(\n db: DatabaseSchema,\n reply: app.bsky.feed.post.ReplyRef,\n) {\n const replyRoot = reply.root.uri\n const replyParent = reply.parent.uri\n const replyGate = postUriToThreadgateUri(replyRoot)\n const results = await db\n .selectFrom('record')\n .where('record.uri', 'in', [replyRoot, replyGate, replyParent])\n .leftJoin('post', 'post.uri', 'record.uri')\n .selectAll('post')\n .select(['record.uri', 'json'])\n .execute()\n const root = results.find((ref) => ref.uri === replyRoot)\n const parent = results.find((ref) => ref.uri === replyParent)\n const gate = results.find((ref) => ref.uri === replyGate)\n return {\n root: root && {\n uri: root.uri,\n invalidReplyRoot: root.invalidReplyRoot,\n record: lexParse<app.bsky.feed.post.Main>(root.json),\n },\n parent: parent && {\n uri: parent.uri,\n invalidReplyRoot: parent.invalidReplyRoot,\n record: lexParse<app.bsky.feed.post.Main>(parent.json),\n },\n gate: gate && {\n uri: gate.uri,\n record: lexParse<app.bsky.feed.threadgate.Main>(gate.json),\n },\n }\n}\n"]}
1
+ {"version":3,"file":"post.js","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/post.ts"],"names":[],"mappings":"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","sourcesContent":["import { Insertable, Selectable, sql } from 'kysely'\nimport { $Typed, Cid, getBlobCidString, lexParse } from '@atproto/lex'\nimport { AtUri, normalizeDatetimeAlways } from '@atproto/syntax'\nimport { app } from '../../../../lexicons/index.js'\nimport {\n postUriToPostgateUri,\n postUriToThreadgateUri,\n uriToDid,\n} from '../../../../util/uris.js'\nimport { RecordWithMedia } from '../../../../views/types.js'\nimport { parsePostgate } from '../../../../views/util.js'\nimport { BackgroundQueue } from '../../background.js'\nimport { DatabaseSchema, DatabaseSchemaType } from '../../db/database-schema.js'\nimport { Database } from '../../db/index.js'\nimport { Notification } from '../../db/tables/notification.js'\nimport { countAll, excluded } from '../../db/util.js'\nimport {\n getAncestorsAndSelfQb,\n getDescendentsQb,\n invalidReplyRoot as checkInvalidReplyRoot,\n violatesThreadGate as checkViolatesThreadGate,\n} from '../../util.js'\nimport { RecordProcessor } from '../processor.js'\n\ntype Notif = Insertable<Notification>\ntype Post = Selectable<DatabaseSchemaType['post']>\ntype PostEmbedImage = DatabaseSchemaType['post_embed_image']\ntype PostEmbedExternal = DatabaseSchemaType['post_embed_external']\ntype PostEmbedRecord = DatabaseSchemaType['post_embed_record']\ntype PostEmbedVideo = DatabaseSchemaType['post_embed_video']\ntype PostEmbedGalleryImage = DatabaseSchemaType['post_embed_gallery_image']\ntype PostAncestor = {\n uri: string\n height: number\n}\ntype PostDescendent = {\n uri: string\n depth: number\n cid: string\n creator: string\n sortAt: string\n}\ntype IndexedPost = {\n post: Post\n facets?: { type: 'mention' | 'link'; value: string }[]\n embeds?: (\n | PostEmbedImage[]\n | PostEmbedExternal\n | PostEmbedRecord\n | PostEmbedVideo\n | PostEmbedGalleryImage[]\n )[]\n ancestors?: PostAncestor[]\n descendents?: PostDescendent[]\n threadgate?: app.bsky.feed.threadgate.Main\n}\n\nconst REPLY_NOTIF_DEPTH = 5\n\nconst insertFn = async (\n db: DatabaseSchema,\n uri: AtUri,\n cid: Cid,\n obj: app.bsky.feed.post.Main,\n timestamp: string,\n): Promise<IndexedPost | null> => {\n const post = {\n uri: uri.toString(),\n cid: cid.toString(),\n creator: uri.host,\n text: obj.text,\n createdAt: normalizeDatetimeAlways(obj.createdAt),\n replyRoot: obj.reply?.root?.uri || null,\n replyRootCid: obj.reply?.root?.cid || null,\n replyParent: obj.reply?.parent?.uri || null,\n replyParentCid: obj.reply?.parent?.cid || null,\n langs: obj.langs?.length\n ? sql<string[]>`${JSON.stringify(obj.langs)}` // sidesteps kysely's array serialization, which is non-jsonb\n : null,\n tags: obj.tags?.length\n ? sql<string[]>`${JSON.stringify(obj.tags)}` // sidesteps kysely's array serialization, which is non-jsonb\n : null,\n indexedAt: timestamp,\n }\n const [insertedPost] = await Promise.all([\n db\n .insertInto('post')\n .values(post)\n .onConflict((oc) => oc.doNothing())\n .returningAll()\n .executeTakeFirst(),\n db\n .insertInto('feed_item')\n .values({\n type: 'post',\n uri: post.uri,\n cid: post.cid,\n postUri: post.uri,\n originatorDid: post.creator,\n sortAt:\n post.indexedAt < post.createdAt ? post.indexedAt : post.createdAt,\n })\n .onConflict((oc) => oc.doNothing())\n .executeTakeFirst(),\n ])\n if (!insertedPost) {\n return null // Post already indexed\n }\n\n if (obj.reply) {\n const { invalidReplyRoot, violatesThreadGate } = await validateReply(\n db,\n uri.host,\n obj.reply,\n )\n if (invalidReplyRoot || violatesThreadGate) {\n Object.assign(insertedPost, { invalidReplyRoot, violatesThreadGate })\n await db\n .updateTable('post')\n .where('uri', '=', post.uri)\n .set({ invalidReplyRoot, violatesThreadGate })\n .executeTakeFirst()\n }\n }\n\n const facets = (obj.facets || [])\n .flatMap((facet) => facet.features)\n .flatMap((feature) => {\n if (app.bsky.richtext.facet.mention.$matches(feature)) {\n return {\n type: 'mention' as const,\n value: feature.did,\n }\n }\n if (app.bsky.richtext.facet.link.$matches(feature)) {\n return {\n type: 'link' as const,\n value: feature.uri,\n }\n }\n return []\n })\n // Embed indices\n const embeds: (\n | PostEmbedImage[]\n | PostEmbedExternal\n | PostEmbedRecord\n | PostEmbedVideo\n | PostEmbedGalleryImage[]\n )[] = []\n const postEmbeds = separateEmbeds(obj.embed)\n for (const postEmbed of postEmbeds) {\n if (app.bsky.embed.images.$matches(postEmbed)) {\n const { images } = postEmbed\n const imagesEmbed = images.map((img, i) => ({\n postUri: uri.toString(),\n position: i,\n imageCid: getBlobCidString(img.image),\n alt: img.alt,\n }))\n embeds.push(imagesEmbed)\n await db.insertInto('post_embed_image').values(imagesEmbed).execute()\n } else if (app.bsky.embed.external.$matches(postEmbed)) {\n const { external } = postEmbed\n const externalEmbed = {\n postUri: uri.toString(),\n uri: external.uri,\n title: external.title,\n description: external.description,\n thumbCid: getBlobCidString(external.thumb) || null,\n }\n embeds.push(externalEmbed)\n await db.insertInto('post_embed_external').values(externalEmbed).execute()\n } else if (app.bsky.embed.record.$matches(postEmbed)) {\n const { record } = postEmbed\n const embedUri = new AtUri(record.uri)\n const recordEmbed = {\n postUri: uri.toString(),\n embedUri: record.uri,\n embedCid: record.cid,\n }\n embeds.push(recordEmbed)\n await db.insertInto('post_embed_record').values(recordEmbed).execute()\n\n if (embedUri.collection === app.bsky.feed.post.$type) {\n const quote = {\n uri: uri.toString(),\n cid: cid.toString(),\n subject: record.uri,\n subjectCid: record.cid,\n createdAt: normalizeDatetimeAlways(obj.createdAt),\n indexedAt: timestamp,\n }\n await db\n .insertInto('quote')\n .values(quote)\n .onConflict((oc) => oc.doNothing())\n .returningAll()\n .executeTakeFirst()\n\n const quoteCountQb = db\n .insertInto('post_agg')\n .values({\n uri: record.uri.toString(),\n quoteCount: db\n .selectFrom('quote')\n .where('quote.subjectCid', '=', record.cid.toString())\n .select(countAll.as('count')),\n })\n .onConflict((oc) =>\n oc\n .column('uri')\n .doUpdateSet({ quoteCount: excluded(db, 'quoteCount') }),\n )\n await quoteCountQb.execute()\n\n const { violatesEmbeddingRules } = await validatePostEmbed(\n db,\n embedUri.toString(),\n uri.toString(),\n )\n Object.assign(insertedPost, {\n violatesEmbeddingRules: violatesEmbeddingRules,\n })\n if (violatesEmbeddingRules) {\n await db\n .updateTable('post')\n .where('uri', '=', insertedPost.uri)\n .set({ violatesEmbeddingRules: violatesEmbeddingRules })\n .executeTakeFirst()\n }\n }\n } else if (app.bsky.embed.video.$matches(postEmbed)) {\n const { video } = postEmbed\n const videoEmbed = {\n postUri: uri.toString(),\n videoCid: getBlobCidString(video),\n // @NOTE: alt is required for image but not for video on the lexicon.\n alt: postEmbed.alt ?? null,\n }\n embeds.push(videoEmbed)\n\n await db.insertInto('post_embed_video').values(videoEmbed).execute()\n } else if (app.bsky.embed.gallery.$matches(postEmbed)) {\n // Gallery items are a union; today only `#image` exists, but we\n // defensively skip unknown variants for forward-compat.\n const galleryImages: PostEmbedGalleryImage[] = []\n postEmbed.items.forEach((item, i) => {\n if (app.bsky.embed.gallery.image.$matches(item)) {\n galleryImages.push({\n postUri: uri.toString(),\n position: i,\n imageCid: getBlobCidString(item.image),\n alt: item.alt,\n })\n }\n })\n if (galleryImages.length > 0) {\n embeds.push(galleryImages)\n await db\n .insertInto('post_embed_gallery_image')\n .values(galleryImages)\n .execute()\n }\n }\n }\n\n const threadgate = await getThreadgateRecord(db, post.replyRoot || post.uri)\n const ancestors = await getAncestorsAndSelfQb(db, {\n uri: post.uri,\n parentHeight: REPLY_NOTIF_DEPTH,\n })\n .selectFrom('ancestor')\n .selectAll()\n .execute()\n const descendents = await getDescendentsQb(db, {\n uri: post.uri,\n depth: REPLY_NOTIF_DEPTH,\n })\n .selectFrom('descendent')\n .innerJoin('post', 'post.uri', 'descendent.uri')\n .selectAll('descendent')\n .select(['cid', 'creator', 'sortAt'])\n .execute()\n return {\n post: insertedPost,\n facets,\n embeds,\n ancestors,\n descendents,\n threadgate,\n }\n}\n\nconst findDuplicate = async (): Promise<AtUri | null> => {\n return null\n}\n\nconst notifsForInsert = (obj: IndexedPost) => {\n const notifs: Notif[] = []\n const notified = new Set([obj.post.creator])\n const maybeNotify = (notif: Notif) => {\n if (!notified.has(notif.did)) {\n notified.add(notif.did)\n notifs.push(notif)\n }\n }\n for (const facet of obj.facets ?? []) {\n if (facet.type === 'mention') {\n maybeNotify({\n did: facet.value,\n reason: 'mention',\n author: obj.post.creator,\n recordUri: obj.post.uri,\n recordCid: obj.post.cid,\n sortAt: obj.post.sortAt,\n })\n }\n }\n\n if (!obj.post.violatesEmbeddingRules) {\n for (const embed of obj.embeds ?? []) {\n if ('embedUri' in embed) {\n const embedUri = new AtUri(embed.embedUri)\n if (embedUri.collection === app.bsky.feed.post.$type) {\n maybeNotify({\n did: embedUri.host,\n reason: 'quote',\n reasonSubject: embedUri.toString(),\n author: obj.post.creator,\n recordUri: obj.post.uri,\n recordCid: obj.post.cid,\n sortAt: obj.post.sortAt,\n })\n }\n }\n }\n }\n\n if (obj.post.violatesThreadGate) {\n // don't generate reply notifications when post violates threadgate\n return notifs\n }\n\n const threadgateHiddenReplies = obj.threadgate?.hiddenReplies || []\n\n // reply notifications\n\n for (const ancestor of obj.ancestors ?? []) {\n if (ancestor.uri === obj.post.uri) continue // no need to notify for own post\n if (ancestor.height < REPLY_NOTIF_DEPTH) {\n const ancestorUri = new AtUri(ancestor.uri)\n maybeNotify({\n did: ancestorUri.host,\n reason: 'reply',\n reasonSubject: ancestorUri.toString(),\n author: obj.post.creator,\n recordUri: obj.post.uri,\n recordCid: obj.post.cid,\n sortAt: obj.post.sortAt,\n })\n // found hidden reply, don't notify any higher ancestors\n if (threadgateHiddenReplies.includes(ancestorUri.toString())) break\n }\n }\n\n // descendents indicate out-of-order indexing: need to notify\n // the current post and upwards.\n for (const descendent of obj.descendents ?? []) {\n for (const ancestor of obj.ancestors ?? []) {\n const totalHeight = descendent.depth + ancestor.height\n if (totalHeight < REPLY_NOTIF_DEPTH) {\n const ancestorUri = new AtUri(ancestor.uri)\n maybeNotify({\n did: ancestorUri.host,\n reason: 'reply',\n reasonSubject: ancestorUri.toString(),\n author: descendent.creator,\n recordUri: descendent.uri,\n recordCid: descendent.cid,\n sortAt: descendent.sortAt,\n })\n }\n }\n }\n\n return notifs\n}\n\nconst deleteFn = async (\n db: DatabaseSchema,\n uri: AtUri,\n): Promise<IndexedPost | null> => {\n const uriStr = uri.toString()\n const [deleted] = await Promise.all([\n db\n .deleteFrom('post')\n .where('uri', '=', uriStr)\n .returningAll()\n .executeTakeFirst(),\n db.deleteFrom('feed_item').where('postUri', '=', uriStr).executeTakeFirst(),\n ])\n await db.deleteFrom('quote').where('subject', '=', uriStr).execute()\n const deletedEmbeds: (\n | PostEmbedImage[]\n | PostEmbedExternal\n | PostEmbedRecord\n | PostEmbedVideo\n | PostEmbedGalleryImage[]\n )[] = []\n const [\n deletedImgs,\n deletedExternals,\n deletedPosts,\n deletedVideo,\n deletedGalleryImgs,\n ] = await Promise.all([\n db\n .deleteFrom('post_embed_image')\n .where('postUri', '=', uriStr)\n .returningAll()\n .execute(),\n db\n .deleteFrom('post_embed_external')\n .where('postUri', '=', uriStr)\n .returningAll()\n .executeTakeFirst(),\n db\n .deleteFrom('post_embed_record')\n .where('postUri', '=', uriStr)\n .returningAll()\n .executeTakeFirst(),\n db\n .deleteFrom('post_embed_video')\n .where('postUri', '=', uriStr)\n .returningAll()\n .executeTakeFirst(),\n db\n .deleteFrom('post_embed_gallery_image')\n .where('postUri', '=', uriStr)\n .returningAll()\n .execute(),\n ])\n if (deletedImgs.length) {\n deletedEmbeds.push(deletedImgs)\n }\n if (deletedExternals) {\n deletedEmbeds.push(deletedExternals)\n }\n if (deletedVideo) {\n deletedEmbeds.push(deletedVideo)\n }\n if (deletedGalleryImgs.length) {\n deletedEmbeds.push(deletedGalleryImgs)\n }\n if (deletedPosts) {\n const embedUri = new AtUri(deletedPosts.embedUri)\n deletedEmbeds.push(deletedPosts)\n\n if (embedUri.collection === app.bsky.feed.post.$type) {\n await db.deleteFrom('quote').where('uri', '=', uriStr).execute()\n await db\n .insertInto('post_agg')\n .values({\n uri: deletedPosts.embedUri,\n quoteCount: db\n .selectFrom('quote')\n .where('quote.subjectCid', '=', deletedPosts.embedCid.toString())\n .select(countAll.as('count')),\n })\n .onConflict((oc) =>\n oc\n .column('uri')\n .doUpdateSet({ quoteCount: excluded(db, 'quoteCount') }),\n )\n .execute()\n }\n }\n return deleted\n ? {\n post: deleted,\n facets: [], // Not used\n embeds: deletedEmbeds,\n }\n : null\n}\n\nconst notifsForDelete = (\n deleted: IndexedPost,\n replacedBy: IndexedPost | null,\n) => {\n const notifs = replacedBy ? notifsForInsert(replacedBy) : []\n return {\n notifs,\n toDelete: [deleted.post.uri],\n }\n}\n\nconst updateAggregates = async (db: DatabaseSchema, postIdx: IndexedPost) => {\n const replyCountQb = postIdx.post.replyParent\n ? db\n .insertInto('post_agg')\n .values({\n uri: postIdx.post.replyParent,\n replyCount: db\n .selectFrom('post')\n .where('post.replyParent', '=', postIdx.post.replyParent)\n .where((eb) =>\n eb.or([\n eb('post.violatesThreadGate', 'is', null),\n eb('post.violatesThreadGate', '=', false),\n ]),\n )\n .select(countAll.as('count')),\n })\n .onConflict((oc) =>\n oc\n .column('uri')\n .doUpdateSet({ replyCount: excluded(db, 'replyCount') }),\n )\n : null\n const postsCountQb = db\n .insertInto('profile_agg')\n .values({\n did: postIdx.post.creator,\n postsCount: db\n .selectFrom('post')\n .where('post.creator', '=', postIdx.post.creator)\n .select(countAll.as('count')),\n })\n .onConflict((oc) =>\n oc.column('did').doUpdateSet({ postsCount: excluded(db, 'postsCount') }),\n )\n await Promise.all([replyCountQb?.execute(), postsCountQb.execute()])\n}\n\nexport type PluginType = ReturnType<typeof makePlugin>\nexport const makePlugin = (db: Database, background: BackgroundQueue) => {\n return new RecordProcessor(db, background, {\n schema: app.bsky.feed.post.main,\n insertFn,\n findDuplicate,\n deleteFn,\n notifsForInsert,\n notifsForDelete,\n updateAggregates,\n })\n}\n\nexport default makePlugin\n\nfunction separateEmbeds(\n embed: app.bsky.feed.post.Main['embed'],\n): Array<\n | RecordWithMedia['media']\n | $Typed<RecordWithMedia['record']>\n | NonNullable<app.bsky.feed.post.Main['embed']>\n> {\n if (!embed) {\n return []\n }\n if (app.bsky.embed.recordWithMedia.$matches(embed)) {\n return [app.bsky.embed.record.$build(embed.record), embed.media]\n }\n return [embed]\n}\n\nasync function validateReply(\n db: DatabaseSchema,\n creator: string,\n reply: app.bsky.feed.post.ReplyRef,\n) {\n const replyRefs = await getReplyRefs(db, reply)\n // check reply\n const invalidReplyRoot =\n !replyRefs.parent || checkInvalidReplyRoot(reply, replyRefs.parent)\n // check interaction\n const violatesThreadGate = await checkViolatesThreadGate(\n db,\n creator,\n uriToDid(reply.root.uri),\n replyRefs.root?.record ?? null,\n replyRefs.gate?.record ?? null,\n )\n return {\n invalidReplyRoot,\n violatesThreadGate,\n }\n}\n\nasync function getThreadgateRecord(db: DatabaseSchema, postUri: string) {\n const threadgateRecordUri = postUriToThreadgateUri(postUri)\n const results = await db\n .selectFrom('record')\n .where('record.uri', '=', threadgateRecordUri)\n .selectAll()\n .execute()\n const threadgateRecord = results.find(\n (ref) => ref.uri === threadgateRecordUri,\n )\n if (threadgateRecord) {\n return lexParse<app.bsky.feed.threadgate.Main>(threadgateRecord.json)\n }\n}\n\nasync function validatePostEmbed(\n db: DatabaseSchema,\n embedUri: string,\n parentUri: string,\n) {\n const postgateRecordUri = postUriToPostgateUri(embedUri)\n const postgateRecord = await db\n .selectFrom('record')\n .where('record.uri', '=', postgateRecordUri)\n .selectAll()\n .executeTakeFirst()\n if (!postgateRecord) {\n return {\n violatesEmbeddingRules: false,\n }\n }\n const {\n embeddingRules: { canEmbed },\n } = parsePostgate({\n gate: lexParse<app.bsky.feed.postgate.Main>(postgateRecord.json),\n viewerDid: uriToDid(parentUri),\n authorDid: uriToDid(embedUri),\n })\n if (canEmbed) {\n return {\n violatesEmbeddingRules: false,\n }\n }\n return {\n violatesEmbeddingRules: true,\n }\n}\n\nasync function getReplyRefs(\n db: DatabaseSchema,\n reply: app.bsky.feed.post.ReplyRef,\n) {\n const replyRoot = reply.root.uri\n const replyParent = reply.parent.uri\n const replyGate = postUriToThreadgateUri(replyRoot)\n const results = await db\n .selectFrom('record')\n .where('record.uri', 'in', [replyRoot, replyGate, replyParent])\n .leftJoin('post', 'post.uri', 'record.uri')\n .selectAll('post')\n .select(['record.uri', 'json'])\n .execute()\n const root = results.find((ref) => ref.uri === replyRoot)\n const parent = results.find((ref) => ref.uri === replyParent)\n const gate = results.find((ref) => ref.uri === replyGate)\n return {\n root: root && {\n uri: root.uri,\n invalidReplyRoot: root.invalidReplyRoot,\n record: lexParse<app.bsky.feed.post.Main>(root.json),\n },\n parent: parent && {\n uri: parent.uri,\n invalidReplyRoot: parent.invalidReplyRoot,\n record: lexParse<app.bsky.feed.post.Main>(parent.json),\n },\n gate: gate && {\n uri: gate.uri,\n record: lexParse<app.bsky.feed.threadgate.Main>(gate.json),\n },\n }\n}\n"]}
@@ -1,11 +1,19 @@
1
- import { Selectable } from 'kysely';
2
1
  import { app } from '../../../../lexicons/index.js';
3
2
  import { BackgroundQueue } from '../../background.js';
4
- import { DatabaseSchemaType } from '../../db/database-schema.js';
5
3
  import { Database } from '../../db/index.js';
6
4
  import { RecordProcessor } from '../processor.js';
7
- type IndexedRepost = Selectable<DatabaseSchemaType['repost']>;
8
5
  export type PluginType = ReturnType<typeof makePlugin>;
9
- export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"tid", "app.bsky.feed.repost", import("@atproto/lex").Validator<Omit<app.bsky.feed.repost.Main, "$type">, Omit<app.bsky.feed.repost.Main, "$type">>>, IndexedRepost>;
6
+ export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"tid", "app.bsky.feed.repost", import("@atproto/lex").Validator<Omit<app.bsky.feed.repost.Main, "$type">, Omit<app.bsky.feed.repost.Main, "$type">>>, {
7
+ cid: string;
8
+ createdAt: string;
9
+ creator: string;
10
+ indexedAt: string;
11
+ sortAt: string;
12
+ subject: string;
13
+ subjectCid: string;
14
+ uri: string;
15
+ via: string | null;
16
+ viaCid: string | null;
17
+ }>;
10
18
  export default makePlugin;
11
19
  //# sourceMappingURL=repost.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"repost.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/repost.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,UAAU,EAAE,MAAM,QAAQ,CAAA;AAG/C,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAkB,kBAAkB,EAAE,MAAM,6BAA6B,CAAA;AAChF,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAG5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAGjD,KAAK,aAAa,GAAG,UAAU,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC,CAAA;AAmJ7D,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe,6NAUnE,CAAA;eAEc,UAAU"}
1
+ {"version":3,"file":"repost.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/repost.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAErD,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAG5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAsJjD,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe;;;;;;;;;;;EAUnE,CAAA;eAEc,UAAU"}
@@ -1,11 +1,16 @@
1
- import { Selectable } from 'kysely';
2
1
  import { app } from '../../../../lexicons/index.js';
3
2
  import { BackgroundQueue } from '../../background.js';
4
- import { DatabaseSchemaType } from '../../db/database-schema.js';
5
3
  import { Database } from '../../db/index.js';
6
4
  import { RecordProcessor } from '../processor.js';
7
- type IndexedStarterPack = Selectable<DatabaseSchemaType['starter_pack']>;
8
5
  export type PluginType = ReturnType<typeof makePlugin>;
9
- export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"tid", "app.bsky.graph.starterpack", import("@atproto/lex").Validator<Omit<app.bsky.graph.starterpack.Main, "$type">, Omit<app.bsky.graph.starterpack.Main, "$type">>>, IndexedStarterPack>;
6
+ export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"tid", "app.bsky.graph.starterpack", import("@atproto/lex").Validator<Omit<app.bsky.graph.starterpack.Main, "$type">, Omit<app.bsky.graph.starterpack.Main, "$type">>>, {
7
+ cid: string;
8
+ createdAt: string;
9
+ creator: string;
10
+ indexedAt: string;
11
+ name: string;
12
+ sortAt: string;
13
+ uri: string;
14
+ }>;
10
15
  export default makePlugin;
11
16
  //# sourceMappingURL=starter-pack.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"starter-pack.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/starter-pack.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAA;AAGnC,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAkB,kBAAkB,EAAE,MAAM,6BAA6B,CAAA;AAChF,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAEjD,KAAK,kBAAkB,GAAG,UAAU,CAAC,kBAAkB,CAAC,cAAc,CAAC,CAAC,CAAA;AAiDxE,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe,oPASnE,CAAA;eAEc,UAAU"}
1
+ {"version":3,"file":"starter-pack.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/starter-pack.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAErD,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAmDjD,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe;;;;;;;;EASnE,CAAA;eAEc,UAAU"}
@@ -1,11 +1,19 @@
1
- import { Selectable } from 'kysely';
2
1
  import { app } from '../../../../lexicons/index.js';
3
2
  import { BackgroundQueue } from '../../background.js';
4
- import { DatabaseSchemaType } from '../../db/database-schema.js';
5
3
  import { Database } from '../../db/index.js';
6
4
  import { RecordProcessor } from '../processor.js';
7
- type IndexedVerification = Selectable<DatabaseSchemaType['verification']>;
8
5
  export type PluginType = ReturnType<typeof makePlugin>;
9
- export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"tid", "app.bsky.graph.verification", import("@atproto/lex").Validator<Omit<app.bsky.graph.verification.Main, "$type">, Omit<app.bsky.graph.verification.Main, "$type">>>, IndexedVerification>;
6
+ export declare const makePlugin: (db: Database, background: BackgroundQueue) => RecordProcessor<import("@atproto/lex").RecordSchema<"tid", "app.bsky.graph.verification", import("@atproto/lex").Validator<Omit<app.bsky.graph.verification.Main, "$type">, Omit<app.bsky.graph.verification.Main, "$type">>>, {
7
+ cid: string;
8
+ createdAt: string;
9
+ creator: string;
10
+ displayName: string;
11
+ handle: string;
12
+ indexedAt: string;
13
+ rkey: string;
14
+ sortedAt: string;
15
+ subject: string;
16
+ uri: string;
17
+ }>;
10
18
  export default makePlugin;
11
19
  //# sourceMappingURL=verification.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"verification.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/verification.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAA;AAGnC,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAkB,kBAAkB,EAAE,MAAM,6BAA6B,CAAA;AAChF,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAEjD,KAAK,mBAAmB,GAAG,UAAU,CAAC,kBAAkB,CAAC,cAAc,CAAC,CAAC,CAAA;AAwFzE,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe,wPASnE,CAAA;eAEc,UAAU"}
1
+ {"version":3,"file":"verification.d.ts","sourceRoot":"","sources":["../../../../../src/data-plane/server/indexing/plugins/verification.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,GAAG,EAAE,MAAM,+BAA+B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAErD,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AA0FjD,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAA;AACtD,eAAO,MAAM,UAAU,OAAQ,QAAQ,cAAc,eAAe;;;;;;;;;;;EASnE,CAAA;eAEc,UAAU"}
@@ -4,12 +4,16 @@ export default (db) => ({
4
4
  const { actorDid, targetDid } = req;
5
5
  const res = await db.db
6
6
  .selectFrom('actor_block')
7
- .where((qb) => qb
8
- .where('actor_block.creator', '=', actorDid)
9
- .where('actor_block.subjectDid', '=', targetDid))
10
- .orWhere((qb) => qb
11
- .where('actor_block.creator', '=', targetDid)
12
- .where('actor_block.subjectDid', '=', actorDid))
7
+ .where((eb) => eb.or([
8
+ eb.and([
9
+ eb('actor_block.creator', '=', actorDid),
10
+ eb('actor_block.subjectDid', '=', targetDid),
11
+ ]),
12
+ eb.and([
13
+ eb('actor_block.creator', '=', targetDid),
14
+ eb('actor_block.subjectDid', '=', actorDid),
15
+ ]),
16
+ ]))
13
17
  .limit(1)
14
18
  .selectAll()
15
19
  .executeTakeFirst();
@@ -41,12 +45,16 @@ export default (db) => ({
41
45
  const res = await db.db
42
46
  .selectFrom('list_block')
43
47
  .innerJoin('list_item', 'list_item.listUri', 'list_block.subjectUri')
44
- .where((qb) => qb
45
- .where('list_block.creator', '=', actorDid)
46
- .where('list_item.subjectDid', '=', targetDid))
47
- .orWhere((qb) => qb
48
- .where('list_block.creator', '=', targetDid)
49
- .where('list_item.subjectDid', '=', actorDid))
48
+ .where((eb) => eb.or([
49
+ eb.and([
50
+ eb('list_block.creator', '=', actorDid),
51
+ eb('list_item.subjectDid', '=', targetDid),
52
+ ]),
53
+ eb.and([
54
+ eb('list_block.creator', '=', targetDid),
55
+ eb('list_item.subjectDid', '=', actorDid),
56
+ ]),
57
+ ]))
50
58
  .limit(1)
51
59
  .selectAll('list_block')
52
60
  .executeTakeFirst();
@@ -72,11 +80,11 @@ export default (db) => ({
72
80
  const { ref } = db.db.dynamic;
73
81
  let builder = db.db
74
82
  .selectFrom('list')
75
- .whereExists(db.db
83
+ .where(({ exists }) => exists(db.db
76
84
  .selectFrom('list_block')
77
85
  .where('list_block.creator', '=', actorDid)
78
86
  .whereRef('list_block.subjectUri', '=', ref('list.uri'))
79
- .selectAll())
87
+ .selectAll()))
80
88
  .selectAll('list');
81
89
  const keyset = new TimeCidKeyset(ref('list.createdAt'), ref('list.cid'));
82
90
  builder = paginate(builder, {