Skip to content

Commit

Permalink
feat: add driverInfo to mongodb component (#2779)
Browse files Browse the repository at this point in the history
* feat: add driverInfo to mongodb component

NODE-6240

* chore: add a getVersion utility function
  • Loading branch information
nbbeeken authored Jul 15, 2024
1 parent 363d1bf commit 9e88c45
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import { MongoDBAtlasVectorSearch } from '@langchain/mongodb'
import { Embeddings } from '@langchain/core/embeddings'
import { Document } from '@langchain/core/documents'
import { ICommonObject, INode, INodeData, INodeOutputsValue, INodeParams, IndexingResult } from '../../../src/Interface'
import { getBaseClasses, getCredentialData, getCredentialParam } from '../../../src/utils'
import { getBaseClasses, getCredentialData, getCredentialParam, getVersion } from '../../../src/utils'
import { addMMRInputParams, resolveVectorStoreOrRetriever } from '../VectorStoreUtils'

class MongoDBAtlas_VectorStores implements INode {
Expand Down Expand Up @@ -191,15 +191,17 @@ let mongoClientSingleton: MongoClient
let mongoUrl: string

const getMongoClient = async (newMongoUrl: string) => {
const driverInfo = { name: 'Flowise', version: (await getVersion()).version }

if (!mongoClientSingleton) {
// if client does not exist
mongoClientSingleton = new MongoClient(newMongoUrl)
mongoClientSingleton = new MongoClient(newMongoUrl, { driverInfo })
mongoUrl = newMongoUrl
return mongoClientSingleton
} else if (mongoClientSingleton && newMongoUrl !== mongoUrl) {
// if client exists but url changed
mongoClientSingleton.close()
mongoClientSingleton = new MongoClient(newMongoUrl)
mongoClientSingleton = new MongoClient(newMongoUrl, { driverInfo })
mongoUrl = newMongoUrl
return mongoClientSingleton
}
Expand Down
25 changes: 25 additions & 0 deletions packages/components/src/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -772,3 +772,28 @@ export const prepareSandboxVars = (variables: IVariable[]) => {
}
return vars
}

let version: string
export const getVersion: () => Promise<{ version: string }> = async () => {
if (version != null) return { version }

const checkPaths = [
path.join(__dirname, '..', 'package.json'),
path.join(__dirname, '..', '..', 'package.json'),
path.join(__dirname, '..', '..', '..', 'package.json'),
path.join(__dirname, '..', '..', '..', '..', 'package.json'),
path.join(__dirname, '..', '..', '..', '..', '..', 'package.json')
]
for (const checkPath of checkPaths) {
try {
const content = await fs.promises.readFile(checkPath, 'utf8')
const parsedContent = JSON.parse(content)
version = parsedContent.version
return { version }
} catch {
continue
}
}

throw new Error('None of the package.json paths could be parsed')
}

0 comments on commit 9e88c45

Please sign in to comment.