eggi-ai-db-schema-2 12.58.0 → 12.58.2

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.
@@ -51,6 +51,7 @@ export declare function getLlmSearchJobs(db: DatabaseOrTransaction | Pool | Pool
51
51
  /**
52
52
  * Gets detailed results for an LLM search job, formatted for the frontend
53
53
  * Now includes pipeline and introduction request status for each result
54
+ * Results are aggregated per person (not per intro path), with intro request count
54
55
  */
55
56
  export declare function getLlmSearchJobResultsDetailed(db: DatabaseOrTransaction | Pool | PoolClient, jobId: number, userId?: number): Promise<any[]>;
56
57
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"llm-search-job-operations.d.ts","sourceRoot":"","sources":["../../src/utils/llm-search-job-operations.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAEH,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,IAAI,CAAC;AAEtC,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAC;AAEvD,OAAO,EACL,KAAK,YAAY,EAGlB,MAAM,eAAe,CAAC;AAEvB;;GAEG;AACH,wBAAsB,kBAAkB,CACtC,EAAE,EAAE,qBAAqB,GAAG,IAAI,GAAG,UAAU,EAC7C,MAAM,EAAE;IACN,iBAAiB,EAAE,MAAM,CAAC;IAC1B,MAAM,EAAE,MAAM,CAAC;IACf,eAAe,EAAE,MAAM,EAAE,CAAC;IAC1B,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAChC,GACA,OAAO,CAAC;IAAE,YAAY,EAAE,YAAY,CAAA;CAAE,CAAC,CA0EzC;AAED;;GAEG;AACH,wBAAsB,kBAAkB,CACtC,EAAE,EAAE,qBAAqB,GAAG,IAAI,GAAG,UAAU,EAC7C,KAAK,EAAE,MAAM,EACb,OAAO,EAAE;IACP,MAAM,CAAC,EAAE,QAAQ,GAAG,YAAY,GAAG,WAAW,GAAG,QAAQ,CAAC;IAC1D,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC/B,QAAQ,CAAC,EAAE,IAAI,CAAC;IAChB,SAAS,CAAC,EAAE,IAAI,CAAC;IACjB,WAAW,CAAC,EAAE,IAAI,CAAC;CACpB,GACA,OAAO,CAAC,YAAY,CAAC,CA0DvB;AAED;;GAEG;AACH,wBAAsB,sBAAsB,CAC1C,EAAE,EAAE,qBAAqB,GAAG,IAAI,GAAG,UAAU,EAC7C,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,KAAK,CAAC;IACb,iBAAiB,EAAE,MAAM,CAAC;IAC1B,cAAc,EAAE,MAAM,CAAC;IACvB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAChC,CAAC,GACD,OAAO,CAAC,IAAI,CAAC,CA4Bf;AAED;;GAEG;AACH,wBAAsB,gBAAgB,CACpC,EAAE,EAAE,qBAAqB,GAAG,IAAI,GAAG,UAAU,EAC7C,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,YAAY,EAAE,CAAC,CAuBzB;AAED;;;GAGG;AACH,wBAAsB,8BAA8B,CAClD,EAAE,EAAE,qBAAqB,GAAG,IAAI,GAAG,UAAU,EAC7C,KAAK,EAAE,MAAM,EACb,MAAM,CAAC,EAAE,MAAM,GACd,OAAO,CAAC,GAAG,EAAE,CAAC,CAsIhB;AAED;;GAEG;AACH,wBAAsB,eAAe,CACnC,EAAE,EAAE,qBAAqB,GAAG,IAAI,GAAG,UAAU,EAC7C,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC,CA4B9B;AAED;;GAEG;AACH,wBAAsB,sBAAsB,CAC1C,EAAE,EAAE,qBAAqB,GAAG,IAAI,GAAG,UAAU,EAC7C,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC,IAAI,CAAC,CAaf;AAED;;GAEG;AACH,wBAAsB,0BAA0B,CAC9C,EAAE,EAAE,qBAAqB,GAAG,IAAI,GAAG,UAAU,EAC7C,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,IAAI,CAAC,CAef"}
1
+ {"version":3,"file":"llm-search-job-operations.d.ts","sourceRoot":"","sources":["../../src/utils/llm-search-job-operations.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAEH,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,IAAI,CAAC;AAEtC,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAC;AAEvD,OAAO,EACL,KAAK,YAAY,EAGlB,MAAM,eAAe,CAAC;AAEvB;;GAEG;AACH,wBAAsB,kBAAkB,CACtC,EAAE,EAAE,qBAAqB,GAAG,IAAI,GAAG,UAAU,EAC7C,MAAM,EAAE;IACN,iBAAiB,EAAE,MAAM,CAAC;IAC1B,MAAM,EAAE,MAAM,CAAC;IACf,eAAe,EAAE,MAAM,EAAE,CAAC;IAC1B,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAChC,GACA,OAAO,CAAC;IAAE,YAAY,EAAE,YAAY,CAAA;CAAE,CAAC,CA0EzC;AAED;;GAEG;AACH,wBAAsB,kBAAkB,CACtC,EAAE,EAAE,qBAAqB,GAAG,IAAI,GAAG,UAAU,EAC7C,KAAK,EAAE,MAAM,EACb,OAAO,EAAE;IACP,MAAM,CAAC,EAAE,QAAQ,GAAG,YAAY,GAAG,WAAW,GAAG,QAAQ,CAAC;IAC1D,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC/B,QAAQ,CAAC,EAAE,IAAI,CAAC;IAChB,SAAS,CAAC,EAAE,IAAI,CAAC;IACjB,WAAW,CAAC,EAAE,IAAI,CAAC;CACpB,GACA,OAAO,CAAC,YAAY,CAAC,CA0DvB;AAED;;GAEG;AACH,wBAAsB,sBAAsB,CAC1C,EAAE,EAAE,qBAAqB,GAAG,IAAI,GAAG,UAAU,EAC7C,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,KAAK,CAAC;IACb,iBAAiB,EAAE,MAAM,CAAC;IAC1B,cAAc,EAAE,MAAM,CAAC;IACvB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAChC,CAAC,GACD,OAAO,CAAC,IAAI,CAAC,CA4Bf;AAED;;GAEG;AACH,wBAAsB,gBAAgB,CACpC,EAAE,EAAE,qBAAqB,GAAG,IAAI,GAAG,UAAU,EAC7C,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,YAAY,EAAE,CAAC,CAuBzB;AAED;;;;GAIG;AACH,wBAAsB,8BAA8B,CAClD,EAAE,EAAE,qBAAqB,GAAG,IAAI,GAAG,UAAU,EAC7C,KAAK,EAAE,MAAM,EACb,MAAM,CAAC,EAAE,MAAM,GACd,OAAO,CAAC,GAAG,EAAE,CAAC,CA6IhB;AAED;;GAEG;AACH,wBAAsB,eAAe,CACnC,EAAE,EAAE,qBAAqB,GAAG,IAAI,GAAG,UAAU,EAC7C,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC,CA4B9B;AAED;;GAEG;AACH,wBAAsB,sBAAsB,CAC1C,EAAE,EAAE,qBAAqB,GAAG,IAAI,GAAG,UAAU,EAC7C,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC,IAAI,CAAC,CAaf;AAED;;GAEG;AACH,wBAAsB,0BAA0B,CAC9C,EAAE,EAAE,qBAAqB,GAAG,IAAI,GAAG,UAAU,EAC7C,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,IAAI,CAAC,CAef"}
@@ -197,13 +197,15 @@ async function getLlmSearchJobs(db, userId) {
197
197
  /**
198
198
  * Gets detailed results for an LLM search job, formatted for the frontend
199
199
  * Now includes pipeline and introduction request status for each result
200
+ * Results are aggregated per person (not per intro path), with intro request count
200
201
  */
201
202
  async function getLlmSearchJobResultsDetailed(db, jobId, userId) {
202
203
  // 1. Get job results and their associated LinkedIn account data
203
204
  // 2. For each result, find the relevant organization_user_relationships_assignments
204
205
  // within the organizations linked to this job
205
- // 3. Check if connection is in sales pipeline (for the requesting user's organization)
206
- // 4. Check if introduction request exists (for the requesting user)
206
+ // 3. Aggregate by person (linkedin_account_id) - one result per person
207
+ // 4. Check if connection is in sales pipeline (unique per person, not per intro path)
208
+ // 5. Count introduction requests (show count of how many intro requests were sent)
207
209
  const sql = `
208
210
  WITH job_orgs AS (
209
211
  SELECT organization_id
@@ -224,57 +226,39 @@ async function getLlmSearchJobResultsDetailed(db, jobId, userId) {
224
226
  r.metadata as result_metadata
225
227
  FROM monitoring.llm_search_job_results r
226
228
  WHERE r.llm_search_job_id = $1
227
- )
228
- SELECT
229
- jr.linkedin_account_id as "id",
230
- la.first_name || ' ' || la.last_name as "full_name",
231
- la.headline as "position",
232
- (SELECT company FROM linkedin.work_experience WHERE linkedin_account_id = la.id AND is_current = true LIMIT 1) as "company_name",
233
- la.profile_picture_url as "profile_image_url",
234
- 'https://www.linkedin.com/in/' || la.public_identifier as "linkedin_url",
235
- la.location,
236
- la.summary as "description",
237
- jr.relevance_score,
238
- jr.llm_recommendation,
239
- JSONB_AGG(
240
- DISTINCT JSONB_BUILD_OBJECT(
241
- 'member_user_id', la_contributor.user_id,
242
- 'member_name', la_contributor.first_name || ' ' || la_contributor.last_name,
243
- 'member_headline', la_contributor.headline,
244
- 'member_profile_picture_url', COALESCE(la_contributor.profile_image_cloudfront_url, la_contributor.profile_picture_url),
245
- 'member_linkedin_public_identifier', la_contributor.public_identifier,
246
- 'organization_id', o.id,
247
- 'organization_name', o.name,
248
- 'organization_user_relationship_assignment_id', oura.id,
249
- 'relationship_id', lr.id
250
- )
251
- ) as "members",
252
- (
253
- SELECT JSONB_AGG(DISTINCT JSONB_BUILD_OBJECT('id', org.id, 'name', org.name))
254
- FROM public.organization_user_relationships_assignments assignment
255
- JOIN public.organizations org ON org.id = assignment.organization_id
256
- WHERE assignment.linkedin_relationship_id IN (
257
- SELECT id FROM linkedin.relationships WHERE linkedin_account_id_a = la.id OR linkedin_account_id_b = la.id
258
- )
259
- AND assignment.organization_id IN (SELECT organization_id FROM job_orgs)
260
- ) as "organizations",
261
- -- Check if connection is in sales pipeline for any of the job organizations
262
- -- Check by organization_user_relationship_assignment_id (most accurate)
263
- -- Use MAX to aggregate across multiple members (should be same value for all)
264
- MAX(
265
- CASE
266
- WHEN EXISTS (
267
- SELECT 1
268
- FROM public.sales_pipeline_assignments spa
269
- INNER JOIN public.sales_pipelines sp ON sp.id = spa.sales_pipeline_id
270
- WHERE spa.organization_user_relationship_assignment_id = oura.id
271
- AND sp.organization_id IN (SELECT organization_id FROM job_orgs)
272
- ) THEN TRUE
273
- ELSE FALSE
274
- END
275
- ) as "is_in_pipeline",
276
- -- Get pipeline stage if in pipeline (use MAX to get one value per result)
277
- MAX(
229
+ ),
230
+ -- First, get all relationships and members for each result
231
+ relationships_with_members AS (
232
+ SELECT
233
+ jr.linkedin_account_id,
234
+ jr.relevance_score,
235
+ jr.llm_recommendation,
236
+ la.id as linkedin_account_id_full,
237
+ la.first_name,
238
+ la.last_name,
239
+ la.headline,
240
+ la.profile_picture_url,
241
+ la.public_identifier,
242
+ la.location,
243
+ la.summary,
244
+ lr.id as relationship_id,
245
+ oura.id as organization_user_relationship_assignment_id,
246
+ la_contributor.user_id as member_user_id,
247
+ la_contributor.first_name || ' ' || la_contributor.last_name as member_name,
248
+ la_contributor.headline as member_headline,
249
+ COALESCE(la_contributor.profile_image_cloudfront_url, la_contributor.profile_picture_url) as member_profile_picture_url,
250
+ la_contributor.public_identifier as member_linkedin_public_identifier,
251
+ o.id as organization_id,
252
+ o.name as organization_name,
253
+ -- Check if this specific relationship assignment is in pipeline
254
+ EXISTS (
255
+ SELECT 1
256
+ FROM public.sales_pipeline_assignments spa
257
+ INNER JOIN public.sales_pipelines sp ON sp.id = spa.sales_pipeline_id
258
+ WHERE spa.organization_user_relationship_assignment_id = oura.id
259
+ AND sp.organization_id IN (SELECT organization_id FROM job_orgs)
260
+ ) as is_this_path_in_pipeline,
261
+ -- Get pipeline stage for this specific relationship assignment
278
262
  (
279
263
  SELECT spa.stage
280
264
  FROM public.sales_pipeline_assignments spa
@@ -282,53 +266,77 @@ async function getLlmSearchJobResultsDetailed(db, jobId, userId) {
282
266
  WHERE spa.organization_user_relationship_assignment_id = oura.id
283
267
  AND sp.organization_id IN (SELECT organization_id FROM job_orgs)
284
268
  LIMIT 1
285
- )
286
- ) as "pipeline_stage",
287
- -- Check if introduction request exists for this relationship and user
288
- -- Use the job's initiated_by_user_id (or provided userId) to check
289
- MAX(
290
- CASE
291
- WHEN EXISTS (
292
- SELECT 1
293
- FROM public.introduction_requests ir
294
- WHERE ir.to_relationship_id = lr.id
295
- AND ir.by_user_id = COALESCE($2, (SELECT initiated_by_user_id FROM job_info))
296
- ) THEN TRUE
297
- ELSE FALSE
298
- END
299
- ) as "has_intro_request",
300
- -- Get introduction request ID if exists (use MAX to get one value per result)
301
- MAX(
302
- (
303
- SELECT ir.id
269
+ ) as this_path_pipeline_stage,
270
+ -- Check if intro request exists for this specific relationship
271
+ EXISTS (
272
+ SELECT 1
304
273
  FROM public.introduction_requests ir
305
274
  WHERE ir.to_relationship_id = lr.id
306
275
  AND ir.by_user_id = COALESCE($2, (SELECT initiated_by_user_id FROM job_info))
307
- LIMIT 1
276
+ ) as has_intro_request_for_this_path
277
+ FROM job_results jr
278
+ JOIN linkedin.accounts la ON jr.linkedin_account_id = la.id
279
+ JOIN linkedin.relationships lr ON (lr.linkedin_account_id_a = la.id OR lr.linkedin_account_id_b = la.id)
280
+ JOIN public.organization_user_relationships_assignments oura ON oura.linkedin_relationship_id = lr.id
281
+ JOIN job_orgs jo ON oura.organization_id = jo.organization_id
282
+ JOIN public.organizations o ON oura.organization_id = o.id
283
+ JOIN linkedin.accounts la_contributor ON la_contributor.id = (CASE WHEN lr.linkedin_account_id_a = la.id THEN lr.linkedin_account_id_b ELSE lr.linkedin_account_id_a END)
284
+ )
285
+ -- Now aggregate by person (linkedin_account_id)
286
+ SELECT
287
+ linkedin_account_id as "id",
288
+ first_name || ' ' || last_name as "full_name",
289
+ headline as "position",
290
+ (SELECT company FROM linkedin.work_experience WHERE linkedin_account_id = linkedin_account_id_full AND is_current = true LIMIT 1) as "company_name",
291
+ profile_picture_url as "profile_image_url",
292
+ 'https://www.linkedin.com/in/' || public_identifier as "linkedin_url",
293
+ location,
294
+ summary as "description",
295
+ MAX(relevance_score) as "relevance_score",
296
+ MAX(llm_recommendation) as "llm_recommendation",
297
+ -- Aggregate all members (intro paths)
298
+ JSONB_AGG(
299
+ DISTINCT JSONB_BUILD_OBJECT(
300
+ 'member_user_id', member_user_id,
301
+ 'member_name', member_name,
302
+ 'member_headline', member_headline,
303
+ 'member_profile_picture_url', member_profile_picture_url,
304
+ 'member_linkedin_public_identifier', member_linkedin_public_identifier,
305
+ 'organization_id', organization_id,
306
+ 'organization_name', organization_name,
307
+ 'organization_user_relationship_assignment_id', organization_user_relationship_assignment_id,
308
+ 'relationship_id', relationship_id
308
309
  )
309
- ) as "intro_request_id"
310
- FROM job_results jr
311
- JOIN linkedin.accounts la ON jr.linkedin_account_id = la.id
312
- JOIN linkedin.relationships lr ON (lr.linkedin_account_id_a = la.id OR lr.linkedin_account_id_b = la.id)
313
- JOIN public.organization_user_relationships_assignments oura ON oura.linkedin_relationship_id = lr.id
314
- JOIN job_orgs jo ON oura.organization_id = jo.organization_id
315
- JOIN public.organizations o ON oura.organization_id = o.id
316
- JOIN linkedin.accounts la_contributor ON la_contributor.id = (CASE WHEN lr.linkedin_account_id_a = la.id THEN lr.linkedin_account_id_b ELSE lr.linkedin_account_id_a END)
310
+ ) as "members",
311
+ -- Get organizations (deduplicated) - get from the aggregated members
312
+ (
313
+ SELECT JSONB_AGG(DISTINCT JSONB_BUILD_OBJECT('id', org_id, 'name', org_name))
314
+ FROM (
315
+ SELECT DISTINCT organization_id as org_id, organization_name as org_name
316
+ FROM relationships_with_members rwm2
317
+ WHERE rwm2.linkedin_account_id = relationships_with_members.linkedin_account_id
318
+ ) orgs
319
+ ) as "organizations",
320
+ -- Pipeline status: if ANY intro path has them in pipeline, they're in pipeline (unique per person)
321
+ BOOL_OR(is_this_path_in_pipeline) as "is_in_pipeline",
322
+ -- Pipeline stage: get the stage if in pipeline (any path)
323
+ MAX(this_path_pipeline_stage) FILTER (WHERE is_this_path_in_pipeline = true) as "pipeline_stage",
324
+ -- Intro request: if ANY intro path has a request, show as true
325
+ BOOL_OR(has_intro_request_for_this_path) as "has_intro_request",
326
+ -- Intro request count: count how many intro requests were sent (for display as "Ask for intro (2)")
327
+ COUNT(*) FILTER (WHERE has_intro_request_for_this_path = true)::integer as "intro_request_count"
328
+ FROM relationships_with_members
317
329
  GROUP BY
318
- jr.linkedin_account_id,
319
- la.id,
320
- la.first_name,
321
- la.last_name,
322
- la.headline,
323
- la.profile_picture_url,
324
- la.public_identifier,
325
- la.location,
326
- la.summary,
327
- jr.relevance_score,
328
- jr.llm_recommendation,
329
- oura.id,
330
- lr.id
331
- ORDER BY jr.relevance_score DESC
330
+ linkedin_account_id,
331
+ linkedin_account_id_full,
332
+ first_name,
333
+ last_name,
334
+ headline,
335
+ profile_picture_url,
336
+ public_identifier,
337
+ location,
338
+ summary
339
+ ORDER BY MAX(relevance_score) DESC
332
340
  `;
333
341
  return (0, pg_client_1.query)(db, sql, [jobId, userId]);
334
342
  }
@@ -1 +1 @@
1
- {"version":3,"file":"llm-search-job-operations.js","sourceRoot":"","sources":["../../src/utils/llm-search-job-operations.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"llm-search-job-operations.js","sourceRoot":"","sources":["../../src/utils/llm-search-job-operations.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "eggi-ai-db-schema-2",
3
- "version": "12.58.0",
3
+ "version": "12.58.2",
4
4
  "description": "Type-safe database schema with native PostgreSQL queries for Eggi.AI with direct RDS connection",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",