mirror of
				https://github.com/zadam/trilium.git
				synced 2025-10-26 17:18:53 +01:00 
			
		
		
		
	fix(llm): add the noteEmbedding object to all things becca to make it happy
This commit is contained in:
		
							parent
							
								
									d9249e3760
								
							
						
					
					
						commit
						f3a21cda98
					
				| @ -12,6 +12,7 @@ import type { AttachmentRow, BlobRow, RevisionRow } from "@triliumnext/commons"; | |||||||
| import BBlob from "./entities/bblob.js"; | import BBlob from "./entities/bblob.js"; | ||||||
| import BRecentNote from "./entities/brecent_note.js"; | import BRecentNote from "./entities/brecent_note.js"; | ||||||
| import type AbstractBeccaEntity from "./entities/abstract_becca_entity.js"; | import type AbstractBeccaEntity from "./entities/abstract_becca_entity.js"; | ||||||
|  | import type BNoteEmbedding from "./entities/bnote_embedding.js"; | ||||||
| 
 | 
 | ||||||
| interface AttachmentOpts { | interface AttachmentOpts { | ||||||
|     includeContentLength?: boolean; |     includeContentLength?: boolean; | ||||||
| @ -32,6 +33,7 @@ export default class Becca { | |||||||
|     attributeIndex!: Record<string, BAttribute[]>; |     attributeIndex!: Record<string, BAttribute[]>; | ||||||
|     options!: Record<string, BOption>; |     options!: Record<string, BOption>; | ||||||
|     etapiTokens!: Record<string, BEtapiToken>; |     etapiTokens!: Record<string, BEtapiToken>; | ||||||
|  |     noteEmbeddings!: Record<string, BNoteEmbedding>; | ||||||
| 
 | 
 | ||||||
|     allNoteSetCache: NoteSet | null; |     allNoteSetCache: NoteSet | null; | ||||||
| 
 | 
 | ||||||
| @ -48,6 +50,7 @@ export default class Becca { | |||||||
|         this.attributeIndex = {}; |         this.attributeIndex = {}; | ||||||
|         this.options = {}; |         this.options = {}; | ||||||
|         this.etapiTokens = {}; |         this.etapiTokens = {}; | ||||||
|  |         this.noteEmbeddings = {}; | ||||||
| 
 | 
 | ||||||
|         this.dirtyNoteSetCache(); |         this.dirtyNoteSetCache(); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -9,9 +9,10 @@ import BBranch from "./entities/bbranch.js"; | |||||||
| import BAttribute from "./entities/battribute.js"; | import BAttribute from "./entities/battribute.js"; | ||||||
| import BOption from "./entities/boption.js"; | import BOption from "./entities/boption.js"; | ||||||
| import BEtapiToken from "./entities/betapi_token.js"; | import BEtapiToken from "./entities/betapi_token.js"; | ||||||
|  | import BNoteEmbedding from "./entities/bnote_embedding.js"; | ||||||
| import cls from "../services/cls.js"; | import cls from "../services/cls.js"; | ||||||
| import entityConstructor from "../becca/entity_constructor.js"; | import entityConstructor from "../becca/entity_constructor.js"; | ||||||
| import type { AttributeRow, BranchRow, EtapiTokenRow, NoteRow, OptionRow } from "@triliumnext/commons"; | import type { AttributeRow, BranchRow, EtapiTokenRow, NoteRow, OptionRow, NoteEmbeddingRow } from "@triliumnext/commons"; | ||||||
| import type AbstractBeccaEntity from "./entities/abstract_becca_entity.js"; | import type AbstractBeccaEntity from "./entities/abstract_becca_entity.js"; | ||||||
| import ws from "../services/ws.js"; | import ws from "../services/ws.js"; | ||||||
| 
 | 
 | ||||||
| @ -63,6 +64,10 @@ function load() { | |||||||
|         for (const row of sql.getRows<EtapiTokenRow>(/*sql*/`SELECT etapiTokenId, name, tokenHash, utcDateCreated, utcDateModified FROM etapi_tokens WHERE isDeleted = 0`)) { |         for (const row of sql.getRows<EtapiTokenRow>(/*sql*/`SELECT etapiTokenId, name, tokenHash, utcDateCreated, utcDateModified FROM etapi_tokens WHERE isDeleted = 0`)) { | ||||||
|             new BEtapiToken(row); |             new BEtapiToken(row); | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|  |         for (const row of sql.getRows<NoteEmbeddingRow>(/*sql*/`SELECT embedId, noteId, providerId, modelId, dimension, embedding, version, dateCreated, dateModified, utcDateCreated, utcDateModified FROM note_embeddings`)) { | ||||||
|  |             new BNoteEmbedding(row).init(); | ||||||
|  |         } | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     for (const noteId in becca.notes) { |     for (const noteId in becca.notes) { | ||||||
| @ -85,7 +90,7 @@ eventService.subscribeBeccaLoader([eventService.ENTITY_CHANGE_SYNCED], ({ entity | |||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (["notes", "branches", "attributes", "etapi_tokens", "options"].includes(entityName)) { |     if (["notes", "branches", "attributes", "etapi_tokens", "options", "note_embeddings"].includes(entityName)) { | ||||||
|         const EntityClass = entityConstructor.getEntityFromEntityName(entityName); |         const EntityClass = entityConstructor.getEntityFromEntityName(entityName); | ||||||
|         const primaryKeyName = EntityClass.primaryKeyName; |         const primaryKeyName = EntityClass.primaryKeyName; | ||||||
| 
 | 
 | ||||||
| @ -143,6 +148,8 @@ eventService.subscribeBeccaLoader([eventService.ENTITY_DELETED, eventService.ENT | |||||||
|         attributeDeleted(entityId); |         attributeDeleted(entityId); | ||||||
|     } else if (entityName === "etapi_tokens") { |     } else if (entityName === "etapi_tokens") { | ||||||
|         etapiTokenDeleted(entityId); |         etapiTokenDeleted(entityId); | ||||||
|  |     } else if (entityName === "note_embeddings") { | ||||||
|  |         noteEmbeddingDeleted(entityId); | ||||||
|     } |     } | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| @ -278,6 +285,10 @@ function etapiTokenDeleted(etapiTokenId: string) { | |||||||
|     delete becca.etapiTokens[etapiTokenId]; |     delete becca.etapiTokens[etapiTokenId]; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | function noteEmbeddingDeleted(embedId: string) { | ||||||
|  |     delete becca.noteEmbeddings[embedId]; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| eventService.subscribeBeccaLoader(eventService.ENTER_PROTECTED_SESSION, () => { | eventService.subscribeBeccaLoader(eventService.ENTER_PROTECTED_SESSION, () => { | ||||||
|     try { |     try { | ||||||
|         becca.decryptProtectedNotes(); |         becca.decryptProtectedNotes(); | ||||||
|  | |||||||
| @ -32,6 +32,12 @@ class BNoteEmbedding extends AbstractBeccaEntity<BNoteEmbedding> { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     init() { | ||||||
|  |         if (this.embedId) { | ||||||
|  |             this.becca.noteEmbeddings[this.embedId] = this; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     updateFromRow(row: NoteEmbeddingRow): void { |     updateFromRow(row: NoteEmbeddingRow): void { | ||||||
|         this.embedId = row.embedId; |         this.embedId = row.embedId; | ||||||
|         this.noteId = row.noteId; |         this.noteId = row.noteId; | ||||||
| @ -44,6 +50,10 @@ class BNoteEmbedding extends AbstractBeccaEntity<BNoteEmbedding> { | |||||||
|         this.dateModified = row.dateModified; |         this.dateModified = row.dateModified; | ||||||
|         this.utcDateCreated = row.utcDateCreated; |         this.utcDateCreated = row.utcDateCreated; | ||||||
|         this.utcDateModified = row.utcDateModified; |         this.utcDateModified = row.utcDateModified; | ||||||
|  | 
 | ||||||
|  |         if (this.embedId) { | ||||||
|  |             this.becca.noteEmbeddings[this.embedId] = this; | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     override beforeSaving() { |     override beforeSaving() { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 perf3ct
						perf3ct